创建轮播(Swiper)

本文详细介绍了Swiper组件如何进行布局与尺寸管理,循环播放、自动轮播设置,导航点样式定制,以及页面切换方式和轮播方向控制。还展示了如何在单页显示多子组件的特性。
摘要由CSDN通过智能技术生成

目录

1、布局与约束

2、循环播放

3、自动轮播

4、导航点样式

5、页面切换方式

6、轮播方向


        Swiper组件提供滑动轮播显示的能力。Swiper本身是一个容器组件,当设置了多个子组件后,可以对这些子组件进行轮播显示。通常,在一些应用首页显示推荐的内容时,需要用到轮播显示的能力。

1、布局与约束

        Swiper作为一个容器组件,在自身尺寸属性未被设置时,会自动根据子组件的大小设置自身的尺寸。如果开发者对Swiper组件设置了固定的尺寸,则在轮播显示过程中均以该尺寸生效;否则,在轮播过程中,会根据子组件的大小自动调整自身的尺寸。

2、循环播放

        通过loop属性控制是否循环播放,该属性默认值为true。

        当loop为true时,在显示第一页或最后一页时,可以继续往前切换到前一页或者往后切换到后一页。如果loop为false,则在第一页或最后一页时,无法继续向前或者向后切换页面。

        loop为true:

@Entry
@Component
struct SwiperPage1 {
  @State message: string = 'Hello World'

  private swiperController: SwiperController = new SwiperController()

