HarmonyOS 鸿蒙Next 跑马灯组件Marquee的使用
HarmonyOS 鸿蒙Next 跑马灯组件Marquee的使用 HarmonyOS 鸿蒙Next 跑马灯组件,用于滚动展示一段单行文本。仅当文本内容宽度超过跑马灯组件宽度时滚动,不超过时不滚动。 用法:
// 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
在HarmonyOS Next API 11中,跑马灯Marquee组件确实需要明确设置宽度,以确保其不会超出预期布局范围。这是因为Marquee组件的滚动行为依赖于其设定的宽度,若未设置或设置不当,可能导致文本滚动时超出容器边界。
对于前面有不确定宽度的组件,您提到的通过onAreaChange
事件来计算整个行或容器的宽度,并据此动态调整Marquee组件的宽度是一个有效的解决方案。这样可以在运行时根据实际情况动态调整Marquee组件的宽度,确保其在不同屏幕尺寸或布局变化下都能正确显示。
具体实现时,您可以在包含Marquee组件的容器或行上监听onAreaChange
事件,通过事件回调中的新旧值来计算宽度,并据此设置Marquee组件的宽度。请确保在Marquee组件的样式中明确指定宽度属性,以避免潜在的布局问题。
如果问题依旧没法解决,请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html。在寻求帮助时,请详细描述您遇到的问题、已尝试的解决方案以及相关的代码和布局设置,以便客服人员能够更快地为您提供帮助。