溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

發(fā)布時間:2022-01-11 10:14:35 來源:億速云 閱讀:237 作者:柒染 欄目:開發(fā)技術(shù)

今天給大家介紹一下基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能。,文章的內(nèi)容小編覺得不錯,現(xiàn)在給大家分享一下,覺得有需要的朋友可以了解一下,希望對大家有所幫助,下面跟著小編的思路一起來閱讀吧。

一、前言

基于Mediapipe+Opencv實現(xiàn)手勢檢測,想實現(xiàn)一下姿態(tài)識別的時候,感覺手勢識別也蠻重要的就過來順便實現(xiàn)一下。


二、環(huán)境配置

軟件:

ANACONDA3+Pycharm2019

環(huán)境:

  • opencv-python>=4.5.5

  • mediapipe>=0.8.9.1

注:一定關(guān)掉科學(xué)上網(wǎng)

三、全部源碼

比較短小且只有一個源文件MediapipeHandTracking.py我就直接在這里貼了

MediapipeHandTracking.py程序結(jié)構(gòu):

  • 第一步:保存mediapipe中的手勢識別解決方案到mpHands,hands,mpDraw中

  • 第二步:參數(shù)設(shè)定

  • 第三步:循環(huán)讀取視頻流到img,img輸入hands.hands函數(shù)得到結(jié)果,繪制結(jié)果到img并輸出

MediapipeHandTracking.py源碼與注釋

import cv2
import mediapipe as mp
import time
#第一步:保存mediapipe中的手勢識別解決方案到mpHands,hands,mpDraw中
mpHands = mp.solutions.hands #以下三個是mediapipe 中的API調(diào)用模板了
hands = mpHands.Hands(min_detection_confidence=0.5, min_tracking_confidence=0.5)#最小檢測置信度,最小追蹤置信度
mpDraw = mp.solutions.drawing_utils                              #獲取mediapipe解決方案的繪畫工具包
#第二步:參數(shù)設(shè)定
handLmsStyle = mpDraw.DrawingSpec(color=(0, 0, 255), thickness=3)#繪制手部關(guān)鍵點的顏色與粗細(xì)
handConStyle = mpDraw.DrawingSpec(color=(0, 255, 0), thickness=5)#繪制手部線條的顏色與粗細(xì)
pTime = 0 #和下面的cTime一起用于計算視頻輸入流FPS
cTime = 0
cap = cv2.VideoCapture(0) #打開編號為0的攝像頭,這個一般是自帶攝像頭
#第三步:循環(huán)讀取視頻流到img,img輸入hands.hands函數(shù)得到結(jié)果,繪制結(jié)果到img并輸出
while True:
    ret, img = cap.read()       #從cap中讀取圖片到img,并將讀取是否成功的結(jié)果保存在ret
    if ret:
        imgRGB = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)  #模型訓(xùn)練的時候是使用RGB訓(xùn)練,對于這個類型識別精度和速度比較高
        result = hands.process(imgRGB)                 #將RGB圖片輸入手部模型將結(jié)果保存在result
        # print(result.multi_hand_landmarks)           #打印result.multi_hand_landmarks內(nèi)容,可以去掉試一下
        imgHeight = img.shape[0]       #獲取攝像機圖片的高
        imgWidth = img.shape[1]        #獲取攝像機圖片的寬
        if result.multi_hand_landmarks:#如果multi_hand_landmarks不為空進(jìn)入循環(huán)
            for handLms in result.multi_hand_landmarks:  #遍歷multi_hand_landmarks內(nèi)每一個hand_landmark(手部關(guān)鍵點),相對于遍歷圖片中每一個手
                mpDraw.draw_landmarks(img, handLms, mpHands.HAND_CONNECTIONS, handLmsStyle, handConStyle) #調(diào)用mediapipe內(nèi)繪畫工具包繪畫手部關(guān)鍵點
                for i, lm in enumerate(handLms.landmark):  #i保存第幾個手部關(guān)鍵點,lm保存該點在圖中的歸一化值
                    xPos = int(lm.x * imgWidth) #第i個關(guān)鍵點x
                    yPos = int(lm.y * imgHeight)#第i個關(guān)鍵點y
                    cv2.putText(img, str(i), (xPos-25, yPos+5), cv2.FONT_HERSHEY_SIMPLEX, 0.4, (0, 0, 255), 2)#繪制關(guān)鍵點在,關(guān)鍵點左邊靠下一點
                    if i == 8:#當(dāng)畫到第八個關(guān)鍵點時
                         cv2.circle(img, (xPos, yPos), 10, (166, 0, 0), cv2.FILLED)#畫一個圓
                         #print(i, xPos, yPos)   #打印繪制這個點時候的坐標(biāo)
        cTime = time.time()
        fps = 1/(cTime-pTime)
        pTime = cTime
        cv2.putText(img, f"FPS : {int(fps)}", (30, 50), cv2.FONT_HERSHEY_SIMPLEX, 1, (255, 0, 0), 3) #繪制FSP到圖中
        cv2.imshow('img', img) #輸出圖片
    if cv2.waitKey(1) == ord('q'):#點擊視頻,輸入q退出
        break

