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 ver detalhes sobre as novas APIs, acesse a Referência da API do Android. As APIs novas estão em destaque para melhor visibilidade.

Você também precisa 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 expandem os recursos principais do sistema Android.

Dois lançamentos de APIs do Android em 2025

  • 此预览版适用于 Android 的下一个主要版本,计划于 2025 年第 2 季度发布。此版本与我们过去的所有 API 版本类似,我们可以进行计划性的行为更改,这些更改通常与 targetSdkVersion 相关联。
  • 我们计划提前一个季度(2021 年第 2 季度,而非之前的第 3 季度)发布主要版本,以便更好地与整个生态系统中的设备发布时间表保持一致,让更多设备能够更早地搭载 Android 主要版本。由于主要版本将于第 2 季度发布,因此您需要比往年提前几个月进行年度兼容性测试,以确保您的应用已做好准备。
  • 我们计划在 2025 年第 4 季度再发布一次,届时还将推出新的开发者 API。2025 年只有第二季度的主要版本包含可能影响应用的计划行为变更。

除了新的开发者 API 之外,第 4 季度次要版本还将包含功能更新、优化和 bug 修复;其中不会包含任何会影响应用的行为变更。

2025 年 Android 版本的时间轴视图,请注意,25Q2 版本是一个主要版本,25Q4 版本是一个次要版本。

我们将继续每季度发布 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 尚未最终确定,可能会发生变化,因此如果您有任何疑虑,请向我们发送反馈

Experiência do usuário e interface do sistema

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

Notificações focadas no progresso

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

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

如需了解详情,请参阅以进度为中心的通知文档页面。

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 avançado

自诞生之日起,Android 就提供了对触感反馈致动器的控制。

Android 11 添加了对更复杂的触感反馈效果的支持,更高级的致动器可以通过设备定义的语义基元 VibrationEffect.Compositions 支持这些效果。

Android 16 添加了触感反馈 API,让应用能够定义触感反馈效果的振幅和频率曲线,同时抽象出设备功能之间的差异。

Produtividade e ferramentas para desenvolvedores

Embora a maior parte do nosso trabalho para melhorar sua produtividade se concentre em ferramentas como o Android Studio, o Jetpack Compose e as bibliotecas do Android Jetpack, sempre buscamos maneiras na plataforma de 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 acionada pelo sistema

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

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

Iniciar componente em 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 tarefas

JobScheduler#getPendingJobReason() API 会返回作业可能处于待处理状态的原因。不过,作业处于待处理状态的原因可能有多种。

在 Android 16 中,我们引入了一个新 API JobScheduler#getPendingJobReasons(int jobId),该 API 会返回作业处于待处理状态的多种原因,包括开发者设置的显式约束条件和系统设置的隐式约束条件。

我们还引入了 JobScheduler#getPendingJobReasonsHistory(int jobId),用于返回最新约束条件更改的列表。

我们建议您使用该 API 来调试作业可能无法执行的原因,尤其是在您发现某些任务的成功率降低或某些作业完成延迟存在 bug 时。例如,未能在后台更新微件,或在应用启动之前未能调用预加载作业。

这还有助于您更好地了解某些作业是否因系统定义的约束条件而无法完成,而不是因明确设置的约束条件而无法完成。

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 na 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 você a levar seu app para 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.

Contorno do texto para máximo contraste

Os usuários com visão reduzida geralmente têm sensibilidade reduzida ao contraste, o que dificulta a distinção de objetos do plano de fundo. Para ajudar esses usuários, o Android 16 apresenta texto com contorno, substituindo o texto de alto contraste, que desenha uma área de contraste maior ao redor do texto para melhorar muito a legibilidade.

O Android 16 tem novas APIs AccessibilityManager para permitir que os apps verifiquem ou registrem um listener para verificar se esse modo está ativado. Isso é principalmente para que kits de ferramentas de interface, como o Compose, ofereçam uma experiência visual semelhante. Se você mantém uma biblioteca do kit de ferramentas de IU ou se o app executa renderização de texto personalizada que ignora a classe android.text.Layout, use isso para saber quando o texto de contorno está ativado.

