zoukankan      html  css  js  c++  java
  • Android之drawable state各个属性详解

     

    我们在定义一个drawable的时候可以通过xml定义的drawable对象。它使得一个图片能在不同的状态下显示不同的图案,比如一个 Button,它有pressed,focused,或者其它状态,通过使用state list drawable,你就可以为每种状态提供不同的图片。

    先看一个范例:

    XML file saved at res/drawable/button.xml:

    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" android:state_enabled="true" android:state_window_focused="false"  
    4.           android:drawable="@drawable/button_pressed" /> <!-- pressed,enable等多个属性 -->  
    5.     <item android:state_focused="true"  
    6.           android:drawable="@drawable/button_focused" /> <!-- focused -->  
    7.     <item android:state_hovered="true"  
    8.           android:drawable="@drawable/button_focused" /> <!-- hovered -->  
    9.     <item android:drawable="@drawable/button_normal" /> <!-- default -->  
    10. </selector>  


     

    This layout XML applies the state list drawable to a Button:

    1. <Button  
    2.     android:layout_height="wrap_content"  
    3.     android:layout_width="wrap_content"  
    4.     android:background="@drawable/button" />  



    android:drawable 放一个drawable资源
    android:state_pressed 是否按下,如一个按钮触摸或者点击。
    android:state_focused 是否取得焦点,比如用户选择了一个文本框。
    android:state_hovered 光标是否悬停,通常与focused state相同,它是4.0的新特性
    android:state_selected 被选中,它与focus state并不完全一样,如一个list view 被选中的时候,它里面的各个子组件可能通过方向键,被选中了。
    android:state_checkable 组件是否能被check。如:RadioButton是可以被check的。
    android:state_checked 被checked了,如:一个RadioButton可以被check了。
    android:state_enabled 能够接受触摸或者点击事件
    android:state_activated 被激活(这个麻烦举个例子,不是特明白)
    android:state_window_focused 应用程序是否在前台,当有通知栏被拉下来或者一个对话框弹出的时候应用程序就不在前台了

     

    注意:如果有多个item,那么程序将自动从上到下进行匹配,最先匹配的将得到应用。(不是通过最佳匹配)
    如果一个item没有任何的状态说明,那么它将可以被任何一个状态匹配。

     

    详细的请看官方的API,那里写的更详细~!http://developer.android.com/guide/topics/resources/drawable-resource.html#StateList
  • 相关阅读:
    July 22nd 2017 Week 29th Saturday
    July 21st 2017 Week 29th Friday
    社交类APP原型模板分享——QQ
    专访UI中国认证设计师卤大湿 | 一位UI大师关于UI设计的思考
    第十届Mockplus ▪ UXPA用户体验西南赛区决赛成功举行
    【附案例】UI交互设计不会做?设计大神带你开启动效灵感之路
    旅游类APP原型模板分享——爱彼迎
    有了这款自动标注/切图神器,攻城狮终于可以省心了
    设计师升职加薪必须知道的10个设计网站
    官网类原型模板分享——Apple
  • 原文地址:https://www.cnblogs.com/xgjblog/p/3884509.html
Copyright © 2011-2022 走看看