python利用dlib获取人脸的68个landmark


Posted in Python onNovember 27, 2019

(1) 单人脸情况

import cv2
import dlib

path = "1.jpg"
img = cv2.imread(path)
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

#人脸检测画框
detector = dlib.get_frontal_face_detector()
# 获取人脸关键点检测器
predictor = dlib.shape_predictor("shape_predictor_68_face_landmarks.dat")
#获取人脸框位置信息
dets = detector(gray, 1)#1表示采样(upsample)次数 0识别的人脸少点,1识别的多点,2识别的更多,小脸也可以识别
for face in dets:
  shape = predictor(img, face) # 寻找人脸的68个标定点
  # 遍历所有点,打印出其坐标,并圈出来
  for pt in shape.parts():
    pt_pos = (pt.x, pt.y)
    cv2.circle(img, pt_pos, 2, (0, 0, 255), 1)#img, center, radius, color, thickness

  cv2.imshow("image", img)

cv2.waitKey(0)
cv2.destroyAllWindows()

(2) 多人脸情况

import cv2
import dlib

path1 = "zxc.jpg"
img = cv2.imread(path1)
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

#人脸检测画框
detector = dlib.get_frontal_face_detector()
# 获取人脸关键点检测器
predictor = dlib.shape_predictor("shape_predictor_68_face_landmarks.dat")
#获取人脸框位置信息
dets = detector(gray, 1)#1表示采样(upsample)次数 0识别的人脸少点,1识别的多点,2识别的更多,小脸也可以识别

for i in range(len(dets)):
  shape = predictor(img, dets[i]) # 寻找人脸的68个标定点
  # 遍历所有点,打印出其坐标,并圈出来
  for pt in shape.parts():
    pt_pos = (pt.x, pt.y)
    cv2.circle(img, pt_pos, 2, (0, 0, 255), 1)#img, center, radius, color, thickness

cv2.imshow("image", img)

cv2.waitKey(0)#等待键盘输入
cv2.destroyAllWindows()

(3) 获取电脑摄像头实时识别标定

import cv2
import dlib
import numpy as np

cap = cv2.VideoCapture(0)#打开笔记本的内置摄像头,若参数是视频文件路径则打开视频
cap.isOpened()

def key_points(img):
  points_keys = []
  PREDICTOR_PATH = "shape_predictor_68_face_landmarks.dat"
  detector = dlib.get_frontal_face_detector()
  predictor = dlib.shape_predictor(PREDICTOR_PATH)
  rects = detector(img,1)

  for i in range(len(rects)):
    landmarks = np.matrix([[p.x,p.y] for p in predictor(img,rects[i]).parts()])
    for point in landmarks:
      pos = (point[0,0],point[0,1])
      points_keys.append(pos)
      cv2.circle(img,pos,2,(255,0,0),-1)
  return img

while(True):
  ret, frame = cap.read()#按帧读取视频,ret,frame是cap.read()方法的两个返回值。其中ret是布尔值,如果读取帧是正确的则返回True,如果文件读取到结尾,它的返回值就为False。frame就是每一帧的图像,是个三维矩阵。
  # gray = cv2.cvtColor(frame)
  face_key = key_points(frame)
  cv2.imshow('frame',face_key)
  if cv2.waitKey(1) & 0xFF == ord('q'):
    break

cap.release()#释放摄像头
cv2.destroyAllWindows()#关闭所有图像窗口

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python 返回汉字的汉语拼音
Feb 27 Python
Python自动化运维和部署项目工具Fabric使用实例
Sep 18 Python
python3+PyQt5重新实现自定义数据拖放处理
Apr 19 Python
Python eval的常见错误封装及利用原理详解
Mar 26 Python
Python PyCharm如何进行断点调试
Jul 05 Python
pytorch中如何使用DataLoader对数据集进行批处理的方法
Aug 06 Python
Python获取统计自己的qq群成员信息的方法
Nov 15 Python
django框架使用views.py的函数对表进行增删改查内容操作详解【models.py中表的创建、views.py中函数的使用,基于对象的跨表查询】
Dec 12 Python
利用Python实现Json序列化库的方法步骤
Sep 09 Python
python 多进程和协程配合使用写入数据
Oct 30 Python
详解python os.path.exists判断文件或文件夹是否存在
Nov 16 Python
yolov5返回坐标的方法实例
Mar 17 Python
python随机数分布random均匀分布实例
Nov 27 #Python
python取均匀不重复的随机数方式
Nov 27 #Python
python中栈的原理及实现方法示例
Nov 27 #Python
关于Numpy数据类型对象(dtype)使用详解
Nov 27 #Python
python队列原理及实现方法示例
Nov 27 #Python
Python numpy.zero() 初始化矩阵实例
Nov 27 #Python
python双端队列原理、实现与使用方法分析
Nov 27 #Python
You might like
重置版宣传动画
2020/04/09 魔兽争霸
PHP之预定义接口详解
2015/07/29 PHP
CI框架(CodeIgniter)公共模型类定义与用法示例
2017/08/10 PHP
详解PHP字符串替换str_replace()函数四种用法
2017/10/13 PHP
PHP 超级全局变量相关总结
2020/06/30 PHP
jQuery hover 延时器实现代码
2011/03/12 Javascript
js动态调用css属性的小规律及实例说明
2013/12/28 Javascript
实例说明为什么不要行内使用javascript
2014/04/18 Javascript
js操作输入框中选择内容兼容IE及其他主流浏览器
2014/04/22 Javascript
JavaScript设计模式初探
2016/01/07 Javascript
简单理解vue中el、template、replace元素
2016/10/27 Javascript
Javascript实现倒计时时差效果
2017/05/18 Javascript
angular框架实现全选与单选chekbox的自定义
2017/07/06 Javascript
angularJs在多个控制器中共享服务数据的方法
2018/09/30 Javascript
vue-cli3.0+element-ui上传组件el-upload的使用
2018/12/03 Javascript
JavaScript 九种跨域方式实现原理
2019/02/11 Javascript
Vue实现table上下移动功能示例
2019/02/21 Javascript
jQuery zTree树插件的使用教程
2019/08/16 jQuery
[56:48]FNATIC vs EG 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
python 查找文件夹下所有文件 实现代码
2009/07/01 Python
Python的print用法示例
2014/02/11 Python
python统计文本字符串里单词出现频率的方法
2015/05/26 Python
python实现音乐下载的统计
2018/06/20 Python
使用TensorFlow实现SVM
2018/09/06 Python
Python实现的远程文件自动打包并下载功能示例
2019/07/12 Python
python 实现网易邮箱邮件阅读和删除的辅助小脚本
2021/03/01 Python
css3 条纹化和透明化表格Firefox下测试成功
2014/04/15 HTML / CSS
如何处理简单的PHP错误
2015/10/14 面试题
行政部总经理岗位职责
2014/01/04 职场文书
岗位竞聘书范文
2014/03/31 职场文书
《蜗牛的奖杯》教后反思
2014/04/24 职场文书
财务部绩效考核方案
2014/05/04 职场文书
财务总监岗位职责范本
2015/04/03 职场文书
2015年党员创先争优公开承诺书
2015/04/27 职场文书
经营场所使用证明
2015/06/19 职场文书
2016年大学生暑假爱心支教活动策划书
2015/11/26 职场文书