@vtx/cs-map
Version:
React components for Vortex
111 lines (108 loc) • 4.57 kB
JavaScript
;
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