ActivityCompat
class ActivityCompat : ContextCompat
Helper for accessing features in android.app.Activity.
Summary
Nested types |
|---|
|
This interface is the contract for receiving the results for permission requests. |
interface ActivityCompat.PermissionCompatDelegateCustomizable delegate that allows delegating permission compatibility methods to a custom implementation. |
Protected constructors |
|---|
|
This class should not be instantiated, but the constructor must be visible for the class to be extended (as in support-v13). |
Public functions |
|
|---|---|
java-static Unit |
finishAffinity(activity: Activity)Finish this activity, and tries to finish all activities immediately below it in the current task that have the same affinity. |
java-static Unit |
finishAfterTransition(activity: Activity)Reverses the Activity Scene entry Transition and triggers the calling Activity to reverse its exit Transition. |
java-static Uri? |
getReferrer(activity: Activity)Return information about who launched this activity. |
java-static Boolean |
This function is deprecated. Use |
java-static Boolean |
isLaunchedFromBubble(activity: Activity)Indicates whether this activity is launched from a bubble. |
java-static Unit |
postponeEnterTransition(activity: Activity) |
java-static Unit |
Cause the given Activity to be recreated with a new instance. |
java-static DragAndDropPermissionsCompat? |
requestDragAndDropPermissions(activity: Activity, dragEvent: DragEvent)Create |
java-static Unit |
requestPermissions(Requests permissions to be granted to this application. |
java-static T |
<T : View?> requireViewById(activity: Activity, id: @IdRes Int)Finds a view that was identified by the |
java-static Unit |
setEnterSharedElementCallback(When |
java-static Unit |
setExitSharedElementCallback(When |
java-static Unit |
setLocusContext(activity: Activity, locusId: LocusIdCompat?, bundle: Bundle?)Sets the |
java-static Unit |
Sets the permission delegate for |
java-static Boolean |
shouldShowRequestPermissionRationale(Gets whether you should show UI with rationale before requesting a permission. |
java-static Unit |
startActivityForResult(Start new activity with options, if able, for which you would like a result when it finished. |
java-static Unit |
startIntentSenderForResult(Start new IntentSender with options, if able, for which you would like a result when it finished. |
java-static Unit |
startPostponedEnterTransition(activity: Activity) |
Inherited Constants |
|---|
Inherited functions |
||||||||||||||||||||||||||||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Protected constructors
ActivityCompat
protected ActivityCompat()
This class should not be instantiated, but the constructor must be visible for the class to be extended (as in support-v13).
Public functions
finishAffinity
java-static fun finishAffinity(activity: Activity): Unit
Finish this activity, and tries to finish all activities immediately below it in the current task that have the same affinity.
On Android 4.1+ calling this method will call through to the native version of this method. For other platforms finish will be called instead.
finishAfterTransition
java-static fun finishAfterTransition(activity: Activity): Unit
Reverses the Activity Scene entry Transition and triggers the calling Activity to reverse its exit Transition. When the exit Transition completes, finish is called. If no entry Transition was used, finish() is called immediately and the Activity exit Transition is run.
On Android 4.4 or lower, this method only finishes the Activity with no special exit transition.
getReferrer
java-static fun getReferrer(activity: Activity): Uri?
Return information about who launched this activity. If the launching Intent contains an Intent.EXTRA_REFERRER, that will be returned as-is; otherwise, if known, an android-app: referrer URI containing the package name that started the Intent will be returned. This may return null if no referrer can be identified -- it is neither explicitly specified, nor is it known which application package was involved.
If called while inside the handling of onNewIntent, this function will return the referrer that submitted that new intent to the activity. Otherwise, it always returns the referrer of the original Intent.
Note that this is not a security feature -- you can not trust the referrer information, applications can spoof it.
java-static funinvalidateOptionsMenu(activity: Activity!): Boolean
Invalidate the activity's options menu, if able.
Before API level 11 (Android 3.0/Honeycomb) the lifecycle of the options menu was controlled primarily by the user's operation of the hardware menu key. When the user presses down on the menu key for the first time the menu was created and prepared by calls to onCreateOptionsMenu and onPrepareOptionsMenu respectively. Subsequent presses of the menu key kept the existing instance of the Menu itself and called onPrepareOptionsMenu to give the activity an opportunity to contextually alter the menu before the menu panel was shown.
In Android 3.0+ the Action Bar forces the options menu to be built early so that items chosen to show as actions may be displayed when the activity first becomes visible. The Activity method invalidateOptionsMenu forces the entire menu to be destroyed and recreated from onCreateOptionsMenu, offering a similar though heavier-weight opportunity to change the menu's contents. Normally this functionality is used to support a changing configuration of Fragments.
Applications may use this support helper to signal a significant change in activity state that should cause the options menu to be rebuilt. If the app is running on an older platform version that does not support menu invalidation the app will still receive onPrepareOptionsMenu the next time the user presses the menu key and this method will return false. If this method returns true the options menu was successfully invalidated.
| Parameters | |
|---|---|
activity: Activity! |
Invalidate the options menu of this activity |
| Returns | |
|---|---|
Boolean |
true if this operation was supported and it completed; false if it was not available. |
isLaunchedFromBubble
java-static fun isLaunchedFromBubble(activity: Activity): Boolean
Indicates whether this activity is launched from a bubble. A bubble is a floating shortcut on the screen that expands to show an activity. If your activity can be used normally or as a bubble, you might use this method to check if the activity is bubbled to modify any behaviour that might be different between the normal activity and the bubbled activity. For example, if you normally cancel the notification associated with the activity when you open the activity, you might not want to do that when you're bubbled as that would remove the bubble.
| Returns | |
|---|---|
Boolean |
|
| See also | |
|---|---|
setBubbleMetadata |
|
Builder |
Compatibility behavior:
|
postponeEnterTransition
java-static fun postponeEnterTransition(activity: Activity): Unit
recreate
java-static fun recreate(activity: Activity): Unit
Cause the given Activity to be recreated with a new instance. This version of the method allows a consistent behavior across API levels, emulating what happens on Android Pie (and newer) when running on older platforms.
| Parameters | |
|---|---|
activity: Activity |
The activity to recreate |
requestDragAndDropPermissions
java-static fun requestDragAndDropPermissions(activity: Activity, dragEvent: DragEvent): DragAndDropPermissionsCompat?
Create DragAndDropPermissionsCompat object bound to this activity and controlling the access permissions for content URIs associated with the android.view.DragEvent.
| Parameters | |
|---|---|
activity: Activity |
activity for which to request the permission. |
dragEvent: DragEvent |
Drag event to request permission for |
| Returns | |
|---|---|
DragAndDropPermissionsCompat? |
The |
requestPermissions
java-static fun requestPermissions(
activity: Activity,
permissions: Array<String!>,
requestCode: @IntRange(from = 0) Int
): Unit
Requests permissions to be granted to this application. These permissions must be requested in your manifest, they should not be granted to your app, and they should have protection level dangerous, regardless whether they are declared by the platform or a third-party app.
Normal permissions PROTECTION_NORMAL are granted at install time if requested in the manifest. Signature permissions PROTECTION_SIGNATURE are granted at install time if requested in the manifest and the signature of your app matches the signature of the app declaring the permissions.
Call shouldShowRequestPermissionRationale before calling this API to check if the system recommends to show a rationale dialog before asking for a permission.
If your app does not have the requested permissions the user will be presented with UI for accepting them. After the user has accepted or rejected the requested permissions you will receive a callback reporting whether the permissions were granted or not. Your activity has to implement androidx.core.app.ActivityCompat.OnRequestPermissionsResultCallback and the results of permission requests will be delivered to its onRequestPermissionsResult method.
Note that requesting a permission does not guarantee it will be granted and your app should be able to run without having this permission.
This method may start an activity allowing the user to choose which permissions to grant and which to reject. Hence, you should be prepared that your activity may be paused and resumed. Further, granting some permissions may require a restart of you application. In such a case, the system will recreate the activity stack before delivering the result to your onRequestPermissionsResult.
When checking whether you have a permission you should use checkSelfPermission.
Calling this API for permissions already granted to your app would show UI to the user to decide whether the app can still hold these permissions. This can be useful if the way your app uses the data guarded by the permissions changes significantly.
You cannot request a permission if your activity sets noHistory to true in the manifest because in this case the activity would not receive result callbacks including onRequestPermissionsResult.
The RuntimePermissions sample app demonstrates how to use this method to request permissions at run time.
If POST_NOTIFICATIONS is requested before the device supports the notification permission, then POST_NOTIFICATIONS will be removed from onRequestPermissionsResult. For devices that don't support POST_NOTIFICATIONS, apps can send users to its notification settings to enable notifications. See android.provider.Settings.ACTION_APP_NOTIFICATION_SETTINGS for more information on launching notification settings.
requireViewById
java-static fun <T : View?> requireViewById(activity: Activity, id: @IdRes Int): T
Finds a view that was identified by the android:id XML attribute that was processed in onCreate, or throws an IllegalArgumentException if the ID is invalid, or there is no matching view in the hierarchy.
Note: In most cases -- depending on compiler support -- the resulting view is automatically cast to the target class type. If the target class type is unconstrained, an explicit cast may be necessary.
| Returns | |
|---|---|
T |
a view with given ID |
| See also | |
|---|---|
findViewById |
|
requireViewById |
setEnterSharedElementCallback
java-static fun setEnterSharedElementCallback(
activity: Activity,
callback: SharedElementCallback?
): Unit
When makeSceneTransitionAnimation was used to start an Activity, callback will be called to handle shared elements on the launched Activity. This requires FEATURE_CONTENT_TRANSITIONS.
| Parameters | |
|---|---|
activity: Activity |
activity for which to set the callback. |
callback: SharedElementCallback? |
Used to manipulate shared element transitions on the launched Activity. |
setExitSharedElementCallback
java-static fun setExitSharedElementCallback(
activity: Activity,
callback: SharedElementCallback?
): Unit
When makeSceneTransitionAnimation was used to start an Activity, callback will be called to handle shared elements on the launching Activity. Most calls will only come when returning from the started Activity. This requires FEATURE_CONTENT_TRANSITIONS.
| Parameters | |
|---|---|
activity: Activity |
activity for which to set the callback. |
callback: SharedElementCallback? |
Used to manipulate shared element transitions on the launching Activity. |
setLocusContext
java-static fun setLocusContext(activity: Activity, locusId: LocusIdCompat?, bundle: Bundle?): Unit
Sets the LocusIdCompat for this activity. The locus id helps identify different instances of the same Activity class.
For example, a locus id based on a specific conversation could be set on a conversation app's chat Activity. The system can then use this locus id along with app's contents to provide ranking signals in various UI surfaces including sharing, notifications, shortcuts and so on.
It is recommended to set the same locus id in the shortcut's locus id using setLocusId so that the system can learn appropriate ranking signals linking the activity's locus id with the matching shortcut.
| Parameters | |
|---|---|
activity: Activity |
activity for which to set locus id. |
locusId: LocusIdCompat? |
a unique, stable id that identifies this |
bundle: Bundle? |
extras set or updated as part of this locus context. This may help provide additional metadata such as URLs, conversation participants specific to this |
| See also | |
|---|---|
ContentCaptureManager |
|
ContentCaptureContext |
Compatibility behavior:
|
setPermissionCompatDelegate
java-static fun setPermissionCompatDelegate(
delegate: ActivityCompat.PermissionCompatDelegate?
): Unit
Sets the permission delegate for ActivityCompat. Replaces the previously set delegate.
| Parameters | |
|---|---|
delegate: ActivityCompat.PermissionCompatDelegate? |
The delegate to be set. |
shouldShowRequestPermissionRationale
java-static fun shouldShowRequestPermissionRationale(
activity: Activity,
permission: String
): Boolean
Gets whether you should show UI with rationale before requesting a permission.
| Parameters | |
|---|---|
activity: Activity |
The target activity. |
permission: String |
A permission your app wants to request. |
| Returns | |
|---|---|
Boolean |
Whether you should show permission rationale UI. |
| See also | |
|---|---|
checkSelfPermission |
|
requestPermissions |
startActivityForResult
java-static fun startActivityForResult(
activity: Activity,
intent: Intent,
requestCode: Int,
options: Bundle?
): Unit
Start new activity with options, if able, for which you would like a result when it finished.
In Android 4.1+ additional options were introduced to allow for more control on activity launch animations. Applications can use this method along with ActivityOptionsCompat to use these animations when available. When run on versions of the platform where this feature does not exist the activity will be launched normally.
| Parameters | |
|---|---|
activity: Activity |
Origin activity to launch from. |
intent: Intent |
The description of the activity to start. |
requestCode: Int |
If >= 0, this code will be returned in onActivityResult() when the activity exits. |
options: Bundle? |
Additional options for how the Activity should be started. May be null if there are no options. See |
startIntentSenderForResult
java-static fun startIntentSenderForResult(
activity: Activity,
intent: IntentSender,
requestCode: Int,
fillInIntent: Intent?,
flagsMask: Int,
flagsValues: Int,
extraFlags: Int,
options: Bundle?
): Unit
Start new IntentSender with options, if able, for which you would like a result when it finished.
In Android 4.1+ additional options were introduced to allow for more control on activity launch animations. Applications can use this method along with ActivityOptionsCompat to use these animations when available. When run on versions of the platform where this feature does not exist the activity will be launched normally.
| Parameters | |
|---|---|
activity: Activity |
Origin activity to launch from. |
intent: IntentSender |
The IntentSender to launch. |
requestCode: Int |
If >= 0, this code will be returned in onActivityResult() when the activity exits. |
fillInIntent: Intent? |
If non-null, this will be provided as the intent parameter to sendIntent. |
flagsMask: Int |
Intent flags in the original IntentSender that you would like to change. |
flagsValues: Int |
Desired values for any bits set in flagsMask |
extraFlags: Int |
Always set to 0. |
options: Bundle? |
Additional options for how the Activity should be started. May be null if there are no options. See |
startPostponedEnterTransition
java-static fun startPostponedEnterTransition(activity: Activity): Unit