您的位置:首页 > 娱乐 > 明星 > 泉州_品牌的定义_提高网站排名软件_模板之家

泉州_品牌的定义_提高网站排名软件_模板之家

2025/1/6 7:02:00 来源:https://blog.csdn.net/m0_61243965/article/details/144758351  浏览:    关键词:泉州_品牌的定义_提高网站排名软件_模板之家
泉州_品牌的定义_提高网站排名软件_模板之家

问题描述:鸿蒙Next如何实现打开相册选图片功能

应用场景:用户个人中心自定义头像的时候,需要选择相册上传照片。

解决方案:

使用picker这个API实现从系统上获取相册图片这个点的,

1、首先要实例一个选择参数PhotoSelectOptions 里面需要设置媒体文件类型还有一个数量

2、然后—>实例一个选择器PhotoViewPicker,

3、通过自带的——>select方法传入先前设置的选择参数即可完成选择并获取到选择图片的文件路径

4、解析文件路径转为PixelMap格式或者base64格式

5、再对接后端接口上传数据

// 导入选择器模块和文件管理模块
import {  zipImageUtil} from '../utils/ZipImageUtil'
import { photoAccessHelper } from '@kit.MediaLibraryKit';
import { image } from '@kit.ImageKit';
import { fileIo as fs } from '@kit.CoreFileKit';
import {  buffer as Buffer} from '@kit.ArkTS';// 拉起相册,选择图片方法
class getPhotofromAlbum{getAlbum: string = '显示相册中的图片';pixel: image.PixelMap | undefined = undefined;albumPath: string = '';photoSize: number = 0;async initData():Promise<string>{try{//创建图片-音频类型文件选择选项实例let PhotoSelectOptions = new photoAccessHelper.PhotoSelectOptions(); PhotoSelectOptions.MIMEType = photoAccessHelper.PhotoViewMIMETypes.IMAGE_TYPE;PhotoSelectOptions.maxSelectNumber = 1; // 最多选择数量//创建图库选择器实例,调用PhotoViewPicker.select接口拉起图库界面进行文件选择。文件选择成功后,返回PhotoSelectResult结果集。let photoPicker = new photoAccessHelper.PhotoViewPicker(); let photoSelectResult: photoAccessHelper.PhotoSelectResult = await photoPicker.select(PhotoSelectOptions);this.albumPath = photoSelectResult.photoUris[0];  //获得到选择图片的文件路径// 使用file解析文件,并读取图片为bufferconst file = fs.openSync(this.albumPath, fs.OpenMode.READ_ONLY);this.photoSize = fs.statSync(file.fd).size;console.info('Photo Size: ' + this.photoSize);let buffer = new ArrayBuffer(this.photoSize);fs.readSync(file.fd, buffer);fs.closeSync(file);// 解码成PixelMapconst imageSource = image.createImageSource(buffer);console.log('imageSource: ' + JSON.stringify(imageSource));let pixelMap = await imageSource.createPixelMap({});//设置打包参数const imagePackerApi = image.createImagePacker();const packOpts: image.PackingOption = { format: "image/jpeg", quality: 100 };let imageBuffer: ArrayBuffer = new ArrayBuffer(1);// 图片压缩或重新打包imageBuffer = await imagePackerApi.packing(imageSource, packOpts);imageBuffer = await zipImageUtil.packingImage(imageBuffer, pixelMap, 100, 500*1024); //压缩到500kbconsole.log('压缩后的字节长度:'+imageBuffer.byteLength/1024)//转成base64地址let base64Str:string = Buffer.from(imageBuffer).toString('base64')return base64Str}catch(e){throw new Error(`相册 获取照片失败 : ${JSON.stringify(e)}`);}}}

调用方法

   new getPictureFromAlbum().initData().then(res => {let base64=res})

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com