Recursos e APIs

O Android 16 introduz ótimos recursos e APIs novos para desenvolvedores. As seções a seguir resumem esses recursos para ajudar você a começar a usar as APIs relacionadas.

Para uma lista detalhada das APIs novas, modificadas e removidas, leia o Relatório de diferenças da API. Para saber mais sobre as novas APIs, acesse a Referência da API do Android. As novas APIs estão em destaque para facilitar a visualização.

Também é importante analisar as áreas em que as mudanças na plataforma podem afetar seus apps. Para mais informações, consulte as seguintes páginas:

Principal recurso

O Android inclui novas APIs que ampliam os recursos principais do sistema.

Duas versões da API do Android em 2025

  • Esta visualização é para a próxima versão principal do Android, com lançamento previsto no segundo trimestre de 2025. Esta versão é semelhante a todas as versões de API do passado, em que podemos ter mudanças de comportamento planejadas que geralmente são vinculadas a uma targetSdkVersion.
  • Estamos planejando o lançamento principal um trimestre antes (segundo trimestre em vez do terceiro trimestre em anos anteriores) para alinhar melhor com a programação de lançamentos de dispositivos em todo o ecossistema, para que mais dispositivos possam receber a versão principal do Android mais cedo. Com o lançamento principal no segundo trimestre, você precisará fazer o teste anual de compatibilidade alguns meses antes do que nos anos anteriores para garantir que seus apps estão prontos.
  • Planejamos lançar outra versão no 4º trimestre de 2025, que também vai incluir novas APIs para desenvolvedores. A versão principal do segundo trimestre será a única em 2025 a incluir mudanças de comportamento planejadas que podem afetar apps.

Além das novas APIs para desenvolvedores, a versão secundária do Q4 vai incluir atualizações de recursos, otimizações e correções de bugs. Ela não vai incluir mudanças de comportamento que afetam o app.

Visualização da linha do tempo das versões do Android em 2025. A versão 25Q2
       é uma versão principal e a 25Q4 é uma versão secundária.

Vamos continuar lançando versões do Android trimestralmente. As atualizações do Q1 e do Q3 entre as versões da API vão oferecer atualizações incrementais para ajudar a garantir qualidade contínua. Estamos trabalhando ativamente com nossos parceiros de dispositivos para disponibilizar a versão do segundo trimestre no maior número possível de dispositivos.

Como usar novas APIs com versões principais e secundárias

Hoje, a proteção de um bloco de código com uma verificação do nível da API é feita usando a constante SDK_INT com VERSION_CODES. Esse suporte vai continuar sendo oferecido para as principais versões do Android.

if (SDK_INT >= VERSION_CODES.BAKLAVA) {
  // Use APIs introduced in Android 16
}

A nova constante SDK_INT_FULL pode ser usada para verificações de API em relação a versões principais e secundárias com a nova enumeração VERSION_CODES_FULL.

if (SDK_INT_FULL >= VERSION_CODES_FULL.[MAJOR or MINOR RELEASE]) {
  // Use APIs introduced in a major or minor release
}

Você também pode usar o método Build.getMinorSdkVersion() para acessar apenas a versão secundária do SDK.

val minorSdkVersion = Build.getMinorSdkVersion(VERSION_CODES_FULL.BAKLAVA)

Essas APIs ainda não foram finalizadas e estão sujeitas a alterações. Envie feedback se tiver alguma dúvida.

Experiência do usuário e interface do sistema

O Android 16 oferece aos desenvolvedores e usuários de apps mais controle e flexibilidade para configurar o dispositivo de acordo com as necessidades.

Notificações com foco no progresso

O Android 16 apresenta notificações com foco no progresso para ajudar os usuários a acompanhar as jornadas iniciadas pelo usuário do início ao fim.

Notification.ProgressStyle é um novo estilo de notificação que permite criar notificações com foco no progresso. Os principais casos de uso incluem compartilhamento de viagens, entrega e navegação. Na classe Notification.ProgressStyle, é possível denotar estados e marcos em uma jornada do usuário usando pontos e segmentos.

