1、用opencv自带的人脸检测器进行人脸检测-Haar like adaboost检测
首先下载cascade文件,放到对应文件夹下。
import cv2
#绘制人脸检测框
def plot_rectangle(image, faces):
#faces:图像中人脸的参数,坐标(x,y),width,height
for (x, y, w, h) in faces:
#要绘制矩形的图像,矩形左上坐标,矩形右下坐标,矩形框颜色,边框粗细
cv2.rectangle(image, (x, y), (x + w, y + h), (255, 0, 0), 4)
return image
def main():
# 1 读取摄像头
cap = cv2.VideoCapture(0 + cv2.CAP_DSHOW)
if cap.isOpened() is False:
print('Camera Error!')
# 2 加载级联分类器
face_alt = cv2.CascadeClassifier('haarcascade_frontalface_alt.xml')
# 3 获取视频,对每一帧进行检测
while True:
# 3.1 读取帧
ret, frame = cap.read()
# 3.2 转化为灰度图
if ret:
gray = cv2.cvtColor(frame, cv2.COLOR_RGB2GRAY)
# 3.3 通过加载的级联分类器,对人脸进行检测
face_alt_detection = face_alt.detectMultiScal