C++ 中利用 Opencv 得到不规则的ROI 区域(已知不规则区域)
因为需要,之前写了一个利用mask 得到不规则ROI 区域的程序。
现在需要修改,发现自己都看不懂是怎么做的了。。
所以把它整理下来。
首先利用 鼠标可以得到 你想要的不规则区域的 顶点信息。具体这里不再描述。
setMouseCallback("setROIParking_Image", on_MouseHandle, (void*)&SrcImage);
得到不规则区域的顶点之后之后,接下来生成mask.
具体程序如下
void Image::GetROImage()
{
Mat srcImage = imread(srcImageName);
for (int j = 0; j < ROInumber; j++)
{
Point root_points[1][4];
root_points[0][0] = DrawPoints[j*4];
root_points[0][1] = DrawPoints[j*4 + 1];
root_points[0][2] = DrawPoints[j*4 + 2];
root_points[0][3] = DrawPoints[j*4 + 3];
const Point* ppt[1] = { root_points[0] };
int npt[] = { 4 };
// polylines(srcImage, ppt, npt, 1, 1, Scalar(0, 0, 0), 1, 8, 0);
vector <Mat>mv;
cv::Mat mask_ann, dst,dst1,dst2;
srcImage.copyTo(mask_ann);
mask_ann.setTo(cv::Scalar::all(0));
fillPoly(mask_ann, ppt, npt, 1, Scalar(255, 255, 255));
split(mask_ann, mv);
srcImage.copyTo(dst, mv[0]);
vector<Point> rectPoints = {}; //得到rectangle 的角点
rectPoints.push_back(DrawPoints[j * 4]);
rectPoints.push_back(DrawPoints[j * 4 +1]);
rectPoints.push_back(DrawPoints[j * 4 +2]);
rectPoints.push_back(DrawPoints[j * 4 +3]);
Rect rec = boundingRect(Mat(rectPoints));
dst1 = dst(rec); //boundingRect(Mat(rectPoints)) //得到rectROImage
if (dst1.cols >= 160)
{
resize(dst1, dst2, Size(160, 120),0,0,3); //得到rectROImage_resize //降采样
}
else
{
resize(dst1, dst2, Size(160, 120),0,0,1);//放大
}
//默认为线性插值 INTER_NEAREST = 0(最近邻插值),
//INTER_LINEAR = 1(线性插值,默认值),
//INTER_CUBIC = 2(三次样条插值),INTER_AREA = 3(区域插值);INTER_LANCZOS4 = 4(Lanczos插值),
//INTER_MAX = 7, WARP_FILL_OUTLIERS = 8,
//降采样:3, 放大:2(效率不高,不推荐);1(效率高,推荐)
imwrite(ROImageNames[j], dst);
imwrite(rectROImageNames[j], dst1);
imwrite(rectROImageNames_resize[j], dst2);
imwrite(rectROImageNames_resize_[j], dst2);
}
}
我这里写的可能有些冗余,主要自己有点的也不是太懂,就根据自己的需要一点点添加得到自己想要的效果。
其中,DrawPoints里存储了不规则区域的顶点(我这里设定了是不规则四边形)。首先是 生成mask(我这里是mask_ann),
srcImage.copyTo(mask_ann);
mask_ann.setTo(cv::Scalar::all(0));
这一部分是生成和原图一样大小的mask 图像,然后将整个图像用黑色填充。
const Point* ppt[1] = { root_points[0] };
int npt[] = { 4 };
fillPoly(mask_ann, ppt, npt, 1, Scalar(255, 255, 255));
这一部分是在mask 图像中将不规则区域的部分用白色填充,参考:http://blog.csdn.net/billbliss/article/details/43968291 可以看一下效果
vector <Mat>mv;
split(mask_ann, mv);
srcImage.copyTo(dst, mv[0]);
我添加的这一部分代码,是跟通道分离有关,具体 也不是特别清楚。但是在我没有添加这一句时,最后得到的图像 有问题(会得到一个不规则ROI区域,但是不是自己想要的那一部分)。split 函数是将mask_ann的三个通道分别赋值给 mv . 因为这里的 mask_ann 是三通道的,而且三通道应该是一样的,我们后面利用mask得到想要的不规则区域时只用到的他的一个通道。mv[0] 即它的一个通道。
后面的
srcImage.copyTo(dst, mv[0]);
即得到想要的不规则区域。即除了不规则区域,其他区域全部为黑色。
Rect rec = boundingRect(Mat(rectPoints));
dst1 = dst(rec); //boundingRect(Mat(rectPoints)) //得到rectROImage
是我从上面得到的部分中进一步的裁剪,把多余的黑色去掉,提取出了以 ROI 区域为边界的的图片(规则四边形,周围区域用黑色填充,因为如果ROI区域太小,得到的图片中大部分都是黑色,所以进一步裁剪)。
因为我想得到最终 尺寸一样的图像,所以利用resize进行了 升降采样。
C++ 中利用 Opencv 得到不规则的ROI 区域(已知不规则区域)的更多相关文章
- MFC中利用Opencv与C++抓取摄像头进行人脸识别(Mat)
原文:http://blog.csdn.net/mr_curry/article/details/51098311 第一次写博客哈哈,有些小激动,还请各位大神多多包涵~ 最近的项目需要用到人脸识别,作 ...
- OpenCV - Android Studio 2.2 中利用CAMKE进行OpenCV的NDK开发
我在http://www.cnblogs.com/fx-blog/p/8206737.html一文中提到了如何在Android Studio中Java层导入OpenCV(包含opencv_contri ...
- 在OpenCV中利用鼠标绘制矩形和截取图像的矩形区域
这是两个相关的程序,前者是后者的基础.实际上前一个程序也是在前面博文的基础上做的修改,请参考<在OpenCV中利用鼠标绘制直线> .下面贴出代码. 程序之一,在OpenCV中利用鼠标绘制矩 ...
- 利用OpenCV检测图像中的长方形画布或纸张并提取图像内容
基于知乎上的一个答案.问题如下: 也就是在一张照片里,已知有个长方形的物体,但是经过了透视投影,已经不再是规则的长方形,那么如何提取这个图形里的内容呢?这是个很常见的场景,比如在博物馆里看到一幅很喜欢 ...
- 在MacOS和iOS系统中使用OpenCV
在MacOS和iOS系统中使用OpenCV 前言 OpenCV 是一个开源的跨平台计算机视觉库,实现了图像处理和计算机视觉方面的很多通用算法. 最近试着在 MacOS 和 iOS 上使用 OpenCV ...
- 如何利用OpenCV自带的级联分类器训练程序训练分类器
介绍 使用级联分类器工作包括两个阶段:训练和检测. 检测部分在OpenCVobjdetect 模块的文档中有介绍,在那个文档中给出了一些级联分类器的基本介绍.当前的指南描述了如何训练分类器:准备训练数 ...
- 如何在Android中使用OpenCV
如何在Android中使用OpenCV 2011-09-21 10:22:35 标签:Android 移动开发 JNI OpenCV NDK 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始 ...
- [转]在MacOS和iOS系统中使用OpenCV
OpenCV 是一个开源的跨平台计算机视觉库,实现了图像处理和计算机视觉方面的很多通用算法. 最近试着在MacOS和iOS上使用OpenCV,发现网上关于在MacOS和iOS上搭建OpenCV的资料很 ...
- opencv探索之路(十二):感兴趣区域ROI和logo添加技术
在图像处理领域,有一个非常重要的名词ROI. 什么是ROI? 它的英文全称是Region Of Interest,对应的中文解释就是感兴趣区域. 感兴趣区域,就是我们从图像中选择一个图像区域,这个区域 ...
随机推荐
- Mac系统如何显示隐藏文件?
显示全部文件 defaults write com.apple.finder AppleShowAllFiles -bool true osascript -e 'tell application & ...
- 为什么打开fiddler电脑就不能上网,关了就能正常打开了呢?
因为打开fiddler是它修改浏览器走代理服务器,关掉fiddler之后,代理服务器已经关闭了.但是,但是浏览器的代理模式还没改回来,就是说浏览器还要通过代理访问站点,然而代理服务器已经没有了.打开浏 ...
- gson格式化参数 对象转Map
前台传json到后台接收: String params = request.getParameters("paramtes"); Map<String, Map<St ...
- selenium IDE安装与使用
官网介绍: Selenium IDE是一个Firefox插件,它记录并回放用户与浏览器的交互.使用它来创建简单的脚本或者帮助进行探索性测试. 安装流程: 只支持用火狐浏览器安装,可以用火狐浏览器的应用 ...
- Fragment传参
1. 封装基类 /** * Created by chenhaibin * Time 18/1/20 * Email chenhaibin415@163.com * Description:封装代码的 ...
- php导出excel不使用科学计数法
在变量前后拼接上制表符 foreach($orderList as $k=>$v){ $orderList[$k]['pos_id'] = "\t".$v['pos_id'] ...
- unfortunately,*********** has stopped及卸载模拟器上的多余不用apk
虽然不知道是怎么了,但是项目进不去了,害的我一脸雾水,百度了下好像没什么人遇到过这问题,都没找到解决办法,那只好来个简单粗暴的,卸载重新安装apk ,希望有大神知道原因和其他方法的欢迎留言或者评价给出 ...
- Nginx入门基础(一)
Nginx介绍 Nginx 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP服务器. 官方测试Nginx能够支撑5万并发链接,并且cpu.内存等资源消耗却非常低,运行 ...
- 学生管理系统(javaweb版)
准备用javaweb 的技术做一个简单的学生管理系统 打算不用登陆的那种,直接进入管理界面. 完成增删改查的功能. 慢慢开始更新,先写那么多.
- IDEA 中tomcat日志位置
参考 https://blog.csdn.net/dela_/article/details/78555977 /home/dela/.IntelliJIdea2017.1/system/tomcat ...