欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

OpenCV實現(xiàn)繪制輪廓外接矩形

 更新時間:2022年12月29日 14:02:28   作者:黑色の鉛筆  
這篇文章主要為大家詳細介紹了OpenCV實現(xiàn)繪制輪廓外接矩形的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

1.尋找輪廓

api

void cv::findContours( InputOutputArray image, OutputArrayOfArrays contours, OutputArray hierarchy, int mode, int method, Point offset = Point()

各個參數(shù)詳解如下:

Image表示輸入圖像,必須是二值圖像,二值圖像可以threshold輸出、Canny輸出、inRange輸出、自適應(yīng)閾值輸出等。

Contours獲取的輪廓,每個輪廓是一系列的點集合

Hierarchy輪廓的層次信息,每個輪廓有四個相關(guān)信息,分別是同層下一個、前一個、第一個子節(jié)點、父節(jié)點

mode 表示輪廓尋找時候的拓撲結(jié)構(gòu)返回 -RETR_EXTERNAL表示只返回最外層輪廓 -RETR_TREE表示返回輪廓樹結(jié)構(gòu)

  • CV_RETR_EXTERNAL:只檢測外輪廓。忽略輪廓內(nèi)部的洞
  • CV_RETR_LIST:檢測所有輪廓,但不建立繼承(包含)關(guān)系
  • CV_RETR_TREE:檢測所有輪廓,并且建立所有的繼承(包含)關(guān)系。也就是說用CV_RETR_EXTERNAL和CV_RETR_LIST方法的時候hierarchy這個變量是沒用的,因為前者沒有包含關(guān)系,找到的都是外輪廓,后者僅僅是找到所喲的輪廓但并不把包含關(guān)系區(qū)分。用TREE這種檢測方法的時候我們的hierarchy這個參數(shù)才是有意義的
  • CV_RETR_CCOMP:檢測所有輪廓,但是僅僅建立兩層包含關(guān)系。外輪廓放到頂層,外輪廓包含的第一層內(nèi)輪廓放到底層,如果內(nèi)輪廓還包含輪廓,那就把這些內(nèi)輪廓放到頂層去。

Method表示輪廓點集合取得是基于什么算法,常見的是基于CHAIN_APPROX_SIMPLE鏈式編碼方法

注意,如果圖像底色是白色,則檢測最外層的輪廓為圖像邊框

2.繪制輪廓外接矩形

繪制外接矩形包括兩種:

繪制最大外接矩形

(Rect cv::boundingRect( InputArray points ))

其中,輸入?yún)?shù)points為一系列點的集合(findContours中contours中的一個元素),對輪廓來說就是該輪廓的點集 返回結(jié)果是一個矩形,x, y, w, h

繪制最小外接矩形

RotatedRect cv::minAreaRect( InputArray points )

其中,輸入?yún)?shù)points為一系列點的集合(findContours中contours中的一個元素) ,對輪廓來說就是該輪廓的點集 返回結(jié)果是一個旋轉(zhuǎn)矩形,包含下面的信息: - 矩形中心位置 - 矩形的寬高 - 旋轉(zhuǎn)角度。

3.代碼

EdgeDetection.h

#pragma once
#include<opencv2/opencv.hpp>
#include<iostream>

using namespace std;
using namespace cv;


class EdgeDetection
{
    cv::Mat m_img;
    cv::Mat m_canny;
public:
    EdgeDetection(cv::Mat iamge);
    bool cannyProcess(unsigned int downThreshold,unsigned int upThreshold);
    bool getContours();

    ~EdgeDetection();
};

EdgeDetection.cpp

#include "EdgeDetection.h"

EdgeDetection::EdgeDetection(cv::Mat image)
{
    m_img = image;
}

bool EdgeDetection::cannyProcess(unsigned int downThreshold, unsigned int upThreshold)
{
    bool ret=true;

    if (m_img.empty())
    {
        ret = false;
    }

    cv::Canny(m_img, m_canny, downThreshold, upThreshold);
    cv::imshow("Canny", m_canny);

    return ret;
}

