服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - opencv3/C++轮廓的提取与筛选方式

opencv3/C++轮廓的提取与筛选方式

2021-08-08 16:06阿卡蒂奥 C/C++

今天小编就为大家分享一篇opencv3/C++轮廓的提取与筛选方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

轮廓提取

findContours发现轮廓

  1. findContours(
  2. InputOutputArray binImg, //输入8bit图像,0值像素值不变,非0的像素看成1;(变为二值图像)
  3. OutputArrayOfArrays contours,//输出找到的轮廓对象
  4. OutputArray, hierachy// 图像的拓扑结构
  5. int mode, //轮廓返回的模式(RETR_TREE等)
  6. int method,//发现方法(CHAIN_APPROX_SIMPLE等)
  7. Point offset=Point()//轮廓像素的位移(默认没有位移(0, 0))
  8. )

【报错问题】

findContours()有时会报告“已触发了一个断点”等错误,尝试过y有效的解决方法有:

1.为vector提前申请一定的空间,如

  1. std::vector<std::vector<Point>> contours(500)

2.Debug版切换为Release版;

drawContours绘制轮廓

  1. drawContours(
  2. InputOutputArray binImg, // 输出图像
  3. OutputArrayOfArrays contours,//找到的全部轮廓对象
  4. Int contourIdx//轮廓索引号
  5. const Scalar & color,//绘制颜色
  6. int thickness,//绘制线宽
  7. int lineType ,//线的类型(默认8)
  8. InputArray hierarchy,//拓扑结构图
  9. int maxlevel,//最大层数(0只绘制当前的,1表示绘制绘制当前及其内嵌的轮廓)
  10. Point offset=Point()//轮廓位移
  11. )

示例:

  1. #include<opencv2/opencv.hpp>
  2. using namespace cv;
  3.  
  4. int main()
  5. {
  6. Mat src,dst;
  7. src = imread("E:/image/image/shape.jpg");
  8. if(src.empty())
  9. {
  10. printf("can not load image \n");
  11. return -1;
  12. }
  13. namedWindow("input", CV_WINDOW_AUTOSIZE);
  14. imshow("input", src);
  15. dst = Mat::zeros(src.size(), CV_8UC3);
  16.  
  17. blur(src,src,Size(3,3));
  18. cvtColor(src,src,COLOR_BGR2GRAY);
  19. Canny(src, src, 20, 80, 3, false);
  20. std::vector<std::vector<Point>> contours;
  21. std::vector<Vec4i> hierarchy;
  22. findContours(src, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE, Point(0, 0));
  23.  
  24. RNG rng(0);
  25. for(int i = 0; i < contours.size(); i++)
  26. {
  27. Scalar color = Scalar(rng.uniform(0,255), rng.uniform(0,255), rng.uniform(0,255));
  28. drawContours(dst, contours, i, color, 2, 8, hierarchy, 0, Point(0,0));
  29. }
  30. namedWindow("output", CV_WINDOW_AUTOSIZE);
  31. imshow("output",dst);
  32. waitKey();
  33. return 0;
  34. }

opencv3/C++轮廓的提取与筛选方式

opencv3/C++轮廓的提取与筛选方式

使用opencv3时(测试用opencv3.1.0)发现,cv命名空间下没有了vector,而在opencv2中(测试用opencv2.4.10)还存在。后查看各自的头文件发现:

