dlib :一个很经典的用于图像处理的开源库,shape_predictor_68_face_landmarks.dat是一个用于人脸68个关键点检测的dat模型库,使用这个模型库可以很方便地进行人脸检测。
【检测人脸5点】
shape_predictor_5_face_landmarks.dat,首先检测人脸5点。
data:image/s3,"s3://crabby-images/994e5/994e59f66824364a371c7f1fdac3d704496fe4ca" alt="【Mind+Python】人脸检测2图1" data:image/s3,"s3://crabby-images/bf1c8/bf1c83a2e8fb704a227f8f67fcda9ce6bbeba3ab" alt="【Mind+Python】人脸检测2图5"
-
- import dlib
- import os
- import cv2
-
-
- predictor_path = "shape_predictor_5_face_landmarks.dat"
- cap = cv2.VideoCapture(0) # 打开摄像头
-
-
- detector = dlib.get_frontal_face_detector()
-
- predicator = dlib.shape_predictor(predictor_path)
- #win = dlib.image_window()
- while cap.isOpened():
- ok, img1 = cap.read()
- if not ok:
- break
-
- dets = detector(img1,1)
- print("Number of faces detected : {}".format(len(dets)))
- for k,d in enumerate(dets):
- print("Detection {} left:{} Top: {} Right {} Bottom {}".format(
- k,d.left(),d.top(),d.right(),d.bottom()
- ))
- lanmarks = [[p.x,p.y] for p in predicator(img1,d).parts()]
- for idx,point in enumerate(lanmarks):
- point = (point[0],point[1])
- cv2.circle(img1,point,5,(0,0,255),-1)
- font = cv2.FONT_HERSHEY_COMPLEX_SMALL
- cv2.putText(img1,str(idx),point,font,0.6,(0,255,0),1,cv2.LINE_AA)
- #对标记点进行递归;
-
- cv2.namedWindow("img",cv2.WINDOW_NORMAL)
- cv2.imshow("img",img1)
- c = cv2.waitKey(1)
- if c & 0xFF == ord('q'):
- break
- cap.release()#释放摄像头并销毁所有窗口
- cv2.destroyAllWindows()
-
-
-
-
-
-
复制代码
【人脸68个关键点】data:image/s3,"s3://crabby-images/ba2bf/ba2bf469a83e25a6033f19207024bf7fc99e8d09" alt="【Mind+Python】人脸检测2图2"
修改:
- predictor_path = "shape_predictor_68_face_landmarks.dat"
复制代码
【文件位置】
shape_predictor_5_face_landmarks.dat,shape_predictor_68_face_landmarks.dat,两文件需放到与py文件同目录下:
data:image/s3,"s3://crabby-images/86ceb/86cebd8231058c8ae38caaf5a4c12f37d3cc5754" alt="【Mind+Python】人脸检测2图3"
【附件】
两文件下载:
http://dlib.net/files/
data:image/s3,"s3://crabby-images/639fe/639fe378685edc2c8a5390722de8cbd6b81f2d76" alt="【Mind+Python】人脸检测2图4"
|