From 3ed89597f5c9eb94750f0bd46853cc06f34dfcf3 Mon Sep 17 00:00:00 2001 From: Sean Lilley Date: Tue, 18 Dec 2018 16:50:34 -0500 Subject: [PATCH] GlobePrimitive tests --- Specs/Scene/ClassificationPrimitiveSpec.js | 49 +++-- Specs/Scene/GroundPrimitiveSpec.js | 227 +++++++++++++-------- 2 files changed, 172 insertions(+), 104 deletions(-) diff --git a/Specs/Scene/ClassificationPrimitiveSpec.js b/Specs/Scene/ClassificationPrimitiveSpec.js index eafb815b1cb1..c98769d3cb9a 100644 --- a/Specs/Scene/ClassificationPrimitiveSpec.js +++ b/Specs/Scene/ClassificationPrimitiveSpec.js @@ -64,17 +64,8 @@ defineSuite([ var primitive; var globePrimitive; var tilesetPrimitive; - - beforeAll(function() { - scene = createScene(); - scene.postProcessStages.fxaa.enabled = false; - - ellipsoid = Ellipsoid.WGS84; - }); - - afterAll(function() { - scene.destroyForSpecs(); - }); + var reusableGlobePrimitive; + var reusableTilesetPrimitive; function viewCenter() { scene.camera.setView({ destination : rectangle }); @@ -88,7 +79,7 @@ defineSuite([ scene.camera.setView({ destination : tilesetRectangle }); } - function MockPrimitive(rectangle, pass) { + function createPrimitive(rectangle, pass) { var renderState; if (pass === Pass.CESIUM_3D_TILE) { renderState = RenderState.fromCache({ @@ -101,7 +92,7 @@ defineSuite([ } var depthColorAttribute = ColorGeometryInstanceAttribute.fromColor(new Color(0.0, 0.0, 1.0, 1.0)); depthColor = depthColorAttribute.value; - this._primitive = new Primitive({ + return new Primitive({ geometryInstances : new GeometryInstance({ geometry : new RectangleGeometry({ ellipsoid : Ellipsoid.WGS84, @@ -119,7 +110,10 @@ defineSuite([ }), asynchronous : false }); + } + function MockPrimitive(primitive, pass) { + this._primitive = primitive; this._pass = pass; } @@ -139,21 +133,36 @@ defineSuite([ }; MockPrimitive.prototype.destroy = function() { - this._primitive.destroy(); return destroyObject(this); }; - beforeEach(function() { - scene.morphTo3D(0); - scene.render(); // clear any afterRender commands + beforeAll(function() { + scene = createScene(); + scene.postProcessStages.fxaa.enabled = false; + + ellipsoid = Ellipsoid.WGS84; rectangle = Rectangle.fromDegrees(-75.0, 25.0, -70.0, 30.0); globeRectangle = Rectangle.fromDegrees(-75.0, 27.5, -70.0, 30.0); tilesetRectangle = Rectangle.fromDegrees(-75.0, 25.0, -70.0, 27.5); + reusableGlobePrimitive = createPrimitive(globeRectangle, Pass.GLOBE); + reusableTilesetPrimitive = createPrimitive(tilesetRectangle, Pass.CESIUM_3D_TILE); + }); + + afterAll(function() { + reusableGlobePrimitive.destroy(); + reusableTilesetPrimitive.destroy(); + scene.destroyForSpecs(); + }); + + beforeEach(function() { + scene.morphTo3D(0); + scene.render(); // clear any afterRender commands + // wrap rectangle primitive so it gets executed during the globe pass or 3D Tiles pass to lay down depth - globePrimitive = new MockPrimitive(globeRectangle, Pass.GLOBE); - tilesetPrimitive = new MockPrimitive(tilesetRectangle, Pass.CESIUM_3D_TILE); + globePrimitive = new MockPrimitive(reusableGlobePrimitive, Pass.GLOBE); + tilesetPrimitive = new MockPrimitive(reusableTilesetPrimitive, Pass.CESIUM_3D_TILE); var center = Rectangle.center(rectangle); var origin = ellipsoid.cartographicToCartesian(center); @@ -1046,7 +1055,7 @@ defineSuite([ primitive.appearance = new MaterialAppearance(); expect(function() { - expectRender(boxColor); + expect(scene).toRender(boxColor); }).toThrowDeveloperError(); }); diff --git a/Specs/Scene/GroundPrimitiveSpec.js b/Specs/Scene/GroundPrimitiveSpec.js index 9b6b81543666..c3c80209a8d0 100644 --- a/Specs/Scene/GroundPrimitiveSpec.js +++ b/Specs/Scene/GroundPrimitiveSpec.js @@ -15,12 +15,14 @@ defineSuite([ 'Core/RectangleGeometry', 'Core/ShowGeometryInstanceAttribute', 'Renderer/Pass', + 'Renderer/RenderState', 'Scene/ClassificationType', 'Scene/EllipsoidSurfaceAppearance', 'Scene/InvertClassification', 'Scene/Material', 'Scene/PerInstanceColorAppearance', 'Scene/Primitive', + 'Scene/StencilConstants', 'Specs/createCanvas', 'Specs/createScene', 'Specs/pollToPromise' @@ -41,12 +43,14 @@ defineSuite([ RectangleGeometry, ShowGeometryInstanceAttribute, Pass, + RenderState, ClassificationType, EllipsoidSurfaceAppearance, InvertClassification, Material, PerInstanceColorAppearance, Primitive, + StencilConstants, createCanvas, createScene, pollToPromise) { @@ -63,74 +67,99 @@ defineSuite([ var rectangleInstance; var primitive; - var depthPrimitive; - var reusablePrimitive; - - beforeAll(function() { - scene = createScene(); - - scene.postProcessStages.fxaa.enabled = false; - - context = scene.context; - - ellipsoid = Ellipsoid.WGS84; - return GroundPrimitive.initializeTerrainHeights().then(function(){ - var depthColorAttribute = ColorGeometryInstanceAttribute.fromColor(new Color(0.0, 0.0, 1.0, 1.0)); - depthColor = depthColorAttribute.value; - var bigRectangle = Rectangle.fromDegrees(-180 + CesiumMath.EPSILON4, -90 + CesiumMath.EPSILON4, 180 - CesiumMath.EPSILON4, 90 - CesiumMath.EPSILON4); - - reusablePrimitive = new Primitive({ - geometryInstances : new GeometryInstance({ - geometry : new RectangleGeometry({ - ellipsoid : ellipsoid, - rectangle : bigRectangle - }), - id : 'depth rectangle', - attributes : { - color : depthColorAttribute - } - }), - appearance : new PerInstanceColorAppearance({ - translucent : false, - flat : true - }), - asynchronous : false + var globePrimitive; + var tilesetPrimitive; + var reusableGlobePrimitive; + var reusableTilesetPrimitive; + + function createPrimitive(rectangle, pass) { + var renderState; + if (pass === Pass.CESIUM_3D_TILE) { + renderState = RenderState.fromCache({ + stencilTest : StencilConstants.setCesium3DTileBit(), + stencilMask : StencilConstants.CESIUM_3D_TILE_MASK, + depthTest : { + enabled : true + } }); + } + var depthColorAttribute = ColorGeometryInstanceAttribute.fromColor(new Color(0.0, 0.0, 1.0, 1.0)); + depthColor = depthColorAttribute.value; + return new Primitive({ + geometryInstances : new GeometryInstance({ + geometry : new RectangleGeometry({ + ellipsoid : Ellipsoid.WGS84, + rectangle : rectangle + }), + id : 'depth rectangle', + attributes : { + color : depthColorAttribute + } + }), + appearance : new PerInstanceColorAppearance({ + translucent : false, + flat : true, + renderState : renderState + }), + asynchronous : false }); - }); - - afterAll(function() { - reusablePrimitive.destroy(); - scene.destroyForSpecs(); - // Leave ground primitive uninitialized - ApproximateTerrainHeights._initPromise = undefined; - ApproximateTerrainHeights._terrainHeights = undefined; - }); + } - function MockGlobePrimitive(primitive) { + function MockPrimitive(primitive, pass) { this._primitive = primitive; - this.pass = Pass.GLOBE; + this._pass = pass; + this.show = true; } - MockGlobePrimitive.prototype.update = function(frameState) { + MockPrimitive.prototype.update = function(frameState) { + if (!this.show) { + return; + } + var commandList = frameState.commandList; var startLength = commandList.length; this._primitive.update(frameState); for (var i = startLength; i < commandList.length; ++i) { var command = commandList[i]; - command.pass = this.pass; + command.pass = this._pass; } }; - MockGlobePrimitive.prototype.isDestroyed = function() { + MockPrimitive.prototype.isDestroyed = function() { return false; }; - MockGlobePrimitive.prototype.destroy = function() { + MockPrimitive.prototype.destroy = function() { return destroyObject(this); }; + beforeAll(function() { + scene = createScene(); + + scene.postProcessStages.fxaa.enabled = false; + + context = scene.context; + + ellipsoid = Ellipsoid.WGS84; + + var bigRectangle = Rectangle.fromDegrees(-180 + CesiumMath.EPSILON4, -90 + CesiumMath.EPSILON4, 180 - CesiumMath.EPSILON4, 90 - CesiumMath.EPSILON4); + reusableGlobePrimitive = createPrimitive(bigRectangle, Pass.GLOBE); + reusableTilesetPrimitive = createPrimitive(bigRectangle, Pass.CESIUM_3D_TILE); + + return GroundPrimitive.initializeTerrainHeights(); + + }); + + afterAll(function() { + reusableGlobePrimitive.destroy(); + reusableTilesetPrimitive.destroy(); + scene.destroyForSpecs(); + // Leave ground primitive uninitialized + ApproximateTerrainHeights._initPromise = undefined; + ApproximateTerrainHeights._terrainHeights = undefined; + }); + beforeEach(function() { scene.morphTo3D(0); scene.render(); // clear any afterRender commands @@ -138,7 +167,8 @@ defineSuite([ rectangle = Rectangle.fromDegrees(-80.0, 20.0, -70.0, 30.0); // wrap rectangle primitive so it gets executed during the globe pass to lay down depth - depthPrimitive = new MockGlobePrimitive(reusablePrimitive); + globePrimitive = new MockPrimitive(reusableGlobePrimitive, Pass.GLOBE); + tilesetPrimitive = new MockPrimitive(reusableTilesetPrimitive, Pass.CESIUM_3D_TILE); var rectColorAttribute = ColorGeometryInstanceAttribute.fromColor(new Color(1.0, 1.0, 0.0, 1.0)); rectColor = rectColorAttribute.value; @@ -155,9 +185,11 @@ defineSuite([ }); afterEach(function() { + scene.primitives.removeAll(); scene.groundPrimitives.removeAll(); primitive = primitive && !primitive.isDestroyed() && primitive.destroy(); - depthPrimitive = depthPrimitive && !depthPrimitive.isDestroyed() && depthPrimitive.destroy(); + globePrimitive = globePrimitive && !globePrimitive.isDestroyed() && globePrimitive.destroy(); + tilesetPrimitive = tilesetPrimitive && !tilesetPrimitive.isDestroyed() && tilesetPrimitive.destroy(); }); it('default constructs', function() { @@ -342,17 +374,53 @@ defineSuite([ expect(frameState.commandList.length).toEqual(0); }); - function verifyGroundPrimitiveRender(primitive, color) { - scene.camera.setView({ destination : rectangle }); + function expectRender(color) { + expect(scene).toRender(color); + } - scene.groundPrimitives.add(depthPrimitive); + function expectRenderBlank() { expect(scene).toRenderAndCall(function(rgba) { expect(rgba).not.toEqual([0, 0, 0, 255]); expect(rgba[0]).toEqual(0); }); + } + + function verifyGroundPrimitiveRender(primitive, color) { + scene.camera.setView({ destination : rectangle }); + + scene.primitives.add(globePrimitive); + scene.primitives.add(tilesetPrimitive); + + expectRenderBlank(); scene.groundPrimitives.add(primitive); - expect(scene).toRender(color); + + primitive.classificationType = ClassificationType.BOTH; + globePrimitive.show = false; + tilesetPrimitive.show = true; + expectRender(color); + globePrimitive.show = true; + tilesetPrimitive.show = false; + expectRender(color); + + primitive.classificationType = ClassificationType.CESIUM_3D_TILE; + globePrimitive.show = false; + tilesetPrimitive.show = true; + expectRender(color); + globePrimitive.show = true; + tilesetPrimitive.show = false; + expectRenderBlank(); + + primitive.classificationType = ClassificationType.TERRAIN; + globePrimitive.show = false; + tilesetPrimitive.show = true; + expectRenderBlank(); + globePrimitive.show = true; + tilesetPrimitive.show = false; + expectRender(color); + + globePrimitive.show = true; + tilesetPrimitive.show = true; } it('renders in 3D', function() { @@ -393,7 +461,7 @@ defineSuite([ scene.camera.setView({ destination : bigIdlRectangle }); - scene.groundPrimitives.add(depthPrimitive); + scene.primitives.add(globePrimitive); expect(scene).toRenderAndCall(function(rgba) { expect(rgba).not.toEqual([0, 0, 0, 255]); expect(rgba[0]).toEqual(0); @@ -428,7 +496,7 @@ defineSuite([ scene.camera.setView({ destination : smallIdlRectangle }); - scene.groundPrimitives.add(depthPrimitive); + scene.primitives.add(globePrimitive); expect(scene).toRenderAndCall(function(rgba) { expect(rgba).not.toEqual([0, 0, 0, 255]); expect(rgba[0]).toEqual(0); @@ -469,39 +537,24 @@ defineSuite([ describe('larger scene', function() { // Screen space techniques may produce unexpected results with 1x1 canvasses var largeScene; - var largeSceneReusablePrimitive; + var largeSceneReusableGlobePrimitive; + var largeSceneReusableTilesetPrimitive; beforeAll(function() { largeScene = createScene({ canvas : createCanvas(2, 2) }); - var depthColorAttribute = ColorGeometryInstanceAttribute.fromColor(new Color(0.0, 0.0, 1.0, 1.0)); - depthColor = depthColorAttribute.value; var bigRectangle = Rectangle.fromDegrees(-180 + CesiumMath.EPSILON4, -90 + CesiumMath.EPSILON4, 180 - CesiumMath.EPSILON4, 90 - CesiumMath.EPSILON4); - - largeSceneReusablePrimitive = new Primitive({ - geometryInstances : new GeometryInstance({ - geometry : new RectangleGeometry({ - ellipsoid : ellipsoid, - rectangle : bigRectangle - }), - id : 'depth rectangle', - attributes : { - color : depthColorAttribute - } - }), - appearance : new PerInstanceColorAppearance({ - translucent : false, - flat : true - }), - asynchronous : false - }); + largeSceneReusableGlobePrimitive = createPrimitive(bigRectangle, Pass.GLOBE); + largeSceneReusableTilesetPrimitive = createPrimitive(bigRectangle, Pass.CESIUM_3D_TILE); }); afterAll(function() { - largeSceneReusablePrimitive.destroy(); + largeSceneReusableGlobePrimitive.destroy(); + largeSceneReusableTilesetPrimitive.destroy(); largeScene.destroyForSpecs(); }); afterEach(function(){ + largeScene.primitives.removeAll(); largeScene.groundPrimitives.removeAll(); }); @@ -511,9 +564,9 @@ defineSuite([ largeScene.postProcessStages.fxaa.enabled = false; largeScene.camera.setView({destination : destination}); - var largeSceneDepthPrimitive = new MockGlobePrimitive(largeSceneReusablePrimitive); + var largeSceneGlobePrimitive = new MockPrimitive(largeSceneReusableGlobePrimitive, Pass.GLOBE); - largeScene.groundPrimitives.add(largeSceneDepthPrimitive); + largeScene.primitives.add(largeSceneGlobePrimitive); expect(largeScene).toRenderAndCall(function(rgba) { expect(arraySlice(rgba, 0, 4)).not.toEqual([0, 0, 0, 255]); expect(rgba[0]).toEqual(0); @@ -696,7 +749,6 @@ defineSuite([ scene.invertClassification = true; scene.invertClassificationColor = new Color(0.25, 0.25, 0.25, 1.0); - depthPrimitive.pass = Pass.CESIUM_3D_TILE; rectangleInstance.attributes.show = new ShowGeometryInstanceAttribute(true); primitive = new GroundPrimitive({ @@ -713,7 +765,7 @@ defineSuite([ invertedColor[2] = Color.floatToByte(Color.byteToFloat(depthColor[2]) * scene.invertClassificationColor.blue); invertedColor[3] = 255; - scene.groundPrimitives.add(depthPrimitive); + scene.primitives.add(tilesetPrimitive); expect(scene).toRender(invertedColor); scene.groundPrimitives.add(primitive); @@ -737,7 +789,6 @@ defineSuite([ scene.invertClassification = true; scene.invertClassificationColor = new Color(0.25, 0.25, 0.25, 0.25); - depthPrimitive.pass = Pass.CESIUM_3D_TILE; rectangleInstance.attributes.show = new ShowGeometryInstanceAttribute(true); primitive = new GroundPrimitive({ @@ -754,7 +805,7 @@ defineSuite([ invertedColor[2] = Color.floatToByte(Color.byteToFloat(depthColor[2]) * scene.invertClassificationColor.blue * scene.invertClassificationColor.alpha); invertedColor[3] = 255; - scene.groundPrimitives.add(depthPrimitive); + scene.primitives.add(tilesetPrimitive); expect(scene).toRender(invertedColor); scene.groundPrimitives.add(primitive); @@ -836,6 +887,10 @@ defineSuite([ verifyGroundPrimitiveRender(primitive, rectColor); + scene.primitives.destroyPrimitives = false; + scene.primitives.removeAll(); + scene.primitives.destroyPrimitives = true; + scene.groundPrimitives.destroyPrimitives = false; scene.groundPrimitives.removeAll(); scene.groundPrimitives.destroyPrimitives = true; @@ -862,6 +917,10 @@ defineSuite([ verifyGroundPrimitiveRender(primitive, rectColor); + scene.primitives.destroyPrimitives = false; + scene.primitives.removeAll(); + scene.primitives.destroyPrimitives = true; + scene.groundPrimitives.destroyPrimitives = false; scene.groundPrimitives.removeAll(); scene.groundPrimitives.destroyPrimitives = true; @@ -904,7 +963,7 @@ defineSuite([ asynchronous : false }); - scene.groundPrimitives.add(depthPrimitive); + scene.primitives.add(globePrimitive); scene.groundPrimitives.add(primitive); scene.camera.setView({ destination : rect }); scene.renderForSpecs();