当前位置: 首页 > java >正文

鸿蒙下载图片保存到相册,截取某个组件保存到相册

鸿蒙下载图片保存到相册,截取某个组件保存到相册

import { image } from '@kit.ImageKit'
import photoAccessHelper from '@ohos.file.photoAccessHelper'
import { BusinessError } from '@kit.BasicServicesKit'
import { http } from '@kit.NetworkKit'
import fs from '@ohos.file.fs';
import { fileUri } from '@kit.CoreFileKit';
import { Context, Permissions } from '@kit.AbilityKit';
import { componentSnapshot } from '@kit.ArkUI';
import { PermissionUtil } from '../util/PermissionUtil';
import { PhotoHelper } from '../util/PhotoHelper';
import { FileUtil } from '../util/FileUtil';
import { LogUtil } from '@ohos/commonlibrary';//保存画报到相册
function savePictorialToPhoto() {//TODO:let pixmap: image.PixelMap | undefined = undefinedlet uriStr: string = ''//截图,“root”是组件的idlet pixelmap = componentSnapshot.getSync("root", { scale: 2, waitUntilRenderFinished: true })pixmap = pixelmapconsole.log("测试保存"+JSON.stringify(pixmap))//保存本地-相册//Dialog截图let ps: Permissions[] = ['ohos.permission.WRITE_IMAGEVIDEO'];PermissionUtil.requestPermissions(ps).then((result) => {if (result) {LogUtil.debug("测试保存"+result)let imgName = `海报_${new Date().getTime()}`;PhotoHelper.save(photoAccessHelper.PhotoType.IMAGE, 'png', { title: imgName }).then(async (uri) => {if (uri) {uriStr = `调用2保存图片,返回uris:\n${uri}`let file = FileUtil.openSync(uri);let packOpts: image.PackingOption = { format: 'image/png', quality: 100 }PhotoHelper.packToFileFromPixelMap(pixmap!!, file.fd, packOpts).then(() => {FileUtil.close(file.fd);console.log("测试保存成功")})}}).catch((err: BusinessError) => {uriStr = `调用保存图片,异常:\n${JSON.stringify(err)}`})} else {console.log("测试保存失败")}})
}@Entry
@Component/***首页*/
struct CeshiPage {build() {//底部导航栏Column() {Button('测试保存相册').onClick(() => {this.dowImageAndSave("http://img14.360buyimg.com/imgzone/jfs/t1/317716/18/12967/150513/686749d5Fef9f99f1/eeefe1ff7bce6117.png",getContext())})Button('测试截图保存相册').onClick(() => {savePictorialToPhoto()})}.id("root").width('100%').height('100%')}async dowImageAndSave(url: string, context: Context) {let phAccessHelper = photoAccessHelper.getPhotoAccessHelper(context)let pixelMap: PixelMap | undefined = undefinedlet packOptions: image.PackingOption = { format: 'image/jpeg', quality: 98 }let imagePackerApi = image.createImagePacker()// 下载图片到本地http.createHttp().request(url, {method: http.RequestMethod.GET,connectTimeout: 60000,readTimeout: 60000}, async (error: BusinessError, data: http.HttpResponse) => {if (error) {console.log(`${error.code},${error.message}`)} else {let imageData: ArrayBuffer = data.result as ArrayBufferlet ImageSource: image.ImageSource = image.createImageSource(imageData)//   创建pixelmap对象pixelMap = await ImageSource.createPixelMap()const path: string = context.cacheDir + "/save_image.jpg"//   写入本地let file = fs.openSync(path, fs.OpenMode.CREATE | fs.OpenMode.READ_WRITE)await imagePackerApi.packToFile(pixelMap, file.fd, packOptions)// 获取图片urilet uri = fileUri.getUriFromPath(path)//   复制图片到相册let uris: Array<string> = [uri]let photoCreationConfig: Array<photoAccessHelper.PhotoCreationConfig> = [{title: 'dowImg',fileNameExtension: 'jpg',photoType: photoAccessHelper.PhotoType.IMAGE,subtype: photoAccessHelper.PhotoSubtype.DEFAULT}]//   基于弹窗授权的方式获取媒体库的目标urilet desFileuris: Array<string> = await phAccessHelper.showAssetsCreationDialog(uris, photoCreationConfig)//   将应用沙箱的照片写入媒体库let desFile: fs.File = await fs.open(desFileuris[0], fs.OpenMode.WRITE_ONLY) //  相册let srcFile: fs.File = await fs.open(uri, fs.OpenMode.READ_ONLY) // 沙箱图片// 沙箱图片复制到相册await fs.copyFile(srcFile.fd, desFile.fd).then(() => {fs.close(srcFile)fs.close(desFile)})}})//=====================}
}
http://www.xdnf.cn/news/17692.html

相关文章:

  • 海康视觉相机驱动软件参数配置
  • 【C++】哈希
  • Unity:GUI笔记(一)——文本、按钮、多选框和单选框、输入框和拖动条、图片绘制和框绘制
  • 电商双 11 美妆数据分析:从数据清洗到市场洞察
  • Linux系统中mount指令的作用与必要性
  • 简单的双向循环链表实现与使用指南
  • Java数据库编程之【JDBC数据库例程】【自动生成报表】【六】
  • Gradient Descent for Logistic Regression|逻辑回归梯度下降
  • Qwen-OCR:开源OCR技术的演进与全面分析
  • 【数据结构】——顺序表链表(超详细解析!!!)
  • Flink运行时的实现细节
  • COAT: 压缩优化器状态和激活以实现内存高效的FP8训练
  • apache+虚拟主机
  • @(AJAX)
  • 使用Spring Boot对接欧州OCPP1.6充电桩:解决WebSocket连接自动断开问题
  • 日志管理--g3log
  • 前端项目一键换肤
  • IEEE 2025 | 重磅开源!SLAM框架用“法向量+LRU缓存”,将三维重建效率飙升72%!
  • 单例模式,动态代理,微服务原理
  • 操作系统1.6:虚拟机
  • 从原理到实践:一文掌握Kafka的消息生产与消费
  • 【bug 解决】串口输出字符乱码的问题
  • pdftk - macOS 上安装使用
  • 干货分享|如何从0到1掌握R语言数据分析
  • OpenAI传来捷报,刚刚夺金IOI,实现通用推理模型的跨越式突破
  • 如何实现PostgreSQL的高可用性,包括主流的复制方案、负载均衡方法以及故障转移流程?
  • 【接口自动化】-11-接口加密签名 全局设置封装
  • 容器安全扫描工具在海外云服务器环境的集成方法
  • Element用法---Loading 加载
  • npm、pnpm、yarn区别