自定义RadioGroup样式

时间:2022-09-07 22:43:35
                随着市场的不断发展壮大,Android的系统控件样式越来越不能满足Android开发者的需求,所以我们经常就需要修改系统控件,这里我们只是从样式上修改RadioGroup,不并非从功能上去扩展组件。废话不多说,我们先看看RadioGroup的原生态样式如下:                                                       自定义RadioGroup样式                                                                                  可以看到RadioGroup的原生控件的样式就是这个样式的.需要说明的是:RadioGroup的长相受到它button和backgroud两个属性的影响!当我们设置button属性为null时,代码如下: 
        <RadioButton
android:id="@+id/rb1"
android:layout_width="0px"
android:layout_height="match_parent"
android:layout_weight="1"
android:checked="true"
android:gravity="center"
android:button="@null"
android:text="今日头条"
android:textSize="17sp" />


运行截图如下:
                                                 自定义RadioGroup样式                                                                                                                                 
               会发现第一个RadioButton前面的圆形不见了,这就是button属性的效果,那么background自然就是给RadioButton添加背景了。
               讨论完了RadioButton自定义样式,我们就需要看看RadioButton的应用场景了。由于RadioGroup的button选择是唯一的,就是两个选项是互斥的,利用这个特性,我们很容易就会把它Android的底部导航以及互斥列表导航开发的设计上,我们会分别举例说明。

列表开关导航

运行效果如下:
                                                                                自定义RadioGroup样式
关键代码如下:
  
<relativelayout android:id="@+id/course_layout" android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1">

<linearlayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_centervertical="true" android:orientation="vertical">

<imageview android:id="@+id/course_image" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:src="@drawable/book_normal">

<textview android:id="@+id/course_text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:text="推荐" android:textcolor="#7597B3">
</textview></imageview></linearlayout>
</relativelayout>

            可以看出,通过给RadioGroup和RadioButton设置backgroud属性,可以使得RadioGroup设计出非常优雅的样式。需要完整代码的,单击源码下载

RadioGroup制作底部导航

在这里,我那以前项目中用到两个导航运行效果如下:
                                         自定义RadioGroup样式                                 自定义RadioGroup样式
项目下载地址:项目一点击下载    ;项目二点击下载
此处需要说明的是,第一个项目不是使用RadioGroup做出来的,其部分样式如下:
       <RelativeLayout
android:id="@+id/course_layout"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1" >

<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:orientation="vertical" >

<ImageView
android:id="@+id/course_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:src="@drawable/book_normal" />

<TextView
android:id="@+id/course_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:text="推荐"
android:textColor="#7597B3" />
</LinearLayout>
</RelativeLayout>


可以看到,此处使用线性布局里添加IamgeView和TextView组成,而第二个项目则是使用RadioGroup写的,关键代码如下:
 <RadioButton
android:id="@+id/homeRb"
style="@style/main_tab_style"
android:checked="true"
android:drawableTop="@drawable/main_tab_home_img"
android:text="@string/nav_home"
android:textColor="@drawable/main_tab_text_color" />


通过设置 drawableTop设置在文本上面添加图片,同时设置文本颜色的切换效果,选中该项时,文字为红色,未选中时文字为黑色.代码如下:
 <?xml version="1.0" encoding="UTF-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools">

<item android:state_focused="true" android:color="@color/red"></item>
<item android:state_pressed="true" android:color="@color/red"></item>
<item android:state_selected="true" android:color="@color/red"></item>
<item android:state_checked="true" android:color="@color/red"></item>
<item android:color="@color/black"></item>
</selector>
注意修改文字的颜色,在selector中是android:color=""而不是android:drawable=""属性了.
      RadioGroup的应用还很多,我在这里希望起到抛砖引玉的作用,也希望大家自己多总结,多积累吧。最后欢迎大家和我一起讨论学习,一起提高!