• 浅谈android的selector,背景选择器


    shape和selector的结合使用

     (2013-04-07 11:11:00)
      分类: android
    1、Shape
    (1)作用:XML中定义的几何形状
    (2)位置:res/drawable/文件的名称.xml
    (3)使用的方法:
    Java代码中:R.drawable.文件的名称
    XML中:Android:background="@drawable/文件的名称"
    (4)shape 属性:
    <shape> Android:shape=["rectangle" | "oval" | "line" | "ring"]
    其中rectagle矩形,oval椭圆,line水平直线,ring环形
    (5)<shape> 中子节点的常用属性:
    <gradient> 渐变
    Android:startColor 起始颜色
    Android:endColor 结束颜色
    Android:angle 渐变角度,0从上到下,90表示从左到右,数值为45的整数倍默认为0;
    Android:type 渐变的样式 liner线性渐变 radial环形渐变 sweep
     
    <solid > 填充
    Android:color 填充的颜色
     
    <stroke > 描边
    Android:width 描边的宽度
    Android:color 描边的颜色
    Android:dashWidth 表示'-'横线的宽度
    Android:dashGap 表示'-'横线之间的距离
     
    <corners > 圆角
    Android:radius 圆角的半径 值越大角越圆
    Android:topRightRadius 右上圆角半径
    Android:bottomLeftRadius 右下圆角角半径
    Android:topLeftRadius 左上圆角半径
    Android:bottomRightRadius 左下圆角半径
    2、Selector
    (1)位置:res/drawable/文件的名称.xml
    (2)使用的方法:
    Java代码中:R.drawable.文件的名称
    XML中:Android:background="@drawable/文件的名称"
    (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/pic_blue"
    />
    <!-- 非触摸模式下获得焦点并单击时的背景图片 -->
    <item
    Android:state_focused="true"
    android:state_pressed="true"
    android:drawable= "@drawable/pic_red"
    />
    <!-- 触摸模式下单击时的背景图片-->
    <item
    Android:state_focused="false"
    Android:state_pressed="true"
    Android:drawable="@drawable/pic_pink"
    />
    <!--选中时的图片背景-->
    <item
    Android:state_selected="true"
    android:drawable="@drawable/pic_orange"
    />
    <!--获得焦点时的图片背景-->
    <item
    Android:state_focused="true"
    Android:drawable="@drawable/pic_green"
    />
    </selector>
     
    eg:shape+selector综合使用
    selector.xml
    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:Android="http://schemas.android.com/apk/res/android">
    <item Android:state_selected="true">
    <shape>
    <gradient Android:angle="270" android:endColor="#99BD4C"
    android:startColor="#A5D245" />
    <size Android:height="60dp" android:width="320dp" />
    <corners android:radius="8dp" />
    </shape>
    </item>
    <item Android:state_pressed="true">
    <shape>
    <gradient Android:angle="270" android:endColor="#99BD4C"
    android:startColor="#A5D245"/>
    <size Android:height="60dp" android:width="320dp" />
    <corners android:radius="8dp" />
    </shape>

    //--------------------------------------------------------------------

    关于listview和button都要改变android原来控件的背景,在网上查找了一些资料不是很全,所以现在总结一下android的selector的用法。
    首先android的selector是在drawable/xxx.xml中配置的。
    先看一下listview中的状态:
    把下面的XML文件保存成你自己命名的.xml文件(比如list_item_bg.xml),在系统使用时根据ListView中的列表项的状态来使用相应的背景图片。
    drawable/list_item_bg.xml
    <?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>
    使用些xml文件:第一种是在listview中配置android:listSelector="@drawable/list_item_bg
    或者在listview的item中添加属性android:background=“@drawable/list_item_bg"即可实现,或者在java代码中使用:Drawable drawable = getResources().getDrawable(R.drawable.list_item_bg);  
           ListView.setSelector(drawable);同样的效果。
    但是这样会出现列表有时候为黑的情况,需要加上:
    android:cacheColorHint="@android:color/transparent"
    使其透明。
    其次再来看看Button的一些背景效果:

    android:state_selected是选中
    android:state_focused是获得焦点
    android:state_pressed是点击
    android:state_enabled是设置是否响应事件,指所有事件
    根据这些状态同样可以设置button的selector效果。也可以设置selector改变button中的文字状态。
    以下就是配置button中的文字效果:
    drawable/button_font.xml
    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:state_selected="true" android:color="#FFF" />
        <item android:state_focused="true" android:color="#FFF" />
        <item android:state_pressed="true" android:color="#FFF" />
        <item android:color="#000" />
    </selector>
    Button还可以实现更复杂的效果,例如渐变啊等等。
    drawable/button_color.xml
    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">         / 
            <item android:state_pressed="true">//定义当button 处于pressed 状态时的形态。 
                  <shape> 
                         <gradient  android:startColor="#8600ff" /> 
                          <stroke   android:width="2dp" android:color="#000000" /> 
                           <corners android:radius="5dp" />  
                           <padding android:left="10dp" android:top="10dp" 
                                    android:bottom="10dp" android:right="10dp"/>  
                     </shape> 
            </item> 
            <item android:state_focused="true">//定义当button获得 focus时的形态 
                     <shape> 
                           <gradient android:startColor="#eac100"/> 
                            <stroke android:width="2dp" android:color="#333333"  color="#ffffff"/> 
                             <corners android:radius="8dp" />   
                             <padding android:left="10dp" android:top="10dp" 
                                      android:bottom="10dp" android:right="10dp"/>                   
                    </shape> 
                </item>
    </selector> 
         最后,需要在包含 button的xml文件里添加两项。假如是 main.xml 文件,
    我们需要在<Button />里加两项。 
         android:focusable="true" 
         android:backgroud="@drawable/button_color"
    这样当你使用Button的时候就可以甩掉系统自带的那黄颜色的背景了,实现个性化的背景,配合应用的整体布局非常之有用啊。

     

    Android_selector标签和shape标签

    分类: 【Android_Layout/Activity】 297人阅读 评论(0) 收藏 举报

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

    使用方法:

    • 在res文件夹下新建drawable文件夹
    • 在drawable下新建XXX.xml
    • Java代码中:R.drawable.XXX          XML中:android:background="@drawable/XXX"

    selector描述:

    selector比较常用的属性:android:state_pressed和android:state_focused

    [html] view plaincopy
     
    1. <?xml version="1.0" encoding="utf-8"?>  
    2. <selector xmlns:android="http://schemas.android.com/apk/res/android">  
    3.   
    4.     <!-- 默认时的背景图片 -->  
    5.     <item android:drawable="@drawable/button" />  
    6.   
    7.     <!-- 按下状态 -->  
    8.     <item android:state_pressed="true" android:drawable="@drawable/button_pressed_true"/>  
    9.   
    10.     <!-- 焦点状态 -->  
    11.     <item android:state_focused="true" android:drawable="@drawable/button_focused_true"/>  
    12.   
    13.     <!-- 非焦点状态 -->  
    14.     <item android:state_focused="false" android:drawable="@drawable/button_focused_false"/></selector>  

    
    

    其他几个不常用的属性:

    [html] view plaincopy
     
    1. <?xml version="1.0" encoding="utf-8"?>  
    2. <selector xmlns:android="http://schemas.android.com/apk/res/android">  
    3.   
    4.     <!-- CheckBox非选中状态 -->      
    5.     <item android:state_checked="false" android:drawable="@drawable/unchecked" />  
    6.   
    7.     <!-- CheckBox选中状态 -->    
    8.     <item android:state_checked="true" android:drawable="@drawable/checked" />  
    9. </selector>  

    android:state_selected:

    true,当被选择时显示该图片;false,当未被选择时显示该图片。

    android:state_checkable

    true,当CheckBox能使用时显示该图片;false,当CheckBox不能使用时显示该图片。

    android:state_enabled

    true,当该组件能使用时显示该图片;false,当该组件不能使用时显示该图片。

    android:state_window_focused

    true,当此activity获得焦点在最前面时显示该图片;false,当没在最前面时显示该图片。

    shape描述:

    先看一个例子:

    [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_pressed="true">  
    4.         <shape>  
    5.             <!-- 渐变 -->  
    6.             <gradient android:endColor="#FFFFFF" android:gradientRadius="25" android:startColor="#ff8c00" android:type="sweep" />  
    7.             <!-- 描边 -->  
    8.             <stroke android:dashGap="30dp" android:dashWidth="5dp" android:width="2dp" android:color="#dcdcdc" />  
    9.             <!-- 圆角 -->  
    10.             <corners android:radius="2dp" />  
    11.             <padding android:bottom="10dp" android:left="10dp" android:right="10dp" android:top="10dp" />  
    12.         </shape>  
    13.     </item>  
    14.     <item android:state_focused="true">  
    15.         <shape>  
    16.             <gradient android:angle="270" android:endColor="#FFFFFF" android:startColor="#ff8c00" />  
    17.             <stroke android:width="2dp" android:color="#dcdcdc" />  
    18.             <corners android:radius="2dp" />  
    19.             <padding android:bottom="10dp" android:left="10dp" android:right="10dp" android:top="10dp" />  
    20.         </shape>  
    21.     </item>  
    22.     <item>  
    23.         <shape>  
    24.             <solid android:color="#ff9d77" />  
    25.             <stroke android:width="2dp" android:color="#fad3cf" />  
    26.             <corners android:bottomLeftRadius="5dp" android:bottomRightRadius="0dp" android:topLeftRadius="0dp" android:topRightRadius="5dp" />  
    27.             <padding android:bottom="10dp" android:left="10dp" android:right="10dp" android:top="10dp" />  
    28.         </shape>  
    29.     </item>  
    30. </selector>  

    属性说明:
    • solid:实心,就是填充的意思

    android:color指定填充的颜色

     

    • gradient:渐变

    android:startColorandroid:endColor分别为起始和结束颜色,android:angle是渐变角度,必须为45的整数倍。

    渐变默认的模式为android:type="linear",即线性渐变

    可以指定渐变为径向渐变,android:type="radial",径向渐变需要指定半径android:gradientRadius="50"

    另外还有android:type="sweep"可以试下效果

    • stroke:描边

    android:width="2dp" 描边的宽度      android:color描边的颜色。

    我们还可以把描边弄成虚线的形式,设置方式为:android:dashWidth="5dp"

    android:dashWidth表示虚线的宽度    android:dashGap表示两个横线之间隔开的距离(“-   -   -”)

    • corners:圆角

    android:radius为角的弧度,值越大角越圆。

    我们还可以把四个角设定成不同的角度,方法为:

    <corners  

            android:topRightRadius="20dp"    右上角  

            android:bottomLeftRadius="20dp"    左下角  

            android:topLeftRadius="1dp"    左上角  

            android:bottomRightRadius="0dp"    右下角  

    />  

    • padding:间隔

    这个就不用多说了,XML布局文件中经常用到。

  • 相关阅读:
    Hadoop Gateway 部署
    java 命令--备忘
    整理下常用硬件性能参数
    python 脚本备份 mysql 数据库到 OSS
    pip 更换国内源
    记录闭包和立即执行函数
    Django 中文乱码问题&富文本显示
    mysql exceeded the 'max_questions' resource 记录
    sql server 数据字典的妙用
    Sublime Text指南
  • 原文地址:https://www.cnblogs.com/fx2008/p/3247630.html
Copyright © 2020-2023  润新知