第15课 利用openCV实现人脸识别

2024-01-07 18:29:25

这节课,我们再来看一个简单且实用的例子:人脸识别。这个小例子可以让你进一步领略openCV的强悍。

1.复制demo14并改名为demo15。

2.修改capImg函数:

int fmle::capImg() {
	// 加载人脸检测分类器
	cv::CascadeClassifier faceCascade;
	faceCascade.load("E:\\SDK\\opencv-sdk\\data\\haarcascades\\haarcascade_frontalface_default.xml");
	cv::Mat image;
	image = cv::imread("girl.jpg");
	// 将图像转换为灰度图像
	cv::Mat grayImage;
	cv::cvtColor(image, grayImage, cv::COLOR_BGR2GRAY);

	// 进行人脸检测
	std::vector<cv::Rect> faces;
	faceCascade.detectMultiScale(grayImage, faces, 1.1, 3, 0, cv::Size(30, 30));

	// 在图像上绘制检测到的人脸
	for (const auto& face : faces) {
		cv::rectangle(image, face, cv::Scalar(0, 255, 0), 2);
	}

	mainDlg->drawMatOfPub(image);
	return 0;
}


3.调试运行,当人脸被检测到时会在人脸周围显示绿框。

4.当然也可以实时检测摄像头中的人脸,流程与图片检测差不多,修改capCam函数:

int fmle::capCam() {
?? ?videoCap.open(0);?? ?
?? ?// 加载人脸检测分类器
?? ?cv::CascadeClassifier faceCascade;
?? ?faceCascade.load("E:\\SDK\\opencv-sdk\\data\\haarcascades\\haarcascade_frontalface_default.xml");
?? ?
?? ?while (true)
?? ?{
?? ??? ?cv::Mat image;
?? ??? ?BOOL ifSuccess = videoCap.read(image);

?? ??? ?// 将图像转换为灰度图像
?? ??? ?cv::Mat grayImage;
?? ??? ?cv::cvtColor(image, grayImage, cv::COLOR_BGR2GRAY);

?? ??? ?// 进行人脸检测
?? ??? ?std::vector<cv::Rect> faces;
?? ??? ?faceCascade.detectMultiScale(grayImage, faces, 1.1, 3, 0, cv::Size(30, 30));

?? ??? ?// 在图像上绘制检测到的人脸
?? ??? ?for (const auto& face : faces) {
?? ??? ??? ?cv::rectangle(image, face, cv::Scalar(0, 255, 0), 2);
?? ??? ?}

?? ??? ?mainDlg->drawMatOfPub(image);
?? ??? ?Sleep(40);
?? ?}?? ?
?? ?videoCap.release();
?? ?
?? ?
?? ?return 0;
}

不过,这个算法对长的不太帅或不太漂亮的人脸有时候会失效。

文章来源:https://blog.csdn.net/XiBuQiuChong/article/details/135432779
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。