Android 16 memperkenalkan fitur dan API baru yang hebat untuk para developer. Bagian berikut merangkum fitur ini untuk membantu Anda mulai menggunakan API terkait.
Untuk melihat daftar mendetail tentang API yang baru, diubah, dan dihapus, baca laporan perbedaan API. Untuk mengetahui detail tentang API baru, buka referensi API Android — API baru ditandai agar lebih mudah dilihat.Anda juga harus meninjau area tempat perubahan platform dapat memengaruhi aplikasi Anda. Untuk informasi selengkapnya, lihat halaman berikut:
- Perubahan perilaku yang memengaruhi aplikasi saat menargetkan Android 16
- Perubahan perilaku yang memengaruhi semua aplikasi terlepas dari
targetSdkVersion
.
Fungsi inti
Android menyertakan API baru yang memperluas kemampuan inti sistem Android.
Dua rilis Android API pada tahun 2025
- Pratinjau ini ditujukan untuk rilis utama Android berikutnya dengan peluncuran yang direncanakan pada Kuartal 2 2025. Rilis ini mirip dengan semua rilis API kami sebelumnya, yang memungkinkan kita memiliki perubahan perilaku terencana yang sering kali terkait dengan targetSdkVersion.
- Kami merencanakan rilis utama satu kuartal lebih awal (K2, bukan K3 pada tahun sebelumnya) agar lebih selaras dengan jadwal peluncuran perangkat di seluruh ekosistem kami, sehingga lebih banyak perangkat dapat mendapatkan rilis utama Android lebih cepat. Dengan rilis utama yang akan datang pada Kuartal 2, Anda harus melakukan pengujian kompatibilitas tahunan beberapa bulan lebih awal dari tahun-tahun sebelumnya untuk memastikan aplikasi Anda siap.
- Kami berencana untuk merilis versi lain pada Kuartal 4 tahun 2025 yang juga akan menyertakan API developer baru. Rilis utama K2 akan menjadi satu-satunya rilis pada tahun 2025 yang menyertakan perubahan perilaku terencana yang dapat memengaruhi aplikasi.
Selain API developer baru, rilis minor K4 akan mengambil update fitur, pengoptimalan, dan perbaikan bug; rilis ini tidak akan menyertakan perubahan perilaku yang memengaruhi aplikasi.

Kami akan terus merilis Android setiap tiga bulan sekali. Update Kuartal 1 dan Kuartal 3 di antara rilis API akan memberikan update inkremental untuk membantu memastikan kualitas yang berkelanjutan. Kami secara aktif bekerja sama dengan partner perangkat untuk menghadirkan rilis Q2 ke sebanyak mungkin perangkat.
Menggunakan API baru dengan rilis utama dan minor
Melindungi blok kode dengan pemeriksaan API level dilakukan saat ini menggunakan
konstanta SDK_INT
dengan
VERSION_CODES
. Fitur ini akan terus
didukung untuk rilis Android utama.
if (SDK_INT >= VERSION_CODES.BAKLAVA) {
// Use APIs introduced in Android 16
}
Konstanta SDK_INT_FULL
baru dapat digunakan untuk pemeriksaan API terhadap versi utama dan minor dengan
enumerasi VERSION_CODES_FULL
baru.
if (SDK_INT_FULL >= VERSION_CODES_FULL.[MAJOR or MINOR RELEASE]) {
// Use APIs introduced in a major or minor release
}
Anda juga dapat menggunakan metode
Build.getMinorSdkVersion()
untuk mendapatkan versi SDK minor saja.
val minorSdkVersion = Build.getMinorSdkVersion(VERSION_CODES_FULL.BAKLAVA)
API ini belum selesai dan dapat berubah sewaktu-waktu. Jadi, kirimkan masukan kepada kami jika Anda memiliki masalah.
Pengalaman pengguna dan UI sistem
Android 16 memberi developer dan pengguna aplikasi kontrol dan fleksibilitas yang lebih besar untuk mengonfigurasi perangkat agar sesuai dengan kebutuhan mereka.
Notifikasi yang berfokus pada progres
Android 16 memperkenalkan notifikasi yang berfokus pada progres untuk membantu pengguna melacak perjalanan awal hingga akhir yang dimulai pengguna dengan lancar.
Notification.ProgressStyle
adalah gaya notifikasi
baru yang memungkinkan Anda membuat notifikasi yang berfokus pada progres. Kasus penggunaan utama mencakup
transportasi online, pengiriman, dan navigasi. Dalam class Notification.ProgressStyle
, Anda dapat menunjukkan status dan tonggak pencapaian dalam perjalanan pengguna menggunakan
titik dan segmen.
Untuk mempelajari lebih lanjut, lihat halaman dokumentasi Notifikasi yang berfokus pada progres.


Pembaruan kembali prediktif
Android 16 adds new APIs to help you enable predictive back system animations in
gesture navigation such as the back-to-home animation. Registering the
onBackInvokedCallback
with the new
PRIORITY_SYSTEM_NAVIGATION_OBSERVER
allows your app to
receive the regular onBackInvoked
call whenever the
system handles a back navigation without impacting the normal back navigation
flow.
Android 16 additionally adds the
finishAndRemoveTaskCallback()
and
moveTaskToBackCallback
. By registering these callbacks
with the OnBackInvokedDispatcher
, the system can trigger
specific behaviors and play corresponding ahead-of-time animations when the back
gesture is invoked.
Haptik yang lebih kaya
Android telah mengekspos kontrol atas aktuator haptic sejak awal.
Android 11 menambahkan dukungan untuk efek haptik yang lebih kompleks yang dapat didukung oleh aktuator
yang lebih canggih melalui
VibrationEffect.Compositions
dari primitif
semantik yang ditentukan perangkat.
Android 16 menambahkan API haptik yang memungkinkan aplikasi menentukan kurva amplitudo dan frekuensi efek haptik sekaligus memisahkan perbedaan antara kemampuan perangkat.
Alat dan produktivitas developer
Meskipun sebagian besar upaya kami untuk meningkatkan produktivitas Anda berpusat pada alat seperti Android Studio, Jetpack Compose, dan library Android Jetpack, kami selalu mencari cara di platform untuk membantu Anda mewujudkan visi Anda.
Penanganan konten untuk wallpaper animasi
Di Android 16, framework wallpaper animasi mendapatkan API konten baru untuk
mengatasi tantangan wallpaper dinamis yang didorong pengguna. Saat ini, wallpaper
live yang menggabungkan konten yang disediakan pengguna memerlukan penerapan
khusus layanan yang kompleks. Android 16 memperkenalkan
WallpaperDescription
dan
WallpaperInstance
. WallpaperDescription memungkinkan Anda
mengidentifikasi instance wallpaper animasi yang berbeda dari layanan yang sama. Misalnya, wallpaper yang memiliki instance di layar utama dan layar
kunci mungkin memiliki konten unik di kedua tempat tersebut. Pemilih wallpaper dan
WallpaperManager
menggunakan metadata ini untuk menampilkan
wallpaper dengan lebih baik kepada pengguna, sehingga menyederhanakan proses bagi Anda untuk membuat pengalaman wallpaper hidup yang beragam dan
dipersonalisasi.
Performa dan baterai
Android 16 memperkenalkan API yang membantu mengumpulkan insight tentang aplikasi Anda.
Pembuatan profil yang dipicu sistem
ProfilingManager
ditambahkan di Android 15, yang memberi aplikasi kemampuan untuk
meminta pengumpulan data pembuatan profil menggunakan Perfetto di perangkat publik di lapangan.
Namun, karena pembuatan profil ini harus dimulai dari aplikasi, alur penting seperti
startup atau ANR akan sulit atau tidak dapat direkam oleh aplikasi.
Untuk membantu hal ini, Android 16 memperkenalkan pembuatan profil yang dipicu sistem ke
ProfilingManager
. Aplikasi dapat mendaftarkan minat untuk menerima rekaman aktivitas untuk pemicu
tertentu seperti cold start reportFullyDrawn
atau ANR, lalu sistem akan memulai dan menghentikan rekaman aktivitas atas nama aplikasi. Setelah
pelacakan selesai, hasilnya akan dikirim ke direktori data aplikasi.
Komponen awal di ApplicationStartInfo
ApplicationStartInfo
ditambahkan di Android
15, yang memungkinkan aplikasi melihat alasan
awal proses, jenis awal, waktu mulai, throttling, dan data diagnostik
berguna lainnya. Android 16 menambahkan
getStartComponent()
untuk membedakan jenis komponen yang memicu awal, yang dapat membantu
mengoptimalkan alur startup aplikasi Anda.
Introspeksi tugas yang lebih baik
JobScheduler#getPendingJobReason()
API menampilkan alasan mengapa tugas
mungkin tertunda. Namun, tugas mungkin tertunda karena beberapa alasan.
Di Android 16, kami memperkenalkan API
JobScheduler#getPendingJobReasons(int jobId)
baru, yang menampilkan beberapa
alasan mengapa tugas tertunda, karena batasan eksplisit yang ditetapkan oleh
developer dan batasan implisit yang ditetapkan oleh sistem.
Kami juga memperkenalkan
JobScheduler#getPendingJobReasonsHistory(int jobId)
, yang menampilkan daftar
perubahan batasan terbaru.
Sebaiknya gunakan API untuk membantu Anda men-debug alasan tugas Anda mungkin tidak dieksekusi, terutama jika Anda melihat penurunan rasio keberhasilan tugas tertentu atau memiliki bug di sekitar latensi penyelesaian tugas tertentu. Misalnya, pembaruan widget di latar belakang gagal terjadi atau tugas pengambilan data gagal dipanggil sebelum aplikasi dimulai.
Hal ini juga dapat membantu Anda lebih memahami apakah tugas tertentu tidak selesai karena batasan yang ditentukan sistem dibandingkan batasan yang ditetapkan secara eksplisit.
Kecepatan refresh adaptif
Adaptive refresh rate (ARR), introduced in Android 15, enables the display refresh rate on supported hardware to adapt to the content frame rate using discrete VSync steps. This reduces power consumption while eliminating the need for potentially jank-inducing mode-switching.
Android 16 introduces hasArrSupport()
and
getSuggestedFrameRate(int)
while restoring
getSupportedRefreshRates()
to make it easier for your apps to take
advantage of ARR. RecyclerView
1.4 internally supports ARR when it is settling from a fling or
smooth scroll, and we're continuing our work to add ARR
support into more Jetpack libraries. This frame rate article covers
many of the APIs you can use to set the frame rate so that your app can directly
use ARR.
API ruang kosong di ADPF
SystemHealthManager
memperkenalkan
getCpuHeadroom
dan
getGpuHeadroom
API, yang dirancang untuk menyediakan game dan
aplikasi yang intensif resource dengan estimasi resource CPU dan GPU yang tersedia. Metode
ini menawarkan cara bagi Anda untuk mengukur cara terbaik aplikasi atau game Anda meningkatkan
kesehatan sistem, terutama jika digunakan bersama dengan Android Dynamic
Performance Framework (ADPF) API lainnya yang mendeteksi throttling
termal.
Dengan menggunakan CpuHeadroomParams
dan
GpuHeadroomParams
di perangkat yang didukung, Anda dapat
menyesuaikan periode waktu yang digunakan untuk menghitung headroom dan memilih antara
ketersediaan resource rata-rata atau minimum. Hal ini dapat membantu Anda mengurangi penggunaan resource CPU atau
GPU dengan semestinya, sehingga menghasilkan pengalaman pengguna yang lebih baik dan meningkatkan
masa pakai baterai.
Aksesibilitas
Android 16 menambahkan API dan fitur aksesibilitas baru yang dapat membantu Anda menghadirkan aplikasi kepada setiap pengguna.
API aksesibilitas yang ditingkatkan
Android 16 menambahkan API tambahan untuk meningkatkan semantik UI yang membantu meningkatkan konsistensi bagi pengguna yang mengandalkan layanan aksesibilitas, seperti TalkBack.
Membuat garis tepi teks untuk kontras teks maksimum
Pengguna dengan gangguan penglihatan sering kali memiliki sensitivitas kontras yang berkurang, sehingga sulit untuk membedakan objek dari latar belakangnya. Untuk membantu pengguna ini, Android 16 memperkenalkan teks garis batas, yang menggantikan teks kontras tinggi, yang menggambar area kontras yang lebih besar di sekitar teks untuk sangat meningkatkan keterbacaan.
Android 16 berisi API AccessibilityManager
baru untuk memungkinkan
aplikasi Anda memeriksa atau mendaftarkan pemroses untuk
melihat apakah mode ini diaktifkan. Hal ini terutama untuk Toolkit UI seperti Compose untuk
menawarkan pengalaman visual yang serupa. Jika Anda mengelola library UI Toolkit atau
aplikasi Anda melakukan rendering teks kustom yang mengabaikan
class android.text.Layout
, Anda dapat menggunakannya untuk mengetahui
saat teks garis batas diaktifkan.

