[关闭]
@coder-pig 2015-07-20T13:23:25.000000Z 字数 5489 阅读 2077

Android基础入门教程——2.3.5.RadioButton(单选按钮)&Checkbox(复选框)

Android基础入门教程


本节引言:

本节给大家带来的是Andoird基本UI控件中的RadioButton和Checkbox;
先说下本节要讲解的内容是:RadioButton和Checkbox的
1.基本用法
2.事件处理;
3.自定义点击效果;
4.改变文字与选择框的相对位置;
5.修改文字与选择框的距离

其实这两个控件有很多地方都是类似的,除了单选和多选,事件处理,其他的都是类似的!
另外还有一个ListView上Checkbox的错位的问题,我们会在ListView那一章对这个问题进行
解决,好的,开始本节内容~
本节官方文档API:RadioButtonCheckBox


1.基本用法与事件处理:


1)RadioButton(单选按钮)

如题单选按钮,就是只能够选中一个,所以我们需要把RadioButton放到RadioGroup按钮组中,从而实现
单选功能!先熟悉下如何使用RadioButton,一个简单的性别选择的例子:
另外我们可以为外层RadioGroup设置orientation属性然后设置RadioButton的排列方式,是竖直还是水平~

效果图:

PS:笔者的手机是Android 5.0.1的,这里的RadioButton相比起旧版本的RadioButton,稍微好看一点~

布局代码如下:

  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:id="@+id/LinearLayout1"
  4. android:layout_width="match_parent"
  5. android:layout_height="match_parent"
  6. android:orientation="vertical"
  7. tools:context=".MainActivity" >
  8. <TextView
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:text="请选择性别"
  12. android:textSize="23dp"
  13. />
  14. <RadioGroup
  15. android:id="@+id/radioGroup"
  16. android:layout_width="wrap_content"
  17. android:layout_height="wrap_content"
  18. android:orientation="horizontal">
  19. <RadioButton
  20. android:id="@+id/btnMan"
  21. android:layout_width="wrap_content"
  22. android:layout_height="wrap_content"
  23. android:text="男"
  24. android:checked="true"/>
  25. <RadioButton
  26. android:id="@+id/btnWoman"
  27. android:layout_width="wrap_content"
  28. android:layout_height="wrap_content"
  29. android:text="女"/>
  30. </RadioGroup>
  31. <Button
  32. android:id="@+id/btnpost"
  33. android:layout_width="wrap_content"
  34. android:layout_height="wrap_content"
  35. android:text="提交"/>
  36. </LinearLayout>

获得选中的值:

这里有两种方法,

第一种是为RadioButton设置一个事件监听器setOnCheckChangeListener

例子代码如下:

  1. RadioGroup radgroup = (RadioGroup) findViewById(R.id.radioGroup);
  2. //第一种获得单选按钮值的方法
  3. //为radioGroup设置一个监听器:setOnCheckedChanged()
  4. radgroup.setOnCheckedChangeListener(new OnCheckedChangeListener() {
  5. @Override
  6. public void onCheckedChanged(RadioGroup group, int checkedId) {
  7. RadioButton radbtn = (RadioButton) findViewById(checkedId);
  8. Toast.makeText(getApplicationContext(), "按钮组值发生改变,你选了" + radbtn.getText(), Toast.LENGTH_LONG).show();
  9. }
  10. });

运行效果图:

PS:另外有一点要切记,要为每个RadioButton添加一个id,不然单选功能会生效!!!

第二种方法是通过单击其他按钮获取选中单选按钮的值,当然我们也可以直接获取,这个看需求~

例子代码如下:

  1. Button btnchange = (Button) findViewById(R.id.btnpost);
  2. RadioGroup radgroup = (RadioGroup) findViewById(R.id.radioGroup);
  3. //为radioGroup设置一个监听器:setOnCheckedChanged()
  4. btnchange.setOnClickListener(new OnClickListener() {
  5. @Override
  6. public void onClick(View v) {
  7. for (int i = 0; i < radgroup.getChildCount(); i++) {
  8. RadioButton rd = (RadioButton) radgroup.getChildAt(i);
  9. if (rd.isChecked()) {
  10. Toast.makeText(getApplicationContext(), "点击提交按钮,获取你选择的是:" + rd.getText(), Toast.LENGTH_LONG).show();
  11. break;
  12. }
  13. }
  14. }
  15. });

运行效果图:

代码解析:
这里我们为提交按钮设置了一个setOnClickListener事件监听器,每次点击的话遍历一次RadioGroup判断哪个按钮被选中我们可以通过下述方法获得RadioButton的相关信息!
getChildCont( )获得按钮组中的单选按钮的数目;
getChinldAt(i):根据索引值获取我们的单选按钮
isChecked( ):判断按钮是否选中


2)CheckBox(复选框)

如题复选框,即可以同时选中多个选项,至于获得选中的值,同样有两种方式:
1.为每个CheckBox添加事件:setOnCheckedChangeListener
2.弄一个按钮,在点击后,对每个checkbox进行判断:isChecked();

运行效果图:

实现代码:

  1. public class MainActivity extends AppCompatActivity implements View.OnClickListener,CompoundButton.OnCheckedChangeListener{
  2. private CheckBox cb_one;
  3. private CheckBox cb_two;
  4. private CheckBox cb_three;
  5. private Button btn_send;
  6. @Override
  7. protected void onCreate(Bundle savedInstanceState) {
  8. super.onCreate(savedInstanceState);
  9. setContentView(R.layout.activity_main);
  10. cb_one = (CheckBox) findViewById(R.id.cb_one);
  11. cb_two = (CheckBox) findViewById(R.id.cb_two);
  12. cb_three = (CheckBox) findViewById(R.id.cb_three);
  13. btn_send = (Button) findViewById(R.id.btn_send);
  14. cb_one.setOnCheckedChangeListener(this);
  15. cb_two.setOnCheckedChangeListener(this);
  16. cb_three.setOnCheckedChangeListener(this);
  17. btn_send.setOnClickListener(this);
  18. }
  19. @Override
  20. public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
  21. if(compoundButton.isChecked()) Toast.makeText(this,compoundButton.getText().toString(),Toast.LENGTH_SHORT).show();
  22. }
  23. @Override
  24. public void onClick(View view) {
  25. String choose = "";
  26. if(cb_one.isChecked())choose += cb_one.getText().toString() + "";
  27. if(cb_two.isChecked())choose += cb_two.getText().toString() + "";
  28. if(cb_three.isChecked())choose += cb_three.getText().toString() + "";
  29. Toast.makeText(this,choose,Toast.LENGTH_SHORT).show();
  30. }
  31. }

2.自定义点击效果

虽然5.0后的RadioButton和Checkbox都比旧版本稍微好看了点,但是对于我们来说
可能还是不喜欢或者需求,需要自己点击效果!实现起来很简单,先编写一个自定义
的selctor资源,设置选中与没选中时的切换图片~!

实现效果图如下:

PS:这里素材的原因,有点小...

实现代码:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  3. <item
  4. android:state_enabled="true"
  5. android:state_checked="true"
  6. android:drawable="@mipmap/ic_checkbox_checked"/>
  7. <item
  8. android:state_enabled="true"
  9. android:state_checked="false"
  10. android:drawable="@mipmap/ic_checkbox_normal" />
  11. </selector>

写好后,我们有两种方法设置,也可以说一种吧!你看看就知道了~

①android:button属性设置为上述的selctor

  1. android:button="@drawable/rad_btn_selctor"

②在style中定义一个属性,然后通过android style属性设置,先往style添加下述代码:

  1. <style name="MyCheckBox" parent="@android:style/Widget.CompoundButton.CheckBox">
  2. <item name="android:button">@drawable/rad_btn_selctor</item>
  3. </style>

然后布局那里:

  1. style="@style/MyCheckBox"

3.改变文字与选择框的相对位置

这个实现起来也很简单,还记得我们之前学TextView的时候用到的drawableXxx吗?
要控制选择框的位置,两部即可!设置:

Step 1. android:button="@null"
Step 2. android:drawableTop="@android:drawable/btn_radio"
当然我们可以把drawableXxx替换成自己喜欢的效果!


4.修改文字与选择框的距离

有时,我们可能需要调节文字与选择框之间的距离,让他们看起来稍微没那么挤,我们可以:
1.在XML代码中控制:
使用android:paddingXxx = "xxx" 来控制距离
2.在Java代码中,稍微好一点,动态计算paddingLeft!

示例代码如下:

  1. rb.setButtonDrawable(R.drawable.rad_btn_selctor);
  2. int rb_paddingLeft = getResources().getDrawable(R.mipmap.ic_checkbox_checked).getIntrinsicWidth()+5;
  3. rb.setPadding(rb_paddingLeft, 0, 0, 0);

本节小结:

好的,关于RadioButton和Checkbox就讲到这里,如果有什么写得不对的,不好的,或者有好的建议欢迎指出
万分感激~谢谢...

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注