123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641 |
- define([
- '../../Core/buildModuleUrl',
- '../../Core/Cartesian3',
- '../../Core/Clock',
- '../../Core/Credit',
- '../../Core/defaultValue',
- '../../Core/defined',
- '../../Core/defineProperties',
- '../../Core/destroyObject',
- '../../Core/DeveloperError',
- '../../Core/Ellipsoid',
- '../../Core/formatError',
- '../../Core/requestAnimationFrame',
- '../../Core/ScreenSpaceEventHandler',
- '../../Scene/BingMapsImageryProvider',
- '../../Scene/Globe',
- '../../Scene/Moon',
- '../../Scene/Scene',
- '../../Scene/SceneMode',
- '../../Scene/SkyAtmosphere',
- '../../Scene/SkyBox',
- '../../Scene/Sun',
- '../getElement'
- ], function(
- buildModuleUrl,
- Cartesian3,
- Clock,
- Credit,
- defaultValue,
- defined,
- defineProperties,
- destroyObject,
- DeveloperError,
- Ellipsoid,
- formatError,
- requestAnimationFrame,
- ScreenSpaceEventHandler,
- BingMapsImageryProvider,
- Globe,
- Moon,
- Scene,
- SceneMode,
- SkyAtmosphere,
- SkyBox,
- Sun,
- getElement) {
- "use strict";
- function getDefaultSkyBoxUrl(suffix) {
- return buildModuleUrl('Assets/Textures/SkyBox/tycho2t3_80_' + suffix + '.jpg');
- }
- function startRenderLoop(widget) {
- widget._renderLoopRunning = true;
- var lastFrameTime = 0;
- function render(frameTime) {
- if (widget.isDestroyed()) {
- return;
- }
- if (widget._useDefaultRenderLoop) {
- try {
- var targetFrameRate = widget._targetFrameRate;
- if (!defined(targetFrameRate)) {
- widget.resize();
- widget.render();
- requestAnimationFrame(render);
- } else {
- var interval = 1000.0 / targetFrameRate;
- var delta = frameTime - lastFrameTime;
- if (delta > interval) {
- widget.resize();
- widget.render();
- lastFrameTime = frameTime - (delta % interval);
- }
- requestAnimationFrame(render);
- }
- } catch (error) {
- widget._useDefaultRenderLoop = false;
- widget._renderLoopRunning = false;
- if (widget._showRenderLoopErrors) {
- var title = 'An error occurred while rendering. Rendering has stopped.';
- widget.showErrorPanel(title, undefined, error);
- }
- }
- } else {
- widget._renderLoopRunning = false;
- }
- }
- requestAnimationFrame(render);
- }
- function configureCanvasSize(widget) {
- var canvas = widget._canvas;
- var width = canvas.clientWidth;
- var height = canvas.clientHeight;
- var zoomFactor = defaultValue(window.devicePixelRatio, 1.0) * widget._resolutionScale;
- widget._canvasWidth = width;
- widget._canvasHeight = height;
- width *= zoomFactor;
- height *= zoomFactor;
- canvas.width = width;
- canvas.height = height;
- widget._canRender = width !== 0 && height !== 0;
- }
- function configureCameraFrustum(widget) {
- var canvas = widget._canvas;
- var width = canvas.width;
- var height = canvas.height;
- if (width !== 0 && height !== 0) {
- var frustum = widget._scene.camera.frustum;
- if (defined(frustum.aspectRatio)) {
- frustum.aspectRatio = width / height;
- } else {
- frustum.top = frustum.right * (height / width);
- frustum.bottom = -frustum.top;
- }
- }
- }
- var cesiumLogoData = '';
-
- var CesiumWidget = function(container, options) {
-
- if (!defined(container)) {
- throw new DeveloperError('container is required.');
- }
-
- container = getElement(container);
- options = defaultValue(options, {});
-
- var element = document.createElement('div');
- element.className = 'cesium-widget';
- container.appendChild(element);
- var canvas = document.createElement('canvas');
- canvas.oncontextmenu = function() {
- return false;
- };
- canvas.onselectstart = function() {
- return false;
- };
- element.appendChild(canvas);
- var creditContainer = document.createElement('div');
- creditContainer.className = 'cesium-widget-credits';
- var creditContainerContainer = defined(options.creditContainer) ? getElement(options.creditContainer) : element;
- creditContainerContainer.appendChild(creditContainer);
- this._element = element;
- this._container = container;
- this._canvas = canvas;
- this._canvasWidth = 0;
- this._canvasHeight = 0;
- this._creditContainer = creditContainer;
- this._canRender = false;
- this._renderLoopRunning = false;
- this._showRenderLoopErrors = defaultValue(options.showRenderLoopErrors, true);
- this._resolutionScale = 1.0;
- this._forceResize = false;
- this._clock = defined(options.clock) ? options.clock : new Clock();
- configureCanvasSize(this);
- try {
- var scene = new Scene({
- canvas : canvas,
- contextOptions : options.contextOptions,
- creditContainer : creditContainer,
- mapProjection : options.mapProjection,
- orderIndependentTranslucency : options.orderIndependentTranslucency,
- scene3DOnly : defaultValue(options.scene3DOnly, false)
- });
- this._scene = scene;
- scene.camera.constrainedAxis = Cartesian3.UNIT_Z;
- configureCameraFrustum(this);
- var ellipsoid = Ellipsoid.WGS84;
- var creditDisplay = scene.frameState.creditDisplay;
- var cesiumCredit = new Credit('Cesium', cesiumLogoData, 'http://cesiumjs.org/');
- creditDisplay.addDefaultCredit(cesiumCredit);
- var globe = new Globe(ellipsoid);
- this._globe = globe;
- scene.globe = globe;
- var skyBox = options.skyBox;
- if (!defined(skyBox)) {
- skyBox = new SkyBox({
- sources : {
- positiveX : getDefaultSkyBoxUrl('px'),
- negativeX : getDefaultSkyBoxUrl('mx'),
- positiveY : getDefaultSkyBoxUrl('py'),
- negativeY : getDefaultSkyBoxUrl('my'),
- positiveZ : getDefaultSkyBoxUrl('pz'),
- negativeZ : getDefaultSkyBoxUrl('mz')
- }
- });
- }
- scene.skyBox = skyBox;
- scene.skyAtmosphere = new SkyAtmosphere(ellipsoid);
- scene.sun = new Sun();
- scene.moon = new Moon();
-
- var imageryProvider = options.imageryProvider;
- if (!defined(imageryProvider)) {
- imageryProvider = new BingMapsImageryProvider({
- url : '//dev.virtualearth.net'
- });
- }
- if (imageryProvider !== false) {
- scene.imageryLayers.addImageryProvider(imageryProvider);
- }
-
- if (defined(options.terrainProvider)) {
- scene.terrainProvider = options.terrainProvider;
- }
- this._screenSpaceEventHandler = new ScreenSpaceEventHandler(canvas);
- if (defined(options.sceneMode)) {
- if (options.sceneMode === SceneMode.SCENE2D) {
- this._scene.morphTo2D(0);
- }
- if (options.sceneMode === SceneMode.COLUMBUS_VIEW) {
- this._scene.morphToColumbusView(0);
- }
- }
- this._useDefaultRenderLoop = undefined;
- this.useDefaultRenderLoop = defaultValue(options.useDefaultRenderLoop, true);
- this._targetFrameRate = undefined;
- this.targetFrameRate = options.targetFrameRate;
- var that = this;
- scene.renderError.addEventListener(function(scene, error) {
- that._useDefaultRenderLoop = false;
- that._renderLoopRunning = false;
- if (that._showRenderLoopErrors) {
- var title = 'An error occurred while rendering. Rendering has stopped.';
- that.showErrorPanel(title, undefined, error);
- }
- });
- } catch (error) {
- var title = 'Error constructing CesiumWidget.';
- var message = 'Visit <a href="http://get.webgl.org">http://get.webgl.org</a> to verify that your web browser and hardware support WebGL. Consider trying a different web browser or updating your video drivers. Detailed error information is below:';
- this.showErrorPanel(title, message, error);
- throw error;
- }
- };
- defineProperties(CesiumWidget.prototype, {
-
- container : {
- get : function() {
- return this._container;
- }
- },
-
- canvas : {
- get : function() {
- return this._canvas;
- }
- },
-
- creditContainer: {
- get : function() {
- return this._creditContainer;
- }
- },
-
- scene : {
- get : function() {
- return this._scene;
- }
- },
-
- imageryLayers : {
- get : function() {
- return this._scene.imageryLayers;
- }
- },
-
- terrainProvider : {
- get : function() {
- return this._scene.terrainProvider;
- },
- set : function(terrainProvider) {
- this._scene.terrainProvider = terrainProvider;
- }
- },
-
- camera : {
- get : function() {
- return this._scene.camera;
- }
- },
-
- clock : {
- get : function() {
- return this._clock;
- }
- },
-
- screenSpaceEventHandler : {
- get : function() {
- return this._screenSpaceEventHandler;
- }
- },
-
- targetFrameRate : {
- get : function() {
- return this._targetFrameRate;
- },
- set : function(value) {
- if (value <= 0) {
- throw new DeveloperError('targetFrameRate must be greater than 0.');
- }
- this._targetFrameRate = value;
- }
- },
-
- useDefaultRenderLoop : {
- get : function() {
- return this._useDefaultRenderLoop;
- },
- set : function(value) {
- if (this._useDefaultRenderLoop !== value) {
- this._useDefaultRenderLoop = value;
- if (value && !this._renderLoopRunning) {
- startRenderLoop(this);
- }
- }
- }
- },
-
- resolutionScale : {
- get : function() {
- return this._resolutionScale;
- },
- set : function(value) {
- if (value <= 0) {
- throw new DeveloperError('resolutionScale must be greater than 0.');
- }
- this._resolutionScale = value;
- this._forceResize = true;
- }
- }
- });
-
- CesiumWidget.prototype.showErrorPanel = function(title, message, error) {
- var element = this._element;
- var overlay = document.createElement('div');
- overlay.className = 'cesium-widget-errorPanel';
- var content = document.createElement('div');
- content.className = 'cesium-widget-errorPanel-content';
- overlay.appendChild(content);
- var errorHeader = document.createElement('div');
- errorHeader.className = 'cesium-widget-errorPanel-header';
- errorHeader.appendChild(document.createTextNode(title));
- content.appendChild(errorHeader);
- var errorPanelScroller = document.createElement('div');
- errorPanelScroller.className = 'cesium-widget-errorPanel-scroll';
- content.appendChild(errorPanelScroller);
- var resizeCallback = function() {
- errorPanelScroller.style.maxHeight = Math.max(Math.round(element.clientHeight * 0.9 - 100), 30) + 'px';
- };
- resizeCallback();
- if (defined(window.addEventListener)) {
- window.addEventListener('resize', resizeCallback, false);
- }
- if (defined(message)) {
- var errorMessage = document.createElement('div');
- errorMessage.className = 'cesium-widget-errorPanel-message';
- errorMessage.innerHTML = '<p>' + message + '</p>';
- errorPanelScroller.appendChild(errorMessage);
- }
- var errorDetails = '(no error details available)';
- if (defined(error)) {
- errorDetails = formatError(error);
- }
- var errorMessageDetails = document.createElement('div');
- errorMessageDetails.className = 'cesium-widget-errorPanel-message';
- errorMessageDetails.appendChild(document.createTextNode(errorDetails));
- errorPanelScroller.appendChild(errorMessageDetails);
- var buttonPanel = document.createElement('div');
- buttonPanel.className = 'cesium-widget-errorPanel-buttonPanel';
- content.appendChild(buttonPanel);
- var okButton = document.createElement('button');
- okButton.setAttribute('type', 'button');
- okButton.className = 'cesium-button';
- okButton.appendChild(document.createTextNode('OK'));
- okButton.onclick = function() {
- if (defined(resizeCallback) && defined(window.removeEventListener)) {
- window.removeEventListener('resize', resizeCallback, false);
- }
- element.removeChild(overlay);
- };
- buttonPanel.appendChild(okButton);
- element.appendChild(overlay);
- console.error(title + '\n' + message + '\n' + errorDetails);
- };
-
- CesiumWidget.prototype.isDestroyed = function() {
- return false;
- };
-
- CesiumWidget.prototype.destroy = function() {
- this._scene = this._scene && this._scene.destroy();
- this._container.removeChild(this._element);
- destroyObject(this);
- };
-
- CesiumWidget.prototype.resize = function() {
- var canvas = this._canvas;
- var width = canvas.clientWidth;
- var height = canvas.clientHeight;
- if (!this._forceResize && this._canvasWidth === width && this._canvasHeight === height) {
- return;
- }
- this._forceResize = false;
- configureCanvasSize(this);
- configureCameraFrustum(this);
- };
-
- CesiumWidget.prototype.render = function() {
- this._scene.initializeFrame();
- var currentTime = this._clock.tick();
- if (this._canRender) {
- this._scene.render(currentTime);
- }
- };
- return CesiumWidget;
- });
|