QT+Python人脸表情特征识别
创始人
2024-02-25 05:11:24
0

程序示例精选

QT+Python人脸表情特征识别

前言

QT+Python是非常经典的窗体编程组合,功能完善,可视化界面美观易维护,这篇博客针对人脸表情特征识别方面编写代码,代码整洁,规则,易读,对学习与使用Python有较好的帮助。


文章目录

        一、所需工具软件

        二、使用步骤

                1. 引入库

                2. 打开图像软件

                3. 识别图像特征

                4. 运行结果

         三、在线协助


一、所需工具软件

          1. Python3.6以上

          2. Pycharm代码编辑器

          3. Qt, Tensorflow, Pandas库

二、使用步骤

1.引入库

代码如下(示例):


# coding:utf-8
import sys
#从转换的.py文件内调用类
import cv2
import numpy as np
import sys
import tensorflow as tffrom untitled import Ui_Dialog
from PyQt5 import QtWidgetsfrom PyQt5 import QtWidgets, QtCore, QtGui
from PyQt5.QtCore import *

2.打开图像文件

代码如下(示例):

   def openFileButton(self):imgName, imgType  = QFileDialog.getOpenFileName(self,"打开文件","./","files(*.*)")img = cv2.imread(imgName)cv2.imwrite("temp/original.jpg", img)height, width, pixels = img.shapeprint("width,height",width,height)print("self.label.width()",self.label.width())print("self.label.height()",self.label.height())frame = cv2.resize(img, (int(rwidth), int(rheight)))print("rwidth-elif,rheight-elfi", rwidth, rheight)img2 = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)  # opencv读取的bgr格式图片转换成rgb格式_image = QtGui.QImage(img2[:], img2.shape[1], img2.shape[0], img2.shape[1] * 3, QtGui.QImage.Format_RGB888)jpg_out = QtGui.QPixmap(_image).scaled(rwidth, rheight) #设置图片大小self.label.setPixmap(jpg_out) #设置图片显示

该处使用的url网络请求的数据。

3.识别图像特征:

代码如下(示例):

    def recogPerson(self):import osimport cv2img = cv2.imread("temp/original.jpg")cv2.imwrite("save/recognPerson2.jpg", img)face_detect = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')eye_detect = cv2.CascadeClassifier('haarcascade_eye.xml')# 灰度处理gray = cv2.cvtColor(img, code=cv2.COLOR_BGR2GRAY)# 检查人脸 按照1.1倍放到 周围最小像素为5face_zone = face_detect.detectMultiScale(gray,1.3,5)# print ('识别人脸的信息:\n',face_zone)l = len(face_zone)ints = 0# 绘制矩形和圆形检测人脸for x, y, w, h in face_zone:ints += 1# 绘制矩形人脸区域if w < 1000:cv2.rectangle(img, pt1=(x, y), pt2=(x + w, y + h), color=[0, 0, 255], thickness=2)# 绘制圆形人脸区域 radius表示半径cv2.circle(img, center=(x + w // 2, y + h // 2), radius=w // 2, color=[0, 255, 0], thickness=2)roi_face = gray[y:y + h, x:x + w]  # 灰度图roi_color = img[y:y + h, x:x + w]  # 彩色图eyes = eye_detect.detectMultiScale(roi_face)for (ex, ey, ew, eh) in eyes:cv2.rectangle(roi_color, (ex, ey), (ex + ew, ey + eh), (0, 255, 0), 2)cv2.imwrite("save/recognPerson.jpg", img)#cv2.waitKey(0)

4.运行结果如下: 

 

三、在线协助:

如需安装运行环境或远程调试,可加扣2945218359, 或扣905733049由专业技术人员远程协助!

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
【Ctfer训练计划】——(三... 作者名:Demo不是emo  主页面链接:主页传送门 创作初心ÿ...