Usa una insignia para mostrar un pequeño elemento visual que denote el estado o un valor numérico en otro elemento componible. Estos son algunos casos comunes en los que podrías usar una insignia:
- Notificaciones: Muestra la cantidad de notificaciones no leídas en el ícono de una app o en la campana de notificaciones.
- Mensajes: Indica mensajes nuevos o no leídos en una aplicación de chat.
- Actualizaciones de estado: Muestran el estado de una tarea, como “completa”, “en curso” o “con errores”.
- Cantidad del carrito: Muestra la cantidad de artículos en el carrito de compras de un usuario.
- Contenido nuevo: Destaca el contenido nuevo o las funciones disponibles para el usuario.
Plataforma de API
Usa el elemento componible BadgedBox
para implementar insignias en tu aplicación. En última instancia, es un contenedor. Controlas su apariencia con estos dos parámetros principales:
content
: Es el contenido componible que contieneBadgedBox
. Por lo general, esIcon
.badge
: Es el elemento componible que aparece como la insignia sobre el contenido. Por lo general, el elemento componibleBadge
dedicado.
Ejemplo básico
En este fragmento de código, se muestra una implementación básica de BadgedBox
:
@Composable fun BadgeExample() { BadgedBox( badge = { Badge() } ) { Icon( imageVector = Icons.Filled.Mail, contentDescription = "Email" ) } }
En este ejemplo, se muestra una insignia que se superpone con el elemento Icon
componible proporcionado. Ten en cuenta lo siguiente en el código:
BadgedBox
funciona como el contenedor general.- El argumento del parámetro
badge
deBadgedBox
esBadge
. ComoBadge
no tiene argumentos propios, la app muestra la insignia predeterminada, que es un pequeño círculo rojo. Icon
sirve como argumento del parámetrocontent
deBadgedBox
. Es el ícono sobre el que aparece la insignia. En este caso, es un ícono de correo electrónico.
Así es como se ve:
Ejemplo detallado
En el siguiente fragmento, se muestra cómo puedes mostrar valores en la insignia que respondan a las acciones del usuario.
@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") } } }
En este ejemplo, se implementa un ícono de carrito de compras con una insignia que muestra la cantidad de artículos en el carrito del usuario.
- El
BadgedBox
se muestra solo cuando el recuento de elementos es superior a 0. - Los argumentos de
containerColor
ycontentColor
controlan el aspecto de la insignia. - El elemento
Text
componible para el espacio de contenido deBadge
aparece dentro de la insignia. En este caso, muestra la cantidad de artículos en el carrito.
Esta implementación aparece de la siguiente manera: