Android Selector 与 Shape 基本用法

转载 2015年07月10日 15:56:11

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"] 

[html] view plaincopy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">  
  3.     <item android:state_enabled="true" android:state_checked="true" android:state_pressed="true"  
  4.           android:drawable="@drawable/enabled_on_pressed" />  
  5.     <item android:state_enabled="true" android:state_checked="false" android:state_pressed="true"  
  6.           android:drawable="@drawable/enabled_off_pressed" />  
  7.     <item android:state_enabled="true" android:state_checked="true"  
  8.           android:drawable="@drawable/enabled_on" />  
  9.     <item android:state_enabled="true" android:state_checked="false"  
  10.           android:drawable="@drawable/enabled_off" />  
  11.     <item android:state_enabled="false" android:state_checked="true"  
  12.           android:drawable="@drawable/disabled_on" />  
  13.     <item android:state_enabled="false" android:state_checked="false"  
  14.           android:drawable="@drawable/disabled_off" />                
  15. </selector>  

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

 

2:Shape

[html] view plaincopy
  1. <shape>  
  2.             <!-- 实心 -->  
  3.             <solid android:color="#ff9d77"/>  
  4.             <!-- 渐变 -->  
  5.             <gradient  
  6.                 android:startColor="#ff8c00"  
  7.                 android:endColor="#FFFFFF"  
  8.                 android:angle="270" />  
  9.             <!-- 描边 -->  
  10.             <stroke  
  11.                 android:width="2dp"  
  12.                 android:color="#dcdcdc" />  
  13.             <!-- 圆角 -->  
  14.             <corners  
  15.                 android:radius="2dp" />  
  16.             <padding  
  17.                 android:left="10dp"  
  18.                 android:top="10dp"  
  19.                 android:right="10dp"  
  20.                 android:bottom="10dp" />  
  21.         </shape>  

solid:实心,就是填充的意思
android:color指定填充的颜色
gradient:渐变
android:startColor和android:endColor分别为起始和结束颜色,ndroid:angle是渐变角度,必须为45的整数倍
另外渐变默认的模式为android:type="linear",即线性渐变,可以指定渐变为径向渐变,android:type="radial",径向渐变需要指定半径android:gradientRadius="50"。
stroke:描边
android:width="2dp" 描边的宽度,android:color 描边的颜色。
我们还可以把描边弄成虚线的形式,设置方式为:
android:dashWidth="5dp" 
android:dashGap="3dp"
其中android:dashWidth表示'-'这样一个横线的宽度,android:dashGap表示之间隔开的距离。
corners:圆角
android:radius为角的弧度,值越大角越圆。
我们还可以把四个角设定成不同的角度,方法为:
<corners 
        android:topRightRadius="20dp"    右上角
        android:bottomLeftRadius="20dp"    右下角
        android:topLeftRadius="1dp"    左上角
        android:bottomRightRadius="0dp"    左下角
 />
这里有个地方需要注意,bottomLeftRadius是右下角,而不是左下角,这个有点郁闷,不过不影响使用,记得别搞错了就行。
还有网上看到有人说设置成0dp无效,不过我在测试中发现是可以的,我用的是2.2,可能修复了这个问题吧,如果无效的话那就只能设成1dp了。
padding:间隔

button_selector.xml:

