opencv 人脸识别,并抓拍

python 复制代码
# -*- 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)
                # 总人数加1
                all_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().second
        init_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 函数:
python 复制代码
import cv2
import os
import datetime

def 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)
相关推荐
hans汉斯6 分钟前
【计算机科学与应用】基于多光谱成像与边缘计算的物流安全风险预警模式及系统实现
大数据·数据库·人工智能·设计模式·机器人·边缘计算·论文笔记
aneasystone本尊6 分钟前
深入 Dify 的应用运行器之知识库检索(续)
人工智能
许泽宇的技术分享15 分钟前
Windows MCP.Net:解锁AI助手的Windows桌面自动化潜能
人工智能·windows·.net·mcp
从后端到QT20 分钟前
大语言模型本地部署之转录文本总结
人工智能·语言模型·自然语言处理
AI新兵24 分钟前
AI大事记13:GPT 与 BERT 的范式之争(上)
人工智能·gpt·bert
文火冰糖的硅基工坊25 分钟前
[人工智能-大模型-43]:模型层技术 - 强化学学习:学习的目标、收敛条件、评估依据、应用到的模型、应用场景 - 通俗易懂。
人工智能·学习
Fibocom广和通33 分钟前
禾赛科技与广和通战略合作,联合推出机器人解决方案加速具身智能商业化落地
人工智能
飞哥数智坊33 分钟前
Claude Skills 自定义实战:提炼会议纪要并推送企业微信
人工智能·claude·chatglm (智谱)
golang学习记39 分钟前
性能飙升4倍,苹果刚发布的M5给人看呆了
人工智能·后端
golang学习记40 分钟前
快手推出AI编程IDE:自主编程时代已来!
人工智能