python参数检验框架_基于python的人员识别检测框架研究

import numpy as np  # 数据处理的库 Numpy

import cv2          # 图像处理的库 OpenCv

import os

import shutil

import _thread

import wx

import csv

from importlib import reload

from skimage import io as iio

import face_recognize_punchcard

import sys

# 创建 cv2 摄像头对象

#    C++: VideoCapture::VideoCapture(int device);

#API:http://www.opencv.org.cn/opencvdoc/2.3.2/html/modules/highgui/doc/reading_and_writing_images_and_video.html#videocapture

# 保存

path_make_dir = "data/face_img_database/"

path_feature_all = "data/feature_all.csv"

info = 'icon/info.png'

#register ui

class   RegisterUi(wx.Frame):

def __init__(self,superion):

wx.Frame.__init__(self,parent=superion,title="人脸录入",size=(800,590),style=wx.DEFAULT_FRAME_STYLE|wx.STAY_ON_TOP)

self.SetBackgroundColour('white')

self.Center()

self.NewButton =  wx.Button(parent=self,pos=(50,120),size=(80,50),label='新建录入')

self.ShortCutButton = wx.Button(parent=self,pos=(50,220),size=(80,50),label='截图保存')

self.SaveButton =  wx.Button(parent=self,pos=(50,320),size=(80,50),label='完成录入')

# 封面图片

self.image_info = wx.Image(info, wx.BITMAP_TYPE_ANY).Scale(600, 480)

# 显示图片

self.bmp = wx.StaticBitmap(parent=self, pos=(180,20), bitmap=wx.Bitmap(self.image_info))

self.Bind(wx.EVT_BUTTON,self.OnShortCutButtonClicked,self.ShortCutButton)

self.Bind(wx.EVT_BUTTON,self.OnNewButtonClicked,self.NewButton)

self.ShortCutButton.Enable(enable=False)

self.SaveButton.Enable(False)

self.Bind(wx.EVT_BUTTON,self.OnSaveButtonClicked,self.SaveButton)

self.sc_number = 0

self.register_flag = 0

self.name = ""

def OnNewButtonClicked(self, event):

while self.name == '':

self.name = wx.GetTextFromUser(message="请先输入录入者的姓名,用于创建姓名文件夹", caption="温馨提示",

default_value="", parent=None)

# 监测是否重名

for exsit_name in (os.listdir(path_make_dir)):

if self.name == exsit_name:

wx.MessageBox(message="姓名已存在,请重新输入", caption="警告")

self.name = ''

break

os.makedirs(path_make_dir+self.name)

print("新建的人脸文件夹: ", path_make_dir+self.name)

self.NewButton.Enable(enable=False)

self.ShortCutButton.Enable(enable=True)

"""使用多线程,子线程运行后台的程序,主线程更新前台的UI,这样不会互相影响"""

# 创建子线程,按钮调用这个方法,

_thread.start_new_thread(self._open_cap, (event,))

def OnShortCutButtonClicked(self,event):

self.SaveButton.Enable(True)

if len(self.rects) !=0:

# 计算矩形框大小,保证同步

height = self.rects[0].bottom() - self.rects[0].top()

width = self.rects[0].right() - self.rects[0].left()

self.sc_number += 1

im_blank = np.zeros((height, width, 3), np.uint8)

for ii in range(height):

for jj in range(width):

im_blank[ii][jj] = self.im_rd[self.rects[0].top() + ii][self.rects[0].left() + jj]

cv2.imencode('.jpg', im_blank)[1].tofile(path_make_dir+self.name + "/img_face_" + str(self.sc_number) + ".jpg") #正确方法

print("写入本地:", str(path_make_dir+self.name) + "/img_face_" + str(self.sc_number) + ".jpg")

else:

print("未检测到人脸,识别无效,未写入本地")

def OnSaveButtonClicked(self,event):

self.bmp.SetBitmap(wx.Bitmap(self.image_info))

self.NewButton.Enable(True)

self.SaveButton.Enable(False)

self.ShortCutButton.Enable(False)

# 释放摄像头

self.cap.release()

# 删除建立的窗口

#cv2.destroyAllWindows()

if self.register_flag == 1:

