久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

《學(xué)習(xí)openCV》例程解析 ex_8_2 (輪廓)

 instl 2013-12-29
例:根據(jù)滑動(dòng)條參數(shù)檢測(cè)輪廓,在滑動(dòng)條變化時(shí)候重新檢測(cè)

效果圖:

  1. /** 
  2.   Our Example 8-2 is drawn from the OpenCV package. Here we create a window with an  
  3. image in it. A trackbar sets a simple threshold, and the contours in the thresholded im- 
  4. age are drawn. The image is updated whenever the trackbar is adjusted. 
  5. Example 8-2. Finding contours based on a trackbar’s location; the contours are updated whenever  
  6. the trackbar is moved                                                                      
  7. */  
  8.   
  9.   
  10. #include "stdafx.h"   
  11. #include "cv.h"   
  12. #include "highgui.h"   
  13.   
  14. IplImage* g_img = NULL;  
  15. IplImage* g_gray = NULL;  
  16. int g_thresh = 100;  
  17. CvMemStorage* g_storage = NULL;         //內(nèi)存存儲(chǔ)器是一個(gè)可用來存儲(chǔ)諸如序列,,輪廓,圖形,子劃分等   
  18.                                         //動(dòng)態(tài)增長(zhǎng)數(shù)據(jù)結(jié)構(gòu)的底層結(jié)構(gòu)。   
  19.   
  20. void on_trackbar(int pos)  
  21. {  
  22.     if (g_storage == NULL)  
  23.     {  
  24.         g_gray = cvCreateImage(cvGetSize(g_img), 8, 1);  
  25.         g_storage = cvCreateMemStorage();//創(chuàng)建內(nèi)存塊默認(rèn)值為64K   
  26.     }  
  27.     else  
  28.     {  
  29.         cvClearMemStorage(g_storage);   //清除儲(chǔ)存塊內(nèi)容,,并不釋放內(nèi)存   
  30.     }  
  31.       
  32.     cvCvtColor(g_img, g_gray, CV_BGR2GRAY);  
  33.     //色彩空間轉(zhuǎn)換, BGR到GRAY   
  34.     cvThreshold(g_gray, g_gray, g_thresh, 255, CV_THRESH_BINARY);  
  35.     //對(duì)數(shù)組元素進(jìn)行固定閾值操作   
  36.     //該函數(shù)的典型應(yīng)用是對(duì)灰度圖像進(jìn)行閾值操作得到二值圖像。   
  37.   
  38.     CvSeq* contours = 0;  
  39.     //可動(dòng)態(tài)增長(zhǎng)元素序列   
  40.     cvFindContours(                     //在二值圖像中尋找輪廓    
  41.         g_gray,                         //輸入二值圖像   
  42.         g_storage,                      //得到的輪廓的存儲(chǔ)容器    
  43.         &contours                       //指向第一個(gè)輪廓的指針   
  44.         );  
  45.     //coutours序列指針指向儲(chǔ)存在g_storage 內(nèi)存塊中的輪廓   
  46.   
  47.     cvZero(g_gray);                     //等于cvSetZero,清空?qǐng)D像   
  48.     if (contours)                       //如果序列非空   
  49.     {  
  50.         cvDrawContours(                 //在圖像中繪制外部和內(nèi)部的輪廓   
  51.             g_gray,  
  52.             contours,                   //指針指向第一個(gè)輪廓   
  53.             cvScalarAll(255),           //g_gray 為單通道顏色,只有一種顏色   
  54.             cvScalarAll(255),           //賦為白色   
  55.             100                         //繪制輪廓的最大等級(jí),如果為0 單獨(dú)繪制輪廓   
  56.             );  
  57.         cvShowImage("Contours", g_gray);  
  58.     }  
  59. }  
  60.   
  61. int main()  
  62. {     
  63.     cvNamedWindow("g_img", CV_WINDOW_AUTOSIZE);  
  64.     g_img = cvLoadImage("lena.jpg");  
  65.     cvShowImage("g_img", g_img);  
  66.   
  67.     cvNamedWindow("Contours", CV_WINDOW_AUTOSIZE);  
  68.   
  69.     cvCreateTrackbar(  
  70.                  "Threshold",       //滑塊名字   
  71.                  "Contours",        //滑塊所在窗口名字   
  72.                  &g_thresh,         //指定創(chuàng)建時(shí)的滑塊位置   
  73.                  255,               //滑塊位置的最大值   
  74.                  on_trackbar        //每次滑塊位置被改變的時(shí)候,,被調(diào)用函數(shù)的指針,。   
  75.                                     //這個(gè)函數(shù)應(yīng)該被聲明為void Foo(int);    
  76.                                     //如果沒有回調(diào)函數(shù),這個(gè)值可以設(shè)為NULL,。    
  77.                  );  
  78.   
  79.     on_trackbar(0);                 //初始先調(diào)用一次,,否者滑塊變動(dòng)時(shí)才顯示   
  80.     cvWaitKey();  
  81.   
  82.     cvDestroyAllWindows();  
  83.     cvReleaseImage(&g_img);  
  84.     cvReleaseImage(&g_gray);  
  85.     return 0;  
  86. }  

(2) 效果圖


改進(jìn)單獨(dú)加顏色繪制輪廓

  1. /** 
  2.     擴(kuò)展8_2使每個(gè)輪廓都隨機(jī)顏色                                                                
  3. */  
  4.   
  5.   
  6. #include "stdafx.h"   
  7. #include "cv.h"   
  8. #include "highgui.h"   
  9.   
  10. IplImage* g_img = NULL;  
  11. IplImage* g_gray = NULL;  
  12. int g_thresh = 100;  
  13. CvMemStorage* g_storage = NULL;         //內(nèi)存存儲(chǔ)器是一個(gè)可用來存儲(chǔ)諸如序列,,輪廓,,圖形,子劃分等   
  14.                                         //動(dòng)態(tài)增長(zhǎng)數(shù)據(jù)結(jié)構(gòu)的底層結(jié)構(gòu)。   
  15.   
  16. void on_trackbar(int pos)  
  17. {  
  18.     if (g_storage == NULL)  
  19.     {  
  20.         g_gray = cvCreateImage(cvGetSize(g_img), 8, 1);  
  21.         g_storage = cvCreateMemStorage();//創(chuàng)建內(nèi)存塊默認(rèn)值為64K   
  22.     }  
  23.     else  
  24.     {  
  25.         cvClearMemStorage(g_storage);   //清除儲(chǔ)存塊內(nèi)容,,并不釋放內(nèi)存   
  26.     }  
  27.       
  28.     cvCvtColor(g_img, g_gray, CV_BGR2GRAY);  
  29.     //色彩空間轉(zhuǎn)換, BGR到GRAY   
  30.     cvThreshold(g_gray, g_gray, g_thresh, 255, CV_THRESH_BINARY);  
  31.     //對(duì)數(shù)組元素進(jìn)行固定閾值操作   
  32.     //該函數(shù)的典型應(yīng)用是對(duì)灰度圖像進(jìn)行閾值操作得到二值圖像,。   
  33.   
  34.     CvSeq* contours = 0;  
  35.     //可動(dòng)態(tài)增長(zhǎng)元素序列   
  36.     cvFindContours(                     //在二值圖像中尋找輪廓    
  37.         g_gray,                         //輸入二值圖像   
  38.         g_storage,                      //得到的輪廓的存儲(chǔ)容器    
  39.         &contours                       //指向第一個(gè)輪廓的指針   
  40.         );  
  41.     //coutours序列指針指向儲(chǔ)存在g_storage 內(nèi)存塊中的輪廓   
  42.   
  43.     cvZero(g_gray);                     //等于cvSetZero,清空?qǐng)D像   
  44.   
  45.     IplImage* g_temp = cvCreateImage(cvGetSize(g_gray), 8, 3);  
  46.     //創(chuàng)建一個(gè)3通道圖像,顯示有顏色的輪廓   
  47.     cvZero(g_temp);                       
  48.   
  49.     for(; contours != 0; contours = contours->h_next)  
  50.     {  
  51.         //因?yàn)橐獑为?dú)繪制輪廓,,所以得用循環(huán)   
  52.         CvScalar color = CV_RGB(rand()&255, rand()&255, rand()&255);  
  53.         //隨機(jī)取色   
  54.         cvDrawContours(                 //在圖像中繪制外部和內(nèi)部的輪廓   
  55.             g_temp,  
  56.             contours,                   //指針指向第一個(gè)輪廓   
  57.             color,  
  58.             color,  
  59.             0                           //單獨(dú)繪制輪廓   
  60.             );  
  61.     }  
  62.     cvShowImage("Contours", g_temp);  
  63. }  
  64.   
  65. int main()  
  66. {     
  67.     cvNamedWindow("g_img", CV_WINDOW_AUTOSIZE);  
  68.     g_img = cvLoadImage("lena.jpg");  
  69.     cvShowImage("g_img", g_img);  
  70.   
  71.     cvNamedWindow("Contours", CV_WINDOW_AUTOSIZE);  
  72.   
  73.     cvCreateTrackbar(  
  74.                  "Threshold",       //滑塊名字   
  75.                  "Contours",        //滑塊所在窗口名字   
  76.                  &g_thresh,         //指定創(chuàng)建時(shí)的滑塊位置   
  77.                  255,               //滑塊位置的最大值   
  78.                  on_trackbar        //每次滑塊位置被改變的時(shí)候,,被調(diào)用函數(shù)的指針。   
  79.                                     //這個(gè)函數(shù)應(yīng)該被聲明為void Foo(int);    
  80.                                     //如果沒有回調(diào)函數(shù),,這個(gè)值可以設(shè)為NULL,。    
  81.                  );  
  82.   
  83.     on_trackbar(0);                 //初始先調(diào)用一次,否者滑塊變動(dòng)時(shí)才顯示   
  84.     cvWaitKey();  
  85.   
  86.     cvDestroyAllWindows();  
  87.     cvReleaseImage(&g_img);  
  88.     cvReleaseImage(&g_gray);  
  89.     return 0;  
  90. }  

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,,所有內(nèi)容均由用戶發(fā)布,,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購買等信息,,謹(jǐn)防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào),。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多