[html] view plaincopy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <selector  
  3.     xmlns:android="http://schemas.android.com/apk/res/android">  
  4.     <item android:state_pressed="true" >  
  5.         <shape>  
  6.             <!-- 渐变 -->  
  7.             <gradient  
  8.                 android:startColor="#ff8c00"  
  9.                 android:endColor="#FFFFFF"  
  10.                 android:type="radial"  
  11.                 android:gradientRadius="50" />  
  12.             <!-- 描边 -->  
  13.             <stroke  
  14.                 android:width="2dp"  
  15.                 android:color="#dcdcdc"  
  16.                 android:dashWidth="5dp"   
  17.                 android:dashGap="3dp" />  
  18.             <!-- 圆角 -->  
  19.             <corners  
  20.                 android:radius="2dp" />  
  21.             <padding  
  22.                 android:left="10dp"  
  23.                 android:top="10dp"  
  24.                 android:right="10dp"  
  25.                 android:bottom="10dp" />  
  26.         </shape>  
  27.     </item>  
  28.   
  29.     <item android:state_focused="true" >  
  30.         <shape>  
  31.             <gradient  
  32.                 android:startColor="#ffc2b7"  
  33.                 android:endColor="#ffc2b7"  
  34.                 android:angle="270" />  
  35.             <stroke  
  36.                 android:width="2dp"  
  37.                 android:color="#dcdcdc" />  
  38.             <corners  
  39.                 android:radius="2dp" />  
  40.             <padding  
  41.                 android:left="10dp"  
  42.                 android:top="10dp"  
  43.                 android:right="10dp"  
  44.                 android:bottom="10dp" />  
  45.         </shape>  
  46.     </item>  
  47.   
  48.     <item>         
  49.         <shape>  
  50.             <solid android:color="#ff9d77"/>  
  51.             <stroke  
  52.                 android:width="2dp"  
  53.                 android:color="#fad3cf" />  
  54.             <corners   
  55.                 android:topRightRadius="5dp"  
  56.                 android:bottomLeftRadius="5dp"  
  57.                 android:topLeftRadius="0dp"  
  58.                 android:bottomRightRadius="0dp"  
  59.             />  
  60.             <padding  
  61.                 android:left="10dp"  
  62.                 android:top="10dp"  
  63.                 android:right="10dp"  
  64.                 android:bottom="10dp" />  
  65.         </shape>  
  66.     </item>  
  67. </selector>  

运行效果如下图:

一般状态:


获得焦点状态:


按下状态:

Selector与Shape的基本用法

1. Selector drawable 的 item 中可以有以下属性: android:drawable ="@drawable/drawable_resource" android:st...
  • lzt623459815
  • lzt623459815
  • 2013年01月24日 16:36
  • 3523

探索Android中selector和shape的结合使用

Android中的Selector(背景选择器)主要是用来改变一个按钮控件的背景,在Android UI设计中经常会遇到,比如我们在点击Button时需要有些效果的变化,这时候就要用到和。和对美化控件...
  • qq_20785431
  • qq_20785431
  • 2015年12月06日 21:10
  • 9521

shape selector一起使用

xmlns:android="http://schemas.android.com/apk/res/android">                    android:shape="re...
  • xcmax
  • xcmax
  • 2015年01月24日 12:26
  • 856

Selector中嵌套Shape

通常情况下,为了更好的复用性,我们都是分别在两个xml文件中写shape和selector,然后在selector中引用shape。但是如果这个shape只在一个selector中使用,不存在其他的复...
  • north1989
  • north1989
  • 2016年10月26日 12:02
  • 745

Android Selector 与 Shape 基本用法

1:Selector  drawable的item中可以有以下属性:  android:drawable="@[package:]drawable/drawable_resource" a...
  • liuhanhan512
  • liuhanhan512
  • 2013年12月01日 09:55
  • 646

Android Selector 与 Shape 基本用法

1:Selector drawable的item中可以有以下属性: android:drawable="@[package:]drawable/drawable_resource" android:s...
  • wswqiang
  • wswqiang
  • 2011年07月19日 11:07
  • 40977

Android中shape和selector的使用详解

shape的基本用法就是在res/drawable下定义一个xml文件用于定义shape,然后在布局控件中如Button,TextView等中用background使用shape。 先了解shape的...
  • jiangtea
  • jiangtea
  • 2016年08月07日 11:02
  • 661

selector嵌套shape

  • lonewolf521125
  • lonewolf521125
  • 2015年08月25日 14:38
  • 1720

selector,shape的自定义使用

1.selector的使用详解 1.创建selector的xml资源文件 右击drawable目录--》点击new--》Drawable resource file 这样selector资源...
  • zhangxing52077
  • zhangxing52077
  • 2016年09月27日 12:25
  • 343

Android Drawable资源中selector、layer-list和shape标签详解

在实际开发中,我们经常会对控件的样式进行一些修改已满足我们的要求,这时候就会引用 Drawable 资源的样式文件。 1、StateListDrawable 资源         StateListD...
  • liuwan1992
  • liuwan1992
  • 2016年10月15日 21:16
  • 3736
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android Selector 与 Shape 基本用法
举报原因:
原因补充:

(最多只允许输入30个字)