Karussell

In einem Karussell wird eine scrollbare Liste mit Elementen angezeigt, die sich dynamisch an die Fenstergröße anpassen. Mit Karussells können Sie eine Sammlung ähnlicher Inhalte präsentieren. Bei Karussellelementen liegt der Schwerpunkt auf visuellen Elementen. Sie können aber auch kurzen Text enthalten, der sich an die Elementgröße anpasst.

Es gibt vier Karussell-Layouts für verschiedene Anwendungsfälle:

  • Multi-Browse: Enthält Artikel unterschiedlicher Größe. Empfohlen, wenn Sie viele Elemente gleichzeitig durchsuchen möchten, z. B. Fotos.
  • Nicht enthalten: Enthält Elemente, die eine einzelne Größe haben und über den Bildschirmrand hinausfließen. Kann angepasst werden, um mehr Text oder eine andere Benutzeroberfläche über oder unter jedem Element anzuzeigen.
  • Hero: Hier wird ein großes Bild hervorgehoben und mit einem kleinen Element wird ein Vorgeschmack auf das nächste Bild gegeben. Empfohlen, um Inhalte hervorzuheben, z. B. Film- oder Serien-Thumbnails.
  • Vollbild: Es wird jeweils ein großes Element von Rand zu Rand angezeigt und vertikal gescrollt. Empfohlen für Inhalte, die höher als breit sind.
Ein nicht eingegrenzter und ein Vollbildkarusselltyp nebeneinander. Der Typ „Nicht eingegrenzt“ enthält mehrere Karussellelemente, während beim Typ „Vollbild“ ein Element den gesamten Bildschirm einnimmt.
Abbildung 1: Die Karusselltypen „Uncontained“ (1) und „Full-screen“ (2).

Auf dieser Seite erfahren Sie, wie Sie die Layouts für die Mehrfachauswahl und das nicht eingeschlossene Karussell implementieren. Weitere Informationen zu den Layouttypen finden Sie in den Richtlinien für Karussell-Material 3.

API-Oberfläche

Verwende die Composables HorizontalMultiBrowseCarousel und HorizontalUncontainedCarousel, um Karussells mit mehreren Browsing-Optionen und nicht enthaltene Karussells zu implementieren. Diese Composables haben die folgenden wichtigen Parameter gemeinsam:

  • state: Eine CarouselState-Instanz, die den aktuellen Artikelindex und die Scrollposition verwaltet. Erstellen Sie diesen Status mit rememberCarouselState { itemCount }, wobei itemCount die Gesamtzahl der Elemente im Karussell ist.
  • itemSpacing: Definiert die Größe des Leerraums zwischen nebeneinanderliegenden Elementen im Karussell.
  • contentPadding: Wendet das Padding auf den Inhaltsbereich des Karussells an. Damit können Sie vor dem ersten oder nach dem letzten Element Leerraum einfügen oder Ränder für die Elemente im scrollbaren Bereich festlegen.
  • content: Eine zusammensetzbare Funktion, die einen Ganzzahlindex empfängt. Mit dieser Lambda-Funktion können Sie die Benutzeroberfläche für jedes Element im Karussell basierend auf seinem Index definieren.

Diese Composables unterscheiden sich in der Art und Weise, wie die Größe von Elementen angegeben wird:

  • itemWidth (für HorizontalUncontainedCarousel): Gibt die genaue Breite für jedes Element in einem nicht eingeschlossenen Karussell an.
  • preferredItemWidth (für HorizontalMultiBrowseCarousel): Gibt die ideale Breite für Elemente in einem Karussell mit mehreren Browsing-Optionen an. So kann die Komponente mehrere Elemente anzeigen, wenn der Platz ausreicht.

Beispiel: Karussell mit mehreren Browsing-Optionen

In diesem Snippet wird ein Karussell mit mehreren Browsing-Optionen implementiert:

Wichtige Punkte zum Code

  • Definiert eine CarouselItem-Datenklasse, die die Daten für jedes Element im Karussell strukturiert.
  • Erstellt und speichert ein List mit CarouselItem-Objekten, die mit Bildressourcen und ‑beschreibungen gefüllt sind.
  • Verwendet die zusammensetzbare Funktion HorizontalMultiBrowseCarousel, die für die Anzeige mehrerer Elemente in einem Karussell entwickelt wurde.
    • Der Status des Karussells wird mit rememberCarouselState initialisiert, dem die Gesamtzahl der Elemente übergeben wird.
    • Elemente haben einen preferredItemWidth (hier 186.dp), der eine optimale Breite für jedes Element angibt. Anhand dieser Informationen wird bestimmt, wie viele Elemente gleichzeitig auf dem Bildschirm angezeigt werden können.
    • Mit dem Parameter itemSpacing wird ein kleiner Abstand zwischen den Elementen eingefügt.
    • Die nachgestellte Lambda-Funktion von HorizontalMultiBrowseCarousel iteriert durch die CarouselItems. In jeder Iteration wird das Element am Index i abgerufen und ein Image-Composable dafür gerendert.
    • Mit Modifier.maskClip(MaterialTheme.shapes.extraLarge) wird auf jedes Bild eine vordefinierte Formmaske angewendet, sodass es abgerundete Ecken hat.
    • contentDescription bietet eine Beschreibung des Bilds für Bedienungshilfen.

Ergebnis

Das folgende Bild zeigt das Ergebnis des vorherigen Snippets:

Ein Karussell mit mehreren Browsing-Optionen und drei Bildern, von denen zwei vollständig und eines teilweise außerhalb des Bildschirms angezeigt werden.
Abbildung 2. Ein Karussell mit mehreren Browsing-Optionen, bei dem das letzte Element abgeschnitten ist.

Beispiel: Nicht eingegrenztes Karussell

Im folgenden Snippet wird ein nicht eingeschlossenes Karussell implementiert:

Wichtige Punkte zum Code

  • Mit der zusammensetzbaren Funktion HorizontalUncontainedCarousel wird das Karussell-Layout erstellt.
    • Mit dem Parameter itemWidth wird eine feste Breite für jedes Element im Karussell festgelegt.

Ergebnis

Das folgende Bild zeigt das Ergebnis des vorherigen Snippets:

Ein nicht eingegrenztes Karussell mit drei Elementen. Das letzte Element ist teilweise sichtbar, wird aber nicht abgeschnitten.
Abbildung 3: Ein nicht eingegrenztes Karussell, bei dem das letzte Element im Karussell nicht abgeschnitten wird.