opencv.hpp头文件中包含着core.hpp(#include “opencv2/core.hpp”);

而在opencv2的core.hpp中包含有

  1. ........
  2. #include <map>
  3. #include <new>
  4. #include <string>
  5. #include <vector>
  6. .......

等头文件,但在opencv3的core.hpp中删去这些包含项。

因此在使用opencv3时cv命名空间下没有了vector。

使用opencv2.4.10时可以写:

  1. #include<opencv2/opencv.hpp>
  2. using namespace cv;
  3.  
  4. int main()
  5. {
  6. Mat src,dst;
  7. src = imread("E:/image/image/shape.jpg");
  8. if(src.empty())
  9. {
  10. printf("can not load image \n");
  11. return -1;
  12. }
  13. namedWindow("input", CV_WINDOW_AUTOSIZE);
  14. imshow("input", src);
  15. dst = Mat::zeros(src.size(), CV_8UC3);
  16. blur(src,src,Size(5,5));
  17. Canny(src, src, 20, 80, 3, false);
  18. vector<vector<Point>>contours;
  19. vector<Vec4i> hierarchy;
  20. findContours(src, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE, Point(0, 0));
  21.  
  22. RNG rng(0);
  23. for(int i = 0; i < contours.size(); i++)
  24. {
  25. Scalar color = Scalar(rng.uniform(0,255), rng.uniform(0,255), rng.uniform(0,255));
  26. drawContours(dst, contours, i, color, 2, 8, hierarchy, 0, Point(0,0));
  27. }
  28. namedWindow("output", CV_WINDOW_AUTOSIZE);
  29. imshow("output",dst);
  30. waitKey();
  31. return 0;
  32. }

绘制轮廓外矩形框

常用绘制轮廓外形状的函数:

cv::boundingRect(InputArray points)绘制一个矩形(轮廓周围最小矩形左上角点和右下角点)

cv::minAreaRect(InputArray points)绘制轮廓周围最小旋转矩形

cv::minEnclosingCircle(InputArray points, Point2f& center, float& radius)//绘制轮廓周围最小圆形

cv::fitEllipse(InputArray points)绘制轮廓周围最小椭圆

绘制轮廓外矩形框:

  1. #include<opencv2/opencv.hpp>
  2. using namespace cv;
  3.  
  4. int main()
  5. {
  6. Mat src,dst;
  7. src = imread("E:/image/shape.jpg");
  8. if(src.empty())
  9. {
  10. printf("can not load image \n");
  11. return -1;
  12. }
  13. namedWindow("input", CV_WINDOW_AUTOSIZE);
  14. imshow("input", src);
  15. dst = Mat::zeros(src.size(), CV_8UC3);
  16. std::vector<std::vector<Point>>contours;
  17. std::vector<Vec4i> hierarchy;
  18. blur(src,src,Size(3,3));
  19. cvtColor(src,src,COLOR_BGR2GRAY);
  20. Canny(src, src, 20, 80, 3, false);
  21. findContours(src, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE, Point(0, 0));
  22.  
  23. RNG rng(0);
  24. std::vector<std::vector<Point>> contoursPloy(contours.size());
  25. std::vector<RotatedRect> minRects(contours.size());
  26.  
  27. for(int i = 0; i < contours.size(); i++)
  28. {
  29. minRects[i] = minAreaRect(Mat(contours[i]));
  30. Scalar color = Scalar(rng.uniform(0,255), rng.uniform(0,255), rng.uniform(0,255));
  31. drawContours(dst, contoursPloy, i, color, 1,8,std::vector<Vec4i>(), 0, Point(0, 0));
  32. Point2f rectPoints[4];
  33. minRects[i].points(rectPoints);
  34. for (int j = 0; j < 4; j++)
  35. {
  36. line(dst, rectPoints[j], rectPoints[(j+1)%4], color, 1, 8, 0);
  37. }
  38. }
  39.  
  40. namedWindow("output", CV_WINDOW_AUTOSIZE);
  41. imshow("output",dst);
  42. waitKey();
  43. return 0;
  44. }

opencv3/C++轮廓的提取与筛选方式

opencv3/C++轮廓的提取与筛选方式

轮廓筛选

  1. moments(
  2. InputArray array,//输入数据
  3. bool binaryImage=false //是否为二值图像
  4. )
  5. contourArea(
  6. InputArray contour,//输入轮廓数据
  7. bool oriented//返回绝对值(默认false)
  8. )
  9.  
  10. arcLength(
  11. InputArray curve,//输入轮廓
  12. bool closed// 轮廓否是封闭曲线
  13. )

轮廓筛选示例:

使用轮廓的面积和长度特征对轮廓进行筛选后用外接矩形将筛选后的轮廓框选出来。

  1. #include<opencv2/opencv.hpp>
  2. using namespace cv;
  3.  
  4. void trackBar(int,void*);
  5.  
  6. Mat src,dst;
  7. std::vector<std::vector<Point>>contours;
  8. int area = 0, length = 0;
  9. int main()
  10. {
  11.  
  12. src = imread("E:/image/shape.jpg");
  13. if(src.empty())
  14. {
  15. printf("can not load image \n");
  16. return -1;
  17. }
  18. namedWindow("input", CV_WINDOW_AUTOSIZE);
  19. imshow("input", src);
  20. dst = Mat::zeros(src.size(), CV_8UC3);
  21.  
  22. std::vector<Vec4i> hierarchy;
  23. blur(src,dst,Size(3,3));
  24. cvtColor(dst,dst,COLOR_BGR2GRAY);
  25. Canny(dst, dst, 20, 80, 3, false);
  26. findContours(dst, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE, Point(0, 0));
  27. namedWindow("output", CV_WINDOW_AUTOSIZE);
  28.  
  29. createTrackbar("area:", "output", &area,150,trackBar);
  30. createTrackbar("length:", "output", &length,150,trackBar);
  31.  
  32. waitKey();
  33. return 0;
  34. }
  35.  
  36. void trackBar(int,void*)
  37. {
  38. Mat src1 = src.clone();
  39. RNG rng(0);
  40. std::vector<std::vector<Point>> contoursPloy(contours.size());
  41. std::vector<RotatedRect> minRects(contours.size());
  42.  
  43. for(int i = 0; i < contours.size(); i++)
  44. {
  45. if(contourArea(contours[i]) > area && arcLength(contours[i], false) > length)
  46. {
  47. minRects[i] = minAreaRect(Mat(contours[i]));
  48. Scalar color = Scalar(rng.uniform(0,255), rng.uniform(0,255), rng.uniform(0,255));
  49. //drawContours(dst, contoursPloy, i, color, 1,8,vector<Vec4i>(), 0, Point(0, 0));
  50. Point2f rectPoints[4];
  51. minRects[i].points(rectPoints);
  52. for (int j = 0; j < 4; j++)
  53. {
  54. line(src1, rectPoints[j], rectPoints[(j+1)%4], color, 2, 8, 0);
  55. }
  56. }
  57. }
  58. imshow("output",src1);
  59. src1 = src;
  60. }

opencv3/C++轮廓的提取与筛选方式

opencv3/C++轮廓的提取与筛选方式

以上这篇opencv3/C++轮廓的提取与筛选方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

原文链接:https://blog.csdn.net/akadiao/article/details/78843773

延伸 · 阅读

精彩推荐
  • C/C++使用C++制作简单的web服务器(续)

    使用C++制作简单的web服务器(续)

    本文承接上文《使用C++制作简单的web服务器》,把web服务器做的功能稍微强大些,主要增加的功能是从文件中读取网页并返回给客户端,而不是把网页代码...

    C++教程网5492021-02-22
  • C/C++深入C++拷贝构造函数的总结详解

    深入C++拷贝构造函数的总结详解

    本篇文章是对C++中拷贝构造函数进行了总结与介绍。需要的朋友参考下...

    C++教程网5182020-11-30
  • C/C++C语言main函数的三种形式实例详解

    C语言main函数的三种形式实例详解

    这篇文章主要介绍了 C语言main函数的三种形式实例详解的相关资料,需要的朋友可以参考下...

    ieearth6912021-05-16
  • C/C++c/c++实现获取域名的IP地址

    c/c++实现获取域名的IP地址

    本文给大家汇总介绍了使用c/c++实现获取域名的IP地址的几种方法以及这些方法的核心函数gethostbyname的详细用法,非常的实用,有需要的小伙伴可以参考下...

    C++教程网10262021-03-16
  • C/C++c/c++内存分配大小实例讲解

    c/c++内存分配大小实例讲解

    在本篇文章里小编给大家整理了一篇关于c/c++内存分配大小实例讲解内容,有需要的朋友们可以跟着学习参考下。...

    jihite5172022-02-22
  • C/C++关于C语言中E-R图的详解

    关于C语言中E-R图的详解

    今天小编就为大家分享一篇关于关于C语言中E-R图的详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看...

    Struggler095962021-07-12
  • C/C++C语言实现双人五子棋游戏

    C语言实现双人五子棋游戏

    这篇文章主要为大家详细介绍了C语言实现双人五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    两片空白7312021-11-12
  • C/C++OpenCV实现拼接图像的简单方法

    OpenCV实现拼接图像的简单方法

    这篇文章主要为大家详细介绍了OpenCV实现拼接图像的简单方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    iteye_183805102021-07-29