HarmonyOS学习路之开发篇—多媒体开发(图像开发 二)

这篇具有很好参考价值的文章主要介绍了HarmonyOS学习路之开发篇—多媒体开发(图像开发 二)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

图像编码开发

场景介绍

图像编码就是将PixelMap图像编码成不同存档格式图片,用于后续其他处理,比如保存、传输等。当前仅支持JPEG格式。

接口说明

ImagePacker主要用于图像编码。

接口名

描述

create()

创建图像打包器实例。

initializePacking(byte[] data, PackingOptions opts)

初始化打包任务,将字节数组设置为打包后输出目的。

initializePacking(byte[] data, int offset, PackingOptions opts)

初始化打包任务,将带偏移量的字节数组设置为打包后输出目的。

initializePacking(OutputStream outputStream, PackingOptions opts)

初始化打包任务,将输出流设置为打包后输出目的。

addImage(PixelMap pixelmap)

将PixelMap对象添加到图像打包器中。

addImage(ImageSource source)

将图像数据源ImageSource中图像添加到图像打包器中。

addImage(ImageSource source, int index)

将图像数据源ImageSource中指定图像添加到图像打包器中。

finalizePacking()

完成图像打包任务。

release()

释放对象关联的本地资源。

开发步骤

1. 创建图像编码ImagePacker对象

ImagePacker imagePacker = ImagePacker.create();

2. 设置编码输出流和编码参数。设置format为编码的图像格式,当前支持jpeg格式。设置quality为图像质量,范围从0-100,100为最佳质量

// 传入本地图片路径,图片格式需要与packingOptions.format相对应
FileOutputStream outputStream = null;
try {
    outputStream = new FileOutputStream("/path/to/packed.file");
} catch (FileNotFoundException e) {
    e.printStackTrace();
}
ImagePacker.PackingOptions packingOptions = new ImagePacker.PackingOptions();
packingOptions.format = "image/jpeg";
packingOptions.quality = 90;
boolean result = imagePacker.initializePacking(outputStream, packingOptions);

3. 添加需要编码的PixelMap对象,进行编码操作

result = imagePacker.addImage(pixelMap);
long dataSize = imagePacker.finalizePacking();

4. 编码输出完成后,可以进行后续处理,比如保存、传输等。

5. 释放创建的ImagePacker

imagePacker.release();

位图操作开发

场景介绍

位图操作就是指对PixelMap图像进行相关的操作,比如创建、查询信息、读写像素数据等。

接口说明

接口名

描述

create(InitializationOptions opts)

根据图像大小、像素格式、alpha类型等初始化选项创建PixelMap。

create(int[] colors, InitializationOptions opts)

根据图像大小、像素格式、alpha类型等初始化选项,以像素颜色数组为数据源创建PixelMap。

create(int[] colors, int offset, int stride, InitializationOptions opts)

根据图像大小、像素格式、alpha类型等初始化选项,以像素颜色数组、起始偏移量、行像素大小描述的数据源创建PixelMap。

create(PixelMap source, InitializationOptions opts)

根据图像大小、像素格式、alpha类型等初始化选项,以源PixelMap为数据源创建PixelMap。

create(PixelMap source, Rect srcRegion, InitializationOptions opts)

根据图像大小、像素格式、alpha类型等初始化选项,以源PixelMap、源裁剪区域描述的数据源创建PixelMap。

getBytesNumberPerRow()

获取每行像素数据占用的字节数。

getPixelBytesCapacity()

获取存储Pixelmap像素数据的内存容量。

isEditable()

判断PixelMap是否允许修改。

isSameImage(PixelMap other)

判断两个图像是否相同,包括ImageInfo属性信息和像素数据。

readPixel(Position pos)

读取指定位置像素的颜色值,返回的颜色格式为PixelFormat.ARGB_8888。

readPixels(int[] pixels, int offset, int stride, Rect region)

读取指定区域像素的颜色值,输出到以起始偏移量、行像素大小描述的像素数组,返回的颜色格式为PixelFormat.ARGB_8888。

readPixels(Buffer dst)

读取像素的颜色值到缓冲区,返回的数据是PixelMap中像素数据的原样拷贝,即返回的颜色数据格式与PixelMap中像素格式一致。

resetConfig(Size size, PixelFormat pixelFormat)

重置PixelMap的大小和像素格式配置,但不会改变原有的像素数据也不会重新分配像素数据的内存,重置后图像数据的字节数不能超过PixelMap的内存容量。

setAlphaType(AlphaType alphaType)

设置PixelMap的Alpha类型。

writePixel(Position pos, int color)

向指定位置像素写入颜色值,写入颜色格式为PixelFormat.ARGB_8888。

writePixels(int[] pixels, int offset, int stride, Rect region)

将像素颜色数组、起始偏移量、行像素的个数描述的源像素数据写入PixelMap的指定区域,写入颜色格式为PixelFormat.ARGB_8888。

writePixels(Buffer src)

将缓冲区描述的源像素数据写入PixelMap,写入的数据将原样覆盖PixelMap中的像素数据,即写入数据的颜色格式应与PixelMap的配置兼容。

writePixels(int color)

将所有像素都填充为指定的颜色值,写入颜色格式为 PixelFormat.ARGB_8888。

getPixelBytesNumber()

获取全部像素数据包含的字节数。

setBaseDensity(int baseDensity)

设置PixelMap的基础像素密度值。

getBaseDensity()

获取PixelMap的基础像素密度值。

setUseMipmap(boolean useMipmap)

设置PixelMap渲染是否使用mipmap。

useMipmap()

获取PixelMap渲染是否使用mipmap。

getNinePatchChunk()

获取图像的NinePatchChunk数据。

getFitDensitySize(int targetDensity)

获取适应目标像素密度的图像缩放的尺寸。

getImageInfo()

获取图像基本信息。

release()

释放对象关联的本地资源

开发步骤

1. 创建位图对象PixelMap

// 从像素颜色数组创建
int[] defaultColors = new int[] {5, 5, 5, 5, 6, 6, 3, 3, 3, 0};
PixelMap.InitializationOptions initializationOptions = new PixelMap.InitializationOptions();
initializationOptions.size = new Size(3, 2);
initializationOptions.pixelFormat = PixelFormat.ARGB_8888;
initializationOptions.editable = true;
PixelMap pixelMap = PixelMap.create(defaultColors, initializationOptions);

// 指定初始化选项创建
PixelMap pixelMap2 = PixelMap.create(initializationOptions);

// 以另外一个PixelMap作为数据源创建
PixelMap pixelMap3 = PixelMap.create(pixelMap2, initializationOptions);

2. 从位图对象中获取信息

long capacity = pixelMap.getPixelBytesCapacity();
long bytesNumber = pixelMap.getPixelBytesNumber();
int rowBytes = pixelMap.getBytesNumberPerRow();
byte[] ninePatchData = pixelMap.getNinePatchChunk();

3. 读写位图像素数据。

// 读取指定位置像素
int color = pixelMap.readPixel(new Position(1, 1));

// 读取指定区域像素
int[] pixelArray = new int[50];
Rect region = new Rect(0, 0, 2, 2);
pixelMap.readPixels(pixelArray, 0, 10, region);

// 读取像素到Buffer
IntBuffer pixelBuf = IntBuffer.allocate(50);
pixelMap.readPixels(pixelBuf);

// 在指定位置写入像素
pixelMap.writePixel(new Position(1, 1), 0xFF112233);

// 在指定区域写入像素
pixelMap.writePixels(pixelArray, 0, 10, region);

// 写入Buffer中的像素
pixelMap.writePixels(pixelBuf);

图像属性解码开发

场景介绍

图像属性解码就是获取图像中包含的属性信息,比如EXIF属性。

接口说明

图像属性解码的功能主要由ImageSource和ExifUtils提供。

ImageSource的主要接口

接口名

描述

getThumbnailInfo()

获取嵌入图像文件的缩略图的基本信息。

getImageThumbnailBytes()

获取嵌入图像文件缩略图的原始数据。

getThumbnailFormat()

获取嵌入图像文件缩略图的格式。

ExifUtils的主要接口

接口名

描述

getLatLong(ImageSource imageSource)

获取嵌入图像文件的经纬度信息。

getAltitude(ImageSource imageSource, double defaultValue)

获取嵌入图像文件的海拔信息。

开发步骤

1. 创建图像数据源ImageSource对象,可以通过SourceOptions指定数据源的格式信息,此格式信息仅为给解码器的提示,正确提供能帮助提高解码效率,如果不设置或设置不正确,会自动检测正确的图像格式。

ImageSource.SourceOptions srcOpts = new ImageSource.SourceOptions();
srcOpts.formatHint = "image/jpeg";
// 此处传入用户自定义的带缩略图的图像路径
String pathName = "/sdcard/image.jpg";
ImageSource imageSource = ImageSource.create(pathName, srcOpts);

2. 获取缩略图信息文章来源地址https://www.toymoban.com/news/detail-503129.html

int format = imageSource.getThumbnailFormat();
byte[] thumbnailBytes = imageSource.getImageThumbnailBytes();

// 将缩略图解码为PixelMap对象
ImageSource.DecodingOptions decodingOpts = new ImageSource.DecodingOptions();
PixelMap thumbnailPixelmap = imageSource.createThumbnailPixelmap(decodingOpts, false);

到了这里,关于HarmonyOS学习路之开发篇—多媒体开发(图像开发 二)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 鸿蒙HarmonyOS开发实战—多媒体开发(音频开发 一)

    HarmonyOS音频模块支持音频业务的开发,提供音频相关的功能,主要包括音频播放、音频采集、音量管理和短音播放等。 基本概念 采样 采样是指将连续时域上的模拟信号按照一定的时间间隔采样,获取到离散时域上离散信号的过程。 采样率 采样率为每秒从连续信号中提取并

    2024年01月24日
    浏览(38)
  • 软考:中级软件设计师:多媒体基础,音频,图像,颜色,多媒体技术的种类,图像音频视频的容量计算,常见的多媒体标准

    提示:系列被面试官问的问题,我自己当时不会,所以下来自己复盘一下,认真学习和总结,以应对未来更多的可能性 关于互联网大厂的笔试面试,都是需要细心准备的 (1)自己的科研经历, 科研内容 ,学习的相关领域知识,要熟悉熟透了 (2)自己的实习经历,做了 什

    2024年02月09日
    浏览(39)
  • 设计HTML5图像和多媒体

    在网页中的文本信息直观、明了,而多媒体信息更富内涵和视觉冲击力。恰当使用不同类型的多媒体可以展示个性,突出重点,吸引用户。在HTML5之前,需要借助插件为网页添加多媒体,如Adobe Flash Player、苹果的QuickTime等。HTML5引入原生的多媒体技术,设计多媒体更简便,用户

    2024年02月12日
    浏览(28)
  • 多媒体数据处理实验3:图像特征提取与检索

    1. 算法描述 功能:   使用BOF(Bag of Features)算法提取图像特征,在corel数据集(10*100)张图片上实现以图搜图,即输入数据集中某一张图,在剩下的999张图里搜索最邻近的10张图。 2.算法流程: 用 SIFT算法 提取图像的特征。每幅图像提取出几百至几千个特征点,将所有图像的特

    2024年02月07日
    浏览(49)
  • (八)穿越多媒体奇境:探索Streamlit的图像、音频与视频魔法

    欢迎各位读者来到“最全Streamlit教程”专栏系列!如果您正在寻找一种简单而强大的方式来创建交互式数据应用程序,那么Streamlit无疑是您的最佳选择。作为该领域的热门框架,Streamlit让数据科学家、开发者和爱好者能够以前所未有的速度构建出引人入胜的数据可视化工具。

    2024年02月13日
    浏览(34)
  • 多媒体开发之cgo

         go语言作为近十年来优秀的现代开发语言的代表,由于继承了c语言的简洁和很多现代语言的表达方式,在广泛的应用场景中得到众多爱好者的喜爱,如何将go和c、c++进行联合开发,拓展整个开发生态,不用重复造轮子,掌握cgo可以让你得心应手的在c和go之间传递信息,

    2024年02月16日
    浏览(35)
  • [HTML]Web前端开发技术4(HTML5、CSS3、JavaScript )图像与多媒体文件hspace,vspace,scrollamount,bgcolor,marquee——喵喵画网页

    希望你开心,希望你健康,希望你幸福,希望你点赞! 最后的最后,关注喵,关注喵,关注喵,佬佬会看到更多有趣的博客哦!!! 喵喵喵,你对我真的很重要! 目录 前言 图像与多媒体文件 网页文件常见的图像格式有: 图像 设置图像的替代文字 设置图像的宽度和高度

    2024年02月05日
    浏览(50)
  • Android多媒体功能开发(2)——FileProvider

    使用系统多媒体界面需要在我们的应用和其他应用之间通过Intent传递音频、图片、视频文件的信息。随着Android版本的升级,对应用数据安全性方面的限制越来越多。 Android 6以后不允许应用在外部存储随便创建目录,只能在Android规定的应用自己的文件目录下创建目录,该目录

    2024年02月14日
    浏览(34)
  • qt6 多媒体开发代码分析(二、录音)

    常见的音频编码格式包括MP3、AAC、OGG、WMA、FLAC等,它们之间具有以下区别: 编码方式不同:这些编码格式采用的编码算法不同,例如MP3和AAC使用有损压缩算法,而FLAC使用无损压缩算法。 压缩率和文件大小不同:由于采用的编码算法不同,不同格式的音频文件压缩率和文件大

    2024年02月07日
    浏览(24)
  • HTML-多媒体嵌入-MDN文档学习笔记

    查看更多学习笔记:GitHub:LoveEmiliaForever MDN中文官网 将图片放入网页 可以使用 img/ 来将图片嵌入网页,它是一个空元素,最少只需 src 属性即可工作 src 指向图片资源的地址,是 img/ 正常工作必不可少的属性 ❗️除非有必要,否则 永远不要 把 src 指向其它网站上的图片,这

    2024年02月20日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包