实例详解Android Selector和Shape的用法

2019-12-10 19:13:27于丽
shape和selector是Android UI设计中经常用到的,比如我们要自定义一个圆角Button,点击Button有些效果的变化,就要用到shape和selector,通过本文结合代码实例给大家详解Android Selector和Shape的用法,感兴趣的朋友一起学习吧  

shape和selector是Android UI设计中经常用到的,比如我们要自定义一个圆角Button,点击Button有些效果的变化,就要用到shape和selector。可以这样说,shape和selector在美化控件中的作用是至关重要的。

1:Selector

drawable的item中可以有以下属性:

android:drawable="@[package:]drawable/drawable_resource" 
android:state_pressed=["true" | "false"] 
android:state_focused=["true" | "false"] 
android:state_selected=["true" | "false"] 
android:state_active=["true" | "false"] 
android:state_checkable=["true" | "false"] 
android:state_checked=["true" | "false"] 
android:state_enabled=["true" | "false"] 
android:state_window_focused=["true" | "false"]

<?xml version="1.0" encoding="utf-8"?> 
<selector xmlns:android="http://www.easck.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语句。