Mudanças de comportamento: todos os apps

A plataforma Android 15 inclui mudanças de comportamento que podem afetar seu app. As mudanças de comportamento abaixo se aplicam a todos os apps executados no Android 15: independente de targetSdkVersion. Teste seu app e modifique-o conforme necessário para apoiá-las adequadamente, quando aplicável.

Consulte também a lista de mudanças de comportamento que afetam apenas apps. destinados ao Android 15.

Principal recurso

O Android 15 modifica ou expande vários recursos principais do sistema Android.

Alterações no estado de pacote interrompido

软件包 FLAG_STOPPED 状态(用户可以通过长按应用图标并选择“强行停止”来参与 AOSP build)一直是为了让应用保持此状态,直到用户通过直接启动应用或间接与应用互动(通过 Sharesheet 或 widget、选择应用作为动态壁纸等)将应用从此状态明确移除。在 Android 15 中,我们将更新系统的行为,以符合这一预期行为。只能通过用户直接或间接操作将应用从停止状态中移除。

为了支持预期行为,除了现有限制之外,当应用在搭载 Android 15 的设备上进入停止状态时,系统还会取消所有待处理 intent。当用户的操作将应用从停止状态中移除时,系统会向应用传递 ACTION_BOOT_COMPLETED 广播,让用户有机会重新注册任何待处理的 intent。

您可以调用新的 ApplicationStartInfo.wasForceStopped() 方法来确认应用是否已置于停止状态。

Suporte a tamanhos de página de 16 KB

Android 过去仅支持 4 KB 内存页面大小, 优化了系统内存性能,以针对 Android 设备通常具备的功能。从 Android 15 开始,AOSP 支持 配置为使用 16 KB (16 KB) 页面大小的设备 设备)。如果您的应用使用任何 NDK 库,请直接使用 或者通过 SDK 间接创建,那么,您需要重新构建自己的应用 支持这些 16KB 设备。

随着设备制造商不断打造出 物理内存 (RAM),许多此类设备都会采用 16KB(以及 页面大小以优化设备的性能。正在添加 支持 16 KB 页面大小的设备,可使您的应用在这些设备上运行 并有助于您的应用从相关的广告效果中获益 改进。如果不重新编译,应用可能无法在 16KB 设备上运行 在未来的 Android 版本中正式推出。

为帮助您为应用添加支持,我们提供了有关如何检查 如果您的应用受到影响 重新构建您的应用(如果适用),以及如何在 Google Play 中 使用模拟器(包括 Android 15)的 16 KB 环境 系统映像)。

Benefícios e ganhos de desempenho

Dispositivos configurados com tamanhos de página de 16 KB usam um pouco mais de memória em média, mas também recebem várias melhorias de desempenho para o sistema e os apps:

  • Menor tempo de inicialização do app enquanto o sistema está sob pressão de memória: 3,16% menor, em média, com melhorias mais significativas (até 30%) para alguns apps testados.
  • Consumo de energia reduzido durante a inicialização do app: em média, 4,56% de redução
  • Lançamento mais rápido da câmera: inicializações a quente 4,48% mais rápidas, em média, e inicializações a frio 6,60% mais rápidas, em média.
  • Melhoria no tempo de inicialização do sistema: melhoria de 1,5% (aproximadamente 0,8 segundo) em média.

Essas melhorias são baseadas em nossos testes iniciais, e os resultados em dispositivos reais provavelmente serão diferentes. Forneceremos análises adicionais de ganhos potenciais para apps à medida que continuarmos nossos testes.

Verificar se o app vai ser afetado

Se o app usar código nativo, recrie-o com suporte a dispositivos de 16 KB. Se você não tem certeza se o app usa código nativo, use o APK Analyzer para identificar se há algum código nativo.

Se o app usa apenas código escrito na linguagem de programação Java ou Kotlin, incluindo bibliotecas ou SDKs, ele já oferece suporte a dispositivos de 16 KB. No entanto, recomendamos que você teste seu app em um ambiente de 16 KB para verificar se não há regressões inesperadas no comportamento dele.

Mudanças necessárias para que alguns apps sejam compatíveis com o espaço privado

O espaço privado é um novo recurso do Android 15 que permite que os usuários criar um espaço separado no dispositivo para manter apps confidenciais longe de olhar curioso, sob uma camada adicional de autenticação. Como os apps no o espaço privado tem visibilidade restrita, alguns tipos de aplicativos precisam outras etapas para poder ver e interagir com apps no modo particular espaço.

