《Qt5.9.7 OpenCV 人脸识别》之OpenCV侦测识别人脸

2023-11-11 23:58

本文主要是介绍《Qt5.9.7 OpenCV 人脸识别》之OpenCV侦测识别人脸,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 拷贝OpenCV自己的训练文件

OpenCV的训练文件针对不同场景提供了不同的xml格式训练文件,方便分类器使用,这里采用其中的主要以人脸为主的训练文件haarcascade_frontalface_alt2.xml。

将上上节编译好的构建目录build\install\etc\haarcascades 下的haarcascade_frontalface_alt2.xml文件拷贝到程序执行文件目录。

2 使用级联分类器CascadeClassifier

OpenCV老版本使用CvHaarClassifierCascade函数,老版本的分类器只支持类Haar特征。3.4.5版本是新版本,可以使用CascadeClassifier类训练人脸检测器,CascadeClassifier既可以使用Haar,也可以使用LBP特征。

2.1 创建分类器对象,定义分类器加载成功标识

 
  1. CascadeClassifier m_ccf; //创建分类器对象

  2. bool m_isClassifierLoaded; //分类器加载成功标识

2.2 分类器加载训练文件

定义训练文件

const std::string xmlPath = "haarcascade_frontalface_alt2.xml";

程序启动加载训练文件

m_isClassifierLoaded = m_ccf.load(xmlPath);   //加载训练文件

3 检测人脸

 
  1. void MainWindow::imageShow(const Mat &img, QLabel *label)

  2. {

  3. if(m_isClassifierLoaded) //加载训练文件已成功

  4. {

  5. std::vector<Rect> faces; //创建一个容器保存检测出来的脸

  6. Mat gray;

  7.  
  8. cvtColor(img,gray,CV_BGR2GRAY); //转换成灰度图,因为harr特征从灰度图中提取

  9.  
  10. equalizeHist(gray,gray); //直方图均衡行

  11.  
  12. m_ccf.detectMultiScale(gray,faces,1.1,2,0|CV_HAAR_SCALE_IMAGE, Size(30, 30)); //检测人脸

  13.  
  14. //画方框

  15. for( int i = 0; i < faces.size(); i++ ){

  16. Point centera( faces[i].x, faces[i].y);

  17. Point centerb( faces[i].x + faces[i].width, faces[i].y + faces[i].height );

  18. rectangle(img,centera,centerb,Scalar(255,0,0));

  19.  
  20. }

  21. }

  22.  
  23. image = mat2QImage(img);

  24. image = image.mirrored(true, false); //将图像水平镜像

  25. label->setPixmap(QPixmap::fromImage(image));

  26. }

4 效果图

5 程序源码

程序源码:https://gitee.com/wangzhenglin/facedetection

这篇关于《Qt5.9.7 OpenCV 人脸识别》之OpenCV侦测识别人脸的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/393691

相关文章

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Python如何将OpenCV摄像头视频流通过浏览器播放

《Python如何将OpenCV摄像头视频流通过浏览器播放》:本文主要介绍Python如何将OpenCV摄像头视频流通过浏览器播放的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完... 目录方法1:使用Flask + MJPEG流实现代码使用方法优点缺点方法2:使用WebSocket传输视

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

Python验证码识别方式(使用pytesseract库)

《Python验证码识别方式(使用pytesseract库)》:本文主要介绍Python验证码识别方式(使用pytesseract库),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录1、安装Tesseract-OCR2、在python中使用3、本地图片识别4、结合playwrigh

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y