public class

ColorStateList

extends Object
implements Parcelable
java.lang.Object
   ↳ android.content.res.ColorStateList

Class Overview

Lets you map View state sets to colors. ColorStateLists are created from XML resource files defined in the "color" subdirectory directory of an application's resource directory. The XML file contains a single "selector" element with a number of "item" elements inside. For example:

 <selector xmlns:android="http://schemas.android.com/apk/res/android">
   <item android:state_focused="true" android:color="@color/testcolor1"/>
   <item android:state_pressed="true" android:state_enabled="false" android:color="@color/testcolor2" />
   <item android:state_enabled="false" android:colore="@color/testcolor3" />
   <item android:state_active="true" android:color="@color/testcolor4" />
   <item android:color="@color/testcolor5"/>
 </selector>
 
This defines a set of state spec / color pairs where each state spec specifies a set of states that a view must either be in or not be in and the color specifies the color associated with that spec. The list of state specs will be processed in order of the items in the XML file. An item with no state spec is considered to match any set of states and is generally useful as a final item to be used as a default. Note that if you have such an item before any other items in the list then any subsequent items will end up being ignored.

Summary

Constants
Creator<ColorStateList> CREATOR
[Expand]
Inherited Constants
From interface android.os.Parcelable
Public Constructors
ColorStateList(int[][] states, int[] colors)
Creates a ColorStateList that returns the specified mapping from states to colors.
Public Methods
static ColorStateList createFromXml(Resources r, XmlPullParser parser)
Create a ColorStateList from an XML document, given a set of Resources.
int describeContents()
Describe the kinds of special objects contained in this Parcelable's marshalled representation.
int getColorForState(int[] stateSet, int defaultColor)
Return the color associated with the given set of View states.
int getDefaultColor()
Return the default color in this ColorStateList.
boolean isStateful()
String toString()
Returns a string containing a concise, human-readable description of this object.
static ColorStateList valueOf(int color)
Creates or retrieves a ColorStateList that always returns a single color.
ColorStateList withAlpha(int alpha)
Creates a new ColorStateList that has the same states and colors as this one but where each color has the specified alpha value (0-255).
void writeToParcel(Parcel dest, int flags)
Flatten this object in to a Parcel.
[Expand]
Inherited Methods
From class java.lang.Object
From interface android.os.Parcelable

Constants

public static final Creator<ColorStateList> CREATOR

Since: API Level 1

Public Constructors

public ColorStateList (int[][] states, int[] colors)

Since: API Level 1

Creates a ColorStateList that returns the specified mapping from states to colors.

Public Methods

public static ColorStateList createFromXml (Resources r, XmlPullParser parser)

Since: API Level 1

Create a ColorStateList from an XML document, given a set of Resources.

public int describeContents ()

Since: API Level 1

Describe the kinds of special objects contained in this Parcelable's marshalled representation.

Returns
  • a bitmask indicating the set of special object types marshalled by the Parcelable.

public int getColorForState (int[] stateSet, int defaultColor)

Since: API Level 1

Return the color associated with the given set of View states.

Parameters
stateSet an array of View states
defaultColor the color to return if there's not state spec in this ColorStateList that matches the stateSet.
Returns

public int getDefaultColor ()

Since: API Level 1

Return the default color in this ColorStateList.

Returns

public boolean isStateful ()

Since: API Level 1

public String toString ()

Since: API Level 1

Returns a string containing a concise, human-readable description of this object. Subclasses are encouraged to override this method and provide an implementation that takes into account the object's type and data. The default implementation simply concatenates the class name, the '@' sign and a hexadecimal representation of the object's hashCode(), that is, it is equivalent to the following expression:

 getClass().getName() + '@' + Integer.toHexString(hashCode())
 

Returns
  • a printable representation of this object.

public static ColorStateList valueOf (int color)

Since: API Level 1

Creates or retrieves a ColorStateList that always returns a single color.

public ColorStateList withAlpha (int alpha)

Since: API Level 1

Creates a new ColorStateList that has the same states and colors as this one but where each color has the specified alpha value (0-255).

public void writeToParcel (Parcel dest, int flags)

Since: API Level 1

Flatten this object in to a Parcel.

Parameters
dest The Parcel in which the object should be written.
flags Additional flags about how the object should be written. May be 0 or PARCELABLE_WRITE_RETURN_VALUE.