基于Python实现打哈欠检测详解
作者:川川菜鸟 发布时间:2021-12-10 06:50:45
标签:Python,打哈欠,检测
效果图
基本思路
在 OpenCV 中使用VideoCapture方法初始化视频渲染对象
创建灰度图像
导入预训练模型,识别脸部和人脸标志
计算上唇和下唇距离(其它类似)
创建唇边距离的If条件,满足则是打哈欠,不满足则只是简单的张嘴
显示帧/图像
部分源码
suc, frame = cam.read()
# 读取不到退出
if not suc:
break
# ---------FPS------------#
ctime = time.time()
fps = int(1 / (ctime - ptime))
ptime = ctime
cv2.putText(frame, f'FPS:{fps}', (frame.shape[1] - 120, frame.shape[0] - 20), cv2.FONT_HERSHEY_PLAIN, 2,
(0, 200, 0), 3)
# ------检测人脸------#
# 转为灰度
img_gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
faces = face_model(img_gray)
for face in faces:
# 检测人脸,框起来-#
x1 = face.left()
y1 = face.top()
x2 = face.right()
y2 = face.bottom()
# print(face.top())
cv2.rectangle(frame, (x1, y1), (x2, y2), (200, 0, 00), 2)
# ----------检测人脸标注-----------#
shapes = landmark_model(img_gray, face)
shape = face_utils.shape_to_np(shapes)
# -------检测上下唇--------#
lip = shape[48:60]
cv2.drawContours(frame, [lip], -1, (0, 165, 255), thickness=3)
# -------计算上下唇距离-----#
lip_dist = cal_yawn(shape)
# 打印距离
# print(lip_dist)
# 大于设定值,则认定是打哈欠
if lip_dist > yawn_thresh:
cv2.putText(frame, f'User Yawning!', (frame.shape[1] // 2 - 170, frame.shape[0] // 2),
cv2.FONT_HERSHEY_SIMPLEX, 2, (0, 0, 200), 2)
# 按字母q退出
cv2.imshow('Webcam', frame)
if cv2.waitKey(1) & 0xFF == ord('q'):
break
来源:https://blog.csdn.net/weixin_46211269/article/details/124105198
0
投稿
猜你喜欢
- asp获取application对象代码如下: <%application("new&qu
- 十要:第一:要认真规划和分析。这是网页设计灵魂工作。创建站点之前,要明确你的网站主要针对哪些访问者,为哪些用户服务,要把握准主页题材第二:网
- 关于这个问题的解答,网络上有成千上万个版本,当然,出现问题的诱因不同,解决的途径也不同,所以我不排除其他解决此类问题的办法,但是这些办法都没
- PHP PDO 错误与错误处理PDO::ERRMODE_SILENT此为默认模式。 PDO 将只简单地设置错误码,可使用PDO::error
- <!DOCTYPE html PUBLIC "-//W3C//DTD X
- 在经过前面几个部分的操作之后,我们的网页已经图文并茂,具有相当的效果了,但是这对于网页来说还不够,为了网站中的众多网页能够成为一个有机的整体
- 本文实例讲述了Flask框架请求钩子与request请求对象。分享给大家供大家参考,具体如下:请求钩子在客户端和服务器交互的过程中,有些准备
- 方法一:定义一个函数,参数为所要生成随机字符串的长度。通过random.randint(a, b)方法得到随机数字,具体函数如下:def g
- 当我们想对python中原有的模块进行覆盖,又不希望退出当前的程序,就需要用到重载的概念。这样既能使模块得到更新,又不影响解释器的使用。在导
- 前言学习Python的过程中,我们会遇到Excel的各种问题。下面这篇文章主要给大家介绍了关于python对excel进行数据剔除操作的相关
- 使用torchvision库的datasets类加载常用的数据集或自定义数据集图像识别是计算机视觉中的一个基础任务,它的目标是让计算机能够识
- 本文实例讲述了python根据路径导入模块的方法,分享给大家供大家参考。具体方法如下:常规做法如下:import sys sys.path.
- <html><head><style>body{font-family:宋体;font-size:16p
- 昨天带伙伴萌学习python爬虫,准备了几个简单的入门实例涉及主要知识点:web是如何交互的requests库的get、post函数的应用r
- 一、Socketserver实现FTP,文件上传、下载目录结构1、socketserver实现ftp文件上传下载,可以同时多用户登录、上传、
- 本文实例为大家分享了python openCV自制绘画板的具体代码,供大家参考,具体内容如下import numpy as npimport
- 利用XMLHTTP无刷新自动实时更新数据,2秒自动刷新一次,2秒取得一次数据.demo.htm 前台显示<script la
- 情况一:坐标上的内容是文字时如上图这样一个横向的柱状图,y坐标轴的内容太长后会导致显示不全。因为数据是由后端传过来的,有些会很长有些会比较短
- 一、我们对XML的读取进行一波演示import xml.dom.minidom#负责解析xml文件的包from xml.dom.minido
- 使用opencv将图片转为灰度图主要有两种方法,第一种是将彩 * 转为灰度图,第二种是在使用OpenCV读取图片的时候直接读取为灰度图。将彩色