Android状态选择器用法总结
原创文章,转载请注明出处http://www.cnblogs.com/baipengzhan/p/6284682.html
本文首先列出常见状态选择器的创建,然后按照常用控件来分别列出状态选择器的具体用法。
颜色状态选择器颜色状态选择器创建在res/color目录下,color目录一般不存在,我们自己创建即可。
颜色状态选择器只能用作改变颜色的地方,例如改变文字颜色等场合,不能作为背景,
当做背景时会出错,这点千万要注意。
以下为一个颜色状态选择器,今后可以参考这个创建其它的:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="#f00" android:state_checked="true"/>
<item android:color="#f00" android:state_pressed="true"/>
<item android:color="#f00" android:state_selected="true"/> <!--没被选中时的颜色-->
<item android:color="#000"/> </selector>
这里的颜色值为硬编码,不推荐,只为说明。
这个颜色状态选择器对应着四种状态,前三种对应着同一种颜色,最后一种为另一种颜色。
四种状态分别为:选中(checked),按下(pressed),选中(selected)和默认状态。
我们通过一个小例子看以下它的使用:
<RadioButton
android:id="@+id/button_4"
android:text="button_4"
android:button="@null"
android:textColor="@color/radiobutton_color_selector"
android:background="@drawable/radiobutton_bg_selector"
android:gravity="center"
android:layout_weight="1"
android:drawableTop="@drawable/radiobutton_pic_selector"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
这里是在一个RadioButton中改变文字颜色时使用的:
android:textColor="@color/radiobutton_color_selector"
一般状态选择器
这种最常用的状态选择器创建在res/drawable目录下,该目录是存在的不需要创建。
这种状态选择器用途就比上一种颜色状态选择器用途广泛多了,比如改变背景图片,
改变背景颜色,改变背景形状等等。
下面我们创建一个改变背景颜色的状态选择器
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_selected="true" android:drawable="@color/radiobutton_bg_selected"/>
<item android:state_checked="true" android:drawable="@color/radiobutton_bg_selected"/>
<item android:state_pressed="true" android:drawable="@color/radiobutton_bg_selected"/> <!--未被选中-->
<item android:drawable="@color/radiobutton_bg_normal"/> </selector>
创建的时候要注意,这里是通过drawable属性改变颜色的,而不是color属性,不同于颜色状态选择器。
drawable属性值不能直接设置颜色值,如#f00等,而要将颜色值封装在values目录下,colors.xml文件中。
该选择器的使用也很简单,作为背景即可,见颜色状态选择器中的例子,设置背景:
android:background="@drawable/radiobutton_bg_selector"
下面我们创建一个改变背景图片的状态选择器
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_selected="true" android:drawable="@mipmap/ic_selected"/>
<item android:state_checked="true" android:drawable="@mipmap/ic_selected"/>
<item android:state_pressed="true" android:drawable="@mipmap/ic_selected"/> <!--未被选中-->
<item android:drawable="@mipmap/ic_launcher"/> </selector>
注意,本状态选择器同样适用android:drawable属性,通过设置图片来让其被使用时出现图片而不是颜色。
但在输入android:drawable属性值时,系统可能出现不提醒(输入不完整信息,提醒完整信息)情况,这个时候我们要手动输入。
这个状态选择器的使用同样用上面RadioButton的例子,在文字上面的图片设置时使用:
android:drawableTop="@drawable/radiobutton_pic_selector"
下面我们创建一个改变背景形状的状态选择器
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" android:drawable="@drawable/textview_pressed_shape"/>
<item android:state_selected="true" android:drawable="@drawable/textview_pressed_shape"/>
<item android:state_checked="true" android:drawable="@drawable/textview_pressed_shape"/> <!--未被选中时-->
<item android:drawable="@drawable/textview_normal_shape"/> </selector>
选中和未选中时背景形状改变,形状资源使用的是自己创建的shape文件,见下面代码:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle"
> <!--矩形的四个角都设置为圆角,半径为5dp-->
<corners android:radius="5dp"/>
<!--设置形状的颜色-->
<solid android:color="#f00"/>
<!--设置形状的大小-->
<size android:width="80dp" android:height="20dp"/> </shape>
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval"
> <!--设置形状的颜色-->
<solid android:color="#0f0"/>
<!--设置形状的大小-->
<size android:width="40dp" android:height="20dp"/> </shape>
shape文件同样创建在res/drawable目录下,本文不做详细介绍。
注意,shape中设置的长宽没有起作用,目前没有查到原因,留待今后解决。
下面我们创建一个改变背景渐变色的状态选择器
这里状态选择器和上一种的区别是shape文件中的设置发生了变化,其余都一样,请看下面的代码:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle"
> <!--矩形的四个角都设置为圆角,半径为5dp-->
<corners android:radius="5dp"/>
<!--设置渐变色-->
<gradient android:startColor="#00f" android:centerColor="#0f0" android:endColor="#f00"/> </shape>
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle"
> <!--矩形的四个角都设置为圆角,半径为5dp-->
<corners android:radius="5dp"/>
<!--设置渐变色-->
<gradient android:startColor="#f00" android:centerColor="#0f0" android:endColor="#00f"/> </shape>
好啦,我们就先总结到这里,最后啰嗦一句,颜色状态选择器放在res/color目录下,这个目录要手动创建,使用的时候只能当做颜色使用,不能当做背景使用;
一般状态选择器放在res/drawable目录下,此目录已经存在,无需我们创建,使用的时候要当做背景,可以改变背景颜色,形状,图片等。
Android状态选择器用法总结的更多相关文章
- Android初级教程:如何自定义一个状态选择器
有这样一种场景:点击一下某个按钮或者图片(view),改变了样式(一般改变背景颜色).这个时候一种解决方案,可能就是状态选择器.接下来就介绍如何实现状态选择器: 步骤: 一.新建这样的文件夹:res/ ...
- Android webservice的用法详细讲解
Android webservice的用法详细讲解 看到有很多朋友对WebService还不是很了解,在此就详细的讲讲WebService,争取说得明白吧.此文章采用的项目是我毕业设计的webserv ...
- listview条目用状态选择器没反应
button和imagebutton天生具有“可点击(click)”.“可按下(press)”的特性,radiobutton具有“可勾选(check)”的特性,但是listview的条目只有“可按下( ...
- xamarin android viewpager的用法
1.什么是ViewPager 通过手势滑动可以完成view的切换,一般是用来app的引导页或则实现图片轮播,类似网页上的banner轮播. Adnroid 3.0后引入的一个UI控件,在xamarin ...
- selector状态选择器
Selector selector就是状态选择器(StateList),它分为两种,一种Color-Selector 和Drawable-Selector. Color-Selector color- ...
- 深入学习jQuery选择器系列第六篇——过滤选择器之状态选择器
× 目录 [1]焦点状态 [2]哈希状态 [3]动画状态[4]显隐状态 前面的话 过滤选择器的内容非常多,本文介绍过滤选择器的最后一部分——状态选择器 焦点状态 :focus :focus选择器选择当 ...
- 【Android学习】android:layout_weight的用法实例
对于android:layout_weight的用法,用下面的例子来说明: <LinearLayout xmlns:android="http://schemas.android.co ...
- Android之Adapter用法总结-(转)
Android之Adapter用法总结 1.概念 Adapter是连接后端数据和前端显示的适配器接口,是数据和UI(View)之间一个重要的纽带.在常见的View(List View,Grid Vie ...
- Android之Adapter用法总结(转)
Android之Adapter用法总结 1.概念 Adapter是连接后端数据和前端显示的适配器接口,是数据和UI(View)之间一个重要的纽带.在常见的View(List View,Grid Vie ...
随机推荐
- Junit单元测试对线程测试没反应
今天还想简单写写线程的东西,结果刚刚写完我就懵逼了. 结果啥都没有输出,而用主方法运行就可以输出.没办法,只有度年来寻求自己的答案了 结果各方面的了解,我算是有个了解了. 首先来看看代码 packag ...
- MyBatis 异常 集锦
异常1.使用映射器 (还没有使用Spring) 异常信息摘要: org.apache.ibatis.binding.BindingException: Type interface com.jege. ...
- 4.请求方式为application/json时的接口测试要如何做?
1.单独新建一个线程组, 在信息头管理器中增加: 在Body Data中,添加json格式的内容(我不会写,直接用fiddler抓包,然后把TextView中的数据复制过来). 2.然后因为登录状态, ...
- HDU 1956 POJ 1637 Sightseeing tour
混合图的欧拉回路判定方法: 1.首先判断基图是否连通,不连通的话表示不可能,否则进入下一步. 2.对于无向边,随便确定一个方向 3.确定好了之后,整张图就变成了有向图,计算每个节点的入度与出度 4.如 ...
- Contest Balloons
Contest Balloons 题目链接:http://codeforces.com/problemset/problem/725/D 贪心+枚举 每次在排名在自己前面的选出w-t值最小的送气球,更 ...
- 《JS权威指南学习总结--6.2属性的查询和设置》
内容要点: 一.数组元素通过字符串索引而不是数字索引,这种数组就是我们所说的关联数组,也称散列.映射或字典. 二.继承 1.JS对象具有"自有属性",也有一些属性是从原型对象继承而 ...
- Spring Security(05)——异常信息本地化
Spring Security支持将展现给终端用户看的异常信息本地化,这些信息包括认证失败.访问被拒绝等.而对于展现给开发者看的异常信息和日志信息(如配置错误)则是不能够进行本地化的,它们是以英文硬编 ...
- 一、什么是WCF
注:本文为学习摘抄,原地址:http://www.cnblogs.com/iamlilinfeng/archive/2012/09/25/2700049.html 一.概述 Windows Commu ...
- ElasticSearch(5)-Mapping
一.Mapping概述 映射 为了能够把日期字段处理成日期,把数字字段处理成数字,把字符串字段处理成全文本(Full-text)或精确的字符串值,Elasticsearch需要知道每个字段里面都包含了 ...
- [转]最常见的20个jQuery面试问题及答案
毫无疑问,jQuery给了JavaScript急需的提振,这是一门如此有用,但同时总是常常被低估的语言. 在 jQuery 粉墨登场之前,我们曾经会写出冗长的JavaScript代码,不仅仅为更大型的 ...