Utilisez un badge pour afficher un petit élément visuel afin d'indiquer l'état ou une valeur numérique sur un autre composable. Voici quelques scénarios courants dans lesquels vous pouvez utiliser un badge:
- Notifications: affichez le nombre de notifications non lues sur une icône d'application ou une cloche de notification.
- Messages: indique les messages nouveaux ou non lus dans une application de chat.
- Informations sur l'état: indique l'état d'une tâche, par exemple "Terminée", "En cours" ou "Échec".
- Quantité panier: indique le nombre d'articles dans le panier d'un utilisateur.
- Nouveaux contenus: mettez en avant les nouveaux contenus ou fonctionnalités disponibles pour l'utilisateur.
Surface de l'API
Utilisez le composable BadgedBox
pour implémenter des badges dans votre application. Il s'agit en fin de compte d'un conteneur. Vous pouvez contrôler son apparence à l'aide des deux paramètres principaux suivants:
content
: contenu composable contenu dansBadgedBox
. Habituellement,Icon
.badge
: composable qui apparaît en tant que badge sur le contenu. Il s'agit généralement du composableBadge
dédié.
Exemple de base
Cet extrait de code présente une implémentation de base de BadgedBox
:
@Composable fun BadgeExample() { BadgedBox( badge = { Badge() } ) { Icon( imageVector = Icons.Filled.Mail, contentDescription = "Email" ) } }
Cet exemple affiche un badge qui chevauche le composable Icon
fourni. Notez les points suivants dans le code:
BadgedBox
sert de conteneur global.- L'argument du paramètre
badge
deBadgedBox
estBadge
. Étant donné queBadge
ne possède pas d'arguments propres, l'application affiche le badge par défaut, qui est un petit cercle rouge. Icon
sert d'argument pour le paramètrecontent
deBadgedBox
. Il s'agit de l'icône sur laquelle le badge s'affiche. Dans ce cas, il s'agit d'une icône de messagerie.
Voici comment cela se présente:
Exemple détaillé
L'extrait de code suivant montre comment afficher des valeurs dans le badge qui répondent aux actions des utilisateurs.
@Composable fun BadgeInteractiveExample() { var itemCount by remember { mutableStateOf(0) } Column( verticalArrangement = Arrangement.spacedBy(16.dp) ) { BadgedBox( badge = { if (itemCount > 0) { Badge( containerColor = Color.Red, contentColor = Color.White ) { Text("$itemCount") } } } ) { Icon( imageVector = Icons.Filled.ShoppingCart, contentDescription = "Shopping cart", ) } Button(onClick = { itemCount++ }) { Text("Add item") } } }
Cet exemple implémente une icône de panier avec un badge qui affiche le nombre d'articles dans le panier de l'utilisateur.
- Le
BadgedBox
ne s'affiche que lorsque le nombre d'éléments est supérieur à 0. - Les arguments de
containerColor
etcontentColor
contrôlent l'apparence du badge. - Le composable
Text
pour l'emplacement de contenu deBadge
apparaît dans le badge. Dans ce cas, il affiche le nombre d'articles dans le panier.
Cette implémentation est la suivante :