Android 10 (API level 29) and higher place restrictions on when apps can start activities when the app runs in the background. These restrictions help minimize interruptions for the user and keep the user more in control of what's shown on their screen.
This guide presents notifications as an alternative for starting activities from the background. It also lists the specific cases where the restriction doesn't apply.
Display notifications instead
In nearly all cases, apps in the background must display time-sensitive notifications to provide urgent information to the user instead of directly starting an activity. Such notifications include handling an incoming phone call or an active alarm clock.
This notification-based alert and reminder system provides several advantages for users:
- When using the device, the user sees a heads-up notification that lets them respond. The user maintains their current context and has control over the content that they see on the screen.
- Time-sensitive notifications respect the user's Do Not Disturb rules. For example, users might permit calls only from specific contacts or from repeat callers when Do Not Disturb is enabled.
- When the device's screen is off, the full-screen intent launches immediately.
- In the device's Settings screen, the user can see which apps have recently sent notifications, including from specific notification channels. From this screen, the user can control their notification preferences.
When apps can start activities
Apps running on Android 10 or higher can start activities when one or more of the following conditions are met:
- The app has a visible window, such as an activity in the foreground.
- Starting with Android 14, this requires the
app sending the
PendingIntentto explicitly opt in by passing in an
- Starting with Android 14, this requires the app sending the
- The app has an activity in the back stack of the foreground task.
The app has an activity in the back stack of an existing task on the Recents screen.
The app has an activity that started very recently.
The app called
finish()on an activity very recently. This applies only when the app had either an activity in the foreground or an activity in the back stack of the foreground task at the time
The app has one of the following services that is bound by the system. These services might need to launch a UI.
The app has a service that is bound by a different, visible app. The app bound to the service must remain visible for the app in the background to start activities successfully.
The app receives a notification
PendingIntentfrom the system. In the case of pending intents for services and broadcast receivers, the app can start activities for a few seconds after the pending intent is sent.
The app receives a
PendingIntentthat is sent from a different, visible app.
The app receives a system broadcast where the app is expected to launch a UI. Examples include
SECRET_CODE_ACTION. The app can start activities for a few seconds after the broadcast is sent.
The app is associated with a companion hardware device through the
CompanionDeviceManagerAPI. This API lets the app start activities in response to actions that the user performs on a paired device.
The app is granted the
SYSTEM_ALERT_WINDOWpermission by the user.