-
Notifications
You must be signed in to change notification settings - Fork 112
/
FingerDescription.js
98 lines (82 loc) · 1.99 KB
/
FingerDescription.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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
const Finger = {
Thumb: 0,
Index: 1,
Middle: 2,
Ring: 3,
Pinky: 4,
// just for convenience
all: [0, 1, 2, 3, 4],
nameMapping: {
0: 'Thumb',
1: 'Index',
2: 'Middle',
3: 'Ring',
4: 'Pinky'
},
// Describes mapping of joints based on the 21 points returned by handpose.
// Handpose indexes are defined as follows:
// (all fingers use last index as "finger tip")
// ---------------------------------------------------------------------------
// [0] Palm
// [1-4] Thumb
// [5-8] Index
// [9-12] Middle
// [13-16] Ring
// [17-20] Pinky
pointsMapping: {
0: [[0, 1], [1, 2], [2, 3], [3, 4]],
1: [[0, 5], [5, 6], [6, 7], [7, 8]],
2: [[0, 9], [9, 10], [10, 11], [11, 12]],
3: [[0, 13], [13, 14], [14, 15], [15, 16]],
4: [[0, 17], [17, 18], [18, 19], [19, 20]]
},
getName: function(value) {
return (typeof this.nameMapping[value] !== undefined) ?
this.nameMapping[value] : false;
},
getPoints: function(value) {
return (typeof this.pointsMapping[value] !== undefined) ?
this.pointsMapping[value] : false;
},
}
const FingerCurl = {
NoCurl: 0,
HalfCurl: 1,
FullCurl: 2,
nameMapping: {
0: 'No Curl',
1: 'Half Curl',
2: 'Full Curl'
},
getName: function(value) {
return (typeof this.nameMapping[value] !== undefined) ?
this.nameMapping[value] : false;
},
};
const FingerDirection = {
VerticalUp: 0,
VerticalDown: 1,
HorizontalLeft: 2,
HorizontalRight: 3,
DiagonalUpRight: 4,
DiagonalUpLeft: 5,
DiagonalDownRight: 6,
DiagonalDownLeft: 7,
nameMapping: {
0: 'Vertical Up',
1: 'Vertical Down',
2: 'Horizontal Left',
3: 'Horizontal Right',
4: 'Diagonal Up Right',
5: 'Diagonal Up Left',
6: 'Diagonal Down Right',
7: 'Diagonal Down Left',
},
getName: function(value) {
return (typeof this.nameMapping[value] !== undefined) ?
this.nameMapping[value] : false;
},
};
export {
Finger, FingerCurl, FingerDirection
}