2020-12-01

Android控件与布局——基础控件RadioButton

今天,我们的主题是基础控件RadioButton。在开始之前,我们还是以官方文档为开端来开始我们的讲解,下面是Android文档中对RadioButton的简介:

看过上一篇文章的应该可以了解到,这个和我们的CheckBox是十分类似的,不同的点在于,这个控件可以由非选中状态通过点击事件转为选中状态,但是不能通过点击实现逆向的状态转换,一个默认样式RadioButton控件的非选中和选中状态如下:

image

其组成和CheckBox一样,我们同样可以分别对其中的字体和Button进行设置,实现达到和CheckBox一样的效果。在上面我们在简介中得知,这个控件能通过点击事件实现的效果如下(不能逆向改变状态):

image

接下来,我们对其基本属性进行设置,改变一下它的样式:

image

下面我们就结合一个小例子来实际的应用一下,这个小例子就是实现多项单选功能,运行的效果如下:

image

布局文件与控制逻辑如下:

<?
package aoto.com.commonwidgetandlayout.basic_widget.radioButton; import android.graphics.Color;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.util.Log;import android.widget.CompoundButton;import android.widget.RadioButton; import aoto.com.commonwidgetandlayout.R; /** * @author why * @date 2019-5-13 20:44:28 */public class RadioButtonActivity extends AppCompatActivity implements CompoundButton.OnCheckedChangeListener {  private static final String TAG = "RadioButtonActivityWhy"; RadioButton radioButton1; RadioButton radioButton2; RadioButton radioButton3; @Override protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.activity_radio_button);  radioButton1=findViewById(R.id.radio_button1);  radioButton2=findViewById(R.id.radio_button2);  radioButton3=findViewById(R.id.radio_button3);   radioButton1.setOnCheckedChangeListener(this);  radioButton2.setOnCheckedChangeListener(this);  radioButton3.setOnCheckedChangeListener(this); }  @Override public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {  if(isChecked){   disableOthers(buttonView.getId());   Log.e(TAG, "您最喜欢的职业是: "+buttonView.getText().toString() );   buttonView.setTextColor(getResources().getColor(R.color.colorPrimary));  }  else {   buttonView.setTextColor(Color.BLACK);  } }  private void disableOthers(int viewId) {  if(R.id.radio_button1!=viewId&&radioButton1.isChecked()){   radioButton1.setChecked(false);  }  if(R.id.radio_button2!=viewId&&radioButton2.isChecked()){   radioButton2.setChecked(false);  }  if(R.id.radio_button3!=viewId&&radioButton3.isChecked()){   radioButton3.setChecked(false);  } }}

可见,我们为了实现一个单选功能做了很多逻辑控制,而这样的场景又非常多,没有关系,我们接着官方文档关于对其的介绍继续向下看:

* <p>* Radio buttons are normally used together in a* {@link android.widget.RadioGroup}. When several radio buttons live inside* a radio group, checking one radio button unchecks all the others.</p>

说这个RadioButton经常会结合RadioGroup一起使用,实现的功能正是我们上面所要实现的多项单选功能的操作。那下面就来看看如何使用RadioGroup实现上述例子的功能:

<?

说这个RadioButton经常会结合RadioGroup一起使用,实现的功能正是我们上面所要实现的多项单选功能的操作。那下面就来看看如何使用RadioGroup实现上述例子的功能:

<?

逻辑部分:

package aoto.com.commonwidgetandlayout.basic_widget.radioButton; import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.util.Log;import android.view.View;import android.widget.RadioButton;import android.widget.RadioGroup; import aoto.com.commonwidgetandlayout.R; /** * @author why * @date 2019-5-13 21:43:42 */public class RadioButton2Activity extends AppCompatActivity {  private static final String TAG = "RadioButton2ActivityWhy"; RadioGroup radioGroup; RadioButton radioButton1; RadioButton radioButton2; RadioButton radioButton3; @Override protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.activity_radio_button2);  radioGroup=findViewById(R.id.job_list);  radioButton1=findViewById(R.id.radio_button1);  radioButton2=findViewById(R.id.radio_button2);  radioButton3=findViewById(R.id.radio_button3);  radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {   @Override   public void onCheckedChanged(RadioGroup group, int checkedId) {    getYourFavorite(checkedId);   }  }); }  /**  * 根据ID,执行相应的逻辑  * @param buttonId  */ private void getYourFavorite(int buttonId){  switch (buttonId){   case R.id.radio_button1:    if(radioButton1.isChecked()) {     Log.e(TAG, "你最爱的职业是: " + radioButton1.getText().toString());    }    break;   case R.id.radio_button2:    if(radioButton2.isChecked()) {     Log.e(TAG, "你最爱的职业是: " + radioButton2.getText().toString());    }    break;   case R.id.radio_button3:    if(radioButton3.isChecked()) {     Log.e(TAG, "你最爱的职业是: " + radioButton3.getText().toString());    }    break;  } }  /**  * 清除选型  * @param view  */ public void clearAll(View view){  radioGroup.clearCheck(); }}

在布局部分,我们只需要把之前放置在布局中的RadioButton放置在RadioGroup中即可:

