diff --git a/Source/DataSources/CorridorGeometryUpdater.js b/Source/DataSources/CorridorGeometryUpdater.js index f1b071a14ba8..67c55bc99d22 100644 --- a/Source/DataSources/CorridorGeometryUpdater.js +++ b/Source/DataSources/CorridorGeometryUpdater.js @@ -592,7 +592,7 @@ define([ } this._primitive = groundPrimitives.add(new GroundPrimitive({ - geometryInstance : new GeometryInstance({ + geometryInstances : new GeometryInstance({ id : entity, geometry : new CorridorGeometry(options), attributes: { diff --git a/Source/DataSources/DataSourceDisplay.js b/Source/DataSources/DataSourceDisplay.js index c7f48feb1255..f28bb9dde0e4 100644 --- a/Source/DataSources/DataSourceDisplay.js +++ b/Source/DataSources/DataSourceDisplay.js @@ -7,6 +7,7 @@ define([ '../Core/destroyObject', '../Core/DeveloperError', '../Core/EventHelper', + '../Scene/GroundPrimitive', './BillboardVisualizer', './BoundingSphereState', './BoxGeometryUpdater', @@ -33,6 +34,7 @@ define([ destroyObject, DeveloperError, EventHelper, + GroundPrimitive, BillboardVisualizer, BoundingSphereState, BoxGeometryUpdater, @@ -77,6 +79,8 @@ define([ throw new DeveloperError('dataSourceCollection is required.'); } //>>includeEnd('debug'); + + GroundPrimitive.initializeTerrainHeights(); var scene = options.scene; var dataSourceCollection = options.dataSourceCollection; @@ -231,6 +235,10 @@ define([ } //>>includeEnd('debug'); + if (!GroundPrimitive._initialized) { + return false; + } + var result = true; var i; diff --git a/Source/DataSources/EllipseGeometryUpdater.js b/Source/DataSources/EllipseGeometryUpdater.js index 7f204a09a7a8..8f2b0eca90b6 100644 --- a/Source/DataSources/EllipseGeometryUpdater.js +++ b/Source/DataSources/EllipseGeometryUpdater.js @@ -609,7 +609,7 @@ define([ } this._primitive = groundPrimitives.add(new GroundPrimitive({ - geometryInstance : new GeometryInstance({ + geometryInstances : new GeometryInstance({ id : entity, geometry : new EllipseGeometry(options), attributes: { diff --git a/Source/DataSources/PolygonGeometryUpdater.js b/Source/DataSources/PolygonGeometryUpdater.js index 0d88fef25369..f3e284dfa533 100644 --- a/Source/DataSources/PolygonGeometryUpdater.js +++ b/Source/DataSources/PolygonGeometryUpdater.js @@ -630,7 +630,7 @@ define([ } this._primitive = groundPrimitives.add(new GroundPrimitive({ - geometryInstance : new GeometryInstance({ + geometryInstances : new GeometryInstance({ id : entity, geometry : new PolygonGeometry(options), attributes: { diff --git a/Source/DataSources/RectangleGeometryUpdater.js b/Source/DataSources/RectangleGeometryUpdater.js index 9a997f42c8c7..c55d5e7994a6 100644 --- a/Source/DataSources/RectangleGeometryUpdater.js +++ b/Source/DataSources/RectangleGeometryUpdater.js @@ -602,7 +602,7 @@ define([ } this._primitive = groundPrimitives.add(new GroundPrimitive({ - geometryInstance : new GeometryInstance({ + geometryInstances : new GeometryInstance({ id : entity, geometry : new RectangleGeometry(options), attributes: { diff --git a/Specs/DataSources/DataSourceDisplaySpec.js b/Specs/DataSources/DataSourceDisplaySpec.js index 2a8b59a21725..4ed201bdae44 100644 --- a/Specs/DataSources/DataSourceDisplaySpec.js +++ b/Specs/DataSources/DataSourceDisplaySpec.js @@ -7,6 +7,7 @@ defineSuite([ 'DataSources/BoundingSphereState', 'DataSources/DataSourceCollection', 'DataSources/Entity', + 'Scene/GroundPrimitive', 'Specs/createScene', 'Specs/MockDataSource' ], function( @@ -17,6 +18,7 @@ defineSuite([ BoundingSphereState, DataSourceCollection, Entity, + GroundPrimitive, createScene, MockDataSource) { 'use strict'; @@ -27,10 +29,17 @@ defineSuite([ beforeAll(function() { scene = createScene(); dataSourceCollection = new DataSourceCollection(); + + return GroundPrimitive.initializeTerrainHeights(); }); afterAll(function() { scene.destroyForSpecs(); + + // Leave ground primitive uninitialized + GroundPrimitive._initialized = false; + GroundPrimitive._initPromise = undefined; + GroundPrimitive._terrainHeights = undefined; }); afterEach(function() { @@ -339,4 +348,28 @@ defineSuite([ return display.update(); }).toThrowDeveloperError(); }); + + it('verify update returns false till terrain heights are initialized', function() { + GroundPrimitive._initialized = false; + GroundPrimitive._initPromise = undefined; + GroundPrimitive._terrainHeights = undefined; + + var source1 = new MockDataSource(); + var source2 = new MockDataSource(); + + display = new DataSourceDisplay({ + scene : scene, + dataSourceCollection : dataSourceCollection, + visualizersCallback : visualizersCallback + }); + dataSourceCollection.add(source1); + dataSourceCollection.add(source2); + display.update(Iso8601.MINIMUM_VALUE); + expect(display.ready).toBe(false); + + return GroundPrimitive.initializeTerrainHeights().then(function() { + display.update(Iso8601.MINIMUM_VALUE); + expect(display.ready).toBe(true); + }); + }); }, 'WebGL'); diff --git a/Specs/DataSources/GeometryVisualizerSpec.js b/Specs/DataSources/GeometryVisualizerSpec.js index f7b897a052cd..a4732555e599 100644 --- a/Specs/DataSources/GeometryVisualizerSpec.js +++ b/Specs/DataSources/GeometryVisualizerSpec.js @@ -22,6 +22,7 @@ defineSuite([ 'DataSources/StaticGeometryPerMaterialBatch', 'DataSources/StaticGroundGeometryColorBatch', 'DataSources/StaticOutlineGeometryBatch', + 'Scene/GroundPrimitive', 'Specs/createDynamicProperty', 'Specs/createScene', 'Specs/pollToPromise' @@ -48,6 +49,7 @@ defineSuite([ StaticGeometryPerMaterialBatch, StaticGroundGeometryColorBatch, StaticOutlineGeometryBatch, + GroundPrimitive, createDynamicProperty, createScene, pollToPromise) { @@ -58,10 +60,17 @@ defineSuite([ var scene; beforeAll(function() { scene = createScene(); + + return GroundPrimitive.initializeTerrainHeights(); }); afterAll(function() { scene.destroyForSpecs(); + + // Leave ground primitive uninitialized + GroundPrimitive._initialized = false; + GroundPrimitive._initPromise = undefined; + GroundPrimitive._terrainHeights = undefined; }); it('Can create and destroy', function() { diff --git a/Specs/Scene/GroundPrimitiveSpec.js b/Specs/Scene/GroundPrimitiveSpec.js index 0e5e87f4da96..80bac3ec1568 100644 --- a/Specs/Scene/GroundPrimitiveSpec.js +++ b/Specs/Scene/GroundPrimitiveSpec.js @@ -70,20 +70,23 @@ defineSuite([ var primitive; var depthPrimitive; - beforeAll(function(done) { + beforeAll(function() { scene = createScene(); scene.fxaa = false; context = scene.context; ellipsoid = Ellipsoid.WGS84; - GroundPrimitive.initializeTerrainHeights().then(function() { - done(); - }); + return GroundPrimitive.initializeTerrainHeights(); }); afterAll(function() { scene.destroyForSpecs(); + + // Leave ground primitive uninitialized + GroundPrimitive._initialized = false; + GroundPrimitive._initPromise = undefined; + GroundPrimitive._terrainHeights = undefined; }); function MockGlobePrimitive(primitive) {