Android selector的属性和使用详解

1.selector中全部属性


2.常用的属性分析

android:state_accessibility_focused是否能够获取焦点
android:state_selected是否选中
android:state_focused是否获得焦点
android:state_pressed是否点击
android:state_enabled设置是否响应事件,指所有事件
android:state_checkable是否可能选中
android:state_checked否是选中
android:state_active是否活动
android:state_activated
android:state_window_focused

3.部分使用代码片(其他的只能看你自己的需求自己搭配)

<?xml version="1.0" encoding="utf-8" ?>     
<selector xmlns:android="http://schemas.android.com/apk/res/android">   
  	<!-- 默认时的背景图片-->    
  	<item android:drawable="@drawable/pic1" />      
	<!-- 没有焦点时的背景图片 -->    
  	<item android:state_window_focused="false" android:drawable="@drawable/pic1" />     
	<!-- 非触摸模式下获得焦点并单击时的背景图片 -->    
  	<item android:state_focused="true" android:state_pressed="true"   android:drawable= "@drawable/pic2" />   
	<!-- 触摸模式下单击时的背景图片-->    
	<item android:state_focused="false" android:state_pressed="true"   android:drawable="@drawable/pic3" />    
	<!--选中时的图片背景-->    
  	<item android:state_selected="true"   android:drawable="@drawable/pic4" />     
	<!--获得焦点时的图片背景-->    
  	<item android:state_focused="true"   android:drawable="@drawable/pic5" />
</selector>  
这里是在checkbox中和radiobutton中使用,checkbox可以当个的切换背景,radiobutton可以多个的在Radiogroup中切换背景
<?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/icon_tabfriends_selected"></item>
	<!--没有选中背景 -->
    <item android:state_checked="false" android:drawable="@drawable/icon_tabfriends_normal"></item>
	<!--默认背景,这里可要可不要 -->
	<item android:drawable="@drawable/icon_tabfriends_normal"></item>
</selector>

4.使用的三种方式

(1)在listview中添加属性

android:listSelector="@drawable/xxx

(2)listview的item中添加属性

android:background="@drawable/xxx"
(3)在java代码中

    Drawable drawable = getResources().getDrawable(R.drawable.xxx);   
    listView.setSelector(drawable);  
为了防止listview滑动变黑,需要在listview中添加

android:cacheColorHint="@android:color/transparent"

可能有些时候你还要用代码去控制一下,单纯的布局还是不行,比如ImageButton你就没有办法去在布局中实现RadioButton的那种效果。


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值