Visão geral de recursos e APIs

O Android 14 introduz ótimos recursos e APIs para desenvolvedores. As seções a seguir ajudam você a conhecer os recursos disponíveis para os apps e a começar a usar as APIs relacionadas.

Para uma lista detalhada das APIs adicionadas, modificadas e removidas, leia o Relatório de diferenças da API. Para mais detalhes sobre as APIs adicionadas, acesse a Referência da API do Android. No Android 14, procure APIs que foram adicionadas no nível 34 da API. Para saber mais sobre as áreas em que as mudanças na plataforma podem afetar seus apps, confira as mudanças de comportamento do Android 14 para apps destinados ao Android 14 e para todos os apps.

Internacionalização

Seleção de idioma por app

O Android 14 expande os recursos de linguagem por app lançados no Android 13 (API de nível 33) com estes recursos extras:

  • Gerar automaticamente o localeConfig de um app: a partir do Android Studio Giraffe Canary 7 e do AGP 8.1.0-alpha07, é possível configurar seu app para oferecer suporte a seleção de idioma por app automaticamente. Com base nos recursos do projeto, o Plug-in do Android para Gradle gera o arquivo LocaleConfig e adiciona uma referência a ele no arquivo de manifesto final. Assim, não é mais necessário criar ou atualizar o arquivo manualmente. O AGP usa os recursos nas pastas res dos módulos do app e qualquer dependência de módulos de biblioteca para determinar as localidades que serão incluídas no arquivo LocaleConfig.

  • Atualizações dinâmicas para o localeConfig de um app: use os métodos setOverrideLocaleConfig() e getOverrideLocaleConfig() em LocaleManager para atualizar dinamicamente a lista de idiomas com suporte no app nas configurações do sistema do dispositivo. Use essa flexibilidade para personalizar a lista de idiomas com suporte por região, executar experimentos A/B ou fornecer uma lista atualizada de localidades se o app usar pushes do lado do servidor para localização.

  • Visibilidade do idioma do app para Editores de método de entrada (IMEs): os IMEs podem usar o método getApplicationLocales() para conferir o idioma do app atual e associar o idioma do IME a ele.

API Grammatical Inflection

Três bilhões de pessoas falam idiomas com marcação de gênero: idiomas em que categorias gramaticais, como substantivos, verbos, adjetivos e preposições, mudam de acordo com o gênero das pessoas e os objetos sobre os quais elas falam. Tradicionalmente, vários idiomas com marcação de gênero usam o gênero gramatical masculino como padrão ou genérico.

Referir-se a usuários no gênero gramatical errado, como falar com uma mulher no gênero gramatical masculino, pode afetar negativamente o desempenho e a atitude dela. Por outro lado, uma interface com linguagem que reflete corretamente o gênero gramatical do usuário pode melhorar o engajamento e fornecer uma experiência do usuário mais personalizada e natural.

为帮助您针对区分性别的语言构建以用户为中心的界面,Android 14 引入了 Grammatical Inflection API,让您无需重构应用便能添加对语法性别的支持。

Preferências regionais

Regional preferences enable users to personalize temperature units, the first day of the week, and numbering systems. A European living in the United States might prefer temperature units to be in Celsius rather than Fahrenheit and for apps to treat Monday as the beginning of the week instead of the US default of Sunday.

New Android Settings menus for these preferences provide users with a discoverable and centralized location to change app preferences. These preferences also persist through backup and restore. Several APIs and intents—such as getTemperatureUnit and getFirstDayOfWeek— grant your app read access to user preferences, so your app can adjust how it displays information. You can also register a BroadcastReceiver on ACTION_LOCALE_CHANGED to handle locale configuration changes when regional preferences change.

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

Regional preferences screen in Android system settings.
Temperature options for regional preferences in Android system settings.

Acessibilidade

Dimensionamento de fonte não linear para 200%

No Android 14 e versões mais recentes, o sistema oferece suporte a escala de fonte de até 200%, oferecendo usuários com deficiência visual com opções de acessibilidade adicionais alinhadas com a Web Diretrizes de Acessibilidade de Conteúdo (WCAG, na sigla em inglês).

Para evitar que elementos de texto grandes na tela fiquem grandes demais, o sistema aplica uma curva de dimensionamento não linear. Essa estratégia significa que textos grandes não são dimensionados na mesma taxa que os menores. O dimensionamento de fontes não linear ajuda a preservar a hierarquia proporcional entre elementos de tamanhos diferentes, reduzindo problemas com dimensionamento linear em graus elevados, como cortes de texto ou dificuldade para ler um texto devido a tamanhos muito grandes de tela.

Testar o app com dimensionamento de fontes não linear

Ative o tamanho máximo da fonte nas configurações de acessibilidade de um dispositivo para testar o app.

Se você já usa unidades de pixels dimensionados (sp) para definir o dimensionamento de texto, então essas opções extras e melhorias de escalonamento são aplicadas automaticamente texto em seu aplicativo. No entanto, você ainda deve realizar testes de interface com o máximo tamanho de fonte ativado (200%) para garantir que o app aplique os tamanhos de fonte corretamente e podem acomodar tamanhos de fonte maiores sem afetar a usabilidade.

Para ativar o tamanho de fonte de 200%, siga estas etapas:

  1. Abra o app Configurações e navegue até Acessibilidade > Texto e tamanho de exibição.
  2. Na opção Tamanho da fonte, toque no ícone de adição (+) até ativar a configuração de tamanho máximo de fonte, conforme mostrado na imagem que acompanha esta seção.

Usar unidades de pixels dimensionados (sp) para tamanhos de texto

Sempre especifique tamanhos de texto em unidades de sp. Quando seu app usa unidades sp, o Android pode aplicar o tamanho de texto preferencial do usuário e dimensioná-lo adequadamente.

Não use unidades sp para preenchimento ou defina alturas de visualização assumindo o preenchimento implícito: com o dimensionamento não linear, as dimensões de sp podem não ser proporcionais. Portanto, 4sp + 20sp podem não ser iguais a 24sp.

Converter unidades de pixels dimensionados

Usar TypedValue.applyDimension() para converter de unidades de sp em pixels, e use TypedValue.deriveDimension() para converter pixels em sp. Esses métodos aplicam o escalonamento não linear apropriado curva automaticamente.

Evite equações fixadas no código usando Configuration.fontScale ou DisplayMetrics.scaledDensity Como o dimensionamento da fonte é não linear, o campo scaledDensity não é mais preciso. O campo fontScale deve ser usado apenas para fins informativos, porque as fontes não são mais dimensionadas com um único valor escalar.

Usar unidades de sp para lineHeight

Sempre defina android:lineHeight usando unidades sp em vez de dp para que a altura da linha seja dimensionada junto com o texto. Caso contrário, se o texto é sp, mas lineHeight está em dp ou px. Ele não é dimensionado e parece apertado. A TextView corrige automaticamente o lineHeight para que o objeto proporções são preservadas, mas somente se textSize e lineHeight forem definido em unidades de sp.

Câmera e mídia

Ultra HDR para imagens

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

Android 14 新增了对高动态范围 (HDR) 图片的支持,可在拍摄照片时保留更多来自传感器的信息,从而实现鲜艳的色彩和更高的对比度。Android 使用 Ultra HDR 格式,该格式与 JPEG 图片完全向后兼容,可让应用与 HDR 图片无缝互操作,并根据需要以标准动态范围 (SDR) 显示这些图片。

当您的应用选择为其 activity 窗口使用 HDR 界面(通过清单条目或通过在运行时调用 Window.setColorMode())时,框架会自动在界面中以 HDR 格式渲染这些图片。您还可以在受支持的设备上拍摄压缩的 Ultra HDR 静态图片。从传感器中恢复的颜色越多,后期编辑的灵活性就越高。与 Ultra HDR 图片关联的 Gainmap 可用于使用 OpenGL 或 Vulkan 渲染这些图片。

Zoom, foco, pós-visualização e muito mais nas extensões de câmera

