• opencv 人脸识别,并抓拍


    1. # -*- coding: utf-8 -*-
    2. import cv2
    3. import imutils
    4. from crop_img import crop_and_save_image
    5. import datetime
    6. # 加载摄像头
    7. cap = cv2.VideoCapture(0)
    8. # 创建人脸检测器
    9. face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
    10. # 初始化人数计数器
    11. num_people = 0 # 画面中人的数量
    12. init_people = 0 #
    13. all_people = 0 # 整个视频中出现的人的数量
    14. i = datetime.datetime.now() # 现在的时间
    15. i_pre = i.second-4 # 避免重复检测的参照时间
    16. while True:
    17. # 读取摄像头数据
    18. ret, frame = cap.read()
    19. # 调整图像大小
    20. frame = imutils.resize(frame, width=500)
    21. # 转换为灰度图像
    22. gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    23. # 检测人脸
    24. faces = face_cascade.detectMultiScale(gray, 1.3, 3)
    25. i = datetime.datetime.now()
    26. # 绘制人脸矩形框
    27. for (x, y, w, h) in faces:
    28. # 当画面中的检测到的人脸有变化时才进行抓拍人脸
    29. if init_people != len(faces):
    30. # print("second*********:", i.second, i_pre)
    31. # 拍判断画面中人脸数变化是否大于2秒,若大于进行新的抓拍,否则则认为为检测抖动不抓拍
    32. if abs(i.second - i_pre) % 60 > 2:
    33. # print("second:", i.second, i_pre)
    34. # 总人数加1
    35. all_people += 1
    36. # print("faces:", len(faces))
    37. # print("hhhhhhhhhhhh")
    38. # 进行抓拍人脸
    39. cropped_image = crop_and_save_image(frame, int(x*0.9), int(y*0.9), int(w*1.4), int(h*1.4)) # 裁剪人脸
    40. else:
    41. # 校验画面人数
    42. init_people = len(faces)
    43. # 绘制人脸检测框
    44. cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
    45. # 当 faces中的人脸序列全部检测完,才进行更新init_people与i_pre
    46. # 更新重复检测时间,校验画面人数
    47. if len(faces) != 0:
    48. i_pre = datetime.datetime.now().second # 获取当前的时间
    49. init_people = len(faces)
    50. if len(faces) == 0:
    51. # i_pre = datetime.datetime.now().second
    52. init_people = 0
    53. # 更新人数计数器
    54. num_people = len(faces)
    55. # 在图像上显示人数
    56. cv2.putText(frame, "Number of People: {}".format(num_people), (10, 30), cv2.FONT_HERSHEY_SIMPLEX, 0.7, (0, 0, 255),
    57. 2)
    58. # 显示图像
    59. cv2.imshow('frame', frame)
    60. # 按下q键退出
    61. if cv2.waitKey(1) & 0xFF == ord('q'):
    62. break
    63. print(all_people)
    64. # 释放摄像头并关闭窗口
    65. cap.release()
    crop_and_save_image 函数:
    1. import cv2
    2. import os
    3. import datetime
    4. def crop_and_save_image(image, x, y, width, height):
    5. """
    6. :param image: 图片
    7. :param x: 裁剪区域的左上角 x 坐标
    8. :param y: 裁剪区域的左上角 y 坐标
    9. :param width: 裁剪区域的宽度
    10. :param height: 裁剪区域的高度
    11. """
    12. # 裁剪图片
    13. cropped_image = image[y:y+height, x:x+width]
    14. # 显示裁剪的图片
    15. cv2.imshow('cropped_image', cropped_image)
    16. # 保存文件夹
    17. output_folder = '../imag/'
    18. save_name = '{}m{}s.jpg'
    19. # 创建文件夹,如果不存在,则创建
    20. os.makedirs(output_folder, exist_ok=True)
    21. i = datetime.datetime.now() # 获取当前的时间
    22. # 拼接保存地址 -- 注意: format中不能存在中文字符,负责无法保存
    23. output_path = os.path.join(output_folder, save_name.format(i.minute, i.second))
    24. # 将当前检测时间信息打印在保存的图片上
    25. 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),
    26. 2)
    27. # 保存当前抓拍到的人脸图片
    28. cv2.imwrite(output_path, cropped_image)

  • 相关阅读:
    java/php/python/nodejs+vue景区失物招领网站平台
    HTML基础
    C++语法——指针和引用
    Typora收费后我换了个Markdown编辑器(Marktext)
    【Sqoop】数据导入导出到Hive问题总结
    Docker基础:Docker安装及镜像加速配置
    数据资产入表-数据治理-标签设计标准
    C++ 享元模式
    目标检测算法——工业缺陷数据集汇总1(附下载链接)
    MediaPlayer
  • 原文地址:https://blog.csdn.net/m0_55674689/article/details/134055403