如何使用Image加载沙箱路径图片资源

沙箱中的图片资源怎么展示

HarmonyOS
2024-06-11 23:18:58
浏览
收藏 0
回答 2
待解决
回答 2
按赞同
/
按时间
OwenOO

使用Image组件, 得到文件沙箱路径后, 调用@ohos.file.fileuri模块的fileuri.getUriFromPath(file.path)将沙箱路径转化为沙箱uri, 传入之后即可正常显示.

示例

import fileUri from '@ohos.file.fileuri'; 
import common from '@ohos.app.ability.common'; 
import fs from '@ohos.file.fs'; 
 
@Entry 
@Component 
struct Index { 
  @State message: string = 'Hello World'; 
  @State uri: string = "" 
 
  build() { 
    Row() { 
      Column() { 
        Text(this.message) 
          .fontSize(50) 
          .fontWeight(FontWeight.Bold) 
          .onClick(() => { 
            let context = getContext(this) as common.UIAbilityContext 
            let filePath = context.filesDir + "/test.png" 
            let arrayBuff = context.resourceManager.getRawFileContentSync("icon.png").buffer 
            console.log('testTag-----',arrayBuff) 
            let file = fs.openSync(filePath,fs.OpenMode.CREATE | fs.OpenMode.READ_WRITE) 
            fs.writeSync(file.fd,arrayBuff) 
            this.uri = fileUri.getUriFromPath(filePath) 
            console.log('testTag-----',filePath) 
          }) 
        Image(this.uri) 
          .width(100) 
          .height(100) 
      } 
      .width('100%') 
    } 
    .height('100%') 
  } 
}
分享
微博
QQ
微信
回复
2024-06-12 23:35:05
wx66e0114324300

这个功能对API版本有要求吗?我实测在API9里加载不出来图片。

分享
微博
QQ
微信
回复
2024-09-11 10:09:56
相关问题
Image组件如何读入沙箱内的图片
2659浏览 • 1回复 待解决
png图片使用Image组件加载出现锯齿
1687浏览 • 1回复 待解决
Image组件如何加载网络图片
2450浏览 • 1回复 待解决
Image组件如何加载沙盒内的图片
2388浏览 • 1回复 待解决
Iamge组件如何加载Graphic的资源图片
6839浏览 • 1回复 待解决
HarmonyOS 加载RN沙盒路径资源文件
72浏览 • 1回复 待解决
HarmonyOS Image加载本地图片咨询
353浏览 • 1回复 待解决
HarmonyOS预加载Image组件的图片
391浏览 • 1回复 待解决
HarmonyOS Image 加载网络图片问题
493浏览 • 1回复 待解决
HarmonyOS image组件图片加载性能数据
185浏览 • 1回复 待解决
HarmonyOS webview如何加载沙箱html
324浏览 • 1回复 待解决
Image图片加载缓慢,有什么方案么?
949浏览 • 1回复 待解决