Python案例实战《手势识别》

目录

      • 1、效果图
      • 2、手势识别关键步骤
        • (1) 导入必要的库
        • (2)配置 MediaPipe
        • (3)启动摄像头
        • (4)设置手指张开判断的距离阈值
        • (5)计算手指之间的欧几里得距离
        • (6)处理视频流
        • (7)计算和显示手指张开的数量
        • (8)显示图像
        • (9)按键退出
        • (10)资源释放
      • 3、源码下载
      • 技术交流

博主介绍:
计算机科班人,全栈工程师,掌握C、C#、Java、Python、Android等主流编程语言,同时也熟练掌握mysql、oracle、sqlserver等主流数据库,能够为大家提供全方位的技术支持和交流。
具有丰富的项目经验和开发技能。提供相关的学习资料、程序开发、技术解答、代码讲解、文档报告等专业服务。
🍅文末获取源码🍅
👇🏻 精彩专栏推荐订阅👇🏻 不然下次找不到我哟
《精品项目实战》


1、效果图

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


2、手势识别关键步骤

(1) 导入必要的库
  • MediaPipe:用于手部识别和关键点检测。
  • OpenCV:用于视频捕捉和图像处理。
  • NumPy:用于数值计算,特别是在计算手指之间的距离时。
(2)配置 MediaPipe
  • 配置 MediaPipe 的手部识别工具,设置了识别模式、最大手数、最小检测信度和最小跟踪信度。
(3)启动摄像头
  • 使用 OpenCV 打开默认摄像头,并设置窗口可调整大小。
(4)设置手指张开判断的距离阈值
  • 定义 FINGER_THRESHOLD,用于判断手指是否张开。该值需要根据实际情况进行调整。
(5)计算手指之间的欧几里得距离
  • 定义函数 calculate_distance,通过手指尖和根部的坐标计算两点之间的欧几里得距离,用于判断手指是否张开。
(6)处理视频流
  • 通过摄像头连续读取图像帧。
  • 对每一帧图像进行处理:转换颜色空间并使用 MediaPipe 进行手部识别。
  • 如果检测到手部关键点,绘制手部关键点,并计算手指尖与根部之间的距离来判断手指是否张开。
(7)计算和显示手指张开的数量
  • 遍历所有识别到的手部,检查每根手指的距离,累加张开的手指数。
  • 使用 OpenCV 在图像上显示张开手指的数量,并输出到控制台。
(8)显示图像
  • 使用 OpenCV 显示处理后的图像,并实时更新。
(9)按键退出
  • q 键退出程序,释放摄像头资源并关闭所有 OpenCV 窗口。
(10)资源释放
  • 释放摄像头资源,关闭所有 OpenCV 创建的窗口。

3、源码下载

https://download.csdn.net/download/xch_yang/90779470

在这里插入图片描述


技术交流

大家点赞、收藏、关注、评论啦!
精彩专栏推荐订阅:下方专栏👇🏻👇🏻👇🏻👇🏻
《精品项目实战》


更多技术干货,请持续关注程序员大佬超。
原创不易,转载请务必注明出处。

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

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

相关文章

5G赋能农业物联网:智能化种植的新纪元

5G赋能农业物联网:智能化种植的新纪元 在农业领域,精准化、智能化已成为现代农业发展的方向。而5G的出现,让农业物联网(Agri-IoT)突破了传统的瓶颈,真正实现了实时监测、高效数据传输、智能化决策&#xf…

VIVADO IP核整理(二)——FFT

目录 IP 核配置IP 核接口s_axis_config_tdata 配置输入输出端口描述 仿真 参考:FFT IP核 详细介绍 参考:官方文档介绍 IP 核配置 在 IP Catalog 中搜索:Fast Fourier Transform 按照上图所示进行配置,下文对配置内容进行详述。 …

【计算机基础】任意进制转换方法详解

文章目录 一、通用进制转换(整数部分)1. R进制转十进制(整数)2. 十进制转R进制(整数)二、通用进制转换(小数部分)1. 十进制小数转R进制2. R进制小数转十进制三、二进制与十进制互转(整数部分)1. 二进制转十进制(整数)2. 十进制转二进制(整数)四、二进制与十进制互…

鼠标交互初体验:点击屏幕生成彩色气泡(EGE 库基础)

在图形编程领域,实现与用户的交互是让程序变得生动有趣的关键环节。对于初学者来说,使用合适的图形库能大幅降低开发难度,快速实现创意想法。EGE 库作为一款简单易用且功能强大的 C/C 图形库,特别适合新手入门图形交互编程。本文将…

Office 三大组件Excel、Word、Access 里 VBA 区别对比

以下是Excel、Word和Access在VBA中的主要区别对比及详细说明: 核心对象模型 Excel Workbook(工作簿)→ Worksheet(工作表)→ Range(单元格区域) 核心围绕单元格数据处理,如 Cells(1,1).Value = "数据" Word Document(文档)→ Range(文本范围)→ Paragrap…

【上位机——MFC】对象和控件绑定

