Panel aplikasi adalah penampung yang memberi pengguna akses ke fitur utama dan item navigasi. Ada dua jenis panel aplikasi, yaitu panel aplikasi atas dan panel aplikasi bawah. Tampilan dan tujuannya masing-masing adalah sebagai berikut:
Jenis |
Tampilan |
Tujuan |
|---|---|---|
Panel aplikasi atas |
Di bagian atas layar. |
Memberikan akses ke tugas dan informasi utama. Biasanya menghosting judul, item tindakan inti, dan item navigasi tertentu. |
Panel aplikasi bawah |
Di bagian bawah layar. |
Biasanya menyertakan item navigasi inti. Mungkin juga memberikan akses ke tindakan utama lainnya, seperti melalui tombol tindakan mengambang yang disertakan. |
Untuk menerapkan panel aplikasi atas dan panel aplikasi bawah, gunakan composable TopAppBar dan
BottomAppBar. Composable ini memungkinkan Anda membuat antarmuka yang konsisten yang merangkum kontrol navigasi dan tindakan, serta selaras dengan prinsip Desain Material.
Panel aplikasi atas
Tabel berikut menguraikan empat jenis panel aplikasi atas:
Jenis |
Contoh |
|---|---|
Kecil: Untuk layar yang tidak memerlukan banyak navigasi atau tindakan. |
|
Rata tengah: Untuk layar yang memiliki satu tindakan utama. |
|
Sedang: Untuk layar yang memerlukan navigasi dan tindakan dalam jumlah sedang. |
|
Besar: Untuk layar yang memerlukan banyak navigasi dan tindakan. |
|
Permukaan API
Berbagai composable yang memungkinkan Anda menerapkan empat panel aplikasi atas yang berbeda cukup mirip. Composable ini memiliki beberapa parameter utama yang sama:
title: Teks yang muncul di seluruh panel aplikasi.navigationIcon: Ikon utama untuk navigasi. Muncul di sebelah kiri panel aplikasi.actions: Ikon yang memberi pengguna akses ke tindakan utama. Ikon ini muncul di sebelah kanan panel aplikasi.scrollBehavior: Menentukan cara panel aplikasi atas merespons scrolling konten dalam scaffold.colors: Menentukan tampilan panel aplikasi.
Perilaku scroll
Anda dapat mengontrol cara panel aplikasi merespons saat pengguna men-scroll konten dalam scaffold yang diberikan. Untuk melakukannya, buat instance
TopAppBarScrollBehavior dan teruskan ke panel aplikasi atas untuk parameter
scrollBehavior.
Ada tiga jenis TopAppBarScrollBehavior. Jenisnya adalah sebagai berikut:
enterAlwaysScrollBehavior: Saat pengguna menarik konten dalam scaffold, panel aplikasi atas akan diciutkan. Panel aplikasi akan diperluas saat pengguna mulai menarik konten dalam ke bawah.exitUntilCollapsedScrollBehavior: Mirip denganenterAlwaysScrollBehavior, meskipun panel aplikasi hanya diperluas saat pengguna menarik konten ke bawah.pinnedScrollBehavior: Panel aplikasi tetap berada di tempatnya dan tidak bereaksi terhadap scrolling.
Contoh berikut menerapkan beberapa opsi ini.
Contoh
Bagian berikut memberikan implementasi untuk empat jenis panel aplikasi atas yang berbeda, termasuk berbagai contoh cara mengontrol perilaku scroll.
Kecil
Untuk membuat panel aplikasi atas kecil, gunakan TopAppBar composable. Contoh berikut menerapkan panel aplikasi atas dasar yang hanya berisi judul.
Contoh berikut tidak meneruskan nilai untuk scrollBehavior ke TopAppBar, sehingga tidak bereaksi terhadap scrolling konten dalam.
@Composable fun SmallTopAppBarExample() { Scaffold( topBar = { TopAppBar( colors = TopAppBarDefaults.topAppBarColors( containerColor = MaterialTheme.colorScheme.primaryContainer, titleContentColor = MaterialTheme.colorScheme.primary, ), title = { Text("Small Top App Bar") } ) }, ) { innerPadding -> ScrollContent(innerPadding) } }
Implementasi ini muncul sebagai berikut:
Rata tengah
Panel aplikasi atas yang rata tengah pada dasarnya sama dengan panel aplikasi kecil, meskipun judulnya berada di tengah dalam komponen. Untuk menerapkannya, gunakan
composable CenterAlignedTopAppBar khusus.
Contoh ini menggunakan enterAlwaysScrollBehavior() untuk mendapatkan nilai yang diteruskan untuk scrollBehavior. Dengan demikian, panel akan diciutkan saat pengguna men-scroll konten dalam scaffold.
@Composable fun CenterAlignedTopAppBarExample() { val scrollBehavior = TopAppBarDefaults.pinnedScrollBehavior(rememberTopAppBarState()) Scaffold( modifier = Modifier.nestedScroll(scrollBehavior.nestedScrollConnection), topBar = { CenterAlignedTopAppBar( colors = TopAppBarDefaults.topAppBarColors( containerColor = MaterialTheme.colorScheme.primaryContainer, titleContentColor = MaterialTheme.colorScheme.primary, ), title = { Text( "Centered Top App Bar", maxLines = 1, overflow = TextOverflow.Ellipsis ) }, navigationIcon = { IconButton(onClick = { /* do something */ }) { Icon( imageVector = Icons.AutoMirrored.Filled.ArrowBack, contentDescription = "Localized description" ) } }, actions = { IconButton(onClick = { /* do something */ }) { Icon( imageVector = Icons.Filled.Menu, contentDescription = "Localized description" ) } }, scrollBehavior = scrollBehavior, ) }, ) { innerPadding -> ScrollContent(innerPadding) } }
Implementasi ini muncul sebagai berikut:
Sedang
Panel aplikasi atas sedang menempatkan judul di bawah ikon tambahan. Untuk membuat
satu, gunakan MediumTopAppBar composable.
Seperti cuplikan sebelumnya, contoh ini menggunakan enterAlwaysScrollBehavior() untuk mendapatkan nilai yang diteruskan untuk scrollBehavior.
@Composable fun MediumTopAppBarExample() { val scrollBehavior = TopAppBarDefaults.enterAlwaysScrollBehavior(rememberTopAppBarState()) Scaffold( modifier = Modifier.nestedScroll(scrollBehavior.nestedScrollConnection), topBar = { MediumTopAppBar( colors = TopAppBarDefaults.topAppBarColors( containerColor = MaterialTheme.colorScheme.primaryContainer, titleContentColor = MaterialTheme.colorScheme.primary, ), title = { Text( "Medium Top App Bar", maxLines = 1, overflow = TextOverflow.Ellipsis ) }, navigationIcon = { IconButton(onClick = { /* do something */ }) { Icon( imageVector = Icons.AutoMirrored.Filled.ArrowBack, contentDescription = "Localized description" ) } }, actions = { IconButton(onClick = { /* do something */ }) { Icon( imageVector = Icons.Filled.Menu, contentDescription = "Localized description" ) } }, scrollBehavior = scrollBehavior ) }, ) { innerPadding -> ScrollContent(innerPadding) } }
Implementasi ini muncul sebagai berikut, dengan demonstrasi tampilan perilaku scroll dari enterAlwaysScrollBehavior():
Besar
Panel aplikasi atas besar mirip dengan panel aplikasi atas sedang, meskipun padding antara judul dan ikon lebih besar dan menempati lebih banyak ruang di layar secara keseluruhan. Untuk
membuatnya, gunakan LargeTopAppBar composable.
Tidak seperti cuplikan sebelumnya, contoh ini menggunakan exitUntilCollapsedScrollBehavior() untuk mendapatkan nilai yang diteruskan untuk scrollBehavior. Dengan demikian, panel akan diciutkan saat pengguna men-scroll konten dalam scaffold, tetapi kemudian diperluas saat pengguna men-scroll ke akhir konten dalam.
@Composable fun LargeTopAppBarExample() { val scrollBehavior = TopAppBarDefaults.exitUntilCollapsedScrollBehavior(rememberTopAppBarState()) Scaffold( modifier = Modifier.nestedScroll(scrollBehavior.nestedScrollConnection), topBar = { LargeTopAppBar( colors = TopAppBarDefaults.topAppBarColors( containerColor = MaterialTheme.colorScheme.primaryContainer, titleContentColor = MaterialTheme.colorScheme.primary, ), title = { Text( "Large Top App Bar", maxLines = 1, overflow = TextOverflow.Ellipsis ) }, navigationIcon = { IconButton(onClick = { /* do something */ }) { Icon( imageVector = Icons.AutoMirrored.Filled.ArrowBack, contentDescription = "Localized description" ) } }, actions = { IconButton(onClick = { /* do something */ }) { Icon( imageVector = Icons.Filled.Menu, contentDescription = "Localized description" ) } }, scrollBehavior = scrollBehavior ) }, ) { innerPadding -> ScrollContent(innerPadding) } }
Implementasi ini muncul sebagai berikut:
Panel aplikasi bawah
Untuk membuat panel aplikasi bawah, gunakan composable BottomAppBar. Menggunakan composable ini cukup mirip dengan composable panel aplikasi atas yang dijelaskan di bagian sebelumnya di halaman ini. Anda meneruskan composable untuk parameter utama berikut:
actions: Serangkaian ikon yang muncul di sisi kiri panel. Ikon ini biasanya merupakan tindakan utama untuk layar tertentu, atau item navigasi.floatingActionButton: Tombol tindakan mengambang yang muncul di sisi kanan panel.
@Composable fun BottomAppBarExample() { Scaffold( bottomBar = { BottomAppBar( actions = { IconButton(onClick = { /* do something */ }) { Icon(Icons.Filled.Check, contentDescription = "Localized description") } IconButton(onClick = { /* do something */ }) { Icon( Icons.Filled.Edit, contentDescription = "Localized description", ) } IconButton(onClick = { /* do something */ }) { Icon( Icons.Filled.Mic, contentDescription = "Localized description", ) } IconButton(onClick = { /* do something */ }) { Icon( Icons.Filled.Image, contentDescription = "Localized description", ) } }, floatingActionButton = { FloatingActionButton( onClick = { /* do something */ }, containerColor = BottomAppBarDefaults.bottomAppBarFabColor, elevation = FloatingActionButtonDefaults.bottomAppBarFabElevation() ) { Icon(Icons.Filled.Add, "Localized description") } } ) }, ) { innerPadding -> Text( modifier = Modifier.padding(innerPadding), text = "Example of a scaffold with a bottom app bar." ) } }
Implementasi ini muncul sebagai berikut: