Cutout di Compose

Potongan layar adalah area di beberapa perangkat yang memanjang ke layar ditampilkan. Hal ini memungkinkan pengalaman edge-to-edge sekaligus menyediakan ruang bagi sensor penting di bagian depan perangkat.

Contoh Cutout dalam mode potret
Gambar 1. Contoh Cutout dalam Mode potret
Contoh Cutout dalam mode lanskap
Gambar 2. Contoh Cutout dalam mode lanskap

Android mendukung potongan layar pada perangkat yang menjalankan Android 9 (API level 28) dan lebih tinggi. Namun, produsen perangkat juga dapat mendukung potongan layar di perangkat yang menjalankan Android 8.1 atau yang lebih lama.

Halaman ini menjelaskan cara menerapkan dukungan untuk perangkat dengan potongan di Compose, termasuk cara menggunakan area potongan— yaitu, bagian tepi ke tepi persegi panjang di permukaan tampilan yang berisi potongan.

Kasus default

Secara default, potongan layar disertakan dalam informasi inset jendela. Karena itu, aplikasi Anda tidak akan menggambar di area potongan layar saat Anda mengikuti panduan untuk membuat aplikasi Anda ditampilkan di layar penuh.

Misalnya, ketika Anda menggunakan Modifier.windowInsetsPadding(WindowInsets.safeContent) atau Modifier.windowInsetsPadding(WindowInsets.safeDrawing), aplikasi Anda secara otomatis tidak akan menggambar di area tempat potongan ditempatkan. WindowInsets.safeContent dan WindowInsets.safeDrawing keduanya berisi informasi potongan layar dan tidak akan menggambar di tempat potongan perangkat alamat IP internalnya.

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)

    WindowCompat.setDecorFitsSystemWindows(window, false)

    setContent {
        Box(Modifier.windowInsetsPadding(WindowInsets.safeContent)) {
            // Any composable inside here will avoid drawing behind cutouts
        }
    }
}

Untuk menyesuaikan perilaku ini lebih lanjut, Anda harus menangani informasi potongan diri Anda sendiri.

Menangani informasi potongan secara manual

Anda dapat menangani potongan dengan salah satu cara berikut:

Untuk Compose, sebaiknya tetapkan windowLayoutInDisplayCutoutMode ke default di tema keseluruhan Anda, lalu manfaatkan WindowInsets.displayCutout menangani inset dalam composable Anda:

Canvas(modifier = Modifier.fillMaxSize().windowInsetsPadding(WindowInsets.displayCutout)) {
    drawRect(Color.Red, style = Stroke(2.dp.toPx()))
}

Pendekatan ini memungkinkan Anda mengikuti padding displayCutout jika diperlukan, atau mengabaikannya jika tidak diperlukan.

Atau, Anda dapat menerapkan setelan yang sama dengan Cutout Tampilan dokumentasi yang dijelaskan dengan menetapkan baik tema aktivitas android:windowLayoutInDisplayCutoutMode ke tema lainnya opsi, atau menyetel atribut jendela menggunakan window.attributes.layoutInDisplayCutoutMode = LAYOUT_IN_DISPLAY_CUTOUT_MODE_DEFAULT. Namun, mode potongan akan diterapkan ke seluruh aktivitas, dan tidak dapat dikontrol per composable individual.

Untuk mematuhi potongan layar di composable tertentu tetapi tidak yang lain, gunakan WindowInset.displayCutout. API ini memungkinkan Anda mengakses potongan jika diperlukan.

Praktik terbaik

Saat menggunakan potongan layar, pertimbangkan hal berikut:

  • Perhatikan penempatan elemen penting pada UI. Jangan biarkan area potongan mengaburkan teks, kontrol, atau informasi penting lainnya.
  • Jangan tempatkan atau perluas elemen interaktif apa pun yang memerlukan sentuhan halus pengenalan ke area potongan. Sensitivitas sentuhan mungkin lebih rendah di area potongan.
  • Saat mengikuti panduan dari tepi ke tepi, informasi potongan akan disertakan dalam inset safeDrawing / safeContent.
  • Jika memungkinkan, gunakan Modifier.windowInsetsPadding(WindowInsets.safeDrawing) untuk menentukan padding yang sesuai untuk diterapkan ke konten Anda. Hindari melakukan hardcode tinggi status bar, karena hal ini dapat menyebabkan tumpang-tindih atau terpotong saat ini.

Menguji cara konten dirender dengan potongan

Pastikan untuk menguji semua layar dan pengalaman aplikasi Anda. Uji pada perangkat dengan berbagai jenis potongan, jika memungkinkan. Jika Anda tidak memiliki perangkat dengan Anda dapat menyimulasikan konfigurasi potongan umum di perangkat atau emulator apa pun menjalankan Android 9 atau yang lebih baru dengan melakukan hal berikut:

  1. Aktifkan Opsi developer.
  2. Di layar Opsi developer, scroll ke bawah ke bagian Gambar lalu pilih Simulasikan tampilan dengan potongan.
  3. Pilih jenis potongan.
    menyimulasikan potongan layar di emulator
    Gambar 3. Gunakan Opsi developer untuk menguji cara konten Anda dirender.