Android : 巧用RadioGroup作为Tab切换的按钮

主流Tab切换式布局,设置RadioButton 的Style变换Tab切换按钮

 
  
文字颜色
tab_selector.xml

<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_checked="true" android:color="#C7513D"/>
    <item android:state_checked="false" android:color="#545454"/>
    <item android:color="@android:color/darker_gray"/>

</selector>

RadioButton 样式
style.xml

 <style name="tab_rb_style">
        <item name="android:layout_width">0dp</item> <!-- 宽度为0dp -->
        <!-- 高度为包裹内容 -->
        <item name="android:layout_height">wrap_content</item>
        <!-- 按照比重适配屏幕宽度, -->
        <item name="android:layout_weight">1.0</item>  
        <!-- 选中/未选中文本颜色 这里用selector -->
        <item name="android:textColor">@color/tab_selector</item> 
        <item name="android:gravity">center</item> 
        <item name="android:textSize">10sp</item>
        <item name="android:layout_gravity">center</item>
        <!-- 隐藏radioButton 圆点选中按钮图片 -->
        <item name="android:button">@null</item> 
        <item name="android:background">@null</item><!-- 将背景置为空 -->
        <item name="android:layout_margin">6dp</item><!-- 上下左右边距 -->
    </style>

使用方式

 <RadioGroup
        android:id="@+id/tab_rg_menu"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:background="@android:color/white"
        android:orientation="horizontal" >

        <RadioButton
            android:id="@+id/tab_rb_1"
            style="@style/tab_rb_style"
            android:drawableTop="@drawable/tab_dismantle_01"
            android:text="@string/tab_name_01" />

        <RadioButton
            android:id="@+id/tab_rb_2"
            style="@style/tab_rb_style"
            android:drawableTop="@drawable/tab_dismantle_02"
            android:text="@string/tab_name_02" />

        <RadioButton
            android:id="@+id/tab_rb_3"
            style="@style/tab_rb_style"
            android:checked="true"
            android:drawableTop="@drawable/tab_dismantle_03"
            android:text="@string/tab_name_03" />

        <RadioButton
            android:id="@+id/tab_rb_4"
            style="@style/tab_rb_style"
            android:drawableTop="@drawable/tab_dismantle_04"
            android:text="@string/tab_name_04" />

        <RadioButton
            android:id="@+id/tab_rb_5"
            style="@style/tab_rb_style"
            android:drawableTop="@drawable/tab_dismantle_05"
            android:text="@string/tab_name_05" />
    </RadioGroup>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值