计算机系统应用教程网站

网站首页 > 技术文章 正文

人脸检测-opencv

btikc 2024-09-05 12:28:55 技术文章 7 ℃ 0 评论


人脸识别是现在几乎所有的APP都在使用的验证操作, 登陆,支付...等等, 我们今天呢先来说一下人脸检测的操作. 使用Python想要完成人脸检测的操作呢, 我们需要准备一个工具, 这个工具就是 opencv

1. opencv的安装

open 开源 computer 计算机 vision 视觉 :开源计算机视觉库, 是由C++
Python胶水语言,粘结其他语言,调用opencv

这个库可以让计算机长眼睛,计算,可以‘看’!

安装操作

pip install opencv-python -i https://pypi.tuna.tsinghua.edu.cn/simple   [opencv库]

pip install opencv-contrib-python -i https://pypi.tuna.tsinghua.edu.cn/simple  [opencv扩展]

pip install numpy -i https://pypi.tuna.tsinghua.edu.cn/simple [numeric python 数字化Python]

安装完毕之后 我们先来简单的使用一下:

2.加载图片

import cv2  # 不是引入opencv   opencv-python对Python封装的接口 都是存在cv2里的

# 读取图片

img = cv2.imread('./timg.jpg')  # 图片的名称不能用汉字
print(img)
'''
三维的数据
    最里层是像素:[颜色值] 每个像素的颜色值
            颜色是由蓝绿红三色调色而成
            [ 83  75  82]
            蓝色  绿色  红色
            每个颜色取值是0-255   值越大 颜色越鲜艳   值越小 颜色就越暗
    中间一层
        每个像素连接出来的宽度
    最外一层
        高度
'''
# 获取图片的像素值      高   宽  像素3个颜色
print(img.shape) # (1392, 959, 3)
shape = img.shape
# 重置图片的大小 会把修改大小的图片
resize_img = cv2.resize(img, dsize=(500, int((500/shape[1]) * shape[0])))  # dsize  宽 高

cv2.imwrite('liqin.jpg', resize_img) # 保存修改大小之后的图片

# 显示图片
cv2.imshow('liqin', resize_img) # 设置显示窗口的名字(不能用中文)  要显示的图片
# 图片显示多长时间后自动关闭
# cv2.waitKey(5000) # 5s后自动关闭   等待5s 键盘输入 如果键盘输入 由键盘输入控制退出  没有输入等待5s自动关闭
# 直到键盘输入才关闭
cv2.waitKey(0) # 0的话就是无限等待  直到键盘输入
# 销毁窗口
cv2.destroyAllWindows()

3.人脸检测之检测一张人脸

我们就借用一下沁沁的照片哈

'''
进行人脸检测时
    根据人脸的特征
    haar抽取图片中的特征方式
    把特征数据封装在文件中
        python环境的安装包 ---》lib ---> site-packages --- cv2 --- data
    将特征文件存放在于当前的py文件相同的目录下
'''
import cv2

img = cv2.imread('./liqin.jpg')
# 根据特征文件生成一个人脸检测器
face_detector = cv2.CascadeClassifier('./haarcascade_frontalface_alt.xml')
# 检测图片中的人脸
face_zones = face_detector.detectMultiScale(img)
print(face_zones)
# [[201  91  96  96]]  二维的
'''
[201  91  96  96] 检测到的人脸区域
  x    y   宽  高
因为一张图片中可能包含好几个人脸 每个人脸都是一维的数据
'''

# 获取人脸区域
for x, y, w, h in face_zones:
    # 用一个矩形把人脸区域圈起来
    '''
    img, 要圈中的图片 
    pt1, 左上角的坐标点
    pt2, 右下角的坐标点
    color, 线的颜色 [蓝 绿 红]
    thickness=None 线宽
    '''
    cv2.rectangle(img, pt1=(x, y), pt2=(x + w, y + h), color=[0,0,255], thickness=2)


# 显示图片
cv2.imshow('liqin', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

结果为:

4.人脸检测之检测多张人脸

以爱因斯坦参加的索尔维会议照为例

'''
检测多张人脸
'''
import cv2
# 1.读取图片
img = cv2.imread('./suoerwei1.jpg')

# 设置人脸识别器
face_detector = cv2.CascadeClassifier('./haarcascade_frontalface_alt.xml')

# 通过人脸检测器 检测图片中的人脸区域
'''
scaleFactor
    缩放比例  默认是1.3 数据是要大于1 的
    实现人脸检测时 要扫描每个区域  规定的起始尺寸  根据scalefactor进行缩放 
    缩放尺寸越小 检测出来的人脸越多
    
minNeighbors
    最少邻居  如果检测出来一张人脸 需要在人脸附近偏移几次 返回的都是人脸 
    这个才把人脸返回
    值越大 人脸检测要求就越高
'''
face_zones = face_detector.detectMultiScale(img, scaleFactor=1.02, minNeighbors=6)
print(face_zones)

# 圈中人脸
for x, y, w, h in face_zones:
    cv2.rectangle(img, pt1=(x, y), pt2=(x+w, y+h), color=[0,0,255],thickness=2)

# 显示图片
cv2.imshow('suoerwei', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

结果为:

注意:在做人脸检测时, 检测出来的人脸与图片的像素清晰度也是有关系的, 模糊的图片检测的话会有误差的

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表