多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
## 颜色状态列表资源 `[ColorStateList](https://developer.android.google.cn/reference/android/content/res/ColorStateList)`是一个您可以在 XML 中定义的对象,您可以将其作为颜色来应用,但它实际上会更改颜色,具体取决于其应用到的`[View](https://developer.android.google.cn/reference/android/view/View)`对象的状态。例如,`[Button](https://developer.android.google.cn/reference/android/widget/Button)`微件可以处于多种不同状态中的一种(按下、聚焦或既不按下也不聚焦),而使用颜色状态列表,您可以为每种状态提供不同的颜色。 您可以在 XML 文件中描述状态列表。每种颜色都在单个`<selector>`元素内的`<item>`元素中定义。每个`<item>`使用不同的属性描述其应在什么状态下使用。 在每次状态更改期间,系统将从上到下遍历状态列表,并且将使用与当前状态匹配的第一项。系统的选择并非基于“最佳匹配”,而仅仅是基于符合状态的最低标准的第一项。 **注意**:如果要提供静态颜色资源,请使用简单的[颜色](https://developer.android.google.cn/guide/topics/resources/more-resources#Color)值。 ### 文件位置: `res/color/*filename*.xml` 该文件名将用作资源 ID。 编译后的资源数据类型: 指向`[ColorStateList](https://developer.android.google.cn/reference/android/content/res/ColorStateList)`的资源指针。 ### 资源引用: 在 Java 中:`R.color.*filename*` 在 XML 中:`@[*package*:]color/*filename*` ### 语法: ~~~     <?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"]             android:state_checkable=["true" | "false"]             android:state_checked=["true" | "false"]             android:state_enabled=["true" | "false"]             android:state_window_focused=["true" | "false"] />     </selector> ~~~ ### 元素: * `<selector>` **必需**。该元素必须是根元素。包含一个或多个`<item>`元素。 属性: `xmlns:android` 字符串。**必需**。定义 XML 命名空间,该命名空间必须为`"http://schemas.android.com/apk/res/android"`。 * `<item>` 定义在某些状态下使用的颜色,状态通过其属性来描述。必须是`<selector>`元素的子元素。 属性: * `android:color` 十六进制颜色。**必需**。颜色通过 RGB 值和可选的 Alpha 通道指定。 该值始终以井号 (#) 字符开头,后跟以下某种格式的“透明度、红、绿、蓝”(Alpha-Red-Green-Blue) 信息: * #RGB * #ARGB * #RRGGBB * #AARRGGBB * `android:state_pressed` 布尔值。如果此项应在按下对象时(例如轻触/点按了按钮时)使用,则为“true”;如果此项应在默认的非按下状态下使用,则为“false”。 * `android:state_focused` 布尔值。如果此项应在聚焦对象时(例如使用轨迹球/方向键突出显示按钮时)使用,则为“true”;如果此项应在默认的非聚焦状态下使用,则为“false”。 * `android:state_selected` 布尔值。如果此项应在选择对象时(例如打开标签页时)使用,则为“true”;如果此项应在未选择对象时使用,则为“false”。 * `android:state_checkable` 布尔值。如果此项应在对象可勾选时使用,则为“true”;如果此项应在对象不可勾选时使用,则为“false”。(仅适用于对象可在可勾选和不可勾选的微件之间转换的情况。) * `android:state_checked` 布尔值。如果此项应在勾选对象时使用,则为“true”;如果应在取消勾选对象时使用,则为“false”。 * `android:state_enabled` 布尔值。如果此项应在启用对象(能够接收轻触/点按事件)时使用,则为“true”;如果应在停用对象时使用,则为“false”。 * `android:state_window_focused` 布尔值。如果此项应在应用窗口具有焦点(应用位于前台)时使用,则为“true”;如果此项应在应用窗口没有焦点时(例如通知栏下拉或出现一个对话框时)使用,则为“false”。 **注意**:请注意,系统将应用状态列表中与对象的当前状态匹配的第一项。因此,如果列表中的第一项不包含上述任何状态属性,则每次都会应用该项,因此默认值应始终为最后一项,如以下示例所示。 ### 示例: 保存于`res/color/button_text.xml`的 XML 文件: ~~~     <?xml version="1.0" encoding="utf-8"?>     <selector xmlns:android="http://schemas.android.com/apk/res/android">         <item android:state_pressed="true"               android:color="#ffff0000"/> <!-- pressed -->         <item android:state_focused="true"               android:color="#ff0000ff"/> <!-- focused -->         <item android:color="#ff000000"/> <!-- default -->     </selector> ~~~ 此布局 XML 会将颜色列表应用到 View: ~~~     <Button         android:layout_width="fill_parent"         android:layout_height="wrap_content"         android:text="@string/button_text"         android:textColor="@color/button_text" /> ~~~