概述
这个函数可以用 指定精度的多边形 拟合 轮廓 。
函数
void cv::approxPolyDP
(
InputArray curve,
OutputArray approxCurve,
double epsilon,
bool closed
)
curve | 输入的轮廓(点的集合) |
approxCurve | 输出的轮廓(点的集合) |
epsilon | 精度(拟合的 边线 到 原轮廓 的距离) |
closed | 如果值为ture,则多边形闭合;否则,开放。 |
测试代码
#include "widget.h"
#include "ui_widget.h"
#include <QDebug>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <vector>
using namespace cv;
using namespace std;
Widget::Widget(QWidget *parent)
: QWidget(parent)
, ui(new Ui::Widget)
{
ui->setupUi(this);
//定义输入和输出图像
Mat src;
Mat dst_gray,
dst_blur,
dst_canny,
dst_dilate;
//载入图像
src = imread("c:/opencv/x6.bmp");
if(src.empty())
{
qDebug()<<"加载图片失败!";
return;
}
//显示
imshow("src",src);
//灰度处理
cv::cvtColor(src,dst_gray,COLOR_BGR2GRAY);
//高斯模糊
GaussianBlur(dst_gray,dst_blur,Size(3,3),0,0);
//边缘检测
Canny(dst_blur,dst_canny,200,220);
//膨胀
dilate(dst_canny,dst_dilate,Mat());
//检测轮廓
vector<vector<Point>> contours;
findContours(dst_dilate,contours,RETR_EXTERNAL,CHAIN_APPROX_NONE);
//多边形拟合
vector<vector<Point>> approxCurve(contours.size());
for (uint i=0;i<contours.size();i++)
{
//计算周长
double len = arcLength(contours[i],true);
//拟合
approxPolyDP(contours[i],approxCurve[i],len*0.02,true);
}
//打印
qDebug()<<approxCurve.size();
//克隆
Mat dst= src.clone();
//绘制拟合图形
drawContours(dst,approxCurve,-1,Scalar(255,0,255),2);
//显示
imshow("dst",dst);
}
Widget::~Widget()
{
delete ui;
}