Функции и API

Android 16 представляет множество новых функций и API для разработчиков. В следующих разделах приведено краткое описание этих функций, которое поможет вам начать работу с соответствующими API.

Подробный список новых, измененных и удаленных API см. в отчете об изменениях API . Подробную информацию о новых API см. в справочнике Android API — новые API выделены для большей наглядности.

Также следует проанализировать области, где изменения платформы могут повлиять на ваши приложения. Для получения дополнительной информации см. следующие страницы:

Основная функциональность

Android включает в себя новые API, расширяющие основные возможности системы Android.

Два релиза Android API в 2025 году

  • Эта предварительная версия предназначена для следующего основного выпуска Android, запуск которого запланирован на второй квартал 2025 года. Этот выпуск похож на все наши предыдущие выпуски API, в которых мы можем планировать изменения поведения, которые часто привязаны к targetSdkVersion.
  • Мы планируем выпуск основного выпуска на квартал раньше (второй квартал, а не третий квартал в предыдущие годы), чтобы лучше согласовываться с графиком запуска устройств в нашей экосистеме, чтобы больше устройств могли получить основной выпуск Android раньше. Поскольку основной выпуск выйдет во втором квартале, вам нужно будет проводить ежегодное тестирование совместимости на несколько месяцев раньше, чем в предыдущие годы, чтобы убедиться, что ваши приложения готовы.
  • Мы планируем выпустить еще один выпуск в четвертом квартале 2025 года, который также будет включать новые API для разработчиков. Основной выпуск второго квартала станет единственным выпуском в 2025 году, включающим запланированные изменения в поведении, которые могут повлиять на приложения.

Помимо новых API-интерфейсов для разработчиков, второстепенный выпуск четвертого квартала будет содержать обновления функций, оптимизации и исправления ошибок; он не будет включать никаких изменений в поведении, влияющих на приложение.

Хронология выпусков Android в 2025 году с учетом того, что 25кв2        выпуск является основным выпуском, а выпуск 25Q4 — второстепенным выпуском.

Мы продолжим выпускать ежеквартальные выпуски Android. Обновления Q1 и Q3 между выпусками API будут предоставлять дополнительные обновления, которые помогут обеспечить постоянное качество. Мы активно работаем с нашими партнерами по устройствам, чтобы сделать выпуск Q2 доступным как можно большему количеству устройств.

Использование новых API с основными и второстепенными выпусками

Защита блока кода с помощью проверки уровня API сегодня осуществляется с использованием константы SDK_INT с помощью VERSION_CODES . Это будет по-прежнему поддерживаться в основных выпусках 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 еще не доработаны и могут быть изменены, поэтому, если у вас есть какие-либо вопросы, отправьте нам свой отзыв .

Пользовательский опыт и пользовательский интерфейс системы

Android 16 предоставляет разработчикам приложений и пользователям больше контроля и гибкости в настройке своих устройств в соответствии с их потребностями.

Уведомления, отслеживающие ход выполнения

Android 16 引入了以进度为中心的通知,可帮助用户顺畅地跟踪用户发起的端到端历程。

Notification.ProgressStyle 是一种新的通知样式,可让您创建以进度为中心的通知。主要用例包括共享车辆、送货和导航。在 Notification.ProgressStyle 类中,您可以使用细分来表示用户体验历程中的状态和里程碑。

To learn more, see the Progress-centric notifications documentation page.

Уведомление о ходе выполнения отображается на экране блокировки.
Уведомление, ориентированное на прогресс, отображается в тени уведомлений.

Прогнозируемые обновления задней панели

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.

Более насыщенные тактильные ощущения

Android has exposed control over the haptic actuator ever since its inception.

Android 11 added support for more complex haptic effects that more advanced actuators could support through VibrationEffect.Compositions of device-defined semantic primitives.

Android 16 adds haptic APIs that let apps define the amplitude and frequency curves of a haptic effect while abstracting away differences between device capabilities.

Инструменты и средства повышения производительности разработчиков

Хотя большая часть нашей работы по повышению вашей производительности сосредоточена на таких инструментах, как Android Studio , Jetpack Compose и библиотеки Android Jetpack , мы всегда ищем способы в рамках платформы помочь вам реализовать ваши замыслы.

