opencv-视频处理--画感兴趣区域(ROI)

感兴趣区域的划分,在视频处理中有着重要应用,用OpenCV介绍两种,在视频中标注感兴趣区域的方法:

原视频:


-----------------------------------------------------------------------------------------------------------------------------------

第一种:暂停视频或者在视频流的第一帧中,画出感兴趣区域

#include<opencv2\core\core.hpp>
#include<opencv2\highgui\highgui.hpp>
#include<opencv2\imgproc\imgproc.hpp>
using namespace cv;
#include<iostream>
#include<vector>
using namespace std;
/*----定义鼠标事件--画矩形区域:作用当两个车灯----*/
//第一步:全局变量
bool drawing_box = false;
bool gotBox =  false;
Rect box;
Point downPoint;
/*
void mouseRectHandler(int event, int x, int y, int flags, void *param)
{
	switch (event)
	{
	case CV_EVENT_MOUSEMOVE:
		if (drawing_box)
		{
			box.width = x - box.x;
			box.height = y - box.y;
		}
		break;
	case CV_EVENT_LBUTTONDOWN:
		drawing_box = true;
		box = Rect(x, y, 0, 0);
		break;
	case CV_EVENT_LBUTTONUP:
		drawing_box = false;
		gotBox = true;
		if (box.width < 0)
		{
			box.x += box.width;
			box.width *= -1;
		}
		if( box.height < 0 )
		{
			box.y += box.height;
			box.height *= -1;
		}
		break;
	default:
		break;
	}
}
*/

void mouseRectHandler(int event, int x, int y, int flags, void *param)
{
	switch (event)
	{
	case CV_EVENT_MOUSEMOVE:
		if (drawing_box)
		{
			//鼠标的移动到downPoint的右下角
			if( x >=downPoint.x && y >= downPoint.y)
			{
				box.x = downPoint.x;
				box.y = downPoint.y;
				box.width = x - downPoint.x;
				box.height =  y -  downPoint.y;
			}
			//鼠标的移动到downPoint的右上角
			if( x >= downPoint.x && y <= downPoint.y)
			{
				box.x =  downPoint.x;
				box.y = y;
				box.width = x - downPoint.x;
				box.height = downPoint.y - y;
			}
			//鼠标的移动到downPoint的左上角
			if( x <= downPoint.x && y <= downPoint.y)
			{
				box.x = x;
				box.y = y;
				box.width = downPoint.x - x;
				box.height = downPoint.y - y;
			}
			//鼠标的移动到downPoint的左下角
			if( x <= downPoint.x && y >= downPoint.y)
			{
				box.x = x;
				box.y = downPoint.y;
				box.width = downPoint.x -x;
				box.height = y - downPoint.y;
			}
		}
		break;

	case CV_EVENT_LBUTTONDOWN:
		//按下鼠标,代表可以可以开始画矩形
		drawing_box = true;
		//记录起点
		downPoint = Point(x,y);
		break;

	case CV_EVENT_LBUTTONUP:

		//松开鼠标,代表结束画矩形
		drawing_box = false;
		gotBox = true;
		break;
	default:
		break;
	}
}

int main(int argc,char*argv[])
 {
     //读取视频
     VideoCapture video(argv[1]);  

     //判断视频是否打开
     if( !video.isOpened())
         return 0;  

     //视频中的第一帧
     Mat firstFrame;  

     Mat frame;  

     //读取视频的第一帧
     video>>frame;  

     //复制到firstFrame中
     frame.copyTo(firstFrame);  

     //register
     namedWindow("video",1);
     setMouseCallback("video",mouseRectHandler,NULL);  

     //画感兴趣区域
     while(!gotBox)
     {
         firstFrame.copyTo(frame);
         rectangle(frame,box,Scalar(255,0,0),2);//画出感兴趣区域
         imshow("video",frame);
         if(waitKey(50) == ‘q‘)//---------很重要
             break;
     }
     //remove callback
     setMouseCallback("video",NULL,NULL);  

     //视频继续
     for(;;)
     {
         //读取视频
		 video>>frame;
		  //判断是否有当前帧
		  if(!frame.data)
			  break;
		  //画出感兴趣区域
		  rectangle(frame,box,Scalar(255,255,0),2);
          imshow("video",frame);
          if(waitKey(33) == ‘q‘)
              break;
     }
     return 0;
 }

【结果显示】:

 