O Android 14 atualiza e melhora as extensões de câmera, permitindo que os apps processem imagens em tempos mais longos, o que melhora as imagens usando algoritmos de computação intensiva, como a fotografia com pouca luz em dispositivos compatíveis. Esses recursos oferecem aos usuários uma experiência ainda mais robusta ao usar os recursos de extensão da câmera. Confira alguns exemplos dessas melhorias:

Zoom no sensor

CameraCharacteristics 中的 REQUEST_AVAILABLE_CAPABILITIES_STREAM_USE_CASE 包含 SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW 时,您的应用可以使用高级传感器功能,将剪裁后的 RAW 数据流的像素与全视野范围相同,方法是将 CaptureRequest 与将数据流用例设置为 CameraMetadata.SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW 的 RAW 目标搭配使用。通过实现请求替换控件,更新后的相机可让用户在其他相机控件准备就绪之前使用缩放控件。

Áudio USB sem perdas

Android 14 支持无损音频格式,可通过 USB 有线耳机提供发烧友级体验。您可以查询 USB 设备的首选混音器属性,注册监听器以监听首选混音器属性的更改,以及使用 AudioMixerAttributes 类配置混音器属性。此类表示音频混音器的格式,例如声道掩码、采样率和行为。该类允许直接发送音频,而无需混音、调节音量或处理效果。

Produtividade e ferramentas para desenvolvedores

Credential Manager

O Android 14 adiciona o Gerenciador de credenciais como uma API da plataforma, com suporte adicional para dispositivos com o Android 4.4 (nível 19 da API) por meio de uma biblioteca Jetpack que usa o Google Play Services. O objetivo do Gerenciador de credenciais é facilitar o login para os usuários com APIs que extraem e armazenam credenciais com provedores de credenciais configurados pelo usuário. O Gerenciador de credenciais oferece suporte a vários métodos de login, incluindo nome de usuário e senha, chaves de acesso e soluções de login federadas (como o recurso Fazer login com o Google) em uma única API.

As chaves de acesso oferecem muitas vantagens. Por exemplo, as chaves de acesso são criadas com base nos padrões do setor, podem funcionar em diferentes sistemas operacionais e ecossistemas de navegadores e podem ser usadas em sites e apps.

Para mais informações, consulte a documentação do Gerenciador de credenciais e das chaves de acesso e o post do blog sobre o Gerenciador de credenciais e as chaves de acesso.

Conexão Saúde

Health Connect 是用户健康与健身数据的设备端仓库。借助该功能,用户可以在一个位置控制要与这些应用共享哪些数据,并在自己喜爱的应用之间共享数据。

在搭载 Android 14 之前的 Android 版本的设备上,Health Connect 可作为应用从 Google Play 商店下载。从 Android 14 开始,Health Connect 将成为 Android 平台的一部分,并通过 Google Play 系统更新接收更新,而无需单独下载。这样一来,Health Connect 就可以频繁更新,您的应用可以依赖于搭载 Android 14 或更高版本的设备上提供的 Health Connect。用户可以通过设备的“设置”访问 Health Connect,隐私控制功能集成到系统设置中。

用户无需在搭载 Android 14 或更高版本的设备上单独下载应用,即可开始使用 Health Connect。
用户可以通过系统设置控制哪些应用可以访问其健康与健身数据。

Health Connect 在 Android 14 中包含多项新功能,例如锻炼路线,可让用户分享可在地图上直观呈现的锻炼路线。路线定义为在一定时间范围内保存的位置列表,您的应用可以将路线插入锻炼时段,将它们关联起来。为确保用户能够完全控制此类敏感数据,用户必须允许与其他应用共享单个路线。

如需了解详情,请参阅 Health Connect 文档以及有关 Android Health 中的新功能的博文。

Atualizações do OpenJDK 17

O Android 14 continua o trabalho de atualizar as principais bibliotecas do Android para se alinhar aos recursos das versões mais recentes do LTS do OpenJDK, incluindo atualizações de bibliotecas e suporte à linguagem Java 17 para desenvolvedores de apps e plataformas.

