[C++] opencv - imwrite函数介绍和使用场景

这篇具有很好参考价值的文章主要介绍了[C++] opencv - imwrite函数介绍和使用场景。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、函数介绍

OpenCV 是一个开源的计算机视觉库,它包含了许多用于图像处理和计算机视觉任务的函数。其中,imsave() 函数是 OpenCV 中的一个非常有用的函数,它可以让程序将处理后的图像数据保存到指定的文件中。

二、函数原型

bool imwrite(const String& filename, InputArray image, const std::vector<int>& params);

其中,
filename 参数表示要保存的文件名
image 参数表示要保存的图像数据
params 可选参数表示保存图像使用的参数

params 使用说明:
该参数需要按照参数id+参数值成对出现,可以出现多对参数值(比如 (paramId_1, paramValue_1, paramId_2, paramValue_2, ...)),但必须保证这些参数对是相关的,比如保存JPG图像时,只能使用和JPEG相关的参数ID进行组合使用。

可以使用的参数Id可以参考cv::ImwriteFlags。

cv::ImwriteFlags是一个枚举类型,用于指定图像写入时的压缩和质量选项。它包含了以下几个成员:

cv::IMWRITE_JPEG_QUALITY:设置JPEG图像的质量,范围为0到100,数值越高质量越好,但文件大小也会相应增加。
cv::IMWRITE_PNG_COMPRESSION:设置PNG图像的压缩级别,范围为0(无压缩)到9(最大压缩),数值越小压缩率越高,但文件大小也会相应增加。
cv::IMWRITE_PXM_BINARY:将PXM图像保存为二进制格式,不进行任何压缩。
cv::IMWRITE_PXM_FORMAT:设置PXM图像的格式,可以是ASCII或二进制。
cv::IMWRITE_UNCHANGED:如果图像已经是原始格式(如BGR),则不进行任何转换。
cv::IMWRITE_ANYDEPTH:如果图像具有不同的深度(例如,一个是8位深度,另一个是16位深度),则将其视为具有相同深度的图像。
cv::IMWRITE_ANY_COLOR:如果图像具有不同的颜色空间(例如,一个是BGR,另一个是HSV),则将其视为具有相同颜色空间的图像。
cv::IMWRITE_ANY_MASK:如果图像具有不同的掩码(例如,一个是3通道,另一个是4通道),则将其视为具有相同掩码的图像。
cv::IMWRITE_ANY_DEPTH:如果图像具有不同的深度(例如,一个是8位深度,另一个是16位深度),则将其视为具有相同深度的图像。
cv::IMWRITE_ANY_INTERPOLATION:如果图像具有不同的插值方法(例如,一个是线性插值,另一个是双线性插值),则将其视为具有相同插值方法的图像。
cv::IMWRITE_ANY_BILINEAR:如果图像具有不同的双线性插值方法(例如,一个是普通双线性插值,另一个是超级双线性插值),则将其视为具有相同双线性插值方法的图像。
cv::IMWRITE_ANY_HALF:如果图像具有不同的半精度浮点数表示方法(例如,一个是16位浮点数,另一个是32位浮点数),则将其视为具有相同半精度浮点数表示方法的图像。
cv::IMWRITE_ANY_VECTOR:如果图像具有不同的向量表示方法(例如,一个是整数向量,另一个是浮点向量),则将其视为具有相同向量表示方法的图像。
cv::IMWRITE_ANY_RGB:如果图像具有不同的RGB分量顺序(例如,一个是BGR,另一个是RGB),则将其视为具有相同RGB分量顺序的图像。
cv::IMWRITE_ANY_STREAM:如果图像具有不同的数据流格式(例如,一个是内存流,另一个是文件流),则将其视为具有相同数据流格式的图像。

三、函数使用的场景

保存图像到本地文件系统

使用 imwrite() 函数可以将处理后的图像数据保存到本地文件系统中。例如,可以使用 imwrite() 函数将一张 JPG 或 PNG 格式的图片保存到本地文件系统中:

Mat image = ...; // 处理后的图像数据
string filename = "test.jpg"; // 要保存的文件名
imwrite(filename, image); // 将图像数据保存到本地文件系统中

保存图像时通过params设置来控制图像质量

下是一些使用OpenCV的imwrite函数的params参数的案例:

保存为JPEG格式的图片,质量为90(默认值为75):

std::vector<int> params = {cv::IMWRITE_JPEG_QUALITY, 90};
cv::imwrite("image.jpg", image, params);

保存为PNG格式的图片,压缩级别为6(默认值为-1):

std::vector<int> params = {cv::IMWRITE_PNG_COMPRESSION, 6};
cv::imwrite("image.png", image, params);

保存图像到内存缓冲区

有时候,需要将图像数据保存到内存缓冲区中进行进一步处理。这时,可以使用 imencode() 函数将图像数据编码为字节流,然后再使用 imdecode() 函数将字节流解码为 Mat 对象:

vector<uchar> buffer; // 存储图像数据的缓冲区
Mat image = ...; // 处理后的图像数据
imencode(".jpg", image, buffer); // 将图像数据编码为字节流
imdecode(buffer, IMREAD_COLOR); // 将字节流解码为 Mat 对象

四、完整代码实例

下面是一个完整的代码示例,演示了如何使用 imwrite() 函数将处理后的图像数据保存到本地文件系统中:

#include <opencv2/opencv.hpp>
using namespace cv;

int main() {
    Mat image = imread("test.jpg"); // 读取本地文件中的图像数据
    if (image.empty()) {
        cout << "Failed to open image file!" << endl;
        return -1;
    }

    string filename = "output.jpg"; // 要保存的文件名
    bool result = imwrite(filename, image); // 将图像数据保存到本地文件系统中
    if (result) {
        cout << "Image saved successfully!" << endl;
    } else {
        cout << "Failed to save image!" << endl;
    }

    return 0;
}

五、总结

通过本文的介绍,我们了解了 OpenCV 中的 imwrite() 函数的基本用法和应用场景。该函数可以帮助我们方便地将处理后的图像数据保存到本地文件系统中,或者将其保存到内存缓冲区中进行进一步处理。在实际开发中,我们可以根据具体需求灵活运用该函数,提高开发效率。文章来源地址https://www.toymoban.com/news/detail-764532.html

到了这里,关于[C++] opencv - imwrite函数介绍和使用场景的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • [C++] opencv - approxPolyDP(多边形拟合)函数介绍和使用场景

    OpenCV中的 approxPolyDP() 函数用于对形状进行逼近,以减少多边形的顶点数,可以用于对图像轮廓点进行多边形拟合。 函数原型如下: 其中, curve 是输入的点集,类型为 InputArray, 可以是 Mat 、 vectorPoint 等; approxCurve是输出的点集,类型为 OutputArray, 也是 Mat 类型; epsilon 是精

    2024年03月14日
    浏览(43)
  • [C++] opencv - fillPoly(填充多边形)函数介绍和使用场景

    fillPoly() 函数是OpenCV中用于绘制填充多边形的函数。函数原型如下: fillPoly() 函数适用于需要绘制填充多边形的场景,例如在图像上绘制一个封闭的图形、制作一个简单的遮罩等。   fillPoly() 函数是OpenCV中用于绘制填充多边形的函数。可以用来绘制实心三角形,实心矩形,实

    2024年02月19日
    浏览(33)
  • python-opencv第二期:imwrite函数详解

    概要:众 嗦粥之 所周知,在如今计算机视觉( Computer Version  short for CV)是人工智能与机器人技术发展的一个重大研究方向,而 opencv 作为一个专门为计算机视觉编程提供技术与函数支持的第三方库,自然是一个需要重点研究的内容。本文就将介绍其中一个较为基础的函数—

    2024年02月02日
    浏览(28)
  • OpenCV第 1 课 计算机视觉和 OpenCV 介绍

      我们人类可以通过眼睛看到五颜六色的世界,是因为人眼的视觉细胞中存在分别对红、绿、蓝敏感的 3 种细胞。其中的光感色素根据光线的不同进行不同比例的分解,从而让我们识别到各种颜色。   对人工智能而言,学会“ 看 ”也是非常关键的一步。那么机器人是如

    2024年01月24日
    浏览(36)
  • 【C++】OpenCV:计算机视觉库介绍及C++环境配置

    OpenCV 是一个跨平台计算机视觉和机器学习软件库,可以运行在Linux、Windows、Android和Mac OS操作系统上。 OpenCV 是用C++语言编写的,同时留有C ++(工程部署用)、Python(深度学习用)、Java和MATLAB(Matlab好多例子都调用的opencv)接口,为了学习(juan)和部署视觉类的应用,记录一

    2024年01月19日
    浏览(40)
  • 计算机视觉的应用26-关于Fast-R-CNN模型的应用场景,Fast-R-CNN模型结构介绍

    大家好,我是微学AI,今天给大家介绍一下计算机视觉的应用26-关于Fast-R-CNN模型的应用场景,Fast-R-CNN模型结构介绍。Fast R-CNN是一种深度学习模型,主要用于目标检测任务,尤其适用于图像中物体的识别与定位。该模型在基于区域的卷积神经网络(R-CNN)系列中具有重要地位,

    2024年04月16日
    浏览(50)
  • 【OpenCV】关于OpenCV中imread/imwrite/imshow/cvtColor等 Api的简单描述和使用

    01、imread 官方定义 imread函数是OpenCV中的一个函数,用于从文件中读取图像。该函数支持读取多种图像格式,包括BMP、JPEG、PNG、TIF等常见格式。 tips: 注意这里imread函数加载的是8bit 图像 示例 02、imwrite 官方定义 imwrite函数是OpenCV中的一个函数,用于将图像写入文件中。该函数支

    2024年02月11日
    浏览(26)
  • 【计算机视觉 · OpenCV】使用 OpenCV 调用手机摄像头

    Droidcam 是一款可以将手机变成网络摄像头的工具,我们可以利用 Droidcam 让 OpenCV 拥有调用手机摄像头的能力。 2.1 安装 DroidCam 在手机和电脑上分别安装 DroidCam 的客户端和服务端 下载地址:https://pan.baidu.com/s/1DrBn3P1Bx-SXa4d6oziifA?pwd=gr1o 提取码:gr1o 2.2 测试连接状态 手机和电脑需

    2024年02月09日
    浏览(33)
  • 计算机视觉:使用opencv实现车牌识别

    汽车车牌识别(License Plate Recognition)是一个日常生活中的普遍应用,特别是在智能交通系统中,汽车牌照识别发挥了巨大的作用。汽车牌照的自动识别技术是把处理图像的方法与计算机的软件技术相连接在一起,以准确识别出车牌牌照的字符为目的,将识别出的数据传送至交

    2024年02月04日
    浏览(32)
  • 计算机视觉:使用opencv实现银行卡号识别

    OpenCV是Open Source Computer Vision Library(开源计算机视觉库)的简称,由Intel公司在1999年提出建立,现在由Willow Garage提供运行支持,它是一个高度开源发行的计算机视觉库,可以实现Windows、Linux、Mac等多平台的跨平台操作。opencv是一个用于图像处理、分析、机器视觉方面的开源函

    2024年02月05日
    浏览(35)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包