if os.path.exists(path_make_dir+self.name):

shutil.rmtree(path_make_dir+self.name)

print("重复录入,已删除姓名文件夹", path_make_dir+self.name)

if self.sc_number == 0 and len(self.name)>0:

if os.path.exists(path_make_dir+self.name):

shutil.rmtree(path_make_dir+self.name)

print("您未保存截图,已删除姓名文件夹", path_make_dir+self.name)

if self.register_flag==0 and self.sc_number!=0:

pics = os.listdir(path_make_dir+self.name)

feature_list = []

feature_average = []

for i in range(len(pics)):

pic_path = path_make_dir+self.name + "/" + pics[i]

print("正在读的人脸图像:", pic_path)

img = iio.imread(pic_path)

img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

dets = face_recognize_punchcard.detector(img_gray, 1)

if len(dets) != 0:

shape = face_recognize_punchcard.predictor(img_gray, dets[0])

face_descriptor = face_recognize_punchcard.facerec.compute_face_descriptor(img_gray, shape)

feature_list.append(face_descriptor)

else:

face_descriptor = 0

print("未在照片中识别到人脸")

if len(feature_list)>0:

for j in range(128):

feature_average.append(0)

for i in range(len(feature_list)):

feature_average[j] += feature_list[i][j]

feature_average[j] = (feature_average[j])/len(feature_list)

feature_average.append(self.name)

with open(path_feature_all, "a+", newline="") as csvfile:

writer = csv.writer(csvfile)

print('写入一条特征人脸入库',feature_average)

writer.writerow(feature_average)

self.name = ""

self.register_flag = 0

self.sc_number = 0;

def _open_cap(self,event):

reload(face_recognize_punchcard)

urlc = 'http://192.168.137.119:8081/'

self.cap = cv2.VideoCapture(urlc)

# cap.set(propId, value)

# 设置视频参数,propId 设置的视频参数,value 设置的参数值

self.cap.set(3, 480)

#self.cap.set(cv2.CAP_PROP_FPS,5)

while self.cap.isOpened():

# cap.read()

# 返回两个值:

#    一个布尔值 true/false,用来判断读取视频是否成功/是否到视频末尾

#    图像对象,图像的三维矩阵q

flag, self.im_rd = self.cap.read()

# 人脸数 rects

self.rects = face_recognize_punchcard.detector(self.im_rd, 1)

cv2.waitKey(1)  # 必不可少

# 待会要写的字体

font = cv2.FONT_HERSHEY_SIMPLEX

if len(self.rects) != 0:

# 检测到人脸

# 矩形框#d是人脸

# 查重

features_cap = face_recognize_punchcard.facerec.compute_face_descriptor(self.im_rd, face_recognize_punchcard.predictor(self.im_rd, self.rects[0]))

for i in range(len(face_recognize_punchcard.features_known_arr)):

# 将某张人脸与存储的所有人脸数据进行比对

compare = face_recognize_punchcard.return_euclidean_distance(features_cap, face_recognize_punchcard.features_known_arr[i][0:-1])

if compare == "same":  # 找到了相似脸

face_name = face_recognize_punchcard.features_known_arr[i][-1]

print(face_name)

wx.MessageBox(message=face_name + ",您已录过人脸,请检查是否签过到", caption="警告")

self.NewButton.Enable(False)

self.ShortCutButton.Enable(False)

self.SaveButton.Enable(True)

self.register_flag = 1

for k, d in enumerate(self.rects):

# 根据人脸大小生成空的图像

# 最后一个参数是线宽

cv2.rectangle(self.im_rd, tuple([d.left(), d.top()]), tuple([d.right(), d.bottom()]), (255, 0, 0), 2)

# 显示人脸数

cv2.putText(self.im_rd, "Faces: " + str(len(self.rects)), (50, 80), font, 0.8, (255, 0, 0), 1, cv2.LINE_AA)

cv2.putText(self.im_rd, "Warning: please shortcut having rectangle", (50, 140), font, 0.8, (0, 0, 255), 1,

cv2.LINE_AA)

# print(im_rd.shape)

height, width = self.im_rd.shape[:2]

image1 = cv2.cvtColor(self.im_rd, cv2.COLOR_BGR2RGB)

