OpenCV之加载、修改、保存图像

简介: OpenCV之加载、修改、保存图像

加载图像(cv::imread)


imread功能是加载图像文件成为一个Mat对象,其中


  • 第一个参数表示图像文件名称


  • 第二个参数,表示加载的图像是什么类型,支持常见的三个参数值


IMREAD_UNCHANGED (<0) 表示加载原图,不做任何改变
IMREAD_GRAYSCALE ( 0)表示把原图作为灰度图像加载进来
IMREAD_COLOR (>0) 表示把原图作为RGB图像加载进来


注意:OpenCV支持JPG、PNG、TIFF等常见格式图像文件加载


例如:读名为test2.jpg


// read image
Mat image = imread("test2.jpg");


修改图像(cv::cvtColor)


void cv::cvtColor(  
    cv::InputArray src, // 输入序列  
    cv::OutputArray dst, // 输出序列  
    int code, // 颜色映射码  
    int dstCn = 0 // 输出的通道数 (0='automatic')  
);  


详细参数可以参考这篇博文:


https://blog.csdn.net/xuwenwen_2013/article/details/78663379


代码案例:


int main()
{
  Mat src = imread("1.jpg", 1), dst;
  imshow("resoure", src);
  // 转为灰度图
  cvtColor(src, dst, CV_RGB2GRAY);
  imshow("效果图", dst);
  cvWaitKey();
  return 0;
}


保存图像(cv::imwrite)


bool imwrite(
  const string& filename, 
  InputArray img, 
  const vector<int>& params=vector<int>() 
)


  • 第一个参数 const String& filename表示需要写入的文件名,必须要加上后缀,比如“123.png”。


  • 第二个参数 InputArray img表示Mat类型的图像数据。


  • 第三个参数 const std::vector& params表示为特定格式保存的参数编码,它有一个默认值std::vector< int >(),所以一般情况下不用写。


案例


结果展示



代码


#include<iostream>
#include<string.h>
#include<math.h>
#include<vector>
#include<opencv2/opencv.hpp>
#include<opencv2/highgui.hpp>
#include <opencv2/highgui/highgui_c.h>
#/*include<highgui.h>*/
using namespace std;
using namespace cv;
int main(int argc, char** argv)
{
  // read image
  Mat image = imread("test2.jpg");
  // 对图像进行所有像素用 (255- 像素值)
  Mat invertImage;
  image.copyTo(invertImage);
  // 获取图像宽、高
  int channels = image.channels();
  int rows = image.rows;
  int cols = image.cols * channels;
  // isContinuous()函数,返回bool值,判断存储是否连续。
  if (image.isContinuous()) {
    cols *= rows;         
    rows = 1;
  }
  // 每个像素点的每个通道255取反
  uchar* p1;
  uchar* p2;
  for (int row = 0; row < rows; row++) {
    p1 = image.ptr<uchar>(row);// 获取像素指针
    p2 = invertImage.ptr<uchar>(row);
    for (int col = 0; col < cols; col++) {
      *p2 = 255 - *p1; // 取反
      p2++;
      p1++;
    }
  }
  // create windows
  namedWindow("My Test", CV_WINDOW_AUTOSIZE);
  namedWindow("My Invert Image", CV_WINDOW_AUTOSIZE);
  // display image
  imshow("My Test", image);
  imshow("My Invert Image", invertImage);
  // 关闭
  waitKey(0);
  destroyWindow("My Test");
  destroyWindow("My Invert Image");
  //保存图像到当前项目
  cv::imwrite("invertImage.jpg", invertImage);
  return 0;
}
相关文章
|
1月前
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
357 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
2月前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
51 4
|
2月前
|
存储 计算机视觉
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
本文介绍了使用OpenCV进行图像读取、显示和存储的基本操作,以及如何绘制直线、圆形、矩形和文本等几何图形的方法。
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
|
3月前
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
|
3月前
|
计算机视觉 索引
OpenCV读取视频失败<无可用信息,未为 opencv_world453.dll 加载任何符号> cv::VideoCapture
本文介绍了解决OpenCV读取视频失败的错误,指出问题通常由视频路径错误或摄像头索引错误导致,并提供了相应的解决方法。
OpenCV读取视频失败<无可用信息,未为 opencv_world453.dll 加载任何符号> cv::VideoCapture
WK
|
3月前
|
编解码 计算机视觉 Python
如何在OpenCV中进行图像转换
在OpenCV中,图像转换涉及颜色空间变换、大小调整及类型转换等操作。常用函数如`cvtColor`可实现BGR到RGB、灰度图或HSV的转换;`resize`则用于调整图像分辨率。此外,通过`astype`或`convertScaleAbs`可改变图像数据类型。对于复杂的几何变换,如仿射或透视变换,则可利用`warpAffine`和`warpPerspective`函数实现。这些技术为图像处理提供了强大的工具。
WK
111 1
|
5月前
|
算法 计算机视觉
【Qt&OpenCV 图像的感兴趣区域ROI】
【Qt&OpenCV 图像的感兴趣区域ROI】
178 1
|
4月前
|
机器学习/深度学习 XML 计算机视觉
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
|
5月前
|
运维 算法 计算机视觉
【Qt&OpenCV 图像的模板匹配 matchTemplate/minMaxLoc】
【Qt&OpenCV 图像的模板匹配 matchTemplate/minMaxLoc】
82 1
|
5月前
|
存储 编解码 算法
【Qt&OpenCV 检测图像中的线/圆/轮廓 HoughLinesP/HoughCircles/findContours&drawContours】
【Qt&OpenCV 检测图像中的线/圆/轮廓 HoughLinesP/HoughCircles/findContours&drawContours】
95 0
下一篇
无影云桌面