Améliorations apportées aux widgets Android 12

Android 12 (niveau d'API 31) remanie l'API Widgets existante pour améliorer l'expérience utilisateur et celle des développeurs sur la plate-forme et dans les lanceurs. Utilisez ce guide pour savoir comment vous assurer que votre widget est compatible avec Android 12 et comme référence pour les API permettant d'actualiser votre widget existant.

Texte alternatif

Vérifier que votre widget est compatible avec Android 12

Les widgets sous Android 12 ont des coins arrondis. Lorsqu'un widget d'application est utilisé sur un appareil équipé d'Android 12 ou version ultérieure, le lanceur identifie automatiquement l'arrière-plan du widget et le recadre pour avoir des coins arrondis.

Dans ce cas, votre widget peut ne pas s'afficher correctement si l'une des conditions suivantes est remplie:

  • Le widget contient du contenu dans les coins: une partie du contenu des coins peut être recadrée.

  • Le widget utilise un arrière-plan non recadré. Cela inclut un arrière-plan transparent, des vues ou des mises en page vides, ou tout autre type d'arrière-plan spécial non recadré. Le système risque de ne pas pouvoir identifier correctement l'arrière-plan à utiliser.

Si votre widget est concerné par cette modification, nous vous recommandons de l'actualiser avec des angles arrondis (comme décrit dans la section suivante) pour qu'il s'affiche correctement.

Utiliser l'exemple

Pour voir toutes ces API en action, consultez notre exemple de widget de liste.

Implémenter des angles arrondis

Android 12 introduit les paramètres système system_app_widget_background_radius et system_app_widget_inner_radius pour définir les rayons des angles arrondis de votre widget.

Widget météo pour Tokyo
Figure 1 : Coins arrondis d'un widget et vue à l'intérieur de celui-ci

1 Angle du widget.

2 Angle d'une vue à l'intérieur du widget.

Pour en savoir plus, consultez Implémenter des angles arrondis.

Ajouter un thème pour les appareils

À partir d'Android 12, un widget peut utiliser les couleurs du thème de l'appareil pour les boutons, les arrière-plans et d'autres composants, y compris les thèmes clair et sombre. Cela permet des transitions plus fluides et une cohérence entre les différents widgets.

Pour en savoir plus, consultez Ajouter une thématisation basée sur les appareils.

Widget avec le thème en mode clair
Figure 2: Widget avec le thème clair
Widgets avec le thème en mode sombre
Figure 3: Widget avec le thème sombre

Simplifier la personnalisation des widgets

Si vous spécifiez une activité de configuration avec l'attribut configure de appwidget-provider, l'hôte du widget d'application lance cette activité immédiatement après qu'un utilisateur a ajouté le widget à son écran d'accueil.

Android 12 ajoute de nouvelles options pour vous permettre d'offrir une meilleure expérience de configuration aux utilisateurs. Pour en savoir plus, consultez Permettre aux utilisateurs de configurer des widgets.

Ajouter de nouveaux boutons composés

Android 12 prend en charge le comportement avec état à l'aide des composants existants suivants:

Le widget est toujours sans état. Votre application doit stocker l'état et s'inscrire aux événements de changement d'état.

Figure 4 : Exemple de widget avec cases à cocher

Pour en savoir plus, consultez Compatibilité avec le comportement avec état.

Utiliser des API améliorées pour les tailles et les mises en page de widgets

À partir d'Android 12, vous pouvez bénéficier d'attributs de taille plus affinés et de mises en page plus flexibles, en spécifiant des contraintes de dimensionnement de widget supplémentaires et en fournissant des mises en page responsives et des mises en page exactes.

Pour en savoir plus, consultez Fournir des mises en page de widget flexibles.

Améliorer l'expérience de sélection de widgets de votre application

Android 12 vous permet d'améliorer l'expérience de sélection de widgets pour votre application en ajoutant des aperçus et des descriptions de widgets dynamiques. Pour en savoir plus, consultez Ajouter des aperçus de widget évolutifs au sélecteur de widgets et Ajouter une description de votre widget.

Rendre les transitions plus fluides

À partir d'Android 12, les lanceurs d'applications offrent une transition plus fluide lorsqu'un utilisateur lance votre application à partir d'un widget. Pour en savoir plus, consultez la section Activer les transitions plus fluides.

Utiliser des collections RemoteViews simplifiées

Android 12 ajoute la méthode setRemoteAdapter(int viewId, RemoteViews.RemoteCollectionItems items), qui permet à votre application de transmettre directement une collection lors du remplissage d'un ListView. Auparavant, lorsque vous utilisiez un ListView, il était nécessaire d'implémenter et de déclarer un RemoteViewsService pour renvoyer RemoteViewsFactory.

Pour en savoir plus, consultez Utiliser les collections RemoteViews.

Utiliser la modification d'exécution de RemoteViews

Android 12 ajoute plusieurs méthodes RemoteViews qui permettent de modifier au moment de l'exécution des attributs RemoteViews. Consultez la documentation de référence de l'API RemoteViews pour obtenir la liste complète des méthodes ajoutées.

Pour en savoir plus, consultez Utiliser la modification de l'environnement d'exécution de RemoteViews.