public final class

AccessibilityEvent

extends AccessibilityRecord
implements Parcelable
java.lang.Object
   ↳ android.view.accessibility.AccessibilityRecord
     ↳ android.view.accessibility.AccessibilityEvent

Class Overview

This class represents accessibility events that are sent by the system when something notable happens in the user interface. For example, when a Button is clicked, a View is focused, etc.

An accessibility event is fired by an individual view which populates the event with data for its state and requests from its parent to send the event to interested parties. The parent can optionally add an AccessibilityRecord for itself before dispatching a similar request to its parent. A parent can also choose not to respect the request for sending an event. The accessibility event is sent by the topmost view in the view tree. Therefore, an AccessibilityService can explore all records in an accessibility event to obtain more information about the context in which the event was fired.

The main purpose of an accessibility event is to expose enough information for an AccessibilityService to provide meaningful feedback to the user. Sometimes however, an accessibility service may need more contextual information then the one in the event pay-load. In such cases the service can obtain the event source which is an AccessibilityNodeInfo (snapshot of a View state) which can be used for exploring the window content. Note that the privilege for accessing an event's source, thus the window content, has to be explicitly requested. For more details refer to AccessibilityService. If an accessibility service has not requested to retrieve the window content the event will not contain reference to its source. Also for events of type TYPE_NOTIFICATION_STATE_CHANGED the source is never available.

This class represents various semantically different accessibility event types. Each event type has an associated set of related properties. In other words, each event type is characterized via a subset of the properties exposed by this class. For each event type there is a corresponding constant defined in this class. Follows a specification of the event types and their associated properties:

VIEW TYPES

View clicked - represents the event of clicking on a View like Button, CompoundButton, etc.
Type:TYPE_VIEW_CLICKED
Properties:

  • getEventType() - The type of the event.
  • getSource() - The source info (for registered clients).
  • getClassName() - The class name of the source.
  • getPackageName() - The package name of the source.
  • getEventTime() - The event time.
  • getText() - The text of the source's sub-tree.
  • isEnabled() - Whether the source is enabled.
  • isPassword() - Whether the source is password.
  • isChecked() - Whether the source is checked.
  • getContentDescription() - The content description of the source.
  • getScrollX() - The offset of the source left edge in pixels (without descendants of AdapterView).
  • getScrollY() - The offset of the source top edge in pixels (without descendants of AdapterView).
  • getFromIndex() - The zero based index of the first visible item of the source, inclusive (for descendants of AdapterView).
  • getToIndex() - The zero based index of the last visible item of the source, inclusive (for descendants of AdapterView).
  • getItemCount() - The total items of the source (for descendants of AdapterView).

View long clicked - represents the event of long clicking on a View like Button, CompoundButton, etc
Type:TYPE_VIEW_LONG_CLICKED
Properties:

  • getEventType() - The type of the event.
  • getSource() - The source info (for registered clients).
  • getClassName() - The class name of the source.
  • getPackageName() - The package name of the source.
  • getEventTime() - The event time.
  • getText() - The text of the source's sub-tree.
  • isEnabled() - Whether the source is enabled.
  • isPassword() - Whether the source is password.
  • isChecked() - Whether the source is checked.
  • getContentDescription() - The content description of the source.
  • getScrollX() - The offset of the source left edge in pixels (without descendants of AdapterView).
  • getScrollY() - The offset of the source top edge in pixels (without descendants of AdapterView).
  • getFromIndex() - The zero based index of the first visible item of the source, inclusive (for descendants of AdapterView).
  • getToIndex() - The zero based index of the last visible item of the source, inclusive (for descendants of AdapterView).
  • getItemCount() - The total items of the source (for descendants of AdapterView).

View selected - represents the event of selecting an item usually in the context of an AdapterView.
Type: TYPE_VIEW_SELECTED
Properties:

View focused - represents the event of focusing a View.
Type: TYPE_VIEW_FOCUSED
Properties:

