Pola wyboru pozwalają użytkownikowi na wybranie jednej lub kilku opcji z wielu dostępnych. Zwykle opcje pól wyboru są wyświetlane na liście pionowej.
Aby utworzyć każdą opcję pola wyboru, w układzie utwórz element CheckBox. Ponieważ zestaw opcji w polach wyboru umożliwia użytkownikowi wybranie wielu elementów, każde pole wyboru jest zarządzane oddzielnie i musisz zarejestrować detektor kliknięć dla każdego z nich.
Odpowiadanie na zdarzenia kliknięcia
Zacznij od utworzenia układu z obiektami CheckBox na liście:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <CheckBox android:id="@+id/checkbox_meat" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Meat" /> <CheckBox android:id="@+id/checkbox_cheese" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Cheese"/> </LinearLayout>
Gdy układ będzie gotowy, przejdź do widoków Activity lub Fragment, znajdź widoki CheckBox i ustaw odbiornik zmian, jak w tym przykładzie:
Kotlin
findViewById<CheckBox>(R.id.checkbox_meat) .setOnCheckedChangeListener { buttonView, isChecked -> Log.d("CHECKBOXES", "Meat is checked: $isChecked") } findViewById<CheckBox>(R.id.checkbox_cheese) .setOnCheckedChangeListener { buttonView, isChecked -> Log.d("CHECKBOXES", "Cheese is checked: $isChecked") }
Java
findViewById<CheckBox>(R.id.checkbox_meat) .setOnCheckedChangeListener { buttonView, isChecked -> Log.d("CHECKBOXES", "Meat is checked: $isChecked"); } findViewById<CheckBox>(R.id.checkbox_cheese) .setOnCheckedChangeListener { buttonView, isChecked -> Log.d("CHECKBOXES", "Cheese is checked: $isChecked"); }
Poprzedni kod wyświetla w Logcat komunikat za każdym razem, gdy zmieni się stan pól wyboru.