harr-cascade检测视频中的目标

#include "cv.h"
#include "highgui.h"
#include <stdio.h>

void displaydetection(IplImage* pInpImg,CvSeq* pFaceRectSeq,char* FileName);

int main(int argc,char** argv)
{
	IplImage* pInpImg=cvCreateImage(cvSize(360,270),8,3);
	CvHaarClassifierCascade* pCascade=0;		//指向后面从文件中获取的分类器
	CvMemStorage* pStorage=0;					//存储检测到的人脸数据
	CvSeq* pFaceRectSeq;						//用来接收检测函数返回的一系列的包含人脸的矩形区域
	IplImage* pImgSrc=NULL;

	//初始化
	CvCapture * capture = cvCaptureFromAVI("0.avi");
	pStorage=cvCreateMemStorage(0);				//创建默认大先64k的动态内存区域
	pCascade=(CvHaarClassifierCascade*)cvLoad("car1.xml");	for(;;)
	{
		pImgSrc = cvQueryFrame(capture);	
		cvResize(pImgSrc,pInpImg);
	//处理图像
	if (!pInpImg||!pStorage||!pCascade)
	{
				printf("initialization failed:%s\n",(!pInpImg)?"can't load image file":(!pCascade)?"can't load haar-cascade---make sure path is correct":"unable to allocate memory for data storage",argv[1]);
				return -1;
			}
			//检测
			pFaceRectSeq=cvHaarDetectObjects(pInpImg,pCascade,pStorage,1.2,2,CV_HAAR_DO_CANNY_PRUNING);//,cvSize(40,40));
//将检测到的人脸以矩形框标出。
displaydetection(pInpImg,pFaceRectSeq,argv[1]);
	}

	cvReleaseImage(&pInpImg);
	cvReleaseHaarClassifierCascade(&pCascade);
	cvReleaseMemStorage(&pStorage);
	return 0;
}

void displaydetection(IplImage* pInpImg,CvSeq* pFaceRectSeq,char* FileName)
{
	int i;
//	cvNamedWindow("haar window",1);

	for (i=0;i<(pFaceRectSeq?pFaceRectSeq->total:0);i++)
	{
		CvRect* r=(CvRect*)cvGetSeqElem(pFaceRectSeq,i);
		CvPoint pt1={r->x,r->y};
		CvPoint pt2={r->x+r->width,r->y+r->height};

		//		cvSetImageROI(pInpImg,*r);
		//		IplImage* dst=cvCreateImage(cvSize(92,112),pInpImg->depth,pInpImg->nChannels);
		//		cvResize(pInpImg,dst,CV_INTER_LINEAR);
		//		cvSaveImage("lian.jpg",dst);
		cvRectangle(pInpImg,pt1,pt2,CV_RGB(0,255,0),3,4,0);
	}
	cvShowImage("haar window",pInpImg);
	//	cvResetImageROI(pInpImg);
	cvWaitKey(1);
	if(pFaceRectSeq->total !=0)
	{
		cvWaitKey(0);
		printf("the number of bigcar is %d\n",pFaceRectSeq->total);
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值