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 开始,Android 支持配置为使用 16 KB 页面大小的设备(即 16 KB 设备)。

随着设备制造商不断打造具有更大物理内存 (RAM) 的设备,这些设备中的许多可能会配置 16 KB(最终更大)的页面大小,以优化设备的性能。添加对 16 KB 设备的支持可让您的应用在这些设备上运行,并帮助您的应用从相关性能改进中受益。为了帮助您解决此问题,我们提供了一些指南,帮助您了解如何检查您的应用是否受到影响、如何重新构建应用(如果适用),以及如何同时使用模拟器和实体设备在 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 criem um espaço separado no dispositivo para manter apps sensíveis longe de curiosos, com uma camada extra de autenticação. Como os apps no espaço particular têm visibilidade restrita, alguns tipos de apps precisam tomar outras medidas para poder ver e interagir com apps no espaço particular de um usuário.

Todos os apps

Como os apps no espaço particular são mantidos em um perfil de usuário separado, como perfis de trabalho, não presuma que todas as cópias instaladas do app que não estejam no perfil principal estejam no perfil de trabalho. Se o app tiver uma lógica relacionada a apps do perfil de trabalho que fazem essa suposição, será necessário ajustar essa lógica.

Apps da tela de início

Se você desenvolver um app de tela de início, faça o seguinte antes que os apps no espaço privado fiquem visíveis:

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

Os apps de tela de início que declaram a permissão ACCESS_HIDDEN_PROFILES precisam processar os seguintes casos de uso de espaço privado:

  1. Seu app precisa ter um contêiner da tela de início separado para apps instalados no espaço privado. Use o método getLauncherUserInfo() para determinar que tipo de perfil de usuário está sendo processado.
  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. Use o método requestQuietModeEnabled() para bloquear (transmitindo true) ou desbloquear (transmitindo false) o espaço privado.
  4. Enquanto ele estiver bloqueado, nenhum app no contêiner do espaço privado poderá ficar visível ou detectável por mecanismos como a pesquisa. Seu app precisa registrar um receptor para as transmissões ACTION_PROFILE_AVAILABLE e ACTION_PROFILE_UNAVAILABLE e atualizar a interface no app quando o estado bloqueado ou desbloqueado do contêiner do espaço privado mudar. Essas duas transmissões incluem EXTRA_USER, que seu app pode usar para se referir ao usuário do perfil particular.

    Você também pode usar o método isQuietModeEnabled() para verificar 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 intent implícita para instalar apps no espaço privado do usuário. Para que o app receba essa intent implícita, declare um <intent-filter> no arquivo de manifesto do app com um <category> de CATEGORY_APP_MARKET.

Fonte de emoji baseada em PNG removida

The legacy, PNG-based emoji font file (NotoColorEmojiLegacy.ttf) has been removed, leaving just the vector-based file. Beginning with Android 13 (API level 33), the emoji font file used by the system emoji renderer changed from a PNG-based file to a vector based file. The system retained the legacy font file in Android 13 and 14 for compatibility reasons, so that apps with their own font renderers could continue to use the legacy font file until they were able to upgrade.

You can choose to adapt your app in a number of ways:

  • Use platform APIs for text rendering. You can render text to a bitmap-backed Canvas and use that to get a raw image if necessary.
  • Add COLRv1 font support to your app. The FreeType open source library supports COLRv1 in version 2.13.0 and higher.
  • As a last resort, you can bundle the legacy emoji font file (NotoColorEmoji.ttf) into your APK, although in that case your app will be missing the latest emoji updates. For more information, see the Noto Emoji GitHub project page.

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

O Android 15 se baseia nas mudanças feitas no Android 14 e amplia ainda mais essa segurança. No Android 15, não é possível instalar apps com uma targetSdkVersion anterior à 24. Exigir que os apps atendam a níveis modernos de API ajuda a garantir melhor segurança e privacidade.

Geralmente, um malware é direcionado a níveis mais baixos de API para contornar as proteções de segurança e privacidade introduzidas em versões mais recentes do Android. Por exemplo, alguns apps de malware usam uma targetSdkVersion de 22 para evitar serem submetidos ao modelo de permissão de execução apresentado em 2015 pelo Android 6.0 Marshmallow (nível 23 da API). Essa mudança do Android 15 dificulta que malwares evitem melhorias de segurança e privacidade. A tentativa de instalar um app direcionado a um nível de API anterior resulta em uma falha na instalação, com uma mensagem como esta aparecendo no Logcat:

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

Em dispositivos que passam por upgrade para o Android 15, todos os apps com uma targetSdkVersion anterior à 24 permanecem instalados.

Se você precisar testar um app destinado a um nível de API mais antigo, use o seguinte comando 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.

在 Android 15 之前,如果某个应用在另一个应用正在播放音频时请求直接播放或分流音频播放,并且已达到资源限制,此应用将无法打开新的 AudioTrack

从 Android 15 开始,当应用请求直接或分流播放并且达到资源限制时,系统会使当前打开的所有 AudioTrack 对象失效,从而阻止执行新的轨道请求。

(直接和分流音轨通常会打开,以播放压缩的音频格式。播放直接音频的常见用例包括通过 HDMI 将编码音频流式传输到电视。分流轨道通常用于在具有硬件 DSP 加速的移动设备上播放压缩音频。)

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

No Android 15 e versões mais recentes, a opção de animações de volta preditiva foi removida. As animações do sistema, como voltar à tela inicial, entre tarefas e entre atividades, agora aparecem para apps que ativaram o gesto de volta preditivo inteiramente ou no nível da atividade. Se o app for afetado, faça o seguinte:

  • Verifique se o app foi migrado corretamente para usar o gesto de volta previsto.
  • Verifique se as transições de fragmento funcionam com a navegação de volta preditiva.
  • Migrar das transições de animação e framework e usar transições Animator e androidx.
  • Migrar das backstacks que o FragmentManager não conhece. Use backstacks gerenciadas por FragmentManager ou pelo componente 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.