From 5fc1db427041806dad300a367482cf87551ca0cc Mon Sep 17 00:00:00 2001 From: hanbollar Date: Thu, 5 Apr 2018 10:56:35 -0400 Subject: [PATCH 01/11] proper updates --- Apps/SampleData/circular_particle.png | Bin 0 -> 975 bytes Apps/SampleData/snowflake_particle.png | Bin 0 -> 3270 bytes .../gallery/Particle System Tails.html | 228 ++++++++++++++++++ .../gallery/Particle System Tails.jpg | Bin 0 -> 18626 bytes .../gallery/Particle System Weather.html | 167 +++++++++++++ .../gallery/Particle System Weather.jpg | Bin 0 -> 27598 bytes CHANGES.md | 6 + Source/Scene/ParticleSystem.js | 12 +- 8 files changed, 408 insertions(+), 5 deletions(-) create mode 100644 Apps/SampleData/circular_particle.png create mode 100644 Apps/SampleData/snowflake_particle.png create mode 100644 Apps/Sandcastle/gallery/Particle System Tails.html create mode 100644 Apps/Sandcastle/gallery/Particle System Tails.jpg create mode 100644 Apps/Sandcastle/gallery/Particle System Weather.html create mode 100644 Apps/Sandcastle/gallery/Particle System Weather.jpg diff --git a/Apps/SampleData/circular_particle.png b/Apps/SampleData/circular_particle.png new file mode 100644 index 0000000000000000000000000000000000000000..ca1cc10d6b2d40cfd2125b8d37050cbd55f3a645 GIT binary patch literal 975 zcmeAS@N?(olHy`uVBq!ia0vp^3LwnE1|*BCs=fdzmUKs7M+SzC{oH>NS%G}c0*}aI z1_r)EAj~ML;ne^Xlq_+LC<)F_D=AMbN@XZW%*-p%%S$a$Fwry6Gqk*NZBq&Z1GA5( zi(^QH``hcb{k@J7$3EWOnr+U)DYSm>bS}pq3?(97QmU+WO)Y%_y7w74@0xK%Nv&mK z6`gvav%_ND{gbw{C)d82_gG|i*W4%beV*-mmpyOh&h&Hdjzs-_AHDv1wolti1KG4g zIWx4s^mbmn@a^-lyt50=TxI6yu3EC{DwGR z>*I$h5ShLhxyAJ^!r_ai=5SdbZY)rm!}t79Yr)0~=4x)v+U|P&7ws3d&ye61#877_>w1UAudtoeji6rzW0m z7C&F-t8PHr$wsk56JZ|6Qv3f;)G*Qc>TwOIZ?j zocf1%f6%Pqyw6peoMf`4=*g!CM<;(z@x7kQX{8>&YLe*W&s&y;9sS|_Luz09{D)AV z0{ye6;?ulUFL&uW@^>yOoEx%bQPH|>*IxO2P@eJSyHXD@n82>`zjxU*cDw3|02_^W zTe6pK5}p2e>(MYvi^}X~c}I}X`QvOV&tECIJ8gmb)z!}u3%AGWi>^B{XY*R1cy{ib zwlJtwYe81M-?jYe>t~IH$77ABuDfyT)$}ZclVgBRZc>ff${+DnIiThC;RHcDKCV~A z5?eVkpPrD_ak_U}EOB?+@8;FTx;7m8hkhHpGF>uNc{;oPJm>X^)g628%kf8-8}IO2 zf9QAu)9Ni()mrx%8cIc37FB+DWcfu=s-}ydExyk34zE9R^6Je;&qZ!@ghfw9?-!B7 z{Kt+xV1MFaA-yM!XYHwLR`IUOF2N&zPX*s!!>rv4B+T3QK8#36G2M1$rh~o<7kR1P!;86UcF)Jx!}N+Z*CuyZHK!;>K}WjTgaCF4_~)ku+&m}wr*;tjR7

