android背景选择器selector用法汇总
16lz
2021-12-04
一.创建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>
最后,需要在包含button的xml文件里添加两项。例如main.xml文件,需要在<Button />里加两项 android:focusable="true"android:background="@drawable/button_color"这样就把drawale/button_color.xml文件与这个控件关联起来了。
更多相关文章
- NPM 和webpack 的基础使用
- 【阿里云镜像】使用阿里巴巴DNS镜像源——DNS配置教程
- Android(安卓)利用Android(安卓)studio打包jar包
- TensorFlow集成Android工程的框架
- android dp 和 px 的相互转换
- android 超简单的下载功能,进度条 异步下载
- vim+ctags+cscope 打造Android源码阅读工具
- Android(安卓)读取 assets目录下的文件
- android 五种 布局文件