OpenCV库分为多个模块:opencv_core模块包含库的核心功能,opencv_imgproc模块包含主要的图像处理函数,opencv_highgui模块提供了读写图像和视频的函数以及一些用户交互函数。
读取图像:
image=cv::imread("puppy.bmp");
if(image.empty()){
}
显示图像:
cv::nameWindow("Original Image");//定义窗口
cv::imshow("Original Image",image);
在OpenCV的C++API中,所有类和函数都在命名空间cv内定义。
回调函数:void onMouse(int event,int x,int y,int flags,void *param);
第一个参数是整数,表示触发回调函数的鼠标事件类型。后面两个参数是事件发生时鼠标的位置,用像素坐标表示。参数flag表示事件发生时按下了鼠标的哪个按键,最后一个参数指向任意对象的指针,作为附加的参数发送给函数。
cv::setMouseCallback("original image",onMOuse,reinterpret_cast<void*>(&image));
Mat
Mat有两个必不可少的组成部分:头部和数据块。头部包含了矩阵的所有相关信息(大小/通道数量/数据类型)。数据块包含了图像的所有像素值。头部有一个指向数据块的指针,即data属性。
1/创建图像方法
cv:: Mat image1(240,320, CV_8U,100);
cv::Mat image2(240,320,CV_8UC3,cv::Scalar(0,0,255));
2/可以随时用create方法分配或重新分配图像的数据块。如果图像已被分配,其原来的内容会被先释放。
image1.create(200,200,CV_8U);
一旦没有了指向Mat对象的引用,分配的内存就会被自动释放。两幅图像之间赋值,图像数据并不会被复制,此时两幅图像都指向同一个内存块。因此只有当图像的所有引用都被释放或赋值给另一幅图像时,内存才会被释放。
3/图像深度复制方法:
image.copyTo(image2);
或者 image5=image3.clone();
定义感兴趣区域ROI
1/如何定义
定义了ROI之后,就可以把ROI当成一个普通的Mat实例进行操作。
A:cv::Rect。imageROI(image,cv::Rect(image.cols-logo.cols,image.rows-logo.rows,logo.cols,logo.rows));
通过指明左上角的位置和矩阵的尺寸(后两个参数是尺寸,前两个是坐标)。
B:还可以通过cv::(cv::Range(image.rows-logo.rows,image.rows),cv::Range(image.cols-logo.cols,image.cols));
注意:图像和ROI共享了同一块图像数据,因此ROI的任何转变都会影响原始图像的相关区域。在定义ROI时,数据并没有复制,因此他的执行时间是固定的,不受ROI尺寸的影响。
C:要定义行组成的ROI:
cv::Mat imageROI=image.rowRange(start,end);
cv::image.colRange(start,end);
掩码
掩码是一个8位图像,如果掩码中某个位置的值不为0,在这个位置的操作就会起作用。
imageROI=image(cv::Rect(image.cols-logo.cols,jimage.rows-logo.rows,logo.cols,logo.rows));
Mat mask(logo);
logo.copyTo(imageROI,mask);