itowns
Version:
A JS/WebGL framework for 3D geospatial data visualization
125 lines (91 loc) • 6.72 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var THREE = _interopRequireWildcard(require("three"));
var _View2 = _interopRequireDefault(require("../View"));
var _CameraUtils = _interopRequireDefault(require("../../Utils/CameraUtils"));
var _PlanarControls = _interopRequireDefault(require("../../Controls/PlanarControls"));
var _PlanarLayer = _interopRequireDefault(require("./Planar/PlanarLayer"));
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function () { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
var PlanarView = /*#__PURE__*/function (_View) {
(0, _inherits2["default"])(PlanarView, _View);
var _super = _createSuper(PlanarView);
/**
* @constructor
* @extends View
*
* @example <caption><b>Enable WebGl 1.0 instead of WebGl 2.0.</b></caption>
* var viewerDiv = document.getElementById('viewerDiv');
* const extent = new Extent('EPSG:3946', 1837816.94334, 1847692.32501, 5170036.4587, 5178412.82698);
* var view = new itowns.PlanarView(viewerDiv, extent, { renderer: { isWebGL2: false } });
*
* @example <caption><b>Instance with placement on the ground.</b></caption>
* var viewerDiv = document.getElementById('viewerDiv');
* const extent = new Extent('EPSG:3946', 1837816.94334, 1847692.32501, 5170036.4587, 5178412.82698);
* var view = new itowns.PlanarView(viewerDiv, extent, { placement: { heading: -49.6, range: 6200, tilt: 17 } });
*
* @param {HTMLDivElement} viewerDiv - Where to attach the view and display it
* in the DOM.
* @param {Extent} extent - The ground extent.
* @param {object=} options - See options of {@link View}.
* @param {boolean} [options.noControls=false] - If true, no controls are associated to the view.
* @param {object=} [options.controls] - options for the {@link PlanarControls} associated to the view, if
* `options.noControls` is false.
* @param {CameraUtils~CameraTransformOptions|Extent} [options.placement] - The
* {@link CameraUtils~CameraTransformOptions} to apply to view's camera or the extent it must display at
* initialization. By default, camera will display the view's extent (given in `extent` parameter).
*/
function PlanarView(viewerDiv, extent) {
var _this;
var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
(0, _classCallCheck2["default"])(this, PlanarView);
THREE.Object3D.DefaultUp.set(0, 0, 1); // Setup View
_this = _super.call(this, extent.crs, viewerDiv, options);
_this.isPlanarView = true; // Configure camera
var dim = extent.dimensions();
var max = Math.max(dim.x, dim.y);
var camera3D = _this.camera.camera3D;
camera3D.near = 0.1;
camera3D.far = camera3D.isOrthographicCamera ? 2000 : 2 * max;
camera3D.updateProjectionMatrix();
var tileLayer = new _PlanarLayer["default"]('planar', extent, options.object3d, options);
_this.mainLoop.gfxEngine.label2dRenderer.infoTileLayer = tileLayer.info;
_this.addLayer(tileLayer); // Configure camera
var placement = options.placement || {};
if (!placement.isExtent) {
placement.coord = placement.coord || extent.center();
placement.tilt = placement.tilt || 90;
placement.heading = placement.heading || 0;
placement.range = placement.range || max;
}
_CameraUtils["default"].transformCameraToLookAtTarget((0, _assertThisInitialized2["default"])(_this), camera3D, placement);
if (!options.noControls) {
_this.controls = new _PlanarControls["default"]((0, _assertThisInitialized2["default"])(_this), options.controls);
}
_this.tileLayer = tileLayer;
return _this;
}
(0, _createClass2["default"])(PlanarView, [{
key: "addLayer",
value: function addLayer(layer) {
return (0, _get2["default"])((0, _getPrototypeOf2["default"])(PlanarView.prototype), "addLayer", this).call(this, layer, this.tileLayer);
}
}]);
return PlanarView;
}(_View2["default"]);
var _default = PlanarView;
exports["default"] = _default;