代码很短,OpenCv很强大。
import cv2
face_cascade = cv2.CascadeClassifier('F:\img\haarcascade_frontalface_default.xml')
'''
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
faces = face_cascade.detectMultiScale(gray, 1.3, 5)
for (x, y, w, h) in faces:
print(faces)
cv2.rectangle(img, (x, y), (x + w, y + h), (255, 0, 0), 2)
cv2.imshow('img', img)
cv2.imwrite("F:/img/cyt2.jpg", img)
cv2.waitKey()
'''
cap = cv2.VideoCapture(0)
while cap.isOpened:
ret, img = cap.read()
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
faces = face_cascade.detectMultiScale(gray, 1.3, 5)
for (x, y, w, h) in faces:
print("左上角及右下角位置:", [x, y, w, h])
cv2.rectangle(img, (x, y), (x + w, y + h), (0, 255, 0), 2)
cv2.imshow("camera", img)
if cv2.waitKey(30) & 0xFF == ord('q'):
bre
cap.release()
cv2.destroyAllWindows()