Platform Android 16 menyertakan perubahan perilaku yang dapat memengaruhi aplikasi Anda.
Perubahan perilaku berikut berlaku untuk semua aplikasi saat dijalankan di Android 16,
terlepas dari targetSdkVersion
. Sebaiknya uji aplikasi Anda, lalu ubah
sesuai kebutuhan untuk mendukung perubahan ini, jika memungkinkan.
Selain itu, pastikan Anda meninjau daftar perubahan perilaku yang hanya memengaruhi aplikasi yang menargetkan Android 16.
Fungsi inti
Android 16 menyertakan perubahan berikut yang mengubah atau memperluas berbagai kemampuan inti sistem Android.
Pengoptimalan kuota JobScheduler
Mulai Android 16, kami menyesuaikan kuota runtime eksekusi tugas reguler dan dipercepat berdasarkan faktor berikut:
- Bucket standby aplikasi yang digunakan aplikasi: di Android 16, bucket standby aktif akan mulai diterapkan oleh kuota runtime yang besar.
- Jika tugas memulai eksekusi saat aplikasi dalam status teratas: di Android 16, Tugas yang dimulai saat aplikasi terlihat oleh pengguna dan berlanjut setelah aplikasi menjadi tidak terlihat, akan mematuhi kuota runtime tugas.
- Jika tugas dieksekusi saat menjalankan Layanan Latar Depan: di Android 16, tugas yang dieksekusi secara serentak dengan layanan latar depan akan mematuhi kuota runtime tugas. Jika Anda memanfaatkan tugas untuk transfer data yang dimulai pengguna, sebaiknya gunakan tugas transfer data yang dimulai pengguna.
Perubahan ini memengaruhi tugas yang dijadwalkan menggunakan WorkManager, JobScheduler, dan
DownloadManager. Untuk men-debug alasan tugas dihentikan, sebaiknya catat alasan
tugas Anda dihentikan dengan memanggil WorkInfo.getStopReason()
(untuk
tugas JobScheduler, panggil JobParameters.getStopReason()
).
Untuk informasi selengkapnya tentang praktik terbaik yang optimal untuk baterai, lihat panduan tentang mengoptimalkan penggunaan baterai untuk API penjadwalan tugas.
Sebaiknya manfaatkan juga
API JobScheduler#getPendingJobReasonsHistory
baru yang diperkenalkan di
Android 16 untuk memahami alasan tugas belum dieksekusi.
Pengujian
Untuk menguji perilaku aplikasi, Anda dapat mengaktifkan penggantian pengoptimalan kuota tugas tertentu selama aplikasi berjalan di perangkat Android 16.
Untuk menonaktifkan penerapan "status teratas akan mematuhi kuota runtime tugas", jalankan perintah adb
berikut:
adb shell am compat enable OVERRIDE_QUOTA_ENFORCEMENT_TO_TOP_STARTED_JOBS APP_PACKAGE_NAME
Untuk menonaktifkan penerapan "tugas yang dieksekusi secara serentak dengan
layanan latar depan akan mematuhi kuota runtime tugas", jalankan perintah
adb
berikut:
adb shell am compat enable OVERRIDE_QUOTA_ENFORCEMENT_TO_FGS_JOBS APP_PACKAGE_NAME
Untuk menguji perilaku bucket standby aplikasi tertentu, Anda dapat menetapkan bucket standby aplikasi
aplikasi menggunakan perintah adb
berikut:
adb shell am set-standby-bucket APP_PACKAGE_NAME active|working_set|frequent|rare|restricted
Untuk memahami bucket standby aplikasi yang berisi aplikasi Anda, Anda bisa mendapatkan bucket
standby aplikasi menggunakan perintah adb
berikut:
adb shell am get-standby-bucket APP_PACKAGE_NAME
Tidak lagi menggunakan JobInfo#setImportantWhileForeground sepenuhnya
Metode JobInfo.Builder#setImportantWhileForeground(boolean)
menunjukkan tingkat kepentingan tugas saat aplikasi penjadwalan berada di
latar depan atau saat dikecualikan sementara dari pembatasan latar belakang.
Metode ini tidak digunakan lagi sejak Android 12 (API level 31). Mulai Android 16, metode ini tidak lagi berfungsi secara efektif dan memanggil metode ini akan diabaikan.
Penghapusan fungsi ini juga berlaku untuk
JobInfo#isImportantWhileForeground()
. Mulai Android
16, jika metode dipanggil, metode akan menampilkan false
.
Pengalaman pengguna dan UI sistem
Android 16 menyertakan perubahan berikut yang dimaksudkan untuk menciptakan pengalaman pengguna yang lebih konsisten dan intuitif.
Penghentian pengumuman aksesibilitas yang mengganggu
Android 16 tidak lagi menggunakan pengumuman aksesibilitas, yang ditandai dengan penggunaan
announceForAccessibility
atau pengiriman
peristiwa aksesibilitas TYPE_ANNOUNCEMENT
. Hal ini dapat membuat
pengalaman pengguna yang tidak konsisten bagi pengguna TalkBack dan pembaca layar Android,
dan alternatifnya lebih baik memenuhi berbagai kebutuhan pengguna di berbagai
teknologi asistif Android.
Contoh alternatif:
- Untuk perubahan UI yang signifikan seperti perubahan jendela, gunakan
Activity.setTitle(CharSequence)
dansetAccessibilityPaneTitle(java.lang.CharSequence)
. Di Compose, gunakanModifier.semantics { paneTitle = "paneTitle" }
- Untuk memberi tahu pengguna tentang perubahan pada UI penting, gunakan
setAccessibilityLiveRegion(int)
. Di Compose, gunakanModifier.semantics { liveRegion = LiveRegionMode.[Polite|Assertive]}
. Fungsi ini sebaiknya digunakan seperlunya karena dapat menghasilkan pengumuman setiap kali Tampilan diperbarui. - Untuk memberi tahu pengguna tentang error, kirim
AccessibilityEvent
dari jenisAccessibilityEvent#CONTENT_CHANGE_TYPE_ERROR
dan tetapkanAccessibilityNodeInfo#setError(CharSequence)
, atau gunakanTextView#setError(CharSequence)
.
Dokumentasi referensi untuk announceForAccessibility
API
yang tidak digunakan lagi menyertakan detail selengkapnya tentang
alternatif yang disarankan.