Badges

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é du panier: affiche 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.
Autre exemple du composant badge.
Figure 1. Exemples de badges

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 de ces deux paramètres principaux:

  • content: contenu modulable contenu dans BadgedBox. Habituellement, Icon.
  • badge: composable qui s'affiche sous forme de badge au-dessus du contenu. Il s'agit généralement du composable Badge 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 de BadgedBox est Badge. Étant donné que Badge 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ètre content de BadgedBox. 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 à quoi il ressemble:

Badge simple ne contenant aucun contenu.
Figure 2. Implémentation minimale du badge.

Exemple détaillé

L'extrait de code suivant montre comment afficher des valeurs dans le badge qui répondent aux actions de l'utilisateur.

@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 et contentColor contrôlent l'apparence du badge.
  • Le composable Text pour l'emplacement de contenu de Badge apparaît dans le badge. Dans ce cas, il affiche le nombre d'articles dans le panier.

Cette implémentation est la suivante :

Implémentation d'un badge contenant le nombre d'articles dans un panier.
Figure 3. Badge indiquant le nombre d'articles dans un panier.

Ressources supplémentaires