RN端HarmonyOS的react-native-image-picker,获取图片只能获取uri,无法获取base64

RN端HarmonyOS的react-native-image-picker,获取图片只能获取uri,无法获取base64

HarmonyOS
2024-08-23 10:21:07
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
superinsect

可以使用HarmonyOS原生能力获取图片base64,参考链接:https://developer.huawei.com/consumer/cn/doc/harmonyos-faqs-V5/faqs-image-kit-0000001816452293-V5#section871313119219

import { image } from '@kit.ImageKit'; 
import { buffer } from '@kit.ArkTS'; 
 
@Entry 
@Component 
struct Index { 
  @State message: string = 'PixelMapToBase64'; 
  @State base64: string = ''; 
  build() { 
    Row() { 
      Column() { 
        Text(this.message) 
          .fontSize(50) 
          .fontWeight(FontWeight.Bold) 
          .onClick(async () => { 
            let resourceManager = getContext(this).resourceManager 
            let imageArray = await resourceManager.getMediaContent($r('app.media.sample7')); 
            let pixelBuffer = new Uint8Array(imageArray).buffer as Object as ArrayBuffer; 
            let imageResource = image.createImageSource(pixelBuffer); 
            let opts: image.DecodingOptions = { editable: true } 
            let pixelMap = await imageResource.createPixelMap(opts); 
            // 转换成base64 
            const imagePackerApi: image.ImagePacker = image.createImagePacker(); 
            let packOpts: image.PackingOption = { format: 'image/jpeg', quality: 100 }; 
            imagePackerApi.packing(pixelMap, packOpts).then((data: ArrayBuffer) => { 
              let buf: buffer.Buffer = buffer.from(data); 
              this.base64 = 'data:image/jpeg;base64,' + buf.toString('base64', 0, buf.length); 
              console.info('base64: ' + this.base64); 
            }) 
          }) 
        Image(this.base64) 
          .width(200).height(200).margin(15) 
      } 
      .width('100%') 
    } 
    .height('100%') 
 
  } 
}
分享
微博
QQ
微信
回复
2024-08-23 21:05:21
相关问题
HarmonyOS Image如何显示base64图片
303浏览 • 1回复 待解决
HarmonyOS 图片进行base64编码报错
517浏览 • 1回复 待解决
HarmonyOS如何将图片Base64
778浏览 • 1回复 待解决
HarmonyOS 图片操作,合成后导出base64
85浏览 • 1回复 待解决
怎么把PixelMap图片BASE64
9244浏览 • 1回复 待解决
HarmonyOS base64解码报错
670浏览 • 1回复 待解决
js canvas转base64编码图片不全
10612浏览 • 1回复 待解决
HarmonyOS base64编码API
102浏览 • 1回复 待解决
HarmonyOS 如何将base64数据转换为图片
385浏览 • 1回复 待解决
HarmonyOS 图片转为base64字符串
86浏览 • 1回复 待解决
HarmonyOS base64编码问题
407浏览 • 1回复 待解决
如何base64转换成图片
10140浏览 • 2回复 待解决
HarmonyOS 中文base64加密解密乱码
444浏览 • 1回复 待解决
客户开发无法获取code
256浏览 • 1回复 待解决
PixelMap怎么转Base64?(非Java)
3121浏览 • 2回复 待解决