第二种情况:不影响视频播放的情况下,画出感兴趣区域

#include<opencv2\core\core.hpp>
#include<opencv2\highgui\highgui.hpp>
#include<opencv2\imgproc\imgproc.hpp>
using namespace cv;
#include<iostream>
#include<vector>
using namespace std;
/*----定义鼠标事件--画矩形区域:作用当两个车灯----*/
//第一步:全局变量
bool drawing_box = false;
bool gotBox =  false;
Rect box;
Point downPoint;
/*
void mouseRectHandler(int event, int x, int y, int flags, void *param)
{
	switch (event)
	{
	case CV_EVENT_MOUSEMOVE:
		if (drawing_box)
		{
			box.width = x - box.x;
			box.height = y - box.y;
		}
		break;
	case CV_EVENT_LBUTTONDOWN:
		drawing_box = true;
		box = Rect(x, y, 0, 0);
		break;
	case CV_EVENT_LBUTTONUP:
		drawing_box = false;
		gotBox = true;
		if (box.width < 0)
		{
			box.x += box.width;
			box.width *= -1;
		}
		if( box.height < 0 )
		{
			box.y += box.height;
			box.height *= -1;
		}
		break;
	default:
		break;
	}
}
*/

void mouseRectHandler(int event, int x, int y, int flags, void *param)
{
	switch (event)
	{
	case CV_EVENT_MOUSEMOVE:
		if (drawing_box)
		{
			//鼠标的移动到downPoint的右下角
			if( x >=downPoint.x && y >= downPoint.y)
			{
				box.x = downPoint.x;
				box.y = downPoint.y;
				box.width = x - downPoint.x;
				box.height =  y -  downPoint.y;
			}
			//鼠标的移动到downPoint的右上角
			if( x >= downPoint.x && y <= downPoint.y)
			{
				box.x =  downPoint.x;
				box.y = y;
				box.width = x - downPoint.x;
				box.height = downPoint.y - y;
			}
			//鼠标的移动到downPoint的左上角
			if( x <= downPoint.x && y <= downPoint.y)
			{
				box.x = x;
				box.y = y;
				box.width = downPoint.x - x;
				box.height = downPoint.y - y;
			}
			//鼠标的移动到downPoint的左下角
			if( x <= downPoint.x && y >= downPoint.y)
			{
				box.x = x;
				box.y = downPoint.y;
				box.width = downPoint.x -x;
				box.height = y - downPoint.y;
			}
		}
		break;

	case CV_EVENT_LBUTTONDOWN:
		//按下鼠标,代表可以可以开始画矩形
		drawing_box = true;
		//记录起点
		downPoint = Point(x,y);
		break;

	case CV_EVENT_LBUTTONUP:

		//松开鼠标,代表结束画矩形
		drawing_box = false;
		gotBox = true;
		break;
	default:
		break;
	}
}

int main(int argc,char*argv[])
 {
     //读取视频
     VideoCapture video(argv[1]);  

     //判断视频是否打开
     if( !video.isOpened())
         return 0;  

     //视频帧
     Mat frame;  

     //register
     namedWindow("video",1);
     setMouseCallback("video",mouseRectHandler,NULL);  

     //画感兴趣区域
    for(;;)
     {
         //读取视频的第一帧
		video>>frame;
		if(!frame.data)
			break;
		 rectangle(frame,box,Scalar(255,255,0),2);//画出感兴趣区域
         imshow("video",frame);
		 if(gotBox)
			 break;
         if(waitKey(50) == ‘q‘)//---------很重要
             break;
     }
     //remove callback
     setMouseCallback("video",NULL,NULL);  

     //视频继续
     for(;;)
     {
         //读取视频
		 video>>frame;
		  //判断是否有当前帧
		  if(!frame.data)
			  break;
		  //画出感兴趣区域
		  rectangle(frame,box,Scalar(0,255,0),2);
          imshow("video",frame);
          if(waitKey(33) == ‘q‘)
              break;
     }
     return 0;
 }

【结果】

  


至于上述两者的区别,试一下就会发现!


时间: 2024-10-13 03:29:47

opencv-视频处理--画感兴趣区域(ROI)的相关文章

【opencv入门之二】感兴趣区域ROI,线性混合addWeighted

