android中自定义radiobutton的背景色选择默认图标

转载自 [http://mypyg.iteye.com/blog/768471]

RadioButton长成什么样子是由其Background、Button等属性决定的,Android系统
使用style定义了默认的属性,在android源码
android/frameworks/base/core/res/res/values/styles.xml中可以看到默认的定义:

<style name="Widget.CompoundButton.RadioButton">  
<item name="android:background">@android:drawable/btn_radio_ label_background</item>  
<item name="android:button">@android:drawable/btn_radio</item>  
</style>  

即其背景图是btn_radio_label_background,其button的样子是btn_radio

btn_radio_label_background是什么?
其路径是android/frameworks/base/core/res/res/drawable-mdpi/btn_radio_label_background.9.png
可以看到是一个NinePatch图片,用来做背景,可以拉伸填充。

btn_radio是什么?
其路径是android/frameworks/base/core/res/res/drawable/btn_radio.xml
是个xml定义的drawable,打开看其内容:

<selector xmlns:android="http://schemas.android.com/apk/res/android">      
<item android:state_checked="true" android:state_window_focused="false"  
 android:drawable="@drawable/btn_radio_on" />  
<item android:state_checked="false" android:state_window_focused="false"  
android:drawable="@drawable/btn_radio_off" />  
<item android:state_checked="true" android:state_pressed="true"  
android:drawable="@drawable/btn_radio_on_pressed" />  
<item android:state_checked="false" android:state_pressed="true"  
android:drawable="@drawable/btn_radio_off_pressed" />  
<item android:state_checked="true" android:state_focused="true"  
 android:drawable="@drawable/btn_radio_on_selected" />  
<item android:state_checked="false" android:state_focused="true"  
 android:drawable="@drawable/btn_radio_off_selected" />  
<item android:state_checked="false" android:drawable="@drawable/btn_radio_off" />  
<item android:state_checked="true" android:drawable="@drawable/btn_radio_on" />  
</selector>  
<item android:state_checked="true" android:state_pressed="true" 
          android:drawable="@drawable/btn_radio_on_pressed" /> 

意思即为当radiobutton被选中时,并且被按下时,其Button应该长成btn_radio_on_pressed这个样子

(3)使用xml描述一个drawable
在res/drawable/创建custom_radio_btn.xml

<?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="true" android:state_pressed="true"  
android:drawable="@drawable/enabled_on_pressed" />  
<item android:state_enabled="true" android:state_checked="false" android:state_pressed="true"  
android:drawable="@drawable/enabled_off_pressed" />  
<item android:state_enabled="true" android:state_checked="true"  
android:drawable="@drawable/enabled_on" />  
<item android:state_enabled="true" android:state_checked="false"  
android:drawable="@drawable/enabled_off" />  
<item android:state_enabled="false" android:state_checked="true"  
android:drawable="@drawable/disabled_on" />  
<item android:state_enabled="false" android:state_checked="false"  
android:drawable="@drawable/disabled_off" />                
</selector>  

Item顺序是有讲究的,条件限定越细致,则应该放到前面。比如这儿如果把1,2行和3,4行的item交换,那么pressed的就永远无法触发了,因为有item已经满足条件返回了。可以理解为代码中的if语句。

创建一个自定义的style,并应用到RaidioButton的style属性上

<style name="CustomRadioBtn">  
<item name="android:background">@drawable/radio_btn_bg</item>  
<item name="android:button">@drawable/custom_radio_btn</item>  
</style>  
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值