<RadioGroup  android:id="@+id/job_list"  android:layout_width="match_parent"  android:layout_height="wrap_content"  android:gravity="center_horizontal">   <RadioButton   android:id="@+id/radio_button1"   android:layout_width="wrap_content"   android:layout_height="wrap_content"   android:layout_marginStart="16dp"   android:layout_marginTop="20dp"   android:text="程序员"   android:textColor="@color/colorPrimaryDark"   android:textSize="25sp" />   <RadioButton   android:id="@+id/radio_button2"   android:layout_width="wrap_content"   android:layout_height="wrap_content"   android:layout_marginStart="16dp"   android:layout_marginTop="11dp"   android:text="政治家"   android:textColor="@color/colorPrimaryDark"   android:textSize="25sp" />   <RadioButton   android:id="@+id/radio_button3"   android:layout_width="wrap_content"   android:layout_height="wrap_content"   android:layout_marginStart="16dp"   android:layout_marginTop="11dp"   android:text="富二代"   android:textColor="@color/colorPrimaryDark"   android:textSize="25sp" /> </RadioGroup>

逻辑部分我们首先为RadioGroup设置状态变化监听:

radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {   @Override   public void onCheckedChanged(RadioGroup group, int checkedId) {    getYourFavorite(checkedId);   }  });

根据选择的RadioButton的ID执行具体的逻辑代码:

 /**  * 根据ID,执行相应的逻辑  * @param buttonId  */ private void getYourFavorite(int buttonId){  switch (buttonId){   case R.id.radio_button1:    if(radioButton1.isChecked()) {     Log.e(TAG, "你最爱的职业是: " + radioButton1.getText().toString());    }    break;   case R.id.radio_button2:    if(radioButton2.isChecked()) {     Log.e(TAG, "你最爱的职业是: " + radioButton2.getText().toString());    }    break;   case R.id.radio_button3:    if(radioButton3.isChecked()) {     Log.e(TAG, "你最爱的职业是: " + radioButton3.getText().toString());    }    break;  } }

注意到在这里我们只实现了数据的获取(RadioButton的文本内容),RadioGroup中的RadioButton之间的状态管理(单选)是RadioGroup内部自己管理的,这为我们节省很多的开发逻辑,也是我们用它的主要目的。此外,这里,我们还可以通过调用clearCheck()实现清除选择状态。

 /**  * 根据ID,执行相应的逻辑  * @param buttonId  */ private void getYourFavorite(int buttonId){  switch (buttonId){   case R.id.radio_button1:    if(radioButton1.isChecked()) {     Log.e(TAG, "你最爱的职业是: " + radioButton1.getText().toString());    }    break;   case R.id.radio_button2:    if(radioButton2.isChecked()) {     Log.e(TAG, "你最爱的职业是: " + radioButton2.getText().toString());    }    break;   case R.id.radio_button3:    if(radioButton3.isChecked()) {     Log.e(TAG, "你最爱的职业是: " + radioButton3.getText().toString());    }    break;  } }

注意到在这里我们只实现了数据的获取(RadioButton的文本内容),RadioGroup中的RadioButton之间的状态管理(单选)是RadioGroup内部自己管理的,这为我们节省很多的开发逻辑,也是我们用它的主要目的。此外,这里,我们还可以通过调用clearCheck()实现清除选择状态。

radioGroup.clearCheck()

运行结果如下所示:

image

同样,如果你觉得RadioButton中的Button样式不好看,你可以自定义一种,这里,我们还是选用上一篇中的样式代码,执行效果如下:

image

修改按钮样式是通过android:button属性:

 <RadioButton   android:id="@+id/radio_button1"   android:button="@drawable/check_box_back"   android:layout_width="wrap_content"   android:layout_height="wrap_content"   android:layout_marginStart="16dp"   android:layout_marginTop="20dp"   android:text="程序员"   android:textColor="@color/colorPrimaryDark"   android:textSize="25sp" />

其中的check_box_back.

<?

该控件的开源项目在网上找了一下,感觉没有什么比较好的,主要是因为它的封装程度已经很高了,如果只是想改动一下显示样式和逻辑,我们自己完全可以实现。好了,关于RadioButton到这里的简单介绍就介绍了。









原文转载:http://www.shaoqun.com/a/494476.html

一淘网:https://www.ikjzd.com/w/1698

costco:https://www.ikjzd.com/w/1680

瀚霖:https://www.ikjzd.com/w/2345


今天,我们的主题是基础控件RadioButton。在开始之前,我们还是以官方文档为开端来开始我们的讲解,下面是Android文档中对RadioButton的简介:看过上一篇文章的应该可以了解到,这个和我们的CheckBox是十分类似的,不同的点在于,这个控件可以由非选中状态通过点击事件转为选中状态,但是不能通过点击实现逆向的状态转换,一个默认样式RadioButton控件的非选中和选中状态如下:其
002315焦点科技:002315焦点科技
国际标准书号:国际标准书号
惠州南昆山有什么好玩的地方吗?:惠州南昆山有什么好玩的地方吗?
本土酒店企业加速"走出去":本土酒店企业加速"走出去"
厦门去哪里泡温泉最好?:厦门去哪里泡温泉最好?

No comments:

Post a Comment