selector常规用法
selector之textColor
/res/color/text_color.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="@color/sample_pressed" android:state_pressed="true" />
<item android:color="@color/sample_default" />
</selector>
然后在Button设置android:textColor="@color/text_color"
其他的一下属性参考:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="hex_color" 颜色值
android:state_pressed=["true" | "false"] 是否按下
android:state_focused=["true" | "false"] 是否获得焦点
android:state_selected=["true" | "false"] 是否选中(如选项卡tab)
android:state_checkable=["true" | "false"] 是否可用选中(如CheckBox)
android:state_checked=["true" | "false"] 是否选中(如CheckBox)
android:state_enabled=["true" | "false"] 控件是否可用
android:state_window_focused=["true" | "false"] /> 应用程序是否在前台
</selector>
https://developer.android.google.cn/guide/topics/resources/color-list-resource.html
selector之background
/res/drawable.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@color/sample_pressed" android:state_pressed="false" />
<item android:drawable="@color/sample_default" android:state_pressed="true" />
</selector>
然后在Button设置android:background="@drawable/bg"
其他的一下属性参考:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"
android:constantSize=["true" | "false"]
android:dither=["true" | "false"]
android:variablePadding=["true" | "false"] >
<item
android:drawable="@[package:]drawable/drawable_resource"
android:state_pressed=["true" | "false"]
android:state_focused=["true" | "false"]
android:state_hovered=["true" | "false"]
android:state_selected=["true" | "false"]
android:state_checkable=["true" | "false"]
android:state_checked=["true" | "false"]
android:state_enabled=["true" | "false"]
android:state_activated=["true" | "false"]
android:state_window_focused=["true" | "false"] />
</selector>
属性的含义,官方上有解释,而且都是中文的~
https://developer.android.google.cn/guide/topics/resources/drawable-resource.html
动态生成selector
通常也用不到~但是如果有皮肤之类的开发就需要了
动态生成selector之textColor
这里的重要类ColorStateList,我们通常设置的selector读取之后就会在里面,而这里,也是使用这个
构造函数
[ColorStateList](https://developer.android.com/reference/android/content/res/ColorStateList.html#ColorStateList(int[][], int[]))(int[][] states, int[] colors)
Creates a ColorStateList that returns the specified mapping from states to colors.
创建一个ColorStateList,它将指定的映射从状态返回到颜色。
参数一:设置状态,比如android.R.attr.state_pressed,当然这里是一个二维数组,查找源码,发现其实就使用了第一个~,比如这里设置(我这里还是用pressed和非pressed做例子)
int[][] states = {{-android.R.attr.state_pressed}, {android.R.attr.state_pressed}};
前面带符号的表示android:state_pressed="false"
参数二:对应的颜色值,参数一写了几个状态,这里就几个颜色值
new int[]{Color.BLUE, Color.RED})
颜色值可以用getResources().getColor(R.color.colorAccent),读取资源文件的,也可以直接使用0xFF00ff00或者Color.parseColor("#00ff00")之类的
最终的代码:
mBtnTextChange = (Button) findViewById(R.id.btn_text_change);
int[][] states = {{-android.R.attr.state_pressed}, {android.R.attr.state_pressed}}; //状态
ColorStateList colorStateList = new ColorStateList(states, new int[]{Color.BLUE, Color.RED});
mBtnTextChange.setTextColor(colorStateList);
动态生成selector之background
StateListDrawable跟ColorStateList 类似,只不过这里保存的是drawable状态集合。
添加状态使用的是[addState()](https://developer.android.google.cn/reference/android/graphics/drawable/StateListDrawable.html#addState(int[], android.graphics.drawable.Drawable))方法
同样的也是两个参数,状态和drawable值,跟ColorStateList 类似,但又有不同,这里状态需要一个个添加,而ColorStateList 是在构造函数中一次性添加,这里直接贴出代码了
mBtnBgChange = (Button) findViewById(R.id.btn_bg_change);
StateListDrawable stateListDrawable = new StateListDrawable();
stateListDrawable.addState(new int[]{-android.R.attr.state_pressed}, new ColorDrawable(Color.BLUE));
stateListDrawable.addState(new int[]{android.R.attr.state_pressed}, new ColorDrawable(Color.RED));
mBtnBgChange.setBackground(stateListDrawable);
注意:-android.R.attr.state_pressed和 android.R.attr.state_pressed的区别在于 “-” 号代表值里的true 和 false ,有“-”为false 没有则为true
网友评论