View text changed - represents the event of changing the text of an EditText.
Type: TYPE_VIEW_TEXT_CHANGED
Properties:

View text selection changed - represents the event of changing the text selection of an EditText.
Type: TYPE_VIEW_TEXT_SELECTION_CHANGED
Properties:

Note: This event type is not dispatched to descendants though View.dispatchPopulateAccessibilityEvent(AccessibilityEvent), hence the event source View and the sub-tree rooted at it will not receive calls to View.onPopulateAccessibilityEvent(AccessibilityEvent). The preferred way to add text content to such events is by setting the contentDescription of the source view.

View scrolled - represents the event of scrolling a view. If the source is a descendant of AdapterView the scroll is reported in terms of visible items - the first visible item, the last visible item, and the total items - because the the source is unaware of its pixel size since its adapter is responsible for creating views. In all other cases the scroll is reported as the current scroll on the X and Y axis respectively plus the height of the source in pixels.
Type: TYPE_VIEW_SCROLLED
Properties:

  • getEventType() - The type of the event.
  • getSource() - The source info (for registered clients).
  • getClassName() - The class name of the source.
  • getPackageName() - The package name of the source.
  • getEventTime() - The event time.
  • getText() - The text of the source's sub-tree.
  • isEnabled() - Whether the source is enabled.
  • getContentDescription() - The content description of the source.
  • getScrollX() - The offset of the source left edge in pixels (without descendants of AdapterView).
  • getScrollY() - The offset of the source top edge in pixels (without descendants of AdapterView).
  • getFromIndex() - The zero based index of the first visible item of the source, inclusive (for descendants of AdapterView).
  • getToIndex() - The zero based index of the last visible item of the source, inclusive (for descendants of AdapterView).
  • getItemCount() - The total items of the source (for descendants of AdapterView).
Note: This event type is not dispatched to descendants though View.dispatchPopulateAccessibilityEvent(AccessibilityEvent), hence the event source View and the sub-tree rooted at it will not receive calls to View.onPopulateAccessibilityEvent(AccessibilityEvent). The preferred way to add text content to such events is by setting the contentDescription of the source view.

TRANSITION TYPES

Window state changed - represents the event of opening a PopupWindow, Menu, Dialog, etc.
Type: TYPE_WINDOW_STATE_CHANGED
Properties:

Window content changed - represents the event of change in the content of a window. This change can be adding/removing view, changing a view size, etc.

Note: This event is fired only for the window source of the last accessibility event different from TYPE_NOTIFICATION_STATE_CHANGED and its purpose is to notify clients that the content of the user interaction window has changed.
Type: TYPE_WINDOW_CONTENT_CHANGED
Properties:

Note: This event type is not dispatched to descendants though View.dispatchPopulateAccessibilityEvent(AccessibilityEvent), hence the event source View and the sub-tree rooted at it will not receive calls to View.onPopulateAccessibilityEvent(AccessibilityEvent). The preferred way to add text content to such events is by setting the contentDescription of the source view.

NOTIFICATION TYPES

Notification state changed - represents the event showing Notification.
Type: TYPE_NOTIFICATION_STATE_CHANGED
Properties:

Note: This event type is not dispatched to descendants though View.dispatchPopulateAccessibilityEvent(AccessibilityEvent), hence the event source View and the sub-tree rooted at it will not receive calls to View.onPopulateAccessibilityEvent(AccessibilityEvent). The preferred way to add text content to such events is by setting the contentDescription of the source view.

EXPLORATION TYPES