Os seguintes recursos e melhorias estão incluídos:

  • Aproximadamente 300 classes java.base foram atualizadas para oferecer suporte ao Java 17.
  • Blocos de texto, que introduzem literais de string de várias linhas à linguagem de programação Java.
  • Correspondência de padrão para instanceof, que permite que um objeto seja tratado como um tipo específico em uma instanceof sem nenhuma outra variável.
  • Classes seladas, que permitem restringir quais classes e interfaces podem estender ou implementar essas classes.

Graças às atualizações do sistema do Google Play (Projeto Mainline), mais de 600 milhões de dispositivos podem receber as atualizações mais recentes do Android Runtime (ART), que incluem essas mudanças. Isso faz parte do nosso compromisso de oferecer aos apps um ambiente mais consistente e seguro em todos os dispositivos, com novos recursos para os usuários, independente da versão da plataforma.

Java e OpenJDK são marcas registradas da Oracle e/ou afiliadas.

Melhorias para app stores

O Android 14 apresenta várias APIs PackageInstaller que permitem que as app stores melhorem a experiência do usuário.

Solicitar aprovação da instalação antes do download

A instalação ou atualização de um app pode exigir a aprovação do usuário. Por exemplo, quando um instalador que usa a permissão REQUEST_INSTALL_PACKAGES tenta instalar um novo app. Nas versões anteriores do Android, as app stores só podem solicitar a aprovação do usuário depois que os APKs são gravados na sessão de instalação e a sessão é confirmada.

A partir do Android 14, o método requestUserPreapproval() permite que os instaladores solicitem a aprovação do usuário antes de confirmar a sessão de instalação. Essa melhoria permite que a app store adie o download de APKs até que a instalação seja aprovada pelo usuário. Além disso, depois que um usuário aprova a instalação, a app store pode fazer o download e instalar o app em segundo plano sem interromper o usuário.

Reivindicar a responsabilidade por atualizações futuras

O método setRequestUpdateOwnership() permite que um instalador indique ao sistema que pretende ser responsável por futuras atualizações de um app que ele está instalando. Esse recurso permite a aplicação da propriedade da atualização, ou seja, apenas o proprietário da atualização pode instalar atualizações automáticas no app. A aplicação da propriedade da atualização ajuda a garantir que os usuários recebam atualizações apenas da app store esperada.

Qualquer outro instalador, incluindo aqueles que usam a permissão INSTALL_PACKAGES, precisa receber aprovação explícita do usuário para instalar uma atualização. Se um usuário decidir continuar com uma atualização de outra fonte, a propriedade da atualização será perdida.

Atualizar apps em momentos menos incômodos

Geralmente, as app stores não querem atualizar um app que está em uso, porque isso encerra os processos em execução e pode interromper o que o usuário está fazendo.

A partir do Android 14, a API InstallConstraints oferece aos instaladores uma maneira de garantir que as atualizações do app ocorram em um momento oportuno. Por exemplo, uma app store pode chamar o método commitSessionAfterInstallConstraintsAreMet() para garantir que uma atualização só será confirmada quando o usuário não estiver mais interagindo com o app em questão.

Instalar divisões opcionais de forma simples

Com os APKs divididos, os recursos de um app podem ser enviados em arquivos APK separados em vez de como um APK monolítico. Os APKs divididos permitem que as app stores otimizem a entrega de diferentes componentes do app. Por exemplo, app stores podem otimizar com base nas propriedades do dispositivo de destino. A API PackageInstaller oferece suporte a divisões desde a apresentação no nível 22 da API.

No Android 14, o método setDontKillApp() permite que um instalador indique que os processos em execução do app não serão encerrados quando novas divisões forem instaladas. As app stores podem usar esse recurso para instalar novos recursos enquanto o usuário está usando o app.

Pacotes de metadados do app

从 Android 14 开始,Android 软件包安装程序可让您指定应用元数据(例如数据安全做法),以在 Google Play 等应用商店页面上架。

Detectar quando usuários fazem capturas de tela no dispositivo