Texto com contraste aprimorado antes e depois do novo recurso de acessibilidade de texto com contorno do Android 16

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

Smartphone como entrada de microfone para ligações com aparelhos auditivos 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 ambiente para aparelhos auditivos LEA

Android 16 新增了一项功能,可让 LE Audio 助听器用户调节助听器麦克风接收的环境声音的音量。在背景噪音过大或过小的情况下,这可能会很有用。

Câmera

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

Exposição automática híbrida

Android 16 向 Camera2 添加了新的混合自动曝光模式,让您可以手动控制曝光的特定方面,同时让自动曝光 (AE) 算法处理其余部分。您可以控制 ISO + AE曝光时间 + AE,与当前方法(您要么完全手动控制,要么完全依赖自动曝光)相比,可提供更大的灵活性。

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

Ajustes precisos de temperatura da cor e tonalidade

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

Detecção de cena no 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

Ilustração da qualidade de imagem do intervalo dinâmico padrão (SDR) em comparação com o intervalo dinâmico alto (HDR).

O Android 16 continua nosso trabalho para oferecer uma qualidade de imagem incrível com imagens UltraHDR. Ele adiciona suporte a imagens UltraHDR no formato de arquivo HEIC. Essas imagens vão receber o tipo ImageFormat HEIC_ULTRAHDR e vão conter um mapa de ganho incorporado semelhante ao formato JPEG UltraHDR. Também estamos trabalhando no suporte a AVIF para UltraHDR. Fique de olho.

Além disso, o Android 16 implementa outros parâmetros no UltraHDR do draft standard ISO 21496-1 (link em inglês), incluindo a capacidade de receber e definir o espaço de cor em que a matemática do mapa de ganho precisa ser aplicada, além de suportar imagens de base codificadas em HDR com mapas de ganho SDR.

Gráficos

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

Efeitos gráficos personalizados com 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 seu app acesso aos avanços mais recentes em tecnologias de comunicação e sem fio.

Intervalo com segurança reforçada

Android 16 在搭载 Wi-Fi 6 的 802.11az 的受支持设备上为 Wi-Fi 位置信息添加了对强大的安全功能的支持,让应用能够将该协议的更高精确性、更高可伸缩性和动态调度与安全增强功能(包括基于 AES-256 的加密和防范中间人攻击)相结合。这样,在近距离使用情形(例如解锁笔记本电脑或车门)时,便可更安全地使用该功能。802.11az 与 Wi-Fi 6 标准集成,可利用其基础架构和功能实现更广泛的采用和更轻松的部署。

APIs de intervalo genéricas

Android 16 包含新的 RangingManager,它提供了在受支持的硬件上确定本地设备与远程设备之间的距离和角度的方法。RangingManager 支持使用各种测距技术,例如 BLE 信道声音探测、基于 BLE RSSI 的测距、超宽带和 Wi-Fi 往返时间。

Presença de dispositivo no gerenciador de dispositivos complementares

Android 16 中引入了用于绑定配套应用服务的新 API。当 BLE 在范围内且蓝牙处于连接状态时,系统会绑定服务;当 BLE 不在范围内或蓝牙处于断开连接状态时,系统会解除绑定服务。应用将根据各种 DevicePresenceEvent 收到新的 'onDevicePresenceEvent()' 回调。如需了解详情,请参阅 'startObservingDevicePresence(ObservingDevicePresenceRequest)'

Mídia

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

Melhorias no seletor de fotos

O seletor de fotos oferece uma maneira segura e integrada para os usuários concederem ao app acesso a imagens e vídeos selecionados do armazenamento local e da nuvem, em vez de toda a biblioteca de mídia. Usando uma combinação de componentes modulares do sistema pelas Atualizações do sistema do Google e os Serviços do Google Play, ele tem suporte ao Android 4.4 (nível 19 da API). A integração requer apenas algumas linhas de código com a biblioteca Android Jetpack associada.

