1. 程式人生 > >Android控制元件系列之RadioButton&RadioGroup

Android控制元件系列之RadioButton&RadioGroup

學習目的:

1、掌握在Android中如何建立RadioGroup和RadioButton

2、掌握RadioGroup的常用屬性

3、理解RadioButton和CheckBox的區別

4、掌握RadioGroup選中狀態變換的事件(監聽器)

RadioButton和CheckBox的區別:

1、單個RadioButton在選中後,通過點選無法變為未選中

    單個CheckBox在選中後,通過點選可以變為未選中

2、一組RadioButton,只能同時選中一個

     一組CheckBox,能同時選中多個

3、RadioButton在大部分UI框架中預設都以圓形表示

     CheckBox在大部分UI框架中預設都以矩形表示

RadioButton和RadioGroup的關係:

1、RadioButton表示單個圓形單選框,而RadioGroup是可以容納多個RadioButton的容器

2、每個RadioGroup中的RadioButton同時只能有一個被選中

3、不同的RadioGroup中的RadioButton互不相干,即如果組A中有一個選中了,組B中依然可以有一個被選中

4、大部分場合下,一個RadioGroup中至少有2個RadioButton

5、大部分場合下,一個RadioGroup中的RadioButton預設會有一個被選中,並建議您將它放在RadioGroup中的起始位置

XML佈局:

複製程式碼 1 <?xml version="1.0" encoding="utf-8"?> 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 3 android:orientation="vertical" 4 android:layout_width="fill_parent" 5 android:layout_height="fill_parent" 6 > 7 <TextView 8 android:layout_width="fill_parent"
9 android:layout_height="wrap_content"10 android:text="請選擇您的性別:"11 android:textSize="9pt"12 />13 <RadioGroup android:id="@+id/radioGroup" android:contentDescription="性別" android:layout_width="wrap_content" android:layout_height="wrap_content">14 <RadioButton android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/radioMale" android:text="男" android:checked="true"></RadioButton>15 <RadioButton android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/radioFemale" android:text="女"></RadioButton>16 </RadioGroup>17 <TextView 18 android:id="@+id/tvSex"19 android:layout_width="fill_parent"20 android:layout_height="wrap_content"21 android:text="您的性別是:男"22 android:textSize="9pt"23 />24 </LinearLayout> 複製程式碼

選中項變更的事件監聽:

當RadioGroup中的選中項變更後,您可能需要做一些相應,比如上述例子中,性別選擇“女”後下面的本文也相應改變,又或者選擇不同的性別後,出現符合該性別的頭像列表進行更新,女生不會喜歡使用大鬍子作為自己的頭像。

後臺程式碼如下:

複製程式碼 1 TextView tv =null;//根據不同選項所要變更的文字控制元件 2 @Override 3 publicvoid onCreate(Bundle savedInstanceState) { 4 super.onCreate(savedInstanceState); 5 6 setContentView(R.layout.main); 7 8 //根據ID找到該文字控制元件 9 tv = (TextView)this.findViewById(R.id.tvSex); 10 //根據ID找到RadioGroup例項11 RadioGroup group = (RadioGroup)this.findViewById(R.id.radioGroup); 12 //繫結一個匿名監聽器13 group.setOnCheckedChangeListener(new OnCheckedChangeListener() { 14 15 @Override 16 publicvoid onCheckedChanged(RadioGroup arg0, int arg1) { 17 // TODO Auto-generated method stub 18 //獲取變更後的選中項的ID19 int radioButtonId = arg0.getCheckedRadioButtonId(); 20 //根據ID獲取RadioButton的例項21 RadioButton rb = (RadioButton)MyActiviy.this.findViewById(radioButtonId); 22 //更新文字內容,以符合選中項23 tv.setText("您的性別是:"+ rb.getText()); 24 } 25 }); 26 } 複製程式碼

效果如下:

總結:

本文介紹了Android中如何使用RadioGroup和RadioButton,對比了RadioButton和CheckBox的區別,並實現了自定義的RadioGroup中被選中RadioButton的變更監聽事件。

RadioButton和CheckBox的區別:

1、單個RadioButton在選中後,通過點選無法變為未選中

    單個CheckBox在選中後,通過點選可以變為未選中

2、一組RadioButton,只能同時選中一個

     一組CheckBox,能同時選中多個

3、RadioButton在大部分UI框架中預設都以圓形表示

     CheckBox在大部分UI框架中預設都以矩形表示

RadioButton和RadioGroup的關係:

1、RadioButton表示單個圓形單選框,而RadioGroup是可以容納多個RadioButton的容器

2、每個RadioGroup中的RadioButton同時只能有一個被選中

3、不同的RadioGroup中的RadioButton互不相干,即如果組A中有一個選中了,組B中依然可以有一個被選中

4、大部分場合下,一個RadioGroup中至少有2個RadioButton

5、大部分場合下,一個RadioGroup中的RadioButton預設會有一個被選中,並建議您將它放在RadioGroup中的起始位置