填坑总结:通过selector的android:state_checkable和android:state_checked设置RadioButton的背景色切换遇到的问题

 目的(需求): 

   想通过selector的android:state_checkable和android:state_checked不可选按钮为灰,可选没选中为白,

   可选已选中为红的效果。

layout的xml代码:

<android.support.v7.widget.AppCompatRadioButton
        android:id="@+id/radio_id1"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:background="@drawable/drawable_selector_btn"
        android:button="@null"
        android:clickable="true"
        android:focusable="true"
        android:gravity="center_horizontal"
        android:padding="8dp"
        android:layout_marginLeft="16dp">
    
</android.support.v7.widget.AppCompatRadioButton>

selector的代码:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checkable="false" android:drawable="@drawable/corners_gray" />
    <item android:state_checked="true" android:drawable="@drawable/corners_red" />
    <item android:state_checked="false" android:drawable="@drawable/corners_unclickable" />
</selector>

坑:

layout没有设置(也没有相应的android:属性可设置)相应的checkable的值为true/false,

所以,当使用了上面的selector代码时,对应的单选钮的checkable就被设置为第一个item对应的false

,显示的app的一直不可以check(选中)。

如果把selector的更改为

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="true" android:drawable="@drawable/corners_red" />
    <item android:state_checked="false" android:drawable="@drawable/corners_unclickable" />
    <item android:state_checkable="false" android:drawable="@drawable/corners_gray" />
</selector>

这时,

对应的单选钮的checkable就被设置为true

显示的app的=一直为可选或者未选中状态。

 

解决方式:(正道)

通过layout的android:enabled,selector的android:state_enabled和android:state_checked实现不可选按钮为灰,可选没选中为白,可选已选中为红的效果。

<android.support.v7.widget.AppCompatRadioButton
android:id="@+id/radio_id1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:background="@drawable/drawable_selector_btn"
android:button="@null"
android:enabled="true"
android:focusable="true"
android:gravity="center_horizontal"
android:padding="8dp"
android:layout_marginLeft="16dp">

</android.support.v7.widget.AppCompatRadioButton>

---------------------------------------

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_enabled="true" android:state_checked="false" android:drawable="@drawable/corners_gray" />
    <item android:state_enabled="true" android:state_checked="true" android:drawable="@drawable/corners_red" />
    <item android:state_enabled="false" android:drawable="@drawable/corners_unclickable" />
</selector>
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值