opencv 人脸识别,并抓拍

2023-10-27 21:01
文章标签 opencv 人脸识别 抓拍

本文主要是介绍opencv 人脸识别,并抓拍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

# -*- coding: utf-8 -*-
import cv2
import imutils
from crop_img import crop_and_save_image
import datetime
# 加载摄像头
cap = cv2.VideoCapture(0)
# 创建人脸检测器
face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')# 初始化人数计数器
num_people = 0  # 画面中人的数量
init_people = 0  #
all_people = 0   # 整个视频中出现的人的数量
i = datetime.datetime.now()   # 现在的时间
i_pre = i.second-4    # 避免重复检测的参照时间
while True:# 读取摄像头数据ret, frame = cap.read()# 调整图像大小frame = imutils.resize(frame, width=500)# 转换为灰度图像gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)# 检测人脸faces = face_cascade.detectMultiScale(gray, 1.3, 3)i = datetime.datetime.now()# 绘制人脸矩形框for (x, y, w, h) in faces:# 当画面中的检测到的人脸有变化时才进行抓拍人脸if init_people != len(faces):# print("second*********:", i.second, i_pre)# 拍判断画面中人脸数变化是否大于2秒,若大于进行新的抓拍,否则则认为为检测抖动不抓拍if abs(i.second - i_pre) % 60 > 2:# print("second:", i.second, i_pre)# 总人数加1all_people += 1# print("faces:", len(faces))# print("hhhhhhhhhhhh")# 进行抓拍人脸cropped_image = crop_and_save_image(frame, int(x*0.9), int(y*0.9), int(w*1.4), int(h*1.4))  # 裁剪人脸else:# 校验画面人数init_people = len(faces)# 绘制人脸检测框cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)# 当 faces中的人脸序列全部检测完,才进行更新init_people与i_pre# 更新重复检测时间,校验画面人数if len(faces) != 0:i_pre = datetime.datetime.now().second  # 获取当前的时间init_people = len(faces)if len(faces) == 0:# i_pre = datetime.datetime.now().secondinit_people = 0# 更新人数计数器num_people = len(faces)# 在图像上显示人数cv2.putText(frame, "Number of People: {}".format(num_people), (10, 30), cv2.FONT_HERSHEY_SIMPLEX, 0.7, (0, 0, 255),2)# 显示图像cv2.imshow('frame', frame)# 按下q键退出if cv2.waitKey(1) & 0xFF == ord('q'):break
print(all_people)
# 释放摄像头并关闭窗口
cap.release()
crop_and_save_image 函数:
import cv2
import os
import datetimedef crop_and_save_image(image, x, y, width, height):""":param image:  图片:param x:      裁剪区域的左上角 x 坐标:param y:      裁剪区域的左上角 y 坐标:param width:  裁剪区域的宽度:param height: 裁剪区域的高度"""# 裁剪图片cropped_image = image[y:y+height, x:x+width]# 显示裁剪的图片cv2.imshow('cropped_image', cropped_image)# 保存文件夹output_folder = '../imag/'save_name = '{}m{}s.jpg'# 创建文件夹,如果不存在,则创建os.makedirs(output_folder, exist_ok=True)i = datetime.datetime.now()  # 获取当前的时间# 拼接保存地址  -- 注意: format中不能存在中文字符,负责无法保存output_path = os.path.join(output_folder, save_name.format(i.minute, i.second))# 将当前检测时间信息打印在保存的图片上cv2.putText(cropped_image, "{}/{}/{} {}:{}:{}".format(i.year, i.month, i.day, i.hour, i.minute, i.second), (20, 15), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 200, 0),2)# 保存当前抓拍到的人脸图片cv2.imwrite(output_path, cropped_image)

这篇关于opencv 人脸识别,并抓拍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

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

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

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

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj