敢不敢和AI比猜拳?能赢算我输----基于手势识别的AI猜拳游戏【含python源码+PyqtUI界面+原理详解】-python手势识别 深度学习实战项目

简介: 敢不敢和AI比猜拳?能赢算我输----基于手势识别的AI猜拳游戏【含python源码+PyqtUI界面+原理详解】-python手势识别 深度学习实战项目

前言

手势识别技术是一种将人类手部的动作转化为机器可理解形式的技术。它可以通过分析图像或视频中的手部或身体动作,来识别并理解用户的意图或指令。手势识别技术广泛应用于人机交互、虚拟现实、增强现实、智能监控等领域。通过手势识别技术,用户可以使用手势进行操作和交互,从而提供更加自然、直观的用户体验。

手势识别技术目前正处于快速发展阶段,并取得了很多重要的研究进展。以下是手势识别技术目前常见的一些研究:

1.传感器技术:传感器技术在手势识别中起着关键作用。例如,深度相机、红外传感器和摄像头等设备能够捕捉到人体的姿态和动作信息。

2.深度学习:深度学习方法在手势识别中被广泛应用。通过使用深度神经网络模型,可以实现对复杂手势的准确识别和分类。

3.实时性:实时手势识别是当前研究的一个重点。研究人员致力于提高算法的效率和响应速度,以满足实时交互的需求。

4.多模态融合:多模态手势识别结合了多种传感器数据,如图像、声音和运动数据,以提高识别准确度和鲁棒性。

5.应用:手势识别技术在各个领域都有广泛应用。例如,在虚拟现实和增强现实中,手势识别可用于交互和控制;在医疗领域,手势识别可用于康复训练和手术操作辅助等。

博主根据Mediapipe框架中的深度学习算法进行手势识别检测,并基于此开发了一款基于手势识别的猜拳软件,可以和机器人进行猜拳游戏。感兴趣的小伙伴可以自己试试。

软件初始界面如下图:

摄像头开启后猜拳的界面如下:

一、软件核心功能介绍及效果演示

手势识别系统主要功能包括以下几个部分:

1. 支持摄像头进行手部动作识别;
2. 可区分左右手,并显示相应手部的坐标位置,以及21个手部关键点;
3. 可与机器人进行猜拳游戏,并显示最终结果;

(1)摄像头猜拳功能演示

点击打开摄像头按钮,即可开启摄像头,再次点击该按钮,会关闭摄像头,操作演示如下:

二、手势识别的基本原理

1.基本原理

Mediapipe是Google开源的一个多媒体处理框架,旨在为开发者提供高效、可扩展的数据流图(dataflow graph)方式来构建多媒体应用程序。它提供了一系列预训练好的模型和工具,用于处理视频、音频、姿势估计、手势识别等多媒体任务。

Mediapipe进行手势识别的基本原理是通过检测和跟踪手部关键点来识别手势。它使用了深度学习模型和计算机视觉技术来实现这一目标。首先,mediapipe使用大量的手部图像数据进行训练,以构建一个手部姿势估计模型。在进行检测时,mediapipe加载训练好的模型,并将输入的图像传递给模型。模型会检测图像中的手部区域,并定位手部关键点的位置。一旦检测到手部关键点的位置,mediapipe会利用计算机视觉技术对这些关键点进行跟踪。这有助于在连续帧之间保持关键点的一致性,以提高识别准确性。然后,根据手部关键点的位置和动作,mediapipe可以将手势分为不同的类别。这些类别可以包括手势如拳头、平手、手势指令等。

2. 代码实现

Mediapipe库基于C++实现,并提供了Python接口,使得开发者能够方便地使用这些功能。下面是使用mediapipe进行手势识别的基本原理:

安装:首先,需要安装mediapipe库。可以通过pip命令进行安装:

pip install mediapipe

导入库:导入mediapipe库和其他必要的依赖项。

python
import cv2
import mediapipe as mp

加载模型:使用mediapipe加载已经训练好的手部关键点模型。

mp_hands = mp.solutions.hands
hands = mp_hands.Hands()
mp_drawing = mp.solutions.drawing_utils

