OpenCv高阶(二十)——dlib脸部轮廓绘制

文章目录

  • 一、人脸面部轮廓绘制代码实现
    • 1、定义绘制直线段的函数
    • 2、定义绘制凸包轮廓的函数
    • 3、读取输入图像
    • 4、初始化dlib的人脸检测器
    • 5、使用检测器在图像中检测人脸(参数0表示不进行图像缩放)
    • 6、加载dlib的68点人脸关键点预测模型
    • 7、遍历检测到的每个人脸
    • 8、显示处理后的图像
  • 总结


一、人脸面部轮廓绘制代码实现

import numpy as np
import dlib
import cv2

1、定义绘制直线段的函数

def drawLine(start, end):# 从形状数组中获取起点到终点的所有点pts = shape[start:end]# 遍历这些点,依次连接相邻点for l in range(1, len(pts)):# 获取前一个点ptsA = tuple(pts[l-1])# 获取当前点ptsB = tuple(pts[l])# 在图像上绘制连接这两个点的绿色线段cv2.line(image, ptsA, ptsB, (0, 245, 0), 2)

2、定义绘制凸包轮廓的函数

def drawConvexHull(start, end):# 从形状数组中获取指定范围内的点Facial = shape[start:end+1]# 计算这些点的凸包(最小凸多边形)mouthHull = cv2.convexHull(Facial)   # 凸包函数# 在图像上绘制凸包轮廓(绿色)cv2.drawContours(image, [mouthHull], -1, (0, 255, 0), 2)

3、读取输入图像

image = cv2.imread('../data/man.png')

4、初始化dlib的人脸检测器

detector = dlib.get_frontal_face_detector()

5、使用检测器在图像中检测人脸(参数0表示不进行图像缩放)

faces = detector(image, 0)

6、加载dlib的68点人脸关键点预测模型

predictor = dlib.shape_predictor('../data/shape_predictor_68_face_landmarks.dat')

7、遍历检测到的每个人脸

for face in faces:# 对当前人脸进行关键点预测shape = predictor(image, face)# 将关键点转换为numpy数组格式 [[x1, y1], [x2, y2], ...]shape = np.array([[p.x, p.y] for p in shape.parts()])# 绘制右眼凸包(关键点36-42)drawConvexHull(36, 42)# 绘制左眼凸包(关键点42-47)drawConvexHull(42, 47)# 绘制上嘴唇凸包(关键点48-59)drawConvexHull(48, 59)# 绘制下嘴唇凸包(关键点60-67)drawConvexHull(60, 67)# 绘制下巴轮廓(关键点0-17)drawLine(0, 17)# 绘制右眉毛轮廓(关键点17-22)drawLine(17, 22)# 绘制左眉毛轮廓(关键点22-27)drawLine(22, 27)# 绘制鼻梁轮廓(关键点27-36)drawLine(27, 36)

8、显示处理后的图像

cv2.imshow('image', image)
# 等待用户按键
cv2.waitKey(0)
# 关闭所有OpenCV窗口
cv2.destroyAllWindows()

效果展示
在这里插入图片描述

代码中使用的关键点索引对应人脸的不同部位:
在这里插入图片描述

眼睛区域:

36-42:右眼轮廓(从右眼角开始顺时针)42-47:左眼轮廓(从左眼角开始顺时针)

嘴唇区域:

48-59:上嘴唇轮廓60-67:下嘴唇轮廓

面部轮廓:

0-16:下巴和脸颊轮廓(代码中绘制0-17,包含17个点)17-21:右眉毛22-26:左眉毛27-35:鼻子(代码中绘制27-36)

函数功能说明
drawLine(start, end) 函数:

功能:连接一系列关键点形成直线段参数:起始索引和结束索引实现:获取索引范围内的点,依次连接相邻点

drawConvexHull(start, end) 函数:

功能:计算并绘制关键点的凸包轮廓参数:起始索引和结束索引实现:计算最小凸多边形并绘制轮廓优势:比简单连线更平滑,能更好捕捉曲线特征

总结

这种组合方法(凸包+直线连接)在保持效率的同时,能够准确描绘人脸的主要特征轮廓,适用于人脸分析、AR滤镜等应用场景。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/web/82138.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WEBSTORM前端 —— 第3章:移动 Web —— 第3节:移动适配

目录 一、移动Web基础 1.谷歌模拟器 2.屏幕分辨率 3.视口 4.二倍图 二、适配方案 三、rem 适配方案 四、less 1.less – 简介 2.less – 注释 3.less – 运算 4.less – 嵌套 5.less – 变量 6.less – 导入 7.less – 导出 8.less – 禁止导出 五…

Altium Disigner(16.1)学习-原理图绘制以及必要操作

一、下载软件 通过网盘分享的文件:Altium Designer 16.zip 链接: https://pan.baidu.com/s/1uBHeoJJ-iA2tXw3NRjCcdA?pwd7c3h 提取码: 7c3h 复制这段内容后打开百度网盘手机App,操作更方便哦 --来自百度网盘超级会员v5的分享 二、建立工程 添加proje…

AI炼丹日志-25 - OpenAI 开源的编码助手 Codex 上手指南

点一下关注吧!!!非常感谢!!持续更新!!! Java篇: MyBatis 更新完毕目前开始更新 Spring,一起深入浅出! 大数据篇 300: Hadoop&…

Redis:安装与常用命令

🌈 个人主页:Zfox_ 🔥 系列专栏:Redis 🔥 安装 Redis 使⽤apt安装 apt install redis -y⽀持远程连接 修改 /etc/redis/redis.conf 修改 bind 127.0.0.1 为 bind 0.0.0.0 修改 protected-mode yes 为 protected-mo…

02 APP 自动化-Appium 运行原理详解

环境搭建见 01 APP 自动化-环境搭建 文章目录 一、Appium及Appium自动化测试原理二、Appium 自动化配置项三、常见 ADB 命令四、第一个 app 自动化脚本 一、Appium及Appium自动化测试原理 Appium 跨平台、开源的 app 自动化测试框架,用来测试 app 应用程序&#x…

UDP/TCP协议全解

目录 一. UDP协议 1.UDP协议概念 2.UDP数据报格式 3.UDP协议差错控制 二. TCP协议 1.TCP协议概念 2.三次握手与四次挥手 3.TCP报文段格式(重点) 4.流量控制 5.拥塞控制 一. UDP协议 1.UDP协议概念 当应用层的进程1要向进程2传输报文&#xff…

AWS之数据分析

目录 数据分析产品对比 1. Amazon Athena 3. AWS Lake Formation 4. AWS Glue 5. Amazon OpenSearch Service 6. Amazon Kinesis Data Analytics 7. Amazon Redshift 8.Amazon Redshift Spectrum 搜索服务对比 核心功能与定位对比 适用场景 关键差异总结 注意事项 …

第13讲、Odoo 18 配置文件(odoo.conf)详细解读

1. 概述 Odoo 配置文件(odoo.conf)是管理 Odoo 服务器行为的核心工具,涵盖了网络、安全、数据库、性能等多方面的关键参数。本文档系统梳理 Odoo 18 配置文件的主要参数,结合实际应用场景,提供权威的配置建议与最佳实…

Python详细实现Dash仪表盘:从零构建数据可视化界面

目录 Python详细实现Dash仪表盘:从零构建数据可视化界面一、引言:为什么选择 Dash?二、Dash 的核心组成与工作流程三、项目目标使用数据: 四、数学模型与聚合公式五、仪表盘结构设计页面设计结构如下: 六、完整代码实现…

ubuntu磁盘挂载

