【Python】使用openCV与dlib实现人脸68特征点的检测与手动修改

本文介绍如何在openCV与dlib的人脸识别中,针对特征点定位不准确的问题,实现手动移动特征点的功能。通过保存和修改像素,确保在移动特征点时不损害原始图像。在鼠标交互过程中,当点击的点与特征点足够接近时,选定特征点并允许移动。在主函数中定义了鼠标事件响应,以解决两个接近特征点同时响应的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在使用plib检测人脸特征点的过程中由于各种原因难免会遇到特征点定位不准确的情况。这时,如果能够手动修改来移动特征点的位置,后续工作则可以更好地得以完成。
由于openCV的画图工具会覆盖原来的图片,这里我通过手动保存被修改像素的办法实现移动定位点而不损害原来图像。

代码思路:先获得每个landmark的坐标,将坐标对应的点的像素(一个7 * 7 * 3的array矩阵)保存在IniPointColor 数组中。
在鼠标左键单击时,如果单击位置与某个点足够接近,那么该点被选中,LButtonFirstActionMovingPoint 设为真。
鼠标移动时,若LButtonFirstAction 为真,则将IniPointColor 中对应点的像素覆盖移动前位置的像素,否则庸PreviousPointColor 中的数值覆盖。之后再将新点的像素值保存在PreviousPointColor 中,并在新的位置绘制点。

import sys
import cv2
import dlib
import numpy as np

#定义全局变量
LButtonFirstAction = False
MovingPoint = False
PreviousPosition = (-1, -1)
PreviousPointColor = np.zeros([7, 7, 3])
MovingPNum = -1
IniPointColor = np.zeros([68, 7, 7, 3])

#获取训练模型
predictor_path = "shape_predictor_68_face_landmarks.dat"

#使用官方提供的模型构建特征提取器
predictor = dlib.shape_predictor(predictor_p
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值