import cv2 as cv
import numpy as np
import time
cap = cv.VideoCapture(0)
start = time.time()
counter = 0
fps = cap.get(cv.CAP_PROP_FPS)#视频平均帧率
while True :
ret, frame = cap.read()
# if ret == False :
# break
gray = cv.cvtColor(frame,cv.COLOR_BGR2GRAY)
#实例化检测器
"""
函数说明:
CascadeClassifier(级联分类器):CascadeClassifier是opencv下objdetect模块中用来做目标检测的级联分类器的一个类,
简而言之是滑动窗口机制+级联分类器的方式
load():加载xml级联分类器
"""
face_cas = cv.CascadeClassifier(r"haarcascade_frontalface_default.xml")
face_cas.load(r"haarcascade_frontalface_default.xml")
eyes_cas = cv.CascadeClassifier(r"haarcascade_eye.xml")
eyes_cas.load(r"haarcascade_eye.xml")
#人脸检测
face_rects = face_cas.detectMultiScale(gray,scaleFactor=1.2,minNeighbors=3,minSize=(64,64))
#绘制人脸检测眼睛
for facerect in face_rects:
x,y,w,h = facerect
cv.rectangle(frame,(x,y),(x+w,y+h),(0,255,0),3)
roi_color = frame[y:y+h,x:x+w]
roi_gray = gray[y:y+h,x:x+w]
eyes = eyes_cas.detectMultiScale(roi_gray)
for (ex,ey,ew,eh) in eyes :
cv.rectangle(roi_color,(ex,ey),(ex+ew,ey+eh),(0,255,0),3)
counter += 1 # 计算帧数
# 实时显示帧数
if(time.time()-start) != 0 :
cv.putText(frame, "FPS {0}".format(float('%.1f' % (counter / (time.time() - start)))), (100, 50),
cv.FONT_HERSHEY_SIMPLEX, 1, (0, 0, 255),
3)
cv.imshow("frame",frame)
#cv.namedWindow("frame",0)
counter = 0
start = time.time()
time.sleep(1 / fps) # 按原帧率播放
#按ESC退出
if cv.waitKey(1)&0xff == 27 :
break
cap.release()
cv.destroyAllWindows()#释放并销毁窗口
python图像处理基础项目(二) ——————— 人脸检测(级联分类器)
最新推荐文章于 2023-12-12 00:36:05 发布