Android: odbiornik pól wyboru

110

Chcę umieścić Listenera na CheckBox. Szukałem info i wygląda to tak:

satView = (CheckBox)findViewById(R.id.sateliteCheckBox);

satView.setOnCheckedChangeListener(new OnCheckedChangeListener() {
    @Override
    public void onCheckedChanged(RadioGroup group, int checkedId) {
        if (isChecked){
            // perform logic
        }
    }

});

Problem polega na tym, że Eclipse myśli, że jest to OnCheckedChangeListenerdla a, RadioGroupi to nie działa. Jak mogę to naprawić?

Roman Rdgz
źródło

Odpowiedzi:

268

Możesz to zrobić:

satView.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {

       @Override
       public void onCheckedChanged(CompoundButton buttonView,boolean isChecked) {

       }
   }
);     
Chris
źródło
1
Dziękuję i oto jak to usunąć: stackoverflow.com/questions/18881817/…
Michał
OnCheckedChangeListeneri CompoundButton.OnCheckedChangeListenersą różne.
zionpi
dla kotlin satView.setOnCheckedChangeListener {buttonView, _ -> if (buttonView.isChecked) {// wykonaj akcję} else {// wykonaj akcję}}
Aminul Haque Aome
48

możesz też zdecydować się na proste View.OnClickListener:

satView.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {
        if(((CompoundButton) view).isChecked()){
            System.out.println("Checked");
        } else {
            System.out.println("Un-Checked");
        }
    }
});
Martin Zeitler
źródło
1
To naprawdę tylko jedno działające rozwiązanie, gdy chciałem odsłuchać akcję kliknięcia pola wyboru , a nie jego stan, jak inne rozwiązania tam polecane.
Acuna
19

Pojawia się błąd, ponieważ zaimportowałeś niewłaściwy pakiet import android.widget.CompoundButton.OnCheckedChangeListener;

Więc wywołanie zwrotne powinno wyglądać następująco:

        box.setOnCheckedChangeListener(new OnCheckedChangeListener() {

        @Override
        public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
            // TODO Auto-generated method stub

        }
    });
Huang
źródło
11

Spróbuj tego:

satView = (CheckBox) findViewById(R.id.sateliteCheckBox);

satView.setOnCheckedChangeListener(new OnCheckedChangeListener() {
    @Override 
    public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
          if (buttonView.isChecked()) { 
                // checked
          } 
          else 
          {
                // not checked
          }
    }

});

Mam nadzieję że to pomoże.

oriolpons
źródło
4

Spróbuj tego

satView.setOnCheckedChangeListener(new android.widget.CompoundButton.OnCheckedChangeListener.OnCheckedChangeListener() {
        @Override
        public void onCheckedChanged(RadioGroup group, int checkedId) {
            if (isChecked){
                // perform logic
            }
        }

    });
konfucjusz
źródło
4

Zmień za RadioGroup grouppomocą, CompoundButton buttonViewa następnie naciśnij Ctrl + Shift + O, aby naprawić import.

SERPRO
źródło
4

Możesz użyć tego kodu.

public class MySampleActivity extends Activity {
    CheckBox cb1, cb2, cb3, cb4;
    LinearLayout l1, l2, l3, l4;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        cb1 = (CheckBox) findViewById(R.id.cb1);
        cb2 = (CheckBox) findViewById(R.id.cb2);
        cb3 = (CheckBox) findViewById(R.id.cb3);
        cb4 = (CheckBox) findViewById(R.id.cb4);
        l1 = (LinearLayout) findViewById(R.id.l1);
        l2 = (LinearLayout) findViewById(R.id.l2);
        l3 = (LinearLayout) findViewById(R.id.l3);
        l4 = (LinearLayout) findViewById(R.id.l4);
    }

    @Override
    protected void onPostCreate(Bundle savedInstanceState) {
        super.onPostCreate(savedInstanceState);
        cb1.setOnCheckedChangeListener(new MyCheckedChangeListener(1));
        cb1.setOnCheckedChangeListener(new MyCheckedChangeListener(2));
        cb1.setOnCheckedChangeListener(new MyCheckedChangeListener(3));
        cb1.setOnCheckedChangeListener(new MyCheckedChangeListener(4));
    }

    public class MyCheckedChangeListener implements CompoundButton.OnCheckedChangeListener {
        int position;

        public MyCheckedChangeListener(int position) {
            this.position = position;
        }

        private void changeVisibility(LinearLayout layout, boolean isChecked) {
            if (isChecked) {
                l1.setVisibility(View.VISIBLE);
            } else {
                l1.setVisibility(View.GONE);
            }

        }

        @Override
        public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
            switch (position) {
                case 1:
                    changeVisibility(l1, isChecked);
                    break;
                case 2:
                    changeVisibility(l2, isChecked);
                    break;
                case 3:
                    changeVisibility(l3, isChecked);
                    break;
                case 4:
                    changeVisibility(l4, isChecked);
                    break;
            }
        }
    }
}
Arun Shankar
źródło
Dlaczego przekazujesz „LinearLayout” do swojej metody „changeVisibility (układ LinearLayout, boolean isChecked)”, a za każdym razem zmieniasz widoczność tylko jednego układu?
Bradley Wilson
4

Tłumaczenie zaakceptowanej odpowiedzi Chrisa na Kotlin:

val checkBox: CheckBox = findViewById(R.id.chk)
checkBox.setOnCheckedChangeListener { buttonView, isChecked ->
    // Code here 
}
Elletlar
źródło
1
Uwaga: jeśli buttonView nie jest używany: „{_, isChecked ->”
Elletlar
2
h.chk.setOnClickListener(new View.OnClickListener()
{
    @Override
    public void onClick(View view)
    {
        CheckBox chk=(CheckBox)view; // important line and code work
        if(chk.isChecked())
        {
            Message.message(a,"Clicked at"+position);
        }
        else
        {
            Message.message(a,"UnClick");
        }
    }
});
Swapnil
źródło
1
Witamy w Stack Overflow! Możesz ulepszyć tę odpowiedź, edytując ją, aby wyjaśnić, jak to działa.
user8397947
1

Jeśli chcesz to zrobić w Kotlinie z implementacją interfejsu.

class MainActivity: AppCompatActivity(),CompoundButton.OnCheckedChangeListener{

 override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

      val yourCheckBox = findViewById<CheckBox>(R.id.check_box)
      yourCheckBox.setOnCheckedChangeListener(this)

    }

 override fun onCheckedChanged(buttonView: CompoundButton?, isChecked: Boolean) {
        when(buttonView?.id){
            R.id.check_box -> Log.d("Checked: ","$isChecked")
        }
    }

}
Gastón Saillén
źródło