HarmonyOS 图片Base64编码

通过CameraKit pick拍照获取的图片怎么进行Base64编码

HarmonyOS
2024-12-20 16:05:43
849浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
zbw_apple

参考demo

let packOpts: image.PackingOption = { format: "image/jpeg", quality: 98 };
let imagePackerApi = image.createImagePacker();
const context: Context = getContext(this);
const resourceMgr = context.resourceManager;
let imageBuffer = await resourceMgr.getMediaContent($r('app.media.ic_low'));
const imageSource: image.ImageSource = image.createImageSource(imageBuffer.buffer);
let decodingOptions: image.DecodingOptions = {
  editable: true,
  desiredPixelFormat: 3,
  rotate: 90
}
// 创建pixelMap并进行简单的旋转和缩放
imageSource.createPixelMap(decodingOptions).then((pixelMap: PixelMap) => {
  this.pixelMap = pixelMap
  // pixelmap 转base64 先要有一个packing的过程
  imagePackerApi.packing(pixelMap, packOpts).then((data: ArrayBuffer) => {
    let base64Str = buffer.from(data).toString('base64')
    let resultBase64Str = "data:image/png;base64," + base64Str
    this.resultBase64Str = resultBase64Str
  }).catch((error: BusinessError) => {
    console.error('Failed to pack the image. And the error is: ' + error);
  })
  pixelMap.release();
})
//重点提示: pixelmap转base64 不能直接转,先要加一个packing的过程,下面的方法是一个错误的实例,转出来的base64字符串不对。
let pixelMap = await imageSource.createPixelMap(opts);
console.log("pixelMap.getPixelBytesNumber():" + pixelMap.getPixelBytesNumber())
let arrayBuffer = new ArrayBuffer(pixelMap.getPixelBytesNumber());
pixelMap.readPixelsToBuffer(arrayBuffer)
console.log("arrayBuffer" + arrayBuffer)
let base64Str = buffer.from(arrayBuffer).toString(Constants.BASE_64);
let resultBase64Str = "data:image/png;base64," + base64Str
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.

获取沙箱路径

import UIAbility from '@ohos.app.ability.UIAbility';
 export default class EntryAbility extends UIAbility {
   onWindowStageCreate(windowStage) {
       let context = this.context;
       let pathDir = context.filesDir;
   }}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.

参考链接:https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/app-sandbox-directory-V5

分享
微博
QQ
微信
回复
2024-12-20 19:18:29


相关问题
HarmonyOS 图片进行base64编码报错
1378浏览 • 1回复 待解决
HarmonyOS base64编码问题
1390浏览 • 1回复 待解决
js canvas转base64编码图片不全
12039浏览 • 1回复 待解决
HarmonyOS base64编码的API
751浏览 • 1回复 待解决
HarmonyOS 图片base64
941浏览 • 1回复 待解决
arkts中怎么实现base64编码
1577浏览 • 1回复 待解决
HarmonyOS 图片压缩和图片base64
1167浏览 • 1回复 待解决
怎么把PixelMap图片BASE64
10378浏览 • 1回复 待解决
HarmonyOS 拍照后的图片base64
677浏览 • 1回复 待解决
HarmonyOS 如何实现Base64数据转图片
901浏览 • 1回复 待解决
HarmonyOS 图片操作,合成后导出base64
984浏览 • 1回复 待解决
HarmonyOS如何将图片Base64
1957浏览 • 1回复 待解决
如何进行base64编码,有人知道吗?
1278浏览 • 1回复 待解决
HarmonyOS base64图片如何转成Arraybuffer
542浏览 • 1回复 待解决
HarmonyOS 关于Image组件使用base64图片
1459浏览 • 1回复 待解决
HarmonyOS Image如何显示base64图片
1280浏览 • 1回复 待解决
如何base64转换成图片
11508浏览 • 2回复 待解决
HarmonyOS base64转image
755浏览 • 1回复 待解决
HarmonyOS 图片base64转码后乱码
719浏览 • 1回复 待解决
HarmonyOS base64编解码
977浏览 • 0回复 待解决