OpenCV之截图工具的实现

OpenCV之截图工具的实现

一、通过鼠标事件进行截图工具的实现

#include<opencv2/opencv.hpp>
#include<iostream>
using namespace std;
using namespace cv;

Mat srcImage;
Rect roirect;
Point startPoint;
Point endPoint;
void MouseEvent(int event, int x, int y, int flags, void*)
{
	//if (event == CV_EVENT_LBUTTONUP||!(flags&CV_EVENT_FLAG_LBUTTON))
	//{
	//	startPoint = Point(-1,-1);
	//}
	if (event == CV_EVENT_LBUTTONDOWN)
	{
		startPoint = Point(x, y);
	}
	else if (event==CV_EVENT_MOUSEMOVE && (flags&CV_EVENT_FLAG_LBUTTON))
	{
		endPoint=Point(x,y);
		Mat tempImage = srcImage.clone();
		//rectangle(src,原点,终点,linecolor,linewidth,linetype,0);
		//rectangle(src,Rect(原点,width,height),linecolor,linewidth,linetype,0);
		rectangle(tempImage,startPoint,endPoint,Scalar(255,0,0),2,8,0);  
		//rectangle(srcImage, startPoint, endPoint, Scalar(255, 0, 0), 2, 8, 0);
		imshow("srcImage",tempImage);
	}
	roirect.width = abs(endPoint.x - startPoint.x);
	roirect.height = abs(endPoint.y - startPoint.y);
	if (roirect.width > 0 && roirect.height > 0)
	{
		roirect.x = min(startPoint.x, endPoint.x);
		roirect.y = min(startPoint.y, endPoint.y);
		Mat roiMat = srcImage(Rect(roirect.x, roirect.y, roirect.width, roirect.height));
		imshow("ROI", roiMat);
		imwrite("E:/Images/nine1.png", roiMat);
	}
}
int main()
{
	srcImage = imread("E:/Images/nine.png");
	//resize(srcImage, srcImage, Size(), 0.25, 0.25);
	if (!srcImage.data)
		return -1;
	namedWindow("srcImage");
	imshow("srcImage", srcImage);
	setMouseCallback("srcImage",MouseEvent,0);
	waitKey(0);
	return 0;
}

这是单纯的单次截图实现
下面可以实现多次的截图实现

二、通过OpenCV中tracking模块中带的selectROI()API进行截图的实现

/**********截图工具selectROI ******************/
#include<opencv2/opencv.hpp>
#include<opencv2/photo.hpp>
#include<opencv2/objdetect.hpp>
#include<opencv2/xfeatures2d.hpp>
#include<opencv2/features2d.hpp>
#include<opencv2/calib3d/calib3d.hpp>
#include<opencv2/stitching.hpp>
#include<opencv2/video.hpp>
#include<opencv2/bgsegm.hpp>
#include<opencv2/tracking.hpp>
#include<opencv2/imgproc/imgproc.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<opencv2/core/utility.hpp>
#include<cstring>
#include<iostream>
#include<fstream>

using namespace std;
using namespace cv;
using namespace cv::xfeatures2d;
int main()
{
	Mat Image = imread("E:/Images/ten.jpg");
	if (Image.empty())
		return -1;
	imshow("Image", Image);
	char windowname[100];
	Rect2d rect = selectROI("Image",Image,false,false);   //单次区域截图
	Mat Im = Image(rect);
	imshow("Im", Im);
	//vector<Rect2d> rect1;
	//selectROI("picture", Image, rect1, false);    //多次区域截图 ENTER表完成 ESC表退出显示所有截的图
	//vector<Rect2d> obj;
	//for (int i = 0; i < rect1.size(); i++)
	//{
	//	sprintf(windowname, "%d.jpg", i);    
	//	obj.push_back(rect1[i]);
	//	Mat Im = Image(rect1[i]);
	//	imshow(windowname, Im);
	//}
	waitKey(0);
	return 0;
}

最后运行结果都为
在这里插入图片描述

注:多次截图需要截取一次按一次enter键

欢迎指正批评!!!

欢迎关注微信公众号–木木夕算法笔记,与博主交流!
公众号会时不时更新有趣的图像算法哦!!!

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值