Opencv绘制最小外接矩形、最小外接圆

 更新时间:2020年07月21日 09:21:46   作者:长缨缚苍龙  
这篇文章主要为大家详细介绍了Opencv绘制最小外接矩形、最小外接圆的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

Opencv中求点集的最小外结矩使用方法minAreaRect,求点集的最小外接圆使用方法minEnclosingCircle。

minAreaRect方法原型:

RotatedRect minAreaRect( InputArray points ); 

输入参数points是所要求最小外结矩的点集数组或向量;

minEnclosingCircle方法原型:

void minEnclosingCircle( InputArray points, 
          CV_OUT Point2f& center, CV_OUT float& radius ); 

第一个参数points是所要求最小外结圆的点集数组或向量;

第二个参数Point2f类型的center是求得的最小外接圆的中心坐标;

第三个参数float类型的radius是求得的最小外接圆的半径; 

使用minAreaRect和minEnclosingCircle方法分别求最小外接矩和圆:

#include "core/core.hpp" 
#include "highgui/highgui.hpp" 
#include "imgproc/imgproc.hpp" 
#include "iostream" 
 
using namespace std; 
using namespace cv; 
 
int main(int argc,char *argv[]) 
{ 
 Mat imageSource=imread(argv[1],0); 
 imshow("Source Image",imageSource); 
 Mat image; 
 blur(imageSource,image,Size(3,3)); 
 threshold(image,image,0,255,CV_THRESH_OTSU);  
 imshow("Threshold Image",image); 
 
 //寻找最外层轮廓 
 vector<vector<Point>> contours; 
 vector<Vec4i> hierarchy; 
 findContours(image,contours,hierarchy,RETR_EXTERNAL,CHAIN_APPROX_NONE,Point()); 
 
 Mat imageContours=Mat::zeros(image.size(),CV_8UC1); //最小外接矩形画布 
 Mat imageContours1=Mat::zeros(image.size(),CV_8UC1); //最小外结圆画布 
 for(int i=0;i<contours.size();i++) 
 {   
  //绘制轮廓 
  drawContours(imageContours,contours,i,Scalar(255),1,8,hierarchy); 
  drawContours(imageContours1,contours,i,Scalar(255),1,8,hierarchy); 
 
 
  //绘制轮廓的最小外结矩形 
  RotatedRect rect=minAreaRect(contours[i]); 
  Point2f P[4]; 
  rect.points(P); 
  for(int j=0;j<=3;j++) 
  { 
   line(imageContours,P[j],P[(j+1)%4],Scalar(255),2); 
  } 
 
  //绘制轮廓的最小外结圆 
  Point2f center; float radius; 
  minEnclosingCircle(contours[i],center,radius); 
  circle(imageContours1,center,radius,Scalar(255),2); 
 
 } 
 imshow("MinAreaRect",imageContours);  
 imshow("MinAreaCircle",imageContours1); 
 waitKey(0); 
 return 0; 

作图步骤:

1. 对原始图像均值滤波并二值化;

2. 求图像的最外层轮廓;

3.  使用minAreaRect方法求轮廓的最小外接矩形,转化求得矩形的四个顶点坐标,并绘制矩形;

4.  使用minEnclosingCircle方法求轮廓的最小外接圆,获取圆心和半径信息,并绘制圆;

原始图像:

最小外接矩:

最小外接圆:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C++简明讲解缺省参数与函数重载的用法

    C++简明讲解缺省参数与函数重载的用法

    所谓缺省参数,顾名思义,就是在声明函数的某个参数的时候为之指定一个默认值,在调用该函数的时候如果采用该默认值,你就无须指定该参数。C++ 允许多个函数拥有相同的名字,只要它们的参数列表不同就可以,这就是函数的重载,借助重载,一个函数名可以有多种用途
    2022-06-06
  • C语言详细讲解if语句与switch语句的用法

    C语言详细讲解if语句与switch语句的用法

    用 if 语句可以构成分支结构,它根据给的条件进行判定,以决定执行哪个分支程序段,C 语言中还有另外一种分支语句,就是 switch 语句
    2022-05-05
  • C++ 超详细示例讲解list的使用

    C++ 超详细示例讲解list的使用

    list是一种序列式容器。list容器完成的功能实际上和数据结构中的双向链表是极其相似的,list中的数据元素是通过链表指针串连成逻辑意义上的线性表,也就是list也具有链表的主要优点,即:在链表的任一位置进行元素的插入、删除操作都是快速的
    2022-07-07
  • c++重载运算符时返回值为类的对象或者返回对象的引用问题

    c++重载运算符时返回值为类的对象或者返回对象的引用问题

    这篇文章主要介绍了c++重载运算符时返回值为类的对象或者返回对象的引用问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • C语言数据结构之二叉链表创建二叉树

    C语言数据结构之二叉链表创建二叉树

    这篇文章主要介绍了C语言数据结构之 二叉链表创建二叉树,下文我们为了更方便的使用二叉树结构体,可以使用 typedef 对结构体进行命名,具体内容需要的小伙伴可以参考一下
    2022-02-02
  • C++中最常用的容器用法与排序实例

    C++中最常用的容器用法与排序实例

    C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器,这篇文章主要给大家介绍了关于C++中最常用的容器用法与排序的相关资料,需要的朋友可以参考下
    2021-08-08
  • 最长公共子字符串的使用分析

    最长公共子字符串的使用分析

    本篇文章是对最长公共子字符串的使用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C++ BoostAsyncSocket实现异步反弹通信的案例详解

    C++ BoostAsyncSocket实现异步反弹通信的案例详解

    这篇文章主要为大家详细介绍了C++ BoostAsyncSocket如何实现异步反弹通信,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的可以了解一下
    2023-03-03
  • vc获取计算机名和ip地址的方法

    vc获取计算机名和ip地址的方法

    这篇文章主要介绍了vc获取计算机名和ip地址的方法,涉及通过VC对系统相关信息操作技巧,需要的朋友可以参考下
    2015-05-05
  • c++ 面向对象的类设计

    c++ 面向对象的类设计

    类的设计在于用恰到好处的信息来完整表达一个职责清晰的概念,恰到好处的意思是不多也不少,少了,就概念就不完整;多了,就显得冗余,累赘,当然特例下,允许少许的重复,但是,这里必须要有很好的理由
    2017-07-07

最新评论