OpenCV轮廓vectorvector
OpenCV轮廓vectorvector,vector,vector,vector
轮廓周围绘制矩形框
vector<vector<Point>>,vector<V e c 4 i>,vector<R e c t>,vector<R o t a t e d R e c t>
刚开始学OpenCV没多久遇到这些个东西不知道是什么,搞得很不舒服。
通过给轮廓绘制矩形框弄明白了这些东西。
vector<vector<Point>>:
vector容器里面放了一个vector容器,子容器里放点
vector<V e c 4 i>:放了4维int向量
vector<R e ct>: 像素width * height from 位置(x*y)
vector<R o t a t e d R e c t>:如图三个成员
上述结果的代码如下:
- #include <opencv2/opencv.hpp>
- #include <iostream>
- using namespace cv;
- using namespace std;
- int main() {
- Mat src, gray_src, drawImg, bin_output;
- src = imread("F:/Temp_vs/pic/09.jpg");
- namedWindow("input", CV_WINDOW_AUTOSIZE);
- namedWindow("output", CV_WINDOW_AUTOSIZE);
- imshow("input", src);
- cvtColor(src, gray_src, CV_BGR2GRAY);
- blur(gray_src, gray_src, Size(10, 10), Point(-1, -1), BORDER_DEFAULT);
- //这些个类型
- vector<vector<Point>> contours;
- vector<Vec4i> hierarchy;
- threshold(gray_src, bin_output, 144, 255, 0); //二值化
- findContours(bin_output, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE, Point(0, 0)); //找轮廓
- //这些个类型
- vector<vector<Point>> contours_poly(contours.size());
- vector<Rect> poly_rects(contours.size());
- vector<RotatedRect> minRect(contours.size());
- //取点
- for (size_t i = 0; i < contours.size(); i++)
- {
- approxPolyDP(Mat(contours[i]), contours_poly[i], 3, true); //减少轮廓点数
- poly_rects[i]=boundingRect(contours_poly[i]);//获取绘制矩形数据
- if (contours_poly[i].size() > 5) {
- minRect[i] = minAreaRect(contours_poly[i]);//获取绘制旋转矩形数据
- }
- }
- //开始绘制
- src.copyTo(drawImg);
- Point2f pst[4];//储存单个旋转矩形的四个点
- cout << "----------Point2f pst[4]------------" << endl;
- for (size_t i = 0; i < contours.size(); i++)
- {
- rectangle(drawImg, poly_rects[i], Scalar(255, 0, 0), 2, 8);//绘制矩形框
- minRect[i].points(pst);//用线段画矩形,将RotatedRect类型转化为四个点
- for (size_t u = 0; u < 4; u++)
- {
- line(drawImg, pst[u], pst[(u + 1) % 4], Scalar(0, 255, 0), 2, 8);
- cout << pst[u]; //显示pst的数据
- }
- cout << endl;
- Rect brect = minRect[i].boundingRect(); //返回包含旋转矩形的最小矩形
- rectangle(drawImg, brect,Scalar(0, 0, 255));
- }
- cout << endl;
- imshow("output", drawImg);
- cout << "----------vector<vector<Point>> contours_poly------------" << endl;
- for (size_t i = 0; i < contours_poly.size(); i++)
- {
- cout << "第" << i << "行:";
- for (size_t j = 0; j < contours_poly[i].size(); j++)
- {
- cout<<contours_poly[i][j];
- }
- cout << endl;
- }
- cout << endl;
- cout << "----------vector<Vec4i> hierarchy------------" << endl;
- for (size_t i = 0; i < hierarchy.size(); i++)
- {
- cout << hierarchy[i] << endl;
- }
- cout << endl;
- cout << "----------vector<Rect> poly_rects------------" << endl;
- for (size_t i = 0; i < poly_rects.size(); i++)
- {
- cout << poly_rects[i]<<endl;
- }
- cout << endl;
- cout << "---------vector<RotatedRect> minRect------------" << endl;
- for (size_t i = 0; i <minRect.size(); i++) //显示一下点minRect
- {
- cout <<"angle:"<< minRect[i].angle<<" center:"<< minRect[i].center<<" size:"<< minRect[i].size<<endl;
- }
- cout << endl;
- waitKey(0);
- return 0;
- }
OpenCV轮廓vectorvector的更多相关文章
- OpenCV 轮廓基本特征
http://blog.csdn.net/tiemaxiaosu/article/details/51360499 OpenCV 轮廓基本特征 2016-05-10 10:26 556人阅读 评论( ...
- 【转载】openCV轮廓操作
声明:非原创,转载自互联网,有问题联系博主 1.轮廓的提取 从图片中将目标提取出来,常常用到的是提取目标的轮廓. OpenCV里提取目标轮廓的函数是findContours(), 它的输入图像是一幅二 ...
- OpenCV 轮廓检测
使用OpenCV可以对图像的轮廓进行检测.这是之前用过的代码,挺简单的,回顾一下.主要要进行以下2步操作: 1.cvThreshold():对图像进行二值化处理 2.cvFindContours(): ...
- OpenCV轮廓检测,计算物体旋转角度
效果还是有点问题的,希望大家共同探讨一下 // FindRotation-angle.cpp : 定义控制台应用程序的入口点. // // findContours.cpp : 定义控制台应用程序的入 ...
- Opencv轮廓计数(学习)
#include <iostream>#include <opencv2/opencv.hpp>#include <opencv2/xfeatures2d.hpp> ...
- OpenCV —— 轮廓
把检测出的边缘像素组装成轮廓 —— cvFindContours OpenCV 使用内存存储器来统一管理各种动态对象的内存.内存存储器在底层被实现为一个有许多相同大小的内存块组成的双向链表 内存储 ...
- opencv轮廓外接矩形
1.寻找轮廓 api void cv::findContours( InputOutputArray image, OutputArrayOfArrays contours, OutputArray ...
- opencv——轮廓发现与轮廓(二值图像)分析
引言 二值图像分析最常见的一个主要方式就是轮廓发现与轮廓分析,其中轮廓发现的目的是为轮廓分析做准备,经过轮廓分析我们可以得到轮廓各种有用的属性信息. 这里顺带提下边缘检测,和轮廓提取的区别: 边缘检测 ...
- opencv轮廓处理函数详细
ApproxChains 用多边形曲线逼近 Freeman 链 CvSeq* cvApproxChains( CvSeq* src_seq, CvMemStorage* storage, int me ...
随机推荐
- mac 管理员权限变成了普通权限处理方法
在更换账户名称的时候出了这个问题.设置的时候不会显示用户名,没有电脑的管理权限了,找到如下方法解决的,试了可行. http://blog.csdn.net/vickylizy/article/deta ...
- 24_ajax请求_使用axios
前置说明: 1.React本身只关注页面,并不包含发送ajax请求的代码 2.前端应用需要通过ajax请求与后台进行交互(json数据) 3.React应用中需要集成第三方ajax库(或自己进行封装) ...
- html 基础之a标签的属性target解析
学习前端,有很多标签其实有很多不同的功能,但是用到的不多,所以就没有发现:当发现的时候,觉得很不可思议,有耳目一新的感觉.例如a 标签,之前只是知道,使用a标签,可以打开一个链接,然后访问一个新的页面 ...
- 记录在Centos下安装和使用Git的过程,从github上克隆仓库和提交。
1 安装git yum install git 2配置DNS vi /etc/resolv.conf nameserver 8.8.8.8nameserver 8.8.4.4 3 设置网关 vi /e ...
- Android忽略文件
转自我自己的博客...Android Studio上传项目到GitHub
- Apache Mina UDP连接目标服务器地址时出现异常
俩种情形,第一种是开始连接时候就没连上服务器:第二种是服务器关闭连接,出现的异常: 第一种: java.lang.reflect.InvocationTargetException at sun.re ...
- 封装jQuery下载文件组件
使用jQuery导出文档文件 jQuery添加download组件 jQuery.download = function(url, data, method){ if( url && ...
- (转)关闭win10的Skype
https://blog.csdn.net/qq_38285661/article/details/86663849 使用win10的小伙伴们,有没有发现一个不用的功能Skype,假如你想卸载又怕卸不 ...
- mp4格式(转帖加修改) 转载
下面的软件下载地址:http://download.csdn.net/source/2607382 ftyp: 这是一个筐,可以装mdat等其他Box. 例:00 00 00 14 66 74 79 ...
- UIApplication 的学习
1.0 URL 的组成 == 协议头://主机名/路径 从iOS7 开始,系统提供了两种管理状态栏的方式,默认交给控制器去管理 2.0 旋转事件----> UIApplication --- ...