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使用QRCode模块生成二维码实例详解
Jun 14 Python
教你用 Python 实现微信跳一跳(Mac+iOS版)
Jan 04 Python
Python实现检测文件MD5值的方法示例
Apr 11 Python
Python数据分析matplotlib设置多个子图的间距方法
Aug 03 Python
celery4+django2定时任务的实现代码
Dec 23 Python
python 应用之Pycharm 新建模板默认添加编码格式-作者-时间等信息【推荐】
Jun 17 Python
Python基于机器学习方法实现的电影推荐系统实例详解
Jun 25 Python
Python 中的 import 机制之实现远程导入模块
Oct 29 Python
Python如何使用paramiko模块连接linux
Mar 18 Python
解决python打开https出现certificate verify failed的问题
Sep 03 Python
python/golang实现循环链表的示例代码
Sep 14 Python
Python办公自动化之教你如何用Python将任意文件转为PDF格式
Jun 28 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
解析php开发中的中文编码问题
2013/08/08 PHP
PHP加密扩展库Mcrypt安装和实例
2013/11/10 PHP
PHP批量删除、清除UTF-8文件BOM头的代码实例
2014/04/14 PHP
PHP5.5在windows安装使用memcached服务端的方法
2014/04/16 PHP
使用 PHPStorm 开发 Laravel
2015/03/24 PHP
thinkPHP中配置的读取与C方法详解
2016/12/05 PHP
Yii CFileCache 获取不到值的原因分析
2017/02/08 PHP
Aster vs KG BO3 第三场2.18
2021/03/10 DOTA
菜鸟javascript基础整理1
2010/12/06 Javascript
让alert不出现弹窗的两种方法
2014/05/18 Javascript
jquery实现简单手风琴菜单效果实例
2015/06/13 Javascript
拥Bootstrap入怀——导航栏篇
2016/05/30 Javascript
JavaScript新增样式规则(推荐)
2016/07/19 Javascript
微信小程序 wx.uploadFile无法上传解决办法
2016/12/14 Javascript
常用的js方法合集
2017/03/10 Javascript
Three.js获取鼠标点击的三维坐标示例代码
2017/03/24 Javascript
vuejs 单文件组件.vue 文件的使用
2017/07/28 Javascript
js实现拖拽上传图片功能
2017/08/01 Javascript
bootstrap confirmation按钮提示组件使用详解
2017/08/22 Javascript
解析Vue 2.5的Diff算法
2017/11/28 Javascript
微信小程序官方动态自定义底部tabBar的例子
2019/09/04 Javascript
javascript中可能用得到的全部的排序算法
2020/03/05 Javascript
解决Vue 移动端点击出现300毫秒延迟的问题
2020/07/21 Javascript
[01:05:40]2014 DOTA2国际邀请赛中国区预选赛 5 23 CIS VS DT第三场
2014/05/24 DOTA
介绍Python中的__future__模块
2015/04/27 Python
详解常用查找数据结构及算法(Python实现)
2016/12/09 Python
老生常谈Python之装饰器、迭代器和生成器
2017/07/26 Python
python+matplotlib演示电偶极子实例代码
2018/01/12 Python
对numpy 数组和矩阵的乘法的进一步理解
2018/04/04 Python
Python matplotlib 画图窗口显示到gui或者控制台的实例
2018/05/24 Python
python判断输入日期为第几天的实例
2018/11/13 Python
通过实例解析python and和or使用方法
2020/11/14 Python
美国最好的钓鱼、狩猎和划船装备商店:Bass Pro Shops
2018/12/02 全球购物
公文写作:工伤事故分析报告怎么写?
2019/11/05 职场文书
Mysql效率优化定位较低sql的两种方式
2021/05/26 MySQL
virtualenv隔离Python环境的问题解析
2022/06/21 Python