直接上代码:
import numpy as np
import cv2
path = 'C:\\Users\\XDM\\AppData\\Local\\Programs\\Python\\Python38\\Lib\\site-packages\\cv2\\data\\'
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
face_cascade.load(path + 'haarcascade_frontalface_default.xml')
eye_cascade = cv2.CascadeClassifier('haarcascade_eye.xml')
eye_cascade.load(path + 'haarcascade_eye.xml')
face_smile = cv2.CascadeClassifier('haarcascade_smile.xml')
face_smile.load(path + 'haarcascade_smile.xml')
camera = cv2.VideoCapture(0, cv2.CAP_DSHOW)
cv2.namedWindow('Dynamic')
while (True):
# 读取一帧图像
ret, frame = camera.read()
if ret:
# 可以用一张图片,也可以通过摄像头直接动态检测,自行修改即可
# frame = cv2.imread('D:\\1.png')
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) # 将图片转化成灰度
faces = face_cascade.detectMultiScale(gray, 1.3, 5)
for (x, y, w, h) in faces:
frame = cv2.rectangle(frame, (x, y), (x + w, y + h), (255, 0, 0), 2)
roi_gray = gray[y:y + h, x:x + w]
roi_color = frame[y:y + h, x:x + w]
eyes = eye_cascade.detectMultiScale(roi_gray)
smiles = face_smile.detectMultiScale(roi_gray)
for (ex, ey, ew, eh) in eyes:
cv2.rectangle(roi_color, (ex, ey), (ex + ew, ey + eh), (0, 255, 0), 2)
for (ex, ey, ew, eh) in smiles:
cv2.rectangle(roi_color, (ex, ey), (ex + ew, ey + eh), (255, 255, 255), 2)
cv2.imshow('Dynamic', frame)
# 按下q键退出
if cv2.waitKey(100) & 0xff == ord('q'):
break
camera.release()
cv2.destroyAllWindows()
直接用的opencv库
感觉库都比较久了,后续找个深度学习的试试效果