UNPKG

itowns

Version:

A JS/WebGL framework for 3D geospatial data visualization

98 lines (77 loc) 3.84 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var THREE = _interopRequireWildcard(require("three")); var _TiledGeometryLayer2 = _interopRequireDefault(require("../../../Layer/TiledGeometryLayer")); var _Extent = require("../../Geographic/Extent"); var _Crs = _interopRequireDefault(require("../../Geographic/Crs")); var _PlanarTileBuilder = _interopRequireDefault(require("./PlanarTileBuilder")); /** * @property {boolean} isPlanarLayer - Used to checkout whether this layer is a * PlanarLayer. Default is true. You should not change this, as it is used * internally for optimisation. */ var PlanarLayer = /*#__PURE__*/ function (_TiledGeometryLayer) { (0, _inherits2["default"])(PlanarLayer, _TiledGeometryLayer); /** * A {@link TiledGeometryLayer} to use with a {@link PlanarView}. It has * specific method for updating and subdivising its grid. * * @constructor * @extends TiledGeometryLayer * * @param {string} id - The id of the layer, that should be unique. It is * not mandatory, but an error will be emitted if this layer is added a * {@link View} that already has a layer going by that id. * @param {Extent} extent - The extent to define the layer within. * @param {THREE.Object3d} [object3d=THREE.Group] - The object3d used to * contain the geometry of the TiledGeometryLayer. It is usually a * `THREE.Group`, but it can be anything inheriting from a `THREE.Object3d`. * @param {Object} [config] - Optional configuration, all elements in it * will be merged as is in the layer. For example, if the configuration * contains three elements `name, protocol, extent`, these elements will be * available using `layer.name` or something else depending on the property * name. * @param {number} [config.maxSubdivisionLevel=5] - Maximum subdivision * level for this tiled layer. * @param {number} [config.maxDeltaElevationLevel=4] - Maximum delta between * two elevations tile. * * @throws {Error} `object3d` must be a valid `THREE.Object3d`. */ function PlanarLayer(id, extent, object3d) { var _this; var config = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {}; (0, _classCallCheck2["default"])(this, PlanarLayer); var tileMatrixSets = []; var tms = _Crs["default"].formatToTms(extent.crs); tileMatrixSets.push(tms); if (tms.includes(':TMS')) { // Add new global extent for this new projection. _Extent.globalExtentTMS.set(extent.crs, extent); } config.tileMatrixSets = tileMatrixSets; _this = (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(PlanarLayer).call(this, id, object3d || new THREE.Group(), [extent], new _PlanarTileBuilder["default"]({ projection: extent.crs }), config)); _this.isPlanarLayer = true; _this.extent = extent; _this.minSubdivisionLevel = _this.minSubdivisionLevel || 0; _this.maxSubdivisionLevel = _this.maxSubdivisionLevel || 5.0; _this.maxDeltaElevation = _this.maxDeltaElevation || 4.0; return _this; } return PlanarLayer; }(_TiledGeometryLayer2["default"]); var _default = PlanarLayer; exports["default"] = _default;