HarmonyOS 鸿蒙Next怎么将pixel对象存在本地相册

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

HarmonyOS 鸿蒙Next怎么将pixel对象存在本地相册 怎么将一个pixelmap对象存如图库

3 回复

可以参考下面代码:

import { photoAccessHelper } from '@kit.MediaLibraryKit';
import { fileIo } from '@kit.CoreFileKit';
import { common } from '@kit.AbilityKit';
import { promptAction } from '@kit.ArkUI';
import { BusinessError } from '@kit.BasicServicesKit';
import { image } from '@kit.ImageKit';

async function savePhotoToGallery(context: common.UIAbilityContext) {
  let helper = photoAccessHelper.getPhotoAccessHelper(context);
  try {
    // onClick触发后5秒内通过createAsset接口创建图片文件,5秒后createAsset权限收回。
    let uri = await helper.createAsset(photoAccessHelper.PhotoType.IMAGE, 'jpg');
    // 使用uri打开文件,可以持续写入内容,写入过程不受时间限制
    let file = await fileIo.open(uri, fileIo.OpenMode.READ_WRITE | fileIo.OpenMode.CREATE);
    // $r('app.media.startIcon')需要替换为开发者所需的图像资源文件
    let value = await context.resourceManager.getMediaContent($r('app.media.startIcon').id, 0)

    // 为了符合你的场景,将获取的图片,转成imageSource
    const imageSource: image.ImageSource = image.createImageSource(value.buffer);
    // 通过imageSource转成pixelMap类型
    imageSource.createPixelMap().then(pixelMap => {
      console.log("Succeeded in creating PixelMap")

      // 通过imagePacker.packing将pixelMap转成arraybuffer
      let imagePackerApi = image.createImagePacker();
      let packOpts: image.PackingOption = { format: "image/png", quality: 100 };
      imagePackerApi.packing(pixelMap, packOpts).then(async data => {
        // 最后再存入相册
        await fileIo.write(file.fd, data);
        await fileIo.close(file.fd);
        promptAction.showToast({ message: '已保存至相册!' });
      })
    }).catch(err => {
      console.error("Failed to creating PixelMap")
    });


  } catch (error) {
    const err: BusinessError = error as BusinessError;
    console.error(`Failed to save photo. Code is ${err.code}, message is ${err.message}`);
  }
}

@Entry
@Component
struct Index {
  build() {
    Row() {
      Column({ space: 10 }) {
        // $r('app.media.startIcon')需要替换为开发者所需的图像资源文件
        Image($r('app.media.startIcon'))
          .height(400)
          .width('100%')

        SaveButton()
          .padding({
            top: 12,
            bottom: 12,
            left: 24,
            right: 24
          })
          .onClick(async (event: ClickEvent, result: SaveButtonOnClickResult) => {
            if (result === SaveButtonOnClickResult.SUCCESS) {
              const context: common.UIAbilityContext = getContext(this) as common.UIAbilityContext;
              // 免去权限申请和权限请求等环节,获得临时授权,保存对应图片
              savePhotoToGallery(context);
            } else {
              promptAction.showToast({ message: '设置权限失败!' })
            }
          })
      }
      .width('100%')
    }
    .height('100%')
    .backgroundColor(0xF1F3F5)
  }
}

使用安全保存控件,不用申请读写相册权限。

代码中为了有段代码是arraybuffer转pixelMap,再转arraybuffer,是为了贴合你需要的代码场景

更多关于HarmonyOS 鸿蒙Next怎么将pixel对象存在本地相册的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


项目名称

  • 状态:已完成
  • 类型:移动应用
  • 技术栈:React Native
  • 描述:这是一个移动应用,用于展示产品信息和用户交互。

在HarmonyOS(鸿蒙)系统中,将pixel对象(通常指图像数据)保存到本地相册,通常涉及以下几个步骤:

  1. 获取图像数据:首先,确保你已经有了图像数据,这些数据可能是从相机捕获的,或者是从某个图像文件中读取的。在鸿蒙系统中,图像数据通常以Bitmap或类似的形式存在。

  2. 创建保存路径:确定你想要保存图像的路径。这可以是设备的内部存储或外部存储(如SD卡)。注意,访问外部存储可能需要额外的权限。

  3. 保存图像:使用鸿蒙提供的API将图像数据写入到指定的文件路径。这通常涉及将Bitmap对象转换为文件流,并写入到存储介质中。鸿蒙系统提供了相应的文件操作API,可以用来创建文件、写入数据等。

  4. 刷新相册:保存图像后,可能需要通知系统的媒体存储服务,以便新保存的图像能够立即出现在相册应用中。这通常涉及发送广播或使用媒体存储API来更新媒体数据库。

请注意,具体的实现细节可能因鸿蒙系统的版本和设备的不同而有所差异。如果上述步骤无法直接解决你的问题,可能是因为缺少具体的上下文或代码示例。

如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html

回到顶部