原文地址:http://blog.youkuaiyun.com/tezhongjunxue/article/details/14648431
对于运动检测的结果,一般都会用到矩形框标出。下面分享一个函数,实现矩形框的绘制。很简单,调用一下即可。
1.先是在程序开始初始化变量,并原型声明。
- CvMemStorage *stor;
- CvSeq *cont;
- void DrawRec(IplImage* pImgFrame,IplImage* pImgProcessed,int MaxArea);
- DrawRec(pImgFrame,pImgProcessed,16);
- void DrawRec(IplImage* pImgFrame,IplImage* pImgProcessed,int MaxArea)
- {
- //pImgFrame:初始未处理的帧,用于最后标出检测结果的输出;
- //pImgProcessed:处理完的帧,用于找运动物体的轮廓
- stor = cvCreateMemStorage(0); //创建动态结构和序列
- cont = cvCreateSeq(CV_SEQ_ELTYPE_POINT, sizeof(CvSeq), sizeof(CvPoint) , stor);
- // 找到所有轮廓
- cvFindContours( pImgProcessed, stor, &cont, sizeof(CvContour),
- CV_RETR_LIST, CV_CHAIN_APPROX_SIMPLE, cvPoint(0,0));
- // 直接使用CONTOUR中的矩形来画轮廓
- for(;cont;cont = cont->h_next)
- {
- CvRect r = ((CvContour*)cont)->rect;
- if(r.height * r.width > MaxArea) // 面积小的方形抛弃掉
- {
- cvRectangle( pImgFrame, cvPoint(r.x,r.y),
- cvPoint(r.x + r.width, r.y + r.height),
- CV_RGB(255,0,0), 1, CV_AA,0);
- }
- }
- cvShowImage("video", pImgFrame);
- }