1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > python opencv最小外接矩形_Opencv绘制最小外接矩形 最小外接圆

python opencv最小外接矩形_Opencv绘制最小外接矩形 最小外接圆

时间:2023-01-25 01:15:41

相关推荐

python opencv最小外接矩形_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> contours;

vector 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

{

//绘制轮廓

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方法求轮廓的最小外接圆,获取圆心和半径信息,并绘制圆;

原始图像:

最小外接矩:

最小外接圆:

opencv学习之路(26)、轮廓查找与绘制(五)——最小外接矩形

一.简介 二.轮廓最小外接矩形的绘制 #include "opencv2/opencv.hpp" using namespace cv; void main() { //轮廓最小外 ...

Opencv 最小外接矩形合并拼接

前一篇画出了最小外接矩形,但是有时候画出来的矩形由于中间像素干扰或者是其他原因矩形框并不是真正想要的 如图1是一个信号的雨图,被矩形框分割成了多个小框: 需要合并矩形框达到的效果: 主要思想: 扫描两 ...

Opencv 图片边缘检测和最小外接矩形

#include "core/core.hpp" #include "highgui/highgui.hpp" #include "imgproc/i ...

cv2&period;minAreaRect&lpar;&rpar; 生成最小外接矩形

简介 使用python opencv返回点集cnt的最小外接矩形,所用函数为 cv2.minAreaRect(cnt) ,cnt是所要求最小外接矩形的点集数组或向量,这个点集不定个数. cv2 ...

BZOJ 1185&colon; &lbrack;HNOI&rsqb;最小矩形覆盖-旋转卡壳法求点集最小外接矩形&lpar;面积&rpar;并输出四个顶点坐标-备忘板子

来源:旋转卡壳法求点集最小外接矩形(面积)并输出四个顶点坐标 BZOJ又崩了,直接贴一下人家的代码. 代码: #include"stdio.h" #include"str ...

Opencv 改进的外接矩形合并拼接方法

上一篇中的方法存在的问题是矩形框不够精确,而且效果不能达到要求 这里使用凸包检测的方法,并将原来膨胀系数由20缩小到5,达到了更好的效果 效果图: 效果图: 代码: #include

OpenCV绘制直线,矩形和园

首先导入我们所需要的库: import numpy as np import cv2 import matplotlib.pyplot as plt 自定义显示图像的函数: def show(imag ...

opencv轮廓外接矩形

1.寻找轮廓 api void cv::findContours( InputOutputArray image, OutputArrayOfArrays contours, OutputArray ...

opencv —— boundingRect、minAreaRect 寻找包裹轮廓的最小正矩形、最小斜矩形

寻找包裹轮廓的最小正矩形:boundingRect 函数 返回矩阵应满足:① 轮廓上的点均在矩阵空间内.② 矩阵是正矩阵(矩形的边界与图像边界平行). Rect boundingRect(InputA ...

随机推荐

Python中的&lowbar;&lowbar;init&lowbar;&lowbar;和&lowbar;&lowbar;new&lowbar;&lowbar;介绍

介绍 首先我们要知道在面向对象编程中,实例化基本遵循创建实例对象.初始化实例对象.最后返回实例对象这么一个过程. Python 中的 __new__ 方法负责创建一个实例对象,__init__ 方法负 ...

Striiv Myland 攻略

推荐一款IOS平台上的运动APP:Striiv.可以记录平时的步数,路程,卡路里,运动时间.如果购买相应的硬件,还可以记录每天爬了多少台阶(这是专门为爬楼者用的么...). 其中比较吸引我的是里面有个 ...

如何用Apache POI操作Excel文件-----如何对一个单元格加注解?

有的时候,我们需要通过操作Apache POI,在生成Cell数据的同时,能对其生成的Cell,加上注解(comments),类似于下面的. 那么对于这种情况,我们的代码应该如何写呢? 借花献佛,我就 ...

webServer xampp的安装及使用

一.下载: 西装xampp1.73版本,其他版本可能会出错,为了你能顺利安装,最好用此版本: 二.安装: 1.安装路径,最好不要放到系统盘去[c:],建议非系统盘都可,尤其是早期的XAMPP版本可能默 ...

A Tour of Go Methods with pointer receivers

Methods can be associated with a named type or a pointer to a named type. We just saw twoAbsmethod ...

字符编码和python使用encode&comma;decode转换utf-8&comma; gbk&comma; gb2312

ASCII码 标准ASCII码使用7位二进制数表示大写或小写字母,数字0到9标点符号以及在美式英语中使用的特殊控制字符. 在标准ASCII码中,最高位(b7)用作奇偶校验位,所谓奇偶校验,是指在代码传 ...

vim 替换

摘自: vim替换命令 替換(substitute) :[range]s/pattern/string/[c,e,g,i] range 指的是範圍,1,7 指從第一行至第七行,1,$ 指從第一行至最後 ...

【C&plus;&plus;】C&plus;&plus;中变量的声明与定义的区别

声明(declaration):意味着告诉编译器关于变量名称.变量类型.变量大小.函数名称.结构名称.大小等等信息,并且在声明阶段不会给变量分配任何的内存. 定义(definition):定义就是在变 ...

自定义UITabbarcontrollerview

// 初始化contentView [self initContentView]; #pragma mark 初始化contentView - (void)initContentView { CGSi ...

C&num;之内存分配

在C#中,内存分成5个区,他们分别是堆.栈.自由存储区.全局/静态存储区和常量存储区. 栈,就是那些由编译器在需要的时候分配,在不需要的时候自动清楚的变量的存储区.里面的变量通常是局部变量.函数参数等 ...

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。