Odznaki

Użyj plakietki, aby wyświetlić mały element wizualny oznaczający stan lub wartość liczbową w innej składance. Oto kilka typowych sytuacji, w których możesz użyć plakietki:

  • Powiadomienia: wyświetlanie liczby nieprzeczytanych powiadomień na ikonie aplikacji lub dzwonku powiadomień.
  • Wiadomości: wskazują nowe lub nieprzeczytane wiadomości w aplikacji do czatu.
  • Aktualizacje stanu: pokazuj stan zadania, np. „ukończone”, „w toku” lub „nieudane”.
  • Liczba produktów w koszyku: wyświetla liczbę produktów w koszyku użytkownika.
  • Nowe treści: wyróżnienie nowych treści lub funkcji dostępnych dla użytkownika.
Inny przykład komponentu plakietki.
Rysunek 1. Przykłady plakietek

Interfejs API

Aby wdrożyć plakietki w aplikacji, użyj funkcji kompozycyjnej BadgedBox. To ostatecznie kontener. Wygląd tego elementu możesz kontrolować za pomocą tych 2 głównych parametrów:

  • content: treści, które można łączyć, a które zawiera BadgedBox. Zwykle Icon.
  • badge: komponent, który pojawia się jako plakietka nad treścią. Zwykle jest to dedykowana funkcja kompozycyjna Badge.

Podstawowy przykład

Ten fragment kodu pokazuje podstawową implementację funkcji BadgedBox:

@Composable
fun BadgeExample() {
    BadgedBox(
        badge = {
            Badge()
        }
    ) {
        Icon(
            imageVector = Icons.Filled.Mail,
            contentDescription = "Email"
        )
    }
}

Ten przykład pokazuje plakietkę, która nakłada się na podany element kompozytowy Icon. Zwróć uwagę na te elementy kodu:

  • BadgedBox jest ogólnym kontenerem.
  • Argument parametru badge funkcji BadgedBox to Badge. Funkcja Badge nie ma własnych argumentów, więc aplikacja wyświetla domyślną plakietkę, czyli mały czerwony okrąg.
  • Icon jest argumentem parametru content w tabeli BadgedBox. To ikona, nad którą wyświetla się plakietka. W tym przypadku jest to ikona poczty.

Wygląda to tak:

Prosty znacznik bez treści.
Rysunek 2. Minimalna implementacja plakietki.

Szczegółowy przykład

Z tego fragmentu kodu dowiesz się, jak wyświetlać na plakietce wartości w odpowiedzi na działania użytkownika.

@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")
        }
    }
}

W tym przykładzie zastosowano ikonę koszyka z plakietką, która pokazuje liczbę produktów w koszyku użytkownika.

  • BadgedBox wyświetla się tylko wtedy, gdy liczba elementów przekracza 0.
  • Argumenty containerColor i contentColor określają wygląd plakietki.
  • Na plakietce wyświetla się kompozyt Text dla miejsca na treści Badge. W tym przypadku wyświetla liczbę produktów w koszyku.

Ta implementacja wygląda tak:

Implementacja plakietki, która zawiera liczbę produktów w koszyku.
Rysunek 3. Plakietka, która pokazuje liczbę produktów w koszyku.

Dodatkowe materiały