public class

Intent

extends Object
implements Parcelable
java.lang.Object
   ↳ android.content.Intent

Class Overview

An intent is an abstract description of an operation to be performed. It can be used with startActivity to launch an Activity, broadcastIntent to send it to any interested BroadcastReceiver components, and startService(Intent) or bindService(Intent, ServiceConnection, int) to communicate with a background Service.

An Intent provides a facility for performing late runtime binding between the code in different applications. Its most significant use is in the launching of activities, where it can be thought of as the glue between activities. It is basically a passive data structure holding an abstract description of an action to be performed. The primary pieces of information in an intent are:

  • action -- The general action to be performed, such as ACTION_VIEW, ACTION_EDIT, ACTION_MAIN, etc.

  • data -- The data to operate on, such as a person record in the contacts database, expressed as a Uri.

Some examples of action/data pairs are:

  • ACTION_VIEW content://contacts/1 -- Display information about the person whose identifier is "1".

  • ACTION_DIAL content://contacts/1 -- Display the phone dialer with the person filled in.

  • ACTION_VIEW tel:123 -- Display the phone dialer with the given number filled in. Note how the VIEW action does what what is considered the most reasonable thing for a particular URI.

  • ACTION_DIAL tel:123 -- Display the phone dialer with the given number filled in.

  • ACTION_EDIT content://contacts/1 -- Edit information about the person whose identifier is "1".

  • ACTION_VIEW content://contacts/ -- Display a list of people, which the user can browse through. This example is a typical top-level entry into the Contacts application, showing you the list of people. Selecting a particular person to view would result in a new intent { ACTION_VIEW content://contacts/N } being used to start an activity to display that person.

In addition to these primary attributes, there are a number of secondary attributes that you can also include with an intent:

  • category -- Gives additional information about the action to execute. For example, CATEGORY_LAUNCHER means it should appear in the Launcher as a top-level application, while CATEGORY_ALTERNATIVE means it should be included in a list of alternative actions the user can perform on a piece of data.

  • type -- Specifies an explicit type (a MIME type) of the intent data. Normally the type is inferred from the data itself. By setting this attribute, you disable that evaluation and force an explicit type.

  • component -- Specifies an explicit name of a component class to use for the intent. Normally this is determined by looking at the other information in the intent (the action, data/type, and categories) and matching that with a component that can handle it. If this attribute is set then none of the evaluation is performed, and this component is used exactly as is. By specifying this attribute, all of the other Intent attributes become optional.

  • extras -- This is a Bundle of any additional information. This can be used to provide extended information to the component. For example, if we have a action to send an e-mail message, we could also include extra pieces of data here to supply a subject, body, etc.

Here are some examples of other operations you can specify as intents using these additional parameters:

There are a variety of standard Intent action and category constants defined in the Intent class, but applications can also define their own. These strings use java style scoping, to ensure they are unique -- for example, the standard ACTION_VIEW is called "android.app.action.VIEW".

Put together, the set of actions, data types, categories, and extra data defines a language for the system allowing for the expression of phrases such as "call john smith's cell". As applications are added to the system, they can extend this language by adding new actions, types, and categories, or they can modify the behavior of existing phrases by supplying their own activities that handle them.

Intent Resolution

There are two primary forms of intents you will use.

  • Explicit Intents have specified a component (via setComponent(ComponentName) or setClass(Context, Class)), which provides the exact class to be run. Often these will not include any other information, simply being a way for an application to launch various internal activities it has as the user interacts with the application.

  • Implicit Intents have not specified a component; instead, they must include enough information for the system to determine which of the available components is best to run for that intent.

When using implicit intents, given such an arbitrary intent we need to know what to do with it. This is handled by the process of Intent resolution, which maps an Intent to an Activity, BroadcastReceiver, or Service (or sometimes two or more activities/receivers) that can handle it.

The intent resolution mechanism basically revolves around matching an Intent against all of the <intent-filter> descriptions in the installed application packages. (Plus, in the case of broadcasts, any BroadcastReceiver objects explicitly registered with registerReceiver(BroadcastReceiver, IntentFilter).) More details on this can be found in the documentation on the IntentFilter class.

There are three pieces of information in the Intent that are used for resolution: the action, type, and category. Using this information, a query is done on the PackageManager for a component that can handle the intent. The appropriate component is determined based on the intent information supplied in the AndroidManifest.xml file as follows:

  • The action, if given, must be listed by the component as one it handles.

  • The type is retrieved from the Intent's data, if not already supplied in the Intent. Like the action, if a type is included in the intent (either explicitly or implicitly in its data), then this must be listed by the component as one it handles.

  • For data that is not a content: URI and where no explicit type is included in the Intent, instead the scheme of the intent data (such as http: or mailto:) is considered. Again like the action, if we are matching a scheme it must be listed by the component as one it can handle.
  • The categories, if supplied, must all be listed by the activity as categories it handles. That is, if you include the categories CATEGORY_LAUNCHER and CATEGORY_ALTERNATIVE, then you will only resolve to components with an intent that lists both of those categories. Activities will very often need to support the CATEGORY_DEFAULT so that they can be found by Context.startActivity().

For example, consider the Note Pad sample application that allows user to browse through a list of notes data and view details about individual items. Text in italics indicate places were you would replace a name with one specific to your own package.

 <manifest xmlns:android="http://schemas.android.com/apk/res/android"
       package="com.android.notepad">
     <application android:icon="@drawable/app_notes"
             android:label="@string/app_name">

         <provider class=".NotePadProvider"
                 android:authorities="com.google.provider.NotePad" />

         <activity class=".NotesList" android:label="@string/title_notes_list">
             <intent-filter>
                 <action android:name="android.intent.action.MAIN" />
                 <category android:name="android.intent.category.LAUNCHER" />
             </intent-filter>
             <intent-filter>
                 <action android:name="android.intent.action.VIEW" />
                 <action android:name="android.intent.action.EDIT" />
                 <action android:name="android.intent.action.PICK" />
                 <category android:name="android.intent.category.DEFAULT" />
                 <data android:mimeType="vnd.android.cursor.dir/vnd.google.note" />
             </intent-filter>
             <intent-filter>
                 <action android:name="android.intent.action.GET_CONTENT" />
                 <category android:name="android.intent.category.DEFAULT" />
                 <data android:mimeType="vnd.android.cursor.item/vnd.google.note" />
             </intent-filter>
         </activity>

         <activity class=".NoteEditor" android:label="@string/title_note">
             <intent-filter android:label="@string/resolve_edit">
                 <action android:name="android.intent.action.VIEW" />
                 <action android:name="android.intent.action.EDIT" />
                 <category android:name="android.intent.category.DEFAULT" />
                 <data android:mimeType="vnd.android.cursor.item/vnd.google.note" />
             </intent-filter>

             <intent-filter>
                 <action android:name="android.intent.action.INSERT" />
                 <category android:name="android.intent.category.DEFAULT" />
                 <data android:mimeType="vnd.android.cursor.dir/vnd.google.note" />
             </intent-filter>

         </activity>

         <activity class=".TitleEditor" android:label="@string/title_edit_title"
                 android:theme="@android:style/Theme.Dialog">
             <intent-filter android:label="@string/resolve_title">
                 <action android:name="com.android.notepad.action.EDIT_TITLE" />
                 <category android:name="android.intent.category.DEFAULT" />
                 <category android:name="android.intent.category.ALTERNATIVE" />
                 <category android:name="android.intent.category.SELECTED_ALTERNATIVE" />
                 <data android:mimeType="vnd.android.cursor.item/vnd.google.note" />
             </intent-filter>
         </activity>

     </application>
 </manifest>

The first activity, com.android.notepad.NotesList, serves as our main entry into the app. It can do three things as described by its three intent templates:

  1.  <intent-filter>
         <action android:name="android.intent.action.MAIN" />
         <category android:name="android.intent.category.LAUNCHER" />
     </intent-filter>

    This provides a top-level entry into the NotePad application: the standard MAIN action is a main entry point (not requiring any other information in the Intent), and the LAUNCHER category says that this entry point should be listed in the application launcher.

  2.  <intent-filter>
         <action android:name="android.intent.action.VIEW" />
         <action android:name="android.intent.action.EDIT" />
         <action android:name="android.intent.action.PICK" />
         <category android:name="android.intent.category.DEFAULT" />
         <data mimeType:name="vnd.android.cursor.dir/vnd.google.note" />
     </intent-filter>

    This declares the things that the activity can do on a directory of notes. The type being supported is given with the <type> tag, where vnd.android.cursor.dir/vnd.google.note is a URI from which a Cursor of zero or more items (vnd.android.cursor.dir) can be retrieved which holds our note pad data (vnd.google.note). The activity allows the user to view or edit the directory of data (via the VIEW and EDIT actions), or to pick a particular note and return it to the caller (via the PICK action). Note also the DEFAULT category supplied here: this is required for the Context.startActivity method to resolve your activity when its component name is not explicitly specified.

  3.  <intent-filter>
         <action android:name="android.intent.action.GET_CONTENT" />
         <category android:name="android.intent.category.DEFAULT" />
         <data android:mimeType="vnd.android.cursor.item/vnd.google.note" />
     </intent-filter>

    This filter describes the ability return to the caller a note selected by the user without needing to know where it came from. The data type vnd.android.cursor.item/vnd.google.note is a URI from which a Cursor of exactly one (vnd.android.cursor.item) item can be retrieved which contains our note pad data (vnd.google.note). The GET_CONTENT action is similar to the PICK action, where the activity will return to its caller a piece of data selected by the user. Here, however, the caller specifies the type of data they desire instead of the type of data the user will be picking from.

