Android 16 memperkenalkan fitur dan API baru yang hebat bagi para developer. Bagian berikut merangkum fitur-fitur ini untuk membantu Anda memulai 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 yang mungkin terpengaruh oleh perubahan platform. Untuk mengetahui 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
- 此预览版适用于 Android 的下一个主要版本,计划于 2025 年第 2 季度发布。此版本与我们过去的所有 API 版本类似,我们可以进行计划性的行为更改,这些更改通常与 targetSdkVersion 相关联。
- 我们计划提前一个季度(2021 年第 2 季度,而非之前的第 3 季度)发布主要版本,以便更好地与整个生态系统中的设备发布时间表保持一致,让更多设备能够更早地搭载 Android 主要版本。由于主要版本将于第 2 季度发布,因此您需要比往年提前几个月进行年度兼容性测试,以确保您的应用已做好准备。
- 我们计划在 2025 年第 4 季度再发布一次,届时还将推出新的开发者 API。2025 年只有第二季度的主要版本包含可能影响应用的计划行为变更。
除了新的开发者 API 之外,第 4 季度次要版本还将包含功能更新、优化和 bug 修复;其中不会包含任何会影响应用的行为变更。

我们将继续每季度发布 Android 版本。在 API 版本之间,第 1 季度和第 3 季度的更新将提供增量更新,以帮助确保持续提供高质量的服务。我们正积极与设备合作伙伴合作,将 Q2 版本推广到尽可能多的设备。
在主要版本和次要版本中使用新 API
目前,使用 SDK_INT
常量与 VERSION_CODES
结合使用,即可通过检查 API 级别来保护代码块。我们将继续支持主要 Android 版本。
if (SDK_INT >= VERSION_CODES.BAKLAVA) {
// Use APIs introduced in Android 16
}
新的 SDK_INT_FULL
常量可用于针对主要版本和次要版本进行 API 检查,并使用新的 VERSION_CODES_FULL
枚举。
if (SDK_INT_FULL >= VERSION_CODES_FULL.[MAJOR or MINOR RELEASE]) {
// Use APIs introduced in a major or minor release
}
您还可以使用 Build.getMinorSdkVersion()
方法仅获取 SDK 次要版本。
val minorSdkVersion = Build.getMinorSdkVersion(VERSION_CODES_FULL.BAKLAVA)
这些 API 尚未最终确定,可能会发生变化,因此如果您有任何疑虑,请向我们发送反馈。
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 添加了新 API,可帮助您在手势导航中启用预测性返回系统动画,例如“返回主屏幕”动画。通过使用新的 PRIORITY_SYSTEM_NAVIGATION_OBSERVER
注册 onBackInvokedCallback
,您的应用可以在系统处理返回导航时接收常规的 onBackInvoked
调用,而不会影响正常的返回导航流程。
Android 16 还添加了 finishAndRemoveTaskCallback()
和 moveTaskToBackCallback
。通过向 OnBackInvokedDispatcher
注册这些回调,系统可以在调用返回手势时触发特定行为并播放相应的提前动画。
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 berfokus 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.
Memulai komponen 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
Kecepatan refresh adaptif (ARR), yang diperkenalkan di Android 15, memungkinkan kecepatan refresh layar pada hardware yang didukung untuk beradaptasi dengan kecepatan frame konten menggunakan langkah VSync terpisah. Hal ini mengurangi konsumsi daya sekaligus menghilangkan kebutuhan untuk beralih mode yang berpotensi menyebabkan jank.
Android 16 memperkenalkan hasArrSupport()
dan
getSuggestedFrameRate(int)
saat memulihkan
getSupportedRefreshRates()
untuk memudahkan aplikasi Anda memanfaatkan
ARR. RecyclerView
1.4 secara internal mendukung ARR saat berhenti dari ayun atau
scroll halus, dan kami melanjutkan upaya untuk menambahkan dukungan
ARR ke lebih banyak library Jetpack. Artikel kecepatan frame ini membahas
banyak API yang dapat Anda gunakan untuk menetapkan kecepatan frame sehingga aplikasi Anda dapat langsung
menggunakan ARR.
Headroom API 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 ke 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 ruangan untuk alat bantu dengar LEA
Android 16 menambahkan kemampuan bagi pengguna alat bantu dengar LE Audio untuk menyesuaikan volume suara sekitar yang ditangkap oleh mikrofon alat bantu dengar. Hal ini dapat membantu dalam situasi saat suara bising di latar belakang terlalu keras atau terlalu pelan.
Kamera
Android 16 meningkatkan dukungan untuk pengguna kamera profesional, yang memungkinkan eksposur otomatis
hybrid beserta 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 memudahkan pengambilan foto gerakan,
dan kami terus meningkatkan kualitas gambar UltraHDR dengan dukungan untuk encoding HEIC
dan parameter baru dari standar draf ISO 21496-1.
Eksposur otomatis campuran
Android 16 menambahkan mode eksposur otomatis hibrida baru ke Camera2, yang memungkinkan Anda mengontrol aspek eksposur tertentu secara manual sekaligus membiarkan algoritma eksposur otomatis (AE) menangani sisanya. Anda dapat mengontrol ISO + AE, dan exposure time + AE, yang memberikan fleksibilitas yang lebih besar dibandingkan dengan pendekatan saat ini, yaitu Anda memiliki kontrol manual penuh atau sepenuhnya mengandalkan eksposur otomatis.
public void setISOPriority() {
...
int[] availablePriorityModes =
mStaticInfo.getCharacteristics().get(CameraCharacteristics.
COLOR_AE_AVAILABLE_PRIORITY_MODES);
...
// 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);
reqBuilder.set(CaptureRequest.SENSOR_SENSITIVITY,
TEST_SENSITIVITY_VALUE);
CaptureRequest request = reqBuilder.build();
...
}
Penyesuaian tint dan suhu warna yang akurat
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.
public void setCCT() {
...
Range<Integer> colorTemperatureRange =
mStaticInfo.getCharacteristics().get(CameraCharacteristics.
COLOR_CORRECTION_COLOR_TEMPERATURE_RANGE);
// Set to manual mode to enable CCT mode
reqBuilder.set(CaptureRequest.CONTROL_AWB_MODE, CameraMetadata.CONTROL_AWB_MODE_OFF);
reqBuilder.set(CaptureRequest.COLOR_CORRECTION_MODE,
CameraMetadata.COLOR_CORRECTION_MODE_CCT);
reqBuilder.set(CaptureRequest.COLOR_CORRECTION_COLOR_TEMPERATURE, 5000);
reqBuilder.set(CaptureRequest.COLOR_CORRECTION_COLOR_TINT, 30);
CaptureRequest request = reqBuilder.build();
...
}
Contoh berikut menunjukkan tampilan foto setelah menerapkan penyesuaian suhu warna dan tint yang berbeda:





Deteksi scene mode malam kamera
Untuk membantu aplikasi Anda mengetahui kapan harus beralih ke dan dari sesi kamera mode malam,
Android 16 menambahkan EXTENSION_NIGHT_MODE_INDICATOR
. Jika
didukung, fitur ini tersedia di CaptureResult
dalam
Camera2.
Ini adalah API yang kami sebutkan secara singkat sebagai segera hadir dalam postingan blog Cara Instagram memungkinkan pengguna mengambil foto cahaya redup yang menakjubkan. Postingan tersebut adalah panduan praktis tentang cara menerapkan mode malam bersama dengan studi kasus yang mengaitkan foto mode malam dalam aplikasi berkualitas lebih tinggi dengan peningkatan jumlah foto yang dibagikan dari kamera dalam aplikasi.
Tindakan intent pengambilan foto gerakan
Android 16 添加了标准 intent 操作 ACTION_MOTION_PHOTO_CAPTURE
和 ACTION_MOTION_PHOTO_CAPTURE_SECURE
,用于请求相机应用拍摄动态照片并将其返回。
您必须传递额外的 EXTRA_OUTPUT
来控制将图片写入的位置,或者通过 Intent.setClipData(ClipData)
传递 Uri
。如果您未设置 ClipData
,系统会在调用 Context.startActivity(Intent)
时将其复制到该位置。
Peningkatan gambar UltraHDR

