Komponent Chip
to kompaktowy, interaktywny element interfejsu. Reprezentują one złożone elementy, takie jak kontakty lub tagi, często z ikoną i etykietą. Można zaznaczyć, zamknąć lub kliknąć.
Oto 4 rodzaje komponentów i miejsca, w których możesz ich używać:
- Pomoc: prowadzi użytkownika podczas wykonywania zadania. Często pojawia się jako tymczasowy element interfejsu w odpowiedzi na dane wejściowe użytkownika.
- Filtrowanie: umożliwia użytkownikom zawężanie treści z wybranych opcji. Można je zaznaczać i odznaczać. Po zaznaczeniu mogą zawierać ikonę znacznika wyboru.
- Wejście: reprezentuje informacje podawane przez użytkownika, takie jak wybory w menu. Mogą zawierać ikonę i tekst oraz znak „X” oznaczający usunięcie.
- Sugestia: wyświetla użytkownikowi rekomendacje na podstawie jego ostatniej aktywności lub danych wejściowych. Zwykle wyświetlają się pod polem do wprowadzania danych, by zachęcić użytkownika do działania.
Interfejs API
Istnieją 4 komponenty odpowiadające 4 typom komponentów. W kolejnych sekcjach znajdziesz szczegółowe omówienie tych funkcji kompozycyjnych i różnic między nimi. Mają jednak wspólne te parametry:
label
: ciąg znaków widoczny na elemencie.icon
: ikona wyświetlana na początku elementu. Niektóre z tych komponentów mają oddzielne parametryleadingIcon
itrailingIcon
.onClick
: funkcja Lambda wywoływana przez element, gdy użytkownik go naciśnie.
Element pomocy
Komponent AssistChip
to prosty sposób na tworzenie elementów pomocy, które kierują użytkownika w określonym kierunku. Jedną z takich funkcji jest parametr leadingIcon
, który umożliwia wyświetlanie ikony po lewej stronie elementu. Ten przykład pokazuje, jak to zrobić:
@Composable fun AssistChipExample() { AssistChip( onClick = { Log.d("Assist chip", "hello world") }, label = { Text("Assist chip") }, leadingIcon = { Icon( Icons.Filled.Settings, contentDescription = "Localized description", Modifier.size(AssistChipDefaults.IconSize) ) } ) }
Implementacja wygląda tak.
Ikona filtra
Komponent FilterChip
wymaga śledzenia, czy element jest wybrany. W tym przykładzie pokazujemy, jak wyświetlić ikonę zaznaczonego elementu tylko wtedy, gdy użytkownik go wybierze:
@Composable fun FilterChipExample() { var selected by remember { mutableStateOf(false) } FilterChip( onClick = { selected = !selected }, label = { Text("Filter chip") }, selected = selected, leadingIcon = if (selected) { { Icon( imageVector = Icons.Filled.Done, contentDescription = "Done icon", modifier = Modifier.size(FilterChipDefaults.IconSize) ) } } else { null }, ) }
Gdy ta implementacja nie jest zaznaczona, implementacja wygląda tak:
Po wybraniu wyświetla się tak:
Element wprowadzania tekstu
Możesz użyć komponentu InputChip
, aby tworzyć elementy, które są wynikiem interakcji z użytkownikiem. Na przykład w kliencie poczty, gdy użytkownik pisze e-maila, element wejściowy może reprezentować osobę, której adres został wpisany w polu „do:”.
Poniższa implementacja prezentuje element wejściowy, który jest już w wybranym stanie. Użytkownik odrzuca element, gdy go naciśnie.
@Composable fun InputChipExample( text: String, onDismiss: () -> Unit, ) { var enabled by remember { mutableStateOf(true) } if (!enabled) return InputChip( onClick = { onDismiss() enabled = !enabled }, label = { Text(text) }, selected = enabled, avatar = { Icon( Icons.Filled.Person, contentDescription = "Localized description", Modifier.size(InputChipDefaults.AvatarSize) ) }, trailingIcon = { Icon( Icons.Default.Close, contentDescription = "Localized description", Modifier.size(InputChipDefaults.AvatarSize) ) }, ) }
Ta implementacja wygląda tak.
Element z sugestią
Element kompozycyjny SuggestionChip
to najbardziej podstawowy z elementów kompozycyjnych wymienionych na tej stronie, zarówno w definicji interfejsu API, jak i typowych przypadkach użycia. Elementy sugerujące zawierają dynamicznie generowane wskazówki. Na przykład w aplikacji do czatu AI możesz użyć elementów z sugestią, aby przedstawić możliwe odpowiedzi na najnowszą wiadomość.
Rozważ implementację SuggestionChip
:
@Composable fun SuggestionChipExample() { SuggestionChip( onClick = { Log.d("Suggestion chip", "hello world") }, label = { Text("Suggestion chip") } ) }
Ta implementacja wygląda tak:
Element
Wszystkie przykłady w tym dokumencie korzystają z podstawowych elementów kompozycyjnych, które mają płaski wygląd. Jeśli chcesz użyć elementu, który ma podwyższoną pozycję, użyj jednego z tych 3 komponentów: