随着市场的不断发展壮大,Android的系统控件样式越来越不能满足Android开发者的需求,所以我们经常就需要修改系统控件,这里我们只是从样式上修改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" />
运行截图如下:
会发现第一个RadioButton前面的圆形不见了,这就是button属性的效果,那么background自然就是给RadioButton添加背景了。
讨论完了RadioButton自定义样式,我们就需要看看RadioButton的应用场景了。由于RadioGroup的button选择是唯一的,就是两个选项是互斥的,利用这个特性,我们很容易就会把它Android的底部导航以及互斥列表导航开发的设计上,我们会分别举例说明。
列表开关导航
运行效果如下:关键代码如下:
<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做出来的,其部分样式如下:
<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的应用还很多,我在这里希望起到抛砖引玉的作用,也希望大家自己多总结,多积累吧。最后欢迎大家和我一起讨论学习,一起提高!