HarmonyOS 鸿蒙Next:调用image.createImageSource方法传入图片沙箱路径失败原因

发布于 1周前 作者 sinazl 来自 鸿蒙OS

HarmonyOS 鸿蒙Next:调用image.createImageSource方法传入图片沙箱路径失败原因
有要学HarmonyOS AI的同学吗,联系我:https://www.itying.com/goods-1206.html

关于HarmonyOS 鸿蒙Next:调用image.createImageSource方法传入图片沙箱路径失败原因的问题,您也可以访问:https://www.itying.com/category-93-b0.html 联系官网客服。

4 回复

调用image.createImageSource方法,传入图片的沙箱路径,如图所示,返回的沙箱路径为:file://com.midea.weexwebsdkdemo/data/storage/el2/base/haps/entry/files/1.png

但是一直创建失败,请问什么原因?

cke_163.png
cke_618.png

有要学HarmonyOS AI的同学吗,联系我:https://www.itying.com/goods-1206.html

import { buffer } from '@kit.ArkTS';
import { fileIo, fileUri } from '@kit.CoreFileKit';
import image from '@ohos.multimedia.image';
import fs from '@ohos.file.fs';
import { common } from '@kit.AbilityKit';

interface objType { uri: string path: string }

export class FileOperate { // data为需要转换的base64字符串,返回沙箱路径uri static async writeFile(data: string): Promise<string> { let uri = ‘’ let filesDir = getContext().filesDir; console.info(filesDir:${filesDir}) try { let filePath = filesDir + “/1.png”; uri = fileUri.getUriFromPath(filePath); let file = fileIo.openSync(filePath, fileIo.OpenMode.READ_WRITE | fileIo.OpenMode.CREATE); console.info("file fd: " + file.fd); const reg = new RegExp(“data:image/\w+;base64,”) const base64 = data.replace(reg, “”); console.log(“base64flag”, base64) const dataBuffer = buffer.from(base64, ‘base64’)

  await fileIo.writeSync(file.fd, dataBuffer.buffer);
  fileIo.closeSync(file);
  console.log(<span class="hljs-string"><span class="hljs-string">"base64 写入成功 uri--&gt;"</span></span>, uri)
} <span class="hljs-keyword"><span class="hljs-keyword">catch</span></span> (<span class="hljs-built_in"><span class="hljs-built_in">Error</span></span>) {
  console.log(<span class="hljs-string"><span class="hljs-string">'Error.code'</span></span>, <span class="hljs-string"><span class="hljs-string">'-----&gt;👉'</span></span>, <span class="hljs-built_in"><span class="hljs-built_in">JSON</span></span>.stringify(<span class="hljs-built_in"><span class="hljs-built_in">Error</span></span>));
}

<span class="hljs-comment"><span class="hljs-comment">//uri:file://com.midea.weexwebsdkdemo/data/storage/el2/base/haps/entry/files/1.png</span></span>
<span class="hljs-keyword"><span class="hljs-keyword">return</span></span> uri

}

static async fileChangePixelMap(path: string) { try {

  <span class="hljs-comment"><span class="hljs-comment">// 打开文件读取流</span></span>
  <span class="hljs-keyword"><span class="hljs-keyword">let</span></span> file = fs.openSync(path, fs.OpenMode.READ_ONLY);
  <span class="hljs-comment"><span class="hljs-comment">// 获取当前上下文</span></span>
  <span class="hljs-keyword"><span class="hljs-keyword">let</span></span> context = getContext() as common.UIAbilityContext;
  <span class="hljs-comment"><span class="hljs-comment">// 新建一个保存裁剪后图片的路径</span></span>
  <span class="hljs-keyword"><span class="hljs-keyword">let</span></span> newPath = context.filesDir + <span class="hljs-string"><span class="hljs-string">'/test'</span></span> + <span class="hljs-keyword"><span class="hljs-keyword">new</span></span> <span class="hljs-built_in"><span class="hljs-built_in">Date</span></span>().getTime() + <span class="hljs-string"><span class="hljs-string">'.jpg'</span></span>;
  <span class="hljs-comment"><span class="hljs-comment">// 复制图片到新的路径</span></span>
  fs.copyFileSync(file.fd, newPath);
  <span class="hljs-comment"><span class="hljs-comment">// 关闭文件读取流</span></span>
  fs.closeSync(file);

  <span class="hljs-comment"><span class="hljs-comment">// 创建图片源对象</span></span>
  <span class="hljs-keyword"><span class="hljs-keyword">const</span></span> imageSource: image.ImageSource = image.createImageSource(newPath);
  console.log(<span class="hljs-string"><span class="hljs-string">'imageSource🥳'</span></span>, <span class="hljs-string"><span class="hljs-string">'-----&gt;👉'</span></span>, <span class="hljs-built_in"><span class="hljs-built_in">JSON</span></span>.stringify(imageSource));
  <span class="hljs-comment"><span class="hljs-comment">// 图片解码选项</span></span>
  <span class="hljs-keyword"><span class="hljs-keyword">let</span></span> decodingOptions: image.DecodingOptions = {
    editable: <span class="hljs-literal"><span class="hljs-literal">true</span></span>,
    desiredPixelFormat: <span class="hljs-number"><span class="hljs-number">3</span></span>,
  };
  <span class="hljs-comment"><span class="hljs-comment">// 创建像素地图</span></span>
  <span class="hljs-keyword"><span class="hljs-keyword">let</span></span> mPixelMap: image.PixelMap = await imageSource.createPixelMap(decodingOptions);
  <span class="hljs-comment"><span class="hljs-comment">// 获取图片信息</span></span>
  <span class="hljs-keyword"><span class="hljs-keyword">let</span></span> mImageInfo: image.ImageInfo = await mPixelMap.getImageInfo();
  console.log(<span class="hljs-string"><span class="hljs-string">'mImageInfo🥳'</span></span>, <span class="hljs-string"><span class="hljs-string">'-----&gt;👉'</span></span>, <span class="hljs-built_in"><span class="hljs-built_in">JSON</span></span>.stringify(mImageInfo));
  <span class="hljs-keyword"><span class="hljs-keyword">return</span></span> mPixelMap
} <span class="hljs-keyword"><span class="hljs-keyword">catch</span></span> (e) {
  console.error(<span class="hljs-string"><span class="hljs-string">'imgChange🥳'</span></span>, <span class="hljs-built_in"><span class="hljs-built_in">JSON</span></span>.stringify(e));
  <span class="hljs-keyword"><span class="hljs-keyword">return</span></span> <span class="hljs-literal"><span class="hljs-literal">undefined</span></span>
}

} }

@Entry @Component struct Page41 { @State mPixelMap: image.PixelMap | undefined = undefined @State uri: string = “” @State base64Str: string = ‘’

build() { Column() { Button(‘测试 writeFile’).onClick(async () => { this.uri = await FileOperate.writeFile(this.base64Str) }) Button(‘测试 fileChangePixelMap’).onClick(async () => { this.mPixelMap = await FileOperate.fileChangePixelMap(this.uri) }) Image(this.mPixelMap).width(‘200lpx’) } .height(‘100%’) .width(‘100%’) } }<button style="position: absolute; padding: 4px 8px 0px; cursor: pointer; top: 8px; right: 8px; font-size: 14px;">复制</button>

回到顶部