Todos os apps

Como os aplicativos no espaço privado são mantidos em um perfil de usuário separado, semelhante aos perfis de trabalho, os apps não podem presumir que as instalações cópias do app que não estão no perfil principal ficam no perfil de trabalho. Se seu app tem uma lógica relacionada a apps do perfil de trabalho que fazem essa suposição, você vai precisar ajustar essa lógica.

Apps de medicina

Quando um usuário bloqueia o espaço privado, todos os apps nele são interrompidos. e esses apps não poderão realizar atividades em primeiro ou segundo plano, incluindo mostrando notificações. Esse comportamento pode impactar criticamente o uso e a função de apps médicos instalados no espaço privado.

A experiência de configuração do espaço privado avisa aos usuários que ele não está adequado para apps que precisam executar tarefas essenciais em primeiro ou segundo plano atividades, como mostrar notificações de apps médicos. No entanto, os aplicativos não poderão determinar se estão ou não sendo usados no espaço privado, por isso, não é possível mostrar um aviso ao usuário para esse caso.

Por esses motivos, se você desenvolve um app de medicina, revise como esse recurso pode afetar seu app e tomar as medidas apropriadas, como informar os usuários para não instale o app no espaço privado, para evitar interrupções importantes recursos.

Apps da tela de início

Se você desenvolver um app de tela de início, faça o seguinte antes dos apps na o espaço privado ficará visível:

  1. Seu app precisa ser atribuído à tela de início padrão do dispositivo. Isso é ter o papel ROLE_HOME.
  2. O app precisa declarar a ACCESS_HIDDEN_PROFILES permissão normal no arquivo de manifesto do app.

Apps de inicialização que declaram a permissão ACCESS_HIDDEN_PROFILES precisam gerenciar nos seguintes casos de uso de espaço privado:

  1. Seu app precisa ter um contêiner da tela de início separado para os apps instalados na espaço privado. Use o método getLauncherUserInfo() para determinar que tipo de perfil de usuário está sendo tratado.
  2. O usuário precisa conseguir ocultar e mostrar o contêiner do espaço privado.
  3. O usuário precisa conseguir bloquear e desbloquear o contêiner do espaço privado. Usar o método requestQuietModeEnabled() para bloquear (por passando true) ou desbloqueie (transmitindo false) o espaço privado.
  4. Enquanto estiver bloqueado, nenhum app no contêiner do espaço privado ficará visível ou detectáveis por mecanismos como a pesquisa. Seu aplicativo deve registrar um receptor para o ACTION_PROFILE_AVAILABLE e ACTION_PROFILE_UNAVAILABLE transmite e atualiza interface no app quando o estado bloqueado ou desbloqueado do espaço privado alterações no contêiner. Essas duas transmissões incluem EXTRA_USER, que o app pode usar para se referir ao usuário de perfil particular.

    Também é possível usar o método isQuietModeEnabled() para: verifica se o perfil do espaço privado está bloqueado ou não.

Apps da app store

O espaço privado inclui um botão "Instalar apps" que inicia uma janela a intenção de instalar apps no espaço privado do usuário. Para que seu app receber essa intent implícita, declare um objeto <intent-filter> no arquivo de manifesto do app com um <category> de CATEGORY_APP_MARKET.

Fonte de emoji baseada em PNG removida

O arquivo legado de fonte de emojis baseada em PNG (NotoColorEmojiLegacy.ttf) foi deixando apenas o arquivo baseado em vetor. Do Android 13 em diante (API) nível 33), o arquivo de fonte de emojis usado pelo renderizador de emojis do sistema mudou de um arquivo baseado em PNG para um arquivo vetorial. O sistema manteve o arquivo de fonte legado no Android 13 e 14 por motivos de compatibilidade, os apps com os próprios renderizadores de fonte podem continuar usando o arquivo de fonte legado. até conseguirem fazer upgrade.

Para verificar se o app foi afetado, pesquise no código dele as referências aos NotoColorEmojiLegacy.ttf.

Há várias maneiras de adaptar o app:

  • Usar APIs da plataforma para renderização de texto. É possível renderizar texto em uma Canvas e use isso para conseguir uma imagem bruta, se necessário.
  • Adicione suporte a fontes COLRv1 ao app. A biblioteca de código aberto FreeType oferece suporte a COLRv1 na versão 2.13.0 e mais alto.
  • Como último recurso, você pode agrupar o arquivo de fonte de emojis legado (NotoColorEmoji.ttf) ao seu APK, mas, nesse caso, seu app não terá as atualizações mais recentes de emojis. Para mais informações, consulte o projeto Noto Emoji do GitHub .

