#include "cv.h"
#include "highgui.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h> //用于防御式编程
#include <math.h>
#include <float.h>//<float.h>与<limits.h>一样是定义边界值的,<float.h>定义的是浮点数的边界值
#include <limits.h>
#include <time.h>
#include <ctype.h>//在调用字符函数时,在源文件中包含的头文件
#ifdef _EiC
#define WIN32
#endif
static CvMemStorage *storage = 0;
static CvHaarClassifierCascade *cascade = 0;//harr 分类器级联的内部标识形式
void detect_and_draw( IplImage *image);
const char *cascade_name = "haarcascade_frontalface_alt2.xml";
int main()
{
CvCapture *capture = 0;
IplImage *frame, *frame_copy = 0;
const char *input_name;
cascade = (CvHaarClassifierCascade*)cvLoad( cascade_name, 0, 0, 0);
if ( !cascade )
{
fprintf( stderr, "ERROR:没有文件\n");
return -1;
}
storage = cvCreateMemStorage(0);//创建内存块
capture = cvCaptureFromCAM(0);//获取摄像头
cvNamedWindow( "人脸识别", 1);//创建格式化窗口
if (capture)
{
//循环从摄像头读出图片进行检测
while(1)
{
//从摄像头或者视频文件中抓取帧
//函数cvQueryFrame从摄像头或者文件中抓取一帧,然后解压并返回这一帧。
//这个函数仅仅是函数cvGrabFrame和函数cvRetrieveFrame在一起调用的组合。返回的图像不可以被用户释放或者修改。
if (!cvGrabFrame( capture )){
break;
}
frame = cvRetrieveFrame( capture ); //获得由cvGrabFrame函数抓取的图片
if (!frame){break;}
if (!frame_copy){
frame_copy = cvCreateImage(cvSize(frame->width,frame->height),IPL_DEPTH_8U,frame->nChannels);
}
//图像原点或者是左上角 (img->origin=IPL_ORIGIN_TL)或者是左下角(img->origin=IPL_ORIGIN_BL)
if (frame->origin == IPL_ORIGIN_TL){
cvCopy (frame, frame_copy, 0);
}
else{
//flip_mode = 0 沿X-轴翻转, flip_mode > 0 (如 1) 沿Y-轴翻转, flip_mode < 0 (如 -1) 沿X-轴和Y-轴翻转.见下面的公式
//函数cvFlip 以三种方式之一翻转数组 (行和列下标是以0为基点的):
cvFlip (frame, frame_copy, 0);//反转图像
}
detect_and_draw( frame_copy ); // 检测并且标识人脸
if(cvWaitKey (10) >= 0)
break;
}
//释放指针
cvReleaseImage( &frame_copy );
cvReleaseCapture( &capture);
}
cvDestroyWindow("人脸识别");
return 0;
}
void detect_and_draw(IplImage *img) //检测和画出人脸的函数体
{
//随机颜色
static CvScalar colors[] =
{
{{0,0,255}},
{{0,128,255}},
{{0,255,255}},
{{0,255,0}},
{{255,128,0}},
{{255,255,0}},
{{255,0,0}},
{{255,0,255}}
};
double scale = 1.3;
IplImage *gray = cvCreateImage(cvSize(img->width,img->height), 8, 1);//灰度图像
IplImage *small_img = cvCreateImage(cvSize(cvRound(img->width/scale),cvRound(img->height/scale)),8, 1);
int i;
cvCvtColor(img, gray, CV_BGR2GRAY);//把输入的彩色图像转化为灰度图像
cvResize(gray, small_img,CV_INTER_LINEAR);//缩小灰色图片
cvEqualizeHist(small_img, small_img);//灰度图象直方图均衡化
cvClearMemStorage(storage);//释放内存块
if (cascade)
{
double t = (double)cvGetTickCount();//精确测量函数的执行时间
//从目标图像small_img中检测出人脸
CvSeq *faces = cvHaarDetectObjects(small_img, cascade,storage,1.1,2,0,cvSize(30, 30));
t = (double)cvGetTickCount() - t; //计算检测到人脸所需时间
printf("检测所用时间 = %gms\n",t/((double)cvGetTickFrequency()*1000.));//打印到屏幕
//画出检测到的人脸外框(可检测到多个人脸)
for (i = 0; i < (faces ? faces->total : 0); i++)
{
//返回索引所指定的元素指针
CvRect *r = (CvRect*)cvGetSeqElem(faces, i);
//用矩形
//确定两个点来确定人脸位置因为用cvRetangle
CvPoint pt1, pt2;
//找到画矩形的两个点
pt1.x = r->x*scale;
pt2.x = (r->x+r->width)*scale;
pt1.y = r->y*scale;
pt2.y = (r->y+r->height)*scale;
//画出矩形
cvRectangle( img, pt1, pt2, colors[i%8], 3, 8, 0 );
}
}
cvShowImage("人脸识别",img);
cvReleaseImage(&gray);
cvReleaseImage(&small_img);
}
分享到:
相关推荐
openCV人脸检测的C++代码
总的来说,"android opencv人脸检测"项目涉及到了Android应用开发、NDK编程、OpenCV库的集成以及计算机视觉中的特征检测技术。通过这样的项目,开发者不仅可以提升Android原生开发能力,还能深入理解计算机视觉领域...
在"OpenCV人脸检测源代码"中,我们可以深入理解如何利用OpenCV来实现高效、准确的人脸检测功能。这个源代码经过调试和实验,其结果表现令人满意,这意味着它具有良好的稳定性和准确性。 人脸检测是计算机视觉领域的...
总的来说,"iOS平台OpenCV人脸检测代码实现"这个项目涉及了iOS应用开发、OpenCV库的集成、计算机视觉中的脸部检测技术以及如何在iOS设备上显示检测结果。这个过程不仅需要掌握Objective-C或Swift编程,还需要理解...
使用的opencv里面的cvHaarDetectObjects函数完成的人脸识别,里面有完整的工程,在vs2010和opencv2.4.9下可以正常运行,里面包括我训练的xml文件和测试用的两个视频,如果你们你们换了其他视频效果不佳,需要自己...
在本文中,我们将深入探讨如何在Visual C++ (VC++)环境下使用OpenCV库进行人脸检测,特别是基于VS2013的项目实现。OpenCV是一个强大的计算机视觉库,提供了多种图像处理和机器学习功能,包括人脸识别。在这个项目中...
在本项目中,"vc++与opencv人脸检测程序"是一个基于C++的计算机视觉应用,利用OpenCV库来实现实时的人脸检测功能。OpenCV(Open Source Computer Vision Library)是一个强大的开源计算机视觉库,它包含了丰富的图像...
二、使用代码进行人脸检测 在实际操作中,我们可以使用以下步骤来实现在OpenCV3中进行人脸检测: 1. 导入必要的库: ```python import cv2 ``` 2. 加载级联分类器: ```python face_cascade = cv2....
在本文中,我们将深入探讨 OpenCV 中基于 Adaboost 的人脸检测算法及其相关代码分析。 Adaboost 是一种机器学习算法,它通过组合多个弱分类器形成一个强分类器。在 OpenCV 的人脸检测中,Adaboost 用于训练一个特征...
在Python中,一个基本的OpenCV人脸检测代码片段可能如下所示: ```python import cv2 # 加载级联分类器 face_cascade = cv2.CascadeClassifier('path/to/haarcascade_frontalface_default.xml') # 读取图像 img =...
"OPenCVDemo"可能是一个项目文件或程序集,包含了C#代码,这些代码实现了OpenCV DNN模块的人脸检测逻辑。 在实现过程中,首先需要加载预训练的面部检测模型,例如,可以使用OpenCV提供的Haar级联分类器或者更现代的...
在"OPENCV_LEARNING"这个压缩包文件中,可能包含了OpenCV的库文件、示例代码、教程文档等资源,帮助你更深入地学习和实践OpenCV的人脸检测功能。通过阅读代码、运行示例并尝试修改参数,你可以更好地掌握OpenCV的...
在这个名为"opencv人脸检测与识别"的项目中,开发者利用OpenCV库实现了人脸检测和人脸识别功能。 首先,人脸检测是计算机视觉中的一个基础任务,主要目标是从图像中定位并提取人脸区域。OpenCV提供了一个名为Haar...
5. **源程序**:"facedetect"可能是项目的主要源代码文件或文件夹,其中包含了实现人脸检测功能的C++代码。这些代码可能包括加载图像、调用OpenCV的级联分类器进行检测、在图像上绘制矩形框标出人脸等步骤。 6. **...
在这个“opencv人脸检测程序源代码”中,我们主要关注的是使用OpenCV进行人脸检测的功能,特别是基于Haar特征的级联分类器。 Haar特征是一种在机器学习领域用于对象检测的技术,由P Viola和J Jones在2001年提出。...
本压缩包中的"opencv人脸识别源码"是针对OpenCV库中人脸识别功能的实现代码,主要用于验证OpenCV库在Python环境下的正确安装和运行。 首先,人脸识别是一项重要的计算机视觉任务,它涉及到人脸检测、特征提取和识别...
- 使用级联分类器进行人脸检测 - 对检测到的人脸区域进行眼睛和嘴巴的定位 - 特征匹配或识别 - 可能的实时性能优化和错误处理 通过仔细研究和理解这些代码,我们可以了解实际应用中的优化技巧,并可能发现进一步...
3. **人脸检测**:使用OpenCV中的Haar级联分类器或者DNN模型(如MTCNN)进行人脸检测,找出图像中的人脸区域。 4. **特征提取**:对检测到的人脸进行特征提取,常用的方法有EigenFace、FisherFace、LBPH等,OpenCV...
OpenCV库为实现AdaBoost提供了接口,这使得开发者能够在VC6.0这样的环境中轻松地进行人脸检测。在OpenCV中,`cv::Boost`类是用于实现AdaBoost的接口,它支持训练和应用决策树的集合。 在人脸检测流程中,通常会使用...
总的来说,这个OpenCV Android demo为我们提供了一个实践计算机视觉技术的起点,涵盖了从基础的人脸检测到复杂的多目标检测和追踪。通过学习和理解这个demo,开发者可以进一步提升自己在Android平台上利用OpenCV进行...