使用OpenCV實(shí)現(xiàn)檢測和追蹤車輛
本文實(shí)例為大家分享了OpenCV實(shí)現(xiàn)檢測和追蹤車輛的具體代碼,供大家參考,具體內(nèi)容如下
完整源碼GitHub
- 使用高斯混合模型(BackgroundSubtractorMOG2)對背景建模,提取出前景
- 使用中值濾波去掉椒鹽噪聲,再閉運(yùn)算和開運(yùn)算填充空洞
- 使用cvBlob庫追蹤車輛,我稍微修改了cvBlob源碼來通過編譯
由于要對背景建模,這個方法要求背景是靜止的
另外不同車輛白色區(qū)域不能連通,否則會認(rèn)為是同一物體
void processVideo(char* videoFilename) { Mat frame; // current frame Mat fgMaskMOG2; // fg mask fg mask generated by MOG2 method Mat bgImg; // background Ptr<BackgroundSubtractorMOG2> pMOG2 = createBackgroundSubtractorMOG2(200, 36.0, false); // MOG2 Background subtractor while (true) { VideoCapture capture(videoFilename); if (!capture.isOpened()) { cerr << "Unable to open video file: " << videoFilename << endl; return; } int width = (int)capture.get(CV_CAP_PROP_FRAME_WIDTH); int height = (int)capture.get(CV_CAP_PROP_FRAME_HEIGHT); unique_ptr<IplImage, void(*)(IplImage*)> labelImg(cvCreateImage(cvSize(width, height), IPL_DEPTH_LABEL, 1), [](IplImage* p){ cvReleaseImage(&p); }); CvBlobs blobs; CvTracks tracks; while (true) { // read input data. ESC or 'q' for quitting int key = waitKey(1); if (key == 'q' || key == 27) return; if (!capture.read(frame)) break; // update background pMOG2->apply(frame, fgMaskMOG2); pMOG2->getBackgroundImage(bgImg); imshow("BG", bgImg); imshow("Original mask", fgMaskMOG2); // post process medianBlur(fgMaskMOG2, fgMaskMOG2, 5); imshow("medianBlur", fgMaskMOG2); morphologyEx(fgMaskMOG2, fgMaskMOG2, MORPH_CLOSE, getStructuringElement(MORPH_RECT, Size(5, 5))); // fill black holes morphologyEx(fgMaskMOG2, fgMaskMOG2, MORPH_OPEN, getStructuringElement(MORPH_RECT, Size(5, 5))); // fill white holes imshow("morphologyEx", fgMaskMOG2); // track cvLabel(&IplImage(fgMaskMOG2), labelImg.get(), blobs); cvFilterByArea(blobs, 64, 10000); cvUpdateTracks(blobs, tracks, 10, 90, 30); cvRenderTracks(tracks, &IplImage(frame), &IplImage(frame)); // show imshow("Frame", frame); key = waitKey(30); } } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Opencv光流運(yùn)動物體追蹤詳解
- opencv3/C++實(shí)現(xiàn)光流點(diǎn)追蹤
- python+opencv實(shí)現(xiàn)動態(tài)物體追蹤
- 如何用OpenCV -python3實(shí)現(xiàn)視頻物體追蹤
- opencv+arduino實(shí)現(xiàn)物體點(diǎn)追蹤效果
- Python+OpenCV實(shí)現(xiàn)實(shí)時眼動追蹤的示例代碼
- OpenCV3.0+Python3.6實(shí)現(xiàn)特定顏色的物體追蹤
- 淺析Python+OpenCV使用攝像頭追蹤人臉面部血液變化實(shí)現(xiàn)脈搏評估
- OpenCV 顏色追蹤的示例代碼
- 圖文詳解OpenCV中光流以及視頻特征點(diǎn)追蹤
相關(guān)文章
c語言生成隨機(jī)數(shù)的方法(獲得一組不同的隨機(jī)數(shù))
c語言生成一組不同的隨機(jī)數(shù),大家參考使用吧2013-12-12c++實(shí)現(xiàn)發(fā)送http請求通過get方式獲取網(wǎng)頁源代碼
這篇文章主要介紹了c++實(shí)現(xiàn)發(fā)送http請求,通過get方式獲取網(wǎng)頁源代碼的示例,需要的朋友可以參考下2014-02-02C語言實(shí)現(xiàn)單鏈表實(shí)現(xiàn)方法
這篇文章主要介紹了C語言實(shí)現(xiàn)單鏈表實(shí)現(xiàn)方法的相關(guān)資料,鏈表分為單向鏈表、雙向鏈表、循環(huán)鏈表,需要的朋友可以參考下2017-08-08C/C++浮點(diǎn)數(shù)使用的兩個注意事項(xiàng)詳解
浮點(diǎn)數(shù)都是有符號的,沒有 unsigned 浮點(diǎn)數(shù),下面這篇文章主要給大家介紹了關(guān)于C/C++浮點(diǎn)數(shù)使用的兩個注意事項(xiàng),文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02C++利用鏈表模板類實(shí)現(xiàn)簡易隊(duì)列
這篇文章主要為大家詳細(xì)介紹了C++利用鏈表模板類實(shí)現(xiàn)一個簡易隊(duì)列,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12C語言中結(jié)構(gòu)體的內(nèi)存對齊規(guī)則講解
C 數(shù)組允許定義可存儲相同類型數(shù)據(jù)項(xiàng)的變量,結(jié)構(gòu)是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許你存儲不同類型的數(shù)據(jù)項(xiàng),本篇讓我們來了解C 的結(jié)構(gòu)體內(nèi)存對齊2022-05-05