zoukankan      html  css  js  c++  java
  • AndroidA——背景选择器selector用法汇总(一)

    一.创建xml文件,位置:drawable/xxx.xml,同目录下记得要放相关图片

     

    [html] view plain copy
     
    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/handle_normal" android:state_enabled="true" android:state_window_focused="false"/>  
    6.     <!-- 触摸模式按下时的背景图片 -->  
    7.     <item android:drawable="@drawable/handle_pressed" android:state_pressed="true"/>  
    8.     <item android:drawable="@drawable/handle_focused" android:state_enabled="true" android:state_focused="true"/>  
    9.     <item android:drawable="@drawable/handle_normal" android:state_enabled="true"/>  
    10.     <!-- 获得焦点时的图片背景 -->  
    11.     <item android:drawable="@drawable/handle_focused" android:state_focused="true"/>  
    12.   
    13.     <!--  
    14.     android:state_selected是选中  
    15.     android:state_focused是获得焦点  
    16.     android:state_pressed是点击  
    17.     android:state_enabled是设置是否响应事件,指所有事件  
    18.     -->  
    19.   
    20. </selector>  

    .使用xml文件:

    1.方法一:在listview中配置android:listSelector="@drawable/xxx
    或者在listview的item中添加属性android:background="@drawable/xxx"

    2.方法二:Drawable drawable = getResources().getDrawable(R.drawable.xxx);  
           ListView.setSelector(drawable);但是这样会出现列表有时候为黑的情况,需要加上:android:cacheColorHint="@android:color/transparent"使其透明。

    相关属性:

    android:state_selected是选中
    android:state_focused是获得焦点
    android:state_pressed是点击
    android:state_enabled是设置是否响应事件,指所有事件

    根据这些状态同样可以设置button的selector效果。也可以设置selector改变button中的文字状态。


    以下是配置button中的文字效果:
    drawable/button_font.xml

    [html] view plain copy
     
    1. <?xml version="1.0" encoding="utf-8"?>  
    2. <selector xmlns:android="http://schemas.android.com/apk/res/android">  
    3.     <item android:state_selected="true" android:color="#FFF" />  
    4.     <item android:state_focused="true" android:color="#FFF" />  
    5.     <item android:state_pressed="true" android:color="#FFF" />  
    6.     <item android:color="#000" />  
    7. </selector>  
    Button还可以实现更复杂的效果,例如渐变
    drawable/button_color.xml

     

    [html] view plain copy
     
    1. <span style="color:#330033;"><?xml version="1.0" encoding="utf-8"?>  
    2. <selector xmlns:android="http://schemas.android.com/apk/res/android">         /   
    3. <item android:state_pressed="true">//定义当button 处于pressed 状态时的形态。   
    4.                 <shape>  
    5.                 <gradient  android:startColor="#8600ff" />   
    6.                       <stroke   android:width="2dp" android:color="#000000" />   
    7.                        <corners android:radius="5dp" />    
    8.                        <padding android:left="10dp" android:top="10dp"   
    9.                                 android:bottom="10dp" android:right="10dp"/>    
    10.                  </shape>   
    11. </item>   
    12. <item android:state_focused="true">//定义当button获得 focus时的形态   
    13.                  <shape>   
    14.                        <gradient android:startColor="#eac100"/>   
    15.                        <stroke android:width="2dp" android:color="#333333"  color="#ffffff"/>   
    16.                        <corners android:radius="8dp" />     
    17.                        <padding android:left="10dp" android:top="10dp"   
    18.                                 android:bottom="10dp" android:right="10dp"/>                     
    19.                 </shape>   
    20.  </item>  
    21. </selector></span><span style="color:#ff0000;"</span>  
    最后,需要在包含 button的xml文件里添加两项。例如main.xml 文件,需要在<Button />里加两项android:focusable="true" android:background="@drawable/button_color"这样就把drawale/button_color.xml文件与这个控件关联起来了。
     
     
     
  • 相关阅读:
    Oracle 12c中文乱码,修改字符集的方法
    C++设计模式——简单工厂模式与策略模式比较
    C++设计模式——工厂模式Factory Method
    JavaWeb——Servlet基础
    C++设计模式——装饰模式Bridge-Pattern
    线性代数思维导图(2)——矩阵
    线性代数思维导图(1)——行列式
    C++设计模式——适配器模式Bridge-Pattern
    C++设计模式——桥接模式Bridge-Pattern
    不想写博客?那试试日记吧!
  • 原文地址:https://www.cnblogs.com/Chenshuai7/p/5519721.html
Copyright © 2011-2022 走看看