View hover enter - represents the event of beginning to hover over a View. The hover may be generated via exploring the screen by touch or via a pointing device.
Type: TYPE_VIEW_HOVER_ENTER
Properties:

  • getEventType() - The type of the event.
  • getSource() - The source info (for registered clients).
  • getClassName() - The class name of the source.
  • getPackageName() - The package name of the source.
  • getEventTime() - The event time.
  • getText() - The text of the source's sub-tree.
  • isEnabled() - Whether the source is enabled.
  • getContentDescription() - The content description of the source.
  • getScrollX() - The offset of the source left edge in pixels (without descendants of AdapterView).
  • getScrollY() - The offset of the source top edge in pixels (without descendants of AdapterView).
  • getFromIndex() - The zero based index of the first visible item of the source, inclusive (for descendants of AdapterView).
  • getToIndex() - The zero based index of the last visible item of the source, inclusive (for descendants of AdapterView).
  • getItemCount() - The total items of the source (for descendants of AdapterView).

View hover exit - represents the event of stopping to hover over a View. The hover may be generated via exploring the screen by touch or via a pointing device.
Type: TYPE_VIEW_HOVER_EXIT
Properties:
  • getEventType() - The type of the event.
  • getSource() - The source info (for registered clients).
  • getClassName() - The class name of the source.
  • getPackageName() - The package name of the source.
  • getEventTime() - The event time.
  • getText() - The text of the source's sub-tree.
  • isEnabled() - Whether the source is enabled.
  • getContentDescription() - The content description of the source.
  • getScrollX() - The offset of the source left edge in pixels (without descendants of AdapterView).
  • getScrollY() - The offset of the source top edge in pixels (without descendants of AdapterView).
  • getFromIndex() - The zero based index of the first visible item of the source, inclusive (for descendants of AdapterView).
  • getToIndex() - The zero based index of the last visible item of the source, inclusive (for descendants of AdapterView).
  • getItemCount() - The total items of the source (for descendants of AdapterView).

Touch exploration gesture start - represents the event of starting a touch exploring gesture.
Type: TYPE_TOUCH_EXPLORATION_GESTURE_START
Properties:

Note: This event type is not dispatched to descendants though View.dispatchPopulateAccessibilityEvent(AccessibilityEvent), hence the event source View and the sub-tree rooted at it will not receive calls to View.onPopulateAccessibilityEvent(AccessibilityEvent). The preferred way to add text content to such events is by setting the contentDescription of the source view.

Touch exploration gesture end - represents the event of ending a touch exploring gesture.
Type: TYPE_TOUCH_EXPLORATION_GESTURE_END
Properties:

Note: This event type is not dispatched to descendants though View.dispatchPopulateAccessibilityEvent(AccessibilityEvent), hence the event source View and the sub-tree rooted at it will not receive calls to View.onPopulateAccessibilityEvent(AccessibilityEvent). The preferred way to add text content to such events is by setting the contentDescription of the source view.

Security note

Since an event contains the text of its source privacy can be compromised by leaking sensitive information such as passwords. To address this issue any event fired in response to manipulation of a PASSWORD field does NOT CONTAIN the text of the password.

Summary

Constants
int INVALID_POSITION Invalid selection/focus position.
int MAX_TEXT_LENGTH Maximum length of the text fields.
int TYPES_ALL_MASK Mask for AccessibilityEvent all types.
int TYPE_NOTIFICATION_STATE_CHANGED Represents the event showing a Notification.
int TYPE_TOUCH_EXPLORATION_GESTURE_END Represents the event of ending a touch exploration gesture.
int TYPE_TOUCH_EXPLORATION_GESTURE_START Represents the event of starting a touch exploration gesture.
int TYPE_VIEW_CLICKED Represents the event of clicking on a View like Button, CompoundButton, etc.
int TYPE_VIEW_FOCUSED Represents the event of focusing a View.
int TYPE_VIEW_HOVER_ENTER Represents the event of a hover enter over a View.
int TYPE_VIEW_HOVER_EXIT Represents the event of a hover exit over a View.
int TYPE_VIEW_LONG_CLICKED Represents the event of long clicking on a View like Button, CompoundButton, etc.
int TYPE_VIEW_SCROLLED Represents the event of scrolling a view.
int TYPE_VIEW_SELECTED Represents the event of selecting an item usually in the context of an AdapterView.
int TYPE_VIEW_TEXT_CHANGED Represents the event of changing the text of an EditText.
int TYPE_VIEW_TEXT_SELECTION_CHANGED Represents the event of changing the selection in an EditText.
int TYPE_WINDOW_CONTENT_CHANGED Represents the event of changing the content of a window.
int TYPE_WINDOW_STATE_CHANGED Represents the event of opening a PopupWindow, Menu, Dialog, etc.
[Expand]
Inherited Constants
From interface android.os.Parcelable
Fields
public static final Creator<AccessibilityEvent> CREATOR
Public Methods
void appendRecord(AccessibilityRecord record)
Appends an AccessibilityRecord to the end of event records.
int describeContents()
Describe the kinds of special objects contained in this Parcelable's marshalled representation.
static String eventTypeToString(int eventType)
Returns the string representation of an event type.
long getEventTime()
Gets the time in which this event was sent.
int getEventType()
Gets the event type.
CharSequence getPackageName()
Gets the package name of the source.
AccessibilityRecord getRecord(int index)
Gets the record at a given index.
int getRecordCount()
Gets the number of records contained in the event.
void initFromParcel(Parcel parcel)
Creates a new instance from a Parcel.
static AccessibilityEvent obtain(int eventType)
Returns a cached instance if such is available or a new one is instantiated with its type property set.
static AccessibilityEvent obtain()
Returns a cached instance if such is available or a new one is instantiated.
static AccessibilityEvent obtain(AccessibilityEvent event)
Returns a cached instance if such is available or a new one is created.
void recycle()
Recycles an instance back to be reused.
void setEventTime(long eventTime)
Sets the time in which this event was sent.
void setEventType(int eventType)
Sets the event type.
void setPackageName(CharSequence packageName)
Sets the package name of the source.
String toString()
Returns a string containing a concise, human-readable description of this object.
void writeToParcel(Parcel parcel, int flags)
Flatten this object in to a Parcel.
[Expand]
Inherited Methods
From class android.view.accessibility.AccessibilityRecord
From class java.lang.Object
From interface android.os.Parcelable

Constants

public static final int INVALID_POSITION

Since: API Level 4

Invalid selection/focus position.

Constant Value: -1 (0xffffffff)

public static final int MAX_TEXT_LENGTH

Since: API Level 4

public static final int TYPE_NOTIFICATION_STATE_CHANGED

Since: API Level 4

Represents the event showing a Notification.

Constant Value: 64 (0x00000040)

public static final int TYPE_TOUCH_EXPLORATION_GESTURE_END

Since: API Level 14

Represents the event of ending a touch exploration gesture.

Constant Value: 1024 (0x00000400)

public static final int TYPE_TOUCH_EXPLORATION_GESTURE_START

Since: API Level 14

Represents the event of starting a touch exploration gesture.

Constant Value: 512 (0x00000200)

public static final int TYPE_VIEW_CLICKED

Since: API Level 4

Represents the event of clicking on a View like Button, CompoundButton, etc.

Constant Value: 1 (0x00000001)

public static final int TYPE_VIEW_FOCUSED

Since: API Level 4

Represents the event of focusing a View.

Constant Value: 8 (0x00000008)

public static final int TYPE_VIEW_HOVER_ENTER

Since: API Level 14

Represents the event of a hover enter over a View.

Constant Value: 128 (0x00000080)

public static final int TYPE_VIEW_HOVER_EXIT

Since: API Level 14

Represents the event of a hover exit over a View.

Constant Value: 256 (0x00000100)

public static final int TYPE_VIEW_LONG_CLICKED

Since: API Level 4

Represents the event of long clicking on a View like Button, CompoundButton, etc.

Constant Value: 2 (0x00000002)

public static final int TYPE_VIEW_SCROLLED

Since: API Level 14

Represents the event of scrolling a view.

Constant Value: 4096 (0x00001000)

public static final int TYPE_VIEW_SELECTED

