forked from MoMask/react-native-ok-gesture-password
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Utils.js
103 lines (92 loc) · 3.2 KB
/
Utils.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
99
100
101
102
103
//02-2, 35-2, 68-2 y1=y2 && x1-x2=|6 * outerRadius| gap=1
//06-6, 17-6, 28-6 x1=x2 && y1-y2=|6 * outerRadius| gap=3
//08-8, x1-x2=|6 * outerRadius| && y1-y2=|6 * outerRadius| gap=4
//26-4 x1-x2=|6 * outerRadius| && y1-y2=|6 * outerRadius| gap=2
function getLineDistance(start, end) {
return Math.sqrt(Math.pow(Math.abs(start.x - end.x), 2) + Math.pow(Math.abs(start.y - end.y), 2));
}
export function isPointInPath(location, origin, radius) {
return radius > getLineDistance(location, origin);
}
export function getLineTransform(start, end) {
let distance = getLineDistance(start, end);
let rotateRad = Math.acos((end.x - start.x) / distance);
if (start.y > end.y) {
rotateRad = Math.PI * 2 - rotateRad;
}
let translateX = (end.x + start.x) / 2 - start.x - distance / 2;
let translateY = (end.y + start.y) / 2 - start.y;
return {
distance,
rotateRad,
translateX,
translateY,
};
}
export function getArrowTransform(start, end, width, borderWidth, vertexDeg) {
let distance = getLineDistance(start, end);
let rotateRad = Math.acos((end.x - start.x) / distance);
if (start.y > end.y) {
rotateRad = Math.PI * 2 - rotateRad;
}
let origin = {
x: start.x + Math.cos(rotateRad) * width * 2,
y: start.y + Math.sin(rotateRad) * width * 2,
};
let vertexRad = vertexDeg / 2 * 2 * Math.PI / 360;
let translateX = -borderWidth;
let translateY = -borderWidth;
if (start.x == end.x) {
if (end.y > start.y) {
translateY = -borderWidth / 2;
} else {
translateY = -borderWidth * 1.5;
}
} else if (start.y == end.y) {
if (end.x > start.x) {
translateX = -borderWidth / 2;
} else {
translateX = -borderWidth * 1.5;
}
} else {
if (start.x > end.x && start.y > end.y) {
translateX = -Math.sqrt(Math.pow(borderWidth * 2.5, 2)) / 2;
translateY = -Math.sqrt(Math.pow(borderWidth * 2.5, 2)) / 2;
} else if (start.x > end.x && end.y > start.y) {
translateX = -Math.sqrt(Math.pow(borderWidth * 2.5, 2)) / 2;
translateY = -Math.sqrt(Math.pow(borderWidth * 1.5, 2)) / 2;
} else if (end.x > start.x && start.y > end.y) {
translateX = -Math.sqrt(Math.pow(borderWidth * 1.5, 2)) / 2;
translateY = -Math.sqrt(Math.pow(borderWidth * 2.5, 2)) / 2;
} else {
translateX = -Math.sqrt(Math.pow(borderWidth * 1.5, 2)) / 2;
translateY = -Math.sqrt(Math.pow(borderWidth * 1.5, 2)) / 2;
}
}
return {
origin,
rotateRad,
translateX,
translateY,
};
}
export function getPassword(sequence) {
return sequence.join('');
}
export function getCrossPoint(points, lastPoint, currentPoint, radius) {
if (lastPoint.index == 4 || currentPoint.index == 4) {
return null;
}
let x1 = lastPoint.origin.x;
let y1 = lastPoint.origin.y;
let x2 = currentPoint.origin.x;
let y2 = currentPoint.origin.y;
let crossLineLength = 6 * radius;
if ((y1 == y2 && Math.abs(x1 - x2) == crossLineLength)
|| (x1 == x2 && Math.abs(y1 - y2) == crossLineLength)
|| (Math.abs(x1 - x2) == crossLineLength && Math.abs(y1 - y2) == crossLineLength)) {
let crossPointIndex = (lastPoint.index + currentPoint.index) / 2;
return points[crossPointIndex];
}
return null;
}