Обработка контента для живых обоев

In Android 16, the live wallpaper framework is gaining a new content API to address the challenges of dynamic, user-driven wallpapers. Currently, live wallpapers incorporating user-provided content require complex, service-specific implementations. Android 16 introduces WallpaperDescription and WallpaperInstance. WallpaperDescription lets you identify distinct instances of a live wallpaper from the same service. For example, a wallpaper that has instances on both the home screen and on the lock screen may have unique content in both places. The wallpaper picker and WallpaperManager use this metadata to better present wallpapers to users, streamlining the process for you to create diverse and personalized live wallpaper experiences.

Производительность и батарея

В Android 16 представлены API, которые помогают собирать информацию о ваших приложениях.

Профилирование, запускаемое системой

ProfilingManager was added in Android 15, giving apps the ability to request profiling data collection using Perfetto on public devices in the field. However, since this profiling must be started from the app, critical flows such as startups or ANRs would be difficult or impossible for apps to capture.

To help with this, Android 16 introduces system-triggered profiling to ProfilingManager. Apps can register interest in receiving traces for certain triggers such as cold start reportFullyDrawn or ANRs, and then the system starts and stops a trace on the app's behalf. After the trace completes, the results are delivered to the app's data directory.

Компонент запуска в ApplicationStartInfo

ApplicationStartInfo was added in Android 15, allowing an app to see reasons for process start, start type, start times, throttling, and other useful diagnostic data. Android 16 adds getStartComponent() to distinguish what component type triggered the start, which can be helpful for optimizing the startup flow of your app.

Более глубокий самоанализ своей работы

The JobScheduler#getPendingJobReason() API returns a reason why a job might be pending. However, a job might be pending for multiple reasons.

In Android 16, we are introducing a new API JobScheduler#getPendingJobReasons(int jobId), which returns multiple reasons why a job is pending, due to both explicit constraints set by the developer and implicit constraints set by the system.

We're also introducing JobScheduler#getPendingJobReasonsHistory(int jobId), which returns a list of the most recent constraint changes.

We recommend using the API to help you debug why your jobs may not be executing, especially if you're seeing reduced success rates of certain tasks or have bugs around latency of certain job completion. For example, updating widgets in the background failed to occur or prefetch job failed to be called prior to app start.

This can also better help you understand if certain jobs are not completing due to system defined constraints versus explicitly set constraints.

Адаптивная частота обновления

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-интерфейсы для измерения запаса высоты в ADPF

SystemHealthManager представляет API-интерфейсы getCpuHeadroom и getGpuHeadroom , предназначенные для предоставления играм и ресурсоемким приложениям оценок доступных ресурсов ЦП и графического процессора. Эти методы позволяют вам оценить, как ваше приложение или игра могут наилучшим образом улучшить работоспособность системы, особенно при использовании в сочетании с другими API-интерфейсами Android Dynamic Performance Framework (ADPF), которые обнаруживают температурное регулирование .

Используя CpuHeadroomParams и GpuHeadroomParams на поддерживаемых устройствах, вы можете настроить временной интервал, используемый для расчета запаса, и выбрать среднюю или минимальную доступность ресурсов. Это может помочь вам соответственно сократить использование ресурсов ЦП или графического процессора, что приведет к улучшению пользовательского опыта и увеличению времени автономной работы.

Доступность

В Android 16 добавлены новые API и функции для обеспечения доступности, которые помогут вам сделать ваше приложение доступным для каждого пользователя.

Улучшены API для обеспечения доступности.

В Android 16 добавлены дополнительные API для улучшения семантики пользовательского интерфейса, которые помогают улучшить согласованность для пользователей, которые полагаются на службы специальных возможностей, такие как TalkBack .

Контурный текст для максимальной контрастности текста

У пользователей со слабым зрением часто снижена контрастная чувствительность, что затрудняет различение объектов на фоне. Чтобы помочь этим пользователям, в Android 16 вводится контурный текст, заменяющий высококонтрастный текст, который рисует вокруг текста более крупную контрастную область, что значительно улучшает читаемость.

Android 16 содержит новые API-интерфейсы AccessibilityManager , позволяющие вашим приложениям проверять или регистрировать прослушиватель, чтобы узнать, включен ли этот режим. В первую очередь это касается наборов UI Toolkit, таких как Compose, которые предлагают аналогичный визуальный опыт. Если вы поддерживаете библиотеку UI Toolkit или ваше приложение выполняет настраиваемую отрисовку текста в обход класса android.text.Layout , вы можете использовать это, чтобы узнать, включен ли контурный текст.

Текст с повышенной контрастностью до и после новой функции специальных возможностей контурного текста в Android 16

Длительность добавлена ​​в TtsSpan

Android 16 расширяет TtsSpan с помощью TYPE_DURATION , состоящего из ARG_HOURS , ARG_MINUTES и ARG_SECONDS . Это позволяет напрямую комментировать продолжительность времени, обеспечивая точное и согласованное преобразование текста в речь с помощью таких сервисов, как TalkBack .

Поддержка элементов с несколькими метками

В настоящее время Android позволяет элементам пользовательского интерфейса получать свою метку доступности из другой, а также теперь предлагает возможность связывания нескольких меток, что является распространенным сценарием в веб-контенте. Введя API на основе списков в AccessibilityNodeInfo , Android может напрямую поддерживать эти отношения с несколькими метками. В рамках этого изменения мы отказались от использования AccessibilityNodeInfo#setLabeledBy и #getLabeledBy в пользу #addLabeledBy , #removeLabeledBy и #getLabeledByList .

Улучшенная поддержка расширяемых элементов.

В Android 16 добавлены API специальных возможностей, которые позволяют передавать развернутое или свернутое состояние интерактивных элементов, таких как меню и расширяемые списки. Установив расширенное состояние с помощью setExpandedState и отправив TYPE_WINDOW_CONTENT_CHANGED AccessibilityEvents с типом изменения контента CONTENT_CHANGE_TYPE_EXPANDED , вы можете гарантировать, что программы чтения с экрана, такие как TalkBack , сообщают об изменениях состояния, обеспечивая более интуитивно понятный и инклюзивный пользовательский интерфейс.

Неопределенные индикаторы прогресса

В Android 16 добавлен RANGE_TYPE_INDETERMINATE , что дает вам возможность предоставлять RangeInfo как для определенных, так и для неопределенных виджетов ProgressBar , что позволяет таким сервисам, как TalkBack , более последовательно предоставлять обратную связь для индикаторов прогресса.

Флажок с тремя состояниями

Новые методы AccessibilityNodeInfo getChecked и setChecked(int) в Android 16 теперь поддерживают состояние «частично проверено» в дополнение к состояниям «проверено» и «не проверено». Это заменяет устаревшие логические значения isChecked и setChecked(boolean) .

Дополнительные описания

Когда служба доступности описывает ViewGroup , она объединяет метки контента из своих дочерних представлений. Если вы предоставляете contentDescription для ViewGroup , службы специальных возможностей предполагают, что вы также переопределяете описание нефокусируемых дочерних представлений. Это может быть проблематично, если вы хотите пометить элементы как раскрывающийся список (например, «Семейство шрифтов»), сохраняя при этом текущий выбор для доступности (например, «Робото»). В Android 16 добавлен setSupplementalDescription , чтобы вы могли предоставлять текст, предоставляющий информацию о ViewGroup , не переопределяя информацию от ее дочерних элементов.

Обязательные поля формы

В Android 16 добавлен setFieldRequired в AccessibilityNodeInfo , чтобы приложения могли сообщать службе специальных возможностей, что требуется ввести данные в поле формы. Это важный сценарий для пользователей, заполняющих многие типы форм, даже такие простые, как флажок «Обязательные положения и условия», помогающий пользователям последовательно идентифицировать и быстро перемещаться между необходимыми полями.

Использование телефона в качестве микрофона для голосовых вызовов при использовании слуховых аппаратов LEA.