四、環(huán)境配置

1、在Anaconda3上新建環(huán)境Gesture

打開Anaconda Prompt,輸入:

conda create -n Gesture python=3.8

2、激活Gesture環(huán)境并下載opencv-python包

激活環(huán)境:conda activate Gesture
下載opencv-python包:pip install opencv-python -i https://pypi.tuna.tsinghua.edu.cn/simple/

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

3、下載mediapipe包

pip install mediapipe -i https://pypi.tuna.tsinghua.edu.cn/simple/

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

4、打開Pycharm完成環(huán)境導(dǎo)入項目

配置代碼運行環(huán)境

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

五、運行程序:

用Pycharm打開包含hanTracking.py程序的文件夾,并運行

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

運行結(jié)果

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

六、程序應(yīng)用擴展

1、手部的關(guān)鍵點的位置和次序我們?nèi)恳阎奶攸c

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

該功能可用于圖片ROI提取截取出圖片,然后進(jìn)行其他一些圖片操作。
該功能可用于手勢響應(yīng)事件。比如約定,食指和大拇指也就是4號和8號觸碰時候觸發(fā)某事件
,等等。
實現(xiàn)AL+操作

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

2、和其他AL結(jié)合

比如姿態(tài)檢測AL,能將人識別成一個火柴人,開發(fā)空間有不少用處。

3、全身檢測源碼

import cv2
import time
import mediapipe as mp
mp_drawing = mp.solutions.drawing_utils
mp_holistic = mp.solutions.holistic
holistic = mp_holistic.Holistic(min_detection_confidence=0.5, min_tracking_confidence=0.5)
handLmsStyle = mp_drawing.DrawingSpec(color=(0, 0, 255), thickness=0)#繪制手部關(guān)鍵點的顏色與粗細(xì)
handConStyle = mp_drawing.DrawingSpec(color=(0, 255, 0), thickness=4)#繪制手部線條的顏色與粗細(xì)
cap = cv2.VideoCapture(0)
while True:
    ret,image=cap.read()
    if ret:
        image = cv2.flip(image, 1)
        image=cv2.cvtColor(image,cv2.COLOR_BGR2RGB)
        results = holistic.process(image)
        if results.pose_landmarks:
            mp_drawing.draw_landmarks(image, results.face_landmarks, mp_holistic.FACEMESH_CONTOURS,handLmsStyle,handConStyle)
            mp_drawing.draw_landmarks(image, results.left_hand_landmarks, mp_holistic.HAND_CONNECTIONS)
            mp_drawing.draw_landmarks(image, results.right_hand_landmarks, mp_holistic.HAND_CONNECTIONS)
            mp_drawing.draw_landmarks(image, results.pose_landmarks, mp_holistic.POSE_CONNECTIONS)
        cv2.imshow("img",image)
        if cv2.waitKey(1)==ord("q"):
            break
holistic.close()

運行效果如下:
曬曬我?guī)洑獾纳嵊?/p>

基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能

以上就是基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能的全部內(nèi)容了,更多與基于Mediapipe+Opencv如何實現(xiàn)手勢檢測功能相關(guān)的內(nèi)容可以搜索億速云之前的文章或者瀏覽下面的文章進(jìn)行學(xué)習(xí)哈!相信小編會給大家增添更多知識,希望大家能夠支持一下億速云!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI