轮播界面

轮播界面会显示一个可滚动的项目列表,该列表会根据窗口大小动态调整。使用轮播界面展示一组相关内容。 轮播界面项侧重于视觉效果,但也可以包含简短的文字,这些文字会根据项的大小进行调整。

有四种轮播界面布局可供选择,以适应不同的使用情形:

  • 多浏览:包含不同尺寸的商品。建议用于一次浏览多项内容,例如照片。
  • 不包含:包含大小单一且可流动到屏幕边缘之外的项。可以自定义,以在每个商品上方或下方显示更多文字或其他界面。
  • 主打:突出显示一张大图片,让用户专注于此,并通过一个小项目预览后续内容。建议用于突出显示您想要强调的内容,例如电影或节目的缩略图。
  • 全屏:一次显示一个从边缘到边缘的大尺寸项,并可垂直滚动。建议用于高度大于宽度的内容。
并排显示的不含容器的全屏轮播广告。非容器轮播广告类型包含多个轮播广告项,而全屏轮播广告类型包含一个占据整个屏幕的广告项
图 1. 不包含内容 (1) 和全屏 (2) 轮播广告类型。

本页面介绍了如何实现多浏览和非容器轮播界面布局。如需详细了解布局类型,请参阅 Carousel Material 3 指南

API Surface

如需实现多浏览轮播界面和非容器轮播界面,请使用 HorizontalMultiBrowseCarouselHorizontalUncontainedCarousel 可组合项。这些可组合函数共享以下关键参数:

  • state:用于管理当前商品索引和滚动位置的 CarouselState 实例。使用 rememberCarouselState { itemCount } 创建此状态,其中 itemCount 是轮播界面中的商品总数。
  • itemSpacing:定义轮播界面中相邻项之间的空白空间量。
  • contentPadding:在轮播界面的内容区域周围应用内边距。使用此属性可在第一项内容之前或最后一项内容之后添加空间,或为可滚动区域内的项提供边距。
  • content:接收整数索引的可组合函数。使用此 lambda 可根据轮播界面中每个商品的索引来定义其界面。

这些可组合项在指定商品尺寸方面有所不同:

  • itemWidth(对于 HorizontalUncontainedCarousel):指定非容器化轮播界面中每个项的确切宽度。
  • preferredItemWidth(适用于 HorizontalMultiBrowseCarousel):建议多浏览轮播界面中商品的理想宽度,让组件在空间允许的情况下显示多个商品。

示例:多浏览轮播界面

此代码段实现了一个多浏览轮播界面:

代码要点

  • 定义 CarouselItem 数据类,用于构建轮播界面中每个元素的数据。
  • 创建并记住填充了图片资源和说明的 CarouselItem 对象的 List
  • 使用 HorizontalMultiBrowseCarousel 可组合项,该可组合项旨在以轮播界面显示多个项。
    • 轮播界面的状态使用 rememberCarouselState 进行初始化,该变量会获得商品的总数。
    • 商品具有 preferredItemWidth(此处为 186.dp),用于指示每件商品的最佳宽度。轮播界面会使用此值来确定一次可在屏幕上显示多少个项。
    • itemSpacing 参数会在项之间添加小间距。
    • HorizontalMultiBrowseCarousel 的尾随 lambda 会遍历 CarouselItems。在每次迭代中,它都会检索索引 i 处的商品,并为其渲染 Image 可组合项。
    • Modifier.maskClip(MaterialTheme.shapes.extraLarge) 会为每张图片应用预定义的形状遮罩,使其具有圆角。
    • contentDescription 为图片提供无障碍说明。

结果

下图显示了上述代码段的运行结果:

一个包含 3 张图片的多浏览轮播界面,其中两张图片完整显示,一张图片部分显示在屏幕外。
图 2. 一个多浏览轮播界面,其中最后一项被剪裁。

示例:非容器化轮播界面

以下代码段实现了一个非容器化轮播界面:

代码要点

  • HorizontalUncontainedCarousel 可组合函数用于创建轮播布局。
    • itemWidth 参数用于为轮播界面中的每个项设置固定宽度。

结果

下图显示了上述代码段的运行结果:

包含 3 项内容的非容器化轮播界面。最后一项部分可见,但未被剪裁。
图 3. 非受限轮播界面,其中轮播界面中的最后一项不会被剪裁。