使用OpenCV实现检测和追踪车辆
发布时间:2020-12-15 01:06:59 所属栏目:C语言 来源:网络整理
导读:本文实例为大家分享了OpenCV实现检测和追踪车辆的具体代码,供大家参考,具体内容如下 完整源码GitHub 使用高斯混合模型(BackgroundSubtractorMOG2)对背景建模,提取出前景 使用中值滤波去掉椒盐噪声,再闭运算和开运算填充空洞 使用cvBlob库追踪车辆,我
本文实例为大家分享了OpenCV实现检测和追踪车辆的具体代码,供大家参考,具体内容如下 完整源码GitHub
由于要对背景建模,这个方法要求背景是静止的 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,MORPH_CLOSE,getStructuringElement(MORPH_RECT,Size(5,5))); // fill black holes morphologyEx(fgMaskMOG2,MORPH_OPEN,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); } } } 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |