Opencv学习1.人脸识别模块

Modules:
把模块放在一起就变成了一个包或者一个库
在模块内我们可以实现很多功能 比如查找颜色,找到x,y位置等等
在这里插入图片描述

在Main Code中,我们调用模块里面的内容

下面进入正题:

重要的函数:
在官网下载haarcascade_frontalface_default.xml 这是检测人脸的数据集

导入具有检测信息的文件:

cv2.CascadeClassifier("haarcascade_frontalface_default.xml的目录文件")

设置检测的多个尺度

.detectMultiScale(img,比例因子,最小领域)

将检测的内容在图片中画出来(这里是矩形框,颜色厚度可自己修改):

for (x,y,w,h) in objects:
        cv2.rectangle(imgObjects,(x,y),(x+w,y+h),(255,0,255),2) 

开始我们的模块编写:

import cv2

'''
人脸识别模块
'''
def FindObjects(img, objectCascade, scaleF=1.1, k=4):
	imgObjects = img.copy()
	imgGray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) #将图片灰度化
	objects = objectCascade.detectMultiScale(imgGray,scaleF,k)
	for (x,y,w,h) in objects:
        cv2.rectangle(imgObjects,(x,y),(x+w,y+h),(255,0,255),2)
    return imgObjects, objects
'''

我们来调用我们的模块:

def main():
    img = cv2.imread("你的图片路径")
    img = cv2.resize(img,(600,600))
    faceCascade = cv2.CascadeClassifier("你的haarcascade_frontalface_default.xml路径")
    imgObjects, objects = findObjects(img,faceCascade)
    cv2.imshow("Output",imgObjects)
    cv2.waitKey(0)

if __name__ == "__main__":
    main()


好的彭于晏真帅

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Esaka7

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值