HarmonyOS 鸿蒙Next:调用image.createImageSource方法传入图片沙箱路径失败原因
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 联系官网客服。
调用image.createImageSource方法,传入图片的沙箱路径,如图所示,返回的沙箱路径为:file://com.midea.weexwebsdkdemo/data/storage/el2/base/haps/entry/files/1.png
但是一直创建失败,请问什么原因?
更多关于HarmonyOS 鸿蒙Next:调用image.createImageSource方法传入图片沙箱路径失败原因的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html
有要学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-->"</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">'----->👉'</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">'----->👉'</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">'----->👉'</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>