opencv从零开始——2. ROI与线性融合
2017-04-23 18:42
288 查看
1.感兴趣的区域:ROI
ROI : 感兴趣的区域(region of interest )代码如下:
#include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp> #include <iostream> using namespace cv; using namespace std; bool ROI_AddImage() { Mat srcImage1 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg"); Mat logoImage = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg"); if (!srcImage1.data) { return false; } if (!logoImage.data) { return false; } Mat imageROI = srcImage1(Rect(300, 300, logoImage.cols, logoImage.rows)); Mat mask = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg", 0); logoImage.copyTo(imageROI, mask); namedWindow("<1>利用ROI实现图像叠加示例窗口"); imshow("<1>利用ROI实现图像叠加示例窗口", srcImage1); Mat img = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg"); imshow("原图", img); waitKey(0); return true; } //"/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/v1.jpg" int main(int argc, char* argv[]) { ROI_AddImage(); return 0; }
效果如下,小猫吃鱼的图片,就是插入进去的:
2. 图像融合
【注意】需要两幅图像,尺寸一致,本次采用的尺寸: 550*405代码如下:
#include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp> #include <iostream> using namespace cv; using namespace std; bool ROI_AddImage() { Mat srcImage1 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg"); Mat logoImage = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg"); if (!srcImage1.data) { return false; } if (!logoImage.data) { return false; } Mat imageROI = srcImage1(Rect(300, 300, logoImage.cols, logoImage.rows)); Mat mask = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg", 0); logoImage.copyTo(imageROI, mask); namedWindow("<1>利用ROI实现图像叠加示例窗口"); imshow("<1>利用ROI实现图像叠加示例窗口", srcImage1); Mat img = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg"); imshow("原图", img); waitKey(0); return true; } bool LinearBlending() { double alphaValue = 0.5; double betaValue; Mat srcImage2, srcImage3, dstImage; //两幅图片,需要裁剪成相同的尺寸,本例采用尺寸: 550 * 405 srcImage2 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/kobe.jpg"); srcImage3 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/James.jpg"); if (!srcImage2.data || !srcImage3.data) { return false; } betaValue = 1.0 - alphaValue; addWeighted(srcImage2, alphaValue, srcImage3, betaValue, 0.0, dstImage); namedWindow("<3>线性混合示例窗口[效果图]", 1); imshow("<3>线性混合示例窗口[效果图]", dstImage); waitKey(0); return true; } //"/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/v1.jpg" int main(int argc, char* argv[]) { //ROI_AddImage(); LinearBlending(); return 0; }
原图如下:
效果图如下:
3. 对感兴趣的区域,融入一幅图像
代码如下:#include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp> #include <iostream> using namespace cv; using namespace std; bool ROI_AddImage() { Mat srcImage1 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg"); Mat logoImage = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg"); if (!srcImage1.data) { return false; } if (!logoImage.data) { return false; } Mat imageROI = srcImage1(Rect(300, 300, logoImage.cols, logoImage.rows)); Mat mask = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo3.jpg", 0); logoImage.copyTo(imageROI, mask); namedWindow("<1>利用ROI实现图像叠加示例窗口"); imshow("<1>利用ROI实现图像叠加示例窗口", srcImage1); Mat img = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg"); imshow("原图", img); waitKey(0); return true; } bool LinearBlending() { double alphaValue = 0.5; double betaValue; Mat srcImage2, srcImage3, dstImage; //两幅图片,需要裁剪成相同的尺寸,本例采用尺寸: 550 * 405 srcImage2 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/kobe.jpg"); srcImage3 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/James.jpg"); if (!srcImage2.data || !srcImage3.data) { return false; } betaValue = 1.0 - alphaValue; addWeighted(srcImage2, alphaValue, srcImage3, betaValue, 0.0, dstImage); namedWindow("<3>线性混合示例窗口[效果图]", 1); imshow("<3>线性混合示例窗口[效果图]", dstImage); waitKey(0); return true; } void ROI_AddImage_LinearBlending() { Mat srcImage1 = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg", 1); Mat logoImage = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/logo.jpg"); if (!srcImage1.data) { return; } if (!logoImage.data) { return; } Mat imageROI = srcImage1(Rect(20, 230, logoImage.cols, logoImage.rows)); addWeighted(imageROI, 0.5, logoImage, 0.3, 0. , imageROI); namedWindow("<4>利用ROI实现图像叠加示例窗口"); imshow("<4>利用ROI实现图像叠加示例窗口", srcImage1); Mat img = imread("/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/7.jpg"); imshow("原图", img); waitKey(0); } //"/mnt/hgfs/code_for_Linux/code_opencv/test1/pic/v1.jpg" int main(int argc, char* argv[]) { //ROI_AddImage(); //LinearBlending(); ROI_AddImage_LinearBlending(); return 0; }
效果图:
4.参考文献
[1] 毛星云 冷雪飞. OpenCV3编程入门[M]. 电子工业出版社, 2015.相关文章推荐
- opencv 线性图像融合
- OpenCV教程 之 基础操作:图像的读入、输出、访问、Mat类、色彩缩减与线性融合
- OpenCV学习笔记(四):ROI区域图像叠加和图像线性混合
- 基于OpenCV的图像线性融合
- Opencv 图片ROI与图片融合
- 【opencv练习09 - 图片线性加权融合】
- OpenCV 学习记录4 ROI区域图像叠加及线性图像混合
- opencv-输入两幅图像实现线性融合
- OpenCV学习七:线性融合函数addWeighted
- [转]Opencv 图片ROI与图片融合
- Python OpenCV 线性滤波器 简介(七)
- opencv:ROI
- 从零开始的C++ opencv的人脸识别程序——第一个C++程序
- opencv 设置任意形状的ROI的各种方法
- 使用OpenCV中的几种线性滤波器对图像平滑处理
- opencv中获取任意方向的ROI
- OpenCV中图像及子图像ROI之间的复制
- 关于opencv 图像融合addWeighted的使用方法
- Opencv图像线性滤波-滚动条
- Opencv 学习笔记之图像线性滤波综合示例