Android active un mode de compatibilité pour les applications qui déclarent des restrictions d'orientation ou de redimensionnement. Le mode de compatibilité garantit un comportement acceptable de l'application sur les appareils à grand écran et les téléphones à clapet pliables, mais avec une facilité d'utilisation non optimale.
Les forçages par application permettent aux fabricants d'appareils de modifier le comportement des applications afin d'améliorer l'expérience utilisateur ou d'éviter les problèmes de fonctionnement d'applications sur des appareils spécifiques.
Appareils de référence
Les appareils suivants peuvent nécessiter des forçages par application en raison de configurations inhabituelles ou non compatibles avec les applications:
- Tablettes:l'orientation naturelle de certaines tablettes, comme la Pixel Tablet, est le mode paysage. Un appareil est dans son orientation naturelle lorsque
Display#getRotation()
renvoieSurface.ROTATION_0
. Si les applications supposent queROTATION_0
est en mode portrait, les mises en page des applications et l'aperçu de l'appareil photo peuvent ne pas correspondre à l'écran de l'appareil. - Appareils pliables en mode paysage:certains appareils pliables, tels que le Pixel Fold, sont en mode portrait lorsqu'ils sont pliés, mais en mode paysage lorsqu'ils sont dépliés. Si les applications supposent que l'orientation est dépliée en mode portrait, des boucles de scintillement ou des problèmes de mise en page risquent d'être détectés.
- Téléphones à clapet pliables : les téléphones à clapet dépliés sont généralement en mode portrait. Mais lorsqu'ils sont pliés, les téléphones ont généralement un petit écran en mode paysage. Les applications doivent identifier et s'adapter aux différentes orientations des écrans.
Problèmes de compatibilité courants
Lorsque les applications rencontrent des problèmes de compatibilité, ces problèmes sont généralement causés par des restrictions de l'orientation de l'application, des restrictions de redimensionnement et de format, une mauvaise gestion de l'orientation de l'aperçu de l'appareil photo et des API mal utilisées.
Format letterbox
Le format letterbox positionne l'application au centre de l'écran ou, sur les grands écrans, d'un côté ou de l'autre pour en faciliter l'accès. Des bandes (barres de couleur unie ou fond d'écran flouté) remplissent la zone d'affichage inutilisée sur les côtés, ou en haut et en bas de l'application.
Le format letterbox est souvent appliqué sur les appareils à grand écran, car les dimensions et le format de l'écran de l'appareil sont généralement différents de ceux des téléphones standards, pour lesquels la plupart des applications sont conçues.
Problème
L'application n'est pas compatible avec toutes les configurations d'affichage, car elle a une orientation ou un format fixe ou n'est pas redimensionnable.
Parmi les paramètres de configuration qui contrôlent l'orientation et le redimensionnement de l'application, on trouve par exemple les suivants :
screenOrientation
: spécifie une orientation fixe pour une application. Les applications peuvent également définir l'orientation au moment de l'exécution à l'aide deActivity#setRequestedOrientation()
.resizeableActivity
: indique si le système est autorisé ou non à redimensionner les applications pour les adapter aux fenêtres de différentes dimensions. Sur Android 11 (niveau d'API 30) ou version antérieure, ce paramètre indique si les applications sont compatibles ou non avec le mode multifenêtre. Sur Android 12 (niveau d'API 31) ou version ultérieure, spécifie si les applications prennent en charge le mode multifenêtre sur les petits écrans (classe de taille de fenêtre compacte). Sur Android 12 et versions ultérieures, les applications sont compatibles avec le mode multifenêtre sur les grands écrans (classe de taille de fenêtre moyenne ou agrandie), quel que soit le réglage de ce paramètre.maxAspectRatio
: spécifie le format maximal accepté par l'application. Seules les applications avecresizeableActivity
défini surfalse
peuvent définirmaxAspectRatio
.minAspectRatio
: spécifie le format minimal accepté par l'application. Seules les applications avecresizeableActivity
défini surfalse
peuvent définirminAspectRatio
.
Optimisation
L'application doit être compatible avec tous les appareils et toutes les orientations et tailles d'affichage en mode multifenêtre. Supprimez toutes les restrictions d'orientation et de format fixe des mises en page et du fichier manifeste de votre application.
Solution de compatibilité
Si une application à orientation ou format fixe s'exécute dans une fenêtre où elle n'est pas directement compatible avec la taille ou l'orientation de la fenêtre, Android la met au format letterbox pour préserver la continuité.
À partir d'Android 12 (niveau d'API 31) et avec la version 12L (niveau d'API 32) ensuite, la plate-forme applique diverses améliorations aux applications au format letterbox. Les fabricants d'appareils mettent en œuvre les améliorations de l'interface utilisateur. Vous n'avez pas besoin d'effectuer de développement supplémentaire pour que votre application puisse bénéficier de ces améliorations.
Android 12 (niveau d'API 31) introduit les améliorations esthétiques suivantes, que les fabricants d'appareils peuvent configurer :
- Angles arrondis : les angles de la fenêtre de l'application ont un aspect plus élégant.
- Transparence de la barre système:les barres d'état et de navigation, qui se superposent à l'application, sont semi-transparentes. Les icônes des barres sont donc toujours visibles sur l'arrière-plan du format letterbox.
- Format configurable:vous pouvez ajuster le format de l'application pour l'améliorer.
La version 12L (niveau d'API 32) ajoute les améliorations fonctionnelles suivantes :
Positionnement configurable:sur les grands écrans, les fabricants d'appareils peuvent positionner l'application sur le côté gauche ou droit de l'écran, ce qui facilite les interactions.
Refonte du bouton de redémarrage:les fabricants d'appareils peuvent donner une nouvelle apparence au bouton de redémarrage du mode de compatibilité de taille afin d'améliorer sa reconnaissance par les utilisateurs.
Android 13 (niveau d'API 33) ajoute une boîte de dialogue pédagogique expliquant à l'utilisateur comment positionner l'application au format letterbox à l'écran ou comment inclure ce format en mode Écran partagé :
Mode de compatibilité de taille
Le mode de compatibilité de taille est un format letterbox qui inclut une commande de redémarrage. Cette commande permet aux utilisateurs de redémarrer l'application et de redessiner l'écran. Android appelle le mode de compatibilité de taille pour les applications qui ne sont pas redimensionnables. Lorsqu'une activité est déplacée vers un conteneur d'affichage incompatible avec ses dimensions, le système peut redimensionner l'application pour qu'elle occupe toute la largeur et/ou toute la longueur de l'écran de l'appareil.
Voici les modifications apportées à la configuration de l'appareil qui peuvent déclencher le mode de compatibilité de taille :
- Rotation de l'appareil
- Pliage ou dépliage d'appareils pliables
- Passage du mode plein écran au mode Écran partagé
Problème
Le mode de compatibilité de taille s'applique généralement aux activités dont l'orientation ou le format sont limités, et qui sont configurées (ou déterminées par le système) pour ne pas être redimensionnables.
Votre application est considérée comme redimensionnable (et ne sera pas placée en mode de compatibilité de taille) si elle répond à l'un des critères suivants :
- Elle est redimensionnable avec
resizeableActivity="true"
. - Elle est compatible avec le mode Picture-in-picture (PIP).
- Elle est intégrée.
- Le fabricant de l'appareil lui a appliqué le forçage par application
FORCE_RESIZE_APP
(les propriétés définies par l'application sont ignorées).
Si votre application ne remplit pas l'une de ces conditions, elle est considérée comme non redimensionnable. Elle peut donc être placée en mode de compatibilité de taille.
Optimisation
L'application doit être compatible avec toutes les tailles d'écran. Rendez votre application redimensionnable en définissant l'attribut android:resizeableActivity
de l'élément <activity>
ou <application>
sur true
dans le fichier manifeste de l'application. Concevez des mises en page responsives/adaptatives pour votre application. Pour en savoir plus, consultez les pages Assurer la compatibilité avec différentes tailles d'écran et Compatibilité avec le mode multifenêtre.
Solution de compatibilité
Android place une application en mode de compatibilité de taille lorsque le système détermine que l'affichage de l'application au format letterbox peut être amélioré en redimensionnant l'application pour qu'elle remplisse la fenêtre d'affichage dans au moins une dimension. Le système affiche une commande de redémarrage qui recrée le processus de l'application, recréant l'activité et redessinant l'écran. Consultez aussi la page Présentation des processus et des threads.
Boucles de clignotement
Lorsqu'une application n'est pas compatible avec toutes les orientations d'écran, elle peut demander de nouvelles orientations à plusieurs reprises lors d'une modification de la configuration, créant ainsi une boucle infinie qui fera clignoter l'écran ou pivoter l'application sans fin.
Problème
Sur Android 12 (niveau d'API 31) ou version ultérieure, les fabricants peuvent configurer leurs appareils de manière à ignorer les restrictions d'orientation spécifiées par les applications et à appliquer à la place les modes de compatibilité. Par exemple, un appareil pliable peut ignorer le paramètre android:screenOrientation="portrait"
d'une activité lorsque celle-ci s'affiche sur l'écran intérieur de l'appareil au format tablette.
Si les restrictions d'orientation d'une application sont ignorées, l'application peut définir son orientation de façon programmatique en appelant Activity#setRequestedOrientation()
. L'appel déclenche un redémarrage de l'application si celle-ci ne gère pas les modifications de configuration (consultez la section Gérer les modifications de configuration). Après le redémarrage, les restrictions d'orientation de l'application sont à nouveau ignorées, l'application répète l'appel de setRequestedOrientation()
, l'appel déclenche un redémarrage de l'application, et ainsi de suite dans une boucle perpétuelle.
Vous pouvez également rencontrer ce problème lorsque l'orientation naturelle (l'orientation usuelle déterminée par Android) de l'écran d'un appareil est le mode paysage (c'est-à-dire que l'appel de Display#getRotation()
renvoie Surface.ROTATION_0
alors que l'appareil est en mode paysage). Par le passé, les applications considéraient que Display.getRotation() =
Surface.ROTATION_0
indiquait que l'appareil était en mode portrait, mais ce n'est pas toujours le cas, par exemple sur l'écran interne de certains appareils pliables et sur certaines tablettes.
Une application en mode paysage sur un écran intérieur pliable peut vérifier la rotation de l'écran, recevoir une valeur de ROTATION_0
, supposer que l'orientation naturelle de l'appareil est en mode portrait et appeler setRequestedOrientation(
ActivityInfo.SCREEN_ORIENTATION_PORTRAIT
)
pour reconfigurer la mise en page de l'application. Après le redémarrage de l'application (en mode paysage), elle peut à nouveau vérifier la rotation de l'écran, recevoir la valeur ROTATION_0
, appeler setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT)
et poursuivre la boucle infinie.
Optimisation
Les applications ne doivent pas effectuer les opérations suivantes :
- Définissez une orientation par défaut avec
Activity#setRequestedOrientation()
dans la méthodeonCreate()
de l'activité, car la requête d'orientation peut être déclenchée de manière inattendue par des modifications de configuration non gérées. - Supposer que l'orientation naturelle de l'appareil (
ROTATION_0
) est le mode portrait - Définir l'orientation en fonction de signaux qui ne sont pas liés à la taille de fenêtre actuelle, comme
Display#getRotation()
, la présence d'uneFoldingFeature
ou des API obsolètes
Solution de compatibilité
Android ignore les appels à Activity#setRequestedOrientation()
dans les situations suivantes:
L'activité a déjà été relancée à partir d'un appel précédent à la méthode, ou le traitement de rotation forcée pour compatibilité de l'appareil photo a été activé (voir Aperçu de l'appareil photo ci-dessous).
Les fabricants d'appareils peuvent appliquer ce comportement à une application avec
OVERRIDE_ENABLE_COMPAT_IGNORE_REQUESTED_ORIENTATION
.L'activité a effectué plus de deux requêtes d'orientation en une seconde, ce qui indique qu'une boucle s'est produite. Parmi les deux requêtes de la boucle, Android utilise celle qui maximise la zone d'affichage de l'application.
Les fabricants d'appareils peuvent appliquer ce comportement à une application avec
OVERRIDE_ENABLE_COMPAT_IGNORE_ORIENTATION_REQUEST_WHEN_LOOP_DETECTED
.
Aperçu de l'appareil photo
L'aperçu de l'appareil photo (ou le viseur) des applications d'appareil photo peut être mal aligné ou déformé sur les tablettes, les ordinateurs portables et les écrans pliables.
Problème
Le document de définition de compatibilité Android spécifie qu'un capteur d'image de l'appareil photo "DOIT être orienté de sorte à faire correspondre la dimension longue de l'appareil photo à la dimension longue de l'écran".
Les applications supposent souvent que l'orientation de l'appareil et celle du capteur de l'appareil photo sont en mode portrait, ce qui est une hypothèse acceptable pour les téléphones mobiles standards. Cependant, l'orientation naturelle des tablettes et des ordinateurs portables et des capteurs de leur appareil photo peut être en mode paysage. En outre, les nouveaux facteurs de forme tels que les pliables peuvent avoir plusieurs orientations naturelles et plusieurs capteurs d'appareil photo dans différentes orientations.
Le démarrage d'une activité avec une orientation d'appareil photo à laquelle l'application ne s'attend pas, ou le passage d'un appareil photo ou d'un écran à l'autre (pour les appareils pliables) peut entraîner un mauvais alignement ou une distorsion de l'aperçu de l'appareil photo.
Optimisation
Les applications d'appareil photo doivent identifier et gérer correctement l'orientation de l'appareil et celle du capteur de l'appareil photo pour présenter un aperçu correctement aligné et à l'échelle. Les applications doivent calculer la rotation de l'appareil, la rotation des capteurs et le format de l'écran ou de la fenêtre, puis appliquer les résultats obtenus à l'aperçu de l'appareil photo. Pour en savoir plus, consultez Aperçu de l'appareil photo et Présentation du viseur de l'appareil photo.
Solution de compatibilité
Un appareil est en orientation naturelle lorsque Display#getRotation()
renvoie Surface.ROTATION_0
. Le système calcule CameraCharacteristics.SENSOR_ORIENTATION
à partir de l'orientation naturelle de l'appareil. Android adapte la fenêtre du mode portrait de l'application limitée au mode portrait à l'orientation naturelle de l'appareil, le comportement attendu par la plupart des applications. Android recadre également l'image du capteur de l'appareil photo lorsque le capteur est orienté en mode paysage alors que l'aperçu de l'appareil photo est en mode portrait. Voici des solutions spécifiques:
Forcer la rotation des aperçus de l'appareil photo pour les applications limitées au mode portrait : les applications limitées au mode portrait s'attendent à ce que l'orientation naturelle de l'appareil et l'orientation du capteur de l'appareil photo soient en mode portrait. Toutefois, sur Android 12 (niveau d'API 31) ou version ultérieure, les applications peuvent s'exécuter dans plusieurs orientations d'appareil si les fabricants d'appareils ignorent la spécification d'orientation.
Lorsqu'une application limitée au mode portrait est connectée à l'appareil photo, Android force la rotation de l'application pour aligner la fenêtre du mode portrait avec l'orientation naturelle de l'appareil.
Sur certaines tablettes (voir les appareils de référence), la fenêtre de l'application en mode portrait est pivotée en mode portrait plein écran pour s'adapter à l'orientation naturelle de l'appareil. L'application occupe la totalité de l'écran après la rotation forcée.
Sur l'écran intérieur en mode paysage des appareils pliables (voir les appareils de référence), les activités limitées au mode portrait sont orientées en mode paysage pour correspondre à l'orientation naturelle lorsque l'appareil est déplié. Après la rotation forcée, l'application est mise au format letterbox.
Recadrage de la caméra avant intérieure:le capteur de la caméra avant intérieure de certains appareils pliables est en mode paysage. En plus de forcer la rotation de l'aperçu de l'appareil photo sur l'écran intérieur de l'appareil pliable, Android recadre le champ de vision de la caméra avant intérieure (paysage) afin que le capteur capture une vue opposée à l'orientation de l'appareil.
Forcer l'actualisation des aperçus de l'appareil photo : le système parcourt les méthodes d'activité
onStop()
etonStart()
(par défaut) ouonPause()
etonResume()
(appliquées par le forçage par application OVERRIDE_CAMERA_COMPAT_ENABLE_REFRESH_VIA_PAUSE) après la rotation forcée pour s'assurer que l'aperçu de l'appareil photo s'affiche correctement.Mise à l'échelle du format : le système modifie de façon dynamique le format de l'aperçu de l'appareil photo qui a fait l'objet d'une rotation forcée, afin qu'il soit à un format minimal plus élevé, ce qui permet de s'assurer que l'aperçu de l'appareil photo est correctement mis à l'échelle.
Les développeurs d'applications peuvent ignorer ces solutions si les applications gèrent correctement l'aperçu de l'appareil photo. Consultez la section Forçages par application.
Mauvaises utilisations courantes d'API
Android prend désormais en charge des fonctionnalités telles que le mode multifenêtre et des appareils tels que les appareils pliables. Les anciennes API sont donc obsolètes et ont été remplacées par des API à jour, compatibles avec toutes les tailles d'écran et tous les facteurs de forme d'appareil. Toutefois, les API obsolètes sont toujours disponibles pour assurer la rétrocompatibilité.
Certaines API View
sont conçues pour des besoins particuliers qui ne sont pas toujours bien compris par les développeurs.
Problème
Les développeurs continuent à utiliser des API Display
obsolètes et supposent à tort que les API renvoient les limites de l'application au lieu des limites de la zone d'affichage de l'appareil. Les développeurs peuvent également utiliser à tort des API de vues spécifiques pour obtenir des métriques d'affichage générales.
Cela entraîne des erreurs de calcul lors du repositionnement des éléments d'interface utilisateur après des événements de redimensionnement de la fenêtre de l'application, ce qui entraîne des problèmes de mise en page.
API Display obsolètes et couramment utilisées de façon incorrecte :
Pour en savoir plus, consultez la section Prendre en charge le mode multifenêtre.
API View mal utilisées :
Optimisation
Ne vous appuyez jamais sur la taille d'écran physique pour positionner les éléments d'interface utilisateur. Migrez votre application vers des API basées sur WindowMetrics
, y compris les API WindowManager
suivantes :
Plate-forme :
Jetpack:
Solution de compatibilité
Deux forçages permettent d'ajuster les API Display
obsolètes et les API View
mal utilisées pour renvoyer les limites de l'application : ALWAYS_SANDBOX_DISPLAY_APIS
pour les API Display
et OVERRIDE_SANDBOX_VIEW_BOUNDS_APIS
pour les API View
. ALWAYS_SANDBOX_DISPLAY_APIS
est également appliqué par défaut aux applications éligibles au mode de compatibilité de taille.
Activités transparentes
Les activités transparentes sont le résultat de styles d'arrière-plan transparents, par exemple:
<style name="Transparent" parent="AppTheme">
<item name="android:windowIsTranslucent">true</item>
<item name="android:windowBackground">@android:color/transparent</item>
</style>
Les thèmes associés aux boîtes de dialogue, tels que Theme.MaterialComponents.Dialog
, peuvent inclure des styles qui rendent les activités transparentes.
Les activités transparentes n'occupent pas tout l'espace d'affichage disponible. Elles sont donc difficiles à gérer, car la zone d'affichage disponible peut changer en fonction des changements de configuration tels que la rotation de l'appareil, le pliage et le dépliage de l'appareil, et le mode multifenêtre.
Problème
Une activité transparente doit respecter les limites de la première activité opaque sous l'activité transparente dans la pile d'activités de la tâche. Cependant, une activité opaque qui lance une boîte de dialogue d'autorisation peut être un trampoline (activité qui lance une autre activité, puis disparaît). Par conséquent, le système ne peut pas déterminer les limites de l'activité de trampoline qui a lancé l'activité de boîte de dialogue d'autorisation transparente.
Optimisation
Les activités transparentes héritent des contraintes de l'activité opaque supérieure située en dessous d'elles dans la pile d'activités d'une tâche. L'activité opaque doit être disponible tout au long du cycle de vie de l'activité transparente, de sa création à sa destruction. C'est pourquoi vous ne devez pas lancer de demandes d'autorisation à partir d'activités de trampoline.
Si une activité de trampoline lance une demande d'autorisation, il est possible que l'utilisateur ne puisse pas voir la boîte de dialogue d'autorisation, car l'activité de trampoline a été détruite avant que l'utilisateur n'ait eu le temps de répondre à la boîte de dialogue, et que ses dimensions et sa position aient été calculées de manière incorrecte.
Les applications doivent toujours lancer les demandes d'autorisation à partir d'activités qui restent visibles jusqu'à ce que l'utilisateur prenne une décision concernant l'autorisation.
Coins arrondis
Une activité peut être transparente en raison d'un style qui spécifie la transparence de l'arrière-plan ou parce que le contenu de l'activité ne remplit pas l'espace d'affichage disponible. Si une activité transparente remplit l'espace d'affichage disponible, le système applique automatiquement des angles arrondis à l'activité si le fabricant de l'appareil l'a configuré. Toutefois, si une activité transparente (telle qu'une boîte de dialogue d'autorisation) ne remplit pas l'espace disponible, c'est à vous de décider d'appliquer ou non des angles arrondis.
Les boîtes de dialogue d'autorisation ne remplissent pas l'espace d'affichage disponible, car leur mise en page utilise généralement LayoutParams.WRAP_CONTENT au lieu de LayoutParams.MATCH_PARENT.
Solution de compatibilité
Les activités qui lancent les activités de boîte de dialogue restent visibles jusqu'à ce que l'utilisateur réponde à la boîte de dialogue.
Le système garantit qu'une activité transparente hérite de toutes les contraintes de la première activité opaque sous l'activité transparente dans la pile d'activités, y compris les contraintes liées aux éléments suivants:
- Mode de compatibilité de taille
- Orientation
- Format
Jeux Unity
Sur Android, les jeux Unity s'exécutent en plein écran ou en mode multifenêtre. Toutefois, de nombreux jeux Unity perdent leur focus et arrêtent de dessiner du contenu lorsque l'application est placée en mode multifenêtre.
Problème
Unity a ajouté une option Resizable Window
dans Unity 2019.4 pour prendre en charge le mode multifenêtre sur Android. Cependant, l'implémentation initiale n'a pas réagi correctement au cycle de vie de l'activité en mode multifenêtre, ce qui a entraîné l'interruption de la lecture par UnityPlayer lorsque l'application perd son focus. Le joueur affichait un écran noir ou la dernière image figée du jeu. Le jeu ne reprenait alors pas tant que l'utilisateur n'avait pas appuyé sur l'écran. De nombreuses applications utilisant le moteur Unity sont confrontées à ce problème et s'affichent sous la forme d'une fenêtre noire en mode multifenêtre.
Optimisation
Mettez à niveau Unity vers la version 2019.4.40 ou une version ultérieure, puis réexportez votre jeu. Laissez l'option Resizable Window
cochée dans les paramètres du lecteur Android. Sinon, le jeu se met en pause lorsqu'il n'est pas au premier plan, même s'il est entièrement visible en mode multifenêtre.
Solution de compatibilité
Les fabricants d'appareils peuvent appliquer le forçage OVERRIDE_ENABLE_COMPAT_FAKE_FOCUS
par application pour fournir un faux événement de focus à une application en mode multifenêtre. Le forçage permet à l'activité de redessiner le contenu au lieu d'afficher un écran noir.
Tester votre application pour identifier les problèmes de compatibilité
Pour tester votre application et comprendre son comportement sous différents facteurs de forme, consultez les ressources suivantes:
- Streaming sur l'appareil:pour tester votre application sur des appareils de production (y compris des appareils de référence) hébergés dans les centres de données Google, consultez Streaming d'appareil Android, optimisé par Firebase .
- Émulateurs dans Android Studio Hedgehog : pour savoir comment créer des émulateurs pour les appareils de référence, consultez la page Créer et gérer des appareils virtuels.
- Émulateur redimensionnable Android Studio : pour savoir comment accéder aux appareils virtuels, consultez Exécuter des applications sur Android Emulator.
Est au format letterbox
Vérifiez que chaque activité peut utiliser tout l'espace d'affichage disponible pour l'application. Tout d'abord, déclarez le code suivant dans votre dossier de test :
Kotlin
fun Activity.isLetterboxed() : Boolean { if (isInMultiWindowMode) return false val wmc = WindowMetricsCalculator.getOrCreate() val currentBounds = wmc.computeCurrentWindowMetrics(this).bounds val maxBounds = wmc.computeMaximumWindowMetrics(this).bounds val isScreenPortrait = maxBounds.height() > maxBounds.width() return if (isScreenPortrait) { currentBounds.height() < maxBounds.height() } else { currentBounds.width() < maxBounds.width() } }
Java
public boolean isLetterboxed(Activity activity) { if (activity.isInMultiWindowMode()) { return false; } WindowMetricsCalculator wmc = WindowMetricsCalculator.getOrCreate(); Rect currentBounds = wmc.computeCurrentWindowMetrics(activity).getBounds() Rect maxBounds = wmc.computeMaximumWindowMetrics(activity).getBounds(); boolean isScreenPortrait = maxBounds.height() > maxBounds.width(); return (isScreenPortrait) ? currentBounds.height() < maxBounds.height() : currentBounds.width() < maxBounds.width(); }
Exécutez ensuite un test pour vérifier le comportement et vous assurer que l'activité cible n'est pas au format letterbox :
Kotlin
@get:Rule val activityRule = ActivityScenarioRule(MainActivity::class.java) @Test fun activity_launched_notLetterBoxed() { activityRule.scenario.onActivity { assertThat(it.isLetterboxed()).isFalse() } }
Java
@Rule public ActivityScenarioRule<MainActivity> rule = new ActivityScenarioRule<>(MainActivity.class); public void activity_launched_notLetterBoxed() { try (ActivityScenario<MainActivity> scenario = ActivityScenario.launch(MainActivity.class)) { scenario.onActivity(activity -> { assertThat(isLetterboxed(activity)).isFalse(); }); } }
Idéalement, n'exécutez ce type de test que jusqu'à ce qu'il réussisse et confirme que les activités de votre application occupent la totalité de l'espace d'affichage disponible pour l'application. Testez votre application sur tous les types d'appareils pour garantir un comportement cohérent.
Forçages par application
Android fournit des forçages qui modifient le comportement configuré des applications. Par exemple, le forçage FORCE_RESIZE_APP
indique au système de contourner le mode de compatibilité de taille et de redimensionner l'application pour qu'elle s'adapte aux dimensions d'affichage, même si resizeableActivity="false"
est spécifié dans le fichier manifeste de l'application.
Les fabricants d'appareils appliquent des forçages à certaines applications ou à toutes les applications sur des appareils à grand écran spécifiques. Sur Android 14 (niveau d'API 34) ou version ultérieure, les utilisateurs peuvent appliquer des forçages aux applications via les paramètres de l'appareil.
Forçages par application de l'utilisateur
Sur Android 14 ou version ultérieure, un menu de paramètres permet aux utilisateurs de modifier le format des applications. Les appareils à grand écran tels que les appareils de référence implémentent le menu.
Le menu contient la liste de toutes les applications installées sur l'appareil. Les utilisateurs choisissent une application, puis définissent le format de l'application sur 3:4, 1:1, en plein écran ou sur une autre valeur configurée par le fabricant de l'appareil. Les utilisateurs peuvent également rétablir le format par défaut de l'application, spécifié dans le fichier manifeste de l'application.
Les applications peuvent désactiver le forçage de la compatibilité en définissant les balises PackageManager.Property
suivantes :
PROPERTY_COMPAT_ALLOW_USER_ASPECT_RATIO_OVERRIDE
Pour désactiver le forçage de compatibilité du format de l'utilisateur, ajoutez la propriété au fichier manifeste de votre application et définissez la valeur sur
false
:<application> <property android:name="android.window. PROPERTY_COMPAT_ALLOW_USER_ASPECT_RATIO_OVERRIDE" android:value="false" /> </application>
Votre application sera exclue de la liste des applications dans les paramètres de l'appareil. Les utilisateurs ne pourront pas ignorer le format de l'application.
Définir la propriété sur
true
n'a aucun effet.PROPERTY_COMPAT_ALLOW_USER_ASPECT_RATIO_FULLSCREEN_OVERRIDE
Pour désactiver l'option plein écran du remplacement de compatibilité du format utilisateur, ajoutez la propriété au fichier manifeste de votre application et définissez la valeur sur
false
:<application> <property android:name="android.window.PROPERTY_COMPAT_ALLOW_USER_ASPECT_RATIO_FULLSCREEN_OVERRIDE" android:value="false" /> </application>
L'option plein écran est supprimée de la liste des options de format dans les paramètres de l'appareil. Les utilisateurs ne pourront pas appliquer le forçage en plein écran à votre application.
Définir cette propriété sur
true
n'a aucun effet.
Optimisez votre application pour tous les écrans:ne définissez pas de restrictions de format dans votre application. Utilisez des classes de taille de fenêtre pour accepter différentes mises en page en fonction de la quantité d'espace d'affichage disponible.
Forçages par application du fabricant de l'appareil
Les fabricants d'appareils appliquent des forçages par application sur certains appareils. Les appareils de référence peuvent appliquer certains forçages à diverses applications par défaut.
Les applications peuvent désactiver la plupart des forçages (voir le tableau Remplacements par application ci-dessous).
Vous pouvez tester votre application avec les forçages activés ou désactivés à l'aide du framework de compatibilité (consultez la section Outils du framework de compatibilité). Lorsque cette option est activée, les forçages s'appliquent à l'ensemble de l'application.
Vous pouvez également utiliser Android Debug Bridge (adb) pour activer ou désactiver les forçages et déterminer ceux qui s'appliquent à votre application.
Activez ou désactivez les forçages comme suit :
adb shell am compat enable/disable <override name/id> <package>
Pour les appareils de référence, vérifiez les forçages qui s'appliquent à votre application:
adb shell dumpsys platform_compat | grep <package name>
Le tableau suivant recense les forçages disponibles, ainsi que des conseils sur comment optimiser votre application afin qu'elle n'ait pas besoin d'utiliser des forçages. Vous pouvez ajouter des indicateurs de propriété au fichier manifeste de votre application pour désactiver certains forçages.
Forçages par application | |||
---|---|---|---|
Type | Nom | ID | Description |
Redimensionnement | FORCE_RESIZE_APP | 174042936 | Contourne le mode de compatibilité de taille pour l'application lors des modifications de configuration. |
FORCE_NON_RESIZE_APP | 181136395 | Force le mode de compatibilité pour l'application en cas de modification de la configuration. | |
Format | OVERRIDE_MIN_ASPECT_RATIO | 174042980 | Forçage faisant office de gardien et qui doit être activé pour appliquer tout autre forçage de format. |
OVERRIDE_MIN_ASPECT_RATIO_PORTRAIT_ONLY | 203647190 | Si cette option est activée (valeur par défaut), le champ d'application du forçage est limité aux activités en mode portrait. | |
OVERRIDE_MIN_ASPECT_RATIO_MEDIUM | 180326845 | Définit le format minimal sur 3:2. | |
OVERRIDE_MIN_ASPECT_RATIO_LARGE | 180326787 | Définit le format minimal sur 16:9. | |
OVERRIDE_MIN_ASPECT_RATIO_TO_ALIGN_WITH_SPLIT_SCREEN | 208648326 | Modifie le format minimal pour qu'il s'adapte à 50 % de la taille de l'écran (ou du format de l'écran partagé). | |
OVERRIDE_MIN_ASPECT_RATIO_EXCLUDE_PORTRAIT_FULLSCREEN | 218959984 | Désactive le forçage du format minimal afin que les applications s'affichent en plein écran lorsque l'appareil est en mode portrait. | |
Orientation | OVERRIDE_ANY_ORIENTATION | 265464455 | Permet de forcer n'importe quelle orientation. |
OVERRIDE_ANY_ORIENTATION_TO_USER | 310816437 | Remplace les restrictions d'orientation, de redimensionnement et de format. | |
OVERRIDE_UNDEFINED_ORIENTATION_TO_PORTRAIT | 265452344 | Force l'orientation en mode portrait lorsque l'orientation d'une activité n'est pas définie. | |
OVERRIDE_UNDEFINED_ORIENTATION_TO_NOSENSOR | 265451093 | Force l'orientation nosensor (utiliser l'orientation naturelle de l'appareil) lorsque l'orientation d'une activité n'est pas définie. |
|
OVERRIDE_LANDSCAPE_ORIENTATION_TO_REVERSE_LANDSCAPE | 266124927 | Fait pivoter les applications limitées au mode paysage de 180 degrés. | |
OVERRIDE_ORIENTATION_ONLY_FOR_CAMERA | 265456536 | Limite le champ d'application du forçage de l'orientation aux moments où l'application est connectée à l'appareil photo. | |
OVERRIDE_USE_DISPLAY_LANDSCAPE_NATURAL_ORIENTATION | 255940284 | Définit l'orientation naturelle fixe paysage pour l'écran lorsqu'une tâche est en plein écran (y compris au format letterbox). | |
OVERRIDE_ENABLE_COMPAT_IGNORE_REQUESTED_ORIENTATION | 254631730 | Ignore les requêtes d'orientation de l'application pour éviter les boucles infinies de rotation. | |
OVERRIDE_ENABLE_COMPAT_IGNORE_ORIENTATION_REQUEST_WHEN_LOOP_DETECTED | 273509367 | Ignore les requêtes d'orientation répétées lors du redémarrage d'une activité. Si Android détecte qu'une application demande au moins deux nouvelles orientations en une seconde, le système considère qu'il s'agit d'une boucle infinie de rotation et applique le forçage. | |
OVERRIDE_RESPECT_REQUESTED_ORIENTATION | 236283604 | Empêche la mise au format letterbox en désactivant le paramètre de requête d'orientation du fabricant de l'appareil. | |
API bac à sable | NEVER_SANDBOX_DISPLAY_APIS | 184838306 | Empêche la modification du comportement de toute API d'affichage. |
ALWAYS_SANDBOX_DISPLAY_APIS | 185004937 | Force les API Display dans l'application à renvoyer les limites de l'application. Les API Display renvoient les limites de zone d'affichage logique, mais l'application suppose parfois que les API Display renvoient les limites de l'application, ce qui entraîne des problèmes d'UI. |
|
OVERRIDE_SANDBOX_VIEW_BOUNDS_APIS | 237531167 | Force les API View utilisées dans l'application à renvoyer les limites de l'application. Les API View renvoient les limites logiques de la zone d'affichage, mais il arrive parfois que l'application suppose que les API View renvoient les limites de l'application, ce qui entraîne des problèmes d'UI. |
|
Compatibilité d'appareil photo | OVERRIDE_CAMERA_COMPAT_DISABLE_FORCE_ROTATION | 263959004 | Désactive la rotation forcée. Par défaut, la rotation de toutes les applications d'appareil photo à orientation fixe est forcée lorsque l'aperçu de l'appareil photo est ouvert. |
OVERRIDE_CAMERA_COMPAT_DISABLE_REFRESH | 264304459 | Supprime l'actualisation forcée par défaut qui s'applique lors de la rotation forcée d'un aperçu d'appareil photo. | |
OVERRIDE_CAMERA_COMPAT_ENABLE_REFRESH_VIA_PAUSE | 264301586 | Remplace l'actualisation forcée par une actualisation en douceur en cas de rotation forcée d'un aperçu d'appareil photo, ce qui permet de conserver l'état lors de la rotation forcée. Par défaut, Android applique une actualisation forcée lorsque la rotation de l'aperçu de l'appareil photo est forcée. En cas d'actualisation forcée, certaines applications peuvent perdre leur état ou afficher un écran noir, en fonction de la mise en cache de leur état précédent. | |
OVERRIDE_CAMERA_LANDSCAPE_TO_PORTRAIT | 250678880 | Recadre le tampon d'image de la caméra avant intérieure. Si le forçage est désactivé, le recadrage de la caméra avant intérieure est supprimé, et le champ de vision de l'aperçu de l'appareil photo est augmenté. Par défaut, sur certains appareils pliables (voir les appareils de référence), le système recadre l'aperçu de l'appareil photo de toutes les applications d'appareil photo lorsque vous utilisez la caméra avant intérieure. | |
Divers | OVERRIDE_ENABLE_COMPAT_FAKE_FOCUS | 263259275 | Empêche l'application d'afficher un écran noir lorsqu'elle perd son focus en mode Écran partagé. L'application attend le retour du focus avant de dessiner son contenu. L'application peut donc se figer ou afficher un écran noir. Le forçage permet à Android d'envoyer un faux événement de focus à l'application, ce qui lui indique de recommencer à dessiner le contenu. |
FORCE_RESIZE_APP
Force le redimensionnement des packages auxquels le forçage est appliqué. Ne modifie pas si l'application peut être mise en mode multifenêtre, mais permet à l'application de se redimensionner sans passer en mode de compatibilité de taille lorsque l'écran est redimensionné.
Comment les applications peuvent obtenir le même résultat que le forçage
Dans le fichier manifeste de l'application, définissez l'attribut android:resizeableActivity
sur true
ou, pour permettre le redimensionnement tout en désactivant le mode multifenêtre avec android:resizeableActivity=false
, définissez l'indicateur de métadonnées android.supports_size_changes
sur true
.
Comment optimiser les applications
Utilisez des mises en page responsives/adaptatives pour permettre aux applications de s'adapter à toutes les tailles d'écran et à tous les formats. Consultez Assurer la compatibilité avec différentes tailles d'écran.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_ALLOW_RESIZEABLE_ACTIVITY_OVERRIDES
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_COMPAT_ALLOW_RESIZEABLE_ACTIVITY_OVERRIDES"
android:value="true|false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage et faire en sorte que l'application puisse être redimensionnée :
adb shell am compat enable FORCE_RESIZE_APP <package>
Pour supprimer le forçage :
adb shell am compat disable FORCE_RESIZE_APP <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
FORCE_NON_RESIZE_APP
Force le non-redimensionnement des packages auxquels le forçage est appliqué et passe en mode de compatibilité de taille en cas de modification de la configuration.
Comment les applications peuvent obtenir le même résultat que le forçage
Définissez l'attribut android:resizeableActivity
et l'indicateur de métadonnées android.supports_size_changes
sur false
dans le fichier manifeste de l'application, puis déclarez une restriction d'orientation ou de format.
Comment optimiser les applications
Toutes les applications dont le comportement est correct en cas de redimensionnement doivent définir android:resizeableActivity
ou android.supports_size_changes
sur true
.
Toutes les autres applications doivent être améliorées afin que leur comportement soit correct en cas de redimensionnement. Consultez android:resizeableActivity.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_ALLOW_RESIZEABLE_ACTIVITY_OVERRIDES
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_COMPAT_ALLOW_RESIZEABLE_ACTIVITY_OVERRIDES"
android:value="true|false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage et faire en sorte que l'application ne puisse pas être redimensionnée :
adb shell am compat enable FORCE_NON_RESIZE_APP <package>
Pour supprimer le forçage :
adb shell am compat disable FORCE_NON_RESIZE_APP <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_MIN_ASPECT_RATIO
Contrôleur pour tous les forçages qui forcent un format minimal donné.
Comment les applications peuvent obtenir le même résultat que le forçage
Définissez android:minAspectRatio
au niveau de l'activité ou de l'application.
Comment optimiser les applications
Ne définissez pas de restrictions de format dans votre application. Assurez-vous que votre application est compatible avec différentes tailles d'écran. Utilisez des classes de taille de fenêtre pour prendre en charge différentes mises en page en fonction de la quantité d'espace qu'occupe votre application à l'écran. Consultez l'API WindowSizeClass
Compose et l'API View WindowSizeClass
.
Comment désactiver ou refuser le forçage
Spécifiez une restriction de format ou définissez l'indicateur de propriété PROPERTY_COMPAT_ALLOW_MIN_ASPECT_RATIO_OVERRIDE
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_COMPAT_ALLOW_MIN_ASPECT_RATIO_OVERRIDE"
android:value="false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_MIN_ASPECT_RATIO <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_MIN_ASPECT_RATIO <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_MIN_ASPECT_RATIO_PORTRAIT_ONLY
Limite les paramètres d'application qui forcent un format minimal donné pour les activités en mode portrait uniquement. Il est activé par défaut et ne prend effet que si OVERRIDE_MIN_ASPECT_RATIO
est également activé.
Comment les applications peuvent obtenir le même résultat que le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Comment optimiser les applications
Voir OVERRIDE_MIN_ASPECT_RATIO.
Comment désactiver ou refuser le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Indicateurs de propriété pour ajuster le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_MIN_ASPECT_RATIO_PORTRAIT_ONLY <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_MIN_ASPECT_RATIO_PORTRAIT_ONLY <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_MIN_ASPECT_RATIO_MEDIUM
Définit le format minimal de l'activité sur une valeur moyenne (3:2).
Comment les applications peuvent obtenir le même résultat que le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Comment optimiser les applications
Voir OVERRIDE_MIN_ASPECT_RATIO.
Comment désactiver ou refuser le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Indicateurs de propriété pour ajuster le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_MIN_ASPECT_RATIO_MEDIUM <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_MIN_ASPECT_RATIO_MEDIUM <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_MIN_ASPECT_RATIO_LARGE
Définit le format minimal de l'activité sur une valeur élevée (16:9).
Comment les applications peuvent obtenir le même résultat que le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Comment optimiser les applications
Voir OVERRIDE_MIN_ASPECT_RATIO.
Comment désactiver ou refuser le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Indicateurs de propriété pour ajuster le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_MIN_ASPECT_RATIO_LARGE <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_MIN_ASPECT_RATIO_LARGE <package>`
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_MIN_ASPECT_RATIO_TO_ALIGN_WITH_SPLIT_SCREEN
Permet l'utilisation du format d'écran partagé. Permet à une application d'utiliser tout l'espace disponible en mode Écran partagé, évitant ainsi le format letterbox.
Comment les applications peuvent obtenir le même résultat que le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Comment optimiser les applications
Voir OVERRIDE_MIN_ASPECT_RATIO.
Comment désactiver ou refuser le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Indicateurs de propriété pour ajuster le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_MIN_ASPECT_RATIO_TO_ALIGN_WITH_SPLIT_SCREEN <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_MIN_ASPECT_RATIO_TO_ALIGN_WITH_SPLIT_SCREEN <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_MIN_ASPECT_RATIO_EXCLUDE_PORTRAIT_FULLSCREEN
Désactive le forçage du format minimal en plein écran en mode portrait afin d'utiliser tout l'espace disponible sur l'écran.
Comment les applications peuvent obtenir le même résultat que le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Comment optimiser les applications
Voir OVERRIDE_MIN_ASPECT_RATIO.
Comment désactiver ou refuser le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Indicateurs de propriété pour ajuster le forçage
Voir OVERRIDE_MIN_ASPECT_RATIO.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_MIN_ASPECT_RATIO_EXCLUDE_PORTRAIT_FULLSCREEN <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_MIN_ASPECT_RATIO_EXCLUDE_PORTRAIT_FULLSCREEN <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_ANY_ORIENTATION
Active les forçages suivants pour forcer n'importe quelle orientation :
- OVERRIDE_UNDEFINED_ORIENTATION_TO_PORTRAIT
- OVERRIDE_UNDEFINED_ORIENTATION_TO_NOSENSOR
- OVERRIDE_LANDSCAPE_ORIENTATION_TO_REVERSE_LANDSCAPE (PAYSAGE_RÉVERSIBLE)
Comment les applications peuvent obtenir le même résultat que le forçage
Définissez l'attribut de manifeste activity:screenOrientation
ou utilisez l'API Activity#setRequestedOrientation()
.
Comment optimiser les applications
Votre application doit être compatible avec toutes les orientations. Un changement d'orientation est un changement de configuration qui peut être géré de deux manières: laisser le système détruire et recréer l'application, ou gérer vous-même les modifications de configuration. Si vous gérez vous-même les modifications de configuration, l'état de l'application peut être conservé à l'aide de ViewModel
. Dans de très rares cas, vous pouvez décider de verrouiller l'orientation sur les petits écrans uniquement. Toutefois, cela risque de ne pas être mis à l'échelle et de permettre à l'utilisateur de faire pivoter l'application si nécessaire. Sur Android 12L et versions ultérieures, l'orientation fixe peut être remplacée par la configuration de l'appareil. Pour en savoir plus sur la gestion des modifications de configuration et sur la prise en charge de toutes les orientations, consultez Gérer les modifications de configuration, Présentation de ViewModel et Orientation de l'application limitée sur les téléphones, mais pas sur les appareils à grand écran.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_ALLOW_ORIENTATION_OVERRIDE
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_COMPAT_ALLOW_ORIENTATION_OVERRIDE"
android:value="true|false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_ANY_ORIENTATION <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_ANY_ORIENTATION <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_ANY_ORIENTATION_TO_USER
Permet à l'application de remplir l'espace d'affichage disponible. Remplace toutes les restrictions d'orientation, de redimensionnement et de format spécifiées dans le fichier manifeste de l'application. Ignore également tous les appels à Activity#setRequestedOrientation()
.
Comment les applications peuvent obtenir le même résultat que le forçage
Ne définissez pas l'attribut de fichier manifeste
android:screenOrientation
, ou définissez-le sur"user"
.Définissez l'attribut de fichier manifeste
android:resizeableActivity
surtrue
.Sur les petits écrans, pour prendre en charge le redimensionnement des applications tout en désactivant le mode multifenêtre avec
android:resizeableActivity=false
, définissez l'indicateur de métadonnéesandroid.supports_size_changes
surtrue
. Ne définissez pasminAspectRatio
etmaxAspectRatio
.
Comment optimiser les applications
Autorisez votre application à prendre en charge toutes les orientations. Ne définissez pas de spécification screenOrientation
dans le fichier manifeste de votre application. Prenez en charge le redimensionnement de l'application, le mode multifenêtre et tous les formats d'affichage en définissant l'attribut android:resizeableActivity
dans le fichier manifeste de votre application sur true
. Consultez Assurer la compatibilité avec différentes tailles d'écran.
Comment désactiver ou refuser le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Indicateurs de propriété pour ajuster le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_ANY_ORIENTATION_TO_USER <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_ANY_ORIENTATION_TO_USER <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_UNDEFINED_ORIENTATION_TO_PORTRAIT
Active l'orientation portrait pour toutes les activités du package. À moins que OVERRIDE_ANY_ORIENTATION ne soit activé, le forçage n'est utilisé que lorsqu'aucune autre orientation fixe n'a été spécifiée par l'activité.
Comment les applications peuvent obtenir le même résultat que le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Comment optimiser les applications
Voir OVERRIDE_ANY_ORIENTATION
.
Comment désactiver ou refuser le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Indicateurs de propriété pour ajuster le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_UNDEFINED_ORIENTATION_TO_PORTRAIT <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_UNDEFINED_ORIENTATION_TO_PORTRAIT <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_UNDEFINED_ORIENTATION_TO_NOSENSOR
Active l'orientation nosensor pour toutes les activités du package. À moins que OVERRIDE_ANY_ORIENTATION ne soit activé, le forçage n'est utilisé que lorsqu'aucune autre orientation fixe n'a été spécifiée par l'activité.
Comment les applications peuvent obtenir le même résultat que le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Comment optimiser les applications
Voir OVERRIDE_ANY_ORIENTATION
.
Comment désactiver ou refuser le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Indicateurs de propriété pour ajuster le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_UNDEFINED_ORIENTATION_TO_NOSENSOR <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_UNDEFINED_ORIENTATION_TO_NOSENSOR <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_LANDSCAPE_ORIENTATION_TO_REVERSE_LANDSCAPE
Active l'orientation reverseLandscape pour toutes les activités du package. À moins que OVERRIDE_ANY_ORIENTATION ne soit activé, le forçage n'est utilisé que lorsqu'aucune autre orientation fixe n'a été spécifiée par l'activité.
Comment les applications peuvent obtenir le même résultat que le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Comment optimiser les applications
Voir OVERRIDE_ANY_ORIENTATION
.
Comment désactiver ou refuser le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Indicateurs de propriété pour ajuster le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_LANDSCAPE_ORIENTATION_TO_REVERSE_LANDSCAPE <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_LANDSCAPE_ORIENTATION_TO_REVERSE_LANDSCAPE <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_ORIENTATION_ONLY_FOR_CAMERA
Les limites OVERRIDE_UNDEFINED_ORIENTATION_TO_PORTRAIT, OVERRIDE_UNDEFINED_ORIENTATION_TO_NOSENSOR et OVERRIDE_LANDSCAPE_ORIENTATION_TO_REVERSE_LANDSCAPE ne prennent effet que lorsque la connexion de la caméra est active.
Comment les applications peuvent obtenir le même résultat que le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Comment optimiser les applications
Voir OVERRIDE_ANY_ORIENTATION
.
Comment désactiver ou refuser le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Indicateurs de propriété pour ajuster le forçage
Voir OVERRIDE_ANY_ORIENTATION
.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_ORIENTATION_ONLY_FOR_CAMERA <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_ORIENTATION_ONLY_FOR_CAMERA <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_USE_DISPLAY_LANDSCAPE_NATURAL_ORIENTATION
Limite l'orientation de l'écran à l'orientation naturelle en mode paysage lorsque les conditions suivantes sont remplies :
- L'activité est en plein écran.
- La propriété du composant de désactivation
PROPERTY_COMPAT_ALLOW_DISPLAY_ORIENTATION_OVERRIDE
n'est pas activée. - Le paramètre de requête d'orientation que le fabricant de l'appareil est activé pour l'écran
- L'orientation naturelle de l'écran est en mode paysage.
Comment les applications peuvent obtenir le même résultat que le forçage
Non applicable. Le problème doit être résolu dans la logique de l'application.
Comment optimiser les applications
Voir OVERRIDE_ANY_ORIENTATION
.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_ALLOW_DISPLAY_ORIENTATION_OVERRIDE
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_COMPAT_ALLOW_DISPLAY_ORIENTATION_OVERRIDE"
android:value="true|false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_USE_DISPLAY_LANDSCAPE_NATURAL_ORIENTATION <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_USE_DISPLAY_LANDSCAPE_NATURAL_ORIENTATION <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_ENABLE_COMPAT_IGNORE_REQUESTED_ORIENTATION
Active la règle de compatibilité qui ignore la mise à jour de l'orientation de l'application en réponse à un appel d'application Activity#setRequestedOrientation()
lorsque l'application est en cours de redémarrage ou qu'elle dispose d'un traitement de compatibilité d'appareil photo actif.
Comment les applications peuvent obtenir le même résultat que le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_IGNORE_REQUESTED_ORIENTATION
sur true
.
Comment optimiser les applications
Voir OVERRIDE_ANY_ORIENTATION
.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_IGNORE_REQUESTED_ORIENTATION
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_COMPAT_IGNORE_REQUESTED_ORIENTATION"
android:value="true|false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_ENABLE_COMPAT_IGNORE_REQUESTED_ORIENTATION <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_ENABLE_COMPAT_IGNORE_REQUESTED_ORIENTATION <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_ENABLE_COMPAT_IGNORE_ORIENTATION_REQUEST_WHEN_LOOP_DETECTED
Active la règle de compatibilité qui ignore l'orientation demandée par une application lorsque l'application appelle Activity#setRequestedOrientation()
plus de deux fois en une seconde si une activité n'est pas mise au format letterbox pour obtenir une orientation fixe.
Comment les applications peuvent obtenir le même résultat que le forçage
Non applicable. Le problème doit être résolu dans la logique de l'application.
Comment optimiser les applications
Voir OVERRIDE_ANY_ORIENTATION
.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_ALLOW_IGNORING_ORIENTATION_REQUEST_WHEN_LOOP_DETECTED
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_COMPAT_ALLOW_IGNORING_ORIENTATION_REQUEST_WHEN_LOOP_DETECTED"
android:value="false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_ENABLE_COMPAT_IGNORE_ORIENTATION_REQUEST_WHEN_LOOP_DETECTED <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_ENABLE_COMPAT_IGNORE_ORIENTATION_REQUEST_WHEN_LOOP_DETECTED <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_RESPECT_REQUESTED_ORIENTATION
Exclut les packages du comportement de requête d'orientation qui peut être activé par les fabricants d'appareils pour une zone d'affichage ou l'ensemble de l'écran.
Comment les applications peuvent obtenir le même résultat que le forçage
Non applicable. Le problème doit être résolu dans la logique de l'application.
Comment optimiser les applications
Voir OVERRIDE_ANY_ORIENTATION
.
Comment désactiver ou refuser le forçage
Aucun refus possible. La désactivation du forçage peut être dangereuse si l'application n'est pas compatible avec un appareil pour lequel le paramètre "Ignorer les requêtes d'orientation" est activé par le fabricant. Pour désactiver le forçage, contactez le service Relations avec les développeurs Android.
Indicateurs de propriété pour ajuster le forçage
Aucun indicateur de propriété pour ce forçage.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_RESPECT_REQUESTED_ORIENTATION <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_RESPECT_REQUESTED_ORIENTATION <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
NEVER_SANDBOX_DISPLAY_APIS
Force le bac à sable de l'API Display
à ne jamais être appliqué aux packages pour une activité en mode letterbox ou en mode de compatibilité de taille. Les API Display
continuent de fournir des limites de zone d'affichage.
Comment les applications peuvent obtenir le même résultat que le forçage
Déclarez le caractère redimensionnable des activités en définissant l'attribut de fichier manifeste android:resizeableActivity
sur true
ou l'indicateur de métadonnées android.supports_size_changes
sur true
.
Comment optimiser les applications
Les applications qui déclarent être entièrement redimensionnables ne doivent jamais s'appuyer sur la taille d'écran pour positionner les éléments d'interface utilisateur. Migrez votre application vers des API à jour qui fournissent WindowMetrics
. Si vous utilisez Jetpack Compose, servez-vous de l'API WindowSizeClass
pour dessiner l'UI en fonction de la surface d'écran de l'application sur l'écran actuel. Consultez la section Utiliser des classes de taille de fenêtre.
Comment désactiver ou refuser le forçage
Aucun refus possible. Migrez vers des API non obsolètes.
Indicateurs de propriété pour ajuster le forçage
Aucun indicateur de propriété pour ce forçage.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable NEVER_SANDBOX_DISPLAY_APIS <package>
Pour supprimer le forçage :
adb shell am compat disable NEVER_SANDBOX_DISPLAY_APIS <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
ALWAYS_SANDBOX_DISPLAY_APIS
Force le bac à sable de l'API Display
à toujours être appliqué aux packages, quel que soit le mode de fenêtrage. Les API Display
fournissent toujours les limites de l'application.
Comment les applications peuvent obtenir le même résultat que le forçage
Déclarez le caractère non redimensionnable des activités en définissant l'attribut android:resizeableActivity
sur false
ou l'indicateur de métadonnées android.supports_size_changes
sur false
.
Comment optimiser les applications
Les applications qui déclarent être entièrement redimensionnables ne doivent jamais dépendre de la taille de l'écran pour positionner les éléments d'interface utilisateur. Migrez votre application d'API obsolètes vers des API à jour qui fournissent WindowMetrics
. Consultez WindowMetricsCalculator
.
Comment désactiver ou refuser le forçage
Aucun refus possible. Migrez vers des API non obsolètes.
Indicateurs de propriété pour ajuster le forçage
Aucun indicateur de propriété pour ce forçage.
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable ALWAYS_SANDBOX_DISPLAY_APIS <package>
Pour supprimer le forçage :
adb shell am compat disable ALWAYS_SANDBOX_DISPLAY_APIS <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_SANDBOX_VIEW_BOUNDS_APIS
Oblige les packages à mettre en bac à sable les API View
suivantes en fonction des limites de l'activité :
Comment les applications peuvent obtenir le même résultat que le forçage
Pour résoudre le problème dans le code d'application, utilisez des API qui fournissent les limites de la fenêtre de l'application et les décalages par rapport à la fenêtre de l'application plutôt que les limites de l'écran de l'appareil et les décalages par rapport à l'écran de l'appareil.
Comment optimiser les applications
Les applications doivent utiliser les API View
, en tenant compte du fait que le format letterbox et le mode multifenêtre peuvent être appliqués à l'application. Consultez WindowMetricsCalculator
.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_ALLOW_SANDBOXING_VIEW_BOUNDS_APIS
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_COMPAT_ALLOW_SANDBOXING_VIEW_BOUNDS_APIS"
android:value="false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_SANDBOX_VIEW_BOUNDS_APIS <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_SANDBOX_VIEW_BOUNDS_APIS <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_CAMERA_COMPAT_DISABLE_FORCE_ROTATION
Désactive la rotation forcée. Améliore l'expérience utilisateur dans certaines applications.
Comment les applications peuvent obtenir le même résultat que le forçage
Définissez l'indicateur de propriété PROPERTY_CAMERA_COMPAT_ALLOW_FORCE_ROTATION
sur false
.
Comment optimiser les applications
Ne vous appuyez pas sur l'orientation du capteur de l'appareil photo mise en cache ni aux informations sur l'appareil. Pour obtenir des conseils en matière de compatibilité de l'appareil photo, consultez Présentation du viseur de l'appareil photo et Prendre en charge les surfaces redimensionnables dans votre application d'appareil photo.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_CAMERA_COMPAT_ALLOW_FORCE_ROTATION
sur true
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_CAMERA_COMPAT_ALLOW_FORCE_ROTATION"
android:value="true|false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage, ce qui supprime la rotation forcée :
adb shell am compat enable OVERRIDE_CAMERA_COMPAT_DISABLE_FORCE_ROTATION <package>
Pour supprimer le forçage, ce qui permet de forcer la rotation :
adb shell am compat disable OVERRIDE_CAMERA_COMPAT_DISABLE_FORCE_ROTATION <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_CAMERA_COMPAT_DISABLE_REFRESH
Désactive l'actualisation de l'activité après la rotation forcée. Améliore l'expérience utilisateur lorsque l'actualisation entraîne une perte d'état dans les applications.
Comment les applications peuvent obtenir le même résultat que le forçage
Définissez l'indicateur de propriété PROPERTY_CAMERA_COMPAT_ALLOW_REFRESH
sur false
.
Comment optimiser les applications
Voir OVERRIDE_CAMERA_COMPAT_DISABLE_FORCE_ROTATION.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_CAMERA_COMPAT_ALLOW_REFRESH
sur true
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_CAMERA_COMPAT_ALLOW_REFRESH"
android:value="true|false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage, ce qui supprime l'actualisation de l'activité :
adb shell am compat enable OVERRIDE_CAMERA_COMPAT_DISABLE_REFRESH <package>
Pour supprimer le forçage, ce qui permet l'actualisation de l'activité :
adb shell am compat disable OVERRIDE_CAMERA_COMPAT_DISABLE_REFRESH <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_CAMERA_COMPAT_ENABLE_REFRESH_VIA_PAUSE
Rend les packages auxquels il est appliqué pour actualiser l'activité à l'aide d'un cycle onResume()
→ onPause()
→ onResume()
au lieu de onResume()
→
onStop()
→ onResume()
après la rotation forcée de compatibilité de l'appareil photo.
Comment les applications peuvent obtenir le même résultat que le forçage
Définissez l'indicateur de propriété PROPERTY_CAMERA_COMPAT_ENABLE_REFRESH_VIA_PAUSE
sur true
.
Comment optimiser les applications
Voir OVERRIDE_CAMERA_COMPAT_DISABLE_FORCE_ROTATION.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_CAMERA_COMPAT_ENABLE_REFRESH_VIA_PAUSE
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_CAMERA_COMPAT_ENABLE_REFRESH_VIA_PAUSE"
android:value="true|false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_CAMERA_COMPAT_ENABLE_REFRESH_VIA_PAUSE <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_CAMERA_COMPAT_ENABLE_REFRESH_VIA_PAUSE <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_CAMERA_LANDSCAPE_TO_PORTRAIT
Force le recadrage de la sortie de l'appareil photo dans l'orientation opposée lorsque l'orientation de l'appareil photo en mode portrait ne correspond pas à l'orientation naturelle de l'appareil. De nombreuses applications ne gèrent pas cette situation et affichent des images étirées dans le cas contraire.
Comment les applications peuvent obtenir le même résultat que le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_OVERRIDE_LANDSCAPE_TO_PORTRAIT
sur true
.
Comment optimiser les applications
Voir OVERRIDE_CAMERA_COMPAT_DISABLE_FORCE_ROTATION.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_OVERRIDE_LANDSCAPE_TO_PORTRAIT
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.camera.PROPERTY_COMPAT_OVERRIDE_LANDSCAPE_TO_PORTRAIT"
android:value="true|false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage, qui applique un recadrage de la caméra avant intérieure :
adb shell am compat enable OVERRIDE_CAMERA_LANDSCAPE_TO_PORTRAIT <package>
Pour supprimer ce forçage, ce qui supprime le recadrage de la caméra avant intérieure :
adb shell am compat disable OVERRIDE_CAMERA_LANDSCAPE_TO_PORTRAIT <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_DISABLE_MEDIA_PROJECTION_SINGLE_APP_OPTION
Empêche les applications de désactiver le partage d'écran (voir Projection multimédia). Implémenté lorsque les applications utilisent de manière abusive l'API createConfigForDefaultDisplay()
pour forcer la capture en plein écran et compromettre la confidentialité des utilisateurs en exposant le contenu des notifications, qui sont capturées en plein écran, mais pas en partage d'écran d'application, et pour toutes les applications, quel que soit le mode de fenêtrage.
Comment les applications peuvent obtenir le même résultat que le forçage
Autorisez le comportement de projection multimédia par défaut (implémenté sous Android 14, niveau d'API 34, avec createScreenCaptureIntent()
), ce qui permet aux utilisateurs de décider s'ils souhaitent partager l'intégralité de l'écran ou une seule fenêtre d'application, quel que soit le mode de fenêtrage. Vous pouvez également appeler createScreenCaptureIntent(MediaProjectionConfig)
avec un argument MediaProjectionConfig
renvoyé à partir d'un appel à createConfigForUserChoice()
.
Comment optimiser les applications
Autorisez les utilisateurs à choisir de partager l'intégralité de l'écran de l'appareil ou une fenêtre d'application lors de la projection multimédia, qui est le comportement par défaut à partir d'Android 14.
Faites en sorte que votre application puisse être redimensionnée (resizeableActivity="true"
) pour prendre en charge le mode multifenêtre.
Comment désactiver ou refuser le forçage
En raison de l'importance de la confidentialité des utilisateurs, votre application ne peut pas désactiver ni désactiver ce forçage.
Indicateurs de propriété pour ajuster le forçage
Aucun.
Commandes adb pour tester le forçage
Pour appliquer le forçage, ce qui annule la désactivation du partage d'écran partiel de l'application (c'est-à-dire, qui active le partage d'écran partiel):
adb shell am compat enable OVERRIDE_DISABLE_MEDIA_PROJECTION_SINGLE_APP_OPTION <package>
Pour supprimer le forçage, ce qui permet à l'application de désactiver le partage d'écran partiel:
adb shell am compat disable OVERRIDE_DISABLE_MEDIA_PROJECTION_SINGLE_APP_OPTION <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
OVERRIDE_ENABLE_COMPAT_FAKE_FOCUS
Active l'envoi d'un focus factice pour les applications non sélectionnées en mode Écran partagé. Certains moteurs de jeu attendent d'obtenir le focus avant de dessiner le contenu de l'application. Ainsi, le focus fictif permet aux applications d'éviter d'afficher un écran noir lorsqu'elles sont réactivées et qu'elles ne possèdent pas encore le focus.
Comment les applications peuvent obtenir le même résultat que le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_ENABLE_FAKE_FOCUS
sur true
.
Comment optimiser les applications
Vous pouvez éviter ce problème si votre application gère plusieurs orientations et que la configuration change correctement. Faites en sorte que votre application soit compatible avec les grands écrans en suivant les consignes relatives à la qualité des applis sur les grands écrans.
Si vous exécutez le moteur de jeu Unity, passez à la version 2019.4.40 ou ultérieure, puis réexportez votre jeu. Laissez l'option Resizable Window
cochée dans les paramètres du lecteur Android.
Comment désactiver ou refuser le forçage
Définissez l'indicateur de propriété PROPERTY_COMPAT_ENABLE_FAKE_FOCUS
sur false
.
Indicateurs de propriété pour ajuster le forçage
<property android:name="android.window.PROPERTY_COMPAT_ENABLE_FAKE_FOCUS"
android:value="true|false"/>
Commandes adb pour tester le forçage
Pour appliquer le forçage :
adb shell am compat enable OVERRIDE_ENABLE_COMPAT_FAKE_FOCUS <package>
Pour supprimer le forçage :
adb shell am compat disable OVERRIDE_ENABLE_COMPAT_FAKE_FOCUS <package>
Remarque : les commandes appliquent ou suppriment le forçage de manière temporaire uniquement.
Ressources supplémentaires
- Consignes relatives à la Qualité des applis sur les grands écrans
- Critères fondamentaux de qualité des applis