说明
很多代码比较老了,这里是目前教新的版本,OpenCV2.4.10或者OpenCV3.X
人眼睛检测
效果

要求
opencv\sources\data\haarcascades复制haarcascade_eye.xml到项目代码目录中
代码
/*
检测人脸并根据人脸的位置图片进行切割
*/
//头文件
#include<opencv2/objdetect/objdetect.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<opencv2/imgproc/imgproc.hpp>
#include<iostream>
using namespace cv;
using namespace std;
//人脸检测的类
CascadeClassifier eyeCascade;
int main()
{
eyeCascade.load("haarcascade_eye.xml"); //加载分类器,注意文件路径
Mat img = imread("F:/test5.jpg");
Mat imgGray;
vector<Rect> eyes;
if (img.empty())
{
return 1;
}
cvtColor(img, imgGray, CV_RGB2GRAY);
eyeCascade.detectMultiScale(imgGray, eyes, 1.1, 6, 0, Size(10, 10)); //检测人脸
if (eyes.size()>0)
{
for (int i = 0; i<eyes.size(); i++)
{
rectangle(img, Point(eyes[i].x, eyes[i].y), Point(eyes[i].x + eyes[i].width, eyes[i].y + eyes[i].height),
Scalar(0, 255, 0), 1, 8); //框出人脸位置
}
}
imshow("Img", img);
waitKey(0);
return 0;
}
网友评论