OpenCV+face++实现实时人脸识别解锁功能
作者:TA的个人主页 > 发布时间:2023-03-17 20:10:19
标签:OpenCV,face++,人脸识别,解锁
本文实例为大家分享了OpenCV+face++实现实时人脸识别解锁功能的具体代码,供大家参考,具体内容如下
1.背景
最近做一个小东西,需要登录功能,一开始做的就是普通的密码登录功能,但是之前看到过python可以做人脸识别,所以我就开了下脑洞,能不能实现一个自己的刷脸解锁功能。
2.知识储备
python基础语法
opencv
face++文档
requests库
3.基本思路
准备一张你想要被识别出的人脸照片,后面刷脸就是按照这张照片来识别,如果和照片中是同一个人就解锁,刷脸就是打开摄像头获取电脑面前人的人脸,然后与之前那张照片比对。
4.代码讲解
看下识别的效果:
第一个函数就是打开摄像头并保存图片:
#从摄像头读取图片并保存
def getpicture():
cap = cv2.VideoCapture(0)#打开摄像头
cascade = cv2.CascadeClassifier("E:\OpenCV\sources\data\haarcascades\haarcascade_frontalface_default.xml")#这里是是自己的人脸识别xml路径
while True:
# get a frame
ret, frame = cap.read()#捕获图片
# show a frame
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)#转为灰度图
rect = cascade.detectMultiScale(gray, scaleFactor=1.15, minNeighbors=5, minSize=(5, 5),flags=cv2.cv.CV_HAAR_SCALE_IMAGE) # 使用模板匹配图形
for x, y, z, w in rect:
cv2.rectangle(frame, (x, y), (x + z, y + w), (0, 0, 255), 2)# 函数的参数分别为:图像,左上角坐标,右下角坐标,颜色,宽度
cv2.imshow("capture", frame)
if cv2.waitKey(1) & 0xFF == ord('q'):#按下q拍照
cv2.imwrite("images\client.jpg", frame)#相对路径,储存图片
break
cap.release()
cv2.destroyAllWindows()
第二个函数是将样本图片与摄像头读取的图片上传到face++进行处理,并拿到它的face_token,该函数主要用到的就是requests库与face++的api。
def upload_img(fileDir, oneface=True):
url = '%s/detect?api_key=%s&api_secret=%s' % (
BASE_URL, API_KEY, API_SECRET)
#注意参数名与api文档一致
files = {'image_file': (os.path.basename(fileDir), open(fileDir, 'rb'),
mimetypes.guess_type(fileDir)[0]), }
r = requests.post(url, files=files)
faces = r.json().get('faces')
#print faces
if faces is None:
print('There is no face found in %s' % fileDir)
else:
return faces[0]['face_token']#返回face_token
第三个函数是比较两张图片的face_token:
def compare(face_token1,face_token2):
url = '%s/compare' % BASE_URL
params = BASE_PARAMS
params['face_token1'] = face_token1
params['face_token2'] = face_token2
r = requests.post(url, params)
#print r.status_code
#print r.json()
return r.json().get('confidence')#返回两张照片的相似度
最后判断一下compare()函数的返回值就知道两张图片是不是同一个人了,再程序中加一个判断语句就可以实现基本的解锁功能了。
完整代码:
#! usr/bin/env python
#-*- coding:utf-8 -*-
import requests
import os
import mimetypes #判断文件类型
import cv2
import time
import win32api
import win32con
BASE_URL = "https://api-cn.faceplusplus.com/facepp/v3"
API_KEY = "g_vhMthXCQEzF0gZG5-o0ICNDhr3-80b"
API_SECRET = "2HD5ysubTeZTwo20JJTudY0cvZN1BPLt"
BASE_PARAMS = {
'api_key':'g_vhMthXCQEzF0gZG5-o0ICNDhr3-80b',
'api_secret':'2HD5ysubTeZTwo20JJTudY0cvZN1BPLt'
}
def upload_img(fileDir, oneface=True):
url = '%s/detect?api_key=%s&api_secret=%s' % (
BASE_URL, API_KEY, API_SECRET)
#注意参数名与api文档一致
files = {'image_file': (os.path.basename(fileDir), open(fileDir, 'rb'),
mimetypes.guess_type(fileDir)[0]), }
r = requests.post(url, files=files)
faces = r.json().get('faces')
#print faces
if faces is None:
print('There is no face found in %s' % fileDir)
else:
return faces[0]['face_token']
def compare(face_token1,face_token2):
url = '%s/compare' % BASE_URL
params = BASE_PARAMS
params['face_token1'] = face_token1
params['face_token2'] = face_token2
r = requests.post(url, params)
#print r.status_code
#print r.json()
return r.json().get('confidence')
def getpicture():
cap = cv2.VideoCapture(0)
cascade = cv2.CascadeClassifier("E:\OpenCV\sources\data\haarcascades\haarcascade_frontalface_default.xml")#这里是是自己的人脸识别xml路径
while True:
# get a frame
ret, frame = cap.read()
# show a frame
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
rect = cascade.detectMultiScale(gray, scaleFactor=1.15, minNeighbors=5, minSize=(5, 5),flags=cv2.cv.CV_HAAR_SCALE_IMAGE)
for x, y, z, w in rect:
cv2.rectangle(frame, (x, y), (x + z, y + w), (0, 0, 255), 2)
cv2.imshow("capture", frame)
if cv2.waitKey(1) & 0xFF == ord('q'):
cv2.imwrite("images\client.jpg", frame)#相对路径
break
cap.release()
cv2.destroyAllWindows()
getpicture()
print u" 数据读取中。。。。\n"
face1 = upload_img(u"images\demo4.jpg")
print u" 正在校对人脸。。。。。\n"
time.sleep(5)#防止出现qps
print u" 再等一下。。。。。\n"
face2 = upload_img(u"images\client.jpg")
confidence = compare(face1,face2)
if confidence>=70:
#print u"同一个人"
#win32api.ShellExecute(0,'op','genealogy.exe','','',1)
win32api.MessageBox(0, u"刷脸成功", u"家谱管理系统", win32con.MB_OK)
#这里写你想要继续执行的代码
else:
win32api.MessageBox(0, u"刷脸失败", u"家谱管理系统", win32con.MB_OK)
#print u"不是同一个人"
运行效果:
因为样本图片是我,所以用白岩松是不能成功的。
来源:https://blog.csdn.net/he_and/article/details/78927125
0
投稿
猜你喜欢
- 在matplotlib下,一个Figure对象可以包含多个子图(Axes),可以使用subplot()快速绘制,其调用形式如下:subplo
- 本案例使用 Jupyter Notebook进行案例演示,数据集为NBA球员信息数据集。本项目将进行完整的数据分析演示。1. 数据介绍数据集
- 网页中的javascript脚本代码往往需要在文档加载完成后才能够去执行,否则可能导致无法获取对象的情况,为了避免这种情况的发生,可以使用以
- 本文实例讲述了Python实现读取及写入csv文件的方法。分享给大家供大家参考,具体如下:新建csvData.csv文件,数据如下:具体代码
- scrapy爬虫框架介绍scrapy不是一个简单的函数功能库,而是一个爬虫框架爬虫框架:爬虫框架是实现爬虫功能的一个软件结构和功能组件的集合
- 1. 引言本文为介绍流行的数独游戏的系列文章中的第一篇。更具体地说,我们如何构建一个脚本来解决数独难题,本文的重点在于介绍用于构建数独求解器
- 1 介绍U-Net最初是用来对医学图像的语义分割,后来也有人将其应用于其他领域。但大多还是用来进行二分类,即将原始图像分成两个灰度级或者色度
- 误区 #1:在服务器故障转移后,正在运行的事务继续执行 这当然是错误的! 每次故障转移都伴随着某种形式的恢复。但是如果当正在执行的事务没有C
- 有用的 Python 单行代码片段,只需一行代码即可解决特定编码问题!在本文中,云朵君将分享20 个 Python 一行代码,你可以在 30
- Python 下的单例模式要点:1.某个类只能有一个实例;2.它必须自行创建这个实例;3.它必须自行向整个系统提供这个实例方法:重写new函
- 今天的博客是直接来源于我自己的个人工具函数库。过去几个月,有些PyImageSearch读者电邮问我:“如何获取URL指向的图片并将其转换成
- functools模块提供了一些常用的高阶函数(处理其他可调用对象/函数的特殊函数;以函数作为输入参数,返回也是函数)。functools模
- 一、85%的广告没人看解读:如何挤进那15%的成功广告中去,吸引了读者就是成功了一半。Quester视角:反过来讲,只有不到1/5的广告能吸
- 引言Algolia 为构建者提供构建世界级体验所需的搜索和推荐服务。Algolia 是一个数据库实时搜索服务,能够提供毫秒级的数据库搜索服务
- 有些时候因为某些原因(如本地机器资源不足、数据不能离网等),需要使用本地电脑连接远程服务器进行开发工作,在这里记录下如何在远程Linux上配
- 视图是 MTV 设计模式中的 V 层,它是实现业务逻辑的关键层,可以用来连接 M 层与 T 层,起着纽带般的作用,在《Django MTV和
- 根据GB11643-1999公民身份证号码是特征组合码,由十七位数字本体码和一位数字校验码组成,排列顺序从左至右依次为:六位数字地址码八位数
- 手动安装Anaconda环境变量安装 Anaconda后,在命令行执行python命令或conda命令会报错无法找到此时就需要我们手动添加环
- 独立 fmt Log输出重定向golang的fmt包的输出函数 Println、Printf、PrintStack等,默认将打印输出到os.
- Javascript 选择器(selector engine)似乎从 jQuery 流行以来就大行其道,改变了原有 Javascript 选