Android: écouteur de case à cocher

110

Je veux mettre un auditeur sur un CheckBox. J'ai cherché des informations et c'est comme ça:

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

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

});

Le problème est qu'Eclipse pense que c'est un OnCheckedChangeListenerpour un RadioGroupet que cela ne fonctionne pas. Comment puis-je réparer cela?

Roman Rdgz
la source

Réponses:

268

Tu peux le faire:

satView.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {

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

       }
   }
);     
Chris
la source
1
Merci et voici comment le supprimer: stackoverflow.com/questions/18881817/…
Michal
OnCheckedChangeListeneret CompoundButton.OnCheckedChangeListenersont différents.
zionpi
pour kotlin satView.setOnCheckedChangeListener {buttonView, _ -> if (buttonView.isChecked) {// exécuter une action} else {// exécuter une action}}
Aminul Haque Aome
48

vous pouvez également opter pour un simple 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
la source
1
Ce n'est vraiment qu'une seule solution de travail lorsque je voulais écouter une action de clic de case à cocher , pas son état comme d'autres solutions le recommandent.
Acuna
19

Vous obtenez l'erreur parce que vous avez importé le mauvais package. import android.widget.CompoundButton.OnCheckedChangeListener;

Le rappel devrait donc être:

        box.setOnCheckedChangeListener(new OnCheckedChangeListener() {

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

        }
    });
Huang
la source
11

Essaye ça:

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
          }
    }

});

J'espère que cela t'aides.

oriolpons
la source
4

essaye ça

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

    });
confucius
la source
4

Changez RadioGroup groupavec CompoundButton buttonView, puis appuyez sur Ctrl + Maj + O pour corriger vos importations.

SERPRO
la source
4

Vous pouvez utiliser ce code.

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
la source
Pourquoi passez-vous un 'LinearLayout' à votre méthode 'changeVisibility (LinearLayout layout, boolean isChecked)' alors que vous ne changez que la visibilité d'une disposition à chaque fois?
Bradley Wilson
4

Traduction de la réponse acceptée par Chris en Kotlin:

val checkBox: CheckBox = findViewById(R.id.chk)
checkBox.setOnCheckedChangeListener { buttonView, isChecked ->
    // Code here 
}
Elletlar
la source
1
Remarque: Si le buttonView n'est pas utilisé: "{_, 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
la source
1
Bienvenue dans Stack Overflow! Vous pouvez améliorer cette réponse en la modifiant pour expliquer comment cela fonctionne.
user8397947
1

Si vous cherchez à faire cela dans Kotlin avec l'implémentation de l'interface.

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
la source