@vtx/cs-map
Version:
React components for Vortex
137 lines (135 loc) • 5.41 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _ImageLayer = _interopRequireDefault(require("../image-layer/ImageLayer"));
var _FeatureLayer = _interopRequireDefault(require("../feature-layer/FeatureLayer"));
var _cesium = require("cesium");
var _lodash = require("lodash");
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
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 _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, 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 GroupLayer = /*#__PURE__*/function () {
function GroupLayer(opt_options) {
var _this = this;
_classCallCheck(this, GroupLayer);
// 获取图层最后一个 index 值
_defineProperty(this, "getLastIndex", function (_index) {
var index = 0;
var layers = _this.layers;
if (layers !== null && layers !== void 0 && layers.length) {
if (_index && layers.findIndex(function (v) {
return _index < v.zIndex;
}) !== -1) {
index = layers.findIndex(function (v) {
return _index < v.zIndex;
});
} else {
index = layers.length - 1;
}
}
return index;
});
var _ref = opt_options || {},
_index2 = _ref.index,
map = _ref.map,
key = _ref.key,
name = _ref.name,
legend = _ref.legend,
_ref$layerControl = _ref.layerControl,
layerControl = _ref$layerControl === void 0 ? true : _ref$layerControl,
_ref$layers = _ref.layers,
_layers = _ref$layers === void 0 ? [] : _ref$layers;
this.map = map;
this.key = key;
this.name = name;
this.legend = legend;
this.layerControl = layerControl;
this.layers = _layers;
this.index = _index2;
}
return _createClass(GroupLayer, [{
key: "addLayer",
value: function addLayer(layer, groupIndex, mapIndex) {
if (this.hasLayer(layer)) {
return;
}
if (layer instanceof _cesium.CustomDataSource || layer instanceof _FeatureLayer["default"]) {
this.map.dataSources.add(layer);
} else if (layer instanceof _ImageLayer["default"]) {
this.map.scene.imageryLayers.add(layer);
} else if (layer instanceof _cesium.Primitive) {
this.map.scene.primitives.add(layer);
}
if (layer.layerControl) {
if ((0, _lodash.isNumber)(groupIndex)) {
this.layers.splice(groupIndex, 0, layer);
} else {
this.layers.push(layer);
}
this.map.layers.onChange();
}
}
}, {
key: "removeLayer",
value: function removeLayer(layer) {
if (!this.hasLayer(layer)) {
return;
}
if (layer instanceof _cesium.CustomDataSource || layer instanceof _FeatureLayer["default"]) {
this.map.dataSources.remove(layer);
} else if (layer instanceof _ImageLayer["default"]) {
this.map.scene.imageryLayers.remove(layer);
} else if (layer instanceof _cesium.Primitive) {
this.map.scene.primitives.remove(layer);
}
if (layer.layerControl) {
this.layers = this.layers.filter(function (v) {
return v !== layer;
});
this.map.layers.onChange();
}
}
}, {
key: "hasLayer",
value: function hasLayer(layer) {
return this.layers.findIndex(function (v) {
return v === layer;
}) !== -1;
}
}, {
key: "getLayers",
value: function getLayers() {
return this.layers;
}
}, {
key: "setLayers",
value: function setLayers(layers) {
this.layers = layers;
}
}, {
key: "indexOf",
value: function indexOf(layer) {
return this.layers.findIndex(function (v) {
return v === layer;
});
}
}, {
key: "setVisible",
value: function setVisible(visible) {
this.show = visible;
this.layers.map(function (v) {
v.show = visible;
});
this.map.layers.onChange();
}
}]);
}();
var _default = exports["default"] = GroupLayer;
//# sourceMappingURL=GroupLayer.js.map