You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
37 lines
911 B
37 lines
911 B
1 year ago
|
import {asin, atan2, cos, degrees, haversin, radians, sin, sqrt} from "./math";
|
||
|
|
||
|
export default function(a, b) {
|
||
|
var x0 = a[0] * radians,
|
||
|
y0 = a[1] * radians,
|
||
|
x1 = b[0] * radians,
|
||
|
y1 = b[1] * radians,
|
||
|
cy0 = cos(y0),
|
||
|
sy0 = sin(y0),
|
||
|
cy1 = cos(y1),
|
||
|
sy1 = sin(y1),
|
||
|
kx0 = cy0 * cos(x0),
|
||
|
ky0 = cy0 * sin(x0),
|
||
|
kx1 = cy1 * cos(x1),
|
||
|
ky1 = cy1 * sin(x1),
|
||
|
d = 2 * asin(sqrt(haversin(y1 - y0) + cy0 * cy1 * haversin(x1 - x0))),
|
||
|
k = sin(d);
|
||
|
|
||
|
var interpolate = d ? function(t) {
|
||
|
var B = sin(t *= d) / k,
|
||
|
A = sin(d - t) / k,
|
||
|
x = A * kx0 + B * kx1,
|
||
|
y = A * ky0 + B * ky1,
|
||
|
z = A * sy0 + B * sy1;
|
||
|
return [
|
||
|
atan2(y, x) * degrees,
|
||
|
atan2(z, sqrt(x * x + y * y)) * degrees
|
||
|
];
|
||
|
} : function() {
|
||
|
return [x0 * degrees, y0 * degrees];
|
||
|
};
|
||
|
|
||
|
interpolate.distance = d;
|
||
|
|
||
|
return interpolate;
|
||
|
}
|