O Android 16 inclui as seguintes melhorias no seletor de fotos:

  • Seletor de fotos incorporado: novas APIs que permitem que os apps incorporem o seletor de fotos à hierarquia de visualização. Isso permite que ela pareça uma parte mais integrada do app, aproveitando o isolamento de processos que permite que os usuários selecionem mídia sem que o app precise de permissões muito amplas. Para maximizar a compatibilidade entre as versões da plataforma e simplificar a integração, use a próxima biblioteca Jetpack do Android se quiser integrar o seletor de fotos incorporado.
  • Pesquisa na nuvem no seletor de fotos: novas APIs que permitem a pesquisa do provedor de mídia na nuvem para o seletor de fotos do Android. A funcionalidade de pesquisa no seletor de fotos será lançada em breve.

Vídeo profissional avançado

Android 16 引入了对高级专业视频 (APV) 编解码器的支持,该编解码器专为专业级高品质视频录制和后期制作而设计。

APV 编解码器标准具有以下特点:

  • 感知上无损的视频画质(接近原始视频画质)
  • 复杂度低且吞吐量高的仅帧内编码(无像素域预测),以更好地支持编辑工作流
  • 支持高比特率范围(最高几十 Gbps),适用于 2K、4K 和 8K 分辨率内容,由轻量级熵编码方案实现
  • 帧平铺,用于沉浸式内容和启用并行编码和解码
  • 支持各种色度采样格式和位深
  • 支持多次解码和重新编码,且不会严重降低视觉质量
  • 支持多视图视频和辅助视频,例如深度、Alpha 和预览
  • 支持 HDR10/10+ 和用户定义的元数据

OpenAPV 项目提供了 APV 的参考实现。Android 16 将实现对 APV 422-10 配置文件的支持,该配置文件提供 YUV 422 色彩采样以及 10 位编码,并且目标比特率最高可达 2 Gbps。

Privacidade

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

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

Health Connect 添加了 ACTIVITY_INTENSITY,这是一种根据世界卫生组织关于中等强度和剧烈强度活动的指南定义的数据类型。每个记录都需要提供开始时间、结束时间以及活动强度(中等或剧烈)。

Health Connect 还包含支持医疗记录的更新版 API。这样一来,应用便可在征得用户明确同意的情况下,读取和写入 FHIR 格式的医疗记录。

Sandbox de privacidade no Android

Android 16 中集成了最新版本的 Privacy Sandbox on Android,这是我们持续致力于开发可让用户放心地知道其隐私受到保护的技术的一部分。您可以访问我们的网站,详细了解 Privacy Sandbox on Android 开发者 Beta 版计划,以便顺利上手。不妨了解 SDK 运行时,它可让 SDK 在与其所服务的应用分离的专用运行时环境中运行,从而为用户数据收集和共享提供更强的保护措施。

Segurança

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

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 dispositivos

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

Estrutura padronizada de qualidade de imagem e áudio para TVs

O novo pacote MediaQuality no Android 16 expõe um conjunto de APIs padronizadas para acesso a perfis de áudio e imagem e configurações relacionadas ao hardware. Isso permite que os apps de streaming consultem perfis e os apliquem à mídia de forma dinâmica:

  • Filmes masterizados com um intervalo dinâmico mais amplo exigem maior precisão de cor para ver detalhes sutis nas sombras e se ajustar à luz ambiente. Portanto, um perfil que prioriza a precisão de cor em vez do brilho pode ser adequado.
  • Eventos esportivos ao vivo geralmente são masterizados com um intervalo dinâmico estreito, mas são assistidos durante o dia. Portanto, um perfil que prioriza o brilho em vez da precisão de cores pode gerar resultados melhores.
  • O conteúdo totalmente interativo exige um processamento mínimo para reduzir a latência e taxas de quadros mais altas. É por isso que muitas TVs são enviadas com um perfil de jogo.

A API permite que os apps alternem entre perfis, e os usuários podem ajustar as TVs compatíveis para se adequar melhor ao conteúdo.

Internacionalização

O Android 16 adiciona recursos e funcionalidades 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 medidas

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.