HarmonyOS Next应用开发——图像PixelMap压缩保存

【高心星出品】

图片编码保存

图片编码指将PixelMap编码成不同格式的存档图片,当前支持打包为JPEG、WebP、png和 HEIF(不同硬件设备支持情况不同) 格式,用于后续处理,如保存、传输等。图片编码是图片解码-图片处理-图片保存的最后环节,保存到当前应用沙箱中比较简单,但保存到用户文件中就比较麻烦。

在这里插入图片描述

图片保存到应用沙箱
图片压缩成字节数组
// 图片打包器
let packer=image.createImagePacker()
let file=fileIo.openSync(getContext(this).getApplicationContext().cacheDir+'/edit.jpg',fileIo.OpenMode.CREATE|fileIo.OpenMode.READ_WRITE)
// 将pixelmap打包成字节数组packer.packing(this.src,{format:'image/jpeg',quality:100}).then((buffer)=>{// 将字节数组 写入文件fileIo.writeSync(file.fd,buffer)})
图片直接打包成文件
// 图片打包器
let packer=image.createImagePacker()
let file=fileIo.openSync(getContext(this).getApplicationContext().cacheDir+'/edit.jpg',fileIo.OpenMode.CREATE|fileIo.OpenMode.READ_WRITE)
// 直接打包成文件
packer.packToFile(this.src,file.fd,{format:'image/jpeg',quality:100}).then(()=>{promptAction.showToast({message:'文件保存成功!'})}).catch(((e:Error)=>{console.error('gxxt ',e.message)}))
完整代码
import { image } from '@kit.ImageKit';
import { fileIo } from '@kit.CoreFileKit';
import { promptAction } from '@kit.ArkUI';@Entry
@Component
struct Imgsave {@State message: string = 'Hello World';@State src:PixelMap|undefined=undefinedaboutToAppear(): void {//  资源管理器let rsmanager=getContext(this).resourceManager//  图片字节let buffer= rsmanager.getMediaContentSync($r('app.media.jingse')).buffer.slice(0)// 生成imagesourcelet source=image.createImageSource(buffer)// 生成pixelmapthis.src=source.createPixelMapSync({editable:true})}savepic(){// 图片打包器let packer=image.createImagePacker()let file=fileIo.openSync(getContext(this).getApplicationContext().cacheDir+'/edit.jpg',fileIo.OpenMode.CREATE|fileIo.OpenMode.READ_WRITE)// 将pixelmap打包成字节数组// packer.packing(this.src,{format:'image/jpeg',quality:100}).then((buffer)=>{//   // 将字节数组 写入文件//   fileIo.writeSync(file.fd,buffer)// })// 直接打包成文件packer.packToFile(this.src,file.fd,{format:'image/jpeg',quality:100}).then(()=>{promptAction.showToast({message:'文件保存成功!'})}).catch(((e:Error)=>{console.error('gxxt ',e.message)}))}build() {Column(){Image(this.src).width(300).height(300).objectFit(ImageFit.Fill)Button('变换保存').width('60%').margin({top:20}).onClick(()=>{// 图片透明度改变和图片旋转180this.src?.opacitySync(0.5)this.src?.rotate(180)//   图片保存this.savepic()})}.width('100%').height('100%')}
}
图片保存到用户文件

由于用户文件系统与应用文件系统的隔离机制,想要访问用户文件系统,首先需要加入权限ohos.permission.WRITE_IMAGEVIDEO。

但鸿蒙又提供了一种临时获取用户权限的组件SaveButton,使用该组件不用申请权限可以临时获取用户文件系统的访问权限。

在这里插入图片描述

保存到相册
 //  图片打包let packer = image.createImagePacker()packer.packing(this.src, { format: 'image/jpeg', quality: 100 }).then(async (buffer) => {//   获取图片的字节数组//   获取图库图片操作管理员let phhelper = photoAccessHelper.getPhotoAccessHelper(getContext(this))// 保存相册请求 参数为上下文环境 保存类型let request = photoAccessHelper.MediaAssetChangeRequest.createAssetRequest(getContext(this),photoAccessHelper.PhotoType.IMAGE, 'jpg')// 将字节数组加入相册资源request.addResource(photoAccessHelper.ResourceType.IMAGE_RESOURCE, buffer)// 将相册改变保存phhelper.applyChanges(request).then(() => {promptAction.showToast({ message: '文件保存成功' })})})
完整代码
import { image } from '@kit.ImageKit';
import { photoAccessHelper } from '@kit.MediaLibraryKit';
import { fileIo } from '@kit.CoreFileKit';
import { promptAction } from '@kit.ArkUI';@Entry
@Component
struct Imagesave1 {@State message: string = 'Hello World';@State src: PixelMap | undefined = undefinedaboutToAppear(): void {//  资源管理器let rsmanager = getContext(this).resourceManager//  图片字节let buffer = rsmanager.getMediaContentSync($r('app.media.jingse')).buffer.slice(0)// 生成imagesourcelet source = image.createImageSource(buffer)// 生成pixelmapthis.src = source.createPixelMapSync({ editable: true })}build() {Column() {Image(this.src).width(300).height(300).objectFit(ImageFit.Fill).margin({ bottom: 20 })SaveButton({ text: SaveDescription.SAVE_IMAGE }).width('60%').onClick((event: ClickEvent, result: SaveButtonOnClickResult) => {if (result == SaveButtonOnClickResult.SUCCESS) {//   授权成功//   图片水平翻转this.src?.flip(true, false)//  图片打包let packer = image.createImagePacker()packer.packing(this.src, { format: 'image/jpeg', quality: 100 }).then(async (buffer) => {//   获取图片的字节数组//   获取图库图片操作管理员let phhelper = photoAccessHelper.getPhotoAccessHelper(getContext(this))// 保存相册请求 参数为上下文环境 保存类型let request = photoAccessHelper.MediaAssetChangeRequest.createAssetRequest(getContext(this),photoAccessHelper.PhotoType.IMAGE, 'jpg')// 将字节数组加入相册资源request.addResource(photoAccessHelper.ResourceType.IMAGE_RESOURCE, buffer)// 将相册改变保存phhelper.applyChanges(request).then(() => {promptAction.showToast({ message: '文件保存成功' })})})} else {promptAction.showToast({ message: '权限申请失败' })}})}.width('100%').height('100%')}
}})})} else {promptAction.showToast({ message: '权限申请失败' })}})}.width('100%').height('100%')}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/57331.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#中的接口的使用

