Carrousel

Un carrousel affiche une liste déroulante d'éléments qui s'adaptent de manière dynamique en fonction de la taille de la fenêtre. Utilisez des carrousels pour présenter une collection de contenus associés. Les éléments de carrousel mettent l'accent sur les visuels, mais peuvent également contenir un texte bref qui s'adapte à la taille de l'élément.

Quatre mises en page de carrousel sont disponibles pour s'adapter à différents cas d'utilisation :

  • Navigation multiple : inclut des articles de différentes tailles. Recommandé pour parcourir de nombreux éléments à la fois, comme des photos.
  • Non contenu : contient des éléments d'une seule taille qui dépassent le bord de l'écran. Peut être personnalisé pour afficher plus de texte ou d'autres éléments d'UI au-dessus ou en dessous de chaque élément.
  • Héros : met en avant une grande image et donne un aperçu du contenu suivant avec un petit élément. Recommandé pour mettre en avant des contenus que vous souhaitez souligner, comme des miniatures de films ou de séries.
  • Plein écran : affiche un grand élément bord à bord à la fois et défile verticalement. Recommandé pour les contenus plus hauts que larges.
Un type de carrousel non contenu et en plein écran affiché côte à côte. Le type de carrousel non contenu comporte plusieurs éléments de carrousel, tandis que le type plein écran comporte un seul élément qui occupe l'écran.
Figure 1. Types de carrousels non contenus (1) et en plein écran (2).

Cette page vous explique comment implémenter les mises en page de carrousels multibrowse et non contenus. Pour en savoir plus sur les types de mise en page, consultez les consignes relatives aux carrousels Material 3.

Surface d'API

Pour implémenter des carrousels multi-navigation et non contenus, utilisez les composables HorizontalMultiBrowseCarousel et HorizontalUncontainedCarousel. Ces composables partagent les paramètres clés suivants :

  • state : instance CarouselState qui gère l'index de l'élément actuel et la position de défilement. Créez cet état à l'aide de rememberCarouselState { itemCount }, où itemCount correspond au nombre total d'éléments du carrousel.
  • itemSpacing : définit la quantité d'espace vide entre les éléments adjacents du carrousel.
  • contentPadding : applique une marge intérieure autour de la zone de contenu du carrousel. Utilisez-le pour ajouter un espace avant le premier élément ou après le dernier, ou pour définir des marges pour les éléments de la région à faire défiler.
  • content : fonction composable qui reçoit un index entier. Utilisez ce lambda pour définir l'UI de chaque élément du carrousel en fonction de son index.

Ces composables diffèrent dans la façon dont ils spécifient la taille des éléments :

  • itemWidth (pour HorizontalUncontainedCarousel) : spécifie la largeur exacte de chaque élément d'un carrousel non contenu.
  • preferredItemWidth (pour HorizontalMultiBrowseCarousel) : suggère la largeur idéale des éléments d'un carrousel de navigation multiple, ce qui permet au composant d'afficher plusieurs éléments si l'espace le permet.

Exemple : Carrousel de navigation multiple

Cet extrait de code implémente un carrousel de navigation multiple :

Points clés concernant le code

  • Définit une classe de données CarouselItem, qui structure les données de chaque élément du carrousel.
  • Crée et mémorise un List d'objets CarouselItem contenant des ressources et des descriptions d'images.
  • Utilise le composable HorizontalMultiBrowseCarousel, qui est conçu pour afficher plusieurs éléments dans un carrousel.
    • L'état du carrousel est initialisé à l'aide de rememberCarouselState, qui reçoit le nombre total d'éléments.
    • Les éléments ont une preferredItemWidth (ici, 186.dp), ce qui suggère une largeur optimale pour chaque élément. Le carrousel l'utilise pour déterminer le nombre d'éléments pouvant tenir sur l'écran à la fois.
    • Le paramètre itemSpacing ajoute un petit espace entre les éléments.
    • Le lambda de fin de HorizontalMultiBrowseCarousel itère sur CarouselItems. À chaque itération, il récupère l'élément à l'index i et affiche un composable Image pour celui-ci.
    • Modifier.maskClip(MaterialTheme.shapes.extraLarge) applique un masque de forme prédéfini à chaque image, ce qui lui donne des coins arrondis.
    • contentDescription fournit une description de l'image pour l'accessibilité.

Résultat

L'image suivante montre le résultat de l'extrait de code précédent :

Carrousel de navigation multiple avec trois images, dont deux sont entièrement visibles et une est partiellement hors écran.
Figure 2. Carrousel multi-navigation, avec le dernier élément coupé.

Exemple : Carrousel non contenu

L'extrait de code suivant implémente un carrousel non contenu :

Points clés concernant le code

  • Le composable HorizontalUncontainedCarousel crée la mise en page du carrousel.
    • Le paramètre itemWidth définit une largeur fixe pour chaque élément du carrousel.

Résultat

L'image suivante montre le résultat de l'extrait de code précédent :

Carrousel non contenu avec trois éléments. Le dernier élément est partiellement visible, mais pas tronqué.
Figure 3. Carrousel non contenu, où le dernier élément du carrousel n'est pas coupé.