HarmonyOS5 便捷生活类——图片进度条的实现方案

加入下方官方优快云班级,得鸿蒙礼盒

一起拿鸿蒙礼盒,戳我戳我!!

本期活动时间:2025年8月1日-12月31日

如有问题欢迎私聊我呀


问题现象

如何实现图片进度条功能?未加载时图片进度条是灰色,加载过程中图片进度条由灰色变成彩色,加载完成后图片进度条完全变成彩色。

背景知识

  • 层叠布局通过Stack容器组件实现位置的固定定位与层叠,容器中的子元素依次入栈,后一个子元素覆盖前一个子元素,子元素可以叠加,也可以设置位置。
  • clipShape可以按指定的形状对当前组件进行裁剪。

解决方案

  1. aboutToAppear生命周期中启动定时器,每150ms触发一次,通过增加状态变量progress从0.0到1.0控制图片变化进度。
     
    aboutToAppear() {
    this.timer = setInterval(() => {
    this.progress = Math.min(1, this.progress + 0.1)
    if (this.progress >= 1) {
    clearInterval(this.timer)
    }
    }, 150)
    }

  2. 使用Stack叠加两张内容相同但颜色不同的图片比如灰色和彩色,彩色图片始终完整显示在底层,灰色图片通过clipShape进行裁剪,裁剪宽度随progress变化。
     
    Stack({ alignContent: Alignment.Start }) {
    Image(this.grayImage)
    .width('100%')
    .height('100%')
    .objectFit(ImageFit.Contain)
    Image(this.colorImage)
    .width('100%')
    .height('100%')
    .objectFit(ImageFit.Contain)
    .clip(true)
    .clipShape(new Rect({
    width: `${this.progress * 100}%`,
    height: '100%'
    }))
    }
    .width(300)
    .height(300)

完整示例参考如下:

 
@Entry
@Component
struct ImageProgress {
@State progress: number = 0.0
private grayImage: Resource = $r('app.media.start') // 对应灰色图片
private colorImage: Resource = $r('app.media.final') // 对应彩色图片
private timer: number = 0
aboutToAppear() {
this.timer = setInterval(() => {
this.progress = Math.min(1, this.progress + 0.05)
if (this.progress >= 1) {
clearInterval(this.timer)
}
}, 150)
}
aboutToDisappear() {
clearInterval(this.timer)
}
build() {
Column() {
Stack({ alignContent: Alignment.Start }) {
Image(this.grayImage)
.width('100%')
.height('100%')
.objectFit(ImageFit.Contain)

Image(this.colorImage)
.width('100%')
.height('100%')
.objectFit(ImageFit.Contain)
.clip(true)
.clipShape(new Rect({
width: `${this.progress * 100}%`,
height: '100%'
}))
}
.width(300)
.height(300)
}
.width('100%')
.height('100%')
.justifyContent(FlexAlign.Center)
}
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值