日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

OpenCV中的凸包

發布時間:2025/3/15 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 OpenCV中的凸包 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

OpenCV中的凸包

凸包是指給定一個二維平面上的點集,凸包就是將這個點集最外層的點連接起來構成的凸多邊形。
上一節的找到圖像的邊界點的坐標信息,在此基礎之上,進行凸包操作。
具體流程:
找到圖像的輪廓邊界坐標信息,存儲在vector<vector> contours中,則每一個contours[i]代表了一條邊際,即是一系列點的集合,然后,我們利用凸包的定義,在這個點集上找到凸包,遍歷contours得到所有的凸包,也存儲在vector<vector>類型中。
最后根據得到的凸包信息,將凸多邊形繪制在圖像之上,可以使用line函數自己每條線都自己繪制,也可以使用提供的API繪制:

convexHull(Mat(求凸包的點集contours[i]),存儲凸包的vector<vector<Point>>[i],bool 操作方向符,為true時,起始點到結束點順勢針,bool 返回點類型,當輸出vector<Point>時,這個參數被忽略。 ); #include "opencv2/opencv.hpp" #include <vector>using namespace std; using namespace cv;Mat src,dst,src_gray;int thresvalue = 100;void dis(int,void*); int main(int argc, char *argv[]) {src = imread("/home/dynamicw/Project/C++_Project/opencvtest/src/lesson01/source/map.png");imshow("src",src);cvtColor(src,src_gray,CV_BGR2GRAY);imshow("src_gray",src_gray);blur(src_gray,src,Size(3,3));namedWindow("test",CV_WINDOW_AUTOSIZE);createTrackbar("value","test",&thresvalue,255,dis);dis(0,0);waitKey(0);return 0; }void dis(int,void*) {Canny(src,dst,thresvalue,thresvalue*2,3);vector<vector<Point>> contours;vector<Vec4i> hierarchy;findContours(dst,contours,hierarchy,CV_RETR_TREE,CV_CHAIN_APPROX_SIMPLE,Point(0,0));vector<vector<Point>> hull(contours.size());for(int i = 0;i < contours.size();i++){cout << contours[i] << endl;convexHull(Mat(contours[i]),hull[i],false);}Mat drawing = Mat::zeros(dst.size(),CV_8UC3);for(int i = 0;i < contours.size();i++){drawContours(drawing,contours,i,Scalar(0,0,255),1,8,vector<Vec4i>(),0,Point());drawContours(drawing,hull,i,Scalar(0,255,0),1,8,vector<Vec4i>(),0,Point());}imshow("drawing",drawing); }

總結

以上是生活随笔為你收集整理的OpenCV中的凸包的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。