python+opencv+mediapipe实现手势检测上下左右(含完整代码)

这篇具有很好参考价值的文章主要介绍了python+opencv+mediapipe实现手势检测上下左右(含完整代码)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

应用场景:ai换脸,根据左右手势选择图片,上下则表示选中。

版本号:python3.7(一开始是3.6,但是mediapipe最低就是3.7

因为网上检测的都不太准,所以我在判断的时候加入了如果70次里55次检测的是左才返回左,测试完之后效果还可以,蛮准的。判断方法想的头都要秃了。

def gesture3(cap, gesture_buffer_size=70, gesture_threshold=55):
    direction = None
    mp_drawing = mp.solutions.drawing_utils
    mp_hands = mp.solutions.hands

    # 初始化手部检测模型
    hands = mp_hands.Hands(static_image_mode=False, max_num_hands=2, min_detection_confidence=0.5)

    gesture_buffer = deque(maxlen=gesture_buffer_size)  # 用于存储最近的几次手势识别结果

    while cap.isOpened():
        success, image = cap.read()
        if not success:
            print("Ignoring empty camera frame.")
            continue

        # 将图像转换为RGB格式
        image = cv2.cvtColor(cv2.flip(image, 1), cv2.COLOR_BGR2RGB)

        # 执行手部检测
        results = hands.process(image)

        if results.multi_hand_landmarks:
            for hand_landmarks in results.multi_hand_landmarks:
                # 在图像上绘制手部标记
                mp_drawing.draw_landmarks(
                    image, hand_landmarks, mp_hands.HAND_CONNECTIONS,
                    mp_drawing.DrawingSpec(color=(121, 22, 76), thickness=2, circle_radius=4),
                    mp_drawing.DrawingSpec(color=(250, 44, 250), thickness=2, circle_radius=2)
                )

                # 获取手部关键点坐标
                landmarks = hand_landmarks.landmark

                # 获取手掌位置(关键点索引为0)
                palm_landmark = hand_landmarks.landmark[0]
                palm_x = palm_landmark.x
                palm_y = palm_landmark.y

                # 获取除大拇指之外的其他手指的指尖位置
                index_tip = hand_landmarks.landmark[mp.solutions.hands.HandLandmark.INDEX_FINGER_TIP]
                middle_tip = hand_landmarks.landmark[mp.solutions.hands.HandLandmark.MIDDLE_FINGER_TIP]
                ring_tip = hand_landmarks.landmark[mp.solutions.hands.HandLandmark.RING_FINGER_TIP]
                pinky_tip = hand_landmarks.landmark[mp.solutions.hands.HandLandmark.PINKY_TIP]

                # 计算其他手指指尖到手掌位置的距离
                index_distance = math.sqrt((index_tip.x - palm_x) ** 2 + (index_tip.y - palm_y) ** 2)
                middle_distance = math.sqrt((middle_tip.x - palm_x) ** 2 + (middle_tip.y - palm_y) ** 2)
                ring_distance = math.sqrt((ring_tip.x - palm_x) ** 2 + (ring_tip.y - palm_y) ** 2)
                pinky_distance = math.sqrt((pinky_tip.x - palm_x) ** 2 + (pinky_tip.y - palm_y) ** 2)

                # 假设第二个关键点代表食指指尖,第三个关键点代表拇指指尖
                index_finger_tip = landmarks[8]
                # 获取拇指 MCP (第一关节)和 TIP(指尖)的坐标
                thumb_mcp = hand_landmarks.landmark[mp_hands.HandLandmark.THUMB_MCP]
                thumb_tip = hand_landmarks.landmark[mp_hands.HandLandmark.THUMB_TIP]

                # 获取手腕的坐标
                wrist = landmarks[0]

                # 计算食指和拇指指尖之间的距离
                distance = math.sqrt((thumb_tip.x - index_finger_tip.x)**2 + (thumb_tip.y - index_finger_tip.y)**2 + (thumb_tip.z - index_finger_tip.z)**2)
                # 计算手指和手掌在X轴和Y轴上的距离
                x_distance = index_tip.x - palm_x
                y_distance = index_tip.y - palm_y
                if abs(x_distance) > abs(y_distance):
                    # 当手腕在食指的左边,并且食指和拇指指尖之间的距离较大时,判断为向左的手势。 判断手心是否超前,以及食指和拇指指尖的距离来确定手势
                    if index_tip.x < palm_x and middle_tip.x < palm_x and ring_tip.x < palm_x and pinky_tip.x < palm_x and wrist.x > index_finger_tip.x and distance > 0.2 and index_finger_tip.x < thumb_tip.x - 0.05:  # 假设手心超前且食指和拇指指尖的距离大于0.1
                        print('Left')
                        gesture_buffer.append("Left")
                    elif index_tip.x > palm_x and middle_tip.x > palm_x and ring_tip.x > palm_x and pinky_tip.x > palm_x and wrist.x < index_finger_tip.x and distance > 0.1 and index_finger_tip.x > thumb_tip.x + 0.05:  # 假设手心超前且食指和拇指指尖的距离大于0.1
                        print('Right')
                        gesture_buffer.append("Right")
                else:
                    # 当手腕在食指的上方,并且食指和拇指指尖之间的距离较大时,判断为向上的手势
                    if index_tip.y < palm_y and middle_tip.y < palm_y and ring_tip.y < palm_y and pinky_tip.y < palm_y and wrist.y > index_finger_tip.y and distance > 0.2:  # 假设手心超前且食指和拇指指尖的距离大于0.1
                        print('Up')
                        gesture_buffer.append("Up")
                    # 这里我不用下了,如果你们需要直接把注释去掉就可以。当手腕在食指的下方,并且食指和拇指指尖之间的距离较大时,判断为向下的手势
                    # elif index_tip.y > palm_y and middle_tip.y > palm_y and ring_tip.y > palm_y and pinky_tip.y > palm_y and wrist.y < index_finger_tip.y and distance > 0.1:  # 假设手心超前且食指和拇指指尖的距离大于0.1
                    #     print('Down')
                    #     gesture_buffer.append("Down")
               


        # 统计手势识别结果
        gesture_counts = {gesture: gesture_buffer.count(gesture) for gesture in set(gesture_buffer)}

        # 判断最终手势
        if len(gesture_buffer) == gesture_buffer_size and max(gesture_counts.values()) >= gesture_threshold:
            direction = max(gesture_counts, key=gesture_counts.get)

        cv2.imshow('Hand Gestures', cv2.cvtColor(image, cv2.COLOR_RGB2BGR))
        if direction or cv2.waitKey(5) & 0xFF == 27:  # 按ESC键退出
            break

    return direction

实现效果如下:
self.landmarks = [mp_hands.handlandmark.thumb_carpal_joint,,python,opencv,开发语言
self.landmarks = [mp_hands.handlandmark.thumb_carpal_joint,,python,opencv,开发语言
self.landmarks = [mp_hands.handlandmark.thumb_carpal_joint,,python,opencv,开发语言
self.landmarks = [mp_hands.handlandmark.thumb_carpal_joint,,python,opencv,开发语言文章来源地址https://www.toymoban.com/news/detail-847290.html

到了这里,关于python+opencv+mediapipe实现手势检测上下左右(含完整代码)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 基于opencv与mediapipe的面部跟踪(人脸检测追踪)python代码实现

            面部跟踪主要是从图像或视频中检测出人脸并输出人脸位置及其大小等有效信息,并在后续帧中继续捕获人脸的位置及其大小等信息,实时跟踪人脸。此技术可用于海关、机场、视频会议、拍照对焦、面部打码等业务场景。(与人脸识别是不同范畴)         本

    2024年01月17日
    浏览(51)
  • python实现两张图片左右(横向)和纵向(上下)拼接组合

    主要用于对两幅图像进行左右组合或者上下组合,详细代码如下: 左右组合 上下组合

    2024年02月15日
    浏览(42)
  • Opencv + MediaPipe -> 手势识别

    一、概述         OpenCV(Open Source Computer Vision Library)是一个跨平台的计算机视觉库,它提供了许多用于图像和视频处理的功能,包括图像和视频的读取、预处理、特征提取、特征匹配、目标检测等。OpenCV是C++编写的,也提供了Python、Java等语言的接口,可以方便地在不同

    2024年02月05日
    浏览(62)
  • 基于python使用OpenCV和MediaPipe通过人体姿态检测实现对标准的仰卧起坐数量的计量(三)

    先来看一下main.py的代码 import cv2 import numpy as np import PoseModule as pm   cap = cv2.VideoCapture(\\\'10.mp4\\\') detector = pm.poseDetector() count = 0 dir = 0   while True:     success, img = cap.read()     img = cv2.resize(img, (400, 300))     img = detector.findPose(img, False)     lmList = detector.fi

    2024年04月16日
    浏览(47)
  • 基于opencv-mediapipe的手势识别

    上一篇文章介绍了基于opencv的手势识别,如果大家运行了我的代码,会发现代码中找出手部轮廓的效果不是很理想。当时我在网上找寻解决的办法,刚好找到了mediapip库,然后我就利用opencv和mediapipe这两个库重新进行了手势识别的代码编写。效果还不错,写篇文章记录一下。

    2024年02月09日
    浏览(37)
  • 基于mediapipe和opencv的手势控制电脑鼠标

    通过我的上一篇文章,可以了解到mediapipe关于手部检测的使用方法。这时我们就可以进行一些更加炫酷的操作。这篇文章我就来讲解一下如何用手势来控制电脑鼠标。 在开始之前我们要介绍一个能够操作电脑鼠标的库pyautogui,这里我简单介绍一下该库的一些函数,方便大家观

    2024年02月07日
    浏览(29)
  • [Python中矩阵上下左右翻转(np.flip)]

    [Python中矩阵上下左右翻转(np.flip)] 现代编程语言和相关库的发展,使得数值计算和数据处理变得更加便捷和高效。在Python中,NumPy库是众多数据科学和工程应用领域的重要支撑之一。其中,np.flip函数可以用于进行矩阵的上下左右翻转操作,是我们在处理图像、信号、物理模

    2024年02月12日
    浏览(37)
  • 用css来实现上下左右箭头

       

    2024年02月12日
    浏览(51)
  • vxe表格实现键盘上下左右方向键移动聚焦

    vxe 表格分为 vxe-table 一般表格和 vxe-grid 高级表格,两者之间的区别我就不说啦,我们来实现这两种表格用键盘按动上下左右方向键达到移动聚焦的效果。话不多说,上正文!!! 首先在标签放入这两个事件: 主要是利用vxe表格内置的@cell-click事件,来监听点击单元格的行号

    2024年02月07日
    浏览(63)
  • uniapp小程序—实现下滑关闭抽屉(包含上下左右滑动)

    操作:点击相应文字时从底部出现弹框,下滑超过一定速率,弹框回到下方隐藏; 这个组件有些多余的地方我没删,可以自行扩展。以下附带移动端的上下左右滑动,可以借鉴实现小程序的左右滑动

    2024年02月13日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包