  build() {
    Row() {
      Column() {
        Swiper(this.swiperController) {
          Text("0")
            .width('90%')
            .height('100%')
            .backgroundColor('#1067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)

          Text("1")
            .width('90%')
            .height('100%')
            .backgroundColor('#2067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)

          Text("2")
            .width('90%')
            .height('100%')
            .backgroundColor('#3067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)
        }
        .loop(true).autoPlay(true).interval(2000)
      }
      .width('100%').height('20%').alignSelf(ItemAlign.Start)
    }
    .height('100%')
  }
}

        

        loop为false:

@Entry
@Component
struct SwiperPage1 {
  @State message: string = 'Hello World'

  private swiperController: SwiperController = new SwiperController()

  build() {
    Row() {
      Column() {
        Swiper(this.swiperController) {
          Text("0")
            .width('90%')
            .height('100%')
            .backgroundColor('#1067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)

          Text("1")
            .width('90%')
            .height('100%')
            .backgroundColor('#2067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)

          Text("2")
            .width('90%')
            .height('100%')
            .backgroundColor('#3067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)
        }
        .loop(false).autoPlay(true).interval(2000)
      }
      .width('100%').height('20%').alignSelf(ItemAlign.Start)
    }
    .height('100%')
  }
}

         

3、自动轮播

        Swiper通过设置autoPlay属性,控制是否自动轮播子组件。该属性默认值为false。

        autoPlay为true时,会自动切换播放子组件,子组件与子组件之间的播放间隔通过interval属性设置。interval属性默认值为3000,单位毫秒。

        autoPlay为true:

@Entry
@Component
struct SwiperPage1 {
  @State message: string = 'Hello World'

  private swiperController: SwiperController = new SwiperController()

  build() {
    Row() {
      Column() {
        Swiper(this.swiperController) {
          Text("0")
            .width('90%')
            .height('100%')
            .backgroundColor('#1067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)

          Text("1")
            .width('90%')
            .height('100%')
            .backgroundColor('#2067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)

          Text("2")
            .width('90%')
            .height('100%')
            .backgroundColor('#3067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)
        }
        .loop(true).autoPlay(true).interval(2000)
      }
      .width('100%').height('20%').alignSelf(ItemAlign.Start)
    }
    .height('100%')
  }
}

4、导航点样式

        Swiper提供了默认的导航点样式,导航点默认显示在Swiper下方居中位置,开发者也可以通过indicatorStyle属性自定义导航点的位置和样式。

        通过indicatorStyle属性,开发者可以设置导航点相对于Swiper组件上下左右四个方位的位置,同时也可以设置每个导航点的尺寸、颜色、蒙层和被选中导航点的颜色。

        导航点使用默认样式:

Swiper(this.swiperController) {
  Text("0")
    .width('90%')
    .height('100%')
    .backgroundColor(Color.Gray)
    .textAlign(TextAlign.Center)
    .fontSize(30)

  Text("1")
    .width('90%')
    .height('100%')
    .backgroundColor(Color.Green)
    .textAlign(TextAlign.Center)
    .fontSize(30)

  Text("2")
    .width('90%')
    .height('100%')
    .backgroundColor(Color.Pink)
    .textAlign(TextAlign.Center)
    .fontSize(30)
}

         自定义导航点样式(示例:导航点直径设为30VP,左边距为0,导航点颜色设为红色):

@Entry
@Component
struct SwipeIndicatorPage {
  @State message: string = 'Hello World'

  private swiperController: SwiperController = new SwiperController()

  build() {
    Row() {
      Column() {
        Swiper(this.swiperController) {
          Text("0")
            .width('90%')
            .height('100%')
            .backgroundColor('#1067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)

          Text("1")
            .width('90%')
            .height('100%')
            .backgroundColor('#2067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)

          Text("2")
            .width('90%')
            .height('100%')
            .backgroundColor('#3067c8ff')
            .textAlign(TextAlign.Center)
            .fontSize(30)
        }
        .loop(true).autoPlay(true).interval(2000).indicatorStyle({
          size: 30,
          left: 0,
          color: Color.Red
        })
      }
      .width('100%').height('20%').alignSelf(ItemAlign.Start)
    }
    .height('100%')
  }
}

5、页面切换方式

        Swiper支持三种页面切换方式:手指滑动、点击导航点和通过控制器。

通过控制器切换页面:

@Entry
@Component
struct SwiperDemo {
  private swiperController: SwiperController = new SwiperController();

  build() {
    Column({ space: 5 }) {
      Swiper(this.swiperController) {
        Text("0")
          .width(250)
          .height(250)
          .backgroundColor(Color.Gray)
          .textAlign(TextAlign.Center)
          .fontSize(30)
        Text("1")
          .width(250)
          .height(250)
          .backgroundColor(Color.Green)
          .textAlign(TextAlign.Center)
          .fontSize(30)
        Text("2")
          .width(250)
          .height(250)
          .backgroundColor(Color.Pink)
          .textAlign(TextAlign.Center)
          .fontSize(30)
      }
      .indicator(true)

      Row({ space: 12 }) {
        Button('showNext')
          .onClick(() => {
            this.swiperController.showNext(); // 通过controller切换到后一页
          })
        Button('showPrevious')
          .onClick(() => {
            this.swiperController.showPrevious(); // 通过controller切换到前一页
          })
      }.margin(5)
    }.width('100%')
    .margin({ top: 5 })
  }
}

6、轮播方向

        Swiper支持水平和垂直方向上进行轮播,主要通过vertical属性控制。

        当vertical为true时,表示在垂直方向上进行轮播;为false时,表示在水平方向上进行轮播。vertical默认值为false。

        设置水平方向上轮播:

Swiper(this.swiperController) {
  ...
}
.indicator(true)
.vertical(false)

         

设置垂直方向轮播:

Swiper(this.swiperController) {
  ...
}
.indicator(true)
.vertical(true)

7、每页显示多个子页面

        Swiper支持在一个页面内同时显示多个子组件,通过displayCount属性设置。

        设置一个页面内显示两个子组件:

Swiper(this.swiperController) {
  Text("0")
    .width(250)
    .height(250)
    .backgroundColor(Color.Gray)
    .textAlign(TextAlign.Center)
    .fontSize(30)
  Text("1")
    .width(250)
    .height(250)
    .backgroundColor(Color.Green)
    .textAlign(TextAlign.Center)
    .fontSize(30)
  Text("2")
    .width(250)
    .height(250)
    .backgroundColor(Color.Pink)
    .textAlign(TextAlign.Center)
    .fontSize(30)
  Text("3")
    .width(250)
    .height(250)
    .backgroundColor(Color.Blue)
    .textAlign(TextAlign.Center)
    .fontSize(30)
}
.indicator(true)
.displayCount(2)

  • 32
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值