openCV图像读取和显示

简介: openCV图像读取和显示
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace std;
using namespace cv;
int main(int argc,char** argv)
{
  cv::Mat img = imread("./sun.png"); //3通道 24位
  if (img.empty()) {
  std::cout << "could not load image!\n" << endl;
  return -1;
  }
  namedWindow("input",WINDOW_FREERATIO);
  imshow("input",img);
  std::cout << "load image!\n" << endl;
  //0 阻塞 1停顿一毫秒
  waitKey(0);
  destroyAllWindows();
  return 0;
}

运行

一、imread

imread是OpenCV图像处理库中的一个函数,用于从文件中读取图像数据并将其存储为一个Mat对象

cv::Mat cv::imread(
    const String& filename,    // 文件路径
    int flags = IMREAD_COLOR   // 图像读取标志,默认为彩色图像
);

其中,参数filename指定了要读取的图像文件的路径和文件名;参数flags指定了读取图像时的标志,它是一个可选参数,默认值为IMREAD_COLOR,表示读取彩色图像。

imread函数支持读取多种图像格式的文件,包括PNG、JPEG、BMP、GIF、TIFF等。读取的图像数据存储在一个Mat对象中,可以通过Mat对象的成员函数来访问和操作图像数据。

需要注意的是,如果指定的文件不存在或格式不正确,imread函数会返回一个空的Mat对象。因此,在调用imread函数之后,需要检查返回值是否为空,以确保图像已经正确读取。

imread函数的flags参数用于指定图像的读取方式,它是一个可选参数,如果不指定则默认为IMREAD_COLOR,即读取彩色图像。flags参数可以取以下几个值之一:

  • IMREAD_UNCHANGED:读取原始图像,包括图像的alpha通道(如果存在的话),并将其存储在Mat对象中。
  • IMREAD_GRAYSCALE:以灰度模式读取图像,将图像转换为单通道灰度图像,并将其存储在Mat对象中。
  • IMREAD_COLOR:读取彩色图像,将图像转换为三通道BGR格式,并将其存储在Mat对象中。
  • IMREAD_ANYDEPTH:读取图像的像素深度为16位或32位的图像,将其存储在Mat对象中。
  • IMREAD_ANYCOLOR:读取图像的颜色格式为任意格式的图像,将其存储在Mat对象中。
  • IMREAD_REDUCED_GRAYSCALE_2:以降采样的灰度模式读取图像,将图像转换为单通道灰度图像,并将其存储在Mat对象中,图像大小减半。
  • IMREAD_REDUCED_GRAYSCALE_4:以降采样的灰度模式读取图像,将图像转换为单通道灰度图像,并将其存储在Mat对象中,图像大小缩小为原来的四分之一。
  • IMREAD_REDUCED_GRAYSCALE_8:以降采样的灰度模式读取图像,将图像转换为单通道灰度图像,并将其存储在Mat对象中,图像大小缩小为原来的八分之一。
    需要注意的是,IMREAD_ANYDEPTH和IMREAD_ANYCOLOR两个标志不能单独使用,必须与其他标志一起使用。同时,降采样的灰度模式只适用于灰度图像,对于彩色图像则无效。

二、namedWindow

namedWindow是OpenCV图像处理库中的一个函数,用于创建一个窗口对象,以便后续在该窗口中显示图像或执行其他操作。

void namedWindow(
    const String& winname,  // 窗口名称
    int flags = WINDOW_AUTOSIZE  // 窗口属性,默认为自适应大小
);

其中,参数winname指定了创建的窗口的名称,可以是任意字符串;参数flags指定了创建的窗口的属性,它是一个可选参数,默认值为WINDOW_AUTOSIZE,表示创建一个自适应大小的窗口,即窗口的大小会自动调整以适应要显示的图像的大小。如果将flags设置为WINDOW_FREERATIO,则创建的窗口可以手动调整大小,即可以通过鼠标拖动窗口边框来改变窗口大小,并且图像的宽高比会保持不变。

namedWindow函数的flags参数用于指定创建的窗口的属性,它是一个可选参数,如果不指定则默认为WINDOW_AUTOSIZE,即创建一个自适应大小的窗口。flags参数可以取以下几个值之一:

  • WINDOW_NORMAL:创建一个手动调整大小的窗口,可以通过鼠标拖动窗口边框来改变窗口大小,并且图像的宽高比会保持不变。
  • WINDOW_AUTOSIZE:创建一个自适应大小的窗口,即窗口的大小会自动调整以适应要显示的图像的大小。
  • WINDOW_FREERATIO:创建一个手动调整大小的窗口,可以通过鼠标拖动窗口边框来改变窗口大小,并且图像的宽高比也可以随意改变。
    需要注意的是,WINDOW_NORMAL和WINDOW_FREERATIO两个标志不能同时使用,只能选择其中一个。

三、imshow

imshow是OpenCV图像处理库中的一个函数,用于在指定的窗口中显示图像。

void imshow(
    const String& winname,  // 窗口名称
    InputArray mat  // 要显示的图像
);

其中,参数winname指定了要在哪个窗口中显示图像,它必须与之前使用namedWindow函数创建的窗口名称相同;参数mat是要显示的图像,它可以是Mat、UMat、MatExpr等类型的对象。


推荐一个零声学院项目课,个人觉得老师讲得不错,分享给大家:

零声白金学习卡(含基础架构/高性能存储/golang云原生/音视频/Linux内核)

https://xxetb.xet.tech/s/VsFMs


相关文章
|
28天前
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
264 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
2月前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
46 4
|
2月前
|
存储 计算机视觉
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
本文介绍了使用OpenCV进行图像读取、显示和存储的基本操作,以及如何绘制直线、圆形、矩形和文本等几何图形的方法。
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
|
3月前
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
WK
|
3月前
|
编解码 计算机视觉 Python
如何在OpenCV中进行图像转换
在OpenCV中,图像转换涉及颜色空间变换、大小调整及类型转换等操作。常用函数如`cvtColor`可实现BGR到RGB、灰度图或HSV的转换;`resize`则用于调整图像分辨率。此外,通过`astype`或`convertScaleAbs`可改变图像数据类型。对于复杂的几何变换,如仿射或透视变换,则可利用`warpAffine`和`warpPerspective`函数实现。这些技术为图像处理提供了强大的工具。
WK
104 1
|
5月前
|
算法 计算机视觉
【Qt&OpenCV 图像的感兴趣区域ROI】
【Qt&OpenCV 图像的感兴趣区域ROI】
153 1
|
5月前
|
运维 算法 计算机视觉
【Qt&OpenCV 图像的模板匹配 matchTemplate/minMaxLoc】
【Qt&OpenCV 图像的模板匹配 matchTemplate/minMaxLoc】
74 1
|
5月前
|
存储 编解码 算法
【Qt&OpenCV 检测图像中的线/圆/轮廓 HoughLinesP/HoughCircles/findContours&drawContours】
【Qt&OpenCV 检测图像中的线/圆/轮廓 HoughLinesP/HoughCircles/findContours&drawContours】
86 0
|
4月前
|
机器学习/深度学习 XML 计算机视觉
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
|
5月前
|
计算机视觉
OpenCV中图像算术操作与逻辑操作
OpenCV中图像算术操作与逻辑操作
65 1