Android

Apprenez du code : Jetpack Compose – Listes et pagination (Partie 1)

Le 26 août 2021 - 8 minutes de lecture

 

Apprenez à créer des listes et à gérer la pagination dans Jetpack Compose

Créé à l’aide de Jetpack Compose ! Composer le logo tiré de documents officiels.

Cela fait partie d’une série en plusieurs parties sur l’apprentissage de l’utilisation de Jetpack Compose via le code. Cette partie de la série se concentrera sur la création de l’écran de la liste des jeux ainsi que sur les cas de test pour cet écran.

Les autres volets de cette série sortent bientôt !

Si vous entendez parler de la composition du jetpack pour la première fois, Google la décrit comme :

Jetpack Compose est une boîte à outils Android moderne pour créer une interface utilisateur native. Il simplifie et accélère le développement de l’interface utilisateur sur Android, donnant vie à vos applications avec moins de code, des outils puissants et des API Kotlin intuitives. Cela rend la création de l’interface utilisateur Android plus rapide et plus facile.

Il y a beaucoup de mots-clés dans le paragraphe ci-dessus, comme moins de morueet, intuitif, plus rapide et Plus facile. L’une des principales choses qui manquent est la facilité de tester votre interface utilisateur de composition. Compose facilite grandement le test de chacun des composants individuels de l’interface utilisateur séparément.

J’entends ce que vous dites – assez d’écriture !

Quelle application allons-nous construire ?

Epic World – Application de découverte de jeux vidéo !

Oui! Nous allons créer une application de découverte de jeux vidéo ! Vous pouvez faire défiler une liste interminable de jeux, cliquer sur le jeu qui vous intéresse pour voir tous les détails, et s’il y a une vidéo disponible, vous pouvez toutes les regarder ! Nous utiliserons l’incroyable API RAWG pour nos données de jeu.

Disséquer l’écran de démarrage

écran de liste de jeux

Comme vous pouvez le voir, il y a 2 composants principaux sur cet écran. La première est la barre d’applications qui a un titre ainsi que des options de recherche et de filtrage. L’autre est votre liste qui est chargée d’afficher tous les jeux et de gérer également la pagination. Codez !

barre d’applications

Nous pouvons concevoir notre barre d’applications en utilisant TopAppBar.

La barre d’application supérieure affiche des informations et des actions liées à l’écran actuel.

Allons de l’avant et créons un composé simple qui a un titre et 2 fonctions pour nos clics de recherche et de filtrage en tant que paramètres d’entrée.

HomeAppBar maison sans style

Prévisualisons notre HomeAppBar et voyez ce que nous avons accompli jusqu’à présent.

Aperçu de la HomeAppBar
Vue initiale de la HomeAppBar

Il a l’air plutôt bien, mais il manque un peu de style. Donnons une couleur d’arrière-plan à la barre d’applications et modifions également la couleur de nos icônes.

Ultimate HomeAppBar

Concevoir une barre d’applications n’a jamais été aussi simple ! notre fin HomeAppBar ressemblera à ceci :

HomeAppBar avec style

Liste des jeux

Notre liste de jeux est une grille avec 2 éléments dans chaque ligne. Quand on pense aux listes, la première chose qui vient à l’esprit est la RecyclerView outil. Dans la composition, nous avons composables paresseux. Comme vous l’aurez deviné, nous avons LazyColumn pour afficher une liste verticale et LazyRow pour afficher une liste horizontale. Mais pour notre cas d’utilisation spécifique, nous avons un autre composant appelé LazyVerticalGrid qui aide à afficher les éléments dans une grille.

Pour la pagination, nous pouvons utiliser le Paging 3 bibliothèque qui fournit un support de composition.

Les composants lents suivent le même ensemble de principes que le widget RecyclerView.

La bibliothèque de pagination vous permet de charger facilement et progressivement les données.

Observation: Au moment d’écrire ces lignes, lazyVerticalGrid est expérimental et la composition de pagination est toujours alpha. Les deux API peuvent changer à l’avenir et être différentes, comme décrit dans cet article.

Commençons par configurer notre bibliothèque de pagination, puis commençons à consommer les données de notre composition.

Définir une source de données

PagingSource c’est le composant principal de notre bibliothèque de pagination 3. Il est responsable de toutes nos données.

GameSource.kt

Configurer un Steam PagingData

