qa-prevention-xgf-app/common/gcoord.js

216 lines
12 KiB
JavaScript
Raw Permalink Normal View History

/* @preserve
* gcoord 0.2.2, geographic coordinate library
* Copyright (c) 2019 Jiulong Hu <me@hujiulong.com>
*/
!function (e, t) {
"object" == typeof exports && "undefined" != typeof module ? t(exports) : "function" == typeof define && define.amd ? define(["exports"], t) : t(e.gcoord = {})
}(this, function (e) {
"use strict";
var t = "WGS84", r = t, n = t, o = "GCJ02", a = o, i = "BD09", u = i, f = i, c = i, s = "BD09MC", l = s,
M = "EPSG3857", g = M, h = M, v = M, d = M;
function m(e) {
throw new Error(e)
}
function G(e) {
return !isNaN(e) && null !== e && !S(e)
}
function S(e) {
return !!e && "[object Array]" === Object.prototype.toString.call(e)
}
function P() {
for (var o = [], e = 0; e < arguments.length; e++) o[e] = arguments[e];
var a = o.length - 1;
return function () {
for (var e = [], t = 0; t < arguments.length; t++) e[t] = arguments[t];
for (var r = a, n = o[a].apply(null, e); r--;) n = o[r].call(null, n);
return n
}
}
var b = Math.sin, y = Math.cos, p = Math.sqrt, B = Math.abs, D = Math.PI, C = 6378245, E = .006693421622965823;
function W(e) {
var t = e[0], r = e[1];
if (!J(t, r)) return [t, r];
for (var n = [t, r], o = n[0], a = n[1], i = x([o, a]), u = i[0] - t, f = i[1] - r; 1e-6 < B(u) || 1e-6 < B(f);) u = (i = x([o -= u, a -= f]))[0] - t, f = i[1] - r;
return [o, a]
}
function x(e) {
var t = e[0], r = e[1];
if (!J(t, r)) return [t, r];
var n = function (e, t) {
var r = function (e, t) {
var r = 300 + e + 2 * t + .1 * e * e + .1 * e * t + .1 * p(B(e));
return r += 2 * (20 * b(6 * e * D) + 20 * b(2 * e * D)) / 3, r += 2 * (20 * b(e * D) + 40 * b(e / 3 * D)) / 3, r += 2 * (150 * b(e / 12 * D) + 300 * b(e / 30 * D)) / 3
}(e - 105, t - 35), n = function (e, t) {
var r = 2 * e - 100 + 3 * t + .2 * t * t + .1 * e * t + .2 * p(B(e));
return r += 2 * (20 * b(6 * e * D) + 20 * b(2 * e * D)) / 3, r += 2 * (20 * b(t * D) + 40 * b(t / 3 * D)) / 3, r += 2 * (160 * b(t / 12 * D) + 320 * b(t * D / 30)) / 3
}(e - 105, t - 35), o = t / 180 * D, a = b(o), i = p(a = 1 - E * a * a);
return [r = 180 * r / (C / i * y(o) * D), n = 180 * n / (C * (1 - E) / (a * i) * D)]
}(t, r);
return [t + n[0], r + n[1]]
}
function J(e, t) {
return 72.004 <= e && e <= 137.8347 && .8293 <= t && t <= 55.8271
}
var k = Math.sin, L = Math.cos, j = Math.atan2, I = Math.sqrt, q = 3e3 * Math.PI / 180;
function w(e) {
var t = e[0] - .0065, r = e[1] - .006, n = I(t * t + r * r) - 2e-5 * k(r * q), o = j(r, t) - 3e-6 * L(t * q);
return [n * L(o), n * k(o)]
}
function N(e) {
var t = e[0], r = e[1], n = I(t * t + r * r) + 2e-5 * k(r * q), o = j(r, t) + 3e-6 * L(t * q);
return [n * L(o) + .0065, n * k(o) + .006]
}
var O = 180 / Math.PI, A = Math.PI / 180, F = 6378137, _ = 20037508.342789244;
function z(e) {
return [e[0] * O / F, (.5 * Math.PI - 2 * Math.atan(Math.exp(-e[1] / F))) * O]
}
function T(e) {
var t = Math.abs(e[0]) <= 180 ? e[0] : e[0] - 360 * (e[0] < 0 ? -1 : 1),
r = [F * t * A, F * Math.log(Math.tan(.25 * Math.PI + .5 * e[1] * A))];
return r[0] > _ && (r[0] = _), r[0] < -_ && (r[0] = -_), r[1] > _ && (r[1] = _), r[1] < -_ && (r[1] = -_), r
}
var U = Math.abs, H = Math.pow, K = [12890594.86, 8362377.87, 5591021, 3481989.83, 1678043.12, 0],
Q = [75, 60, 45, 30, 15, 0],
R = [[1.410526172116255e-8, 898305509648872e-20, -1.9939833816331, 200.9824383106796, -187.2403703815547, 91.6087516669843, -23.38765649603339, 2.57121317296198, -.03801003308653, 17337981.2], [-7.435856389565537e-9, 8983055097726239e-21, -.78625201886289, 96.32687599759846, -1.85204757529826, -59.36935905485877, 47.40033549296737, -16.50741931063887, 2.28786674699375, 10260144.86], [-3.030883460898826e-8, 898305509983578e-20, .30071316287616, 59.74293618442277, 7.357984074871, -25.38371002664745, 13.45380521110908, -3.29883767235584, .32710905363475, 6856817.37], [-1.981981304930552e-8, 8983055099779535e-21, .03278182852591, 40.31678527705744, .65659298677277, -4.44255534477492, .85341911805263, .12923347998204, -.04625736007561, 4482777.06], [3.09191371068437e-9, 8983055096812155e-21, 6995724062e-14, 23.10934304144901, -.00023663490511, -.6321817810242, -.00663494467273, .03430082397953, -.00466043876332, 2555164.4], [2.890871144776878e-9, 8983055095805407e-21, -3.068298e-8, 7.47137025468032, -353937994e-14, -.02145144861037, -1234426596e-14, .00010322952773, -323890364e-14, 826088.5]],
V = [[-.0015702102444, 111320.7020616939, 0x60e374c3105a3, -0x24bb4115e2e164, 0x5cc55543bb0ae8, -0x7ce070193f3784, 0x5e7ca61ddf8150, -0x261a578d8b24d0, 0x665d60f3742ca, 82.5], [.0008277824516172526, 111320.7020463578, 647795574.6671607, -4082003173.641316, 10774905663.51142, -15171875531.51559, 12053065338.62167, -5124939663.577472, 913311935.9512032, 67.5], [.00337398766765, 111320.7020202162, 4481351.045890365, -23393751.19931662, 79682215.47186455, -115964993.2797253, 97236711.15602145, -43661946.33752821, 8477230.501135234, 52.5], [.00220636496208, 111320.7020209128, 51751.86112841131, 3796837.749470245, 992013.7397791013, -1221952.21711287, 1340652.697009075, -620943.6990984312, 144416.9293806241, 37.5], [-.0003441963504368392, 111320.7020576856, 278.2353980772752, 2485758.690035394, 6070.750963243378, 54821.18345352118, 9540.606633304236, -2710.55326746645, 1405.483844121726, 22.5], [-.0003218135878613132, 111320.7020701615, .00369383431289, 823725.6402795718, .46104986909093, 2351.343141331292, 1.58060784298199, 8.77738589078284, .37238884252424, 7.45]];
function X(e, t, r) {
var n = U(t) / r[9], o = r[0] + r[1] * U(e),
a = r[2] + r[3] * n + r[4] * H(n, 2) + r[5] * H(n, 3) + r[6] * H(n, 4) + r[7] * H(n, 5) + r[8] * H(n, 6);
return [o *= e < 0 ? -1 : 1, a *= t < 0 ? -1 : 1]
}
function Y(e) {
for (var t = e[0], r = e[1], n = [], o = 0; o < Q.length; o++) if (U(r) > Q[o]) {
n = V[o];
break
}
return X(t, r, n)
}
function Z(e) {
for (var t = e[0], r = e[1], n = [], o = 0; o < K.length; o++) if (K[o] <= r) {
n = R[o];
break
}
return X(t, r, n)
}
var $ = {to: {GCJ02: x, BD09: P(N, x), BD09MC: P(Y, N, x), EPSG3857: T}},
ee = {to: {WGS84: W, BD09: N, BD09MC: P(Y, N), EPSG3857: P(T, W)}},
te = {to: {WGS84: P(W, w), GCJ02: w, EPSG3857: P(T, W, w), BD09MC: Y}},
re = {to: {WGS84: z, GCJ02: P(x, z), BD09: P(N, x, z), BD09MC: P(Y, N, x, z)}},
ne = {to: {WGS84: P(W, w, Z), GCJ02: P(w, Z), EPSG3857: P(T, W, w, Z), BD09: Z}},
oe = Object.freeze({WGS84: $, GCJ02: ee, BD09: te, EPSG3857: re, BD09MC: ne});
function ae(e, t, r) {
e || m("coordinate is required"), t || m("original coordinate system is required"), r || m("target coordinate system is required");
var n = oe[t];
if (n || m("original coordinate system is invalid"), t === r) return e;
var o = n.to[r];
o || m("target coordinate system is invalid");
var a = typeof e;
if ("string" != a && "object" != a && m("coordinate must be an geojson or an array of position"), "string" == a) try {
e = JSON.parse(e)
} catch (e) {
m("input is not a legal JSON string")
}
var i = !1;
S(e) && (e.length < 2 && m("position must be at 2 numbers long"), G(e[0]) && G(e[1]) || m("position must contain numbers"), e = e.map(Number), i = !0);
var u = o;
return i ? u(e) : (function e(t, r, n) {
if (void 0 === n && (n = !1), null !== t) for (var o, a, i, u, f, c, s, l, M = 0, g = 0, h = t.type, v = "FeatureCollection" === h, d = "Feature" === h, G = v ? t.features.length : 1, S = 0; S < G; S++) {
f = (l = !!(s = v ? t.features[S].geometry : d ? t.geometry : t) && "GeometryCollection" === s.type) ? s.geometries.length : 1;
for (var P = 0; P < f; P++) {
var b = 0, y = 0;
if (null !== (u = l ? s.geometries[P] : s)) {
var p = u.type;
switch (M = !n || "Polygon" !== p && "MultiPolygon" !== p ? 0 : 1, p) {
case null:
break;
case"Point":
if (!1 === r(c = u.coordinates, g, S, b, y)) return !1;
g++, b++;
break;
case"LineString":
case"MultiPoint":
for (c = u.coordinates, o = 0; o < c.length; o++) {
if (!1 === r(c[o], g, S, b, y)) return !1;
g++, "MultiPoint" === p && b++
}
"LineString" === p && b++;
break;
case"Polygon":
case"MultiLineString":
for (c = u.coordinates, o = 0; o < c.length; o++) {
for (a = 0; a < c[o].length - M; a++) {
if (!1 === r(c[o][a], g, S, b, y)) return !1;
g++
}
"MultiLineString" === p && b++, "Polygon" === p && y++
}
"Polygon" === p && b++;
break;
case"MultiPolygon":
for (c = u.coordinates, o = 0; o < c.length; o++) {
for (a = y = 0; a < c[o].length; a++) {
for (i = 0; i < c[o][a].length - M; i++) {
if (!1 === r(c[o][a][i], g, S, b, y)) return !1;
g++
}
y++
}
b++
}
break;
case"GeometryCollection":
for (o = 0; o < u.geometries.length; o++) if (!1 === e(u.geometries[o], r, n)) return !1;
break;
default:
m("Unknown Geometry Type")
}
}
}
}
}(e, function (e) {
var t;
t = u(e), e[0] = t[0], e[1] = t[1]
}), e)
}
var ie = {
WGS84: t,
WGS1984: r,
EPSG4326: n,
GCJ02: o,
AMap: a,
BD09: i,
BD09LL: u,
Baidu: f,
BMap: c,
BD09MC: s,
BD09Meter: l,
EPSG3857: M,
EPSG900913: g,
EPSG102100: h,
WebMercator: v,
WM: d,
transform: ae
};
e.WGS84 = t, e.WGS1984 = r, e.EPSG4326 = n, e.GCJ02 = o, e.AMap = a, e.BD09 = i, e.BD09LL = u, e.Baidu = f, e.BMap = c, e.BD09MC = s, e.BD09Meter = l, e.EPSG3857 = M, e.EPSG900913 = g, e.EPSG102100 = h, e.WebMercator = v, e.WM = d, e.transform = ae, e.default = ie, Object.defineProperty(e, "__esModule", {value: !0})
});