Durasi ditambahkan ke TtsSpan
Android 16 memperluas TtsSpan
dengan TYPE_DURATION
,
yang terdiri dari ARG_HOURS
, ARG_MINUTES
,
dan ARG_SECONDS
. Hal ini memungkinkan Anda menganotasi durasi
waktu secara langsung, sehingga memastikan output text-to-speech yang akurat dan konsisten dengan layanan
seperti TalkBack.
Mendukung elemen dengan beberapa label
Android saat ini memungkinkan elemen UI untuk memperoleh label aksesibilitas dari
elemen lain, dan kini menawarkan kemampuan untuk mengaitkan beberapa label, sebuah skenario umum dalam konten web. Dengan memperkenalkan API berbasis daftar dalam
AccessibilityNodeInfo
, Android dapat langsung mendukung
hubungan multi-label ini. Sebagai bagian dari perubahan ini, kami telah menghentikan
AccessibilityNodeInfo#setLabeledBy
dan
#getLabeledBy
dan menggantinya dengan
#addLabeledBy
, #removeLabeledBy
, dan
#getLabeledByList
.
Dukungan yang lebih baik untuk elemen yang dapat diluaskan
Android 16 menambahkan API aksesibilitas yang memungkinkan Anda menyampaikan status elemen interaktif yang diperluas atau
ditutup, seperti menu dan daftar yang dapat diluaskan. Dengan
menetapkan status yang diperluas menggunakan setExpandedState
dan
mengirim TYPE_WINDOW_CONTENT_CHANGED AccessibilityEvents
dengan jenis perubahan konten CONTENT_CHANGE_TYPE_EXPANDED
,
Anda dapat memastikan bahwa pembaca layar seperti TalkBack mengumumkan
perubahan status, sehingga memberikan pengalaman pengguna yang lebih intuitif dan inklusif.
Status Progres Tidak Pasti
Android 16 menambahkan RANGE_TYPE_INDETERMINATE
, yang memberi Anda cara
untuk mengekspos RangeInfo
untuk widget ProgressBar
determinate dan
indeterminate, sehingga layanan seperti
TalkBack dapat memberikan masukan secara lebih konsisten untuk indikator
progres.
CheckBox tiga status
Metode AccessibilityNodeInfo
getChecked
dan setChecked(int)
baru di Android 16 kini mendukung status "sebagian dicentang" selain
" dicentang" dan "tidak dicentang". Ini menggantikan boolean
isChecked
dan setChecked(boolean)
yang tidak digunakan lagi.
Deskripsi tambahan
Saat menjelaskan ViewGroup
, layanan aksesibilitas
akan menggabungkan label konten dari tampilan turunannya. Jika Anda memberikan
contentDescription
untuk ViewGroup
, layanan aksesibilitas akan menganggap Anda
juga mengganti deskripsi tampilan turunan yang tidak dapat difokuskan. Hal ini dapat
menjadi masalah jika Anda ingin memberi label pada hal-hal seperti drop-down (misalnya, "Font
Family") sekaligus mempertahankan pilihan saat ini untuk aksesibilitas (misalnya,
"Roboto"). Android 16 menambahkan setSupplementalDescription
sehingga
Anda dapat memberikan teks yang memberikan informasi tentang ViewGroup
tanpa
mengganti informasi dari turunannya.
Kolom formulir wajib diisi
Android 16 menambahkan setFieldRequired
ke
AccessibilityNodeInfo
sehingga aplikasi dapat memberi tahu layanan
aksesibilitas bahwa input ke kolom formulir diperlukan. Ini adalah skenario penting
bagi pengguna yang mengisi banyak jenis formulir, bahkan hal-hal sepele seperti kotak centang
persyaratan dan ketentuan yang diperlukan, yang membantu pengguna untuk secara konsisten mengidentifikasi dan
berpindah dengan cepat di antara kolom yang diperlukan.
Ponsel sebagai input mikrofon untuk panggilan suara dengan alat bantu dengar LEA
Android 16 menambahkan kemampuan bagi pengguna alat bantu dengar LE Audio untuk beralih antara mikrofon bawaan di alat bantu dengar dan mikrofon di ponsel mereka untuk panggilan suara. Hal ini dapat membantu di lingkungan yang bising atau situasi lain saat mikrofon alat bantu dengar mungkin tidak berperforma baik.
Kontrol volume sekitar untuk alat bantu dengar LEA
Android 16 adds the capability for users of LE Audio hearing aids to adjust the volume of ambient sound that is picked up by the hearing aid's microphones. This can be helpful in situations where background noise is too loud or too quiet.
Kamera
Android 16 meningkatkan dukungan untuk pengguna kamera profesional, sehingga memungkinkan eksposur otomatis hybrid bersama dengan penyesuaian suhu warna dan tint yang akurat. Indikator mode malam baru membantu aplikasi Anda mengetahui kapan harus beralih ke dan dari sesi kamera mode malam. Tindakan Intent
baru mempermudah pengambilan foto bergerak, dan kami terus meningkatkan kualitas gambar UltraHDR dengan dukungan untuk encoding HEIC dan parameter baru dari draf standar ISO 21496-1.
Eksposur otomatis hybrid
Android 16 adds new hybrid auto-exposure modes to Camera2, allowing you to manually control specific aspects of exposure while letting the auto-exposure (AE) algorithm handle the rest. You can control ISO + AE, and exposure time + AE, providing greater flexibility compared to the current approach where you either have full manual control or rely entirely on auto-exposure.
fun setISOPriority() {
// ... (Your existing code before the snippet) ...
val availablePriorityModes = mStaticInfo.characteristics.get(
CameraCharacteristics.CONTROL_AE_AVAILABLE_PRIORITY_MODES
)
// ... (Your existing code between the snippets) ...
// Turn on AE mode to set priority mode
reqBuilder.set(
CaptureRequest.CONTROL_AE_MODE,
CameraMetadata.CONTROL_AE_MODE_ON
)
reqBuilder.set(
CaptureRequest.CONTROL_AE_PRIORITY_MODE,
CameraMetadata.CONTROL_AE_PRIORITY_MODE_SENSOR_SENSITIVITY_PRIORITY
)
reqBuilder.set(
CaptureRequest.SENSOR_SENSITIVITY,
TEST_SENSITIVITY_VALUE
)
val request: CaptureRequest = reqBuilder.build()
// ... (Your existing code after the snippet) ...
}
Penyesuaian tint dan color temperature yang presisi
Android 16 menambahkan dukungan kamera untuk penyesuaian tint dan suhu warna yang halus
untuk mendukung aplikasi perekaman video profesional dengan lebih baik. Di versi Android
sebelumnya, Anda dapat mengontrol setelan white balance melalui
CONTROL_AWB_MODE
, yang berisi opsi yang terbatas pada
daftar preset, seperti Incandescent,
Cloudy, dan Twilight. COLOR_CORRECTION_MODE_CCT
memungkinkan penggunaan
COLOR_CORRECTION_COLOR_TEMPERATURE
dan
COLOR_CORRECTION_COLOR_TINT
untuk penyesuaian
white balance yang akurat berdasarkan color temperature yang berkorelasi.
fun setCCT() {
// ... (Your existing code before this point) ...
val colorTemperatureRange: Range<Int> =
mStaticInfo.characteristics[CameraCharacteristics.COLOR_CORRECTION_COLOR_TEMPERATURE_RANGE]
// Set to manual mode to enable CCT mode
reqBuilder[CaptureRequest.CONTROL_AWB_MODE] = CameraMetadata.CONTROL_AWB_MODE_OFF
reqBuilder[CaptureRequest.COLOR_CORRECTION_MODE] = CameraMetadata.COLOR_CORRECTION_MODE_CCT
reqBuilder[CaptureRequest.COLOR_CORRECTION_COLOR_TEMPERATURE] = 5000
reqBuilder[CaptureRequest.COLOR_CORRECTION_COLOR_TINT] = 30
val request: CaptureRequest = reqBuilder.build()
// ... (Your existing code after this point) ...
}
Contoh berikut menunjukkan tampilan foto setelah menerapkan penyesuaian suhu warna dan tint yang berbeda:





