UNPKG

@vtx/cs-map

Version:

React components for Vortex

111 lines (108 loc) 4.57 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.getBox = exports["default"] = exports.computeMinMax = void 0; function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } /** * 兼容最小最大值 * @param minCoordinate * @param maxCoordinate * @param padding * @returns {[*,*,*,*]} */ var computeMinMax = exports.computeMinMax = function computeMinMax(minCoordinate, maxCoordinate, padding) { if (padding) { if (Array.isArray(padding)) { if (padding.length === 2) { minCoordinate[0] = minCoordinate[0] - padding[0]; maxCoordinate[0] = maxCoordinate[0] + padding[0]; minCoordinate[1] = minCoordinate[1] - padding[1]; maxCoordinate[1] = maxCoordinate[1] + padding[1]; } else if (padding.length === 4) { maxCoordinate[0] = maxCoordinate[0] + padding[0]; maxCoordinate[1] = maxCoordinate[1] + padding[1]; minCoordinate[1] = minCoordinate[1] - padding[2]; minCoordinate[0] = minCoordinate[0] - padding[3]; } } else { maxCoordinate[0] = maxCoordinate[0] + padding; minCoordinate[0] = minCoordinate[0] - padding; maxCoordinate[1] = maxCoordinate[1] + padding; minCoordinate[1] = minCoordinate[1] - padding; } } return [minCoordinate[0], minCoordinate[1], maxCoordinate[0], maxCoordinate[1]]; }; var getPaddingByUnit = function getPaddingByUnit(padding, unit) { if (unit === 'px') { // 将像素值转换为度 var pixelToDegreeConversionFactor = 1 / 111000; // 1 度大约等于 111000 像素 padding = padding * pixelToDegreeConversionFactor; } else if (unit === 'm') { // 将 padding 值从米转换为度 padding = padding / 111000; // 1 度大约等于 111000 米 } return padding; }; var transformPaddingByUnit = function transformPaddingByUnit(padding, unit) { if (padding) { if (Array.isArray(padding)) { padding = padding.map(function (item) { return getPaddingByUnit(item, unit); }); } else { padding = getPaddingByUnit(padding, unit); } } return padding; }; /** * 获取边界 * @param coordinates * @param options * @returns {[*,*,*,*]} */ var getBox = exports.getBox = function getBox(coordinates, options) { // 找到最小的经度和纬度值 var minCoordinate = []; var maxCoordinate = []; coordinates.forEach(function (c, index) { var i = index % 2; if (i === 0) { if (minCoordinate[0] === undefined || c < minCoordinate[0]) { minCoordinate[0] = c; } if (maxCoordinate[0] === undefined || c > maxCoordinate[0]) { maxCoordinate[0] = c; } } else if (i === 1) { if (minCoordinate[1] === undefined || c < minCoordinate[1]) { minCoordinate[1] = c; } if (maxCoordinate[1] === undefined || c > maxCoordinate[1]) { maxCoordinate[1] = c; } } }); if (options) { var padding = options.padding, unit = options.unit; return computeMinMax(minCoordinate, maxCoordinate, transformPaddingByUnit(padding, unit)); } return [minCoordinate[0], minCoordinate[1], maxCoordinate[0], maxCoordinate[1]]; }; var _default = exports["default"] = function _default(geoJson, options) { var coordinates = []; geoJson.features.map(function (feature) { var c = feature.geometry.coordinates.flat(Infinity); coordinates.push.apply(coordinates, _toConsumableArray(c)); }); return getBox(coordinates, options); }; //# sourceMappingURL=getBBoxFromGeojson.js.map