Qt-OpenCV学习笔记--多边形拟合--approxPolyDP()

概述

这个函数可以用 指定精度的多边形 拟合 轮廓 

函数

void cv::approxPolyDP
(
	InputArray 	  curve,
    OutputArray   approxCurve,
    double 	epsilon,
    bool 	closed 
)		
curve 输入的轮廓(点的集合)
approxCurve 输出的轮廓(点的集合)
epsilon 精度(拟合的 边线 到 原轮廓 的距离)
closed  如果值为ture,则多边形闭合;否则,开放。

测试代码

#include "widget.h"
#include "ui_widget.h"

#include 

#include 
#include 
#include 

#include 

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> contours;
    findContours(dst_dilate,contours,RETR_EXTERNAL,CHAIN_APPROX_NONE);

    //多边形拟合
    vector> approxCurve(contours.size());

    for (uint i=0;i

测试结果

Qt-OpenCV学习笔记--多边形拟合--approxPolyDP()_第1张图片

参考

opencv多边形拟合曲线approxPolyDP()函数

openCV之approxPolyDP()多边拟合函数

你可能感兴趣的:(opencv,学习,qt,计算机视觉)