位置: IT常识 - 正文

【计算机视觉】基于Python—OpenCV的手势识别详解(一)(计算机视觉算法)

编辑:rootadmin
【计算机视觉】基于Python—OpenCV的手势识别详解(一) 文章目录更新日记前言前期准备识别手部模型识别视频输入方法手势识别方法完整代码结语更新日记

推荐整理分享【计算机视觉】基于Python—OpenCV的手势识别详解(一)(计算机视觉算法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:计算机视觉技术的应用,计算机视觉技术,计算机视觉与图像处理,计算机视觉与图像处理,计算机视觉的未来发展方向有哪些,计算机视觉的未来发展方向有哪些,计算机视觉技术,计算机视觉技术,内容如对您有帮助,希望把文章链接给更多的朋友!

更新日记: 2022.04.18:应各位网友需求,已mp库更新后的手部识别模型代码。目前可以正常的RUN啦!!

前言

人工智能的浪潮正在席卷全球。一个已经被谈论了几十年的概念,如今这几年,相关技术的发展速度越来越快。机器学习、深度学习、计算机视觉等名词逐渐走进人们的生活,它们同属于人工智能的范畴之中。

计算机视觉是人工智能领域的一个分支计算机视觉实际上是一个跨领域的交叉学科,包括计算机科学,数学,工程学,物理学,生物学和心理学等领域。许多科学家认为,计算机视觉为人工智能的发展开拓了道路。

简单来说,计算机视觉就是赋予计算机一双观察世界的眼睛,再使用计算机优秀的大脑快速的计算,服务人类。

今天我们将深入浅出,简单介绍Python计算机视觉中的手势识别方法,识别手势——数字(一、二、三、四、五和大拇指的赞赏)。如果你喜欢本篇文章或对你有帮助的话,别忘了点赞+关注噢!

前期准备

本篇我们将会用到Python的OpenCV模块和手部模型模块mediapipe,在Python的pip安装方法中,安装方法如下:

opencv是常用的图像识别模块

mediapipe是谷歌开发并开源的多媒体机器学习模型应用框架。

pip install opencv-pythonpip install mediapipe

如果你的电脑装有Anaconda,建议选择在Anaconda的环境命令行中进行相应模块的安装,以此构建更具体的机器学习环境

当你安装好OpenCV和mediapipe模块以后,你可以在Python代码中写入

import cv2import mediapipe as mp

如果运行成功,那么你的Opencv-python模块即为安装成功,那么我们现在就开始进入今天的正题吧!

识别手部模型

既然要做手势识别,那么就要去找到我们传入图像的手部信息。本处我们将使用mediapipe模型去找到手部模型,并完成手部模型的识别模块,并命名,我们将在后续手势识别内容中将其作为模块引入

HandTrackingModule.py

# -*- coding:utf-8 -*-"""CODE >>> SINCE IN CAIXYPROMISE.MOTTO >>> STRIVE FOR EXCELLENT.CONSTANTLY STRIVING FOR SELF-IMPROVEMENT.@ By: CaixyPromise@ Date: 2021-10-17"""import cv2import mediapipe as mpclass HandDetector: """ 使用mediapipe库查找手。导出地标像素格式。添加了额外的功能。 如查找方式,许多手指向上或两个手指之间的距离。而且提供找到的手的边界框信息。 """ def __init__(self, mode=False, maxHands=2, detectionCon=0.5, minTrackCon = 0.5): """ :param mode: 在静态模式下,对每个图像进行检测 :param maxHands: 要检测的最大手数 :param detectionCon: 最小检测置信度 :param minTrackCon: 最小跟踪置信度 """ self.mode = mode self.maxHands = maxHands self.modelComplex = False self.detectionCon = detectionCon self.minTrackCon = minTrackCon# 初始化手部识别模型 self.mpHands = mp.solutions.hands self.hands = self.mpHands.Hands(self.mode, self.maxHands, self.modelComplex, self.detectionCon, self.minTrackCon) self.mpDraw = mp.solutions.drawing_utils# 初始化绘图器 self.tipIds = [4, 8, 12, 16, 20]# 指尖列表 self.fingers = [] self.lmList = [] def findHands(self, img, draw=True): """ 从图像(BRG)中找到手部。 :param img: 用于查找手的图像。 :param draw: 在图像上绘制输出的标志。 :return: 带或不带图形的图像 """ imgRGB = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) # 将传入的图像由BGR模式转标准的Opencv模式——RGB模式, self.results = self.hands.process(imgRGB) if self.results.multi_hand_landmarks: for handLms in self.results.multi_hand_landmarks: if draw: self.mpDraw.draw_landmarks(img, handLms, self.mpHands.HAND_CONNECTIONS) return img def findPosition(self, img, handNo=0, draw=True): """ 查找单手的地标并将其放入列表中像素格式。还可以返回手部周围的边界框。 :param img: 要查找的主图像 :param handNo: 如果检测到多只手,则为手部id :param draw: 在图像上绘制输出的标志。(默认绘制矩形框) :return: 像素格式的手部关节位置列表;手部边界框 """ xList = [] yList = [] bbox = [] bboxInfo =[] self.lmList = [] if self.results.multi_hand_landmarks: myHand = self.results.multi_hand_landmarks[handNo] for id, lm in enumerate(myHand.landmark): h, w, c = img.shape px, py = int(lm.x * w), int(lm.y * h) xList.append(px) yList.append(py) self.lmList.append([px, py]) if draw: cv2.circle(img, (px, py), 5, (255, 0, 255), cv2.FILLED) xmin, xmax = min(xList), max(xList) ymin, ymax = min(yList), max(yList) boxW, boxH = xmax - xmin, ymax - ymin bbox = xmin, ymin, boxW, boxH cx, cy = bbox[0] + (bbox[2] // 2), \ bbox[1] + (bbox[3] // 2) bboxInfo = {"id": id, "bbox": bbox,"center": (cx, cy)} if draw: cv2.rectangle(img, (bbox[0] - 20, bbox[1] - 20), (bbox[0] + bbox[2] + 20, bbox[1] + bbox[3] + 20), (0, 255, 0), 2) return self.lmList, bboxInfo def fingersUp(self): """ 查找列表中打开并返回的手指数。会分别考虑左手和右手 :return:竖起手指的列表 """ if self.results.multi_hand_landmarks: myHandType = self.handType() fingers = [] # Thumb if myHandType == "Right": if self.lmList[self.tipIds[0]][0] > self.lmList[self.tipIds[0] - 1][0]: fingers.append(1) else: fingers.append(0) else: if self.lmList[self.tipIds[0]][0] < self.lmList[self.tipIds[0] - 1][0]: fingers.append(1) else: fingers.append(0) # 4 Fingers for id in range(1, 5): if self.lmList[self.tipIds[id]][1] < self.lmList[self.tipIds[id] - 2][1]: fingers.append(1) else: fingers.append(0) return fingers def handType(self): """ 检查传入的手部是左还是右 :return: "Right" 或 "Left" """ if self.results.multi_hand_landmarks: if self.lmList[17][0] < self.lmList[5][0]: return "Right" else: return "Left"识别视频输入方法【计算机视觉】基于Python—OpenCV的手势识别详解(一)(计算机视觉算法)

完成手部模型的获取与识别,现在我们就要将内容传入到计算机当中,使其能进行手部的识别以及手势的识别。本处我们将使用OpenCV进行内容的输入流,开启计算机的摄像头获取内容,并使用刚刚我们写的HandTrackingModule模块作为手部的识别模块。

Main.py

# -*- coding:utf-8 -*-"""CODE >>> SINCE IN CAIXYPROMISE.MOTTO >>> STRIVE FOR EXCELLENT.CONSTANTLY STRIVING FOR SELF-IMPROVEMENT.@ By: CaixyPromise@ Date: 2021-10-17"""import cv2from HandTrackingModule import HandDetectorclass Main: def __init__(self): self.camera = cv2.VideoCapture(0,cv2.CAP_DSHOW) # 以视频流传入 self.camera.set(3, 1280) # 设置分辨率 self.camera.set(4, 720) def Gesture_recognition(self): while True: self.detector = HandDetector() frame, img = self.camera.read() img = self.detector.findHands(img) # 找到你的手部 lmList, bbox = self.detector.findPosition(img) # 获取你手部的方位 cv2.imshow("camera", img) if cv2.getWindowProperty('camera', cv2.WND_PROP_VISIBLE) < 1: break # 通过关闭按钮退出程序 cv2.waitKey(1) # if cv2.waitKey(1) & 0xFF == ord("q"): # break # 按下q退出

现在,当我们运行程序后,程序会运行你的计算机默认摄像头,当你露出你的手时,会传出图像圈住你的手部,并且绘制出你的手部主要关节点。

其中,你的手部主要关节点已经标好序号,你的手部分为了21个关节点,指尖分别为4 8 12 16 20

具体关节分为:

手势识别方法

通过前面的讲解,我们完成了手部获取与识别、识别内容的输入,那么我们现在就来开始写我们的手势识别方法。这里,我们用到识别模块里的fingersUp()方法。

找到我们刚刚写的Main.py文件(识别内容输入方法),当我们找到并绘制出我们的手部位置以后,此时的findPosition()方法会得到你的手部具体方位,其中lmList是关节位置方位(type:list),bbox是边框方位(type:dict),当未识别到内容时两者均为空。所以,我们只需要写当数组中存在数据(非空),进行手指判断即可,那么我们可以写成

# -*- coding:utf-8 -*-"""CODE >>> SINCE IN CAIXYPROMISE.MOTTO >>> STRIVE FOR EXCELLENT.CONSTANTLY STRIVING FOR SELF-IMPROVEMENT.@ By: CaixyPromise@ Date: 2021-10-17"""def Gesture_recognition(self): while True: self.detector = HandDetector() frame, img = self.camera.read() img = self.detector.findHands(img) lmList, bbox = self.detector.findPosition(img) if lmList: x1, x2, x3, x4, x5 = self.detector.fingersUp()

上面我们fingersUp()方法谈到,fingersUp()方法会传回从大拇指开始数的长度为5的数组,立起的手指标记为1,放下标记为0。

本次我们的目的时写一个识别我们生活常见的数字手势以及一个赞扬大拇指的手势。结合我们生活,识别你的手势可以写为

# -*- coding:utf-8 -*-"""CODE >>> SINCE IN CAIXYPROMISE.MOTTO >>> STRIVE FOR EXCELLENT.CONSTANTLY STRIVING FOR SELF-IMPROVEMENT.@ By: CaixyPromise@ Date: 2021-10-17"""def Gesture_recognition(self): while True: self.detector = HandDetector() frame, img = self.camera.read() img = self.detector.findHands(img) lmList, bbox = self.detector.findPosition(img) if lmList: x1, x2, x3, x4, x5 = self.detector.fingersUp() if (x2 == 1 and x3 == 1) and (x4 == 0 and x5 == 0 and x1 == 0): # TWO elif (x2 == 1 and x3 == 1 and x4 == 1) and (x1 == 0 and x5 == 0): # THREE elif (x2 == 1 and x3 == 1 and x4 == 1 and x5 == 1) and (x1 == 0): # FOUR elif x1 == 1 and x2 == 1 and x3 == 1 and x4 == 1 and x5 == 1: # FIVE elif x2 == 1 and (x1 == 0, x3 == 0, x4 == 0, x5 == 0): # ONE elif x1 and (x2 == 0, x3 == 0, x4 == 0, x5 == 0): # NICE_GOOD

完成基本的识别以后,我们要把内容表达输出出来。这里我们结合bbox返回的手部方框方位,再使用opencv里的putText方法,实现识别结果的输出。

# -*- coding:utf-8 -*-"""CODE >>> SINCE IN CAIXYPROMISE.MOTTO >>> STRIVE FOR EXCELLENT.CONSTANTLY STRIVING FOR SELF-IMPROVEMENT.@ By: CaixyPromise@ Date: 2021-10-17"""def Gesture_recognition(self): while True: self.detector = HandDetector() frame, img = self.camera.read() img = self.detector.findHands(img) lmList, bbox = self.detector.findPosition(img) if lmList: x_1, y_1 = bbox["bbox"][0], bbox["bbox"][1] x1, x2, x3, x4, x5 = self.detector.fingersUp() if (x2 == 1 and x3 == 1) and (x4 == 0 and x5 == 0 and x1 == 0): cv2.putText(img, "2_TWO", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) elif (x2 == 1 and x3 == 1 and x4 == 1) and (x1 == 0 and x5 == 0): cv2.putText(img, "3_THREE", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) elif (x2 == 1 and x3 == 1 and x4 == 1 and x5 == 1) and (x1 == 0): cv2.putText(img, "4_FOUR", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) elif x1 == 1 and x2 == 1 and x3 == 1 and x4 == 1 and x5 == 1: cv2.putText(img, "5_FIVE", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) elif x2 == 1 and (x1 == 0, x3 == 0, x4 == 0, x5 == 0): cv2.putText(img, "1_ONE", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) elif x1 and (x2 == 0, x3 == 0, x4 == 0, x5 == 0): cv2.putText(img, "GOOD!", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) cv2.imshow("camera", img) if cv2.getWindowProperty('camera', cv2.WND_PROP_VISIBLE) < 1: break cv2.waitKey(1)

现在,我们已经完成手势的识别与结果输出,我们把完整代码运行一下,即可验证出我们的代码效果。

完整代码

完整代码如下

# -*- coding:utf-8 -*-"""CODE >>> SINCE IN CAIXYPROMISE.STRIVE FOR EXCELLENT.CONSTANTLY STRIVING FOR SELF-IMPROVEMENT.@ by: caixy@ date: 2021-10-1"""import cv2from HandTrackingModule import HandDetectorclass Main: def __init__(self): self.camera = cv2.VideoCapture(0,cv2.CAP_DSHOW) self.camera.set(3, 1280) self.camera.set(4, 720) def Gesture_recognition(self): while True: self.detector = HandDetector() frame, img = self.camera.read() img = self.detector.findHands(img) lmList, bbox = self.detector.findPosition(img) if lmList: x_1, y_1 = bbox["bbox"][0], bbox["bbox"][1] x1, x2, x3, x4, x5 = self.detector.fingersUp() if (x2 == 1 and x3 == 1) and (x4 == 0 and x5 == 0 and x1 == 0): cv2.putText(img, "2_TWO", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) elif (x2 == 1 and x3 == 1 and x4 == 1) and (x1 == 0 and x5 == 0): cv2.putText(img, "3_THREE", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) elif (x2 == 1 and x3 == 1 and x4 == 1 and x5 == 1) and (x1 == 0): cv2.putText(img, "4_FOUR", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) elif x1 == 1 and x2 == 1 and x3 == 1 and x4 == 1 and x5 == 1: cv2.putText(img, "5_FIVE", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) elif x2 == 1 and (x1 == 0, x3 == 0, x4 == 0, x5 == 0): cv2.putText(img, "1_ONE", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) elif x1 and (x2 == 0, x3 == 0, x4 == 0, x5 == 0): cv2.putText(img, "GOOD!", (x_1, y_1), cv2.FONT_HERSHEY_PLAIN, 3, (0, 0, 255), 3) cv2.imshow("camera", img) if cv2.getWindowProperty('camera', cv2.WND_PROP_VISIBLE) < 1: break cv2.waitKey(1) # if cv2.waitKey(1) & 0xFF == ord("q"): # breakif __name__ == '__main__': Solution = Main() Solution.Gesture_recognition()

效果一目了然,计算机成功识别了你的手势并把内容输出。快去试试吧!

结语

本篇计算机视觉的手势识别内容写完了,这也是本人第一篇关于人工智能类计算机视觉的推文,后续我们也会持续输出有关于人工智能类的文章,如果本篇写作有纰漏和错误或疑问的地方,还望各位能在评论区指出,让我们一起共同进步一起学习。

创作不易,如果你觉得这篇文章对你有用的话,别忘了点赞在看+关注噢!

下一篇我们将介绍手势识别的进阶——动态手势的识别,我们会将文章第一时间发送在微信公众号:“01编程小屋”当中,别忘了关注我们的公众号以免错过了噢!

本文链接地址:https://www.jiuchutong.com/zhishi/300850.html 转载请保留说明!

上一篇:Python 爬虫案例(python爬虫案例题目)

下一篇:自动驾驶入门必须要学会的ADAS(详解)(自动驾驶科普)

  • 微信读书是免费的吗(微信读书免费会员)

    微信读书是免费的吗(微信读书免费会员)

  • 电脑微信截图微信窗口就不见了(电脑微信截图微信窗口不隐藏)

    电脑微信截图微信窗口就不见了(电脑微信截图微信窗口不隐藏)

  • 在华为手机上怎么隐藏应用(在华为手机上怎么注销小米账号)

    在华为手机上怎么隐藏应用(在华为手机上怎么注销小米账号)

  • 苹果手机怎么录屏幕视频带声音(苹果手机怎么录音电话通话)

    苹果手机怎么录屏幕视频带声音(苹果手机怎么录音电话通话)

  • airpods切歌不灵敏(airpods切歌不好使)

    airpods切歌不灵敏(airpods切歌不好使)

  • 华为手机最下面三个键不见了怎么办(华为手机最下面的图标不显示怎么办)

    华为手机最下面三个键不见了怎么办(华为手机最下面的图标不显示怎么办)

  • 通过局域网方式接入Internet必需的硬件有(通过局域网上网的计算机的ip地址)

    通过局域网方式接入Internet必需的硬件有(通过局域网上网的计算机的ip地址)

  • iqooneo3指纹在哪(iqooneo3指纹在哪里)

    iqooneo3指纹在哪(iqooneo3指纹在哪里)

  • 微信聊天记录如何备份(微信聊天记录如何彻底删除)

    微信聊天记录如何备份(微信聊天记录如何彻底删除)

  • 压缩文件已损坏是什么意思(压缩文件已损坏或压缩文件未知)

    压缩文件已损坏是什么意思(压缩文件已损坏或压缩文件未知)

  • 抖音0播放量怎么恢复正常(抖音播放量怎么表现)

    抖音0播放量怎么恢复正常(抖音播放量怎么表现)

  • 电脑任务栏点击没反应是什么原因(电脑任务栏点击没反应)

    电脑任务栏点击没反应是什么原因(电脑任务栏点击没反应)

  • 苹果怎么加内存(苹果怎么加内存条)

    苹果怎么加内存(苹果怎么加内存条)

  • ipad无法连接到app store是什么意思(苹果ipad连不上wifi怎么回事)

    ipad无法连接到app store是什么意思(苹果ipad连不上wifi怎么回事)

  • 微博怎么关注通讯录好友(如何在微博关注通讯录好友)

    微博怎么关注通讯录好友(如何在微博关注通讯录好友)

  • 手机上的txt文件能删吗

    手机上的txt文件能删吗

  • 存储器分为哪三个种类(存储器分为哪三种类型)

    存储器分为哪三个种类(存储器分为哪三种类型)

  • 微信朋友圈双击头像抖动(微信朋友圈双击无法回到顶部)

    微信朋友圈双击头像抖动(微信朋友圈双击无法回到顶部)

  • 手机注册淘宝店铺流程(手机注册淘宝店铺怎么注销)

    手机注册淘宝店铺流程(手机注册淘宝店铺怎么注销)

  • 苹果七手机基带坏了(苹果七手机基带修要多少钱)

    苹果七手机基带坏了(苹果七手机基带修要多少钱)

  • 粉笔账号可以几个人用(粉笔账号几个设备登录)

    粉笔账号可以几个人用(粉笔账号几个设备登录)

  • mix2尺寸(小米mix2尺寸长宽高)

    mix2尺寸(小米mix2尺寸长宽高)

  • cor-al10什么型号(cor-al10c)

    cor-al10什么型号(cor-al10c)

  • 如何刷新bios?在windows系统上刷新bios的方法(笔记本如何刷新bios)

    如何刷新bios?在windows系统上刷新bios的方法(笔记本如何刷新bios)

  • 坏账准备要写到明细账里面吗
  • 政府农民合作社架构
  • 生产调味料用什么手续
  • 企业如何做增量
  • 总账和成本哪个工资高
  • 个人所得税减除费用6万元什么意思
  • 资产负债表应付账款怎么算
  • 百旺税盘网络连接不上
  • 个税里任职受雇从业类型
  • 取得划拨或赠与资产需要缴企业所得税吗?
  • 网店会计的工作内容是什么
  • 担保预计负债要如何做账?
  • 转让长期股权投资交什么税
  • 增值税进项和销项税的计算方法
  • 外资企业所得税优惠政策
  • 特许权使用费收入确认分录
  • 增值税发票丢失可以用复印件入账么
  • 问10个问题
  • 消费税为什么不计入长投成本
  • 汇算清缴涉及到哪些科目的调整
  • 住房公积金个人缴费比例
  • 停车管理费什么时候交
  • 发票少开退回多付的货款怎么入账?
  • 增值税申报交税后怎样补录未抵扣进项税
  • 出口退税函调是什么意思
  • 房屋对外投资
  • 小额纳税人增值税专用发票税率1%
  • 当月扣缴社保需要申报吗
  • 超市的成功秘诀
  • linux c gui
  • 对公转账存款
  • 经营租赁固定资产体现实质重于形式
  • 实收资本大于注册资本是什么意思
  • 递延所得税负债借贷方向
  • joomla安装教程
  • 黄金海岸冲浪者沙滩
  • WGAN(Wasserstein GAN)看这一篇就够啦,WGAN论文解读
  • html在线小游戏
  • 计算机视觉opencv 有什么项目
  • vue.js如何安装
  • nodejs 下载
  • php 模拟post
  • 宝塔怎么做?
  • 企业年报网上申报入口贵州
  • 种植中药材公司取名字大全
  • 季度申报所得税时可以用以前年度亏损吗
  • 购进小汽车自用为什么可以抵扣进项税
  • 公司收购股权交什么税
  • 4s店开的维修发票怎么开
  • 娱乐服务计费销售额包括
  • 固定资产可以一次性折旧吗
  • 网上代增值税专用发票
  • 增值税发票内容填写不全应如何进行处理?
  • 异地学校
  • 事业单位财务报销制度和流程
  • 过路费油费计入什么费用
  • 在建工程转固定资产的账务处理
  • 小规模纳税人进项可以抵扣吗
  • SQL order by ID desc/asc加一个排序的字段解决查询慢问题
  • win7怎么创建新用户
  • FreeBSD架? FTP
  • hke是什么意思
  • windows8笔记本电脑
  • linux charon
  • linux 用户进程
  • Win7系统可以装ie10浏览器么
  • threejs中文文档pdf
  • mongo 安装
  • javascript:openattachment
  • linux shell脚本编程入门
  • AppWidgetProvider使用介绍
  • unity协程的工作原理
  • python爬虫快速入门
  • javascript面向对象编程
  • 怎么在手机开数据那里看用了多少流量
  • 关联企业业务往来税收调整
  • 化妆品的消费税税率是多少
  • 公益性捐赠支出属于什么会计科目
  • 关于研发费用的审计程序,下列说法中错误的是
  • 广东电子税务局官网登录入口手机版
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设