OpenCV(三十五):凸包检测

1.凸包检测介绍

凸包检测是计算凸包的一种技术,凸包就是:给定二维平面上的点集,将最外层的点连接起来构成的凸边形,它是包含点集中所有的点。

2.凸包检测函数convexHull()

void cv::convexHull ( InputArray points,

OutputArray hull,

boolclockwise = false,

bool returnPoints = true

)

  • points:输入的2D点集
  • hull:输出凸包的顶点
  • clockwise: 方向标志,当参数为true时,凸包顺序为顺时针方向,否则为逆时针方向。returnPoints:输出数据的类型标志,当参数为true时第二个参数输出的结果是凸包顶点的坐标,否则第二个参数输出的结果是凸包顶点的索引。

3.示例代码:

复制代码
//凸包检测
void Convex_hull_detection(Mat image){
    Mat gray,binary;
    cvtColor(image,gray,COLOR_BGR2GRAY);//灰度化
    threshold(gray,binary,40,255,THRESH_BINARY);//自适应二值化
    //开运算消除细小区域
    Mat k= getStructuringElement(MORPH_RECT,Size(3,3),Point(-1,-1));
    morphologyEx(binary,binary,MORPH_OPEN,k);
    //轮廓的发现与绘制
    vector<vector<Point>> contours;//轮廓
    vector<Vec4i> hierarchy;//存放轮廓结构变量
    findContours(binary,contours,hierarchy,0,2,Point());
   for(int n=0;n<contours.size();n++){
       //计算凸包
       vector<Point> hull;
       convexHull(contours[n],hull);
       //绘制凸包
       for(int i=0;i<hull.size();i++){
           //绘制凸包顶点
           circle(image,hull[i],4,Scalar(255,0,0,255),2,8,0);
           //连接凸包
           if(i==hull.size()-1){
               line(image,hull[i],hull[0],Scalar(0,0,255,255),2,8,0);
               break;
           }
           line(image,hull[i],hull[i-1],Scalar(0,0,255,255),2,8,0);
       }
   }
    imwrite("/sdcard/DCIM/hull.png",image);

}

凸包检测的结果:

相关推荐
嘀咕博客2 分钟前
Stable Virtual Camera:Stability AI等推出的AI模型 ,2D图像轻松转3D视频
人工智能·3d·音视频·ai工具
北京地铁1号线6 分钟前
机器学习面试题:逻辑回归Logistic Regression(LR)
人工智能·机器学习
云雾J视界10 分钟前
AI赋能与敏捷融合:未来电源项目管理者的角色重塑与技能升级——从华为实战看高技术研发项目的管理变革
人工智能·华为·项目管理·电源研发·敏捷项目·电源项目
canonical_entropy22 分钟前
不同的工作需要不同人格的AI大模型?
人工智能·后端·ai编程
老黄编程25 分钟前
--gpu-architecture <arch> (-arch)
linux·人工智能·机器学习
青草地溪水旁26 分钟前
设计模式(C++)详解——建造者模式(1)
c++·设计模式·建造者模式
IT_陈寒32 分钟前
Vite 5.0 终极优化指南:7个配置技巧让你的构建速度提升200%
前端·人工智能·后端
点云SLAM44 分钟前
结构光三维重建原理详解(1)
人工智能·数码相机·计算机视觉·三维重建·结构光重建·gray 编码·标定校正
代码AI弗森3 小时前
从 IDE 到 CLI:AI 编程代理工具全景与落地指南(附对比矩阵与脚本化示例)
ide·人工智能·矩阵
自动驾驶小卡5 小时前
boost::circular_buffer的使用方法简介
c++·boost·circular_buffer