Mg71%R53gy?)|X9kC}5Cb{4DUX(Z2Ip2>f60V<^Ru!-(YhKt3Y2n2S wr(U)%?zub5ac1P%Q-6{-T?+^^4-|N8YQYJYeVCG}+boFyt=akR{006MTC;$Ke literal 0 HcmV?d00001 diff --git a/Apps/SampleData/snowflake_particle.png b/Apps/SampleData/snowflake_particle.png new file mode 100644 index 0000000000000000000000000000000000000000..8fadd90568184e748c3a9f189a5813c7fd77c3d8 GIT binary patch literal 3270 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 + + + + + + + + Cesium Demo + + + + + + +

+

Loading...

+
+ + + + diff --git a/Apps/Sandcastle/gallery/Particle System Tails.jpg b/Apps/Sandcastle/gallery/Particle System Tails.jpg new file mode 100644 index 0000000000000000000000000000000000000000..633d3820d2afcb4e712cd03a002e8199d93ffedd GIT binary patch literal 18626 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 DKfXNM literal 0 HcmV?d00001 diff --git a/Apps/Sandcastle/gallery/Particle System Weather.html b/Apps/Sandcastle/gallery/Particle System Weather.html new file mode 100644 index 000000000000..93e2adae3b7d --- /dev/null +++ b/Apps/Sandcastle/gallery/Particle System Weather.html @@ -0,0 +1,167 @@ + + + + + + + + + Cesium Demo + + + + + + +
+

Loading...

+
+
+ + + + diff --git a/Apps/Sandcastle/gallery/Particle System Weather.jpg b/Apps/Sandcastle/gallery/Particle System Weather.jpg new file mode 100644 index 0000000000000000000000000000000000000000..24a0bf06112081273d03a86dcb3d26f16b9545d1 GIT binary patch literal 27598 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 a*G~Tcz-m9?S>1Z+-}nt)$3;oZfB)HqCf~CF literal 0 HcmV?d00001 diff --git a/CHANGES.md b/CHANGES.md index e67cb71e0711..850691d24eaf 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -47,7 +47,13 @@ Change Log * `sourceType` specifies the type of data source if the URL doesn't have a known file extension. * `flyTo=false` optionally disables the automatic `flyTo` after loading the data source. * Added a multi-part CZML example to Sandcastle. [#6320](https://github.com/AnalyticalGraphicsInc/cesium/pull/6320) +* `Credit` has been modified to take an HTML string as the credit content [#6331](https://github.com/AnalyticalGraphicsInc/cesium/pull/6331) +* Added support for ordering in `DataSourceCollection` [#6316](https://github.com/AnalyticalGraphicsInc/cesium/pull/6316) + * All ground geometry from one `DataSource` will render in front of all ground geometry from another `DataSource` in the same collection with a lower index. + * Use `DataSourceCollection.raise`, `DataSourceCollection.lower`, `DataSourceCollection.raiseToTop` and `DataSourceCollection.lowerToBottom` functions to change the ordering of a `DataSource` in the collection. * Improved processing order of 3D tiles. [#6364](https://github.com/AnalyticalGraphicsInc/cesium/pull/6364) +* Added more ParticleSystem Sandcastle examples for rocket and comet tails and weather. [#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) +* Added ParticleSystem parameter to allow for default of one color or scale instead of always requiring start and end versions.[#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) ##### Fixes :wrench: * Fixed Cesium ion browser caching. [#6353](https://github.com/AnalyticalGraphicsInc/cesium/pull/6353). diff --git a/Source/Scene/ParticleSystem.js b/Source/Scene/ParticleSystem.js index 6ce7467f73ca..bff7dce9434a 100644 --- a/Source/Scene/ParticleSystem.js +++ b/Source/Scene/ParticleSystem.js @@ -44,8 +44,10 @@ define([ * @param {ParticleEmitter} [options.emitter=new CircleEmitter(0.5)] The particle emitter for this system. * @param {Matrix4} [options.modelMatrix=Matrix4.IDENTITY] The 4x4 transformation matrix that transforms the particle system from model to world coordinates. * @param {Matrix4} [options.emitterModelMatrix=Matrix4.IDENTITY] The 4x4 transformation matrix that transforms the particle system emitter within the particle systems local coordinate system. + * @param {Color} [options.color] Sets the start and end colors. * @param {Color} [options.startColor=Color.WHITE] The color of a particle when it is born. * @param {Color} [options.endColor=Color.WHITE] The color of a particle when it dies. + * @param {Number} [options.scale] Sets the start and end scales. * @param {Number} [options.startScale=1.0] The scale of the particle when it is born. * @param {Number} [options.endScale=1.0] The scale of the particle when it dies. * @param {Number} [options.rate=5] The number of particles to emit per second. @@ -115,11 +117,11 @@ define([ this._matrixDirty = true; this._combinedMatrix = new Matrix4(); - this._startColor = Color.clone(defaultValue(options.startColor, Color.WHITE)); - this._endColor = Color.clone(defaultValue(options.endColor, Color.WHITE)); + this._startColor = Color.clone(defaultValue(options.color, defaultValue(options.startColor, Color.WHITE))); + this._endColor = Color.clone(defaultValue(options.color, defaultValue(options.endColor, Color.WHITE))); - this._startScale = defaultValue(options.startScale, 1.0); - this._endScale = defaultValue(options.endScale, 1.0); + this._startScale = defaultValue(options.scale, defaultValue(options.startScale, 1.0)); + this._endScale = defaultValue(options.scale, defaultValue(options.endScale, 1.0)); this._rate = defaultValue(options.rate, 5); @@ -162,7 +164,7 @@ define([ * The particle emitter for this * @memberof ParticleSystem.prototype * @type {ParticleEmitter} - * @default CricleEmitter + * @default CircleEmitter */ emitter : { get : function() { From e2379d5610b02cdccd8ceeac47de774cc1d6a794 Mon Sep 17 00:00:00 2001 From: hanbollar Date: Thu, 5 Apr 2018 10:59:41 -0400 Subject: [PATCH 02/11] updated changes.md --- CHANGES.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index 850691d24eaf..6e74483e7966 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -9,6 +9,10 @@ Change Log * Fixed glTF support to handle skinned meshes when no skin is supplied. [#6061](https://github.com/AnalyticalGraphicsInc/cesium/issues/6061) * Allow loadWithXhr to work with string URLs in a web worker. +##### Additions :tada: +* Added more ParticleSystem Sandcastle examples for rocket and comet tails and weather. [#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) +* Added ParticleSystem parameter to allow for default of one color or scale instead of always requiring start and end versions.[#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) + ### 1.44 - 2018-04-02 ##### Highlights :sparkler: @@ -52,8 +56,6 @@ Change Log * All ground geometry from one `DataSource` will render in front of all ground geometry from another `DataSource` in the same collection with a lower index. * Use `DataSourceCollection.raise`, `DataSourceCollection.lower`, `DataSourceCollection.raiseToTop` and `DataSourceCollection.lowerToBottom` functions to change the ordering of a `DataSource` in the collection. * Improved processing order of 3D tiles. [#6364](https://github.com/AnalyticalGraphicsInc/cesium/pull/6364) -* Added more ParticleSystem Sandcastle examples for rocket and comet tails and weather. [#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) -* Added ParticleSystem parameter to allow for default of one color or scale instead of always requiring start and end versions.[#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) ##### Fixes :wrench: * Fixed Cesium ion browser caching. [#6353](https://github.com/AnalyticalGraphicsInc/cesium/pull/6353). From 12d0f3cc41c743a179080d11745c06e8d296fe1c Mon Sep 17 00:00:00 2001 From: hanbollar Date: Thu, 5 Apr 2018 11:11:09 -0400 Subject: [PATCH 03/11] remove changes in particle system class --- CHANGES.md | 1 - Source/Scene/ParticleSystem.js | 12 +++++------- 2 files changed, 5 insertions(+), 8 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index 6e74483e7966..3a3af22982bd 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -11,7 +11,6 @@ Change Log ##### Additions :tada: * Added more ParticleSystem Sandcastle examples for rocket and comet tails and weather. [#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) -* Added ParticleSystem parameter to allow for default of one color or scale instead of always requiring start and end versions.[#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) ### 1.44 - 2018-04-02 diff --git a/Source/Scene/ParticleSystem.js b/Source/Scene/ParticleSystem.js index bff7dce9434a..6ce7467f73ca 100644 --- a/Source/Scene/ParticleSystem.js +++ b/Source/Scene/ParticleSystem.js @@ -44,10 +44,8 @@ define([ * @param {ParticleEmitter} [options.emitter=new CircleEmitter(0.5)] The particle emitter for this system. * @param {Matrix4} [options.modelMatrix=Matrix4.IDENTITY] The 4x4 transformation matrix that transforms the particle system from model to world coordinates. * @param {Matrix4} [options.emitterModelMatrix=Matrix4.IDENTITY] The 4x4 transformation matrix that transforms the particle system emitter within the particle systems local coordinate system. - * @param {Color} [options.color] Sets the start and end colors. * @param {Color} [options.startColor=Color.WHITE] The color of a particle when it is born. * @param {Color} [options.endColor=Color.WHITE] The color of a particle when it dies. - * @param {Number} [options.scale] Sets the start and end scales. * @param {Number} [options.startScale=1.0] The scale of the particle when it is born. * @param {Number} [options.endScale=1.0] The scale of the particle when it dies. * @param {Number} [options.rate=5] The number of particles to emit per second. @@ -117,11 +115,11 @@ define([ this._matrixDirty = true; this._combinedMatrix = new Matrix4(); - this._startColor = Color.clone(defaultValue(options.color, defaultValue(options.startColor, Color.WHITE))); - this._endColor = Color.clone(defaultValue(options.color, defaultValue(options.endColor, Color.WHITE))); + this._startColor = Color.clone(defaultValue(options.startColor, Color.WHITE)); + this._endColor = Color.clone(defaultValue(options.endColor, Color.WHITE)); - this._startScale = defaultValue(options.scale, defaultValue(options.startScale, 1.0)); - this._endScale = defaultValue(options.scale, defaultValue(options.endScale, 1.0)); + this._startScale = defaultValue(options.startScale, 1.0); + this._endScale = defaultValue(options.endScale, 1.0); this._rate = defaultValue(options.rate, 5); @@ -164,7 +162,7 @@ define([ * The particle emitter for this * @memberof ParticleSystem.prototype * @type {ParticleEmitter} - * @default CircleEmitter + * @default CricleEmitter */ emitter : { get : function() { From 46ac1d74599e12a7628fa2faea57c00daa711b45 Mon Sep 17 00:00:00 2001 From: hanbollar Date: Thu, 5 Apr 2018 11:16:35 -0400 Subject: [PATCH 04/11] fix eslint errors --- Apps/Sandcastle/gallery/Particle System Weather.html | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/Apps/Sandcastle/gallery/Particle System Weather.html b/Apps/Sandcastle/gallery/Particle System Weather.html index 93e2adae3b7d..691aedaef51d 100644 --- a/Apps/Sandcastle/gallery/Particle System Weather.html +++ b/Apps/Sandcastle/gallery/Particle System Weather.html @@ -50,6 +50,8 @@ var snowParticleSize = scene.drawingBufferWidth / 100.0; var snowRadius = 100000.0; +var snowSystem; + var snowGravityScratch = new Cesium.Cartesian3(); var snowUpdate = function(particle, dt) { snowGravityScratch = Cesium.Cartesian3.normalize(particle.position, snowGravityScratch); @@ -64,7 +66,7 @@ } }; -var snowSystem = new Cesium.ParticleSystem({ +snowSystem = new Cesium.ParticleSystem({ modelMatrix : new Cesium.Matrix4.fromTranslation(scene.camera.position), minimumSpeed : -1.0, maximumSpeed : 0.0, @@ -88,6 +90,8 @@ var rainParticleSize = scene.drawingBufferWidth / 80.0; var rainRadius = 100000.0; +var rainSystem; + var rainGravityScratch = new Cesium.Cartesian3(); var rainUpdate = function(particle, dt) { rainGravityScratch = Cesium.Cartesian3.normalize(particle.position, rainGravityScratch); @@ -103,7 +107,7 @@ } }; -var rainSystem = new Cesium.ParticleSystem({ +rainSystem = new Cesium.ParticleSystem({ modelMatrix : new Cesium.Matrix4.fromTranslation(scene.camera.position), speed : -1.0, lifeTime : 15.0, From 93e7c45c89c2583a064725a8795ef7b6b5acea54 Mon Sep 17 00:00:00 2001 From: hanbollar Date: Thu, 12 Apr 2018 15:57:41 -0400 Subject: [PATCH 05/11] updates for deprecations --- .../gallery/Particle System Fireworks.html | 14 +++++------ .../gallery/Particle System Tails.html | 12 ++++----- .../gallery/Particle System Weather.html | 25 +++++++++---------- Apps/Sandcastle/gallery/Particle System.html | 19 ++++++-------- 4 files changed, 31 insertions(+), 39 deletions(-) diff --git a/Apps/Sandcastle/gallery/Particle System Fireworks.html b/Apps/Sandcastle/gallery/Particle System Fireworks.html index 2e61fecda5c9..440b23381d67 100644 --- a/Apps/Sandcastle/gallery/Particle System Fireworks.html +++ b/Apps/Sandcastle/gallery/Particle System Fireworks.html @@ -59,7 +59,7 @@ var minimumExplosionSize = 30.0; var maximumExplosionSize = 100.0; -var particlePixelSize = 7.0; +var particlePixelSize = new Cesium.Cartesian2(7.0, 7.0); var burstSize = 400.0; var lifetime = 10.0; var numberOfFireworks = 20.0; @@ -90,15 +90,14 @@ image : getImage(), startColor : color, endColor : color.withAlpha(0.0), - life : life, + particleLife : life, speed : 100.0, - width : particlePixelSize, - height : particlePixelSize, - rate : 0, + imageSize : particlePixelSize, + emissionRate : 0, emitter : new Cesium.SphereEmitter(0.1), bursts : bursts, - lifeTime : lifetime, - forces : [force], + lifetime : lifetime, + updateCallback : force, modelMatrix : modelMatrix, emitterModelMatrix : emitterModelMatrix })); @@ -161,7 +160,6 @@ Cesium.Cartesian3.normalize(toFireworks, toFireworks); var angle = Cesium.Math.PI_OVER_TWO - Math.acos(Cesium.Cartesian3.dot(toFireworks, Cesium.Cartesian3.UNIT_Z)); camera.lookUp(angle); - //Sandcastle_End Sandcastle.finishedLoading(); } diff --git a/Apps/Sandcastle/gallery/Particle System Tails.html b/Apps/Sandcastle/gallery/Particle System Tails.html index 4062508aef9c..6bab8526808c 100644 --- a/Apps/Sandcastle/gallery/Particle System Tails.html +++ b/Apps/Sandcastle/gallery/Particle System Tails.html @@ -152,6 +152,7 @@ var matrix4Scratch = new Cesium.Matrix4(); var scratchAngleForOffset = 0.0; var scratchOffset = new Cesium.Cartesian3(); +var imageSize = new Cesium.Cartesian2(15.0, 15.0); function createParticleSystems(options, systemsArray) { var length = options.numberOfSystems; for (var i = 0; i < length; ++i) { @@ -167,15 +168,14 @@ image : getImage(), startColor : color, endColor : color.withAlpha(0.0), - life : 3.5, + particleLife : 3.5, speed : 0.00005, - width : 15.0, - height : 15.0, - rate : 30.0, + imageSize : imageSize, + emissionRate : 30.0, emitter : new Cesium.CircleEmitter(0.1), bursts : [ ], - lifeTime : 0.1, - forces : [force], + lifetime : 0.1, + updateCallback : force, modelMatrix : particlesModelMatrix, emitterModelMatrix : emitterModelMatrix })); diff --git a/Apps/Sandcastle/gallery/Particle System Weather.html b/Apps/Sandcastle/gallery/Particle System Weather.html index 691aedaef51d..6864b9196a36 100644 --- a/Apps/Sandcastle/gallery/Particle System Weather.html +++ b/Apps/Sandcastle/gallery/Particle System Weather.html @@ -49,7 +49,8 @@ // snow var snowParticleSize = scene.drawingBufferWidth / 100.0; var snowRadius = 100000.0; - +var minimumSnowImageSize = new Cesium.Cartesian2(snowParticleSize, snowParticleSize); +var maximumSnowImageSize = new Cesium.Cartesian2(snowParticleSize * 2.0, snowParticleSize * 2.0); var snowSystem; var snowGravityScratch = new Cesium.Cartesian3(); @@ -70,25 +71,24 @@ modelMatrix : new Cesium.Matrix4.fromTranslation(scene.camera.position), minimumSpeed : -1.0, maximumSpeed : 0.0, - lifeTime : 15.0, + lifetime : 15.0, emitter : new Cesium.SphereEmitter(snowRadius), startScale : 0.5, endScale : 1.0, image : "../../SampleData/snowflake_particle.png", - rate : 7000.0, + emissionRate : 7000.0, startColor : Cesium.Color.WHITE.withAlpha(0.0), endColor : Cesium.Color.WHITE.withAlpha(1.0), - minimumWidth : snowParticleSize, - minimumHeight :snowParticleSize, - maximumWidth : snowParticleSize * 2.0, - maximumHeight :snowParticleSize * 2.0, - forces : [snowUpdate] + minimumImageSize : minimumSnowImageSize, + maximumImageSize : maximumSnowImageSize, + updateCallback : snowUpdate }); scene.primitives.add(snowSystem); // rain var rainParticleSize = scene.drawingBufferWidth / 80.0; var rainRadius = 100000.0; +var rainImageSize = new Cesium.Cartesian2(rainParticleSize, rainParticleSize * 2.0); var rainSystem; @@ -110,17 +110,16 @@ rainSystem = new Cesium.ParticleSystem({ modelMatrix : new Cesium.Matrix4.fromTranslation(scene.camera.position), speed : -1.0, - lifeTime : 15.0, + lifetime : 15.0, emitter : new Cesium.SphereEmitter(rainRadius), startScale : 1.0, endScale : 0.0, image : "../../SampleData/circular_particle.png", - rate : 9000.0, + emissionRate : 9000.0, startColor :new Cesium.Color(0.27, 0.5, 0.70, 0.0), endColor : new Cesium.Color(0.27, 0.5, 0.70, 0.98), - width : rainParticleSize, - height : rainParticleSize * 2, - forces : [rainUpdate] + imageSize : rainImageSize, + updateCallback : rainUpdate }); scene.primitives.add(rainSystem); diff --git a/Apps/Sandcastle/gallery/Particle System.html b/Apps/Sandcastle/gallery/Particle System.html index fa7a210acf79..7eab28acbf21 100644 --- a/Apps/Sandcastle/gallery/Particle System.html +++ b/Apps/Sandcastle/gallery/Particle System.html @@ -263,20 +263,16 @@ startScale : viewModel.startScale, endScale : viewModel.endScale, - minimumLife : viewModel.minimumLife, - maximumLife : viewModel.maximumLife, + minimumParticleLife : viewModel.minimumLife, + maximumParticleLife : viewModel.maximumLife, minimumSpeed : viewModel.minimumSpeed, maximumSpeed : viewModel.maximumSpeed, - minimumWidth : viewModel.particleSize, - minimumHeight : viewModel.particleSize, - - maximumWidth : viewModel.particleSize, - maximumHeight : viewModel.particleSize, + imageSize : new Cesium.Cartesian2(viewModel.particleSize, viewModel.particleSize), // Particles per second. - rate : viewModel.rate, + emissionRate : viewModel.rate, bursts : [ // these burst will occasionally sync to create a multicolored effect @@ -285,13 +281,13 @@ new Cesium.ParticleBurst({time : 15.0, minimum : 200, maximum : 300}) ], - lifeTime : 16.0, + lifetime : 16.0, emitter : new Cesium.CircleEmitter(2.0), emitterModelMatrix : computeEmitterModelMatrix(), - forces : [applyGravity] + updateCallback : applyGravity })); var gravityScratch = new Cesium.Cartesian3(); @@ -422,8 +418,7 @@ }]; Sandcastle.addToolbarMenu(options); - - //Sandcastle_End + //Sandcastle_End Sandcastle.finishedLoading(); } From 4a1ba163e3266cfadc8376998d14c2e4c658cf62 Mon Sep 17 00:00:00 2001 From: hanbollar Date: Tue, 17 Apr 2018 13:32:22 -0400 Subject: [PATCH 06/11] updated changes md for weird formatting after merging --- CHANGES.md | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index 154c71791ca6..efe67030747c 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -12,6 +12,8 @@ Change Log * Added `Math.log2` to compute the base 2 logarithm of a number. * Added 'PeliasGeocoderService', which provides geocoding via a [Pelias](https://pelias.io) server. * Added `GeocodeType` enum and use it as an optional parameter to all `GeocoderService` instances to differentiate between autocomplete and search requests. +* Improved `MapboxImageryProvider` performance by 300% via `tiles.mapbox.com` subdomain switching. [#6426](https://github.com/AnalyticalGraphicsInc/cesium/issues/6426) +* Added more ParticleSystem Sandcastle examples for rocket and comet tails and weather. [#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) ##### Fixes :wrench: * Fixed bugs in `TimeIntervalCollection.removeInterval`. [#6418](https://github.com/AnalyticalGraphicsInc/cesium/pull/6418). @@ -22,11 +24,6 @@ Change Log * Fix Firefox WebGL console warnings. [#5912](https://github.com/AnalyticalGraphicsInc/cesium/issues/5912) * Fix parsing Cesium.js in older browsers that do not support all TypedArray types. [#6396](https://github.com/AnalyticalGraphicsInc/cesium/pull/6396) * Fix flicker when adding, removing, or modifiying entities. [#3945](https://github.com/AnalyticalGraphicsInc/cesium/issues/3945) -##### Additions :tada: -* Improved `MapboxImageryProvider` performance by 300% via `tiles.mapbox.com` subdomain switching. [#6426](https://github.com/AnalyticalGraphicsInc/cesium/issues/6426) - -##### Additions :tada: -* Added more ParticleSystem Sandcastle examples for rocket and comet tails and weather. [#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) ### 1.44 - 2018-04-02 From 54fe548f8dd61508946e3d1b4f86d02c5e71a9c1 Mon Sep 17 00:00:00 2001 From: hpinkos Date: Thu, 19 Apr 2018 18:30:39 -0400 Subject: [PATCH 07/11] Allow Resource.delete to send data --- Source/Core/Resource.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Source/Core/Resource.js b/Source/Core/Resource.js index f504941b354a..682824d71745 100644 --- a/Source/Core/Resource.js +++ b/Source/Core/Resource.js @@ -1446,7 +1446,8 @@ define([ return resource.delete({ // Make copy of just the needed fields because headers can be passed to both the constructor and to fetch responseType: options.responseType, - overrideMimeType: options.overrideMimeType + overrideMimeType: options.overrideMimeType, + data: options.data }); }; From 410102f4c1befd715afcf97659b2d892f7c4be8f Mon Sep 17 00:00:00 2001 From: hpinkos Date: Fri, 20 Apr 2018 10:05:46 -0400 Subject: [PATCH 08/11] doc --- Source/Core/Resource.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Source/Core/Resource.js b/Source/Core/Resource.js index 682824d71745..5fc104794dd4 100644 --- a/Source/Core/Resource.js +++ b/Source/Core/Resource.js @@ -1430,6 +1430,7 @@ define([ * * @param {String|Object} options A url or an object with the following properties * @param {String} options.url The url of the resource. + * @param {Object} [options.data] Data that is posted with the resource. * @param {Object} [options.queryParameters] An object containing query parameters that will be sent when retrieving the resource. * @param {Object} [options.templateValues] Key/Value pairs that are used to replace template values (eg. {x}). * @param {Object} [options.headers={}] Additional HTTP headers that will be sent. @@ -1571,6 +1572,7 @@ define([ * * @param {Object} data Data that is posted with the resource. * @param {Object} [options] Object with the following properties: + * @param {Object} [options.data] Data that is posted with the resource. * @param {String} [options.responseType] The type of response. This controls the type of item returned. * @param {Object} [options.headers] Additional HTTP headers to send with the request, if any. * @param {String} [options.overrideMimeType] Overrides the MIME type returned by the server. From bc7ad0869d22e14e610e0573fc4936ff9a7176ba Mon Sep 17 00:00:00 2001 From: hanbollar Date: Tue, 24 Apr 2018 10:49:21 -0400 Subject: [PATCH 09/11] updates based on ggetz comments --- .../Imagery Layers Texture Filters.html | 4 +- .../gallery/Particle System Tails.html | 25 +++---- .../gallery/Particle System Weather.html | 10 +-- Apps/Sandcastle/gallery/Particle System.html | 42 +++++------ CHANGES.md | 7 +- CONTRIBUTORS.md | 1 + Source/Core/IonGeocoderService.js | 64 ++++++++++++++++ Source/Core/PeliasGeocoderService.js | 1 + Source/Core/RequestScheduler.js | 16 +++- Source/Scene/IonImageryProvider.js | 3 - Source/Scene/Model.js | 10 ++- Source/Scene/PolylineCollection.js | 6 ++ Source/Widgets/Geocoder/GeocoderViewModel.js | 6 +- Specs/Core/IonGeocoderServiceSpec.js | 48 ++++++++++++ Specs/Core/IonResourceSpec.js | 10 +-- Specs/Core/RequestSchedulerSpec.js | 75 +++++++++++++------ Specs/Scene/IonImageryProviderSpec.js | 26 +++---- Specs/Scene/PolylineCollectionSpec.js | 14 ++++ 18 files changed, 271 insertions(+), 97 deletions(-) create mode 100644 Source/Core/IonGeocoderService.js create mode 100644 Specs/Core/IonGeocoderServiceSpec.js diff --git a/Apps/Sandcastle/gallery/Imagery Layers Texture Filters.html b/Apps/Sandcastle/gallery/Imagery Layers Texture Filters.html index 4b6fe4166cb4..72fca860b7e6 100644 --- a/Apps/Sandcastle/gallery/Imagery Layers Texture Filters.html +++ b/Apps/Sandcastle/gallery/Imagery Layers Texture Filters.html @@ -55,11 +55,11 @@ layers.removeAll(); var layerLinear = layers.addImageryProvider(Cesium.createTileMapServiceImageryProvider({ - url : require.toUrl('Assets/Textures/NaturalEarthII') + url : Cesium.buildModuleUrl('Assets/Textures/NaturalEarthII') })); var layerNearest = layers.addImageryProvider(Cesium.createTileMapServiceImageryProvider({ - url : require.toUrl('Assets/Textures/NaturalEarthII') + url : Cesium.buildModuleUrl('Assets/Textures/NaturalEarthII') })); // Set the texture minification and magnification filters of layerNearest. Default is LINEAR. diff --git a/Apps/Sandcastle/gallery/Particle System Tails.html b/Apps/Sandcastle/gallery/Particle System Tails.html index 6bab8526808c..bcd66de1a3c8 100644 --- a/Apps/Sandcastle/gallery/Particle System Tails.html +++ b/Apps/Sandcastle/gallery/Particle System Tails.html @@ -34,10 +34,10 @@ var planePosition = Cesium.Cartesian3.fromDegrees(-75.59777, 40.03883, 800.0); var particlesOffset = new Cesium.Cartesian3(-8.950115473940969, 34.852766731753945, -30.235411095432937); var cameraLocation = Cesium.Cartesian3.add(planePosition, particlesOffset, new Cesium.Cartesian3()); -var recenterCamera = function() { - viewer.camera.lookAt(cameraLocation, new Cesium.Cartesian3(170, -170, 170)); +var resetCamera = function() { + viewer.camera.lookAt(cameraLocation, new Cesium.Cartesian3(-450, -300, 200)); }; -recenterCamera(); +resetCamera(); // Draw particle image to a canvas var particleCanvas; @@ -69,9 +69,9 @@ }); // creating particles model matrix -var transl = Cesium.Matrix4.fromTranslation(particlesOffset, new Cesium.Matrix4()); -var translPosition = Cesium.Matrix4.fromTranslation(planePosition, new Cesium.Matrix4()); -var particlesModelMatrix = Cesium.Matrix4.multiplyTransformation(translPosition, transl, new Cesium.Matrix4()); +var translationOffset = Cesium.Matrix4.fromTranslation(particlesOffset, new Cesium.Matrix4()); +var translationOfPlane = Cesium.Matrix4.fromTranslation(planePosition, new Cesium.Matrix4()); +var particlesModelMatrix = Cesium.Matrix4.multiplyTransformation(translationOfPlane, translationOffset, new Cesium.Matrix4()); // creating the particle systems var rocketOptions = { @@ -130,8 +130,7 @@ var scratchCartesian3 = new Cesium.Cartesian3(); var scratchCartographic = new Cesium.Cartographic(); var forceFunction = function(options, iteration) { - var iterationOffset = iteration; - var func = function(particle) { + return function(particle) { scratchCartesian3 = Cesium.Cartesian3.normalize(particle.position, new Cesium.Cartesian3()); scratchCartesian3 = Cesium.Cartesian3.multiplyByScalar(scratchCartesian3, -1.0, scratchCartesian3); @@ -139,14 +138,13 @@ scratchCartographic = Cesium.Cartographic.fromCartesian(particle.position, Cesium.Ellipsoid.WGS84, scratchCartographic); - var angle = Cesium.Math.PI * 2.0 * iterationOffset / options.numberOfSystems; - iterationOffset += options.iterationOffset; + var angle = Cesium.Math.PI * 2.0 * iteration / options.numberOfSystems; + iteration += options.iterationOffset; scratchCartographic.longitude += Math.cos(angle) * options.cartographicStep; scratchCartographic.latitude += Math.sin(angle) * options.cartographicStep; particle.position = Cesium.Cartographic.toCartesian(scratchCartographic); }; - return func; }; var matrix4Scratch = new Cesium.Matrix4(); @@ -173,7 +171,6 @@ imageSize : imageSize, emissionRate : 30.0, emitter : new Cesium.CircleEmitter(0.1), - bursts : [ ], lifetime : 0.1, updateCallback : force, modelMatrix : particlesModelMatrix, @@ -201,7 +198,7 @@ onselect : function() { showAll(rocketSystems, false); showAll(cometSystems, true); - recenterCamera(); + resetCamera(); } }, { @@ -209,7 +206,7 @@ onselect : function() { showAll(cometSystems, false); showAll(rocketSystems, true); - recenterCamera(); + resetCamera(); } }]; Sandcastle.addToolbarMenu(options); diff --git a/Apps/Sandcastle/gallery/Particle System Weather.html b/Apps/Sandcastle/gallery/Particle System Weather.html index 6864b9196a36..7035b4d507e1 100644 --- a/Apps/Sandcastle/gallery/Particle System Weather.html +++ b/Apps/Sandcastle/gallery/Particle System Weather.html @@ -35,7 +35,7 @@ }); var scene = viewer.scene; scene.globe.depthTestAgainstTerrain = true; -var recenterFunction = function() { +var resetCameraFunction = function() { scene.camera.setView({ destination : new Cesium.Cartesian3(277096.634865404, 5647834.481964232, 2985563.7039122293), orientation : { @@ -44,7 +44,7 @@ } }); }; -recenterFunction(); +resetCameraFunction(); // snow var snowParticleSize = scene.drawingBufferWidth / 100.0; @@ -60,7 +60,7 @@ particle.velocity = Cesium.Cartesian3.add(particle.velocity, snowGravityScratch, particle.velocity); var distance = Cesium.Cartesian3.distance(scene.camera.position, particle.position); - if (distance > (snowRadius)) { + if (distance > snowRadius) { particle.endColor.alpha = 0.0; } else { particle.endColor.alpha = snowSystem.endColor.alpha / (distance / snowRadius + 0.1); @@ -100,7 +100,7 @@ particle.position = Cesium.Cartesian3.add(particle.position, rainGravityScratch, particle.position); var distance = Cesium.Cartesian3.distance(scene.camera.position, particle.position); - if (distance > (rainRadius)) { + if (distance > rainRadius) { particle.endColor.alpha = 0.0; } else { particle.endColor.alpha = rainSystem.endColor.alpha / (distance / rainRadius + 0.1); @@ -124,7 +124,7 @@ scene.primitives.add(rainSystem); // button -Sandcastle.addToolbarButton("Recenter", recenterFunction); +Sandcastle.addToolbarButton("Reset Camera", resetCameraFunction); // drop down var options = [{ diff --git a/Apps/Sandcastle/gallery/Particle System.html b/Apps/Sandcastle/gallery/Particle System.html index 7eab28acbf21..ea86ed3e60f7 100644 --- a/Apps/Sandcastle/gallery/Particle System.html +++ b/Apps/Sandcastle/gallery/Particle System.html @@ -45,8 +45,8 @@ Rate - - + + @@ -61,16 +61,16 @@ Min Life - - + + Max Life - - + + @@ -161,10 +161,10 @@ viewer.timeline.zoomTo(start, stop); var viewModel = { - rate : 5.0, + emissionRate : 5.0, gravity : 0.0, - minimumLife : 1.0, - maximumLife : 1.0, + minimumParticleLife : 1.0, + maximumParticleLife : 1.0, minimumSpeed : 1.0, maximumSpeed : 4.0, startScale : 1.0, @@ -263,8 +263,8 @@ startScale : viewModel.startScale, endScale : viewModel.endScale, - minimumParticleLife : viewModel.minimumLife, - maximumParticleLife : viewModel.maximumLife, + minimumParticleLife : viewModel.minimumParticleLife, + maximumParticleLife : viewModel.maximumParticleLife, minimumSpeed : viewModel.minimumSpeed, maximumSpeed : viewModel.maximumSpeed, @@ -272,7 +272,7 @@ imageSize : new Cesium.Cartesian2(viewModel.particleSize, viewModel.particleSize), // Particles per second. - emissionRate : viewModel.rate, + emissionRate : viewModel.emissionRate, bursts : [ // these burst will occasionally sync to create a multicolored effect @@ -316,31 +316,29 @@ } }); -Cesium.knockout.getObservable(viewModel, 'rate').subscribe( +Cesium.knockout.getObservable(viewModel, 'emissionRate').subscribe( function(newValue) { - particleSystem.rate = parseFloat(newValue); + particleSystem.emissionRate = parseFloat(newValue); } ); Cesium.knockout.getObservable(viewModel, 'particleSize').subscribe( function(newValue) { var particleSize = parseFloat(newValue); - particleSystem.minimumWidth = particleSize; - particleSystem.maximumWidth = particleSize; - particleSystem.minimumHeight = particleSize; - particleSystem.maximumHeight = particleSize; + particleSystem.imageSize.x = particleSize; + particleSystem.imageSize.y = particleSize; } ); -Cesium.knockout.getObservable(viewModel, 'minimumLife').subscribe( +Cesium.knockout.getObservable(viewModel, 'minimumParticleLife').subscribe( function(newValue) { - particleSystem.minimumLife = parseFloat(newValue); + particleSystem.minimumParticleLife = parseFloat(newValue); } ); -Cesium.knockout.getObservable(viewModel, 'maximumLife').subscribe( +Cesium.knockout.getObservable(viewModel, 'maximumParticleLife').subscribe( function(newValue) { - particleSystem.maximumLife = parseFloat(newValue); + particleSystem.maximumParticleLife = parseFloat(newValue); } ); diff --git a/CHANGES.md b/CHANGES.md index 5bf407fbc1b7..2ac1613b0b99 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -9,6 +9,7 @@ Change Log * Any width and height variables in `ParticleSystem` will no longer be individual components. `ParticleSystem.minimumWidth` and `ParticleSystem.minimumHeight` will now be `ParticleSystem.minimumImageSize`, `ParticleSystem.maximumWidth` and `ParticleSystem.maximumHeight` will now be `ParticleSystem.maximumImageSize`, and `ParticleSystem.width` and `ParticleSystem.height` will now be `ParticleSystem.imageSize`. Use of the `minimumWidth`, `minimumHeight`, `maximumWidth`, `maximumHeight`, `width`, and `height` parameters is deprecated and will be removed in Cesium 1.46. ##### Additions :tada: +* Added `IonGeocoderService` and made it the default geocoding service for the `Geocoder` widget. * Added option `logarithmicDepthBuffer` to `Scene`. With this option there is typically a single frustum using logarithmic depth rendered. This increases performance by issuing less draw calls to the GPU and helps to avoid artifacts on the connection of two frustums. [#5851](https://github.com/AnalyticalGraphicsInc/cesium/pull/5851) * When a log depth buffer is supported, the frustum near and far planes default to `0.1` and `1e10` respectively. * Added `Math.log2` to compute the base 2 logarithm of a number. @@ -17,6 +18,7 @@ Change Log * Improved `MapboxImageryProvider` performance by 300% via `tiles.mapbox.com` subdomain switching. [#6426](https://github.com/AnalyticalGraphicsInc/cesium/issues/6426) * Added ability to invoke `sampleTerrain` from node.js to enable offline terrain sampling * Added more ParticleSystem Sandcastle examples for rocket and comet tails and weather. [#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) +* Added ability to invoke `sampleTerrain` from node.js to enable offline terrain sampling * Added color and scale attributes to the `ParticleSystem` class constructor. When defined the variables override startColor and endColor and startScale and endScale. [#6429](https://github.com/AnalyticalGraphicsInc/cesium/pull/6429) ##### Fixes :wrench: @@ -27,7 +29,10 @@ Change Log * `GroundPrimitive`s and `ClassificationPrimitive`s will become ready when `show` is `false`. [#6428](https://github.com/AnalyticalGraphicsInc/cesium/pull/6428) * Fix Firefox WebGL console warnings. [#5912](https://github.com/AnalyticalGraphicsInc/cesium/issues/5912) * Fix parsing Cesium.js in older browsers that do not support all TypedArray types. [#6396](https://github.com/AnalyticalGraphicsInc/cesium/pull/6396) -* Fix flicker when adding, removing, or modifiying entities. [#3945](https://github.com/AnalyticalGraphicsInc/cesium/issues/3945) +* Fixed a bug causing crashes when setting colors on un-pickable models. [$6442](https://github.com/AnalyticalGraphicsInc/cesium/issues/6442) +* Fix flicker when adding, removing, or modifying entities. [#3945](https://github.com/AnalyticalGraphicsInc/cesium/issues/3945) +* Fixed crash bug in PolylineCollection when a polyline was updated and removed at the same time. [#6455](https://github.com/AnalyticalGraphicsInc/cesium/pull/6455) +* Fixed Imagery Layers Texture Filters Sandcastle example. [#6472](https://github.com/AnalyticalGraphicsInc/cesium/pull/6472). ### 1.44 - 2018-04-02 diff --git a/CONTRIBUTORS.md b/CONTRIBUTORS.md index b298aa129217..0d1135678ed0 100644 --- a/CONTRIBUTORS.md +++ b/CONTRIBUTORS.md @@ -178,3 +178,4 @@ See [CONTRIBUTING.md](CONTRIBUTING.md) for details on how to contribute to Cesiu * [Stephen Wiseman](https://github.com/srwiseman) * [Gabriel Macario](https://github.com/gabriel-macario) * [Jonathan Puckey](https://github.com/puckey) +* [Mark Erikson](https://github.com/markerikson) diff --git a/Source/Core/IonGeocoderService.js b/Source/Core/IonGeocoderService.js new file mode 100644 index 000000000000..574b9f3da804 --- /dev/null +++ b/Source/Core/IonGeocoderService.js @@ -0,0 +1,64 @@ +define([ + './Check', + './defaultValue', + './defined', + './defineProperties', + './Ion', + './PeliasGeocoderService', + './Rectangle', + './Resource' +], function ( + Check, + defaultValue, + defined, + defineProperties, + Ion, + PeliasGeocoderService, + Rectangle, + Resource) { + 'use strict'; + + /** + * Provides geocoding through Cesium ion. + * @alias IonGeocoderService + * @constructor + * + * @param {Object} [options] Object with the following properties: + * @param {String} [options.accessToken=Ion.defaultAccessToken] The access token to use. + * @param {String|Resource} [options.server=Ion.defaultServer] The resource to the Cesium ion API server. + * + * @see Ion + */ + function IonGeocoderService(options) { + options = defaultValue(options, defaultValue.EMPTY_OBJECT); + + var accessToken = defaultValue(options.accessToken, Ion.defaultAccessToken); + var server = Resource.createIfNeeded(defaultValue(options.server, Ion.defaultServer)); + server.appendForwardSlash(); + + var searchEndpoint = server.getDerivedResource({ + url: 'v1/geocode' + }); + + if (defined(accessToken)) { + searchEndpoint.appendQueryParameters({ access_token: accessToken }); + } + + this._accessToken = accessToken; + this._server = server; + this._pelias = new PeliasGeocoderService(searchEndpoint); + } + + /** + * @function + * + * @param {String} query The query to be sent to the geocoder service + * @param {GeocodeType} [type=GeocodeType.SEARCH] The type of geocode to perform. + * @returns {Promise} + */ + IonGeocoderService.prototype.geocode = function (query, geocodeType) { + return this._pelias.geocode(query, geocodeType); + }; + + return IonGeocoderService; +}); diff --git a/Source/Core/PeliasGeocoderService.js b/Source/Core/PeliasGeocoderService.js index b357db862c8f..c8c23ebccfab 100644 --- a/Source/Core/PeliasGeocoderService.js +++ b/Source/Core/PeliasGeocoderService.js @@ -38,6 +38,7 @@ define([ //>>includeEnd('debug'); this._url = Resource.createIfNeeded(url); + this._url.appendForwardSlash(); } defineProperties(PeliasGeocoderService.prototype, { diff --git a/Source/Core/RequestScheduler.js b/Source/Core/RequestScheduler.js index 10ccb51b9a0e..6fd455b58007 100644 --- a/Source/Core/RequestScheduler.js +++ b/Source/Core/RequestScheduler.js @@ -2,6 +2,7 @@ define([ '../ThirdParty/Uri', '../ThirdParty/when', './Check', + './defaultValue', './defined', './defineProperties', './Event', @@ -13,6 +14,7 @@ define([ Uri, when, Check, + defaultValue, defined, defineProperties, Event, @@ -67,12 +69,21 @@ define([ RequestScheduler.maximumRequests = 50; /** - * The maximum number of simultaneous active requests per server. Un-throttled requests do not observe this limit. + * The maximum number of simultaneous active requests per server. Un-throttled requests or servers specifically + * listed in requestsByServer do not observe this limit. * @type {Number} * @default 6 */ RequestScheduler.maximumRequestsPerServer = 6; + /** + * A per serverKey list of overrides to use for throttling instead of maximumRequestsPerServer + */ + RequestScheduler.requestsByServer = { + 'api.cesium.com:443': 18, + 'assets.cesium.com:443': 18 + }; + /** * Specifies if the request scheduler should throttle incoming requests, or let the browser queue requests under its control. * @type {Boolean} @@ -146,7 +157,8 @@ define([ } function serverHasOpenSlots(serverKey) { - return numberOfActiveRequestsByServer[serverKey] < RequestScheduler.maximumRequestsPerServer; + var maxRequests = defaultValue(RequestScheduler.requestsByServer[serverKey], RequestScheduler.maximumRequestsPerServer); + return numberOfActiveRequestsByServer[serverKey] < maxRequests; } function issueRequest(request) { diff --git a/Source/Scene/IonImageryProvider.js b/Source/Scene/IonImageryProvider.js index 5f2e6524cf51..8176a85298b5 100644 --- a/Source/Scene/IonImageryProvider.js +++ b/Source/Scene/IonImageryProvider.js @@ -179,9 +179,6 @@ define([ that._tileCredits = endpoint.attributions.map(Credit.getIonCredit); - return imageryProvider; - }) - .then(function(imageryProvider) { imageryProvider.errorEvent.addEventListener(function(tileProviderError) { //Propagate the errorEvent but set the provider to this instance instead //of the inner instance. diff --git a/Source/Scene/Model.js b/Source/Scene/Model.js index 9aa1769fef2d..c53098437a4d 100644 --- a/Source/Scene/Model.js +++ b/Source/Scene/Model.js @@ -1973,7 +1973,7 @@ define([ /////////////////////////////////////////////////////////////////////////// // When building programs for the first time, do not include modifiers for clipping planes and color - // since this is the version of the program that will be cached. + // since this is the version of the program that will be cached for use with other Models. function createProgram(id, model, context) { var program = model._sourcePrograms[id]; var shaders = model._sourceShaders; @@ -4612,12 +4612,14 @@ define([ var pickProgram = rendererPickPrograms[programId]; nodeCommand.command.shaderProgram = renderProgram; - nodeCommand.pickCommand.shaderProgram = pickProgram; if (defined(nodeCommand.command2D)) { nodeCommand.command2D.shaderProgram = renderProgram; } - if (defined(nodeCommand.pickCommand2D)) { - nodeCommand.pickCommand2D.shaderProgram = pickProgram; + if (model.allowPicking) { + nodeCommand.pickCommand.shaderProgram = pickProgram; + if (defined(nodeCommand.pickCommand2D)) { + nodeCommand.pickCommand2D.shaderProgram = pickProgram; + } } } diff --git a/Source/Scene/PolylineCollection.js b/Source/Scene/PolylineCollection.js index 936744c6ae0b..3404930bb870 100644 --- a/Source/Scene/PolylineCollection.js +++ b/Source/Scene/PolylineCollection.js @@ -299,6 +299,12 @@ define([ PolylineCollection.prototype.remove = function(polyline) { if (this.contains(polyline)) { this._polylines[polyline._index] = undefined; // Removed later + + var polylineUpdateIndex = this._polylinesToUpdate.indexOf(polyline); + if (polylineUpdateIndex !== -1) { + this._polylinesToUpdate.splice(polylineUpdateIndex, 1); + } + this._polylinesRemoved = true; this._createVertexArray = true; this._createBatchTable = true; diff --git a/Source/Widgets/Geocoder/GeocoderViewModel.js b/Source/Widgets/Geocoder/GeocoderViewModel.js index a2c8c975be54..84d6c7714054 100644 --- a/Source/Widgets/Geocoder/GeocoderViewModel.js +++ b/Source/Widgets/Geocoder/GeocoderViewModel.js @@ -1,5 +1,5 @@ define([ - '../../Core/BingMapsGeocoderService', + '../../Core/IonGeocoderService', '../../Core/CartographicGeocoderService', '../../Core/defaultValue', '../../Core/defined', @@ -13,7 +13,7 @@ define([ '../createCommand', '../getElement' ], function( - BingMapsGeocoderService, + IonGeocoderService, CartographicGeocoderService, defaultValue, defined, @@ -52,7 +52,7 @@ define([ } else { this._geocoderServices = [ new CartographicGeocoderService(), - new BingMapsGeocoderService({scene: options.scene}) + new IonGeocoderService() ]; } diff --git a/Specs/Core/IonGeocoderServiceSpec.js b/Specs/Core/IonGeocoderServiceSpec.js new file mode 100644 index 000000000000..6ed001df423b --- /dev/null +++ b/Specs/Core/IonGeocoderServiceSpec.js @@ -0,0 +1,48 @@ +defineSuite([ + 'Core/IonGeocoderService', + 'Core/Ion', + 'Core/GeocodeType', + 'Core/Rectangle', + 'Core/Resource', + 'ThirdParty/when' + ], function( + IonGeocoderService, + Ion, + GeocodeType, + Rectangle, + Resource, + when) { + 'use strict'; + + it('Creates with default parameters', function() { + var service = new IonGeocoderService(); + + expect(service._accessToken).toEqual(Ion.defaultAccessToken); + expect(service._server.url).toEqual(Ion.defaultServer.url); + }); + + it('Creates with specified parameters', function() { + var accessToken = '123456'; + var server = 'http://not.ion.invalid/'; + + var service = new IonGeocoderService({ + accessToken: accessToken, + server: server + }); + + expect(service._accessToken).toEqual(accessToken); + expect(service._server.url).toEqual(server); + }); + + it('calls inner geocoder and returns result', function () { + var service = new IonGeocoderService(); + + var expectedResult = when.resolve(); + spyOn(service._pelias, 'geocode').and.returnValue(expectedResult); + + var query = 'some query'; + var result = service.geocode(query, GeocodeType.SEARCH); + expect(result).toBe(expectedResult); + expect(service._pelias.geocode).toHaveBeenCalledWith(query, GeocodeType.SEARCH); + }); +}); diff --git a/Specs/Core/IonResourceSpec.js b/Specs/Core/IonResourceSpec.js index c3238098d33b..0baf9e621260 100644 --- a/Specs/Core/IonResourceSpec.js +++ b/Specs/Core/IonResourceSpec.js @@ -98,7 +98,7 @@ defineSuite([ return testNonImageryExternalResource({ type: '3DTILES', externalType: '3DTILES', - options: { url: 'https://test.invalid/tileset.json' }, + options: { url: 'http://test.invalid/tileset.json' }, attributions: [] }); }); @@ -107,7 +107,7 @@ defineSuite([ return testNonImageryExternalResource({ type: 'TERRAIN', externalType: 'STK_TERRAIN_SERVER', - options: { url: 'https://test.invalid/world' }, + options: { url: 'http://test.invalid/world' }, attributions: [] }); }); @@ -116,7 +116,7 @@ defineSuite([ return testNonImageryExternalResource({ type: 'IMAGERY', externalType: 'URL_TEMPLATE', - url: 'https://test.invalid/world', + url: 'http://test.invalid/world', attributions: [] }) .then(fail) @@ -209,7 +209,7 @@ defineSuite([ var externalEndpoint = { type: '3DTILES', externalType: '3DTILES', - options: { url: 'https://test.invalid/tileset.json' }, + options: { url: 'http://test.invalid/tileset.json' }, attributions: [] }; var options = {}; @@ -233,7 +233,7 @@ defineSuite([ var externalEndpoint = { type: '3DTILES', externalType: '3DTILES', - options: { url: 'https://test.invalid/tileset.json' }, + options: { url: 'http://test.invalid/tileset.json' }, attributions: [] }; diff --git a/Specs/Core/RequestSchedulerSpec.js b/Specs/Core/RequestSchedulerSpec.js index fbdf872694c6..55f49fc1492e 100644 --- a/Specs/Core/RequestSchedulerSpec.js +++ b/Specs/Core/RequestSchedulerSpec.js @@ -13,21 +13,25 @@ defineSuite([ var originalMaximumRequests; var originalMaximumRequestsPerServer; var originalPriorityHeapLength; + var originalRequestsByServer; beforeAll(function() { originalMaximumRequests = RequestScheduler.maximumRequests; originalMaximumRequestsPerServer = RequestScheduler.maximumRequestsPerServer; originalPriorityHeapLength = RequestScheduler.priorityHeapLength; + originalRequestsByServer = RequestScheduler.requestsByServer; }); beforeEach(function() { RequestScheduler.clearForSpecs(); + RequestScheduler.requestsByServer = {}; }); afterEach(function() { RequestScheduler.maximumRequests = originalMaximumRequests; RequestScheduler.maximumRequestsPerServer = originalMaximumRequestsPerServer; RequestScheduler.priorityHeapLength = originalPriorityHeapLength; + RequestScheduler.requestsByServer = originalRequestsByServer; }); it('request throws when request is undefined', function() { @@ -61,13 +65,13 @@ defineSuite([ }); it('getServer with https', function() { - var server = RequestScheduler.getServerKey('https://foo.com/1'); - expect(server).toEqual('foo.com:443'); + var server = RequestScheduler.getServerKey('https://test.invalid/1'); + expect(server).toEqual('test.invalid:443'); }); it('getServer with http', function() { - var server = RequestScheduler.getServerKey('http://foo.com/1'); - expect(server).toEqual('foo.com:80'); + var server = RequestScheduler.getServerKey('http://test.invalid/1'); + expect(server).toEqual('test.invalid:80'); }); it('honors maximumRequests', function() { @@ -84,7 +88,7 @@ defineSuite([ function createRequest() { return new Request({ - url : 'http://foo.com/1', + url : 'http://test.invalid/1', requestFunction : requestFunction, throttle : true }); @@ -147,7 +151,7 @@ defineSuite([ return deferred.promise; } - var url = 'http://foo.com/1'; + var url = 'http://test.invalid/1'; var server = RequestScheduler.getServerKey(url); function createRequest() { @@ -216,7 +220,7 @@ defineSuite([ function createRequest(priority) { var request = new Request({ - url : 'http://foo.com/1', + url : 'http://test.invalid/1', requestFunction : requestFunction, throttle : true, priority : priority @@ -302,7 +306,7 @@ defineSuite([ }); it('request goes through immediately when throttle is false', function() { - var url = 'https://foo.com/1'; + var url = 'https://test.invalid/1'; testImmediateRequest(url, false); }); @@ -317,7 +321,7 @@ defineSuite([ var request = new Request({ throttle : true, - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction }); expect(request.state).toBe(RequestState.UNISSUED); @@ -342,7 +346,7 @@ defineSuite([ var request = new Request({ throttle : true, - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction }); @@ -373,7 +377,7 @@ defineSuite([ var request = new Request({ throttle : true, - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction, cancelFunction : cancelFunction }); @@ -409,7 +413,7 @@ defineSuite([ } var request = new Request({ - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction }); @@ -442,7 +446,7 @@ defineSuite([ function createRequest(priority) { return new Request({ throttle : true, - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : getRequestFunction(priority), priority : priority }); @@ -477,7 +481,7 @@ defineSuite([ function createRequest(priority) { return new Request({ throttle : true, - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction, priorityFunction : getPriorityFunction(priority) }); @@ -529,7 +533,7 @@ defineSuite([ function createRequest(priority) { return new Request({ throttle : true, - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction, priority : priority }); @@ -566,7 +570,7 @@ defineSuite([ function createRequest(throttle) { return new Request({ - url : 'http://foo.com/1', + url : 'http://test.invalid/1', requestFunction : requestFunction, throttle : throttle }); @@ -604,7 +608,7 @@ defineSuite([ function createRequest(throttleByServer) { return new Request({ - url : 'http://foo.com/1', + url : 'http://test.invalid/1', requestFunction : requestFunction, throttleByServer : throttleByServer }); @@ -637,7 +641,7 @@ defineSuite([ RequestScheduler.throttleRequests = true; var request = new Request({ throttle : true, - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction }); var promise = RequestScheduler.request(request); @@ -646,7 +650,7 @@ defineSuite([ RequestScheduler.throttleRequests = false; request = new Request({ throttle : true, - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction }); promise = RequestScheduler.request(request); @@ -669,7 +673,7 @@ defineSuite([ function createRequest() { return new Request({ - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction }); } @@ -708,7 +712,7 @@ defineSuite([ } var request = new Request({ - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction }); @@ -806,7 +810,7 @@ defineSuite([ } var request = new Request({ - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestFunction }); @@ -839,7 +843,7 @@ defineSuite([ } var requestToCancel = new Request({ - url : 'https://foo.com/1', + url : 'https://test.invalid/1', requestFunction : requestCancelFunction }); @@ -854,4 +858,29 @@ defineSuite([ cancelDeferred.resolve(); removeListenerCallback(); }); + + it('RequestScheduler.requestsByServer allows for custom maximum requests', function() { + var promise; + + RequestScheduler.requestsByServer['test.invalid:80'] = 23; + + for (var i = 0; i < 23; i++) { + promise = RequestScheduler.request(new Request({ + url: 'http://test.invalid/1', + throttle: true, + throttleByServer: true, + requestFunction: function() { return when.defer(); } + })); + RequestScheduler.update(); + expect(promise).toBeDefined(); + } + + promise = RequestScheduler.request(new Request({ + url: 'http://test.invalid/1', + throttle: true, + throttleByServer: true, + requestFunction: function() { return when.defer(); } + })); + expect(promise).toBeUndefined(); + }); }); diff --git a/Specs/Scene/IonImageryProviderSpec.js b/Specs/Scene/IonImageryProviderSpec.js index e8c05332492f..e6ff84baf2d2 100644 --- a/Specs/Scene/IonImageryProviderSpec.js +++ b/Specs/Scene/IonImageryProviderSpec.js @@ -39,7 +39,7 @@ defineSuite([ function createTestProvider(endpointData) { endpointData = defaultValue(endpointData, { type: 'IMAGERY', - url: 'https://test.invalid/layer', + url: 'http://test.invalid/layer', accessToken: 'not_really_a_refresh_token', attributions: [] }); @@ -74,7 +74,7 @@ defineSuite([ it('readyPromise rejects with non-imagery asset', function(done) { var provider = createTestProvider({ type: '3DTILES', - url: 'https://test.invalid/layer', + url: 'http://test.invalid/layer', accessToken: 'not_really_a_refresh_token', attributions: [] }); @@ -93,7 +93,7 @@ defineSuite([ var provider = createTestProvider({ type: 'IMAGERY', externalType: 'TUBELCANE', - options: { url: 'https://test.invalid/layer' }, + options: { url: 'http://test.invalid/layer' }, attributions: [] }); @@ -181,7 +181,7 @@ defineSuite([ var serverCredit = { text: 'Text', image: 'http://test.invalid/image', url: 'http://test.invalid/', collapsible: false }; var provider = createTestProvider({ type: 'IMAGERY', - url: 'https://test.invalid/layer', + url: 'http://test.invalid/layer', accessToken: 'not_really_a_refresh_token', attributions: [serverCredit] }); @@ -212,14 +212,14 @@ defineSuite([ spyOn(Resource._Implementations, 'loadAndExecuteScript').and.callFake(function(url, name, deffered) { deffered.resolve({ resourceSets: [{ resources: [{ imageUrl: '', imageUrlSubdomains: [], zoomMax: 0 }] }] }); }); - return testExternalImagery('ARCGIS_MAPSERVER', { url: 'https://test.invalid' }, ArcGisMapServerImageryProvider); + return testExternalImagery('ARCGIS_MAPSERVER', { url: 'http://test.invalid' }, ArcGisMapServerImageryProvider); }); it('createImageryProvider works with BING', function() { spyOn(Resource._Implementations, 'loadAndExecuteScript').and.callFake(function(url, name, deffered) { deffered.resolve({ resourceSets: [{ resources: [{ imageUrl: '', imageUrlSubdomains: [], zoomMax: 0 }] }] }); }); - return testExternalImagery('BING', { url: 'https://test.invalid' }, BingMapsImageryProvider); + return testExternalImagery('BING', { url: 'http://test.invalid' }, BingMapsImageryProvider); }); it('createImageryProvider works with GOOGLE_EARTH', function() { @@ -227,11 +227,11 @@ defineSuite([ deferred.resolve(JSON.stringify({ layers: [{ id: 0, version: '' }] })); }); - return testExternalImagery('GOOGLE_EARTH', { url: 'https://test.invalid', channel: 0 }, GoogleEarthEnterpriseMapsProvider); + return testExternalImagery('GOOGLE_EARTH', { url: 'http://test.invalid', channel: 0 }, GoogleEarthEnterpriseMapsProvider); }); it('createImageryProvider works with MAPBOX', function() { - return testExternalImagery('MAPBOX', { url: 'https://test.invalid', mapId: 1 }, MapboxImageryProvider); + return testExternalImagery('MAPBOX', { url: 'http://test.invalid', mapId: 1 }, MapboxImageryProvider); }); it('createImageryProvider works with SINGLE_TILE', function() { @@ -239,22 +239,22 @@ defineSuite([ deferred.resolve({}); }); - return testExternalImagery('SINGLE_TILE', { url: 'https://test.invalid' }, SingleTileImageryProvider); + return testExternalImagery('SINGLE_TILE', { url: 'http://test.invalid' }, SingleTileImageryProvider); }); it('createImageryProvider works with TMS', function() { - return testExternalImagery('TMS', { url: 'https://test.invalid' }, UrlTemplateImageryProvider); + return testExternalImagery('TMS', { url: 'http://test.invalid' }, UrlTemplateImageryProvider); }); it('createImageryProvider works with URL_TEMPLATE', function() { - return testExternalImagery('URL_TEMPLATE', { url: 'https://test.invalid' }, UrlTemplateImageryProvider); + return testExternalImagery('URL_TEMPLATE', { url: 'http://test.invalid' }, UrlTemplateImageryProvider); }); it('createImageryProvider works with WMS', function() { - return testExternalImagery('WMS', { url: 'https://test.invalid', layers: [] }, WebMapServiceImageryProvider); + return testExternalImagery('WMS', { url: 'http://test.invalid', layers: [] }, WebMapServiceImageryProvider); }); it('createImageryProvider works with WMTS', function() { - return testExternalImagery('WMTS', { url: 'https://test.invalid', layer: '', style: '', tileMatrixSetID: 1 }, WebMapTileServiceImageryProvider); + return testExternalImagery('WMTS', { url: 'http://test.invalid', layer: '', style: '', tileMatrixSetID: 1 }, WebMapTileServiceImageryProvider); }); }); diff --git a/Specs/Scene/PolylineCollectionSpec.js b/Specs/Scene/PolylineCollectionSpec.js index ffc2a741e6ea..dfd311ab0030 100644 --- a/Specs/Scene/PolylineCollectionSpec.js +++ b/Specs/Scene/PolylineCollectionSpec.js @@ -329,6 +329,20 @@ defineSuite([ expect(polylines.length).toEqual(0); }); + it('removes a polyline from the updated list when removed', function() { + var firstPolyline = polylines.add(); + var secondPolyline = polylines.add(); + + firstPolyline.width = 4; + secondPolyline.width = 5; + + expect(polylines._polylinesToUpdate.length).toEqual(2); + + polylines.remove(secondPolyline); + + expect(polylines._polylinesToUpdate.length).toEqual(1); + }); + it('can check if it contains a polyline', function() { var polyline = polylines.add(); From 091558a2b7dfbe8d3698bc363562e3ba5ad11a73 Mon Sep 17 00:00:00 2001 From: hanbollar Date: Tue, 24 Apr 2018 15:15:11 -0400 Subject: [PATCH 10/11] updates --- Apps/Sandcastle/gallery/Particle System Weather.html | 10 +++++----- Apps/Sandcastle/gallery/Particle System.html | 6 ++++-- CHANGES.md | 5 ----- 3 files changed, 9 insertions(+), 12 deletions(-) diff --git a/Apps/Sandcastle/gallery/Particle System Weather.html b/Apps/Sandcastle/gallery/Particle System Weather.html index 7035b4d507e1..b1886e906b54 100644 --- a/Apps/Sandcastle/gallery/Particle System Weather.html +++ b/Apps/Sandcastle/gallery/Particle System Weather.html @@ -75,7 +75,7 @@ emitter : new Cesium.SphereEmitter(snowRadius), startScale : 0.5, endScale : 1.0, - image : "../../SampleData/snowflake_particle.png", + image : '../../SampleData/snowflake_particle.png', emissionRate : 7000.0, startColor : Cesium.Color.WHITE.withAlpha(0.0), endColor : Cesium.Color.WHITE.withAlpha(1.0), @@ -114,7 +114,7 @@ emitter : new Cesium.SphereEmitter(rainRadius), startScale : 1.0, endScale : 0.0, - image : "../../SampleData/circular_particle.png", + image : '../../SampleData/circular_particle.png', emissionRate : 9000.0, startColor :new Cesium.Color(0.27, 0.5, 0.70, 0.0), endColor : new Cesium.Color(0.27, 0.5, 0.70, 0.98), @@ -124,11 +124,11 @@ scene.primitives.add(rainSystem); // button -Sandcastle.addToolbarButton("Reset Camera", resetCameraFunction); +Sandcastle.addToolbarButton('Reset Camera', resetCameraFunction); // drop down var options = [{ - text : "Snow", + text : 'Snow', onselect : function() { rainSystem.show = false; snowSystem.show = true; @@ -141,7 +141,7 @@ scene.fog.minimumBrightness = 0.8; } }, { - text : "Rain", + text : 'Rain', onselect : function() { rainSystem.show = true; snowSystem.show = false; diff --git a/Apps/Sandcastle/gallery/Particle System.html b/Apps/Sandcastle/gallery/Particle System.html index ea86ed3e60f7..58d25362742f 100644 --- a/Apps/Sandcastle/gallery/Particle System.html +++ b/Apps/Sandcastle/gallery/Particle System.html @@ -325,8 +325,10 @@ Cesium.knockout.getObservable(viewModel, 'particleSize').subscribe( function(newValue) { var particleSize = parseFloat(newValue); - particleSystem.imageSize.x = particleSize; - particleSystem.imageSize.y = particleSize; + particleSystem.minimumImageSize.x = particleSize; + particleSystem.minimumImageSize.y = particleSize; + particleSystem.maximumImageSize.x = particleSize; + particleSystem.maximumImageSize.y = particleSize; } ); diff --git a/CHANGES.md b/CHANGES.md index f49e19e5cd16..ad402267a05b 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -36,11 +36,6 @@ Change Log * Fixed crash bug in PolylineCollection when a polyline was updated and removed at the same time. [#6455](https://github.com/AnalyticalGraphicsInc/cesium/pull/6455) * Fixed Imagery Layers Texture Filters Sandcastle example. [#6472](https://github.com/AnalyticalGraphicsInc/cesium/pull/6472). -##### Deprecated :hourglass_flowing_sand: -* `Particle.size`, `ParticleSystem.rate`, `ParticleSystem.lifeTime`, `ParticleSystem.life`, `ParticleSystem.minimumLife`, and `ParticleSystem.maximumLife` have been renamed to `Particle.imageSize`, `ParticleSystem.emissionRate`, `ParticleSystem.lifetime`, `ParticleSystem.particleLife`, `ParticleSystem.minimumParticleLife`, and `ParticleSystem.maximumParticleLife`. Use of the `size`, `rate`, `lifeTime`, `life`, `minimumLife`, and `maximumLife` parameters is deprecated and will be removed in Cesium 1.46. -* `ParticleSystem.forces` array has been switched out for singular function `ParticleSystems.updateCallback`. Use of the `forces` parameter is deprecated and will be removed in Cesium 1.46. -* Any width and height variables in `ParticleSystem` will no longer be individual components. `ParticleSystem.minimumWidth` and `ParticleSystem.minimumHeight` will now be `ParticleSystem.minimumImageSize`, `ParticleSystem.maximumWidth` and `ParticleSystem.maximumHeight` will now be `ParticleSystem.maximumImageSize`, and `ParticleSystem.width` and `ParticleSystem.height` will now be `ParticleSystem.imageSize`. Use of the `minimumWidth`, `minimumHeight`, `maximumWidth`, `maximumHeight`, `width`, and `height` parameters is deprecated and will be removed in Cesium 1.46. - ### 1.44 - 2018-04-02 ##### Highlights :sparkler: From 5af2e5555d0baaf572aa8399304c4cba0d19a1ea Mon Sep 17 00:00:00 2001 From: Gabby Getz Date: Wed, 25 Apr 2018 11:04:33 -0400 Subject: [PATCH 11/11] Resolve CHANGES.md --- CHANGES.md | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index ad402267a05b..5c2b561044e2 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -21,6 +21,8 @@ Change Log * Added ability to invoke `sampleTerrain` from node.js to enable offline terrain sampling * Added more ParticleSystem Sandcastle examples for rocket and comet tails and weather. [#6375](https://github.com/AnalyticalGraphicsInc/cesium/pull/6375) * Added color and scale attributes to the `ParticleSystem` class constructor. When defined the variables override startColor and endColor and startScale and endScale. [#6429](https://github.com/AnalyticalGraphicsInc/cesium/pull/6429) +-* Added ability to invoke `sampleTerrain` from node.js to enable offline terrain sampling +-* Improved `MapboxImageryProvider` performance by 300% via `tiles.mapbox.com` subdomain switching. [#6426](https://github.com/AnalyticalGraphicsInc/cesium/issues/6426) ##### Fixes :wrench: * Fixed bugs in `TimeIntervalCollection.removeInterval`. [#6418](https://github.com/AnalyticalGraphicsInc/cesium/pull/6418). @@ -74,10 +76,6 @@ Change Log * `sourceType` specifies the type of data source if the URL doesn't have a known file extension. * `flyTo=false` optionally disables the automatic `flyTo` after loading the data source. * Added a multi-part CZML example to Sandcastle. [#6320](https://github.com/AnalyticalGraphicsInc/cesium/pull/6320) -* `Credit` has been modified to take an HTML string as the credit content [#6331](https://github.com/AnalyticalGraphicsInc/cesium/pull/6331) -* Added support for ordering in `DataSourceCollection` [#6316](https://github.com/AnalyticalGraphicsInc/cesium/pull/6316) - * All ground geometry from one `DataSource` will render in front of all ground geometry from another `DataSource` in the same collection with a lower index. - * Use `DataSourceCollection.raise`, `DataSourceCollection.lower`, `DataSourceCollection.raiseToTop` and `DataSourceCollection.lowerToBottom` functions to change the ordering of a `DataSource` in the collection. * Improved processing order of 3D tiles. [#6364](https://github.com/AnalyticalGraphicsInc/cesium/pull/6364) ##### Fixes :wrench: