opencv--convexHull()用法

[cpp]  view plain  copy
 print ?
  1. #include<iostream>  
  2. #include<opencv2/opencv.hpp>  
  3. #include<vector>  
  4.   
  5. using namespace cv;  
  6. using namespace std;  
  7.   
  8. int main()  
  9. {  
  10.     //先初始化变量  
  11.     Mat srcImage(Size(600, 600), CV_8UC3, Scalar(0));  
  12.     Mat saveImage;  
  13.     srcImage.copyTo(saveImage);  
  14.     RNG &rng = theRNG();  
  15.   
  16.     char key;  
  17.     Point midPoint;  
  18.     //hull 变量用来存储点的序号  
  19.     vector<int> hull;  
  20.     while (1)  
  21.     {  
  22.         //因为下面是入栈操作,所以,需要在循环内为变量分配空间,否则,栈内的数据无法出栈  
  23.         vector<Point> points;  
  24.         //首先确定随机点的坐标,以及随机点落定的范围  
  25.         int count = (unsigned int)rng % 100 + 3;  
  26.         for (int i = 0; i < count; i++)  
  27.         {  
  28.             //确定随机点的范围  
  29.             midPoint.x = rng.uniform(srcImage.cols / 4, srcImage.cols * 3 / 4);  
  30.             midPoint.y = rng.uniform(srcImage.rows / 4, srcImage.rows * 3 / 4);  
  31.             points.push_back(midPoint);  
  32.         }  
  33.   
  34.           
  35.         //该用法结束后,hull将外围点的序号存放起来  
  36.         convexHull(Mat(points), hull, true);  
  37.   
  38.         //绘制随机点  
  39.         for (int i = 0; i < points.size(); i++)  
  40.         {  
  41.             circle(srcImage, points[i], 0, Scalar(255, 255, 0), 3, 8);  
  42.         }  
  43.   
  44.         //绘制凸包  
  45.         Point point0 = points[hull[hull.size() - 1]];  
  46.         for (int i = 0; i < hull.size(); i++)  
  47.         {  
  48.             Point curPoint = points[hull[i]];  
  49.   
  50.             line(srcImage, point0, curPoint, Scalar(255, 255, 0), 3, 8);  
  51.   
  52.             point0 = curPoint;  
  53.         }  
  54.   
  55.         imshow("【显示窗口】", srcImage);  
  56.           
  57.         //停止在没有按键事件发生时  
  58.         key = waitKey();  
  59.         if (key == 27)  
  60.             break;  
  61.         else  
  62.             srcImage = Scalar(0);  
  63.             /*saveImage.copyTo(srcImage);*/  
  64.     }  
  65.   
  66.     return 0;  
  67. }  


按下空格键进行切换

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值