Android 11 offre aux développeurs de nouvelles fonctionnalités et API de qualité. Les sections ci-dessous vous présentent les nouvelles fonctionnalités disponibles pour vos application et leurs nouvelles API.
Pour obtenir une liste détaillée des nouvelles API, des API modifiées et supprimées, consultez le rapport de différences des API. Pour en savoir plus sur les nouvelles API, consultez la documentation de référence des API Android. Les nouvelles API sont mises en évidence. Pour savoir dans quels domaines les changements de plate-forme peuvent affecter vos applications, consultez les modifications de comportement d'Android 11 pour les applications ciblant Android R et pour toutes les applications, ainsi que les modifications de confidentialité.
Nouvelles expériences
Commandes de contrôle des appareils
Android 11 inclut une nouvelle API ControlsProviderService
que vous pouvez utiliser pour exposer les commandes des appareils externes connectés. Ces commandes s'affichent sous Commandes de l'appareil dans le menu d'alimentation d'Android. Pour en savoir plus, consultez la section Contrôler des appareils externes.
Commandes multimédias
Android 11 modifie l'affichage des commandes multimédias. Les commandes multimédias s'affichent à côté des réglages rapides. Les sessions de plusieurs applications sont organisées dans un carrousel à faire glisser, qui comprend les flux lus localement sur le téléphone, les flux à distance, tels que ceux détectés sur des appareils externes ou des sessions de diffusion, et les sessions précédentes pouvant être reprises dans l'ordre de leur dernière lecture.
Les utilisateurs peuvent redémarrer des sessions précédentes à partir du carrousel sans avoir à démarrer l'application. Lorsque la lecture commence, l'utilisateur interagit avec les commandes multimédias comme d'habitude.
Pour en savoir plus, consultez la section Commandes multimédias.
Écrans
Meilleure prise en charge des affichages en cascade
Android 11 fournit plusieurs API pour prendre en charge les écrans en cascade, qui s'enroulent autour du bord de l'appareil. Ces écrans sont traités comme une variante des écrans avec encoches. Les méthodes existantes DisplayCutout
.getSafeInset…()
renvoient désormais l'encart sécurisé pour éviter les zones en cascade et les découpes.
Pour afficher le contenu de votre application dans la zone de cascade:
Appelez
DisplayCutout.getWaterfallInsets()
pour obtenir les dimensions exactes de l'encart en cascade.Définissez l'attribut de mise en page de la fenêtre
layoutInDisplayCutoutMode
surLAYOUT_IN_DISPLAY_CUTOUT_MODE_ALWAYS
pour permettre à la fenêtre de s'étendre dans les zones de découpe et de cascade sur tous les bords de l'écran. Vous devez vous assurer qu'aucun contenu essentiel ne se trouve dans les zones de découpe ou de cascade.
Capteur d'angle de charnière et appareils pliables
Android 11 permet aux applications exécutées sur des appareils avec des configurations d'écran basées sur une charnière de déterminer l'angle de la charnière en fournissant un nouveau capteur avec TYPE_HINGE_ANGLE
et un nouveau SensorEvent
qui peut surveiller l'angle de la charnière et fournir une mesure en degrés entre deux parties intégrantes de l'appareil. Vous pouvez utiliser ces mesures brutes pour effectuer des animations précises lorsque l'utilisateur manipule l'appareil.
Consultez la section Produits pliables.
Conversations
Améliorations apportées aux conversations
Android 11 apporte plusieurs améliorations à la gestion des conversations. Les conversations sont des communications bidirectionnelles en temps réel entre deux personnes ou plus. Ces conversations sont mises en avant, et les utilisateurs disposent de plusieurs nouvelles options pour interagir avec elles.
Pour en savoir plus sur les conversations et sur la façon dont votre application peut les prendre en charge, consultez la section Personnes et conversations.
Bulles de chat
Les bulles sont désormais disponibles pour les développeurs afin de mettre en avant les conversations dans l'ensemble du système. Les bulles étaient une fonctionnalité expérimentale d'Android 10 activée via une option pour les développeurs. Dans Android 11, cela n'est plus nécessaire.
Si une application cible Android 11 (niveau d'API 30) ou une version ultérieure, ses notifications ne sont pas présentées sous forme de bulles, sauf si elles répondent aux nouvelles exigences concernant les conversations. Plus précisément, la notification doit être associée à un raccourci.
Avant Android 11, si vous souhaitiez que la notification soit affichée sous forme de bulle, vous deviez spécifier explicitement qu'elle était définie pour être toujours lancée en mode UI de document. À partir d'Android 11, vous n'avez plus besoin d'effectuer ce paramètre explicitement. Si la notification est mise en bulle, la plate-forme définit automatiquement la notification pour qu'elle se lance toujours en mode UI de document.
Plusieurs améliorations ont été apportées aux performances des bulles, et les utilisateurs ont plus de flexibilité pour activer et désactiver les bulles dans chaque application. Pour les développeurs qui ont implémenté la prise en charge expérimentale, quelques modifications ont été apportées aux API dans Android 11:
- Le constructeur
BubbleMetadata.Builder()
sans paramètres est obsolète. Utilisez plutôt l'un des deux nouveaux constructeursBubbleMetadata.Builder(PendingIntent, Icon)
ouBubbleMetadata.Builder(String)
. - Créez
BubbleMetadata
à partir d'un ID de raccourci en appelantBubbleMetadata.Builder(String)
. La chaîne transmise doit correspondre à l'ID de raccourci fourni àNotification.Builder
. - Créez des icônes de bulle avec
Icon.createWithContentUri()
ou avec la nouvelle méthodecreateWithAdaptiveBitmapContentUri()
.
Indicateurs visuels 5G
Pour savoir comment afficher des indicateurs 5G sur les appareils des utilisateurs, consultez Indiquer à vos utilisateurs quand ils sont connectés à la 5G.
Confidentialité
Android 11 introduit un grand nombre de modifications et de restrictions visant à améliorer la confidentialité des utilisateurs. Pour en savoir plus, consultez la page Confidentialité.
Sécurité
Mises à jour de l'authentification biométrique
Pour vous aider à contrôler le niveau de sécurité des données de votre application, Android 11 apporte plusieurs améliorations à l'authentification biométrique. Ces modifications apparaissent également dans la bibliothèque biométrique Jetpack.
Types d'authentification
Android 11 introduit l'interface BiometricManager.Authenticators
, que vous pouvez utiliser pour déclarer les types d'authentification compatibles avec votre application.
Déterminer le type d'authentification utilisé
Une fois l'utilisateur authentifié, vous pouvez vérifier s'il a utilisé des identifiants d'appareil ou des identifiants biométriques en appelant getAuthenticationType()
.
Prise en charge supplémentaire des clés auth-per-use
Android 11 offre une meilleure compatibilité avec l'authentification à l'aide de clés d'authentification par utilisation.
Méthodes obsolètes
Android 11 abandonne les méthodes suivantes:
- La méthode
setDeviceCredentialAllowed()
. - La méthode
setUserAuthenticationValidityDurationSeconds()
. - Version surchargée de
canAuthenticate()
qui n'accepte aucun argument.
Partage sécurisé d'ensembles de données volumineux
Dans certains cas, comme ceux impliquant le machine learning ou la lecture de contenus multimédias, votre application peut vouloir utiliser le même grand ensemble de données qu'une autre application. Dans les versions précédentes d'Android, votre application et une autre application devaient chacune télécharger une copie distincte du même ensemble de données.
Pour réduire la redondance des données, à la fois sur le réseau et sur le disque, Android 11 permet de mettre en cache ces grands ensembles de données sur l'appareil à l'aide de blobs de données partagés. Pour en savoir plus sur le partage des ensembles de données, consultez le guide détaillé sur le partage de grands ensembles de données.
Effectuer un chiffrement basé sur les fichiers après un redémarrage OTA sans identifiants utilisateur
Une fois la mise à jour OTA terminée et l'appareil redémarré, les clés chiffrées par identifiant (CE) placées dans un stockage protégé par identifiant sont immédiatement disponibles pour les opérations de chiffrement basé sur les fichiers (FBE). Cela signifie qu'après une mise à jour OTA, votre application peut reprendre les opérations qui nécessitent les clés CE avant que l'utilisateur ne saisisse son code, son schéma ou son mot de passe.
Performances et qualité
Débogage sans fil
Android 11 prend en charge le déploiement et le débogage sans fil de votre application depuis votre poste de travail via Android Debug Bridge (adb). Vous pouvez par exemple déployer votre application débogable sur plusieurs appareils distants sans connecter physiquement votre appareil via USB ni devoir faire face aux problèmes de connexion USB courants, tels que l'installation de pilotes. Pour en savoir plus, consultez Exécuter des applications sur un appareil matériel.
Installation incrémentielle d'APK avec ADB
L'installation de fichiers APK volumineux (plus de 2 Go) sur un appareil peut prendre beaucoup de temps, même si une petite modification est apportée à une application. L'installation incrémentielle d'APK ADB (Android Debug Bridge) accélère ce processus en installant suffisamment de l'APK pour lancer l'application tout en diffusant les données restantes en arrière-plan. adb install
utilisera automatiquement cette fonctionnalité si elle est compatible avec l'appareil et si vous avez installé la dernière version des SDK Platform-Tools. Si ce n'est pas le cas, la méthode d'installation par défaut est utilisée de manière silencieuse.
Utilisez la commande adb suivante pour utiliser cette fonctionnalité. Si l'appareil n'est pas compatible avec l'installation incrémentielle, la commande échoue et affiche une explication détaillée.
adb install --incremental
Avant d'exécuter une installation incrémentielle d'APK ADB, vous devez signer votre APK et créer un fichier APK Signature Scheme v4. Pour que cette fonctionnalité fonctionne, le fichier de signature v4 doit être placé à côté de l'APK.
Détection d'erreur à l'aide de l'outil d'allocation de mémoire natif
GWP-ASan est une fonctionnalité d'allocation de mémoire native qui permet de détecter les bugs de type "use-after-free" et "heap-buffer-overflow". Vous pouvez activer cette fonctionnalité globalement ou pour des sous-processus spécifiques de votre application. Pour en savoir plus, consultez le guide GWP-Asan.
API Neural Networks 1.3
Android 11 étend et améliore l'API Neural Networks (NNAPI).
Nouvelles opérations
NNAPI 1.3 introduit un nouveau type d'opérande, TENSOR_QUANT8_ASYMM_SIGNED
, compatible avec le nouveau schéma de quantification de TensorFlow Lite.
De plus, NNAPI 1.3 introduit les nouvelles opérations suivantes:
QUANTIZED_LSTM
IF
WHILE
ELU
HARD_SWISH
FILL
RANK
Nouvelles commandes de ML
NNAPI 1.3 introduit de nouveaux contrôles pour assurer le bon fonctionnement du machine learning:
API QoS:la nouvelle API Quality of Service prend en charge l'établissement des priorités et les échéances des tâches dans NNAPI avec les nouvelles fonctions suivantes:
Entrée/Sortie de domaine de mémoire:NNAPI 1.3 est compatible avec les domaines de mémoire en entrée et en sortie pour l'exécution. Cela permet d'éliminer les copies inutiles des mêmes données entre les différents composants du système, améliorant ainsi les performances d'exécution des réseaux de neurones Android. Cette fonctionnalité ajoute un ensemble de nouvelles API NDK à utiliser avec les objets
ANeuralNetworksMemoryDesc
etANeuralNetworkMemory
, y compris les fonctions suivantes:ANeuralNetworksMemoryDesc_create()
ANeuralNetworksMemoryDesc_free()
ANeuralNetworksMemoryDesc_addInputRole()
ANeuralNetworksMemoryDesc_addOutputRole()
ANeuralNetworksMemoryDesc_setDimensions()
ANeuralNetworksMemoryDesc_finish()
ANeuralNetworksMemory_createFromDesc()
ANeuralNetworksMemory_copy()
Pour en savoir plus, consultez l'exemple de domaine de mémoire de réseau de neurones.
Compatibilité avec l'API de dépendance et la barrière de synchronisation:NNAPI 1.3 est compatible avec le calcul asynchrone avec des dépendances, ce qui permet de réduire considérablement les frais généraux lors de l'appel de petits modèles en chaîne. Cette fonctionnalité ajoute les nouvelles fonctions suivantes:
Flux de contrôle:NNAPI 1.3 est compatible avec le flux de contrôle général avec les nouvelles opérations de graphique
ANEURALNETWORKS_IF
etANEURALNETWORKS_WHILE
, qui acceptent d'autres modèles comme arguments à l'aide du nouveau type d'opérandeANEURALNETWORKS_MODEL
. De plus, cette fonctionnalité ajoute les nouvelles fonctions suivantes:
API NDK Thermal
Lorsque les appareils sont trop chauds, ils peuvent ralentir le processeur et/ou le GPU, ce qui peut affecter les applications de manière inattendue. Les applications ou les jeux qui intègrent des graphismes complexes, de nombreux calculs ou une activité réseau soutenue sont plus susceptibles de rencontrer des problèmes.
Utilisez l'API Thermal du NDK dans Android 11 pour surveiller les changements de température de l'appareil, puis prenez les mesures nécessaires pour limiter la consommation d'énergie et la température. Cette API est semblable à l'API Java Thermal. Vous pouvez l'utiliser pour recevoir des notifications en cas de changement d'état thermique ou pour interroger directement l'état actuel.
Texte et saisie
Amélioration des transitions IME
Android 11 introduit de nouvelles API permettant d'améliorer les transitions pour les éditeurs de mode de saisie (IME), tels que les claviers à l'écran. Ces API permettent d'ajuster plus facilement le contenu de votre application en synchronisation avec l'apparition et la disparition de l'IME, ainsi qu'avec d'autres éléments tels que les barres d'état et de navigation.
Pour afficher un IME alors qu'un EditText
est actif, appelez view.getInsetsController().show(Type.ime())
.
(Vous pouvez appeler cette méthode sur n'importe quelle vue de la même hiérarchie que l'EditText
sélectionnée. Vous n'avez pas besoin de l'appeler spécifiquement sur l'EditText
.) Pour masquer le IME, appelez view.getInsetsController().hide(Type.ime())
.
Vous pouvez vérifier si un IME est actuellement visible en appelant view.getRootWindowInsets().isVisible(Type.ime())
.
Pour synchroniser les vues de votre application avec l'apparition et la disparition de l'IME, définissez un écouteur sur une vue en fournissant un WindowInsetsAnimation.Callback
à View.setWindowInsetsAnimationCallback()
.
(Vous pouvez définir cet écouteur sur n'importe quelle vue, il ne doit pas s'agir d'une EditText
.) L'IME appelle la méthode onPrepare()
de votre écouteur, puis appelle onStart()
au début de la transition. Il appelle ensuite onProgress()
à chaque progression de la transition. Une fois la transition terminée, l'IME appelle onEnd()
.
À tout moment de la transition, vous pouvez connaître la progression de la transition en appelant WindowInsetsAnimation.getFraction()
.
Pour découvrir comment utiliser ces API, consultez le nouvel exemple de code WindowInsetsAnimation.
Contrôler l'animation IME
Vous pouvez également prendre le contrôle de l'animation IME ou d'une autre barre système, comme la barre de navigation. Pour ce faire, appelez d'abord setOnApplyWindowInsetsListener()
pour définir un nouvel écouteur pour les modifications des encarts de fenêtre:
Kotlin
rootView.setOnApplyWindowInsetsListener { rootView, windowInsets -> val barsIme = windowInsets.getInsets(Type.systemBars() or Type.ime()) rootView.setPadding(barsIme.left, barsIme.top, barsIme.right, barsIme.bottom) // We return the new WindowInsets.CONSUMED to stop the insets being // dispatched any further into the view hierarchy. This replaces the // deprecated WindowInsets.consumeSystemWindowInsets() and related // functions. WindowInsets.CONSUMED }
Java
mRoot.setOnApplyWindowInsetsListener(new View.OnApplyWindowInsetsListener() { @Override public WindowInsets onApplyWindowInsets(View v, WindowInsets insets) { Insets barsIME = insets.getInsets(Type.systemBars() | Type.ime()); mRootView.setPadding(barsIme.left, barsIme.top, barsIme.right, barsIme.bottom); // We return the new WindowInsets.CONSUMED to stop the insets being // dispatched any further into the view hierarchy. This replaces the // deprecated WindowInsets.consumeSystemWindowInsets() and related // functions. return WindowInsets.CONSUMED; } });
Pour déplacer l'IME ou une autre barre système, appelez la méthode controlWindowInsetsAnimation()
du contrôleur:
Kotlin
view.windowInsetsController.controlWindowInsetsAnimation( Type.ime(), 1000, LinearInterpolator(), cancellationSignal, object : WindowInsetsAnimationControlListener() { fun onReady(controller: WindowInsetsAnimationController, types: Int) { // update IME inset controller.setInsetsAndAlpha(Insets.of(0, 0, 0, inset), 1f /* alpha */, 0.1 /* fraction progress */) } } );
Java
mRoot.getWindowInsetsController().controlWindowInsetsAnimation( Type.ime(), 1000, new LinearInterpolator(), cancellationSignal, new WindowInsetsAnimationControlListener() { @Override public void onReady( @NonNull WindowInsetsAnimationController controller, int types ) { // update IME inset controller.setInsetsAndAlpha(Insets.of(0, 0, 0, inset), 1f /* alpha */, 0.1 /* fraction progress */); } @Override public void onCancelled() {} });
Mises à jour des bibliothèques ICU
Android 11 met à jour le package android.icu
pour qu'il utilise la version 66 de la bibliothèque ICU, contre la version 63 d'Android 10. La nouvelle version de la bibliothèque inclut des données de paramètres régionaux CLDR mises à jour et un certain nombre d'améliorations de la prise en charge de l'internationalisation dans Android.
Les modifications notables apportées aux nouvelles versions de la bibliothèque sont les suivantes:
- De nombreuses API de mise en forme acceptent désormais un nouveau type d'objet renvoyé qui étend
FormattedValue
. - L'API
LocaleMatcher
est améliorée avec une classe de constructeur, la prise en charge du typejava.util.Locale
et une classe de résultats présentant des données supplémentaires sur une correspondance. - Unicode 13 est désormais compatible.
Contenus multimédias
Allouer des tampons MediaCodec
Android 11 inclut de nouvelles API MediaCodec
qui offrent aux applications plus de contrôle lors de l'allocation des tampons d'entrée et de sortie. Cela permet à votre application de gérer la mémoire plus efficacement.
Nouveaux cours:
Nouvelles méthodes:
MediaCodec.getQueueRequest()
MediaCodec.getOutputFrame()
MediaCodec.LinearBlock.isCodecCopyFreeCompatible()
De plus, le comportement des deux méthodes dans MediaCodec.Callback()
a changé:
onInputBufferAvailable()
- Au lieu d'appeler
MediaCodec.getInputBuffer()
etMediaCodec.queueInputBuffer()
avec l'index, si elles sont configurées pour utiliser l'API Block Model, les applications doivent utiliserMediaCodec.getQueueRequest
avec l'index, en joignant un LinearBlock/HardwareBuffer à l'emplacement. onOutputBufferAvailable()
- Au lieu d'appeler
MediaCodec.getOutputBuffer()
avec l'index, les applications peuvent utiliserMediaCodec.getOutputFrame()
avec l'index pour obtenir l'objetOutputFrame
avec plus d'informations et des tampons LinearBlock/HardwareBuffer.
Décodage à faible latence dans MediaCodec
Android 11 améliore MediaCodec
afin de permettre le décodage à faible latence pour les jeux et d'autres applications en temps réel. Vous pouvez vérifier si un codec est compatible avec le décodage à faible latence en transmettant FEATURE_LowLatency
à MediaCodecInfo.CodecCapabilities.isFeatureSupported()
.
Pour activer ou désactiver le décodage à faible latence, effectuez l'une des opérations suivantes:
- Définissez la nouvelle clé
KEY_LOW_LATENCY
sur 0 ou 1 à l'aide deMediaCodec.configure()
. - Définissez la nouvelle clé de paramètre
PARAMETER_KEY_LOW_LATENCY
sur 0 ou 1 à l'aide deMediaCodec.setParameters()
.
Nouvelle fonction AAudio AAudioStream_release()
La fonction AAudioStream_close()
libère et ferme un flux audio en même temps. Cela peut être dangereux. Si un autre processus tente d'accéder au flux après sa fermeture, il plante.
La nouvelle fonction AAudioStream_release()
libère le flux, mais ne le ferme pas. Cela libère ses ressources et laisse le flux dans un état connu. L'objet persiste jusqu'à ce que vous appeliez AAudioStream_close()
.
API MediaParser
MediaParser est une nouvelle API de bas niveau pour l'extraction de contenu multimédia. Il est plus flexible que MediaExtractor et offre un contrôle supplémentaire sur la fonctionnalité d'extraction multimédia.
Capture audio depuis un périphérique USB
Lorsqu'une application sans autorisation RECORD_AUDIO
utilise UsbManager
pour demander un accès direct à un appareil audio USB avec fonctionnalité de capture audio (un casque USB, par exemple), un nouveau message d'avertissement demandant à l'utilisateur de confirmer l'autorisation d'utiliser l'appareil s'affiche. Le système ignore toute option "Toujours utiliser". L'utilisateur doit donc accuser réception de l'avertissement et accorder l'autorisation chaque fois qu'une application demande l'accès.
Pour éviter ce comportement, votre application doit demander l'autorisation RECORD_AUDIO
.
Accès simultané au micro
Android 11 ajoute de nouvelles méthodes aux API AudioRecord
, MediaRecorder
et AAudioStream
. Ces méthodes activent et désactivent la possibilité de capturer simultanément, quel que soit le cas d'utilisation sélectionné. Consultez Partager l'entrée audio.
Sélecteur de sortie
Android 11 implémente un nouveau comportement pour les applications qui utilisent les API Cast et MediaRouter.
En plus d'accéder aux options de diffusion depuis une application, les options de commutation apparaissent également dans le lecteur multimédia du système. Cela permet à l'utilisateur de naviguer facilement lorsqu'il passe d'un appareil à un autre lorsqu'il change de contexte de visionnage et d'écoute (par exemple, lorsqu'il regarde une vidéo dans la cuisine ou sur un téléphone, ou qu'il écoute du contenu audio à la maison ou en voiture). Reportez-vous au sélecteur de sortie.
Connectivité
Améliorations de Wi-Fi Passpoint
Pour en savoir plus sur les fonctionnalités de Passpoint ajoutées dans Android 11, consultez Passpoint.
L'API Wi-Fi Suggestion est étendue
Android 11 étend l'API Wi-Fi Suggestion pour améliorer les fonctionnalités de gestion de réseau de votre application, y compris les suivantes:
- Les applications de gestion de la connectivité peuvent gérer leurs propres réseaux en autorisant les demandes de déconnexion.
- Les réseaux Passpoint sont intégrés à l'API Suggestion et peuvent être suggérés à l'utilisateur.
- Les API Analytics vous permettent d'obtenir des informations sur la qualité de vos réseaux.
Mises à jour de CallScreeningService
À partir d'Android 11, un CallScreeningService peut demander des informations sur l'état de validation STIR/SHAKEN (verstat) des appels entrants. Ces informations sont fournies dans les détails des appels entrants.
Si un CallScreeningService
détient l'autorisation READ_CONTACTS
, l'application est avertie en cas d'appels entrants ou sortants vers un numéro figurant dans la liste de contacts de l'utilisateur.
Pour en savoir plus, consultez la section Empêcher le spoofing du numéro de l'appelant.
Nouveautés concernant l'API Open Mobile
Pour en savoir plus sur la compatibilité avec OMAPI sous Android 11 ou version ultérieure, consultez Compatibilité avec les lecteurs de l'API Open Mobile.
VPN performants
Les applications qui ciblent le niveau d'API 30 ou supérieur ou qui s'exécutent sur des appareils lancés avec le niveau d'API 29 ou supérieur peuvent appliquer IKEv2/IPsec aux VPN, qu'ils soient configurés par l'utilisateur ou basés sur une application.
Les VPN s'exécutent de manière native sur le système d'exploitation, ce qui simplifie le code requis pour établir des connexions VPN IKEv2/IPsec dans une application.
Contrôle des accès au réseau par processus
Pour plus d'informations sur l'activation de l'accès au réseau par processus, consultez la section Gérer l'utilisation du réseau.
Autoriser plusieurs configurations Passpoint installées avec le même nom de domaine complet
À partir d'Android 11, vous pouvez utiliser PasspointConfiguration.getUniqueId()
pour obtenir un identifiant unique pour un objet PasspointConfiguration
, ce qui permet aux utilisateurs de votre application d'installer plusieurs profils avec le même nom de domaine complet (FQDN).
Cette fonctionnalité est utile lorsqu'un opérateur déploie plusieurs combinaisons de code pays mobile (MCC) et de code de réseau mobile (MNC) sur son réseau, mais qui ne possède qu'un seul nom de domaine complet. Sur Android 11 et versions ultérieures, il est possible d'installer plusieurs profils avec le même FQDN qui correspond au réseau en tant que fournisseur de domicile lorsque l'utilisateur installe une carte SIM avec MCC ou MNC.
Compatibilité avec les antennes GNSS
Android 11 introduit la classe GnssAntennaInfo
, qui permet à votre application d'utiliser davantage le positionnement précis au centimètre que le système de navigation par satellite mondial (GNSS) peut fournir.
Pour en savoir plus, consultez le guide sur les informations sur le calibrage de l'antenne.
Graphiques
Décodeur d'images du NDK
L'API ImageDecoder
du NDK fournit une API standard pour les applications C/C++ Android permettant de décoder directement les images. Les développeurs d'applications n'ont plus besoin d'utiliser les API du framework (via JNI) ni de regrouper des bibliothèques de décodage d'images tierces. Pour en savoir plus, consultez le guide du développeur du décodeur d'images.
API de fréquence d'images
Android 11 fournit une API qui permet aux applications d'informer le système de la fréquence d'images souhaitée afin de réduire les à-coups sur les appareils compatibles avec plusieurs fréquences d'actualisation. Pour savoir comment utiliser cette API, consultez le guide sur la fréquence d'images.
Demander et vérifier la prise en charge de la faible latence
Certains écrans peuvent effectuer un post-traitement graphique, comme certains écrans et téléviseurs externes. Ce post-traitement améliore les graphismes, mais peut augmenter la latence. Les écrans plus récents, compatibles avec HDMI 2.1, disposent d'un mode automatique à faible latence (ALLM, également appelé mode jeu), qui minimise la latence en désactivant ce post-traitement. Pour en savoir plus sur l'ALLM, consultez la spécification HDMI 2.1.
Une fenêtre peut demander l'utilisation du mode à faible latence automatique, si celui-ci est disponible. L'ALLM est particulièrement utile pour les applications telles que les jeux et la visioconférence, où la faible latence est plus importante que les meilleurs graphismes possibles.
Pour activer ou désactiver le post-traitement minimal, appelez Window.setPreferMinimalPostProcessing()
ou définissez l'attribut preferMinimalPostProcessing
de la fenêtre sur true
. Tous les écrans n'acceptent pas un post-traitement minimal. Pour savoir si un écran particulier le permet, appelez la nouvelle méthode Display.isMinimalPostProcessingSupported()
.
Injection de couche de débogage graphique performante
Les applications peuvent désormais charger des calques graphiques externes (GLES, Vulkan) dans le code d'application natif pour exposer les mêmes fonctionnalités qu'une application débogable, mais sans entraîner de coûts de performances. Cette fonctionnalité est particulièrement importante lorsque vous effectuez le profilage de votre application avec des outils tels que GAPID. Pour profiler votre application, incluez l'élément de métadonnées suivant dans le fichier manifeste de votre application au lieu de la rendre débogable:
<application ... > <meta-data android:name="com.android.graphics.injectLayers.enable" android:value="true" /> </application>
Images et appareil photo
Couper le son et le vibreur des notifications pendant la capture active
À partir d'Android 11, lorsque vous utilisez activement l'appareil photo, votre application ne peut couper que les vibrations, les sons et les vibrations, ou aucun des deux à l'aide de setCameraAudioRestriction()
.
Compatibilité étendue de l'appareil photo dans Android Emulator
Pour en savoir plus sur la compatibilité étendue des appareils photo dans l'émulateur à partir d'Android 11, consultez la section Compatibilité de l'appareil photo.
Prise en charge de l'utilisation simultanée de plusieurs caméras
Android 11 ajoute des API pour demander la prise en charge de l'utilisation de plusieurs appareils photo à la fois, y compris les caméras avant et arrière.
Pour vérifier la prise en charge de l'appareil sur lequel votre application s'exécute, utilisez les méthodes suivantes:
getConcurrentCameraIds()
renvoie unSet
de combinaisons d'ID de caméra pouvant diffuser simultanément des combinaisons de flux garanties lorsqu'elles sont configurées par le même processus d'application.isConcurrentSessionConfigurationSupported()
demande si les caméras peuvent prendre en charge simultanément les configurations de session correspondantes.
Meilleure prise en charge des images HEIF comportant plusieurs images
À partir d'Android 11, si vous appelez ImageDecoder.decodeDrawable()
et transmettez une image HEIF contenant une séquence d'images (telle qu'une animation ou une photo en rafale), la méthode renvoie un AnimatedImageDrawable
contenant l'ensemble de la séquence d'images. Dans les versions antérieures d'Android, la méthode renvoyait un BitmapDrawable
d'un seul frame.
Si le graphique HEIF contient plusieurs images qui ne sont pas dans une séquence, vous pouvez récupérer une image individuelle en appelant MediaMetadataRetriever.getImageAtIndex()
.
Accessibilité
Informations destinées aux développeurs de services d'accessibilité
Si vous créez un service d'accessibilité personnalisé, vous pouvez utiliser les fonctionnalités suivantes dans Android 11:
- L'explication destinée à l'utilisateur d'un service d'accessibilité permet désormais d'utiliser du code HTML et des images en plus du texte brut. Cette flexibilité vous permet d'expliquer plus facilement aux utilisateurs finaux ce que votre service fait et comment il peut les aider.
- Pour utiliser une description de l'état d'un élément d'interface utilisateur plus sémantiquement pertinente que
contentDescription
, appelez la méthodegetStateDescription()
. - Pour demander que les événements tactiles contournent l'explorateur tactile du système, appelez
setTouchExplorationPassthroughRegion()
. De même, pour demander que les gestes contournent le détecteur de gestes du système, appelezsetGestureDetectionPassthroughRegion()
. - Vous pouvez demander des actions IME, telles que "Entrée" et "Suivant", ainsi que des captures d'écran de fenêtres qui n'activent pas l'indicateur
FLAG_SECURE
.
Autres fonctionnalités
Motif de sortie du processus de l'application
Android 11 introduit la méthode ActivityManager.getHistoricalProcessExitReasons()
, qui indique les raisons de toute interruption de processus récente. Les applications peuvent utiliser cette méthode pour collecter des informations de diagnostic sur les plantages, par exemple pour déterminer si l'arrêt d'un processus est dû à des erreurs ANR, à des problèmes de mémoire ou à d'autres raisons.
Vous pouvez également utiliser la nouvelle méthode setProcessStateSummary()
pour stocker des informations d'état personnalisées à des fins d'analyse ultérieure.
La méthode getHistoricalProcessExitReasons()
renvoie des instances de la classe ApplicationExitInfo
, qui contient des informations sur l'arrêt d'un processus d'application. En appelant getReason()
sur une instance de cette classe, vous pouvez déterminer pourquoi le processus de votre application a été arrêté. Par exemple, une valeur de retour de REASON_CRASH
indique qu'une exception non gérée s'est produite dans votre application. Si votre application doit garantir l'unicité des événements de sortie, elle peut gérer un identifiant propre à l'application, tel qu'une valeur de hachage basée sur le code temporel de la méthode getTimestamp()
.
Ressources supplémentaires
Pour en savoir plus, consultez l'article sur les nouveaux outils Android 11 pour rendre les applications plus privées et plus stables sur Medium.
Chargeurs de ressources
Android 11 introduit une nouvelle API qui permet aux applications d'étendre de manière dynamique la façon dont les ressources sont recherchées et chargées. Les nouvelles classes d'API ResourcesLoader
et ResourcesProvider
sont principalement chargées de fournir les nouvelles fonctionnalités. Ensemble, ils permettent de fournir des ressources et des éléments supplémentaires, ou de modifier les valeurs des ressources et des éléments existants.
Les objets ResourcesLoader
sont des conteneurs qui fournissent des objets ResourcesProvider
à l'instance Resources
d'une application. À leur tour, les objets ResourcesProvider
fournissent des méthodes permettant de charger des données de ressources à partir d'APK et de tables de ressources.
L'un des principaux cas d'utilisation de cette API est le chargement d'éléments personnalisés. Vous pouvez utiliser loadFromDirectory()
pour créer un ResourcesProvider
qui redirige la résolution des ressources et des éléments basés sur des fichiers, ce qui le fait rechercher un répertoire spécifique plutôt que l'APK de l'application. Vous pouvez accéder à ces éléments via la famille de méthodes open()
de la classe d'API AssetManager
, comme pour les éléments groupés dans l'APK.
APK Signature Scheme v4
Android 11 est compatible avec APK Signature Scheme v4. Ce schéma génère un nouveau type de signature dans un fichier distinct (apk-name.apk.idsig
), mais est par ailleurs semblable aux versions 2 et 3. Aucune modification n'est apportée à l'APK. Ce schéma est compatible avec l'installation incrémentielle d'APK d'ADB, ce qui accélère l'installation de l'APK.
Filtres d'intent dynamiques
Pour recevoir des intents, une application doit déclarer au moment de la compilation les types de données qu'elle peut recevoir en définissant un filtre d'intent dans le fichier manifeste de l'application. Dans Android 10 et versions antérieures, les applications n'ont aucun moyen de modifier leurs filtres d'intent au moment de l'exécution. Cela pose problème pour les applications de virtualisation (telles que les machines virtuelles et les bureaux à distance), car elles n'ont aucun moyen de savoir exactement quel logiciel l'utilisateur installera dedans.
Android 11 introduit les groupes MIME, un nouvel élément manifeste qui permet à une application de déclarer un ensemble dynamique de types MIME dans un filtre d'intent et de le modifier de manière automatisée au moment de l'exécution. Pour utiliser un groupe MIME, incluez un élément de données dans le fichier manifeste de votre application avec le nouvel attribut android:mimeGroup
:
<intent-filter> <action android:name="android.intent.action.SEND"/> <category android:name="android.intent.category.DEFAULT"/> <data android:mimeGroup="myMimeGroup"/> </intent-filter>
La valeur de l'attribut android:mimeGroup
est un ID de chaîne arbitraire qui identifie le groupe MIME au moment de l'exécution. Vous pouvez accéder au contenu d'un groupe MIME et le mettre à jour en transmettant son ID aux nouvelles méthodes suivantes de la classe d'API PackageManager
:
Lorsque vous ajoutez un type MIME à un groupe MIME de manière programmatique, il fonctionne exactement de la même manière qu'un type MIME statique déclaré explicitement dans le fichier manifeste.
Améliorations apportées à la saisie automatique
Android 11 introduit des améliorations pour les services de saisie automatique.
Identifiants d'indice dans AssistStructure.ViewNode
Il est souvent utile pour les services de saisie automatique de calculer un hachage de signature pour un affichage en fonction de ses propriétés. La suggestion d'affichage est une propriété particulièrement intéressante à inclure lors du calcul d'un hachage de signature, mais elle peut changer en fonction des paramètres régionaux du téléphone. Pour résoudre ce problème, Android 11 étend AssistStructure.ViewNode
avec une nouvelle méthode getHintIdEntry()
, qui renvoie l'identifiant de ressource pour le texte d'invite d'une vue. Cette méthode fournit une valeur indépendante de la langue que vous pouvez utiliser pour calculer les hachages de signature.
Événements affichés dans les ensembles de données
Pour aider les services de saisie automatique à améliorer leurs suggestions, Android 11 permet d'identifier les cas où un service de saisie automatique a présenté des ensembles de données, mais que l'utilisateur n'en a sélectionné aucun. Dans Android 11, FillEventHistory
signale un nouveau type d'événement TYPE_DATASETS_SHOWN
. FillEventHistory
consigne un événement de ce type chaque fois que le service de saisie semi-automatique présente un ou plusieurs ensembles de données à l'utilisateur. Les services de saisie automatique peuvent utiliser ces événements conjointement avec l'événement TYPE_DATASET_SELECTED
existant pour déterminer si l'utilisateur a sélectionné l'une des options de saisie automatique fournies.
Intégration IME
Les claviers et autres IME peuvent désormais afficher des suggestions de saisie automatique intégrées, dans une barre de suggestions ou une interface similaire, au lieu d'un menu déroulant. Pour protéger les informations sensibles telles que les mots de passe et les numéros de carte de crédit, les suggestions sont présentées à l'utilisateur, mais ne sont pas connues de l'IME tant qu'il n'en a pas sélectionné une. Pour savoir comment les IME et les gestionnaires de mots de passe peuvent prendre en charge cette fonctionnalité, consultez Intégrer la saisie automatique aux claviers.
Partage de données avec un service de capture de contenu
À partir d'Android 11, votre application peut partager des données avec le service de capture de contenu de l'appareil. Cette fonctionnalité permet à un appareil de fournir plus facilement des informations contextuelles, comme l'affichage du nom d'un titre actuellement diffusé dans l'environnement de l'utilisateur.
Pour rendre les données de votre application disponibles pour le service de capture de contenu, appelez la méthode shareData()
sur une instance de ContentCaptureManager
. Si le système accepte la requête de partage de données, votre application reçoit un descripteur de fichier en écriture seule à partager avec le service de capture de contenu.