我在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()
答案 0 :(得分:1)
完成时
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
可能有更好的方法,但这显示了基本概念。