Bootstrap

自定义RadioGroup样式

                随着市场的不断发展壮大,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制作底部导航

在这里,我那以前项目中用到两个导航运行效果如下:
                                                                           
项目下载地址: 项目一点击下载     ;项目二点击下载
此处需要说明的是,第一个项目不是使用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的应用还很多,我在这里希望起到抛砖引玉的作用,也希望大家自己多总结,多积累吧。最后欢迎大家和我一起讨论学习,一起提高!


;