Added in API level 1

NotificationManager


open class NotificationManager
kotlin.Any
   ↳ android.app.NotificationManager

Class to notify the user of events that happen. This is how you tell the user that something has happened in the background.

Notifications can take different forms:

  • A persistent icon that goes in the status bar and is accessible through the launcher, (when the user selects it, a designated Intent can be launched),
  • Turning on or flashing LEDs on the device, or
  • Alerting the user by flashing the backlight, playing a sound, or vibrating.

Each of the notify methods takes an int id parameter and optionally a String tag parameter, which may be null. These parameters are used to form a pair (tag, id), or (null, id) if tag is unspecified. This pair identifies this notification from your app to the system, so that pair should be unique within your app. If you call one of the notify methods with a (tag, id) pair that is currently active and a new set of notification parameters, it will be updated. For example, if you pass a new status bar icon, the old icon in the status bar will be replaced with the new one. This is also the same tag and id you pass to the cancel(int) or cancel(java.lang.String,int) method to clear this notification.

Summary

Nested classes
open

Notification policy configuration.

Constants
static String

Intent that is broadcast when an application is blocked or unblocked.

static String

Activity Action: Launch an Automatic Zen Rule configuration screen

static String

Intent that is broadcast when the status of an AutomaticZenRule has changed.

static String

Intent that is broadcast when the state of getConsolidatedNotificationPolicy() changes.

static String

Intent that is broadcast when the state of getCurrentInterruptionFilter() changes.

static String

Intent that is broadcast when a NotificationChannel is blocked (when NotificationChannel.getImportance() is IMPORTANCE_NONE) or unblocked (when NotificationChannel.getImportance() is anything other than IMPORTANCE_NONE).

static String

Intent that is broadcast when a NotificationChannelGroup is blocked or unblocked.

static String

Intent that is broadcast when the state of isNotificationPolicyAccessGranted() changes.

static String

Intent that is broadcast when the state of getNotificationPolicy() changes.

static Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the given rule has been activated by the user or cross device sync.

static Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the given rule has been deactivated ("snoozed") by the user.

static Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the given rule currently exists but is disabled.

static Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the given rule currently exists and is enabled.

static Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the given rule has been deleted.

static Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the current status of the rule is unknown at your target sdk version, and you should continue to provide state changes via setAutomaticZenRuleState(java.lang.String,android.service.notification.Condition).

static Int

Indicates that all bubbles are allowed from the app.

static Int

Indicates that the no bubbles are allowed from the app.

static Int

Indicates that only notifications selected by the user will appear as bubbles.

static String

Used as an optional string extra on ACTION_AUTOMATIC_ZEN_RULE intents.

static String

String extra for ACTION_AUTOMATIC_ZEN_RULE_STATUS_CHANGED containing the id of the AutomaticZenRule (see addAutomaticZenRule(android.app.AutomaticZenRule)) that has changed.

static String

Integer extra for ACTION_AUTOMATIC_ZEN_RULE_STATUS_CHANGED containing the state of the AutomaticZenRule.

static String

Extra for ACTION_NOTIFICATION_CHANNEL_BLOCK_STATE_CHANGED or ACTION_NOTIFICATION_CHANNEL_GROUP_BLOCK_STATE_CHANGED containing the new blocked state as a boolean.

static String

Extra for ACTION_NOTIFICATION_CHANNEL_GROUP_BLOCK_STATE_CHANGED containing the id of the NotificationChannelGroup which has a new blocked state.

static String

Extra for ACTION_NOTIFICATION_CHANNEL_BLOCK_STATE_CHANGED containing the id of the NotificationChannel which has a new blocked state.

static String

Extra for ACTION_NOTIFICATION_POLICY_CHANGED and ACTION_CONSOLIDATED_NOTIFICATION_POLICY_CHANGED containing the new Policy value.

static Int

Default notification importance: shows everywhere, makes noise, but does not visually intrude.

static Int

Higher notification importance: shows everywhere, makes noise and peeks.

static Int

Low notification importance: Shows in the shade, and potentially in the status bar (see shouldHideSilentStatusBarIcons()), but is not audibly intrusive.

static Int

Unused.

static Int

Min notification importance: only shows in the shade, below the fold.

static Int

A notification with no importance: does not show in the shade.

static Int

Value signifying that the user has not expressed an importance.

static Int

Interruption filter constant - Alarms only interruption filter - all notifications except those of category Notification.CATEGORY_ALARM are suppressed.

static Int

Interruption filter constant - Normal interruption filter - no notifications are suppressed.

static Int

Interruption filter constant - No interruptions filter - all notifications are suppressed and all audio streams (except those used for phone calls) and vibrations are muted.

static Int

Interruption filter constant - Priority interruption filter - all notifications are suppressed except those that match the priority criteria.

static Int

Interruption filter constant - returned when the value is unavailable for any reason.

static String

A required meta-data tag for activities that handle ACTION_AUTOMATIC_ZEN_RULE.

static String

An optional meta-data tag for activities that handle ACTION_AUTOMATIC_ZEN_RULE.

Public methods
open String!

Creates the given zen rule.

open Boolean

Returns true if users can independently and fully manage AutomaticZenRule rules.

open Boolean

Gets whether all notifications posted by this app can appear outside of the notification shade, floating over other apps' content.

open Boolean

Returns whether bubbles are enabled at the feature level for the current user.

open Boolean

Returns whether notifications from the calling package are enabled.

open Boolean

Returns whether notifications from this package are temporarily hidden.

open Boolean

Returns whether you are allowed to post notifications on behalf of a given package, with notifyAsPackage(java.lang.String,java.lang.String,int,android.app.Notification).

open Boolean

Returns whether the calling app's properly formatted notifications can appear in a promoted format, which may result in higher ranking, appearances on additional surfaces, and richer presentation.

open Boolean

Returns whether the calling app can send fullscreen intents.

open Unit
cancel(id: Int)

Cancels a previously posted notification.

open Unit
cancel(tag: String?, id: Int)

Cancels a previously posted notification.

open Unit

Cancel all previously shown notifications.

open Unit
cancelAsPackage(targetPackage: String, tag: String?, id: Int)

Cancels a previously posted notification.

open Unit

Creates a notification channel that notifications can be posted to.

open Unit

Creates a group container for NotificationChannel objects.

open Unit

Creates multiple notification channel groups.

open Unit

Creates multiple notification channels that different notifications can be posted to.

open Unit

Deletes the given notification channel.

open Unit

Deletes the given notification channel group, and all notification channels that belong to it.

open Array<StatusBarNotification!>!

Recover a list of active notifications: ones that have been posted by the calling app that have not yet been dismissed by the user or cancel(java.lang.String,int)ed by the app.

open AutomaticZenRule!

Returns the AutomaticZenRule with the given id, if it exists and the caller has access.

open Int

Returns the current activation state of an AutomaticZenRule.

open MutableMap<String!, AutomaticZenRule!>!

Returns AutomaticZenRules owned by the caller.

open Int

Gets the bubble preference for the app.

open NotificationManager.Policy

Returns the currently applied notification policy.

Int

Gets the current notification interruption filter.

open Int

Returns the user specified importance for notifications from the calling package.

open NotificationChannel!

Returns the notification channel settings for a given channel id.

open NotificationChannel?
getNotificationChannel(channelId: String, conversationId: String)

Returns the notification channel settings for a given channel and conversation id.

open NotificationChannelGroup!

Returns the notification channel group settings for a given channel group id.

open MutableList<NotificationChannelGroup!>!

Returns all notification channel groups belonging to the calling app.

open MutableList<NotificationChannel!>!

Returns all notification channels belonging to the calling package.

open String?

Returns the delegate that can post notifications on your behalf, if there currently is one.

open NotificationManager.Policy!

Gets the current user-specified default notification policy.

open Boolean

Checks whether the user has approved a given android.service.notification.NotificationListenerService.

open Boolean

Checks the ability to modify Notification Policy for the calling package.

open Boolean

Returns whether a call from the provided URI is permitted to notify the user.

open Unit
notify(id: Int, notification: Notification!)

Post a notification to be shown in the status bar.

open Unit
notify(tag: String!, id: Int, notification: Notification!)

Posts a notification to be shown in the status bar.

open Unit
notifyAsPackage(targetPackage: String, tag: String?, id: Int, notification: Notification)

Posts a notification as a specified package to be shown in the status bar.

open Boolean

Deletes the automatic zen rule with the given id.

open Unit

Informs the notification manager that the state of an AutomaticZenRule has changed.

Unit
setInterruptionFilter(interruptionFilter: Int)

Sets the current notification interruption filter.

open Unit

Allows a package to post notifications on your behalf using notifyAsPackage(java.lang.String,java.lang.String,int,android.app.Notification).

open Unit

Sets the current notification policy (which applies when setInterruptionFilter is called with the INTERRUPTION_FILTER_PRIORITY value).

open Boolean

Returns whether the user wants silent notifications (see IMPORTANCE_LOW to appear in the status bar.

open Boolean
updateAutomaticZenRule(id: String!, automaticZenRule: AutomaticZenRule!)

Updates the given zen rule.

Constants

ACTION_APP_BLOCK_STATE_CHANGED

Added in API level 28
static val ACTION_APP_BLOCK_STATE_CHANGED: String

Intent that is broadcast when an application is blocked or unblocked. This broadcast is only sent to the app whose block state has changed. Input: nothing Output: EXTRA_BLOCKED_STATE

Value: "android.app.action.APP_BLOCK_STATE_CHANGED"

ACTION_AUTOMATIC_ZEN_RULE

Added in API level 29
static val ACTION_AUTOMATIC_ZEN_RULE: String

Activity Action: Launch an Automatic Zen Rule configuration screen

Input: Optionally, EXTRA_AUTOMATIC_RULE_ID, if the configuration screen for an existing rule should be displayed. If the rule id is missing or null, apps should display a configuration screen where users can create a new instance of the rule.

Output: Nothing

You can have multiple activities handling this intent, if you support multiple rules. In order for the system to properly display all of your rule types so that users can create new instances or configure existing ones, you need to add some extra metadata (META_DATA_AUTOMATIC_RULE_TYPE) to your activity tag in your manifest. If you'd like to limit the number of rules a user can create from this flow, you can additionally optionally include META_DATA_RULE_INSTANCE_LIMIT. For example,

<code>&lt;meta-data
          android:name="android.service.zen.automatic.ruleType"
          android:value="@string/my_condition_rule" /&gt;
      &lt;meta-data
          android:name="android.service.zen.automatic.ruleInstanceLimit"
          android:value="1" /&gt;
      </code>
Value: "android.app.action.AUTOMATIC_ZEN_RULE"

ACTION_AUTOMATIC_ZEN_RULE_STATUS_CHANGED

Added in API level 30
static val ACTION_AUTOMATIC_ZEN_RULE_STATUS_CHANGED: String

Intent that is broadcast when the status of an AutomaticZenRule has changed.

Use this to know whether you need to continue monitor to device state in order to provide up-to-date states (with setAutomaticZenRuleState(java.lang.String,android.service.notification.Condition)) for this rule.

Input: nothing Output: EXTRA_AUTOMATIC_ZEN_RULE_ID Output: EXTRA_AUTOMATIC_ZEN_RULE_STATUS
Value: "android.app.action.AUTOMATIC_ZEN_RULE_STATUS_CHANGED"

ACTION_CONSOLIDATED_NOTIFICATION_POLICY_CHANGED

Added in API level 35
static val ACTION_CONSOLIDATED_NOTIFICATION_POLICY_CHANGED: String

Intent that is broadcast when the state of getConsolidatedNotificationPolicy() changes.

This broadcast is only sent to registered receivers and receivers in packages that have been granted Notification Policy access (see isNotificationPolicyAccessGranted()).

Value: "android.app.action.CONSOLIDATED_NOTIFICATION_POLICY_CHANGED"

ACTION_INTERRUPTION_FILTER_CHANGED

Added in API level 23
static val ACTION_INTERRUPTION_FILTER_CHANGED: String

Intent that is broadcast when the state of getCurrentInterruptionFilter() changes.

This broadcast is only sent to registered receivers and (starting from Build.VERSION_CODES.Q) receivers in packages that have been granted Do Not Disturb access (see isNotificationPolicyAccessGranted()).

Value: "android.app.action.INTERRUPTION_FILTER_CHANGED"

ACTION_NOTIFICATION_CHANNEL_BLOCK_STATE_CHANGED

Added in API level 28
static val ACTION_NOTIFICATION_CHANNEL_BLOCK_STATE_CHANGED: String

Intent that is broadcast when a NotificationChannel is blocked (when NotificationChannel.getImportance() is IMPORTANCE_NONE) or unblocked (when NotificationChannel.getImportance() is anything other than IMPORTANCE_NONE). This broadcast is only sent to the app that owns the channel that has changed. Input: nothing Output: EXTRA_NOTIFICATION_CHANNEL_ID Output: EXTRA_BLOCKED_STATE

Value: "android.app.action.NOTIFICATION_CHANNEL_BLOCK_STATE_CHANGED"

ACTION_NOTIFICATION_CHANNEL_GROUP_BLOCK_STATE_CHANGED

Added in API level 28
static val ACTION_NOTIFICATION_CHANNEL_GROUP_BLOCK_STATE_CHANGED: String

Intent that is broadcast when a NotificationChannelGroup is blocked or unblocked. This broadcast is only sent to the app that owns the channel group that has changed. Input: nothing Output: EXTRA_NOTIFICATION_CHANNEL_GROUP_ID Output: EXTRA_BLOCKED_STATE

Value: "android.app.action.NOTIFICATION_CHANNEL_GROUP_BLOCK_STATE_CHANGED"

ACTION_NOTIFICATION_POLICY_ACCESS_GRANTED_CHANGED

Added in API level 23
static val ACTION_NOTIFICATION_POLICY_ACCESS_GRANTED_CHANGED: String

Intent that is broadcast when the state of isNotificationPolicyAccessGranted() changes. This broadcast is only sent to registered receivers, and only to the apps that have changed.

Value: "android.app.action.NOTIFICATION_POLICY_ACCESS_GRANTED_CHANGED"

ACTION_NOTIFICATION_POLICY_CHANGED

Added in API level 23
static val ACTION_NOTIFICATION_POLICY_CHANGED: String

Intent that is broadcast when the state of getNotificationPolicy() changes.

This broadcast is only sent to registered receivers and (starting from Build.VERSION_CODES.Q) receivers in packages that have been granted Do Not Disturb access (see isNotificationPolicyAccessGranted()).

Starting with Build.VERSION_CODES.VANILLA_ICE_CREAM, most calls to setNotificationPolicy(android.app.NotificationManager.Policy) will update the app's implicit rule policy instead of the global policy, so this broadcast will be sent much less frequently.

Value: "android.app.action.NOTIFICATION_POLICY_CHANGED"

AUTOMATIC_RULE_STATUS_ACTIVATED

Added in API level 35
static val AUTOMATIC_RULE_STATUS_ACTIVATED: Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the given rule has been activated by the user or cross device sync. Sent from Build.VERSION_CODES.VANILLA_ICE_CREAM. If the rule owner has a mode that includes a DND component, the rule owner should activate any extra behavior that's part of that mode in response to this broadcast.

Value: 4

AUTOMATIC_RULE_STATUS_DEACTIVATED

Added in API level 35
static val AUTOMATIC_RULE_STATUS_DEACTIVATED: Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the given rule has been deactivated ("snoozed") by the user. The rule will not return to an activated state until the app calls setAutomaticZenRuleState(java.lang.String,android.service.notification.Condition) with Condition.STATE_FALSE (either immediately or when the trigger criteria is no longer met) and then Condition.STATE_TRUE when the trigger criteria is freshly met, or when the user re-activates it.

Value: 5

AUTOMATIC_RULE_STATUS_DISABLED

Added in API level 30
static val AUTOMATIC_RULE_STATUS_DISABLED: Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the given rule currently exists but is disabled. You do not need to continue to provide state changes via setAutomaticZenRuleState(java.lang.String,android.service.notification.Condition) until the rule is reenabled.

Value: 2

AUTOMATIC_RULE_STATUS_ENABLED

Added in API level 30
static val AUTOMATIC_RULE_STATUS_ENABLED: Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the given rule currently exists and is enabled. You should continue to provide state changes via setAutomaticZenRuleState(java.lang.String,android.service.notification.Condition).

Value: 1

AUTOMATIC_RULE_STATUS_REMOVED

Added in API level 30
static val AUTOMATIC_RULE_STATUS_REMOVED: Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the given rule has been deleted. Further calls to setAutomaticZenRuleState(java.lang.String,android.service.notification.Condition) will be ignored.

Value: 3

AUTOMATIC_RULE_STATUS_UNKNOWN

Added in API level 30
static val AUTOMATIC_RULE_STATUS_UNKNOWN: Int

Constant value for EXTRA_AUTOMATIC_ZEN_RULE_STATUS - the current status of the rule is unknown at your target sdk version, and you should continue to provide state changes via setAutomaticZenRuleState(java.lang.String,android.service.notification.Condition).

Value: -1

BUBBLE_PREFERENCE_ALL

Added in API level 31
static val BUBBLE_PREFERENCE_ALL: Int

Indicates that all bubbles are allowed from the app. If the app sends bubbles, the bubble will appear along with the notification.

Value: 1

BUBBLE_PREFERENCE_NONE

Added in API level 31
static val BUBBLE_PREFERENCE_NONE: Int

Indicates that the no bubbles are allowed from the app. If the app sends bubbles, only the notification will appear. The notification will have an affordance allowing the user to bubble it. If the user selects this affordance, that notification is approved to bubble and the apps' bubble preference will be upgraded to BUBBLE_PREFERENCE_SELECTED.

Value: 0

BUBBLE_PREFERENCE_SELECTED

Added in API level 31
static val BUBBLE_PREFERENCE_SELECTED: Int

Indicates that only notifications selected by the user will appear as bubbles. If the app sends bubbles that haven't been selected, only the notification appear. If the bubble has been approved by the user, it will appear along with the notification.

Value: 2

EXTRA_AUTOMATIC_RULE_ID

Added in API level 29
static val EXTRA_AUTOMATIC_RULE_ID: String

Used as an optional string extra on ACTION_AUTOMATIC_ZEN_RULE intents. If provided, contains the id of the AutomaticZenRule (as returned from NotificationManager.addAutomaticZenRule(AutomaticZenRule)) for which configuration settings should be displayed.

Value: "android.app.extra.AUTOMATIC_RULE_ID"

EXTRA_AUTOMATIC_ZEN_RULE_ID

Added in API level 30
static val EXTRA_AUTOMATIC_ZEN_RULE_ID: String

String extra for ACTION_AUTOMATIC_ZEN_RULE_STATUS_CHANGED containing the id of the AutomaticZenRule (see addAutomaticZenRule(android.app.AutomaticZenRule)) that has changed.

Value: "android.app.extra.AUTOMATIC_ZEN_RULE_ID"

EXTRA_AUTOMATIC_ZEN_RULE_STATUS

Added in API level 30
static val EXTRA_AUTOMATIC_ZEN_RULE_STATUS: String

Integer extra for ACTION_AUTOMATIC_ZEN_RULE_STATUS_CHANGED containing the state of the AutomaticZenRule.

The value will be one of AUTOMATIC_RULE_STATUS_ENABLED, AUTOMATIC_RULE_STATUS_DISABLED, AUTOMATIC_RULE_STATUS_REMOVED, AUTOMATIC_RULE_STATUS_ACTIVATED, AUTOMATIC_RULE_STATUS_DEACTIVATED, or AUTOMATIC_RULE_STATUS_UNKNOWN.

Note that the AUTOMATIC_RULE_STATUS_ACTIVATED and AUTOMATIC_RULE_STATUS_DEACTIVATED statuses are only sent to packages targeting Build.VERSION_CODES.VANILLA_ICE_CREAM and above; apps targeting a lower SDK version will be sent AUTOMATIC_RULE_STATUS_UNKNOWN in their place instead.

Value: "android.app.extra.AUTOMATIC_ZEN_RULE_STATUS"

EXTRA_BLOCKED_STATE

Added in API level 28
static val EXTRA_BLOCKED_STATE: String

Extra for ACTION_NOTIFICATION_CHANNEL_BLOCK_STATE_CHANGED or ACTION_NOTIFICATION_CHANNEL_GROUP_BLOCK_STATE_CHANGED containing the new blocked state as a boolean. The value will be true if this channel or group is now blocked and false if this channel or group is now unblocked.

Value: "android.app.extra.BLOCKED_STATE"

EXTRA_NOTIFICATION_CHANNEL_GROUP_ID

Added in API level 28
static val EXTRA_NOTIFICATION_CHANNEL_GROUP_ID: String

Extra for ACTION_NOTIFICATION_CHANNEL_GROUP_BLOCK_STATE_CHANGED containing the id of the NotificationChannelGroup which has a new blocked state. The value will be the NotificationChannelGroup.getId() of the group.

Value: "android.app.extra.NOTIFICATION_CHANNEL_GROUP_ID"

EXTRA_NOTIFICATION_CHANNEL_ID

Added in API level 28
static val EXTRA_NOTIFICATION_CHANNEL_ID: String

Extra for ACTION_NOTIFICATION_CHANNEL_BLOCK_STATE_CHANGED containing the id of the NotificationChannel which has a new blocked state. The value will be the NotificationChannel.getId() of the channel.

Value: "android.app.extra.NOTIFICATION_CHANNEL_ID"

EXTRA_NOTIFICATION_POLICY

Added in API level 35
static val EXTRA_NOTIFICATION_POLICY: String

Extra for ACTION_NOTIFICATION_POLICY_CHANGED and ACTION_CONSOLIDATED_NOTIFICATION_POLICY_CHANGED containing the new Policy value.

Value: "android.app.extra.NOTIFICATION_POLICY"

IMPORTANCE_DEFAULT

Added in API level 24
static val IMPORTANCE_DEFAULT: Int

Default notification importance: shows everywhere, makes noise, but does not visually intrude.

Value: 3

IMPORTANCE_HIGH

Added in API level 24
static val IMPORTANCE_HIGH: Int

Higher notification importance: shows everywhere, makes noise and peeks. May use full screen intents.

Value: 4

IMPORTANCE_LOW

Added in API level 24
static val IMPORTANCE_LOW: Int

Low notification importance: Shows in the shade, and potentially in the status bar (see shouldHideSilentStatusBarIcons()), but is not audibly intrusive.

Value: 2

IMPORTANCE_MAX

Added in API level 24
static val IMPORTANCE_MAX: Int

Unused.

Value: 5

IMPORTANCE_MIN

Added in API level 24
static val IMPORTANCE_MIN: Int

Min notification importance: only shows in the shade, below the fold. This should not be used with Service.startForeground since a foreground service is supposed to be something the user cares about so it does not make semantic sense to mark its notification as minimum importance. If you do this as of Android version android.os.Build.VERSION_CODES#O, the system will show a higher-priority notification about your app running in the background.

Value: 1

IMPORTANCE_NONE

Added in API level 24
static val IMPORTANCE_NONE: Int

A notification with no importance: does not show in the shade.

Value: 0

IMPORTANCE_UNSPECIFIED

Added in API level 24
static val IMPORTANCE_UNSPECIFIED: Int

Value signifying that the user has not expressed an importance. This value is for persisting preferences, and should never be associated with an actual notification.

Value: -1000

INTERRUPTION_FILTER_ALARMS

Added in API level 23
static val INTERRUPTION_FILTER_ALARMS: Int

Interruption filter constant - Alarms only interruption filter - all notifications except those of category Notification.CATEGORY_ALARM are suppressed. Some audio streams are muted.

Value: 4

INTERRUPTION_FILTER_ALL

Added in API level 23
static val INTERRUPTION_FILTER_ALL: Int

Interruption filter constant - Normal interruption filter - no notifications are suppressed.

Value: 1

INTERRUPTION_FILTER_NONE

Added in API level 23
static val INTERRUPTION_FILTER_NONE: Int

Interruption filter constant - No interruptions filter - all notifications are suppressed and all audio streams (except those used for phone calls) and vibrations are muted.

Value: 3

INTERRUPTION_FILTER_PRIORITY

Added in API level 23
static val INTERRUPTION_FILTER_PRIORITY: Int

Interruption filter constant - Priority interruption filter - all notifications are suppressed except those that match the priority criteria. Some audio streams are muted. See Policy.priorityCallSenders, Policy.priorityCategories, Policy.priorityMessageSenders to define or query this criteria. Users can additionally specify packages that can bypass this interruption filter.

Value: 2

INTERRUPTION_FILTER_UNKNOWN

Added in API level 23
static val INTERRUPTION_FILTER_UNKNOWN: Int

Interruption filter constant - returned when the value is unavailable for any reason.

Value: 0

META_DATA_AUTOMATIC_RULE_TYPE

Added in API level 29
static val META_DATA_AUTOMATIC_RULE_TYPE: String

A required meta-data tag for activities that handle ACTION_AUTOMATIC_ZEN_RULE. This tag should contain a localized name of the type of the zen rule provided by the activity.

Value: "android.service.zen.automatic.ruleType"

META_DATA_RULE_INSTANCE_LIMIT

Added in API level 29
static val META_DATA_RULE_INSTANCE_LIMIT: String

An optional meta-data tag for activities that handle ACTION_AUTOMATIC_ZEN_RULE. This tag should contain the maximum number of rule instances that can be created for this rule type. Omit or enter a value <= 0 to allow unlimited instances.

Value: "android.service.zen.automatic.ruleInstanceLimit"

Public methods

addAutomaticZenRule

Added in API level 24
open fun addAutomaticZenRule(automaticZenRule: AutomaticZenRule!): String!

Creates the given zen rule.

Throws a SecurityException if policy access is not granted to this package. See isNotificationPolicyAccessGranted.

Parameters
automaticZenRule AutomaticZenRule!: the rule to create.
Return
String! The id of the newly created rule; null if the rule could not be created.

areAutomaticZenRulesUserManaged

Added in API level 35
open fun areAutomaticZenRulesUserManaged(): Boolean

Returns true if users can independently and fully manage AutomaticZenRule rules. This includes the ability to independently activate/deactivate rules and overwrite/freeze the behavior (policy) of the rule when activated.

If this method returns true, calls to updateAutomaticZenRule(java.lang.String,android.app.AutomaticZenRule) may fail and apps should defer rule management to system settings/uis via Settings.ACTION_AUTOMATIC_ZEN_RULE_SETTINGS.

areBubblesAllowed

Added in API level 29
Deprecated in API level 31
open fun areBubblesAllowed(): Boolean

Deprecated: use getBubblePreference() instead.

Gets whether all notifications posted by this app can appear outside of the notification shade, floating over other apps' content.

This value will be ignored for notifications that are posted to channels that do not allow bubbles (NotificationChannel.canBubble()).

areBubblesEnabled

Added in API level 31
open fun areBubblesEnabled(): Boolean

Returns whether bubbles are enabled at the feature level for the current user. When enabled, notifications able to bubble will display an affordance allowing the user to bubble them.

areNotificationsEnabled

Added in API level 24
open fun areNotificationsEnabled(): Boolean

Returns whether notifications from the calling package are enabled.

areNotificationsPaused

Added in API level 29
open fun areNotificationsPaused(): Boolean

Returns whether notifications from this package are temporarily hidden. This could be done because the package was marked as distracting to the user via PackageManager#setDistractingPackageRestrictions(String[], int) or because the package is PackageManager#setPackagesSuspended(String[], boolean, PersistableBundle, PersistableBundle, SuspendDialogInfo) suspended.

canNotifyAsPackage

Added in API level 29
open fun canNotifyAsPackage(pkg: String): Boolean

Returns whether you are allowed to post notifications on behalf of a given package, with notifyAsPackage(java.lang.String,java.lang.String,int,android.app.Notification). See setNotificationDelegate(java.lang.String).

Parameters
pkg String: This value cannot be null.

canPostPromotedNotifications

open fun canPostPromotedNotifications(): Boolean

Returns whether the calling app's properly formatted notifications can appear in a promoted format, which may result in higher ranking, appearances on additional surfaces, and richer presentation. Apps can request this permission by sending the user to the activity that matches the system intent action android.provider.Settings#ACTION_APP_NOTIFICATION_PROMOTION_SETTINGS.

canUseFullScreenIntent

Added in API level 34
open fun canUseFullScreenIntent(): Boolean

Returns whether the calling app can send fullscreen intents.

From Android android.os.Build.VERSION_CODES#UPSIDE_DOWN_CAKE, apps may not have permission to use android.Manifest.permission#USE_FULL_SCREEN_INTENT. If permission is denied, notification will show up as an expanded heads up notification on lockscreen.

To request access, add the android.Manifest.permission#USE_FULL_SCREEN_INTENT permission to your manifest, and use android.provider.Settings#ACTION_MANAGE_APP_USE_FULL_SCREEN_INTENT.

cancel

Added in API level 1
open fun cancel(id: Int): Unit

Cancels a previously posted notification.

If the notification does not currently represent a foreground service or a user-initiated job, it will be removed from the UI and live notification listeners will be informed so they can remove the notification from their UIs.

cancel

Added in API level 5
open fun cancel(
    tag: String?,
    id: Int
): Unit

Cancels a previously posted notification.

If the notification does not currently represent a foreground service or a user-initiated job, it will be removed from the UI and live notification listeners will be informed so they can remove the notification from their UIs.

Parameters
tag String?: This value may be null.

cancelAll

Added in API level 1
open fun cancelAll(): Unit

Cancel all previously shown notifications. See #cancel for the detailed behavior.

cancelAsPackage

open fun cancelAsPackage(
    targetPackage: String,
    tag: String?,
    id: Int
): Unit

Cancels a previously posted notification.

If the notification does not currently represent a foreground service or a user-initiated job, it will be removed from the UI and live notification listeners will be informed so they can remove the notification from their UIs.

This method may be used by a notification delegate to cancel notifications that they have posted via notifyAsPackage(java.lang.String,java.lang.String,int,android.app.Notification).

Parameters
targetPackage String: The package to cancel the notification as. If this package is not your package, you can only cancel notifications you posted with A string identifier for this notification. May be

createNotificationChannel

Added in API level 26
open fun createNotificationChannel(channel: NotificationChannel): Unit

Creates a notification channel that notifications can be posted to. This can also be used to restore a deleted channel and to update an existing channel's name, description, group, and/or importance.

The name and description should only be changed if the locale changes or in response to the user renaming this channel. For example, if a user has a channel named 'Messages' and the user changes their locale, this channel's name should be updated with the translation of 'Messages' in the new locale.

The importance of an existing channel will only be changed if the new importance is lower than the current value and the user has not altered any settings on this channel.

The group an existing channel will only be changed if the channel does not already belong to a group. All other fields are ignored for channels that already exist.

Parameters
channel NotificationChannel: the channel to create. Note that the created channel may differ from this value. If the provided channel is malformed, a RemoteException will be thrown. This value cannot be null.

createNotificationChannelGroup

Added in API level 26
open fun createNotificationChannelGroup(group: NotificationChannelGroup): Unit

Creates a group container for NotificationChannel objects. This can be used to rename an existing group.

Group information is only used for presentation, not for behavior. Groups are optional for channels, and you can have a mix of channels that belong to groups and channels that do not.

For example, if your application supports multiple accounts, and those accounts will have similar channels, you can create a group for each account with account specific labels instead of appending account information to each channel's label.

Parameters
group NotificationChannelGroup: The group to create This value cannot be null.

createNotificationChannelGroups

Added in API level 26
open fun createNotificationChannelGroups(groups: MutableList<NotificationChannelGroup!>): Unit

Creates multiple notification channel groups.

Parameters
groups MutableList<NotificationChannelGroup!>: The list of groups to create This value cannot be null.

createNotificationChannels

Added in API level 26
open fun createNotificationChannels(channels: MutableList<NotificationChannel!>): Unit

Creates multiple notification channels that different notifications can be posted to. See createNotificationChannel(android.app.NotificationChannel).

Parameters
channels MutableList<NotificationChannel!>: the list of channels to attempt to create. This value cannot be null.

deleteNotificationChannel

Added in API level 26
open fun deleteNotificationChannel(channelId: String!): Unit

Deletes the given notification channel.

If you create a new channel with this same id, the deleted channel will be un-deleted with all of the same settings it had before it was deleted.

deleteNotificationChannelGroup

Added in API level 26
open fun deleteNotificationChannelGroup(groupId: String!): Unit

Deletes the given notification channel group, and all notification channels that belong to it.

getActiveNotifications

Added in API level 23
open fun getActiveNotifications(): Array<StatusBarNotification!>!

Recover a list of active notifications: ones that have been posted by the calling app that have not yet been dismissed by the user or cancel(java.lang.String,int)ed by the app.

StatusBarNotification object, including the original tag and id supplied to notify() (via getTag() and getId()) as well as a copy of the original Notification object (via StatusBarNotification.getNotification()).

From Build.VERSION_CODES.Q, will also return notifications you've posted as an app's notification delegate via NotificationManager.notifyAsPackage(String, String, int, Notification).

Return
Array<StatusBarNotification!>! An array of StatusBarNotification.

getAutomaticZenRule

Added in API level 24
open fun getAutomaticZenRule(id: String!): AutomaticZenRule!

Returns the AutomaticZenRule with the given id, if it exists and the caller has access.

Throws a SecurityException if policy access is not granted to this package. See isNotificationPolicyAccessGranted.

Returns null if there are no zen rules that match the given id, or if the calling package doesn't own the matching rule. See AutomaticZenRule.getOwner.

getAutomaticZenRuleState

Added in API level 35
open fun getAutomaticZenRuleState(id: String): Int

Returns the current activation state of an AutomaticZenRule.

Returns Condition.STATE_UNKNOWN if the rule does not exist or the calling package doesn't have access to it.

Parameters
id String: The id of the rule This value cannot be null.
Return
Int the state of the rule. Value is android.service.notification.Condition#STATE_FALSE, android.service.notification.Condition#STATE_TRUE, android.service.notification.Condition#STATE_UNKNOWN, or android.service.notification.Condition#STATE_ERROR

getAutomaticZenRules

Added in API level 24
open fun getAutomaticZenRules(): MutableMap<String!, AutomaticZenRule!>!

Returns AutomaticZenRules owned by the caller.

Throws a SecurityException if policy access is not granted to this package. See isNotificationPolicyAccessGranted.

getBubblePreference

Added in API level 31
open fun getBubblePreference(): Int

Gets the bubble preference for the app. This preference only applies to notifications that have been properly configured to bubble.

If BUBBLE_PREFERENCE_ALL, then any bubble notification will appear as a bubble, as long as the user hasn't excluded it (NotificationChannel.canBubble()).

If BUBBLE_PREFERENCE_SELECTED, then any bubble notification will appear as a bubble, as long as the user has selected it.

If BUBBLE_PREFERENCE_NONE, then no notification may appear as a bubble from the app.

Return
Int the users' bubble preference for the app. Value is android.app.NotificationManager#BUBBLE_PREFERENCE_NONE, android.app.NotificationManager#BUBBLE_PREFERENCE_SELECTED, or android.app.NotificationManager#BUBBLE_PREFERENCE_ALL

getConsolidatedNotificationPolicy

Added in API level 30
open fun getConsolidatedNotificationPolicy(): NotificationManager.Policy

Returns the currently applied notification policy.

If getCurrentInterruptionFilter is equal to INTERRUPTION_FILTER_ALL, then the consolidated notification policy will match the default notification policy returned by getNotificationPolicy.

Return
NotificationManager.Policy This value cannot be null.

getCurrentInterruptionFilter

Added in API level 23
fun getCurrentInterruptionFilter(): Int

Gets the current notification interruption filter.

The interruption filter defines which notifications are allowed to interrupt the user (e.g. via sound & vibration) and is applied globally.

Return
Int Value is android.app.NotificationManager#INTERRUPTION_FILTER_NONE, android.app.NotificationManager#INTERRUPTION_FILTER_PRIORITY, android.app.NotificationManager#INTERRUPTION_FILTER_ALARMS, android.app.NotificationManager#INTERRUPTION_FILTER_ALL, or android.app.NotificationManager#INTERRUPTION_FILTER_UNKNOWN

getNotificationChannel

Added in API level 26
open fun getNotificationChannel(channelId: String!): NotificationChannel!

Returns the notification channel settings for a given channel id.

The channel must belong to your package, or to a package you are an approved notification delegate for (see canNotifyAsPackage(java.lang.String)), or it will not be returned. To query a channel as a notification delegate, call this method from a context created for that package (see Context.createPackageContext(String, int)).

getNotificationChannel

Added in API level 30
open fun getNotificationChannel(
    channelId: String,
    conversationId: String
): NotificationChannel?

Returns the notification channel settings for a given channel and conversation id.

The channel must belong to your package, or to a package you are an approved notification delegate for (see canNotifyAsPackage(java.lang.String)), or it will not be returned. To query a channel as a notification delegate, call this method from a context created for that package (see Context.createPackageContext(String, int)).

Parameters
channelId String: This value cannot be null.
conversationId String: This value cannot be null.
Return
NotificationChannel? This value may be null.

getNotificationChannelGroup

Added in API level 28
open fun getNotificationChannelGroup(channelGroupId: String!): NotificationChannelGroup!

Returns the notification channel group settings for a given channel group id. The channel group must belong to your package, or null will be returned.

getNotificationChannelGroups

Added in API level 26
open fun getNotificationChannelGroups(): MutableList<NotificationChannelGroup!>!

Returns all notification channel groups belonging to the calling app.

getNotificationChannels

Added in API level 26
open fun getNotificationChannels(): MutableList<NotificationChannel!>!

Returns all notification channels belonging to the calling package.

Approved notification delegates (see canNotifyAsPackage(java.lang.String)) can query notification channels belonging to packages they are the delegate for. To do so, call this method from a context created for that package (see Context.createPackageContext(String, int)).

getNotificationDelegate

Added in API level 29
open fun getNotificationDelegate(): String?

Returns the delegate that can post notifications on your behalf, if there currently is one.

Return
String? This value may be null.

getNotificationPolicy

Added in API level 23
open fun getNotificationPolicy(): NotificationManager.Policy!

Gets the current user-specified default notification policy.

For apps targeting Build.VERSION_CODES.VANILLA_ICE_CREAM and above (with some exceptions, such as companion device managers) this method will return the policy associated to their implicit AutomaticZenRule instead, if it exists. See setNotificationPolicy(android.app.NotificationManager.Policy).

isNotificationListenerAccessGranted

Added in API level 27
open fun isNotificationListenerAccessGranted(listener: ComponentName!): Boolean

Checks whether the user has approved a given android.service.notification.NotificationListenerService.

The listener service must belong to the calling app.

Apps can request notification listener access by sending the user to the activity that matches the system intent action android.provider.Settings#ACTION_NOTIFICATION_LISTENER_SETTINGS.

isNotificationPolicyAccessGranted

Added in API level 23
open fun isNotificationPolicyAccessGranted(): Boolean

Checks the ability to modify Notification Policy for the calling package.

Returns true if the calling package can modify notification policy.

Apps can request policy access by sending the user to the activity that matches the system intent action android.provider.Settings#ACTION_NOTIFICATION_POLICY_ACCESS_SETTINGS.

Use ACTION_NOTIFICATION_POLICY_ACCESS_GRANTED_CHANGED to listen for user grant or denial of this access.

matchesCallFilter

Added in API level 33
open fun matchesCallFilter(uri: Uri): Boolean

Returns whether a call from the provided URI is permitted to notify the user.

A true return value indicates one of the following: Do Not Disturb is not currently active; or the caller is a repeat caller and the current policy allows interruptions from repeat callers; or the caller is in the user's set of contacts whose calls are allowed to interrupt Do Not Disturb.

If Do Not Disturb is enabled and either no interruptions or only alarms are allowed, this method will return false regardless of input.

The provided URI should be a tel: or mailto: schema URI indicating the source of the call. For an accurate answer regarding whether the caller matches the user's permitted contacts, the path part of the URI must match an entry the Contacts database in the appropriate column.

Passing in a android.provider.ContactsContract.Contacts#CONTENT_LOOKUP_URI is also permissible, but should only be used for priority contact interruptions and may not provide accurate results in the case of repeat callers.

See also Person.Builder.setUri and android.provider.ContactsContract.Contacts#CONTENT_LOOKUP_URI for more information.

Callers of this method must have notification listener access, permission to read contacts, or have system permissions.

NOTE: This method calls into Contacts, which may take some time, and should not be called on the main thread.


This method may take several seconds to complete, so it should only be called from a worker thread.
Parameters
uri Uri: A URI representing a caller. Must not be null.
Return
Boolean A boolean indicating whether a call from the URI provided would be allowed to interrupt the user given the current filter.

notify

Added in API level 1
open fun notify(
    id: Int,
    notification: Notification!
): Unit

Post a notification to be shown in the status bar. If a notification with the same id has already been posted by your application and has not yet been canceled, it will be replaced by the updated information.

Parameters
id Int: An identifier for this notification unique within your application.
notification Notification!: A Notification object describing what to show the user. Must not be null.

notify

Added in API level 5
open fun notify(
    tag: String!,
    id: Int,
    notification: Notification!
): Unit

Posts a notification to be shown in the status bar. If a notification with the same tag and id has already been posted by your application and has not yet been canceled, it will be replaced by the updated information. All listener services will be granted Intent.FLAG_GRANT_READ_URI_PERMISSION access to any uris provided on this notification or the NotificationChannel this notification is posted to using Context.grantUriPermission(String, Uri, int). Permission will be revoked when the notification is canceled, or you can revoke permissions with Context.revokeUriPermission(Uri, int).

Parameters
tag String!: A string identifier for this notification. May be null.
id Int: An identifier for this notification. The pair (tag, id) must be unique within your application.
notification Notification!: A Notification object describing what to show the user. Must not be null.

notifyAsPackage

Added in API level 29
open fun notifyAsPackage(
    targetPackage: String,
    tag: String?,
    id: Int,
    notification: Notification
): Unit

Posts a notification as a specified package to be shown in the status bar. If a notification with the same tag and id has already been posted for that package and has not yet been canceled, it will be replaced by the updated information. All listener services will be granted Intent.FLAG_GRANT_READ_URI_PERMISSION access to any uris provided on this notification or the NotificationChannel this notification is posted to using Context.grantUriPermission(String, Uri, int). Permission will be revoked when the notification is canceled, or you can revoke permissions with Context.revokeUriPermission(Uri, int).

Parameters
targetPackage String: The package to post the notification as. The package must have granted you access to post notifications on their behalf with setNotificationDelegate(java.lang.String). This value cannot be null.
tag String?: A string identifier for this notification. May be null.
id Int: An identifier for this notification. The pair (tag, id) must be unique within your application.
notification Notification: A Notification object describing what to show the user. Must not be null.

removeAutomaticZenRule

Added in API level 24
open fun removeAutomaticZenRule(id: String!): Boolean

Deletes the automatic zen rule with the given id.

Throws a SecurityException if policy access is not granted to this package. See isNotificationPolicyAccessGranted.

Callers can only delete rules that they own. See AutomaticZenRule.getOwner.

Parameters
id String!: the id of the rule to delete.
Return
Boolean Whether the rule was successfully deleted.

setAutomaticZenRuleState

Added in API level 29
open fun setAutomaticZenRuleState(
    id: String,
    condition: Condition
): Unit

Informs the notification manager that the state of an AutomaticZenRule has changed. Use this method to put the system into Do Not Disturb mode or request that it exits Do Not Disturb mode. The calling app must own the provided android.app.AutomaticZenRule.

This method can be used in conjunction with or as a replacement to android.service.notification.ConditionProviderService#notifyCondition(Condition).

The condition change may be ignored if the user has activated or deactivated the rule manually -- the user can "override" the rule this time, with the rule resuming its normal operation for the next cycle. When this has happened, the supplied condition will be applied only once the automatic state is in agreement with the user-provided state. For example, assume that the AutomaticZenRule corresponds to a "Driving Mode" with automatic driving detection.

  1. App detects driving and notifies the system that the rule should be active, calling this method with a Condition with Condition.STATE_TRUE).
  2. User deactivates ("snoozes") the rule for some reason. This overrides the app-provided condition state.
  3. App is still detecting driving, so again calls with Condition.STATE_TRUE. This is ignored by the system, as the user override prevails.
  4. Some time later, the app detects that driving stopped, so the rule should be inactive, and calls with Condition.STATE_FALSE). This doesn't change the actual rule state (it was already inactive due to the user's override), but clears the override.
  5. Some time later, the app detects that driving has started again, and notifies that the rule should be active (calling with Condition.STATE_TRUE again). The rule is activated.

Note that the behavior at step #3 is different if the app also specifies Condition.SOURCE_USER_ACTION as the Condition.source -- rule state updates coming from user actions are not ignored.

Parameters
id String: The id of the rule whose state should change This value cannot be null.
condition Condition: The new state of this rule This value cannot be null.

setInterruptionFilter

Added in API level 23
fun setInterruptionFilter(interruptionFilter: Int): Unit

Sets the current notification interruption filter.

The interruption filter defines which notifications are allowed to interrupt the user (e.g. via sound & vibration) and is applied globally.

Apps targeting Build.VERSION_CODES.VANILLA_ICE_CREAM and above (with some exceptions, such as companion device managers) cannot modify the global interruption filter. Calling this method will instead activate or deactivate an AutomaticZenRule associated to the app, using a ZenPolicy that corresponds to the Policy supplied to setNotificationPolicy(android.app.NotificationManager.Policy) (or the global policy when one wasn't provided).

Only available if policy access is granted to this package. See isNotificationPolicyAccessGranted.

Parameters
interruptionFilter Int: Value is android.app.NotificationManager#INTERRUPTION_FILTER_NONE, android.app.NotificationManager#INTERRUPTION_FILTER_PRIORITY, android.app.NotificationManager#INTERRUPTION_FILTER_ALARMS, android.app.NotificationManager#INTERRUPTION_FILTER_ALL, or android.app.NotificationManager#INTERRUPTION_FILTER_UNKNOWN

setNotificationDelegate

Added in API level 29
open fun setNotificationDelegate(delegate: String?): Unit

Allows a package to post notifications on your behalf using notifyAsPackage(java.lang.String,java.lang.String,int,android.app.Notification). This can be used to allow persistent processes to post notifications based on messages received on your behalf from the cloud, without your process having to wake up. You can check if you have an allowed delegate with getNotificationDelegate() and revoke your delegate by passing null to this method.

Parameters
delegate String?: Package name of the app which can send notifications on your behalf. This value may be null.

setNotificationPolicy

Added in API level 23
open fun setNotificationPolicy(policy: NotificationManager.Policy): Unit

Sets the current notification policy (which applies when setInterruptionFilter is called with the INTERRUPTION_FILTER_PRIORITY value).

Apps targeting Build.VERSION_CODES.VANILLA_ICE_CREAM and above (with some exceptions, such as companion device managers) cannot modify the global notification policy. Calling this method will instead create or update an AutomaticZenRule associated to the app, using a ZenPolicy corresponding to the Policy supplied here, and which will be activated/deactivated by calls to setInterruptionFilter(int).

Only available if policy access is granted to this package. See isNotificationPolicyAccessGranted.

Parameters
policy NotificationManager.Policy: The new desired policy. This value cannot be null.

shouldHideSilentStatusBarIcons

Added in API level 29
open fun shouldHideSilentStatusBarIcons(): Boolean

Returns whether the user wants silent notifications (see IMPORTANCE_LOW to appear in the status bar.

Only available for notification.

updateAutomaticZenRule

Added in API level 24
open fun updateAutomaticZenRule(
    id: String!,
    automaticZenRule: AutomaticZenRule!
): Boolean

Updates the given zen rule.

Before Build.VERSION_CODES.VANILLA_ICE_CREAM, updating a rule that is not backed up by a android.service.notification.ConditionProviderService will deactivate it if it was previously active. Starting with Build.VERSION_CODES.VANILLA_ICE_CREAM, this will only happen if the rule's definition is actually changing.

Throws a SecurityException if policy access is not granted to this package. See isNotificationPolicyAccessGranted.

Callers can only update rules that they own. See AutomaticZenRule.getOwner.

Parameters
id String!: The id of the rule to update
automaticZenRule AutomaticZenRule!: the rule to update.
Return
Boolean Whether the rule was successfully updated.