C++下OpenCV学习笔记
----图像叠加与混合
一.感兴趣区域:ROI
- 定义方法
(1)Rect定义法
Mat imageRoi;
imageRoi = image(Rect(500, 250, image.cols, image.rows));
(2)Range定义法
Mat imageRoi;
imageRoi = image(Range(250, 250 + image.rows), Range(200, 200 + image.cols));
- 掩膜(mask)与感兴趣区域(ROI)
(1)定义
用预先制作的感兴趣区域掩膜与待处理图像相乘,得到感兴趣区域图像,感兴趣区域内图像值保持不变,而区外图像值都为0。
(2)代码实现
#include<opencv2/opencv.hpp>
using namespace cv;
int main()
{
Mat srcImage1 = imread("C://Users//441//Desktop//ZL//夏目//1.jpg");
Mat srcImage2 = imread("C://Users//441//Desktop//ZL//夏目//th(2).jpg");
Mat imageRoi = srcImage1(Rect(0, 277, srcImage2.cols, srcImage2.rows));
Mat mask = imread("C://Users//441//Desktop//ZL//夏目//th(2).jpg", 0);
srcImage2.copyTo(imageRoi, mask);
namedWindow("ROI图像叠加");
imshow("ROI图像叠加", srcImage1);
waitKey(0);
}
srcImage1的尺寸为820x461;
srcImage2的尺寸为252x184.
(3)运行结果
二.线性混合操作
- 原理
G(x) = (1 - a)F(x) + aQ(x)
>>a的取值范围为0到1之间
>>F(x)和Q(x)为参与混合的两幅图像,G(x)表示输出图像
>>通过对两幅图像的每个像素值做线性加权得到最终的输出图像
>>两幅图像的大小和类型必须完全一致
- 实现
主要运用addWeighted函数实现。
三.计算数组的加权和:addWeighted函数
---->初识addWeighted函数
- 原理
void addWeighted(InputArray src1,double alpha,InputArray src2,double beta,double gamma,OutputArray dst,int dytpe=-1);
addWeighted函数计算两个数组(src1和src2)的加权和:
dst = src1[I] * alpha + src[2] * beta + gamma;
>>I为多维数组的索引值
>>当输出数组深度为CV_32S时,函数不适用,内存溢出或结果错误。
- 当两幅图片尺寸不同时的叠加
(1)代码实现
#include <opencv2/opencv.hpp>
using namespace cv;
int main()
{
Mat src1 = imread("C:\\Users\\441\\Desktop\\ZL\\夏目\\1.jpg");
Mat src2 = imread("C:\\Users\\441\\Desktop\\ZL\\夏目\\th(2).jpg");
Mat dst;

本文详细介绍了在C++下使用OpenCV进行图像处理的一些关键操作,包括定义感兴趣区域ROI、线性混合图像、使用addWeighted函数计算数组加权和、分离与合并颜色通道以及调整图像的亮度和对比度。通过实例代码展示了如何实现这些功能,帮助读者深入理解OpenCV图像处理的基本技巧。

2308

被折叠的 条评论
为什么被折叠?



