O Android 15 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 novas APIs estão em destaque para visibilidade. Além disso, para saber mais sobre as áreas em que as mudanças na plataforma podem afetar seus apps, consulte as mudanças de comportamento que afetam os apps direcionados ao Android 15 e as mudanças de comportamento que afetam todos os apps, independente datargetSdkVersion
.
Câmera e mídia
O Android 15 inclui uma variedade de recursos que melhoram a experiência de câmera e mídia e que dão acesso a ferramentas e hardware para ajudar os criadores a dar vida às ideias deles no Android.
Para saber mais sobre os recursos mais recentes e soluções para desenvolvedores para mídia e câmera Android, confira a palestra Como criar experiências modernas de mídia e câmera Android do Google I/O.
Intensificação de pouca luz
Android 15 引入了低光增强,这是一种新的自动曝光模式,可供 Camera 2 和夜间模式相机扩展使用。“低光增强”功能可调整预览视频流在弱光条件下的曝光量。这与夜间模式相机扩展程序创建静态图片的方式不同,因为夜间模式会组合多张照片来制作单张增强图片。虽然夜间模式非常适合创建静态图片,但无法创建连续的帧流,但“低光增强”可以。因此,“低光增强”可以实现新的相机功能,例如:
- 提供增强的图片预览,以便用户更好地为弱光环境取景
- 在光线昏暗的环境下扫描二维码
如果您启用“弱光增强”,它会在光线较暗时自动开启,在光线较暗时关闭。
应用可以在光线昏暗的环境下录制预览流,以保存明亮的视频。
有关详情,请参阅弱光增强。
Controles de câmera no app
O Android 15 adiciona uma nova extensão para ter mais controle sobre o hardware da câmera e os algoritmos em dispositivos com suporte:
- Ajustes avançados de intensidade do flash que permitem um controle preciso da intensidade
do flash nos modos
SINGLE
eTORCH
durante a captura de imagens.
Controle de margem de HDR
O Android 15 escolhe a margem de HDR adequada para os recursos
do dispositivo e a profundidade de bits do painel. Em páginas que têm muito conteúdo
SDR, como um app de mensagens exibindo uma única miniatura HDR, esse
comportamento pode afetar negativamente o brilho percebido do conteúdo
SDR. O Android 15 permite controlar a margem do HDR com
setDesiredHdrHeadroom
para encontrar um equilíbrio entre
conteúdo SDR e HDR.
Controle do volume
Android 15 introduces support for the CTA-2075 loudness standard to help you avoid audio loudness inconsistencies and ensure users don't have to constantly adjust volume when switching between content. The system leverages known characteristics of the output devices (headphones and speaker) along with loudness metadata available in AAC audio content to intelligently adjust the audio loudness and dynamic range compression levels.
To enable this feature, you need to ensure loudness metadata is available in
your AAC content and enable the platform feature in your app. For this, you
instantiate a LoudnessCodecController
object by
calling its create factory method with the audio
session ID from the associated AudioTrack
; this
automatically starts applying audio updates. You can pass an
OnLoudnessCodecUpdateListener
to modify or filter
loudness parameters before they are applied on the
MediaCodec
.
// Media contains metadata of type MPEG_4 OR MPEG_D
val mediaCodec = …
val audioTrack = AudioTrack.Builder()
.setSessionId(sessionId)
.build()
...
// Create new loudness controller that applies the parameters to the MediaCodec
try {
val lcController = LoudnessCodecController.create(mSessionId)
// Starts applying audio updates for each added MediaCodec
}
AndroidX media3 ExoPlayer will also be updated to use the
LoudnessCodecController
APIs for a seamless app integration.
Dispositivos MIDI virtual 2.0
O Android 13 adicionou suporte à conexão com Dispositivos MIDI 2.0 por USB, que se comunicam usando Pacotes MIDI (UMP). O Android 15 estende o suporte à UMP para MIDI virtual , permitindo que apps de composição controlem apps de sintetizador como um dispositivo MIDI 2.0 virtual, como faria com um USB MIDI 2.0.
Decodificação de software AV1 mais eficiente
dav1d, o conhecido decodificador de software AV1 do VideoLAN agora está disponível para dispositivos Android que não são compatíveis com a decodificação AV1 em hardware. O dav1d tem um desempenho até três vezes maior do que o decodificador de software AV1 legado, permitindo a reprodução HD AV1 para mais usuários, incluindo alguns dispositivos de níveis básicos e intermediários.
Por enquanto, seu app precisa ativar o uso dav1d invocando-o pelo nome
"c2.android.av1-dav1d.decoder"
. O dav1d será o decodificador padrão do software AV1 em uma atualização subsequente. Esse suporte é padronizado e oferece backport para
dispositivos Android 11 que recebem atualizações do sistema do Google Play.
Produtividade e ferramentas para desenvolvedores
Embora a maior parte do nosso trabalho para melhorar a produtividade tenha como foco ferramentas como o Android Studio, o Jetpack Compose e as bibliotecas do Android Jetpack, sempre procuramos maneiras de ajudar você a dar vida às suas ideias com mais facilidade.
Atualizações do OpenJDK 17
Android 15 会继续更新 Android 的核心库,以与最新 OpenJDK LTS 版本中的功能保持一致。
其中包含以下主要功能和改进:
- 改进了 NIO 缓冲区的使用寿命
- 信息流
- 其他
math
和strictmath
方法 util
软件包更新,包括有序的collection
、map
和set
Deflater
中的ByteBuffer
支持- 安全更新,例如
X500PrivateCredential
和安全密钥更新
这些 API 通过 Google Play 系统更新在超过 10 亿台搭载 Android 12(API 级别 31)及更高版本的设备上进行了更新,让您能够以最新的编程功能为目标平台。
Melhorias no PDF
O Android 15 inclui melhorias substanciais nas APIs
PdfRenderer
. Os apps podem incorporar recursos avançados, como renderização de
arquivos protegidos por senha, anotações, edição de formulários, pesquisa e seleção com cópia. As otimizações de PDF linearizado são compatíveis para acelerar a visualização de PDF local e reduzir o uso de recursos.
O PdfRenderer
foi movido para um módulo que pode ser atualizado usando atualizações
do sistema do Google Play, independentemente da versão da plataforma. Oferecemos suporte
a essas mudanças no Android 11 (nível 30 da API) criando uma versão da plataforma da API
compatível com versões anteriores ao Android 15, chamada
PdfRendererPreV
.
Valorizamos seu feedback sobre as melhorias feitas na plataforma da API PdfRenderer
e planejamos facilitar ainda mais a incorporação dessas APIs ao
app com uma biblioteca do Android Jetpack que será lançada em breve.
Refinamentos automáticos da troca de idioma
O Android 14 adicionou o reconhecimento de vários idiomas no dispositivo em áudio com a alternância
automática entre idiomas, mas isso pode causar a queda das palavras,
especialmente quando os idiomas são alternados com menos pausa entre as duas
expressões. O Android 15 adiciona outros controles para ajudar os apps a ajustar essa alternância
para o caso de uso.
EXTRA_LANGUAGE_SWITCH_INITIAL_ACTIVE_DURATION_TIME_MILLIS
confina a troca automática ao início da sessão de áudio, enquanto
EXTRA_LANGUAGE_SWITCH_MATCH_SWITCHES
desativa a
alternância de idioma após um número definido de trocas. Essas opções são
especialmente úteis se você espera que um único idioma falado
durante a sessão precise ser detectado automaticamente.
API OpenType Variable Font aprimorada
Android 15 improves the usability of the OpenType variable font. You can create
a FontFamily
instance from a variable font without specifying weight axes
with the buildVariableFamily
API. The text renderer overrides the value
of wght
axis to match the displaying text.
Using the API simplifies the code for creating a Typeface
considerably:
Kotlin
val newTypeface = Typeface.CustomFallbackBuilder( FontFamily.Builder( Font.Builder(assets, "RobotoFlex.ttf").build()) .buildVariableFamily()) .build()
Java
Typeface newTypeface = Typeface.CustomFallbackBuilder( new FontFamily.Builder( new Font.Builder(assets, "RobotoFlex.ttf").build()) .buildVariableFamily()) .build();
Previously, to create the same Typeface
, you would need much more code:
Kotlin
val oldTypeface = Typeface.CustomFallbackBuilder( FontFamily.Builder( Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 400") .setWeight(400) .build()) .addFont( Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 100") .setWeight(100) .build() ) .addFont( Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 200") .setWeight(200) .build() ) .addFont( Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 300") .setWeight(300) .build() ) .addFont( Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 500") .setWeight(500) .build() ) .addFont( Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 600") .setWeight(600) .build() ) .addFont( Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 700") .setWeight(700) .build() ) .addFont( Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 800") .setWeight(800) .build() ) .addFont( Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 900") .setWeight(900) .build() ).build() ).build()
Java
Typeface oldTypeface = new Typeface.CustomFallbackBuilder( new FontFamily.Builder( new Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 400") .setWeight(400) .build() ) .addFont( new Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 100") .setWeight(100) .build() ) .addFont( new Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 200") .setWeight(200) .build() ) .addFont( new Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 300") .setWeight(300) .build() ) .addFont( new Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 500") .setWeight(500) .build() ) .addFont( new Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 600") .setWeight(600) .build() ) .addFont( new Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 700") .setWeight(700) .build() ) .addFont( new Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 800") .setWeight(800) .build() ) .addFont( new Font.Builder(assets, "RobotoFlex.ttf") .setFontVariationSettings("'wght' 900") .setWeight(900) .build() ) .build() ).build();
Here's an example of how a Typeface
created with both the old and new APIs
renders:
In this example, the Typeface
created with the old API doesn't have the
capability to create accurate font weights for the 350, 450, 550 and 650
Font
instances, so the renderer falls back to the closest weight. So in
this case, 300 is rendered instead of 350, 400 is rendered instead of 450, and
so on. By contrast, the Typeface
created with the new APIs dynamically creates
a Font
instance for a given weight, so accurate weights are rendered for 350,
450, 550, and 650 as well.
Controles granulares de quebra de linha
从 Android 15 开始,TextView
和底层
换行符可以保留同一行中给定的文本部分,
可读性。您可以通过使用
字符串资源中的 <nobreak>
标记,或
createNoBreakSpan
。同样,您可以保留
使用 <nohyphen>
标记断字;或者
createNoHyphenationSpan
。
例如,以下字符串资源不包含换行符,并且 渲染时会显示“Pixel 8 Pro”文字在不理想的位置发生故障:
<resources>
<string name="pixel8pro">The power and brains behind Pixel 8 Pro.</string>
</resources>
相比之下,此字符串资源包含 <nobreak>
标记,用于封装
如“Pixel 8 Pro”并防止换行:
<resources>
<string name="pixel8pro">The power and brains behind <nobreak>Pixel 8 Pro.</nobreak></string>
</resources>
下方显示了这些字符串的呈现方式差异 图片:
Arquivamento de apps
O Android e o Google Play anunciaram o suporte ao arquivamento de apps por último ano, permitindo que os usuários liberem espaço removendo parcialmente apps usados com pouca frequência do dispositivo que foram publicados usando o app Android Pacote no Google Play. O Android 15 inclui suporte no nível do SO para arquivamento e desarquivamento de apps, facilitando a implementação em todas as app stores.
Apps com a permissão REQUEST_DELETE_PACKAGES
podem chamar o
PackageInstaller
requestArchive
para solicitar o arquivamento de um
do pacote de apps instalado, que remove o APK e todos os arquivos em cache, mas persiste
dados do usuário. Os apps arquivados são retornados como apps que podem ser exibidos por meio do
APIs do LauncherApps
os usuários verão um tratamento de interface para destacar
e os apps são arquivados. Se um usuário tocar em um app arquivado, o instalador responsável
receberá uma solicitação para desarquivá-la. Nesse caso, será possível
monitorado pela transmissão ACTION_PACKAGE_ADDED
.
Gráficos
O Android 15 traz as melhorias gráficas mais recentes, incluindo o ANGLE e adições ao sistema gráfico Canvas.
Como modernizar o acesso a GPUs do Android
O hardware do Android evoluiu bastante desde os primeiros dias, em que o SO principal era executado em uma única CPU, e as GPUs eram acessadas usando APIs com base em pipelines de função fixa. A API gráfica Vulkan® está disponível no NDK desde o Android 7.0 (nível 24 da API) com uma abstração de nível inferior que reflete melhor o hardware de GPU moderno, escalona melhor para oferecer suporte a vários núcleos da CPU e oferece redução da sobrecarga do driver da CPU, melhorando o desempenho do app. O Vulkan oferece suporte a todos os mecanismos de jogos modernos.
O Vulkan é a interface preferencial do Android para a GPU. Portanto, o Android 15 inclui o ANGLE como uma camada opcional para executar o OpenGL® ES sobre o Vulkan. A migração para o ANGLE vai padronizar a implementação do OpenGL do Android para melhorar a compatibilidade e, em alguns casos, o desempenho. Você pode testar a estabilidade e o desempenho do app OpenGL ES com o ANGLE ativando a opção do desenvolvedor em Settings -> System -> Developer Options -> Experimental: Enable ANGLE no Android 15.
O Android ANGLE no roteiro Vulkan
Como parte da simplificação da nossa pilha de GPU, a partir de agora, lançaremos o ANGLE como o driver do sistema GL em mais dispositivos novos, com a expectativa futura de que o OpenGL/ES só esteja disponível pelo ANGLE. Dito isso, planejamos continuar a compatibilidade com o OpenGL ES em todos os dispositivos.
Próximas etapas recomendadas
Use as opções do desenvolvedor para selecionar o driver ANGLE para OpenGL ES e testar seu app. Para novos projetos, recomendamos o uso do Vulkan para C/C++.
Melhorias no Canvas
O Android 15 continua nossa modernização do sistema gráfico Canvas do Android com novos recursos:
Matrix44
fornece uma matriz 4x4 para transformar coordenadas que precisam ser usadas quando você quiser manipular a tela em 3D.clipShader
cruza o clipe atual com o sombreador especificado, enquantoclipOutShader
define o clipe como a diferença entre o clipe atual e o sombreador, tratando o sombreador como uma máscara alfa. Isso permite desenhar formas complexas de maneira eficiente.
Performance e bateria
O Android continua focado em ajudar você a melhorar o desempenho e a qualidade dos seus apps. O Android 15 apresenta novas APIs que ajudam a tornar as tarefas do app mais eficientes, otimizar a performance e coletar insights sobre eles.
Para conferir práticas recomendadas de eficiência da bateria, depuração de rede e uso de energia, além de detalhes sobre como melhoramos a eficiência do trabalho em segundo plano no Android 15 e em versões recentes do Android, consulte a palestra Como melhorar a eficiência do trabalho em segundo plano no Android no Google I/O.
API ApplicationStartInfo
Nas versões anteriores do Android, a inicialização de apps era um pouco misteriosa. Era
difícil determinar, no seu app, se ele iniciava de um estado frio, quente
ou quente. Também era difícil saber quanto tempo o app passava durante as
várias fases de lançamento: bifurcar o processo, chamar onCreate
, desenhar o
primeiro frame, entre outras. Quando a classe Application
era instanciada, você não tinha
como saber se o app era iniciado por uma transmissão, um provedor de conteúdo, um
job, um backup, uma inicialização concluída, um alarme ou um Activity
.
A API ApplicationStartInfo
no Android 15 oferece
tudo isso e muito mais. Você pode até adicionar seus próprios carimbos de data/hora ao
fluxo para ajudar a coletar dados de tempo em um só lugar. Além de coletar
métricas, você pode usar ApplicationStartInfo
para otimizar diretamente a inicialização
do app. Por exemplo, você pode eliminar a instanciação cara de bibliotecas relacionadas à interface
na classe Application
quando o app está iniciando devido a uma
transmissão.
Informações detalhadas sobre o tamanho do app
Desde o Android 8.0 (nível 26 da API), o Android inclui a
API StorageStats.getAppBytes
, que resume o tamanho
instalado de um app como um único número de bytes, que é uma soma do tamanho do APK, do
tamanho dos arquivos extraídos do APK e dos arquivos gerados no
dispositivo, como código compilado antecipado (AOT, na sigla em inglês). Esse número não é muito
útil em termos de como seu app está usando o armazenamento.
O Android 15 adiciona a API
StorageStats.getAppBytesByDataType([type])
, que permite
ter insights sobre como o app está usando todo esse espaço, incluindo divisões de arquivo
APK, AOT e código relacionado à aceleração, metadados de dex, bibliotecas e perfis
guiados.
Criação de perfil gerenciada pelo app
O Android 15 inclui a classe ProfilingManager
, que permite
coletar informações de criação de perfil dentro do seu aplicativo. Planejamos encerrar esse
com uma API Android Jetpack que simplificará a criação de perfis
mas a API principal permite a coleta de heap dumps,
perfis, amostragem de pilhas e muito mais. Ele fornece um callback para o app com uma
tag fornecida para identificar o arquivo de saída, que é enviado para o diretório
de arquivos do app. A API faz uma limitação de taxa para minimizar o impacto no desempenho.
Melhorias no banco de dados SQLite
Android 15 introduces SQLite APIs that expose advanced features from the underlying SQLite engine that target specific performance issues that can manifest in apps.
Developers should consult best practices for SQLite performance to get the most out of their SQLite database, especially when working with large databases or when running latency-sensitive queries.
- Read-only deferred transactions: when issuing transactions that are
read-only (don't include write statements), use
beginTransactionReadOnly()
andbeginTransactionWithListenerReadOnly(SQLiteTransactionListener)
to issue read-onlyDEFERRED
transactions. Such transactions can run concurrently with each other, and if the database is in WAL mode, they can run concurrently withIMMEDIATE
orEXCLUSIVE
transactions. - Row counts and IDs: APIs were added to retrieve the count of changed
rows or the last inserted row ID without issuing an additional query.
getLastChangedRowCount()
returns the number of rows that were inserted, updated, or deleted by the most recent SQL statement within the current transaction, whilegetTotalChangedRowCount()
returns the count on the current connection.getLastInsertRowId()
returns therowid
of the last row to be inserted on the current connection. - Raw statements: issue a raw SQlite statement, bypassing convenience wrappers and any additional processing overhead that they may incur.
Atualizações do Android Dynamic Performance Framework
Android 15 继续投资开发 Android 动态性能框架 (ADPF),这是一组 API,可让游戏和性能密集型应用更直接地与 Android 设备的电源和散热系统进行互动。在受支持的设备上,Android 15 将添加新的 ADPF 功能:
- 适用于提示会话的节能模式,用于指明其关联的线程应该优先考虑节能而非性能,非常适合长时间运行的后台工作负载。
- 可以在提示会话中报告 GPU 和 CPU 的运行时长,从而使系统能够同时调整 CPU 和 GPU 频率,以便更好地满足工作负载需求。
- 热余量阈值,用于根据余量预测来解释可能的热节流状态。
如需详细了解如何在应用和游戏中使用 ADPF,请参阅相关文档。
Privacidade
O Android 15 inclui uma variedade de recursos que ajudam os desenvolvedores de apps a proteger a privacidade do usuário.
Detecção de gravação de tela
Android 15 添加了对应用的支持,以检测 正在录制。每当应用转换时,系统都会调用回调 在屏幕录制内容中处于可见与隐藏状态之间。应用 如果注册进程的 UID 拥有的 activity 正在录制。这样一来,如果您的应用正在执行敏感操作,您可以 可以告知用户其正在录制。
val mCallback = Consumer<Int> { state ->
if (state == SCREEN_RECORDING_STATE_VISIBLE) {
// We're being recorded
} else {
// We're not being recorded
}
}
override fun onStart() {
super.onStart()
val initialState =
windowManager.addScreenRecordingCallback(mainExecutor, mCallback)
mCallback.accept(initialState)
}
override fun onStop() {
super.onStop()
windowManager.removeScreenRecordingCallback(mCallback)
}
Recursos expandidos de IntentFilter
O Android 15 oferece suporte a uma resolução de Intent
mais precisa usando
UriRelativeFilterGroup
, que contém um conjunto de
Objetos UriRelativeFilter
que formam um conjunto de Intent
que precisam ser cumpridas,
incluindo parâmetros de consulta e URL
e regras de bloqueio ou exclusão.
Essas regras podem ser definidas no arquivo XML AndroidManifest
com o novo
tag <uri-relative-filter-group>
, que pode incluir uma tag
tag android:allow
. Elas podem conter tags <data>
que usam dados atuais
atributos de tag, bem como os novos android:query
e android:fragment
atributos.
Confira um exemplo da sintaxe AndroidManifest
:
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="http" />
<data android:scheme="https" />
<data android:domain="astore.com" />
<uri-relative-filter-group>
<data android:pathPrefix="/auth" />
<data android:query="region=na" />
</uri-relative-filter-group>
<uri-relative-filter-group android:allow="false">
<data android:pathPrefix="/auth" />
<data android:query="mobileoptout=true" />
</uri-relative-filter-group>
<uri-relative-filter-group android:allow="false">
<data android:pathPrefix="/auth" />
<data android:fragmentPrefix="faq" />
</uri-relative-filter-group>
</intent-filter>
Espaço privado
Private space lets users create a separate space on their device where they can keep sensitive apps away from prying eyes, under an additional layer of authentication. The private space uses a separate user profile. The user can choose to use the device lock or a separate lock factor for the private space.
Apps in the private space show up in a separate container in the launcher, and are hidden from the recents view, notifications, settings, and from other apps when the private space is locked. User-generated and downloaded content (such as media or files) and accounts are separated between the private space and the main space. The system sharesheet and the photo picker can be used to give apps access to content across spaces when the private space is unlocked.
Users can't move existing apps and their data into the private space. Instead, users select an install option in the private space to install an app using whichever app store they prefer. Apps in the private space are installed as separate copies from any apps in the main space (new copies of the same app).
When a user locks the private space, the profile is stopped. While the profile is stopped, apps in the private space are no longer active and can't perform foreground or background activities, including showing notifications.
We recommend that you test your app with private space to make sure your app works as expected, especially if your app falls into one of the following categories:
- Apps with logic for work profiles that assumes that any installed copies of their app that aren't in the main profile are in the work profile.
- Medical apps
- Launcher apps
- App store apps
Consultar a seleção de usuário mais recente para acessar as fotos selecionadas
Agora os apps podem destacar apenas as últimas fotos selecionadas
e vídeos quando o acesso parcial às permissões de mídia é concedido. Isso
pode melhorar a experiência do usuário em apps que solicitam com frequência
acesso a fotos e vídeos. Para usar esse recurso no app, ative o
Argumento QUERY_ARG_LATEST_SELECTION_ONLY
ao consultar MediaStore
usando ContentResolver
.
Kotlin
val externalContentUri = MediaStore.Files.getContentUri("external") val mediaColumns = arrayOf( FileColumns._ID, FileColumns.DISPLAY_NAME, FileColumns.MIME_TYPE, ) val queryArgs = bundleOf( // Return only items from the last selection (selected photos access) QUERY_ARG_LATEST_SELECTION_ONLY to true, // Sort returned items chronologically based on when they were added to the device's storage QUERY_ARG_SQL_SORT_ORDER to "${FileColumns.DATE_ADDED} DESC", QUERY_ARG_SQL_SELECTION to "${FileColumns.MEDIA_TYPE} = ? OR ${FileColumns.MEDIA_TYPE} = ?", QUERY_ARG_SQL_SELECTION_ARGS to arrayOf( FileColumns.MEDIA_TYPE_IMAGE.toString(), FileColumns.MEDIA_TYPE_VIDEO.toString() ) )
Java
Uri externalContentUri = MediaStore.Files.getContentUri("external"); String[] mediaColumns = { FileColumns._ID, FileColumns.DISPLAY_NAME, FileColumns.MIME_TYPE }; Bundle queryArgs = new Bundle(); queryArgs.putBoolean(MediaStore.QUERY_ARG_LATEST_SELECTION_ONLY, true); queryArgs.putString(MediaStore.QUERY_ARG_SQL_SORT_ORDER, FileColumns.DATE_ADDED + " DESC"); queryArgs.putString(MediaStore.QUERY_ARG_SQL_SELECTION, FileColumns.MEDIA_TYPE + " = ? OR " + FileColumns.MEDIA_TYPE + " = ?"); queryArgs.putStringArray(MediaStore.QUERY_ARG_SQL_SELECTION_ARGS, new String[] { String.valueOf(FileColumns.MEDIA_TYPE_IMAGE), String.valueOf(FileColumns.MEDIA_TYPE_VIDEO) });
Sandbox de privacidade no Android
O Android 15 inclui as extensões mais recentes dos Serviços de publicidade do Android, incorporando a versão mais recente do Sandbox de privacidade do Android. Essa adição faz parte do nosso trabalho para desenvolver novas tecnologias que melhoram a privacidade do usuário e permitem experiências de publicidade personalizadas e eficazes em apps para dispositivos móveis. Nossa página do Sandbox de privacidade tem mais informações sobre a prévia para desenvolvedores e os programas Beta do Sandbox de privacidade do Android para ajudar você a começar.
Conexão Saúde
O Android 15 integra as extensões mais recentes A Conexão Saúde do Android, uma plataforma segura e centralizada para gerenciar e compartilhar dados de saúde e condicionamento físico coletados pelo app. Esta atualização adiciona suporte a outros tipos de dados em fitness; nutrição, temperatura da pele, planos de treino e muito mais.
O monitoramento de temperatura da pele permite que os usuários armazenem e compartilhem de forma mais precisa dados de temperatura de um wearable ou outro dispositivo de monitoramento.
Os planos de treinamento são planos de treino estruturados para ajudar o usuário a alcançar os objetivos de condicionamento físico. O suporte a planos de treinamento inclui vários objetivos de conclusão e performance:
- Metas de conclusão em torno de calorias queimadas, distância, duração, repetição e passos.
- Metas de desempenho de o máximo de repetições possível (AMRAP), cadência, frequência cardíaca, potência, taxa de esforço percebida e velocidade.
Saiba mais sobre as atualizações mais recentes do Conexão Saúde no Android na palestra Como criar experiências adaptáveis com o Android Health do Google I/O.
Compartilhamento de tela parcial
O Android 15 oferece suporte ao compartilhamento de tela parcial para que os usuários possam compartilhar ou gravar apenas uma
janela de app em vez de toda a tela do dispositivo. Esse recurso, ativado pela primeira vez no
Android 14 QPR2, inclui
callbacks MediaProjection
que permitem que seu app
personalize a experiência de compartilhamento parcial de tela. Para aplicativos que segmentam
O Android 14 (nível 34 da API) ou versões mais recentes,
o consentimento do usuário é obrigatório para cada
Sessão de captura do MediaProjection
.
Experiência do usuário e interface do sistema
O Android 15 oferece aos desenvolvedores de apps e usuários mais controle e flexibilidade para configurar o dispositivo para atender às necessidades deles.
Para saber mais sobre como usar as melhorias mais recentes do Android 15 para melhorar a experiência do usuário no seu app, consulte a palestra Melhorar a experiência do usuário no app Android do Google I/O.
Visualizações de widgets mais completas com a API Generated Previews
Before Android 15, the only way to provide widget picker previews was to specify a static image or layout resource. These previews often differ significantly from the look of the actual widget when it is placed on the home screen. Also, static resources can't be created with Jetpack Glance, so a Glance developer had to screenshot their widget or create an XML layout to have a widget preview.
Android 15 adds support for generated previews. This means that app widget
providers can generate RemoteViews
to use as the picker preview, instead
of a static resource.
Push API
Apps can provide generated previews through a push API. Apps can provide
previews at any point in their lifecycle, and don't receive an explicit request
from the host to provide previews. Previews are persisted in AppWidgetService
,
and hosts can request them on-demand. The following example loads an XML widget
layout resource and sets it as the preview:
AppWidgetManager.getInstance(appContext).setWidgetPreview(
ComponentName(
appContext,
SociaLiteAppWidgetReceiver::class.java
),
AppWidgetProviderInfo.WIDGET_CATEGORY_HOME_SCREEN,
RemoteViews("com.example", R.layout.widget_preview)
)
The expected flow is:
- At any time, the widget provider calls
setWidgetPreview
. The provided previews are persisted inAppWidgetService
with other provider info. setWidgetPreview
notifies hosts of an updated preview through theAppWidgetHost.onProvidersChanged
callback. In response, the widget host reloads all of its provider information.- When displaying a widget preview, the host checks
AppWidgetProviderInfo.generatedPreviewCategories
, and if the chosen category is available, callsAppWidgetManager.getWidgetPreview
to return the saved preview for this provider.
When to call setWidgetPreview
Because there is no callback to provide previews, apps can choose to send previews at any point when they are running. How often to update the preview depends on the widget's use case.
The following list describes the two main categories of preview use cases:
- Providers that show real data in their widget previews, such as personalized or recent information. These providers can set the preview once the user has signed in or has done initial configuration in their app. After this, they can set up a periodic task to update the previews at their chosen cadence. Examples of this type of widget could be a photo, calendar, weather or news widget.
- Providers that show static information in previews or quick-action widgets that don't display any data. These providers can set previews once, when the app first launches. Examples of this type of widget include a drive quick actions widget or chrome shortcuts widget.
Some providers might show static previews on the hub mode picker, but real information on the homescreen picker. These providers should follow the guidance for both of these use cases to set previews.
Picture-in-picture
Android 15 introduces changes in Picture-in-Picture (PiP) ensuring an even smoother transition when entering into PiP mode. This will be beneficial for apps having UI elements overlaid on top of their main UI, which goes into PiP.
Developers use the onPictureInPictureModeChanged
callback to define logic
that toggles the visibility of the overlaid UI elements. This callback is
triggered when the PiP enter or exit animation is completed. Beginning in
Android 15, the PictureInPictureUiState
class includes another state.
With this UI state, apps targeting Android 15 (API level 35) will observe the
Activity#onPictureInPictureUiStateChanged
callback being invoked with
isTransitioningToPip()
as soon as the PiP animation starts. There are
many UI elements that are not relevant for the app when it is in PiP mode, for
example views or layout that include information such as suggestions, upcoming
video, ratings, and titles. When the app goes to PiP mode, use the
onPictureInPictureUiStateChanged
callback to hide these UI elements. When the
app goes to full screen mode from the PiP window, use
onPictureInPictureModeChanged
callback to unhide these elements, as shown in
the following examples:
override fun onPictureInPictureUiStateChanged(pipState: PictureInPictureUiState) {
if (pipState.isTransitioningToPip()) {
// Hide UI elements
}
}
override fun onPictureInPictureModeChanged(isInPictureInPictureMode: Boolean) {
if (isInPictureInPictureMode) {
// Unhide UI elements
}
}
This quick visibility toggle of irrelevant UI elements (for a PiP window) helps ensure a smoother and flicker-free PiP enter animation.
Regras aprimoradas do "Não perturbe"
O AutomaticZenRule
permite que os apps personalizem a atenção
de gerenciamento (Não perturbe) e decida quando ativar ou desativar
para resolvê-los com rapidez. O Android 15 aprimora essas regras de forma significativa, com o objetivo de melhorar a
experiência do usuário. As seguintes melhorias estão incluídas:
- Adição de tipos a
AutomaticZenRule
, permitindo que o sistema aplique um tratamento especial a algumas regras. - Adição de um ícone à
AutomaticZenRule
, ajudando a tornar os modos mais reconhecíveis. - Adicionar uma string
triggerDescription
aAutomaticZenRule
que descreve as condições em que a regra deve ficar ativa para o usuário. - Adicionado
ZenDeviceEffects
paraAutomaticZenRule
, permitindo que as regras acionem elementos como escala de cinza tela, modo noturno ou esmaecer o plano de fundo.
Definir VibrationEffect para canais de notificação
O Android 15 oferece suporte à configuração de vibrações avançadas para notificações recebidas
canal usando NotificationChannel.setVibrationEffect
, então
os usuários podem distinguir entre diferentes tipos de notificação sem
sem olhar para o dispositivo.
Telas e formatos grandes
O Android 15 oferece aos apps suporte para aproveitar ao máximo os formatos do Android, incluindo telas grandes, flippables e dobráveis.
Multitarefas aprimoradas em telas grandes
O Android 15 oferece aos usuários maneiras melhores de realizar várias tarefas em dispositivos de tela grande. Por exemplo, os usuários podem salvar as combinações de apps favoritos na tela dividida para acesso rápido e fixar a barra de tarefas na tela para alternar rapidamente entre os apps. Isso significa que garantir que seu app seja adaptável é mais importante do que nunca.
O Google I/O tem sessões sobre Como criar versões adaptáveis para Android apps e Como criar uma interface com o Material Design 3 biblioteca adaptável isso pode ajudar, e nossa documentação tem mais informações para ajudar você a criar para projetos de telas.
Capa de suporte para tela
O app pode declarar uma propriedade que o Android 15 usa para
permitir que Application
ou Activity
sejam apresentados nas pequenas
telas de capa
de dispositivos flexíveis com suporte. Essas telas são muito pequenas para serem
consideradas como destinos compatíveis com a execução de apps Android, mas seu app pode
oferecer suporte a elas, disponibilizando o app em mais lugares.
Conectividade
O Android 15 atualiza a plataforma para oferecer ao app acesso aos avanços mais recentes em comunicação e tecnologias sem fio.
Suporte a satélite
O Android 15 continua a ampliar o suporte à plataforma para conectividade por satélite e inclui alguns elementos de IU para garantir uma experiência do usuário consistente em todo o de conectividade por satélite.
Os apps podem usar o ServiceState.isUsingNonTerrestrialNetwork()
para
detectam quando um dispositivo está conectado a um satélite, o que aumenta o reconhecimento
por que serviços de rede completos podem estar indisponíveis. Além disso, o Android 15
oferece suporte a apps de SMS e MMS, bem como apps RCS pré-carregados para usar
a conectividade por satélite para enviar e receber mensagens.
Experiências NFC mais suaves
Android 15 致力于打造更顺畅、更可靠的感应式付款体验,同时继续支持 Android 强大的 NFC 应用生态系统。在受支持的设备上,应用可以请求 NfcAdapter
进入观察模式。在该模式下,设备会监听 NFC 读取器但不会响应 NFC 读取器,从而将应用的 NFC 服务 PollingFrame
对象发送给系统进行处理。PollingFrame
对象可用于在与 NFC 读取器首次通信之前进行身份验证,以便在许多情况下实现一键交易。
此外,应用现在可以在受支持的设备上注册过滤器,以便接收轮询循环 activity 的通知,从而与多个 NFC 感知应用顺畅运行。
Função da Carteira
O Android 15 introduz um novo papel da Carteira que permite uma maior integração com o app de carteira preferido do usuário. Esse papel substitui a configuração de pagamento por aproximação padrão da NFC. Os usuários podem gerenciar o titular da função da Carteira acessando Configurações > Apps > Aplicativos padrão.
O papel "Carteira" é usado ao rotear toques em NFC para AIDs registrados na categoria de pagamento. Os toques sempre vão para o titular da função "Carteira", a menos que outro app registrado para o mesmo AID esteja em execução em primeiro plano.
Esse papel também é usado para determinar onde o bloco QuickAccess da Carteira precisa ficar quando ativado. Quando o papel está definido como "Nenhum", o bloco QuickAccess não fica disponível e os toques NFC da categoria de pagamento são entregues apenas ao app em primeiro plano.
Segurança
O Android 15 ajuda você a reforçar a segurança do app, proteger os dados dele e oferecer aos usuários mais transparência e controle sobre os próprios dados. Consulte a palestra Como proteger a segurança do usuário no Android do Google I/O para saber mais sobre o que estamos fazendo para melhorar a proteção do usuário e proteger seu app contra novas ameaças.
Integrar o Gerenciador de credenciais ao preenchimento automático
Starting with Android 15, developers can link specific views like username or password fields with Credential Manager requests, making it easier to provide a tailored user experience during the sign-in process. When the user focuses on one of these views, a corresponding request is sent to Credential Manager. The resulting credentials are aggregated across providers and displayed in autofill fallback UIs, such as inline suggestions or drop-down suggestions. The Jetpack androidx.credentials library is the preferred endpoint for developers to use and will soon be available to further enhance this feature in Android 15 and higher.
Integrar a inscrição por toque único e login com solicitações biométricas
O Gerenciador de credenciais integra solicitações biométricas aos processos de criação e login de credenciais, eliminando a necessidade de os provedores gerenciarem solicitações biométricas. Como resultado, os provedores de credenciais só precisam se concentrar no dos fluxos "create" e "get", ampliados pelo resultado do fluxo biométrico. Esse processo simplificado cria uma credencial mais eficiente e simplificada o processo de criação e recuperação.
Gerenciamento de chaves para criptografia de ponta a ponta
Apresentamos o E2eeContactKeysManager
no Android 15, que
facilita a criptografia de ponta a ponta (E2EE) nos seus apps Android, fornecendo uma
API no nível do SO para o armazenamento de chaves públicas criptográficas.
O E2eeContactKeysManager
foi projetado para integração com o app de contatos da plataforma para oferecer aos usuários uma maneira centralizada de gerenciar e verificar as chaves públicas dos contatos.
Verificações de permissão em URIs de conteúdo
O Android 15 introduz um novo conjunto de APIs que realizam verificações de permissão em URIs de conteúdo:
Context.checkContentUriPermissionFull
: executa uma verificação de permissão completa em URIs de conteúdo.- Atributo de manifesto
Activity
requireContentUriPermissionFromCaller
: aplica permissões especificadas nos URIs de conteúdo fornecidos na inicialização da atividade. - Classe
ComponentCaller
para autores de chamadasActivity
: representa o app que iniciou a atividade.
Acessibilidade
O Android 15 adiciona recursos que melhoram a acessibilidade para os usuários.
Melhor braille
No Android 15, agora é possível para o TalkBack oferecer suporte a telas em braille que usam o padrão HID por USB e Bluetooth seguro.
Esse padrão, muito parecido com o usado por mouses e teclados, vai ajudar o Android a oferecer suporte a uma maior variedade de telas em braille com o tempo.
Internacionalização
O Android 15 adiciona recursos e funcionalidades que complementam a experiência do usuário quando um dispositivo é usado em idiomas diferentes.
Fonte da variável CJK
No Android 15 e versões mais recentes, o arquivo de fontes para os idiomas chinês, japonês e coreano (CJK), NotoSansCJK, agora é uma fonte variável. Fontes variáveis abrem novas possibilidades para tipografia criativa em idiomas CJK. Os designers podem explorar uma variedade mais ampla de estilos e criar layouts visualmente incríveis que anteriormente eram difíceis ou impossíveis de alcançar.
Justificativa entre caracteres
Starting with Android 15, text can be justified utilizing letter spacing by
using JUSTIFICATION_MODE_INTER_CHARACTER
. Inter-word justification was
first introduced in Android 8.0 (API level 26), and inter-character
justification provides similar capabilities for languages that use the
whitespace character for segmentation, such as Chinese, Japanese, and others.
Configuração automática de quebra de linha
O Android passou a oferecer suporte a quebras de linha baseadas em frases em japonês e coreano em
Android 13 (nível 33 da API). No entanto, embora as quebras de linha baseadas em frase melhorem
legibilidade de linhas de texto curtas, eles não funcionam bem para linhas de texto longas.
No Android 15, os apps só podem aplicar quebras de linha baseadas em frases para linhas curtas
de texto usando o método LINE_BREAK_WORD_STYLE_AUTO
é a melhor opção. Essa opção seleciona a melhor opção de estilo de palavra para o texto.
Para linhas de texto curtas, são usadas quebras de linha baseadas em frases, funcionando da mesma
como LINE_BREAK_WORD_STYLE_PHRASE
, conforme mostrado no
imagem a seguir:
Para linhas de texto mais longas, LINE_BREAK_WORD_STYLE_AUTO
usa um "no"
estilo de palavra com quebra de linha, funcionando da mesma forma
LINE_BREAK_WORD_STYLE_NONE
, conforme mostrado no
imagem a seguir:
Nova fonte japonesa Hentaigana
No Android 15, um arquivo de fonte do antigo hiragana japonês (conhecido como hentaigana) é empacotado por padrão. As formas únicas dos caracteres de Hentaigana podem adicionar um toque distinto a obras de arte ou designs, além de ajudar a preservar a transmissão e o entendimento precisos de documentos japoneses antigos.
Cone de VideoLAN Copyright (c) 1996-2010 VideoLAN. Esse logotipo ou uma versão modificada pode ser usado ou modificado por qualquer pessoa para se referir ao projeto VideoLAN ou qualquer produto desenvolvido pela equipe da VideoLAN, mas não indica endosso pelo projeto.
A Vulkan e o logotipo da Vulkan são marcas registradas da Khronos Group Inc.
OpenGL é uma marca registrada, e o logotipo OpenGL ES é uma marca registrada da Hewlett Packard Enterprise usada com permissão da Khronos.