To create a more standardized experience for detecting screenshots, Android 14 introduces a privacy-preserving screenshot detection API. This API lets apps register callbacks on a per-activity basis. These callbacks are invoked, and the user is notified, when the user takes a screenshot while that activity is visible.

Experiência do usuário

Ações personalizadas e melhoria na classificação do Sharesheet

O Android 14 atualiza o Sharesheet do sistema para oferecer suporte a ações personalizadas do app e resultados de visualização mais informativos para os usuários.

Adicionar ações personalizadas

Com o Android 14, o app pode adicionar ações personalizadas ao Sharesheet do sistema que ele invoca.

Captura de tela de ações personalizadas na página de compartilhamento.

Melhorar a classificação dos alvos de compartilhamento direto

O Android 14 usa mais indicadores de apps para determinar a classificação dos alvos de compartilhamento diretos a fim de apresentar resultados mais úteis para o usuário. Para fornecer o indicador mais útil para a classificação, siga as orientações para melhorar a classificação dos seus alvos de compartilhamento direto. Os apps de comunicação também podem informar o uso de atalhos para mensagens de entrada e saída.

Linha de compartilhamento direto na página de compartilhamento, conforme mostrado em 1

Suporte a animações de voltas preditivas integradas e personalizadas

视频:预测性返回动画

Android 13 在开发者选项背后引入了预测性“返回主屏幕”动画。在已启用开发者选项的受支持应用中使用时,滑回手势会显示动画,表明返回手势会使应用退回到主屏幕。

Android 14 包含针对“预测性返回”的多项改进和新指南:

在此 Android 14 预览版中,所有预测性返回功能都是位于开发者选项背后。请参阅与将您的应用迁移到预测性返回有关的开发者指南,以及与创建自定义应用内转换有关的开发者指南

Substituições por app do fabricante de dispositivos de tela grande

借助按应用替换项,设备制造商可以更改应用在大屏设备上的行为。例如,FORCE_RESIZE_APP 替换项会指示系统调整应用大小以适应显示屏尺寸(避免进入尺寸兼容模式),即使在应用清单中设置了 resizeableActivity="false" 也是如此。

替换项旨在改善大屏设备上的用户体验。

借助新的清单属性,您可以为应用停用某些设备制造商替换项。

Substituições por app para usuários de telas grandes

Per-app overrides change the behavior of apps on large screen devices. For example, the OVERRIDE_MIN_ASPECT_RATIO_LARGE device manufacturer override sets the app aspect ratio to 16:9 regardless of the app's configuration.

Android 14 QPR1 enables users to apply per‑app overrides by means of a new settings menu on large screen devices.

Compartilhamento de tela de app

借助应用界面共享功能,用户可以在录制屏幕内容时共享应用窗口,而不是整个设备屏幕。

在应用屏幕共享模式下,状态栏、导航栏、通知和其他系统界面元素会从共享显示屏中排除。系统只会分享所选应用的内容。

应用屏幕共享功能可让用户运行多个应用,但将内容共享限制为单个应用,从而提高工作效率并保护隐私。

Resposta inteligente com tecnologia de LLM no Gboard do Pixel 8 Pro

Em dispositivos Pixel 8 Pro com a versão de dezembro, os desenvolvedores podem testar respostas inteligentes de maior qualidade no Gboard com modelos de linguagem grandes (LLMs) no dispositivo em execução no Google Tensor.

Esse recurso está disponível como uma prévia limitada para o inglês dos EUA no WhatsApp, no Line e no KakaoTalk. É necessário usar um dispositivo Pixel 8 Pro com o Gboard como teclado.

Para testar, primeiro ative o recurso em Configurações > Opções do desenvolvedor > Configurações do AICore > Ativar o AICore persistente.

Em seguida, abra uma conversa em um app compatível para conferir a resposta inteligente com LLM na faixa de sugestões do Gboard em resposta às mensagens recebidas.

O Gboard usa LLMs no dispositivo para fornecer respostas inteligentes de melhor qualidade.

Gráficos

Os caminhos podem ser consultados e interpolados

A API Path do Android é um mecanismo avançado e flexível para criar e renderizar gráficos vetoriais, com a capacidade de traçar ou preencher um caminho, construir um caminho a partir de segmentos de linha ou curvas quadráticas ou cúbicas, realizar operações booleanas para conseguir formas ainda mais complexas ou todas essas formas simultaneamente. Uma limitação é a capacidade de descobrir o que está presente em um objeto de caminho. Os componentes internos do objeto são opacos para autores de chamadas após a criação.

Para criar um Path, chame métodos como moveTo(), lineTo() e cubicTo() para adicionar segmentos de caminho. Mas não há uma maneira de perguntar a esse caminho quais são os segmentos. Portanto, você precisa manter essas informações no momento da criação.

A partir do Android 14, é possível consultar caminhos para descobrir o que há dentro deles. Primeiro, você precisa conseguir um objeto PathIterator usando a API Path.getPathIterator:

Kotlin

val path = Path().apply {
    moveTo(1.0f, 1.0f)
    lineTo(2.0f, 2.0f)
    close()
}
val pathIterator = path.pathIterator

Java

Path path = new Path();
path.moveTo(1.0F, 1.0F);
path.lineTo(2.0F, 2.0F);
path.close();
PathIterator pathIterator = path.getPathIterator();

Em seguida, chame PathIterator para iterar os segmentos um por um, recuperando todos os dados necessários para cada segmento. Este exemplo usa objetos PathIterator.Segment, que empacotam os dados para você:

Kotlin

for (segment in pathIterator) {
    println("segment: ${segment.verb}, ${segment.points}")
}

Java

while (pathIterator.hasNext()) {
    PathIterator.Segment segment = pathIterator.next();
    Log.i(LOG_TAG, "segment: " + segment.getVerb() + ", " + segment.getPoints());
}

O PathIterator também tem uma versão não alocada de next(), em que é possível transmitir um buffer para armazenar os dados dos pontos.

Um dos casos de uso importantes para consultar os dados Path é a interpolação. Por exemplo, você pode querer animar (ou transformar) entre dois caminhos diferentes. Para simplificar ainda mais esse caso de uso, o Android 14 também inclui o método interpolate() em Path. Supondo que os dois caminhos tenham a mesma estrutura interna, o método interpolate() cria um novo Path com esse resultado interpolado. Este exemplo retorna um caminho com um formato que está na metade do caminho (uma interpolação linear de 0,5) entre path e otherPath:

Kotlin

val interpolatedResult = Path()
if (path.isInterpolatable(otherPath)) {
    path.interpolate(otherPath, .5f, interpolatedResult)
}

Java

Path interpolatedResult = new Path();
if (path.isInterpolatable(otherPath)) {
    path.interpolate(otherPath, 0.5F, interpolatedResult);
}

A biblioteca graphics-path do Jetpack também permite APIs semelhantes em versões anteriores do Android.

Malhas personalizadas com shaders de vértice e fragmento

O Android já oferece suporte a renderização de malhas triangulares com sombreamento personalizado, mas o formato de malha de entrada foi limitado a algumas combinações de atributos predefinidas. O Android 14 adiciona suporte a malhas personalizadas, que podem ser definidas como triângulos ou faixas de triângulo, e podem ser indexadas, se necessário. Essas malhas são especificadas com atributos personalizados, incrementos de vértice, variação e sombreadores de vértice e fragmento escritos em AGSL.

O sombreador de vértice define as variações, como posição e cor, enquanto o sombreador de fragmentos pode definir a cor do pixel, normalmente usando as variações criadas pelo sombreador de vértice. Se a cor for fornecida pelo shader de fragmentos, ela será mesclada com a cor Paint atual usando o modo de mesclagem selecionado ao desenhar a malha. Os uniformes podem ser transmitidos para os sombreadores de fragmentos e vértices para mais flexibilidade.

Renderizador de buffer de hardware para Canvas

协助使用 Android 的 Canvas API 通过 硬件加速至 HardwareBuffer、Android 14 引入了 HardwareBufferRenderer。如果您的用例涉及通过 SurfaceControl 与系统合成器通信以实现低延迟绘制,此 API 特别有用。