Setelah Aktivitas mengambil kendali untuk menangani semua inset, Anda dapat menggunakan API Compose untuk memastikan konten tidak dikaburkan dan elemen yang dapat berinteraksi tidak tumpang-tindih dengan UI sistem. API ini juga menyinkronkan tata letak aplikasi Anda dengan perubahan inset.
Misalnya, ini adalah metode paling dasar untuk menerapkan inset ke konten seluruh aplikasi Anda:
override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) enableEdgeToEdge() setContent { Box(Modifier.safeDrawingPadding()) { // the rest of the app } } }
Cuplikan ini menerapkan inset jendela safeDrawing
sebagai padding di sekitar
seluruh konten aplikasi. Meskipun hal ini memastikan bahwa elemen yang dapat berinteraksi tidak
tumpang-tindih dengan UI sistem, hal ini juga berarti bahwa tidak ada aplikasi yang akan menggambar di belakang
UI sistem untuk mencapai efek dari tepi ke tepi. Untuk memanfaatkan seluruh
jendela sepenuhnya, Anda perlu menyesuaikan tempat inset diterapkan berdasarkan layar
atau komponen.
Semua jenis inset ini dianimasikan secara otomatis dengan animasi IME yang di-backport ke API 21. Secara luas, semua tata letak Anda yang menggunakan inset ini juga akan otomatis dianimasikan saat nilai inset berubah.
Ada dua cara utama untuk menggunakan jenis inset ini guna menyesuaikan tata letak Composable: pengubah padding dan pengubah ukuran inset.
Pengubah padding
Modifier.windowInsetsPadding(windowInsets: WindowInsets)
menerapkan
inset jendela yang diberikan sebagai padding, yang berfungsi seperti Modifier.padding
.
Misalnya, Modifier.windowInsetsPadding(WindowInsets.safeDrawing)
menerapkan
inset gambar yang aman sebagai padding di keempat sisi.
Ada juga beberapa metode utilitas bawaan untuk jenis inset yang paling umum.
Modifier.safeDrawingPadding()
adalah salah satu metode tersebut, yang setara dengan
Modifier.windowInsetsPadding(WindowInsets.safeDrawing)
. Ada pengubah
analog untuk jenis inset lainnya.
Pengubah ukuran inset
Pengubah berikut menerapkan jumlah inset jendela dengan menetapkan ukuran komponen menjadi ukuran inset:
Menerapkan sisi awal windowInsets sebagai lebar (seperti |
|
Menerapkan sisi akhir windowInsets sebagai lebar (seperti |
|
Menerapkan sisi atas windowInsets sebagai tinggi (seperti |
|
|
Menerapkan sisi bawah windowInsets sebagai tinggi (seperti |
Pengubah ini sangat berguna untuk menentukan ukuran Spacer
yang menggunakan
ruang inset:
LazyColumn( Modifier.imePadding() ) { // Other content item { Spacer( Modifier.windowInsetsBottomHeight( WindowInsets.systemBars ) ) } }
Konsumsi inset
Pengubah padding inset (windowInsetsPadding
dan helper seperti
safeDrawingPadding
) secara otomatis menggunakan bagian inset yang
diterapkan sebagai padding. Saat masuk lebih dalam ke hierarki komposisi, pengubah padding
inset bertingkat dan pengubah ukuran inset mengetahui bahwa beberapa bagian
inset telah digunakan oleh pengubah padding inset luar, dan menghindari
penggunaan bagian inset yang sama lebih dari sekali yang akan menghasilkan terlalu banyak
ruang tambahan.
Pengubah ukuran inset juga menghindari penggunaan bagian inset yang sama lebih dari sekali jika inset telah digunakan. Namun, karena mengubah ukuran secara langsung, komponen ini tidak menggunakan inset.
Akibatnya, pengubah padding bertingkat akan otomatis mengubah jumlah padding yang diterapkan ke setiap composable.
Melihat contoh LazyColumn
yang sama seperti sebelumnya, LazyColumn
sedang
diubah ukurannya oleh pengubah imePadding
. Di dalam LazyColumn
, item terakhir
diukur agar memiliki tinggi bagian bawah panel sistem:
LazyColumn( Modifier.imePadding() ) { // Other content item { Spacer( Modifier.windowInsetsBottomHeight( WindowInsets.systemBars ) ) } }
Saat IME ditutup, pengubah imePadding()
tidak menerapkan padding, karena
IME tidak memiliki tinggi. Karena pengubah imePadding()
tidak menerapkan padding,
tidak ada inset yang digunakan, dan tinggi Spacer
akan menjadi ukuran
sisi bawah panel sistem.
Saat IME terbuka, inset IME akan dianimasikan agar cocok dengan ukuran IME, dan
pengubah imePadding()
mulai menerapkan padding bawah untuk mengubah ukuran
LazyColumn
saat IME terbuka. Saat pengubah imePadding()
mulai menerapkan padding bawah, pengubah tersebut juga mulai menggunakan jumlah inset tersebut. Oleh karena itu, tinggi Spacer
mulai menurun, karena bagian spasi untuk panel
sistem telah diterapkan oleh pengubah imePadding()
. Setelah
pengubah imePadding()
menerapkan jumlah padding bawah yang lebih besar
dari kolom sistem, tinggi Spacer
adalah nol.
Saat IME ditutup, perubahan terjadi secara terbalik: Spacer
mulai
diperluas dari tinggi nol setelah imePadding()
menerapkan lebih sedikit dari
sisi bawah panel sistem, hingga akhirnya Spacer
cocok dengan tinggi
sisi bawah panel sistem setelah IME sepenuhnya dianimasikan.
TextField
.Perilaku ini dicapai melalui komunikasi antara semua
pengubah windowInsetsPadding
, dan dapat dipengaruhi dengan beberapa cara
lain.
Modifier.consumeWindowInsets(insets: WindowInsets)
juga menggunakan inset
dengan cara yang sama seperti Modifier.windowInsetsPadding
, tetapi tidak menerapkan
inset yang digunakan sebagai padding. Hal ini berguna jika dikombinasikan dengan pengubah
ukuran inset, untuk menunjukkan kepada saudara bahwa jumlah inset tertentu
telah digunakan:
Column(Modifier.verticalScroll(rememberScrollState())) { Spacer(Modifier.windowInsetsTopHeight(WindowInsets.systemBars)) Column( Modifier.consumeWindowInsets( WindowInsets.systemBars.only(WindowInsetsSides.Vertical) ) ) { // content Spacer(Modifier.windowInsetsBottomHeight(WindowInsets.ime)) } Spacer(Modifier.windowInsetsBottomHeight(WindowInsets.systemBars)) }
Modifier.consumeWindowInsets(paddingValues: PaddingValues)
berperilaku sangat
mirip dengan versi dengan argumen WindowInsets
, tetapi memerlukan
PaddingValues
arbitrer untuk digunakan. Hal ini berguna untuk memberi tahu
turunan saat padding atau spasi disediakan oleh beberapa mekanisme lain selain
pengubah padding inset, seperti Modifier.padding
biasa atau pengatur jarak
tinggi tetap:
Column(Modifier.padding(16.dp).consumeWindowInsets(PaddingValues(16.dp))) { // content Spacer(Modifier.windowInsetsBottomHeight(WindowInsets.ime)) }
Jika inset jendela mentah diperlukan tanpa penggunaan, gunakan
nilai WindowInsets
secara langsung, atau gunakan WindowInsets.asPaddingValues()
untuk
menampilkan PaddingValues
inset yang tidak terpengaruh oleh penggunaan.
Namun, karena pengecualian di bawah, sebaiknya gunakan pengubah padding
inset jendela dan pengubah ukuran inset jendela jika memungkinkan.
Fase Insets dan Jetpack Compose
Compose menggunakan API inti AndroidX yang mendasarinya untuk mengupdate dan menganimasikan inset, yang menggunakan API platform yang mendasarinya yang mengelola inset. Karena perilaku platform tersebut, inset memiliki hubungan khusus dengan fase Jetpack Compose.
Nilai inset diperbarui setelah fase komposisi, tetapi sebelum fase tata letak. Artinya, membaca nilai inset dalam komposisi umumnya menggunakan nilai inset yang terlambat satu frame. Pengubah bawaan yang dijelaskan di halaman ini dibuat untuk menunda penggunaan nilai inset hingga fase tata letak, yang memastikan bahwa nilai inset digunakan pada bingkai yang sama saat diperbarui.