定义接口 public interface IMyInterface {int MyProperty { get; set; }void MyMethod(); } 实现类 internal class MyClass : IMyInterface {public int MyProperty { get; set; }public void MyMethod(){Console.WriteLine("MyMethod is called");} } 目录结构…

logback-spring.xml 配置

<?xml version"1.0" encoding"UTF-8"?> <configuration debug"false"> <!-- 只需配置好 log.dir 和 appName 属性 --> <property name"log.dir" value"/alidata1/admin/prophet-za-metadata"/&g…

什麼是高速HTTP代理?

高速HTTP代理是一種用於加速和優化互聯網連接的技術。它通過在用戶和目標網站之間充當仲介伺服器&#xff0c;幫助用戶快速訪問網路資源。HTTP代理不僅可以提高訪問速度&#xff0c;還能提供一定程度的隱私保護和安全性。 高速HTTP代理的工作原理 HTTP代理伺服器位於用戶設備…

linux使用close函数关闭文件后,变跟内容会立即同步到磁盘吗

Linux使用close函数关闭文件后&#xff0c;变更内容不会立即同步到磁盘‌ ‌close函数的作用‌&#xff1a;Linux系统中的close函数用于关闭一个已经打开的文件描述符。当一个文件描述符被关闭后&#xff0c;它将不再引用任何文件&#xff0c;且这个文件描述符的值可以被后续的…

深度学习 %matplotlib inline

%matplotlib inline 是在 Jupyter Notebook 中使用的一个魔法命令&#xff0c;主要用于配置 Matplotlib 图形的显示方式。具体来说&#xff0c;这个命令的作用是将 Matplotlib 生成的图形直接嵌入到 notebook 中&#xff0c;而不是在弹出的窗口中显示。 使用方法 在 Jupyter …

苏宁商品详情接口技术解析与实战代码

在电商平台的开发中&#xff0c;商品详情接口是至关重要的一环&#xff0c;它提供了商品的详细信息&#xff0c;包括价格、库存、规格、图片等&#xff0c;为用户购物决策提供关键依据。苏宁作为国内知名的电商平台&#xff0c;其提供的商品详情接口为开发者提供了丰富的商品数…

负载箱的作用?

负载箱&#xff0c;顾名思义&#xff0c;就是用来承载电力设备的箱子。在电力系统中&#xff0c;负载箱的作用非常重要&#xff0c;它不仅可以模拟实际的电力负载&#xff0c;还可以对电力设备进行测试和调试&#xff0c;确保其正常运行。下面详细介绍负载箱的作用。 1. 模拟实…

【妙趣横生】01_C语言的指针是啥?为啥那么难懂?

引入&#xff1a; C语言的指针是啥&#xff1f;为啥那么难懂&#xff1f; C语言中的指针是C语言的一个核心概念&#xff0c;也是其强大和灵活性的重要来源之一。然而&#xff0c;对于初学者来说&#xff0c;指针确实可能是一个难以理解的概念。下面我会尽量用简单的语言来解释…

