Android学习笔记七:基本视图组件:RadioGroup和RadioButton

[url=http://sarin.iteye.com/blog/1632124]接上文[/url]
在Web开发中,HTML的可以实现单选按钮,单选按钮主要用于多值选一的操作,比如性别的选择,仅能从“男”或“女”中选择,那么就可以使用单选按钮实现。那么在Android中实现单选就需要使用到RadioGroup和RadioButton两个视图组件,它们结合使用才能达到单选按钮的效果。
首先我们来看看这两个组件的文档:
[img]http://dl.iteye.com/upload/attachment/0072/5127/4e774451-2a25-3d43-b5e3-4eb25f9ad2c0.jpg[/img]
[b]
java.lang.Object
↳ android.view.View
↳ android.view.ViewGroup
↳ android.widget.LinearLayout
↳ android.widget.RadioGroup[/b]
可以看出,RadioGroup是线性布局管理器LinearLayout的子类,那么也就说明,在RadioGroup中的组件是线性排列的,也就是说RadioButton线性排列在RadioGroup内。RadioGroup可以视为是RadioButton的容器,下面来看看RadioButton的文档:
[img]http://dl.iteye.com/upload/attachment/0072/5129/67ba1a7a-6187-32de-965b-ddecf2144cc6.jpg[/img]
[b]
java.lang.Object
↳ android.view.View
↳ android.widget.TextView
↳ android.widget.Button
↳ android.widget.CompoundButton
↳ android.widget.RadioButton[/b]
RadioButton是Button类的间接子类,它直接继承自CompoundButton,这样的设计也是为了复选框Checkbox的设计提出公共的父类。
下面在Eclipse中新建一个项目,我们来介绍RadioGroup和RadioButton的使用:

android:id="@+id/genderLabel"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="请选择您的性别"
android:textSize="20dp" />
android:id="@+id/gender"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
android:id="@+id/male"
android:text="男" />
android:id="@+id/female"
android:text="女" />


对于TextView组件不做解释了,就是用于一个提示信息,之后我们定义了一个RadioGroup,设置这个组件的一些属性,这里我们设置ID和长宽信息。注意它是先行布局管理器的子类,是放置RadioButton的容器,那么这里我们这是一个orientation属性来规定RadioButton的排列方式,这里vertical表示纵垂直向排列。
在RadioGroup中定义了两个RadioButton组件,就是两个具体的单选按钮,首先分别设置ID,之后就是要显示的文字,没什么可多说的。下面运行程序来看看效果:
[img]http://dl.iteye.com/upload/attachment/0072/5132/b5953a0b-c6c2-39aa-9378-384cbf548101.jpg[/img]
这里呈现出了单选按钮的效果。在Web开发中,HTML的单选按钮有默认选中设置,使用来标识,那么在Aandroid中,我们也可以设置默认选中的项目,修改代码如下

android:id="@+id/male"
android:checked="true"
android:text="男" />

这里表示默认选中“男”,和HTML代码十分类似,但我们还有另外一种标识默认选中的方法,代码如下:

android:id="@+id/gender"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:checkedButton="@+id/female"
android:orientation="vertical" >

我们在RadioGroup中用checkedButton属性来设置也是可以的,其直为RadioButton的ID,那么我们就不用在具体的RadioButton上来标识了,从而保持RadioButton代码的一致性,运行程序,得到如下效果:
[img]http://dl.iteye.com/upload/attachment/0072/5134/9fff7d77-af98-3554-9e36-bff46c3a1f8f.jpg[/img]
此时和我们设置的是一致的,默认选中的是“女”。默认选中的意义在于,如果用户漏选某个值,而这个值要提交给后台程序处理,恰恰又没有校验的时候,那么不会引起后台程序的错误,这个设置是很有必要的。在Web开发中,对于单选按钮,通常也会设置默认选中的一个值。
看过竖直排列后,我们来看看水平排列的效果,很简单,修改RadioGroup的orientation为horizontal即可:

android:id="@+id/gender"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:checkedButton="@+id/male"
android:orientation="horizontal" >

运行代码,我们可以看到如下效果:
[img]http://dl.iteye.com/upload/attachment/0072/5136/f66ffb52-a455-33e4-873d-7ccf80a9ca1a.jpg[/img]
这样,选项就水平排列了。
下面我们使用程序来对RadioGroup和RadioButton进行控制,比如新加入一个需求,性别可以选择保密,并且设置保密为默认选中状态,那么在代码中,我们可以这么来实现:

package org.ourpioneer;
import android.app.Activity;
import android.os.Bundle;
import android.widget.RadioButton;
import android.widget.RadioGroup;
public class RadioDemoActivity extends Activity {
private RadioGroup radioGroup;
private RadioButton radio;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
super.setContentView(R.layout.main);
radio = new RadioButton(this);
radio.setChecked(true);
radio.setText("保密");
radioGroup = (RadioGroup) super.findViewById(R.id.gender);
radioGroup.addView(radio);
}
}

在这里,我们将RadioGroup和RadioButton作为类的成员变量出现。首先是创建RadioButton组件,和之前的组件一样,构造方法接受一个Context类型的变量,就是this。其次设置这个按钮为默认选中的状态,并且给出提示信息“保密”。之后获取到我们在main.xml文件中定义的RadioGroup组件,并向这个RadioGroup中添加我们新创建的RadioButton,那么运行程序,我们可以看到如下效果:
[img]http://dl.iteye.com/upload/attachment/0072/5138/a8b044ca-6b83-332f-8548-4c127b801d47.jpg[/img]
这样也就实现了在程序中动态地对单选按钮组件的控制。
这部分源代码请参考附件。
[url=http://sarin.iteye.com/blog/1665694]接下文[/url]

你可能感兴趣的:(积少成多)