在 Ubuntu 系统中,挂载额外的磁盘或分区是一项常见操作,无论是为了扩展存储空间还是组织数据。本文将详细介绍如何使用mount命令挂载文件系统,并处理可能遇到的问题。 1、挂载文件系统的基本步骤 1.1、 查找磁盘设备名称 首先需要确定要挂载…

[9-2] USART串口外设 江协科技学习笔记(9个知识点)

1 2 3 智能卡、IrDA和LIN是三种不同的通信技术,它们在电子和汽车领域中有着广泛的应用: • 智能卡(Smart Card): • 是什么:智能卡是一种带有嵌入式微处理器和存储器的塑料卡片,可以存储和处理数…

【js逆向_AES】全国二手房指数数据爬取

目标:请求参数signcode,请求结果data。 网址:aHR0cDovL3d3dy5jY2hpbmRleC5jb20vSG9tZS9pbmRleA 查看载荷 查看响应数据 点击xhr,发现所有请求参数都是一个signCode,还是加密后的结果,对应结果中数据data也…

模块化设计,static和extern(面试题常见)

文章目录 一、函数的声明和定义1.1 单个文件1.2 多个文件1.3 static和extern1.3.1 static修饰局部变量1.3.2 static修饰全局变量1.3.3 static修饰函数 总结 一、函数的声明和定义 1.1 单个文件 一般我们在使用函数的时候,直接将函数写出来就使用了 题目:写一个函数…

PySide6 GUI 学习笔记——常用类及控件使用方法(地址类QUrl)

文章目录 地址类QUrl主要功能URL 格式介绍常见 scheme(协议)类型QUrl 类常用方法常用方法示例典型应用场景 地址类QUrl QUrl 是 PySide6.QtCore 模块中的一个类,用于处理和操作 URL(统一资源定位符)。它可以解析、构建…

GEE:获取研究区的DEM数据

最近有粉丝追更 GEE 系列,说上次看完 DEM 代码解析后,自己试着改了一版。今天咱们就来拆解他的优化版代码 ——基于 SRTM 数据获取研究区 DEM 并导出,顺便聊聊怎么把 GEE 代码写得更专业! 先下结论:代码逻辑完整,3 处细节值得新手抄作业! 这版代码在数据加载→裁剪→可…

汽车安全 2030 预测 (功能安全FuSa、预期功能安全SOTIF、网络安全CyberSecurity):成本、效益与行业影响

汽车安全 2030 预测 (功能安全FuSa、预期功能安全SOTIF、网络安全CyberSecurity):成本、效益与行业影响 到 2030 年,汽车行业将迎来一场安全技术的深度变革,其中 “三重安全防护”(功能安全 FuSa、预期功能安全 SOTIF、网络安全&…

深入理解设计模式之状态模式

深入理解设计模式之:状态模式(State Pattern) 一、什么是状态模式? 状态模式(State Pattern)是一种行为型设计模式。它允许一个对象在其内部状态发生改变时,改变其行为(即表现出不…

Redis的大Key问题如何解决?

大家好,我是锋哥。今天分享关于【Redis的大Key问题如何解决?】面试题。希望对大家有帮助; Redis的大Key问题如何解决? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 Redis中的“大Key”问题是指某个键的值占用了过多…

【STM32开发板】接口部分

一、USB接口 可以看到USBP和USBN与PA12,PA11引脚相接,根据协议,需要添加上拉电阻 二、ADC和DAC 根据原理图找到可以作为ADC和DAC的引脚 ADC和DAC属于模拟部分的,所以要接模拟地 三、指示灯电路 找几个通用的引脚,因为单片机的灌电流比拉电流…

[Hackers and Painters] 读书笔记 | 设计模式思想 | LISP

目录 黑客与艺术的关系 “如果你有两个选择,就选择较难的那个“ 金钱不等于财富。创造有价值的东西就是创造财富 项目公式 探讨关于优秀程序员的话题 摘抄 保罗格雷厄姆其人其事 人物经历 图书介绍 个人作品编辑 译者序 为什么书呆子不受欢迎 黑客与画…