HarmonyOS 鸿蒙Next 自定义组件中,Image控件无法更新图片

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

设置一个自定义组件:

@Component
struct ImgItem {
  @Prop img: PixelMap | null = null
  @Prop title: string = "测试"

  build() {
    Column() {
      Text(this.title)
      Image(this.img).width(100).height(100).backgroundColor("#f00")
    }
  }
}

在页面使用:

@Entry
@Component
struct Index {
  @State img: PixelMap | null = null
  @State title: string = ""

  fromRawFile(name: string): Promise<PixelMap> {
    let testdata = getContext().resourceManager.getRawFileContentSync(name)
    let imageSource = image.createImageSource(testdata.buffer)
    return imageSource.createPixelMap()
  }

  async aboutToAppear() {
    this.img = await this.fromRawFile("test.jpg")
    this.title = "测试2"
  }

  build() {
    Column() {
      ImgItem({ img: this.img, title: this.title }).margin({ top: 50 })
      Button("更换").onClick(async () => {
        this.img = await this.fromRawFile("test.png")
        this.title = "测试3"
      }).margin({ top: 14 })
    }.height("100%").width("100%")
  }
} 

img无法更新,title可以更新


更多关于HarmonyOS 鸿蒙Next 自定义组件中,Image控件无法更新图片的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

2 回复

[@State](/user/State) 允许装饰的变量类型为

Object、class、string、number、boolean、enum类型,以及这些类型的数组。

支持Date类型。

API11及以上支持MapSet类型。

支持undefined和null类型。

支持ArkUI框架定义的联合类型LengthResourceStrResourceColor类型。

类型必须被指定。

支持类型的场景请参考观察变化

不支持any。

API11及以上支持上述支持类型的联合类型,比如string | number, string | undefined 或者 ClassA | null,示例见[@State](/user/State)支持联合类型实例

注意

当使用undefined和null的时候,建议显式指定类型,遵循TypeScript类型校验,比如:[@State](/user/State) a : string | undefined = undefined是推荐的,不推荐[@State](/user/State) a: string = undefined。

更多关于HarmonyOS 鸿蒙Next 自定义组件中,Image控件无法更新图片的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


在HarmonyOS 鸿蒙Next自定义组件中,若Image控件无法更新图片,通常可能涉及数据绑定或控件刷新机制的问题。

  1. 检查数据源:首先确认你尝试更新的图片数据源是否正确加载并更新。如果图片路径或资源ID发生变化,确保这些变化被正确传递到Image控件。

  2. 数据绑定:如果使用了数据绑定,检查绑定的变量是否已被正确更新。在数据模型发生变化后,确保触发界面刷新,比如通过调用组件的刷新方法。

  3. UI线程:确保图片更新操作在UI线程中执行。鸿蒙系统中,UI更新通常需要在主线程进行。

  4. 图片缓存:有时图片加载框架或控件自身会缓存图片。如果图片URL未改变但内容更新,可能需要手动清除缓存或改变URL标识来强制重新加载。

  5. 控件状态:检查Image控件是否被正确设置为可见和可交互状态,有时控件状态设置错误也会影响其更新。

如果上述检查均无误但问题依旧存在,可能是系统或框架的bug。此时,可以尝试重启应用或设备,查看问题是否复现。如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html

回到顶部