OnClickListener не работает должным образом

У меня есть onclicklistener на линии:

mAssistUpdateButton = (Button) findViewById(R.id.assist_instr_btn);
        mAssistUpdateButton.setOnClickListener(this);

который должен позвонить:

public void onClick(View v) {
    if (v == mAssistUpdateButton) {

но это, кажется, не достигает этой точки в коде. Я просмотрел это несколько раз и не могу понять, что я сделал неправильно.

Любой вклад с благодарностью.

ИСТОЧНИК:

import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import javax.xml.parsers.ParserConfigurationException;

import org.xml.sax.SAXException;

import android.annotation.SuppressLint;
import android.annotation.TargetApi;
import android.app.Activity;
import android.app.AlertDialog;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.ContentResolver;
import android.content.ContentValues;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.net.Uri;
import android.os.Build;
import android.os.Build.VERSION_CODES;
import android.os.Bundle;
import android.provider.Settings;
import android.telephony.TelephonyManager;
import android.text.Html;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;

public class ConfigFinalActivity extends Activity implements OnClickListener {
    private static final String TAG = "ConfigActivity";
    TelephonyManager tm;
    AlertDialog mErrorAlert = null;
    private Notification mNotification = null;
    private Button mXButton = null;
    private Button mAssistUpdateButton = null;
    private Button mAssistInstrButton = null;
    private Button mReadAgainButton = null;
    private int mInstructionNumber = 0;
    public static ArrayList<String> NameArr = new ArrayList<String>();
    public static ArrayList<String> ValueArr = new ArrayList<String>();
    public static ArrayList<String> nameArr = new ArrayList<String>();
    public static ArrayList<String> ApnArr = new ArrayList<String>();
    public static ArrayList<String> mmscArr = new ArrayList<String>();
    public static ArrayList<String> mmsportArr = new ArrayList<String>();
    public static ArrayList<String> mmsproxyArr = new ArrayList<String>();
    public static ArrayList<String> portArr = new ArrayList<String>();
    public static ArrayList<String> proxyArr = new ArrayList<String>();
    public static int count;
    public static int TotalSteps = 8;
    int i, g = 0, result = 0;
    String Result = "";
    public static ContentValues Values = new ContentValues();
    XmlParserHandlerFinal handler;

    public static final Uri APN_TABLE_URI = Uri
            .parse("content://telephony/carriers");
    public static String Base_URL = "https://www.mysettings.com/";
    public static InputStream stream = null;
    UpdateActivity update;
    public static String status;

    /** Called when the activity is first created. */
    @SuppressLint("NewApi")
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        int version = android.os.Build.VERSION.SDK_INT;
        tm = (TelephonyManager) getSystemService(TELEPHONY_SERVICE);
        update = new UpdateActivity();
        nameArr = update.getnameArr();
        ApnArr = update.getApnArr();
        mmscArr = update.getMMSCArr();
        mmsproxyArr = update.getMmscProxyArr();
        mmsportArr = update.getMmsPortArr();
        proxyArr = update.getMmscProxyArr();
        portArr = update.getMmsPortArr();
        count = update.getCount();
        if (ApnArr.isEmpty() || mmscArr.isEmpty() || mmsportArr.isEmpty()
                || mmsproxyArr.isEmpty() || proxyArr.isEmpty()
                || portArr.isEmpty()) {
            tryagain();
        } else if (version < VERSION_CODES.ICE_CREAM_SANDWICH) {

            // Update APN table
            try {
                result = updateTable();
            } catch (IOException e1) {
                // TODO Auto-generated catch block
                e1.printStackTrace();
            }// Settings updated with this atomic call
            catch (SAXException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            } catch (ParserConfigurationException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }

            if (result != -1) {
                status = "success";

            } else {
                status = "failure";
            }

            if (status.equals("success")) {
                completeUpdate();
            } else if (status.equals("failure")) {
                tryagain();
                // showAlert(getString(R.string.unchanged_net10_dialog));
            }

        } else {// ICS and later versions

            // Reduce number of steps to 6
            TotalSteps = 6;
            setContentView(R.layout.assist_instructions);
    //      String assistUpdate = getString(R.string.instructions_1);
    //      CharSequence styledText = Html.fromHtml(assistUpdate);
            TextView assistText = (TextView) findViewById(R.id.apn_app_text_cta2);
    //      assistText.setText(styledText);
            mAssistUpdateButton = (Button) findViewById(R.id.assist_instr_btn);
            mAssistUpdateButton.setOnClickListener(this);

        }
    }

    public void onClick(View v) {
        if (v == mAssistUpdateButton) {

            // Update button for ICS and up is selected
            // Get the TextView in the Assist Update UI

            TextView tv = (TextView) findViewById(R.id.apn_app_text_cta2);
            String text = "";
            CharSequence styledText = text;
            switch (mInstructionNumber) {

            case 0:

                // Retrieve the instruction string resource corresponding the
                // 2nd set of instructions
        //      text = String.format(getString(R.string.instructions_3),
    //                  TotalSteps);
//      styledText = Html.fromHtml(text);
                // Update the TextView with the correct set of instructions
                //tv.setText(styledText);
                // Increment instruction number so the correct instructions
                // string resource can be retrieve the next time the update
                // button is pressed
                mInstructionNumber++;
                break;

            case 1:
                // First set of instructions for step by step process to update
                // the APN Settings to the corresponding layout
                //setContentView(R.layout.screen5);
////                String one_text = String.format(getString(R.string.one),
////                        TotalSteps);
////                CharSequence styledText_one = Html.fromHtml(one_text);
//              TextView one = (TextView) findViewById(R.id.text_one);
//              one.setTextSize(18);
//              one.setText(styledText_one);
//              String two_text = String.format(getString(R.string.two),
//                      TotalSteps);
//              CharSequence styledText_two = Html.fromHtml(two_text);
//              TextView two = (TextView) findViewById(R.id.text_two);
//              two.setTextSize(18);
//              two.setText(styledText_two);
//              String three_text = String.format(getString(R.string.three),
//                      TotalSteps);
//              CharSequence styledText_three = Html.fromHtml(three_text);
//              TextView three = (TextView) findViewById(R.id.text_three);
        //      three.setTextSize(18);
            //  three.setText(styledText_three);
                mAssistUpdateButton = (Button) findViewById(R.id.assist_instr_btn);
                mAssistUpdateButton.setOnClickListener(this);
                mInstructionNumber++;
                break;

            case 2:
                // second set of instructions for step by step process to update
                // the APN Settings to the corresponding layout
            //  setContentView(R.layout.screen6);
            //  String four_text = String.format(getString(R.string.four),
        //              TotalSteps);
        //      styledText = Html.fromHtml(four_text);
        //      TextView four = (TextView) findViewById(R.id.text_four);
        //      four.setTextSize(18);
        //      four.setText(styledText);
        //      String five_text = String.format(getString(R.string.five),
            //          TotalSteps);
            //  styledText = Html.fromHtml(five_text);
            //  TextView five = (TextView) findViewById(R.id.text_five);
            //  five.setTextSize(18);
            //  five.setText(styledText);
        //      String six_text = String.format(getString(R.string.six),
//                      TotalSteps);
//              styledText = Html.fromHtml(six_text);
//              TextView six = (TextView) findViewById(R.id.text_six);
//              six.setTextSize(18);
//              six.setText(styledText);
//          //  String seven_text = String.format(getString(R.string.seven),
                //      TotalSteps);
            //  styledText = Html.fromHtml(seven_text);
            //  TextView seven = (TextView) findViewById(R.id.text_seven);
        //      seven.setTextSize(18);
        //      seven.setText(styledText);
            //  String eight_text = String.format(getString(R.string.eight),
                //      TotalSteps);
            //  styledText = Html.fromHtml(eight_text);
            //  TextView eight = (TextView) findViewById(R.id.text_eight);
        //      eight.setTextSize(18);
        //      eight.setText(styledText);

                // just for testing
                Result = "success";
                mAssistUpdateButton = (Button) findViewById(R.id.assist_instr_btn);
                if (Result.equalsIgnoreCase("success")) {
                    mAssistUpdateButton.setOnClickListener(this);
                } else if (Result.equalsIgnoreCase("failure")) {
                    // // Displaying final layout after failure of Post-ICS
                    // settings
                    // read the result in the response ..if success go ahead
                    // else load the tryagain screen

        //          setContentView(R.layout.tryagain);
        //          setContentView(R.layout.tryagain);
                    String tryAgainText = "";
                    CharSequence styledTryAgainText;

//                  tryAgainText = String.format(
//                          getString(R.string.tryagain_text1), TotalSteps);
//                  styledTryAgainText = Html.fromHtml(tryAgainText);
//                  TextView tryAgain1 = (TextView) findViewById(R.id.tryagain_text1);
//                  tryAgain1.setText(styledTryAgainText);

//                  tryAgainText = String.format(
//                          getString(R.string.tryagain_text2), TotalSteps);
//                  styledTryAgainText = Html.fromHtml(tryAgainText);
//                  TextView tryAgain2 = (TextView) findViewById(R.id.tryagain_text2);
//                  tryAgain2.setText(styledTryAgainText);
//
//                  tryAgainText = String.format(
//                          getString(R.string.tryagain_text3), TotalSteps);
//                  styledTryAgainText = Html.fromHtml(tryAgainText);
//                  TextView tryAgain3 = (TextView) findViewById(R.id.tryagain_text3);
//                  tryAgain3.setText(styledTryAgainText);

                }

                mInstructionNumber++;
                break;
            case 3:
                // final set of instructions

            //  setContentView(R.layout.assist_instructions_update);
            //  String last_instr_text = String.format(
        //              getString(R.string.instructions_5), TotalSteps);
            //  styledText = Html.fromHtml(last_instr_text);
            //  TextView last_text = (TextView) findViewById(R.id.apn_app_text_cta3);
            //  last_text.setText(styledText);

//      //      String last_instr_text1 = String.format(
//                      getString(R.string.thatsit), TotalSteps);
//              styledText = Html.fromHtml(last_instr_text1);
//              TextView last_text1 = (TextView) findViewById(R.id.thatsIt);
//              last_text1.setText(styledText);

                String mreadAgaintext = String
                        .format(getString(R.string.read_again_text));
                styledText = Html.fromHtml(mreadAgaintext);

                mAssistInstrButton = (Button) findViewById(R.id.assist_instr_btn);
            //ReadAgainButton = (Button) findViewById(R.id.read_again_btn);

            //ReadAgainButton.setText(styledText);
                mAssistInstrButton.setOnClickListener(this);
        //mReadAgainButton.setOnClickListener(this);
            }
        } else if (v == mAssistInstrButton) {
            // "LET'S DO THIS" Button in final instructions screen for ICS and
            // up is selected
            Values = getValues();
            startActivity(new Intent(Settings.ACTION_APN_SETTINGS));
            try {
                showNotification();
            } catch (SAXException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            } catch (ParserConfigurationException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            finish();

3 ответа

Решение

Вы не можете сравнивать объекты вида таким образом. Обычно вы сравниваете идентификатор кнопки так:

public void onClick(View v) {
    switch(v.getId()) {
    case R.id.assist_instr_btn:
    case R.id.button2:
    }
}

редактировать: я также предлагаю вам прочитать в тестирование равенства объектов в Java. С помощью == хорошо для примитивов, но обычно не для объектов.

Вы использовали правильный импорт? Так должно быть

import android.view.View.OnclickListener

Как сказал Тревор-е, предпочтительнее сравнивать идентификаторы

public void onClick(View v) {    
    switch(v.getId()) {   
      case R.id.btn_1:   
      ...    
      break;   
    case R.id.btn_2:   
      ...   
      break;   
    }   
}

если вы хотите сравнить объекты (представления в вашем случае, вы должны использовать ".equals". Ваш метод будет выглядеть так:

public void onClick(View v) {    
    if(v.equals(mAssistsUpdateButton )) {   
      //your code
    }else if (v.equals(mButton2 )) {   
      //your code
    }
}

вышеупомянутое правильно, но я думаю, что сравнение идентификаторов быстрее

Надеюсь, что это помогает Ура

Другие вопросы по тегам