Deteksi adegan mode malam kamera
To help your app know when to switch to and from a night mode camera session,
Android 16 adds EXTENSION_NIGHT_MODE_INDICATOR
. If
supported, it's available in the CaptureResult
within
Camera2.
This is the API we briefly mentioned as coming soon in the How Instagram enabled users to take stunning low light photos blog post. That post is a practical guide on how to implement night mode together with a case study that links higher-quality in-app night mode photos with an increase in the number of photos shared from the in-app camera.
Tindakan intent pengambilan foto motion
Android 16 adds standard Intent actions —
ACTION_MOTION_PHOTO_CAPTURE
, and
ACTION_MOTION_PHOTO_CAPTURE_SECURE
— which request that
the camera application capture a motion photo and return
it.
You must either pass an extra EXTRA_OUTPUT
to control
where the image will be written, or a Uri
through
Intent.setClipData(ClipData)
. If you don't set a
ClipData
, it will be copied there for you when calling
Context.startActivity(Intent)
.
Peningkatan gambar UltraHDR

Android 16 continues our work to deliver dazzling image quality with UltraHDR
images. It adds support for UltraHDR images in the HEIC file
format. These images will get ImageFormat
type
HEIC_ULTRAHDR
and will contain an embedded gainmap similar
to the existing UltraHDR JPEG format. We're working on AVIF support for UltraHDR
as well, so stay tuned.
In addition, Android 16 implements additional parameters in UltraHDR from the ISO 21496-1 draft standard, including the ability to get and set the colorspace that gainmap math should be applied in, as well as support for HDR encoded base images with SDR gainmaps.
Grafik
Android 16 menyertakan peningkatan grafis terbaru, seperti efek grafis kustom dengan AGSL.
Efek grafis kustom dengan AGSL
Android 16 menambahkan RuntimeColorFilter
dan
RuntimeXfermode
, yang memungkinkan Anda menulis efek kompleks seperti
Threshold, Sepia, dan Hue Saturation, serta menerapkannya untuk menggambar panggilan. Sejak Android
13, Anda dapat menggunakan AGSL untuk membuat
RuntimeShaders kustom yang memperluas Shader
. API baru
mencerminkan hal ini, dengan menambahkan RuntimeColorFilter
yang didukung AGSL yang
memperluas ColorFilter
, dan efek Xfermode
yang
memungkinkan Anda menerapkan komposisi dan penggabungan kustom berbasis AGSL antara piksel sumber dan
tujuan.
private val thresholdEffectString = """
uniform half threshold;
half4 main(half4 c) {
half luminosity = dot(c.rgb, half3(0.2126, 0.7152, 0.0722));
half bw = step(threshold, luminosity);
return bw.xxx1 * c.a;
}"""
fun setCustomColorFilter(paint: Paint) {
val filter = RuntimeColorFilter(thresholdEffectString)
filter.setFloatUniform(0.5);
paint.colorFilter = filter
}
Konektivitas
Android 16 mengupdate platform untuk memberi aplikasi Anda akses ke kemajuan terbaru dalam teknologi nirkabel dan komunikasi.
Pengukuran jarak dengan keamanan yang ditingkatkan
Android 16 menambahkan dukungan untuk fitur keamanan yang andal di lokasi Wi-Fi pada perangkat yang didukung dengan 802.11az Wi-Fi 6, yang memungkinkan aplikasi menggabungkan akurasi yang lebih tinggi, skalabilitas yang lebih besar, dan penjadwalan dinamis protokol dengan peningkatan keamanan termasuk enkripsi berbasis AES-256 dan perlindungan terhadap serangan MITM. Hal ini memungkinkannya digunakan dengan lebih aman dalam kasus penggunaan kedekatan, seperti membuka kunci laptop atau pintu kendaraan. 802.11az terintegrasi dengan standar Wi-Fi 6, yang memanfaatkan infrastruktur dan kemampuannya untuk adopsi yang lebih luas dan deployment yang lebih mudah.
API pengukuran jarak generik
Android 16 menyertakan RangingManager
baru, yang menyediakan
cara untuk menentukan jarak dan sudut pada hardware yang didukung antara perangkat
lokal dan perangkat jarak jauh. RangingManager
mendukung penggunaan berbagai
teknologi pengukuran jarak seperti sounding saluran BLE, pengukuran jarak berbasis RSSI BLE, Ultra
Wideband, dan waktu perjalanan bolak-balik Wi-Fi.
Kehadiran perangkat pengelola perangkat pendamping
Di Android 16, API baru diperkenalkan untuk mengikat layanan aplikasi
pendamping Anda. Layanan akan terikat saat BLE berada dalam jangkauan dan Bluetooth terhubung
dan layanan akan dibatalkan ikatannya saat BLE berada di luar jangkauan atau Bluetooth
terputus. Aplikasi akan menerima callback
'onDevicePresenceEvent()' baru berdasarkan berbagai
DevicePresenceEvent
.
Detail selengkapnya dapat ditemukan di
'startObservingDevicePresence(ObservingDevicePresenceRequest)'.
Media
Android 16 menyertakan berbagai fitur yang meningkatkan pengalaman media.
Peningkatan pemilih foto
The photo picker provides a safe, built-in way for users to grant your app access to selected images and videos from both local and cloud storage, instead of their entire media library. Using a combination of Modular System Components through Google System Updates and Google Play services, it's supported back to Android 4.4 (API level 19). Integration requires just a few lines of code with the associated Android Jetpack library.
Android 16 includes the following improvements to the photo picker:
- Embedded photo picker: New APIs that enable apps to embed the photo picker into their view hierarchy. This allows it to feel like a more integrated part of the app while still leveraging the process isolation that allows users to select media without the app needing overly broad permissions. To maximize compatibility across platform versions and simplify your integration, you'll want to use the forthcoming Android Jetpack library if you want to integrate the embedded photo picker.
- Cloud search in photo picker: New APIs that enable searching from the cloud media provider for the Android photo picker. Search functionality in the photo picker is coming soon.
Video Profesional Lanjutan
Android 16 introduces support for the Advanced Professional Video (APV) codec which is designed to be used for professional level high quality video recording and post production.
The APV codec standard has the following features:
- Perceptually lossless video quality (close to raw video quality)
- Low complexity and high throughput intra-frame-only coding (without pixel domain prediction) to better support editing workflows
- Support for high bit-rate range up to a few Gbps for 2K, 4K and 8K resolution content, enabled by a lightweight entropy coding scheme
- Frame tiling for immersive content and for enabling parallel encoding and decoding
- Support for various chroma sampling formats and bit-depths
- Support for multiple decoding and re-encoding without severe visual quality degradation
- Support multi-view video and auxiliary video like depth, alpha, and preview
- Support for HDR10/10+ and user-defined metadata
A reference implementation of APV is provided through the OpenAPV project. Android 16 will implement support for the APV 422-10 Profile that provides YUV 422 color sampling along with 10-bit encoding and for target bitrates of up to 2Gbps.
Privasi
Android 16 menyertakan berbagai fitur yang membantu developer aplikasi melindungi privasi pengguna.
Update Health Connect
Health Connect menambahkan ACTIVITY_INTENSITY
, jenis data yang ditentukan sesuai dengan pedoman
Organisasi Kesehatan Dunia terkait aktivitas sedang dan berat. Setiap
data memerlukan waktu mulai, waktu berakhir, dan apakah intensitas aktivitas
sedang atau berat.
Health Connect juga berisi API yang diperbarui yang mendukung rekam medis. Hal ini memungkinkan aplikasi membaca dan menulis catatan medis dalam format FHIR dengan izin pengguna yang eksplisit.
Privacy Sandbox di Android
Android 16 incorporates the latest version of the Privacy Sandbox on Android, part of our ongoing work to develop technologies where users know their privacy is protected. Our website has more about the Privacy Sandbox on Android developer beta program to help you get started. Check out the SDK Runtime which allows SDKs to run in a dedicated runtime environment separate from the app they are serving, providing stronger safeguards around user data collection and sharing.
Keamanan
Android 16 menyertakan fitur yang membantu Anda meningkatkan keamanan aplikasi dan melindungi data aplikasi Anda.
API berbagi kunci
Android 16 menambahkan API yang mendukung berbagi akses ke
kunci Android Keystore dengan aplikasi lain. Class
KeyStoreManager
baru mendukung
pemberian dan pencabutan akses ke kunci
oleh uid aplikasi, dan menyertakan API untuk aplikasi agar dapat mengakses kunci
yang dibagikan.
Faktor bentuk perangkat
Android 16 memberikan dukungan bagi aplikasi Anda untuk mendapatkan manfaat maksimal dari faktor bentuk Android.
Framework kualitas gambar dan audio standar untuk TV
The new MediaQuality
package in Android 16 exposes
a set of standardized APIs for access to audio and picture profiles and
hardware-related settings. This allows streaming apps to query profiles and
apply them to media dynamically:
- Movies mastered with a wider dynamic range require greater color accuracy to see subtle details in shadows and adjust to ambient light, so a profile that prefers color accuracy over brightness may be appropriate.
- Live sporting events are often mastered with a narrow dynamic range, but are often watched in daylight, so a profile that preferences brightness over color accuracy can give better results.
- Fully interactive content wants minimal processing to reduce latency, and wants higher frame rates, which is why many TV's ship with a game profile.
The API allows apps to switch between profiles and users to enjoy tuning supported TVs to best suit their content.
Internasionalisasi
Android 16 menambahkan fitur dan kemampuan yang melengkapi pengalaman pengguna saat perangkat digunakan dalam bahasa yang berbeda.
Teks vertikal
Android 16 menambahkan dukungan tingkat rendah untuk merender dan mengukur teks secara vertikal guna
memberikan dukungan penulisan vertikal dasar bagi developer library. Hal ini
sangat berguna untuk bahasa seperti Jepang yang biasanya menggunakan sistem
tulisan vertikal. Flag baru,
VERTICAL_TEXT_FLAG
,
telah ditambahkan ke class Paint
. Saat
tanda ini ditetapkan menggunakan
Paint.setFlags
, API
pengukuran teks Paint akan melaporkan progres vertikal, bukan progres
horizontal, dan Canvas
akan menggambar teks
secara vertikal.
val text = "「春は、曙。」"
Box(
Modifier.padding(innerPadding).background(Color.White).fillMaxSize().drawWithContent {
drawIntoCanvas { canvas ->
val paint = Paint().apply { textSize = 64.sp.toPx() }
// Draw text vertically
paint.flags = paint.flags or VERTICAL_TEXT_FLAG
val height = paint.measureText(text)
canvas.nativeCanvas.drawText(
text,
0,
text.length,
size.width / 2,
(size.height - height) / 2,
paint
)
}
}
) {}
Penyesuaian sistem pengukuran
Pengguna kini dapat menyesuaikan sistem pengukuran mereka di preferensi regional dalam
Setelan. Preferensi pengguna disertakan sebagai bagian dari kode lokalitas, sehingga Anda dapat
mendaftarkan BroadcastReceiver
di
ACTION_LOCALE_CHANGED
untuk menangani perubahan konfigurasi lokalitas saat
preferensi regional berubah.
Menggunakan formator dapat membantu mencocokkan pengalaman lokal. Misalnya, "0,5 in" dalam bahasa Inggris (Amerika Serikat), adalah "12,7 mm" untuk pengguna yang telah menyetel ponsel ke bahasa Inggris (Denmark) atau yang menggunakan ponsel dalam bahasa Inggris (Amerika Serikat) dengan sistem metrik sebagai preferensi sistem pengukuran.
Untuk menemukan setelan ini, buka aplikasi Setelan, lalu buka Sistem > Bahasa & wilayah.