-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmediaPipe.js
59 lines (51 loc) · 2.07 KB
/
mediaPipe.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import {
PoseLandmarker,
FilesetResolver,
DrawingUtils,
} from "https://cdn.skypack.dev/@mediapipe/[email protected]";
let poseLandmarker;
let runningMode = "VIDEO";
// let video = null;
let lastVideoTime = -1;
const mediaPipe = {
landmarks: [],
worldLandmarks: [],
};
// Before we can use PoseLandmarker class we must wait for it to finish
// loading. Machine Learning models can be large and take a moment to
// get everything needed to run.
const createPoseLandmarker = async () => {
const vision = await FilesetResolver.forVisionTasks(
"https://cdn.jsdelivr.net/npm/@mediapipe/[email protected]/wasm"
);
poseLandmarker = await PoseLandmarker.createFromOptions(vision, {
baseOptions: {
// modelAssetPath: `https://storage.googleapis.com/mediapipe-models/pose_landmarker/pose_landmarker_lite/float16/1/pose_landmarker_lite.task`,
// modelAssetPath: `https://storage.googleapis.com/mediapipe-models/pose_landmarker/pose_landmarker_lite/float16/latest/pose_landmarker_lite.task`,
modelAssetPath: `https://storage.googleapis.com/mediapipe-models/pose_landmarker/pose_landmarker_full/float16/latest/pose_landmarker_full.task`,
// modelAssetPath: `https://storage.googleapis.com/mediapipe-models/pose_landmarker/pose_landmarker_heavy/float16/latest/pose_landmarker_heavy.task`,
delegate: "GPU",
},
runningMode: runningMode,
numPoses: 1,
});
};
createPoseLandmarker();
const predictWebcam = (video) => {
// Now let's start detecting the stream.
let startTimeMs = performance.now();
if (video.elt && lastVideoTime !== video.elt.currentTime && poseLandmarker) {
lastVideoTime = video.elt.currentTime;
// console.log(poseLandmarker)
poseLandmarker.detectForVideo(video.elt, startTimeMs, (result) => {
mediaPipe.landmarks = result.landmarks;
mediaPipe.worldLandmarks = result.worldLandmarks;
});
}
// Call this function again to keep predicting when the browser is ready.
window.requestAnimationFrame(() => {
predictWebcam(video);
});
};
mediaPipe.predictWebcam = predictWebcam;
export { mediaPipe };