Para saber mais, consulte a página de documentação Notificações centradas no progresso.

Uma notificação focada no progresso exibida na tela de bloqueio.
Uma notificação focada no progresso exibida na aba de notificações.

Atualizações de volta preditiva

O Android 16 adiciona novas APIs para ajudar a ativar animações de volta preditiva do sistema na navegação por gestos, como a animação de volta à tela inicial. Registrar o onBackInvokedCallback com o novo PRIORITY_SYSTEM_NAVIGATION_OBSERVER permite que o app receba a chamada onBackInvoked normal sempre que o sistema processa uma navegação de retorno sem afetar o fluxo normal de navegação de retorno.

O Android 16 também adiciona o finishAndRemoveTaskCallback() e o moveTaskToBackCallback. Ao registrar esses callbacks com o OnBackInvokedDispatcher, o sistema pode acionar comportamentos específicos e reproduzir animações antecipadas correspondentes quando o gesto de voltar é invocado.

Retorno tátil mais completo

O Android expõe o controle do atuador háptico desde o início.

O Android 11 adicionou suporte a efeitos hápticos mais complexos que atuadores mais avançados podem oferecer com VibrationEffect.Compositions de primitivas semânticas definidas pelo dispositivo.

O Android 16 adiciona APIs hápticas que permitem que os apps definam as curvas de amplitude e frequência de um efeito háptico, abstraindo as diferenças entre os recursos do dispositivo.

Produtividade e ferramentas para desenvolvedores

Embora a maior parte do nosso trabalho para melhorar a produtividade se concentre em ferramentas como Android Studio, Jetpack Compose e as bibliotecas do Android Jetpack, sempre procuramos maneiras de usar a plataforma para ajudar você a realizar sua visão.

Processamento de conteúdo para planos de fundo interativos

在 Android 16 中,动态壁纸框架将获得一个新的 content API,以应对由用户驱动的动态壁纸带来的挑战。目前,包含用户提供的内容的实时壁纸需要复杂的服务专用实现。Android 16 引入了 WallpaperDescriptionWallpaperInstance。借助 WallpaperDescription,您可以识别同一服务中的动态壁纸的不同实例。例如,如果某张壁纸同时在主屏幕和锁定屏幕上显示,则这两种情况下显示的内容可能各不相同。壁纸选择器和 WallpaperManager 会使用此元数据更好地向用户呈现壁纸,从而简化创建多样化个性化动态壁纸体验的过程。

Desempenho e bateria

O Android 16 apresenta APIs que ajudam a coletar insights sobre seus apps.

Criação de perfis acionados pelo sistema

ProfilingManager 在 Android 15 中添加,让应用能够在现场使用 Perfetto 请求收集性能数据。不过,由于此性能分析必须从应用启动,因此应用很难或根本无法捕获启动或 ANR 等关键流程。

为此,Android 16 向 ProfilingManager 引入了系统触发的性能分析。应用可以注册接收特定触发器(例如冷启动 reportFullyDrawn 或 ANR)轨迹的兴趣,然后系统会代表应用启动和停止轨迹。轨迹完成后,结果会传送到应用的数据目录。

Iniciar o componente no ApplicationStartInfo

ApplicationStartInfo foi adicionado no Android 15, permitindo que um app mostre os motivos para a inicialização do processo, o tipo de inicialização, os horários de inicialização, o controle de demanda e outros dados de diagnóstico úteis. O Android 16 adiciona getStartComponent() para distinguir qual tipo de componente acionou a inicialização, o que pode ser útil para otimizar o fluxo de inicialização do app.

Melhor introspecção de trabalho

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.

Taxa de atualização adaptativa

Android 15 中引入的自适应刷新率 (ARR) 可让受支持硬件上的显示屏刷新率使用离散的 VSync 步长来适应内容帧速率。这不仅降低了功耗,还无需进行可能导致卡顿的模式切换。

Android 16 引入了 hasArrSupport()getSuggestedFrameRate(int),同时恢复了 getSupportedRefreshRates(),以便您的应用更轻松地利用 ARR。RecyclerView 1.4从快速滑动或平滑滚动中稳定下来时会在内部支持 ARR,我们将继续努力,将 ARR 支持添加到更多 Jetpack 库中。这篇帧速率文章介绍了许多可用于设置帧速率的 API,以便您的应用可以直接使用 ARR。

APIs de headroom no ADPF

O SystemHealthManager apresenta as APIs getCpuHeadroom e getGpuHeadroom, projetadas para fornecer jogos e apps com uso intensivo de recursos com estimativas de recursos disponíveis de CPU e GPU. Esses métodos oferecem uma maneira de avaliar como seu app ou jogo pode melhorar a integridade do sistema, principalmente quando usado com outras APIs do Android Dynamic Performance Framework (ADPF, na sigla em inglês) que detectam o throttling térmico.

Ao usar CpuHeadroomParams e GpuHeadroomParams em dispositivos compatíveis, você pode personalizar a janela de tempo usada para calcular o headroom e selecionar a disponibilidade de recursos média ou mínima. Isso pode ajudar a reduzir o uso de recursos da CPU ou da GPU, o que leva a uma melhor experiência do usuário e à melhoria da duração da bateria.

Acessibilidade

O Android 16 adiciona novas APIs e recursos de acessibilidade que podem ajudar a oferecer seu app a todos os usuários.

APIs de acessibilidade aprimoradas

O Android 16 adiciona APIs adicionais para melhorar a semântica da interface, o que ajuda a melhorar a consistência para usuários que dependem de serviços de acessibilidade, como o TalkBack.

Duração adicionada ao TtsSpan

O Android 16 estende TtsSpan com um TYPE_DURATION, que consiste em ARG_HOURS, ARG_MINUTES e ARG_SECONDS. Isso permite anotar diretamente a duração do tempo, garantindo uma saída de texto para fala precisa e consistente com serviços como o TalkBack.

Suporte a elementos com vários rótulos

Atualmente, o Android permite que elementos da interface derivem o rótulo de acessibilidade de outro e agora oferece a capacidade de associar vários rótulos, um cenário comum no conteúdo da Web. Ao introduzir uma API baseada em lista em AccessibilityNodeInfo, o Android pode oferecer suporte direto a essas relacionamentos com vários rótulos. Como parte dessa mudança, suspendemos o uso de AccessibilityNodeInfo#setLabeledBy e #getLabeledBy em favor de #addLabeledBy, #removeLabeledBy e #getLabeledByList.

Melhoria no suporte a elementos expansíveis

O Android 16 adiciona APIs de acessibilidade que permitem transmitir o estado aberto ou recolhido de elementos interativos, como menus e listas expansíveis. Ao definir o estado expandido usando setExpandedState e enviar TYPE_WINDOW_CONTENT_CHANGED AccessibilityEvents com um tipo de mudança de conteúdo CONTENT_CHANGE_TYPE_EXPANDED, é possível garantir que leitores de tela como o TalkBack anunciem mudanças de estado, oferecendo uma experiência do usuário mais intuitiva e inclusiva.

Barras de progresso indeterminadas

O Android 16 adiciona RANGE_TYPE_INDETERMINATE, oferecendo uma maneira de exibir RangeInfo para widgets ProgressBar determinados e indeterminados, permitindo que serviços como o TalkBack forneçam feedback mais consistente para indicadores de progresso.

Caixa de seleção de três estados

Os novos métodos AccessibilityNodeInfo getChecked e setChecked(int) no Android 16 agora oferecem suporte a um estado "parcialmente verificado", além de "verificado" e "não verificado". Isso substitui os booleanos isChecked e setChecked(boolean), que foram descontinuados.

Descrições complementares

Quando um serviço de acessibilidade descreve um ViewGroup, ele combina marcadores de conteúdo das visualizações filhas. Se você fornecer um contentDescription para o ViewGroup, os serviços de acessibilidade vão assumir que você também está substituindo a descrição de visualizações filhas não focalizáveis. Isso pode ser um problema se você quiser rotular itens como um menu suspenso (por exemplo, "Família de fontes") e preservar a seleção atual para acessibilidade (por exemplo, "Roboto"). O Android 16 adiciona setSupplementalDescription para que você possa fornecer texto que ofereça informações sobre um ViewGroup sem substituir as informações dos filhos.

Campos obrigatórios do formulário

O Android 16 adiciona setFieldRequired a AccessibilityNodeInfo para que os apps possam informar a um serviço de acessibilidade que a entrada em um campo de formulário é obrigatória. Esse é um cenário importante para os usuários que preenchem muitos tipos de formulários, mesmo coisas simples como uma caixa de seleção de termos e condições, ajudando os usuários a identificar e navegar rapidamente entre os campos obrigatórios.

O smartphone como entrada de microfone para ligações com aparelhos auditivos de LEA

O Android 16 adiciona a capacidade de usuários de aparelhos auditivos de áudio LE alternarem entre os microfones integrados nos aparelhos auditivos e o microfone no smartphone para ligações. Isso pode ser útil em ambientes barulhentos ou em outras situações em que os microfones do aparelho auditivo não funcionam bem.

Controles de volume de ambiente para aparelhos auditivos LEA

O Android 16 adiciona a capacidade de os usuários de aparelhos auditivos de áudio LE ajustarem o volume do som ambiente captado pelos microfones do aparelho. Isso pode ser útil em situações em que o ruído de fundo está muito alto ou muito baixo.

Câmera

O Android 16 aprimora o suporte a usuários de câmeras profissionais, permitindo a exposição automática híbrida, além de ajustes precisos de temperatura de cor e tonalidade. Um novo indicador de modo noturno ajuda o app a saber quando alternar para e de uma sessão de câmera no modo noturno. As novas ações Intent facilitam a captura de fotos em movimento. Continuamos melhorando as imagens UltraHDR com suporte à codificação HEIC e novos parâmetros do rascunho da norma ISO 21496-1.

Exposição automática híbrida

O Android 16 adiciona novos modos híbridos de exposição automática à Camera2, permitindo que você controle manualmente aspectos específicos da exposição enquanto deixa o algoritmo de exposição automática (AE, na sigla em inglês) cuidar do restante. É possível controlar ISO + AE e tempo de exposição + AE, oferecendo maior flexibilidade em comparação com a abordagem atual, em que você tem controle manual total ou depende totalmente da exposição automática.

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

Ajustes precisos de temperatura e matiz de cor

Android 16 增加了对相机的精细色温和色调调整的支持,以更好地支持专业视频录制应用。在较低版本的 Android 中,您可以通过 CONTROL_AWB_MODE 控制白平衡设置,其中包含仅限于预设列表的选项,例如白炽灯多云黄昏COLOR_CORRECTION_MODE_CCT 可让您使用 COLOR_CORRECTION_COLOR_TEMPERATURECOLOR_CORRECTION_COLOR_TINT 根据相关色温精确调整白平衡。

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

以下示例展示了应用不同色温和色调调整后的照片效果:

未应用色温或色调调整的原始图片。
将色温调整为 3000 的图片。
将色温调整为 7000 的图片。


将色调级别降低 50 的图片。
色调级别提高了 50 的图片。

Detecção de cena do modo noturno da câmera

为了帮助应用了解何时切换到夜间模式相机会话以及何时从夜间模式相机会话切换出,Android 16 添加了 EXTENSION_NIGHT_MODE_INDICATOR。如果受支持,则可在 Camera2 内的 CaptureResult 中使用。

这是我们在Instagram 如何让用户拍出令人惊艳的低光照片博文中提到的即将推出的 API。该博文提供了有关如何实现夜间模式的实用指南,并附有一份案例研究,该案例研究将应用内夜间模式照片质量的提升与通过应用内相机分享的照片数量的增加联系起来。

Ações de intent de captura de fotos com movimento

O Android 16 adiciona ações padrão da intent, ACTION_MOTION_PHOTO_CAPTURE e ACTION_MOTION_PHOTO_CAPTURE_SECURE, que solicitam que o aplicativo de câmera capture e retorne uma foto com movimento.

