Python 在OpenCV中自动拍照

Python 在OpenCV中自动拍照,python,opencv,face-recognition,Python,Opencv,Face Recognition,我在OpenCV中编写了人脸识别代码。我希望程序在检测到人脸时自动拍照 下面是完整的代码 import cv2 face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml') video = cv2.VideoCapture(0) while True: ret, img = video.read() gray = cv2.cvtColor(img, cv2.COLOR_BGR2G

我在OpenCV中编写了人脸识别代码。我希望程序在检测到人脸时自动拍照

下面是完整的代码

import cv2


face_cascade = 
cv2.CascadeClassifier('haarcascade_frontalface_default.xml')

video = cv2.VideoCapture(0)


while True:
    ret, img = video.read()
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    faces = face_cascade.detectMultiScale(gray, scaleFactor=1.05, 
minNeighbors=5)


for (x,y,w,h) in faces:
    cv2.rectangle(img,(x,y),(x+w,y+h),(0,255,0),2)



cv2.imshow('img',img)
k = cv2.waitKey(1)
if k == ord('q'):
    break

video.release()
cv2.destroyAllWindows()
当你这样做的时候

ret, img = video.read()
你确实拍了一张照片。否则,你就无法检测到该帧中的人脸,是吗

我想你问过关于将帧保存为图像的问题

您只需检查是否存在任何面,然后使用
cv2.imwrite
保存它

以下代码将图像保存在当前目录中,文件名按递增顺序编号:

count = 0
while True:
    ret, img = video.read()
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    faces = face_cascade.detectMultiScale(gray, scaleFactor=1.05, 
minNeighbors=5)


if (len(faces) != 0)
    cv2.imwrite('face_image_%d.png' % count)
    count += 1
可能有更好的方法,但这表明了基本概念