Maintenant que notre source de pagination est prête, configurons le flux de données dans notre ViewModel. Pager La classe aide à exposer un flux de données de pagination en tant que Flow<PagingData<GameResultsEntity>> de GamesSource. Ce flux est émis à chaque fois Pager rechercher de nouvelles données de notre GamesSource.

HomeViewModel.kt

Ici le PagingConfig prend pageSize comme paramètre d’entrée qui définit le nombre d’éléments chargés à la fois à partir du PagingSource.

Affichage des données

Maintenant que nous avons configuré un flux de données dans notre ViewModel, il ne reste plus qu’à récupérer ce flux et à l’afficher dans notre LazyVerticalGrid. Pour cela, nous pouvons utiliser le collectAsLazyPagingItems() fonction d’extension qui collecte notre flux et le convertit en LazyPagingItems.

Liste des jeux sans élément de jeu de style

LazyVerticalGrid également besoin de connaître les informations de la cellule. Dans notre cas, puisque nous voulons 2 colonnes fixes, nous pouvons les fournir via l’instance de GrideCells.Fixed.

Combinons notre barre d’applications et notre liste de jeux et voyons ce que nous avons jusqu’à présent !

écran d’accueil sans style
Écran d’accueil

Nous avons notre liste et nous avons aussi la pagination ! Le tout avec quelques lignes de code !

Concevoir l’objet du jeu

élément de jeu

En haut, nous avons l’image de notre jeu, en dessous nous avons le titre du jeu et, en dessous, notre note. La première disposition qui me vient à l’esprit est une Column mais je voulais montrer l’utilisation de ConstraintLayout dans la composition, concevons-la donc en utilisant un ConstraintLayout.

De plus, nous utiliserons la bibliothèque Coil pour afficher les images.

GameItem avec style

En cours d’exécution, nous avons les éléments suivants :

Écran d’accueil élégant

Nous avons presque atteint notre état final. Ajustons un peu plus notre écran.

Affichage de l’état de chargement et de l’état d’erreur

La bibliothèque de pagination a un support intégré pour afficher l’état de chargement et l’état d’erreur. Nous pouvons obtenir l’état de chargement de LoadState objet pouvant être obtenu auprès de LazyPagingItems.

Chargement de la vue dans notre liste

loadState.refresh est pour quand les données sont chargées pour la première fois et loadState.append est pour chaque recherche après la première fois. L’exécuter maintenant nous donnera ce qui suit :

Écran d’accueil avec état de charge

Je vous laisse l’état d’erreur. Faites-moi part de votre conception dans les commentaires!

Tester les composés

Maintenant que nous avons conçu notre écran de démarrage, voyons comment il peut être testé.

Le test des interfaces utilisateur ou des écrans est utilisé pour vérifier le comportement correct de votre code Compose, améliorant ainsi la qualité de votre application en détectant les erreurs dès le début du processus de développement.

Pour tous nos tests, nous utiliserons ComposeTestRule UN TestRule qui vous permet de tester et de contrôler des composés et des applications à l’aide de Compose.

Lorsque vous testez votre interface utilisateur, les trois API importantes à prendre en compte sont :

  • Localisateurs: Permet de sélectionner un ou plusieurs éléments
  • Affirmations: permet de vérifier si l’élément est affiché ou possède certains attributs
  • Actions: vous permet d’effectuer certaines actions de prévisualisation, telles que cliquer ou faire défiler

Puisque nous avons d’abord conçu notre barre d’applications, essayons d’écrire un test pour celle-ci.

AccueilAppBar Test

Le test est assez explicite. Nous chargeons notre barre d’application initiale et passons « Titre » comme titre, puis déclarons qu’un aperçu avec le texte « Titre » est affiché.

Je vous laisse le reste des tests de la barre d’applications. Un exemple de cas de test pourrait être de tester si notre Rechercher et filtre les icônes sont affichées dans la barre d’applications. Soyez créatif et essayez de couvrir autant de tests que possible !

Essayons d’écrire un quiz pour la liste des jeux.

Test de l’écran d’accueil

Il y a quelques choses qui se passent dans le test. Tout d’abord, nous nous moquons de nos ViewModel et fourni une réponse simulée pour obtenir les données. Ensuite, nous chargeons notre écran d’accueil et veillons à ce que les jeux soient affichés dans notre liste.

Encore une fois, je vous laisse le reste des tests. Utilisez toute votre créativité et couvrez autant de tests que possible pour l’écran !

Commentaires

Laisser un commentaire

Votre commentaire sera révisé par les administrateurs si besoin.