Android 12 (niveau d'API 31) remanie l'API Widgets existante pour améliorer l'expérience utilisateur et de développement sur la plate-forme et les lanceurs. Utilisez ce guide pour savoir comment vous assurer que votre widget est compatible avec Android 12. Il peut également servir de référence pour les API permettant d'actualiser votre widget existant.
Assurer la compatibilité de votre widget avec Android 12
Les widgets d'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 que ses coins soient arrondis.
Dans ce scénario, il est possible que votre widget ne s'affiche pas correctement dans l'une des conditions suivantes:
Le widget contient du contenu dans les coins: cela peut entraîner le recadrage de certains contenus dans la zone des coins.
Le widget utilise un arrière-plan qui ne peut pas être 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 qui n'est pas sujet au recadrage. Le système ne pourra peut-être pas identifier correctement l'arrière-plan à utiliser.
Si votre widget est affecté 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.
1 Coin du widget.
2 Angle d'une vue dans le widget.
Pour en savoir plus, consultez Implémenter des angles arrondis.
Ajouter une thématisation de l'appareil
À 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 clairs et sombres. Cela permet de fluidifier les transitions et d'assurer la cohérence entre les différents widgets.
Pour en savoir plus, consultez Ajouter une thématisation de l'appareil.
Faciliter 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 de proposer une meilleure expérience de configuration aux utilisateurs. Pour en savoir plus, consultez Autoriser les utilisateurs à configurer des widgets.
Ajouter des 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 pour les événements de changement d'état.
Pour en savoir plus, consultez la section Compatibilité avec le comportement avec état.
Utiliser des API améliorées pour les tailles et les mises en page des widgets
À partir d'Android 12, vous pouvez bénéficier d'attributs de taille plus précis 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 exactes.
Pour en savoir plus, consultez Fournir des mises en page de widget flexibles.
Améliorer l'expérience du sélecteur de widgets dans votre application
Android 12 vous permet d'améliorer l'expérience du sélecteur 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 widgets évolutifs au sélecteur de widgets et Ajouter une description à votre widget.
Créer des transitions plus fluides
À partir d'Android 12, les lanceurs offrent une transition plus fluide lorsqu'un utilisateur lance votre application à partir d'un widget. Pour en savoir plus, consultez la section Activer des 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
, vous deviez implémenter et 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 les attributs RemoteViews
au moment de l'exécution. 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 d'exécution de RemoteViews
.