zoukankan      html  css  js  c++  java
  • Android selector的使用

    在开发应用中,很多情况下要设计listview或button控件的背景,下面总结一下android的selector的用法:

    1.在drawable中配置Android的selector。
    将如下的XML文件保存成你自己命名的.xml文件(比如item_bg.xml),并将该文件放置在drawable文件中,在系统使用时根据ListView中的列表项的状态来使用相应的背景图片。

     

    <?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>

    2.使用上面的配置文件:
    第一种方法是在listview配置文件中配置,代码如下:android:listSelector="@drawable/item_bg"

    第二种方法是在listview的item中添加属性,代码如下:android:background=“@drawable/item_bg"
    第三种方法是在java代码中设置,代码如下:Drawable drawable =getResources().getDrawable(R.drawable.item_bg); 
     ListView.setSelector(drawable);
    上面的设置方法显示效果有时候为黑,所以需要在配置文件上加上如下代码:android:cacheColorHint="@android:color/transparent" 使其背景是透明的。
    同样,Button也有一些背景效果,如下为属性解释:
    android:state_selected是设置选中时的效果
    android:state_focused是设置获得焦点的效果
    android:state_pressed是设置点击的效果
    android:state_enabled是设置是否响应事件

    下面是一个selector用来设置button中的文字状态

    <?xmlversion="1.0" encoding="utf-8"?>
    <selectorxmlns:android="http://schemas.android.com/apk/res/android">
        <itemandroid:state_selected="true" android:color="#FFF" />
        <itemandroid:state_focused="true" android:color="#FFF" />
        <itemandroid:state_pressed="true" android:color="#FFF" />
        <itemandroid:color="#000" />
    </selector>
  • 相关阅读:
    Vue单页面应用
    MVVM模式理解
    Ajax原生四大步骤
    Vue 全家桶介绍
    原生js的dom操作
    vs2015+opencv3.3.1+ maxflow-v3.01 c++实现Yuri Boykov 的Interactive Graph Cuts
    c++迭代递归实现汉诺塔(5种迭代方法满足你)
    opencv3.3.1+vs2015+c++实现直接在图像上画掩码,保存掩码图片
    声明函数指针、回调函数、函数对象------c++程序设计基础、编程抽象与算法策略
    C++/C语言的标准库函数与运算符的区别new/delete malloc/free
  • 原文地址:https://www.cnblogs.com/gyqrenkai/p/5822993.html
Copyright © 2011-2022 走看看