对象和控件绑定 将控件窗口和类对象绑定具有两大作用 如果和数据类对象绑定,对象和控件可以进行数据交换。 如果和控件类对象绑定,对象就可以代表整个控件。 与数据类型对象绑定的使用 数据类型对象和控件可实现数据交互重写父类成员虚函数DoDataExch…

Excel处理控件Aspose.Cells教程:压缩Excel文件完整指南

Excel 电子表格是管理、分析和可视化数据的有效工具,但随着文件复杂度的增加,它们很快就会变得臃肿。无论是由于数据集庞大、嵌入图片、格式过多还是隐藏工作表,Excel 文件的大小都可能迅速膨胀,导致打开速度变慢、难以通过电子邮…

软考【软考高级QA】

软考高级QA 1.操作系统管理和调度进程时,有哪些状态?(5种)2.操作系统管理和调度进程时,会进行哪些状态转换? 1.操作系统管理和调度进程时,有哪些状态?(5种) …

神经网络基础-从零开始搭建一个神经网络

一、什么是神经网络 人工神经网络(Articial Neural Network,简写为ANN)也称为神经网络(NN),是一种模仿生物神经网络和功能的计算模型,人脑可以看做是一个生物神经网络,由众多的神经元连接而成,…

Golang 接口 vs Rust Trait:一场关于抽象的哲学对话

一、引言 在现代编程语言中,接口(Interface) 和 Trait 是实现多态和抽象行为的关键机制。它们允许我们定义行为契约,让不同的类型共享相同的语义接口,从而提升代码的复用性和扩展性。 Go 和 Rust 分别代表了两种截然…

java实现一个操作日志模块功能,怎么设计

为了设计一个高效、可靠且可扩展的操作日志模块,可以结合 ​AOP(面向切面编程)​、异步处理​(多线程或MQ)以及合理的存储策略,具体方案如下: ​1. 技术选型与架构设计​ ​​(1) AOP 实现非侵…

【论文阅读】HunyuanVideo: A Systematic Framework For Large Video Generative Models

HunyuanVideo: A Systematic Framework For Large Video Generative Models 原文摘要 研究背景与问题 视频生成的变革性影响:近期视频生成技术的进步深刻改变了个人生活与行业应用。 闭源模型的垄断:主流视频生成模型(如Runway Gen-3、Luma …

在ubuntu中brpc框架安装

下载最新release版本, 稳定性好, 网址链接。 一、解压源码包 # 解压到当前目录 tar -xzvf brpc-1.12.1.tar.gz# 进入解压后的目录 cd brpc-1.12.1二、安装编译依赖(Ubuntu/Debian) sudo apt update sudo apt install -y g make…

《深入理解 Java 虚拟机》笔记

文章目录 最近笔记内存管理执行子系统程序编译、代码优化 老版本 最近笔记 内存管理 执行子系统 程序编译、代码优化 老版本

【Linuc】深入理解 Linux 文件权限

文章目录 一、权限基础解析1. 权限三元组2. 权限类型与数字映射二、查看文件权限三、修改权限实战1. chmod 命令符号模式数字模式(推荐)2. chown 修改归属四、特殊权限机制1. SetUID (Set User ID)2. SetGID (Set Group ID)3. Sticky Bit五、高级权限管理1. 默认权限控制2. A…

RabbitMq学习(第一天)

文章目录 1、mq(消息队列)概述2、RabbitMQ环境搭建3、java基于AMQP协议操作RabbitMQ4、基于Spring AMQP操作RabbitMQ5、代码中创建队列与交换机①、配置类创建②、基于RabbitListener注解创建 6、RabbitMQ详解①、work模型②、交换机1、Fanout(广播)交换机2、Direct(定向)交换机…

缓存置换:用c++实现最不经常使用(LFU)算法

在探讨缓存置换算法时,我们曾详细解读过LRU(Least Recently Used)算法,它凭借 “最近最少使用” 的策略在缓存管理领域大放异彩。今天,让我们将目光聚焦于另一种重要的缓存置换算法 ——LFU(Least Frequent…

深度学习模型的部署实践与Web框架选择

引言 在深度学习项目的完整生命周期中,模型训练只是第一步,将训练好的模型部署到生产环境才能真正发挥其价值。本文将详细介绍模型部署的核心概念、常见部署方式以及三种主流Python Web框架的对比分析,帮助开发者选择最适合自己项目的技术方…

多功能气体检测报警系统,精准监测,守护安全

在化学品生产、石油化工、矿山、消防、环保、实验室等领域,有毒有害气体泄漏风险严重威胁工作人员和环境安全。化工企业生产中易产生大量可燃有毒气体,泄漏达一定浓度易引发爆炸、中毒等重大事故;矿井下瓦斯、一氧化碳等有害气体的浓度实时监…

lvgl多语言设置

搭建开发环境 安装node.js 安装node.js,点击进入官网地址 安装lv_i18n lv_i18n项目地址:Github:https://github.com/lvgl/lv_i18ngit运行命令安装lv_i18n:npm i lv_i18n -g。测试命令:lv_i18n -h 搭建过程报错 …