Since: API Level 4

Represents the event of selecting an item usually in the context of an AdapterView.

Constant Value: 4 (0x00000004)

public static final int TYPE_VIEW_TEXT_CHANGED

Since: API Level 4

Represents the event of changing the text of an EditText.

Constant Value: 16 (0x00000010)

public static final int TYPE_VIEW_TEXT_SELECTION_CHANGED

Since: API Level 14

Represents the event of changing the selection in an EditText.

Constant Value: 8192 (0x00002000)

public static final int TYPE_WINDOW_CONTENT_CHANGED

Since: API Level 14

Represents the event of changing the content of a window.

Constant Value: 2048 (0x00000800)

public static final int TYPE_WINDOW_STATE_CHANGED

Since: API Level 4

Represents the event of opening a PopupWindow, Menu, Dialog, etc.

Constant Value: 32 (0x00000020)

Fields

public static final Creator<AccessibilityEvent> CREATOR

Since: API Level 4

Public Methods

public void appendRecord (AccessibilityRecord record)

Since: API Level 14

Appends an AccessibilityRecord to the end of event records.

Parameters
record The record to append.
Throws
IllegalStateException If called from an AccessibilityService.

public int describeContents ()

Since: API Level 4

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 static String eventTypeToString (int eventType)

Since: API Level 14

Returns the string representation of an event type. For example, TYPE_VIEW_CLICKED is represented by the string TYPE_VIEW_CLICKED.

Parameters
eventType The event type
Returns
  • The string representation.

public long getEventTime ()

Since: API Level 4

Gets the time in which this event was sent.

Returns
  • The event time.

public int getEventType ()

Since: API Level 4

Gets the event type.

Returns
  • The event type.

public CharSequence getPackageName ()

Since: API Level 4

Gets the package name of the source.

Returns
  • The package name.

public AccessibilityRecord getRecord (int index)

Since: API Level 14

Gets the record at a given index.

Parameters
index The index.
Returns
  • The record at the specified index.

public int getRecordCount ()

Since: API Level 14

Gets the number of records contained in the event.

Returns
  • The number of records.

public void initFromParcel (Parcel parcel)

Since: API Level 4

Creates a new instance from a Parcel.

Parameters
parcel A parcel containing the state of a AccessibilityEvent.

public static AccessibilityEvent obtain (int eventType)

Since: API Level 4

Returns a cached instance if such is available or a new one is instantiated with its type property set.

Parameters
eventType The event type.
Returns
  • An instance.

public static AccessibilityEvent obtain ()

Since: API Level 4

Returns a cached instance if such is available or a new one is instantiated.

Returns
  • An instance.

public static AccessibilityEvent obtain (AccessibilityEvent event)

Since: API Level 14

Returns a cached instance if such is available or a new one is created. The returned instance is initialized from the given event.

Parameters
event The other event.
Returns
  • An instance.

public void recycle ()

Since: API Level 4

Recycles an instance back to be reused.

Note: You must not touch the object after calling this function.

Throws
IllegalStateException If the event is already recycled.

public void setEventTime (long eventTime)

Since: API Level 4

Sets the time in which this event was sent.

Parameters
eventTime The event time.
Throws
IllegalStateException If called from an AccessibilityService.

public void setEventType (int eventType)

Since: API Level 4

Sets the event type.

Parameters
eventType The event type.
Throws
IllegalStateException If called from an AccessibilityService.

public void setPackageName (CharSequence packageName)

Since: API Level 4

Sets the package name of the source.

Parameters
packageName The package name.
Throws
IllegalStateException If called from an AccessibilityService.

public String toString ()

Since: API Level 4

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 is equivalent to the following expression:

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

See Writing a useful toString method if you intend implementing your own toString method.

Returns
  • a printable representation of this object.

public void writeToParcel (Parcel parcel, int flags)

Since: API Level 4

Flatten this object in to a Parcel.

Parameters
parcel 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.