網站首頁 編程語言 正文
1、 凸包
什么是凸包?
解釋:給定二維平面上的點集,凸包就是將最外層的點連接起來構成的凸邊形,它是包含點集中所有的點。
如下:用人手圖來舉例說明凸缺陷概念。手周圍深色的線描畫出凸包,A到H被標出的區域是凸包的各個“缺陷”,這些凸度缺陷提供了手以及手狀態的特征表現的方法。
2、尋找凸包:convexHull()函數
說明:convexHull()函數用于尋找圖像點集中的凸包。
void convexHull(InputArray points,OutputArray hull,bool clockwise=false,bool returnPoints=true)
第一個參數:輸入的二維點集,可以填Mat類型或者std::vector
第二個參數:輸出參數,函數調用后找到的凸包。
第三個參數:操作方向的標識符。當此標識符為True時,輸出的凸包為順時針方向。否則為逆時針方向。
第四個參數:操作標識符,默認值True。當標識符為真時,函數返回各個凸包的各個點。否則,它返回凸包各點的指數。
3、函數解析之theRNG()
函數說明:返回默認的隨機數生成器。如果需要使用生成器獲得一個隨機數或者初始化一個數組,可以使用 randu 或者 randn代替。但想要在一個循環中產生很多隨機數,那么使用此函數檢索生成器,會很快。
RNG &rng = theRNG(); //用其引用來接收theRNG函數返回的隨機數生成器(RNG就是隨機數生成器的類)
4 、circle()函數【回憶】
void circle(CV_IN_OUT Mat& image, Point center, int radius, const Scalar& color, int thickness=1, int lineType=8);
image:為圖像,單通道多通道都行,不需要特殊要求
center:為畫圓的圓心坐標
radius:為圓的半徑
color:為設定圓的顏色,比如用CV_RGB(255, 0,0)設置為紅色, CV_RGB(255,255,255)設置為白色,CV_RGB(0, 0,0)設置為黑色
thickness:為設置圓線條的粗細,值越大則線條越粗,為負數則是填充效果,-1表示繪制實心圓
lineType:表示線形。OpenCV中有三種可以選擇LINE_4、LINE_8、LINE_AA。其中LINE_4表示采用4鄰接的方式繪制,LINE_8表示采用8鄰接的方式繪制,
LINE_AA表示高斯濾波抗鋸齒。
5、基礎示例程序:凸包檢測基礎
說明:隨機生成3~103個坐標值隨機的彩色點,然后將這些點連接起來
#include<opencv2/opencv.hpp>
#include<opencv2/imgproc/imgproc.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<iostream>
using namespace std;
using namespace cv;
int main()
{
//初始化變量和隨機值
Mat image(500, 500, CV_8UC3);
RNG & rng = theRNG();
while (1)
{
char key;
int count = (unsigned)rng % 100 + 3;//隨機生成點的數量
cout << count << endl;
vector<Point> points;//點值
//隨機生成點坐標
for (int i = 0; i < count; i++)
{
Point point;
point.x = rng.uniform(image.cols / 4, image.cols * 3 / 4);//uniform() 方法將隨機生成下一個實數,它在[x,y]范圍內。
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 會先創建臨時對象,然后將臨時對象拷貝到容器中
}
//檢測凸包
vector<int> hull;
convexHull(Mat(points), hull, true);
//繪制出隨機顏色的點
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);
}
//準備參數
int hullcount = (int)hull.size();//凸包邊數
Point point0 = points[hull[hullcount - 1]];//連接凸包邊的坐標點
// 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;
}
原文鏈接:https://blog.csdn.net/qq_44859533/article/details/126269730
相關推薦
- 2022-10-24 C++?String部分成員模擬實現流程詳解_C 語言
- 2023-06-03 Android廣播機制原理與開發_Android
- 2022-08-25 內存泄露導致Android?中setVisibility()?失效原理_Android
- 2022-05-18 Matlab實現多子圖同步調整視角_C 語言
- 2022-11-10 golang?常用定時任務匯總_Golang
- 2022-07-21 python logging模塊使用介紹
- 2022-12-08 vscode擴展代碼定位實現步驟詳解_相關技巧
- 2023-04-08 C語言字符串左旋的兩種實現方法_C 語言
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支