基于face_recognition进行人脸关键点检测(1)

1. face_recognition 使用世界上最简单的人脸识别工具,它使用dlib最先进的人脸识别技术构建而成,并具有深度学习功能。

1Github 地址:https://github.com/ageitgey/face_recognition

2)官方指南:https://face-recognition.readthedocs.io/en/latest/readme.html

3)源码实现:https://face-recognition.readthedocs.io/en/latest/face_recognition.html

# 1 加入库
import face_recognition
import cv2
import matplotlib.pyplot as plt

# 2 方法:显示图片
def show_image(image, title):
    plt.title(title)
    plt.imshow(image)
    plt.axis("off")

# 3 方法:绘制Landmars关键点
def show_landmarks(image, landmarks):
    for landmarks_dict in landmarks: #取出列表中的一个字典
        for landmarks_key in landmarks_dict.keys(): #获取字典中的键
            for point in landmarks_dict[landmarks_key]: # 获取每个键对应的值/点
                cv2.circle(image, point, 2, (0,0,255), -1) # 画出点
    return image
# 4 主函数
def main():
    # 5 读取图片
    image = cv2.imread("Tom.jpeg")
    # 6 图片灰度转换
    gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
    # 7 调用face_recognition库中的方法:face_landmarks()  检测人脸中的关键点
    face_marks = face_recognition.face_landmarks(gray, None, "large")
    # none 表示不确定人脸所在的位置,自动找。
    # large表示68,small表示5
    print(face_marks) #输出一列表,里面是一个字典,每个点来描述
    # 8 绘制关键点
    img_result = show_landmarks(image.copy(), face_marks)
    # 9 创建画布
    plt.figure(figsize=(9,6))
    plt.suptitle("Face Landmarks with face_recognition", fontsize=14, fontweight="bold")
    # 10 显示整体效果
    show_image(img_result, "landmarks")

    plt.show()

if __name__ == '__main__':
    main()

2.库的安装

         一定要求dlib 19.7.0,而不是根据已有的dlib版本安装相应的face_recognition。这样就可以安装了face_recognition1.3.0,就在pycharm中安装。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码

)">
< <上一篇
下一篇>>