深入了解Spring重试组件spring-retry

在我们的项目中&#xff0c;为了提高程序的健壮性&#xff0c;很多时候都需要有重试机制进行兜底&#xff0c;最多就场景就比如调用远程的服务&#xff0c;调用中间件服务等&#xff0c;因为网络是不稳定的&#xff0c;所以在进行远程调用的时候偶尔会产生超时的异常&#xff0…

7. 配置

三种获取配置的方法 返回 /config/config.php 、/config/autoload/xxx.php 中的值 <?php namespace App\Controller;use Hyperf\Config\Annotation\Value; use Hyperf\Contract\ConfigInterface; use Hyperf\Di\Annotation\Inject; use Hyperf\HttpServer\Annotation\AutoC…

Vue应用中使用xlsx库实现Excel文件导出的完整指南

Vue应用中使用xlsx库实现Excel文件导出的完整指南 在现代Web开发中&#xff0c;经常需要将数据导出为Excel文件&#xff0c;以便于用户进行离线分析或记录。Vue.js作为一个轻量级且高效的前端框架&#xff0c;结合xlsx库可以轻松实现这一功能。本文将详细介绍如何在Vue应用中使…

这几次比赛题解

因为考虑到再看&#xff0c;所以将所有题目都做成了pdf格式 梦熊十三连测 T1 这道题其实什么也不用想&#xff0c;就按照题目给的意思来打代码就行&#xff0c;这就有40分可以拿。懒人做法 #include<bits/stdc.h> using namespace std; typedef long long ll; ll read…

python实现机器狗的行动控制

import sys import timefrom fontTools.merge import timer from ipykernel.heartbeat import Heartbeatdef OdomCallback(msg):print("腿部里程计调用")global body_x, body_yclass Move_control():def __init__(self):# 连接机器狗的运动主机及其端口self.server_a…

(二)Java1.8核心包rt.jar——java.lang.instrument

1、ClassFileTransformer /** * 参数: * loader - 正在加载类的类加载器 * className - 正在加载的类的名称 * classBeingRedefined -重定义的类 * protectionDomain-要定义或重定义的类的保护域 * classfileBuffer-类文件格式的输入字节缓冲区(不得修改) */ 1 public interfa…

MP9928模块分析

MP9928 是一款高性能的同步降压 DC/DC 转换器控制器 IC&#xff0c;具有宽输入范围。以下是其操作和关键特性的总结&#xff1a; 概述 电流模式控制&#xff1a;MP9928 使用电流模式、可编程开关频率控制架构&#xff0c;通过外部 N 沟道 MOSFET 开关来调节输出电压。 反馈和…

Golang | Leetcode Golang题解之第500题键盘行

题目&#xff1a; 题解&#xff1a; func findWords(words []string) (ans []string) {const rowIdx "12210111011122000010020202" next:for _, word : range words {idx : rowIdx[unicode.ToLower(rune(word[0]))-a]for _, ch : range word[1:] {if rowIdx[unico…

【uni-app学习-2】

一、跳转 方法&#xff1a;在methods中去定义方法&#xff1a; 上述为直接跳转&#xff0c;但是当你要跳转页面是由多个可切换页面组成比如&#xff1a; 这个页面其实是由两个页面组成&#xff0c;一个主页&#xff0c;一个我的&#xff0c;两个页面 路由配置需要用到toob…

房屋租赁网站毕业设计基于SpringBootSSM框架的计算机毕业设计

计算机毕业设计/springboot/javaWEB/J2EE/MYSQL数据库/vue前后分离小程序 目录 一、项目背景与目的‌ ‌二、系统需求分析‌ 2.1功能需求 2.2 技术需求 2.3 可执行性 ‌三、系统设计与实现‌ ‌3.1系统架构设计‌&#xff1a; ‌3.2功能模块开发‌&#xff1a; ‌3.3…

golang生成并分析cpu prof文件

1. 定义一个接口&#xff0c;请求接口时&#xff0c;生成cpu.prof文件 在主协程中新启一个协程&#xff0c;当请求接口时&#xff0c;生成一个60秒的cpu.prof文件 go func() {http.HandleFunc("/prof", startProfileHandler)http.ListenAndServe(":9092"…

WebScoket 使用教程

一、简介&#xff1a; WebSocket是一种协议&#xff0c;用于在Web应用程序和服务器之间建立实时、双向的通信连接。它通过一个单一的TCP连接提供了持久化连接&#xff0c;这使得Web应用程序可以更加实时地传递数据。WebSocket协议最初由W3C开发&#xff0c;并于2011年成为标准…