É necessário transmitir um EXTRA_OUTPUT extra para controlar onde a imagem será gravada ou um Uri por Intent.setClipData(ClipData). Se você não definir um ClipData, ele será copiado para você ao chamar Context.startActivity(Intent).

Exemplo de uma foto com movimento, mostrando a imagem estática seguida pela reprodução do movimento.

Melhorias de imagem UltraHDR

标准动态范围 (SDR) 与高动态范围 (HDR) 图片质量对比示意图。

Android 16 继续致力于通过 UltraHDR 图片提供出色的图片质量。它添加了对 HEIC 文件格式的 UltraHDR 图片的支持。这些图片将获得 ImageFormat 类型 HEIC_ULTRAHDR,并包含类似于现有 UltraHDR JPEG 格式的嵌入式增益图。我们还在努力为 UltraHDR 添加 AVIF 支持,敬请期待。

此外,Android 16 在 UltraHDR 中实现了 ISO 21496-1 草稿标准中的其他参数,包括能够获取和设置应应用增益图算法的色彩空间,以及支持使用 SDR 增益图的 HDR 编码基础图片。

Gráficos

O Android 16 inclui as melhorias gráficas mais recentes, como efeitos gráficos personalizados com AGSL.

Efeitos gráficos personalizados com a AGSL

O Android 16 adiciona RuntimeColorFilter e RuntimeXfermode, permitindo que você crie efeitos complexos, como Threshold, Sepia e Hue Saturation, e os aplique a chamadas de exibição. Desde o Android 13, é possível usar a AGSL para criar RuntimeShaders personalizados que estendem Shader. A nova API reflete isso, adicionando um RuntimeColorFilter com tecnologia AGSL que amplia ColorFilter e um efeito Xfermode que permite implementar a composição e a mesclagem personalizadas com base na AGSL entre os pixels de origem e de destino.

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
}

Conectividade

O Android 16 atualiza a plataforma para dar ao app acesso aos avanços mais recentes em comunicação e tecnologias sem fio.

Faixa de alcance com segurança reforçada

O Android 16 adiciona suporte a recursos de segurança robustos na localização do Wi-Fi em dispositivos com suporte ao 802.11az do Wi-Fi 6, permitindo que os apps combinem a maior precisão, maior escalonabilidade e programação dinâmica do protocolo com aprimoramentos de segurança, incluindo criptografia baseada em AES-256 e proteção contra ataques MITM. Isso permite que ele seja usado com mais segurança em casos de uso de proximidade, como desbloquear um laptop ou uma porta de veículo. O 802.11az é integrado ao padrão Wi-Fi 6, aproveitando a infraestrutura e os recursos dele para uma adoção mais ampla e uma implantação mais fácil.

APIs genéricas de medição de distância

O Android 16 inclui o novo RangingManager, que oferece maneiras de determinar a distância e o ângulo no hardware com suporte entre o dispositivo local e um dispositivo remoto. O RangingManager oferece suporte ao uso de várias tecnologias de medição, como a detecção de canal BLE, a medição baseada em RSSI BLE, a banda ultralarga e o tempo de ida e volta do Wi-Fi.

Mídia

O Android 16 inclui vários recursos que melhoram a experiência de mídia.

Melhorias no seletor de fotos

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.

Vídeo profissional avançado

O Android 16 apresenta suporte ao codec Advanced Professional Video (APV, na sigla em inglês), que foi projetado para ser usado em gravação de vídeo e pós-produção de alta qualidade de nível profissional.

O padrão de codec APV tem os seguintes recursos:

  • Qualidade de vídeo sem perdas perceptível (próxima da qualidade de vídeo bruto)
  • Baixa complexidade e codificação intra-frame com alto throughput (sem previsão de domínio de pixels) para melhor suporte a fluxos de trabalho de edição
  • Suporte a um intervalo de taxa de bits alto de até alguns Gbps para conteúdo de resolução 2K, 4K e 8K, ativado por um esquema de codificação de entropia leve
  • Dividir o frame em blocos para conteúdo imersivo e ativar a codificação e decodificação paralelas
  • Suporte a vários formatos de amostragem de cromatismo e profundidades de bits
  • Suporte a várias decodificações e recodificações sem degradação severa da qualidade visual
  • Oferecer suporte a vídeos com várias visualizações e vídeos auxiliares, como profundidade, Alfa e visualização
  • Suporte a HDR10/10+ e metadados definidos pelo usuário