Aumento da versão mínima do SDK de destino de 23 para 24

Android 15 基于 在 Android 14 中进行的更改,并扩展了 安全性。在 Android 15 中, 无法安装低于 24 的 targetSdkVersion。 要求应用符合现代 API 级别有助于确保更好的安全性和 保护隐私。

恶意软件通常会以较低的 API 级别为目标平台,以绕过安全和隐私 更高的 Android 版本中引入的保护机制。例如,有些恶意软件应用使用 targetSdkVersion 22,以避免受到 Android 6.0 Marshmallow(API 级别 23)在 2015 年引入的运行时权限模型的约束。这项 Android 15 变更使恶意软件更难以规避安全和隐私权方面的改进限制。尝试安装以较低 API 级别为目标平台的应用将导致安装失败,并且 Logcat 中会显示如下所示的消息:

INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 24, but found 7

在升级到 Android 15 的设备上,targetSdkVersion 级别较低的任何应用 安装在 Google Play 上

如果您需要测试以旧版 API 级别为目标平台的应用,请使用以下 ADB 命令:

adb install --bypass-low-target-sdk-block FILENAME.apk

Câmera e mídia

O Android 15 faz as mudanças abaixo no comportamento da câmera e da mídia para todos apps.

A reprodução de áudio direta e descarregada agora invalida faixas de áudio diretas ou descarregadas anteriormente quando os limites de recursos são atingidos.

Antes do Android 15, se um app solicitasse a reprodução de áudio direta ou descarregamento enquanto outro app estivesse tocando áudio e os limites de recursos fossem atingidos, o app não conseguia abrir uma nova AudioTrack.

No Android 15 e versões mais recentes, quando um app solicita a reprodução direta ou descarregamento e os limites de recursos são atingidos, o sistema invalida todos os objetos AudioTrack abertos no momento que impedem o preenchimento da nova solicitação de faixa.

As faixas de áudio direta e de descarga geralmente são abertas para reprodução de formatos de áudio compactados. Casos de uso comuns para tocar áudio direto incluem streaming de áudio codificado por HDMI para uma TV. As faixas de descarregamento normalmente são usadas para reproduzir áudio compactado em um dispositivo móvel com aceleração de DSP de hardware.

Experiência do usuário e interface do sistema

O Android 15 inclui algumas mudanças que visam criar uma versão mais consistente, experiência do usuário intuitiva.

Animações de volta preditiva ativadas para apps em que o recurso foi ativado

从 Android 15 开始,移除了预测性返回动画的开发者选项。现在,对于已完全或在 activity 级别选择启用预测性返回手势的应用,系统现在会显示“返回主屏幕”“跨任务”和“跨 activity”等系统动画。如果您的应用受到影响,请执行以下操作:

  • 确保您的应用已正确迁移,以使用预测性返回手势。
  • 确保您的 fragment 转换支持预测性返回导航。
  • 停止使用动画和框架转换,并改用 Animator 和 AndroidX 转换。
  • FragmentManager 不知道的返回堆栈中迁出。请改用由 FragmentManager 或 Navigation 组件管理的返回堆栈。

Widgets desativados quando o usuário força o fechamento de um app

Se um usuário forçar o fechamento de um app em um dispositivo com o Android 15, o sistema desativará temporariamente todos os widgets do app. Os widgets ficam esmaecidos, e o usuário não consegue interagir com eles. Isso ocorre porque, no Android 15 e versões mais recentes, o sistema cancela todas as intents pendentes de um app com fechamento forçado.

O sistema reativará esses widgets na próxima vez que o usuário iniciar o aplicativo.

Para mais informações, consulte Mudanças no estado de pacote interrompido.

Suspensões de uso

A cada versão, APIs específicas do Android podem se tornar obsoletas ou ter que ser refatorado para fornecer uma melhor experiência ao desenvolvedor ou oferecer suporte a nova plataforma capabilities. Nesses casos, descontinuamos oficialmente as APIs obsoletas e direcionar os desenvolvedores para APIs alternativas.

Descontinuação significa que encerramos o suporte oficial para as APIs, mas elas ainda continuam disponíveis para os desenvolvedores. Para saber mais sobre eventos descontinuações nesta versão do Android, consulte a página de descontinuações.