OpenCV可以从存储介质中读入图像,也可以将摄像头(Camera)抓取的图像载入内存,然后进行处理。而存储图像就是将内存中的图像数据写入存储介质中,如写入硬盘、优盘等。
OpenCV要读入图像、操作图像。首先要用到Mat类,并且需创建Mat对象。要用Camera抓取图像需用到VideoCapture 类,并构建VideoCapture对象。
从档案读入图像
读入图像 需用到imread()函数,其基于的原型如下:
Mat cv::imread(const String& filename, int flags = IMREAD_COLOR)
参数filename为需读入图像的完整名称,包含文件路径、文件名、及扩展名。扩展名必须是OpenCV支持的图像类型。OpenCV支持的图像类型如下:
参数 flags包含以下几种:
IMREAD_COLOR 为缺省值,读入图像时,将图像装换为3通道 BGR 色彩图像。
IMREAD_UNCHANGED 读入图像时按原样返回加载的图像(如果原图存在alpha通道,否则会被裁 剪)。忽略 EXIF方向。
IMREAD_GRAYSCALE 读入图像时,把图像转换为单通道的灰度图像。
IMREAD_ANYDEPTH 如果原图为16bit/32bit,读入时保留原图像深度,其余的转换为8bit。
IMREAD_ANYCOLOR 以任何可能的颜色格式读取图像。也就是保留原图像格式。
IMREAD_LOAD_GDAL 读入图像时, 使用gdal驱动程序加载图像。
IMREAD_REDUCED_GRAYSCALE_2 读入图像时,将图像转换为单通道灰度图像,图像大小减小1/2。
IMREAD_REDUCED_COLOR_2 读入图像时,将图像转换为3通道BGR色彩图像,并且图像大小减1/2。
IMREAD_REDUCED_GRAYSCALE_4 读入图像时,将图像转换为单通道灰度图像,图像大小减小1/4。
IMREAD_REDUCED_COLOR_4 读入图像时,将图像转换为3通道BGR色彩图像,并且图像大小减1/4。
IMREAD_REDUCED_GRAYSCALE_8 读入图像时,将图像转换为单通道灰度图像,图像大小减小1/8。
IMREAD_REDUCED_COLOR_8 读入图像时将图像转换为3通道BGR色彩图像,并且图像大小减1/8。
IMREAD_IGNORE_ORIENTATION 读入图像时,不会根据EXIF的方向标志旋转图像。
显示图像
要显示读入图像则需用到imshow()函数,imshow()函数的原型如下:
void cv::imshow(const String & winname, InputArray mat)
winname 为显示图像窗口的名称,如果输入的名称为一个建好的窗口,图像将显示在该窗口上,如果不存在输入名的窗口,则以输入名新建一个窗口,并将图像显示在该窗口上。
mat 为装载有欲显示图片的Mat对象。
存储图像
要存储图像需用到 imwrite()函数,imwrite()函数的原型如下:
bool cv::imwrite(const String & filename, InputArry img, const std::vector<int>& params = std::vector<int>())
参数filename 为存储到介质中的完整文件名,需包含存储路径、文件名、扩展名。扩展名必须是OpenCV支持的图像类型。
参数img为载有需存储图像的Mat对象。最后一个参数,通常保持缺省状态不予理会。
图像读入、显示、存储示例
下面以一个实例来演示OpenCV图像读入、显示、存储操作。
1. 新建一个VC2022控制台空项目,将需操作的图片Copy到该项目文件夹下(这里略去OpenCV4.8在VS2022中的配置操作介绍)。
2. 在解决方案源文件夹中添加新建项main.cpp
3. 在main.cpp中添加源代码,所加代码如下:
#include <iostream>
#include <opencv2/opencv.hpp>using namespace cv;
using namespace std;int main(int argc, char** argv)
{Mat src1 = imread("1.jpg", IMREAD_UNCHANGED);namedWindow("src1", WINDOW_AUTOSIZE);imshow("src1", src1);Mat src2 = imread("1.jpg", IMREAD_GRAYSCALE);namedWindow("src2", WINDOW_AUTOSIZE);imshow("src2", src2);Mat src3 = imread("1.jpg", IMREAD_COLOR);namedWindow("src3", WINDOW_AUTOSIZE);imshow("src3", src3);Mat src4 = imread("1.jpg", IMREAD_ANYDEPTH);namedWindow("src4", WINDOW_AUTOSIZE);imshow("src4 ", src4);Mat src5 = imread("1.jpg", IMREAD_ANYCOLOR);namedWindow("src5", WINDOW_AUTOSIZE);imshow("src5", src5);Mat src6 = imread("1.jpg", IMREAD_LOAD_GDAL);namedWindow("src6", WINDOW_AUTOSIZE);imshow("src6 ", src6);Mat src7 = imread("1.jpg", IMREAD_REDUCED_GRAYSCALE_2);namedWindow("src7", WINDOW_AUTOSIZE);imshow("src7", src7);Mat src8 = imread("1.jpg", IMREAD_REDUCED_COLOR_2);namedWindow("src8", WINDOW_AUTOSIZE);imshow("src8", src8);Mat src9 = imread("1.jpg", IMREAD_REDUCED_GRAYSCALE_4);namedWindow("src9", WINDOW_AUTOSIZE);imshow("src9", src9);Mat src10 = imread("1.jpg", IMREAD_REDUCED_COLOR_4);namedWindow("src10", WINDOW_AUTOSIZE);imshow("src10", src10);Mat src11 = imread("1.jpg", IMREAD_REDUCED_GRAYSCALE_8);namedWindow("src11", WINDOW_AUTOSIZE);imshow("src11", src11);Mat src12 = imread("1.jpg", IMREAD_REDUCED_COLOR_8);namedWindow("src12", WINDOW_AUTOSIZE);imshow("src12", src12);Mat src13 = imread("1.jpg", IMREAD_IGNORE_ORIENTATION);namedWindow("src13", WINDOW_AUTOSIZE);imshow("src13", src13);moveWindow("src1", 10, 50);moveWindow("src2", 10, src1.rows + 100);moveWindow("src3", src1.cols + 10, 50);moveWindow("src4", src1.cols + 10, src1.rows + 100);moveWindow("src5", src1.cols * 2 + 10, 50);moveWindow("src6", src1.cols * 2 + 10, src1.rows + 100);moveWindow("src7", src1.cols * 3 + 10, 50);moveWindow("src8", src1.cols * 3+ 10, src1.rows + 100);moveWindow("src9", src1.cols * 4 + 10, 50);moveWindow("src10", src1.cols * 4 + 10, src1.rows + 100);moveWindow("src11", src1.cols * 5 + 10, 50);moveWindow("src12", src1.cols * 5 + 10, src1.rows + 100);moveWindow("src13", src1.cols * 6 + 10, 50);imwrite("1.bmp", src2);waitKey(0); // wait till any key is pressedreturn 0;
}
4. 试运行 按ctrl+F5,结果如下:
打开项目文件夹,可以看到多出了一个1.bmp文件。
双击这个文件,用Win10照片打开。
结果如下:
是一张灰度图片说明存储正确。
从摄像头获取图像
将前面的部分代码注释掉,加入如下代码:
#include <iostream>
#include <opencv2/opencv.hpp>using namespace cv;
using namespace std;int main(int argc, char** argv)
{/*Mat src1 = imread("1.jpg", IMREAD_UNCHANGED);namedWindow("src1", WINDOW_AUTOSIZE);imshow("src1", src1);Mat src2 = imread("1.jpg", IMREAD_GRAYSCALE);namedWindow("src2", WINDOW_AUTOSIZE);imshow("src2", src2);Mat src3 = imread("1.jpg", IMREAD_COLOR);namedWindow("src3", WINDOW_AUTOSIZE);imshow("src3", src3);Mat src4 = imread("1.jpg", IMREAD_ANYDEPTH);namedWindow("src4", WINDOW_AUTOSIZE);imshow("src4 ", src4);Mat src5 = imread("1.jpg", IMREAD_ANYCOLOR);namedWindow("src5", WINDOW_AUTOSIZE);imshow("src5", src5);Mat src6 = imread("1.jpg", IMREAD_LOAD_GDAL);namedWindow("src6", WINDOW_AUTOSIZE);imshow("src6 ", src6);Mat src7 = imread("1.jpg", IMREAD_REDUCED_GRAYSCALE_2);namedWindow("src7", WINDOW_AUTOSIZE);imshow("src7", src7);Mat src8 = imread("1.jpg", IMREAD_REDUCED_COLOR_2);namedWindow("src8", WINDOW_AUTOSIZE);imshow("src8", src8);Mat src9 = imread("1.jpg", IMREAD_REDUCED_GRAYSCALE_4);namedWindow("src9", WINDOW_AUTOSIZE);imshow("src9", src9);Mat src10 = imread("1.jpg", IMREAD_REDUCED_COLOR_4);namedWindow("src10", WINDOW_AUTOSIZE);imshow("src10", src10);Mat src11 = imread("1.jpg", IMREAD_REDUCED_GRAYSCALE_8);namedWindow("src11", WINDOW_AUTOSIZE);imshow("src11", src11);Mat src12 = imread("1.jpg", IMREAD_REDUCED_COLOR_8);namedWindow("src12", WINDOW_AUTOSIZE);imshow("src12", src12);Mat src13 = imread("1.jpg", IMREAD_IGNORE_ORIENTATION);namedWindow("src13", WINDOW_AUTOSIZE);imshow("src13", src13);moveWindow("src1", 10, 50);moveWindow("src2", 10, src1.rows + 100);moveWindow("src3", src1.cols + 10, 50);moveWindow("src4", src1.cols + 10, src1.rows + 100);moveWindow("src5", src1.cols * 2 + 10, 50);moveWindow("src6", src1.cols * 2 + 10, src1.rows + 100);moveWindow("src7", src1.cols * 3 + 10, 50);moveWindow("src8", src1.cols * 3+ 10, src1.rows + 100);moveWindow("src9", src1.cols * 4 + 10, 50);moveWindow("src10", src1.cols * 4 + 10, src1.rows + 100);moveWindow("src11", src1.cols * 5 + 10, 50);moveWindow("src12", src1.cols * 5 + 10, src1.rows + 100);moveWindow("src13", src1.cols * 6 + 10, 50);imwrite("1.bmp", src2);*/VideoCapture cp;Mat frCamera;cp.open(0);if (!cp.isOpened())cout << "Camera Cann't be opened!" << endl;else{cp >> frCamera;imshow("Camera Image", frCamera);}waitKey(0); // wait till any key is pressedreturn 0;
}
试运行 按Ctrl+F5结果如下:
可以看出,摄像头抓取的图片已传入Mat对象,并显示在窗口中。