В Android 16 пользователям слуховых аппаратов LE Audio добавлена ​​возможность переключаться между встроенными микрофонами слуховых аппаратов и микрофоном телефона для голосовых вызовов. Это может быть полезно в шумной обстановке или в других ситуациях, когда микрофоны слухового аппарата могут работать некорректно.

Регуляторы окружающего звука для слуховых аппаратов 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.

Камера

Android 16 расширяет поддержку профессиональных пользователей камер, позволяя использовать гибридную автоматическую экспозицию, а также точно настраивать цветовую температуру и оттенок. Новый индикатор ночного режима помогает приложению определять, когда следует переключаться между ночным и ночным режимами съемки. Новые действия Intent упрощают съемку движущихся изображений, и мы продолжаем улучшать изображения UltraHDR, добавляя поддержку кодирования HEIC и новых параметров из проекта стандарта ISO 21496-1.

Гибридная автоэкспозиция

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) ...
}

Точная настройка цветовой температуры и оттенка.

В Android 16 добавлена ​​поддержка камеры для точной настройки цветовой температуры и оттенков для лучшей поддержки профессиональных приложений для записи видео. В предыдущих версиях Android вы могли управлять настройками баланса белого с помощью CONTROL_AWB_MODE , который содержит параметры, ограниченные списком предустановок, таких как «Лампа накаливания» , «Облачно » и «Сумерки» . COLOR_CORRECTION_MODE_CCT позволяет использовать COLOR_CORRECTION_COLOR_TEMPERATURE и COLOR_CORRECTION_COLOR_TINT для точной настройки баланса белого на основе коррелированной цветовой температуры.

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) ...
}

В следующих примерах показано, как будет выглядеть фотография после применения различных настроек цветовой температуры и оттенка:

Исходное изображение без примененных настроек цветовой температуры или оттенка.
Изображение с цветовой температурой, настроенной на 3000.
Изображение с цветовой температурой, настроенной на 7000.


Изображение с уровнем оттенка, пониженным на 50.
Изображение с уровнем оттенка, увеличенным на 50.

Обнаружение сцены в ночном режиме камеры

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.

Действия, направленные на захват движущихся фотографий

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).

An example of a motion photo, showing the still image followed by the motion playback.

Улучшение изображения UltraHDR

An illustration of Standard Dynamic Range (SDR) versus High Dynamic Range (HDR) image quality.

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.

Графика

Android 16 включает в себя последние улучшения графики, такие как пользовательские графические эффекты с использованием AGSL.

Пользовательские графические эффекты с помощью AGSL

Android 16 adds RuntimeColorFilter and RuntimeXfermode, allowing you to author complex effects like Threshold, Sepia, and Hue Saturation and apply them to draw calls. Since Android 13, you've been able to use AGSL to create custom RuntimeShaders that extend Shader. The new API mirrors this, adding an AGSL-powered RuntimeColorFilter that extends ColorFilter, and a Xfermode effect that lets you implement AGSL-based custom compositing and blending between source and destination pixels.

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
}

Подключение

Обновление Android 16 предоставляет вашему приложению доступ к новейшим достижениям в области коммуникационных и беспроводных технологий.

Расширение зоны действия с повышенной безопасностью

В Android 16 добавлена ​​поддержка надежных функций безопасности при определении местоположения Wi-Fi на поддерживаемых устройствах с Wi-Fi 6 802.11az, что позволяет приложениям сочетать более высокую точность, большую масштабируемость и динамическое планирование протокола с улучшениями безопасности, включая AES-256. шифрование и защита от атак MITM. Это позволяет более безопасно использовать его в случаях, когда устройство находится вблизи, например, для разблокировки ноутбука или двери автомобиля. 802.11az интегрирован со стандартом Wi-Fi 6, используя его инфраструктуру и возможности для более широкого внедрения и упрощения развертывания.

Универсальные API для определения расстояния

Android 16 includes the new RangingManager, which provides ways to determine the distance and angle on supported hardware between the local device and a remote device. RangingManager supports the usage of a variety of ranging technologies such as BLE channel sounding, BLE RSSI-based ranging, Ultra Wideband, and Wi-Fi round trip time.

Сопутствующий менеджер устройств: наличие устройства

В Android 16 вводятся новые API для привязки службы вашего сопутствующего приложения. Служба будет привязана, когда BLE находится в зоне действия и Bluetooth подключен, и служба будет отвязана, когда BLE находится вне зоны действия или Bluetooth отключен. Приложение получит новый обратный вызов 'onDevicePresenceEvent()' на основе различных DevicePresenceEvent . Более подробную информацию можно найти в 'startObservingDevicePresence(ObservingDevicePresenceRequest)' .

СМИ

Android 16 включает в себя множество функций, улучшающих работу с мультимедиа.

Улучшения в инструменте выбора фотографий.

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.

Продвинутое профессиональное видео

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.

Конфиденциальность

Android 16 включает в себя множество функций, которые помогают разработчикам приложений защищать конфиденциальность пользователей.

Обновления Health Connect

Health Connect adds ACTIVITY_INTENSITY, a data type defined according to World Health Organization guidelines around moderate and vigorous activity. Each record requires the start time, the end time, and whether the activity intensity is moderate or vigorous.

Health Connect also contains updated APIs supporting medical records. This allows apps to read and write medical records in FHIR format with explicit user consent.

«Песочница конфиденциальности» на 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.

Безопасность

Android 16 включает в себя функции, которые помогут вам повысить безопасность вашего приложения и защитить его данные.

API для обмена ключами

Android 16 adds APIs that support sharing access to Android Keystore keys with other apps. The new KeyStoreManager class supports granting and revoking access to keys by app uid, and includes an API for apps to access shared keys.

форм-факторы устройств

Android 16 обеспечивает вашим приложениям поддержку, позволяющую максимально эффективно использовать возможности форм-факторов Android.

Стандартизированная система оценки качества изображения и звука для телевизоров.

Новый пакет MediaQuality в Android 16 предоставляет набор стандартизированных API-интерфейсов для доступа к профилям звука и изображения, а также настройкам, связанным с оборудованием. Это позволяет потоковым приложениям запрашивать профили и динамически применять их к мультимедиа:

  • Фильмы, снятые с более широким динамическим диапазоном, требуют большей точности цветопередачи, чтобы увидеть тонкие детали в тенях и адаптироваться к окружающему освещению, поэтому может подойти профиль, который предпочитает точность цветопередачи яркости.
  • Прямые трансляции спортивных событий часто создаются с узким динамическим диапазоном, но их часто смотрят при дневном свете, поэтому профиль, в котором яркость предпочтительнее точности цветопередачи, может дать лучшие результаты.
  • Полностью интерактивный контент требует минимальной обработки для уменьшения задержки и более высокой частоты кадров, поэтому многие телевизоры поставляются с игровым профилем.

API позволяет приложениям переключаться между профилями, а пользователи могут наслаждаться настройкой поддерживаемых телевизоров в соответствии с их контентом.

Интернационализация

Android 16 добавляет функции и возможности, которые улучшают пользовательский опыт при использовании устройства на разных языках.

Вертикальный текст

В Android 16 добавлена ​​низкоуровневая поддержка вертикального рендеринга и измерения текста, чтобы обеспечить базовую поддержку вертикального письма для разработчиков библиотек. Это особенно полезно для таких языков, как японский, в которых обычно используются вертикальные системы письма. В класс Paint добавлен новый флаг VERTICAL_TEXT_FLAG . Когда этот флаг установлен с помощью Paint.setFlags , API измерения текста Paint будут сообщать о вертикальном перемещении вместо горизонтального, а Canvas будет рисовать текст вертикально.

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
            )
        }
    }
) {}

Настройка измерительной системы

Users can now customize their measurement system in regional preferences within Settings. The user preference is included as part of the locale code, so you can register a BroadcastReceiver on ACTION_LOCALE_CHANGED to handle locale configuration changes when regional preferences change.

Using formatters can help match the local experience. For example, "0.5 in" in English (United States), is "12,7 mm" for a user who has set their phone to English (Denmark) or who uses their phone in English (United States) with the metric system as the measurement system preference.

To find these settings, open the Settings app and navigate to System > Languages & region.