多项选择按钮(CheckBox)属于输入型组件,该组件允许用户一次选择多个选项。当用户不方便在手机屏幕上直接进行输入操作时,该组件的使用显得尤为方便。
下面通过实例讲解 CheckBox 的使用方法。该实例的运行效果如图 1 所示。
图 1 CheckBox 的应用界面
工程 WidgetDemo 中的布局文件 main.xml 中增加的代码如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingRight="10dp"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:orientation="vertical"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:context=".MainActivity">
<TextView android:text="爱好:"
android:textSize="24sp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/tv" />
<RelativeLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<CheckBox
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="音乐"
android:id="@+id/chb_music"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_marginTop="10dp"
android:checked="false" />
<CheckBox
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="游戏"
android:id="@+id/chb_game"
android:layout_below="@+id/chb_music"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true" />
<CheckBox
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="旅游"
android:id="@+id/chb_trip"
android:layout_alignTop="@+id/chb_music"
android:layout_alignRight="@+id/chb_film"
android:layout_alignLeft="@+id/chb_film" />
<CheckBox
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="看电影"
android:id="@+id/chb_film"
android:layout_below="@+id/chb_trip"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true" />
</RelativeLayout>
<Button
android:id="@+id/end"
android:text="完成"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:paddingTop="10dp"
android:id="@+id/result_tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
</LinearLayout>
当用户对多项选择按钮进行选择时,为了确定用户选择的是哪几项,需要对每个多项选择按钮进行监听。
CompoundButton.OnCheckedChangedListener 接口可用于对 CheckBox 的状态进行监听。当 CheckBox 的状态在未被选中和被选中之间变化时,该接口的 onCheckedChanged() 方法会被系统调用。CheckBox 通过 setOnCheckedChangeListener() 方法将该接口对象设置为自己的监听器。
MainActivity 代码如下:
package introduction.android.widgetdemo; import android.os.Bundle; import android.support.design.widget.FloatingActionButton; import android.support.design.widget.Snackbar; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.Toolbar; import android.view.View; import android.view.Menu; import android.view.MenuItem; import android.widget.Button; import android.widget.CheckBox; import android.widget.CompoundButton; import android.widget.TextView; import java.util.ArrayList; public class MainActivity extends AppCompatActivity implements CompoundButton.OnCheckedChangeListener { private CheckBox musicCkb; private CheckBox tripCkb; private CheckBox filmCkb; private CheckBox gameCkb; private TextView result_tv; private Button endBtn; //爱好数组 ArrayList<String> hobbies=new ArrayList<String>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //初始化控件 musicCkb = (CheckBox) findViewById(R.id.chb_music); tripCkb = (CheckBox) findViewById(R.id.chb_trip); filmCkb = (CheckBox) findViewById(R.id.chb_film); gameCkb = (CheckBox) findViewById(R.id.chb_game); result_tv = (TextView) findViewById(R.id.result_tv); endBtn= (Button) findViewById(R.id.end); //设置监听器 musicCkb.setOnCheckedChangeListener(this); tripCkb.setOnCheckedChangeListener(this); filmCkb.setOnCheckedChangeListener(this); gameCkb.setOnCheckedChangeListener(this); //为button设置监听器 endBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { StringBuilder sb=new StringBuilder(); for (int i =0;i<hobbies.size();i++) { //把选择的爱好添加到string尾部 if(i==(hobbies.size()-1)) { sb.append(hobbies.get(i)); }else { sb.append(hobbies.get(i)+","); } } //显示选择结果 result_tv.setText("你选择了:"+sb); } }); } @Override public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { if (isChecked){ //添加到爱好数组 hobbies.add(buttonView.getText().toString().trim()); }else { //从数组中移除 hobbies.remove(buttonView.getText().toString().trim()); } } }
当 CheckBox 的状态发生改变时,通过 Checkbox.isChecked() 方法可以获取当前 CheckBox 按钮的选中状态,进而进行处理。