android背景选择器selector用法汇总
16lz
2022-01-13
一.创建xml文件,位置:drawable/xxx.xml,同目录下记得要放相关图片
[html] view plain copy
- <?xmlversion="1.0"encoding="utf-8"?>
- <selectorxmlns:android="http://schemas.android.com/apk/res/android">
- <!--没有焦点时的背景图片-->
- <itemandroid:drawable="@drawable/handle_normal"android:state_enabled="true"android:state_window_focused="false"/>
- <!--触摸模式按下时的背景图片-->
- <itemandroid:drawable="@drawable/handle_pressed"android:state_pressed="true"/>
- <itemandroid:drawable="@drawable/handle_focused"android:state_enabled="true"android:state_focused="true"/>
- <itemandroid:drawable="@drawable/handle_normal"android:state_enabled="true"/>
- <!--获得焦点时的图片背景-->
- <itemandroid:drawable="@drawable/handle_focused"android:state_focused="true"/>
- <!--
- android:state_selected是选中
- android:state_focused是获得焦点
- android:state_pressed是点击
- android:state_enabled是设置是否响应事件,指所有事件
- -->
- </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
- <?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>
drawable/button_color.xml
[html] view plain copy
- <spanstyle="color:#330033;"><?xmlversion="1.0"encoding="utf-8"?>
- <selectorxmlns:android="http://schemas.android.com/apk/res/android">/
- <itemandroid:state_pressed="true">//定义当button处于pressed状态时的形态。
- <shape>
- <gradientandroid:startColor="#8600ff"/>
- <strokeandroid:width="2dp"android:color="#000000"/>
- <cornersandroid:radius="5dp"/>
- <paddingandroid:left="10dp"android:top="10dp"
- android:bottom="10dp"android:right="10dp"/>
- </shape>
- </item>
- <itemandroid:state_focused="true">//定义当button获得focus时的形态
- <shape>
- <gradientandroid:startColor="#eac100"/>
- <strokeandroid:width="2dp"android:color="#333333"color="#ffffff"/>
- <cornersandroid:radius="8dp"/>
- <paddingandroid:left="10dp"android:top="10dp"
- android:bottom="10dp"android:right="10dp"/>
- </shape>
- </item>
- </selector></span><spanstyle="color:#ff0000;"></span>
更多相关文章
- Android学习笔记(33):Android对话框
- Android中TabLayout添加小红点
- Android官方命令深入分析之Hierarchy Viewer
- Android与JavaScrpit相互调用
- AIDL介绍和实例讲解
- android.net.LocalSocket
- Android点击水波纹效果
- Android参数设置: Preference
- NPM 和webpack 的基础使用