opencv學習之路(24)、輪廓查找與繪製(三)——凸包

1、簡介

2、繪製點集的凸包

 1 #include<opencv2/opencv.hpp>
 2 using namespace cv;
 3 
 4 void main()
 5 {
 6     //---繪製點集的凸包
 7     Mat img(400, 400, CV_8UC3, Scalar::all(0));  //定義繪製圖像
 8     RNG rng;  //定義隨機數對象
 9     while(1)
10     {
11         char key;
12         int count = (unsigned int)rng % 100;  //定義點的個數  
13         vector<Point> points;  //定義點集
14         for(int i=0; i<count; i++)
15         {
16             Point pt;
17             pt.x = rng.uniform(img.cols/4, img.cols*3/4);  //設定點的x範圍
18             pt.y = rng.uniform(img.rows/4, img.rows*3/4);  //設定點的y範圍
19             points.push_back(pt);
20         }
21 
22         //檢測凸包
23         vector<int> hull;
24         convexHull(Mat(points), hull, true);
25 
26         img = Scalar::all(0);
27         for(int i = 0; i < count; i++ )
28             circle(img, points[i], 3, Scalar(rng.uniform(0, 255), rng.uniform(0, 255), rng.uniform(0, 255)), CV_FILLED, CV_AA);
29 
30         //準備參數
31         int hullcount = (int)hull.size(); //凸包的邊數
32         Point point0 = points[hull[hullcount-1]]; //鏈接凸包邊的座標點
33 
34         //繪製凸包的邊
35         for(int  i = 0; i < hullcount; i++ )
36         {
37             Point point = points[hull[i]];
38             circle(img, point, 8, Scalar(0, 255, 0), 2, 8);
39             line(img, point0, point, Scalar(255, 255, 255), 2, CV_AA);
40             point0 = point;
41         }
42 
43         //顯示效果圖
44         imshow("img", img);
45 
46         //按下ESC,Q,或者q,程序退出
47         key = (char)waitKey();
48         if( key == 27 || key == 'q' || key == 'Q' ) 
49             break;
50     }
51}

3、繪製輪廓的凸包

 

 1 #include<opencv2/opencv.hpp>
 2 using namespace cv;
 3 
 4 void main()
 5 {
 6     Mat srcImg = imread("E://12.jpg");
 7     imshow("src", srcImg);
 8     Mat dstImg2 = srcImg.clone();
 9     Mat tempImg(srcImg.rows, srcImg.cols, CV_8UC3, Scalar::all(0));  //用於繪製凸包
10     Mat dstImg(srcImg.rows, srcImg.cols, CV_8UC3, Scalar::all(0));  //用於繪製輪廓
11     cvtColor(srcImg, srcImg, CV_BGR2GRAY);
12     threshold(srcImg, srcImg, 100, 255, CV_THRESH_BINARY); //二值化
13     
14     vector<vector<Point>> contours;
15     vector<Vec4i> hierarcy;
16     findContours(srcImg, contours, hierarcy, CV_RETR_EXTERNAL, CV_CHAIN_APPROX_NONE);
17     vector<vector<Point>> hull(contours.size());
18     for(int i=0; i<contours.size(); i++)
19     {
20         convexHull(Mat(contours[i]), hull[i], true);     //查找凸包
21         drawContours(dstImg, contours, i, Scalar(255, 255, 255), -1, 8);  //繪製輪廓
22         //drawContours(dstImg, hull, i, Scalar(rand()%255, rand()%255, rand()%255), 2, 8);
23         drawContours(tempImg, hull, i, Scalar(255, 255, 255), -1, 8);
24     }
25     imshow("hull", tempImg);
26     imshow("contours", dstImg);
27 
28     Mat diffImg;
29     absdiff(tempImg, dstImg, diffImg);  //圖像相減
30     Mat element = getStructuringElement(MORPH_RECT, Size(3, 3), Point(-1, -1));
31     erode(diffImg, diffImg, element);
32     imshow("diff", diffImg);
33 
34     vector<vector<Point>> contours2;
35     vector<Vec4i> hierarcy2;
36     cvtColor(diffImg, diffImg, CV_BGR2GRAY); //轉爲灰度圖
37     threshold(diffImg, diffImg, 100, 255, CV_THRESH_BINARY); //二值化
38     findContours(diffImg, contours2, hierarcy2, CV_RETR_EXTERNAL, CV_CHAIN_APPROX_NONE);
39     drawContours(dstImg2, contours2, -1, Scalar(0, 0, 255), 2, 8);  //紅色繪製缺陷輪廓
40     imshow("defects", dstImg2);
41     waitKey(0);
42 }

相關文章
相關標籤/搜索