@vtx/cs-map
Version:
React components for Vortex
377 lines (359 loc) • 13.2 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
var EARTH_RADIUS = 6370996.81;
var MC_BAND = [12890594.86, 8362377.87, 5591021, 3481989.83, 1678043.12, 0];
var LL_BAND = [75, 60, 45, 30, 15, 0];
var MC2LL = [[1.410526172116255e-8, 8.98305509648872e-6, -1.9939833816331, 2.009824383106796e2, -1.872403703815547e2, 91.6087516669843, -23.38765649603339, 2.57121317296198, -0.03801003308653, 1.73379812e7], [-7.435856389565537e-9, 8.983055097726239e-6, -0.78625201886289, 96.32687599759846, -1.85204757529826, -59.36935905485877, 47.40033549296737, -16.50741931063887, 2.28786674699375, 1.026014486e7], [-3.030883460898826e-8, 8.98305509983578e-6, 0.30071316287616, 59.74293618442277, 7.357984074871, -25.38371002664745, 13.45380521110908, -3.29883767235584, 0.32710905363475, 6.85681737e6], [-1.981981304930552e-8, 8.983055099779535e-6, 0.03278182852591, 40.31678527705744, 0.65659298677277, -4.44255534477492, 0.85341911805263, 0.12923347998204, -0.04625736007561, 4.48277706e6], [3.09191371068437e-9, 8.983055096812155e-6, 0.00006995724062, 23.10934304144901, -0.00023663490511, -0.6321817810242, -0.00663494467273, 0.03430082397953, -0.00466043876332, 2.5551644e6], [2.890871144776878e-9, 8.983055095805407e-6, -0.00000003068298, 7.47137025468032, -0.00000353937994, -0.02145144861037, -0.00001234426596, 0.00010322952773, -0.00000323890364, 8.260885e5]];
var LL2MC = [[-0.0015702102444, 1.113207020616939e5, 1.704480524535203e15, -1.033898737604234e16, 2.611266785660388e16, -3.51496691766537e16, 2.659570071840392e16, -1.072501245418824e16, 1.800819912950474e15, 82.5], [8.277824516172526e-4, 1.113207020463578e5, 6.477955746671608e8, -4.082003173641316e9, 1.077490566351142e10, -1.517187553151559e10, 1.205306533862167e10, -5.124939663577472e9, 9.133119359512032e8, 67.5], [0.00337398766765, 1.113207020202162e5, 4.481351045890365e6, -2.339375119931662e7, 7.968221547186455e7, -1.159649932797253e8, 9.723671115602145e7, -4.366194633752821e7, 8.477230501135234e6, 52.5], [0.00220636496208, 1.113207020209128e5, 5.175186112841131e4, 3.796837749470245e6, 9.920137397791013e5, -1.22195221711287e6, 1.340652697009075e6, -6.209436990984312e5, 1.444169293806241e5, 37.5], [-3.441963504368392e-4, 1.113207020576856e5, 2.782353980772752e2, 2.485758690035394e6, 6.070750963243378e3, 5.482118345352118e4, 9.540606633304236e3, -2.71055326746645e3, 1.405483844121726e3, 22.5], [-3.218135878613132e-4, 1.113207020701615e5, 0.00369383431289, 8.237256402795718e5, 0.46104986909093, 2.351343141331292e3, 1.58060784298199, 8.77738589078284, 0.37238884252424, 7.45]];
var BaiduMercatorProjection = /*#__PURE__*/function () {
function BaiduMercatorProjection() {
_classCallCheck(this, BaiduMercatorProjection);
this.isWgs84 = false;
}
return _createClass(BaiduMercatorProjection, [{
key: "getDistanceByMC",
value: function getDistanceByMC(point1, point2) {
if (!point1 || !point2) {
return 0;
}
point1 = this.convertMC2LL(point1);
if (!point1) {
return 0;
}
var x1 = this.toRadians(point1['lng']);
var y1 = this.toRadians(point1['lat']);
point2 = this.convertMC2LL(point2);
if (!point2) {
return 0;
}
var x2 = this.toRadians(point2['lng']);
var y2 = this.toRadians(point2['lat']);
return this.getDistance(x1, x2, y1, y2);
}
/**
* 根据经纬度坐标计算两点间距离;
* @param point1
* @param point2
* @returns {number|*} 返回两点间的距离
*/
}, {
key: "getDistanceByLL",
value: function getDistanceByLL(point1, point2) {
if (!point1 || !point2) {
return 0;
}
point1['lng'] = this.getLoop(point1['lng'], -180, 180);
point1['lat'] = this.getRange(point1['lat'], -74, 74);
point2['lng'] = this.getLoop(point2['lng'], -180, 180);
point2['lat'] = this.getRange(point2['lat'], -74, 74);
var x1 = this.toRadians(point1['lng']);
var y1 = this.toRadians(point1['lat']);
var x2 = this.toRadians(point2['lng']);
var y2 = this.toRadians(point2['lat']);
return this.getDistance(x1, x2, y1, y2);
}
/**
* 平面直角坐标转换成经纬度坐标;
* @param point
* @returns {Point|{lng: number, lat: number}}
*/
}, {
key: "convertMC2LL",
value: function convertMC2LL(point) {
if (!point) {
return {
lng: 0,
lat: 0
};
}
var lnglat = {};
if (this.isWgs84) {
lnglat.lng = point.lng / 20037508.34 * 180;
var mmy = point.lat / 20037508.34 * 180;
lnglat.lat = 180 / Math.PI * (2 * Math.atan(Math.exp(mmy * Math.PI / 180)) - Math.PI / 2);
return {
lng: lnglat['lng'].toFixed(6),
lat: lnglat['lat'].toFixed(6)
};
}
var temp = {
lng: Math.abs(point['lng']),
lat: Math.abs(point['lat'])
};
var factor = undefined;
for (var i = 0; i < MC_BAND.length; i++) {
if (temp['lat'] >= MC_BAND[i]) {
factor = MC2LL[i];
break;
}
}
lnglat = this.convertor(point, factor);
return {
lng: lnglat['lng'].toFixed(6),
lat: lnglat['lat'].toFixed(6)
};
}
/**
* 经纬度坐标转换成平面直角坐标;
* @param point 经纬度坐标
* @returns {{lng: number, lat: number}|*}
*/
}, {
key: "convertLL2MC",
value: function convertLL2MC(point) {
if (!point) {
return {
lng: 0,
lat: 0
};
}
if (point['lng'] > 180 || point['lng'] < -180 || point['lat'] > 90 || point['lat'] < -90) {
return point;
}
if (this.isWgs84) {
var mercator = {};
var earthRad = 6378137.0;
mercator.lng = point.lng * Math.PI / 180 * earthRad;
var a = point.lat * Math.PI / 180;
mercator.lat = earthRad / 2 * Math.log((1.0 + Math.sin(a)) / (1.0 - Math.sin(a)));
return {
lng: parseFloat(mercator['lng'].toFixed(2)),
lat: parseFloat(mercator['lat'].toFixed(2))
};
}
point['lng'] = this.getLoop(point['lng'], -180, 180);
point['lat'] = this.getRange(point['lat'], -74, 74);
var temp = {
lng: point['lng'],
lat: point['lat']
};
var factor = undefined;
for (var i = 0; i < LL_BAND.length; i++) {
if (temp['lat'] >= LL_BAND[i]) {
factor = LL2MC[i];
break;
}
}
if (!factor) {
for (var _i = 0; _i < LL_BAND.length; _i++) {
if (temp['lat'] <= -LL_BAND[_i]) {
factor = LL2MC[_i];
break;
}
}
}
var mc = this.convertor(point, factor);
return {
lng: parseFloat(mc['lng'].toFixed(2)),
lat: parseFloat(mc['lat'].toFixed(2))
};
}
/**
*
* @param fromPoint
* @param factor
* @returns {{lng: *, lat: *}}
*/
}, {
key: "convertor",
value: function convertor(fromPoint, factor) {
if (!fromPoint || !factor) {
return {
lng: 0,
lat: 0
};
}
var x = factor[0] + factor[1] * Math.abs(fromPoint['lng']);
var temp = Math.abs(fromPoint['lat']) / factor[9];
var y = factor[2] + factor[3] * temp + factor[4] * temp * temp + factor[5] * temp * temp * temp + factor[6] * temp * temp * temp * temp + factor[7] * temp * temp * temp * temp * temp + factor[8] * temp * temp * temp * temp * temp * temp;
x *= fromPoint['lng'] < 0 ? -1 : 1;
y *= fromPoint['lat'] < 0 ? -1 : 1;
return {
lng: x,
lat: y
};
}
/**
*
* @param x1
* @param x2
* @param y1
* @param y2
* @returns {number}
*/
}, {
key: "getDistance",
value: function getDistance(x1, x2, y1, y2) {
return EARTH_RADIUS * Math.acos(Math.sin(y1) * Math.sin(y2) + Math.cos(y1) * Math.cos(y2) * Math.cos(x2 - x1));
}
/**
*
* @param deg
* @returns {number}
*/
}, {
key: "toRadians",
value: function toRadians(deg) {
return Math.PI * deg / 180;
}
/**
*
* @param rad
* @returns {number}
*/
}, {
key: "toDegrees",
value: function toDegrees(rad) {
return 180 * rad / Math.PI;
}
/**
*
* @param v
* @param a
* @param b
* @returns {number}
*/
}, {
key: "getRange",
value: function getRange(v, a, b) {
if (a != null) {
v = Math.max(v, a);
}
if (b != null) {
v = Math.min(v, b);
}
return v;
}
/**
*
* @param v
* @param a
* @param b
* @returns {*}
*/
}, {
key: "getLoop",
value: function getLoop(v, a, b) {
while (v > b) {
v -= b - a;
}
while (v < a) {
v += b - a;
}
return v;
}
/**
*
* @param point
* @returns {{lng: number, lat: number}|*}
*/
}, {
key: "lngLatToMercator",
value: function lngLatToMercator(point) {
return this.convertLL2MC(point);
}
/**
*
* @param point
* @returns {{x: (number|*), y: (number|*)}}
*/
}, {
key: "lngLatToPoint",
value: function lngLatToPoint(point) {
var mercator = this.convertLL2MC(point);
return {
x: mercator['lng'],
y: mercator['lat']
};
}
/**
* 墨卡托变换至经纬度
* @param point 墨卡托
* @returns Point 经纬度
*/
}, {
key: "mercatorToLngLat",
value: function mercatorToLngLat(point) {
return this.convertMC2LL(point);
}
/**
* 平面到球面坐标
* @param point 平面坐标
* @returns Point 球面坐标
*/
}, {
key: "pointToLngLat",
value: function pointToLngLat(point) {
var mercator = {
lng: point.x,
lat: point.y
};
return this.convertMC2LL(mercator);
}
/**
* 地理坐标转换至像素坐标
* @param point 地理坐标
* @param zoom 级别
* @param mapCenter 地图中心点,注意为了保证没有误差,这里需要传递墨卡托坐标
* @param mapSize 地图容器大小
*/
}, {
key: "pointToPixel",
value: function pointToPixel(point, zoom, mapCenter, mapSize) {
if (!point) {
return;
}
point = this.lngLatToMercator(point);
var zoomUnits = this.getZoomUnits(zoom);
var x = Math.round((point['lng'] - mapCenter['lng']) / zoomUnits + mapSize.width / 2);
var y = Math.round((mapCenter['lat'] - point['lat']) / zoomUnits + mapSize.height / 2);
return {
x: x,
y: y
};
}
/**
* 像素坐标转换至地理坐标
* @param pixel 像素坐标
* @param zoom 级别
* @param mapCenter 地图中心点,注意为了保证没有误差,这里需要传递墨卡托坐标
* @param mapSize 地图容器大小
*/
}, {
key: "pixelToPoint",
value: function pixelToPoint(pixel, zoom, mapCenter, mapSize) {
if (!pixel) {
return;
}
var zoomUnits = this.getZoomUnits(zoom);
var lng = mapCenter['lng'] + zoomUnits * (pixel.x - mapSize.width / 2);
var lat = mapCenter['lat'] - zoomUnits * (pixel.y - mapSize.height / 2);
var point = {
lng: lng,
lat: lat
};
return this.mercatorToLngLat(point);
}
/**
*
* @param zoom
* @returns {number}
*/
}, {
key: "getZoomUnits",
value: function getZoomUnits(zoom) {
return Math.pow(2, 18 - zoom);
}
}]);
}();
var _default = exports["default"] = BaiduMercatorProjection;
//# sourceMappingURL=BaiduMercatorProjection.js.map