Uma implementação de referência do APV é fornecida pelo projeto OpenAPV. O Android 16 vai implementar suporte ao perfil APV 422-10, que oferece amostragem de cores YUV 422 com codificação de 10 bits e para taxas de bits de destino de até 2 Gbps.

Privacidade

O Android 16 inclui vários recursos que ajudam os desenvolvedores de apps a proteger a privacidade do usuário.

Atualizações do app Conexão Saúde

Health Connect in the developer preview adds ACTIVITY_INTENSITY, a new 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 health records. This allows apps to read and write medical records in FHIR format with explicit user consent. This API is in an early access program. If you'd like to participate, sign up to be part of our early access program.

Sandbox de privacidade no 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.

Segurança

O Android 16 inclui recursos que ajudam a melhorar a segurança e proteger os dados do app.

API de compartilhamento de chaves

O Android 16 adiciona APIs que oferecem suporte ao compartilhamento de acesso a chaves do Keystore do Android com outros apps. A nova classe KeyStoreManager oferece suporte a acesso e revogação de chaves por uid do app e inclui uma API para que os apps acessem chaves compartilhadas.

Formatos de dispositivo

O Android 16 oferece suporte aos seus apps para aproveitar ao máximo os formatos do Android.

Estrutura padronizada de qualidade de imagem e áudio para TVs

Android 16 中的新 MediaQuality 软件包公开了一组标准化 API,用于访问音频和图片配置文件以及与硬件相关的设置。这样,在线播放应用就可以查询配置文件并将其动态应用于媒体:

  • 使用更大动态范围进行母版制作的电影需要更高的色彩准确度,才能看清阴影中的细微细节并根据环境光线进行调整,因此,最好使用色彩准确度优先于亮度的配置文件。
  • 体育赛事直播通常采用较窄的动态范围进行母版制作,但通常是在白天观看,因此偏向亮度而非色彩准确度的配置文件可以获得更好的效果。
  • 完全交互式内容需要尽可能减少处理以缩短延迟时间,并且需要更高的帧速率,因此许多电视都附带游戏配置文件。

借助此 API,应用可以在个人资料之间切换,用户可以享受调整支持的电视,以便尽可能适合其内容。

Internacionalização

O Android 16 adiciona recursos e capacidades que complementam a experiência do usuário quando um dispositivo é usado em diferentes idiomas.

Texto vertical

O Android 16 adiciona suporte de baixo nível para renderização e medição de texto verticalmente para oferecer suporte básico de escrita vertical para desenvolvedores de bibliotecas. Isso é especialmente útil para idiomas como o japonês, que costumam usar sistemas de escrita vertical. Uma nova flag, VERTICAL_TEXT_FLAG, foi adicionada à classe Paint. Quando essa flag é definida usando Paint.setFlags, as APIs de medição de texto do Paint vão informar avanços verticais em vez de horizontais, e Canvas vai desenhar o texto verticalmente.

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

Personalização do sistema de medição

Os usuários agora podem personalizar o sistema de medição nas preferências regionais nas Configurações. A preferência do usuário é incluída como parte do código de localidade. Assim, é possível registrar um BroadcastReceiver em ACTION_LOCALE_CHANGED para processar mudanças de configuração de localidade quando as preferências regionais mudarem.

O uso de formatadores pode ajudar a corresponder à experiência local. Por exemplo, "0,5 pol" em inglês (Estados Unidos) é "12,7 mm" para um usuário que definiu o smartphone como inglês (Dinamarca) ou que usa o smartphone em inglês (Estados Unidos) com o sistema métrico como a preferência de sistema de medição.

Para encontrar essas configurações, abra o app Configurações e navegue até Sistema > Idiomas e região.