Pływający przycisk polecenia (FAB) to wyróżniony przycisk, który umożliwia użytkownikowi wykonanie głównego działania w aplikacji. Promuje ono jedno konkretne działanie, które jest najczęstszą ścieżką użytkownika, i zazwyczaj znajduje się w prawym dolnym rogu ekranu.
Oto 3 przypadki użycia przycisku FAB:
- Utwórz nowy element: w aplikacji do robienia notatek możesz użyć przycisku FAB, by szybko utworzyć nową notatkę.
- Dodawanie nowego kontaktu: w aplikacji do obsługi czatu przycisk typu FAB może otworzyć interfejs, który pozwoli użytkownikowi dodać kogoś do rozmowy.
- Wyśrodkowanie lokalizacji: w interfejsie mapy przycisk FAB może wyśrodkować mapę na bieżącej lokalizacji użytkownika.
W stylu Material Design są 4 rodzaje przycisków PPP:
- Pływający przycisk polecenia: zwykły pływający przycisk polecenia.
- Mały przycisk typu FAB: mniejszy pływający przycisk polecenia.
- Duży pływający przycisk polecenia: większy pływający przycisk polecenia.
- Rozszerzony pływający przycisk polecenia: pływający przycisk polecenia, który zawiera więcej niż tylko ikonę.
Interfejs API
Chociaż do tworzenia pływających przycisków akcji zgodnych z Material Design możesz używać różnych komponentów, ich parametry nie różnią się znacząco. Oto najważniejsze parametry, o których należy pamiętać:
onClick
: funkcja wywoływana, gdy użytkownik naciśnie przycisk.containerColor
: kolor przycisku.contentColor
: kolor ikony.
Pływający przycisk polecenia
Aby utworzyć ogólny pływający przycisk działania, użyj podstawowego komponentu FloatingActionButton
. Ten przykład pokazuje podstawową implementację przycisku FAB:
@Composable fun Example(onClick: () -> Unit) { FloatingActionButton( onClick = { onClick() }, ) { Icon(Icons.Filled.Add, "Floating action button.") } }
Ta implementacja wygląda tak:
Mały przycisk
Aby utworzyć mały pływający przycisk polecenia, użyj funkcji kompozycyjnej SmallFloatingActionButton
. Przykład poniżej pokazuje, jak to zrobić, z dodatkiem kolorów niestandardowych.
@Composable fun SmallExample(onClick: () -> Unit) { SmallFloatingActionButton( onClick = { onClick() }, containerColor = MaterialTheme.colorScheme.secondaryContainer, contentColor = MaterialTheme.colorScheme.secondary ) { Icon(Icons.Filled.Add, "Small floating action button.") } }
Ta implementacja wygląda tak:
Duży przycisk
Aby utworzyć duży przycisk akcji pływającej, użyj komponentu LargeFloatingActionButton
. Ta kompozycja nie różni się znacząco od innych przykładów, z tym wyjątkiem, że ma większy przycisk.
Poniżej widać prostą implementację dużego przycisku PPP.
@Composable fun LargeExample(onClick: () -> Unit) { LargeFloatingActionButton( onClick = { onClick() }, shape = CircleShape, ) { Icon(Icons.Filled.Add, "Large floating action button") } }
Ta implementacja wygląda tak:
Przycisk rozszerzony
Za pomocą komponentu ExtendedFloatingActionButton
możesz tworzyć bardziej złożone przyciski działań. Główną różnicą między tymi parametrami a parametrem FloatingActionButton
jest to, że mają one dedykowane parametry icon
i text
. Umożliwiają one tworzenie bardziej złożonych przycisków, które dostosowują się do zawartości.
Ten fragment kodu pokazuje, jak zaimplementować parametr ExtendedFloatingActionButton
, podając przykładowe wartości parametrów icon
i text
.
@Composable fun ExtendedExample(onClick: () -> Unit) { ExtendedFloatingActionButton( onClick = { onClick() }, icon = { Icon(Icons.Filled.Edit, "Extended floating action button.") }, text = { Text(text = "Extended FAB") }, ) }
Implementacja wygląda tak: