opencv中具有检测人体各部分的级联分类器,在opencv文件夹里面的sources/data/haarcascades里面。

这里要选择的是能够检测人体头像的还有检测眼睛的级联分类器的文件。

它们分别是:

检测头像 haarcascade_frontalface_alt.xml或者haarcascade_frontalface_alt2.xml
检测眼睛 haarcascade_eye.xml或者haarcascade_eye_tree_eyeglasses.xml

检测用的函数是:

cvHaarDetectObjects(CvArr* image,

            CvHaarClassifierCascade *cascade,

            cvMemStorage* storage,

            double scale_factor=1.1,

            int min_neighors=,

            int flags=,

            CvSize min_size=cvSize(,),

            CvSize max_size=cvSize(,)

                                );                        
 image 被检图像
cascade haar 分类器级联的内部标识形式
storage 用来存储检测到的一序列候选目标矩形框的内存区域。
可以通过cvCreateStorage(int block_size)来创建缓冲内存。
当设置block_size=0,默认分配64k的缓冲空间内存块。
 
scale_factor 在前后两次相继的扫描中,搜索窗口的比例系数。
 
min_neighbors 构成检测目标的相邻矩形的最小个数(缺省-1)。
如果组成检测目标的小矩形的个数和小于 min_neighbors-1 都会被排除。
如果min_neighbors 为 0, 则函数不做任何操作就返回所有的被检候选矩形框,
这种设定值一般用在用户自定义对检测结果的组合程序上。
 
flags 操作方式。当前唯一可以定义的操作方式是 CV_HAAR_DO_CANNY_PRUNING。
如果被设定,函数利用Canny边缘检测器来排除一
些边缘很少或者很多的图像区域,因为这样的区域一般不含被检目标。
人脸检测中通过设定阈值使用了这种方法,并因此提高了检测速度。
min_size 检测窗口的最小尺寸。
 
缺省的情况下被设为分类器训练时采用的样本尺寸(人脸检测中缺省大小是~20×20)。
 #define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include"cv.h"
#include"highgui.h"
using namespace cv;
using namespace std; IplImage* Dectimg(IplImage *getimg);
//要将这两个文件的文件路径写清楚或者把他们复制到本项目文件夹里
//检测人眼
//static char *cascade_name = "haarcascade_eye_tree_eyeglasses.xml";
//检测人脸
static char* cascade_name = "haarcascade_frontalface_alt2.xml"; CvHaarClassifierCascade *cascade = ;
int main()
{
//用cvLoad()加载级联分类器文件
cascade = (CvHaarClassifierCascade *)cvLoad(cascade_name); //打开摄像头,读入个人录像
CvCapture* capture = cvCreateCameraCapture(CV_CAP_ANY);
//定义IplImage的指针并且初始化。
IplImage * getfile = cvQueryFrame(capture);
//命名窗口
cvNamedWindow("Result");
//循环读入帧
while ((getfile = cvQueryFrame(capture)) != NULL)
{
//每次读入图像帧后进入检测函数
IplImage *picture = Dectimg(getfile); cvShowImage("Result", picture);
//间隔时间15 us,等待输入按键,如果按键为ESC(这个键的键值为27)就退出。
if (cvWaitKey() == )break;
}
cvWaitKey();
//释放图片指针
cvReleaseImage(&getfile);
//释放读入视频帧的指针
cvReleaseCapture(&capture);
//关闭所有窗口
cvDestroyAllWindows();
return ;
} //检测图片中的目标图像,并且用矩形将目标圈出来
IplImage* Dectimg(IplImage *getimg)
{
//克隆图像
IplImage *img = cvCloneImage(getimg);
double scale = 1.2;
//缩小图像,提高检测速度
IplImage *smallimg = cvCreateImage(cvSize(img->width / scale,img->height/scale),img->depth,img->nChannels);
cvResize(img, smallimg);
//创建单通道图像
IplImage *grayimg = cvCreateImage(cvGetSize(smallimg),smallimg->depth,);
//转换成灰度图像
cvCvtColor(smallimg,grayimg,CV_RGB2GRAY);
//创建缓存
CvMemStorage *storage = ;
storage = cvCreateMemStorage();
//将图像均衡化
cvEqualizeHist(grayimg,grayimg);
cvClearMemStorage(storage);
//检测图像,将会得到目标区域的矩形
CvSeq *objects = cvHaarDetectObjects(grayimg,cascade,storage,scale,,,cvSize(,));
if (objects->total > )
{
/*
for (int i = 0; i < objects->total; i++)
{
CvPoint center;
int radius;
CvRect *rect = (CvRect*)cvGetSeqElem(objects,i);
center.x = (rect->x + rect->width / 2)*scale;
center.y = (rect->y + rect->height / 2)*scale
;
radius = cvRound((rect->width+rect->height)*0.26*scale);
cvCircle(getimg, center, radius, cvScalar(14, 45, 73), 4);
}
*/
for (int i = ; i < objects->total; i++)
{
CvRect *rect = (CvRect*)cvGetSeqElem(objects,i);
cvRectangle(getimg,
cvPoint(cvRound( rect->x*scale),cvRound( rect->y*scale)),
cvPoint(cvRound(1.2*(rect->x+rect->width)),
cvRound(1.2*(rect->y+rect->height))),
cvScalar(,,),);
}
}
else
return NULL;//如果没有检测到目标图像就返回空指针
return getimg;
}

最新文章

  1. 细说SSO单点登录
  2. Shiro 学习笔记(二)——shiro身份验证
  3. Windows 8.1 应用再出发 - 视图状态的更新
  4. JAVA版Kafka代码及配置解释
  5. [译] AlphaGo 的确是一个大事件
  6. 在Linux环境下安装和配置phpmyadmin
  7. phpcms 源码分析一: common.inc.php
  8. /etc/resolv.conf文件详解
  9. phpstorm集成phpunit(转)
  10. CSS 控制应为Html页面高度导致抖动的问题
  11. hdu 4444 Walk (离散化+建图+bfs+三维判重 好题)
  12. iOS 力学动画生成器UIKit Dynamics 之碰撞效果解说
  13. Tomcat访问路径去掉发布项目的项目名称
  14. [LeetCode] Shortest Distance to a Character 到字符的最短距离
  15. requests 可以玩接口自动化测试,爬虫也是可以滴
  16. MySQL 5.6中如何定位DDL被阻塞的问题
  17. GLSL 变量属性
  18. 使用git遇到的一些问题
  19. [Python设计模式] 第9章 如何准备多份简历——原型模式
  20. com.netflix.zuul.exception.ZuulException: Forwarding error

热门文章

  1. gossip版本raft算法实现
  2. wpa_supplicant之eloop_run分析
  3. Java实验二实验报告:java面向对象程序设计
  4. P4编程环境搭建遇到的问题与解决方法
  5. LintCode-50.数组剔除元素后的乘积
  6. 3dContactPointAnnotationTool开发日志(五)
  7. sublime Text3 如何自动排版代码
  8. 为什么 MongoDB (索引)使用B-树而 Mysql 使用 B+树
  9. 第33天:封装自己的class类
  10. 【bzoj1798】[Ahoi2009]Seq 维护序列seq 线段树