参考网站: http://blog.csdn.net/poem_qianmo/article/details/20911629 1.感兴趣区域ROI //[2]定义一个Mat类型并给其设定ROI区域 Mat imageROI = srcImage1( Rect(200, 250, logoImage.cols, logoImage.rows )); //[3]加载掩摸(必须是灰度图) Mat mask = imread( "dota_logo.jpg", 0 ); //[4]将掩摸拷贝

OpenCV设置感兴趣区域ROI,对图像进行局部处理

今天终于将霍夫检测的源码用C++写出来了,八天时间遇到最多的问题还是数据结构不熟悉,有些问题不知道怎么问,不知道从何下手 写出来的检测直线基本符合要求,问题是如果在现实中检测铁轨的话,附近会有石子,测试中发现如果石子的数目少,则检测效果较好,如果石子多,那么石子构成的点将影响检测 现在想到的一种方法就是设置感兴趣区域,将石子的影响减少 源码如下: 1.Iplimage设置感兴趣区域 int main( int argc, char** argv ) { IplImage *img = cvLoa

opencv读写视频,对感兴趣区域进行裁剪

作为小码农,本人最近想对一段视频的某个区域进行处理,因此要将该段视频区域裁剪出来,搜搜网上,发现没有痕迹,是故自己琢磨一下,左右借鉴,编了如下代码,目标得以实现,希望对你有用. #include "stdafx.h" #include "opencv2/opencv.hpp" #include <iostream> #include <vector> using namespace std; using namespace cv; int m

感兴趣区域ROI

Mat srcImage1 = imread("dota_pa.jpg"); Mat logoImage = imread("dota_logo.jpg"); Mat imageROI = srcImage1(Rect(10, 10, logoImage.cols, logoImage.rows));//使用矩形界定 logoImage.copyTo(imageROI);//就改变了srcImage1数据矩阵中的内容

opencv图像及视频感兴趣区域设置

之前学过的简单绘图方法,例如矩形,椭圆等,今天试着在视频图像中用矩形标注感兴趣区域(ROI) <----图像篇----> #include "opencv2/core/core.hpp" #include "opencv2/imgproc/imgproc.hpp" #include "opencv2/highgui/highgui.hpp" #include <iostream> using namespace std;

OpenCV中感兴趣区域的选取与检测(一)

1.感兴趣区域的选取 感兴趣区域(Region of Interest, ROI)的选取,一般有两种情形:1)已知ROI在图像中的位置:2)ROI在图像中的位置未知. 1)第一种情形 很简单,根据ROI的坐标直接从原图抠出,不过前提是要知道其坐标,直接上例子吧. int getROI(Mat image, Rect rect) { Mat img=image.clone(); Mat roi; int cols=img.cols, rows=img.rows; //ROI越界,返回 if(col

【练习3.5】使用感兴趣区域(ROI)

2014-05-29 第三章 初探OpenCV 练习第5题: 题目:学习使用感兴趣区域(ROI).创建一个210*210的单通道图像并将其归0.在图中使用ROI和cvSet建立一个增长如金字塔状的数组,也就是:外部边界为0,下一个内部边界应该为20,在下一个内部边界为40,依此类推,直到最后内部值为200,所有边界应该为10个像素宽度.最后显示这个图形. 按照题目要求使用ROI和cvSet实现 #include "stdafx.h" #include "cv.h"

opencv中感兴趣区域以及mask的使用

在图像处理的过程中,我们时常需要对指定区域或目标进行操作,这个区域我们称之为感兴趣区域.在学习opencv的初级阶段,对于感兴趣区域的操作方法是必须要掌握的. 比如下图: 我们获取到一帧图像Img,它里面有两个目标,一个蓝色块和一个红色块,我们一般会经常碰到以下三种情况: (1)我们希望将Img中的蓝色目标提取出来并另存为一个图像: (2)我们希望将Img中不是蓝色目标的其他目标都隐藏起来,只显示蓝色目标,或只对蓝色目标的区域进行图像处理. (3)我们只希望对Img中红色目标区域进行处理. 我们

获取图片中感兴趣区域的信息(Matlab实现)

内容提要 如果一幅图中只有一小部分图像你感兴趣(你想研究的部分),那么截图工具就可以了,但是如果你想知道这个区域在原图像中的坐标位置呢? 这可是截图工具所办不到的,前段时间我就需要这个功能,于是将其用Matlab实现. 其实只要用到Matlab中的两个函数: 函数: imrect 函数: getPosition 如果要截取其中的部分图像,就离不开下面的函数: 函数: imcrop 代码实现 clc; clear; close all; %-----------------------------