手势识别:打开摄像头并读取视频帧,将每一帧传递给hands.process()方法进行手势识别。

# coding:utf-8
cap = cv2.VideoCapture(0)  # 打开摄像头
while True:
    ret, frame = cap.read()  # 读取视频帧
    if not ret:
        break
    image = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)  # 转换颜色空间
    results = hands.process(image)  # 手势识别
    # 处理识别结果
    if results.multi_hand_landmarks:
        for hand_landmarks in results.multi_hand_landmarks:
            mp_drawing.draw_landmarks(
                frame,
                hand_landmarks,
                mp_hands.HAND_CONNECTIONS) # 用于指定地标如何在图中连接。
            for point in hand_landmarks.landmark:
                x = int(point.x * frame.shape[1])
                y = int(point.y * frame.shape[0])
                cv2.circle(frame, (x, y), 5, (0, 255, 0), -1) # 画出关键点
    cv2.imshow('Gesture Recognition', frame)  # 显示结果
    if cv2.waitKey(1) & 0xFF == ord('q'):
        break
cap.release()
cv2.destroyAllWindows()

在上述代码中,我们首先导入了mediapipe库和其他必要的依赖项。然后,使用mp.solutions.hands.Hands()加载手部关键点模型,并打开摄像头读取视频帧。每一帧都传递给hands.process()方法进行手势识别。返回的结果包含检测到的手部关键点的位置信息,我们可以根据这些信息进行相应的处理。手部关键点位置如下图:

通过遍历识别结果中的多个手部关键点,我们可以获取每个关键点在图像中的坐标,并在图像上绘制圆形表示关键点的位置。最后,使用cv2.imshow()方法显示结果,并通过cv2.waitKey()检测按键操作。

这就是使用mediapipe进行手势识别的基本原理。通过结合mediapipe库提供的预训练模型和API,开发者可以更轻松地构建手势识别应用程序。

下图是摄像头检测结果:

根据以上原理,博主基于python+ pyqt5开发了基于手势识别与机器人猜拳的软件。也就是第二部分介绍的软件功能内容。

