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

OpenCV實(shí)現(xiàn)物體的凸包檢測的示例代碼

 更新時(shí)間:2022年08月11日 16:20:26   作者:我菜就愛學(xué)  
給定二維平面上的點(diǎn)集,凸包就是將最外層的點(diǎn)連接起來構(gòu)成的凸邊形,它是包含點(diǎn)集中所有的點(diǎn)。本文將利用OpenCV實(shí)現(xiàn)物體的凸包檢測,感興趣的可以了解一下

1、 凸包

什么是凸包?

解釋:給定二維平面上的點(diǎn)集,凸包就是將最外層的點(diǎn)連接起來構(gòu)成的凸邊形,它是包含點(diǎn)集中所有的點(diǎn)。

如下:用人手圖來舉例說明凸缺陷概念。手周圍深色的線描畫出凸包,A到H被標(biāo)出的區(qū)域是凸包的各個(gè)“缺陷”,這些凸度缺陷提供了手以及手狀態(tài)的特征表現(xiàn)的方法。

2、尋找凸包:convexHull()函數(shù)

說明:convexHull()函數(shù)用于尋找圖像點(diǎn)集中的凸包。

void convexHull(InputArray points,OutputArray hull,bool clockwise=false,bool returnPoints=true)

第一個(gè)參數(shù):輸入的二維點(diǎn)集,可以填Mat類型或者std::vector

第二個(gè)參數(shù):輸出參數(shù),函數(shù)調(diào)用后找到的凸包。

第三個(gè)參數(shù):操作方向的標(biāo)識(shí)符。當(dāng)此標(biāo)識(shí)符為True時(shí),輸出的凸包為順時(shí)針方向。否則為逆時(shí)針方向。

第四個(gè)參數(shù):操作標(biāo)識(shí)符,默認(rèn)值True。當(dāng)標(biāo)識(shí)符為真時(shí),函數(shù)返回各個(gè)凸包的各個(gè)點(diǎn)。否則,它返回凸包各點(diǎn)的指數(shù)。

3、函數(shù)解析之theRNG()

函數(shù)說明:返回默認(rèn)的隨機(jī)數(shù)生成器。如果需要使用生成器獲得一個(gè)隨機(jī)數(shù)或者初始化一個(gè)數(shù)組,可以使用 randu 或者 randn代替。但想要在一個(gè)循環(huán)中產(chǎn)生很多隨機(jī)數(shù),那么使用此函數(shù)檢索生成器,會(huì)很快。

RNG &rng = theRNG();  //用其引用來接收theRNG函數(shù)返回的隨機(jī)數(shù)生成器(RNG就是隨機(jī)數(shù)生成器的類)

4 、circle()函數(shù)【回憶】

void circle(CV_IN_OUT Mat& image, Point center, int radius, const Scalar& color, int thickness=1, int lineType=8); 

image:為圖像,單通道多通道都行,不需要特殊要求

center:為畫圓的圓心坐標(biāo)

radius:為圓的半徑

color:為設(shè)定圓的顏色,比如用CV_RGB(255, 0,0)設(shè)置為紅色, CV_RGB(255,255,255)設(shè)置為白色,CV_RGB(0, 0,0)設(shè)置為黑色

thickness:為設(shè)置圓線條的粗細(xì),值越大則線條越粗,為負(fù)數(shù)則是填充效果,-1表示繪制實(shí)心圓

lineType:表示線形。OpenCV中有三種可以選擇LINE_4、LINE_8、LINE_AA。其中LINE_4表示采用4鄰接的方式繪制,LINE_8表示采用8鄰接的方式繪制,

LINE_AA表示高斯濾波抗鋸齒。

5、基礎(chǔ)示例程序:凸包檢測基礎(chǔ)

說明:隨機(jī)生成3~103個(gè)坐標(biāo)值隨機(jī)的彩色點(diǎn),然后將這些點(diǎn)連接起來

#include<opencv2/opencv.hpp>
#include<opencv2/imgproc/imgproc.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<iostream>
using namespace std;
using namespace cv;
int main()
{
    //初始化變量和隨機(jī)值
    Mat image(500, 500, CV_8UC3);
    RNG & rng = theRNG();
    while (1)
    {
        char key;
        int count = (unsigned)rng % 100 + 3;//隨機(jī)生成點(diǎn)的數(shù)量
        cout << count << endl;
        vector<Point> points;//點(diǎn)值
        //隨機(jī)生成點(diǎn)坐標(biāo)
        for (int i = 0; i < count; i++)
        {
            Point point;
            point.x = rng.uniform(image.cols / 4, image.cols * 3 / 4);//uniform() 方法將隨機(jī)生成下一個(gè)實(shí)數(shù),它在[x,y]范圍內(nèi)。
            point.y = rng.uniform(image.rows / 4, image.rows * 3 / 4);
            if(i<10)
                cout << "(" << point.x << "," << point.y << ")" << endl;
            points.push_back(point);//C++ vector::push_back 會(huì)先創(chuàng)建臨時(shí)對象,然后將臨時(shí)對象拷貝到容器中
        }
        //檢測凸包
        vector<int> hull;
        convexHull(Mat(points), hull, true);    
        //繪制出隨機(jī)顏色的點(diǎn)
        image = Scalar::all(0);
        for (int i = 0; i < count; i++)
        {
            circle(image, points[i], 3, Scalar(rng.uniform(0, 255), rng.uniform(0, 255), rng.uniform(0, 255)), FILLED,LINE_AA);
        }
        //準(zhǔn)備參數(shù)
        int hullcount = (int)hull.size();//凸包邊數(shù)
        Point point0 = points[hull[hullcount - 1]];//連接凸包邊的坐標(biāo)點(diǎn)
        //    cout << hull[0] <<":"<< hull.size()<<endl;
        //繪制凸包的邊
        for (int i = 0; i < hullcount; i++)
        {
            Point point = points[hull[i]];
            line(image, point0, point, Scalar(255, 255, 255), 2, LINE_AA);
            point0 = point;
        }
        imshow("凸包檢測", image);
        key = (char)waitKey();
        if (key == 27 || key == 'q' || key == 'Q')
            break;
    }
    return 0;
}

到此這篇關(guān)于OpenCV實(shí)現(xiàn)物體的凸包檢測的示例代碼的文章就介紹到這了,更多相關(guān)OpenCV物體凸包檢測內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言數(shù)據(jù)結(jié)構(gòu)中二分查找遞歸非遞歸實(shí)現(xiàn)并分析

    C語言數(shù)據(jù)結(jié)構(gòu)中二分查找遞歸非遞歸實(shí)現(xiàn)并分析

    這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)中二分查找遞歸非遞歸實(shí)現(xiàn)并分析的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • 利用QT實(shí)現(xiàn)UDP聊天小程序

    利用QT實(shí)現(xiàn)UDP聊天小程序

    這篇文章主要為大家詳細(xì)介紹了潤滑利用QT的UDP技術(shù),實(shí)現(xiàn)兩個(gè)QT程序之間的聊天程序。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以學(xué)習(xí)一下
    2022-11-11
  • c++ 臨時(shí)對象的來源

    c++ 臨時(shí)對象的來源

    大家可能對這個(gè)臨時(shí)對象這個(gè)概念還不是很清楚,那么首先我們花一些時(shí)間來理解臨時(shí)對象
    2013-01-01
  • C語言實(shí)現(xiàn)班級成績管理系統(tǒng)

    C語言實(shí)現(xiàn)班級成績管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)班級成績管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • C語言實(shí)現(xiàn)軍旗游戲的示例代碼

    C語言實(shí)現(xiàn)軍旗游戲的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何利用C語言實(shí)現(xiàn)軍旗游戲,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-11-11
  • C++異步調(diào)用方法詳解

    C++異步調(diào)用方法詳解

    這篇文章主要介紹了C++異步調(diào)用方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05
  • C語言實(shí)現(xiàn)Linux下的socket文件傳輸實(shí)例

    C語言實(shí)現(xiàn)Linux下的socket文件傳輸實(shí)例

    這篇文章主要介紹了C語言實(shí)現(xiàn)Linux下的socket文件傳輸?shù)姆椒?較為詳細(xì)的分析了C語言文件Socket文件傳輸客戶端與服務(wù)器端相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2015-06-06
  • Qt編寫地圖實(shí)現(xiàn)動(dòng)態(tài)點(diǎn)位標(biāo)注的示例代碼

    Qt編寫地圖實(shí)現(xiàn)動(dòng)態(tài)點(diǎn)位標(biāo)注的示例代碼

    動(dòng)態(tài)點(diǎn)位標(biāo)注是定制的一個(gè)功能模塊,提供直接地圖上選點(diǎn)設(shè)置標(biāo)記點(diǎn),點(diǎn)位信息用結(jié)構(gòu)體存儲(chǔ),其中包括了經(jīng)度、緯度、速度、時(shí)間等信息。本文將介紹實(shí)現(xiàn)這一功能的示例代碼,需要的可以參考一下
    2022-01-01
  • C語言實(shí)現(xiàn)三子棋小游戲詳解

    C語言實(shí)現(xiàn)三子棋小游戲詳解

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)三子棋小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • C++/Qt遍歷多維數(shù)組的3種方式示例

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

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

最新評論