OpenCV-如何提取出图片ROI区域

    根据项目需要,提取视频中的ROI区域进行处理,对于无关区域可以屏蔽掉。主要原理是把原始帧中的ROI定位(如帧差法、背景减除法找出轮廓矩形)后复制到一个黑色背景中,再进行后续预处理。

    这里只是以图片为例,简述下原理,代码如下:

#include<iostream>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>

using namespace cv;
using namespace std;

bool ROI_AddImage();

int main()
{
	system("color 3F");

	if (ROI_AddImage())
	{
		cout << endl << "OK! Success!";
	}

	while (1)
	{
		if (waitKey(100) == 27)
			break;
	}
}

bool ROI_AddImage()
{

	//【1】读入图像
	Mat srcImage = imread("srcimage.jpg");
	Mat backGround = Mat::zeros(srcImage.size(),CV_8UC3);
	imshow("srcImage", srcImage);

	vector<Rect> rectROI;
	Rect rect1(0, 0, 50, 50);
	Rect rect2(70, 80, 30, 50);
	Rect rect3(200, 180, 40, 60);

	Mat ROI1 = srcImage(rect1);
	Mat ROI2 = srcImage(rect2);
	Mat ROI3 = srcImage(rect3);

	rectROI.push_back(rect1);
	rectROI.push_back(rect2);
	rectROI.push_back(rect3);

	for(int i = 0; i < rectROI.size(); i++)
	{
		srcImage(rectROI[i]).copyTo(backGround(rectROI[i]));
	}

	imshow("利用ROI实现图像叠加", backGround);

	return 0;
}

原图如下:

图1 原图"srcimage"

运行结果如下:

运行结果中的3个ROI区域是用Rect类手动标注的,重点是.copyTo()在运行时要求前后区域大小一致。

 

  • 0
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值