相关文章
|
1月前
|
JSON 算法 API
1688商品详情API实战:Python调用全流程与数据解析技巧
本文介绍了1688电商平台的商品详情API接口,助力电商从业者高效获取商品信息。接口可返回商品基础属性、价格体系、库存状态、图片描述及商家详情等多维度数据,支持全球化语言设置。通过Python示例代码展示了如何调用该接口,帮助用户快速上手,适用于选品分析、市场研究等场景。
|
18天前
|
人工智能 安全 Shell
Jupyter MCP服务器部署实战:AI模型与Python环境无缝集成教程
Jupyter MCP服务器基于模型上下文协议(MCP),实现大型语言模型与Jupyter环境的无缝集成。它通过标准化接口,让AI模型安全访问和操作Jupyter核心组件,如内核、文件系统和终端。本文深入解析其技术架构、功能特性及部署方法。MCP服务器解决了传统AI模型缺乏实时上下文感知的问题,支持代码执行、变量状态获取、文件管理等功能,提升编程效率。同时,严格的权限控制确保了安全性。作为智能化交互工具,Jupyter MCP为动态计算环境与AI模型之间搭建了高效桥梁。
80 2
Jupyter MCP服务器部署实战:AI模型与Python环境无缝集成教程
|
28天前
|
数据采集 自然语言处理 Java
Playwright 多语言一体化——Python/Java/.NET 全栈采集实战
本文以反面教材形式,剖析了在使用 Playwright 爬取懂车帝车友圈问答数据时常见的配置错误(如未设置代理、Cookie 和 User-Agent),并提供了 Python、Java 和 .NET 三种语言的修复代码示例。通过错误示例 → 问题剖析 → 修复过程 → 总结教训的完整流程,帮助读者掌握如何正确配置爬虫代理及其它必要参数,避免 IP 封禁和反爬检测,实现高效数据采集与分析。
Playwright 多语言一体化——Python/Java/.NET 全栈采集实战
|
28天前
|
监控 供应链 数据挖掘
淘宝商品详情API接口解析与 Python 实战指南
淘宝商品详情API接口是淘宝开放平台提供的编程工具,支持开发者获取商品详细信息,包括基础属性、价格、库存、销售策略及卖家信息等。适用于电商数据分析、竞品分析与价格策略优化等场景。接口功能涵盖商品基础信息、详情描述、图片视频资源、SKU属性及评价统计的查询。通过构造请求URL和签名,可便捷调用数据。典型应用场景包括电商比价工具、商品数据分析平台、供应链管理及营销活动监控等,助力高效运营与决策。
152 26
|
19天前
|
机器学习/深度学习 算法 测试技术
图神经网络在信息检索重排序中的应用:原理、架构与Python代码解析
本文探讨了基于图的重排序方法在信息检索领域的应用与前景。传统两阶段检索架构中,初始检索速度快但结果可能含噪声,重排序阶段通过强大语言模型提升精度,但仍面临复杂需求挑战
53 0
图神经网络在信息检索重排序中的应用:原理、架构与Python代码解析
|
21天前
|
存储 机器学习/深度学习 人工智能
多模态RAG实战指南:完整Python代码实现AI同时理解图片、表格和文本
本文探讨了多模态RAG系统的最优实现方案,通过模态特定处理与后期融合技术,在性能、准确性和复杂度间达成平衡。系统包含文档分割、内容提取、HTML转换、语义分块及向量化存储五大模块,有效保留结构和关系信息。相比传统方法,该方案显著提升了复杂查询的检索精度(+23%),并支持灵活升级。文章还介绍了查询处理机制与优势对比,为构建高效多模态RAG系统提供了实践指导。
200 0
多模态RAG实战指南:完整Python代码实现AI同时理解图片、表格和文本
|
25天前
|
机器学习/深度学习 人工智能 算法
Python+YOLO v8 实战:手把手教你打造专属 AI 视觉目标检测模型
本文介绍了如何使用 Python 和 YOLO v8 开发专属的 AI 视觉目标检测模型。首先讲解了 YOLO 的基本概念及其高效精准的特点,接着详细说明了环境搭建步骤,包括安装 Python、PyCharm 和 Ultralytics 库。随后引导读者加载预训练模型进行图片验证,并准备数据集以训练自定义模型。最后,展示了如何验证训练好的模型并提供示例代码。通过本文,你将学会从零开始打造自己的目标检测系统,满足实际场景需求。
274 0
Python+YOLO v8 实战:手把手教你打造专属 AI 视觉目标检测模型
|
1月前
|
JSON API 数据格式
手把手教你抓取京东商品评论:API 接口解析与 Python 实战
京东商品评论蕴含用户对产品质量、体验和服务的真实反馈,分析这些数据有助于企业优化产品和满足用户需求。由于京东未提供官方API,需通过逆向工程获取评论数据。其主要接口为“商品评论列表接口”,支持按商品ID、评分、排序方式等参数获取评论,返回JSON格式数据,包含评论列表、摘要(如好评率)及热门标签等信息。
|
18天前
|
数据采集 存储 数据可视化
2025python实战:利用海外代理IP验证广告投放效果
本文介绍了如何利用Python结合海外代理IP技术,验证广告在不同国家的实际投放效果。通过模拟各地网络环境访问广告页面,检查内容是否与计划一致,并生成曝光报告。具体实现包括:获取高质量代理IP、使用Selenium或Playwright模拟用户行为、解析广告内容及生成可视化报告。案例显示,该方法能有效确保广告精准投放,优化策略并节省预算。
|
28天前
|
人工智能 缓存 搜索推荐
1688图片搜索API接口解析与 Python实战指南
1688图片搜索API接口支持通过上传图片搜索相似商品,适用于电商及商品推荐场景。用户上传图片后,经图像识别提取特征并生成关键词,调用接口返回包含商品ID、标题和价格的相似商品列表。该接口需提供图片URL或Base64编码数据,还可附加分页与筛选参数。示例代码展示Python调用方法,调试时建议使用沙箱环境测试稳定性,并优化性能与错误处理逻辑。

热门文章

最新文章

推荐镜像

更多