欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2022-05-09 17:06:17
...
    接上文
   在Web开发中,HTML的<input type="radio">可以实现单选按钮,单选按钮主要用于多值选一的操作,比如性别的选择,仅能从“男”或“女”中选择,那么就可以使用单选按钮实现。那么在Android中实现单选就需要使用到RadioGroup和RadioButton两个视图组件,它们结合使用才能达到单选按钮的效果。
    首先我们来看看这两个组件的文档:
Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 

java.lang.Object
   ↳ android.view.View
   ↳ android.view.ViewGroup
   ↳ android.widget.LinearLayout
   ↳ android.widget.RadioGroup

    可以看出,RadioGroup是线性布局管理器LinearLayout的子类,那么也就说明,在RadioGroup中的组件是线性排列的,也就是说RadioButton线性排列在RadioGroup内。RadioGroup可以视为是RadioButton的容器,下面来看看RadioButton的文档:
Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 

java.lang.Object
   ↳ android.view.View
   ↳ android.widget.TextView
   ↳ android.widget.Button
   ↳ android.widget.CompoundButton
   ↳ android.widget.RadioButton

   RadioButton是Button类的间接子类,它直接继承自CompoundButton,这样的设计也是为了复选框Checkbox的设计提出公共的父类。
   下面在Eclipse中新建一个项目,我们来介绍RadioGroup和RadioButton的使用:
    <TextView
        android:id="@+id/genderLabel"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="请选择您的性别"
        android:textSize="20dp" />
    <RadioGroup
        android:id="@+id/gender"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical" >
        <RadioButton
            android:id="@+id/male"
            android:text="男" />
        <RadioButton
            android:id="@+id/female"
            android:text="女" />
    </RadioGroup>

    对于TextView组件不做解释了,就是用于一个提示信息,之后我们定义了一个RadioGroup,设置这个组件的一些属性,这里我们设置ID和长宽信息。注意它是先行布局管理器的子类,是放置RadioButton的容器,那么这里我们这是一个orientation属性来规定RadioButton的排列方式,这里vertical表示纵垂直向排列。
    在RadioGroup中定义了两个RadioButton组件,就是两个具体的单选按钮,首先分别设置ID,之后就是要显示的文字,没什么可多说的。下面运行程序来看看效果:
Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 
    这里呈现出了单选按钮的效果。在Web开发中,HTML的单选按钮有默认选中设置,使用<input type="radio" checked>来标识,那么在Aandroid中,我们也可以设置默认选中的项目,修改代码如下
        <RadioButton
            android:id="@+id/male"
            android:checked="true"
            android:text="男" />

    这里表示默认选中“男”,和HTML代码十分类似,但我们还有另外一种标识默认选中的方法,代码如下:
    <RadioGroup
        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代码的一致性,运行程序,得到如下效果:
Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 
    此时和我们设置的是一致的,默认选中的是“女”。默认选中的意义在于,如果用户漏选某个值,而这个值要提交给后台程序处理,恰恰又没有校验的时候,那么不会引起后台程序的错误,这个设置是很有必要的。在Web开发中,对于单选按钮,通常也会设置默认选中的一个值。
    看过竖直排列后,我们来看看水平排列的效果,很简单,修改RadioGroup的orientation为horizontal即可:
    <RadioGroup
        android:id="@+id/gender"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:checkedButton="@+id/male"
        android:orientation="horizontal" >

    运行代码,我们可以看到如下效果:
Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 
    这样,选项就水平排列了。
   下面我们使用程序来对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,那么运行程序,我们可以看到如下效果:
Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 
    这样也就实现了在程序中动态地对单选按钮组件的控制。
    这部分源代码请参考附件。
    接下文
  • Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 
  • 大小: 77.2 KB
  • Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 
  • 大小: 76 KB
  • Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 
  • 大小: 30.9 KB
  • Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 
  • 大小: 31 KB
  • Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 
  • 大小: 31.3 KB
  • Android学习笔记七:基本视图组件:RadioGroup和RadioButton
            
    
    博客分类: 积少成多 android 
  • 大小: 33.2 KB
相关标签: android