Given these capabilities, the following intents will resolve to the NotesList activity:

  • { action=android.app.action.MAIN } matches all of the activities that can be used as top-level entry points into an application.

  • { action=android.app.action.MAIN, category=android.app.category.LAUNCHER } is the actual intent used by the Launcher to populate its top-level list.

  • { action=android.app.action.VIEW data=content://com.google.provider.NotePad/notes } displays a list of all the notes under "content://com.google.provider.NotePad/notes", which the user can browse through and see the details on.

  • { action=android.app.action.PICK data=content://com.google.provider.NotePad/notes } provides a list of the notes under "content://com.google.provider.NotePad/notes", from which the user can pick a note whose data URL is returned back to the caller.

  • { action=android.app.action.GET_CONTENT type=vnd.android.cursor.item/vnd.google.note } is similar to the pick action, but allows the caller to specify the kind of data they want back so that the system can find the appropriate activity to pick something of that data type.

The second activity, com.android.notepad.NoteEditor, shows the user a single note entry and allows them to edit it. It can do two things as described by its two intent templates:

  1.  <intent-filter android:label="@string/resolve_edit">
         <action android:name="android.intent.action.VIEW" />
         <action android:name="android.intent.action.EDIT" />
         <category android:name="android.intent.category.DEFAULT" />
         <data android:mimeType="vnd.android.cursor.item/vnd.google.note" />
     </intent-filter>

    The first, primary, purpose of this activity is to let the user interact with a single note, as decribed by the MIME type vnd.android.cursor.item/vnd.google.note. The activity can either VIEW a note or allow the user to EDIT it. Again we support the DEFAULT category to allow the activity to be launched without explicitly specifying its component.

  2.  <intent-filter>
         <action android:name="android.intent.action.INSERT" />
         <category android:name="android.intent.category.DEFAULT" />
         <data android:mimeType="vnd.android.cursor.dir/vnd.google.note" />
     </intent-filter>

    The secondary use of this activity is to insert a new note entry into an existing directory of notes. This is used when the user creates a new note: the INSERT action is executed on the directory of notes, causing this activity to run and have the user create the new note data which it then adds to the content provider.

Given these capabilities, the following intents will resolve to the NoteEditor activity:

  • { action=android.app.action.VIEW data=content://com.google.provider.NotePad/notes/{ID} } shows the user the content of note {ID}.

  • { action=android.app.action.EDIT data=content://com.google.provider.NotePad/notes/{ID} } allows the user to edit the content of note {ID}.

  • { action=android.app.action.INSERT data=content://com.google.provider.NotePad/notes } creates a new, empty note in the notes list at "content://com.google.provider.NotePad/notes" and allows the user to edit it. If they keep their changes, the URI of the newly created note is returned to the caller.

The last activity, com.android.notepad.TitleEditor, allows the user to edit the title of a note. This could be implemented as a class that the application directly invokes (by explicitly setting its component in the Intent), but here we show a way you can publish alternative operations on existing data:

 <intent-filter android:label="@string/resolve_title">
     <action android:name="com.android.notepad.action.EDIT_TITLE" />
     <category android:name="android.intent.category.DEFAULT" />
     <category android:name="android.intent.category.ALTERNATIVE" />
     <category android:name="android.intent.category.SELECTED_ALTERNATIVE" />
     <data android:mimeType="vnd.android.cursor.item/vnd.google.note" />
 </intent-filter>

In the single intent template here, we have created our own private action called com.android.notepad.action.EDIT_TITLE which means to edit the title of a note. It must be invoked on a specific note (data type vnd.android.cursor.item/vnd.google.note) like the previous view and edit actions, but here displays and edits the title contained in the note data.

In addition to supporting the default category as usual, our title editor also supports two other standard categories: ALTERNATIVE and SELECTED_ALTERNATIVE. Implementing these categories allows others to find the special action it provides without directly knowing about it, through the queryIntentActivityOptions(ComponentName, Intent[], Intent, int) method, or more often to build dynamic menu items with addIntentOptions(int, int, int, ComponentName, Intent[], Intent, int, MenuItem[]). Note that in the intent template here was also supply an explicit name for the template (via android:label="@string/resolve_title") to better control what the user sees when presented with this activity as an alternative action to the data they are viewing.

Given these capabilities, the following intent will resolve to the TitleEditor activity:

  • { action=com.android.notepad.action.EDIT_TITLE data=content://com.google.provider.NotePad/notes/{ID} } displays and allows the user to edit the title associated with note {ID}.

Standard Activity Actions

These are the current standard actions that Intent defines for launching activities (usually through startActivity(Intent). The most important, and by far most frequently used, are ACTION_MAIN and ACTION_EDIT.

Standard Broadcast Actions

These are the current standard actions that Intent defines for receiving broadcasts (usually through registerReceiver(BroadcastReceiver, IntentFilter) or a <receiver> tag in a manifest).

Standard Categories

These are the current standard categories that can be used to further clarify an Intent via addCategory(String).

Standard Extra Data

These are the current standard fields that can be used as extra data via putExtra(String, Bundle).

Flags

These are the possible flags that can be used in the Intent via setFlags(int) and addFlags(int). See setFlags(int) for a list of all possible flags.

Summary

Nested Classes
class Intent.FilterComparison Wrapper class holding an Intent and implementing comparisons on it for the purpose of filtering. 
class Intent.ShortcutIconResource Represents a shortcut/live folder icon resource. 
Constants
String ACTION_AIRPLANE_MODE_CHANGED

Broadcast Action: The user has switched the phone into or out of Airplane Mode.

String ACTION_ALL_APPS Activity Action: List all available applications

Input: Nothing.

String ACTION_ANSWER Activity Action: Handle an incoming phone call.
String ACTION_ATTACH_DATA Used to indicate that some piece of data should be attached to some other place.
String ACTION_BATTERY_CHANGED Broadcast Action: The charging state, or charge level of the battery has changed.
String ACTION_BATTERY_LOW Broadcast Action: Indicates low battery condition on the device.
String ACTION_BATTERY_OKAY Broadcast Action: Indicates the battery is now okay after being low.
String ACTION_BOOT_COMPLETED Broadcast Action: This is broadcast once, after the system has finished booting.
String ACTION_BUG_REPORT Activity Action: Show activity for reporting a bug.
String ACTION_CALL Activity Action: Perform a call to someone specified by the data.
String ACTION_CALL_BUTTON Activity Action: The user pressed the "call" button to go to the dialer or other appropriate UI for placing a call.
String ACTION_CAMERA_BUTTON Broadcast Action: The "Camera Button" was pressed.
String ACTION_CHOOSER Activity Action: Display an activity chooser, allowing the user to pick what they want to before proceeding.
String ACTION_CLOSE_SYSTEM_DIALOGS Broadcast Action: This is broadcast when a user action should request a temporary system dialog to dismiss.
String ACTION_CONFIGURATION_CHANGED Broadcast Action: The current device Configuration (orientation, locale, etc) has changed.
String ACTION_CREATE_SHORTCUT Activity Action: Creates a shortcut.
String ACTION_DATE_CHANGED Broadcast Action: The date has changed.
String ACTION_DEFAULT A synonym for ACTION_VIEW, the "standard" action that is performed on a piece of data.
String ACTION_DELETE Activity Action: Delete the given data from its container.
String ACTION_DEVICE_STORAGE_LOW Broadcast Action: Indicates low memory condition on the device

This is a protected intent that can only be sent by the system.

String ACTION_DEVICE_STORAGE_OK Broadcast Action: Indicates low memory condition on the device no longer exists

This is a protected intent that can only be sent by the system.

String ACTION_DIAL Activity Action: Dial a number as specified by the data.
String ACTION_EDIT Activity Action: Provide explicit editable access to the given data.
String ACTION_FACTORY_TEST Activity Action: Main entry point for factory tests.
String ACTION_GET_CONTENT Activity Action: Allow the user to select a particular kind of data and return it.
String ACTION_GTALK_SERVICE_CONNECTED Broadcast Action: An GTalk connection has been established.
String ACTION_GTALK_SERVICE_DISCONNECTED Broadcast Action: An GTalk connection has been disconnected.
String ACTION_HEADSET_PLUG Broadcast Action: Wired Headset plugged in or unplugged.
String ACTION_INPUT_METHOD_CHANGED Broadcast Action: An input method has been changed.
String ACTION_INSERT Activity Action: Insert an empty item into the given container.
String ACTION_INSERT_OR_EDIT Activity Action: Pick an existing item, or insert a new item, and then edit it.
String ACTION_MAIN Activity Action: Start as a main entry point, does not expect to receive data.
String ACTION_MANAGE_PACKAGE_STORAGE Broadcast Action: Indicates low memory condition notification acknowledged by user and package management should be started.
String ACTION_MEDIA_BAD_REMOVAL Broadcast Action: External media was removed from SD card slot, but mount point was not unmounted.
String ACTION_MEDIA_BUTTON Broadcast Action: The "Media Button" was pressed.
String ACTION_MEDIA_CHECKING Broadcast Action: External media is present, and being disk-checked The path to the mount point for the checking media is contained in the Intent.mData field.
String ACTION_MEDIA_EJECT Broadcast Action: User has expressed the desire to remove the external storage media.
String ACTION_MEDIA_MOUNTED Broadcast Action: External media is present and mounted at its mount point.
String ACTION_MEDIA_NOFS Broadcast Action: External media is present, but is using an incompatible fs (or is blank) The path to the mount point for the checking media is contained in the Intent.mData field.
String ACTION_MEDIA_REMOVED Broadcast Action: External media has been removed.
String ACTION_MEDIA_SCANNER_FINISHED Broadcast Action: The media scanner has finished scanning a directory.
String ACTION_MEDIA_SCANNER_SCAN_FILE Broadcast Action: Request the media scanner to scan a file and add it to the media database.
String ACTION_MEDIA_SCANNER_STARTED Broadcast Action: The media scanner has started scanning a directory.
String ACTION_MEDIA_SHARED Broadcast Action: External media is unmounted because it is being shared via USB mass storage.
String ACTION_MEDIA_UNMOUNTABLE Broadcast Action: External media is present but cannot be mounted.
String ACTION_MEDIA_UNMOUNTED Broadcast Action: External media is present, but not mounted at its mount point.
String ACTION_NEW_OUTGOING_CALL Broadcast Action: An outgoing call is about to be placed.
String ACTION_PACKAGE_ADDED Broadcast Action: A new application package has been installed on the device.
String ACTION_PACKAGE_CHANGED Broadcast Action: An existing application package has been changed (e.g.
String ACTION_PACKAGE_DATA_CLEARED Broadcast Action: The user has cleared the data of a package.
String ACTION_PACKAGE_INSTALL Broadcast Action: Trigger the download and eventual installation of a package.
String ACTION_PACKAGE_REMOVED Broadcast Action: An existing application package has been removed from the device.
String ACTION_PACKAGE_REPLACED Broadcast Action: A new version of an application package has been installed, replacing an existing version that was previously installed.
String ACTION_PACKAGE_RESTARTED Broadcast Action: The user has restarted a package, and all of its processes have been killed.
String ACTION_PICK Activity Action: Pick an item from the data, returning what was selected.
String ACTION_PICK_ACTIVITY Activity Action: Pick an activity given an intent, returning the class selected.
String ACTION_POWER_CONNECTED Broadcast Action: External power has been connected to the device.
String ACTION_POWER_DISCONNECTED Broadcast Action: External power has been removed from the device.
String ACTION_POWER_USAGE_SUMMARY Activity Action: Show power usage information to the user.
String ACTION_PROVIDER_CHANGED Broadcast Action: Some content providers have parts of their namespace where they publish new events or items that the user may be especially interested in.
String ACTION_REBOOT Broadcast Action: Have the device reboot.
String ACTION_RUN Activity Action: Run the data, whatever that means.
String ACTION_SCREEN_OFF Broadcast Action: Sent after the screen turns off.
String ACTION_SCREEN_ON Broadcast Action: Sent after the screen turns on.
String ACTION_SEARCH Activity Action: Perform a search.
String ACTION_SEARCH_LONG_PRESS Activity Action: Start action associated with long pressing on the search key.
String ACTION_SEND Activity Action: Deliver some data to someone else.
String ACTION_SENDTO Activity Action: Send a message to someone specified by the data.
String ACTION_SEND_MULTIPLE Activity Action: Deliver multiple data to someone else.
String ACTION_SET_WALLPAPER Activity Action: Show settings for choosing wallpaper

Input: Nothing.

String ACTION_SHUTDOWN Broadcast Action: Device is shutting down.
String ACTION_SYNC Activity Action: Perform a data synchronization.
String ACTION_SYSTEM_TUTORIAL Activity Action: Start the platform-defined tutorial

Input: getStringExtra(SearchManager.QUERY) is the text to search for.

String ACTION_TIMEZONE_CHANGED Broadcast Action: The timezone has changed.
String ACTION_TIME_CHANGED Broadcast Action: The time was set.
String ACTION_TIME_TICK Broadcast Action: The current time has changed.
String ACTION_UID_REMOVED Broadcast Action: A user ID has been removed from the system.
String ACTION_UMS_CONNECTED Broadcast Action: The device has entered USB Mass Storage mode.
String ACTION_UMS_DISCONNECTED Broadcast Action: The device has exited USB Mass Storage mode.
String ACTION_USER_PRESENT Broadcast Action: Sent when the user is present after device wakes up (e.g when the keyguard is gone).
String ACTION_VIEW Activity Action: Display the data to the user.
String ACTION_VOICE_COMMAND Activity Action: Start Voice Command.
String ACTION_WALLPAPER_CHANGED Broadcast Action: The current system wallpaper has changed.
String ACTION_WEB_SEARCH Activity Action: Perform a web search.
String CATEGORY_ALTERNATIVE Set if the activity should be considered as an alternative action to the data the user is currently viewing.
String CATEGORY_BROWSABLE Activities that can be safely invoked from a browser must support this category.
String CATEGORY_DEFAULT Set if the activity should be an option for the default action (center press) to perform on a piece of data.
String CATEGORY_DEVELOPMENT_PREFERENCE This activity is a development preference panel.
String CATEGORY_EMBED Capable of running inside a parent activity container.
String CATEGORY_FRAMEWORK_INSTRUMENTATION_TEST To be used as code under test for framework instrumentation tests.
String CATEGORY_HOME This is the home activity, that is the first activity that is displayed when the device boots.
String CATEGORY_INFO Provides information about the package it is in; typically used if a package does not contain a CATEGORY_LAUNCHER to provide a front-door to the user without having to be shown in the all apps list.
String CATEGORY_LAUNCHER Should be displayed in the top-level launcher.
String CATEGORY_MONKEY This activity may be exercised by the monkey or other automated test tools.
String CATEGORY_OPENABLE Used to indicate that a GET_CONTENT intent only wants URIs that can be opened with ContentResolver.openInputStream.
String CATEGORY_PREFERENCE This activity is a preference panel.
String CATEGORY_SAMPLE_CODE To be used as an sample code example (not part of the normal user experience).
String CATEGORY_SELECTED_ALTERNATIVE Set if the activity should be considered as an alternative selection action to the data the user has currently selected.
String CATEGORY_TAB Intended to be used as a tab inside of an containing TabActivity.
String CATEGORY_TEST To be used as a test (not part of the normal user experience).
String CATEGORY_UNIT_TEST To be used as a unit test (run through the Test Harness).
Creator<Intent> CREATOR
String EXTRA_ALARM_COUNT Used as an int extra field in AlarmManager intents to tell the application being invoked how many pending alarms are being delievered with the intent.
String EXTRA_BCC A String[] holding e-mail addresses that should be blind carbon copied.
String EXTRA_CC A String[] holding e-mail addresses that should be carbon copied.
String EXTRA_DATA_REMOVED Used as a boolean extra field in ACTION_PACKAGE_REMOVED intents to indicate whether this represents a full uninstall (removing both the code and its data) or a partial uninstall (leaving its data, implying that this is an update).
String EXTRA_DONT_KILL_APP Used as an boolean extra field in ACTION_PACKAGE_REMOVED or ACTION_PACKAGE_CHANGED intents to override the default action of restarting the application.
String EXTRA_EMAIL A String[] holding e-mail addresses that should be delivered to.
String EXTRA_INTENT An Intent describing the choices you would like shown with ACTION_PICK_ACTIVITY.
String EXTRA_KEY_EVENT A KeyEvent object containing the event that triggered the creation of the Intent it is in.
String EXTRA_PHONE_NUMBER A String holding the phone number originally entered in ACTION_NEW_OUTGOING_CALL, or the actual number to call in a ACTION_CALL.
String EXTRA_REPLACING Used as a boolean extra field in ACTION_PACKAGE_REMOVED intents to indicate that this is a replacement of the package, so this broadcast will immediately be followed by an add broadcast for a different version of the same package.
String EXTRA_SHORTCUT_ICON The name of the extra used to define the icon, as a Bitmap, of a shortcut.
String EXTRA_SHORTCUT_ICON_RESOURCE The name of the extra used to define the icon, as a ShortcutIconResource, of a shortcut.
String EXTRA_SHORTCUT_INTENT The name of the extra used to define the Intent of a shortcut.
String EXTRA_SHORTCUT_NAME The name of the extra used to define the name of a shortcut.
String EXTRA_STREAM A content: URI holding a stream of data associated with the Intent, used with ACTION_SEND to supply the data being sent.
String EXTRA_SUBJECT A constant string holding the desired subject line of a message.
String EXTRA_TEMPLATE The initial data to place in a newly created record.
String EXTRA_TEXT A constant CharSequence that is associated with the Intent, used with ACTION_SEND to supply the literal data to be sent.
String EXTRA_TITLE A CharSequence dialog title to provide to the user when used with a ACTION_CHOOSER.
String EXTRA_UID Used as an int extra field in ACTION_UID_REMOVED intents to supply the uid the package had been assigned.
int FILL_IN_ACTION Use with fillIn(Intent, int) to allow the current action value to be overwritten, even if it is already set.
int FILL_IN_CATEGORIES Use with fillIn(Intent, int) to allow the current categories to be overwritten, even if they are already set.
int FILL_IN_COMPONENT Use with fillIn(Intent, int) to allow the current component value to be overwritten, even if it is already set.
int FILL_IN_DATA Use with fillIn(Intent, int) to allow the current data or type value overwritten, even if it is already set.
int FILL_IN_PACKAGE Use with fillIn(Intent, int) to allow the current package value to be overwritten, even if it is already set.
int FLAG_ACTIVITY_BROUGHT_TO_FRONT This flag is not normally set by application code, but set for you by the system as described in the launchMode documentation for the singleTask mode.
int FLAG_ACTIVITY_CLEAR_TOP If set, and the activity being launched is already running in the current task, then instead of launching a new instance of that activity, all of the other activities on top of it will be closed and this Intent will be delivered to the (now on top) old activity as a new Intent.
int FLAG_ACTIVITY_CLEAR_WHEN_TASK_RESET If set, this marks a point in the task's activity stack that should be cleared when the task is reset.
int FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS If set, the new activity is not kept in the list of recently launched activities.
int FLAG_ACTIVITY_FORWARD_RESULT If set and this intent is being used to launch a new activity from an existing one, then the reply target of the existing activity will be transfered to the new activity.
int FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY This flag is not normally set by application code, but set for you by the system if this activity is being launched from history (longpress home key).
int FLAG_ACTIVITY_MULTIPLE_TASK Do not use this flag unless you are implementing your own top-level application launcher.
int FLAG_ACTIVITY_NEW_TASK If set, this activity will become the start of a new task on this history stack.
int FLAG_ACTIVITY_NO_HISTORY If set, the new activity is not kept in the history stack.
int FLAG_ACTIVITY_NO_USER_ACTION If set, this flag will prevent the normal onUserLeaveHint() callback from occurring on the current frontmost activity before it is paused as the newly-started activity is brought to the front.
int FLAG_ACTIVITY_PREVIOUS_IS_TOP If set and this intent is being used to launch a new activity from an existing one, the current activity will not be counted as the top activity for deciding whether the new intent should be delivered to the top instead of starting a new one.
int FLAG_ACTIVITY_REORDER_TO_FRONT If set in an Intent passed to Context.startActivity(), this flag will cause the launched activity to be brought to the front of its task's history stack if it is already running.
int FLAG_ACTIVITY_RESET_TASK_IF_NEEDED If set, and this activity is either being started in a new task or bringing to the top an existing task, then it will be launched as the front door of the task.
int FLAG_ACTIVITY_SINGLE_TOP If set, the activity will not be launched if it is already running at the top of the history stack.
int FLAG_DEBUG_LOG_RESOLUTION A flag you can enable for debugging: when set, log messages will be printed during the resolution of this intent to show you what has been found to create the final resolved list.
int FLAG_FROM_BACKGROUND Can be set by the caller to indicate that this Intent is coming from a background operation, not from direct user interaction.
int FLAG_GRANT_READ_URI_PERMISSION If set, the recipient of this Intent will be granted permission to perform read operations on the Uri in the Intent's data.
int FLAG_GRANT_WRITE_URI_PERMISSION If set, the recipient of this Intent will be granted permission to perform write operations on the Uri in the Intent's data.
int FLAG_RECEIVER_REGISTERED_ONLY If set, when sending a broadcast only registered receivers will be called -- no BroadcastReceiver components will be launched.
int URI_INTENT_SCHEME Flag for use with toUri(int) and parseUri(String, int): the URI string always has the "intent:" scheme.
[Expand]
Inherited Constants
From interface android.os.Parcelable
Public Constructors
Intent()
Create an empty intent.
Intent(Intent o)
Copy constructor.
Intent(String action)
Create an intent with a given action.
Intent(String action, Uri uri)
Create an intent with a given action and for a given data url.
Intent(Context packageContext, Class<?> cls)
Create an intent for a specific component.
Intent(String action, Uri uri, Context packageContext, Class<?> cls)
Create an intent for a specific component with a specified action and data.
Public Methods
Intent addCategory(String category)
Add a new category to the intent.
Intent addFlags(int flags)
Add additional flags to the intent (or with existing flags value).
Object clone()
Creates and returns a copy of this Object.
Intent cloneFilter()
Make a clone of only the parts of the Intent that are relevant for filter matching: the action, data, type, component, and categories.
static Intent createChooser(Intent target, CharSequence title)
Convenience function for creating a ACTION_CHOOSER Intent.
int describeContents()
Describe the kinds of special objects contained in this Parcelable's marshalled representation.
int fillIn(Intent other, int flags)
Copy the contents of other in to this object, but only where fields are not defined by this object.
boolean filterEquals(Intent other)
Determine if two intents are the same for the purposes of intent resolution (filtering).
int filterHashCode()
Generate hash code that matches semantics of filterEquals().
String getAction()
Retrieve the general action to be performed, such as ACTION_VIEW.
boolean[] getBooleanArrayExtra(String name)
Retrieve extended data from the intent.
boolean getBooleanExtra(String name, boolean defaultValue)
Retrieve extended data from the intent.
Bundle getBundleExtra(String name)
Retrieve extended data from the intent.
byte[] getByteArrayExtra(String name)
Retrieve extended data from the intent.
byte getByteExtra(String name, byte defaultValue)
Retrieve extended data from the intent.
Set<String> getCategories()
Return the set of all categories in the intent.
char[] getCharArrayExtra(String name)
Retrieve extended data from the intent.
char getCharExtra(String name, char defaultValue)
Retrieve extended data from the intent.
CharSequence getCharSequenceExtra(String name)
Retrieve extended data from the intent.
ComponentName getComponent()
Retrieve the concrete component associated with the intent.
Uri getData()
Retrieve data this intent is operating on.
String getDataString()
The same as getData(), but returns the URI as an encoded String.
double[] getDoubleArrayExtra(String name)
Retrieve extended data from the intent.
double getDoubleExtra(String name, double defaultValue)
Retrieve extended data from the intent.
Bundle getExtras()
Retrieves a map of extended data from the intent.
int getFlags()
Retrieve any special flags associated with this intent.
float[] getFloatArrayExtra(String name)
Retrieve extended data from the intent.
float getFloatExtra(String name, float defaultValue)
Retrieve extended data from the intent.
int[] getIntArrayExtra(String name)
Retrieve extended data from the intent.
int getIntExtra(String name, int defaultValue)
Retrieve extended data from the intent.
ArrayList<Integer> getIntegerArrayListExtra(String name)
Retrieve extended data from the intent.
static Intent getIntent(String uri)
This method is deprecated. Use parseUri(String, int) instead.
static Intent getIntentOld(String uri)
long[] getLongArrayExtra(String name)
Retrieve extended data from the intent.
long getLongExtra(String name, long defaultValue)
Retrieve extended data from the intent.
String getPackage()
Retrieve the application package name this Intent is limited to.
Parcelable[] getParcelableArrayExtra(String name)
Retrieve extended data from the intent.
<T extends Parcelable> ArrayList<T> getParcelableArrayListExtra(String name)
Retrieve extended data from the intent.
<T extends Parcelable> T getParcelableExtra(String name)
Retrieve extended data from the intent.
String getScheme()
Return the scheme portion of the intent's data.
Serializable getSerializableExtra(String name)
Retrieve extended data from the intent.
short[] getShortArrayExtra(String name)
Retrieve extended data from the intent.
short getShortExtra(String name, short defaultValue)
Retrieve extended data from the intent.
String[] getStringArrayExtra(String name)
Retrieve extended data from the intent.
ArrayList<String> getStringArrayListExtra(String name)
Retrieve extended data from the intent.
String getStringExtra(String name)
Retrieve extended data from the intent.
String getType()
Retrieve any explicit MIME type included in the intent.
boolean hasCategory(String category)
Check if an category exists in the intent.
boolean hasExtra(String name)
Returns true if an extra value is associated with the given name.
boolean hasFileDescriptors()
Returns true if the Intent's extras contain a parcelled file descriptor.
static Intent parseIntent(Resources resources, XmlPullParser parser, AttributeSet attrs)
Parses the "intent" element (and its children) from XML and instantiates an Intent object.
static Intent parseUri(String uri, int flags)
Create an intent from a URI.
Intent putExtra(String name, String[] value)
Add extended data to the intent.
Intent putExtra(String name, Parcelable value)
Add extended data to the intent.
Intent putExtra(String name, long value)
Add extended data to the intent.
Intent putExtra(String name, boolean value)
Add extended data to the intent.
Intent putExtra(String name, double value)
Add extended data to the intent.
Intent putExtra(String name, Parcelable[] value)
Add extended data to the intent.
Intent putExtra(String name, char value)
Add extended data to the intent.
Intent putExtra(String name, int[] value)
Add extended data to the intent.
Intent putExtra(String name, int value)
Add extended data to the intent.
Intent putExtra(String name, double[] value)
Add extended data to the intent.
Intent putExtra(String name, float value)
Add extended data to the intent.
Intent putExtra(String name, short value)
Add extended data to the intent.
Intent putExtra(String name, long[] value)
Add extended data to the intent.
Intent putExtra(String name, boolean[] value)
Add extended data to the intent.
Intent putExtra(String name, short[] value)
Add extended data to the intent.
Intent putExtra(String name, String value)
Add extended data to the intent.
Intent putExtra(String name, Serializable value)
Add extended data to the intent.
Intent putExtra(String name, float[] value)
Add extended data to the intent.
Intent putExtra(String name, Bundle value)
Add extended data to the intent.
Intent putExtra(String name, byte[] value)
Add extended data to the intent.
Intent putExtra(String name, CharSequence value)
Add extended data to the intent.
Intent putExtra(String name, char[] value)
Add extended data to the intent.
Intent putExtra(String name, byte value)
Add extended data to the intent.
Intent putExtras(Intent src)
Copy all extras in 'src' in to this intent.
Intent putExtras(Bundle extras)
Add a set of extended data to the intent.
Intent putIntegerArrayListExtra(String name, ArrayList<Integer> value)
Add extended data to the intent.
Intent putParcelableArrayListExtra(String name, ArrayList<? extends Parcelable> value)
Add extended data to the intent.
Intent putStringArrayListExtra(String name, ArrayList<String> value)
Add extended data to the intent.
void readFromParcel(Parcel in)
void removeCategory(String category)
Remove an category from an intent.
void removeExtra(String name)
Remove extended data from the intent.
Intent replaceExtras(Intent src)
Completely replace the extras in the Intent with the extras in the given Intent.
Intent replaceExtras(Bundle extras)
Completely replace the extras in the Intent with the given Bundle of extras.
ComponentName resolveActivity(PackageManager pm)
Return the Activity component that should be used to handle this intent.
ActivityInfo resolveActivityInfo(PackageManager pm, int flags)
Resolve the Intent into an ActivityInfo describing the activity that should execute the intent.
String resolveType(ContentResolver resolver)
Return the MIME data type of this intent.
String resolveType(Context context)
Return the MIME data type of this intent.
String resolveTypeIfNeeded(ContentResolver resolver)
Return the MIME data type of this intent, only if it will be needed for intent resolution.
Intent setAction(String action)
Set the general action to be performed.
Intent setClass(Context packageContext, Class<?> cls)
Convenience for calling setComponent(ComponentName) with the name returned by a Class object.
Intent setClassName(String packageName, String className)
Convenience for calling setComponent(ComponentName) with an explicit application package name and class name.
Intent setClassName(Context packageContext, String className)
Convenience for calling setComponent(ComponentName) with an explicit class name.
Intent setComponent(ComponentName component)
(Usually optional) Explicitly set the component to handle the intent.
Intent setData(Uri data)
Set the data this intent is operating on.
Intent setDataAndType(Uri data, String type)
(Usually optional) Set the data for the intent along with an explicit MIME data type.
void setExtrasClassLoader(ClassLoader loader)
Sets the ClassLoader that will be used when unmarshalling any Parcelable values from the extras of this Intent.
Intent setFlags(int flags)
Set special flags controlling how this intent is handled.
Intent setPackage(String packageName)
(Usually optional) Set an explicit application package name that limits the components this Intent will resolve to.
Intent setType(String type)
Set an explicit MIME data type.
String toString()
Returns a string containing a concise, human-readable description of this object.
String toURI()
This method is deprecated. Use toUri(int) instead.
String toUri(int flags)
Convert this Intent into a String holding a URI representation of it.
void writeToParcel(Parcel out, 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 String ACTION_AIRPLANE_MODE_CHANGED

Since: API Level 1

Broadcast Action: The user has switched the phone into or out of Airplane Mode. One or more radios have been turned off or on. The intent will have the following extra value:

  • state - A boolean value indicating whether Airplane Mode is on. If true, then cell radio and possibly other radios such as bluetooth or WiFi may have also been turned off

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.AIRPLANE_MODE"

public static final String ACTION_ALL_APPS

Since: API Level 1

Activity Action: List all available applications

Input: Nothing.

Output: nothing.

Constant Value: "android.intent.action.ALL_APPS"

public static final String ACTION_ANSWER

Since: API Level 1

Activity Action: Handle an incoming phone call.

Input: nothing.

Output: nothing.

Constant Value: "android.intent.action.ANSWER"

public static final String ACTION_ATTACH_DATA

Since: API Level 1

Used to indicate that some piece of data should be attached to some other place. For example, image data could be attached to a contact. It is up to the recipient to decide where the data should be attached; the intent does not specify the ultimate destination.

Input: getData() is URI of data to be attached.

Output: nothing.

Constant Value: "android.intent.action.ATTACH_DATA"

public static final String ACTION_BATTERY_CHANGED

Since: API Level 1

Broadcast Action: The charging state, or charge level of the battery has changed.

You can not receive this through components declared in manifests, only by explicitly registering for it with Context.registerReceiver().

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.BATTERY_CHANGED"

public static final String ACTION_BATTERY_LOW

Since: API Level 1

Broadcast Action: Indicates low battery condition on the device. This broadcast corresponds to the "Low battery warning" system dialog.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.BATTERY_LOW"

public static final String ACTION_BATTERY_OKAY

Since: API Level 4

Broadcast Action: Indicates the battery is now okay after being low. This will be sent after ACTION_BATTERY_LOW once the battery has gone back up to an okay state.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.BATTERY_OKAY"

public static final String ACTION_BOOT_COMPLETED

Since: API Level 1

Broadcast Action: This is broadcast once, after the system has finished booting. It can be used to perform application-specific initialization, such as installing alarms. You must hold the RECEIVE_BOOT_COMPLETED permission in order to receive this broadcast.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.BOOT_COMPLETED"

public static final String ACTION_BUG_REPORT

Since: API Level 1

Activity Action: Show activity for reporting a bug.

Input: Nothing.

Output: Nothing.

Constant Value: "android.intent.action.BUG_REPORT"

public static final String ACTION_CALL

Since: API Level 1

Activity Action: Perform a call to someone specified by the data.

Input: If nothing, an empty dialer is started; else getData() is URI of a phone number to be dialed or a tel: URI of an explicit phone number.

Output: nothing.

Note: there will be restrictions on which applications can initiate a call; most applications should use the ACTION_DIAL.

Note: this Intent cannot be used to call emergency numbers. Applications can dial emergency numbers using ACTION_DIAL, however.

Constant Value: "android.intent.action.CALL"

public static final String ACTION_CALL_BUTTON

Since: API Level 1

Activity Action: The user pressed the "call" button to go to the dialer or other appropriate UI for placing a call.

Input: Nothing.

Output: Nothing.

Constant Value: "android.intent.action.CALL_BUTTON"

public static final String ACTION_CAMERA_BUTTON

Since: API Level 1

Broadcast Action: The "Camera Button" was pressed. Includes a single extra field, EXTRA_KEY_EVENT, containing the key event that caused the broadcast.

Constant Value: "android.intent.action.CAMERA_BUTTON"

public static final String ACTION_CHOOSER

Since: API Level 1

Activity Action: Display an activity chooser, allowing the user to pick what they want to before proceeding. This can be used as an alternative to the standard activity picker that is displayed by the system when you try to start an activity with multiple possible matches, with these differences in behavior:

  • You can specify the title that will appear in the activity chooser.
  • The user does not have the option to make one of the matching activities a preferred activity, and all possible activities will always be shown even if one of them is currently marked as the preferred activity.

This action should be used when the user will naturally expect to select an activity in order to proceed. An example if when not to use it is when the user clicks on a "mailto:" link. They would naturally expect to go directly to their mail app, so startActivity() should be called directly: it will either launch the current preferred app, or put up a dialog allowing the user to pick an app to use and optionally marking that as preferred.

In contrast, if the user is selecting a menu item to send a picture they are viewing to someone else, there are many different things they may want to do at this point: send it through e-mail, upload it to a web service, etc. In this case the CHOOSER action should be used, to always present to the user a list of the things they can do, with a nice title given by the caller such as "Send this photo with:".

As a convenience, an Intent of this form can be created with the createChooser(Intent, CharSequence) function.

Input: No data should be specified. get*Extra must have a EXTRA_INTENT field containing the Intent being executed, and can optionally have a EXTRA_TITLE field containing the title text to display in the chooser.

Output: Depends on the protocol of EXTRA_INTENT.

Constant Value: "android.intent.action.CHOOSER"

public static final String ACTION_CLOSE_SYSTEM_DIALOGS

Since: API Level 1

Broadcast Action: This is broadcast when a user action should request a temporary system dialog to dismiss. Some examples of temporary system dialogs are the notification window-shade and the recent tasks dialog.

Constant Value: "android.intent.action.CLOSE_SYSTEM_DIALOGS"

public static final String ACTION_CONFIGURATION_CHANGED

Since: API Level 1

Broadcast Action: The current device Configuration (orientation, locale, etc) has changed. When such a change happens, the UIs (view hierarchy) will need to be rebuilt based on this new information; for the most part, applications don't need to worry about this, because the system will take care of stopping and restarting the application to make sure it sees the new changes. Some system code that can not be restarted will need to watch for this action and handle it appropriately.

This is a protected intent that can only be sent by the system.

See Also
Constant Value: "android.intent.action.CONFIGURATION_CHANGED"

public static final String ACTION_CREATE_SHORTCUT

Since: API Level 1

Activity Action: Creates a shortcut.

Input: Nothing.

Output: An Intent representing the shortcut. The intent must contain three extras: SHORTCUT_INTENT (value: Intent), SHORTCUT_NAME (value: String), and SHORTCUT_ICON (value: Bitmap) or SHORTCUT_ICON_RESOURCE (value: ShortcutIconResource).

Constant Value: "android.intent.action.CREATE_SHORTCUT"

public static final String ACTION_DATE_CHANGED

Since: API Level 1

Broadcast Action: The date has changed.

Constant Value: "android.intent.action.DATE_CHANGED"

public static final String ACTION_DEFAULT

Since: API Level 1

A synonym for ACTION_VIEW, the "standard" action that is performed on a piece of data.

Constant Value: "android.intent.action.VIEW"

public static final String ACTION_DELETE

Since: API Level 1

Activity Action: Delete the given data from its container.

Input: getData() is URI of data to be deleted.

Output: nothing.

Constant Value: "android.intent.action.DELETE"

public static final String ACTION_DEVICE_STORAGE_LOW

Since: API Level 1

Broadcast Action: Indicates low memory condition on the device

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.DEVICE_STORAGE_LOW"

public static final String ACTION_DEVICE_STORAGE_OK

Since: API Level 1

Broadcast Action: Indicates low memory condition on the device no longer exists

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.DEVICE_STORAGE_OK"

public static final String ACTION_DIAL

Since: API Level 1

Activity Action: Dial a number as specified by the data. This shows a UI with the number being dialed, allowing the user to explicitly initiate the call.

Input: If nothing, an empty dialer is started; else getData() is URI of a phone number to be dialed or a tel: URI of an explicit phone number.

Output: nothing.

Constant Value: "android.intent.action.DIAL"

public static final String ACTION_EDIT

Since: API Level 1

Activity Action: Provide explicit editable access to the given data.

Input: getData() is URI of data to be edited.

Output: nothing.

Constant Value: "android.intent.action.EDIT"

public static final String ACTION_FACTORY_TEST

Since: API Level 1

Activity Action: Main entry point for factory tests. Only used when the device is booting in factory test node. The implementing package must be installed in the system image.

Input: nothing

Output: nothing

Constant Value: "android.intent.action.FACTORY_TEST"

public static final String ACTION_GET_CONTENT

Since: API Level 1

Activity Action: Allow the user to select a particular kind of data and return it. This is different than ACTION_PICK in that here we just say what kind of data is desired, not a URI of existing data from which the user can pick. A ACTION_GET_CONTENT could allow the user to create the data as it runs (for example taking a picture or recording a sound), let them browser over the web and download the desired data, etc.

There are two main ways to use this action: if you want an specific kind of data, such as a person contact, you set the MIME type to the kind of data you want and launch it with startActivity(Intent). The system will then launch the best application to select that kind of data for you.

You may also be interested in any of a set of types of content the user can pick. For example, an e-mail application that wants to allow the user to add an attachment to an e-mail message can use this action to bring up a list of all of the types of content the user can attach.

In this case, you should wrap the GET_CONTENT intent with a chooser (through createChooser(Intent, CharSequence)), which will give the proper interface for the user to pick how to send your data and allow you to specify a prompt indicating what they are doing. You will usually specify a broad MIME type (such as image/* or */*), resulting in a broad range of content types the user can select from.

When using such a broad GET_CONTENT action, it is often desireable to only pick from data that can be represented as a stream. This is accomplished by requiring the CATEGORY_OPENABLE in the Intent.

Input: getType() is the desired MIME type to retrieve. Note that no URI is supplied in the intent, as there are no constraints on where the returned data originally comes from. You may also include the CATEGORY_OPENABLE if you can only accept data that can be opened as a stream.

Output: The URI of the item that was picked. This must be a content: URI so that any receiver can access it.

Constant Value: "android.intent.action.GET_CONTENT"

public static final String ACTION_GTALK_SERVICE_CONNECTED

Since: API Level 1

Broadcast Action: An GTalk connection has been established.

Constant Value: "android.intent.action.GTALK_CONNECTED"

public static final String ACTION_GTALK_SERVICE_DISCONNECTED

Since: API Level 1

Broadcast Action: An GTalk connection has been disconnected.

Constant Value: "android.intent.action.GTALK_DISCONNECTED"

public static final String ACTION_HEADSET_PLUG

Since: API Level 1

Broadcast Action: Wired Headset plugged in or unplugged.

The intent will have the following extra values:

  • state - 0 for unplugged, 1 for plugged.
  • name - Headset type, human readable string

Constant Value: "android.intent.action.HEADSET_PLUG"

public static final String ACTION_INPUT_METHOD_CHANGED

Since: API Level 3

Broadcast Action: An input method has been changed.

Constant Value: "android.intent.action.INPUT_METHOD_CHANGED"

public static final String ACTION_INSERT

Since: API Level 1

Activity Action: Insert an empty item into the given container.

Input: getData() is URI of the directory (vnd.android.cursor.dir/*) in which to place the data.

Output: URI of the new data that was created.

Constant Value: "android.intent.action.INSERT"

public static final String ACTION_INSERT_OR_EDIT

Since: API Level 1

Activity Action: Pick an existing item, or insert a new item, and then edit it.

Input: getType() is the desired MIME type of the item to create or edit. The extras can contain type specific data to pass through to the editing/creating activity.

Output: The URI of the item that was picked. This must be a content: URI so that any receiver can access it.

Constant Value: "android.intent.action.INSERT_OR_EDIT"

public static final String ACTION_MAIN

Since: API Level 1

Activity Action: Start as a main entry point, does not expect to receive data.

Input: nothing

Output: nothing

Constant Value: "android.intent.action.MAIN"

public static final String ACTION_MANAGE_PACKAGE_STORAGE

Since: API Level 1

Broadcast Action: Indicates low memory condition notification acknowledged by user and package management should be started. This is triggered by the user from the ACTION_DEVICE_STORAGE_LOW notification.

Constant Value: "android.intent.action.MANAGE_PACKAGE_STORAGE"

public static final String ACTION_MEDIA_BAD_REMOVAL

Since: API Level 1

Broadcast Action: External media was removed from SD card slot, but mount point was not unmounted. The path to the mount point for the removed media is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_BAD_REMOVAL"

public static final String ACTION_MEDIA_BUTTON

Since: API Level 1

Broadcast Action: The "Media Button" was pressed. Includes a single extra field, EXTRA_KEY_EVENT, containing the key event that caused the broadcast.

Constant Value: "android.intent.action.MEDIA_BUTTON"

public static final String ACTION_MEDIA_CHECKING

Since: API Level 3

Broadcast Action: External media is present, and being disk-checked The path to the mount point for the checking media is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_CHECKING"

public static final String ACTION_MEDIA_EJECT

Since: API Level 1

Broadcast Action: User has expressed the desire to remove the external storage media. Applications should close all files they have open within the mount point when they receive this intent. The path to the mount point for the media to be ejected is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_EJECT"

public static final String ACTION_MEDIA_MOUNTED

Since: API Level 1

Broadcast Action: External media is present and mounted at its mount point. The path to the mount point for the removed media is contained in the Intent.mData field. The Intent contains an extra with name "read-only" and Boolean value to indicate if the media was mounted read only.

Constant Value: "android.intent.action.MEDIA_MOUNTED"

public static final String ACTION_MEDIA_NOFS

Since: API Level 3

Broadcast Action: External media is present, but is using an incompatible fs (or is blank) The path to the mount point for the checking media is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_NOFS"

public static final String ACTION_MEDIA_REMOVED

Since: API Level 1

Broadcast Action: External media has been removed. The path to the mount point for the removed media is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_REMOVED"

public static final String ACTION_MEDIA_SCANNER_FINISHED

Since: API Level 1

Broadcast Action: The media scanner has finished scanning a directory. The path to the scanned directory is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_SCANNER_FINISHED"

public static final String ACTION_MEDIA_SCANNER_SCAN_FILE

Since: API Level 1

Broadcast Action: Request the media scanner to scan a file and add it to the media database. The path to the file is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_SCANNER_SCAN_FILE"

public static final String ACTION_MEDIA_SCANNER_STARTED

Since: API Level 1

Broadcast Action: The media scanner has started scanning a directory. The path to the directory being scanned is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_SCANNER_STARTED"

public static final String ACTION_MEDIA_SHARED

Since: API Level 1

Broadcast Action: External media is unmounted because it is being shared via USB mass storage. The path to the mount point for the removed media is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_SHARED"

public static final String ACTION_MEDIA_UNMOUNTABLE

Since: API Level 1

Broadcast Action: External media is present but cannot be mounted. The path to the mount point for the removed media is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_UNMOUNTABLE"

public static final String ACTION_MEDIA_UNMOUNTED

Since: API Level 1

Broadcast Action: External media is present, but not mounted at its mount point. The path to the mount point for the removed media is contained in the Intent.mData field.

Constant Value: "android.intent.action.MEDIA_UNMOUNTED"

public static final String ACTION_NEW_OUTGOING_CALL

Since: API Level 1

Broadcast Action: An outgoing call is about to be placed.

The Intent will have the following extra value:

Once the broadcast is finished, the resultData is used as the actual number to call. If null, no call will be placed.

It is perfectly acceptable for multiple receivers to process the outgoing call in turn: for example, a parental control application might verify that the user is authorized to place the call at that time, then a number-rewriting application might add an area code if one was not specified.

For consistency, any receiver whose purpose is to prohibit phone calls should have a priority of 0, to ensure it will see the final phone number to be dialed. Any receiver whose purpose is to rewrite phone numbers to be called should have a positive priority. Negative priorities are reserved for the system for this broadcast; using them may cause problems.

Any BroadcastReceiver receiving this Intent must not abort the broadcast.

Emergency calls cannot be intercepted using this mechanism, and other calls cannot be modified to call emergency numbers using this mechanism.

You must hold the PROCESS_OUTGOING_CALLS permission to receive this Intent.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.NEW_OUTGOING_CALL"

public static final String ACTION_PACKAGE_ADDED

Since: API Level 1

Broadcast Action: A new application package has been installed on the device. The data contains the name of the package. Note that the newly installed package does not receive this broadcast.

My include the following extras:

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.PACKAGE_ADDED"

public static final String ACTION_PACKAGE_CHANGED

Since: API Level 1

Broadcast Action: An existing application package has been changed (e.g. a component has been enabled or disabled. The data contains the name of the package.

  • EXTRA_UID containing the integer uid assigned to the package.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.PACKAGE_CHANGED"

public static final String ACTION_PACKAGE_DATA_CLEARED

Since: API Level 3

Broadcast Action: The user has cleared the data of a package. This should be preceded by ACTION_PACKAGE_RESTARTED, after which all of its persistent data is erased and this broadcast sent. Note that the cleared package does not receive this broadcast. The data contains the name of the package.

  • EXTRA_UID containing the integer uid assigned to the package.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.PACKAGE_DATA_CLEARED"

public static final String ACTION_PACKAGE_INSTALL

Since: API Level 1

Broadcast Action: Trigger the download and eventual installation of a package.

Input: getData() is the URI of the package file to download.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.PACKAGE_INSTALL"

public static final String ACTION_PACKAGE_REMOVED

Since: API Level 1

Broadcast Action: An existing application package has been removed from the device. The data contains the name of the package. The package that is being installed does not receive this Intent.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.PACKAGE_REMOVED"

public static final String ACTION_PACKAGE_REPLACED

Since: API Level 3

Broadcast Action: A new version of an application package has been installed, replacing an existing version that was previously installed. The data contains the name of the package.

My include the following extras:

  • EXTRA_UID containing the integer uid assigned to the new package.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.PACKAGE_REPLACED"

public static final String ACTION_PACKAGE_RESTARTED

Since: API Level 1

Broadcast Action: The user has restarted a package, and all of its processes have been killed. All runtime state associated with it (processes, alarms, notifications, etc) should be removed. Note that the restarted package does not receive this broadcast. The data contains the name of the package.

  • EXTRA_UID containing the integer uid assigned to the package.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.PACKAGE_RESTARTED"

public static final String ACTION_PICK

Since: API Level 1

Activity Action: Pick an item from the data, returning what was selected.

Input: getData() is URI containing a directory of data (vnd.android.cursor.dir/*) from which to pick an item.

Output: The URI of the item that was picked.

Constant Value: "android.intent.action.PICK"

public static final String ACTION_PICK_ACTIVITY

Since: API Level 1

Activity Action: Pick an activity given an intent, returning the class selected.

Input: get*Extra field EXTRA_INTENT is an Intent used with queryIntentActivities(Intent, int) to determine the set of activities from which to pick.

Output: Class name of the activity that was selected.

Constant Value: "android.intent.action.PICK_ACTIVITY"

public static final String ACTION_POWER_CONNECTED

Since: API Level 4

Broadcast Action: External power has been connected to the device. This is intended for applications that wish to register specifically to this notification. Unlike ACTION_BATTERY_CHANGED, applications will be woken for this and so do not have to stay active to receive this notification. This action can be used to implement actions that wait until power is available to trigger.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.ACTION_POWER_CONNECTED"

public static final String ACTION_POWER_DISCONNECTED

Since: API Level 4

Broadcast Action: External power has been removed from the device. This is intended for applications that wish to register specifically to this notification. Unlike ACTION_BATTERY_CHANGED, applications will be woken for this and so do not have to stay active to receive this notification. This action can be used to implement actions that wait until power is available to trigger.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.ACTION_POWER_DISCONNECTED"

public static final String ACTION_POWER_USAGE_SUMMARY

Since: API Level 4

Activity Action: Show power usage information to the user.

Input: Nothing.

Output: Nothing.

Constant Value: "android.intent.action.POWER_USAGE_SUMMARY"

public static final String ACTION_PROVIDER_CHANGED

Since: API Level 1

Broadcast Action: Some content providers have parts of their namespace where they publish new events or items that the user may be especially interested in. For these things, they may broadcast this action when the set of interesting items change. For example, GmailProvider sends this notification when the set of unread mail in the inbox changes.

The data of the intent identifies which part of which provider changed. When queried through the content resolver, the data URI will return the data set in question.

The intent will have the following extra values:

  • count - The number of items in the data set. This is the same as the number of items in the cursor returned by querying the data URI.
This intent will be sent at boot (if the count is non-zero) and when the data set changes. It is possible for the data set to change without the count changing (for example, if a new unread message arrives in the same sync operation in which a message is archived). The phone should still ring/vibrate/etc as normal in this case.

Constant Value: "android.intent.action.PROVIDER_CHANGED"

public static final String ACTION_REBOOT

Since: API Level 1

Broadcast Action: Have the device reboot. This is only for use by system code.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.REBOOT"

public static final String ACTION_RUN

Since: API Level 1

Activity Action: Run the data, whatever that means.

Input: ? (Note: this is currently specific to the test harness.)

Output: nothing.

Constant Value: "android.intent.action.RUN"

public static final String ACTION_SCREEN_OFF

Since: API Level 1

Broadcast Action: Sent after the screen turns off.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.SCREEN_OFF"

public static final String ACTION_SCREEN_ON

Since: API Level 1

Broadcast Action: Sent after the screen turns on.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.SCREEN_ON"

public static final String ACTION_SEARCH

Since: API Level 1

Activity Action: Perform a search.

Input: getStringExtra(SearchManager.QUERY) is the text to search for. If empty, simply enter your search results Activity with the search UI activated.

Output: nothing.

Constant Value: "android.intent.action.SEARCH"

public static final String ACTION_SEARCH_LONG_PRESS

Since: API Level 3

Activity Action: Start action associated with long pressing on the search key.

Input: Nothing.

Output: Nothing.

Constant Value: "android.intent.action.SEARCH_LONG_PRESS"

public static final String ACTION_SEND

Since: API Level 1

Activity Action: Deliver some data to someone else. Who the data is being delivered to is not specified; it is up to the receiver of this action to ask the user where the data should be sent.

When launching a SEND intent, you should usually wrap it in a chooser (through createChooser(Intent, CharSequence)), which will give the proper interface for the user to pick how to send your data and allow you to specify a prompt indicating what they are doing.

Input: getType() is the MIME type of the data being sent. get*Extra can have either a EXTRA_TEXT or EXTRA_STREAM field, containing the data to be sent. If using EXTRA_TEXT, the MIME type should be "text/plain"; otherwise it should be the MIME type of the data in EXTRA_STREAM. Use */* if the MIME type is unknown (this will only allow senders that can handle generic data streams).

Optional standard extras, which may be interpreted by some recipients as appropriate, are: EXTRA_EMAIL, EXTRA_CC, EXTRA_BCC, EXTRA_SUBJECT.

Output: nothing.

Constant Value: "android.intent.action.SEND"

public static final String ACTION_SENDTO

Since: API Level 1

Activity Action: Send a message to someone specified by the data.

Input: getData() is URI describing the target.

Output: nothing.

Constant Value: "android.intent.action.SENDTO"

public static final String ACTION_SEND_MULTIPLE

Since: API Level 4

Activity Action: Deliver multiple data to someone else.

Like ACTION_SEND, except the data is multiple.

Input: getType() is the MIME type of the data being sent. get*ArrayListExtra can have either a EXTRA_TEXT or EXTRA_STREAM field, containing the data to be sent.

Optional standard extras, which may be interpreted by some recipients as appropriate, are: EXTRA_EMAIL, EXTRA_CC, EXTRA_BCC, EXTRA_SUBJECT.

Output: nothing.

Constant Value: "android.intent.action.SEND_MULTIPLE"

public static final String ACTION_SET_WALLPAPER

Since: API Level 1

Activity Action: Show settings for choosing wallpaper

Input: Nothing.

Output: Nothing.

Constant Value: "android.intent.action.SET_WALLPAPER"

public static final String ACTION_SHUTDOWN

Since: API Level 4

Broadcast Action: Device is shutting down. This is broadcast when the device is being shut down (completely turned off, not sleeping). Once the broadcast is complete, the final shutdown will proceed and all unsaved data lost. Apps will not normally need to handle this, since the forground activity will be paused as well.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.ACTION_SHUTDOWN"

public static final String ACTION_SYNC

Since: API Level 1

Activity Action: Perform a data synchronization.

Input: ?

Output: ?

Constant Value: "android.intent.action.SYNC"

public static final String ACTION_SYSTEM_TUTORIAL

Since: API Level 3

Activity Action: Start the platform-defined tutorial

Input: getStringExtra(SearchManager.QUERY) is the text to search for. If empty, simply enter your search results Activity with the search UI activated.

Output: nothing.

Constant Value: "android.intent.action.SYSTEM_TUTORIAL"

public static final String ACTION_TIMEZONE_CHANGED

Since: API Level 1

Broadcast Action: The timezone has changed. The intent will have the following extra values:

  • time-zone - The java.util.TimeZone.getID() value identifying the new time zone.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.TIMEZONE_CHANGED"

public static final String ACTION_TIME_CHANGED

Since: API Level 1

Broadcast Action: The time was set.

Constant Value: "android.intent.action.TIME_SET"

public static final String ACTION_TIME_TICK

Since: API Level 1

Broadcast Action: The current time has changed. Sent every minute. You can not receive this through components declared in manifests, only by exlicitly registering for it with Context.registerReceiver().

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.TIME_TICK"

public static final String ACTION_UID_REMOVED

Since: API Level 1

Broadcast Action: A user ID has been removed from the system. The user ID number is stored in the extra data under EXTRA_UID.

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.UID_REMOVED"

public static final String ACTION_UMS_CONNECTED

Since: API Level 1

Broadcast Action: The device has entered USB Mass Storage mode. This is used mainly for the USB Settings panel. Apps should listen for ACTION_MEDIA_MOUNTED and ACTION_MEDIA_UNMOUNTED broadcasts to be notified when the SD card file system is mounted or unmounted

Constant Value: "android.intent.action.UMS_CONNECTED"

public static final String ACTION_UMS_DISCONNECTED

Since: API Level 1

Broadcast Action: The device has exited USB Mass Storage mode. This is used mainly for the USB Settings panel. Apps should listen for ACTION_MEDIA_MOUNTED and ACTION_MEDIA_UNMOUNTED broadcasts to be notified when the SD card file system is mounted or unmounted

Constant Value: "android.intent.action.UMS_DISCONNECTED"

public static final String ACTION_USER_PRESENT

Since: API Level 3

Broadcast Action: Sent when the user is present after device wakes up (e.g when the keyguard is gone).

This is a protected intent that can only be sent by the system.

Constant Value: "android.intent.action.USER_PRESENT"

public static final String ACTION_VIEW

Since: API Level 1

Activity Action: Display the data to the user. This is the most common action performed on data -- it is the generic action you can use on a piece of data to get the most reasonable thing to occur. For example, when used on a contacts entry it will view the entry; when used on a mailto: URI it will bring up a compose window filled with the information supplied by the URI; when used with a tel: URI it will invoke the dialer.

Input: getData() is URI from which to retrieve data.

Output: nothing.

Constant Value: "android.intent.action.VIEW"

public static final String ACTION_VOICE_COMMAND

Since: API Level 1

Activity Action: Start Voice Command.

Input: Nothing.

Output: Nothing.

Constant Value: "android.intent.action.VOICE_COMMAND"

public static final String ACTION_WALLPAPER_CHANGED

Since: API Level 1

Broadcast Action: The current system wallpaper has changed. See getWallpaper() for retrieving the new wallpaper.

Constant Value: "android.intent.action.WALLPAPER_CHANGED"

public static final String ACTION_WEB_SEARCH

Since: API Level 1

Activity Action: Perform a web search.

Input: getStringExtra(SearchManager.QUERY) is the text to search for. If it is a url starts with http or https, the site will be opened. If it is plain text, Google search will be applied.

Output: nothing.

Constant Value: "android.intent.action.WEB_SEARCH"

public static final String CATEGORY_ALTERNATIVE

Since: API Level 1

Set if the activity should be considered as an alternative action to the data the user is currently viewing. See also CATEGORY_SELECTED_ALTERNATIVE for an alternative action that applies to the selection in a list of items.

Supporting this category means that you would like your activity to be displayed in the set of alternative things the user can do, usually as part of the current activity's options menu. You will usually want to include a specific label in the <intent-filter> of this action describing to the user what it does.

The action of IntentFilter with this category is important in that it describes the specific action the target will perform. This generally should not be a generic action (such as ACTION_VIEW, but rather a specific name such as "com.android.camera.action.CROP. Only one alternative of any particular action will be shown to the user, so using a specific action like this makes sure that your alternative will be displayed while also allowing other applications to provide their own overrides of that particular action.

Constant Value: "android.intent.category.ALTERNATIVE"

public static final String CATEGORY_BROWSABLE

Since: API Level 1

Activities that can be safely invoked from a browser must support this category. For example, if the user is viewing a web page or an e-mail and clicks on a link in the text, the Intent generated execute that link will require the BROWSABLE category, so that only activities supporting this category will be considered as possible actions. By supporting this category, you are promising that there is nothing damaging (without user intervention) that can happen by invoking any matching Intent.

Constant Value: "android.intent.category.BROWSABLE"

public static final String CATEGORY_DEFAULT

Since: API Level 1

Set if the activity should be an option for the default action (center press) to perform on a piece of data. Setting this will hide from the user any activities without it set when performing an action on some data. Note that this is normal -not- set in the Intent when initiating an action -- it is for use in intent filters specified in packages.

Constant Value: "android.intent.category.DEFAULT"

public static final String CATEGORY_DEVELOPMENT_PREFERENCE

Since: API Level 1

This activity is a development preference panel.

Constant Value: "android.intent.category.DEVELOPMENT_PREFERENCE"

public static final String CATEGORY_EMBED

Since: API Level 1

Capable of running inside a parent activity container.

Constant Value: "android.intent.category.EMBED"

public static final String CATEGORY_FRAMEWORK_INSTRUMENTATION_TEST

Since: API Level 1

To be used as code under test for framework instrumentation tests.

Constant Value: "android.intent.category.FRAMEWORK_INSTRUMENTATION_TEST"

public static final String CATEGORY_HOME

Since: API Level 1

This is the home activity, that is the first activity that is displayed when the device boots.

Constant Value: "android.intent.category.HOME"

public static final String CATEGORY_INFO

Since: API Level 3

Provides information about the package it is in; typically used if a package does not contain a CATEGORY_LAUNCHER to provide a front-door to the user without having to be shown in the all apps list.

Constant Value: "android.intent.category.INFO"

public static final String CATEGORY_LAUNCHER

Since: API Level 1

Should be displayed in the top-level launcher.

Constant Value: "android.intent.category.LAUNCHER"

public static final String CATEGORY_MONKEY

Since: API Level 1

This activity may be exercised by the monkey or other automated test tools.

Constant Value: "android.intent.category.MONKEY"

public static final String CATEGORY_OPENABLE

Since: API Level 1

Used to indicate that a GET_CONTENT intent only wants URIs that can be opened with ContentResolver.openInputStream. Openable URIs must support the columns in OpenableColumns when queried, though it is allowable for those columns to be blank.

Constant Value: "android.intent.category.OPENABLE"

public static final String CATEGORY_PREFERENCE

Since: API Level 1

This activity is a preference panel.

Constant Value: "android.intent.category.PREFERENCE"

public static final String CATEGORY_SAMPLE_CODE

Since: API Level 1

To be used as an sample code example (not part of the normal user experience).

Constant Value: "android.intent.category.SAMPLE_CODE"

public static final String CATEGORY_SELECTED_ALTERNATIVE

Since: API Level 1

Set if the activity should be considered as an alternative selection action to the data the user has currently selected. This is like CATEGORY_ALTERNATIVE, but is used in activities showing a list of items from which the user can select, giving them alternatives to the default action that will be performed on it.

Constant Value: "android.intent.category.SELECTED_ALTERNATIVE"

public static final String CATEGORY_TAB

Since: API Level 1

Intended to be used as a tab inside of an containing TabActivity.

Constant Value: "android.intent.category.TAB"

public static final String CATEGORY_TEST

Since: API Level 1

To be used as a test (not part of the normal user experience).

Constant Value: "android.intent.category.TEST"

public static final String CATEGORY_UNIT_TEST

Since: API Level 1

To be used as a unit test (run through the Test Harness).

Constant Value: "android.intent.category.UNIT_TEST"

public static final Creator<Intent> CREATOR

Since: API Level 1

public static final String EXTRA_ALARM_COUNT

Since: API Level 1

Used as an int extra field in AlarmManager intents to tell the application being invoked how many pending alarms are being delievered with the intent. For one-shot alarms this will always be 1. For recurring alarms, this might be greater than 1 if the device was asleep or powered off at the time an earlier alarm would have been delivered.

Constant Value: "android.intent.extra.ALARM_COUNT"

public static final String EXTRA_BCC

Since: API Level 1

A String[] holding e-mail addresses that should be blind carbon copied.

Constant Value: "android.intent.extra.BCC"

public static final String EXTRA_CC

Since: API Level 1

A String[] holding e-mail addresses that should be carbon copied.

Constant Value: "android.intent.extra.CC"

public static final String EXTRA_DATA_REMOVED

Since: API Level 3

Used as a boolean extra field in ACTION_PACKAGE_REMOVED intents to indicate whether this represents a full uninstall (removing both the code and its data) or a partial uninstall (leaving its data, implying that this is an update).

Constant Value: "android.intent.extra.DATA_REMOVED"

public static final String EXTRA_DONT_KILL_APP

Since: API Level 1

Used as an boolean extra field in ACTION_PACKAGE_REMOVED or ACTION_PACKAGE_CHANGED intents to override the default action of restarting the application.

Constant Value: "android.intent.extra.DONT_KILL_APP"

public static final String EXTRA_EMAIL

Since: API Level 1

A String[] holding e-mail addresses that should be delivered to.

Constant Value: "android.intent.extra.EMAIL"

public static final String EXTRA_INTENT

Since: API Level 1

An Intent describing the choices you would like shown with ACTION_PICK_ACTIVITY.

Constant Value: "android.intent.extra.INTENT"

public static final String EXTRA_KEY_EVENT

Since: API Level 1

A KeyEvent object containing the event that triggered the creation of the Intent it is in.

Constant Value: "android.intent.extra.KEY_EVENT"

public static final String EXTRA_PHONE_NUMBER

Since: API Level 1

A String holding the phone number originally entered in ACTION_NEW_OUTGOING_CALL, or the actual number to call in a ACTION_CALL.

Constant Value: "android.intent.extra.PHONE_NUMBER"

public static final String EXTRA_REPLACING

Since: API Level 3

Used as a boolean extra field in ACTION_PACKAGE_REMOVED intents to indicate that this is a replacement of the package, so this broadcast will immediately be followed by an add broadcast for a different version of the same package.

Constant Value: "android.intent.extra.REPLACING"

public static final String EXTRA_SHORTCUT_ICON

Since: API Level 1

The name of the extra used to define the icon, as a Bitmap, of a shortcut.

Constant Value: "android.intent.extra.shortcut.ICON"

public static final String EXTRA_SHORTCUT_ICON_RESOURCE

Since: API Level 1

The name of the extra used to define the icon, as a ShortcutIconResource, of a shortcut.

Constant Value: "android.intent.extra.shortcut.ICON_RESOURCE"

public static final String EXTRA_SHORTCUT_INTENT

Since: API Level 1

The name of the extra used to define the Intent of a shortcut.

Constant Value: "android.intent.extra.shortcut.INTENT"

public static final String EXTRA_SHORTCUT_NAME

Since: API Level 1

The name of the extra used to define the name of a shortcut.

Constant Value: "android.intent.extra.shortcut.NAME"

public static final String EXTRA_STREAM

Since: API Level 1

A content: URI holding a stream of data associated with the Intent, used with ACTION_SEND to supply the data being sent.

Constant Value: "android.intent.extra.STREAM"

public static final String EXTRA_SUBJECT

Since: API Level 1

A constant string holding the desired subject line of a message.

Constant Value: "android.intent.extra.SUBJECT"

public static final String EXTRA_TEMPLATE

Since: API Level 1

The initial data to place in a newly created record. Use with ACTION_INSERT. The data here is a Map containing the same fields as would be given to the underlying ContentProvider.insert() call.

Constant Value: "android.intent.extra.TEMPLATE"

public static final String EXTRA_TEXT

Since: API Level 1

A constant CharSequence that is associated with the Intent, used with ACTION_SEND to supply the literal data to be sent. Note that this may be a styled CharSequence, so you must use Bundle.getCharSequence() to retrieve it.

Constant Value: "android.intent.extra.TEXT"

public static final String EXTRA_TITLE

Since: API Level 1

A CharSequence dialog title to provide to the user when used with a ACTION_CHOOSER.

Constant Value: "android.intent.extra.TITLE"

public static final String EXTRA_UID

Since: API Level 1

Used as an int extra field in ACTION_UID_REMOVED intents to supply the uid the package had been assigned. Also an optional extra in ACTION_PACKAGE_REMOVED or ACTION_PACKAGE_CHANGED for the same purpose.

Constant Value: "android.intent.extra.UID"

public static final int FILL_IN_ACTION

Since: API Level 1

Use with fillIn(Intent, int) to allow the current action value to be overwritten, even if it is already set.

Constant Value: 1 (0x00000001)

public static final int FILL_IN_CATEGORIES

Since: API Level 1

Use with fillIn(Intent, int) to allow the current categories to be overwritten, even if they are already set.

Constant Value: 4 (0x00000004)

public static final int FILL_IN_COMPONENT

Since: API Level 1

Use with fillIn(Intent, int) to allow the current component value to be overwritten, even if it is already set.

Constant Value: 8 (0x00000008)

public static final int FILL_IN_DATA

Since: API Level 1

Use with fillIn(Intent, int) to allow the current data or type value overwritten, even if it is already set.

Constant Value: 2 (0x00000002)

public static final int FILL_IN_PACKAGE

Since: API Level 4

Use with fillIn(Intent, int) to allow the current package value to be overwritten, even if it is already set.

Constant Value: 16 (0x00000010)

public static final int FLAG_ACTIVITY_BROUGHT_TO_FRONT

Since: API Level 1

This flag is not normally set by application code, but set for you by the system as described in the launchMode documentation for the singleTask mode.

Constant Value: 4194304 (0x00400000)

public static final int FLAG_ACTIVITY_CLEAR_TOP

Since: API Level 1

If set, and the activity being launched is already running in the current task, then instead of launching a new instance of that activity, all of the other activities on top of it will be closed and this Intent will be delivered to the (now on top) old activity as a new Intent.

For example, consider a task consisting of the activities: A, B, C, D. If D calls startActivity() with an Intent that resolves to the component of activity B, then C and D will be finished and B receive the given Intent, resulting in the stack now being: A, B.

The currently running instance of task B in the above example will either receive the new intent you are starting here in its onNewIntent() method, or be itself finished and restarted with the new intent. If it has declared its launch mode to be "multiple" (the default) it will be finished and re-created; for all other launch modes it will receive the Intent in the current instance.

This launch mode can also be used to good effect in conjunction with FLAG_ACTIVITY_NEW_TASK: if used to start the root activity of a task, it will bring any currently running instance of that task to the foreground, and then clear it to its root state. This is especially useful, for example, when launching an activity from the notification manager.

See Application Fundamentals: Activities and Tasks for more details on tasks.

Constant Value: 67108864 (0x04000000)

public static final int FLAG_ACTIVITY_CLEAR_WHEN_TASK_RESET

Since: API Level 3

If set, this marks a point in the task's activity stack that should be cleared when the task is reset. That is, the next time the task is brought to the foreground with FLAG_ACTIVITY_RESET_TASK_IF_NEEDED (typically as a result of the user re-launching it from home), this activity and all on top of it will be finished so that the user does not return to them, but instead returns to whatever activity preceeded it.

This is useful for cases where you have a logical break in your application. For example, an e-mail application may have a command to view an attachment, which launches an image view activity to display it. This activity should be part of the e-mail application's task, since it is a part of the task the user is involved in. However, if the user leaves that task, and later selects the e-mail app from home, we may like them to return to the conversation they were viewing, not the picture attachment, since that is confusing. By setting this flag when launching the image viewer, that viewer and any activities it starts will be removed the next time the user returns to mail.

Constant Value: 524288 (0x00080000)

public static final int FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS

Since: API Level 1

If set, the new activity is not kept in the list of recently launched activities.

Constant Value: 8388608 (0x00800000)

public static final int FLAG_ACTIVITY_FORWARD_RESULT

Since: API Level 1

If set and this intent is being used to launch a new activity from an existing one, then the reply target of the existing activity will be transfered to the new activity. This way the new activity can call setResult(int) and have that result sent back to the reply target of the original activity.

Constant Value: 33554432 (0x02000000)

public static final int FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY

Since: API Level 1

This flag is not normally set by application code, but set for you by the system if this activity is being launched from history (longpress home key).

Constant Value: 1048576 (0x00100000)

public static final int FLAG_ACTIVITY_MULTIPLE_TASK

Since: API Level 1

Do not use this flag unless you are implementing your own top-level application launcher. Used in conjunction with FLAG_ACTIVITY_NEW_TASK to disable the behavior of bringing an existing task to the foreground. When set, a new task is always started to host the Activity for the Intent, regardless of whether there is already an existing task running the same thing.

Because the default system does not include graphical task management, you should not use this flag unless you provide some way for a user to return back to the tasks you have launched.

This flag is ignored if FLAG_ACTIVITY_NEW_TASK is not set.

See Application Fundamentals: Activities and Tasks for more details on tasks.

Constant Value: 134217728 (0x08000000)

public static final int FLAG_ACTIVITY_NEW_TASK

Since: API Level 1

If set, this activity will become the start of a new task on this history stack. A task (from the activity that started it to the next task activity) defines an atomic group of activities that the user can move to. Tasks can be moved to the foreground and background; all of the activities inside of a particular task always remain in the same order. See Application Fundamentals: Activities and Tasks for more details on tasks.

This flag is generally used by activities that want to present a "launcher" style behavior: they give the user a list of separate things that can be done, which otherwise run completely independently of the activity launching them.

When using this flag, if a task is already running for the activity you are now starting, then a new activity will not be started; instead, the current task will simply be brought to the front of the screen with the state it was last in. See FLAG_ACTIVITY_MULTIPLE_TASK for a flag to disable this behavior.

This flag can not be used when the caller is requesting a result from the activity being launched.

Constant Value: 268435456 (0x10000000)

public static final int FLAG_ACTIVITY_NO_HISTORY

Since: API Level 1

If set, the new activity is not kept in the history stack. As soon as the user navigates away from it, the activity is finished. This may also be set with the noHistory attribute.

Constant Value: 1073741824 (0x40000000)

public static final int FLAG_ACTIVITY_NO_USER_ACTION

Since: API Level 3

If set, this flag will prevent the normal onUserLeaveHint() callback from occurring on the current frontmost activity before it is paused as the newly-started activity is brought to the front.

Typically, an activity can rely on that callback to indicate that an explicit user action has caused their activity to be moved out of the foreground. The callback marks an appropriate point in the activity's lifecycle for it to dismiss any notifications that it intends to display "until the user has seen them," such as a blinking LED.

If an activity is ever started via any non-user-driven events such as phone-call receipt or an alarm handler, this flag should be passed to Context.startActivity, ensuring that the pausing activity does not think the user has acknowledged its notification.

Constant Value: 262144 (0x00040000)

public static final int FLAG_ACTIVITY_PREVIOUS_IS_TOP

Since: API Level 1

If set and this intent is being used to launch a new activity from an existing one, the current activity will not be counted as the top activity for deciding whether the new intent should be delivered to the top instead of starting a new one. The previous activity will be used as the top, with the assumption being that the current activity will finish itself immediately.

Constant Value: 16777216 (0x01000000)

public static final int FLAG_ACTIVITY_REORDER_TO_FRONT

Since: API Level 3

If set in an Intent passed to Context.startActivity(), this flag will cause the launched activity to be brought to the front of its task's history stack if it is already running.

For example, consider a task consisting of four activities: A, B, C, D. If D calls startActivity() with an Intent that resolves to the component of activity B, then B will be brought to the front of the history stack, with this resulting order: A, C, D, B. This flag will be ignored if FLAG_ACTIVITY_CLEAR_TOP is also specified.

Constant Value: 131072 (0x00020000)

public static final int FLAG_ACTIVITY_RESET_TASK_IF_NEEDED

Since: API Level 1

If set, and this activity is either being started in a new task or bringing to the top an existing task, then it will be launched as the front door of the task. This will result in the application of any affinities needed to have that task in the proper state (either moving activities to or from it), or simply resetting that task to its initial state if needed.

Constant Value: 2097152 (0x00200000)

public static final int FLAG_ACTIVITY_SINGLE_TOP

Since: API Level 1

If set, the activity will not be launched if it is already running at the top of the history stack.

Constant Value: 536870912 (0x20000000)

public static final int FLAG_DEBUG_LOG_RESOLUTION

Since: API Level 1

A flag you can enable for debugging: when set, log messages will be printed during the resolution of this intent to show you what has been found to create the final resolved list.

Constant Value: 8 (0x00000008)

public static final int FLAG_FROM_BACKGROUND

Since: API Level 1

Can be set by the caller to indicate that this Intent is coming from a background operation, not from direct user interaction.

Constant Value: 4 (0x00000004)

public static final int FLAG_GRANT_READ_URI_PERMISSION

Since: API Level 1

If set, the recipient of this Intent will be granted permission to perform read operations on the Uri in the Intent's data.

Constant Value: 1 (0x00000001)

public static final int FLAG_GRANT_WRITE_URI_PERMISSION

Since: API Level 1

If set, the recipient of this Intent will be granted permission to perform write operations on the Uri in the Intent's data.

Constant Value: 2 (0x00000002)

public static final int FLAG_RECEIVER_REGISTERED_ONLY

Since: API Level 1

If set, when sending a broadcast only registered receivers will be called -- no BroadcastReceiver components will be launched.

Constant Value: 1073741824 (0x40000000)

public static final int URI_INTENT_SCHEME

Since: API Level 4

Flag for use with toUri(int) and parseUri(String, int): the URI string always has the "intent:" scheme. This syntax can be used when you want to later disambiguate between URIs that are intended to describe an Intent vs. all others that should be treated as raw URIs. When used with parseUri(String, int), any other scheme will result in a generic VIEW action for that raw URI.

Constant Value: 1 (0x00000001)

Public Constructors

public Intent ()

Since: API Level 1

Create an empty intent.

public Intent (Intent o)

Since: API Level 1

Copy constructor.

public Intent (String action)

Since: API Level 1

Create an intent with a given action. All other fields (data, type, class) are null. Note that the action must be in a namespace because Intents are used globally in the system -- for example the system VIEW action is android.intent.action.VIEW; an application's custom action would be something like com.google.app.myapp.CUSTOM_ACTION.

Parameters
action The Intent action, such as ACTION_VIEW.

public Intent (String action, Uri uri)

Since: API Level 1

Create an intent with a given action and for a given data url. Note that the action must be in a namespace because Intents are used globally in the system -- for example the system VIEW action is android.intent.action.VIEW; an application's custom action would be something like com.google.app.myapp.CUSTOM_ACTION.

Note: scheme and host name matching in the Android framework is case-sensitive, unlike the formal RFC. As a result, you should always ensure that you write your Uri with these elements using lower case letters, and normalize any Uris you receive from outside of Android to ensure the scheme and host is lower case.

Parameters
action The Intent action, such as ACTION_VIEW.
uri The Intent data URI.

public Intent (Context packageContext, Class<?> cls)

Since: API Level 1

Create an intent for a specific component. All other fields (action, data, type, class) are null, though they can be modified later with explicit calls. This provides a convenient way to create an intent that is intended to execute a hard-coded class name, rather than relying on the system to find an appropriate class for you; see setComponent(ComponentName) for more information on the repercussions of this.

Parameters
packageContext A Context of the application package implementing this class.
cls The component class that is to be used for the intent.

public Intent (String action, Uri uri, Context packageContext, Class<?> cls)

Since: API Level 1

Create an intent for a specific component with a specified action and data. This is equivalent using Intent(String, android.net.Uri) to construct the Intent and then calling setClass(Context, Class) to set its class.

Note: scheme and host name matching in the Android framework is case-sensitive, unlike the formal RFC. As a result, you should always ensure that you write your Uri with these elements using lower case letters, and normalize any Uris you receive from outside of Android to ensure the scheme and host is lower case.

Parameters
action The Intent action, such as ACTION_VIEW.
uri The Intent data URI.
packageContext A Context of the application package implementing this class.
cls The component class that is to be used for the intent.

Public Methods

public Intent addCategory (String category)

Since: API Level 1

Add a new category to the intent. Categories provide additional detail about the action the intent is perform. When resolving an intent, only activities that provide all of the requested categories will be used.

Parameters
category The desired category. This can be either one of the predefined Intent categories, or a custom category in your own namespace.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent addFlags (int flags)

Since: API Level 1

Add additional flags to the intent (or with existing flags value).

Parameters
flags The new flags to set.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.
See Also

public Object clone ()

Since: API Level 1

Creates and returns a copy of this Object. The default implementation returns a so-called "shallow" copy: It creates a new instance of the same class and then copies the field values (including object references) from this instance to the new instance. A "deep" copy, in contrast, would also recursively clone nested objects. A subclass that needs to implement this kind of cloning should call super.clone() to create the new instance and then create deep copies of the nested, mutable objects.

Returns
  • a copy of this object.

public Intent cloneFilter ()

Since: API Level 1

Make a clone of only the parts of the Intent that are relevant for filter matching: the action, data, type, component, and categories.

public static Intent createChooser (Intent target, CharSequence title)

Since: API Level 1

Convenience function for creating a ACTION_CHOOSER Intent.

Parameters
target The Intent that the user will be selecting an activity to perform.
title Optional title that will be displayed in the chooser.
Returns

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 fillIn (Intent other, int flags)

Since: API Level 1

Copy the contents of other in to this object, but only where fields are not defined by this object. For purposes of a field being defined, the following pieces of data in the Intent are considered to be separate fields:

In addition, you can use the FILL_IN_ACTION, FILL_IN_DATA, FILL_IN_CATEGORIES, FILL_IN_PACKAGE, and FILL_IN_COMPONENT to override the restriction where the corresponding field will not be replaced if it is already set.

Note: The component field will only be copied if FILL_IN_COMPONENT is explicitly specified.

For example, consider Intent A with {data="foo", categories="bar"} and Intent B with {action="gotit", data-type="some/thing", categories="one","two"}.

Calling A.fillIn(B, Intent.FILL_IN_DATA) will result in A now containing: {action="gotit", data-type="some/thing", categories="bar"}.

Parameters
other Another Intent whose values are to be used to fill in the current one.
flags Options to control which fields can be filled in.
Returns

public boolean filterEquals (Intent other)

Since: API Level 1

Determine if two intents are the same for the purposes of intent resolution (filtering). That is, if their action, data, type, class, and categories are the same. This does not compare any extra data included in the intents.

Parameters
other The other Intent to compare against.
Returns
  • Returns true if action, data, type, class, and categories are the same.

public int filterHashCode ()

Since: API Level 1

Generate hash code that matches semantics of filterEquals().

Returns
  • Returns the hash value of the action, data, type, class, and categories.

public String getAction ()

Since: API Level 1

Retrieve the general action to be performed, such as ACTION_VIEW. The action describes the general way the rest of the information in the intent should be interpreted -- most importantly, what to do with the data returned by getData().

Returns
  • The action of this intent or null if none is specified.

public boolean[] getBooleanArrayExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no boolean array value was found.

public boolean getBooleanExtra (String name, boolean defaultValue)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
defaultValue the value to be returned if no value of the desired type is stored with the given name.
Returns
  • the value of an item that previously added with putExtra() or the default value if none was found.

public Bundle getBundleExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no Bundle value was found.

public byte[] getByteArrayExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no byte array value was found.

public byte getByteExtra (String name, byte defaultValue)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
defaultValue the value to be returned if no value of the desired type is stored with the given name.
Returns
  • the value of an item that previously added with putExtra() or the default value if none was found.

public Set<String> getCategories ()

Since: API Level 1

Return the set of all categories in the intent. If there are no categories, returns NULL.

Returns
  • Set The set of categories you can examine. Do not modify!

public char[] getCharArrayExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no char array value was found.

public char getCharExtra (String name, char defaultValue)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
defaultValue the value to be returned if no value of the desired type is stored with the given name.
Returns
  • the value of an item that previously added with putExtra() or the default value if none was found.

public CharSequence getCharSequenceExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no CharSequence value was found.

public ComponentName getComponent ()

Since: API Level 1

Retrieve the concrete component associated with the intent. When receiving an intent, this is the component that was found to best handle it (that is, yourself) and will always be non-null; in all other cases it will be null unless explicitly set.

Returns
  • The name of the application component to handle the intent.

public Uri getData ()

Since: API Level 1

Retrieve data this intent is operating on. This URI specifies the name of the data; often it uses the content: scheme, specifying data in a content provider. Other schemes may be handled by specific activities, such as http: by the web browser.

Returns
  • The URI of the data this intent is targeting or null.

public String getDataString ()

Since: API Level 1

The same as getData(), but returns the URI as an encoded String.

public double[] getDoubleArrayExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no double array value was found.

public double getDoubleExtra (String name, double defaultValue)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
defaultValue the value to be returned if no value of the desired type is stored with the given name.
Returns
  • the value of an item that previously added with putExtra() or the default value if none was found.

public Bundle getExtras ()

Since: API Level 1

Retrieves a map of extended data from the intent.

Returns
  • the map of all extras previously added with putExtra(), or null if none have been added.

public int getFlags ()

Since: API Level 1

Retrieve any special flags associated with this intent. You will normally just set them with setFlags(int) and let the system take the appropriate action with them.

Returns
  • int The currently set flags.
See Also

public float[] getFloatArrayExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no float array value was found.

public float getFloatExtra (String name, float defaultValue)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
defaultValue the value to be returned if no value of the desired type is stored with the given name.
Returns
  • the value of an item that previously added with putExtra(), or the default value if no such item is present

public int[] getIntArrayExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no int array value was found.

public int getIntExtra (String name, int defaultValue)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
defaultValue the value to be returned if no value of the desired type is stored with the given name.
Returns
  • the value of an item that previously added with putExtra() or the default value if none was found.

public ArrayList<Integer> getIntegerArrayListExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no ArrayList value was found.

public static Intent getIntent (String uri)

Since: API Level 1

This method is deprecated.Use parseUri(String, int) instead.

Call parseUri(String, int) with 0 flags.

public static Intent getIntentOld (String uri)

Since: API Level 1

public long[] getLongArrayExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no long array value was found.

public long getLongExtra (String name, long defaultValue)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
defaultValue the value to be returned if no value of the desired type is stored with the given name.
Returns
  • the value of an item that previously added with putExtra() or the default value if none was found.

public String getPackage ()

Since: API Level 4

Retrieve the application package name this Intent is limited to. When resolving an Intent, if non-null this limits the resolution to only components in the given application package.

Returns
  • The name of the application package for the Intent.

public Parcelable[] getParcelableArrayExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no Parcelable[] value was found.

public ArrayList<T> getParcelableArrayListExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no ArrayList value was found.

public T getParcelableExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no Parcelable value was found.

public String getScheme ()

Since: API Level 1

Return the scheme portion of the intent's data. If the data is null or does not include a scheme, null is returned. Otherwise, the scheme prefix without the final ':' is returned, i.e. "http".

This is the same as calling getData().getScheme() (and checking for null data).

Returns
  • The scheme of this intent.
See Also

public Serializable getSerializableExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no Serializable value was found.

public short[] getShortArrayExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no short array value was found.

public short getShortExtra (String name, short defaultValue)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
defaultValue the value to be returned if no value of the desired type is stored with the given name.
Returns
  • the value of an item that previously added with putExtra() or the default value if none was found.

public String[] getStringArrayExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no String array value was found.

public ArrayList<String> getStringArrayListExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no ArrayList value was found.

public String getStringExtra (String name)

Since: API Level 1

Retrieve extended data from the intent.

Parameters
name The name of the desired item.
Returns
  • the value of an item that previously added with putExtra() or null if no String value was found.

public String getType ()

Since: API Level 1

Retrieve any explicit MIME type included in the intent. This is usually null, as the type is determined by the intent data.

Returns
  • If a type was manually set, it is returned; else null is returned.

public boolean hasCategory (String category)

Since: API Level 1

Check if an category exists in the intent.

Parameters
category The category to check.
Returns
  • boolean True if the intent contains the category, else false.

public boolean hasExtra (String name)

Since: API Level 1

Returns true if an extra value is associated with the given name.

Parameters
name the extra's name
Returns
  • true if the given extra is present.

public boolean hasFileDescriptors ()

Since: API Level 1

Returns true if the Intent's extras contain a parcelled file descriptor.

Returns
  • true if the Intent contains a parcelled file descriptor.

public static Intent parseIntent (Resources resources, XmlPullParser parser, AttributeSet attrs)

Since: API Level 1

Parses the "intent" element (and its children) from XML and instantiates an Intent object. The given XML parser should be located at the tag where parsing should start (often named "intent"), from which the basic action, data, type, and package and class name will be retrieved. The function will then parse in to any child elements, looking for tags to add categories and to attach extra data to the intent.

Parameters
resources The Resources to use when inflating resources.
parser The XML parser pointing at an "intent" tag.
attrs The AttributeSet interface for retrieving extended attribute data at the current parser location.
Returns
  • An Intent object matching the XML data.
Throws
XmlPullParserException If there was an XML parsing error.
IOException If there was an I/O error.

public static Intent parseUri (String uri, int flags)

Since: API Level 4

Create an intent from a URI. This URI may encode the action, category, and other intent fields, if it was returned by toUri(int). If the Intent was not generate by toUri(), its data will be the entire URI and its action will be ACTION_VIEW.

The URI given here must not be relative -- that is, it must include the scheme and full path.

Parameters
uri The URI to turn into an Intent.
flags Additional processing flags. Either 0 or
Returns
  • Intent The newly created Intent object.
Throws
URISyntaxException Throws URISyntaxError if the basic URI syntax it bad (as parsed by the Uri class) or the Intent data within the URI is invalid.
See Also

public Intent putExtra (String name, String[] value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The String array data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, Parcelable value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The Parcelable data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, long value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The long data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, boolean value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The boolean data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, double value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The double data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, Parcelable[] value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The Parcelable[] data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, char value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The char data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, int[] value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The int array data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, int value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The integer data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, double[] value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The double array data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, float value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The float data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, short value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The short data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, long[] value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The byte array data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, boolean[] value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The boolean array data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, short[] value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The short array data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, String value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The String data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, Serializable value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The Serializable data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, float[] value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The float array data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, Bundle value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The Bundle data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, byte[] value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The byte array data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, CharSequence value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The CharSequence data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, char[] value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The char array data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtra (String name, byte value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The byte data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putExtras (Intent src)

Since: API Level 1

Copy all extras in 'src' in to this intent.

Parameters
src Contains the extras to copy.

public Intent putExtras (Bundle extras)

Since: API Level 1

Add a set of extended data to the intent. The keys must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
extras The Bundle of extras to add to this intent.

public Intent putIntegerArrayListExtra (String name, ArrayList<Integer> value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The ArrayList data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putParcelableArrayListExtra (String name, ArrayList<? extends Parcelable> value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The ArrayList data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent putStringArrayListExtra (String name, ArrayList<String> value)

Since: API Level 1

Add extended data to the intent. The name must include a package prefix, for example the app com.android.contacts would use names like "com.android.contacts.ShowAll".

Parameters
name The name of the extra data, with package prefix.
value The ArrayList data value.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public void readFromParcel (Parcel in)

Since: API Level 1

public void removeCategory (String category)

Since: API Level 1

Remove an category from an intent.

Parameters
category The category to remove.

public void removeExtra (String name)

Since: API Level 1

Remove extended data from the intent.

public Intent replaceExtras (Intent src)

Since: API Level 3

Completely replace the extras in the Intent with the extras in the given Intent.

Parameters
src The exact extras contained in this Intent are copied into the target intent, replacing any that were previously there.

public Intent replaceExtras (Bundle extras)

Since: API Level 3

Completely replace the extras in the Intent with the given Bundle of extras.

Parameters
extras The new set of extras in the Intent, or null to erase all extras.

public ComponentName resolveActivity (PackageManager pm)

Since: API Level 1

Return the Activity component that should be used to handle this intent. The appropriate component is determined based on the information in the intent, evaluated as follows:

If getComponent() returns an explicit class, that is returned without any further consideration.

The activity must handle the CATEGORY_DEFAULT Intent category to be considered.

If getAction() is non-NULL, the activity must handle this action.

If resolveType(ContentResolver) returns non-NULL, the activity must handle this type.

If addCategory(String) has added any categories, the activity must handle ALL of the categories specified.

If getPackage() is non-NULL, only activity components in that application package will be considered.

If there are no activities that satisfy all of these conditions, a null string is returned.

If multiple activities are found to satisfy the intent, the one with the highest priority will be used. If there are multiple activities with the same priority, the system will either pick the best activity based on user preference, or resolve to a system class that will allow the user to pick an activity and forward from there.

This method is implemented simply by calling resolveActivity(Intent, int) with the "defaultOnly" parameter true.

This API is called for you as part of starting an activity from an intent. You do not normally need to call it yourself.

Parameters
pm The package manager with which to resolve the Intent.
Returns
  • Name of the component implementing an activity that can display the intent.

public ActivityInfo resolveActivityInfo (PackageManager pm, int flags)

Since: API Level 1

Resolve the Intent into an ActivityInfo describing the activity that should execute the intent. Resolution follows the same rules as described for resolveActivity(PackageManager), but you get back the completely information about the resolved activity instead of just its class name.

Parameters
pm The package manager with which to resolve the Intent.
flags Addition information to retrieve as per PackageManager.getActivityInfo().
Returns
  • PackageManager.ActivityInfo

public String resolveType (ContentResolver resolver)

Since: API Level 1

Return the MIME data type of this intent. If the type field is explicitly set, that is simply returned. Otherwise, if the data is set, the type of that data is returned. If neither fields are set, a null is returned.

Parameters
resolver A ContentResolver that can be used to determine the MIME type of the intent's data.
Returns
  • The MIME type of this intent.

public String resolveType (Context context)

Since: API Level 1

Return the MIME data type of this intent. If the type field is explicitly set, that is simply returned. Otherwise, if the data is set, the type of that data is returned. If neither fields are set, a null is returned.

Returns
  • The MIME type of this intent.

public String resolveTypeIfNeeded (ContentResolver resolver)

Since: API Level 1

Return the MIME data type of this intent, only if it will be needed for intent resolution. This is not generally useful for application code; it is used by the frameworks for communicating with back-end system services.

Parameters
resolver A ContentResolver that can be used to determine the MIME type of the intent's data.
Returns
  • The MIME type of this intent, or null if it is unknown or not needed.

public Intent setAction (String action)

Since: API Level 1

Set the general action to be performed.

Parameters
action An action name, such as ACTION_VIEW. Application-specific actions should be prefixed with the vendor's package name.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.
See Also

public Intent setClass (Context packageContext, Class<?> cls)

Since: API Level 1

Convenience for calling setComponent(ComponentName) with the name returned by a Class object.

Parameters
packageContext A Context of the application package implementing this class.
cls The class name to set, equivalent to setClassName(context, cls.getName()).
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent setClassName (String packageName, String className)

Since: API Level 1

Convenience for calling setComponent(ComponentName) with an explicit application package name and class name.

Parameters
packageName The name of the package implementing the desired component.
className The name of a class inside of the application package that will be used as the component for this Intent.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent setClassName (Context packageContext, String className)

Since: API Level 1

Convenience for calling setComponent(ComponentName) with an explicit class name.

Parameters
packageContext A Context of the application package implementing this class.
className The name of a class inside of the application package that will be used as the component for this Intent.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent setComponent (ComponentName component)

Since: API Level 1

(Usually optional) Explicitly set the component to handle the intent. If left with the default value of null, the system will determine the appropriate class to use based on the other fields (action, data, type, categories) in the Intent. If this class is defined, the specified class will always be used regardless of the other fields. You should only set this value when you know you absolutely want a specific class to be used; otherwise it is better to let the system find the appropriate class so that you will respect the installed applications and user preferences.

Parameters
component The name of the application component to handle the intent, or null to let the system find one for you.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent setData (Uri data)

Since: API Level 1

Set the data this intent is operating on. This method automatically clears any type that was previously set by setType(String).

Note: scheme and host name matching in the Android framework is case-sensitive, unlike the formal RFC. As a result, you should always ensure that you write your Uri with these elements using lower case letters, and normalize any Uris you receive from outside of Android to ensure the scheme and host is lower case.

Parameters
data The URI of the data this intent is now targeting.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent setDataAndType (Uri data, String type)

Since: API Level 1

(Usually optional) Set the data for the intent along with an explicit MIME data type. This method should very rarely be used -- it allows you to override the MIME type that would ordinarily be inferred from the data with your own type given here.

Note: MIME type, Uri scheme, and host name matching in the Android framework is case-sensitive, unlike the formal RFC definitions. As a result, you should always write these elements with lower case letters, and normalize any MIME types or Uris you receive from outside of Android to ensure these elements are lower case before supplying them here.

Parameters
data The URI of the data this intent is now targeting.
type The MIME type of the data being handled by this intent.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public void setExtrasClassLoader (ClassLoader loader)

Since: API Level 1

Sets the ClassLoader that will be used when unmarshalling any Parcelable values from the extras of this Intent.

Parameters
loader a ClassLoader, or null to use the default loader at the time of unmarshalling.

public Intent setFlags (int flags)

Since: API Level 1

Set special flags controlling how this intent is handled. Most values here depend on the type of component being executed by the Intent, specifically the FLAG_ACTIVITY_* flags are all for use with Context.startActivity() and the FLAG_RECEIVER_* flags are all for use with Context.sendBroadcast().

See the Application Fundamentals: Activities and Tasks documentation for important information on how some of these options impact the behavior of your application.

Parameters
flags The desired flags.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent setPackage (String packageName)

Since: API Level 4

(Usually optional) Set an explicit application package name that limits the components this Intent will resolve to. If left to the default value of null, all components in all applications will considered. If non-null, the Intent can only match the components in the given application package.

Parameters
packageName The name of the application package to handle the intent, or null to allow any application package.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

public Intent setType (String type)

Since: API Level 1

Set an explicit MIME data type. This is used to create intents that only specify a type and not data, for example to indicate the type of data to return. This method automatically clears any data that was previously set by setData(Uri).

Note: MIME type matching in the Android framework is case-sensitive, unlike formal RFC MIME types. As a result, you should always write your MIME types with lower case letters, and any MIME types you receive from outside of Android should be converted to lower case before supplying them here.

Parameters
type The MIME type of the data being handled by this intent.
Returns
  • Returns the same Intent object, for chaining multiple calls into a single statement.

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 String toURI ()

Since: API Level 1

This method is deprecated.Use toUri(int) instead.

Call toUri(int) with 0 flags.

public String toUri (int flags)

Since: API Level 4

Convert this Intent into a String holding a URI representation of it. The returned URI string has been properly URI encoded, so it can be used with Uri.parse(String). The URI contains the Intent's data as the base URI, with an additional fragment describing the action, categories, type, flags, package, component, and extras.

You can convert the returned string back to an Intent with getIntent(String).

Parameters
flags Additional operating flags. Either 0 or URI_INTENT_SCHEME.
Returns
  • Returns a URI encoding URI string describing the entire contents of the Intent.

public void writeToParcel (Parcel out, int flags)

Since: API Level 1

Flatten this object in to a Parcel.

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