Android 16 merupakan lanjutan upaya kami untuk menghadirkan kualitas gambar yang memukau dengan gambar
UltraHDR. Versi ini menambahkan dukungan untuk gambar UltraHDR dalam format file
HEIC. Gambar ini akan mendapatkan jenis ImageFormat
HEIC_ULTRAHDR
dan akan berisi peta gain tersemat yang mirip
dengan format JPEG UltraHDR yang ada. Kami juga sedang mengerjakan dukungan AVIF untuk UltraHDR, jadi nantikan kabar terbarunya.
Selain itu, Android 16 menerapkan parameter tambahan di UltraHDR dari standar draf ISO 21496-1, termasuk kemampuan untuk mendapatkan dan menetapkan ruang warna tempat matematika gainmap harus diterapkan, serta dukungan untuk gambar dasar yang dienkode HDR dengan gainmap SDR.
Grafik
Android 16 menyertakan peningkatan grafis terbaru, seperti efek grafis kustom dengan AGSL.
Efek grafis kustom dengan AGSL
Android 16 添加了 RuntimeColorFilter
和 RuntimeXfermode
,让您可以创作阈值、Sepia 和 Hue Saturation 等复杂效果,并将其应用于绘制调用。从 Android 13 开始,您可以使用 AGSL 创建扩展 Shader
的自定义 RuntimeShader。新 API 反映了这一点,添加了由 AGSL 驱动的 RuntimeColorFilter
(用于扩展 ColorFilter
)和 Xfermode
效果,让您可以在源像素和目标像素之间实现基于 AGSL 的自定义合成和混合。
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 komunikasi dan nirkabel.
Pengukuran 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 rentang umum
Android 16 包含新的 RangingManager
,它提供了在受支持的硬件上确定本地设备与远程设备之间的距离和角度的方法。RangingManager
支持使用各种测距技术,例如 BLE 信道声音探测、基于 BLE RSSI 的测距、超宽带和 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
Pemilih foto menyediakan cara bawaan yang aman bagi pengguna untuk memberikan akses aplikasi Anda ke gambar dan video yang dipilih dari penyimpanan lokal dan cloud, bukan seluruh koleksi media mereka. Dengan menggunakan kombinasi Komponen Sistem Modular melalui Update Sistem Google dan layanan Google Play, fitur ini didukung kembali ke Android 4.4 (API level 19). Integrasi hanya memerlukan beberapa baris kode dengan library Android Jetpack terkait.
Android 16 menyertakan peningkatan berikut pada pemilih foto:
- Alat pilih foto tersemat: API baru yang memungkinkan aplikasi menyertakan alat pilih foto ke dalam hierarki tampilannya. Hal ini memungkinkannya merasa seperti bagian aplikasi yang lebih terintegrasi sekaligus masih memanfaatkan isolasi proses yang memungkinkan pengguna memilih media tanpa memerlukan izin yang terlalu luas. Untuk memaksimalkan kompatibilitas di seluruh versi platform dan menyederhanakan integrasi, sebaiknya gunakan library Android Jetpack mendatang jika Anda ingin mengintegrasikan alat pilih foto tersemat.
- Cloud Search di pemilih foto: API baru yang memungkinkan penelusuran dari penyedia media cloud untuk pemilih foto Android. Fungsi penelusuran di pemilih foto akan segera hadir.
Video Profesional Lanjutan
Android 16 memperkenalkan dukungan untuk codec Advanced Professional Video (APV) yang dirancang untuk digunakan dalam proses perekaman dan pascaproduksi video berkualitas tinggi tingkat profesional.
Standar codec APV memiliki fitur berikut:
- Kualitas video yang tidak mengalami kompresi secara persepsi (hampir sama dengan kualitas video mentah)
- Kompleksitas rendah dan coding intra-frame-only throughput tinggi (tanpa prediksi domain piksel) untuk mendukung alur kerja pengeditan dengan lebih baik
- Dukungan untuk rentang kecepatan bit tinggi hingga beberapa Gbps untuk konten resolusi 2K, 4K, dan 8K, yang diaktifkan oleh skema coding entropi ringan
- Pemasangan ubin frame untuk konten imersif dan untuk mengaktifkan encoding dan decoding paralel
- Dukungan untuk berbagai format sampling kromatik dan kedalaman bit
- Dukungan untuk beberapa decoding dan encoding ulang tanpa penurunan kualitas visual yang parah
- Mendukung video multi-tampilan dan video tambahan seperti kedalaman, alfa, dan pratinjau
- Dukungan untuk HDR10/10+ dan metadata yang ditentukan pengguna
Implementasi referensi APV disediakan melalui project OpenAPV. Android 16 akan menerapkan dukungan untuk Profil APV 422-10 yang menyediakan sampling warna YUV 422 bersama dengan encoding 10-bit dan untuk target kecepatan bit hingga 2 Gbps.
Privasi
Android 16 menyertakan berbagai fitur yang membantu developer aplikasi melindungi privasi pengguna.
Update Health Connect
Health Connect 添加了 ACTIVITY_INTENSITY
,这是一种根据世界卫生组织关于中等强度和剧烈强度活动的指南定义的数据类型。每个记录都需要提供开始时间、结束时间以及活动强度(中等或剧烈)。
Health Connect 还包含支持医疗记录的更新版 API。这样一来,应用便可在征得用户明确同意的情况下,读取和写入 FHIR 格式的医疗记录。
Privacy Sandbox di Android
Android 16 menggabungkan versi terbaru Privacy Sandbox di Android, yang merupakan bagian dari upaya berkelanjutan kami untuk mengembangkan teknologi yang memungkinkan pengguna mengetahui bahwa privasi mereka dilindungi. Situs kami memiliki informasi selengkapnya tentang program beta developer Privacy Sandbox di Android untuk membantu Anda memulai. Lihat Runtime SDK yang memungkinkan SDK berjalan di lingkungan runtime khusus yang terpisah dari aplikasi yang ditayangkan, sehingga memberikan pengamanan yang lebih kuat seputar pengumpulan dan pembagian data pengguna.
Keamanan
Android 16 menyertakan fitur yang membantu Anda meningkatkan keamanan aplikasi dan melindungi data aplikasi.
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 memberi aplikasi Anda dukungan untuk mendapatkan hasil maksimal dari faktor bentuk Android.
Framework kualitas gambar dan audio standar untuk TV
Paket
MediaQuality
baru di Android 16 mengekspos
serangkaian API standar untuk akses ke profil audio dan gambar serta
setelan terkait hardware. Hal ini memungkinkan aplikasi streaming membuat kueri profil dan
menerapkan profil tersebut ke media secara dinamis:
- Film yang dimaster dengan rentang dinamis yang lebih luas memerlukan akurasi warna yang lebih tinggi untuk melihat detail halus dalam bayangan dan menyesuaikan dengan cahaya sekitar, sehingga profil yang memilih akurasi warna daripada kecerahan mungkin sesuai.
- Acara olahraga live sering kali dimaster dengan rentang dinamis yang sempit, tetapi sering ditonton di siang hari, sehingga profil yang lebih mengutamakan kecerahan daripada akurasi warna dapat memberikan hasil yang lebih baik.
- Konten yang sepenuhnya interaktif menginginkan pemrosesan minimal untuk mengurangi latensi, dan menginginkan kecepatan frame yang lebih tinggi, itulah sebabnya banyak TV dilengkapi dengan profil game.
API ini memungkinkan aplikasi beralih antar-profil dan pengguna untuk menikmati penyesuaian TV yang didukung agar sesuai dengan konten mereka.
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.