本文实例为大家分享了python实现动态人脸捕获的具体代码,供大家参考,具体内容如下
步骤
- 载入cv2
- 捕获摄像头
- 获取第一帧图像
- 定义人脸识别信息
- 开始循环
- 对第一帧图像进行识别
- 标示脸部特征和方框
- 显示帧
- 如果一切正常则读入下一帧
- 循环直至捕获失败
- 如果键入‘q'退出循环
- 循环结束清零
程序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
import cv2 import numpy as np cv2.namedWindow( "Face_Detect" ) #定义一个窗口 cap = cv2.VideoCapture( 0 ) #捕获摄像头图像 success,frame = cap.read() #读入第一帧 classifier = cv2.CascadeClassifier( "C:/opencv-3.3.0/data/haarcascades/haarcascade_frontalface_alt.xml" ) * * #定义人脸识别的分类数据集,需要自己查找,在opencv的目录下,参考上面我的路径** while success: #如果读入帧正常 size = frame.shape[: 2 ] image = np.zeros(size,dtype = np.float16) image = cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY) cv2.equalizeHist(image,image) divisor = 8 h,w = size minSize = ( int (w / divisor), int (h / divisor)) #像素一定是整数,或者用w//divisor faceRects = classifier.detectMultiScale(image, 1.2 , 2 ,cv2.CASCADE_SCALE_IMAGE,minSize) #人脸识别 if len (faceRects)> 0 : for faceRect in faceRects: x,y,w,h = faceRect cv2.circle(frame,(x + w / / 2 ,y + h / / 2 ), min (w / / 2 ,h / / 2 ),( 255 , 0 , 0 ), 2 ) #圆形轮廓 cv2.circle(frame,(x + w / / 4 ,y + 2 * h / / 5 ), min (w / / 8 ,h / / 8 ),( 0 , 255 , 0 ), 2 ) #左眼轮廓 cv2.circle(frame,(x + 3 * w / / 4 ,y + 2 * h / / 5 ), min (w / / 8 ,h / / 8 ),( 0 , 255 , 0 ), 2 ) #右眼轮廓 cv2.circle(frame,(x + w / / 2 ,y + 2 * h / / 3 ), min (w / / 8 ,h / / 8 ),( 0 , 255 , 0 ), 2 ) #鼻子轮廓 cv2.rectangle(frame, (x, y), (x + w, y + h), ( 0 , 0 , 255 ), 2 ) #矩形轮廓 cv2.imshow( "Face_Detect" ,frame) #显示轮廓 success,frame = cap.read() #如正常则读入下一帧 c = chr (key& 255 ) if c in [ 'q' , 'Q' , chr ( 27 )]: #如果键入‘q'退出循环 print ( 'exit' \n) break #退出循环 #循环结束则清零 cap.release() cv2.destroyAllWindows() |
运行后如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/m0_37606112/article/details/78278427