转载自:http://my.oschina.net/amigos/blog/59261
实现RadioButton由两部分组成,也就是RadioButton和RadioGroup配合使用.RadioGroup是单选组合框,可以容纳多个RadioButton的容器.在没有RadioGroup的情况下,RadioButton可以全部都选中;当多个RadioButton被RadioGroup包含的情况下,RadioButton只可以选择一个。并用setOnCheckedChangeListener来对单选按钮进行监听
03 |
RadioGroup.getCheckedRadioButtonId ();--获取选中按钮的id |
05 |
RadioGroup.clearCheck ();//---清除选中状态 |
07 |
RadioGroup.check (int id);//---通过参入选项id来设置该选项为选中状态如果传递-1作为指定的选择标识符来清除单选按钮组的勾选状态,相当于调用clearCheck()操作 |
09 |
setOnCheckedChangeListener (RadioGroup.OnCheckedChangeListener listener); //--一个当该单选按钮组中的单选按钮勾选状态发生改变时所要调用的回调函数 |
11 |
addView (View child, int index, ViewGroup.LayoutParams params);//---使用指定的布局参数添加一个子视图 |
13 |
//参数 child 所要添加的子视图 index 将要添加子视图的位置 params 所要添加的子视图的布局参数 |
15 |
RadioButton.getText();//获取单选框的值 |
17 |
//此外,RadioButton的checked属性设置为true,代码里调用RadioButton的check(id)方法,不会触发onCheckedChanged事件 |
RadioButton和RadioGroup的关系:
1、RadioButton表示单个圆形单选框,而RadioGroup是可以容纳多个RadioButton的容器
2、每个RadioGroup中的RadioButton同时只能有一个被选中
3、不同的RadioGroup中的RadioButton互不相干,即如果组A中有一个选中了,组B中依然可以有一个被选中
4、大部分场合下,一个RadioGroup中至少有2个RadioButton
5、大部分场合下,一个RadioGroup中的RadioButton默认会有一个被选中,并建议您将它放在RadioGroup中的起始位置
看案例:
1.定义布局文件:
01 |
<?xml version="1.0" encoding="utf-8"?> |
02 |
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android" |
03 |
android:layout_width="match_parent" |
04 |
android:layout_height="match_parent" > |
06 |
android:orientation="vertical" |
07 |
android:layout_width="match_parent" |
08 |
android:layout_height="wrap_content" |
09 |
android:layout_marginRight="5dp" > |
12 |
android:id="@+id/radiogroup_info_id" |
13 |
android:layout_width="228px" |
14 |
android:layout_height="wrap_content" |
15 |
android:text="我选择的是...?" |
16 |
android:textSize="30sp" |
20 |
android:id="@+id/radioGroup_sex_id" |
21 |
android:layout_width="match_parent" |
22 |
android:layout_height="match_parent" |
25 |
android:id="@+id/boy_id" |
26 |
android:layout_width="match_parent" |
27 |
android:layout_height="match_parent" |
31 |
android:id="@+id/girl_id" |
32 |
android:layout_width="match_parent" |
33 |
android:layout_height="match_parent" |
39 |
android:id="@+id/radio_clear" |
40 |
android:layout_width="match_parent" |
41 |
android:layout_height="match_parent" |
46 |
android:id="@+id/radio_add_child" |
47 |
android:layout_width="match_parent" |
48 |
android:layout_height="match_parent" |
2.java代码文件
01 |
package com.dream.app.start.first.radiobutton; |
03 |
import com.dream.app.start.R; |
04 |
import com.dream.app.start.R.id; |
05 |
import com.dream.app.start.R.layout; |
06 |
import com.dream.app.start.three.utils.PublicClass; |
08 |
import android.app.Activity; |
09 |
import android.os.Bundle; |
10 |
import android.view.View; |
11 |
import android.view.View.OnClickListener; |
12 |
import android.view.ViewGroup.LayoutParams; |
13 |
import android.widget.Button; |
14 |
import android.widget.RadioButton; |
15 |
import android.widget.RadioGroup; |
16 |
import android.widget.RadioGroup.OnCheckedChangeListener; |
17 |
import android.widget.TextView; |
18 |
import android.widget.ToggleButton; |
20 |
public class RadioButtonDemo extends PublicClass { |
21 |
private TextView textView=null; |
22 |
private RadioGroup radioGroup=null; |
23 |
private RadioButton radioButton_boy,radioButton_girl; |
24 |
private Button radio_clear,child; |
26 |
* <a href="http://my.oschina.net/u/244147" target="_blank" rel="nofollow">@see</a> android.app.Activity#onCreate(android.os.Bundle) |
29 |
protected void onCreate(Bundle savedInstanceState) { |
30 |
// TODO Auto-generated method stub |
31 |
super.onCreate(savedInstanceState); |
33 |
setContentView(R.layout.layout_frist_radiobuton); |
35 |
textView = (TextView)findViewById(R.id.radiogroup_info_id); |
38 |
radioGroup=(RadioGroup)findViewById(R.id.radioGroup_sex_id); |
39 |
radioButton_boy=(RadioButton)findViewById(R.id.boy_id); |
40 |
radioButton_girl=(RadioButton)findViewById(R.id.girl_id); |
41 |
child=(Button)findViewById(R.id.radio_add_child); |
43 |
radioGroup.setOnCheckedChangeListener(listen); |
44 |
radio_clear=(Button)findViewById(R.id.radio_clear); |
45 |
radio_clear.setOnClickListener(onClick); |
46 |
child.setOnClickListener(onClick); |
49 |
private OnCheckedChangeListener listen=new OnCheckedChangeListener() { |
52 |
public void onCheckedChanged(RadioGroup group, int checkedId) { |
53 |
int id= group.getCheckedRadioButtonId(); |
54 |
switch (group.getCheckedRadioButtonId()) { |
56 |
textView.setText("我选择的是:"+radioButton_girl.getText()); |
59 |
textView.setText("我选择的是:"+radioButton_boy.getText()); |
62 |
textView.setText("我选择的是:新增"); |
68 |
private OnClickListener onClick=new OnClickListener() { |
71 |
public void onClick(View v) { |
72 |
radio_clear=(Button)v; |
73 |
switch (radio_clear.getId()) { |
74 |
case R.id.radio_clear: |
75 |
radioGroup.check(-1);//清除选项 |
76 |
// radioGroup.clearCheck(); //清除选项 |
77 |
textView.setText("我选择的是...?"); |
79 |
case R.id.radio_add_child: |
81 |
RadioButton newRadio =new RadioButton(getApplicationContext()); |
82 |
newRadio.setText("新增"); |
83 |
radioGroup.addView(newRadio, radioGroup.getChildCount()); |
运行效果:


3.

4:可以通过设置如下属性可以使单选按钮在显示文本的右边
android:button="@null"
android:drawableRight="@android:drawable/btn_radio"
效果:

RadioButton和CheckBox的区别:
1、单个RadioButton在选中后,通过点击无法变为未选中
单个CheckBox在选中后,通过点击可以变为未选中
2、一组RadioButton,只能同时选中一个
一组CheckBox,能同时选中多个
3、RadioButton在大部分UI框架中默认都以圆形表示
CheckBox在大部分UI框架中默认都以矩形表示
==================================================
☆定制RadioButton样式RadioButton长成什么样子是由其Background、Button等属性决定的,Android系统
使用style定义了默认的属性,在android源码
android/frameworks/base/core/res/res/values/styles.xml中可以看到默认的定义:
1 |
<style name="Widget.CompoundButton.RadioButton"> |
2 |
<item name="android:background">@android:drawable/btn_radio_label_background</item> |
3 |
<item name="android:button">@android:drawable/btn_radio</item> |
即其背景图是btn_radio_label_background,其button的样子是btn_radio
btn_radio_label_background是什么?
其路径是android/frameworks/base/core/res/res/drawable-mdpi/btn_radio_label_background.9.png
可以看到是一个NinePatch图片,用来做背景,可以拉伸填充。
btn_radio是什么?
其路径是android/frameworks/base/core/res/res/drawable/btn_radio.xml
是个xml定义的drawable,打开看其内容:
01 |
<selector xmlns:android="http://schemas.android.com/apk/res/android"> |
02 |
<item android:state_checked="true" android:state_window_focused="false" |
03 |
android:drawable="@drawable/btn_radio_on" /> |
04 |
<item android:state_checked="false" android:state_window_focused="false" |
05 |
android:drawable="@drawable/btn_radio_off" /> |
07 |
<item android:state_checked="true" android:state_pressed="true" |
08 |
android:drawable="@drawable/btn_radio_on_pressed" /> |
09 |
<item android:state_checked="false" android:state_pressed="true" |
10 |
android:drawable="@drawable/btn_radio_off_pressed" /> |
12 |
<item android:state_checked="true" android:state_focused="true" |
13 |
android:drawable="@drawable/btn_radio_on_selected" /> |
14 |
<item android:state_checked="false" android:state_focused="true" |
15 |
android:drawable="@drawable/btn_radio_off_selected" /> |
17 |
<item android:state_checked="false" android:drawable="@drawable/btn_radio_off" /> |
18 |
<item android:state_checked="true" android:drawable="@drawable/btn_radio_on" /> |
<item android:state_checked="true" android:state_pressed="true"
android:drawable="@drawable/btn_radio_on_pressed" />
意思即为当radiobutton被选中时,并且被按下时,其Button应该长成btn_radio_on_pressed这个样子。

文件是android/frameworks/base/core/res/res/drawable-mdpi/btn_radio_on_pressed.png
drawable的item中可以有以下属性:
1 |
android:drawable="@[package:]drawable/drawable_resource" |
2 |
android:state_pressed=["true" | "false"] |
3 |
android:state_focused=["true" | "false"] |
4 |
android:state_selected=["true" | "false"] |
5 |
android:state_active=["true" | "false"] |
6 |
android:state_checkable=["true" | "false"] |
7 |
android:state_checked=["true" | "false"] |
8 |
android:state_enabled=["true" | "false"] |
9 |
android:state_window_focused=["true" | "false"] |
当按钮的状态和某个item匹配后,就会使用此item定义的drawable作为按钮图片。
从上面分析我们如果要修改RadioButton的外观,
自定义有三种方式:
1.方式一:
01 |
<?xml version="1.0" encoding="utf-8"?> |
02 |
<selector xmlns:android="http://schemas.android.com/apk/res/android"> |
05 |
android:state_checked="false" |
06 |
android:drawable="@drawable/tabswitcher_long" /> |
09 |
android:state_checked="true" |
10 |
android:drawable="@drawable/tabswitcher_short" /> |
在布局文件中使用
7 |
android:background="@drawable/radio" |
android:button="@null" 去除RadioButton前面的圆点
2.方式二:在JAVA代码中定义
2 |
public boolean onTouchEvent(MotionEvent event) { |
3 |
if(event.getActionMasked() == MotionEvent.ACTION_DOWN){ |
4 |
this.setBackgroundResource(com.wxg.tab.R.drawable.main_bg); |
5 |
}else if(event.getActionMasked()== MotionEvent.ACTION_DOWN) { |
6 |
this.setBackgroundResource(com.wxg.tab.R.drawable.hui); |
8 |
return super.onTouchEvent(event); |
去除RadioButton前面的圆点adioButton.setButtonDrawable(android.R.color.transparent);
3. 方式三
使用XML文件定义,在JAVA代码中使用 radioButton.setBackgroundResource(R.drawable.radio);调用
==============================================================
设置RadioButton在文字的右边
2 |
android:id="@+id/button2" |
3 |
android:layout_width="fill_parent" |
4 |
android:layout_height="50dip" |
6 |
android:drawableRight="@android:drawable/btn_radio" //在右边 |
7 |
android:paddingLeft="30dip" |
8 |
android:text="Android高手" |
9 |
android:textSize="20dip" /> </b> |
================================================================
自定义 radiobutton 文字颜色随选中状态而改变
主要是写一个 color selector
在res/建一个文件夹取名color
res/color/color_radiobutton.xml
1 |
<?xml version="1.0" encoding="utf-8"?> |
2 |
<selector xmlns:android="http://schemas.android.com/apk/res/android"> |
4 |
<item android:state_checked="true" |
5 |
android:color="@color/color_text_selected"/> |
7 |
<item android:color="@color/color_text_normal"/> |
布局文件定义控件:
02 |
android:id="@+id/radiobutton_1" |
03 |
android:layout_width="wrap_content" |
04 |
android:layout_height="wrap_content" |
05 |
android:background="@drawable/selector_radio" |
06 |
android:button="@null" |
07 |
android:checked="true" |
08 |
android:gravity="center" |
11 |
android:textColor="@color/color_radiobutton" |
12 |
android:textSize="@dimen/font_size" |
13 |
android:textStyle="bold" /> |
============================================================
RadioButton上显示图片和文字
使用XML文件很简单就可以实现,但是有时必须要使用java code 的方式动态实现,这就有些复杂了,这需要继承RadioButton并覆盖其中的onDraw方法。
在代码中的image是Bitmap对象。
03 |
protected void onDraw(Canvas canvas) { |
09 |
Paint pt = new Paint(); |
11 |
pt.setARGB(255,66,66,66); |
15 |
pt.setAntiAlias(true); |
19 |
int imageX=(int)(this.getWidth()-image.getWidth())/2; |
21 |
canvas.drawBitmap(image,imageX,5,pt); |
23 |
pt.setARGB(255,255,255,255); |
27 |
int strX=(int)(this.getWidth()-name.getBytes().length*5.5)/2; |
29 |
canvas.drawText(name,strX,(image.getHeight()+15),pt); |
- React Native之(支持iOS与Android)自定义单选按钮(RadioGroup,RadioButton)
React Native之(支持iOS与Android)自定义单选按钮(RadioGroup,RadioButton) 一,需求与简单介绍 在开发项目时发现RN没有给提供RadioButton和Rad ...
- Android下利用RadioGroup和RadioButton实现Tabbar的效果
本实现方法主要使用RadioGroup和RadioButton的组合方式来实现Tabbar的效果. 其中选中的Tab的切换的动作可以通过RadioGroup的OnCheckedChangeListen ...
- Android控件之RadioGroup与RadioButton(单选控件)
一.RadioGroup与RadioButton 1.什么是RadioGroup: RadioButton的一个集合,提供多选机制 2.什么是RadioButton: RadioButton包裹在Ra ...
- Android入门(八):使用RadioGroup 和RadioButton组件建立单选清单
这一章,我们学习RadioGroup 和RadioButton组件,我们新建一个项目,编码过程与前几章的项目类似. 1.建立字符串资源文件strings.xml: <resources> ...
- Android控件系列之RadioButton&RadioGroup(转)
学习目的: 1.掌握在Android中如何建立RadioGroup和RadioButton 2.掌握RadioGroup的常用属性 3.理解RadioButton和CheckBox的区别 4.掌握Ra ...
- android学习日记03--常用控件checkbox/radiobutton
常用控件3.checkbox 复选框,确定是否勾选,点击一下勾选,点击第二下取消,当有一系列备选项时适合用checkbox控件,方便用户提交数据. 贴上例子Activity的java代码 packag ...
- Android控件系列之RadioButton&RadioGroup
学习目的: 1.掌握在Android中如何建立RadioGroup和RadioButton 2.掌握RadioGroup的常用属性 3.理解RadioButton和CheckBox的区别 4.掌握Ra ...
- Android RadioGroup和RadioButton详解
实现RadioButton由两部分组成,也就是RadioButton和RadioGroup配合使用.RadioGroup是单选组合框,可以容纳多个RadioButton的容器.在没有RadioGrou ...
- 3.Android之单选按钮RadioGroup和复选框Checkbox学习
单选按钮和复选框在实际中经常看到,今天就简单梳理下. 首先,我们在工具中拖进单选按钮RadioGroup和复选框Checkbox,如图: xml对应的源码: <?xml version=&quo ...
随机推荐
- 多线程系列八:线程安全、Java内存模型(JMM)、底层实现原理
一.线程安全 1. 怎样让多线程下的类安全起来 无状态.加锁.让类不可变.栈封闭.安全的发布对象 2. 死锁 2.1 死锁概念及解决死锁的原则 一定发生在多个线程争夺多个资源里的情况下,发生的原因是 ...
- Mybatis系列(五):mybatis逆向工程
一.背景 在实际开发中我们会自己去写mapper映射文件,接口,数据库表对应的实体类,如果需求任务比较少,咱们还可以慢慢的一个一个去写,但是这是不现实的,因为在工作中我们的任务是很多的,这时mybat ...
- C# 让枚举返回字符串
下面的手段是使用给枚举项打标签的方式,来返回字符串 分别定义一个属性类,一个枚举帮助类 /// <summary> /// 自定义属性 /// </summary> [Attr ...
- Git log和git reflog
1.git log log命令可以显示所有提交过的版本信息.显示信息如下: $ git log commit e1bdff6e4830e09383078c860f45334d03771b03 (HE ...
- 压缩打包介绍/gzip压缩工具/bzip2压缩工具/xz压缩工具
6.1 压缩打包介绍 6.2 gzip压缩工具 6.3 bzip2压缩工具 6.4 xz压缩工具 常见的压缩文件格式 windows .rar .zip .7z linux ...
- 什么时候layoutSubview会被调用
文档描述不够详细,有人测试结果如下: init does not cause layoutSubviews to be called (duh) addSubview causes layoutSub ...
- 1 最简单的hello world
preface 今天我开始自学flask了,由此记录学习中的点点滴滴. 有问题请联系我(Mr.Leo 18500777133@sina.cn) include: 简介flask hello world ...
- jQuery时间格式转换
http://www.cnblogs.com/ShaYeBlog/p/4129301.html
- VSCode升级后启动不了~
之前安装了VSCode,一直用的好好的,每次启动后后下角总会提示自己有新版本可以更新,然后就手贱点击了更新,然后就出问题了,更新后VSCode无法启动,打不开了,哭死! 于是,我尝试了以下方法,均无济 ...
- Sublime的插件Color Highlighter的安装方法
ColorHighlighter是一个显示选中颜色代码的视觉颜色的插件.如果您选择“# fff“,它将向您展示白色.ColorHighlighter支持所有CSS颜色格式,如Hex,RGB,HSL,H ...