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

标签(空格分隔): Android基础入门教程


本节引言:

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

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


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


1)RadioButton(单选按钮)

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

效果图:

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

布局代码如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:id="@+id/LinearLayout1"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context=".MainActivity" ><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:text="请选择性别"android:textSize="23dp"/><RadioGroupandroid:id="@+id/radioGroup"android:layout_width="wrap_content"android:layout_height="wrap_content"android:orientation="horizontal"><RadioButtonandroid:id="@+id/btnMan"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="男"android:checked="true"/><RadioButtonandroid:id="@+id/btnWoman"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="女"/></RadioGroup><Buttonandroid:id="@+id/btnpost"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="提交"/></LinearLayout>

获得选中的值:

这里有两种方法,

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

例子代码如下:

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

运行效果图:

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

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

例子代码如下:

Button btnchange = (Button) findViewById(R.id.btnpost);RadioGroup radgroup = (RadioGroup) findViewById(R.id.radioGroup);//为radioGroup设置一个监听器:setOnCheckedChanged()  btnchange.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {for (int i = 0; i < radgroup.getChildCount(); i++) {RadioButton rd = (RadioButton) radgroup.getChildAt(i);if (rd.isChecked()) {Toast.makeText(getApplicationContext(), "点击提交按钮,获取你选择的是:" + rd.getText(), Toast.LENGTH_LONG).show();break;}}}});

运行效果图:

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


2)CheckBox(复选框)

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

运行效果图:

实现代码:

public class MainActivity extends AppCompatActivity implements View.OnClickListener,CompoundButton.OnCheckedChangeListener{private CheckBox cb_one;private CheckBox cb_two;private CheckBox cb_three;private Button btn_send;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);cb_one = (CheckBox) findViewById(R.id.cb_one);cb_two = (CheckBox) findViewById(R.id.cb_two);cb_three = (CheckBox) findViewById(R.id.cb_three);btn_send = (Button) findViewById(R.id.btn_send);cb_one.setOnCheckedChangeListener(this);cb_two.setOnCheckedChangeListener(this);cb_three.setOnCheckedChangeListener(this);btn_send.setOnClickListener(this);}@Overridepublic void onCheckedChanged(CompoundButton compoundButton, boolean b) {if(compoundButton.isChecked()) Toast.makeText(this,compoundButton.getText().toString(),Toast.LENGTH_SHORT).show();}@Overridepublic void onClick(View view) {String choose = "";if(cb_one.isChecked())choose += cb_one.getText().toString() + "";if(cb_two.isChecked())choose += cb_two.getText().toString() + "";if(cb_three.isChecked())choose += cb_three.getText().toString() + "";Toast.makeText(this,choose,Toast.LENGTH_SHORT).show();}
}

2.自定义点击效果

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

实现效果图如下:

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

实现代码:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"><item
        android:state_enabled="true"android:state_checked="true"android:drawable="@mipmap/ic_checkbox_checked"/><item
        android:state_enabled="true"android:state_checked="false"android:drawable="@mipmap/ic_checkbox_normal" />
</selector>

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

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

android:button="@drawable/rad_btn_selctor"

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

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

然后布局那里:

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!

示例代码如下:

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