bool EdgeDetection::getContours()
{
    bool ret = true;
    if (m_canny.empty())
    {
        ret = false;
    }

    cv::Mat k = cv::getStructuringElement(cv::MORPH_RECT, cv::Size(3, 3), cv::Point(-1, -1));
    cv::dilate(m_canny, m_canny, k);
    imshow("dilate", m_canny);

    // 輪廓發(fā)現(xiàn)與繪制
    vector<vector<cv::Point> > contours;
    vector<Vec4i> hierarchy;
    findContours(m_canny, contours, cv::RETR_EXTERNAL, CHAIN_APPROX_SIMPLE, Point());

    for (size_t i = 0; i < contours.size();++i)
    {
        // 最大外接輪廓
        cv::Rect rect = cv::boundingRect(contours[i]);
        cv::rectangle(m_img,rect,cv::Scalar(0,255,0),2,LINE_8);


        // 最小外接輪廓
        RotatedRect rrt = minAreaRect(contours[i]);
        Point2f pts[4];
        rrt.points(pts);
        // 繪制旋轉(zhuǎn)矩形與中心位置
        for (int i = 0; i < 4; i++) {
            line(m_img, pts[i % 4], pts[(i + 1) % 4], Scalar(0, 0, 255), 2, 8, 0);
        }
        Point2f cpt = rrt.center;
        circle(m_img, cpt, 2, Scalar(255, 0, 0), 2, 8, 0);
    }





    imshow("contours", m_img);
    return ret;
}

EdgeDetection::~EdgeDetection()
{
}

main.cpp

#include"EdgeDetection.h"
using namespace std;
using namespace cv;



int main(int argc, char* argv[])
{
    Mat src = imread("rect.jpg");
    if (src.empty())
    {
        cout << "image is empty" << endl;
        return -1;
    }

    imshow("input", src);

    EdgeDetection ed(src);

    ed.cannyProcess(80,160);
    ed.getContours();

    waitKey(0);
    return 0;
}

原圖

canny

目標圖

到此這篇關(guān)于OpenCV實現(xiàn)繪制輪廓外接矩形的文章就介紹到這了,更多相關(guān)OpenCV輪廓外接矩形內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++中的策略模式淺析

    C++中的策略模式淺析

    策略模式屬于C++設(shè)計模式中行為模式之一,該模式定義了一系列算法,并將每個算法封裝起來,使它們可以相互替換。本文將通過示例詳細講解這一模式,需要的可以參考一下
    2023-02-02
  • c++中c_str()的用法示例

    c++中c_str()的用法示例

    這篇文章主要介紹了c++中c_str()的用法示例,幫助大家更好的理解和學習C++,感興趣的朋友可以了解下
    2020-09-09
  • C語言中的線程信號控制詳解

    C語言中的線程信號控制詳解

    這篇文章主要通過一些示例為大家詳細介紹一下C語言中的線程信號控制,文中的示例代碼講解詳細,對我們深入了解C語言有一定的幫助,感興趣的可以學習一下
    2023-02-02
  • Opencv實現(xiàn)邊緣檢測與輪廓發(fā)現(xiàn)及繪制輪廓方法詳解

    Opencv實現(xiàn)邊緣檢測與輪廓發(fā)現(xiàn)及繪制輪廓方法詳解

    這篇文章主要介紹了Opencv實現(xiàn)邊緣檢測與輪廓發(fā)現(xiàn)及繪制輪廓方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-12-12
  • C語言運算符及其優(yōu)先級匯總表口訣

    C語言運算符及其優(yōu)先級匯總表口訣

    由于C語言的運算符優(yōu)先級與C++的不完全一樣(主要是增加了幾個運算符),所以這個口訣不能完全實用于C++.但是應(yīng)該能夠兼容,大家可以比較一下他們的區(qū)別應(yīng)該就能夠很快掌握C++的優(yōu)先級的
    2013-07-07
  • 浮點數(shù)在計算機中存儲方式是怎樣的

    浮點數(shù)在計算機中存儲方式是怎樣的

    這篇文章介紹了浮點數(shù)在計算機中是如何存儲的,講解的比較詳細,有需要的朋友可以參考一下。
    2016-06-06
  • C++/Qt遍歷多維數(shù)組的3種方式示例

    C++/Qt遍歷多維數(shù)組的3種方式示例

    一維數(shù)組對于存儲和處理一組數(shù)據(jù)很有用,但有時候,有必要使用多維數(shù)組,下面這篇文章主要給大家介紹了關(guān)于C++/Qt遍歷多維數(shù)組的3種方式,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-05-05
  • 基于C++字符串替換函數(shù)的使用詳解

    基于C++字符串替換函數(shù)的使用詳解

    本篇文章是對C++字符串替換函數(shù)的使用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言中將日期和時間以字符串格式輸出的方法

    C語言中將日期和時間以字符串格式輸出的方法

    這篇文章主要介紹了C語言中將日期和時間以字符串格式輸出的方法,分別是ctime()函數(shù)和asctime()函數(shù),注意參數(shù)區(qū)別,需要的朋友可以參考下
    2015-08-08
  • c++判斷文件是否存在的方法匯總

    c++判斷文件是否存在的方法匯總

    這篇文章主要介紹了c++判斷文件是否存在的方法匯總,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08

最新評論