Builder
class Builder
kotlin.Any | |
↳ | androidx.core.app.NotificationCompat.BubbleMetadata.Builder |
Builder to construct a BubbleMetadata
object.
Summary
Public constructors | |
---|---|
<init>() |
|
Creates a |
|
<init>(@NonNull intent: PendingIntent, @NonNull icon: IconCompat) Creates a |
Public methods | |
---|---|
NotificationCompat.BubbleMetadata |
build() Creates the |
NotificationCompat.BubbleMetadata.Builder |
setAutoExpandBubble(shouldExpand: Boolean) If set and the app creating the bubble is in the foreground, the bubble will be posted in its expanded state, with the contents of |
NotificationCompat.BubbleMetadata.Builder |
setDeleteIntent(@Nullable deleteIntent: PendingIntent?) Sets an optional intent to send when this bubble is explicitly removed by the user. |
NotificationCompat.BubbleMetadata.Builder |
setDesiredHeight(@Dimension(0) height: Int) Sets the desired height in DPs for the app content defined by |
NotificationCompat.BubbleMetadata.Builder |
setDesiredHeightResId(@DimenRes heightResId: Int) Sets the desired height via resId for the app content defined by |
NotificationCompat.BubbleMetadata.Builder |
setIcon(@NonNull icon: IconCompat) Sets the icon for the bubble. |
NotificationCompat.BubbleMetadata.Builder |
setIntent(@NonNull intent: PendingIntent) Sets the intent that will be used when the bubble is expanded. |
NotificationCompat.BubbleMetadata.Builder |
setSuppressNotification(shouldSuppressNotif: Boolean) If set and the app posting the bubble is in the foreground, the bubble will be posted without the associated notification in the notification shade. |
Public constructors
<init>
Builder()
Deprecated: use Builder(String)
for a bubble created via a ShortcutInfoCompat
or Builder(PendingIntent, IconCompat)
for a bubble created via a PendingIntent
.
<init>
Builder(@NonNull shortcutId: String)
Creates a BubbleMetadata.Builder
based on a ShortcutInfoCompat
. To create a shortcut bubble, ensure that the shortcut associated with the provided {@param shortcutId} is published as a dynamic shortcut that was built with ShortcutInfoCompat.Builder#setLongLived(boolean)
being true, otherwise your notification will not be able to bubble.
The shortcut icon will be used to represent the bubble when it is collapsed.
The shortcut activity will be used when the bubble is expanded. This will display the shortcut activity in a floating window over the existing foreground activity.
If the shortcut has not been published when the bubble notification is sent, no bubble will be produced. If the shortcut is deleted while the bubble is active, the bubble will be removed.
Exceptions | |
---|---|
NullPointerException |
if shortcutId is null. |
<init>
Builder(
@NonNull intent: PendingIntent,
@NonNull icon: IconCompat)
Creates a BubbleMetadata.Builder
based on the provided intent and icon.
The icon will be used to represent the bubble when it is collapsed. An icon should be representative of the content within the bubble. If your app produces multiple bubbles, the icon should be unique for each of them.
The intent that will be used when the bubble is expanded. This will display the app content in a floating window over the existing foreground activity. The intent should point to a resizable activity.
Exceptions | |
---|---|
NullPointerException |
if icon is null. |
Public methods
build
@NonNull fun build(): NotificationCompat.BubbleMetadata
Creates the BubbleMetadata
defined by this builder.
Will throw NullPointerException
if required fields have not been set on this builder.
setAutoExpandBubble
@NonNull fun setAutoExpandBubble(shouldExpand: Boolean): NotificationCompat.BubbleMetadata.Builder
If set and the app creating the bubble is in the foreground, the bubble will be posted in its expanded state, with the contents of getIntent()
in a floating window.
If the app creating the bubble is not in the foreground this flag has no effect.
Generally this flag should only be set if the user has performed an action to request or create a bubble.
setDeleteIntent
@NonNull fun setDeleteIntent(@Nullable deleteIntent: PendingIntent?): NotificationCompat.BubbleMetadata.Builder
Sets an optional intent to send when this bubble is explicitly removed by the user.
setDesiredHeight
@NonNull fun setDesiredHeight(@Dimension(0) height: Int): NotificationCompat.BubbleMetadata.Builder
Sets the desired height in DPs for the app content defined by setIntent(PendingIntent)
, this height may not be respected if there is not enough space on the screen or if the provided height is too small to be useful.
If setDesiredHeightResId(int)
was previously called on this builder, the previous value set will be cleared after calling this method, and this value will be used instead.
setDesiredHeightResId
@NonNull fun setDesiredHeightResId(@DimenRes heightResId: Int): NotificationCompat.BubbleMetadata.Builder
Sets the desired height via resId for the app content defined by setIntent(PendingIntent)
, this height may not be respected if there is not enough space on the screen or if the provided height is too small to be useful.
If setDesiredHeight(int)
was previously called on this builder, the previous value set will be cleared after calling this method, and this value will be used instead.
setIcon
@NonNull fun setIcon(@NonNull icon: IconCompat): NotificationCompat.BubbleMetadata.Builder
Sets the icon for the bubble. Can only be used if the bubble was created via Builder(PendingIntent, IconCompat)
.
The icon will be used to represent the bubble when it is collapsed. An icon should be representative of the content within the bubble. If your app produces multiple bubbles, the icon should be unique for each of them.
It is recommended to use an Icon
of type Icon#TYPE_URI
or Icon#TYPE_URI_ADAPTIVE_BITMAP
Exceptions | |
---|---|
NullPointerException |
if icon is null. |
IllegalStateException |
if this builder was created via Builder(String) . |
setIntent
@NonNull fun setIntent(@NonNull intent: PendingIntent): NotificationCompat.BubbleMetadata.Builder
Sets the intent that will be used when the bubble is expanded. This will display the app content in a floating window over the existing foreground activity.
Exceptions | |
---|---|
NullPointerException |
if intent is null. |
IllegalStateException |
if this builder was created via Builder(String) . |
setSuppressNotification
@NonNull fun setSuppressNotification(shouldSuppressNotif: Boolean): NotificationCompat.BubbleMetadata.Builder
If set and the app posting the bubble is in the foreground, the bubble will be posted without the associated notification in the notification shade.
If the app posting the bubble is not in the foreground this flag has no effect.
Generally this flag should only be set if the user has performed an action to request or create a bubble, or if the user has seen the content in the notification and the notification is no longer relevant.