本节小结:

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

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

  1. 最新Android基础入门教程目录(完结版)

    第一章:环境搭建与开发相关(已完结 10/10) https://blog.csdn.net/coder_pig/article/details/50000773 Android基础入门教程--1.1 ...

  2. 2015年最新Android基础入门教程目录(完结版)

    2015年最新Android基础入门教程目录(完结版) 标签(空格分隔): Android基础入门教程 前言: 关于<2015年最新Android基础入门教程目录>终于在今天落下了帷幕,全 ...

  3. android 编辑9图片,Android基础入门教程——1.6 .9(九妹)图片怎么玩

    Android基础入门教程--1.6 .9(九妹)图片怎么玩 Android基础入门教程 1.本节引言: 可能有的一些疑问: 1.什么是.9图片? 答:图片后缀名前有.9的图片,如pic1.9.png ...

  4. android设置webview缓存目录,Android基础入门教程——7.5.5 WebView缓存问题

    Android基础入门教程--7.5.5 WebView缓存问题 Android基础入门教程 本节引言:现在很多门户类信息网站,比如虎嗅,ifanr,钛媒体等等的APP,简单点说是信息阅读类的APP, ...

  5. Android基础入门教程——4.3.1 BroadcastReceiver牛刀小试

    Android基础入门教程--4.3.1 BroadcastReceiver牛刀小试 标签(空格分隔): Android基础入门教程 本节引言 本节我们将来学习Android四大组件中的第三个:Bro ...

  6. Android基础入门教程——10.1 TelephonyManager(电话管理器)

    Android基础入门教程--10.1 TelephonyManager(电话管理器) 标签(空格分隔): Android基础入门教程 本节引言: 本章节是Android基础入门教程的最后一章,主要讲 ...

  7. Android基础入门教程——7.6.1 Socket学习网络基础准备

    Android基础入门教程--7.6.1 Socket学习网络基础准备 标签(空格分隔): Android基础入门教程 本节引言: 为了照顾没学过Java Socket的初学者,或者说捋一捋Andro ...

  8. Android基础入门教程——1.7 界面原型设计

    Android基础入门教程--1.7 界面原型设计 标签(空格分隔): Android基础入门教程 本节引言: 引用锤子科技视觉设计总监--罗子雄在重庆TEDx活动上说的一小段话: 每当我们看到一些美 ...

  9. Android基础入门教程——2.5.1 Toast(吐司)的基本使用

    Android基础入门教程--2.5.1 Toast(吐司)的基本使用 标签(空格分隔): Android基础入门教程 本节引言: 好的,终于学习完Adapter类相关的一些控件,当然除了讲解的那几个 ...

最新文章

  1. Tomcat发布项目方法!
  2. JDBC批量Insert深度优化(有事务)
  3. Python 图片与字符串互转
  4. SQL SERVER2008 存储过程、表、视图、函数的权限
  5. C++中内存分配方式、空指针及野指针的区别
  6. decode函数乱码_Python中文乱码的2种解决方案
  7. RHEL6入门系列之三十三,写在最后
  8. 本地搭建私有云盘:群晖系统存储空间设置 3/5
  9. 高压输电线路线夹温度监测系统装置
  10. Android 自带的字体库、字体样式
  11. 高级英语(张汉熙版)第一册学习笔记(原文及全文翻译)——2 - Hiroshima-The “Liveliest“ City in Japan (excerpts)(广岛——日本“最有活力”的城市)
  12. 旧BugkuCTF—部分wp
  13. weblogic反序列化漏洞修复
  14. 银行业务中台和阿里中台的异曲同工之妙
  15. 牛逼的Android UI
  16. python填补缺失值数据驱动代码_python填补缺失值数据驱动代码_python数据预处理之缺失值的各种填补方式...
  17. DHU数据结构-顺序表- ADT应用-找出两个等长升序序列的中位数
  18. 「微信将不再提供小程序打开 App 技术服务」带给我的思考
  19. GCC最新版安装及错误解决
  20. [Mattermost]Gauge测试UI+Jenkins流水线+Mattermost消息订阅(Mattermost篇)

热门文章

  1. ios long转float_iOS 数据类型转换
  2. text-overflow: ellipsis; white-space: nowrap;文本超出部门省略号
  3. 使用python爬虫模拟12306登陆
  4. tf.one_hot()使用
  5. 电热水壶坏了别扔,它很容易修好的!
  6. 面试必问: 结构体大小的计算方法
  7. 结构体大小的计算 用最简单的方法,通俗易懂的方法计算结构体大小
  8. SpringBoot默认包扫描机制及使用@ComponentScan指定扫描路径
  9. 真的能从脑电信号识别出我的情绪吗?
  10. 公司发年终奖了,老王坐不住了