HarmonyOS 鸿蒙Next 跑马灯组件Marquee的使用

发布于 1周前 作者 h691938207 最后一次编辑是 5天前 来自 鸿蒙OS

HarmonyOS 鸿蒙Next 跑马灯组件Marquee的使用 HarmonyOS 鸿蒙Next 跑马灯组件,用于滚动展示一段单行文本。仅当文本内容宽度超过跑马灯组件宽度时滚动,不超过时不滚动。 image.png 用法:

// xxx.ets
@Entry
@Component
struct MarqueeExample {
  @State start: boolean = false
  @State src: string = ''
  @State marqueeText: string = 'Running Marquee'
  private fromStart: boolean = true
  private step: number = 10
  private loop: number = Number.POSITIVE_INFINITY
  controller: TextClockController = new TextClockController()
  convert2time(value: number): string{
    let date = new Date(Number(value+'000'));
    let hours = date.getHours().toString().padStart(2, '0');
    let minutes = date.getMinutes().toString().padStart(2, '0');
    let seconds = date.getSeconds().toString().padStart(2, '0');
    return hours+ ":" + minutes + ":" + seconds;
  }

  build() {
    Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
      Marquee({
        start: this.start,
        step: this.step,
        loop: this.loop,
        fromStart: this.fromStart,
        src: this.marqueeText + this.src
      })
        .marqueeUpdateStrategy(MarqueeUpdateStrategy.PRESERVE_POSITION)
        .width(300)
        .height(80)
        .fontColor('#FFFFFF')
        .fontSize(48)
        .fontWeight(700)
        .backgroundColor('#182431')
        .margin({ bottom: 40 })
        .onStart(() => {
          console.info('Marquee animation complete onStart')
        })
        .onBounce(() => {
          console.info('Marquee animation complete onBounce')
        })
        .onFinish(() => {
          console.info('Marquee animation complete onFinish')
        })
      Button('Start')
        .onClick(() => {
          this.start = true
          //启动文本时钟
          this.controller.start()
        })
        .width(120)
        .height(40)
        .fontSize(16)
        .fontWeight(500)
        .backgroundColor('#007DFF')
      TextClock({ timeZoneOffset: -8, controller: this.controller })
        .format('hms')
        .onDateChange((value: number) => {
          this.src = this.convert2time(value);
        })
        .margin(20)
        .fontSize(30)
    }
    .width('100%')
    .height('100%')
  }
}

HarmonyOS 鸿蒙Next 跑马灯组件Marquee官方文档:

https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/ts-basic-components-marquee-V5

1 回复

在HarmonyOS Next API 11中,跑马灯Marquee组件确实需要明确设置宽度,以确保其不会超出预期布局范围。这是因为Marquee组件的滚动行为依赖于其设定的宽度,若未设置或设置不当,可能导致文本滚动时超出容器边界。

对于前面有不确定宽度的组件,您提到的通过onAreaChange事件来计算整个行或容器的宽度,并据此动态调整Marquee组件的宽度是一个有效的解决方案。这样可以在运行时根据实际情况动态调整Marquee组件的宽度,确保其在不同屏幕尺寸或布局变化下都能正确显示。

具体实现时,您可以在包含Marquee组件的容器或行上监听onAreaChange事件,通过事件回调中的新旧值来计算宽度,并据此设置Marquee组件的宽度。请确保在Marquee组件的样式中明确指定宽度属性,以避免潜在的布局问题。

如果问题依旧没法解决,请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html。在寻求帮助时,请详细描述您遇到的问题、已尝试的解决方案以及相关的代码和布局设置,以便客服人员能够更快地为您提供帮助。

回到顶部