pic = wx.Bitmap.FromBuffer(width, height, image1)

# 显示图片在panel上

self.bmp.SetBitmap(pic)

#直接在sbclicked里设置self.bmp.SetBitmap(wx.Bitmap(self.image_cover)),子线程还在运行

if self.NewButton.IsEnabLED()==True and self.ShortCutButton.IsEnabled()==False and self.SaveButton.IsEnabled()==False:

self.bmp.SetBitmap(wx.Bitmap(self.image_info))

_thread.exit()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/558567.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

js父元素获取子元素img_css,前端_父标签div中包含一个子元素img标签,子元素div标签,为什么img要加上浮动,子元素div才会处于正常位置?,css,前端 - phpStudy...

父标签div中包含一个子元素img标签,子元素div标签,为什么img要加上浮动,子元素div才会处于正常位置?dom结构如图img加上float 子元素div显示正常。不加float div显示错位。附上我写的一个dome测试用的,大家可本地看下究…

android运营商获取本机号码_一键登录已成大势所趋,Android端操作指南来啦!

根据极光(Aurora Mobile)发布的《2019年Q2移动互联网行业数据研究报告》,2019年第二季度,移动网民人均安装APP总量已达56款。面对如此繁多的APP,想在用户的手机中占据一席之地,移动开发者们就不得不努力提升用户体验。而现实却是&…

mysql数据库中删除数据用什么语句_mysql数据库删除数据语句

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里云数据库专家保驾护航,为用户…

spring批量写入mysql数据库_MyBatis-spring和spring JDBC批量插入Mysql的效率比较

工具框架用spring-batch,数据库是mysql(未做特殊优化)。比较数据框架mybatis和spring jdbc的插入效率。Mybatis三种实现:1、mybatis的官方写法Java代码publicvoidbatchInsert1(List poilist)throwsException {SqlSession sqlSession sqlSessionFactory.…

mysql启动触发器_MYSQL中禁用/启动触发器

在使用MYSQL过程中,经常会使用到触发器,但是有时使用不当会造成一些麻烦。有没有一种办法可以控制触发器的调用呢?触发器顾名思义就是数据库在一定的调条件自动调用的SQL语句,触发器拒绝了人工调用的过程,由数据库MYSQ…

mysql数据库权威指南_MySQL_MySQL权威指南读书笔记(三),第二章:MYSQL数据库里面的数 - phpStudy...

MySQL权威指南读书笔记(三)第二章:MYSQL数据库里面的数据用想用好MYSQL,就必须透彻理解MYSQL是如何看待和处理数据的。本章主要讨论了两个问题:一是SQL所能处理的数据值的类型;二是这些数据类型…

mysql 批量替换 所有表_[收藏]批量替换一个数据库中所有表中所有记录

/***********批量替换一个数据库中所有表中所有记录************/declare delStr nvarchar(500)set delStr这里是要替换的字符/**********以下为操作实体************/set nocount ondeclare tableName nvarchar(100),columnName nvarchar(100),tbID int,iRow int,iResult intd…

java偶数和_Java编程计算1-100之间所有偶数的和。

展开全部 public class Demo05ShiCao{public static void main(String[] args){int sum1 = 0; for(int i = 1; i <= 100; i++){if(i % 2 == 0){sum1 +=i; } } System.out.println("结果e5a48de588b63231313335323631343130323136353331333366303138是:" + sum1);…

金额转换java_java金额转换

像商品价格&#xff0c;订单&#xff0c;结算都会涉及到一些金额的问题&#xff0c;为了避免精度丢失通常会做一些处理&#xff0c;常规的系统中金额一般精确到小数点后两位&#xff0c;也就是分&#xff1b;这样数据库在设计的时候金额就直接存储整型数据类型&#xff0c;前端…

java 栈 大小_java – JVM堆栈大小规范

Question, what does 1 MB stack size states in JVM as I have no idea what size a stack frame of?1 MB默认线程堆栈大小意味着每个线程默认具有1MB(1048576字节)的堆栈空间.例外情况是,如果您的代码使用其中一个Thread构造函数创建一个线程,您可以在其中提供堆栈大小参数.…

java bloomfilter_爬虫技术之——bloom filter(含java代码)

在爬虫系统中&#xff0c;在内存中维护着两个关于URL的队列&#xff0c;ToDo队列和Visited队列&#xff0c;ToDo队列存放的是爬虫从已经爬取的网页中解析出来的即将爬取的URL&#xff0c;但是网页是互联的&#xff0c;很可能解析出来的URL是已经爬取到的&#xff0c;因此需要VI…

java new对象 =null_在Java中将对象分配为null会影响垃圾回收吗?

通常&#xff0c;没有。但就像所有事情一样&#xff1a;这取决于。如今&#xff0c;Java中的GC非常好&#xff0c;所有内容都应该在不再可用后立即清理。这就是在为局部变量留下一个方法之后&#xff0c;以及当不再为字段引用类实例时。如果您知道它将继续引用&#xff0c;则只…

java php js_【javascript/PHP】当一个JavaScripter初次进入PHP的世界,他将看到这样的风景...

本文将从以下11点介绍javascript和PHP在基础语法和基本操作上的异同&#xff1a;1.数据类型的异同2.常量和变量的定义的不同&#xff0c;字符串连接运算符不同3.对象的创建方法的不同4.PHP与JS在变量声明提升和函数声明提升的差异5.var在JS和PHP中使用的差异6.PHP和JS在访问对象…

java so jnienv_JNI初步(五)jni ndk 一个.so文件依赖另一个.so文件的写法

注意&#xff1a;本文是在ndk环境下编写1.写native类声明native方法package com.godv.audiosuc;public class NativePlayers {static{System.loadLibrary("JNI_ANDROID_AUDIOS");System.loadLibrary("JNI_ANDROID_TEST");}//native方法public static nativ…

从零开始学java 框架_从零开始学 Java - 搭建 Spring MVC 框架

如果创建一个 Spring 项目Spring MVC 框架在 Java 的 Web 项目中应该是无人不知的吧&#xff0c;你不会搭建一个 Spring 框架&#xff1f;作为身为一个刚刚学习Java的我都会&#xff0c;如果你不会的话&#xff0c;那可真令人忧伤。1.在 MyEclipse 创建项目后&#xff0c;可以以…

java 系统类型_Java获取操作系统类型

Java获取操作系统完整版系统枚举类&#xff1a;public enum EPlatform {Any("any"),Linux("Linux"),Mac_OS("Mac OS"),Mac_OS_X("Mac OS X"),Windows("Windows"),OS2("OS/2"),Solaris("Solaris"),SunOS…

java的min函数_Java语言实现包含min函数的栈

package stack;import java.util.ArrayList;/*** 实现包含min函数的栈* author DHC* param */public class MinInStack {public static void main(String[] args) {MinInStack newStack new MinInStack();newStack.push(4);newStack.push(6);newStack.push(2);newStack.push(5…

updatepanel失效怎么办_【点滴积累】解决jQuery绑定事件在updatepanel更新后失效的方法...

背景 接到了领导给的一个New Feature&#xff0c;为系统的菜单导航栏进行一些个性化的操作(鼠标移到导航菜单时下方出现子菜单&#xff0c;移到其他的菜单选项时显示该选项的子菜单&#xff0c;隐藏其他子菜单。其次就是当使用鼠标点击一个菜单选项时就把该菜单及其子菜单固定&…

azure mysql on vnet_管理 VNet 终结点 - Azure 门户 - Azure Database for MySQL | Microsoft Docs

您现在访问的是微软AZURE全球版技术文档网站&#xff0c;若需要访问由世纪互联运营的MICROSOFT AZURE中国区技术文档网站&#xff0c;请访问 https://docs.azure.cn.使用 Azure 门户创建和管理 Azure Database for MySQL VNet 服务终结点和 VNet 规则Create and manage Azure D…

java excel api及详细教程_针对Java Excel API及详细教程

时在java开发中会操作excel表格&#xff0c;其实操作起来也特别简单。这里把前期操作步骤说一下&#xff0c;本文会简单的介绍一个开放源码项目&#xff1a;Java Excel Api&#xff0c;使用它大家就可以方便的操作Excel文件了。首先下载好&#xff1a;Java Excel Api&#xff0…