diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Widgets/Images/ImageryProviders/stadiaAlidadeSmooth.png b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Widgets/Images/ImageryProviders/stadiaAlidadeSmooth.png new file mode 100644 index 0000000000000000000000000000000000000000..0520e17c706f233fccb3ce9e09f171949945e6ed Binary files /dev/null and b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Widgets/Images/ImageryProviders/stadiaAlidadeSmooth.png differ diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Widgets/Images/ImageryProviders/stadiaAlidadeSmoothDark.png b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Widgets/Images/ImageryProviders/stadiaAlidadeSmoothDark.png new file mode 100644 index 0000000000000000000000000000000000000000..1546494ca34e9e2c08d62f36d71aa89ad0aad762 Binary files /dev/null and b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Widgets/Images/ImageryProviders/stadiaAlidadeSmoothDark.png differ diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-3ICSQSQA.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-3ICSQSQA.js new file mode 100644 index 0000000000000000000000000000000000000000..576893581f7a37fd4b8c6a9ef2513d250cb20369 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-3ICSQSQA.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as C}from"./chunk-U7I5YLBQ.js";import{a as P}from"./chunk-RUSF25XT.js";import{a as O,b as L}from"./chunk-C6Y3PRDH.js";import{a as y}from"./chunk-LI57NJAL.js";import{e as S}from"./chunk-ODUTJJQ5.js";var T={};function b(a,e){return y.equalsEpsilon(a.latitude,e.latitude,y.EPSILON10)&&y.equalsEpsilon(a.longitude,e.longitude,y.EPSILON10)}var q=new L,v=new L;function w(a,e,i,h){e=P(e,O.equalsEpsilon);let p=e.length;if(p<2)return;let E=S(h),u=S(i),l=new Array(p),g=new Array(p),r=new Array(p),d=e[0];l[0]=d;let f=a.cartesianToCartographic(d,q);u&&(f.height=i[0]),g[0]=f.height,E?r[0]=h[0]:r[0]=0;let o=g[0],m=r[0],t=o===m,n=1;for(let c=1;c=0?R.longitude:R.longitude+E.TWO_PI;p=Math.min(p,m),O=Math.max(O,m)}return y-c>O-p&&(c=p,y=O,y>E.PI&&(y=y-E.TWO_PI),c>E.PI&&(c=c-E.TWO_PI)),M(o)?(o.west=c,o.south=e,o.east=y,o.north=h,o):new q(c,e,y,h)};q.fromCartesianArray=function(n,o,c){f.defined("cartesians",n),o=T(o,dn.WGS84);let y=Number.MAX_VALUE,p=-Number.MAX_VALUE,O=Number.MAX_VALUE,e=-Number.MAX_VALUE,h=Number.MAX_VALUE,d=-Number.MAX_VALUE;for(let j=0,R=n.length;j=0?m.longitude:m.longitude+E.TWO_PI;O=Math.min(O,A),e=Math.max(e,A)}return p-y>e-O&&(y=O,p=e,p>E.PI&&(p=p-E.TWO_PI),y>E.PI&&(y=y-E.TWO_PI)),M(c)?(c.west=y,c.south=h,c.east=p,c.north=d,c):new q(y,h,p,d)};q.clone=function(n,o){if(M(n))return M(o)?(o.west=n.west,o.south=n.south,o.east=n.east,o.north=n.north,o):new q(n.west,n.south,n.east,n.north)};q.equalsEpsilon=function(n,o,c){return c=T(c,0),n===o||M(n)&&M(o)&&Math.abs(n.west-o.west)<=c&&Math.abs(n.south-o.south)<=c&&Math.abs(n.east-o.east)<=c&&Math.abs(n.north-o.north)<=c};q.prototype.clone=function(n){return q.clone(this,n)};q.prototype.equals=function(n){return q.equals(this,n)};q.equals=function(n,o){return n===o||M(n)&&M(o)&&n.west===o.west&&n.south===o.south&&n.east===o.east&&n.north===o.north};q.prototype.equalsEpsilon=function(n,o){return q.equalsEpsilon(this,n,o)};q.validate=function(n){f.typeOf.object("rectangle",n);let o=n.north;f.typeOf.number.greaterThanOrEquals("north",o,-E.PI_OVER_TWO),f.typeOf.number.lessThanOrEquals("north",o,E.PI_OVER_TWO);let c=n.south;f.typeOf.number.greaterThanOrEquals("south",c,-E.PI_OVER_TWO),f.typeOf.number.lessThanOrEquals("south",c,E.PI_OVER_TWO);let y=n.west;f.typeOf.number.greaterThanOrEquals("west",y,-Math.PI),f.typeOf.number.lessThanOrEquals("west",y,Math.PI);let p=n.east;f.typeOf.number.greaterThanOrEquals("east",p,-Math.PI),f.typeOf.number.lessThanOrEquals("east",p,Math.PI)};q.southwest=function(n,o){return f.typeOf.object("rectangle",n),M(o)?(o.longitude=n.west,o.latitude=n.south,o.height=0,o):new x(n.west,n.south)};q.northwest=function(n,o){return f.typeOf.object("rectangle",n),M(o)?(o.longitude=n.west,o.latitude=n.north,o.height=0,o):new x(n.west,n.north)};q.northeast=function(n,o){return f.typeOf.object("rectangle",n),M(o)?(o.longitude=n.east,o.latitude=n.north,o.height=0,o):new x(n.east,n.north)};q.southeast=function(n,o){return f.typeOf.object("rectangle",n),M(o)?(o.longitude=n.east,o.latitude=n.south,o.height=0,o):new x(n.east,n.south)};q.center=function(n,o){f.typeOf.object("rectangle",n);let c=n.east,y=n.west;c0?y+=E.TWO_PI:O0&&(O+=E.TWO_PI),y=R))return M(c)?(c.west=h,c.south=j,c.east=d,c.north=R,c):new q(h,j,d,R)};q.simpleIntersection=function(n,o,c){f.typeOf.object("rectangle",n),f.typeOf.object("otherRectangle",o);let y=Math.max(n.west,o.west),p=Math.max(n.south,o.south),O=Math.min(n.east,o.east),e=Math.min(n.north,o.north);if(!(p>=e||y>=O))return M(c)?(c.west=y,c.south=p,c.east=O,c.north=e,c):new q(y,p,O,e)};q.union=function(n,o,c){f.typeOf.object("rectangle",n),f.typeOf.object("otherRectangle",o),M(c)||(c=new q);let y=n.east,p=n.west,O=o.east,e=o.west;y0?y+=E.TWO_PI:O0&&(O+=E.TWO_PI),yp||E.equalsEpsilon(c,p,E.EPSILON14))&&(c=n.south&&y<=n.north};var Jn=new x;q.subsample=function(n,o,c,y){f.typeOf.object("rectangle",n),o=T(o,dn.WGS84),c=T(c,0),M(y)||(y=[]);let p=0,O=n.north,e=n.south,h=n.east,d=n.west,j=Jn;j.height=c,j.longitude=d,j.latitude=O,y[p]=o.cartographicToCartesian(j,y[p]),p++,j.longitude=h,y[p]=o.cartographicToCartesian(j,y[p]),p++,j.latitude=e,y[p]=o.cartographicToCartesian(j,y[p]),p++,j.longitude=d,y[p]=o.cartographicToCartesian(j,y[p]),p++,O<0?j.latitude=O:e>0?j.latitude=e:j.latitude=0;for(let R=1;R<8;++R)j.longitude=-Math.PI+R*E.PI_OVER_TWO,q.contains(n,j)&&(y[p]=o.cartographicToCartesian(j,y[p]),p++);return j.latitude===0&&(j.longitude=d,y[p]=o.cartographicToCartesian(j,y[p]),p++,j.longitude=h,y[p]=o.cartographicToCartesian(j,y[p]),p++),y.length=p,y};q.subsection=function(n,o,c,y,p,O){if(f.typeOf.object("rectangle",n),f.typeOf.number.greaterThanOrEquals("westLerp",o,0),f.typeOf.number.lessThanOrEquals("westLerp",o,1),f.typeOf.number.greaterThanOrEquals("southLerp",c,0),f.typeOf.number.lessThanOrEquals("southLerp",c,1),f.typeOf.number.greaterThanOrEquals("eastLerp",y,0),f.typeOf.number.lessThanOrEquals("eastLerp",y,1),f.typeOf.number.greaterThanOrEquals("northLerp",p,0),f.typeOf.number.lessThanOrEquals("northLerp",p,1),f.typeOf.number.lessThanOrEquals("westLerp",o,y),f.typeOf.number.lessThanOrEquals("southLerp",c,p),M(O)||(O=new q),n.west<=n.east){let h=n.east-n.west;O.west=n.west+o*h,O.east=n.west+y*h}else{let h=E.TWO_PI+n.east-n.west;O.west=E.negativePiToPi(n.west+o*h),O.east=E.negativePiToPi(n.west+y*h)}let e=n.north-n.south;return O.south=n.south+c*e,O.north=n.south+p*e,o===1&&(O.west=n.east),y===1&&(O.east=n.east),c===1&&(O.south=n.north),p===1&&(O.north=n.north),O};q.MAX_VALUE=Object.freeze(new q(-Math.PI,-E.PI_OVER_TWO,Math.PI,E.PI_OVER_TWO));var mo=q;function w(n,o){this.x=T(n,0),this.y=T(o,0)}w.fromElements=function(n,o,c){return M(c)?(c.x=n,c.y=o,c):new w(n,o)};w.clone=function(n,o){if(M(n))return M(o)?(o.x=n.x,o.y=n.y,o):new w(n.x,n.y)};w.fromCartesian3=w.clone;w.fromCartesian4=w.clone;w.packedLength=2;w.pack=function(n,o,c){return f.typeOf.object("value",n),f.defined("array",o),c=T(c,0),o[c++]=n.x,o[c]=n.y,o};w.unpack=function(n,o,c){return f.defined("array",n),o=T(o,0),M(c)||(c=new w),c.x=n[o++],c.y=n[o],c};w.packArray=function(n,o){f.defined("array",n);let c=n.length,y=c*2;if(!M(o))o=new Array(y);else{if(!Array.isArray(o)&&o.length!==y)throw new H("If result is a typed array, it must have exactly array.length * 2 elements");o.length!==y&&(o.length=y)}for(let p=0;pe.right)throw new w("right must be greater than left.");if(e.bottom>e.top)throw new w("top must be greater than bottom.");if(e.near<=0||e.near>e.far)throw new w("near must be greater than zero and less than far.");e._left=e.left,e._right=e.right,e._top=e.top,e._bottom=e.bottom,e._near=e.near,e._far=e.far,e._orthographicMatrix=O.computeOrthographicOffCenter(e.left,e.right,e.bottom,e.top,e.near,e.far,e._orthographicMatrix)}}Object.defineProperties(k.prototype,{projectionMatrix:{get:function(){return ce(this),this._orthographicMatrix}}});var me=new r,ye=new r,ge=new r,ee=new r;k.prototype.computeCullingVolume=function(e,t,n){if(!a(e))throw new w("position is required.");if(!a(t))throw new w("direction is required.");if(!a(n))throw new w("up is required.");let f=this._cullingVolume.planes,p=this.top,_=this.bottom,s=this.right,y=this.left,i=this.near,c=this.far,d=r.cross(t,n,me);r.normalize(d,d);let g=ye;r.multiplyByScalar(t,i,g),r.add(e,g,g);let l=ge;r.multiplyByScalar(d,y,l),r.add(g,l,l);let o=f[0];return a(o)||(o=f[0]=new b),o.x=d.x,o.y=d.y,o.z=d.z,o.w=-r.dot(d,l),r.multiplyByScalar(d,s,l),r.add(g,l,l),o=f[1],a(o)||(o=f[1]=new b),o.x=-d.x,o.y=-d.y,o.z=-d.z,o.w=-r.dot(r.negate(d,ee),l),r.multiplyByScalar(n,_,l),r.add(g,l,l),o=f[2],a(o)||(o=f[2]=new b),o.x=n.x,o.y=n.y,o.z=n.z,o.w=-r.dot(n,l),r.multiplyByScalar(n,p,l),r.add(g,l,l),o=f[3],a(o)||(o=f[3]=new b),o.x=-n.x,o.y=-n.y,o.z=-n.z,o.w=-r.dot(r.negate(n,ee),l),o=f[4],a(o)||(o=f[4]=new b),o.x=t.x,o.y=t.y,o.z=t.z,o.w=-r.dot(t,g),r.multiplyByScalar(t,c,l),r.add(e,l,l),o=f[5],a(o)||(o=f[5]=new b),o.x=-t.x,o.y=-t.y,o.z=-t.z,o.w=-r.dot(r.negate(t,ee),l),this._cullingVolume};k.prototype.getPixelDimensions=function(e,t,n,f,p){if(ce(this),!a(e)||!a(t))throw new w("Both drawingBufferWidth and drawingBufferHeight are required.");if(e<=0)throw new w("drawingBufferWidth must be greater than zero.");if(t<=0)throw new w("drawingBufferHeight must be greater than zero.");if(!a(n))throw new w("distance is required.");if(!a(f))throw new w("pixelRatio is required.");if(f<=0)throw new w("pixelRatio must be greater than zero.");if(!a(p))throw new w("A result object is required.");let _=this.right-this.left,s=this.top-this.bottom,y=f*_/e,i=f*s/t;return p.x=y,p.y=i,p};k.prototype.clone=function(e){return a(e)||(e=new k),e.left=this.left,e.right=this.right,e.top=this.top,e.bottom=this.bottom,e.near=this.near,e.far=this.far,e._left=void 0,e._right=void 0,e._top=void 0,e._bottom=void 0,e._near=void 0,e._far=void 0,e};k.prototype.equals=function(e){return a(e)&&e instanceof k&&this.right===e.right&&this.left===e.left&&this.top===e.top&&this.bottom===e.bottom&&this.near===e.near&&this.far===e.far};k.prototype.equalsEpsilon=function(e,t,n){return e===this||a(e)&&e instanceof k&&P.equalsEpsilon(this.right,e.right,t,n)&&P.equalsEpsilon(this.left,e.left,t,n)&&P.equalsEpsilon(this.top,e.top,t,n)&&P.equalsEpsilon(this.bottom,e.bottom,t,n)&&P.equalsEpsilon(this.near,e.near,t,n)&&P.equalsEpsilon(this.far,e.far,t,n)};var he=k;function v(e){e=m(e,m.EMPTY_OBJECT),this._offCenterFrustum=new he,this.width=e.width,this._width=void 0,this.aspectRatio=e.aspectRatio,this._aspectRatio=void 0,this.near=m(e.near,1),this._near=this.near,this.far=m(e.far,5e8),this._far=this.far}v.packedLength=4;v.pack=function(e,t,n){return F.typeOf.object("value",e),F.defined("array",t),n=m(n,0),t[n++]=e.width,t[n++]=e.aspectRatio,t[n++]=e.near,t[n]=e.far,t};v.unpack=function(e,t,n){return F.defined("array",e),t=m(t,0),a(n)||(n=new v),n.width=e[t++],n.aspectRatio=e[t++],n.near=e[t++],n.far=e[t],n};function j(e){if(!a(e.width)||!a(e.aspectRatio)||!a(e.near)||!a(e.far))throw new w("width, aspectRatio, near, or far parameters are not set.");let t=e._offCenterFrustum;if(e.width!==e._width||e.aspectRatio!==e._aspectRatio||e.near!==e._near||e.far!==e._far){if(e.aspectRatio<0)throw new w("aspectRatio must be positive.");if(e.near<0||e.near>e.far)throw new w("near must be greater than zero and less than far.");e._aspectRatio=e.aspectRatio,e._width=e.width,e._near=e.near,e._far=e.far;let n=1/e.aspectRatio;t.right=e.width*.5,t.left=-t.right,t.top=n*t.right,t.bottom=-t.top,t.near=e.near,t.far=e.far}}Object.defineProperties(v.prototype,{projectionMatrix:{get:function(){return j(this),this._offCenterFrustum.projectionMatrix}},offCenterFrustum:{get:function(){return j(this),this._offCenterFrustum}}});v.prototype.computeCullingVolume=function(e,t,n){return j(this),this._offCenterFrustum.computeCullingVolume(e,t,n)};v.prototype.getPixelDimensions=function(e,t,n,f,p){return j(this),this._offCenterFrustum.getPixelDimensions(e,t,n,f,p)};v.prototype.clone=function(e){return a(e)||(e=new v),e.aspectRatio=this.aspectRatio,e.width=this.width,e.near=this.near,e.far=this.far,e._aspectRatio=void 0,e._width=void 0,e._near=void 0,e._far=void 0,this._offCenterFrustum.clone(e._offCenterFrustum),e};v.prototype.equals=function(e){return!a(e)||!(e instanceof v)?!1:(j(this),j(e),this.width===e.width&&this.aspectRatio===e.aspectRatio&&this._offCenterFrustum.equals(e._offCenterFrustum))};v.prototype.equalsEpsilon=function(e,t,n){return!a(e)||!(e instanceof v)?!1:(j(this),j(e),P.equalsEpsilon(this.width,e.width,t,n)&&P.equalsEpsilon(this.aspectRatio,e.aspectRatio,t,n)&&this._offCenterFrustum.equalsEpsilon(e._offCenterFrustum,t,n))};var B=v;function S(e){e=m(e,m.EMPTY_OBJECT),this.left=e.left,this._left=void 0,this.right=e.right,this._right=void 0,this.top=e.top,this._top=void 0,this.bottom=e.bottom,this._bottom=void 0,this.near=m(e.near,1),this._near=this.near,this.far=m(e.far,5e8),this._far=this.far,this._cullingVolume=new $,this._perspectiveMatrix=new O,this._infinitePerspective=new O}function te(e){if(!a(e.right)||!a(e.left)||!a(e.top)||!a(e.bottom)||!a(e.near)||!a(e.far))throw new w("right, left, top, bottom, near, or far parameters are not set.");let t=e.top,n=e.bottom,f=e.right,p=e.left,_=e.near,s=e.far;if(t!==e._top||n!==e._bottom||p!==e._left||f!==e._right||_!==e._near||s!==e._far){if(e.near<=0||e.near>e.far)throw new w("near must be greater than zero and less than far.");e._left=p,e._right=f,e._top=t,e._bottom=n,e._near=_,e._far=s,e._perspectiveMatrix=O.computePerspectiveOffCenter(p,f,n,t,_,s,e._perspectiveMatrix),e._infinitePerspective=O.computeInfinitePerspectiveOffCenter(p,f,n,t,_,e._infinitePerspective)}}Object.defineProperties(S.prototype,{projectionMatrix:{get:function(){return te(this),this._perspectiveMatrix}},infiniteProjectionMatrix:{get:function(){return te(this),this._infinitePerspective}}});var Ce=new r,be=new r,Pe=new r,Oe=new r;S.prototype.computeCullingVolume=function(e,t,n){if(!a(e))throw new w("position is required.");if(!a(t))throw new w("direction is required.");if(!a(n))throw new w("up is required.");let f=this._cullingVolume.planes,p=this.top,_=this.bottom,s=this.right,y=this.left,i=this.near,c=this.far,d=r.cross(t,n,Ce),g=be;r.multiplyByScalar(t,i,g),r.add(e,g,g);let l=Pe;r.multiplyByScalar(t,c,l),r.add(e,l,l);let o=Oe;r.multiplyByScalar(d,y,o),r.add(g,o,o),r.subtract(o,e,o),r.normalize(o,o),r.cross(o,n,o),r.normalize(o,o);let h=f[0];return a(h)||(h=f[0]=new b),h.x=o.x,h.y=o.y,h.z=o.z,h.w=-r.dot(o,e),r.multiplyByScalar(d,s,o),r.add(g,o,o),r.subtract(o,e,o),r.cross(n,o,o),r.normalize(o,o),h=f[1],a(h)||(h=f[1]=new b),h.x=o.x,h.y=o.y,h.z=o.z,h.w=-r.dot(o,e),r.multiplyByScalar(n,_,o),r.add(g,o,o),r.subtract(o,e,o),r.cross(d,o,o),r.normalize(o,o),h=f[2],a(h)||(h=f[2]=new b),h.x=o.x,h.y=o.y,h.z=o.z,h.w=-r.dot(o,e),r.multiplyByScalar(n,p,o),r.add(g,o,o),r.subtract(o,e,o),r.cross(o,d,o),r.normalize(o,o),h=f[3],a(h)||(h=f[3]=new b),h.x=o.x,h.y=o.y,h.z=o.z,h.w=-r.dot(o,e),h=f[4],a(h)||(h=f[4]=new b),h.x=t.x,h.y=t.y,h.z=t.z,h.w=-r.dot(t,g),r.negate(t,o),h=f[5],a(h)||(h=f[5]=new b),h.x=o.x,h.y=o.y,h.z=o.z,h.w=-r.dot(o,l),this._cullingVolume};S.prototype.getPixelDimensions=function(e,t,n,f,p){if(te(this),!a(e)||!a(t))throw new w("Both drawingBufferWidth and drawingBufferHeight are required.");if(e<=0)throw new w("drawingBufferWidth must be greater than zero.");if(t<=0)throw new w("drawingBufferHeight must be greater than zero.");if(!a(n))throw new w("distance is required.");if(!a(f))throw new w("pixelRatio is required");if(f<=0)throw new w("pixelRatio must be greater than zero.");if(!a(p))throw new w("A result object is required.");let _=1/this.near,s=this.top*_,y=2*f*n*s/t;s=this.right*_;let i=2*f*n*s/e;return p.x=i,p.y=y,p};S.prototype.clone=function(e){return a(e)||(e=new S),e.right=this.right,e.left=this.left,e.top=this.top,e.bottom=this.bottom,e.near=this.near,e.far=this.far,e._left=void 0,e._right=void 0,e._top=void 0,e._bottom=void 0,e._near=void 0,e._far=void 0,e};S.prototype.equals=function(e){return a(e)&&e instanceof S&&this.right===e.right&&this.left===e.left&&this.top===e.top&&this.bottom===e.bottom&&this.near===e.near&&this.far===e.far};S.prototype.equalsEpsilon=function(e,t,n){return e===this||a(e)&&e instanceof S&&P.equalsEpsilon(this.right,e.right,t,n)&&P.equalsEpsilon(this.left,e.left,t,n)&&P.equalsEpsilon(this.top,e.top,t,n)&&P.equalsEpsilon(this.bottom,e.bottom,t,n)&&P.equalsEpsilon(this.near,e.near,t,n)&&P.equalsEpsilon(this.far,e.far,t,n)};var pe=S;function R(e){e=m(e,m.EMPTY_OBJECT),this._offCenterFrustum=new pe,this.fov=e.fov,this._fov=void 0,this._fovy=void 0,this._sseDenominator=void 0,this.aspectRatio=e.aspectRatio,this._aspectRatio=void 0,this.near=m(e.near,1),this._near=this.near,this.far=m(e.far,5e8),this._far=this.far,this.xOffset=m(e.xOffset,0),this._xOffset=this.xOffset,this.yOffset=m(e.yOffset,0),this._yOffset=this.yOffset}R.packedLength=6;R.pack=function(e,t,n){return F.typeOf.object("value",e),F.defined("array",t),n=m(n,0),t[n++]=e.fov,t[n++]=e.aspectRatio,t[n++]=e.near,t[n++]=e.far,t[n++]=e.xOffset,t[n]=e.yOffset,t};R.unpack=function(e,t,n){return F.defined("array",e),t=m(t,0),a(n)||(n=new R),n.fov=e[t++],n.aspectRatio=e[t++],n.near=e[t++],n.far=e[t++],n.xOffset=e[t++],n.yOffset=e[t],n};function T(e){if(!a(e.fov)||!a(e.aspectRatio)||!a(e.near)||!a(e.far))throw new w("fov, aspectRatio, near, or far parameters are not set.");let t=e._offCenterFrustum;if(e.fov!==e._fov||e.aspectRatio!==e._aspectRatio||e.near!==e._near||e.far!==e._far||e.xOffset!==e._xOffset||e.yOffset!==e._yOffset){if(e.fov<0||e.fov>=Math.PI)throw new w("fov must be in the range [0, PI).");if(e.aspectRatio<0)throw new w("aspectRatio must be positive.");if(e.near<0||e.near>e.far)throw new w("near must be greater than zero and less than far.");e._aspectRatio=e.aspectRatio,e._fov=e.fov,e._fovy=e.aspectRatio<=1?e.fov:Math.atan(Math.tan(e.fov*.5)/e.aspectRatio)*2,e._near=e.near,e._far=e.far,e._sseDenominator=2*Math.tan(.5*e._fovy),e._xOffset=e.xOffset,e._yOffset=e.yOffset,t.top=e.near*Math.tan(.5*e._fovy),t.bottom=-t.top,t.right=e.aspectRatio*t.top,t.left=-t.right,t.near=e.near,t.far=e.far,t.right+=e.xOffset,t.left+=e.xOffset,t.top+=e.yOffset,t.bottom+=e.yOffset}}Object.defineProperties(R.prototype,{projectionMatrix:{get:function(){return T(this),this._offCenterFrustum.projectionMatrix}},infiniteProjectionMatrix:{get:function(){return T(this),this._offCenterFrustum.infiniteProjectionMatrix}},fovy:{get:function(){return T(this),this._fovy}},sseDenominator:{get:function(){return T(this),this._sseDenominator}},offCenterFrustum:{get:function(){return T(this),this._offCenterFrustum}}});R.prototype.computeCullingVolume=function(e,t,n){return T(this),this._offCenterFrustum.computeCullingVolume(e,t,n)};R.prototype.getPixelDimensions=function(e,t,n,f,p){return T(this),this._offCenterFrustum.getPixelDimensions(e,t,n,f,p)};R.prototype.clone=function(e){return a(e)||(e=new R),e.aspectRatio=this.aspectRatio,e.fov=this.fov,e.near=this.near,e.far=this.far,e._aspectRatio=void 0,e._fov=void 0,e._near=void 0,e._far=void 0,this._offCenterFrustum.clone(e._offCenterFrustum),e};R.prototype.equals=function(e){return!a(e)||!(e instanceof R)?!1:(T(this),T(e),this.fov===e.fov&&this.aspectRatio===e.aspectRatio&&this._offCenterFrustum.equals(e._offCenterFrustum))};R.prototype.equalsEpsilon=function(e,t,n){return!a(e)||!(e instanceof R)?!1:(T(this),T(e),P.equalsEpsilon(this.fov,e.fov,t,n)&&P.equalsEpsilon(this.aspectRatio,e.aspectRatio,t,n)&&this._offCenterFrustum.equalsEpsilon(e._offCenterFrustum,t,n))};var L=R;var I=0,Fe=1;function Y(e){F.typeOf.object("options",e),F.typeOf.object("options.frustum",e.frustum),F.typeOf.object("options.origin",e.origin),F.typeOf.object("options.orientation",e.orientation);let t=e.frustum,n=e.orientation,f=e.origin,p=m(e.vertexFormat,A.DEFAULT),_=m(e._drawNearPlane,!0),s,y;t instanceof L?(s=I,y=L.packedLength):t instanceof B&&(s=Fe,y=B.packedLength),this._frustumType=s,this._frustum=t.clone(),this._origin=r.clone(f),this._orientation=N.clone(n),this._drawNearPlane=_,this._vertexFormat=p,this._workerName="createFrustumGeometry",this.packedLength=2+y+r.packedLength+N.packedLength+A.packedLength}Y.pack=function(e,t,n){F.typeOf.object("value",e),F.defined("array",t),n=m(n,0);let f=e._frustumType,p=e._frustum;return t[n++]=f,f===I?(L.pack(p,t,n),n+=L.packedLength):(B.pack(p,t,n),n+=B.packedLength),r.pack(e._origin,t,n),n+=r.packedLength,N.pack(e._orientation,t,n),n+=N.packedLength,A.pack(e._vertexFormat,t,n),n+=A.packedLength,t[n]=e._drawNearPlane?1:0,t};var xe=new L,ze=new B,ve=new N,Re=new r,qe=new A;Y.unpack=function(e,t,n){F.defined("array",e),t=m(t,0);let f=e[t++],p;f===I?(p=L.unpack(e,t,xe),t+=L.packedLength):(p=B.unpack(e,t,ze),t+=B.packedLength);let _=r.unpack(e,t,Re);t+=r.packedLength;let s=N.unpack(e,t,ve);t+=N.packedLength;let y=A.unpack(e,t,qe);t+=A.packedLength;let i=e[t]===1;if(!a(n))return new Y({frustum:p,origin:_,orientation:s,vertexFormat:y,_drawNearPlane:i});let c=f===n._frustumType?n._frustum:void 0;return n._frustum=p.clone(c),n._frustumType=f,n._origin=r.clone(_,n._origin),n._orientation=N.clone(s,n._orientation),n._vertexFormat=A.clone(y,n._vertexFormat),n._drawNearPlane=i,n};function W(e,t,n,f,p,_,s,y){let i=e/3*2;for(let c=0;c<4;++c)a(t)&&(t[e]=_.x,t[e+1]=_.y,t[e+2]=_.z),a(n)&&(n[e]=s.x,n[e+1]=s.y,n[e+2]=s.z),a(f)&&(f[e]=y.x,f[e+1]=y.y,f[e+2]=y.z),e+=3;p[i]=0,p[i+1]=0,p[i+2]=1,p[i+3]=0,p[i+4]=1,p[i+5]=1,p[i+6]=0,p[i+7]=1}var Te=new u,Me=new O,ne=new O,se=new r,le=new r,we=new r,ke=new r,Se=new r,De=new r,U=new Array(3),Z=new Array(4);Z[0]=new b(-1,-1,1,1);Z[1]=new b(1,-1,1,1);Z[2]=new b(1,1,1,1);Z[3]=new b(-1,1,1,1);var _e=new Array(4);for(let e=0;e<4;++e)_e[e]=new b;Y._computeNearFarPlanes=function(e,t,n,f,p,_,s,y){let i=u.fromQuaternion(t,Te),c=m(_,se),d=m(s,le),g=m(y,we);c=u.getColumn(i,0,c),d=u.getColumn(i,1,d),g=u.getColumn(i,2,g),r.normalize(c,c),r.normalize(d,d),r.normalize(g,g),r.negate(c,c);let l=O.computeView(e,g,d,c,Me),o,h,M=f.projectionMatrix;if(n===I){let x=O.multiply(M,l,ne);h=O.inverse(x,ne)}else o=O.inverseTransformation(l,ne);a(h)?(U[0]=f.near,U[1]=f.far):(U[0]=0,U[1]=f.near,U[2]=f.far);for(let x=0;x<2;++x)for(let z=0;z<4;++z){let C=b.clone(Z[z],_e[z]);if(a(h)){C=O.multiplyByVector(h,C,C);let D=1/C.w;r.multiplyByScalar(C,D,C),r.subtract(C,e,C),r.normalize(C,C);let K=r.dot(g,C);r.multiplyByScalar(C,U[x]/K,C),r.add(C,e,C)}else{let D=f.offCenterFrustum;a(D)&&(f=D);let K=U[x],G=U[x+1];C.x=(C.x*(f.right-f.left)+f.left+f.right)*.5,C.y=(C.y*(f.top-f.bottom)+f.bottom+f.top)*.5,C.z=(C.z*(K-G)-K-G)*.5,C.w=1,O.multiplyByVector(o,C,C)}p[12*x+z*3]=C.x,p[12*x+z*3+1]=C.y,p[12*x+z*3+2]=C.z}};Y.createGeometry=function(e){let t=e._frustumType,n=e._frustum,f=e._origin,p=e._orientation,_=e._drawNearPlane,s=e._vertexFormat,y=_?6:5,i=new Float64Array(3*4*6);Y._computeNearFarPlanes(f,p,t,n,i);let c=3*4*2;i[c]=i[3*4],i[c+1]=i[3*4+1],i[c+2]=i[3*4+2],i[c+3]=i[0],i[c+4]=i[1],i[c+5]=i[2],i[c+6]=i[3*3],i[c+7]=i[3*3+1],i[c+8]=i[3*3+2],i[c+9]=i[3*7],i[c+10]=i[3*7+1],i[c+11]=i[3*7+2],c+=3*4,i[c]=i[3*5],i[c+1]=i[3*5+1],i[c+2]=i[3*5+2],i[c+3]=i[3],i[c+4]=i[3+1],i[c+5]=i[3+2],i[c+6]=i[0],i[c+7]=i[1],i[c+8]=i[2],i[c+9]=i[3*4],i[c+10]=i[3*4+1],i[c+11]=i[3*4+2],c+=3*4,i[c]=i[3],i[c+1]=i[3+1],i[c+2]=i[3+2],i[c+3]=i[3*5],i[c+4]=i[3*5+1],i[c+5]=i[3*5+2],i[c+6]=i[3*6],i[c+7]=i[3*6+1],i[c+8]=i[3*6+2],i[c+9]=i[3*2],i[c+10]=i[3*2+1],i[c+11]=i[3*2+2],c+=3*4,i[c]=i[3*2],i[c+1]=i[3*2+1],i[c+2]=i[3*2+2],i[c+3]=i[3*6],i[c+4]=i[3*6+1],i[c+5]=i[3*6+2],i[c+6]=i[3*7],i[c+7]=i[3*7+1],i[c+8]=i[3*7+2],i[c+9]=i[3*3],i[c+10]=i[3*3+1],i[c+11]=i[3*3+2],_||(i=i.subarray(3*4));let d=new ae({position:new J({componentDatatype:H.DOUBLE,componentsPerAttribute:3,values:i})});if(a(s.normal)||a(s.tangent)||a(s.bitangent)||a(s.st)){let l=a(s.normal)?new Float32Array(12*y):void 0,o=a(s.tangent)?new Float32Array(3*4*y):void 0,h=a(s.bitangent)?new Float32Array(3*4*y):void 0,M=a(s.st)?new Float32Array(2*4*y):void 0,x=se,z=le,C=we,D=r.negate(x,ke),K=r.negate(z,Se),G=r.negate(C,De);c=0,_&&(W(c,l,o,h,M,G,x,z),c+=3*4),W(c,l,o,h,M,C,D,z),c+=3*4,W(c,l,o,h,M,D,G,z),c+=3*4,W(c,l,o,h,M,K,G,D),c+=3*4,W(c,l,o,h,M,x,C,z),c+=3*4,W(c,l,o,h,M,z,C,D),a(l)&&(d.normal=new J({componentDatatype:H.FLOAT,componentsPerAttribute:3,values:l})),a(o)&&(d.tangent=new J({componentDatatype:H.FLOAT,componentsPerAttribute:3,values:o})),a(h)&&(d.bitangent=new J({componentDatatype:H.FLOAT,componentsPerAttribute:3,values:h})),a(M)&&(d.st=new J({componentDatatype:H.FLOAT,componentsPerAttribute:2,values:M}))}let g=new Uint16Array(6*y);for(let l=0;le?d=R.TWO_PI-i+e:d=e-i;let S=Math.ceil(d/_)+1,f=Math.ceil(s/_)+1,w=d/(S-1),m=s/(f-1),M=I.northwest(t,u),o=I.center(t,F);(l!==0||h!==0)&&(o.longitudeR.PI_OVER_TWO||n<-R.PI_OVER_TWO||n>R.PI_OVER_TWO)throw new k("Rotated rectangle is invalid. It crosses over either the north or south pole.");c.granYCos=C.granYCos,c.granYSin=C.granYSin,c.granXCos=C.granXCos,c.granXSin=C.granXSin,x.north=r,x.south=n,x.east=e,x.west=i}if(h!==0){l=l-h;let C=I.northwest(x,a),P=B(C,l,w,m,o,S,f);c.stGranYCos=P.granYCos,c.stGranXCos=P.granXCos,c.stGranYSin=P.granYSin,c.stGranXSin=P.granXSin,c.stNwCorner=C,c.stWest=P.west,c.stSouth=P.south}return c};var nt=L;export{nt as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-67OQHZOZ.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-67OQHZOZ.js new file mode 100644 index 0000000000000000000000000000000000000000..b235cc346bd9027c1d4aa07bf2eaea9bb69bd7a3 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-67OQHZOZ.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a}from"./chunk-LI57NJAL.js";import{a as N}from"./chunk-IBAO62UG.js";import{a as t}from"./chunk-FUATUYJ3.js";import{e as i}from"./chunk-ODUTJJQ5.js";var r={UNSIGNED_BYTE:N.UNSIGNED_BYTE,UNSIGNED_SHORT:N.UNSIGNED_SHORT,UNSIGNED_INT:N.UNSIGNED_INT};r.getSizeInBytes=function(e){switch(e){case r.UNSIGNED_BYTE:return Uint8Array.BYTES_PER_ELEMENT;case r.UNSIGNED_SHORT:return Uint16Array.BYTES_PER_ELEMENT;case r.UNSIGNED_INT:return Uint32Array.BYTES_PER_ELEMENT}throw new t("indexDatatype is required and must be a valid IndexDatatype constant.")};r.fromSizeInBytes=function(e){switch(e){case 2:return r.UNSIGNED_SHORT;case 4:return r.UNSIGNED_INT;case 1:return r.UNSIGNED_BYTE;default:throw new t("Size in bytes cannot be mapped to an IndexDatatype")}};r.validate=function(e){return i(e)&&(e===r.UNSIGNED_BYTE||e===r.UNSIGNED_SHORT||e===r.UNSIGNED_INT)};r.createTypedArray=function(e,n){if(!i(e))throw new t("numberOfVertices is required.");return e>=a.SIXTY_FOUR_KILOBYTES?new Uint32Array(n):new Uint16Array(n)};r.createTypedArrayFromArrayBuffer=function(e,n,E,o){if(!i(e))throw new t("numberOfVertices is required.");if(!i(n))throw new t("sourceArray is required.");if(!i(E))throw new t("byteOffset is required.");return e>=a.SIXTY_FOUR_KILOBYTES?new Uint32Array(n,E,o):new Uint16Array(n,E,o)};r.fromTypedArray=function(e){if(e instanceof Uint8Array)return r.UNSIGNED_BYTE;if(e instanceof Uint16Array)return r.UNSIGNED_SHORT;if(e instanceof Uint32Array)return r.UNSIGNED_INT;throw new t("array must be a Uint8Array, Uint16Array, or Uint32Array.")};var u=Object.freeze(r);export{u as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-6A32WNKQ.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-6A32WNKQ.js new file mode 100644 index 0000000000000000000000000000000000000000..f5f4bc1b2ebf05a0d5b1de18eb0dc8e3bd63afcc --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-6A32WNKQ.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +var e={NONE:0,GEODESIC:1,RHUMB:2},t=Object.freeze(e);export{t as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-6Z3TD6OI.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-6Z3TD6OI.js new file mode 100644 index 0000000000000000000000000000000000000000..31e21a6ea65b736616fd00b7770da89868414d2d --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-6Z3TD6OI.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as K}from"./chunk-YTG33ZHK.js";import{a as L}from"./chunk-ATQXFTWF.js";import{b as v,c as J,d as Z}from"./chunk-NNIY7VTE.js";import{b as B,c as k,d as I}from"./chunk-5EDTRNG5.js";import{a as t,b as T,c as F,d}from"./chunk-C6Y3PRDH.js";import{a as g}from"./chunk-LI57NJAL.js";import{a as W}from"./chunk-P44SUSQU.js";import{a as b,b as z}from"./chunk-FUATUYJ3.js";import{e as p}from"./chunk-ODUTJJQ5.js";function m(n,e){this.center=t.clone(W(n,t.ZERO)),this.halfAxes=d.clone(W(e,d.ZERO))}m.packedLength=t.packedLength+d.packedLength;m.pack=function(n,e,c){return z.typeOf.object("value",n),z.defined("array",e),c=W(c,0),t.pack(n.center,e,c),d.pack(n.halfAxes,e,c+t.packedLength),e};m.unpack=function(n,e,c){return z.defined("array",n),e=W(e,0),p(c)||(c=new m),t.unpack(n,e,c.center),d.unpack(n,e+t.packedLength,c.halfAxes),c};var Ct=new t,ut=new t,Pt=new t,xt=new t,yt=new t,At=new t,Nt=new d,Mt={unitary:new d,diagonal:new d};m.fromPoints=function(n,e){if(p(e)||(e=new m),!p(n)||n.length===0)return e.halfAxes=d.ZERO,e.center=t.ZERO,e;let c,h=n.length,r=t.clone(n[0],Ct);for(c=1;cg.TWO_PI)throw new b("Rectangle width must be between 0 and 2 * pi");if(n.height<0||n.height>g.PI)throw new b("Rectangle height must be between 0 and pi");if(p(h)&&!g.equalsEpsilon(h.radii.x,h.radii.y,g.EPSILON15))throw new b("Ellipsoid must be an ellipsoid of revolution (radii.x == radii.y)");e=W(e,0),c=W(c,0),h=W(h,F.WGS84);let o,i,C,w,l,u,a;if(n.width<=g.PI){let R=k.center(n,$),j=h.cartographicToCartesian(R,bt),S=new K(j,h);a=S.plane;let E=R.longitude,ot=n.south<0&&n.north>0?0:R.latitude,st=T.fromRadians(E,n.north,c,St),V=T.fromRadians(n.west,n.north,c,Tt),it=T.fromRadians(n.west,ot,c,gt),_=T.fromRadians(n.west,n.south,c,Et),ht=T.fromRadians(E,n.south,c,Rt),ft=h.cartographicToCartesian(st,Wt),D=h.cartographicToCartesian(V,H),dt=h.cartographicToCartesian(it,zt),X=h.cartographicToCartesian(_,tt),mt=h.cartographicToCartesian(ht,It),wt=S.projectPointToNearestOnPlane(ft,Lt),Y=S.projectPointToNearestOnPlane(D,Ut),lt=S.projectPointToNearestOnPlane(dt,qt),G=S.projectPointToNearestOnPlane(X,jt),pt=S.projectPointToNearestOnPlane(mt,Bt);return o=Math.min(Y.x,lt.x,G.x),i=-o,w=Math.max(Y.y,wt.y),C=Math.min(G.y,pt.y),V.height=_.height=e,D=h.cartographicToCartesian(V,H),X=h.cartographicToCartesian(_,tt),l=Math.min(L.getPointDistance(a,D),L.getPointDistance(a,X)),u=c,Q(S.origin,S.xAxis,S.yAxis,S.zAxis,o,i,C,w,l,u,r)}let s=n.south>0,f=n.north<0,A=s?n.south:f?n.north:0,M=k.center(n,$).longitude,x=t.fromRadians(M,A,c,h,vt);x.z=0;let N=Math.abs(x.x)=w?v.INSIDE:v.INTERSECTING};var at=new t,ct=new t,rt=new t,Ft=new t,et=new t,Jt=new t;m.distanceSquaredTo=function(n,e){if(!p(n))throw new b("box is required.");if(!p(e))throw new b("cartesian is required.");let c=t.subtract(e,n.center,nt),h=n.halfAxes,r=d.getColumn(h,0,at),o=d.getColumn(h,1,ct),i=d.getColumn(h,2,rt),C=t.magnitude(r),w=t.magnitude(o),l=t.magnitude(i),u=!0,a=!0,s=!0;C>0?t.divideByScalar(r,C,r):u=!1,w>0?t.divideByScalar(o,w,o):a=!1,l>0?t.divideByScalar(i,l,i):s=!1;let f=!u+!a+!s,A,M,x;if(f===1){let O=r;A=o,M=i,a?s||(O=i,M=r):(O=o,A=r),x=t.cross(A,M,et),O===r?r=x:O===o?o=x:O===i&&(i=x)}else if(f===2){A=r,a?A=o:s&&(A=i);let O=t.UNIT_Y;O.equalsEpsilon(A,g.EPSILON3)&&(O=t.UNIT_X),M=t.cross(A,O,Ft),t.normalize(M,M),x=t.cross(A,M,et),t.normalize(x,x),A===r?(o=M,i=x):A===o?(i=M,r=x):A===i&&(r=M,o=x)}else f===3&&(r=t.UNIT_X,o=t.UNIT_Y,i=t.UNIT_Z);let y=Jt;y.x=t.dot(c,r),y.y=t.dot(c,o),y.z=t.dot(c,i);let N=0,P;return y.x<-C?(P=y.x+C,N+=P*P):y.x>C&&(P=y.x-C,N+=P*P),y.y<-w?(P=y.y+w,N+=P*P):y.y>w&&(P=y.y-w,N+=P*P),y.z<-l?(P=y.z+l,N+=P*P):y.z>l&&(P=y.z-l,N+=P*P),N};var Kt=new t,Qt=new t;m.computePlaneDistances=function(n,e,c,h){if(!p(n))throw new b("box is required.");if(!p(e))throw new b("position is required.");if(!p(c))throw new b("direction is required.");p(h)||(h=new J);let r=Number.POSITIVE_INFINITY,o=Number.NEGATIVE_INFINITY,i=n.center,C=n.halfAxes,w=d.getColumn(C,0,at),l=d.getColumn(C,1,ct),u=d.getColumn(C,2,rt),a=t.add(w,l,Kt);t.add(a,u,a),t.add(a,i,a);let s=t.subtract(a,e,Qt),f=t.dot(c,s);return r=Math.min(f,r),o=Math.max(f,o),t.add(i,w,a),t.add(a,l,a),t.subtract(a,u,a),t.subtract(a,e,s),f=t.dot(c,s),r=Math.min(f,r),o=Math.max(f,o),t.add(i,w,a),t.subtract(a,l,a),t.add(a,u,a),t.subtract(a,e,s),f=t.dot(c,s),r=Math.min(f,r),o=Math.max(f,o),t.add(i,w,a),t.subtract(a,l,a),t.subtract(a,u,a),t.subtract(a,e,s),f=t.dot(c,s),r=Math.min(f,r),o=Math.max(f,o),t.subtract(i,w,a),t.add(a,l,a),t.add(a,u,a),t.subtract(a,e,s),f=t.dot(c,s),r=Math.min(f,r),o=Math.max(f,o),t.subtract(i,w,a),t.add(a,l,a),t.subtract(a,u,a),t.subtract(a,e,s),f=t.dot(c,s),r=Math.min(f,r),o=Math.max(f,o),t.subtract(i,w,a),t.subtract(a,l,a),t.add(a,u,a),t.subtract(a,e,s),f=t.dot(c,s),r=Math.min(f,r),o=Math.max(f,o),t.subtract(i,w,a),t.subtract(a,l,a),t.subtract(a,u,a),t.subtract(a,e,s),f=t.dot(c,s),r=Math.min(f,r),o=Math.max(f,o),h.start=r,h.stop=o,h};var $t=new t,Ht=new t,te=new t;m.computeCorners=function(n,e){z.typeOf.object("box",n),p(e)||(e=[new t,new t,new t,new t,new t,new t,new t,new t]);let c=n.center,h=n.halfAxes,r=d.getColumn(h,0,$t),o=d.getColumn(h,1,Ht),i=d.getColumn(h,2,te);return t.clone(c,e[0]),t.subtract(e[0],r,e[0]),t.subtract(e[0],o,e[0]),t.subtract(e[0],i,e[0]),t.clone(c,e[1]),t.subtract(e[1],r,e[1]),t.subtract(e[1],o,e[1]),t.add(e[1],i,e[1]),t.clone(c,e[2]),t.subtract(e[2],r,e[2]),t.add(e[2],o,e[2]),t.subtract(e[2],i,e[2]),t.clone(c,e[3]),t.subtract(e[3],r,e[3]),t.add(e[3],o,e[3]),t.add(e[3],i,e[3]),t.clone(c,e[4]),t.add(e[4],r,e[4]),t.subtract(e[4],o,e[4]),t.subtract(e[4],i,e[4]),t.clone(c,e[5]),t.add(e[5],r,e[5]),t.subtract(e[5],o,e[5]),t.add(e[5],i,e[5]),t.clone(c,e[6]),t.add(e[6],r,e[6]),t.add(e[6],o,e[6]),t.subtract(e[6],i,e[6]),t.clone(c,e[7]),t.add(e[7],r,e[7]),t.add(e[7],o,e[7]),t.add(e[7],i,e[7]),e};var ee=new d;m.computeTransformation=function(n,e){z.typeOf.object("box",n),p(e)||(e=new B);let c=n.center,h=d.multiplyByUniformScale(n.halfAxes,2,ee);return B.fromRotationTranslation(h,c,e)};var ne=new Z;m.isOccluded=function(n,e){if(!p(n))throw new b("box is required.");if(!p(e))throw new b("occluder is required.");let c=Z.fromOrientedBoundingBox(n,ne);return!e.isBoundingSphereVisible(c)};m.prototype.intersectPlane=function(n){return m.intersectPlane(this,n)};m.prototype.distanceSquaredTo=function(n){return m.distanceSquaredTo(this,n)};m.prototype.computePlaneDistances=function(n,e,c){return m.computePlaneDistances(this,n,e,c)};m.prototype.computeCorners=function(n){return m.computeCorners(this,n)};m.prototype.computeTransformation=function(n){return m.computeTransformation(this,n)};m.prototype.isOccluded=function(n){return m.isOccluded(this,n)};m.equals=function(n,e){return n===e||p(n)&&p(e)&&t.equals(n.center,e.center)&&d.equals(n.halfAxes,e.halfAxes)};m.prototype.clone=function(n){return m.clone(this,n)};m.prototype.equals=function(n){return m.equals(this,n)};var ye=m;export{ye as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-A4RD4IQP.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-A4RD4IQP.js new file mode 100644 index 0000000000000000000000000000000000000000..32e1c143e4ee56ddceb48a1ac1bf391836dd3516 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-A4RD4IQP.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{f as O,i as G}from"./chunk-NNIY7VTE.js";import{b as l,c as R,d as a,e as L}from"./chunk-5EDTRNG5.js";import{a as A,b as h,d as y}from"./chunk-C6Y3PRDH.js";import{a as c}from"./chunk-IBAO62UG.js";import{a as s}from"./chunk-P44SUSQU.js";import{a as N,b as w}from"./chunk-FUATUYJ3.js";import{e as I}from"./chunk-ODUTJJQ5.js";var U={NONE:0,TRIANGLES:1,LINES:2,POLYLINES:3},M=Object.freeze(U);var r={POINTS:c.POINTS,LINES:c.LINES,LINE_LOOP:c.LINE_LOOP,LINE_STRIP:c.LINE_STRIP,TRIANGLES:c.TRIANGLES,TRIANGLE_STRIP:c.TRIANGLE_STRIP,TRIANGLE_FAN:c.TRIANGLE_FAN};r.isLines=function(t){return t===r.LINES||t===r.LINE_LOOP||t===r.LINE_STRIP};r.isTriangles=function(t){return t===r.TRIANGLES||t===r.TRIANGLE_STRIP||t===r.TRIANGLE_FAN};r.validate=function(t){return t===r.POINTS||t===r.LINES||t===r.LINE_LOOP||t===r.LINE_STRIP||t===r.TRIANGLES||t===r.TRIANGLE_STRIP||t===r.TRIANGLE_FAN};var F=Object.freeze(r);function _(t){t=s(t,s.EMPTY_OBJECT),w.typeOf.object("options.attributes",t.attributes),this.attributes=t.attributes,this.indices=t.indices,this.primitiveType=s(t.primitiveType,F.TRIANGLES),this.boundingSphere=t.boundingSphere,this.geometryType=s(t.geometryType,M.NONE),this.boundingSphereCV=t.boundingSphereCV,this.offsetAttribute=t.offsetAttribute}_.computeNumberOfVertices=function(t){w.typeOf.object("geometry",t);let m=-1;for(let u in t.attributes)if(t.attributes.hasOwnProperty(u)&&I(t.attributes[u])&&I(t.attributes[u].values)){let o=t.attributes[u],e=o.values.length/o.componentsPerAttribute;if(m!==e&&m!==-1)throw new N("All attribute lists must have the same number of attributes.");m=e}return m};var W=new h,H=new A,V=new l,Z=[new h,new h,new h],K=[new a,new a,new a],$=[new a,new a,new a],tt=new A,et=new O,rt=new l,nt=new L;_._textureCoordinateRotationPoints=function(t,m,u,o){let e,g=R.center(o,W),D=h.toCartesian(g,u,H),Y=G.eastNorthUpToFixedFrame(D,u,V),C=l.inverse(Y,V),b=K,f=Z;f[0].longitude=o.west,f[0].latitude=o.south,f[1].longitude=o.west,f[1].latitude=o.north,f[2].longitude=o.east,f[2].latitude=o.south;let n=tt;for(e=0;e<3;e++)h.toCartesian(f[e],u,n),n=l.multiplyByPointAsVector(C,n,n),b[e].x=n.x,b[e].y=n.y;let B=O.fromAxisAngle(A.UNIT_Z,-m,et),v=y.fromQuaternion(B,rt),j=t.length,T=Number.POSITIVE_INFINITY,p=Number.POSITIVE_INFINITY,d=Number.NEGATIVE_INFINITY,x=Number.NEGATIVE_INFINITY;for(e=0;e4)throw new N("options.componentsPerAttribute must be between 1 and 4.");if(!I(t.values))throw new N("options.values is required.");this.componentDatatype=t.componentDatatype,this.componentsPerAttribute=t.componentsPerAttribute,this.normalize=s(t.normalize,!1),this.values=t.values}var Ot=ot;export{M as a,F as b,Lt as c,Ot as d}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-AJGH25BB.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-AJGH25BB.js new file mode 100644 index 0000000000000000000000000000000000000000..c192398f5e875738dcac42af70b318109c51e5a0 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-AJGH25BB.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as N}from"./chunk-6A32WNKQ.js";import{a as ot}from"./chunk-GH2M3QEY.js";import{a as K,b as B}from"./chunk-MUMMGJJL.js";import{a as k}from"./chunk-RUSF25XT.js";import{a as F}from"./chunk-Y5NK5HSS.js";import{a as nt}from"./chunk-67OQHZOZ.js";import{a as et}from"./chunk-FUN3J34G.js";import{b as Y,c as Q,d as H}from"./chunk-A4RD4IQP.js";import{f as j}from"./chunk-NNIY7VTE.js";import{d as A}from"./chunk-5EDTRNG5.js";import{a as q}from"./chunk-IO6LETQ6.js";import{a as b,b as W,c as tt,d as z}from"./chunk-C6Y3PRDH.js";import{a as S}from"./chunk-LI57NJAL.js";import{a as X}from"./chunk-P44SUSQU.js";import{e as w}from"./chunk-ODUTJJQ5.js";function _(){this._array=[],this._offset=0,this._length=0}Object.defineProperties(_.prototype,{length:{get:function(){return this._length}}});_.prototype.enqueue=function(n){this._array.push(n),this._length++};_.prototype.dequeue=function(){if(this._length===0)return;let n=this._array,s=this._offset,c=n[s];return n[s]=void 0,s++,s>10&&s*2>n.length&&(this._array=n.slice(s),s=0),this._offset=s,this._length--,c};_.prototype.peek=function(){if(this._length!==0)return this._array[this._offset]};_.prototype.contains=function(n){return this._array.indexOf(n)!==-1};_.prototype.clear=function(){this._array.length=this._offset=this._length=0};_.prototype.sort=function(n){this._offset>0&&(this._array=this._array.slice(this._offset),this._offset=0),this._array.sort(n)};var J=_;var x={};x.computeHierarchyPackedLength=function(n,s){let c=0,f=[n];for(;f.length>0;){let u=f.pop();if(!w(u))continue;c+=2;let r=u.positions,t=u.holes;if(w(r)&&r.length>0&&(c+=r.length*s.packedLength),w(t)){let e=t.length;for(let o=0;o0;){let r=u.pop();if(!w(r))continue;let t=r.positions,e=r.holes;if(s[c++]=w(t)?t.length:0,s[c++]=w(e)?e.length:0,w(t)){let o=t.length;for(let i=0;i0?new Array(u):void 0;for(let e=0;e=0?(h=Math.floor(n/65536)*65536,o.high=h,o.low=n-h):(h=Math.floor(-n/65536)*65536,o.high=-h,o.low=n+h),o};var e={high:0,low:0};f.fromCartesian=function(n,o){t.typeOf.object("cartesian",n),g(o)||(o=new f);let h=o.high,i=o.low;return f.encode(n.x,e),h.x=e.high,i.x=e.low,f.encode(n.y,e),h.y=e.high,i.y=e.low,f.encode(n.z,e),h.z=e.high,i.z=e.low,o};var m=new f;f.writeElements=function(n,o,h){t.defined("cartesianArray",o),t.typeOf.number("index",h),t.typeOf.number.greaterThanOrEquals("index",h,0),f.fromCartesian(n,m);let i=m.high,w=m.low;o[h]=i.x,o[h+1]=i.y,o[h+2]=i.z,o[h+3]=w.x,o[h+4]=w.y,o[h+5]=w.z};var O=f;export{O as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-C3GEAKG7.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-C3GEAKG7.js new file mode 100644 index 0000000000000000000000000000000000000000..91c07f54f5eda17537e42b1fdabd1d897e4ac3d2 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-C3GEAKG7.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as L}from"./chunk-SKT4NNP6.js";import{a as j}from"./chunk-YYCOBWZH.js";import{a as D}from"./chunk-67OQHZOZ.js";import{a as V}from"./chunk-FUN3J34G.js";import{b as T,c as B,d as x}from"./chunk-A4RD4IQP.js";import{d as O}from"./chunk-NNIY7VTE.js";import{a as S}from"./chunk-IO6LETQ6.js";import{a as c,c as l}from"./chunk-C6Y3PRDH.js";import{a as E}from"./chunk-LI57NJAL.js";import{a as m}from"./chunk-P44SUSQU.js";import{a as _}from"./chunk-FUATUYJ3.js";import{e as d}from"./chunk-ODUTJJQ5.js";var q=new c,M=new c;function U(e){let t=e.center;M=c.multiplyByScalar(e.ellipsoid.geodeticSurfaceNormal(t,M),e.height,M),M=c.add(t,M,M);let i=new O(M,e.semiMajorAxis),f=L.computeEllipsePositions(e,!1,!0).outerPositions,o=new V({position:new x({componentDatatype:S.DOUBLE,componentsPerAttribute:3,values:L.raisePositionsToHeight(f,e,!1)})}),r=f.length/3,u=D.createTypedArray(r,r*2),h=0;for(let n=0;n0){let g=Math.min(p,n);k=Math.round(n/g);let H=Math.min(k*p,n);for(s=0;s0&&(J=!0,U+=u-1),b0&&t!==f-1&&o!==0&&o!==c-1&&(st[$]=!0),$++;e=0;let F,L;for(t=1;t=et&&tz.EPSILON12);return h(i)?(i.x=y*L,i.y=d*k,i.z=a*U,i):new O(y*L,d*k,a*U)}var X=hn;function R(n,o,e){this.longitude=u(n,0),this.latitude=u(o,0),this.height=u(e,0)}R.fromRadians=function(n,o,e,t){return c.typeOf.number("longitude",n),c.typeOf.number("latitude",o),e=u(e,0),h(t)?(t.longitude=n,t.latitude=o,t.height=e,t):new R(n,o,e)};R.fromDegrees=function(n,o,e,t){return c.typeOf.number("longitude",n),c.typeOf.number("latitude",o),n=z.toRadians(n),o=z.toRadians(o),R.fromRadians(n,o,e,t)};var mn=new O,bn=new O,un=new O,wn=new O(1/6378137,1/6378137,1/6356752314245179e-9),jn=new O(1/(6378137*6378137),1/(6378137*6378137),1/(6356752314245179e-9*6356752314245179e-9)),zn=z.EPSILON1;R.fromCartesian=function(n,o,e){let t=h(o)?o.oneOverRadii:wn,i=h(o)?o.oneOverRadiiSquared:jn,y=h(o)?o._centerToleranceSquared:zn,d=X(n,t,i,y,bn);if(!h(d))return;let a=O.multiplyComponents(d,i,mn);a=O.normalize(a,a);let m=O.subtract(n,d,un),b=Math.atan2(a.y,a.x),j=Math.asin(a.z),S=z.sign(O.dot(m,n))*O.magnitude(m);return h(e)?(e.longitude=b,e.latitude=j,e.height=S,e):new R(b,j,S)};R.toCartesian=function(n,o,e){return c.defined("cartographic",n),O.fromRadians(n.longitude,n.latitude,n.height,o,e)};R.clone=function(n,o){if(h(n))return h(o)?(o.longitude=n.longitude,o.latitude=n.latitude,o.height=n.height,o):new R(n.longitude,n.latitude,n.height)};R.equals=function(n,o){return n===o||h(n)&&h(o)&&n.longitude===o.longitude&&n.latitude===o.latitude&&n.height===o.height};R.equalsEpsilon=function(n,o,e){return e=u(e,0),n===o||h(n)&&h(o)&&Math.abs(n.longitude-o.longitude)<=e&&Math.abs(n.latitude-o.latitude)<=e&&Math.abs(n.height-o.height)<=e};R.ZERO=Object.freeze(new R(0,0,0));R.prototype.clone=function(n){return R.clone(this,n)};R.prototype.equals=function(n){return R.equals(this,n)};R.prototype.equalsEpsilon=function(n,o){return R.equalsEpsilon(this,n,o)};R.prototype.toString=function(){return`(${this.longitude}, ${this.latitude}, ${this.height})`};var on=R;function tn(n,o,e,t){o=u(o,0),e=u(e,0),t=u(t,0),c.typeOf.number.greaterThanOrEquals("x",o,0),c.typeOf.number.greaterThanOrEquals("y",e,0),c.typeOf.number.greaterThanOrEquals("z",t,0),n._radii=new O(o,e,t),n._radiiSquared=new O(o*o,e*e,t*t),n._radiiToTheFourth=new O(o*o*o*o,e*e*e*e,t*t*t*t),n._oneOverRadii=new O(o===0?0:1/o,e===0?0:1/e,t===0?0:1/t),n._oneOverRadiiSquared=new O(o===0?0:1/(o*o),e===0?0:1/(e*e),t===0?0:1/(t*t)),n._minimumRadius=Math.min(o,e,t),n._maximumRadius=Math.max(o,e,t),n._centerToleranceSquared=z.EPSILON1,n._radiiSquared.z!==0&&(n._squaredXOverSquaredZ=n._radiiSquared.x/n._radiiSquared.z)}function w(n,o,e){this._radii=void 0,this._radiiSquared=void 0,this._radiiToTheFourth=void 0,this._oneOverRadii=void 0,this._oneOverRadiiSquared=void 0,this._minimumRadius=void 0,this._maximumRadius=void 0,this._centerToleranceSquared=void 0,this._squaredXOverSquaredZ=void 0,tn(this,n,o,e)}Object.defineProperties(w.prototype,{radii:{get:function(){return this._radii}},radiiSquared:{get:function(){return this._radiiSquared}},radiiToTheFourth:{get:function(){return this._radiiToTheFourth}},oneOverRadii:{get:function(){return this._oneOverRadii}},oneOverRadiiSquared:{get:function(){return this._oneOverRadiiSquared}},minimumRadius:{get:function(){return this._minimumRadius}},maximumRadius:{get:function(){return this._maximumRadius}}});w.clone=function(n,o){if(!h(n))return;let e=n._radii;return h(o)?(O.clone(e,o._radii),O.clone(n._radiiSquared,o._radiiSquared),O.clone(n._radiiToTheFourth,o._radiiToTheFourth),O.clone(n._oneOverRadii,o._oneOverRadii),O.clone(n._oneOverRadiiSquared,o._oneOverRadiiSquared),o._minimumRadius=n._minimumRadius,o._maximumRadius=n._maximumRadius,o._centerToleranceSquared=n._centerToleranceSquared,o):new w(e.x,e.y,e.z)};w.fromCartesian3=function(n,o){return h(o)||(o=new w),h(n)&&tn(o,n.x,n.y,n.z),o};w.WGS84=Object.freeze(new w(6378137,6378137,6356752314245179e-9));w.UNIT_SPHERE=Object.freeze(new w(1,1,1));w.MOON=Object.freeze(new w(z.LUNAR_RADIUS,z.LUNAR_RADIUS,z.LUNAR_RADIUS));w.prototype.clone=function(n){return w.clone(this,n)};w.packedLength=O.packedLength;w.pack=function(n,o,e){return c.typeOf.object("value",n),c.defined("array",o),e=u(e,0),O.pack(n._radii,o,e),o};w.unpack=function(n,o,e){c.defined("array",n),o=u(o,0);let t=O.unpack(n,o);return w.fromCartesian3(t,e)};w.prototype.geocentricSurfaceNormal=O.normalize;w.prototype.geodeticSurfaceNormalCartographic=function(n,o){c.typeOf.object("cartographic",n);let e=n.longitude,t=n.latitude,i=Math.cos(t),y=i*Math.cos(e),d=i*Math.sin(e),a=Math.sin(t);return h(o)||(o=new O),o.x=y,o.y=d,o.z=a,O.normalize(o,o)};w.prototype.geodeticSurfaceNormal=function(n,o){if(!O.equalsEpsilon(n,O.ZERO,z.EPSILON14))return h(o)||(o=new O),o=O.multiplyComponents(n,this._oneOverRadiiSquared,o),O.normalize(o,o)};var Sn=new O,Mn=new O;w.prototype.cartographicToCartesian=function(n,o){let e=Sn,t=Mn;this.geodeticSurfaceNormalCartographic(n,e),O.multiplyComponents(this._radiiSquared,e,t);let i=Math.sqrt(O.dot(e,t));return O.divideByScalar(t,i,t),O.multiplyByScalar(e,n.height,e),h(o)||(o=new O),O.add(t,e,o)};w.prototype.cartographicArrayToCartesianArray=function(n,o){c.defined("cartographics",n);let e=n.length;h(o)?o.length=e:o=new Array(e);for(let t=0;t=this._radii.z-o))return e};var Tn=[.14887433898163,.43339539412925,.67940956829902,.86506336668898,.97390652851717,0],gn=[.29552422471475,.26926671930999,.21908636251598,.14945134915058,.066671344308684,0];function en(n,o,e){c.typeOf.number("a",n),c.typeOf.number("b",o),c.typeOf.func("func",e);let t=.5*(o+n),i=.5*(o-n),y=0;for(let d=0;d<5;d++){let a=i*Tn[d];y+=gn[d]*(e(t+a)+e(t-a))}return y*=i,y}w.prototype.surfaceArea=function(n){c.typeOf.object("rectangle",n);let o=n.west,e=n.east,t=n.south,i=n.north;for(;et&&(i=b,t=j)}let y=1,d=0,a=V[i],m=H[i];if(Math.abs(n[p.getElementIndex(m,a)])>e){let b=n[p.getElementIndex(m,m)],j=n[p.getElementIndex(a,a)],S=n[p.getElementIndex(m,a)],M=(b-j)/2/S,q;M<0?q=-1/(-M+Math.sqrt(1+M*M)):q=1/(M+Math.sqrt(1+M*M)),y=1/Math.sqrt(1+q*q),d=q*y}return o=p.clone(p.IDENTITY,o),o[p.getElementIndex(a,a)]=o[p.getElementIndex(m,m)]=y,o[p.getElementIndex(m,a)]=d,o[p.getElementIndex(a,m)]=-d,o}var Y=new p,fn=new p;p.computeEigenDecomposition=function(n,o){c.typeOf.object("matrix",n);let e=z.EPSILON20,t=10,i=0,y=0;h(o)||(o={});let d=o.unitary=p.clone(p.IDENTITY,o.unitary),a=o.diagonal=p.clone(n,o.diagonal),m=e*Nn(a);for(;ym;)Ln(a,Y),p.transpose(Y,fn),p.multiply(a,Y,a),p.multiply(fn,a,a),p.multiply(d,Y,d),++i>2&&(++y,i=0);return o};p.abs=function(n,o){return c.typeOf.object("matrix",n),c.typeOf.object("result",o),o[0]=Math.abs(n[0]),o[1]=Math.abs(n[1]),o[2]=Math.abs(n[2]),o[3]=Math.abs(n[3]),o[4]=Math.abs(n[4]),o[5]=Math.abs(n[5]),o[6]=Math.abs(n[6]),o[7]=Math.abs(n[7]),o[8]=Math.abs(n[8]),o};p.determinant=function(n){c.typeOf.object("matrix",n);let o=n[0],e=n[3],t=n[6],i=n[1],y=n[4],d=n[7],a=n[2],m=n[5],b=n[8];return o*(y*b-m*d)+i*(m*t-e*b)+a*(e*d-y*t)};p.inverse=function(n,o){c.typeOf.object("matrix",n),c.typeOf.object("result",o);let e=n[0],t=n[1],i=n[2],y=n[3],d=n[4],a=n[5],m=n[6],b=n[7],j=n[8],S=p.determinant(n);if(Math.abs(S)<=z.EPSILON15)throw new r("matrix is not invertible");o[0]=d*j-b*a,o[1]=b*i-t*j,o[2]=t*a-d*i,o[3]=m*a-y*j,o[4]=e*j-m*i,o[5]=y*i-e*a,o[6]=y*b-m*d,o[7]=m*t-e*b,o[8]=e*d-y*t;let M=1/S;return p.multiplyByScalar(o,M,o)};var kn=new p;p.inverseTranspose=function(n,o){return c.typeOf.object("matrix",n),c.typeOf.object("result",o),p.inverse(p.transpose(n,kn),o)};p.equals=function(n,o){return n===o||h(n)&&h(o)&&n[0]===o[0]&&n[1]===o[1]&&n[2]===o[2]&&n[3]===o[3]&&n[4]===o[4]&&n[5]===o[5]&&n[6]===o[6]&&n[7]===o[7]&&n[8]===o[8]};p.equalsEpsilon=function(n,o,e){return e=u(e,0),n===o||h(n)&&h(o)&&Math.abs(n[0]-o[0])<=e&&Math.abs(n[1]-o[1])<=e&&Math.abs(n[2]-o[2])<=e&&Math.abs(n[3]-o[3])<=e&&Math.abs(n[4]-o[4])<=e&&Math.abs(n[5]-o[5])<=e&&Math.abs(n[6]-o[6])<=e&&Math.abs(n[7]-o[7])<=e&&Math.abs(n[8]-o[8])<=e};p.IDENTITY=Object.freeze(new p(1,0,0,0,1,0,0,0,1));p.ZERO=Object.freeze(new p(0,0,0,0,0,0,0,0,0));p.COLUMN0ROW0=0;p.COLUMN0ROW1=1;p.COLUMN0ROW2=2;p.COLUMN1ROW0=3;p.COLUMN1ROW1=4;p.COLUMN1ROW2=5;p.COLUMN2ROW0=6;p.COLUMN2ROW1=7;p.COLUMN2ROW2=8;Object.defineProperties(p.prototype,{length:{get:function(){return p.packedLength}}});p.prototype.clone=function(n){return p.clone(this,n)};p.prototype.equals=function(n){return p.equals(this,n)};p.equalsArray=function(n,o,e){return n[0]===o[e]&&n[1]===o[e+1]&&n[2]===o[e+2]&&n[3]===o[e+3]&&n[4]===o[e+4]&&n[5]===o[e+5]&&n[6]===o[e+6]&&n[7]===o[e+7]&&n[8]===o[e+8]};p.prototype.equalsEpsilon=function(n,o){return p.equalsEpsilon(this,n,o)};p.prototype.toString=function(){return`(${this[0]}, ${this[3]}, ${this[6]}) +(${this[1]}, ${this[4]}, ${this[7]}) +(${this[2]}, ${this[5]}, ${this[8]})`};var uo=p;export{O as a,on as b,fo as c,uo as d}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-DMHOSKRF.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-DMHOSKRF.js new file mode 100644 index 0000000000000000000000000000000000000000..d4c8391b11ffbbe05277c964d4ac784771adbfdd --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-DMHOSKRF.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as y}from"./chunk-YZMLQP2E.js";import{d as F}from"./chunk-NNIY7VTE.js";import{b as d,c as W,d as x}from"./chunk-5EDTRNG5.js";import{a as A}from"./chunk-IO6LETQ6.js";import{a as s,c as M}from"./chunk-C6Y3PRDH.js";import{a as q}from"./chunk-LI57NJAL.js";import{a as P}from"./chunk-P44SUSQU.js";import{b as z}from"./chunk-FUATUYJ3.js";import{e as u}from"./chunk-ODUTJJQ5.js";function T(o,t){z.typeOf.object("ellipsoid",o),this._ellipsoid=o,this._cameraPosition=new s,this._cameraPositionInScaledSpace=new s,this._distanceToLimbInScaledSpaceSquared=0,u(t)&&(this.cameraPosition=t)}Object.defineProperties(T.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},cameraPosition:{get:function(){return this._cameraPosition},set:function(o){let e=this._ellipsoid.transformPositionToScaledSpace(o,this._cameraPositionInScaledSpace),a=s.magnitudeSquared(e)-1;s.clone(o,this._cameraPosition),this._cameraPositionInScaledSpace=e,this._distanceToLimbInScaledSpaceSquared=a}}});var L=new s;T.prototype.isPointVisible=function(o){let e=this._ellipsoid.transformPositionToScaledSpace(o,L);return D(e,this._cameraPositionInScaledSpace,this._distanceToLimbInScaledSpaceSquared)};T.prototype.isScaledSpacePointVisible=function(o){return D(o,this._cameraPositionInScaledSpace,this._distanceToLimbInScaledSpaceSquared)};var et=new s;T.prototype.isScaledSpacePointVisiblePossiblyUnderEllipsoid=function(o,t){let e=this._ellipsoid,a,i;return u(t)&&t<0&&e.minimumRadius>-t?(i=et,i.x=this._cameraPosition.x/(e.radii.x+t),i.y=this._cameraPosition.y/(e.radii.y+t),i.z=this._cameraPosition.z/(e.radii.z+t),a=i.x*i.x+i.y*i.y+i.z*i.z-1):(i=this._cameraPositionInScaledSpace,a=this._distanceToLimbInScaledSpaceSquared),D(o,i,a)};T.prototype.computeHorizonCullingPoint=function(o,t,e){return Z(this._ellipsoid,o,t,e)};var j=M.clone(M.UNIT_SPHERE);T.prototype.computeHorizonCullingPointPossiblyUnderEllipsoid=function(o,t,e,a){let i=U(this._ellipsoid,e,j);return Z(i,o,t,a)};T.prototype.computeHorizonCullingPointFromVertices=function(o,t,e,a,i){return v(this._ellipsoid,o,t,e,a,i)};T.prototype.computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid=function(o,t,e,a,i,c){let n=U(this._ellipsoid,i,j);return v(n,o,t,e,a,c)};var it=[];T.prototype.computeHorizonCullingPointFromRectangle=function(o,t,e){z.typeOf.object("rectangle",o);let a=W.subsample(o,t,0,it),i=F.fromPoints(a);if(!(s.magnitude(i.center)<.1*t.minimumRadius))return this.computeHorizonCullingPoint(i.center,a,e)};var at=new s;function U(o,t,e){if(u(t)&&t<0&&o.minimumRadius>-t){let a=s.fromElements(o.radii.x+t,o.radii.y+t,o.radii.z+t,at);o=M.fromCartesian3(a,e)}return o}function Z(o,t,e,a){z.typeOf.object("directionToPoint",t),z.defined("positions",e),u(a)||(a=new s);let i=K(o,t),c=0;for(let n=0,r=e.length;n0:n>i&&n*n/s.magnitudeSquared(c)>i)}var nt=new s,st=new s;function Q(o,t,e){let a=o.transformPositionToScaledSpace(t,nt),i=s.magnitudeSquared(a),c=Math.sqrt(i),n=s.divideByScalar(a,c,st);i=Math.max(1,i),c=Math.max(1,c);let r=s.dot(n,e),m=s.magnitude(s.cross(n,e,n)),l=1/c,p=Math.sqrt(i-1)*l;return 1/(r*l-m*p)}function J(o,t,e){if(!(t<=0||t===1/0||t!==t))return s.multiplyByScalar(o,t,e)}var R=new s;function K(o,t){return s.equals(t,s.ZERO)?t:(o.transformPositionToScaledSpace(t,R),s.normalize(R,R))}var xt=T;var b={};b.getHeight=function(o,t,e){return(o-e)*t+e};var ct=new s;b.getPosition=function(o,t,e,a,i){let c=t.cartesianToCartographic(o,ct),n=b.getHeight(c.height,e,a);return s.fromRadians(c.longitude,c.latitude,n,t,i)};var X=b;var rt={NONE:0,BITS12:1},S=Object.freeze(rt);var C=new s,mt=new s,f=new x,G=new d,dt=new d,lt=Math.pow(2,12);function h(o,t,e,a,i,c,n,r,m,l){let p=S.NONE,g,N;if(u(t)&&u(e)&&u(a)&&u(i)){let E=t.minimum,I=t.maximum,_=s.subtract(I,E,mt),$=a-e;Math.max(s.maximumComponent(_),$)n.width?n.width=t:t<0&&(n.width-=t,n.x=h.x),c>n.height?n.height=c:c<0&&(n.height-=c,n.y=h.y),n};o.intersect=function(i,h){m.typeOf.object("left",i),m.typeOf.object("right",h);let n=i.x,t=i.y,c=h.x,e=h.y;return n>c+h.width||n+i.widthe+h.height?d.OUTSIDE:d.INTERSECTING};o.equals=function(i,h){return i===h||f(i)&&f(h)&&i.x===h.x&&i.y===h.y&&i.width===h.width&&i.height===h.height};o.prototype.clone=function(i){return o.clone(this,i)};o.prototype.intersect=function(i){return o.intersect(this,i)};o.prototype.equals=function(i){return o.equals(this,i)};var S=o;export{S as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-EX77JNA7.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-EX77JNA7.js new file mode 100644 index 0000000000000000000000000000000000000000..9d302d1f2b6d9a2aeae26c21be9d2c6e52f4aed8 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-EX77JNA7.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as z,c as q}from"./chunk-QA2UBISA.js";import{a as U}from"./chunk-U7I5YLBQ.js";import{f as I}from"./chunk-NNIY7VTE.js";import{a as e,d as C}from"./chunk-C6Y3PRDH.js";import{a as O}from"./chunk-LI57NJAL.js";import{e as j}from"./chunk-ODUTJJQ5.js";var G={},B=new e,J=new e,_=new e,v=new e,g=[new e,new e],K=new e,W=new e,X=new e,$=new e,ee=new e,te=new e,ne=new e,oe=new e,re=new e,se=new e,F=new I,k=new C;function V(o,s,a,c,r){let d=e.angleBetween(e.subtract(s,o,B),e.subtract(a,o,J)),y=c===z.BEVELED?1:Math.ceil(d/O.toRadians(5))+1,n=y*3,l=new Array(n);l[n-3]=a.x,l[n-2]=a.y,l[n-1]=a.z;let m;r?m=C.fromQuaternion(I.fromAxisAngle(e.negate(o,B),d/y,F),k):m=C.fromQuaternion(I.fromAxisAngle(o,d/y,F),k);let t=0;s=e.clone(s,B);for(let i=0;i=o)throw new r(`Expected ${t} to be less than ${o}, actual value was ${e}`)};n.typeOf.number.lessThanOrEquals=function(t,e,o){if(n.typeOf.number(t,e),e>o)throw new r(`Expected ${t} to be less than or equal to ${o}, actual value was ${e}`)};n.typeOf.number.greaterThan=function(t,e,o){if(n.typeOf.number(t,e),e<=o)throw new r(`Expected ${t} to be greater than ${o}, actual value was ${e}`)};n.typeOf.number.greaterThanOrEquals=function(t,e,o){if(n.typeOf.number(t,e),e1){let o=e[0].modelMatrix;for(c=1;c=0){let u=i[g];r=u.offset+u.count,o=u.index,c=t[o].indices.length}else r=0,o=0,c=t[o].indices.length;let s=e.length;for(let u=0;uc&&(r=0,c=t[++o].indices.length),i.push({index:o,offset:r,count:l}),r+=l}}function X(e,n){let t=[];return T(e,"geometry",n,t),T(e,"westHemisphereGeometry",n,t),T(e,"eastHemisphereGeometry",n,t),t}var S={};S.combineGeometry=function(e){let n,t,i=e.instances,r=i.length,c,o,g=!1;r>0&&(n=Q(e),n.length>0&&(t=b.createAttributeLocations(n[0]),e.createPickOffsets&&(c=X(i,n))),a(i[0].attributes)&&a(i[0].attributes.offset)&&(o=new Array(r),g=!0));let s=new Array(r),u=new Array(r);for(let m=0;m0&&(t.set(s.indices,o),o+=d)}return n.push(t.buffer),{stringTable:i,packedData:t}};S.unpackCreateGeometryResults=function(e){let n=e.stringTable,t=e.packedData,i,r=new Array(t[0]),c=0,o=1;for(;o0){let A=x.length/C;for(V=U.createTypedArray(A,h),i=0;in&&(n=p),++a,p=e[a]}let c=[];for(let a=0;as&&(c[e[a]]=o,++o);return(o-s+1)/(i/3)};Nt.tipsify=function(t){t=K(t,K.EMPTY_OBJECT);let e=t.indices,n=t.maximumIndex,s=K(t.cacheSize,24),i;function c(C,z,q,V){for(;z.length>=1;){let G=z[z.length-1];if(z.splice(z.length-1,1),C[G].numLiveTriangles>0)return G}for(;i0)return++i,i-1;++i}return-1}function o(C,z,q,V,G,M,J){let Y=-1,_,Pt=-1,gt=0;for(;gtPt||Pt===-1)&&(Pt=_,Y=ft)),++gt}return Y===-1?c(V,M,C,J):Y}if(!f(e))throw new I("indices is required.");let a=e.length;if(a<3||a%3!==0)throw new I("indices length must be a multiple of three.");if(n<=0)throw new I("maximumIndex must be greater than zero.");if(s<3)throw new I("cacheSize must be greater than two.");let p=0,u=0,d=e[u],m=a;if(f(n))p=n+1;else{for(;up&&(p=d),++u,d=e[u];if(p===-1)return 0;++p}let l=[],h;for(h=0;hs&&(w.timeStamp=b,++b),++u}v=o(e,s,S,l,b,x,p)}return P};var Wt=Nt;var F={};function St(t,e,n,s,i){t[e++]=n,t[e++]=s,t[e++]=s,t[e++]=i,t[e++]=i,t[e]=n}function de(t){let e=t.length,n=e/3*6,s=j.createTypedArray(e,n),i=0;for(let c=0;c=3){let n=(e-2)*6,s=j.createTypedArray(e,n);St(s,0,t[0],t[1],t[2]);let i=6;for(let c=3;c0){let e=t.length-1,n=(e-1)*6,s=j.createTypedArray(e,n),i=t[0],c=0;for(let o=1;oi&&(i=n[c]);t.indices=Wt.tipsify({indices:n,maximumIndex:i,cacheSize:e})}return t};function $t(t){let e={};for(let n in t)if(t.hasOwnProperty(n)&&f(t[n])&&f(t[n].values)){let s=t[n];e[n]=new U({componentDatatype:s.componentDatatype,componentsPerAttribute:s.componentsPerAttribute,normalize:s.normalize,values:[]})}return e}function be(t,e,n){for(let s in e)if(e.hasOwnProperty(s)&&f(e[s])&&f(e[s].values)){let i=e[s];for(let c=0;c=N.SIXTY_FOUR_KILOBYTES){let s=[],i=[],c=0,o=$t(t.attributes),a=t.indices,p=a.length,u;t.primitiveType===D.TRIANGLES?u=3:t.primitiveType===D.LINES?u=2:t.primitiveType===D.POINTS&&(u=1);for(let d=0;d=N.SIXTY_FOUR_KILOBYTES&&(e.push(new B({attributes:o,indices:i,primitiveType:t.primitiveType,boundingSphere:t.boundingSphere,boundingSphereCV:t.boundingSphereCV})),s=[],i=[],c=0,o=$t(t.attributes))}i.length!==0&&e.push(new B({attributes:o,indices:i,primitiveType:t.primitiveType,boundingSphere:t.boundingSphere,boundingSphereCV:t.boundingSphereCV}))}else e.push(t);return e};var Jt=new r,we=new Mt;F.projectTo2D=function(t,e,n,s,i){if(!f(t))throw new I("geometry is required.");if(!f(e))throw new I("attributeName is required.");if(!f(n))throw new I("attributeName3D is required.");if(!f(s))throw new I("attributeName2D is required.");if(!f(t.attributes[e]))throw new I(`geometry must have attribute matching the attributeName argument: ${e}.`);if(t.attributes[e].componentDatatype!==k.DOUBLE)throw new I("The attribute componentDatatype must be ComponentDatatype.DOUBLE.");let c=t.attributes[e];i=f(i)?i:new _t;let o=i.ellipsoid,a=c.values,p=new Float64Array(a.length),u=0;for(let d=0;db&&(b=x)}return new B({attributes:d,indices:y,primitiveType:u,boundingSphere:f(v)?new rt(v,b):void 0})}F.combineInstances=function(t){if(!f(t)||t.length<1)throw new I("instances is required and must have length greater than zero.");let e=[],n=[],s=t.length;for(let c=0;c0&&i.push(Vt(e,"geometry")),n.length>0&&(i.push(Vt(n,"westHemisphereGeometry")),i.push(Vt(n,"eastHemisphereGeometry"))),i};var Z=new r,ht=new r,ct=new r,at=new r;F.computeNormal=function(t){if(!f(t))throw new I("geometry is required.");if(!f(t.attributes.position)||!f(t.attributes.position.values))throw new I("geometry.attributes.position.values is required.");if(!f(t.indices))throw new I("geometry.indices is required.");if(t.indices.length<2||t.indices.length%3!==0)throw new I("geometry.indices length must be greater than 0 and be a multiple of 3.");if(t.primitiveType!==D.TRIANGLES)throw new I("geometry.primitiveType must be PrimitiveType.TRIANGLES.");let e=t.indices,n=t.attributes,s=n.position.values,i=n.position.values.length/3,c=e.length,o=new Array(i),a=new Array(c/3),p=new Array(c),u;for(u=0;u0){for(d=0;d3&&(n[3]=0,n[4]=2,n[5]=3);let s=6;for(let i=3;ii?s>c?o=N.sign(t.y):o=N.sign(n.y):i>c?o=N.sign(e.y):o=N.sign(n.y);let a=o<0;tt(t,a),tt(e,a),tt(n,a)}var ee=new r;function X(t,e,n,s){r.add(t,r.multiplyByScalar(r.subtract(e,t,ee),t.y/(t.y-e.y),ee),n),r.clone(n,s),tt(n,!0),tt(s,!1)}var nt=new r,it=new r,st=new r,ot=new r,Rt={positions:new Array(7),indices:new Array(3*3)};function Ne(t,e,n){if(t.x>=0||e.x>=0||n.x>=0)return;Ee(t,e,n);let s=t.y<0,i=e.y<0,c=n.y<0,o=0;o+=s?1:0,o+=i?1:0,o+=c?1:0;let a=Rt.indices;o===1?(a[1]=3,a[2]=4,a[5]=6,a[7]=6,a[8]=5,s?(X(t,e,nt,st),X(t,n,it,ot),a[0]=0,a[3]=1,a[4]=2,a[6]=1):i?(X(e,n,nt,st),X(e,t,it,ot),a[0]=1,a[3]=2,a[4]=0,a[6]=2):c&&(X(n,t,nt,st),X(n,e,it,ot),a[0]=2,a[3]=0,a[4]=1,a[6]=0)):o===2&&(a[2]=4,a[4]=4,a[5]=3,a[7]=5,a[8]=6,s?i?c||(X(n,t,nt,st),X(n,e,it,ot),a[0]=0,a[1]=1,a[3]=0,a[6]=2):(X(e,n,nt,st),X(e,t,it,ot),a[0]=2,a[1]=0,a[3]=2,a[6]=1):(X(t,e,nt,st),X(t,n,it,ot),a[0]=1,a[1]=2,a[3]=1,a[6]=0));let p=Rt.positions;return p[0]=t,p[1]=e,p[2]=n,p.length=3,(o===1||o===2)&&(p[3]=nt,p[4]=it,p[5]=st,p[6]=ot,p.length=7),Rt}function ne(t,e){let n=t.attributes;if(n.position.values.length===0)return;for(let i in n)if(n.hasOwnProperty(i)&&f(n[i])&&f(n[i].values)){let c=n[i];c.values=k.createTypedArray(c.componentDatatype,c.values)}let s=B.computeNumberOfVertices(t);return t.indices=j.createTypedArray(s,t.indices),e&&(t.boundingSphere=rt.fromVertices(n.position.values)),t}function lt(t){let e=t.attributes,n={};for(let s in e)if(e.hasOwnProperty(s)&&f(e[s])&&f(e[s].values)){let i=e[s];n[s]=new U({componentDatatype:i.componentDatatype,componentsPerAttribute:i.componentsPerAttribute,normalize:i.normalize,values:[]})}return new B({attributes:n,indices:[],primitiveType:t.primitiveType})}function kt(t,e,n){let s=f(t.geometry.boundingSphere);e=ne(e,s),n=ne(n,s),f(n)&&!f(e)?t.geometry=n:!f(n)&&f(e)?t.geometry=e:(t.westHemisphereGeometry=e,t.eastHemisphereGeometry=n,t.geometry=void 0)}function Ft(t,e){let n=new t,s=new t,i=new t;return function(c,o,a,p,u,d,m,l){let h=t.fromArray(u,c*e,n),y=t.fromArray(u,o*e,s),v=t.fromArray(u,a*e,i);t.multiplyByScalar(h,p.x,h),t.multiplyByScalar(y,p.y,y),t.multiplyByScalar(v,p.z,v);let b=t.add(h,y,h);t.add(b,v,b),l&&t.normalize(b,b),t.pack(b,d,m*e)}}var ze=Ft(dt,4),It=Ft(r,3),ae=Ft(R,2),De=function(t,e,n,s,i,c,o){let a=i[t]*s.x,p=i[e]*s.y,u=i[n]*s.z;c[o]=a+p+u>N.EPSILON6?1:0},wt=new r,Gt=new r,Ct=new r,qe=new r;function Tt(t,e,n,s,i,c,o,a,p,u,d,m,l,h,y,v){if(!f(c)&&!f(o)&&!f(a)&&!f(p)&&!f(u)&&h===0)return;let b=r.fromArray(i,t*3,wt),S=r.fromArray(i,e*3,Gt),x=r.fromArray(i,n*3,Ct),w=Ht(s,b,S,x,qe);if(f(w)){if(f(c)&&It(t,e,n,w,c,m.normal.values,v,!0),f(u)){let A=r.fromArray(u,t*3,wt),E=r.fromArray(u,e*3,Gt),P=r.fromArray(u,n*3,Ct);r.multiplyByScalar(A,w.x,A),r.multiplyByScalar(E,w.y,E),r.multiplyByScalar(P,w.z,P);let O;!r.equals(A,r.ZERO)||!r.equals(E,r.ZERO)||!r.equals(P,r.ZERO)?(O=r.add(A,E,A),r.add(O,P,O),r.normalize(O,O)):(O=wt,O.x=0,O.y=0,O.z=0),r.pack(O,m.extrudeDirection.values,v*3)}if(f(d)&&De(t,e,n,w,d,m.applyOffset.values,v),f(o)&&It(t,e,n,w,o,m.tangent.values,v,!0),f(a)&&It(t,e,n,w,a,m.bitangent.values,v,!0),f(p)&&ae(t,e,n,w,p,m.st.values,v),h>0)for(let A=0;A3){let V=q.positions,G=q.indices,M=G.length;for(let J=0;J0)continue;let p=r.unpack(s,o,fe);(a.y<0&&p.y>0||a.y>0&&p.y<0)&&(o-3>0?(s[o]=n[o-3],s[o+1]=n[o-2],s[o+2]=n[o-1]):r.pack(a,s,o));let u=r.unpack(i,o,Bt);(a.y<0&&u.y>0||a.y>0&&u.y<0)&&(o+30||rt.intersectPlane(n,Et.ORIGIN_ZX_PLANE)!==Ut.INTERSECTING))return t;if(e.geometryType!==mt.NONE)switch(e.geometryType){case mt.POLYLINES:Ue(t);break;case mt.TRIANGLES:ie(t);break;case mt.LINES:se(t);break}else Le(e),e.primitiveType===D.TRIANGLES?ie(t):e.primitiveType===D.LINES&&se(t);return t};var gn=F;export{gn as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-GSCCE6TP.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-GSCCE6TP.js new file mode 100644 index 0000000000000000000000000000000000000000..e8513c2d4fded06882e0cef5761415e204d7bdfc --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-GSCCE6TP.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{b as t}from"./chunk-5EDTRNG5.js";import{a as r}from"./chunk-P44SUSQU.js";import{a as m}from"./chunk-FUATUYJ3.js";import{e as i}from"./chunk-ODUTJJQ5.js";function d(e){if(e=r(e,r.EMPTY_OBJECT),!i(e.geometry))throw new m("options.geometry is required.");this.geometry=e.geometry,this.modelMatrix=t.clone(r(e.modelMatrix,t.IDENTITY)),this.id=e.id,this.pickPrimitive=e.pickPrimitive,this.attributes=r(e.attributes,{}),this.westHemisphereGeometry=void 0,this.eastHemisphereGeometry=void 0}var s=d;export{s as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-HYO3T7II.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-HYO3T7II.js new file mode 100644 index 0000000000000000000000000000000000000000..09eedbca3c57e255c583273c1bd84d8fefccffe9 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-HYO3T7II.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as b}from"./chunk-YYCOBWZH.js";import{a as u}from"./chunk-M3OLDEEW.js";import{a as O}from"./chunk-FUN3J34G.js";import{b as w,c as h,d as x}from"./chunk-A4RD4IQP.js";import{d}from"./chunk-NNIY7VTE.js";import{a as y}from"./chunk-IO6LETQ6.js";import{a as i}from"./chunk-C6Y3PRDH.js";import{a as p}from"./chunk-P44SUSQU.js";import{a as z,b as c}from"./chunk-FUATUYJ3.js";import{e as A}from"./chunk-ODUTJJQ5.js";var D=new i;function f(r){r=p(r,p.EMPTY_OBJECT);let o=r.minimum,m=r.maximum;if(c.typeOf.object("min",o),c.typeOf.object("max",m),A(r.offsetAttribute)&&r.offsetAttribute===b.TOP)throw new z("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");let a=p(r.vertexFormat,u.DEFAULT);this._minimum=i.clone(o),this._maximum=i.clone(m),this._vertexFormat=a,this._offsetAttribute=r.offsetAttribute,this._workerName="createBoxGeometry"}f.fromDimensions=function(r){r=p(r,p.EMPTY_OBJECT);let o=r.dimensions;c.typeOf.object("dimensions",o),c.typeOf.number.greaterThanOrEquals("dimensions.x",o.x,0),c.typeOf.number.greaterThanOrEquals("dimensions.y",o.y,0),c.typeOf.number.greaterThanOrEquals("dimensions.z",o.z,0);let m=i.multiplyByScalar(o,.5,new i);return new f({minimum:i.negate(m,new i),maximum:m,vertexFormat:r.vertexFormat,offsetAttribute:r.offsetAttribute})};f.fromAxisAlignedBoundingBox=function(r){return c.typeOf.object("boundingBox",r),new f({minimum:r.minimum,maximum:r.maximum})};f.packedLength=2*i.packedLength+u.packedLength+1;f.pack=function(r,o,m){return c.typeOf.object("value",r),c.defined("array",o),m=p(m,0),i.pack(r._minimum,o,m),i.pack(r._maximum,o,m+i.packedLength),u.pack(r._vertexFormat,o,m+2*i.packedLength),o[m+2*i.packedLength+u.packedLength]=p(r._offsetAttribute,-1),o};var _=new i,g=new i,k=new u,F={minimum:_,maximum:g,vertexFormat:k,offsetAttribute:void 0};f.unpack=function(r,o,m){c.defined("array",r),o=p(o,0);let a=i.unpack(r,o,_),s=i.unpack(r,o+i.packedLength,g),n=u.unpack(r,o+2*i.packedLength,k),e=r[o+2*i.packedLength+u.packedLength];return A(m)?(m._minimum=i.clone(a,m._minimum),m._maximum=i.clone(s,m._maximum),m._vertexFormat=u.clone(n,m._vertexFormat),m._offsetAttribute=e===-1?void 0:e,m):(F.offsetAttribute=e===-1?void 0:e,new f(F))};f.createGeometry=function(r){let o=r._minimum,m=r._maximum,a=r._vertexFormat;if(i.equals(o,m))return;let s=new O,n,e;if(a.position&&(a.st||a.normal||a.tangent||a.bitangent)){if(a.position&&(e=new Float64Array(6*4*3),e[0]=o.x,e[1]=o.y,e[2]=m.z,e[3]=m.x,e[4]=o.y,e[5]=m.z,e[6]=m.x,e[7]=m.y,e[8]=m.z,e[9]=o.x,e[10]=m.y,e[11]=m.z,e[12]=o.x,e[13]=o.y,e[14]=o.z,e[15]=m.x,e[16]=o.y,e[17]=o.z,e[18]=m.x,e[19]=m.y,e[20]=o.z,e[21]=o.x,e[22]=m.y,e[23]=o.z,e[24]=m.x,e[25]=o.y,e[26]=o.z,e[27]=m.x,e[28]=m.y,e[29]=o.z,e[30]=m.x,e[31]=m.y,e[32]=m.z,e[33]=m.x,e[34]=o.y,e[35]=m.z,e[36]=o.x,e[37]=o.y,e[38]=o.z,e[39]=o.x,e[40]=m.y,e[41]=o.z,e[42]=o.x,e[43]=m.y,e[44]=m.z,e[45]=o.x,e[46]=o.y,e[47]=m.z,e[48]=o.x,e[49]=m.y,e[50]=o.z,e[51]=m.x,e[52]=m.y,e[53]=o.z,e[54]=m.x,e[55]=m.y,e[56]=m.z,e[57]=o.x,e[58]=m.y,e[59]=m.z,e[60]=o.x,e[61]=o.y,e[62]=o.z,e[63]=m.x,e[64]=o.y,e[65]=o.z,e[66]=m.x,e[67]=o.y,e[68]=m.z,e[69]=o.x,e[70]=o.y,e[71]=m.z,s.position=new x({componentDatatype:y.DOUBLE,componentsPerAttribute:3,values:e})),a.normal){let t=new Float32Array(72);t[0]=0,t[1]=0,t[2]=1,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=1,t[9]=0,t[10]=0,t[11]=1,t[12]=0,t[13]=0,t[14]=-1,t[15]=0,t[16]=0,t[17]=-1,t[18]=0,t[19]=0,t[20]=-1,t[21]=0,t[22]=0,t[23]=-1,t[24]=1,t[25]=0,t[26]=0,t[27]=1,t[28]=0,t[29]=0,t[30]=1,t[31]=0,t[32]=0,t[33]=1,t[34]=0,t[35]=0,t[36]=-1,t[37]=0,t[38]=0,t[39]=-1,t[40]=0,t[41]=0,t[42]=-1,t[43]=0,t[44]=0,t[45]=-1,t[46]=0,t[47]=0,t[48]=0,t[49]=1,t[50]=0,t[51]=0,t[52]=1,t[53]=0,t[54]=0,t[55]=1,t[56]=0,t[57]=0,t[58]=1,t[59]=0,t[60]=0,t[61]=-1,t[62]=0,t[63]=0,t[64]=-1,t[65]=0,t[66]=0,t[67]=-1,t[68]=0,t[69]=0,t[70]=-1,t[71]=0,s.normal=new x({componentDatatype:y.FLOAT,componentsPerAttribute:3,values:t})}if(a.st){let t=new Float32Array(48);t[0]=0,t[1]=0,t[2]=1,t[3]=0,t[4]=1,t[5]=1,t[6]=0,t[7]=1,t[8]=1,t[9]=0,t[10]=0,t[11]=0,t[12]=0,t[13]=1,t[14]=1,t[15]=1,t[16]=0,t[17]=0,t[18]=1,t[19]=0,t[20]=1,t[21]=1,t[22]=0,t[23]=1,t[24]=1,t[25]=0,t[26]=0,t[27]=0,t[28]=0,t[29]=1,t[30]=1,t[31]=1,t[32]=1,t[33]=0,t[34]=0,t[35]=0,t[36]=0,t[37]=1,t[38]=1,t[39]=1,t[40]=0,t[41]=0,t[42]=1,t[43]=0,t[44]=1,t[45]=1,t[46]=0,t[47]=1,s.st=new x({componentDatatype:y.FLOAT,componentsPerAttribute:2,values:t})}if(a.tangent){let t=new Float32Array(72);t[0]=1,t[1]=0,t[2]=0,t[3]=1,t[4]=0,t[5]=0,t[6]=1,t[7]=0,t[8]=0,t[9]=1,t[10]=0,t[11]=0,t[12]=-1,t[13]=0,t[14]=0,t[15]=-1,t[16]=0,t[17]=0,t[18]=-1,t[19]=0,t[20]=0,t[21]=-1,t[22]=0,t[23]=0,t[24]=0,t[25]=1,t[26]=0,t[27]=0,t[28]=1,t[29]=0,t[30]=0,t[31]=1,t[32]=0,t[33]=0,t[34]=1,t[35]=0,t[36]=0,t[37]=-1,t[38]=0,t[39]=0,t[40]=-1,t[41]=0,t[42]=0,t[43]=-1,t[44]=0,t[45]=0,t[46]=-1,t[47]=0,t[48]=-1,t[49]=0,t[50]=0,t[51]=-1,t[52]=0,t[53]=0,t[54]=-1,t[55]=0,t[56]=0,t[57]=-1,t[58]=0,t[59]=0,t[60]=1,t[61]=0,t[62]=0,t[63]=1,t[64]=0,t[65]=0,t[66]=1,t[67]=0,t[68]=0,t[69]=1,t[70]=0,t[71]=0,s.tangent=new x({componentDatatype:y.FLOAT,componentsPerAttribute:3,values:t})}if(a.bitangent){let t=new Float32Array(72);t[0]=0,t[1]=1,t[2]=0,t[3]=0,t[4]=1,t[5]=0,t[6]=0,t[7]=1,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=0,t[13]=1,t[14]=0,t[15]=0,t[16]=1,t[17]=0,t[18]=0,t[19]=1,t[20]=0,t[21]=0,t[22]=1,t[23]=0,t[24]=0,t[25]=0,t[26]=1,t[27]=0,t[28]=0,t[29]=1,t[30]=0,t[31]=0,t[32]=1,t[33]=0,t[34]=0,t[35]=1,t[36]=0,t[37]=0,t[38]=1,t[39]=0,t[40]=0,t[41]=1,t[42]=0,t[43]=0,t[44]=1,t[45]=0,t[46]=0,t[47]=1,t[48]=0,t[49]=0,t[50]=1,t[51]=0,t[52]=0,t[53]=1,t[54]=0,t[55]=0,t[56]=1,t[57]=0,t[58]=0,t[59]=1,t[60]=0,t[61]=0,t[62]=1,t[63]=0,t[64]=0,t[65]=1,t[66]=0,t[67]=0,t[68]=1,t[69]=0,t[70]=0,t[71]=1,s.bitangent=new x({componentDatatype:y.FLOAT,componentsPerAttribute:3,values:t})}n=new Uint16Array(6*2*3),n[0]=0,n[1]=1,n[2]=2,n[3]=0,n[4]=2,n[5]=3,n[6]=4+2,n[7]=4+1,n[8]=4+0,n[9]=4+3,n[10]=4+2,n[11]=4+0,n[12]=8+0,n[13]=8+1,n[14]=8+2,n[15]=8+0,n[16]=8+2,n[17]=8+3,n[18]=12+2,n[19]=12+1,n[20]=12+0,n[21]=12+3,n[22]=12+2,n[23]=12+0,n[24]=16+2,n[25]=16+1,n[26]=16+0,n[27]=16+3,n[28]=16+2,n[29]=16+0,n[30]=20+0,n[31]=20+1,n[32]=20+2,n[33]=20+0,n[34]=20+2,n[35]=20+3}else e=new Float64Array(8*3),e[0]=o.x,e[1]=o.y,e[2]=o.z,e[3]=m.x,e[4]=o.y,e[5]=o.z,e[6]=m.x,e[7]=m.y,e[8]=o.z,e[9]=o.x,e[10]=m.y,e[11]=o.z,e[12]=o.x,e[13]=o.y,e[14]=m.z,e[15]=m.x,e[16]=o.y,e[17]=m.z,e[18]=m.x,e[19]=m.y,e[20]=m.z,e[21]=o.x,e[22]=m.y,e[23]=m.z,s.position=new x({componentDatatype:y.DOUBLE,componentsPerAttribute:3,values:e}),n=new Uint16Array(6*2*3),n[0]=4,n[1]=5,n[2]=6,n[3]=4,n[4]=6,n[5]=7,n[6]=1,n[7]=0,n[8]=3,n[9]=1,n[10]=3,n[11]=2,n[12]=1,n[13]=6,n[14]=5,n[15]=1,n[16]=2,n[17]=6,n[18]=2,n[19]=3,n[20]=7,n[21]=2,n[22]=7,n[23]=6,n[24]=3,n[25]=0,n[26]=4,n[27]=3,n[28]=4,n[29]=7,n[30]=0,n[31]=1,n[32]=5,n[33]=0,n[34]=5,n[35]=4;let v=i.subtract(m,o,D),L=i.magnitude(v)*.5;if(A(r._offsetAttribute)){let t=e.length,T=r._offsetAttribute===b.NONE?0:1,E=new Uint8Array(t/3).fill(T);s.applyOffset=new x({componentDatatype:y.UNSIGNED_BYTE,componentsPerAttribute:1,values:E})}return new h({attributes:s,indices:n,primitiveType:w.TRIANGLES,boundingSphere:new d(i.ZERO,L),offsetAttribute:r._offsetAttribute})};var l;f.getUnitBox=function(){return A(l)||(l=f.createGeometry(f.fromDimensions({dimensions:new i(1,1,1),vertexFormat:u.POSITION_ONLY}))),l};var R=f;export{R as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-IBAO62UG.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-IBAO62UG.js new file mode 100644 index 0000000000000000000000000000000000000000..5e293fb7a5ceef1b51bd33692a3db4196f926c76 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-IBAO62UG.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +var E={DEPTH_BUFFER_BIT:256,STENCIL_BUFFER_BIT:1024,COLOR_BUFFER_BIT:16384,POINTS:0,LINES:1,LINE_LOOP:2,LINE_STRIP:3,TRIANGLES:4,TRIANGLE_STRIP:5,TRIANGLE_FAN:6,ZERO:0,ONE:1,SRC_COLOR:768,ONE_MINUS_SRC_COLOR:769,SRC_ALPHA:770,ONE_MINUS_SRC_ALPHA:771,DST_ALPHA:772,ONE_MINUS_DST_ALPHA:773,DST_COLOR:774,ONE_MINUS_DST_COLOR:775,SRC_ALPHA_SATURATE:776,FUNC_ADD:32774,BLEND_EQUATION:32777,BLEND_EQUATION_RGB:32777,BLEND_EQUATION_ALPHA:34877,FUNC_SUBTRACT:32778,FUNC_REVERSE_SUBTRACT:32779,BLEND_DST_RGB:32968,BLEND_SRC_RGB:32969,BLEND_DST_ALPHA:32970,BLEND_SRC_ALPHA:32971,CONSTANT_COLOR:32769,ONE_MINUS_CONSTANT_COLOR:32770,CONSTANT_ALPHA:32771,ONE_MINUS_CONSTANT_ALPHA:32772,BLEND_COLOR:32773,ARRAY_BUFFER:34962,ELEMENT_ARRAY_BUFFER:34963,ARRAY_BUFFER_BINDING:34964,ELEMENT_ARRAY_BUFFER_BINDING:34965,STREAM_DRAW:35040,STATIC_DRAW:35044,DYNAMIC_DRAW:35048,BUFFER_SIZE:34660,BUFFER_USAGE:34661,CURRENT_VERTEX_ATTRIB:34342,FRONT:1028,BACK:1029,FRONT_AND_BACK:1032,CULL_FACE:2884,BLEND:3042,DITHER:3024,STENCIL_TEST:2960,DEPTH_TEST:2929,SCISSOR_TEST:3089,POLYGON_OFFSET_FILL:32823,SAMPLE_ALPHA_TO_COVERAGE:32926,SAMPLE_COVERAGE:32928,NO_ERROR:0,INVALID_ENUM:1280,INVALID_VALUE:1281,INVALID_OPERATION:1282,OUT_OF_MEMORY:1285,CW:2304,CCW:2305,LINE_WIDTH:2849,ALIASED_POINT_SIZE_RANGE:33901,ALIASED_LINE_WIDTH_RANGE:33902,CULL_FACE_MODE:2885,FRONT_FACE:2886,DEPTH_RANGE:2928,DEPTH_WRITEMASK:2930,DEPTH_CLEAR_VALUE:2931,DEPTH_FUNC:2932,STENCIL_CLEAR_VALUE:2961,STENCIL_FUNC:2962,STENCIL_FAIL:2964,STENCIL_PASS_DEPTH_FAIL:2965,STENCIL_PASS_DEPTH_PASS:2966,STENCIL_REF:2967,STENCIL_VALUE_MASK:2963,STENCIL_WRITEMASK:2968,STENCIL_BACK_FUNC:34816,STENCIL_BACK_FAIL:34817,STENCIL_BACK_PASS_DEPTH_FAIL:34818,STENCIL_BACK_PASS_DEPTH_PASS:34819,STENCIL_BACK_REF:36003,STENCIL_BACK_VALUE_MASK:36004,STENCIL_BACK_WRITEMASK:36005,VIEWPORT:2978,SCISSOR_BOX:3088,COLOR_CLEAR_VALUE:3106,COLOR_WRITEMASK:3107,UNPACK_ALIGNMENT:3317,PACK_ALIGNMENT:3333,MAX_TEXTURE_SIZE:3379,MAX_VIEWPORT_DIMS:3386,SUBPIXEL_BITS:3408,RED_BITS:3410,GREEN_BITS:3411,BLUE_BITS:3412,ALPHA_BITS:3413,DEPTH_BITS:3414,STENCIL_BITS:3415,POLYGON_OFFSET_UNITS:10752,POLYGON_OFFSET_FACTOR:32824,TEXTURE_BINDING_2D:32873,SAMPLE_BUFFERS:32936,SAMPLES:32937,SAMPLE_COVERAGE_VALUE:32938,SAMPLE_COVERAGE_INVERT:32939,COMPRESSED_TEXTURE_FORMATS:34467,DONT_CARE:4352,FASTEST:4353,NICEST:4354,GENERATE_MIPMAP_HINT:33170,BYTE:5120,UNSIGNED_BYTE:5121,SHORT:5122,UNSIGNED_SHORT:5123,INT:5124,UNSIGNED_INT:5125,FLOAT:5126,DEPTH_COMPONENT:6402,ALPHA:6406,RGB:6407,RGBA:6408,LUMINANCE:6409,LUMINANCE_ALPHA:6410,UNSIGNED_SHORT_4_4_4_4:32819,UNSIGNED_SHORT_5_5_5_1:32820,UNSIGNED_SHORT_5_6_5:33635,FRAGMENT_SHADER:35632,VERTEX_SHADER:35633,MAX_VERTEX_ATTRIBS:34921,MAX_VERTEX_UNIFORM_VECTORS:36347,MAX_VARYING_VECTORS:36348,MAX_COMBINED_TEXTURE_IMAGE_UNITS:35661,MAX_VERTEX_TEXTURE_IMAGE_UNITS:35660,MAX_TEXTURE_IMAGE_UNITS:34930,MAX_FRAGMENT_UNIFORM_VECTORS:36349,SHADER_TYPE:35663,DELETE_STATUS:35712,LINK_STATUS:35714,VALIDATE_STATUS:35715,ATTACHED_SHADERS:35717,ACTIVE_UNIFORMS:35718,ACTIVE_ATTRIBUTES:35721,SHADING_LANGUAGE_VERSION:35724,CURRENT_PROGRAM:35725,NEVER:512,LESS:513,EQUAL:514,LEQUAL:515,GREATER:516,NOTEQUAL:517,GEQUAL:518,ALWAYS:519,KEEP:7680,REPLACE:7681,INCR:7682,DECR:7683,INVERT:5386,INCR_WRAP:34055,DECR_WRAP:34056,VENDOR:7936,RENDERER:7937,VERSION:7938,NEAREST:9728,LINEAR:9729,NEAREST_MIPMAP_NEAREST:9984,LINEAR_MIPMAP_NEAREST:9985,NEAREST_MIPMAP_LINEAR:9986,LINEAR_MIPMAP_LINEAR:9987,TEXTURE_MAG_FILTER:10240,TEXTURE_MIN_FILTER:10241,TEXTURE_WRAP_S:10242,TEXTURE_WRAP_T:10243,TEXTURE_2D:3553,TEXTURE:5890,TEXTURE_CUBE_MAP:34067,TEXTURE_BINDING_CUBE_MAP:34068,TEXTURE_CUBE_MAP_POSITIVE_X:34069,TEXTURE_CUBE_MAP_NEGATIVE_X:34070,TEXTURE_CUBE_MAP_POSITIVE_Y:34071,TEXTURE_CUBE_MAP_NEGATIVE_Y:34072,TEXTURE_CUBE_MAP_POSITIVE_Z:34073,TEXTURE_CUBE_MAP_NEGATIVE_Z:34074,MAX_CUBE_MAP_TEXTURE_SIZE:34076,TEXTURE0:33984,TEXTURE1:33985,TEXTURE2:33986,TEXTURE3:33987,TEXTURE4:33988,TEXTURE5:33989,TEXTURE6:33990,TEXTURE7:33991,TEXTURE8:33992,TEXTURE9:33993,TEXTURE10:33994,TEXTURE11:33995,TEXTURE12:33996,TEXTURE13:33997,TEXTURE14:33998,TEXTURE15:33999,TEXTURE16:34e3,TEXTURE17:34001,TEXTURE18:34002,TEXTURE19:34003,TEXTURE20:34004,TEXTURE21:34005,TEXTURE22:34006,TEXTURE23:34007,TEXTURE24:34008,TEXTURE25:34009,TEXTURE26:34010,TEXTURE27:34011,TEXTURE28:34012,TEXTURE29:34013,TEXTURE30:34014,TEXTURE31:34015,ACTIVE_TEXTURE:34016,REPEAT:10497,CLAMP_TO_EDGE:33071,MIRRORED_REPEAT:33648,FLOAT_VEC2:35664,FLOAT_VEC3:35665,FLOAT_VEC4:35666,INT_VEC2:35667,INT_VEC3:35668,INT_VEC4:35669,BOOL:35670,BOOL_VEC2:35671,BOOL_VEC3:35672,BOOL_VEC4:35673,FLOAT_MAT2:35674,FLOAT_MAT3:35675,FLOAT_MAT4:35676,SAMPLER_2D:35678,SAMPLER_CUBE:35680,VERTEX_ATTRIB_ARRAY_ENABLED:34338,VERTEX_ATTRIB_ARRAY_SIZE:34339,VERTEX_ATTRIB_ARRAY_STRIDE:34340,VERTEX_ATTRIB_ARRAY_TYPE:34341,VERTEX_ATTRIB_ARRAY_NORMALIZED:34922,VERTEX_ATTRIB_ARRAY_POINTER:34373,VERTEX_ATTRIB_ARRAY_BUFFER_BINDING:34975,IMPLEMENTATION_COLOR_READ_TYPE:35738,IMPLEMENTATION_COLOR_READ_FORMAT:35739,COMPILE_STATUS:35713,LOW_FLOAT:36336,MEDIUM_FLOAT:36337,HIGH_FLOAT:36338,LOW_INT:36339,MEDIUM_INT:36340,HIGH_INT:36341,FRAMEBUFFER:36160,RENDERBUFFER:36161,RGBA4:32854,RGB5_A1:32855,RGB565:36194,DEPTH_COMPONENT16:33189,STENCIL_INDEX:6401,STENCIL_INDEX8:36168,DEPTH_STENCIL:34041,RENDERBUFFER_WIDTH:36162,RENDERBUFFER_HEIGHT:36163,RENDERBUFFER_INTERNAL_FORMAT:36164,RENDERBUFFER_RED_SIZE:36176,RENDERBUFFER_GREEN_SIZE:36177,RENDERBUFFER_BLUE_SIZE:36178,RENDERBUFFER_ALPHA_SIZE:36179,RENDERBUFFER_DEPTH_SIZE:36180,RENDERBUFFER_STENCIL_SIZE:36181,FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE:36048,FRAMEBUFFER_ATTACHMENT_OBJECT_NAME:36049,FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL:36050,FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE:36051,COLOR_ATTACHMENT0:36064,DEPTH_ATTACHMENT:36096,STENCIL_ATTACHMENT:36128,DEPTH_STENCIL_ATTACHMENT:33306,NONE:0,FRAMEBUFFER_COMPLETE:36053,FRAMEBUFFER_INCOMPLETE_ATTACHMENT:36054,FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT:36055,FRAMEBUFFER_INCOMPLETE_DIMENSIONS:36057,FRAMEBUFFER_UNSUPPORTED:36061,FRAMEBUFFER_BINDING:36006,RENDERBUFFER_BINDING:36007,MAX_RENDERBUFFER_SIZE:34024,INVALID_FRAMEBUFFER_OPERATION:1286,UNPACK_FLIP_Y_WEBGL:37440,UNPACK_PREMULTIPLY_ALPHA_WEBGL:37441,CONTEXT_LOST_WEBGL:37442,UNPACK_COLORSPACE_CONVERSION_WEBGL:37443,BROWSER_DEFAULT_WEBGL:37444,COMPRESSED_RGB_S3TC_DXT1_EXT:33776,COMPRESSED_RGBA_S3TC_DXT1_EXT:33777,COMPRESSED_RGBA_S3TC_DXT3_EXT:33778,COMPRESSED_RGBA_S3TC_DXT5_EXT:33779,COMPRESSED_RGB_PVRTC_4BPPV1_IMG:35840,COMPRESSED_RGB_PVRTC_2BPPV1_IMG:35841,COMPRESSED_RGBA_PVRTC_4BPPV1_IMG:35842,COMPRESSED_RGBA_PVRTC_2BPPV1_IMG:35843,COMPRESSED_RGBA_ASTC_4x4_WEBGL:37808,COMPRESSED_RGB_ETC1_WEBGL:36196,COMPRESSED_RGBA_BPTC_UNORM:36492,HALF_FLOAT_OES:36193,DOUBLE:5130,READ_BUFFER:3074,UNPACK_ROW_LENGTH:3314,UNPACK_SKIP_ROWS:3315,UNPACK_SKIP_PIXELS:3316,PACK_ROW_LENGTH:3330,PACK_SKIP_ROWS:3331,PACK_SKIP_PIXELS:3332,COLOR:6144,DEPTH:6145,STENCIL:6146,RED:6403,RGB8:32849,RGBA8:32856,RGB10_A2:32857,TEXTURE_BINDING_3D:32874,UNPACK_SKIP_IMAGES:32877,UNPACK_IMAGE_HEIGHT:32878,TEXTURE_3D:32879,TEXTURE_WRAP_R:32882,MAX_3D_TEXTURE_SIZE:32883,UNSIGNED_INT_2_10_10_10_REV:33640,MAX_ELEMENTS_VERTICES:33e3,MAX_ELEMENTS_INDICES:33001,TEXTURE_MIN_LOD:33082,TEXTURE_MAX_LOD:33083,TEXTURE_BASE_LEVEL:33084,TEXTURE_MAX_LEVEL:33085,MIN:32775,MAX:32776,DEPTH_COMPONENT24:33190,MAX_TEXTURE_LOD_BIAS:34045,TEXTURE_COMPARE_MODE:34892,TEXTURE_COMPARE_FUNC:34893,CURRENT_QUERY:34917,QUERY_RESULT:34918,QUERY_RESULT_AVAILABLE:34919,STREAM_READ:35041,STREAM_COPY:35042,STATIC_READ:35045,STATIC_COPY:35046,DYNAMIC_READ:35049,DYNAMIC_COPY:35050,MAX_DRAW_BUFFERS:34852,DRAW_BUFFER0:34853,DRAW_BUFFER1:34854,DRAW_BUFFER2:34855,DRAW_BUFFER3:34856,DRAW_BUFFER4:34857,DRAW_BUFFER5:34858,DRAW_BUFFER6:34859,DRAW_BUFFER7:34860,DRAW_BUFFER8:34861,DRAW_BUFFER9:34862,DRAW_BUFFER10:34863,DRAW_BUFFER11:34864,DRAW_BUFFER12:34865,DRAW_BUFFER13:34866,DRAW_BUFFER14:34867,DRAW_BUFFER15:34868,MAX_FRAGMENT_UNIFORM_COMPONENTS:35657,MAX_VERTEX_UNIFORM_COMPONENTS:35658,SAMPLER_3D:35679,SAMPLER_2D_SHADOW:35682,FRAGMENT_SHADER_DERIVATIVE_HINT:35723,PIXEL_PACK_BUFFER:35051,PIXEL_UNPACK_BUFFER:35052,PIXEL_PACK_BUFFER_BINDING:35053,PIXEL_UNPACK_BUFFER_BINDING:35055,FLOAT_MAT2x3:35685,FLOAT_MAT2x4:35686,FLOAT_MAT3x2:35687,FLOAT_MAT3x4:35688,FLOAT_MAT4x2:35689,FLOAT_MAT4x3:35690,SRGB:35904,SRGB8:35905,SRGB8_ALPHA8:35907,COMPARE_REF_TO_TEXTURE:34894,RGBA32F:34836,RGB32F:34837,RGBA16F:34842,RGB16F:34843,VERTEX_ATTRIB_ARRAY_INTEGER:35069,MAX_ARRAY_TEXTURE_LAYERS:35071,MIN_PROGRAM_TEXEL_OFFSET:35076,MAX_PROGRAM_TEXEL_OFFSET:35077,MAX_VARYING_COMPONENTS:35659,TEXTURE_2D_ARRAY:35866,TEXTURE_BINDING_2D_ARRAY:35869,R11F_G11F_B10F:35898,UNSIGNED_INT_10F_11F_11F_REV:35899,RGB9_E5:35901,UNSIGNED_INT_5_9_9_9_REV:35902,TRANSFORM_FEEDBACK_BUFFER_MODE:35967,MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS:35968,TRANSFORM_FEEDBACK_VARYINGS:35971,TRANSFORM_FEEDBACK_BUFFER_START:35972,TRANSFORM_FEEDBACK_BUFFER_SIZE:35973,TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN:35976,RASTERIZER_DISCARD:35977,MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS:35978,MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS:35979,INTERLEAVED_ATTRIBS:35980,SEPARATE_ATTRIBS:35981,TRANSFORM_FEEDBACK_BUFFER:35982,TRANSFORM_FEEDBACK_BUFFER_BINDING:35983,RGBA32UI:36208,RGB32UI:36209,RGBA16UI:36214,RGB16UI:36215,RGBA8UI:36220,RGB8UI:36221,RGBA32I:36226,RGB32I:36227,RGBA16I:36232,RGB16I:36233,RGBA8I:36238,RGB8I:36239,RED_INTEGER:36244,RGB_INTEGER:36248,RGBA_INTEGER:36249,SAMPLER_2D_ARRAY:36289,SAMPLER_2D_ARRAY_SHADOW:36292,SAMPLER_CUBE_SHADOW:36293,UNSIGNED_INT_VEC2:36294,UNSIGNED_INT_VEC3:36295,UNSIGNED_INT_VEC4:36296,INT_SAMPLER_2D:36298,INT_SAMPLER_3D:36299,INT_SAMPLER_CUBE:36300,INT_SAMPLER_2D_ARRAY:36303,UNSIGNED_INT_SAMPLER_2D:36306,UNSIGNED_INT_SAMPLER_3D:36307,UNSIGNED_INT_SAMPLER_CUBE:36308,UNSIGNED_INT_SAMPLER_2D_ARRAY:36311,DEPTH_COMPONENT32F:36012,DEPTH32F_STENCIL8:36013,FLOAT_32_UNSIGNED_INT_24_8_REV:36269,FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING:33296,FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE:33297,FRAMEBUFFER_ATTACHMENT_RED_SIZE:33298,FRAMEBUFFER_ATTACHMENT_GREEN_SIZE:33299,FRAMEBUFFER_ATTACHMENT_BLUE_SIZE:33300,FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE:33301,FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE:33302,FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE:33303,FRAMEBUFFER_DEFAULT:33304,UNSIGNED_INT_24_8:34042,DEPTH24_STENCIL8:35056,UNSIGNED_NORMALIZED:35863,DRAW_FRAMEBUFFER_BINDING:36006,READ_FRAMEBUFFER:36008,DRAW_FRAMEBUFFER:36009,READ_FRAMEBUFFER_BINDING:36010,RENDERBUFFER_SAMPLES:36011,FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER:36052,MAX_COLOR_ATTACHMENTS:36063,COLOR_ATTACHMENT1:36065,COLOR_ATTACHMENT2:36066,COLOR_ATTACHMENT3:36067,COLOR_ATTACHMENT4:36068,COLOR_ATTACHMENT5:36069,COLOR_ATTACHMENT6:36070,COLOR_ATTACHMENT7:36071,COLOR_ATTACHMENT8:36072,COLOR_ATTACHMENT9:36073,COLOR_ATTACHMENT10:36074,COLOR_ATTACHMENT11:36075,COLOR_ATTACHMENT12:36076,COLOR_ATTACHMENT13:36077,COLOR_ATTACHMENT14:36078,COLOR_ATTACHMENT15:36079,FRAMEBUFFER_INCOMPLETE_MULTISAMPLE:36182,MAX_SAMPLES:36183,HALF_FLOAT:5131,RG:33319,RG_INTEGER:33320,R8:33321,RG8:33323,R16F:33325,R32F:33326,RG16F:33327,RG32F:33328,R8I:33329,R8UI:33330,R16I:33331,R16UI:33332,R32I:33333,R32UI:33334,RG8I:33335,RG8UI:33336,RG16I:33337,RG16UI:33338,RG32I:33339,RG32UI:33340,VERTEX_ARRAY_BINDING:34229,R8_SNORM:36756,RG8_SNORM:36757,RGB8_SNORM:36758,RGBA8_SNORM:36759,SIGNED_NORMALIZED:36764,COPY_READ_BUFFER:36662,COPY_WRITE_BUFFER:36663,COPY_READ_BUFFER_BINDING:36662,COPY_WRITE_BUFFER_BINDING:36663,UNIFORM_BUFFER:35345,UNIFORM_BUFFER_BINDING:35368,UNIFORM_BUFFER_START:35369,UNIFORM_BUFFER_SIZE:35370,MAX_VERTEX_UNIFORM_BLOCKS:35371,MAX_FRAGMENT_UNIFORM_BLOCKS:35373,MAX_COMBINED_UNIFORM_BLOCKS:35374,MAX_UNIFORM_BUFFER_BINDINGS:35375,MAX_UNIFORM_BLOCK_SIZE:35376,MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS:35377,MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS:35379,UNIFORM_BUFFER_OFFSET_ALIGNMENT:35380,ACTIVE_UNIFORM_BLOCKS:35382,UNIFORM_TYPE:35383,UNIFORM_SIZE:35384,UNIFORM_BLOCK_INDEX:35386,UNIFORM_OFFSET:35387,UNIFORM_ARRAY_STRIDE:35388,UNIFORM_MATRIX_STRIDE:35389,UNIFORM_IS_ROW_MAJOR:35390,UNIFORM_BLOCK_BINDING:35391,UNIFORM_BLOCK_DATA_SIZE:35392,UNIFORM_BLOCK_ACTIVE_UNIFORMS:35394,UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES:35395,UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER:35396,UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER:35398,INVALID_INDEX:4294967295,MAX_VERTEX_OUTPUT_COMPONENTS:37154,MAX_FRAGMENT_INPUT_COMPONENTS:37157,MAX_SERVER_WAIT_TIMEOUT:37137,OBJECT_TYPE:37138,SYNC_CONDITION:37139,SYNC_STATUS:37140,SYNC_FLAGS:37141,SYNC_FENCE:37142,SYNC_GPU_COMMANDS_COMPLETE:37143,UNSIGNALED:37144,SIGNALED:37145,ALREADY_SIGNALED:37146,TIMEOUT_EXPIRED:37147,CONDITION_SATISFIED:37148,WAIT_FAILED:37149,SYNC_FLUSH_COMMANDS_BIT:1,VERTEX_ATTRIB_ARRAY_DIVISOR:35070,ANY_SAMPLES_PASSED:35887,ANY_SAMPLES_PASSED_CONSERVATIVE:36202,SAMPLER_BINDING:35097,RGB10_A2UI:36975,INT_2_10_10_10_REV:36255,TRANSFORM_FEEDBACK:36386,TRANSFORM_FEEDBACK_PAUSED:36387,TRANSFORM_FEEDBACK_ACTIVE:36388,TRANSFORM_FEEDBACK_BINDING:36389,COMPRESSED_R11_EAC:37488,COMPRESSED_SIGNED_R11_EAC:37489,COMPRESSED_RG11_EAC:37490,COMPRESSED_SIGNED_RG11_EAC:37491,COMPRESSED_RGB8_ETC2:37492,COMPRESSED_SRGB8_ETC2:37493,COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2:37494,COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2:37495,COMPRESSED_RGBA8_ETC2_EAC:37496,COMPRESSED_SRGB8_ALPHA8_ETC2_EAC:37497,TEXTURE_IMMUTABLE_FORMAT:37167,MAX_ELEMENT_INDEX:36203,TEXTURE_IMMUTABLE_LEVELS:33503,MAX_TEXTURE_MAX_ANISOTROPY_EXT:34047},_=Object.freeze(E);export{_ as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-IO6LETQ6.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-IO6LETQ6.js new file mode 100644 index 0000000000000000000000000000000000000000..501a4cc8ea031135289c9b1f97729186c9484409 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-IO6LETQ6.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as N}from"./chunk-IBAO62UG.js";import{a as i}from"./chunk-P44SUSQU.js";import{a}from"./chunk-FUATUYJ3.js";import{e as T}from"./chunk-ODUTJJQ5.js";var r={BYTE:N.BYTE,UNSIGNED_BYTE:N.UNSIGNED_BYTE,SHORT:N.SHORT,UNSIGNED_SHORT:N.UNSIGNED_SHORT,INT:N.INT,UNSIGNED_INT:N.UNSIGNED_INT,FLOAT:N.FLOAT,DOUBLE:N.DOUBLE};r.getSizeInBytes=function(n){if(!T(n))throw new a("value is required.");switch(n){case r.BYTE:return Int8Array.BYTES_PER_ELEMENT;case r.UNSIGNED_BYTE:return Uint8Array.BYTES_PER_ELEMENT;case r.SHORT:return Int16Array.BYTES_PER_ELEMENT;case r.UNSIGNED_SHORT:return Uint16Array.BYTES_PER_ELEMENT;case r.INT:return Int32Array.BYTES_PER_ELEMENT;case r.UNSIGNED_INT:return Uint32Array.BYTES_PER_ELEMENT;case r.FLOAT:return Float32Array.BYTES_PER_ELEMENT;case r.DOUBLE:return Float64Array.BYTES_PER_ELEMENT;default:throw new a("componentDatatype is not a valid value.")}};r.fromTypedArray=function(n){if(n instanceof Int8Array)return r.BYTE;if(n instanceof Uint8Array)return r.UNSIGNED_BYTE;if(n instanceof Int16Array)return r.SHORT;if(n instanceof Uint16Array)return r.UNSIGNED_SHORT;if(n instanceof Int32Array)return r.INT;if(n instanceof Uint32Array)return r.UNSIGNED_INT;if(n instanceof Float32Array)return r.FLOAT;if(n instanceof Float64Array)return r.DOUBLE;throw new a("array must be an Int8Array, Uint8Array, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, or Float64Array.")};r.validate=function(n){return T(n)&&(n===r.BYTE||n===r.UNSIGNED_BYTE||n===r.SHORT||n===r.UNSIGNED_SHORT||n===r.INT||n===r.UNSIGNED_INT||n===r.FLOAT||n===r.DOUBLE)};r.createTypedArray=function(n,e){if(!T(n))throw new a("componentDatatype is required.");if(!T(e))throw new a("valuesOrLength is required.");switch(n){case r.BYTE:return new Int8Array(e);case r.UNSIGNED_BYTE:return new Uint8Array(e);case r.SHORT:return new Int16Array(e);case r.UNSIGNED_SHORT:return new Uint16Array(e);case r.INT:return new Int32Array(e);case r.UNSIGNED_INT:return new Uint32Array(e);case r.FLOAT:return new Float32Array(e);case r.DOUBLE:return new Float64Array(e);default:throw new a("componentDatatype is not a valid value.")}};r.createArrayBufferView=function(n,e,E,t){if(!T(n))throw new a("componentDatatype is required.");if(!T(e))throw new a("buffer is required.");switch(E=i(E,0),t=i(t,(e.byteLength-E)/r.getSizeInBytes(n)),n){case r.BYTE:return new Int8Array(e,E,t);case r.UNSIGNED_BYTE:return new Uint8Array(e,E,t);case r.SHORT:return new Int16Array(e,E,t);case r.UNSIGNED_SHORT:return new Uint16Array(e,E,t);case r.INT:return new Int32Array(e,E,t);case r.UNSIGNED_INT:return new Uint32Array(e,E,t);case r.FLOAT:return new Float32Array(e,E,t);case r.DOUBLE:return new Float64Array(e,E,t);default:throw new a("componentDatatype is not a valid value.")}};r.fromName=function(n){switch(n){case"BYTE":return r.BYTE;case"UNSIGNED_BYTE":return r.UNSIGNED_BYTE;case"SHORT":return r.SHORT;case"UNSIGNED_SHORT":return r.UNSIGNED_SHORT;case"INT":return r.INT;case"UNSIGNED_INT":return r.UNSIGNED_INT;case"FLOAT":return r.FLOAT;case"DOUBLE":return r.DOUBLE;default:throw new a("name is not a valid value.")}};var U=Object.freeze(r);export{U as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-ITS5OBIO.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-ITS5OBIO.js new file mode 100644 index 0000000000000000000000000000000000000000..082970fc867eb8427159e5815da0f1fd09869d38 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-ITS5OBIO.js @@ -0,0 +1,28 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{e as f}from"./chunk-ODUTJJQ5.js";function c(t){let n,a=t.name,e=t.message;f(a)&&f(e)?n=`${a}: ${e}`:n=t.toString();let o=t.stack;return f(o)&&(n+=` +${o}`),n}var i=c;function l(t){async function n({data:e}){let o=[],s={id:e.id,result:void 0,error:void 0};self.CESIUM_BASE_URL=e.baseUrl;try{let r=await t(e.parameters,o);s.result=r}catch(r){r instanceof Error?s.error={name:r.name,message:r.message,stack:r.stack}:s.error=r}e.canTransferArrayBuffer||(o.length=0);try{postMessage(s,o)}catch(r){s.result=void 0,s.error=`postMessage failed with error: ${i(r)} + with responseMessage: ${JSON.stringify(s)}`,postMessage(s)}}function a(e){postMessage({id:e.data?.id,error:`postMessage failed with error: ${JSON.stringify(e)}`})}return self.onmessage=n,self.onmessageerror=a,self}var d=l;export{d as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-KGKEYLWF.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-KGKEYLWF.js new file mode 100644 index 0000000000000000000000000000000000000000..5a8986374e47b7c13faecfd50971feb2ec9f7d9b --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-KGKEYLWF.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as fn,c as Tn}from"./chunk-ODUTJJQ5.js";var Dn=Tn((nt,bt)=>{var _=_||{};_.scope={};_.arrayIteratorImpl=function(p){var c=0;return function(){return c>>0,_.propertyToPolyfillSymbol[a]=_.IS_SYMBOL_NATIVE?_.global.Symbol(a):_.POLYFILL_PREFIX+s+"$"+a),_.defineProperty(y,_.propertyToPolyfillSymbol[a],{configurable:!0,writable:!0,value:c})))};_.polyfill("Promise",function(p){function c(){this.batch_=null}function s(i){return i instanceof a?i:new a(function(l,h){l(i)})}if(p&&(!(_.FORCE_POLYFILL_PROMISE||_.FORCE_POLYFILL_PROMISE_WHEN_NO_UNHANDLED_REJECTION&&typeof _.global.PromiseRejectionEvent>"u")||!_.global.Promise||_.global.Promise.toString().indexOf("[native code]")===-1))return p;c.prototype.asyncExecute=function(i){if(this.batch_==null){this.batch_=[];var l=this;this.asyncExecuteFunction(function(){l.executeBatch_()})}this.batch_.push(i)};var y=_.global.setTimeout;c.prototype.asyncExecuteFunction=function(i){y(i,0)},c.prototype.executeBatch_=function(){for(;this.batch_&&this.batch_.length;){var i=this.batch_;this.batch_=[];for(var l=0;l"u"?!0:(typeof i=="function"?i=new i("unhandledrejection",{cancelable:!0}):typeof l=="function"?i=new l("unhandledrejection",{cancelable:!0}):(i=_.global.document.createEvent("CustomEvent"),i.initCustomEvent("unhandledrejection",!1,!0,i)),i.promise=this,i.reason=this.result_,h(i))},a.prototype.executeOnSettledCallbacks_=function(){if(this.onSettledCallbacks_!=null){for(var i=0;i=g}},"es6","es3");_.polyfill("Array.prototype.copyWithin",function(p){function c(s){return s=Number(s),s===1/0||s===-1/0?s:s|0}return p||function(s,y,a){var g=this.length;if(s=c(s),y=c(y),a=a===void 0?g:c(a),s=0>s?Math.max(g+s,0):Math.min(s,g),y=0>y?Math.max(g+y,0):Math.min(y,g),a=0>a?Math.max(g+a,0):Math.min(a,g),sy;)--a in this?this[--s]=this[a]:delete this[--s];return this}},"es6","es3");_.typedArrayCopyWithin=function(p){return p||Array.prototype.copyWithin};_.polyfill("Int8Array.prototype.copyWithin",_.typedArrayCopyWithin,"es6","es5");_.polyfill("Uint8Array.prototype.copyWithin",_.typedArrayCopyWithin,"es6","es5");_.polyfill("Uint8ClampedArray.prototype.copyWithin",_.typedArrayCopyWithin,"es6","es5");_.polyfill("Int16Array.prototype.copyWithin",_.typedArrayCopyWithin,"es6","es5");_.polyfill("Uint16Array.prototype.copyWithin",_.typedArrayCopyWithin,"es6","es5");_.polyfill("Int32Array.prototype.copyWithin",_.typedArrayCopyWithin,"es6","es5");_.polyfill("Uint32Array.prototype.copyWithin",_.typedArrayCopyWithin,"es6","es5");_.polyfill("Float32Array.prototype.copyWithin",_.typedArrayCopyWithin,"es6","es5");_.polyfill("Float64Array.prototype.copyWithin",_.typedArrayCopyWithin,"es6","es5");var dt=function(){var p=typeof document<"u"&&document.currentScript?document.currentScript.src:void 0;return typeof __filename<"u"&&(p=p||__filename),function(c){function s(e){return t.locateFile?t.locateFile(e,Q):Q+e}function y(e,r,n){var o=r+n;for(n=r;e[n]&&!(n>=o);)++n;if(16m?o+=String.fromCharCode(m):(m-=65536,o+=String.fromCharCode(55296|m>>10,56320|m&1023))}}else o+=String.fromCharCode(m)}return o}function a(e,r){return e?y(tt,e,r):""}function g(){var e=_t.buffer;t.HEAP8=q=new Int8Array(e),t.HEAP16=new Int16Array(e),t.HEAP32=et=new Int32Array(e),t.HEAPU8=tt=new Uint8Array(e),t.HEAPU16=new Uint16Array(e),t.HEAPU32=x=new Uint32Array(e),t.HEAPF32=new Float32Array(e),t.HEAPF64=new Float64Array(e)}function i(e){throw t.onAbort&&t.onAbort(e),e="Aborted("+e+")",J(e),Gt=!0,e=new WebAssembly.RuntimeError(e+". Build with -sASSERTIONS for more info."),ot(e),e}function l(e){try{if(e==z&&Z)return new Uint8Array(Z);if(ut)return ut(e);throw"both async and sync fetching of the wasm failed"}catch(r){i(r)}}function h(){if(!Z&&(It||$)){if(typeof fetch=="function"&&!z.startsWith("file://"))return fetch(z,{credentials:"same-origin"}).then(function(e){if(!e.ok)throw"failed to load wasm binary file at '"+z+"'";return e.arrayBuffer()}).catch(function(){return l(z)});if(st)return new Promise(function(e,r){st(z,function(n){e(new Uint8Array(n))},r)})}return Promise.resolve().then(function(){return l(z)})}function I(e){for(;0>2]=r},this.get_type=function(){return x[this.ptr+4>>2]},this.set_destructor=function(r){x[this.ptr+8>>2]=r},this.get_destructor=function(){return x[this.ptr+8>>2]},this.set_refcount=function(r){et[this.ptr>>2]=r},this.set_caught=function(r){q[this.ptr+12>>0]=r?1:0},this.get_caught=function(){return q[this.ptr+12>>0]!=0},this.set_rethrown=function(r){q[this.ptr+13>>0]=r?1:0},this.get_rethrown=function(){return q[this.ptr+13>>0]!=0},this.init=function(r,n){this.set_adjusted_ptr(0),this.set_type(r),this.set_destructor(n),this.set_refcount(0),this.set_caught(!1),this.set_rethrown(!1)},this.add_ref=function(){et[this.ptr>>2]+=1},this.release_ref=function(){var r=et[this.ptr>>2];return et[this.ptr>>2]=r-1,r===1},this.set_adjusted_ptr=function(r){x[this.ptr+16>>2]=r},this.get_adjusted_ptr=function(){return x[this.ptr+16>>2]},this.get_exception_ptr=function(){if(ln(this.get_type()))return x[this.excPtr>>2];var r=this.get_adjusted_ptr();return r!==0?r:this.excPtr}}function K(){function e(){if(!it&&(it=!0,t.calledRun=!0,!Gt)){if(Rt=!0,I(ct),ht(t),t.onRuntimeInitialized&&t.onRuntimeInitialized(),t.postRun)for(typeof t.postRun=="function"&&(t.postRun=[t.postRun]);t.postRun.length;)Pt.unshift(t.postRun.shift());I(Pt)}}if(!(0=o?r++:2047>=o?r+=2:55296<=o&&57343>=o?(r+=4,++n):r+=3}if(r=Array(r+1),n=0,o=r.length,0=b){var X=e.charCodeAt(++m);b=65536+((b&1023)<<10)|X&1023}if(127>=b){if(n>=o)break;r[n++]=b}else{if(2047>=b){if(n+1>=o)break;r[n++]=192|b>>6}else{if(65535>=b){if(n+2>=o)break;r[n++]=224|b>>12}else{if(n+3>=o)break;r[n++]=240|b>>18,r[n++]=128|b>>12&63}r[n++]=128|b>>6&63}r[n++]=128|b&63}}r[n]=0}return e=d.alloc(r,q),d.copy(r,q,e),e}return e}function at(e){if(typeof e=="object"){var r=d.alloc(e,q);return d.copy(e,q,r),r}return e}function H(){throw"cannot construct a VoidPtr, no constructor in IDL"}function B(){this.ptr=Mt(),T(B)[this.ptr]=this}function w(){this.ptr=Ft(),T(w)[this.ptr]=this}function Y(){this.ptr=wt(),T(Y)[this.ptr]=this}function A(){this.ptr=Vt(),T(A)[this.ptr]=this}function E(){this.ptr=Jt(),T(E)[this.ptr]=this}function j(){this.ptr=ne(),T(j)[this.ptr]=this}function P(){this.ptr=ae(),T(P)[this.ptr]=this}function O(){this.ptr=ce(),T(O)[this.ptr]=this}function W(){this.ptr=de(),T(W)[this.ptr]=this}function v(){throw"cannot construct a Status, no constructor in IDL"}function R(){this.ptr=Ie(),T(R)[this.ptr]=this}function S(){this.ptr=Ge(),T(S)[this.ptr]=this}function M(){this.ptr=Re(),T(M)[this.ptr]=this}function N(){this.ptr=Ue(),T(N)[this.ptr]=this}function U(){this.ptr=we(),T(U)[this.ptr]=this}function F(){this.ptr=We(),T(F)[this.ptr]=this}function L(){this.ptr=He(),T(L)[this.ptr]=this}function D(){this.ptr=Ke(),T(D)[this.ptr]=this}function u(){this.ptr=_r(),T(u)[this.ptr]=this}c=c===void 0?{}:c;var t=typeof c<"u"?c:{},ht,ot;t.ready=new Promise(function(e,r){ht=e,ot=r});var At=!1,Tt=!1;t.onRuntimeInitialized=function(){At=!0,Tt&&typeof t.onModuleLoaded=="function"&&t.onModuleLoaded(t)},t.onModuleParsed=function(){Tt=!0,At&&typeof t.onModuleLoaded=="function"&&t.onModuleLoaded(t)},t.isVersionSupported=function(e){return typeof e!="string"?!1:(e=e.split("."),2>e.length||3=e[1]?!0:!(e[0]!=0||10>>=0,2147483648=n;n*=2){var o=r*(1+.2/n);o=Math.min(o,e+100663296);var m=Math;o=Math.max(e,o),m=m.min.call(m,2147483648,o+(65536-o%65536)%65536);t:{o=_t.buffer;try{_t.grow(m-o.byteLength+65535>>>16),g();var b=1;break t}catch{}b=void 0}if(b)return!0}return!1},f:function(e){return 52},d:function(e,r,n,o,m){return 70},c:function(e,r,n,o){for(var m=0,b=0;b>2],mn=x[r+4>>2];r+=8;for(var lt=0;lt>2]=m,0}};(function(){function e(m,b){t.asm=m.exports,_t=t.asm.h,g(),ct.unshift(t.asm.i),k--,t.monitorRunDependencies&&t.monitorRunDependencies(k),k==0&&(yt!==null&&(clearInterval(yt),yt=null),rt&&(m=rt,rt=null,m()))}function r(m){e(m.instance)}function n(m){return h().then(function(b){return WebAssembly.instantiate(b,o)}).then(function(b){return b}).then(m,function(b){J("failed to asynchronously prepare wasm: "+b),i(b)})}var o={a:An};if(k++,t.monitorRunDependencies&&t.monitorRunDependencies(k),t.instantiateWasm)try{return t.instantiateWasm(o,e)}catch(m){J("Module.instantiateWasm callback failed with error: "+m),ot(m)}return function(){return Z||typeof WebAssembly.instantiateStreaming!="function"||z.startsWith("data:application/octet-stream;base64,")||z.startsWith("file://")||gt||typeof fetch!="function"?n(r):fetch(z,{credentials:"same-origin"}).then(function(m){return WebAssembly.instantiateStreaming(m,o).then(r,function(b){return J("wasm streaming compile failed: "+b),J("falling back to ArrayBuffer instantiation"),n(r)})})}().catch(ot),{}})();var St=t._emscripten_bind_VoidPtr___destroy___0=function(){return(St=t._emscripten_bind_VoidPtr___destroy___0=t.asm.k).apply(null,arguments)},Mt=t._emscripten_bind_DecoderBuffer_DecoderBuffer_0=function(){return(Mt=t._emscripten_bind_DecoderBuffer_DecoderBuffer_0=t.asm.l).apply(null,arguments)},Nt=t._emscripten_bind_DecoderBuffer_Init_2=function(){return(Nt=t._emscripten_bind_DecoderBuffer_Init_2=t.asm.m).apply(null,arguments)},Ut=t._emscripten_bind_DecoderBuffer___destroy___0=function(){return(Ut=t._emscripten_bind_DecoderBuffer___destroy___0=t.asm.n).apply(null,arguments)},Ft=t._emscripten_bind_AttributeTransformData_AttributeTransformData_0=function(){return(Ft=t._emscripten_bind_AttributeTransformData_AttributeTransformData_0=t.asm.o).apply(null,arguments)},Lt=t._emscripten_bind_AttributeTransformData_transform_type_0=function(){return(Lt=t._emscripten_bind_AttributeTransformData_transform_type_0=t.asm.p).apply(null,arguments)},Ct=t._emscripten_bind_AttributeTransformData___destroy___0=function(){return(Ct=t._emscripten_bind_AttributeTransformData___destroy___0=t.asm.q).apply(null,arguments)},wt=t._emscripten_bind_GeometryAttribute_GeometryAttribute_0=function(){return(wt=t._emscripten_bind_GeometryAttribute_GeometryAttribute_0=t.asm.r).apply(null,arguments)},zt=t._emscripten_bind_GeometryAttribute___destroy___0=function(){return(zt=t._emscripten_bind_GeometryAttribute___destroy___0=t.asm.s).apply(null,arguments)},Vt=t._emscripten_bind_PointAttribute_PointAttribute_0=function(){return(Vt=t._emscripten_bind_PointAttribute_PointAttribute_0=t.asm.t).apply(null,arguments)},Bt=t._emscripten_bind_PointAttribute_size_0=function(){return(Bt=t._emscripten_bind_PointAttribute_size_0=t.asm.u).apply(null,arguments)},Wt=t._emscripten_bind_PointAttribute_GetAttributeTransformData_0=function(){return(Wt=t._emscripten_bind_PointAttribute_GetAttributeTransformData_0=t.asm.v).apply(null,arguments)},Qt=t._emscripten_bind_PointAttribute_attribute_type_0=function(){return(Qt=t._emscripten_bind_PointAttribute_attribute_type_0=t.asm.w).apply(null,arguments)},xt=t._emscripten_bind_PointAttribute_data_type_0=function(){return(xt=t._emscripten_bind_PointAttribute_data_type_0=t.asm.x).apply(null,arguments)},Yt=t._emscripten_bind_PointAttribute_num_components_0=function(){return(Yt=t._emscripten_bind_PointAttribute_num_components_0=t.asm.y).apply(null,arguments)},Ht=t._emscripten_bind_PointAttribute_normalized_0=function(){return(Ht=t._emscripten_bind_PointAttribute_normalized_0=t.asm.z).apply(null,arguments)},qt=t._emscripten_bind_PointAttribute_byte_stride_0=function(){return(qt=t._emscripten_bind_PointAttribute_byte_stride_0=t.asm.A).apply(null,arguments)},kt=t._emscripten_bind_PointAttribute_byte_offset_0=function(){return(kt=t._emscripten_bind_PointAttribute_byte_offset_0=t.asm.B).apply(null,arguments)},Xt=t._emscripten_bind_PointAttribute_unique_id_0=function(){return(Xt=t._emscripten_bind_PointAttribute_unique_id_0=t.asm.C).apply(null,arguments)},Kt=t._emscripten_bind_PointAttribute___destroy___0=function(){return(Kt=t._emscripten_bind_PointAttribute___destroy___0=t.asm.D).apply(null,arguments)},Jt=t._emscripten_bind_AttributeQuantizationTransform_AttributeQuantizationTransform_0=function(){return(Jt=t._emscripten_bind_AttributeQuantizationTransform_AttributeQuantizationTransform_0=t.asm.E).apply(null,arguments)},$t=t._emscripten_bind_AttributeQuantizationTransform_InitFromAttribute_1=function(){return($t=t._emscripten_bind_AttributeQuantizationTransform_InitFromAttribute_1=t.asm.F).apply(null,arguments)},Zt=t._emscripten_bind_AttributeQuantizationTransform_quantization_bits_0=function(){return(Zt=t._emscripten_bind_AttributeQuantizationTransform_quantization_bits_0=t.asm.G).apply(null,arguments)},te=t._emscripten_bind_AttributeQuantizationTransform_min_value_1=function(){return(te=t._emscripten_bind_AttributeQuantizationTransform_min_value_1=t.asm.H).apply(null,arguments)},ee=t._emscripten_bind_AttributeQuantizationTransform_range_0=function(){return(ee=t._emscripten_bind_AttributeQuantizationTransform_range_0=t.asm.I).apply(null,arguments)},re=t._emscripten_bind_AttributeQuantizationTransform___destroy___0=function(){return(re=t._emscripten_bind_AttributeQuantizationTransform___destroy___0=t.asm.J).apply(null,arguments)},ne=t._emscripten_bind_AttributeOctahedronTransform_AttributeOctahedronTransform_0=function(){return(ne=t._emscripten_bind_AttributeOctahedronTransform_AttributeOctahedronTransform_0=t.asm.K).apply(null,arguments)},oe=t._emscripten_bind_AttributeOctahedronTransform_InitFromAttribute_1=function(){return(oe=t._emscripten_bind_AttributeOctahedronTransform_InitFromAttribute_1=t.asm.L).apply(null,arguments)},_e=t._emscripten_bind_AttributeOctahedronTransform_quantization_bits_0=function(){return(_e=t._emscripten_bind_AttributeOctahedronTransform_quantization_bits_0=t.asm.M).apply(null,arguments)},ie=t._emscripten_bind_AttributeOctahedronTransform___destroy___0=function(){return(ie=t._emscripten_bind_AttributeOctahedronTransform___destroy___0=t.asm.N).apply(null,arguments)},ae=t._emscripten_bind_PointCloud_PointCloud_0=function(){return(ae=t._emscripten_bind_PointCloud_PointCloud_0=t.asm.O).apply(null,arguments)},pe=t._emscripten_bind_PointCloud_num_attributes_0=function(){return(pe=t._emscripten_bind_PointCloud_num_attributes_0=t.asm.P).apply(null,arguments)},ue=t._emscripten_bind_PointCloud_num_points_0=function(){return(ue=t._emscripten_bind_PointCloud_num_points_0=t.asm.Q).apply(null,arguments)},se=t._emscripten_bind_PointCloud___destroy___0=function(){return(se=t._emscripten_bind_PointCloud___destroy___0=t.asm.R).apply(null,arguments)},ce=t._emscripten_bind_Mesh_Mesh_0=function(){return(ce=t._emscripten_bind_Mesh_Mesh_0=t.asm.S).apply(null,arguments)},ye=t._emscripten_bind_Mesh_num_faces_0=function(){return(ye=t._emscripten_bind_Mesh_num_faces_0=t.asm.T).apply(null,arguments)},le=t._emscripten_bind_Mesh_num_attributes_0=function(){return(le=t._emscripten_bind_Mesh_num_attributes_0=t.asm.U).apply(null,arguments)},me=t._emscripten_bind_Mesh_num_points_0=function(){return(me=t._emscripten_bind_Mesh_num_points_0=t.asm.V).apply(null,arguments)},fe=t._emscripten_bind_Mesh___destroy___0=function(){return(fe=t._emscripten_bind_Mesh___destroy___0=t.asm.W).apply(null,arguments)},de=t._emscripten_bind_Metadata_Metadata_0=function(){return(de=t._emscripten_bind_Metadata_Metadata_0=t.asm.X).apply(null,arguments)},be=t._emscripten_bind_Metadata___destroy___0=function(){return(be=t._emscripten_bind_Metadata___destroy___0=t.asm.Y).apply(null,arguments)},he=t._emscripten_bind_Status_code_0=function(){return(he=t._emscripten_bind_Status_code_0=t.asm.Z).apply(null,arguments)},Ae=t._emscripten_bind_Status_ok_0=function(){return(Ae=t._emscripten_bind_Status_ok_0=t.asm._).apply(null,arguments)},Te=t._emscripten_bind_Status_error_msg_0=function(){return(Te=t._emscripten_bind_Status_error_msg_0=t.asm.$).apply(null,arguments)},De=t._emscripten_bind_Status___destroy___0=function(){return(De=t._emscripten_bind_Status___destroy___0=t.asm.aa).apply(null,arguments)},Ie=t._emscripten_bind_DracoFloat32Array_DracoFloat32Array_0=function(){return(Ie=t._emscripten_bind_DracoFloat32Array_DracoFloat32Array_0=t.asm.ba).apply(null,arguments)},ge=t._emscripten_bind_DracoFloat32Array_GetValue_1=function(){return(ge=t._emscripten_bind_DracoFloat32Array_GetValue_1=t.asm.ca).apply(null,arguments)},ve=t._emscripten_bind_DracoFloat32Array_size_0=function(){return(ve=t._emscripten_bind_DracoFloat32Array_size_0=t.asm.da).apply(null,arguments)},Ee=t._emscripten_bind_DracoFloat32Array___destroy___0=function(){return(Ee=t._emscripten_bind_DracoFloat32Array___destroy___0=t.asm.ea).apply(null,arguments)},Ge=t._emscripten_bind_DracoInt8Array_DracoInt8Array_0=function(){return(Ge=t._emscripten_bind_DracoInt8Array_DracoInt8Array_0=t.asm.fa).apply(null,arguments)},Oe=t._emscripten_bind_DracoInt8Array_GetValue_1=function(){return(Oe=t._emscripten_bind_DracoInt8Array_GetValue_1=t.asm.ga).apply(null,arguments)},je=t._emscripten_bind_DracoInt8Array_size_0=function(){return(je=t._emscripten_bind_DracoInt8Array_size_0=t.asm.ha).apply(null,arguments)},Pe=t._emscripten_bind_DracoInt8Array___destroy___0=function(){return(Pe=t._emscripten_bind_DracoInt8Array___destroy___0=t.asm.ia).apply(null,arguments)},Re=t._emscripten_bind_DracoUInt8Array_DracoUInt8Array_0=function(){return(Re=t._emscripten_bind_DracoUInt8Array_DracoUInt8Array_0=t.asm.ja).apply(null,arguments)},Se=t._emscripten_bind_DracoUInt8Array_GetValue_1=function(){return(Se=t._emscripten_bind_DracoUInt8Array_GetValue_1=t.asm.ka).apply(null,arguments)},Me=t._emscripten_bind_DracoUInt8Array_size_0=function(){return(Me=t._emscripten_bind_DracoUInt8Array_size_0=t.asm.la).apply(null,arguments)},Ne=t._emscripten_bind_DracoUInt8Array___destroy___0=function(){return(Ne=t._emscripten_bind_DracoUInt8Array___destroy___0=t.asm.ma).apply(null,arguments)},Ue=t._emscripten_bind_DracoInt16Array_DracoInt16Array_0=function(){return(Ue=t._emscripten_bind_DracoInt16Array_DracoInt16Array_0=t.asm.na).apply(null,arguments)},Fe=t._emscripten_bind_DracoInt16Array_GetValue_1=function(){return(Fe=t._emscripten_bind_DracoInt16Array_GetValue_1=t.asm.oa).apply(null,arguments)},Le=t._emscripten_bind_DracoInt16Array_size_0=function(){return(Le=t._emscripten_bind_DracoInt16Array_size_0=t.asm.pa).apply(null,arguments)},Ce=t._emscripten_bind_DracoInt16Array___destroy___0=function(){return(Ce=t._emscripten_bind_DracoInt16Array___destroy___0=t.asm.qa).apply(null,arguments)},we=t._emscripten_bind_DracoUInt16Array_DracoUInt16Array_0=function(){return(we=t._emscripten_bind_DracoUInt16Array_DracoUInt16Array_0=t.asm.ra).apply(null,arguments)},ze=t._emscripten_bind_DracoUInt16Array_GetValue_1=function(){return(ze=t._emscripten_bind_DracoUInt16Array_GetValue_1=t.asm.sa).apply(null,arguments)},Ve=t._emscripten_bind_DracoUInt16Array_size_0=function(){return(Ve=t._emscripten_bind_DracoUInt16Array_size_0=t.asm.ta).apply(null,arguments)},Be=t._emscripten_bind_DracoUInt16Array___destroy___0=function(){return(Be=t._emscripten_bind_DracoUInt16Array___destroy___0=t.asm.ua).apply(null,arguments)},We=t._emscripten_bind_DracoInt32Array_DracoInt32Array_0=function(){return(We=t._emscripten_bind_DracoInt32Array_DracoInt32Array_0=t.asm.va).apply(null,arguments)},Qe=t._emscripten_bind_DracoInt32Array_GetValue_1=function(){return(Qe=t._emscripten_bind_DracoInt32Array_GetValue_1=t.asm.wa).apply(null,arguments)},xe=t._emscripten_bind_DracoInt32Array_size_0=function(){return(xe=t._emscripten_bind_DracoInt32Array_size_0=t.asm.xa).apply(null,arguments)},Ye=t._emscripten_bind_DracoInt32Array___destroy___0=function(){return(Ye=t._emscripten_bind_DracoInt32Array___destroy___0=t.asm.ya).apply(null,arguments)},He=t._emscripten_bind_DracoUInt32Array_DracoUInt32Array_0=function(){return(He=t._emscripten_bind_DracoUInt32Array_DracoUInt32Array_0=t.asm.za).apply(null,arguments)},qe=t._emscripten_bind_DracoUInt32Array_GetValue_1=function(){return(qe=t._emscripten_bind_DracoUInt32Array_GetValue_1=t.asm.Aa).apply(null,arguments)},ke=t._emscripten_bind_DracoUInt32Array_size_0=function(){return(ke=t._emscripten_bind_DracoUInt32Array_size_0=t.asm.Ba).apply(null,arguments)},Xe=t._emscripten_bind_DracoUInt32Array___destroy___0=function(){return(Xe=t._emscripten_bind_DracoUInt32Array___destroy___0=t.asm.Ca).apply(null,arguments)},Ke=t._emscripten_bind_MetadataQuerier_MetadataQuerier_0=function(){return(Ke=t._emscripten_bind_MetadataQuerier_MetadataQuerier_0=t.asm.Da).apply(null,arguments)},Je=t._emscripten_bind_MetadataQuerier_HasEntry_2=function(){return(Je=t._emscripten_bind_MetadataQuerier_HasEntry_2=t.asm.Ea).apply(null,arguments)},$e=t._emscripten_bind_MetadataQuerier_GetIntEntry_2=function(){return($e=t._emscripten_bind_MetadataQuerier_GetIntEntry_2=t.asm.Fa).apply(null,arguments)},Ze=t._emscripten_bind_MetadataQuerier_GetIntEntryArray_3=function(){return(Ze=t._emscripten_bind_MetadataQuerier_GetIntEntryArray_3=t.asm.Ga).apply(null,arguments)},tr=t._emscripten_bind_MetadataQuerier_GetDoubleEntry_2=function(){return(tr=t._emscripten_bind_MetadataQuerier_GetDoubleEntry_2=t.asm.Ha).apply(null,arguments)},er=t._emscripten_bind_MetadataQuerier_GetStringEntry_2=function(){return(er=t._emscripten_bind_MetadataQuerier_GetStringEntry_2=t.asm.Ia).apply(null,arguments)},rr=t._emscripten_bind_MetadataQuerier_NumEntries_1=function(){return(rr=t._emscripten_bind_MetadataQuerier_NumEntries_1=t.asm.Ja).apply(null,arguments)},nr=t._emscripten_bind_MetadataQuerier_GetEntryName_2=function(){return(nr=t._emscripten_bind_MetadataQuerier_GetEntryName_2=t.asm.Ka).apply(null,arguments)},or=t._emscripten_bind_MetadataQuerier___destroy___0=function(){return(or=t._emscripten_bind_MetadataQuerier___destroy___0=t.asm.La).apply(null,arguments)},_r=t._emscripten_bind_Decoder_Decoder_0=function(){return(_r=t._emscripten_bind_Decoder_Decoder_0=t.asm.Ma).apply(null,arguments)},ir=t._emscripten_bind_Decoder_DecodeArrayToPointCloud_3=function(){return(ir=t._emscripten_bind_Decoder_DecodeArrayToPointCloud_3=t.asm.Na).apply(null,arguments)},ar=t._emscripten_bind_Decoder_DecodeArrayToMesh_3=function(){return(ar=t._emscripten_bind_Decoder_DecodeArrayToMesh_3=t.asm.Oa).apply(null,arguments)},pr=t._emscripten_bind_Decoder_GetAttributeId_2=function(){return(pr=t._emscripten_bind_Decoder_GetAttributeId_2=t.asm.Pa).apply(null,arguments)},ur=t._emscripten_bind_Decoder_GetAttributeIdByName_2=function(){return(ur=t._emscripten_bind_Decoder_GetAttributeIdByName_2=t.asm.Qa).apply(null,arguments)},sr=t._emscripten_bind_Decoder_GetAttributeIdByMetadataEntry_3=function(){return(sr=t._emscripten_bind_Decoder_GetAttributeIdByMetadataEntry_3=t.asm.Ra).apply(null,arguments)},cr=t._emscripten_bind_Decoder_GetAttribute_2=function(){return(cr=t._emscripten_bind_Decoder_GetAttribute_2=t.asm.Sa).apply(null,arguments)},yr=t._emscripten_bind_Decoder_GetAttributeByUniqueId_2=function(){return(yr=t._emscripten_bind_Decoder_GetAttributeByUniqueId_2=t.asm.Ta).apply(null,arguments)},lr=t._emscripten_bind_Decoder_GetMetadata_1=function(){return(lr=t._emscripten_bind_Decoder_GetMetadata_1=t.asm.Ua).apply(null,arguments)},mr=t._emscripten_bind_Decoder_GetAttributeMetadata_2=function(){return(mr=t._emscripten_bind_Decoder_GetAttributeMetadata_2=t.asm.Va).apply(null,arguments)},fr=t._emscripten_bind_Decoder_GetFaceFromMesh_3=function(){return(fr=t._emscripten_bind_Decoder_GetFaceFromMesh_3=t.asm.Wa).apply(null,arguments)},dr=t._emscripten_bind_Decoder_GetTriangleStripsFromMesh_2=function(){return(dr=t._emscripten_bind_Decoder_GetTriangleStripsFromMesh_2=t.asm.Xa).apply(null,arguments)},br=t._emscripten_bind_Decoder_GetTrianglesUInt16Array_3=function(){return(br=t._emscripten_bind_Decoder_GetTrianglesUInt16Array_3=t.asm.Ya).apply(null,arguments)},hr=t._emscripten_bind_Decoder_GetTrianglesUInt32Array_3=function(){return(hr=t._emscripten_bind_Decoder_GetTrianglesUInt32Array_3=t.asm.Za).apply(null,arguments)},Ar=t._emscripten_bind_Decoder_GetAttributeFloat_3=function(){return(Ar=t._emscripten_bind_Decoder_GetAttributeFloat_3=t.asm._a).apply(null,arguments)},Tr=t._emscripten_bind_Decoder_GetAttributeFloatForAllPoints_3=function(){return(Tr=t._emscripten_bind_Decoder_GetAttributeFloatForAllPoints_3=t.asm.$a).apply(null,arguments)},Dr=t._emscripten_bind_Decoder_GetAttributeIntForAllPoints_3=function(){return(Dr=t._emscripten_bind_Decoder_GetAttributeIntForAllPoints_3=t.asm.ab).apply(null,arguments)},Ir=t._emscripten_bind_Decoder_GetAttributeInt8ForAllPoints_3=function(){return(Ir=t._emscripten_bind_Decoder_GetAttributeInt8ForAllPoints_3=t.asm.bb).apply(null,arguments)},gr=t._emscripten_bind_Decoder_GetAttributeUInt8ForAllPoints_3=function(){return(gr=t._emscripten_bind_Decoder_GetAttributeUInt8ForAllPoints_3=t.asm.cb).apply(null,arguments)},vr=t._emscripten_bind_Decoder_GetAttributeInt16ForAllPoints_3=function(){return(vr=t._emscripten_bind_Decoder_GetAttributeInt16ForAllPoints_3=t.asm.db).apply(null,arguments)},Er=t._emscripten_bind_Decoder_GetAttributeUInt16ForAllPoints_3=function(){return(Er=t._emscripten_bind_Decoder_GetAttributeUInt16ForAllPoints_3=t.asm.eb).apply(null,arguments)},Gr=t._emscripten_bind_Decoder_GetAttributeInt32ForAllPoints_3=function(){return(Gr=t._emscripten_bind_Decoder_GetAttributeInt32ForAllPoints_3=t.asm.fb).apply(null,arguments)},Or=t._emscripten_bind_Decoder_GetAttributeUInt32ForAllPoints_3=function(){return(Or=t._emscripten_bind_Decoder_GetAttributeUInt32ForAllPoints_3=t.asm.gb).apply(null,arguments)},jr=t._emscripten_bind_Decoder_GetAttributeDataArrayForAllPoints_5=function(){return(jr=t._emscripten_bind_Decoder_GetAttributeDataArrayForAllPoints_5=t.asm.hb).apply(null,arguments)},Pr=t._emscripten_bind_Decoder_SkipAttributeTransform_1=function(){return(Pr=t._emscripten_bind_Decoder_SkipAttributeTransform_1=t.asm.ib).apply(null,arguments)},Rr=t._emscripten_bind_Decoder_GetEncodedGeometryType_Deprecated_1=function(){return(Rr=t._emscripten_bind_Decoder_GetEncodedGeometryType_Deprecated_1=t.asm.jb).apply(null,arguments)},Sr=t._emscripten_bind_Decoder_DecodeBufferToPointCloud_2=function(){return(Sr=t._emscripten_bind_Decoder_DecodeBufferToPointCloud_2=t.asm.kb).apply(null,arguments)},Mr=t._emscripten_bind_Decoder_DecodeBufferToMesh_2=function(){return(Mr=t._emscripten_bind_Decoder_DecodeBufferToMesh_2=t.asm.lb).apply(null,arguments)},Nr=t._emscripten_bind_Decoder___destroy___0=function(){return(Nr=t._emscripten_bind_Decoder___destroy___0=t.asm.mb).apply(null,arguments)},Ur=t._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_INVALID_TRANSFORM=function(){return(Ur=t._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_INVALID_TRANSFORM=t.asm.nb).apply(null,arguments)},Fr=t._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_NO_TRANSFORM=function(){return(Fr=t._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_NO_TRANSFORM=t.asm.ob).apply(null,arguments)},Lr=t._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_QUANTIZATION_TRANSFORM=function(){return(Lr=t._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_QUANTIZATION_TRANSFORM=t.asm.pb).apply(null,arguments)},Cr=t._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_OCTAHEDRON_TRANSFORM=function(){return(Cr=t._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_OCTAHEDRON_TRANSFORM=t.asm.qb).apply(null,arguments)},wr=t._emscripten_enum_draco_GeometryAttribute_Type_INVALID=function(){return(wr=t._emscripten_enum_draco_GeometryAttribute_Type_INVALID=t.asm.rb).apply(null,arguments)},zr=t._emscripten_enum_draco_GeometryAttribute_Type_POSITION=function(){return(zr=t._emscripten_enum_draco_GeometryAttribute_Type_POSITION=t.asm.sb).apply(null,arguments)},Vr=t._emscripten_enum_draco_GeometryAttribute_Type_NORMAL=function(){return(Vr=t._emscripten_enum_draco_GeometryAttribute_Type_NORMAL=t.asm.tb).apply(null,arguments)},Br=t._emscripten_enum_draco_GeometryAttribute_Type_COLOR=function(){return(Br=t._emscripten_enum_draco_GeometryAttribute_Type_COLOR=t.asm.ub).apply(null,arguments)},Wr=t._emscripten_enum_draco_GeometryAttribute_Type_TEX_COORD=function(){return(Wr=t._emscripten_enum_draco_GeometryAttribute_Type_TEX_COORD=t.asm.vb).apply(null,arguments)},Qr=t._emscripten_enum_draco_GeometryAttribute_Type_GENERIC=function(){return(Qr=t._emscripten_enum_draco_GeometryAttribute_Type_GENERIC=t.asm.wb).apply(null,arguments)},xr=t._emscripten_enum_draco_EncodedGeometryType_INVALID_GEOMETRY_TYPE=function(){return(xr=t._emscripten_enum_draco_EncodedGeometryType_INVALID_GEOMETRY_TYPE=t.asm.xb).apply(null,arguments)},Yr=t._emscripten_enum_draco_EncodedGeometryType_POINT_CLOUD=function(){return(Yr=t._emscripten_enum_draco_EncodedGeometryType_POINT_CLOUD=t.asm.yb).apply(null,arguments)},Hr=t._emscripten_enum_draco_EncodedGeometryType_TRIANGULAR_MESH=function(){return(Hr=t._emscripten_enum_draco_EncodedGeometryType_TRIANGULAR_MESH=t.asm.zb).apply(null,arguments)},qr=t._emscripten_enum_draco_DataType_DT_INVALID=function(){return(qr=t._emscripten_enum_draco_DataType_DT_INVALID=t.asm.Ab).apply(null,arguments)},kr=t._emscripten_enum_draco_DataType_DT_INT8=function(){return(kr=t._emscripten_enum_draco_DataType_DT_INT8=t.asm.Bb).apply(null,arguments)},Xr=t._emscripten_enum_draco_DataType_DT_UINT8=function(){return(Xr=t._emscripten_enum_draco_DataType_DT_UINT8=t.asm.Cb).apply(null,arguments)},Kr=t._emscripten_enum_draco_DataType_DT_INT16=function(){return(Kr=t._emscripten_enum_draco_DataType_DT_INT16=t.asm.Db).apply(null,arguments)},Jr=t._emscripten_enum_draco_DataType_DT_UINT16=function(){return(Jr=t._emscripten_enum_draco_DataType_DT_UINT16=t.asm.Eb).apply(null,arguments)},$r=t._emscripten_enum_draco_DataType_DT_INT32=function(){return($r=t._emscripten_enum_draco_DataType_DT_INT32=t.asm.Fb).apply(null,arguments)},Zr=t._emscripten_enum_draco_DataType_DT_UINT32=function(){return(Zr=t._emscripten_enum_draco_DataType_DT_UINT32=t.asm.Gb).apply(null,arguments)},tn=t._emscripten_enum_draco_DataType_DT_INT64=function(){return(tn=t._emscripten_enum_draco_DataType_DT_INT64=t.asm.Hb).apply(null,arguments)},en=t._emscripten_enum_draco_DataType_DT_UINT64=function(){return(en=t._emscripten_enum_draco_DataType_DT_UINT64=t.asm.Ib).apply(null,arguments)},rn=t._emscripten_enum_draco_DataType_DT_FLOAT32=function(){return(rn=t._emscripten_enum_draco_DataType_DT_FLOAT32=t.asm.Jb).apply(null,arguments)},nn=t._emscripten_enum_draco_DataType_DT_FLOAT64=function(){return(nn=t._emscripten_enum_draco_DataType_DT_FLOAT64=t.asm.Kb).apply(null,arguments)},on=t._emscripten_enum_draco_DataType_DT_BOOL=function(){return(on=t._emscripten_enum_draco_DataType_DT_BOOL=t.asm.Lb).apply(null,arguments)},_n=t._emscripten_enum_draco_DataType_DT_TYPES_COUNT=function(){return(_n=t._emscripten_enum_draco_DataType_DT_TYPES_COUNT=t.asm.Mb).apply(null,arguments)},an=t._emscripten_enum_draco_StatusCode_OK=function(){return(an=t._emscripten_enum_draco_StatusCode_OK=t.asm.Nb).apply(null,arguments)},pn=t._emscripten_enum_draco_StatusCode_DRACO_ERROR=function(){return(pn=t._emscripten_enum_draco_StatusCode_DRACO_ERROR=t.asm.Ob).apply(null,arguments)},un=t._emscripten_enum_draco_StatusCode_IO_ERROR=function(){return(un=t._emscripten_enum_draco_StatusCode_IO_ERROR=t.asm.Pb).apply(null,arguments)},sn=t._emscripten_enum_draco_StatusCode_INVALID_PARAMETER=function(){return(sn=t._emscripten_enum_draco_StatusCode_INVALID_PARAMETER=t.asm.Qb).apply(null,arguments)},cn=t._emscripten_enum_draco_StatusCode_UNSUPPORTED_VERSION=function(){return(cn=t._emscripten_enum_draco_StatusCode_UNSUPPORTED_VERSION=t.asm.Rb).apply(null,arguments)},yn=t._emscripten_enum_draco_StatusCode_UNKNOWN_VERSION=function(){return(yn=t._emscripten_enum_draco_StatusCode_UNKNOWN_VERSION=t.asm.Sb).apply(null,arguments)};t._malloc=function(){return(t._malloc=t.asm.Tb).apply(null,arguments)},t._free=function(){return(t._free=t.asm.Ub).apply(null,arguments)};var ln=function(){return(ln=t.asm.Vb).apply(null,arguments)};t.___start_em_js=15856,t.___stop_em_js=15954;var it;if(rt=function e(){it||K(),it||(rt=e)},t.preInit)for(typeof t.preInit=="function"&&(t.preInit=[t.preInit]);0=d.size?(0>>=0,r.BYTES_PER_ELEMENT){case 2:n>>>=1;break;case 4:n>>>=2;break;case 8:n>>>=3}for(var o=0;oe.byteLength)return t.INVALID_GEOMETRY_TYPE;switch(e[7]){case 0:return t.POINT_CLOUD;case 1:return t.TRIANGULAR_MESH;default:return t.INVALID_GEOMETRY_TYPE}},c.ready}}();typeof nt=="object"&&typeof bt=="object"?bt.exports=dt:typeof define=="function"&&define.amd?define([],function(){return dt}):typeof nt=="object"&&(nt.DracoDecoderModule=dt)});export{Dn as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-LI57NJAL.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-LI57NJAL.js new file mode 100644 index 0000000000000000000000000000000000000000..5e8955ff6f691affaad0efe234a8ea6d8ec56284 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-LI57NJAL.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as f}from"./chunk-P44SUSQU.js";import{a as n,b as c}from"./chunk-FUATUYJ3.js";import{c as I,d as _,e as o}from"./chunk-ODUTJJQ5.js";var P=I((O,d)=>{var u=function(t){t==null&&(t=new Date().getTime()),this.N=624,this.M=397,this.MATRIX_A=2567483615,this.UPPER_MASK=2147483648,this.LOWER_MASK=2147483647,this.mt=new Array(this.N),this.mti=this.N+1,t.constructor==Array?this.init_by_array(t,t.length):this.init_seed(t)};u.prototype.init_seed=function(t){for(this.mt[0]=t>>>0,this.mti=1;this.mti>>30;this.mt[this.mti]=(((t&4294901760)>>>16)*1812433253<<16)+(t&65535)*1812433253+this.mti,this.mt[this.mti]>>>=0}};u.prototype.init_by_array=function(t,i){var e,s,h;for(this.init_seed(19650218),e=1,s=0,h=this.N>i?this.N:i;h;h--){var a=this.mt[e-1]^this.mt[e-1]>>>30;this.mt[e]=(this.mt[e]^(((a&4294901760)>>>16)*1664525<<16)+(a&65535)*1664525)+t[s]+s,this.mt[e]>>>=0,e++,s++,e>=this.N&&(this.mt[0]=this.mt[this.N-1],e=1),s>=i&&(s=0)}for(h=this.N-1;h;h--){var a=this.mt[e-1]^this.mt[e-1]>>>30;this.mt[e]=(this.mt[e]^(((a&4294901760)>>>16)*1566083941<<16)+(a&65535)*1566083941)-e,this.mt[e]>>>=0,e++,e>=this.N&&(this.mt[0]=this.mt[this.N-1],e=1)}this.mt[0]=2147483648};u.prototype.random_int=function(){var t,i=new Array(0,this.MATRIX_A);if(this.mti>=this.N){var e;for(this.mti==this.N+1&&this.init_seed(5489),e=0;e>>1^i[t&1];for(;e>>1^i[t&1];t=this.mt[this.N-1]&this.UPPER_MASK|this.mt[0]&this.LOWER_MASK,this.mt[this.N-1]=this.mt[this.M-1]^t>>>1^i[t&1],this.mti=0}return t=this.mt[this.mti++],t^=t>>>11,t^=t<<7&2636928640,t^=t<<15&4022730752,t^=t>>>18,t>>>0};u.prototype.random_int31=function(){return this.random_int()>>>1};u.prototype.random_incl=function(){return this.random_int()*(1/4294967295)};u.prototype.random=function(){return this.random_int()*(1/4294967296)};u.prototype.random_excl=function(){return(this.random_int()+.5)*(1/4294967296)};u.prototype.random_long=function(){var t=this.random_int()>>>5,i=this.random_int()>>>6;return(t*67108864+i)*(1/9007199254740992)};d.exports=u});var m=_(P(),1);var r={};r.EPSILON1=.1;r.EPSILON2=.01;r.EPSILON3=.001;r.EPSILON4=1e-4;r.EPSILON5=1e-5;r.EPSILON6=1e-6;r.EPSILON7=1e-7;r.EPSILON8=1e-8;r.EPSILON9=1e-9;r.EPSILON10=1e-10;r.EPSILON11=1e-11;r.EPSILON12=1e-12;r.EPSILON13=1e-13;r.EPSILON14=1e-14;r.EPSILON15=1e-15;r.EPSILON16=1e-16;r.EPSILON17=1e-17;r.EPSILON18=1e-18;r.EPSILON19=1e-19;r.EPSILON20=1e-20;r.EPSILON21=1e-21;r.GRAVITATIONALPARAMETER=3986004418e5;r.SOLAR_RADIUS=6955e5;r.LUNAR_RADIUS=1737400;r.SIXTY_FOUR_KILOBYTES=64*1024;r.FOUR_GIGABYTES=4*1024*1024*1024;r.sign=f(Math.sign,function(i){return i=+i,i===0||i!==i?i:i>0?1:-1});r.signNotZero=function(t){return t<0?-1:1};r.toSNorm=function(t,i){return i=f(i,255),Math.round((r.clamp(t,-1,1)*.5+.5)*i)};r.fromSNorm=function(t,i){return i=f(i,255),r.clamp(t,0,i)/i*2-1};r.normalize=function(t,i,e){return e=Math.max(e-i,0),e===0?0:r.clamp((t-i)/e,0,1)};r.sinh=f(Math.sinh,function(i){return(Math.exp(i)-Math.exp(-i))/2});r.cosh=f(Math.cosh,function(i){return(Math.exp(i)+Math.exp(-i))/2});r.lerp=function(t,i,e){return(1-e)*t+e*i};r.PI=Math.PI;r.ONE_OVER_PI=1/Math.PI;r.PI_OVER_TWO=Math.PI/2;r.PI_OVER_THREE=Math.PI/3;r.PI_OVER_FOUR=Math.PI/4;r.PI_OVER_SIX=Math.PI/6;r.THREE_PI_OVER_TWO=3*Math.PI/2;r.TWO_PI=2*Math.PI;r.ONE_OVER_TWO_PI=1/(2*Math.PI);r.RADIANS_PER_DEGREE=Math.PI/180;r.DEGREES_PER_RADIAN=180/Math.PI;r.RADIANS_PER_ARCSECOND=r.RADIANS_PER_DEGREE/3600;r.toRadians=function(t){if(!o(t))throw new n("degrees is required.");return t*r.RADIANS_PER_DEGREE};r.toDegrees=function(t){if(!o(t))throw new n("radians is required.");return t*r.DEGREES_PER_RADIAN};r.convertLongitudeRange=function(t){if(!o(t))throw new n("angle is required.");let i=r.TWO_PI,e=t-Math.floor(t/i)*i;return e<-Math.PI?e+i:e>=Math.PI?e-i:e};r.clampToLatitudeRange=function(t){if(!o(t))throw new n("angle is required.");return r.clamp(t,-1*r.PI_OVER_TWO,r.PI_OVER_TWO)};r.negativePiToPi=function(t){if(!o(t))throw new n("angle is required.");return t>=-r.PI&&t<=r.PI?t:r.zeroToTwoPi(t+r.PI)-r.PI};r.zeroToTwoPi=function(t){if(!o(t))throw new n("angle is required.");if(t>=0&&t<=r.TWO_PI)return t;let i=r.mod(t,r.TWO_PI);return Math.abs(i)r.EPSILON14?r.TWO_PI:i};r.mod=function(t,i){if(!o(t))throw new n("m is required.");if(!o(i))throw new n("n is required.");if(i===0)throw new n("divisor cannot be 0.");return r.sign(t)===r.sign(i)&&Math.abs(t)e};r.greaterThanOrEquals=function(t,i,e){if(!o(t))throw new n("first is required.");if(!o(i))throw new n("second is required.");if(!o(e))throw new n("absoluteEpsilon is required.");return t-i>-e};var w=[1];r.factorial=function(t){if(typeof t!="number"||t<0)throw new n("A number greater than or equal to 0 is required.");let i=w.length;if(t>=i){let e=w[i-1];for(let s=i;s<=t;s++){let h=e*s;w.push(h),e=h}}return w[t]};r.incrementWrap=function(t,i,e){if(e=f(e,0),!o(t))throw new n("n is required.");if(i<=e)throw new n("maximumValue must be greater than minimumValue.");return++t,t>i&&(t=e),t};r.isPowerOfTwo=function(t){if(typeof t!="number"||t<0||t>4294967295)throw new n("A number between 0 and (2^32)-1 is required.");return t!==0&&(t&t-1)===0};r.nextPowerOfTwo=function(t){if(typeof t!="number"||t<0||t>2147483648)throw new n("A number between 0 and 2^31 is required.");return--t,t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,++t,t};r.previousPowerOfTwo=function(t){if(typeof t!="number"||t<0||t>4294967295)throw new n("A number between 0 and (2^32)-1 is required.");return t|=t>>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,t|=t>>32,t=(t>>>0)-(t>>>1),t};r.clamp=function(t,i,e){return c.typeOf.number("value",t),c.typeOf.number("min",i),c.typeOf.number("max",e),te?e:t};var E=new m.default;r.setRandomNumberSeed=function(t){if(!o(t))throw new n("seed is required.");E=new m.default(t)};r.nextRandomNumber=function(){return E.random()};r.randomBetween=function(t,i){return r.nextRandomNumber()*(i-t)+t};r.acosClamped=function(t){if(!o(t))throw new n("value is required.");return Math.acos(r.clamp(t,-1,1))};r.asinClamped=function(t){if(!o(t))throw new n("value is required.");return Math.asin(r.clamp(t,-1,1))};r.chordLength=function(t,i){if(!o(t))throw new n("angle is required.");if(!o(i))throw new n("radius is required.");return 2*i*Math.sin(t*.5)};r.logBase=function(t,i){if(!o(t))throw new n("number is required.");if(!o(i))throw new n("base is required.");return Math.log(t)/Math.log(i)};r.cbrt=f(Math.cbrt,function(i){let e=Math.pow(Math.abs(i),.3333333333333333);return i<0?-e:e});r.log2=f(Math.log2,function(i){return Math.log(i)*Math.LOG2E});r.fog=function(t,i){let e=t*i;return 1-Math.exp(-(e*e))};r.fastApproximateAtan=function(t){return c.typeOf.number("x",t),t*(-.1784*Math.abs(t)-.0663*t*t+1.0301)};r.fastApproximateAtan2=function(t,i){c.typeOf.number("x",t),c.typeOf.number("y",i);let e,s=Math.abs(t);e=Math.abs(i);let h=Math.max(s,e);e=Math.min(s,e);let a=e/h;if(isNaN(a))throw new n("either x or y must be nonzero");return s=r.fastApproximateAtan(a),s=Math.abs(i)>Math.abs(t)?r.PI_OVER_TWO-s:s,s=t<0?r.PI-s:s,s=i<0?-s:s,s};var A=r;export{A as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-LLBHZLGF.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-LLBHZLGF.js new file mode 100644 index 0000000000000000000000000000000000000000..909b5e9bc584393eb6e7a814e524aa9c08febda3 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-LLBHZLGF.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{b as d}from"./chunk-NNIY7VTE.js";import{a as i}from"./chunk-C6Y3PRDH.js";import{a as z}from"./chunk-P44SUSQU.js";import{b as r}from"./chunk-FUATUYJ3.js";import{e as c}from"./chunk-ODUTJJQ5.js";function t(m,n,e){this.minimum=i.clone(z(m,i.ZERO)),this.maximum=i.clone(z(n,i.ZERO)),c(e)?e=i.clone(e):e=i.midpoint(this.minimum,this.maximum,new i),this.center=e}t.fromCorners=function(m,n,e){return r.defined("minimum",m),r.defined("maximum",n),c(e)||(e=new t),e.minimum=i.clone(m,e.minimum),e.maximum=i.clone(n,e.maximum),e.center=i.midpoint(m,n,e.center),e};t.fromPoints=function(m,n){if(c(n)||(n=new t),!c(m)||m.length===0)return n.minimum=i.clone(i.ZERO,n.minimum),n.maximum=i.clone(i.ZERO,n.maximum),n.center=i.clone(i.ZERO,n.center),n;let e=m[0].x,a=m[0].y,u=m[0].z,o=m[0].x,y=m[0].y,l=m[0].z,I=m.length;for(let E=1;E0?d.INSIDE:o+u<0?d.OUTSIDE:d.INTERSECTING};t.prototype.clone=function(m){return t.clone(this,m)};t.prototype.intersectPlane=function(m){return t.intersectPlane(this,m)};t.prototype.equals=function(m){return t.equals(this,m)};var P=t;export{P as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-LQRZQ5E6.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-LQRZQ5E6.js new file mode 100644 index 0000000000000000000000000000000000000000..7aaf7628c63df4a5662edb2ee16a049d2e8b34e4 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-LQRZQ5E6.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as y,b as P,c as W}from"./chunk-C6Y3PRDH.js";import{a as L}from"./chunk-LI57NJAL.js";import{a as B}from"./chunk-P44SUSQU.js";import{b as q}from"./chunk-FUATUYJ3.js";import{e as T}from"./chunk-ODUTJJQ5.js";function Y(n){let a=n._uSquared,t=n._ellipsoid.maximumRadius,e=n._ellipsoid.minimumRadius,f=(t-e)/t,m=Math.cos(n._startHeading),_=Math.sin(n._startHeading),r=(1-f)*Math.tan(n._start.latitude),p=1/Math.sqrt(1+r*r),R=p*r,M=Math.atan2(r,m),l=p*_,U=l*l,i=1-U,A=Math.sqrt(i),c=a/4,o=c*c,h=o*c,S=o*o,u=1+c-3*o/4+5*h/4-175*S/64,C=1-c+15*o/8-35*h/8,d=1-3*c+35*o/4,g=1-5*c,w=u*M-C*Math.sin(2*M)*c/2-d*Math.sin(4*M)*o/16-g*Math.sin(6*M)*h/48-Math.sin(8*M)*5*S/512,s=n._constants;s.a=t,s.b=e,s.f=f,s.cosineHeading=m,s.sineHeading=_,s.tanU=r,s.cosineU=p,s.sineU=R,s.sigma=M,s.sineAlpha=l,s.sineSquaredAlpha=U,s.cosineSquaredAlpha=i,s.cosineAlpha=A,s.u2Over4=c,s.u4Over16=o,s.u6Over64=h,s.u8Over256=S,s.a0=u,s.a1=C,s.a2=d,s.a3=g,s.distanceRatio=w}function Z(n,a){return n*a*(4+n*(4-3*a))/16}function k(n,a,t,e,f,m,_){let r=Z(n,t);return(1-r)*n*a*(e+r*f*(_+r*m*(2*_*_-1)))}function $(n,a,t,e,f,m,_){let r=(a-t)/a,p=m-e,R=Math.atan((1-r)*Math.tan(f)),M=Math.atan((1-r)*Math.tan(_)),l=Math.cos(R),U=Math.sin(R),i=Math.cos(M),A=Math.sin(M),c=l*i,o=l*A,h=U*A,S=U*i,u=p,C=L.TWO_PI,d=Math.cos(u),g=Math.sin(u),w,s,O,H,b;do{d=Math.cos(u),g=Math.sin(u);let z=o-S*d;O=Math.sqrt(i*i*g*g+z*z),s=h+c*d,w=Math.atan2(O,s);let D;O===0?(D=0,H=1):(D=c*g/O,H=1-D*D),C=u,b=s-2*h/H,isFinite(b)||(b=0),u=p+k(r,D,H,w,O,s,b)}while(Math.abs(u-C)>L.EPSILON12);let v=H*(a*a-t*t)/(t*t),V=1+v*(4096+v*(v*(320-175*v)-768))/16384,I=v*(256+v*(v*(74-47*v)-128))/1024,F=b*b,J=I*O*(b+I*(s*(2*F-1)-I*b*(4*O*O-3)*(4*F-3)/6)/4),K=t*V*(w-J),Q=Math.atan2(i*g,o-S*d),X=Math.atan2(l*g,o*d-S);n._distance=K,n._startHeading=Q,n._endHeading=X,n._uSquared=v}var j=new y,x=new y;function N(n,a,t,e){let f=y.normalize(e.cartographicToCartesian(a,x),j),m=y.normalize(e.cartographicToCartesian(t,x),x);q.typeOf.number.greaterThanOrEquals("value",Math.abs(Math.abs(y.angleBetween(f,m))-Math.PI),.0125),$(n,e.maximumRadius,e.minimumRadius,a.longitude,a.latitude,t.longitude,t.latitude),n._start=P.clone(a,n._start),n._end=P.clone(t,n._end),n._start.height=0,n._end.height=0,Y(n)}function E(n,a,t){let e=B(t,W.WGS84);this._ellipsoid=e,this._start=new P,this._end=new P,this._constants={},this._startHeading=void 0,this._endHeading=void 0,this._distance=void 0,this._uSquared=void 0,T(n)&&T(a)&&N(this,n,a,e)}Object.defineProperties(E.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},surfaceDistance:{get:function(){return q.defined("distance",this._distance),this._distance}},start:{get:function(){return this._start}},end:{get:function(){return this._end}},startHeading:{get:function(){return q.defined("distance",this._distance),this._startHeading}},endHeading:{get:function(){return q.defined("distance",this._distance),this._endHeading}}});E.prototype.setEndPoints=function(n,a){q.defined("start",n),q.defined("end",a),N(this,n,a,this._ellipsoid)};E.prototype.interpolateUsingFraction=function(n,a){return this.interpolateUsingSurfaceDistance(this._distance*n,a)};E.prototype.interpolateUsingSurfaceDistance=function(n,a){q.defined("distance",this._distance);let t=this._constants,e=t.distanceRatio+n/t.b,f=Math.cos(2*e),m=Math.cos(4*e),_=Math.cos(6*e),r=Math.sin(2*e),p=Math.sin(4*e),R=Math.sin(6*e),M=Math.sin(8*e),l=e*e,U=e*l,i=t.u8Over256,A=t.u2Over4,c=t.u6Over64,o=t.u4Over16,h=2*U*i*f/3+e*(1-A+7*o/4-15*c/4+579*i/64-(o-15*c/4+187*i/16)*f-(5*c/4-115*i/16)*m-29*i*_/16)+(A/2-o+71*c/32-85*i/16)*r+(5*o/16-5*c/4+383*i/96)*p-l*((c-11*i/2)*r+5*i*p/2)+(29*c/96-29*i/16)*R+539*i*M/1536,S=Math.asin(Math.sin(h)*t.cosineAlpha),u=Math.atan(t.a/t.b*Math.tan(S));h=h-t.sigma;let C=Math.cos(2*t.sigma+h),d=Math.sin(h),g=Math.cos(h),w=t.cosineU*g,s=t.sineU*d,H=Math.atan2(d*t.sineHeading,w-s*t.cosineHeading)-k(t.f,t.sineAlpha,t.cosineSquaredAlpha,h,d,g,C);return T(a)?(a.longitude=this._start.longitude+H,a.latitude=u,a.height=0,a):new P(this._start.longitude+H,u,0)};var ct=E;export{ct as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-M3OLDEEW.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-M3OLDEEW.js new file mode 100644 index 0000000000000000000000000000000000000000..224d2c4b21564df204b10c1154d8a235ced28bb5 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-M3OLDEEW.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as t}from"./chunk-P44SUSQU.js";import{a as O}from"./chunk-FUATUYJ3.js";import{e as f}from"./chunk-ODUTJJQ5.js";function n(e){e=t(e,t.EMPTY_OBJECT),this.position=t(e.position,!1),this.normal=t(e.normal,!1),this.st=t(e.st,!1),this.bitangent=t(e.bitangent,!1),this.tangent=t(e.tangent,!1),this.color=t(e.color,!1)}n.POSITION_ONLY=Object.freeze(new n({position:!0}));n.POSITION_AND_NORMAL=Object.freeze(new n({position:!0,normal:!0}));n.POSITION_NORMAL_AND_ST=Object.freeze(new n({position:!0,normal:!0,st:!0}));n.POSITION_AND_ST=Object.freeze(new n({position:!0,st:!0}));n.POSITION_AND_COLOR=Object.freeze(new n({position:!0,color:!0}));n.ALL=Object.freeze(new n({position:!0,normal:!0,st:!0,tangent:!0,bitangent:!0}));n.DEFAULT=n.POSITION_NORMAL_AND_ST;n.packedLength=6;n.pack=function(e,o,i){if(!f(e))throw new O("value is required");if(!f(o))throw new O("array is required");return i=t(i,0),o[i++]=e.position?1:0,o[i++]=e.normal?1:0,o[i++]=e.st?1:0,o[i++]=e.tangent?1:0,o[i++]=e.bitangent?1:0,o[i]=e.color?1:0,o};n.unpack=function(e,o,i){if(!f(e))throw new O("array is required");return o=t(o,0),f(i)||(i=new n),i.position=e[o++]===1,i.normal=e[o++]===1,i.st=e[o++]===1,i.tangent=e[o++]===1,i.bitangent=e[o++]===1,i.color=e[o]===1,i};n.clone=function(e,o){if(f(e))return f(o)||(o=new n),o.position=e.position,o.normal=e.normal,o.st=e.st,o.tangent=e.tangent,o.bitangent=e.bitangent,o.color=e.color,o};var _=n;export{_ as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-MUMMGJJL.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-MUMMGJJL.js new file mode 100644 index 0000000000000000000000000000000000000000..cb153974d297a182690f9bf7137f6712b5a2d85b --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-MUMMGJJL.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as ue}from"./chunk-Y5NK5HSS.js";import{b as he,c as pe,d as ne}from"./chunk-A4RD4IQP.js";import{d as w}from"./chunk-5EDTRNG5.js";import{a as te}from"./chunk-IO6LETQ6.js";import{a as p,b as ee,c as Se}from"./chunk-C6Y3PRDH.js";import{a as Y}from"./chunk-LI57NJAL.js";import{a as le}from"./chunk-IBAO62UG.js";import{a as K}from"./chunk-P44SUSQU.js";import{b}from"./chunk-FUATUYJ3.js";import{c as We,d as Ge,e as D}from"./chunk-ODUTJJQ5.js";var Oe=We((st,de)=>{"use strict";de.exports=xe;de.exports.default=xe;function xe(e,n,t){t=t||2;var u=n&&n.length,r=u?n[0]*t:e.length,i=Ce(e,0,r,t,!0),s=[];if(!i||i.next===i.prev)return s;var o,f,c,l,y,v,g;if(u&&(i=ke(e,n,i,t)),e.length>80*t){o=c=e[0],f=l=e[1];for(var h=t;hc&&(c=y),v>l&&(l=v);g=Math.max(c-o,l-f),g=g!==0?32767/g:0}return re(i,s,t,o,f,g,0),s}function Ce(e,n,t,u,r){var i,s;if(r===ge(e,n,t,u)>0)for(i=n;i=n;i-=u)s=Ae(i,e[i],e[i+1],s);return s&&ae(s,s.next)&&(oe(s),s=s.next),s}function N(e,n){if(!e)return e;n||(n=e);var t=e,u;do if(u=!1,!t.steiner&&(ae(t,t.next)||A(t.prev,t,t.next)===0)){if(oe(t),t=n=t.prev,t===t.next)break;u=!0}else t=t.next;while(u||t!==n);return n}function re(e,n,t,u,r,i,s){if(e){!s&&i&&qe(e,u,r,i);for(var o=e,f,c;e.prev!==e.next;){if(f=e.prev,c=e.next,i?Ie(e,u,r,i):$e(e)){n.push(f.i/t|0),n.push(e.i/t|0),n.push(c.i/t|0),oe(e),e=c.next,o=c.next;continue}if(e=c,e===o){s?s===1?(e=He(N(e),n,t),re(e,n,t,u,r,i,2)):s===2&&Ne(e,n,t,u,r,i):re(N(e),n,t,u,r,i,1);break}}}}function $e(e){var n=e.prev,t=e,u=e.next;if(A(n,t,u)>=0)return!1;for(var r=n.x,i=t.x,s=u.x,o=n.y,f=t.y,c=u.y,l=ri?r>s?r:s:i>s?i:s,g=o>f?o>c?o:c:f>c?f:c,h=u.next;h!==n;){if(h.x>=l&&h.x<=v&&h.y>=y&&h.y<=g&&V(r,o,i,f,s,c,h.x,h.y)&&A(h.prev,h,h.next)>=0)return!1;h=h.next}return!0}function Ie(e,n,t,u){var r=e.prev,i=e,s=e.next;if(A(r,i,s)>=0)return!1;for(var o=r.x,f=i.x,c=s.x,l=r.y,y=i.y,v=s.y,g=of?o>c?o:c:f>c?f:c,L=l>y?l>v?l:v:y>v?y:v,z=ye(g,h,n,t,u),F=ye(T,L,n,t,u),x=e.prevZ,a=e.nextZ;x&&x.z>=z&&a&&a.z<=F;){if(x.x>=g&&x.x<=T&&x.y>=h&&x.y<=L&&x!==r&&x!==s&&V(o,l,f,y,c,v,x.x,x.y)&&A(x.prev,x,x.next)>=0||(x=x.prevZ,a.x>=g&&a.x<=T&&a.y>=h&&a.y<=L&&a!==r&&a!==s&&V(o,l,f,y,c,v,a.x,a.y)&&A(a.prev,a,a.next)>=0))return!1;a=a.nextZ}for(;x&&x.z>=z;){if(x.x>=g&&x.x<=T&&x.y>=h&&x.y<=L&&x!==r&&x!==s&&V(o,l,f,y,c,v,x.x,x.y)&&A(x.prev,x,x.next)>=0)return!1;x=x.prevZ}for(;a&&a.z<=F;){if(a.x>=g&&a.x<=T&&a.y>=h&&a.y<=L&&a!==r&&a!==s&&V(o,l,f,y,c,v,a.x,a.y)&&A(a.prev,a,a.next)>=0)return!1;a=a.nextZ}return!0}function He(e,n,t){var u=e;do{var r=u.prev,i=u.next.next;!ae(r,i)&&be(r,u,u.next,i)&&ie(r,i)&&ie(i,r)&&(n.push(r.i/t|0),n.push(u.i/t|0),n.push(i.i/t|0),oe(u),oe(u.next),u=e=i),u=u.next}while(u!==e);return N(u)}function Ne(e,n,t,u,r,i){var s=e;do{for(var o=s.next.next;o!==s.prev;){if(s.i!==o.i&&je(s,o)){var f=Ee(s,o);s=N(s,s.next),f=N(f,f.next),re(s,n,t,u,r,i,0),re(f,n,t,u,r,i,0);return}o=o.next}s=s.next}while(s!==e)}function ke(e,n,t,u){var r=[],i,s,o,f,c;for(i=0,s=n.length;i=t.next.y&&t.next.y!==t.y){var o=t.x+(r-t.y)*(t.next.x-t.x)/(t.next.y-t.y);if(o<=u&&o>i&&(i=o,s=t.x=t.x&&t.x>=c&&u!==t.x&&V(rs.x||t.x===s.x&&Ve(s,t)))&&(s=t,y=v)),t=t.next;while(t!==f);return s}function Ve(e,n){return A(e.prev,e,n.prev)<0&&A(n.next,e,e.next)<0}function qe(e,n,t,u){var r=e;do r.z===0&&(r.z=ye(r.x,r.y,n,t,u)),r.prevZ=r.prev,r.nextZ=r.next,r=r.next;while(r!==e);r.prevZ.nextZ=null,r.prevZ=null,Je(r)}function Je(e){var n,t,u,r,i,s,o,f,c=1;do{for(t=e,e=null,i=null,s=0;t;){for(s++,u=t,o=0,n=0;n0||f>0&&u;)o!==0&&(f===0||!u||t.z<=u.z)?(r=t,t=t.nextZ,o--):(r=u,u=u.nextZ,f--),i?i.nextZ=r:e=r,r.prevZ=i,i=r;t=u}i.nextZ=null,c*=2}while(s>1);return e}function ye(e,n,t,u,r){return e=(e-t)*r|0,n=(n-u)*r|0,e=(e|e<<8)&16711935,e=(e|e<<4)&252645135,e=(e|e<<2)&858993459,e=(e|e<<1)&1431655765,n=(n|n<<8)&16711935,n=(n|n<<4)&252645135,n=(n|n<<2)&858993459,n=(n|n<<1)&1431655765,e|n<<1}function Qe(e){var n=e,t=e;do(n.x=(e-s)*(i-o)&&(e-s)*(u-o)>=(t-s)*(n-o)&&(t-s)*(i-o)>=(r-s)*(u-o)}function je(e,n){return e.next.i!==n.i&&e.prev.i!==n.i&&!Xe(e,n)&&(ie(e,n)&&ie(n,e)&&Ye(e,n)&&(A(e.prev,e,n.prev)||A(e,n.prev,n))||ae(e,n)&&A(e.prev,e,e.next)>0&&A(n.prev,n,n.next)>0)}function A(e,n,t){return(n.y-e.y)*(t.x-n.x)-(n.x-e.x)*(t.y-n.y)}function ae(e,n){return e.x===n.x&&e.y===n.y}function be(e,n,t,u){var r=fe(A(e,n,t)),i=fe(A(e,n,u)),s=fe(A(t,u,e)),o=fe(A(t,u,n));return!!(r!==i&&s!==o||r===0&&ce(e,t,n)||i===0&&ce(e,u,n)||s===0&&ce(t,e,u)||o===0&&ce(t,n,u))}function ce(e,n,t){return n.x<=Math.max(e.x,t.x)&&n.x>=Math.min(e.x,t.x)&&n.y<=Math.max(e.y,t.y)&&n.y>=Math.min(e.y,t.y)}function fe(e){return e>0?1:e<0?-1:0}function Xe(e,n){var t=e;do{if(t.i!==e.i&&t.next.i!==e.i&&t.i!==n.i&&t.next.i!==n.i&&be(t,t.next,e,n))return!0;t=t.next}while(t!==e);return!1}function ie(e,n){return A(e.prev,e,e.next)<0?A(e,n,e.next)>=0&&A(e,e.prev,n)>=0:A(e,n,e.prev)<0||A(e,e.next,n)<0}function Ye(e,n){var t=e,u=!1,r=(e.x+n.x)/2,i=(e.y+n.y)/2;do t.y>i!=t.next.y>i&&t.next.y!==t.y&&r<(t.next.x-t.x)*(i-t.y)/(t.next.y-t.y)+t.x&&(u=!u),t=t.next;while(t!==e);return u}function Ee(e,n){var t=new me(e.i,e.x,e.y),u=new me(n.i,n.x,n.y),r=e.next,i=n.prev;return e.next=n,n.prev=e,t.next=r,r.prev=t,u.next=t,t.prev=u,i.next=u,u.prev=i,u}function Ae(e,n,t,u){var r=new me(e,n,t);return u?(r.next=u.next,r.prev=u,u.next.prev=r,u.next=r):(r.prev=r,r.next=r),r}function oe(e){e.next.prev=e.prev,e.prev.next=e.next,e.prevZ&&(e.prevZ.nextZ=e.nextZ),e.nextZ&&(e.nextZ.prevZ=e.prevZ)}function me(e,n,t){this.i=e,this.x=n,this.y=t,this.prev=null,this.next=null,this.z=0,this.prevZ=null,this.nextZ=null,this.steiner=!1}xe.deviation=function(e,n,t,u){var r=n&&n.length,i=r?n[0]*t:e.length,s=Math.abs(ge(e,0,i,t));if(r)for(var o=0,f=n.length;o0&&(u+=e[r-1].length,t.holes.push(u))}return t}});var se={CLOCKWISE:le.CW,COUNTER_CLOCKWISE:le.CCW};se.validate=function(e){return e===se.CLOCKWISE||e===se.COUNTER_CLOCKWISE};var ve=Object.freeze(se);var Le=Ge(Oe(),1);var et=new p,tt=new p,B={};B.computeArea2D=function(e){b.defined("positions",e),b.typeOf.number.greaterThanOrEquals("positions.length",e.length,3);let n=e.length,t=0;for(let u=n-1,r=0;r0?ve.COUNTER_CLOCKWISE:ve.CLOCKWISE};B.triangulate=function(e,n){b.defined("positions",e);let t=w.packArray(e);return(0,Le.default)(t,n,2)};var De=new p,Fe=new p,Pe=new p,Te=new p,Me=new p,Ze=new p,R=new p,Re=new w,ze=new w,Be=new w,q=new w;B.computeSubdivision=function(e,n,t,u,r){r=K(r,Y.RADIANS_PER_DEGREE);let i=D(u);b.typeOf.object("ellipsoid",e),b.defined("positions",n),b.defined("indices",t),b.typeOf.number.greaterThanOrEquals("indices.length",t.length,3),b.typeOf.number.equals("indices.length % 3","0",t.length%3,0),b.typeOf.number.greaterThan("granularity",r,0);let s=t.slice(0),o,f=n.length,c=new Array(f*3),l=new Array(f*2),y=0,v=0;for(o=0;o0;){let x=s.pop(),a=s.pop(),m=s.pop(),C=p.fromArray(c,m*3,De),E=p.fromArray(c,a*3,Fe),J=p.fromArray(c,x*3,Pe),Q,j,W;i&&(Q=w.fromArray(l,m*2,Re),j=w.fromArray(l,a*2,ze),W=w.fromArray(l,x*2,Be));let k=p.multiplyByScalar(p.normalize(C,Te),T,Te),U=p.multiplyByScalar(p.normalize(E,Me),T,Me),G=p.multiplyByScalar(p.normalize(J,Ze),T,Ze),$=p.magnitudeSquared(p.subtract(k,U,R)),I=p.magnitudeSquared(p.subtract(U,G,R)),X=p.magnitudeSquared(p.subtract(G,k,R)),H=Math.max($,I,X),M,S,d;H>z?$===H?(M=`${Math.min(m,a)} ${Math.max(m,a)}`,o=h[M],D(o)||(S=p.add(C,E,R),p.multiplyByScalar(S,.5,S),c.push(S.x,S.y,S.z),o=c.length/3-1,h[M]=o,i&&(d=w.add(Q,j,q),w.multiplyByScalar(d,.5,d),l.push(d.x,d.y))),s.push(m,o,x),s.push(o,a,x)):I===H?(M=`${Math.min(a,x)} ${Math.max(a,x)}`,o=h[M],D(o)||(S=p.add(E,J,R),p.multiplyByScalar(S,.5,S),c.push(S.x,S.y,S.z),o=c.length/3-1,h[M]=o,i&&(d=w.add(j,W,q),w.multiplyByScalar(d,.5,d),l.push(d.x,d.y))),s.push(a,o,m),s.push(o,x,m)):X===H&&(M=`${Math.min(x,m)} ${Math.max(x,m)}`,o=h[M],D(o)||(S=p.add(J,C,R),p.multiplyByScalar(S,.5,S),c.push(S.x,S.y,S.z),o=c.length/3-1,h[M]=o,i&&(d=w.add(W,Q,q),w.multiplyByScalar(d,.5,d),l.push(d.x,d.y))),s.push(x,o,a),s.push(o,m,a)):(g.push(m),g.push(a),g.push(x))}let F={attributes:{position:new ne({componentDatatype:te.DOUBLE,componentsPerAttribute:3,values:c})},indices:g,primitiveType:he.TRIANGLES};return i&&(F.attributes.st=new ne({componentDatatype:te.FLOAT,componentsPerAttribute:2,values:l})),new pe(F)};var nt=new ee,rt=new ee,it=new ee,we=new ee;B.computeRhumbLineSubdivision=function(e,n,t,u,r){r=K(r,Y.RADIANS_PER_DEGREE);let i=D(u);b.typeOf.object("ellipsoid",e),b.defined("positions",n),b.defined("indices",t),b.typeOf.number.greaterThanOrEquals("indices.length",t.length,3),b.typeOf.number.equals("indices.length % 3","0",t.length%3,0),b.typeOf.number.greaterThan("granularity",r,0);let s=t.slice(0),o,f=n.length,c=new Array(f*3),l=new Array(f*2),y=0,v=0;for(o=0;o0;){let m=s.pop(),C=s.pop(),E=s.pop(),J=p.fromArray(c,E*3,De),Q=p.fromArray(c,C*3,Fe),j=p.fromArray(c,m*3,Pe),W,k,U;i&&(W=w.fromArray(l,E*2,Re),k=w.fromArray(l,C*2,ze),U=w.fromArray(l,m*2,Be));let G=e.cartesianToCartographic(J,nt),$=e.cartesianToCartographic(Q,rt),I=e.cartesianToCartographic(j,it);z.setEndPoints(G,$);let X=z.surfaceDistance;F.setEndPoints($,I);let H=F.surfaceDistance;x.setEndPoints(I,G);let M=x.surfaceDistance,S=Math.max(X,H,M),d,P,_,Z,O;S>L?X===S?(d=`${Math.min(E,C)} ${Math.max(E,C)}`,o=h[d],D(o)||(P=z.interpolateUsingFraction(.5,we),_=(G.height+$.height)*.5,Z=p.fromRadians(P.longitude,P.latitude,_,e,R),c.push(Z.x,Z.y,Z.z),o=c.length/3-1,h[d]=o,i&&(O=w.add(W,k,q),w.multiplyByScalar(O,.5,O),l.push(O.x,O.y))),s.push(E,o,m),s.push(o,C,m)):H===S?(d=`${Math.min(C,m)} ${Math.max(C,m)}`,o=h[d],D(o)||(P=F.interpolateUsingFraction(.5,we),_=($.height+I.height)*.5,Z=p.fromRadians(P.longitude,P.latitude,_,e,R),c.push(Z.x,Z.y,Z.z),o=c.length/3-1,h[d]=o,i&&(O=w.add(k,U,q),w.multiplyByScalar(O,.5,O),l.push(O.x,O.y))),s.push(C,o,E),s.push(o,m,E)):M===S&&(d=`${Math.min(m,E)} ${Math.max(m,E)}`,o=h[d],D(o)||(P=x.interpolateUsingFraction(.5,we),_=(I.height+G.height)*.5,Z=p.fromRadians(P.longitude,P.latitude,_,e,R),c.push(Z.x,Z.y,Z.z),o=c.length/3-1,h[d]=o,i&&(O=w.add(U,W,q),w.multiplyByScalar(O,.5,O),l.push(O.x,O.y))),s.push(m,o,C),s.push(o,E,C)):(g.push(E),g.push(C),g.push(m))}let a={attributes:{position:new ne({componentDatatype:te.DOUBLE,componentsPerAttribute:3,values:c})},indices:g,primitiveType:he.TRIANGLES};return i&&(a.attributes.st=new ne({componentDatatype:te.FLOAT,componentsPerAttribute:2,values:l})),new pe(a)};B.scaleToGeodeticHeight=function(e,n,t,u){t=K(t,Se.WGS84);let r=et,i=tt;if(n=K(n,0),u=K(u,!0),D(e)){let s=e.length;for(let o=0;oe.MaximumLatitude?t=e.MaximumLatitude:t<-e.MaximumLatitude&&(t=-e.MaximumLatitude);let i=Math.sin(t);return .5*Math.log((1+i)/(1-i))};e.MaximumLatitude=e.mercatorAngleToGeodeticLatitude(Math.PI);e.prototype.project=function(t,i){let o=this._semimajorAxis,r=t.longitude*o,n=e.geodeticLatitudeToMercatorAngle(t.latitude)*o,m=t.height;return a(i)?(i.x=r,i.y=n,i.z=m,i):new c(r,n,m)};e.prototype.unproject=function(t,i){if(!a(t))throw new s("cartesian is required");let o=this._oneOverSemimajorAxis,r=t.x*o,n=e.mercatorAngleToGeodeticLatitude(t.y*o),m=t.z;return a(i)?(i.longitude=r,i.latitude=n,i.height=m,i):new p(r,n,m)};var L=e;export{L as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-NNIY7VTE.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-NNIY7VTE.js new file mode 100644 index 0000000000000000000000000000000000000000..dd79581cc512ea377b18068a45e9954b48ef91be --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-NNIY7VTE.js @@ -0,0 +1,62 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as qe}from"./chunk-NX64RCXJ.js";import{a as xt,b as L,c as vt,d as sn}from"./chunk-5EDTRNG5.js";import{a as f,b as De,c as ze,d as B}from"./chunk-C6Y3PRDH.js";import{a as J}from"./chunk-LI57NJAL.js";import{a as Ee}from"./chunk-3NARV6MR.js";import{a as O}from"./chunk-P44SUSQU.js";import{a as R,b as w}from"./chunk-FUATUYJ3.js";import{a as _t,c as St,d as Ge,e as d}from"./chunk-ODUTJJQ5.js";var or=St((et,tt)=>{/*! https://mths.be/punycode v1.4.0 by @mathias */(function(e){var t=typeof et=="object"&&et&&!et.nodeType&&et,n=typeof tt=="object"&&tt&&!tt.nodeType&&tt,i=typeof global=="object"&&global;(i.global===i||i.window===i||i.self===i)&&(e=i);var s,o=2147483647,c=36,u=1,p=26,b=38,g=700,y=72,S=128,A="-",I=/^xn--/,T=/[^\x20-\x7E]/,k=/[\x2E\u3002\uFF0E\uFF61]/g,D={overflow:"Overflow: input needs wider integers to process","not-basic":"Illegal input >= 0x80 (not a basic code point)","invalid-input":"Invalid input"},F=c-u,z=Math.floor,M=String.fromCharCode,N;function Y(h){throw new RangeError(D[h])}function oe(h,P){for(var q=h.length,V=[];q--;)V[q]=P(h[q]);return V}function ie(h,P){var q=h.split("@"),V="";q.length>1&&(V=q[0]+"@",h=q[1]),h=h.replace(k,".");var ne=h.split("."),se=oe(ne,P).join(".");return V+se}function X(h){for(var P=[],q=0,V=h.length,ne,se;q=55296&&ne<=56319&&q65535&&(P-=65536,q+=M(P>>>10&1023|55296),P=56320|P&1023),q+=M(P),q}).join("")}function Q(h){return h-48<10?h-22:h-65<26?h-65:h-97<26?h-97:c}function r(h,P){return h+22+75*(h<26)-((P!=0)<<5)}function a(h,P,q){var V=0;for(h=q?z(h/g):h>>1,h+=z(h/P);h>F*p>>1;V+=c)h=z(h/F);return z(V+(F+1)*h/(h+b))}function l(h){var P=[],q=h.length,V,ne=0,se=S,G=y,ae,he,be,ye,fe,_e,xe,Ue,Le;for(ae=h.lastIndexOf(A),ae<0&&(ae=0),he=0;he=128&&Y("not-basic"),P.push(h.charCodeAt(he));for(be=ae>0?ae+1:0;be=q&&Y("invalid-input"),xe=Q(h.charCodeAt(be++)),(xe>=c||xe>z((o-ne)/fe))&&Y("overflow"),ne+=xe*fe,Ue=_e<=G?u:_e>=G+p?p:_e-G,!(xez(o/Le)&&Y("overflow"),fe*=Le;V=P.length+1,G=a(ne-ye,V,ye==0),z(ne/V)>o-se&&Y("overflow"),se+=z(ne/V),ne%=V,P.splice(ne++,0,se)}return W(P)}function m(h){var P,q,V,ne,se,G,ae,he,be,ye,fe,_e=[],xe,Ue,Le,on;for(h=X(h),xe=h.length,P=S,q=0,se=y,G=0;G=P&&fez((o-q)/Ue)&&Y("overflow"),q+=(ae-P)*Ue,P=ae,G=0;Go&&Y("overflow"),fe==P){for(he=q,be=c;ye=be<=se?u:be>=se+p?p:be-se,!(he{/*! + * URI.js - Mutating URLs + * IPv6 Support + * + * Version: 1.19.11 + * + * Author: Rodney Rehm + * Web: http://medialize.github.io/URI.js/ + * + * Licensed under + * MIT License http://www.opensource.org/licenses/mit-license + * + */(function(e,t){"use strict";typeof It=="object"&&It.exports?It.exports=t():typeof define=="function"&&define.amd?define(t):e.IPv6=t(e)})(ir,function(e){"use strict";var t=e&&e.IPv6;function n(s){var o=s.toLowerCase(),c=o.split(":"),u=c.length,p=8;c[0]===""&&c[1]===""&&c[2]===""?(c.shift(),c.shift()):c[0]===""&&c[1]===""?c.shift():c[u-1]===""&&c[u-2]===""&&c.pop(),u=c.length,c[u-1].indexOf(".")!==-1&&(p=7);var b;for(b=0;b1);S++)g.splice(0,1);c[y]=g.join("")}var A=-1,I=0,T=0,k=-1,D=!1;for(y=0;yI&&(A=k,I=T)):c[y]==="0"&&(D=!0,k=y,T=1);T>I&&(A=k,I=T),I>1&&c.splice(A,I,""),u=c.length;var F="";for(c[0]===""&&(F=":"),y=0;y{/*! + * URI.js - Mutating URLs + * Second Level Domain (SLD) Support + * + * Version: 1.19.11 + * + * Author: Rodney Rehm + * Web: http://medialize.github.io/URI.js/ + * + * Licensed under + * MIT License http://www.opensource.org/licenses/mit-license + * + */(function(e,t){"use strict";typeof Ut=="object"&&Ut.exports?Ut.exports=t():typeof define=="function"&&define.amd?define(t):e.SecondLevelDomains=t(e)})(ar,function(e){"use strict";var t=e&&e.SecondLevelDomains,n={list:{ac:" com gov mil net org ",ae:" ac co gov mil name net org pro sch ",af:" com edu gov net org ",al:" com edu gov mil net org ",ao:" co ed gv it og pb ",ar:" com edu gob gov int mil net org tur ",at:" ac co gv or ",au:" asn com csiro edu gov id net org ",ba:" co com edu gov mil net org rs unbi unmo unsa untz unze ",bb:" biz co com edu gov info net org store tv ",bh:" biz cc com edu gov info net org ",bn:" com edu gov net org ",bo:" com edu gob gov int mil net org tv ",br:" adm adv agr am arq art ato b bio blog bmd cim cng cnt com coop ecn edu eng esp etc eti far flog fm fnd fot fst g12 ggf gov imb ind inf jor jus lel mat med mil mus net nom not ntr odo org ppg pro psc psi qsl rec slg srv tmp trd tur tv vet vlog wiki zlg ",bs:" com edu gov net org ",bz:" du et om ov rg ",ca:" ab bc mb nb nf nl ns nt nu on pe qc sk yk ",ck:" biz co edu gen gov info net org ",cn:" ac ah bj com cq edu fj gd gov gs gx gz ha hb he hi hl hn jl js jx ln mil net nm nx org qh sc sd sh sn sx tj tw xj xz yn zj ",co:" com edu gov mil net nom org ",cr:" ac c co ed fi go or sa ",cy:" ac biz com ekloges gov ltd name net org parliament press pro tm ",do:" art com edu gob gov mil net org sld web ",dz:" art asso com edu gov net org pol ",ec:" com edu fin gov info med mil net org pro ",eg:" com edu eun gov mil name net org sci ",er:" com edu gov ind mil net org rochest w ",es:" com edu gob nom org ",et:" biz com edu gov info name net org ",fj:" ac biz com info mil name net org pro ",fk:" ac co gov net nom org ",fr:" asso com f gouv nom prd presse tm ",gg:" co net org ",gh:" com edu gov mil org ",gn:" ac com gov net org ",gr:" com edu gov mil net org ",gt:" com edu gob ind mil net org ",gu:" com edu gov net org ",hk:" com edu gov idv net org ",hu:" 2000 agrar bolt casino city co erotica erotika film forum games hotel info ingatlan jogasz konyvelo lakas media news org priv reklam sex shop sport suli szex tm tozsde utazas video ",id:" ac co go mil net or sch web ",il:" ac co gov idf k12 muni net org ",in:" ac co edu ernet firm gen gov i ind mil net nic org res ",iq:" com edu gov i mil net org ",ir:" ac co dnssec gov i id net org sch ",it:" edu gov ",je:" co net org ",jo:" com edu gov mil name net org sch ",jp:" ac ad co ed go gr lg ne or ",ke:" ac co go info me mobi ne or sc ",kh:" com edu gov mil net org per ",ki:" biz com de edu gov info mob net org tel ",km:" asso com coop edu gouv k medecin mil nom notaires pharmaciens presse tm veterinaire ",kn:" edu gov net org ",kr:" ac busan chungbuk chungnam co daegu daejeon es gangwon go gwangju gyeongbuk gyeonggi gyeongnam hs incheon jeju jeonbuk jeonnam k kg mil ms ne or pe re sc seoul ulsan ",kw:" com edu gov net org ",ky:" com edu gov net org ",kz:" com edu gov mil net org ",lb:" com edu gov net org ",lk:" assn com edu gov grp hotel int ltd net ngo org sch soc web ",lr:" com edu gov net org ",lv:" asn com conf edu gov id mil net org ",ly:" com edu gov id med net org plc sch ",ma:" ac co gov m net org press ",mc:" asso tm ",me:" ac co edu gov its net org priv ",mg:" com edu gov mil nom org prd tm ",mk:" com edu gov inf name net org pro ",ml:" com edu gov net org presse ",mn:" edu gov org ",mo:" com edu gov net org ",mt:" com edu gov net org ",mv:" aero biz com coop edu gov info int mil museum name net org pro ",mw:" ac co com coop edu gov int museum net org ",mx:" com edu gob net org ",my:" com edu gov mil name net org sch ",nf:" arts com firm info net other per rec store web ",ng:" biz com edu gov mil mobi name net org sch ",ni:" ac co com edu gob mil net nom org ",np:" com edu gov mil net org ",nr:" biz com edu gov info net org ",om:" ac biz co com edu gov med mil museum net org pro sch ",pe:" com edu gob mil net nom org sld ",ph:" com edu gov i mil net ngo org ",pk:" biz com edu fam gob gok gon gop gos gov net org web ",pl:" art bialystok biz com edu gda gdansk gorzow gov info katowice krakow lodz lublin mil net ngo olsztyn org poznan pwr radom slupsk szczecin torun warszawa waw wroc wroclaw zgora ",pr:" ac biz com edu est gov info isla name net org pro prof ",ps:" com edu gov net org plo sec ",pw:" belau co ed go ne or ",ro:" arts com firm info nom nt org rec store tm www ",rs:" ac co edu gov in org ",sb:" com edu gov net org ",sc:" com edu gov net org ",sh:" co com edu gov net nom org ",sl:" com edu gov net org ",st:" co com consulado edu embaixada gov mil net org principe saotome store ",sv:" com edu gob org red ",sz:" ac co org ",tr:" av bbs bel biz com dr edu gen gov info k12 name net org pol tel tsk tv web ",tt:" aero biz cat co com coop edu gov info int jobs mil mobi museum name net org pro tel travel ",tw:" club com ebiz edu game gov idv mil net org ",mu:" ac co com gov net or org ",mz:" ac co edu gov org ",na:" co com ",nz:" ac co cri geek gen govt health iwi maori mil net org parliament school ",pa:" abo ac com edu gob ing med net nom org sld ",pt:" com edu gov int net nome org publ ",py:" com edu gov mil net org ",qa:" com edu gov mil net org ",re:" asso com nom ",ru:" ac adygeya altai amur arkhangelsk astrakhan bashkiria belgorod bir bryansk buryatia cbg chel chelyabinsk chita chukotka chuvashia com dagestan e-burg edu gov grozny int irkutsk ivanovo izhevsk jar joshkar-ola kalmykia kaluga kamchatka karelia kazan kchr kemerovo khabarovsk khakassia khv kirov koenig komi kostroma kranoyarsk kuban kurgan kursk lipetsk magadan mari mari-el marine mil mordovia mosreg msk murmansk nalchik net nnov nov novosibirsk nsk omsk orenburg org oryol penza perm pp pskov ptz rnd ryazan sakhalin samara saratov simbirsk smolensk spb stavropol stv surgut tambov tatarstan tom tomsk tsaritsyn tsk tula tuva tver tyumen udm udmurtia ulan-ude vladikavkaz vladimir vladivostok volgograd vologda voronezh vrn vyatka yakutia yamal yekaterinburg yuzhno-sakhalinsk ",rw:" ac co com edu gouv gov int mil net ",sa:" com edu gov med net org pub sch ",sd:" com edu gov info med net org tv ",se:" a ac b bd c d e f g h i k l m n o org p parti pp press r s t tm u w x y z ",sg:" com edu gov idn net org per ",sn:" art com edu gouv org perso univ ",sy:" com edu gov mil net news org ",th:" ac co go in mi net or ",tj:" ac biz co com edu go gov info int mil name net nic org test web ",tn:" agrinet com defense edunet ens fin gov ind info intl mincom nat net org perso rnrt rns rnu tourism ",tz:" ac co go ne or ",ua:" biz cherkassy chernigov chernovtsy ck cn co com crimea cv dn dnepropetrovsk donetsk dp edu gov if in ivano-frankivsk kh kharkov kherson khmelnitskiy kiev kirovograd km kr ks kv lg lugansk lutsk lviv me mk net nikolaev od odessa org pl poltava pp rovno rv sebastopol sumy te ternopil uzhgorod vinnica vn zaporizhzhe zhitomir zp zt ",ug:" ac co go ne or org sc ",uk:" ac bl british-library co cym gov govt icnet jet lea ltd me mil mod national-library-scotland nel net nhs nic nls org orgn parliament plc police sch scot soc ",us:" dni fed isa kids nsn ",uy:" com edu gub mil net org ",ve:" co com edu gob info mil net org web ",vi:" co com k12 net org ",vn:" ac biz com edu gov health info int name net org pro ",ye:" co com gov ltd me net org plc ",yu:" ac co edu gov org ",za:" ac agric alt bourse city co cybernet db edu gov grondar iaccess imt inca landesign law mil net ngo nis nom olivetti org pix school tm web ",zm:" ac co com edu gov net org sch ",com:"ar br cn de eu gb gr hu jpn kr no qc ru sa se uk us uy za ",net:"gb jp se uk ",org:"ae",de:"com "},has:function(i){var s=i.lastIndexOf(".");if(s<=0||s>=i.length-1)return!1;var o=i.lastIndexOf(".",s-1);if(o<=0||o>=s-1)return!1;var c=n.list[i.slice(s+1)];return c?c.indexOf(" "+i.slice(o+1,s)+" ")>=0:!1},is:function(i){var s=i.lastIndexOf(".");if(s<=0||s>=i.length-1)return!1;var o=i.lastIndexOf(".",s-1);if(o>=0)return!1;var c=n.list[i.slice(s+1)];return c?c.indexOf(" "+i.slice(0,s)+" ")>=0:!1},get:function(i){var s=i.lastIndexOf(".");if(s<=0||s>=i.length-1)return null;var o=i.lastIndexOf(".",s-1);if(o<=0||o>=s-1)return null;var c=n.list[i.slice(s+1)];return!c||c.indexOf(" "+i.slice(o+1,s)+" ")<0?null:i.slice(o+1)},noConflict:function(){return e.SecondLevelDomains===this&&(e.SecondLevelDomains=t),this}};return n})});var $e=St((ur,Dt)=>{/*! + * URI.js - Mutating URLs + * + * Version: 1.19.11 + * + * Author: Rodney Rehm + * Web: http://medialize.github.io/URI.js/ + * + * Licensed under + * MIT License http://www.opensource.org/licenses/mit-license + * + */(function(e,t){"use strict";typeof Dt=="object"&&Dt.exports?Dt.exports=t(or(),sr(),cr()):typeof define=="function"&&define.amd?define(["./punycode","./IPv6","./SecondLevelDomains"],t):e.URI=t(e.punycode,e.IPv6,e.SecondLevelDomains,e)})(ur,function(e,t,n,i){"use strict";var s=i&&i.URI;function o(r,a){var l=arguments.length>=1,m=arguments.length>=2;if(!(this instanceof o))return l?m?new o(r,a):new o(r):new o;if(r===void 0){if(l)throw new TypeError("undefined is not a valid argument for URI");typeof location<"u"?r=location.href+"":r=""}if(r===null&&l)throw new TypeError("null is not a valid argument for URI");return this.href(r),a!==void 0?this.absoluteTo(a):this}function c(r){return/^[0-9]+$/.test(r)}o.version="1.19.11";var u=o.prototype,p=Object.prototype.hasOwnProperty;function b(r){return r.replace(/([.*+?^=!:${}()|[\]\/\\])/g,"\\$1")}function g(r){return r===void 0?"Undefined":String(Object.prototype.toString.call(r)).slice(8,-1)}function y(r){return g(r)==="Array"}function S(r,a){var l={},m,_;if(g(a)==="RegExp")l=null;else if(y(a))for(m=0,_=a.length;m<_;m++)l[a[m]]=!0;else l[a]=!0;for(m=0,_=r.length;m<_;m++){var v=l&&l[r[m]]!==void 0||!l&&a.test(r[m]);v&&(r.splice(m,1),_--,m--)}return r}function A(r,a){var l,m;if(y(a)){for(l=0,m=a.length;l]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))/ig,o.findUri={start:/\b(?:([a-z][a-z0-9.+-]*:\/\/)|www\.)/gi,end:/[\s\r\n]|$/,trim:/[`!()\[\]{};:'".,<>?«»“”„‘’]+$/,parens:/(\([^\)]*\)|\[[^\]]*\]|\{[^}]*\}|<[^>]*>)/g},o.leading_whitespace_expression=/^[\x00-\x20\u00a0\u1680\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff]+/,o.ascii_tab_whitespace=/[\u0009\u000A\u000D]+/g,o.defaultPorts={http:"80",https:"443",ftp:"21",gopher:"70",ws:"80",wss:"443"},o.hostProtocols=["http","https"],o.invalid_hostname_characters=/[^a-zA-Z0-9\.\-:_]/,o.domAttributes={a:"href",blockquote:"cite",link:"href",base:"href",script:"src",form:"action",img:"src",area:"href",iframe:"src",embed:"src",source:"src",track:"src",input:"src",audio:"src",video:"src"},o.getDomAttribute=function(r){if(!(!r||!r.nodeName)){var a=r.nodeName.toLowerCase();if(!(a==="input"&&r.type!=="image"))return o.domAttributes[a]}};function k(r){return escape(r)}function D(r){return encodeURIComponent(r).replace(/[!'()*]/g,k).replace(/\*/g,"%2A")}o.encode=D,o.decode=decodeURIComponent,o.iso8859=function(){o.encode=escape,o.decode=unescape},o.unicode=function(){o.encode=D,o.decode=decodeURIComponent},o.characters={pathname:{encode:{expression:/%(24|26|2B|2C|3B|3D|3A|40)/ig,map:{"%24":"$","%26":"&","%2B":"+","%2C":",","%3B":";","%3D":"=","%3A":":","%40":"@"}},decode:{expression:/[\/\?#]/g,map:{"/":"%2F","?":"%3F","#":"%23"}}},reserved:{encode:{expression:/%(21|23|24|26|27|28|29|2A|2B|2C|2F|3A|3B|3D|3F|40|5B|5D)/ig,map:{"%3A":":","%2F":"/","%3F":"?","%23":"#","%5B":"[","%5D":"]","%40":"@","%21":"!","%24":"$","%26":"&","%27":"'","%28":"(","%29":")","%2A":"*","%2B":"+","%2C":",","%3B":";","%3D":"="}}},urnpath:{encode:{expression:/%(21|24|27|28|29|2A|2B|2C|3B|3D|40)/ig,map:{"%21":"!","%24":"$","%27":"'","%28":"(","%29":")","%2A":"*","%2B":"+","%2C":",","%3B":";","%3D":"=","%40":"@"}},decode:{expression:/[\/\?#:]/g,map:{"/":"%2F","?":"%3F","#":"%23",":":"%3A"}}}},o.encodeQuery=function(r,a){var l=o.encode(r+"");return a===void 0&&(a=o.escapeQuerySpace),a?l.replace(/%20/g,"+"):l},o.decodeQuery=function(r,a){r+="",a===void 0&&(a=o.escapeQuerySpace);try{return o.decode(a?r.replace(/\+/g,"%20"):r)}catch{return r}};var F={encode:"encode",decode:"decode"},z,M=function(r,a){return function(l){try{return o[a](l+"").replace(o.characters[r][a].expression,function(m){return o.characters[r][a].map[m]})}catch{return l}}};for(z in F)o[z+"PathSegment"]=M("pathname",F[z]),o[z+"UrnPathSegment"]=M("urnpath",F[z]);var N=function(r,a,l){return function(m){var _;l?_=function(q){return o[a](o[l](q))}:_=o[a];for(var v=(m+"").split(r),h=0,P=v.length;h-1&&(a.fragment=r.substring(l+1)||null,r=r.substring(0,l)),l=r.indexOf("?"),l>-1&&(a.query=r.substring(l+1)||null,r=r.substring(0,l)),r=r.replace(/^(https?|ftp|wss?)?:+[/\\]*/i,"$1://"),r=r.replace(/^[/\\]{2,}/i,"//"),r.substring(0,2)==="//"?(a.protocol=null,r=r.substring(2),r=o.parseAuthority(r,a)):(l=r.indexOf(":"),l>-1&&(a.protocol=r.substring(0,l)||null,a.protocol&&!a.protocol.match(o.protocol_expression)?a.protocol=void 0:r.substring(l+1,l+3).replace(/\\/g,"/")==="//"?(r=r.substring(l+3),r=o.parseAuthority(r,a)):(r=r.substring(l+1),a.urn=!0))),a.path=r,a},o.parseHost=function(r,a){r||(r=""),r=r.replace(/\\/g,"/");var l=r.indexOf("/"),m,_;if(l===-1&&(l=r.length),r.charAt(0)==="[")m=r.indexOf("]"),a.hostname=r.substring(1,m)||null,a.port=r.substring(m+2,l)||null,a.port==="/"&&(a.port=null);else{var v=r.indexOf(":"),h=r.indexOf("/"),P=r.indexOf(":",v+1);P!==-1&&(h===-1||P-1?_:r.length-1),h;return v>-1&&(_===-1||v<_)?(h=r.substring(0,v).split(":"),a.username=h[0]?o.decode(h[0]):null,h.shift(),a.password=h[0]?o.decode(h.join(":")):null,r=l.substring(v+1)):(a.username=null,a.password=null),r},o.parseQuery=function(r,a){if(!r)return{};if(r=r.replace(/&+/g,"&").replace(/^\?*&*|&+$/g,""),!r)return{};for(var l={},m=r.split("&"),_=m.length,v,h,P,q=0;q<_;q++)v=m[q].split("="),h=o.decodeQuery(v.shift(),a),P=v.length?o.decodeQuery(v.join("="),a):null,h!=="__proto__"&&(p.call(l,h)?((typeof l[h]=="string"||l[h]===null)&&(l[h]=[l[h]]),l[h].push(P)):l[h]=P);return l},o.build=function(r){var a="",l=!1;return r.protocol&&(a+=r.protocol+":"),!r.urn&&(a||r.hostname)&&(a+="//",l=!0),a+=o.buildAuthority(r)||"",typeof r.path=="string"&&(r.path.charAt(0)!=="/"&&l&&(a+="/"),a+=r.path),typeof r.query=="string"&&r.query&&(a+="?"+r.query),typeof r.fragment=="string"&&r.fragment&&(a+="#"+r.fragment),a},o.buildHost=function(r){var a="";if(r.hostname)o.ip6_expression.test(r.hostname)?a+="["+r.hostname+"]":a+=r.hostname;else return"";return r.port&&(a+=":"+r.port),a},o.buildAuthority=function(r){return o.buildUserinfo(r)+o.buildHost(r)},o.buildUserinfo=function(r){var a="";return r.username&&(a+=o.encode(r.username)),r.password&&(a+=":"+o.encode(r.password)),a&&(a+="@"),a},o.buildQuery=function(r,a,l){var m="",_,v,h,P;for(v in r)if(v!=="__proto__"&&p.call(r,v))if(y(r[v]))for(_={},h=0,P=r[v].length;h-1?G=G.slice(0,ae)+G.slice(ae).replace(v,""):G=G.replace(v,""),!(G.length<=q[0].length)&&!(l.ignore&&l.ignore.test(G))){se=V+G.length;var ye=a(G,V,se,r);if(ye===void 0){m.lastIndex=se;continue}ye=String(ye),r=r.slice(0,V)+ye+r.slice(se),m.lastIndex=V+ye.length}}return m.lastIndex=0,r},o.ensureValidHostname=function(r,a){var l=!!r,m=!!a,_=!1;if(m&&(_=A(o.hostProtocols,a)),_&&!l)throw new TypeError("Hostname cannot be empty, if protocol is "+a);if(r&&r.match(o.invalid_hostname_characters)){if(!e)throw new TypeError('Hostname "'+r+'" contains characters other than [A-Z0-9.-:_] and Punycode.js is not available');if(e.toASCII(r).match(o.invalid_hostname_characters))throw new TypeError('Hostname "'+r+'" contains characters other than [A-Z0-9.-:_]')}},o.ensureValidPort=function(r){if(r){var a=Number(r);if(!(c(a)&&a>0&&a<65536))throw new TypeError('Port "'+r+'" is not a valid port')}},o.noConflict=function(r){if(r){var a={URI:this.noConflict()};return i.URITemplate&&typeof i.URITemplate.noConflict=="function"&&(a.URITemplate=i.URITemplate.noConflict()),i.IPv6&&typeof i.IPv6.noConflict=="function"&&(a.IPv6=i.IPv6.noConflict()),i.SecondLevelDomains&&typeof i.SecondLevelDomains.noConflict=="function"&&(a.SecondLevelDomains=i.SecondLevelDomains.noConflict()),a}else i.URI===this&&(i.URI=s);return this},u.build=function(r){return r===!0?this._deferred_build=!0:(r===void 0||this._deferred_build)&&(this._string=o.build(this._parts),this._deferred_build=!1),this},u.clone=function(){return new o(this)},u.valueOf=u.toString=function(){return this.build(!1)._string};function Y(r){return function(a,l){return a===void 0?this._parts[r]||"":(this._parts[r]=a||null,this.build(!l),this)}}function oe(r,a){return function(l,m){return l===void 0?this._parts[r]||"":(l!==null&&(l=l+"",l.charAt(0)===a&&(l=l.substring(1))),this._parts[r]=l,this.build(!m),this)}}u.protocol=Y("protocol"),u.username=Y("username"),u.password=Y("password"),u.hostname=Y("hostname"),u.port=Y("port"),u.query=oe("query","?"),u.fragment=oe("fragment","#"),u.search=function(r,a){var l=this.query(r,a);return typeof l=="string"&&l.length?"?"+l:l},u.hash=function(r,a){var l=this.fragment(r,a);return typeof l=="string"&&l.length?"#"+l:l},u.pathname=function(r,a){if(r===void 0||r===!0){var l=this._parts.path||(this._parts.hostname?"/":"");return r?(this._parts.urn?o.decodeUrnPath:o.decodePath)(l):l}else return this._parts.urn?this._parts.path=r?o.recodeUrnPath(r):"":this._parts.path=r?o.recodePath(r):"/",this.build(!a),this},u.path=u.pathname,u.href=function(r,a){var l;if(r===void 0)return this.toString();this._string="",this._parts=o._parts();var m=r instanceof o,_=typeof r=="object"&&(r.hostname||r.path||r.pathname);if(r.nodeName){var v=o.getDomAttribute(r);r=r[v]||"",_=!1}if(!m&&_&&r.pathname!==void 0&&(r=r.toString()),typeof r=="string"||r instanceof String)this._parts=o.parse(String(r),this._parts);else if(m||_){var h=m?r._parts:r;for(l in h)l!=="query"&&p.call(this._parts,l)&&(this._parts[l]=h[l]);h.query&&this.query(h.query,!1)}else throw new TypeError("invalid input");return this.build(!a),this},u.is=function(r){var a=!1,l=!1,m=!1,_=!1,v=!1,h=!1,P=!1,q=!this._parts.urn;switch(this._parts.hostname&&(q=!1,l=o.ip4_expression.test(this._parts.hostname),m=o.ip6_expression.test(this._parts.hostname),a=l||m,_=!a,v=_&&n&&n.has(this._parts.hostname),h=_&&o.idn_expression.test(this._parts.hostname),P=_&&o.punycode_expression.test(this._parts.hostname)),r.toLowerCase()){case"relative":return q;case"absolute":return!q;case"domain":case"name":return _;case"sld":return v;case"ip":return a;case"ip4":case"ipv4":case"inet4":return l;case"ip6":case"ipv6":case"inet6":return m;case"idn":return h;case"url":return!this._parts.urn;case"urn":return!!this._parts.urn;case"punycode":return P}return null};var ie=u.protocol,X=u.port,W=u.hostname;u.protocol=function(r,a){if(r&&(r=r.replace(/:(\/\/)?$/,""),!r.match(o.protocol_expression)))throw new TypeError('Protocol "'+r+`" contains characters other than [A-Z0-9.+-] or doesn't start with [A-Z]`);return ie.call(this,r,a)},u.scheme=u.protocol,u.port=function(r,a){return this._parts.urn?r===void 0?"":this:(r!==void 0&&(r===0&&(r=null),r&&(r+="",r.charAt(0)===":"&&(r=r.substring(1)),o.ensureValidPort(r))),X.call(this,r,a))},u.hostname=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(r!==void 0){var l={preventInvalidHostname:this._parts.preventInvalidHostname},m=o.parseHost(r,l);if(m!=="/")throw new TypeError('Hostname "'+r+'" contains characters other than [A-Z0-9.-]');r=l.hostname,this._parts.preventInvalidHostname&&o.ensureValidHostname(r,this._parts.protocol)}return W.call(this,r,a)},u.origin=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(r===void 0){var l=this.protocol(),m=this.authority();return m?(l?l+"://":"")+this.authority():""}else{var _=o(r);return this.protocol(_.protocol()).authority(_.authority()).build(!a),this}},u.host=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(r===void 0)return this._parts.hostname?o.buildHost(this._parts):"";var l=o.parseHost(r,this._parts);if(l!=="/")throw new TypeError('Hostname "'+r+'" contains characters other than [A-Z0-9.-]');return this.build(!a),this},u.authority=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(r===void 0)return this._parts.hostname?o.buildAuthority(this._parts):"";var l=o.parseAuthority(r,this._parts);if(l!=="/")throw new TypeError('Hostname "'+r+'" contains characters other than [A-Z0-9.-]');return this.build(!a),this},u.userinfo=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(r===void 0){var l=o.buildUserinfo(this._parts);return l&&l.substring(0,l.length-1)}else return r[r.length-1]!=="@"&&(r+="@"),o.parseUserinfo(r,this._parts),this.build(!a),this},u.resource=function(r,a){var l;return r===void 0?this.path()+this.search()+this.hash():(l=o.parse(r),this._parts.path=l.path,this._parts.query=l.query,this._parts.fragment=l.fragment,this.build(!a),this)},u.subdomain=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(r===void 0){if(!this._parts.hostname||this.is("IP"))return"";var l=this._parts.hostname.length-this.domain().length-1;return this._parts.hostname.substring(0,l)||""}else{var m=this._parts.hostname.length-this.domain().length,_=this._parts.hostname.substring(0,m),v=new RegExp("^"+b(_));if(r&&r.charAt(r.length-1)!=="."&&(r+="."),r.indexOf(":")!==-1)throw new TypeError("Domains cannot contain colons");return r&&o.ensureValidHostname(r,this._parts.protocol),this._parts.hostname=this._parts.hostname.replace(v,r),this.build(!a),this}},u.domain=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(typeof r=="boolean"&&(a=r,r=void 0),r===void 0){if(!this._parts.hostname||this.is("IP"))return"";var l=this._parts.hostname.match(/\./g);if(l&&l.length<2)return this._parts.hostname;var m=this._parts.hostname.length-this.tld(a).length-1;return m=this._parts.hostname.lastIndexOf(".",m-1)+1,this._parts.hostname.substring(m)||""}else{if(!r)throw new TypeError("cannot set domain empty");if(r.indexOf(":")!==-1)throw new TypeError("Domains cannot contain colons");if(o.ensureValidHostname(r,this._parts.protocol),!this._parts.hostname||this.is("IP"))this._parts.hostname=r;else{var _=new RegExp(b(this.domain())+"$");this._parts.hostname=this._parts.hostname.replace(_,r)}return this.build(!a),this}},u.tld=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(typeof r=="boolean"&&(a=r,r=void 0),r===void 0){if(!this._parts.hostname||this.is("IP"))return"";var l=this._parts.hostname.lastIndexOf("."),m=this._parts.hostname.substring(l+1);return a!==!0&&n&&n.list[m.toLowerCase()]&&n.get(this._parts.hostname)||m}else{var _;if(r)if(r.match(/[^a-zA-Z0-9-]/))if(n&&n.is(r))_=new RegExp(b(this.tld())+"$"),this._parts.hostname=this._parts.hostname.replace(_,r);else throw new TypeError('TLD "'+r+'" contains characters other than [A-Z0-9]');else{if(!this._parts.hostname||this.is("IP"))throw new ReferenceError("cannot set TLD on non-domain host");_=new RegExp(b(this.tld())+"$"),this._parts.hostname=this._parts.hostname.replace(_,r)}else throw new TypeError("cannot set TLD empty");return this.build(!a),this}},u.directory=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(r===void 0||r===!0){if(!this._parts.path&&!this._parts.hostname)return"";if(this._parts.path==="/")return"/";var l=this._parts.path.length-this.filename().length-1,m=this._parts.path.substring(0,l)||(this._parts.hostname?"/":"");return r?o.decodePath(m):m}else{var _=this._parts.path.length-this.filename().length,v=this._parts.path.substring(0,_),h=new RegExp("^"+b(v));return this.is("relative")||(r||(r="/"),r.charAt(0)!=="/"&&(r="/"+r)),r&&r.charAt(r.length-1)!=="/"&&(r+="/"),r=o.recodePath(r),this._parts.path=this._parts.path.replace(h,r),this.build(!a),this}},u.filename=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(typeof r!="string"){if(!this._parts.path||this._parts.path==="/")return"";var l=this._parts.path.lastIndexOf("/"),m=this._parts.path.substring(l+1);return r?o.decodePathSegment(m):m}else{var _=!1;r.charAt(0)==="/"&&(r=r.substring(1)),r.match(/\.?\//)&&(_=!0);var v=new RegExp(b(this.filename())+"$");return r=o.recodePath(r),this._parts.path=this._parts.path.replace(v,r),_?this.normalizePath(a):this.build(!a),this}},u.suffix=function(r,a){if(this._parts.urn)return r===void 0?"":this;if(r===void 0||r===!0){if(!this._parts.path||this._parts.path==="/")return"";var l=this.filename(),m=l.lastIndexOf("."),_,v;return m===-1?"":(_=l.substring(m+1),v=/^[a-z0-9%]+$/i.test(_)?_:"",r?o.decodePathSegment(v):v)}else{r.charAt(0)==="."&&(r=r.substring(1));var h=this.suffix(),P;if(h)r?P=new RegExp(b(h)+"$"):P=new RegExp(b("."+h)+"$");else{if(!r)return this;this._parts.path+="."+o.recodePath(r)}return P&&(r=o.recodePath(r),this._parts.path=this._parts.path.replace(P,r)),this.build(!a),this}},u.segment=function(r,a,l){var m=this._parts.urn?":":"/",_=this.path(),v=_.substring(0,1)==="/",h=_.split(m);if(r!==void 0&&typeof r!="number"&&(l=a,a=r,r=void 0),r!==void 0&&typeof r!="number")throw new Error('Bad segment "'+r+'", must be 0-based integer');if(v&&h.shift(),r<0&&(r=Math.max(h.length+r,0)),a===void 0)return r===void 0?h:h[r];if(r===null||h[r]===void 0)if(y(a)){h=[];for(var P=0,q=a.length;Pc.x&&f.clone(n,c),Xu.y&&f.clone(n,u),Wp.z&&f.clone(n,p)}let y=f.magnitudeSquared(f.subtract(c,i,ce)),S=f.magnitudeSquared(f.subtract(u,s,ce)),A=f.magnitudeSquared(f.subtract(p,o,ce)),I=i,T=c,k=y;S>k&&(k=S,I=s,T=u),A>k&&(k=A,I=o,T=p);let D=gn;D.x=(I.x+T.x)*.5,D.y=(I.y+T.y)*.5,D.z=(I.z+T.z)*.5;let F=f.magnitudeSquared(f.subtract(T,D,ce)),z=Math.sqrt(F),M=wn;M.x=i.x,M.y=s.y,M.z=o.z;let N=bn;N.x=c.x,N.y=u.y,N.z=p.z;let Y=f.midpoint(M,N,_n),oe=0;for(g=0;goe&&(oe=ie);let X=f.magnitudeSquared(f.subtract(n,D,ce));if(X>F){let W=Math.sqrt(X);z=(z+W)*.5,F=z*z;let Q=W-z;D.x=(z*D.x+Q*n.x)/W,D.y=(z*D.y+Q*n.y)/W,D.z=(z*D.z+Q*n.z)/W}}return zp.x&&f.clone(s,p),Qb.y&&f.clone(s,b),rg.z&&f.clone(s,g)}let A=f.magnitudeSquared(f.subtract(p,o,ce)),I=f.magnitudeSquared(f.subtract(b,c,ce)),T=f.magnitudeSquared(f.subtract(g,u,ce)),k=o,D=p,F=A;I>F&&(F=I,k=c,D=b),T>F&&(F=T,k=u,D=g);let z=gn;z.x=(k.x+D.x)*.5,z.y=(k.y+D.y)*.5,z.z=(k.z+D.z)*.5;let M=f.magnitudeSquared(f.subtract(D,z,ce)),N=Math.sqrt(M),Y=wn;Y.x=o.x,Y.y=c.y,Y.z=u.z;let oe=bn;oe.x=p.x,oe.y=b.y,oe.z=g.z;let ie=f.midpoint(Y,oe,_n),X=0;for(S=0;SX&&(X=W);let Q=f.magnitudeSquared(f.subtract(s,z,ce));if(Q>M){let r=Math.sqrt(Q);N=(N+r)*.5,M=N*N;let a=r-N;z.x=(N*z.x+a*s.x)/r,z.y=(N*z.y+a*s.y)/r,z.z=(N*z.z+a*s.z)/r}}return Nu.x&&f.clone(i,u),Wp.y&&f.clone(i,p),Qb.z&&f.clone(i,b)}let S=f.magnitudeSquared(f.subtract(u,s,ce)),A=f.magnitudeSquared(f.subtract(p,o,ce)),I=f.magnitudeSquared(f.subtract(b,c,ce)),T=s,k=u,D=S;A>D&&(D=A,T=o,k=p),I>D&&(D=I,T=c,k=b);let F=gn;F.x=(T.x+k.x)*.5,F.y=(T.y+k.y)*.5,F.z=(T.z+k.z)*.5;let z=f.magnitudeSquared(f.subtract(k,F,ce)),M=Math.sqrt(z),N=wn;N.x=s.x,N.y=o.y,N.z=c.z;let Y=bn;Y.x=u.x,Y.y=p.y,Y.z=b.z;let oe=f.midpoint(N,Y,_n),ie=0;for(y=0;yie&&(ie=X);let W=f.magnitudeSquared(f.subtract(i,F,ce));if(W>z){let Q=Math.sqrt(W);M=(M+Q)*.5,z=M*M;let r=Q-M;F.x=(M*F.x+r*i.x)/Q,F.y=(M*F.y+r*i.y)/Q,F.z=(M*F.z+r*i.z)/Q}}return M=p+c)return e.clone(n),n;if(c>=p+s)return t.clone(n),n;let b=(s+p+c)*.5,g=f.multiplyByScalar(u,(-s+b)/p,Ro);return f.add(g,i,g),f.clone(g,n.center),n.radius=b,n};var Po=new f;U.expand=function(e,t,n){w.typeOf.object("sphere",e),w.typeOf.object("point",t),n=U.clone(e,n);let i=f.magnitude(f.subtract(t,n.center,Po));return i>n.radius&&(n.radius=i),n};U.intersectPlane=function(e,t){w.typeOf.object("sphere",e),w.typeOf.object("plane",t);let n=e.center,i=e.radius,s=t.normal,o=f.dot(s,n)+t.distance;return o<-i?Et.OUTSIDE:o0){s=o-1;continue}return o}return~(s+1)}var Qe=Mo;function jo(e,t,n,i,s){this.xPoleWander=e,this.yPoleWander=t,this.xPoleOffset=n,this.yPoleOffset=i,this.ut1MinusUtc=s}var ut=jo;function No(e,t,n,i,s,o,c,u){this.year=e,this.month=t,this.day=n,this.hour=i,this.minute=s,this.second=o,this.millisecond=c,this.isLeapSecond=u}var Ct=No;function Bo(e){if(e===null||isNaN(e))throw new R("year is required and must be a number.");return e%4===0&&e%100!==0||e%400===0}var Sn=Bo;function Lo(e,t){this.julianDate=e,this.offset=t}var Z=Lo;var Qo={SECONDS_PER_MILLISECOND:.001,SECONDS_PER_MINUTE:60,MINUTES_PER_HOUR:60,HOURS_PER_DAY:24,SECONDS_PER_HOUR:3600,MINUTES_PER_DAY:1440,SECONDS_PER_DAY:86400,DAYS_PER_JULIAN_CENTURY:36525,PICOSECOND:1e-9,MODIFIED_JULIAN_DATE_DIFFERENCE:24000005e-1},K=Object.freeze(Qo);var $o={UTC:0,TAI:1},j=Object.freeze($o);var rr=new Ct,At=[31,28,31,30,31,30,31,31,30,31,30,31],Rt=29;function xn(e,t){return C.compare(e.julianDate,t.julianDate)}var Ke=new Z;function Tt(e){Ke.julianDate=e;let t=C.leapSeconds,n=Qe(t,Ke,xn);n<0&&(n=~n),n>=t.length&&(n=t.length-1);let i=t[n].offset;n>0&&C.secondsDifference(t[n].julianDate,e)>i&&(n--,i=t[n].offset),C.addSeconds(e,i,e)}function nr(e,t){Ke.julianDate=e;let n=C.leapSeconds,i=Qe(n,Ke,xn);if(i<0&&(i=~i),i===0)return C.addSeconds(e,-n[0].offset,t);if(i>=n.length)return C.addSeconds(e,-n[i-1].offset,t);let s=C.secondsDifference(n[i].julianDate,e);if(s===0)return C.addSeconds(e,-n[i].offset,t);if(!(s<=1))return C.addSeconds(e,-n[--i].offset,t)}function ke(e,t,n){let i=t/K.SECONDS_PER_DAY|0;return e+=i,t-=K.SECONDS_PER_DAY*i,t<0&&(e--,t+=K.SECONDS_PER_DAY),n.dayNumber=e,n.secondsOfDay=t,n}function vn(e,t,n,i,s,o,c){let u=(t-14)/12|0,p=e+4800+u,b=(1461*p/4|0)+(367*(t-2-12*u)/12|0)-(3*((p+100)/100|0)/4|0)+n-32075;i=i-12,i<0&&(i+=24);let g=o+(i*K.SECONDS_PER_HOUR+s*K.SECONDS_PER_MINUTE+c*K.SECONDS_PER_MILLISECOND);return g>=43200&&(b-=1),[b,g]}var Wo=/^(\d{4})$/,Vo=/^(\d{4})-(\d{2})$/,Ho=/^(\d{4})-?(\d{3})$/,Yo=/^(\d{4})-?W(\d{2})-?(\d{1})?$/,Zo=/^(\d{4})-?(\d{2})-?(\d{2})$/,On=/([Z+\-])?(\d{2})?:?(\d{2})?$/,Jo=/^(\d{2})(\.\d+)?/.source+On.source,Xo=/^(\d{2}):?(\d{2})(\.\d+)?/.source+On.source,Go=/^(\d{2}):?(\d{2}):?(\d{2})(\.\d+)?/.source+On.source,ve="Invalid ISO 8601 date.";function C(e,t,n){this.dayNumber=void 0,this.secondsOfDay=void 0,e=O(e,0),t=O(t,0),n=O(n,j.UTC);let i=e|0;t=t+(e-i)*K.SECONDS_PER_DAY,ke(i,t,this),n===j.UTC&&Tt(this)}C.fromGregorianDate=function(e,t){if(!(e instanceof Ct))throw new R("date must be a valid GregorianDate.");let n=vn(e.year,e.month,e.day,e.hour,e.minute,e.second,e.millisecond);return d(t)?(ke(n[0],n[1],t),Tt(t),t):new C(n[0],n[1],j.UTC)};C.fromDate=function(e,t){if(!(e instanceof Date)||isNaN(e.getTime()))throw new R("date must be a valid JavaScript Date.");let n=vn(e.getUTCFullYear(),e.getUTCMonth()+1,e.getUTCDate(),e.getUTCHours(),e.getUTCMinutes(),e.getUTCSeconds(),e.getUTCMilliseconds());return d(t)?(ke(n[0],n[1],t),Tt(t),t):new C(n[0],n[1],j.UTC)};C.fromIso8601=function(e,t){if(typeof e!="string")throw new R(ve);e=e.replace(",",".");let n=e.split("T"),i,s=1,o=1,c=0,u=0,p=0,b=0,g=n[0],y=n[1],S,A;if(!d(g))throw new R(ve);let I;if(n=g.match(Zo),n!==null){if(I=g.split("-").length-1,I>0&&I!==2)throw new R(ve);i=+n[1],s=+n[2],o=+n[3]}else if(n=g.match(Vo),n!==null)i=+n[1],s=+n[2];else if(n=g.match(Wo),n!==null)i=+n[1];else{let F;if(n=g.match(Ho),n!==null){if(i=+n[1],F=+n[2],A=Sn(i),F<1||A&&F>366||!A&&F>365)throw new R(ve)}else if(n=g.match(Yo),n!==null){i=+n[1];let z=+n[2],M=+n[3]||0;if(I=g.split("-").length-1,I>0&&(!d(n[3])&&I!==1||d(n[3])&&I!==2))throw new R(ve);let N=new Date(Date.UTC(i,0,4));F=z*7+M-N.getUTCDay()-3}else throw new R(ve);S=new Date(Date.UTC(i,0,1)),S.setUTCDate(F),s=S.getUTCMonth()+1,o=S.getUTCDate()}if(A=Sn(i),s<1||s>12||o<1||(s!==2||!A)&&o>At[s-1]||A&&s===2&&o>Rt)throw new R(ve);let T;if(d(y)){if(n=y.match(Go),n!==null){if(I=y.split(":").length-1,I>0&&I!==2&&I!==3)throw new R(ve);c=+n[1],u=+n[2],p=+n[3],b=+(n[4]||0)*1e3,T=5}else if(n=y.match(Xo),n!==null){if(I=y.split(":").length-1,I>2)throw new R(ve);c=+n[1],u=+n[2],p=+(n[3]||0)*60,T=4}else if(n=y.match(Jo),n!==null)c=+n[1],u=+(n[2]||0)*60,T=3;else throw new R(ve);if(u>=60||p>=61||c>24||c===24&&(u>0||p>0||b>0))throw new R(ve);let F=n[T],z=+n[T+1],M=+(n[T+2]||0);switch(F){case"+":c=c-z,u=u-M;break;case"-":c=c+z,u=u+M;break;case"Z":break;default:u=u+new Date(Date.UTC(i,s-1,o,c,u)).getTimezoneOffset();break}}let k=p===60;for(k&&p--;u>=60;)u-=60,c++;for(;c>=24;)c-=24,o++;for(S=A&&s===2?Rt:At[s-1];o>S;)o-=S,s++,s>12&&(s-=12,i++),S=A&&s===2?Rt:At[s-1];for(;u<0;)u+=60,c--;for(;c<0;)c+=24,o--;for(;o<1;)s--,s<1&&(s+=12,i--),S=A&&s===2?Rt:At[s-1],o+=S;let D=vn(i,s,o,c,u,p,b);return d(t)?(ke(D[0],D[1],t),Tt(t)):t=new C(D[0],D[1],j.UTC),k&&C.addSeconds(t,1,t),t};C.now=function(e){return C.fromDate(new Date,e)};var Pt=new C(0,0,j.TAI);C.toGregorianDate=function(e,t){if(!d(e))throw new R("julianDate is required.");let n=!1,i=nr(e,Pt);d(i)||(C.addSeconds(e,-1,Pt),i=nr(Pt,Pt),n=!0);let s=i.dayNumber,o=i.secondsOfDay;o>=43200&&(s+=1);let c=s+68569|0,u=4*c/146097|0;c=c-((146097*u+3)/4|0)|0;let p=4e3*(c+1)/1461001|0;c=c-(1461*p/4|0)+31|0;let b=80*c/2447|0,g=c-(2447*b/80|0)|0;c=b/11|0;let y=b+2-12*c|0,S=100*(u-49)+p+c|0,A=o/K.SECONDS_PER_HOUR|0,I=o-A*K.SECONDS_PER_HOUR,T=I/K.SECONDS_PER_MINUTE|0;I=I-T*K.SECONDS_PER_MINUTE;let k=I|0,D=(I-k)/K.SECONDS_PER_MILLISECOND;return A+=12,A>23&&(A-=24),n&&(k+=1),d(t)?(t.year=S,t.month=y,t.day=g,t.hour=A,t.minute=T,t.second=k,t.millisecond=D,t.isLeapSecond=n,t):new Ct(S,y,g,A,T,k,D,n)};C.toDate=function(e){if(!d(e))throw new R("julianDate is required.");let t=C.toGregorianDate(e,rr),n=t.second;return t.isLeapSecond&&(n-=1),new Date(Date.UTC(t.year,t.month-1,t.day,t.hour,t.minute,n,t.millisecond))};C.toIso8601=function(e,t){if(!d(e))throw new R("julianDate is required.");let n=C.toGregorianDate(e,rr),i=n.year,s=n.month,o=n.day,c=n.hour,u=n.minute,p=n.second,b=n.millisecond;i===1e4&&s===1&&o===1&&c===0&&u===0&&p===0&&b===0&&(i=9999,s=12,o=31,c=24);let g;return!d(t)&&b!==0?(g=(b*.01).toString().replace(".",""),`${i.toString().padStart(4,"0")}-${s.toString().padStart(2,"0")}-${o.toString().padStart(2,"0")}T${c.toString().padStart(2,"0")}:${u.toString().padStart(2,"0")}:${p.toString().padStart(2,"0")}.${g}Z`):!d(t)||t===0?`${i.toString().padStart(4,"0")}-${s.toString().padStart(2,"0")}-${o.toString().padStart(2,"0")}T${c.toString().padStart(2,"0")}:${u.toString().padStart(2,"0")}:${p.toString().padStart(2,"0")}Z`:(g=(b*.01).toFixed(t).replace(".","").slice(0,t),`${i.toString().padStart(4,"0")}-${s.toString().padStart(2,"0")}-${o.toString().padStart(2,"0")}T${c.toString().padStart(2,"0")}:${u.toString().padStart(2,"0")}:${p.toString().padStart(2,"0")}.${g}Z`)};C.clone=function(e,t){if(d(e))return d(t)?(t.dayNumber=e.dayNumber,t.secondsOfDay=e.secondsOfDay,t):new C(e.dayNumber,e.secondsOfDay,j.TAI)};C.compare=function(e,t){if(!d(e))throw new R("left is required.");if(!d(t))throw new R("right is required.");let n=e.dayNumber-t.dayNumber;return n!==0?n:e.secondsOfDay-t.secondsOfDay};C.equals=function(e,t){return e===t||d(e)&&d(t)&&e.dayNumber===t.dayNumber&&e.secondsOfDay===t.secondsOfDay};C.equalsEpsilon=function(e,t,n){return n=O(n,0),e===t||d(e)&&d(t)&&Math.abs(C.secondsDifference(e,t))<=n};C.totalDays=function(e){if(!d(e))throw new R("julianDate is required.");return e.dayNumber+e.secondsOfDay/K.SECONDS_PER_DAY};C.secondsDifference=function(e,t){if(!d(e))throw new R("left is required.");if(!d(t))throw new R("right is required.");return(e.dayNumber-t.dayNumber)*K.SECONDS_PER_DAY+(e.secondsOfDay-t.secondsOfDay)};C.daysDifference=function(e,t){if(!d(e))throw new R("left is required.");if(!d(t))throw new R("right is required.");let n=e.dayNumber-t.dayNumber,i=(e.secondsOfDay-t.secondsOfDay)/K.SECONDS_PER_DAY;return n+i};C.computeTaiMinusUtc=function(e){Ke.julianDate=e;let t=C.leapSeconds,n=Qe(t,Ke,xn);return n<0&&(n=~n,--n,n<0&&(n=0)),t[n].offset};C.addSeconds=function(e,t,n){if(!d(e))throw new R("julianDate is required.");if(!d(t))throw new R("seconds is required.");if(!d(n))throw new R("result is required.");return ke(e.dayNumber,e.secondsOfDay+t,n)};C.addMinutes=function(e,t,n){if(!d(e))throw new R("julianDate is required.");if(!d(t))throw new R("minutes is required.");if(!d(n))throw new R("result is required.");let i=e.secondsOfDay+t*K.SECONDS_PER_MINUTE;return ke(e.dayNumber,i,n)};C.addHours=function(e,t,n){if(!d(e))throw new R("julianDate is required.");if(!d(t))throw new R("hours is required.");if(!d(n))throw new R("result is required.");let i=e.secondsOfDay+t*K.SECONDS_PER_HOUR;return ke(e.dayNumber,i,n)};C.addDays=function(e,t,n){if(!d(e))throw new R("julianDate is required.");if(!d(t))throw new R("days is required.");if(!d(n))throw new R("result is required.");let i=e.dayNumber+t;return ke(i,e.secondsOfDay,n)};C.lessThan=function(e,t){return C.compare(e,t)<0};C.lessThanOrEquals=function(e,t){return C.compare(e,t)<=0};C.greaterThan=function(e,t){return C.compare(e,t)>0};C.greaterThanOrEquals=function(e,t){return C.compare(e,t)>=0};C.prototype.clone=function(e){return C.clone(this,e)};C.prototype.equals=function(e){return C.equals(this,e)};C.prototype.equalsEpsilon=function(e,t){return C.equalsEpsilon(this,e,t)};C.prototype.toString=function(){return C.toIso8601(this)};C.leapSeconds=[new Z(new C(2441317,43210,j.TAI),10),new Z(new C(2441499,43211,j.TAI),11),new Z(new C(2441683,43212,j.TAI),12),new Z(new C(2442048,43213,j.TAI),13),new Z(new C(2442413,43214,j.TAI),14),new Z(new C(2442778,43215,j.TAI),15),new Z(new C(2443144,43216,j.TAI),16),new Z(new C(2443509,43217,j.TAI),17),new Z(new C(2443874,43218,j.TAI),18),new Z(new C(2444239,43219,j.TAI),19),new Z(new C(2444786,43220,j.TAI),20),new Z(new C(2445151,43221,j.TAI),21),new Z(new C(2445516,43222,j.TAI),22),new Z(new C(2446247,43223,j.TAI),23),new Z(new C(2447161,43224,j.TAI),24),new Z(new C(2447892,43225,j.TAI),25),new Z(new C(2448257,43226,j.TAI),26),new Z(new C(2448804,43227,j.TAI),27),new Z(new C(2449169,43228,j.TAI),28),new Z(new C(2449534,43229,j.TAI),29),new Z(new C(2450083,43230,j.TAI),30),new Z(new C(2450630,43231,j.TAI),31),new Z(new C(2451179,43232,j.TAI),32),new Z(new C(2453736,43233,j.TAI),33),new Z(new C(2454832,43234,j.TAI),34),new Z(new C(2456109,43235,j.TAI),35),new Z(new C(2457204,43236,j.TAI),36),new Z(new C(2457754,43237,j.TAI),37)];var ue=C;var zr=Ge($e(),1);function Ko(e){return(e.length===0||e[e.length-1]!=="/")&&(e=`${e}/`),e}var fr=Ko;function lr(e,t){if(e===null||typeof e!="object")return e;t=O(t,!1);let n=new e.constructor;for(let i in e)if(e.hasOwnProperty(i)){let s=e[i];t&&(s=lr(s,t)),n[i]=s}return n}var nt=lr;function ei(){let e,t,n=new Promise(function(i,s){e=i,t=s});return{resolve:e,reject:t,promise:n}}var We=ei;var dr=Ge($e(),1);function En(e,t){let n;return typeof document<"u"&&(n=document),En._implementation(e,t,n)}En._implementation=function(e,t,n){if(!d(e))throw new R("relative uri is required.");if(!d(t)){if(typeof n>"u")return e;t=O(n.baseURI,n.location.href)}let i=new dr.default(e);return i.scheme()!==""?i.toString():i.absoluteTo(t).toString()};var ft=En;var pr=Ge($e(),1);function ti(e,t){if(!d(e))throw new R("uri is required.");let n="",i=e.lastIndexOf("/");return i!==-1&&(n=e.substring(0,i+1)),t&&(e=new pr.default(e),e.query().length!==0&&(n+=`?${e.query()}`),e.fragment().length!==0&&(n+=`#${e.fragment()}`)),n}var mr=ti;var hr=Ge($e(),1);function ni(e){if(!d(e))throw new R("uri is required.");let t=new hr.default(e);t.normalize();let n=t.path(),i=n.lastIndexOf("/");return i!==-1&&(n=n.substr(i+1)),i=n.lastIndexOf("."),i===-1?n="":n=n.substr(i+1),n}var yr=ni;var gr={};function ri(e,t,n){d(t)||(t=e.width),d(n)||(n=e.height);let i=gr[t];d(i)||(i={},gr[t]=i);let s=i[n];if(!d(s)){let o=document.createElement("canvas");o.width=t,o.height=n,s=o.getContext("2d",{willReadFrequently:!0}),s.globalCompositeOperation="copy",i[n]=s}return s.drawImage(e,0,0,t,n),s.getImageData(0,0,t,n).data}var Cn=ri;var oi=/^blob:/i;function ii(e){return w.typeOf.string("uri",e),oi.test(e)}var zt=ii;var Ce;function si(e){d(Ce)||(Ce=document.createElement("a")),Ce.href=window.location.href;let t=Ce.host,n=Ce.protocol;return Ce.href=e,Ce.href=Ce.href,n!==Ce.protocol||t!==Ce.host}var wr=si;var ai=/^data:/i;function ci(e){return w.typeOf.string("uri",e),ai.test(e)}var qt=ci;function ui(e){let t=document.createElement("script");return t.async=!0,t.src=e,new Promise((n,i)=>{window.crossOriginIsolated&&t.setAttribute("crossorigin","anonymous");let s=document.getElementsByTagName("head")[0];t.onload=function(){t.onload=void 0,s.removeChild(t),n()},t.onerror=function(o){i(o)},s.appendChild(t)})}var br=ui;function fi(e){if(!d(e))throw new R("obj is required.");let t="";for(let n in e)if(e.hasOwnProperty(n)){let i=e[n],s=`${encodeURIComponent(n)}=`;if(Array.isArray(i))for(let o=0,c=i.length;o0){let c=s.substring(0,o),u=s.substring(o+2);t[c]=u}}return t}var Or=mi;function Er(e,t,n){this.statusCode=e,this.response=t,this.responseHeaders=n,typeof this.responseHeaders=="string"&&(this.responseHeaders=Or(this.responseHeaders))}Er.prototype.toString=function(){let e="Request has failed.";return d(this.statusCode)&&(e+=` Status Code: ${this.statusCode}`),e};var lt=Er;var Ft=Ge($e(),1);function dt(){this._listeners=[],this._scopes=[],this._toRemove=[],this._insideRaiseEvent=!1}Object.defineProperties(dt.prototype,{numberOfListeners:{get:function(){return this._listeners.length-this._toRemove.length}}});dt.prototype.addEventListener=function(e,t){w.typeOf.func("listener",e),this._listeners.push(e),this._scopes.push(t);let n=this;return function(){n.removeEventListener(e,t)}};dt.prototype.removeEventListener=function(e,t){w.typeOf.func("listener",e);let n=this._listeners,i=this._scopes,s=-1;for(let o=0;o0){for(s.sort(hi),e=0;e=0;--t)this.heapify(t)};Ve.prototype.insert=function(e){w.defined("element",e);let t=this._array,n=this._comparator,i=this._maximumLength,s=this._length++;for(si&&(o=t[i],this._length=i),o};Ve.prototype.pop=function(e){if(e=O(e,0),this._length===0)return;w.typeOf.number.lessThan("index",e,this._length);let t=this._array,n=t[e];return An(t,e,--this._length),this.heapify(e),t[this._length]=void 0,n};var Ar=Ve;function yi(e,t){return e.priority-t.priority}var H={numberOfAttemptedRequests:0,numberOfActiveRequests:0,numberOfCancelledRequests:0,numberOfCancelledActiveRequests:0,numberOfFailedRequests:0,numberOfActiveRequestsEver:0,lastNumberOfActiveRequests:0},rt=20,le=new Ar({comparator:yi});le.maximumLength=rt;le.reserve(rt);var Ae=[],Pe={},gi=typeof document<"u"?new Ft.default(document.location.href):new Ft.default,Mt=new Cr;function ee(){}ee.maximumRequests=50;ee.maximumRequestsPerServer=6;ee.requestsByServer={"api.cesium.com:443":18,"assets.ion.cesium.com:443":18,"ibasemaps-api.arcgis.com:443":18,"tile.googleapis.com:443":18,"tile.openstreetmap.org:443":18};ee.throttleRequests=!0;ee.debugShowStatistics=!1;ee.requestCompletedEvent=Mt;Object.defineProperties(ee,{statistics:{get:function(){return H}},priorityHeapLength:{get:function(){return rt},set:function(e){if(ee;){let t=le.pop();He(t)}rt=e,le.maximumLength=e,le.reserve(e)}}});function Rr(e){d(e.priorityFunction)&&(e.priority=e.priorityFunction())}ee.serverHasOpenSlots=function(e,t){t=O(t,1);let n=O(ee.requestsByServer[e],ee.maximumRequestsPerServer);return Pe[e]+t<=n};ee.heapHasOpenSlots=function(e){return le.length+e<=rt};function Pr(e){return e.state===te.UNISSUED&&(e.state=te.ISSUED,e.deferred=We()),e.deferred.promise}function wi(e){return function(t){if(e.state===te.CANCELLED)return;let n=e.deferred;--H.numberOfActiveRequests,--Pe[e.serverKey],Mt.raiseEvent(),e.state=te.RECEIVED,e.deferred=void 0,n.resolve(t)}}function bi(e){return function(t){e.state!==te.CANCELLED&&(++H.numberOfFailedRequests,--H.numberOfActiveRequests,--Pe[e.serverKey],Mt.raiseEvent(t),e.state=te.FAILED,e.deferred.reject(t))}}function Tr(e){let t=Pr(e);return e.state=te.ACTIVE,Ae.push(e),++H.numberOfActiveRequests,++H.numberOfActiveRequestsEver,++Pe[e.serverKey],e.requestFunction().then(wi(e)).catch(bi(e)),t}function He(e){let t=e.state===te.ACTIVE;if(e.state=te.CANCELLED,++H.numberOfCancelledRequests,d(e.deferred)){let n=e.deferred;e.deferred=void 0,n.reject()}t&&(--H.numberOfActiveRequests,--Pe[e.serverKey],++H.numberOfCancelledActiveRequests),d(e.cancelFunction)&&e.cancelFunction()}ee.update=function(){let e,t,n=0,i=Ae.length;for(e=0;e0&&(Ae[e-n]=t)}Ae.length-=n;let s=le.internalArray,o=le.length;for(e=0;e0;){if(t=le.pop(),t.cancelled){He(t);continue}if(t.throttleByServer&&!ee.serverHasOpenSlots(t.serverKey)){He(t);continue}Tr(t),++u}_i()};ee.getServerKey=function(e){w.typeOf.string("url",e);let t=new Ft.default(e);t.scheme()===""&&(t=t.absoluteTo(gi),t.normalize());let n=t.authority();/:/.test(n)||(n=`${n}:${t.scheme()==="https"?"443":"80"}`);let i=Pe[n];return d(i)||(Pe[n]=0),n};ee.request=function(e){if(w.typeOf.object("request",e),w.typeOf.string("request.url",e.url),w.typeOf.func("request.requestFunction",e.requestFunction),qt(e.url)||zt(e.url))return Mt.raiseEvent(),e.state=te.RECEIVED,e.requestFunction();if(++H.numberOfAttemptedRequests,d(e.serverKey)||(e.serverKey=ee.getServerKey(e.url)),ee.throttleRequests&&e.throttleByServer&&!ee.serverHasOpenSlots(e.serverKey))return;if(!ee.throttleRequests||!e.throttle)return Tr(e);if(Ae.length>=ee.maximumRequests)return;Rr(e);let t=le.insert(e);if(d(t)){if(t===e)return;He(t)}return Pr(e)};function _i(){ee.debugShowStatistics&&(H.numberOfActiveRequests===0&&H.lastNumberOfActiveRequests>0&&(H.numberOfAttemptedRequests>0&&(console.log(`Number of attempted requests: ${H.numberOfAttemptedRequests}`),H.numberOfAttemptedRequests=0),H.numberOfCancelledRequests>0&&(console.log(`Number of cancelled requests: ${H.numberOfCancelledRequests}`),H.numberOfCancelledRequests=0),H.numberOfCancelledActiveRequests>0&&(console.log(`Number of cancelled active requests: ${H.numberOfCancelledActiveRequests}`),H.numberOfCancelledActiveRequests=0),H.numberOfFailedRequests>0&&(console.log(`Number of failed requests: ${H.numberOfFailedRequests}`),H.numberOfFailedRequests=0)),H.lastNumberOfActiveRequests=H.numberOfActiveRequests)}ee.clearForSpecs=function(){for(;le.length>0;){let t=le.pop();He(t)}let e=Ae.length;for(let t=0;t0}},credits:{get:function(){return this._credits}}});E.prototype.toString=function(){return this.getUrlComponent(!0,!0)};E.prototype.parseUrl=function(e,t,n,i){let s=new zr.default(e),o=xi(s.query());this._queryParameters=t?Bt(o,this.queryParameters,n):o,s.search(""),s.fragment(""),d(i)&&s.scheme()===""&&(s=s.absoluteTo(ft(i))),this._url=s.toString()};function xi(e){return e.length===0?{}:e.indexOf("=")===-1?{[e]:void 0}:Sr(e)}function Bt(e,t,n){if(!n)return qe(e,t);let i=nt(e,!0);for(let s in t)if(t.hasOwnProperty(s)){let o=i[s],c=t[s];d(o)?(Array.isArray(o)||(o=i[s]=[o]),i[s]=o.concat(c)):i[s]=Array.isArray(c)?c.slice():c}return i}E.prototype.getUrlComponent=function(e,t){if(this.isDataUri)return this._url;let n=this._url;e&&(n=`${n}${vi(this.queryParameters)}`),n=n.replace(/%7B/g,"{").replace(/%7D/g,"}");let i=this._templateValues;return Object.keys(i).length>0&&(n=n.replace(/{(.*?)}/g,function(s,o){let c=i[o];return d(c)?encodeURIComponent(c):s})),t&&d(this.proxy)&&(n=this.proxy.getURL(n)),n};function vi(e){let t=Object.keys(e);return t.length===0?"":t.length===1&&!d(e[t[0]])?`?${t[0]}`:`?${_r(e)}`}E.prototype.setQueryParameters=function(e,t){t?this._queryParameters=Bt(this._queryParameters,e,!1):this._queryParameters=Bt(e,this._queryParameters,!1)};E.prototype.appendQueryParameters=function(e){this._queryParameters=Bt(e,this._queryParameters,!0)};E.prototype.setTemplateValues=function(e,t){t?this._templateValues=qe(this._templateValues,e):this._templateValues=qe(e,this._templateValues)};E.prototype.getDerivedResource=function(e){let t=this.clone();if(t._retryCount=0,d(e.url)){let n=O(e.preserveQueryParameters,!1);t.parseUrl(e.url,!0,n,this._url)}return d(e.queryParameters)&&(t._queryParameters=qe(e.queryParameters,t.queryParameters)),d(e.templateValues)&&(t._templateValues=qe(e.templateValues,t.templateValues)),d(e.headers)&&(t.headers=qe(e.headers,t.headers)),d(e.proxy)&&(t.proxy=e.proxy),d(e.request)&&(t.request=e.request),d(e.retryCallback)&&(t.retryCallback=e.retryCallback),d(e.retryAttempts)&&(t.retryAttempts=e.retryAttempts),t};E.prototype.retryOnError=function(e){let t=this.retryCallback;if(typeof t!="function"||this._retryCount>=this.retryAttempts)return Promise.resolve(!1);let n=this;return Promise.resolve(t(this,e)).then(function(i){return++n._retryCount,i})};E.prototype.clone=function(e){return d(e)?(e._url=this._url,e._queryParameters=nt(this._queryParameters),e._templateValues=nt(this._templateValues),e.headers=nt(this.headers),e.proxy=this.proxy,e.retryCallback=this.retryCallback,e.retryAttempts=this.retryAttempts,e._retryCount=0,e.request=this.request.clone(),e):new E({url:this._url,queryParameters:this.queryParameters,templateValues:this.templateValues,headers:this.headers,proxy:this.proxy,retryCallback:this.retryCallback,retryAttempts:this.retryAttempts,request:this.request.clone(),parseUrl:!1,credits:d(this.credits)?this.credits.slice():void 0})};E.prototype.getBaseUri=function(e){return mr(this.getUrlComponent(e),e)};E.prototype.appendForwardSlash=function(){this._url=fr(this._url)};E.prototype.fetchArrayBuffer=function(){return this.fetch({responseType:"arraybuffer"})};E.fetchArrayBuffer=function(e){return new E(e).fetchArrayBuffer()};E.prototype.fetchBlob=function(){return this.fetch({responseType:"blob"})};E.fetchBlob=function(e){return new E(e).fetchBlob()};E.prototype.fetchImage=function(e){e=O(e,O.EMPTY_OBJECT);let t=O(e.preferImageBitmap,!1),n=O(e.preferBlob,!1),i=O(e.flipY,!1),s=O(e.skipColorSpaceConversion,!1);if(Tn(this.request),!qr||this.isDataUri||this.isBlobUri||!this.hasHeaders&&!n)return Pn({resource:this,flipY:i,skipColorSpaceConversion:s,preferImageBitmap:t});let o=this.fetchBlob();if(!d(o))return;let c,u,p,b;return E.supportsImageBitmapOptions().then(function(g){return c=g,u=c&&t,o}).then(function(g){if(!d(g))return;if(b=g,u)return E.createImageBitmapFromBlob(g,{flipY:i,premultiplyAlpha:!1,skipColorSpaceConversion:s});let y=window.URL.createObjectURL(g);return p=new E({url:y}),Pn({resource:p,flipY:i,skipColorSpaceConversion:s,preferImageBitmap:!1})}).then(function(g){if(d(g))return g.blob=b,u||window.URL.revokeObjectURL(p.url),g}).catch(function(g){return d(p)&&window.URL.revokeObjectURL(p.url),g.blob=b,Promise.reject(g)})};function Pn(e){let t=e.resource,n=e.flipY,i=e.skipColorSpaceConversion,s=e.preferImageBitmap,o=t.request;o.url=t.url,o.requestFunction=function(){let u=!1;!t.isDataUri&&!t.isBlobUri&&(u=t.isCrossOriginUrl);let p=We();return E._Implementations.createImage(o,u,p,n,i,s),p.promise};let c=jt.request(o);if(d(c))return c.catch(function(u){return o.state!==te.FAILED?Promise.reject(u):t.retryOnError(u).then(function(p){return p?(o.state=te.UNISSUED,o.deferred=void 0,Pn({resource:t,flipY:n,skipColorSpaceConversion:i,preferImageBitmap:s})):Promise.reject(u)})})}E.fetchImage=function(e){return new E(e).fetchImage({flipY:e.flipY,skipColorSpaceConversion:e.skipColorSpaceConversion,preferBlob:e.preferBlob,preferImageBitmap:e.preferImageBitmap})};E.prototype.fetchText=function(){return this.fetch({responseType:"text"})};E.fetchText=function(e){return new E(e).fetchText()};E.prototype.fetchJson=function(){let e=this.fetch({responseType:"text",headers:{Accept:"application/json,*/*;q=0.01"}});if(d(e))return e.then(function(t){if(d(t))return JSON.parse(t)})};E.fetchJson=function(e){return new E(e).fetchJson()};E.prototype.fetchXML=function(){return this.fetch({responseType:"document",overrideMimeType:"text/xml"})};E.fetchXML=function(e){return new E(e).fetchXML()};E.prototype.fetchJsonp=function(e){e=O(e,"callback"),Tn(this.request);let t;do t=`loadJsonp${J.nextRandomNumber().toString().substring(2,8)}`;while(d(window[t]));return kr(this,e,t)};function kr(e,t,n){let i={};i[t]=n,e.setQueryParameters(i);let s=e.request,o=e.url;s.url=o,s.requestFunction=function(){let u=We();return window[n]=function(p){u.resolve(p);try{delete window[n]}catch{window[n]=void 0}},E._Implementations.loadAndExecuteScript(o,n,u),u.promise};let c=jt.request(s);if(d(c))return c.catch(function(u){return s.state!==te.FAILED?Promise.reject(u):e.retryOnError(u).then(function(p){return p?(s.state=te.UNISSUED,s.deferred=void 0,kr(e,t,n)):Promise.reject(u)})})}E.fetchJsonp=function(e){return new E(e).fetchJsonp(e.callbackParameterName)};E.prototype._makeRequest=function(e){let t=this;Tn(t.request);let n=t.request,i=t.url;n.url=i,n.requestFunction=function(){let o=e.responseType,c=qe(e.headers,t.headers),u=e.overrideMimeType,p=e.method,b=e.data,g=We(),y=E._Implementations.loadWithXhr(i,o,p,b,c,g,u);return d(y)&&d(y.abort)&&(n.cancelFunction=function(){y.abort()}),g.promise};let s=jt.request(n);if(d(s))return s.then(function(o){return n.cancelFunction=void 0,o}).catch(function(o){return n.cancelFunction=void 0,n.state!==te.FAILED?Promise.reject(o):t.retryOnError(o).then(function(c){return c?(n.state=te.UNISSUED,n.deferred=void 0,t.fetch(e)):Promise.reject(o)})})};function Tn(e){if(e.state===te.ISSUED||e.state===te.ACTIVE)throw new Ee("The Resource is already being fetched.");e.state=te.UNISSUED,e.deferred=void 0}var Oi=/^data:(.*?)(;base64)?,(.*)$/;function Nt(e,t){let n=decodeURIComponent(t);return e?atob(n):n}function Ur(e,t){let n=Nt(e,t),i=new ArrayBuffer(n.length),s=new Uint8Array(i);for(let o=0;o(u=b.parse(e),p=g,u.protocol==="https:"?import("https"):import("http"))).then(b=>{let g={protocol:u.protocol,hostname:u.hostname,port:u.port,path:u.path,query:u.query,method:n,headers:s};b.request(g).on("response",function(y){if(y.statusCode<200||y.statusCode>=300){o.reject(new lt(y.statusCode,y,y.headers));return}let S=[];y.on("data",function(A){S.push(A)}),y.on("end",function(){let A=Buffer.concat(S);y.headers["content-encoding"]==="gzip"?p.gunzip(A,function(I,T){I?o.reject(new Ee("Error decompressing response.")):o.resolve(Dr(T,t))}):o.resolve(Dr(A,t))})}).on("error",function(y){o.reject(new lt)}).end()})}var Ai=typeof XMLHttpRequest>"u";E._Implementations.loadWithXhr=function(e,t,n,i,s,o,c){let u=Oi.exec(e);if(u!==null){o.resolve(Ei(u,t));return}if(Ai){Ci(e,t,n,i,s,o,c);return}let p=new XMLHttpRequest;if(Rn.contains(e)&&(p.withCredentials=!0),p.open(n,e,!0),d(c)&&d(p.overrideMimeType)&&p.overrideMimeType(c),d(s))for(let g in s)s.hasOwnProperty(g)&&p.setRequestHeader(g,s[g]);d(t)&&(p.responseType=t);let b=!1;return typeof e=="string"&&(b=e.indexOf("file://")===0||typeof window<"u"&&window.location.origin==="file://"),p.onload=function(){if((p.status<200||p.status>=300)&&!(b&&p.status===0)){o.reject(new lt(p.status,p.response,p.getAllResponseHeaders()));return}let g=p.response,y=p.responseType;if(n==="HEAD"||n==="OPTIONS"){let A=p.getAllResponseHeaders().trim().split(/[\r\n]+/),I={};A.forEach(function(T){let k=T.split(": "),D=k.shift();I[D]=k.join(": ")}),o.resolve(I);return}if(p.status===204)o.resolve();else if(d(g)&&(!d(t)||y===t))o.resolve(g);else if(t==="json"&&typeof g=="string")try{o.resolve(JSON.parse(g))}catch(S){o.reject(S)}else(y===""||y==="document")&&d(p.responseXML)&&p.responseXML.hasChildNodes()?o.resolve(p.responseXML):(y===""||y==="text")&&d(p.responseText)?o.resolve(p.responseText):o.reject(new Ee("Invalid XMLHttpRequest response type."))},p.onerror=function(g){o.reject(new lt)},p.send(i),p};E._Implementations.loadAndExecuteScript=function(e,t,n){return br(e,t).catch(function(i){n.reject(i)})};E._DefaultImplementations={};E._DefaultImplementations.createImage=E._Implementations.createImage;E._DefaultImplementations.loadWithXhr=E._Implementations.loadWithXhr;E._DefaultImplementations.loadAndExecuteScript=E._Implementations.loadAndExecuteScript;E.DEFAULT=Object.freeze(new E({url:typeof document>"u"?"":document.location.href.split("?")[0]}));var Fe=E;function ht(e){e=O(e,O.EMPTY_OBJECT),this._dates=void 0,this._samples=void 0,this._dateColumn=-1,this._xPoleWanderRadiansColumn=-1,this._yPoleWanderRadiansColumn=-1,this._ut1MinusUtcSecondsColumn=-1,this._xCelestialPoleOffsetRadiansColumn=-1,this._yCelestialPoleOffsetRadiansColumn=-1,this._taiMinusUtcSecondsColumn=-1,this._columnCount=0,this._lastIndex=-1,this._addNewLeapSeconds=O(e.addNewLeapSeconds,!0),d(e.data)?Fr(this,e.data):Fr(this,{columnNames:["dateIso8601","modifiedJulianDateUtc","xPoleWanderRadians","yPoleWanderRadians","ut1MinusUtcSeconds","lengthOfDayCorrectionSeconds","xCelestialPoleOffsetRadians","yCelestialPoleOffsetRadians","taiMinusUtcSeconds"],samples:[]})}ht.fromUrl=async function(e,t){w.defined("url",e),t=O(t,O.EMPTY_OBJECT);let n=Fe.createIfNeeded(e),i;try{i=await n.fetchJson()}catch{throw new Ee(`An error occurred while retrieving the EOP data from the URL ${n.url}.`)}return new ht({addNewLeapSeconds:t.addNewLeapSeconds,data:i})};ht.NONE=Object.freeze({compute:function(e,t){return d(t)?(t.xPoleWander=0,t.yPoleWander=0,t.xPoleOffset=0,t.yPoleOffset=0,t.ut1MinusUtc=0):t=new ut(0,0,0,0,0),t}});ht.prototype.compute=function(e,t){if(!d(this._samples))return;if(d(t)||(t=new ut(0,0,0,0,0)),this._samples.length===0)return t.xPoleWander=0,t.yPoleWander=0,t.xPoleOffset=0,t.yPoleOffset=0,t.ut1MinusUtc=0,t;let n=this._dates,i=this._lastIndex,s=0,o=0;if(d(i)){let u=n[i],p=n[i+1],b=ue.lessThanOrEquals(u,e),g=!d(p),y=g||ue.greaterThanOrEquals(p,e);if(b&&y)return s=i,!g&&p.equals(e)&&++s,o=s+1,jr(this,n,this._samples,e,s,o,t),t}let c=Qe(n,e,ue.compare,this._dateColumn);return c>=0?(ct.length-1)return c.xPoleWander=0,c.yPoleWander=0,c.xPoleOffset=0,c.yPoleOffset=0,c.ut1MinusUtc=0,c;let p=t[s],b=t[o];if(p.equals(b)||i.equals(p))return Mr(e,n,s,u,c),c;if(i.equals(b))return Mr(e,n,o,u,c),c;let g=ue.secondsDifference(i,p)/ue.secondsDifference(b,p),y=s*u,S=o*u,A=n[y+e._ut1MinusUtcSecondsColumn],I=n[S+e._ut1MinusUtcSecondsColumn],T=I-A;if(T>.5||T<-.5){let k=n[y+e._taiMinusUtcSecondsColumn],D=n[S+e._taiMinusUtcSecondsColumn];k!==D&&(b.equals(i)?A=I:I-=D-k)}return c.xPoleWander=mt(g,n[y+e._xPoleWanderRadiansColumn],n[S+e._xPoleWanderRadiansColumn]),c.yPoleWander=mt(g,n[y+e._yPoleWanderRadiansColumn],n[S+e._yPoleWanderRadiansColumn]),c.xPoleOffset=mt(g,n[y+e._xCelestialPoleOffsetRadiansColumn],n[S+e._xCelestialPoleOffsetRadiansColumn]),c.yPoleOffset=mt(g,n[y+e._yCelestialPoleOffsetRadiansColumn],n[S+e._yCelestialPoleOffsetRadiansColumn]),c.ut1MinusUtc=mt(g,A,I),c}var Nr=ht;function de(e,t,n){this.heading=O(e,0),this.pitch=O(t,0),this.roll=O(n,0)}de.fromQuaternion=function(e,t){if(!d(e))throw new R("quaternion is required");d(t)||(t=new de);let n=2*(e.w*e.y-e.z*e.x),i=1-2*(e.x*e.x+e.y*e.y),s=2*(e.w*e.x+e.y*e.z),o=1-2*(e.y*e.y+e.z*e.z),c=2*(e.w*e.z+e.x*e.y);return t.heading=-Math.atan2(c,o),t.roll=Math.atan2(s,i),t.pitch=-J.asinClamped(n),t};de.fromDegrees=function(e,t,n,i){if(!d(e))throw new R("heading is required");if(!d(t))throw new R("pitch is required");if(!d(n))throw new R("roll is required");return d(i)||(i=new de),i.heading=e*J.RADIANS_PER_DEGREE,i.pitch=t*J.RADIANS_PER_DEGREE,i.roll=n*J.RADIANS_PER_DEGREE,i};de.clone=function(e,t){if(d(e))return d(t)?(t.heading=e.heading,t.pitch=e.pitch,t.roll=e.roll,t):new de(e.heading,e.pitch,e.roll)};de.equals=function(e,t){return e===t||d(e)&&d(t)&&e.heading===t.heading&&e.pitch===t.pitch&&e.roll===t.roll};de.equalsEpsilon=function(e,t,n,i){return e===t||d(e)&&d(t)&&J.equalsEpsilon(e.heading,t.heading,n,i)&&J.equalsEpsilon(e.pitch,t.pitch,n,i)&&J.equalsEpsilon(e.roll,t.roll,n,i)};de.prototype.clone=function(e){return de.clone(this,e)};de.prototype.equals=function(e){return de.equals(this,e)};de.prototype.equalsEpsilon=function(e,t,n){return de.equalsEpsilon(this,e,t,n)};de.prototype.toString=function(){return`(${this.heading}, ${this.pitch}, ${this.roll})`};var In=de;var Br=/((?:.*\/)|^)Cesium\.js(?:\?|\#|$)/;function Pi(){let e=document.getElementsByTagName("script");for(let t=0,n=e.length;t"u"?e:(d(Lt)||(Lt=document.createElement("a")),Lt.href=e,Lt.href)}var Ye;function Qr(){if(d(Ye))return Ye;let e;if(typeof CESIUM_BASE_URL<"u"?e=CESIUM_BASE_URL:d(import.meta)&&d(import.meta.url)?e=ft(".",import.meta.url):typeof define=="object"&&d(define.amd)&&!define.amd.toUrlUndefined&&d(_t.toUrl)?e=ft("..",Ze("Core/buildModuleUrl.js")):e=Pi(),!d(e))throw new R("Unable to determine Cesium base URL automatically, try defining a global variable called CESIUM_BASE_URL.");return Ye=new Fe({url:Lr(e)}),Ye.appendForwardSlash(),Ye}function Ti(e){return Lr(_t.toUrl(`../${e}`))}function $r(e){return Qr().getDerivedResource({url:e}).url}var Qt;function Ze(e){return d(Qt)||(typeof define=="object"&&d(define.amd)&&!define.amd.toUrlUndefined&&d(_t.toUrl)?Qt=Ti:Qt=$r),Qt(e)}Ze._cesiumScriptRegex=Br;Ze._buildModuleUrlFromBaseUrl=$r;Ze._clearBaseResource=function(){Ye=void 0};Ze.setBaseUrl=function(e){Ye=Fe.DEFAULT.getDerivedResource({url:e})};Ze.getCesiumBaseUrl=Qr;var Wr=Ze;function Ii(e,t,n){this.x=e,this.y=t,this.s=n}var $t=Ii;function zn(e){e=O(e,O.EMPTY_OBJECT),this._xysFileUrlTemplate=Fe.createIfNeeded(e.xysFileUrlTemplate),this._interpolationOrder=O(e.interpolationOrder,9),this._sampleZeroJulianEphemerisDate=O(e.sampleZeroJulianEphemerisDate,24423965e-1),this._sampleZeroDateTT=new ue(this._sampleZeroJulianEphemerisDate,0,j.TAI),this._stepSizeDays=O(e.stepSizeDays,1),this._samplesPerXysFile=O(e.samplesPerXysFile,1e3),this._totalSamples=O(e.totalSamples,27426),this._samples=new Array(this._totalSamples*3),this._chunkDownloadsInProgress=[];let t=this._interpolationOrder,n=this._denominators=new Array(t+1),i=this._xTable=new Array(t+1),s=Math.pow(this._stepSizeDays,t);for(let o=0;o<=t;++o){n[o]=s,i[o]=o*this._stepSizeDays;for(let c=0;c<=t;++c)c!==o&&(n[o]*=o-c);n[o]=1/n[o]}this._work=new Array(t+1),this._coef=new Array(t+1)}var Ui=new ue(0,0,j.TAI);function Un(e,t,n){let i=Ui;return i.dayNumber=t,i.secondsOfDay=n,ue.daysDifference(i,e._sampleZeroDateTT)}zn.prototype.preload=function(e,t,n,i){let s=Un(this,e,t),o=Un(this,n,i),c=s/this._stepSizeDays-this._interpolationOrder/2|0;c<0&&(c=0);let u=o/this._stepSizeDays-this._interpolationOrder/2|0+this._interpolationOrder;u>=this._totalSamples&&(u=this._totalSamples-1);let p=c/this._samplesPerXysFile|0,b=u/this._samplesPerXysFile|0,g=[];for(let y=p;y<=b;++y)g.push(Dn(this,y));return Promise.all(g)};zn.prototype.computeXysRadians=function(e,t,n){let i=Un(this,e,t);if(i<0)return;let s=i/this._stepSizeDays|0;if(s>=this._totalSamples)return;let o=this._interpolationOrder,c=s-(o/2|0);c<0&&(c=0);let u=c+o;u>=this._totalSamples&&(u=this._totalSamples-1,c=u-o,c<0&&(c=0));let p=!1,b=this._samples;if(d(b[c*3])||(Dn(this,c/this._samplesPerXysFile|0),p=!0),d(b[u*3])||(Dn(this,u/this._samplesPerXysFile|0),p=!0),p)return;d(n)?(n.x=0,n.y=0,n.s=0):n=new $t(0,0,0);let g=i-c*this._stepSizeDays,y=this._work,S=this._denominators,A=this._coef,I=this._xTable,T,k;for(T=0;T<=o;++T)y[T]=g-I[T];for(T=0;T<=o;++T){for(A[T]=1,k=0;k<=o;++k)k!==T&&(A[T]*=y[k]);A[T]*=S[T];let D=(c+T)*3;n.x+=A[T]*b[D++],n.y+=A[T]*b[D++],n.s+=A[T]*b[D]}return n};function Dn(e,t){if(e._chunkDownloadsInProgress[t])return e._chunkDownloadsInProgress[t];let n,i=e._xysFileUrlTemplate;d(i)?n=i.getDerivedResource({templateValues:{0:t}}):n=new Fe({url:Wr(`Assets/IAU2006_XYS/IAU2006_XYS_${t}.json`)});let s=n.fetchJson().then(function(o){e._chunkDownloadsInProgress[t]=!1;let c=e._samples,u=o.samples,p=t*e._samplesPerXysFile*3;for(let b=0,g=u.length;b{let t=new Image;t.onload=function(){pe._result=t.width>0&&t.height>0,e(pe._result)},t.onerror=function(){pe._result=!1,e(pe._result)},t.src="data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA"})),pe._promise};Object.defineProperties(pe,{initialized:{get:function(){return d(pe._result)}}});var st=[];typeof ArrayBuffer<"u"&&(st.push(Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array),typeof Uint8ClampedArray<"u"&&st.push(Uint8ClampedArray),typeof Uint8ClampedArray<"u"&&st.push(Uint8ClampedArray),typeof BigInt64Array<"u"&&st.push(BigInt64Array),typeof BigUint64Array<"u"&&st.push(BigUint64Array));var Se={isChrome:Nn,chromeVersion:Di,isSafari:Jr,safariVersion:zi,isWebkit:Xr,webkitVersion:qi,isInternetExplorer:Gr,internetExplorerVersion:ki,isEdge:Xt,edgeVersion:Fi,isFirefox:Gt,firefoxVersion:Ni,isWindows:Mi,isIPadOrIOS:ji,hardwareConcurrency:O(me.hardwareConcurrency,3),supportsPointerEvents:Bi,supportsImageRenderingPixelated:to,supportsWebP:pe,imageRenderingValue:Li,typedArrayTypes:st};Se.supportsBasis=function(e){return Se.supportsWebAssembly()&&e.context.supportsBasis};Se.supportsFullscreen=function(){return Hr.supportsFullscreen()};Se.supportsTypedArrays=function(){return typeof ArrayBuffer<"u"};Se.supportsBigInt64Array=function(){return typeof BigInt64Array<"u"};Se.supportsBigUint64Array=function(){return typeof BigUint64Array<"u"};Se.supportsBigInt=function(){return typeof BigInt<"u"};Se.supportsWebWorkers=function(){return typeof Worker<"u"};Se.supportsWebAssembly=function(){return typeof WebAssembly<"u"};Se.supportsWebgl2=function(e){return w.defined("scene",e),e.context.webgl2};Se.supportsEsmWebWorkers=function(){return!Gt()||parseInt(Bn)>=114};var gt=Se;function x(e,t,n,i){this.x=O(e,0),this.y=O(t,0),this.z=O(n,0),this.w=O(i,0)}var wt=new f;x.fromAxisAngle=function(e,t,n){w.typeOf.object("axis",e),w.typeOf.number("angle",t);let i=t/2,s=Math.sin(i);wt=f.normalize(e,wt);let o=wt.x*s,c=wt.y*s,u=wt.z*s,p=Math.cos(i);return d(n)?(n.x=o,n.y=c,n.z=u,n.w=p,n):new x(o,c,u,p)};var Qi=[1,2,0],$i=new Array(3);x.fromRotationMatrix=function(e,t){w.typeOf.object("matrix",e);let n,i,s,o,c,u=e[B.COLUMN0ROW0],p=e[B.COLUMN1ROW1],b=e[B.COLUMN2ROW2],g=u+p+b;if(g>0)n=Math.sqrt(g+1),c=.5*n,n=.5/n,i=(e[B.COLUMN1ROW2]-e[B.COLUMN2ROW1])*n,s=(e[B.COLUMN2ROW0]-e[B.COLUMN0ROW2])*n,o=(e[B.COLUMN0ROW1]-e[B.COLUMN1ROW0])*n;else{let y=Qi,S=0;p>u&&(S=1),b>u&&b>p&&(S=2);let A=y[S],I=y[A];n=Math.sqrt(e[B.getElementIndex(S,S)]-e[B.getElementIndex(A,A)]-e[B.getElementIndex(I,I)]+1);let T=$i;T[S]=.5*n,n=.5/n,c=(e[B.getElementIndex(I,A)]-e[B.getElementIndex(A,I)])*n,T[A]=(e[B.getElementIndex(A,S)]+e[B.getElementIndex(S,A)])*n,T[I]=(e[B.getElementIndex(I,S)]+e[B.getElementIndex(S,I)])*n,i=-T[0],s=-T[1],o=-T[2]}return d(t)?(t.x=i,t.y=s,t.z=o,t.w=c,t):new x(i,s,o,c)};var no=new x,ro=new x,Ln=new x,oo=new x;x.fromHeadingPitchRoll=function(e,t){return w.typeOf.object("headingPitchRoll",e),oo=x.fromAxisAngle(f.UNIT_X,e.roll,no),Ln=x.fromAxisAngle(f.UNIT_Y,-e.pitch,t),t=x.multiply(Ln,oo,Ln),ro=x.fromAxisAngle(f.UNIT_Z,-e.heading,no),x.multiply(ro,t,t)};var Kt=new f,Qn=new f,Oe=new x,io=new x,en=new x;x.packedLength=4;x.pack=function(e,t,n){return w.typeOf.object("value",e),w.defined("array",t),n=O(n,0),t[n++]=e.x,t[n++]=e.y,t[n++]=e.z,t[n]=e.w,t};x.unpack=function(e,t,n){return w.defined("array",e),t=O(t,0),d(n)||(n=new x),n.x=e[t],n.y=e[t+1],n.z=e[t+2],n.w=e[t+3],n};x.packedInterpolationLength=3;x.convertPackedArrayForInterpolation=function(e,t,n,i){x.unpack(e,n*4,en),x.conjugate(en,en);for(let s=0,o=n-t+1;s=0?o=1:(o=-1,s=-s);let c=s-1,u=1-n,p=n*n,b=u*u;for(let A=7;A>=0;--A)Te[A]=(tn[A]*p-nn[A])*c,Ie[A]=(tn[A]*b-nn[A])*c;let g=o*n*(1+Te[0]*(1+Te[1]*(1+Te[2]*(1+Te[3]*(1+Te[4]*(1+Te[5]*(1+Te[6]*(1+Te[7])))))))),y=u*(1+Ie[0]*(1+Ie[1]*(1+Ie[2]*(1+Ie[3]*(1+Ie[4]*(1+Ie[5]*(1+Ie[6]*(1+Ie[7])))))))),S=x.multiplyByScalar(e,y,Hi);return x.multiplyByScalar(t,g,i),x.add(S,i,i)};x.fastSquad=function(e,t,n,i,s,o){w.typeOf.object("q0",e),w.typeOf.object("q1",t),w.typeOf.object("s0",n),w.typeOf.object("s1",i),w.typeOf.number("t",s),w.typeOf.object("result",o);let c=x.fastSlerp(e,t,s,bt),u=x.fastSlerp(n,i,s,at);return x.fastSlerp(c,u,2*s*(1-s),o)};x.equals=function(e,t){return e===t||d(e)&&d(t)&&e.x===t.x&&e.y===t.y&&e.z===t.z&&e.w===t.w};x.equalsEpsilon=function(e,t,n){return n=O(n,0),e===t||d(e)&&d(t)&&Math.abs(e.x-t.x)<=n&&Math.abs(e.y-t.y)<=n&&Math.abs(e.z-t.z)<=n&&Math.abs(e.w-t.w)<=n};x.ZERO=Object.freeze(new x(0,0,0,0));x.IDENTITY=Object.freeze(new x(0,0,0,1));x.prototype.clone=function(e){return x.clone(this,e)};x.prototype.equals=function(e){return x.equals(this,e)};x.prototype.equalsEpsilon=function(e,t){return x.equalsEpsilon(this,e,t)};x.prototype.toString=function(){return`(${this.x}, ${this.y}, ${this.z}, ${this.w})`};var Xe=x;var $={},Hn={up:{south:"east",north:"west",west:"south",east:"north"},down:{south:"west",north:"east",west:"north",east:"south"},south:{up:"west",down:"east",west:"down",east:"up"},north:{up:"east",down:"west",west:"up",east:"down"},west:{up:"north",down:"south",north:"down",south:"up"},east:{up:"south",down:"north",north:"up",south:"down"}},ct={north:[-1,0,0],east:[0,1,0],up:[0,0,1],south:[1,0,0],west:[0,-1,0],down:[0,0,-1]},Yn={},we={east:new f,north:new f,up:new f,west:new f,south:new f,down:new f},je=new f,Ne=new f,Be=new f;$.localFrameToFixedFrameGenerator=function(e,t){if(!Hn.hasOwnProperty(e)||!Hn[e].hasOwnProperty(t))throw new R("firstAxis and secondAxis must be east, north, up, west, south or down.");let n=Hn[e][t],i,s=e+t;return d(Yn[s])?i=Yn[s]:(i=function(o,c,u){if(!d(o))throw new R("origin is required.");if(d(u)||(u=new L),f.equalsEpsilon(o,f.ZERO,J.EPSILON14))f.unpack(ct[e],0,je),f.unpack(ct[t],0,Ne),f.unpack(ct[n],0,Be);else if(J.equalsEpsilon(o.x,0,J.EPSILON14)&&J.equalsEpsilon(o.y,0,J.EPSILON14)){let p=J.sign(o.z);f.unpack(ct[e],0,je),e!=="east"&&e!=="west"&&f.multiplyByScalar(je,p,je),f.unpack(ct[t],0,Ne),t!=="east"&&t!=="west"&&f.multiplyByScalar(Ne,p,Ne),f.unpack(ct[n],0,Be),n!=="east"&&n!=="west"&&f.multiplyByScalar(Be,p,Be)}else{c=O(c,ze.WGS84),c.geodeticSurfaceNormal(o,we.up);let p=we.up,b=we.east;b.x=-o.y,b.y=o.x,b.z=0,f.normalize(b,we.east),f.cross(p,b,we.north),f.multiplyByScalar(we.up,-1,we.down),f.multiplyByScalar(we.east,-1,we.west),f.multiplyByScalar(we.north,-1,we.south),je=we[e],Ne=we[t],Be=we[n]}return u[0]=je.x,u[1]=je.y,u[2]=je.z,u[3]=0,u[4]=Ne.x,u[5]=Ne.y,u[6]=Ne.z,u[7]=0,u[8]=Be.x,u[9]=Be.y,u[10]=Be.z,u[11]=0,u[12]=o.x,u[13]=o.y,u[14]=o.z,u[15]=1,u},Yn[s]=i),i};$.eastNorthUpToFixedFrame=$.localFrameToFixedFrameGenerator("east","north");$.northEastDownToFixedFrame=$.localFrameToFixedFrameGenerator("north","east");$.northUpEastToFixedFrame=$.localFrameToFixedFrameGenerator("north","up");$.northWestUpToFixedFrame=$.localFrameToFixedFrameGenerator("north","west");var Yi=new Xe,Zi=new f(1,1,1),Ji=new L;$.headingPitchRollToFixedFrame=function(e,t,n,i,s){w.typeOf.object("HeadingPitchRoll",t),i=O(i,$.eastNorthUpToFixedFrame);let o=Xe.fromHeadingPitchRoll(t,Yi),c=L.fromTranslationQuaternionRotationScale(f.ZERO,o,Zi,Ji);return s=i(e,n,s),L.multiply(s,c,s)};var Xi=new L,Gi=new B;$.headingPitchRollQuaternion=function(e,t,n,i,s){w.typeOf.object("HeadingPitchRoll",t);let o=$.headingPitchRollToFixedFrame(e,t,n,i,Xi),c=L.getMatrix3(o,Gi);return Xe.fromRotationMatrix(c,s)};var Ki=new f(1,1,1),es=new f,co=new L,ts=new L,ns=new B,rs=new Xe;$.fixedFrameToHeadingPitchRoll=function(e,t,n,i){w.defined("transform",e),t=O(t,ze.WGS84),n=O(n,$.eastNorthUpToFixedFrame),d(i)||(i=new In);let s=L.getTranslation(e,es);if(f.equals(s,f.ZERO))return i.heading=0,i.pitch=0,i.roll=0,i;let o=L.inverseTransformation(n(s,t,co),co),c=L.setScale(e,Ki,ts);c=L.setTranslation(c,f.ZERO,c),o=L.multiply(o,c,o);let u=Xe.fromRotationMatrix(L.getMatrix3(o,ns),rs);return u=Xe.normalize(u,u),In.fromQuaternion(u,i)};var os=6*3600+41*60+50.54841,is=8640184812866e-6,ss=.093104,as=-62e-7,cs=11772758384668e-32,us=72921158553e-15,fs=J.TWO_PI/86400,rn=new ue;$.computeTemeToPseudoFixedMatrix=function(e,t){if(!d(e))throw new R("date is required.");rn=ue.addSeconds(e,-ue.computeTaiMinusUtc(e),rn);let n=rn.dayNumber,i=rn.secondsOfDay,s,o=n-2451545;i>=43200?s=(o+.5)/K.DAYS_PER_JULIAN_CENTURY:s=(o-.5)/K.DAYS_PER_JULIAN_CENTURY;let u=(os+s*(is+s*(ss+s*as)))*fs%J.TWO_PI,p=us+cs*(n-24515455e-1),b=(i+K.SECONDS_PER_DAY*.5)%K.SECONDS_PER_DAY,g=u+p*b,y=Math.cos(g),S=Math.sin(g);return d(t)?(t[0]=y,t[1]=-S,t[2]=0,t[3]=S,t[4]=y,t[5]=0,t[6]=0,t[7]=0,t[8]=1,t):new B(y,S,0,-S,y,0,0,0,1)};$.iau2006XysData=new Vr;$.earthOrientationParameters=Nr.NONE;var Xn=32.184,ls=2451545;$.preloadIcrfFixed=function(e){let t=e.start.dayNumber,n=e.start.secondsOfDay+Xn,i=e.stop.dayNumber,s=e.stop.secondsOfDay+Xn;return $.iau2006XysData.preload(t,n,i,s)};$.computeIcrfToFixedMatrix=function(e,t){if(!d(e))throw new R("date is required.");d(t)||(t=new B);let n=$.computeFixedToIcrfMatrix(e,t);if(d(n))return B.transpose(n,t)};var ds=new $t(0,0,0),ps=new ut(0,0,0,0,0,0),Zn=new B,Jn=new B;$.computeFixedToIcrfMatrix=function(e,t){if(!d(e))throw new R("date is required.");d(t)||(t=new B);let n=$.earthOrientationParameters.compute(e,ps);if(!d(n))return;let i=e.dayNumber,s=e.secondsOfDay+Xn,o=$.iau2006XysData.computeXysRadians(i,s,ds);if(!d(o))return;let c=o.x+n.xPoleOffset,u=o.y+n.yPoleOffset,p=1/(1+Math.sqrt(1-c*c-u*u)),b=Zn;b[0]=1-p*c*c,b[3]=-p*c*u,b[6]=c,b[1]=-p*c*u,b[4]=1-p*u*u,b[7]=u,b[2]=-c,b[5]=-u,b[8]=1-p*(c*c+u*u);let g=B.fromRotationZ(-o.s,Jn),y=B.multiply(b,g,Zn),S=e.dayNumber,A=e.secondsOfDay-ue.computeTaiMinusUtc(e)+n.ut1MinusUtc,I=S-2451545,T=A/K.SECONDS_PER_DAY,k=.779057273264+T+.00273781191135448*(I+T);k=k%1*J.TWO_PI;let D=B.fromRotationZ(k,Jn),F=B.multiply(y,D,Zn),z=Math.cos(n.xPoleWander),M=Math.cos(n.yPoleWander),N=Math.sin(n.xPoleWander),Y=Math.sin(n.yPoleWander),oe=i-ls+s/K.SECONDS_PER_DAY;oe/=36525;let ie=-47e-6*oe*J.RADIANS_PER_DEGREE/3600,X=Math.cos(ie),W=Math.sin(ie),Q=Jn;return Q[0]=z*X,Q[1]=z*W,Q[2]=N,Q[3]=-M*W+Y*N*X,Q[4]=M*X+Y*N*W,Q[5]=-Y*z,Q[6]=-Y*W-M*N*X,Q[7]=Y*X-M*N*W,Q[8]=M*z,B.multiply(F,Q,t)};var ms=new xt;$.pointToWindowCoordinates=function(e,t,n,i){return i=$.pointToGLWindowCoordinates(e,t,n,i),i.y=2*t[5]-i.y,i};$.pointToGLWindowCoordinates=function(e,t,n,i){if(!d(e))throw new R("modelViewProjectionMatrix is required.");if(!d(t))throw new R("viewportTransformation is required.");if(!d(n))throw new R("point is required.");d(i)||(i=new sn);let s=ms;return L.multiplyByVector(e,xt.fromElements(n.x,n.y,n.z,1,s),s),xt.multiplyByScalar(s,1/s.w,s),L.multiplyByVector(t,s,s),sn.fromCartesian4(s,i)};var hs=new f,ys=new f,gs=new f;$.rotationMatrixFromPositionVelocity=function(e,t,n,i){if(!d(e))throw new R("position is required.");if(!d(t))throw new R("velocity is required.");let s=O(n,ze.WGS84).geodeticSurfaceNormal(e,hs),o=f.cross(t,s,ys);f.equalsEpsilon(o,f.ZERO,J.EPSILON6)&&(o=f.clone(f.UNIT_X,o));let c=f.cross(o,t,gs);return f.normalize(c,c),f.cross(t,c,o),f.negate(o,o),f.normalize(o,o),d(i)||(i=new B),i[0]=t.x,i[1]=t.y,i[2]=t.z,i[3]=o.x,i[4]=o.y,i[5]=o.z,i[6]=c.x,i[7]=c.y,i[8]=c.z,i};var uo=new L(0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,1),fo=new De,lo=new f,ws=new f,bs=new B,Gn=new L,po=new L;$.basisTo2D=function(e,t,n){if(!d(e))throw new R("projection is required.");if(!d(t))throw new R("matrix is required.");if(!d(n))throw new R("result is required.");let i=L.getTranslation(t,ws),s=e.ellipsoid,o=s.cartesianToCartographic(i,fo),c=e.project(o,lo);f.fromElements(c.z,c.x,c.y,c);let u=$.eastNorthUpToFixedFrame(i,s,Gn),p=L.inverseTransformation(u,po),b=L.getMatrix3(t,bs),g=L.multiplyByMatrix3(p,b,n);return L.multiply(uo,g,n),L.setTranslation(n,c,n),n};$.wgs84To2DModelMatrix=function(e,t,n){if(!d(e))throw new R("projection is required.");if(!d(t))throw new R("center is required.");if(!d(n))throw new R("result is required.");let i=e.ellipsoid,s=$.eastNorthUpToFixedFrame(t,i,Gn),o=L.inverseTransformation(s,po),c=i.cartesianToCartographic(t,fo),u=e.project(c,lo);f.fromElements(u.z,u.x,u.y,u);let p=L.fromTranslation(u,Gn);return L.multiply(uo,o,n),L.multiply(p,n,n),n};var nf=$;export{an as a,Et as b,Kn as c,Qs as d,gt as e,Xe as f,Fe as g,Wr as h,nf as i}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-NX64RCXJ.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-NX64RCXJ.js new file mode 100644 index 0000000000000000000000000000000000000000..a8b3c5f720992dfec546baf34d9d8a8d1623acb0 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-NX64RCXJ.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a}from"./chunk-P44SUSQU.js";import{e as l}from"./chunk-ODUTJJQ5.js";function p(n,r,i){i=a(i,!1);let f={},u=l(n),s=l(r),e,t,o;if(u)for(e in n)n.hasOwnProperty(e)&&(t=n[e],s&&i&&typeof t=="object"&&r.hasOwnProperty(e)?(o=r[e],typeof o=="object"?f[e]=p(t,o,i):f[e]=t):f[e]=t);if(s)for(e in r)r.hasOwnProperty(e)&&!f.hasOwnProperty(e)&&(o=r[e],f[e]=o);return f}var h=p;export{h as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-ODUTJJQ5.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-ODUTJJQ5.js new file mode 100644 index 0000000000000000000000000000000000000000..fce0f385861f4fe8e07426ffb7eb91c897dfbcb6 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-ODUTJJQ5.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +var i=Object.create;var u=Object.defineProperty;var r=Object.getOwnPropertyDescriptor;var l=Object.getOwnPropertyNames;var o=Object.getPrototypeOf,c=Object.prototype.hasOwnProperty;var a=(n=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(n,{get:(e,d)=>(typeof require<"u"?require:e)[d]}):n)(function(n){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+n+'" is not supported')}),b=n=>e=>{var d=n[e];if(d)return d();throw new Error("Module not found in bundle: "+e)};var g=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports);var p=(n,e,d,t)=>{if(e&&typeof e=="object"||typeof e=="function")for(let f of l(e))!c.call(n,f)&&f!==d&&u(n,f,{get:()=>e[f],enumerable:!(t=r(e,f))||t.enumerable});return n};var h=(n,e,d)=>(d=n!=null?i(o(n)):{},p(e||!n||!n.__esModule?u(d,"default",{value:n,enumerable:!0}):d,n));function x(n){return n!=null}var k=x;export{a,b,g as c,h as d,k as e}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-P44SUSQU.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-P44SUSQU.js new file mode 100644 index 0000000000000000000000000000000000000000..c5b8df05abcbb99fe70ca223c5dd2d1493ae8707 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-P44SUSQU.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +function u(e,n){return e??n}u.EMPTY_OBJECT=Object.freeze({});var t=u;export{t as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-QA2UBISA.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-QA2UBISA.js new file mode 100644 index 0000000000000000000000000000000000000000..21bd46ac5e7da3109b5b3bc13688122cccea3993 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-QA2UBISA.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as _}from"./chunk-U7I5YLBQ.js";import{a as te}from"./chunk-YTG33ZHK.js";import{f as Z,i as me}from"./chunk-NNIY7VTE.js";import{a as fe,b as j,d as ee}from"./chunk-5EDTRNG5.js";import{a as e,b as ie,d as O}from"./chunk-C6Y3PRDH.js";import{a as Q}from"./chunk-LI57NJAL.js";import{a as se}from"./chunk-P44SUSQU.js";import{a as le}from"./chunk-FUATUYJ3.js";import{e as $}from"./chunk-ODUTJJQ5.js";var Se={ROUNDED:0,MITERED:1,BEVELED:2},G=Object.freeze(Se);var ue={};function P(r,n){if(!$(r))throw new le("identifier is required.");$(ue[r])||(ue[r]=!0,console.warn(se(n,r)))}P.geometryOutlines="Entity geometry outlines are unsupported on terrain. Outlines will be disabled. To enable outlines, disable geometry terrain clamping by explicitly setting height to 0.";P.geometryZIndex="Entity geometry with zIndex are unsupported when height or extrudedHeight are defined. zIndex will be ignored";P.geometryHeightReference="Entity corridor, ellipse, polygon or rectangle with heightReference must also have a defined height. heightReference will be ignored";P.geometryExtrudedHeightReference="Entity corridor, ellipse, polygon or rectangle with extrudedHeightReference must also have a defined extrudedHeight. extrudedHeightReference will be ignored";var he=P;var w=[new e,new e],Te=new e,Be=new e,Ce=new e,ze=new e,Ae=new e,be=new e,Oe=new e,ve=new e,De=new e,I=new e,W=new e,R={},re=new ie;function je(r,n){let a=new Array(r.length);for(let o=0;o=0?-l:l}var Me=new e(-1,0,0),H=new j,Ve=new j,oe=new O,Ne=O.IDENTITY.clone(),Fe=new e,Ge=new fe,de=new e;function v(r,n,a,o,t,c,f,l){let m=Fe,s=Ge;H=me.eastNorthUpToFixedFrame(r,t,H),m=j.multiplyByPointAsVector(H,Me,m),m=e.normalize(m,m);let S=He(m,n,r,t);oe=O.fromRotationZ(S,oe),de.z=c,H=j.multiplyTransformation(H,j.fromRotationTranslation(oe,de,Ve),H);let d=Ne;d[0]=f;for(let x=0;x0){let D=s?2:1;for(let y=0;y=0};var qe=new e,Pe=new e;R.computePositions=function(r,n,a,o,t){let c=o._ellipsoid,f=je(r,c),l=o._granularity,m=o._cornerType,s=t?Le(n,a):ge(n,a),S=t?ge(n,a):void 0,d=a.height/2,x=a.width/2,i=r.length,g=[],D=t?[]:void 0,y=Te,b=Be,h=Ce,E=ze,B=Ae,C=be,z=Oe,u=ve,T=De,p=r[0],M=r[1];E=c.geodeticSurfaceNormal(p,E),y=e.subtract(M,p,y),y=e.normalize(y,y),u=e.cross(E,y,u),u=e.normalize(u,u);let V=f[0],A=f[1];t&&(D=v(p,u,S,D,c,V+d,1,1)),T=e.clone(p,T),p=M,b=e.negate(y,b);let N,F;for(let U=1;U1;--r){for(e[t++]=n++,e[t++]=n,e[t++]=i,s=2*r,f=0;fI.PI&&(c.north=c.north>0?I.PI_OVER_TWO-I.EPSILON7:c.north,c.south=c.south<0?I.EPSILON7-I.PI_OVER_TWO:c.south,c.east=I.PI,c.west=-I.PI),c}function U(o){o=T(o,T.EMPTY_OBJECT);let e=o.center,t=T(o.ellipsoid,v.WGS84),n=o.semiMajorAxis,s=o.semiMinorAxis,i=T(o.granularity,I.RADIANS_PER_DEGREE),r=T(o.vertexFormat,z.DEFAULT);if(H.defined("options.center",e),H.typeOf.number("options.semiMajorAxis",n),H.typeOf.number("options.semiMinorAxis",s),n1;--I){if(y=w.PI_OVER_TWO-(I-1)*P,t=W(-y,_,h,r,M,a,s,u,l,t),i=W(y+Math.PI,_,h,r,M,a,s,u,l,i),O){for(e[o++]=t.x,e[o++]=t.y,e[o++]=t.z,R=2*(I-1)+2,T=1;T0){n=C(n,L.IDENTITY);let t=L.inverseTransformation(n,Y),l=L.multiplyByPoint(t,a.ZERO,W),u=a.normalize(L.multiplyByPointAsVector(t,a.UNIT_Y,v),v),d=b.fromPointNormal(l,u,F),i=a.normalize(L.multiplyByPointAsVector(t,a.UNIT_X,H),H),w=b.fromPointNormal(l,i,j),h=1;o.push(a.clone(r[0]));let f=o[0],y=r.length;for(let g=1;g0&&(Y=!0,E+=m),l1&&(t-=1),t*6<1?r+(o-r)*6*t:t*2<1?o:t*3<2?r+(o-r)*(2/3-t)*6:r}function e(r,o,t,f){this.red=C(r,1),this.green=C(o,1),this.blue=C(t,1),this.alpha=C(f,1)}e.fromCartesian4=function(r,o){return n.typeOf.object("cartesian",r),O(o)?(o.red=r.x,o.green=r.y,o.blue=r.z,o.alpha=r.w,o):new e(r.x,r.y,r.z,r.w)};e.fromBytes=function(r,o,t,f,s){return r=e.byteToFloat(C(r,255)),o=e.byteToFloat(C(o,255)),t=e.byteToFloat(C(t,255)),f=e.byteToFloat(C(f,255)),O(s)?(s.red=r,s.green=o,s.blue=t,s.alpha=f,s):new e(r,o,t,f)};e.fromAlpha=function(r,o,t){return n.typeOf.object("color",r),n.typeOf.number("alpha",o),O(t)?(t.red=r.red,t.green=r.green,t.blue=r.blue,t.alpha=o,t):new e(r.red,r.green,r.blue,o)};var A,g,m;j.supportsTypedArrays()&&(A=new ArrayBuffer(4),g=new Uint32Array(A),m=new Uint8Array(A));e.fromRgba=function(r,o){return g[0]=r,e.fromBytes(m[0],m[1],m[2],m[3],o)};e.fromHsl=function(r,o,t,f,s){r=C(r,0)%1,o=C(o,0),t=C(t,0),f=C(f,1);let c=t,b=t,i=t;if(o!==0){let S;t<.5?S=t*(1+o):S=t+o-t*o;let F=2*t-S;c=l(F,S,r+1/3),b=l(F,S,r),i=l(F,S,r-1/3)}return O(s)?(s.red=c,s.green=b,s.blue=i,s.alpha=f,s):new e(c,b,i,f)};e.fromRandom=function(r,o){r=C(r,C.EMPTY_OBJECT);let t=r.red;if(!O(t)){let b=C(r.minimumRed,0),i=C(r.maximumRed,1);n.typeOf.number.lessThanOrEquals("minimumRed",b,i),t=b+E.nextRandomNumber()*(i-b)}let f=r.green;if(!O(f)){let b=C(r.minimumGreen,0),i=C(r.maximumGreen,1);n.typeOf.number.lessThanOrEquals("minimumGreen",b,i),f=b+E.nextRandomNumber()*(i-b)}let s=r.blue;if(!O(s)){let b=C(r.minimumBlue,0),i=C(r.maximumBlue,1);n.typeOf.number.lessThanOrEquals("minimumBlue",b,i),s=b+E.nextRandomNumber()*(i-b)}let c=r.alpha;if(!O(c)){let b=C(r.minimumAlpha,0),i=C(r.maximumAlpha,1);n.typeOf.number.lessThanOrEquals("minumumAlpha",b,i),c=b+E.nextRandomNumber()*(i-b)}return O(o)?(o.red=t,o.green=f,o.blue=s,o.alpha=c,o):new e(t,f,s,c)};var a=/^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i,z=/^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i,p=/^rgba?\s*\(\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i,R=/^hsla?\s*\(\s*([0-9.]+)\s*[,\s]+\s*([0-9.]+%)\s*[,\s]+\s*([0-9.]+%)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i;e.fromCssColorString=function(r,o){n.typeOf.string("color",r),O(o)||(o=new e),r=r.trim();let t=e[r.toUpperCase()];if(O(t))return e.clone(t,o),o;let f=a.exec(r);return f!==null?(o.red=parseInt(f[1],16)/15,o.green=parseInt(f[2],16)/15,o.blue=parseInt(f[3],16)/15,o.alpha=parseInt(C(f[4],"f"),16)/15,o):(f=z.exec(r),f!==null?(o.red=parseInt(f[1],16)/255,o.green=parseInt(f[2],16)/255,o.blue=parseInt(f[3],16)/255,o.alpha=parseInt(C(f[4],"ff"),16)/255,o):(f=p.exec(r),f!==null?(o.red=parseFloat(f[1])/(f[1].substr(-1)==="%"?100:255),o.green=parseFloat(f[2])/(f[2].substr(-1)==="%"?100:255),o.blue=parseFloat(f[3])/(f[3].substr(-1)==="%"?100:255),o.alpha=parseFloat(C(f[4],"1.0")),o):(f=R.exec(r),f!==null?e.fromHsl(parseFloat(f[1])/360,parseFloat(f[2])/100,parseFloat(f[3])/100,parseFloat(C(f[4],"1.0")),o):(o=void 0,o))))};e.packedLength=4;e.pack=function(r,o,t){return n.typeOf.object("value",r),n.defined("array",o),t=C(t,0),o[t++]=r.red,o[t++]=r.green,o[t++]=r.blue,o[t]=r.alpha,o};e.unpack=function(r,o,t){return n.defined("array",r),o=C(o,0),O(t)||(t=new e),t.red=r[o++],t.green=r[o++],t.blue=r[o++],t.alpha=r[o],t};e.byteToFloat=function(r){return r/255};e.floatToByte=function(r){return r===1?255:r*256|0};e.clone=function(r,o){if(O(r))return O(o)?(o.red=r.red,o.green=r.green,o.blue=r.blue,o.alpha=r.alpha,o):new e(r.red,r.green,r.blue,r.alpha)};e.equals=function(r,o){return r===o||O(r)&&O(o)&&r.red===o.red&&r.green===o.green&&r.blue===o.blue&&r.alpha===o.alpha};e.equalsArray=function(r,o,t){return r.red===o[t]&&r.green===o[t+1]&&r.blue===o[t+2]&&r.alpha===o[t+3]};e.prototype.clone=function(r){return e.clone(this,r)};e.prototype.equals=function(r){return e.equals(this,r)};e.prototype.equalsEpsilon=function(r,o){return this===r||O(r)&&Math.abs(this.red-r.red)<=o&&Math.abs(this.green-r.green)<=o&&Math.abs(this.blue-r.blue)<=o&&Math.abs(this.alpha-r.alpha)<=o};e.prototype.toString=function(){return`(${this.red}, ${this.green}, ${this.blue}, ${this.alpha})`};e.prototype.toCssColorString=function(){let r=e.floatToByte(this.red),o=e.floatToByte(this.green),t=e.floatToByte(this.blue);return this.alpha===1?`rgb(${r},${o},${t})`:`rgba(${r},${o},${t},${this.alpha})`};e.prototype.toCssHexString=function(){let r=e.floatToByte(this.red).toString(16);r.length<2&&(r=`0${r}`);let o=e.floatToByte(this.green).toString(16);o.length<2&&(o=`0${o}`);let t=e.floatToByte(this.blue).toString(16);if(t.length<2&&(t=`0${t}`),this.alpha<1){let f=e.floatToByte(this.alpha).toString(16);return f.length<2&&(f=`0${f}`),`#${r}${o}${t}${f}`}return`#${r}${o}${t}`};e.prototype.toBytes=function(r){let o=e.floatToByte(this.red),t=e.floatToByte(this.green),f=e.floatToByte(this.blue),s=e.floatToByte(this.alpha);return O(r)?(r[0]=o,r[1]=t,r[2]=f,r[3]=s,r):[o,t,f,s]};e.prototype.toRgba=function(){return m[0]=e.floatToByte(this.red),m[1]=e.floatToByte(this.green),m[2]=e.floatToByte(this.blue),m[3]=e.floatToByte(this.alpha),g[0]};e.prototype.brighten=function(r,o){return n.typeOf.number("magnitude",r),n.typeOf.number.greaterThanOrEquals("magnitude",r,0),n.typeOf.object("result",o),r=1-r,o.red=1-(1-this.red)*r,o.green=1-(1-this.green)*r,o.blue=1-(1-this.blue)*r,o.alpha=this.alpha,o};e.prototype.darken=function(r,o){return n.typeOf.number("magnitude",r),n.typeOf.number.greaterThanOrEquals("magnitude",r,0),n.typeOf.object("result",o),r=1-r,o.red=this.red*r,o.green=this.green*r,o.blue=this.blue*r,o.alpha=this.alpha,o};e.prototype.withAlpha=function(r,o){return e.fromAlpha(this,r,o)};e.add=function(r,o,t){return n.typeOf.object("left",r),n.typeOf.object("right",o),n.typeOf.object("result",t),t.red=r.red+o.red,t.green=r.green+o.green,t.blue=r.blue+o.blue,t.alpha=r.alpha+o.alpha,t};e.subtract=function(r,o,t){return n.typeOf.object("left",r),n.typeOf.object("right",o),n.typeOf.object("result",t),t.red=r.red-o.red,t.green=r.green-o.green,t.blue=r.blue-o.blue,t.alpha=r.alpha-o.alpha,t};e.multiply=function(r,o,t){return n.typeOf.object("left",r),n.typeOf.object("right",o),n.typeOf.object("result",t),t.red=r.red*o.red,t.green=r.green*o.green,t.blue=r.blue*o.blue,t.alpha=r.alpha*o.alpha,t};e.divide=function(r,o,t){return n.typeOf.object("left",r),n.typeOf.object("right",o),n.typeOf.object("result",t),t.red=r.red/o.red,t.green=r.green/o.green,t.blue=r.blue/o.blue,t.alpha=r.alpha/o.alpha,t};e.mod=function(r,o,t){return n.typeOf.object("left",r),n.typeOf.object("right",o),n.typeOf.object("result",t),t.red=r.red%o.red,t.green=r.green%o.green,t.blue=r.blue%o.blue,t.alpha=r.alpha%o.alpha,t};e.lerp=function(r,o,t,f){return n.typeOf.object("start",r),n.typeOf.object("end",o),n.typeOf.number("t",t),n.typeOf.object("result",f),f.red=E.lerp(r.red,o.red,t),f.green=E.lerp(r.green,o.green,t),f.blue=E.lerp(r.blue,o.blue,t),f.alpha=E.lerp(r.alpha,o.alpha,t),f};e.multiplyByScalar=function(r,o,t){return n.typeOf.object("color",r),n.typeOf.number("scalar",o),n.typeOf.object("result",t),t.red=r.red*o,t.green=r.green*o,t.blue=r.blue*o,t.alpha=r.alpha*o,t};e.divideByScalar=function(r,o,t){return n.typeOf.object("color",r),n.typeOf.number("scalar",o),n.typeOf.object("result",t),t.red=r.red/o,t.green=r.green/o,t.blue=r.blue/o,t.alpha=r.alpha/o,t};e.ALICEBLUE=Object.freeze(e.fromCssColorString("#F0F8FF"));e.ANTIQUEWHITE=Object.freeze(e.fromCssColorString("#FAEBD7"));e.AQUA=Object.freeze(e.fromCssColorString("#00FFFF"));e.AQUAMARINE=Object.freeze(e.fromCssColorString("#7FFFD4"));e.AZURE=Object.freeze(e.fromCssColorString("#F0FFFF"));e.BEIGE=Object.freeze(e.fromCssColorString("#F5F5DC"));e.BISQUE=Object.freeze(e.fromCssColorString("#FFE4C4"));e.BLACK=Object.freeze(e.fromCssColorString("#000000"));e.BLANCHEDALMOND=Object.freeze(e.fromCssColorString("#FFEBCD"));e.BLUE=Object.freeze(e.fromCssColorString("#0000FF"));e.BLUEVIOLET=Object.freeze(e.fromCssColorString("#8A2BE2"));e.BROWN=Object.freeze(e.fromCssColorString("#A52A2A"));e.BURLYWOOD=Object.freeze(e.fromCssColorString("#DEB887"));e.CADETBLUE=Object.freeze(e.fromCssColorString("#5F9EA0"));e.CHARTREUSE=Object.freeze(e.fromCssColorString("#7FFF00"));e.CHOCOLATE=Object.freeze(e.fromCssColorString("#D2691E"));e.CORAL=Object.freeze(e.fromCssColorString("#FF7F50"));e.CORNFLOWERBLUE=Object.freeze(e.fromCssColorString("#6495ED"));e.CORNSILK=Object.freeze(e.fromCssColorString("#FFF8DC"));e.CRIMSON=Object.freeze(e.fromCssColorString("#DC143C"));e.CYAN=Object.freeze(e.fromCssColorString("#00FFFF"));e.DARKBLUE=Object.freeze(e.fromCssColorString("#00008B"));e.DARKCYAN=Object.freeze(e.fromCssColorString("#008B8B"));e.DARKGOLDENROD=Object.freeze(e.fromCssColorString("#B8860B"));e.DARKGRAY=Object.freeze(e.fromCssColorString("#A9A9A9"));e.DARKGREEN=Object.freeze(e.fromCssColorString("#006400"));e.DARKGREY=e.DARKGRAY;e.DARKKHAKI=Object.freeze(e.fromCssColorString("#BDB76B"));e.DARKMAGENTA=Object.freeze(e.fromCssColorString("#8B008B"));e.DARKOLIVEGREEN=Object.freeze(e.fromCssColorString("#556B2F"));e.DARKORANGE=Object.freeze(e.fromCssColorString("#FF8C00"));e.DARKORCHID=Object.freeze(e.fromCssColorString("#9932CC"));e.DARKRED=Object.freeze(e.fromCssColorString("#8B0000"));e.DARKSALMON=Object.freeze(e.fromCssColorString("#E9967A"));e.DARKSEAGREEN=Object.freeze(e.fromCssColorString("#8FBC8F"));e.DARKSLATEBLUE=Object.freeze(e.fromCssColorString("#483D8B"));e.DARKSLATEGRAY=Object.freeze(e.fromCssColorString("#2F4F4F"));e.DARKSLATEGREY=e.DARKSLATEGRAY;e.DARKTURQUOISE=Object.freeze(e.fromCssColorString("#00CED1"));e.DARKVIOLET=Object.freeze(e.fromCssColorString("#9400D3"));e.DEEPPINK=Object.freeze(e.fromCssColorString("#FF1493"));e.DEEPSKYBLUE=Object.freeze(e.fromCssColorString("#00BFFF"));e.DIMGRAY=Object.freeze(e.fromCssColorString("#696969"));e.DIMGREY=e.DIMGRAY;e.DODGERBLUE=Object.freeze(e.fromCssColorString("#1E90FF"));e.FIREBRICK=Object.freeze(e.fromCssColorString("#B22222"));e.FLORALWHITE=Object.freeze(e.fromCssColorString("#FFFAF0"));e.FORESTGREEN=Object.freeze(e.fromCssColorString("#228B22"));e.FUCHSIA=Object.freeze(e.fromCssColorString("#FF00FF"));e.GAINSBORO=Object.freeze(e.fromCssColorString("#DCDCDC"));e.GHOSTWHITE=Object.freeze(e.fromCssColorString("#F8F8FF"));e.GOLD=Object.freeze(e.fromCssColorString("#FFD700"));e.GOLDENROD=Object.freeze(e.fromCssColorString("#DAA520"));e.GRAY=Object.freeze(e.fromCssColorString("#808080"));e.GREEN=Object.freeze(e.fromCssColorString("#008000"));e.GREENYELLOW=Object.freeze(e.fromCssColorString("#ADFF2F"));e.GREY=e.GRAY;e.HONEYDEW=Object.freeze(e.fromCssColorString("#F0FFF0"));e.HOTPINK=Object.freeze(e.fromCssColorString("#FF69B4"));e.INDIANRED=Object.freeze(e.fromCssColorString("#CD5C5C"));e.INDIGO=Object.freeze(e.fromCssColorString("#4B0082"));e.IVORY=Object.freeze(e.fromCssColorString("#FFFFF0"));e.KHAKI=Object.freeze(e.fromCssColorString("#F0E68C"));e.LAVENDER=Object.freeze(e.fromCssColorString("#E6E6FA"));e.LAVENDAR_BLUSH=Object.freeze(e.fromCssColorString("#FFF0F5"));e.LAWNGREEN=Object.freeze(e.fromCssColorString("#7CFC00"));e.LEMONCHIFFON=Object.freeze(e.fromCssColorString("#FFFACD"));e.LIGHTBLUE=Object.freeze(e.fromCssColorString("#ADD8E6"));e.LIGHTCORAL=Object.freeze(e.fromCssColorString("#F08080"));e.LIGHTCYAN=Object.freeze(e.fromCssColorString("#E0FFFF"));e.LIGHTGOLDENRODYELLOW=Object.freeze(e.fromCssColorString("#FAFAD2"));e.LIGHTGRAY=Object.freeze(e.fromCssColorString("#D3D3D3"));e.LIGHTGREEN=Object.freeze(e.fromCssColorString("#90EE90"));e.LIGHTGREY=e.LIGHTGRAY;e.LIGHTPINK=Object.freeze(e.fromCssColorString("#FFB6C1"));e.LIGHTSEAGREEN=Object.freeze(e.fromCssColorString("#20B2AA"));e.LIGHTSKYBLUE=Object.freeze(e.fromCssColorString("#87CEFA"));e.LIGHTSLATEGRAY=Object.freeze(e.fromCssColorString("#778899"));e.LIGHTSLATEGREY=e.LIGHTSLATEGRAY;e.LIGHTSTEELBLUE=Object.freeze(e.fromCssColorString("#B0C4DE"));e.LIGHTYELLOW=Object.freeze(e.fromCssColorString("#FFFFE0"));e.LIME=Object.freeze(e.fromCssColorString("#00FF00"));e.LIMEGREEN=Object.freeze(e.fromCssColorString("#32CD32"));e.LINEN=Object.freeze(e.fromCssColorString("#FAF0E6"));e.MAGENTA=Object.freeze(e.fromCssColorString("#FF00FF"));e.MAROON=Object.freeze(e.fromCssColorString("#800000"));e.MEDIUMAQUAMARINE=Object.freeze(e.fromCssColorString("#66CDAA"));e.MEDIUMBLUE=Object.freeze(e.fromCssColorString("#0000CD"));e.MEDIUMORCHID=Object.freeze(e.fromCssColorString("#BA55D3"));e.MEDIUMPURPLE=Object.freeze(e.fromCssColorString("#9370DB"));e.MEDIUMSEAGREEN=Object.freeze(e.fromCssColorString("#3CB371"));e.MEDIUMSLATEBLUE=Object.freeze(e.fromCssColorString("#7B68EE"));e.MEDIUMSPRINGGREEN=Object.freeze(e.fromCssColorString("#00FA9A"));e.MEDIUMTURQUOISE=Object.freeze(e.fromCssColorString("#48D1CC"));e.MEDIUMVIOLETRED=Object.freeze(e.fromCssColorString("#C71585"));e.MIDNIGHTBLUE=Object.freeze(e.fromCssColorString("#191970"));e.MINTCREAM=Object.freeze(e.fromCssColorString("#F5FFFA"));e.MISTYROSE=Object.freeze(e.fromCssColorString("#FFE4E1"));e.MOCCASIN=Object.freeze(e.fromCssColorString("#FFE4B5"));e.NAVAJOWHITE=Object.freeze(e.fromCssColorString("#FFDEAD"));e.NAVY=Object.freeze(e.fromCssColorString("#000080"));e.OLDLACE=Object.freeze(e.fromCssColorString("#FDF5E6"));e.OLIVE=Object.freeze(e.fromCssColorString("#808000"));e.OLIVEDRAB=Object.freeze(e.fromCssColorString("#6B8E23"));e.ORANGE=Object.freeze(e.fromCssColorString("#FFA500"));e.ORANGERED=Object.freeze(e.fromCssColorString("#FF4500"));e.ORCHID=Object.freeze(e.fromCssColorString("#DA70D6"));e.PALEGOLDENROD=Object.freeze(e.fromCssColorString("#EEE8AA"));e.PALEGREEN=Object.freeze(e.fromCssColorString("#98FB98"));e.PALETURQUOISE=Object.freeze(e.fromCssColorString("#AFEEEE"));e.PALEVIOLETRED=Object.freeze(e.fromCssColorString("#DB7093"));e.PAPAYAWHIP=Object.freeze(e.fromCssColorString("#FFEFD5"));e.PEACHPUFF=Object.freeze(e.fromCssColorString("#FFDAB9"));e.PERU=Object.freeze(e.fromCssColorString("#CD853F"));e.PINK=Object.freeze(e.fromCssColorString("#FFC0CB"));e.PLUM=Object.freeze(e.fromCssColorString("#DDA0DD"));e.POWDERBLUE=Object.freeze(e.fromCssColorString("#B0E0E6"));e.PURPLE=Object.freeze(e.fromCssColorString("#800080"));e.RED=Object.freeze(e.fromCssColorString("#FF0000"));e.ROSYBROWN=Object.freeze(e.fromCssColorString("#BC8F8F"));e.ROYALBLUE=Object.freeze(e.fromCssColorString("#4169E1"));e.SADDLEBROWN=Object.freeze(e.fromCssColorString("#8B4513"));e.SALMON=Object.freeze(e.fromCssColorString("#FA8072"));e.SANDYBROWN=Object.freeze(e.fromCssColorString("#F4A460"));e.SEAGREEN=Object.freeze(e.fromCssColorString("#2E8B57"));e.SEASHELL=Object.freeze(e.fromCssColorString("#FFF5EE"));e.SIENNA=Object.freeze(e.fromCssColorString("#A0522D"));e.SILVER=Object.freeze(e.fromCssColorString("#C0C0C0"));e.SKYBLUE=Object.freeze(e.fromCssColorString("#87CEEB"));e.SLATEBLUE=Object.freeze(e.fromCssColorString("#6A5ACD"));e.SLATEGRAY=Object.freeze(e.fromCssColorString("#708090"));e.SLATEGREY=e.SLATEGRAY;e.SNOW=Object.freeze(e.fromCssColorString("#FFFAFA"));e.SPRINGGREEN=Object.freeze(e.fromCssColorString("#00FF7F"));e.STEELBLUE=Object.freeze(e.fromCssColorString("#4682B4"));e.TAN=Object.freeze(e.fromCssColorString("#D2B48C"));e.TEAL=Object.freeze(e.fromCssColorString("#008080"));e.THISTLE=Object.freeze(e.fromCssColorString("#D8BFD8"));e.TOMATO=Object.freeze(e.fromCssColorString("#FF6347"));e.TURQUOISE=Object.freeze(e.fromCssColorString("#40E0D0"));e.VIOLET=Object.freeze(e.fromCssColorString("#EE82EE"));e.WHEAT=Object.freeze(e.fromCssColorString("#F5DEB3"));e.WHITE=Object.freeze(e.fromCssColorString("#FFFFFF"));e.WHITESMOKE=Object.freeze(e.fromCssColorString("#F5F5F5"));e.YELLOW=Object.freeze(e.fromCssColorString("#FFFF00"));e.YELLOWGREEN=Object.freeze(e.fromCssColorString("#9ACD32"));e.TRANSPARENT=Object.freeze(new e(0,0,0,0));var h=e;export{h as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-Y5NK5HSS.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-Y5NK5HSS.js new file mode 100644 index 0000000000000000000000000000000000000000..8a05e1a81a08374d526e6ff5a5d2782c5ea1586d --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-Y5NK5HSS.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as p,b as P,c as q}from"./chunk-C6Y3PRDH.js";import{a}from"./chunk-LI57NJAL.js";import{a as T}from"./chunk-P44SUSQU.js";import{a as S,b as g}from"./chunk-FUATUYJ3.js";import{e as l}from"./chunk-ODUTJJQ5.js";function y(n,i,o){if(n===0)return i*o;let t=n*n,e=t*t,c=e*t,r=c*t,h=r*t,s=h*t,d=o,u=Math.sin(2*d),f=Math.sin(4*d),M=Math.sin(6*d),_=Math.sin(8*d),E=Math.sin(10*d),I=Math.sin(12*d);return i*((1-t/4-3*e/64-5*c/256-175*r/16384-441*h/65536-4851*s/1048576)*d-(3*t/8+3*e/32+45*c/1024+105*r/4096+2205*h/131072+6237*s/524288)*u+(15*e/256+45*c/1024+525*r/16384+1575*h/65536+155925*s/8388608)*f-(35*c/3072+175*r/12288+3675*h/262144+13475*s/1048576)*M+(315*r/131072+2205*h/524288+43659*s/8388608)*_-(693*h/1310720+6237*s/5242880)*E+1001*s/8388608*I)}function z(n,i,o){let t=n/o;if(i===0)return t;let e=t*t,c=e*t,r=c*t,h=i,s=h*h,d=s*s,u=d*s,f=u*s,M=f*s,_=M*s,E=Math.sin(2*t),I=Math.cos(2*t),v=Math.sin(4*t),V=Math.cos(4*t),C=Math.sin(6*t),R=Math.cos(6*t),N=Math.sin(8*t),x=Math.cos(8*t),b=Math.sin(10*t),U=Math.cos(10*t),H=Math.sin(12*t);return t+t*s/4+7*t*d/64+15*t*u/256+579*t*f/16384+1515*t*M/65536+16837*t*_/1048576+(3*t*d/16+45*t*u/256-t*(32*e-561)*f/4096-t*(232*e-1677)*M/16384+t*(399985-90560*e+512*r)*_/5242880)*I+(21*t*u/256+483*t*f/4096-t*(224*e-1969)*M/16384-t*(33152*e-112599)*_/1048576)*V+(151*t*f/4096+4681*t*M/65536+1479*t*_/16384-453*c*_/32768)*R+(1097*t*M/65536+42783*t*_/1048576)*x+8011*t*_/1048576*U+(3*s/8+3*d/16+213*u/2048-3*e*u/64+255*f/4096-33*e*f/512+20861*M/524288-33*e*M/512+r*M/1024+28273*_/1048576-471*e*_/8192+9*r*_/4096)*E+(21*d/256+21*u/256+533*f/8192-21*e*f/512+197*M/4096-315*e*M/4096+584039*_/16777216-12517*e*_/131072+7*r*_/2048)*v+(151*u/6144+151*f/4096+5019*M/131072-453*e*M/16384+26965*_/786432-8607*e*_/131072)*C+(1097*f/131072+1097*M/65536+225797*_/10485760-1097*e*_/65536)*N+(8011*M/2621440+8011*_/1048576)*b+293393*_/251658240*H}function O(n,i){if(n===0)return Math.log(Math.tan(.5*(a.PI_OVER_TWO+i)));let o=n*Math.sin(i);return Math.log(Math.tan(.5*(a.PI_OVER_TWO+i)))-n/2*Math.log((1+o)/(1-o))}function G(n,i,o,t,e){let c=O(n._ellipticity,o),r=O(n._ellipticity,e);return Math.atan2(a.negativePiToPi(t-i),r-c)}function k(n,i,o,t,e,c,r){let h=n._heading,s=c-t,d=0;if(a.equalsEpsilon(Math.abs(h),a.PI_OVER_TWO,a.EPSILON8))if(i===o)d=i*Math.cos(e)*a.negativePiToPi(s);else{let u=Math.sin(e);d=i*Math.cos(e)*a.negativePiToPi(s)/Math.sqrt(1-n._ellipticitySquared*u*u)}else{let u=y(n._ellipticity,i,e);d=(y(n._ellipticity,i,r)-u)/Math.cos(h)}return Math.abs(d)}var A=new p,w=new p;function D(n,i,o,t){let e=p.normalize(t.cartographicToCartesian(i,w),A),c=p.normalize(t.cartographicToCartesian(o,w),w);g.typeOf.number.greaterThanOrEquals("value",Math.abs(Math.abs(p.angleBetween(e,c))-Math.PI),.0125);let r=t.maximumRadius,h=t.minimumRadius,s=r*r,d=h*h;n._ellipticitySquared=(s-d)/s,n._ellipticity=Math.sqrt(n._ellipticitySquared),n._start=P.clone(i,n._start),n._start.height=0,n._end=P.clone(o,n._end),n._end.height=0,n._heading=G(n,i.longitude,i.latitude,o.longitude,o.latitude),n._distance=k(n,t.maximumRadius,t.minimumRadius,i.longitude,i.latitude,o.longitude,o.latitude)}function W(n,i,o,t,e,c){if(o===0)return P.clone(n,c);let r=e*e,h,s,d;if(Math.abs(a.PI_OVER_TWO-Math.abs(i))>a.EPSILON8){let u=y(e,t,n.latitude),f=o*Math.cos(i),M=u+f;s=z(M,e,t);let _=O(e,n.latitude),E=O(e,s);d=Math.tan(i)*(E-_),h=a.negativePiToPi(n.longitude+d)}else{s=n.latitude;let u;if(e===0)u=t*Math.cos(n.latitude);else{let f=Math.sin(n.latitude);u=t*Math.cos(n.latitude)/Math.sqrt(1-r*f*f)}d=o/u,i>0?h=a.negativePiToPi(n.longitude+d):h=a.negativePiToPi(n.longitude-d)}return l(c)?(c.longitude=h,c.latitude=s,c.height=0,c):new P(h,s,0)}function m(n,i,o){let t=T(o,q.WGS84);this._ellipsoid=t,this._start=new P,this._end=new P,this._heading=void 0,this._distance=void 0,this._ellipticity=void 0,this._ellipticitySquared=void 0,l(n)&&l(i)&&D(this,n,i,t)}Object.defineProperties(m.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},surfaceDistance:{get:function(){return g.defined("distance",this._distance),this._distance}},start:{get:function(){return this._start}},end:{get:function(){return this._end}},heading:{get:function(){return g.defined("distance",this._distance),this._heading}}});m.fromStartHeadingDistance=function(n,i,o,t,e){g.defined("start",n),g.defined("heading",i),g.defined("distance",o),g.typeOf.number.greaterThan("distance",o,0);let c=T(t,q.WGS84),r=c.maximumRadius,h=c.minimumRadius,s=r*r,d=h*h,u=Math.sqrt((s-d)/s);i=a.negativePiToPi(i);let f=W(n,i,o,c.maximumRadius,u);return!l(e)||l(t)&&!t.equals(e.ellipsoid)?new m(n,f,c):(e.setEndPoints(n,f),e)};m.prototype.setEndPoints=function(n,i){g.defined("start",n),g.defined("end",i),D(this,n,i,this._ellipsoid)};m.prototype.interpolateUsingFraction=function(n,i){return this.interpolateUsingSurfaceDistance(n*this._distance,i)};m.prototype.interpolateUsingSurfaceDistance=function(n,i){if(g.typeOf.number("distance",n),!l(this._distance)||this._distance===0)throw new S("EllipsoidRhumbLine must have distinct start and end set.");return W(this._start,this._heading,n,this._ellipsoid.maximumRadius,this._ellipticity,i)};m.prototype.findIntersectionWithLongitude=function(n,i){if(g.typeOf.number("intersectionLongitude",n),!l(this._distance)||this._distance===0)throw new S("EllipsoidRhumbLine must have distinct start and end set.");let o=this._ellipticity,t=this._heading,e=Math.abs(t),c=this._start;if(n=a.negativePiToPi(n),a.equalsEpsilon(Math.abs(n),Math.PI,a.EPSILON14)&&(n=a.sign(c.longitude)*Math.PI),l(i)||(i=new P),Math.abs(a.PI_OVER_TWO-e)<=a.EPSILON8)return i.longitude=n,i.latitude=c.latitude,i.height=0,i;if(a.equalsEpsilon(Math.abs(a.PI_OVER_TWO-e),a.PI_OVER_TWO,a.EPSILON8))return a.equalsEpsilon(n,c.longitude,a.EPSILON12)?void 0:(i.longitude=n,i.latitude=a.PI_OVER_TWO*a.sign(a.PI_OVER_TWO-t),i.height=0,i);let r=c.latitude,h=o*Math.sin(r),s=Math.tan(.5*(a.PI_OVER_TWO+r))*Math.exp((n-c.longitude)/Math.tan(t)),d=(1+h)/(1-h),u=c.latitude,f;do{f=u;let M=o*Math.sin(f),_=(1+M)/(1-M);u=2*Math.atan(s*Math.pow(_/d,o/2))-a.PI_OVER_TWO}while(!a.equalsEpsilon(u,f,a.EPSILON12));return i.longitude=n,i.latitude=u,i.height=0,i};m.prototype.findIntersectionWithLatitude=function(n,i){if(g.typeOf.number("intersectionLatitude",n),!l(this._distance)||this._distance===0)throw new S("EllipsoidRhumbLine must have distinct start and end set.");let o=this._ellipticity,t=this._heading,e=this._start;if(a.equalsEpsilon(Math.abs(t),a.PI_OVER_TWO,a.EPSILON8))return;let c=O(o,e.latitude),r=O(o,n),h=Math.tan(t)*(r-c),s=a.negativePiToPi(e.longitude+h);return l(i)?(i.longitude=s,i.latitude=n,i.height=0,i):new P(s,n,0)};var $=m;export{$ as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-YTG33ZHK.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-YTG33ZHK.js new file mode 100644 index 0000000000000000000000000000000000000000..4a3a64b4668c503dc056b553fb6c0ef3370f44a3 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-YTG33ZHK.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as P}from"./chunk-LLBHZLGF.js";import{a as j,b as d}from"./chunk-YYMHH3T4.js";import{a as O}from"./chunk-ATQXFTWF.js";import{i as u}from"./chunk-NNIY7VTE.js";import{a as A,b as m,d as l}from"./chunk-5EDTRNG5.js";import{a as e,c as _}from"./chunk-C6Y3PRDH.js";import{a as g}from"./chunk-P44SUSQU.js";import{a as y,b as p}from"./chunk-FUATUYJ3.js";import{e as r}from"./chunk-ODUTJJQ5.js";var x=new A;function s(n,t){if(p.defined("origin",n),t=g(t,_.WGS84),n=t.scaleToGeodeticSurface(n),!r(n))throw new y("origin must not be at the center of the ellipsoid.");let o=u.eastNorthUpToFixedFrame(n,t);this._ellipsoid=t,this._origin=n,this._xAxis=e.fromCartesian4(m.getColumn(o,0,x)),this._yAxis=e.fromCartesian4(m.getColumn(o,1,x));let i=e.fromCartesian4(m.getColumn(o,2,x));this._plane=O.fromPointNormal(n,i)}Object.defineProperties(s.prototype,{ellipsoid:{get:function(){return this._ellipsoid}},origin:{get:function(){return this._origin}},plane:{get:function(){return this._plane}},xAxis:{get:function(){return this._xAxis}},yAxis:{get:function(){return this._yAxis}},zAxis:{get:function(){return this._plane.normal}}});var C=new P;s.fromPoints=function(n,t){p.defined("cartesians",n);let o=P.fromPoints(n,C);return new s(o.center,t)};var w=new j,h=new e;s.prototype.projectPointOntoPlane=function(n,t){p.defined("cartesian",n);let o=w;o.origin=n,e.normalize(n,o.direction);let i=d.rayPlane(o,this._plane,h);if(r(i)||(e.negate(o.direction,o.direction),i=d.rayPlane(o,this._plane,h)),r(i)){let c=e.subtract(i,this._origin,i),a=e.dot(this._xAxis,c),f=e.dot(this._yAxis,c);return r(t)?(t.x=a,t.y=f,t):new l(a,f)}};s.prototype.projectPointsOntoPlane=function(n,t){p.defined("cartesians",n),r(t)||(t=[]);let o=0,i=n.length;for(let c=0;cf&&f/a0?[u/t,r/u]:[r/u,u/t]};var T=nt;var ot={};ot.computeDiscriminant=function(t,e,r,n){if(typeof t!="number")throw new w("a is a required number.");if(typeof e!="number")throw new w("b is a required number.");if(typeof r!="number")throw new w("c is a required number.");if(typeof n!="number")throw new w("d is a required number.");let i=t*t,c=e*e,s=r*r,u=n*n;return 18*t*e*r*n+c*s-27*i*u-4*(t*s*r+c*e*n)};function rt(t,e,r,n){let i=t,c=e/3,s=r/3,u=n,a=i*s,f=c*u,l=c*c,d=s*s,p=i*s-l,q=i*u-c*s,m=c*u-d,h=4*p*m-q*q,C,D;if(h<0){let X,k,G;l*f>=a*d?(X=i,k=p,G=-2*c*p+i*q):(X=u,k=m,G=-u*q+2*s*m);let at=-(G<0?-1:1)*Math.abs(X)*Math.sqrt(-h);D=-G+at;let $=D/2,j=$<0?-Math.pow(-$,1/3):Math.pow($,1/3),tt=D===at?-j:-k/j;return C=k<=0?j+tt:-G/(j*j+tt*tt+k),l*f>=a*d?[(C-c)/i]:[-u/(C+s)]}let W=p,V=-2*c*p+i*q,L=m,B=-u*q+2*s*m,I=Math.sqrt(h),E=Math.sqrt(3)/2,P=Math.abs(Math.atan2(i*I,-V)/3);C=2*Math.sqrt(-W);let y=Math.cos(P);D=C*y;let S=C*(-y/2-E*Math.sin(P)),M=D+S>2*c?D-c:S-c,N=i,x=M/N;P=Math.abs(Math.atan2(u*I,-B)/3),C=2*Math.sqrt(-L),y=Math.cos(P),D=C*y,S=C*(-y/2-E*Math.sin(P));let _=-u,A=D+S<2*s?D+s:S+s,v=_/A,yt=N*A,ut=-M*A-N*_,bt=M*_,U=(s*ut-c*bt)/(-c*ut+s*yt);return x<=U?x<=v?U<=v?[x,U,v]:[x,v,U]:[v,x,U]:x<=v?[U,x,v]:U<=v?[U,v,x]:[v,U,x]}ot.computeRealRoots=function(t,e,r,n){if(typeof t!="number")throw new w("a is a required number.");if(typeof e!="number")throw new w("b is a required number.");if(typeof r!="number")throw new w("c is a required number.");if(typeof n!="number")throw new w("d is a required number.");let i,c;if(t===0)return T.computeRealRoots(e,r,n);if(e===0){if(r===0){if(n===0)return[0,0,0];c=-n/t;let s=c<0?-Math.pow(-c,1/3):Math.pow(c,1/3);return[s,s,s]}else if(n===0)return i=T.computeRealRoots(t,0,r),i.Length===0?[0]:[i[0],0,i[1]];return rt(t,0,r,n)}else{if(r===0)return n===0?(c=-e/t,c<0?[c,0,0]:[0,0,c]):rt(t,e,0,n);if(n===0)return i=T.computeRealRoots(t,e,r),i.length===0?[0]:i[1]<=0?[i[0],i[1],0]:i[0]>=0?[0,i[0],i[1]]:[i[0],0,i[1]]}return rt(t,e,r,n)};var F=ot;var it={};it.computeDiscriminant=function(t,e,r,n,i){if(typeof t!="number")throw new w("a is a required number.");if(typeof e!="number")throw new w("b is a required number.");if(typeof r!="number")throw new w("c is a required number.");if(typeof n!="number")throw new w("d is a required number.");if(typeof i!="number")throw new w("e is a required number.");let c=t*t,s=c*t,u=e*e,a=u*e,f=r*r,l=f*r,d=n*n,p=d*n,q=i*i,m=q*i;return u*f*d-4*a*p-4*t*l*d+18*t*e*r*p-27*c*d*d+256*s*m+i*(18*a*r*n-4*u*l+16*t*f*f-80*t*e*f*n-6*t*u*d+144*c*r*d)+q*(144*t*u*r-27*u*u-128*c*f-192*c*e*n)};function z(t,e,r,n){let i=t*t,c=e-3*i/8,s=r-e*t/2+i*t/8,u=n-r*t/4+e*i/16-3*i*i/256,a=F.computeRealRoots(1,2*c,c*c-4*u,-s*s);if(a.length>0){let f=-t/4,l=a[a.length-1];if(Math.abs(l)=0&&q>=0){let h=Math.sqrt(p),C=Math.sqrt(q);return[f-C,f-h,f+h,f+C]}else{if(p>=0&&q<0)return m=Math.sqrt(p),[f-m,f+m];if(p<0&&q>=0)return m=Math.sqrt(q),[f-m,f+m]}}return[]}else if(l>0){let d=Math.sqrt(l),p=(c+l-s/d)/2,q=(c+l+s/d)/2,m=T.computeRealRoots(1,d,p),h=T.computeRealRoots(1,-d,q);return m.length!==0?(m[0]+=f,m[1]+=f,h.length!==0?(h[0]+=f,h[1]+=f,m[1]<=h[0]?[m[0],m[1],h[0],h[1]]:h[1]<=m[0]?[h[0],h[1],m[0],m[1]]:m[0]>=h[0]&&m[1]<=h[1]?[h[0],m[0],m[1],h[1]]:h[0]>=m[0]&&h[1]<=m[1]?[m[0],h[0],h[1],m[1]]:m[0]>h[0]&&m[0]0){let d=l[0],p=e-d,q=p*p,m=t/2,h=p/2,C=q-4*n,D=q+4*Math.abs(n),W=s-4*d,V=s+4*Math.abs(d),L,B;if(d<0||C*V=M[0]&&S[1]<=M[1]?[M[0],S[0],S[1],M[1]]:M[0]>=S[0]&&M[1]<=S[1]?[S[0],M[0],M[1],S[1]]:S[0]>M[0]&&S[0]l)||(p=o.cross(d,u,ht),m=o.dot(s,p),m<0||q+m>l))return;h=o.dot(a,p)/l}else{if(Math.abs(l)1||(p=o.cross(d,u,ht),m=o.dot(s,p)*C,m<0||q+m>1))return;h=o.dot(a,p)*C}return h};O.rayTriangle=function(t,e,r,n,i,c){let s=O.rayTriangleParametric(t,e,r,n,i);if(!(!g(s)||s<0))return g(c)||(c=new o),o.multiplyByScalar(t.direction,s,c),o.add(t.origin,c,c)};var Ct=new st;O.lineSegmentTriangle=function(t,e,r,n,i,c,s){if(!g(t))throw new w("v0 is required.");if(!g(e))throw new w("v1 is required.");if(!g(r))throw new w("p0 is required.");if(!g(n))throw new w("p1 is required.");if(!g(i))throw new w("p2 is required.");let u=Ct;o.clone(t,u.origin),o.subtract(e,t,u.direction),o.normalize(u.direction,u.direction);let a=O.rayTriangleParametric(u,r,n,i,c);if(!(!g(a)||a<0||a>o.distance(t,e)))return g(s)||(s=new o),o.multiplyByScalar(u.direction,a,s),o.add(u.origin,s,s)};function Et(t,e,r,n){let i=e*e-4*t*r;if(i<0)return;if(i>0){let s=1/(2*t),u=Math.sqrt(i),a=(-e+u)*s,f=(-e-u)*s;return as))return n.start=Math.max(n.start,0),n.stop=Math.min(n.stop,s),n};var It=new o,Dt=new o;O.rayEllipsoid=function(t,e){if(!g(t))throw new w("ray is required.");if(!g(e))throw new w("ellipsoid is required.");let r=e.oneOverRadii,n=o.multiplyComponents(r,t.origin,It),i=o.multiplyComponents(r,t.direction,Dt),c=o.magnitudeSquared(n),s=o.dot(n,i),u,a,f,l,d;if(c>1){if(s>=0)return;let p=s*s;if(u=c-1,a=o.magnitudeSquared(i),f=a*u,pf){l=s*s-f,d=-s+Math.sqrt(l);let m=d/a,h=u/d;return m0?q.push(new o(n,i*y,i*-N)):N!==0?(q.push(new o(n,i*y,i*-N)),q.push(new o(n,i*y,i*N)),++P):q.push(new o(n,i*y,i*N))}return q}var ct=new o,wt=new o,qt=new o,K=new o,xt=new o,Tt=new b,zt=new b,Wt=new b,Vt=new b,vt=new b,gt=new b,pt=new b,St=new o,Ut=new o,Qt=new ft;O.grazingAltitudeLocation=function(t,e){if(!g(t))throw new w("ray is required.");if(!g(e))throw new w("ellipsoid is required.");let r=t.origin,n=t.direction;if(!o.equals(r,o.ZERO)){let I=e.geodeticSurfaceNormal(r,ct);if(o.dot(n,I)>=0)return r}let i=g(this.rayEllipsoid(t,e)),c=e.transformPositionToScaledSpace(n,ct),s=o.normalize(c,c),u=o.mostOrthogonalAxis(c,K),a=o.normalize(o.cross(u,s,wt),wt),f=o.normalize(o.cross(s,a,qt),qt),l=Tt;l[0]=s.x,l[1]=s.y,l[2]=s.z,l[3]=a.x,l[4]=a.y,l[5]=a.z,l[6]=f.x,l[7]=f.y,l[8]=f.z;let d=b.transpose(l,zt),p=b.fromScale(e.radii,Wt),q=b.fromScale(e.oneOverRadii,Vt),m=vt;m[0]=0,m[1]=-n.z,m[2]=n.y,m[3]=n.z,m[4]=0,m[5]=-n.x,m[6]=-n.y,m[7]=n.x,m[8]=0;let h=b.multiply(b.multiply(d,q,gt),m,gt),C=b.multiply(b.multiply(h,p,pt),l,pt),D=b.multiplyByVector(h,r,xt),W=Bt(C,o.negate(D,ct),0,0,1),V,L,B=W.length;if(B>0){let I=o.clone(o.ZERO,Ut),E=Number.NEGATIVE_INFINITY;for(let y=0;yE&&(E=M,I=o.clone(V,I))}let P=e.cartesianToCartographic(I,Qt);return E=R.clamp(E,0,1),L=o.magnitude(o.subtract(I,r,K))*Math.sqrt(1-E*E),L=i?-L:L,P.height=L,e.cartographicToCartesian(P,new o)}};var At=new o;O.lineSegmentPlane=function(t,e,r,n){if(!g(t))throw new w("endPoint0 is required.");if(!g(e))throw new w("endPoint1 is required.");if(!g(r))throw new w("plane is required.");g(n)||(n=new o);let i=o.subtract(e,t,At),c=r.normal,s=o.dot(c,i);if(Math.abs(s)1))return o.multiplyByScalar(i,a,n),o.add(t,n,n),n};O.trianglePlaneIntersection=function(t,e,r,n){if(!g(t)||!g(e)||!g(r)||!g(n))throw new w("p0, p1, p2, and plane are required.");let i=n.normal,c=n.distance,s=o.dot(i,t)+c<0,u=o.dot(i,e)+c<0,a=o.dot(i,r)+c<0,f=0;f+=s?1:0,f+=u?1:0,f+=a?1:0;let l,d;if((f===1||f===2)&&(l=new o,d=new o),f===1){if(s)return O.lineSegmentPlane(t,e,n,l),O.lineSegmentPlane(t,r,n,d),{positions:[t,e,r,l,d],indices:[0,3,4,1,2,4,1,4,3]};if(u)return O.lineSegmentPlane(e,r,n,l),O.lineSegmentPlane(e,t,n,d),{positions:[t,e,r,l,d],indices:[1,3,4,2,0,4,2,4,3]};if(a)return O.lineSegmentPlane(r,t,n,l),O.lineSegmentPlane(r,e,n,d),{positions:[t,e,r,l,d],indices:[2,3,4,0,1,4,0,4,3]}}else if(f===2)if(s)if(u){if(!a)return O.lineSegmentPlane(t,r,n,l),O.lineSegmentPlane(e,r,n,d),{positions:[t,e,r,l,d],indices:[0,1,4,0,4,3,2,3,4]}}else return O.lineSegmentPlane(r,e,n,l),O.lineSegmentPlane(t,e,n,d),{positions:[t,e,r,l,d],indices:[2,0,4,2,4,3,1,3,4]};else return O.lineSegmentPlane(e,t,n,l),O.lineSegmentPlane(r,t,n,d),{positions:[t,e,r,l,d],indices:[1,2,4,1,4,3,0,3,4]}};var qe=O;export{st as a,qe as b}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-YZMLQP2E.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-YZMLQP2E.js new file mode 100644 index 0000000000000000000000000000000000000000..f726deee6ed7021c12da1af44249d67b24a7b069 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-YZMLQP2E.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as w,b as z,d as T,e as S}from"./chunk-5EDTRNG5.js";import{a as y}from"./chunk-IO6LETQ6.js";import{a as C,d as x}from"./chunk-C6Y3PRDH.js";import{a as h}from"./chunk-LI57NJAL.js";import{a as u,b as a}from"./chunk-FUATUYJ3.js";import{e as b}from"./chunk-ODUTJJQ5.js";var c={SCALAR:"SCALAR",VEC2:"VEC2",VEC3:"VEC3",VEC4:"VEC4",MAT2:"MAT2",MAT3:"MAT3",MAT4:"MAT4"};c.getMathType=function(e){switch(e){case c.SCALAR:return Number;case c.VEC2:return T;case c.VEC3:return C;case c.VEC4:return w;case c.MAT2:return S;case c.MAT3:return x;case c.MAT4:return z;default:throw new u("attributeType is not a valid value.")}};c.getNumberOfComponents=function(e){switch(e){case c.SCALAR:return 1;case c.VEC2:return 2;case c.VEC3:return 3;case c.VEC4:case c.MAT2:return 4;case c.MAT3:return 9;case c.MAT4:return 16;default:throw new u("attributeType is not a valid value.")}};c.getAttributeLocationCount=function(e){switch(e){case c.SCALAR:case c.VEC2:case c.VEC3:case c.VEC4:return 1;case c.MAT2:return 2;case c.MAT3:return 3;case c.MAT4:return 4;default:throw new u("attributeType is not a valid value.")}};c.getGlslType=function(e){switch(a.typeOf.string("attributeType",e),e){case c.SCALAR:return"float";case c.VEC2:return"vec2";case c.VEC3:return"vec3";case c.VEC4:return"vec4";case c.MAT2:return"mat2";case c.MAT3:return"mat3";case c.MAT4:return"mat4";default:throw new u("attributeType is not a valid value.")}};var N=Object.freeze(c);var V=1/256,D=256,r={};r.octEncodeInRange=function(e,t,n){a.defined("vector",e),a.defined("result",n);let o=C.magnitudeSquared(e);if(Math.abs(o-1)>h.EPSILON6)throw new u("vector must be normalized.");if(n.x=e.x/(Math.abs(e.x)+Math.abs(e.y)+Math.abs(e.z)),n.y=e.y/(Math.abs(e.x)+Math.abs(e.y)+Math.abs(e.z)),e.z<0){let i=n.x,d=n.y;n.x=(1-Math.abs(d))*h.signNotZero(i),n.y=(1-Math.abs(i))*h.signNotZero(d)}return n.x=h.toSNorm(n.x,t),n.y=h.toSNorm(n.y,t),n};r.octEncode=function(e,t){return r.octEncodeInRange(e,255,t)};var A=new T,F=new Uint8Array(1);function E(e){return F[0]=e,F[0]}r.octEncodeToCartesian4=function(e,t){return r.octEncodeInRange(e,65535,A),t.x=E(A.x*V),t.y=E(A.x),t.z=E(A.y*V),t.w=E(A.y),t};r.octDecodeInRange=function(e,t,n,o){if(a.defined("result",o),e<0||e>n||t<0||t>n)throw new u(`x and y must be unsigned normalized integers between 0 and ${n}`);if(o.x=h.fromSNorm(e,n),o.y=h.fromSNorm(t,n),o.z=1-(Math.abs(o.x)+Math.abs(o.y)),o.z<0){let i=o.x;o.x=(1-Math.abs(o.y))*h.signNotZero(i),o.y=(1-Math.abs(i))*h.signNotZero(o.y)}return C.normalize(o,o)};r.octDecode=function(e,t,n){return r.octDecodeInRange(e,t,255,n)};r.octDecodeFromCartesian4=function(e,t){a.typeOf.object("encoded",e),a.typeOf.object("result",t);let n=e.x,o=e.y,i=e.z,d=e.w;if(n<0||n>255||o<0||o>255||i<0||i>255||d<0||d>255)throw new u("x, y, z, and w must be unsigned normalized integers between 0 and 255");let f=n*D+o,s=i*D+d;return r.octDecodeInRange(f,s,65535,t)};r.octPackFloat=function(e){return a.defined("encoded",e),256*e.x+e.y};var l=new T;r.octEncodeFloat=function(e){return r.octEncode(e,l),r.octPackFloat(l)};r.octDecodeFloat=function(e,t){a.defined("value",e);let n=e/256,o=Math.floor(n),i=(n-o)*256;return r.octDecode(o,i,t)};r.octPack=function(e,t,n,o){a.defined("v1",e),a.defined("v2",t),a.defined("v3",n),a.defined("result",o);let i=r.octEncodeFloat(e),d=r.octEncodeFloat(t),f=r.octEncode(n,l);return o.x=65536*f.x+i,o.y=65536*f.y+d,o};r.octUnpack=function(e,t,n,o){a.defined("packed",e),a.defined("v1",t),a.defined("v2",n),a.defined("v3",o);let i=e.x/65536,d=Math.floor(i),f=(i-d)*65536;i=e.y/65536;let s=Math.floor(i),m=(i-s)*65536;r.octDecodeFloat(f,t),r.octDecodeFloat(m,n),r.octDecode(d,s,o)};r.compressTextureCoordinates=function(e){a.defined("textureCoordinates",e);let t=e.x*4095|0,n=e.y*4095|0;return 4096*t+n};r.decompressTextureCoordinates=function(e,t){a.defined("compressed",e),a.defined("result",t);let n=e/4096,o=Math.floor(n);return t.x=o/4095,t.y=(e-o*4096)/4095,t};function g(e){return e>>1^-(e&1)}r.zigZagDeltaDecode=function(e,t,n){a.defined("uBuffer",e),a.defined("vBuffer",t),a.typeOf.number.equals("uBuffer.length","vBuffer.length",e.length,t.length),b(n)&&a.typeOf.number.equals("uBuffer.length","heightBuffer.length",e.length,n.length);let o=e.length,i=0,d=0,f=0;for(let s=0;s>11,I=p>>5&d,O=p&i,M=3*m;t[M]=R*f,t[M+1]=I*s,t[M+2]=O*f}return t};var W=r;export{W as a}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-ZFLJGI6G.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-ZFLJGI6G.js new file mode 100644 index 0000000000000000000000000000000000000000..49c01ae90877e6772cca0559d999c7d62765d212 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/Cesium/Workers/chunk-ZFLJGI6G.js @@ -0,0 +1,26 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import{a as Q}from"./chunk-UCJPMZM6.js";import{a as z}from"./chunk-YYCOBWZH.js";import{a as _}from"./chunk-M3OLDEEW.js";import{a as K}from"./chunk-67OQHZOZ.js";import{a as H}from"./chunk-FUN3J34G.js";import{b as J,c as W,d as P}from"./chunk-A4RD4IQP.js";import{d as j}from"./chunk-NNIY7VTE.js";import{d as k}from"./chunk-5EDTRNG5.js";import{a as L}from"./chunk-IO6LETQ6.js";import{a as b}from"./chunk-C6Y3PRDH.js";import{a as Z}from"./chunk-LI57NJAL.js";import{a as x}from"./chunk-P44SUSQU.js";import{a as F}from"./chunk-FUATUYJ3.js";import{e as g}from"./chunk-ODUTJJQ5.js";var M=new k,ot=new b,nt=new b,it=new b,st=new b;function O(t){t=x(t,x.EMPTY_OBJECT);let n=t.length,e=t.topRadius,h=t.bottomRadius,o=x(t.vertexFormat,_.DEFAULT),r=x(t.slices,128);if(!g(n))throw new F("options.length must be defined.");if(!g(e))throw new F("options.topRadius must be defined.");if(!g(h))throw new F("options.bottomRadius must be defined.");if(r<3)throw new F("options.slices must be greater than or equal to 3.");if(g(t.offsetAttribute)&&t.offsetAttribute===z.TOP)throw new F("GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry.");this._length=n,this._topRadius=e,this._bottomRadius=h,this._vertexFormat=_.clone(o),this._slices=r,this._offsetAttribute=t.offsetAttribute,this._workerName="createCylinderGeometry"}O.packedLength=_.packedLength+5;O.pack=function(t,n,e){if(!g(t))throw new F("value is required");if(!g(n))throw new F("array is required");return e=x(e,0),_.pack(t._vertexFormat,n,e),e+=_.packedLength,n[e++]=t._length,n[e++]=t._topRadius,n[e++]=t._bottomRadius,n[e++]=t._slices,n[e]=x(t._offsetAttribute,-1),n};var X=new _,C={vertexFormat:X,length:void 0,topRadius:void 0,bottomRadius:void 0,slices:void 0,offsetAttribute:void 0};O.unpack=function(t,n,e){if(!g(t))throw new F("array is required");n=x(n,0);let h=_.unpack(t,n,X);n+=_.packedLength;let o=t[n++],r=t[n++],p=t[n++],D=t[n++],w=t[n];return g(e)?(e._vertexFormat=_.clone(h,e._vertexFormat),e._length=o,e._topRadius=r,e._bottomRadius=p,e._slices=D,e._offsetAttribute=w===-1?void 0:w,e):(C.length=o,C.topRadius=r,C.bottomRadius=p,C.slices=D,C.offsetAttribute=w===-1?void 0:w,new O(C))};O.createGeometry=function(t){let n=t._length,e=t._topRadius,h=t._bottomRadius,o=t._vertexFormat,r=t._slices;if(n<=0||e<0||h<0||e===0&&h===0)return;let p=r+r,D=r+p,w=p+p,E=Q.computePositions(n,e,h,r,!0),N=o.st?new Float32Array(w*2):void 0,c=o.normal?new Float32Array(w*3):void 0,m=o.tangent?new Float32Array(w*3):void 0,u=o.bitangent?new Float32Array(w*3):void 0,i,U=o.normal||o.tangent||o.bitangent;if(U){let T=o.tangent||o.bitangent,f=0,d=0,l=0,q=Math.atan2(h-e,n),A=ot;A.z=Math.sin(q);let B=Math.cos(q),R=it,y=nt;for(i=0;i 1) { + h -= 1; + } + if (h * 6 < 1) { + return m1 + (m2 - m1) * 6 * h; + } + if (h * 2 < 1) { + return m2; + } + if (h * 3 < 2) { + return m1 + (m2 - m1) * (2 / 3 - h) * 6; + } + return m1; +} +function Color(red, green, blue, alpha) { + this.red = defaultValue_default(red, 1); + this.green = defaultValue_default(green, 1); + this.blue = defaultValue_default(blue, 1); + this.alpha = defaultValue_default(alpha, 1); +} +Color.fromCartesian4 = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + if (!defined_default(result)) { + return new Color(cartesian.x, cartesian.y, cartesian.z, cartesian.w); + } + result.red = cartesian.x; + result.green = cartesian.y; + result.blue = cartesian.z; + result.alpha = cartesian.w; + return result; +}; +Color.fromBytes = function(red, green, blue, alpha, result) { + red = Color.byteToFloat(defaultValue_default(red, 255)); + green = Color.byteToFloat(defaultValue_default(green, 255)); + blue = Color.byteToFloat(defaultValue_default(blue, 255)); + alpha = Color.byteToFloat(defaultValue_default(alpha, 255)); + if (!defined_default(result)) { + return new Color(red, green, blue, alpha); + } + result.red = red; + result.green = green; + result.blue = blue; + result.alpha = alpha; + return result; +}; +Color.fromAlpha = function(color, alpha, result) { + Check_default.typeOf.object("color", color); + Check_default.typeOf.number("alpha", alpha); + if (!defined_default(result)) { + return new Color(color.red, color.green, color.blue, alpha); + } + result.red = color.red; + result.green = color.green; + result.blue = color.blue; + result.alpha = alpha; + return result; +}; +var scratchArrayBuffer; +var scratchUint32Array; +var scratchUint8Array; +if (FeatureDetection_default.supportsTypedArrays()) { + scratchArrayBuffer = new ArrayBuffer(4); + scratchUint32Array = new Uint32Array(scratchArrayBuffer); + scratchUint8Array = new Uint8Array(scratchArrayBuffer); +} +Color.fromRgba = function(rgba, result) { + scratchUint32Array[0] = rgba; + return Color.fromBytes( + scratchUint8Array[0], + scratchUint8Array[1], + scratchUint8Array[2], + scratchUint8Array[3], + result + ); +}; +Color.fromHsl = function(hue, saturation, lightness, alpha, result) { + hue = defaultValue_default(hue, 0) % 1; + saturation = defaultValue_default(saturation, 0); + lightness = defaultValue_default(lightness, 0); + alpha = defaultValue_default(alpha, 1); + let red = lightness; + let green = lightness; + let blue = lightness; + if (saturation !== 0) { + let m2; + if (lightness < 0.5) { + m2 = lightness * (1 + saturation); + } else { + m2 = lightness + saturation - lightness * saturation; + } + const m1 = 2 * lightness - m2; + red = hue2rgb(m1, m2, hue + 1 / 3); + green = hue2rgb(m1, m2, hue); + blue = hue2rgb(m1, m2, hue - 1 / 3); + } + if (!defined_default(result)) { + return new Color(red, green, blue, alpha); + } + result.red = red; + result.green = green; + result.blue = blue; + result.alpha = alpha; + return result; +}; +Color.fromRandom = function(options, result) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + let red = options.red; + if (!defined_default(red)) { + const minimumRed = defaultValue_default(options.minimumRed, 0); + const maximumRed = defaultValue_default(options.maximumRed, 1); + Check_default.typeOf.number.lessThanOrEquals("minimumRed", minimumRed, maximumRed); + red = minimumRed + Math_default.nextRandomNumber() * (maximumRed - minimumRed); + } + let green = options.green; + if (!defined_default(green)) { + const minimumGreen = defaultValue_default(options.minimumGreen, 0); + const maximumGreen = defaultValue_default(options.maximumGreen, 1); + Check_default.typeOf.number.lessThanOrEquals( + "minimumGreen", + minimumGreen, + maximumGreen + ); + green = minimumGreen + Math_default.nextRandomNumber() * (maximumGreen - minimumGreen); + } + let blue = options.blue; + if (!defined_default(blue)) { + const minimumBlue = defaultValue_default(options.minimumBlue, 0); + const maximumBlue = defaultValue_default(options.maximumBlue, 1); + Check_default.typeOf.number.lessThanOrEquals( + "minimumBlue", + minimumBlue, + maximumBlue + ); + blue = minimumBlue + Math_default.nextRandomNumber() * (maximumBlue - minimumBlue); + } + let alpha = options.alpha; + if (!defined_default(alpha)) { + const minimumAlpha = defaultValue_default(options.minimumAlpha, 0); + const maximumAlpha = defaultValue_default(options.maximumAlpha, 1); + Check_default.typeOf.number.lessThanOrEquals( + "minumumAlpha", + minimumAlpha, + maximumAlpha + ); + alpha = minimumAlpha + Math_default.nextRandomNumber() * (maximumAlpha - minimumAlpha); + } + if (!defined_default(result)) { + return new Color(red, green, blue, alpha); + } + result.red = red; + result.green = green; + result.blue = blue; + result.alpha = alpha; + return result; +}; +var rgbaMatcher = /^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i; +var rrggbbaaMatcher = /^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i; +var rgbParenthesesMatcher = /^rgba?\s*\(\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)\s*[,\s]+\s*([0-9.]+%?)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i; +var hslParenthesesMatcher = /^hsla?\s*\(\s*([0-9.]+)\s*[,\s]+\s*([0-9.]+%)\s*[,\s]+\s*([0-9.]+%)(?:\s*[,\s/]+\s*([0-9.]+))?\s*\)$/i; +Color.fromCssColorString = function(color, result) { + Check_default.typeOf.string("color", color); + if (!defined_default(result)) { + result = new Color(); + } + color = color.trim(); + const namedColor = Color[color.toUpperCase()]; + if (defined_default(namedColor)) { + Color.clone(namedColor, result); + return result; + } + let matches = rgbaMatcher.exec(color); + if (matches !== null) { + result.red = parseInt(matches[1], 16) / 15; + result.green = parseInt(matches[2], 16) / 15; + result.blue = parseInt(matches[3], 16) / 15; + result.alpha = parseInt(defaultValue_default(matches[4], "f"), 16) / 15; + return result; + } + matches = rrggbbaaMatcher.exec(color); + if (matches !== null) { + result.red = parseInt(matches[1], 16) / 255; + result.green = parseInt(matches[2], 16) / 255; + result.blue = parseInt(matches[3], 16) / 255; + result.alpha = parseInt(defaultValue_default(matches[4], "ff"), 16) / 255; + return result; + } + matches = rgbParenthesesMatcher.exec(color); + if (matches !== null) { + result.red = parseFloat(matches[1]) / ("%" === matches[1].substr(-1) ? 100 : 255); + result.green = parseFloat(matches[2]) / ("%" === matches[2].substr(-1) ? 100 : 255); + result.blue = parseFloat(matches[3]) / ("%" === matches[3].substr(-1) ? 100 : 255); + result.alpha = parseFloat(defaultValue_default(matches[4], "1.0")); + return result; + } + matches = hslParenthesesMatcher.exec(color); + if (matches !== null) { + return Color.fromHsl( + parseFloat(matches[1]) / 360, + parseFloat(matches[2]) / 100, + parseFloat(matches[3]) / 100, + parseFloat(defaultValue_default(matches[4], "1.0")), + result + ); + } + result = void 0; + return result; +}; +Color.packedLength = 4; +Color.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value.red; + array[startingIndex++] = value.green; + array[startingIndex++] = value.blue; + array[startingIndex] = value.alpha; + return array; +}; +Color.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new Color(); + } + result.red = array[startingIndex++]; + result.green = array[startingIndex++]; + result.blue = array[startingIndex++]; + result.alpha = array[startingIndex]; + return result; +}; +Color.byteToFloat = function(number) { + return number / 255; +}; +Color.floatToByte = function(number) { + return number === 1 ? 255 : number * 256 | 0; +}; +Color.clone = function(color, result) { + if (!defined_default(color)) { + return void 0; + } + if (!defined_default(result)) { + return new Color(color.red, color.green, color.blue, color.alpha); + } + result.red = color.red; + result.green = color.green; + result.blue = color.blue; + result.alpha = color.alpha; + return result; +}; +Color.equals = function(left, right) { + return left === right || // + defined_default(left) && // + defined_default(right) && // + left.red === right.red && // + left.green === right.green && // + left.blue === right.blue && // + left.alpha === right.alpha; +}; +Color.equalsArray = function(color, array, offset) { + return color.red === array[offset] && color.green === array[offset + 1] && color.blue === array[offset + 2] && color.alpha === array[offset + 3]; +}; +Color.prototype.clone = function(result) { + return Color.clone(this, result); +}; +Color.prototype.equals = function(other) { + return Color.equals(this, other); +}; +Color.prototype.equalsEpsilon = function(other, epsilon) { + return this === other || // + defined_default(other) && // + Math.abs(this.red - other.red) <= epsilon && // + Math.abs(this.green - other.green) <= epsilon && // + Math.abs(this.blue - other.blue) <= epsilon && // + Math.abs(this.alpha - other.alpha) <= epsilon; +}; +Color.prototype.toString = function() { + return `(${this.red}, ${this.green}, ${this.blue}, ${this.alpha})`; +}; +Color.prototype.toCssColorString = function() { + const red = Color.floatToByte(this.red); + const green = Color.floatToByte(this.green); + const blue = Color.floatToByte(this.blue); + if (this.alpha === 1) { + return `rgb(${red},${green},${blue})`; + } + return `rgba(${red},${green},${blue},${this.alpha})`; +}; +Color.prototype.toCssHexString = function() { + let r = Color.floatToByte(this.red).toString(16); + if (r.length < 2) { + r = `0${r}`; + } + let g = Color.floatToByte(this.green).toString(16); + if (g.length < 2) { + g = `0${g}`; + } + let b = Color.floatToByte(this.blue).toString(16); + if (b.length < 2) { + b = `0${b}`; + } + if (this.alpha < 1) { + let hexAlpha = Color.floatToByte(this.alpha).toString(16); + if (hexAlpha.length < 2) { + hexAlpha = `0${hexAlpha}`; + } + return `#${r}${g}${b}${hexAlpha}`; + } + return `#${r}${g}${b}`; +}; +Color.prototype.toBytes = function(result) { + const red = Color.floatToByte(this.red); + const green = Color.floatToByte(this.green); + const blue = Color.floatToByte(this.blue); + const alpha = Color.floatToByte(this.alpha); + if (!defined_default(result)) { + return [red, green, blue, alpha]; + } + result[0] = red; + result[1] = green; + result[2] = blue; + result[3] = alpha; + return result; +}; +Color.prototype.toRgba = function() { + scratchUint8Array[0] = Color.floatToByte(this.red); + scratchUint8Array[1] = Color.floatToByte(this.green); + scratchUint8Array[2] = Color.floatToByte(this.blue); + scratchUint8Array[3] = Color.floatToByte(this.alpha); + return scratchUint32Array[0]; +}; +Color.prototype.brighten = function(magnitude, result) { + Check_default.typeOf.number("magnitude", magnitude); + Check_default.typeOf.number.greaterThanOrEquals("magnitude", magnitude, 0); + Check_default.typeOf.object("result", result); + magnitude = 1 - magnitude; + result.red = 1 - (1 - this.red) * magnitude; + result.green = 1 - (1 - this.green) * magnitude; + result.blue = 1 - (1 - this.blue) * magnitude; + result.alpha = this.alpha; + return result; +}; +Color.prototype.darken = function(magnitude, result) { + Check_default.typeOf.number("magnitude", magnitude); + Check_default.typeOf.number.greaterThanOrEquals("magnitude", magnitude, 0); + Check_default.typeOf.object("result", result); + magnitude = 1 - magnitude; + result.red = this.red * magnitude; + result.green = this.green * magnitude; + result.blue = this.blue * magnitude; + result.alpha = this.alpha; + return result; +}; +Color.prototype.withAlpha = function(alpha, result) { + return Color.fromAlpha(this, alpha, result); +}; +Color.add = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.red = left.red + right.red; + result.green = left.green + right.green; + result.blue = left.blue + right.blue; + result.alpha = left.alpha + right.alpha; + return result; +}; +Color.subtract = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.red = left.red - right.red; + result.green = left.green - right.green; + result.blue = left.blue - right.blue; + result.alpha = left.alpha - right.alpha; + return result; +}; +Color.multiply = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.red = left.red * right.red; + result.green = left.green * right.green; + result.blue = left.blue * right.blue; + result.alpha = left.alpha * right.alpha; + return result; +}; +Color.divide = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.red = left.red / right.red; + result.green = left.green / right.green; + result.blue = left.blue / right.blue; + result.alpha = left.alpha / right.alpha; + return result; +}; +Color.mod = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.red = left.red % right.red; + result.green = left.green % right.green; + result.blue = left.blue % right.blue; + result.alpha = left.alpha % right.alpha; + return result; +}; +Color.lerp = function(start, end, t, result) { + Check_default.typeOf.object("start", start); + Check_default.typeOf.object("end", end); + Check_default.typeOf.number("t", t); + Check_default.typeOf.object("result", result); + result.red = Math_default.lerp(start.red, end.red, t); + result.green = Math_default.lerp(start.green, end.green, t); + result.blue = Math_default.lerp(start.blue, end.blue, t); + result.alpha = Math_default.lerp(start.alpha, end.alpha, t); + return result; +}; +Color.multiplyByScalar = function(color, scalar, result) { + Check_default.typeOf.object("color", color); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result.red = color.red * scalar; + result.green = color.green * scalar; + result.blue = color.blue * scalar; + result.alpha = color.alpha * scalar; + return result; +}; +Color.divideByScalar = function(color, scalar, result) { + Check_default.typeOf.object("color", color); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result.red = color.red / scalar; + result.green = color.green / scalar; + result.blue = color.blue / scalar; + result.alpha = color.alpha / scalar; + return result; +}; +Color.ALICEBLUE = Object.freeze(Color.fromCssColorString("#F0F8FF")); +Color.ANTIQUEWHITE = Object.freeze(Color.fromCssColorString("#FAEBD7")); +Color.AQUA = Object.freeze(Color.fromCssColorString("#00FFFF")); +Color.AQUAMARINE = Object.freeze(Color.fromCssColorString("#7FFFD4")); +Color.AZURE = Object.freeze(Color.fromCssColorString("#F0FFFF")); +Color.BEIGE = Object.freeze(Color.fromCssColorString("#F5F5DC")); +Color.BISQUE = Object.freeze(Color.fromCssColorString("#FFE4C4")); +Color.BLACK = Object.freeze(Color.fromCssColorString("#000000")); +Color.BLANCHEDALMOND = Object.freeze(Color.fromCssColorString("#FFEBCD")); +Color.BLUE = Object.freeze(Color.fromCssColorString("#0000FF")); +Color.BLUEVIOLET = Object.freeze(Color.fromCssColorString("#8A2BE2")); +Color.BROWN = Object.freeze(Color.fromCssColorString("#A52A2A")); +Color.BURLYWOOD = Object.freeze(Color.fromCssColorString("#DEB887")); +Color.CADETBLUE = Object.freeze(Color.fromCssColorString("#5F9EA0")); +Color.CHARTREUSE = Object.freeze(Color.fromCssColorString("#7FFF00")); +Color.CHOCOLATE = Object.freeze(Color.fromCssColorString("#D2691E")); +Color.CORAL = Object.freeze(Color.fromCssColorString("#FF7F50")); +Color.CORNFLOWERBLUE = Object.freeze(Color.fromCssColorString("#6495ED")); +Color.CORNSILK = Object.freeze(Color.fromCssColorString("#FFF8DC")); +Color.CRIMSON = Object.freeze(Color.fromCssColorString("#DC143C")); +Color.CYAN = Object.freeze(Color.fromCssColorString("#00FFFF")); +Color.DARKBLUE = Object.freeze(Color.fromCssColorString("#00008B")); +Color.DARKCYAN = Object.freeze(Color.fromCssColorString("#008B8B")); +Color.DARKGOLDENROD = Object.freeze(Color.fromCssColorString("#B8860B")); +Color.DARKGRAY = Object.freeze(Color.fromCssColorString("#A9A9A9")); +Color.DARKGREEN = Object.freeze(Color.fromCssColorString("#006400")); +Color.DARKGREY = Color.DARKGRAY; +Color.DARKKHAKI = Object.freeze(Color.fromCssColorString("#BDB76B")); +Color.DARKMAGENTA = Object.freeze(Color.fromCssColorString("#8B008B")); +Color.DARKOLIVEGREEN = Object.freeze(Color.fromCssColorString("#556B2F")); +Color.DARKORANGE = Object.freeze(Color.fromCssColorString("#FF8C00")); +Color.DARKORCHID = Object.freeze(Color.fromCssColorString("#9932CC")); +Color.DARKRED = Object.freeze(Color.fromCssColorString("#8B0000")); +Color.DARKSALMON = Object.freeze(Color.fromCssColorString("#E9967A")); +Color.DARKSEAGREEN = Object.freeze(Color.fromCssColorString("#8FBC8F")); +Color.DARKSLATEBLUE = Object.freeze(Color.fromCssColorString("#483D8B")); +Color.DARKSLATEGRAY = Object.freeze(Color.fromCssColorString("#2F4F4F")); +Color.DARKSLATEGREY = Color.DARKSLATEGRAY; +Color.DARKTURQUOISE = Object.freeze(Color.fromCssColorString("#00CED1")); +Color.DARKVIOLET = Object.freeze(Color.fromCssColorString("#9400D3")); +Color.DEEPPINK = Object.freeze(Color.fromCssColorString("#FF1493")); +Color.DEEPSKYBLUE = Object.freeze(Color.fromCssColorString("#00BFFF")); +Color.DIMGRAY = Object.freeze(Color.fromCssColorString("#696969")); +Color.DIMGREY = Color.DIMGRAY; +Color.DODGERBLUE = Object.freeze(Color.fromCssColorString("#1E90FF")); +Color.FIREBRICK = Object.freeze(Color.fromCssColorString("#B22222")); +Color.FLORALWHITE = Object.freeze(Color.fromCssColorString("#FFFAF0")); +Color.FORESTGREEN = Object.freeze(Color.fromCssColorString("#228B22")); +Color.FUCHSIA = Object.freeze(Color.fromCssColorString("#FF00FF")); +Color.GAINSBORO = Object.freeze(Color.fromCssColorString("#DCDCDC")); +Color.GHOSTWHITE = Object.freeze(Color.fromCssColorString("#F8F8FF")); +Color.GOLD = Object.freeze(Color.fromCssColorString("#FFD700")); +Color.GOLDENROD = Object.freeze(Color.fromCssColorString("#DAA520")); +Color.GRAY = Object.freeze(Color.fromCssColorString("#808080")); +Color.GREEN = Object.freeze(Color.fromCssColorString("#008000")); +Color.GREENYELLOW = Object.freeze(Color.fromCssColorString("#ADFF2F")); +Color.GREY = Color.GRAY; +Color.HONEYDEW = Object.freeze(Color.fromCssColorString("#F0FFF0")); +Color.HOTPINK = Object.freeze(Color.fromCssColorString("#FF69B4")); +Color.INDIANRED = Object.freeze(Color.fromCssColorString("#CD5C5C")); +Color.INDIGO = Object.freeze(Color.fromCssColorString("#4B0082")); +Color.IVORY = Object.freeze(Color.fromCssColorString("#FFFFF0")); +Color.KHAKI = Object.freeze(Color.fromCssColorString("#F0E68C")); +Color.LAVENDER = Object.freeze(Color.fromCssColorString("#E6E6FA")); +Color.LAVENDAR_BLUSH = Object.freeze(Color.fromCssColorString("#FFF0F5")); +Color.LAWNGREEN = Object.freeze(Color.fromCssColorString("#7CFC00")); +Color.LEMONCHIFFON = Object.freeze(Color.fromCssColorString("#FFFACD")); +Color.LIGHTBLUE = Object.freeze(Color.fromCssColorString("#ADD8E6")); +Color.LIGHTCORAL = Object.freeze(Color.fromCssColorString("#F08080")); +Color.LIGHTCYAN = Object.freeze(Color.fromCssColorString("#E0FFFF")); +Color.LIGHTGOLDENRODYELLOW = Object.freeze(Color.fromCssColorString("#FAFAD2")); +Color.LIGHTGRAY = Object.freeze(Color.fromCssColorString("#D3D3D3")); +Color.LIGHTGREEN = Object.freeze(Color.fromCssColorString("#90EE90")); +Color.LIGHTGREY = Color.LIGHTGRAY; +Color.LIGHTPINK = Object.freeze(Color.fromCssColorString("#FFB6C1")); +Color.LIGHTSEAGREEN = Object.freeze(Color.fromCssColorString("#20B2AA")); +Color.LIGHTSKYBLUE = Object.freeze(Color.fromCssColorString("#87CEFA")); +Color.LIGHTSLATEGRAY = Object.freeze(Color.fromCssColorString("#778899")); +Color.LIGHTSLATEGREY = Color.LIGHTSLATEGRAY; +Color.LIGHTSTEELBLUE = Object.freeze(Color.fromCssColorString("#B0C4DE")); +Color.LIGHTYELLOW = Object.freeze(Color.fromCssColorString("#FFFFE0")); +Color.LIME = Object.freeze(Color.fromCssColorString("#00FF00")); +Color.LIMEGREEN = Object.freeze(Color.fromCssColorString("#32CD32")); +Color.LINEN = Object.freeze(Color.fromCssColorString("#FAF0E6")); +Color.MAGENTA = Object.freeze(Color.fromCssColorString("#FF00FF")); +Color.MAROON = Object.freeze(Color.fromCssColorString("#800000")); +Color.MEDIUMAQUAMARINE = Object.freeze(Color.fromCssColorString("#66CDAA")); +Color.MEDIUMBLUE = Object.freeze(Color.fromCssColorString("#0000CD")); +Color.MEDIUMORCHID = Object.freeze(Color.fromCssColorString("#BA55D3")); +Color.MEDIUMPURPLE = Object.freeze(Color.fromCssColorString("#9370DB")); +Color.MEDIUMSEAGREEN = Object.freeze(Color.fromCssColorString("#3CB371")); +Color.MEDIUMSLATEBLUE = Object.freeze(Color.fromCssColorString("#7B68EE")); +Color.MEDIUMSPRINGGREEN = Object.freeze(Color.fromCssColorString("#00FA9A")); +Color.MEDIUMTURQUOISE = Object.freeze(Color.fromCssColorString("#48D1CC")); +Color.MEDIUMVIOLETRED = Object.freeze(Color.fromCssColorString("#C71585")); +Color.MIDNIGHTBLUE = Object.freeze(Color.fromCssColorString("#191970")); +Color.MINTCREAM = Object.freeze(Color.fromCssColorString("#F5FFFA")); +Color.MISTYROSE = Object.freeze(Color.fromCssColorString("#FFE4E1")); +Color.MOCCASIN = Object.freeze(Color.fromCssColorString("#FFE4B5")); +Color.NAVAJOWHITE = Object.freeze(Color.fromCssColorString("#FFDEAD")); +Color.NAVY = Object.freeze(Color.fromCssColorString("#000080")); +Color.OLDLACE = Object.freeze(Color.fromCssColorString("#FDF5E6")); +Color.OLIVE = Object.freeze(Color.fromCssColorString("#808000")); +Color.OLIVEDRAB = Object.freeze(Color.fromCssColorString("#6B8E23")); +Color.ORANGE = Object.freeze(Color.fromCssColorString("#FFA500")); +Color.ORANGERED = Object.freeze(Color.fromCssColorString("#FF4500")); +Color.ORCHID = Object.freeze(Color.fromCssColorString("#DA70D6")); +Color.PALEGOLDENROD = Object.freeze(Color.fromCssColorString("#EEE8AA")); +Color.PALEGREEN = Object.freeze(Color.fromCssColorString("#98FB98")); +Color.PALETURQUOISE = Object.freeze(Color.fromCssColorString("#AFEEEE")); +Color.PALEVIOLETRED = Object.freeze(Color.fromCssColorString("#DB7093")); +Color.PAPAYAWHIP = Object.freeze(Color.fromCssColorString("#FFEFD5")); +Color.PEACHPUFF = Object.freeze(Color.fromCssColorString("#FFDAB9")); +Color.PERU = Object.freeze(Color.fromCssColorString("#CD853F")); +Color.PINK = Object.freeze(Color.fromCssColorString("#FFC0CB")); +Color.PLUM = Object.freeze(Color.fromCssColorString("#DDA0DD")); +Color.POWDERBLUE = Object.freeze(Color.fromCssColorString("#B0E0E6")); +Color.PURPLE = Object.freeze(Color.fromCssColorString("#800080")); +Color.RED = Object.freeze(Color.fromCssColorString("#FF0000")); +Color.ROSYBROWN = Object.freeze(Color.fromCssColorString("#BC8F8F")); +Color.ROYALBLUE = Object.freeze(Color.fromCssColorString("#4169E1")); +Color.SADDLEBROWN = Object.freeze(Color.fromCssColorString("#8B4513")); +Color.SALMON = Object.freeze(Color.fromCssColorString("#FA8072")); +Color.SANDYBROWN = Object.freeze(Color.fromCssColorString("#F4A460")); +Color.SEAGREEN = Object.freeze(Color.fromCssColorString("#2E8B57")); +Color.SEASHELL = Object.freeze(Color.fromCssColorString("#FFF5EE")); +Color.SIENNA = Object.freeze(Color.fromCssColorString("#A0522D")); +Color.SILVER = Object.freeze(Color.fromCssColorString("#C0C0C0")); +Color.SKYBLUE = Object.freeze(Color.fromCssColorString("#87CEEB")); +Color.SLATEBLUE = Object.freeze(Color.fromCssColorString("#6A5ACD")); +Color.SLATEGRAY = Object.freeze(Color.fromCssColorString("#708090")); +Color.SLATEGREY = Color.SLATEGRAY; +Color.SNOW = Object.freeze(Color.fromCssColorString("#FFFAFA")); +Color.SPRINGGREEN = Object.freeze(Color.fromCssColorString("#00FF7F")); +Color.STEELBLUE = Object.freeze(Color.fromCssColorString("#4682B4")); +Color.TAN = Object.freeze(Color.fromCssColorString("#D2B48C")); +Color.TEAL = Object.freeze(Color.fromCssColorString("#008080")); +Color.THISTLE = Object.freeze(Color.fromCssColorString("#D8BFD8")); +Color.TOMATO = Object.freeze(Color.fromCssColorString("#FF6347")); +Color.TURQUOISE = Object.freeze(Color.fromCssColorString("#40E0D0")); +Color.VIOLET = Object.freeze(Color.fromCssColorString("#EE82EE")); +Color.WHEAT = Object.freeze(Color.fromCssColorString("#F5DEB3")); +Color.WHITE = Object.freeze(Color.fromCssColorString("#FFFFFF")); +Color.WHITESMOKE = Object.freeze(Color.fromCssColorString("#F5F5F5")); +Color.YELLOW = Object.freeze(Color.fromCssColorString("#FFFF00")); +Color.YELLOWGREEN = Object.freeze(Color.fromCssColorString("#9ACD32")); +Color.TRANSPARENT = Object.freeze(new Color(0, 0, 0, 0)); +var Color_default = Color; + +export { + Color_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-2C65EKYA.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-2C65EKYA.js new file mode 100644 index 0000000000000000000000000000000000000000..28e5d9ff08d937358e8ba34212b70192eeb43058 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-2C65EKYA.js @@ -0,0 +1,55 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + + +// packages/engine/Source/Core/ArcType.js +var ArcType = { + /** + * Straight line that does not conform to the surface of the ellipsoid. + * + * @type {number} + * @constant + */ + NONE: 0, + /** + * Follow geodesic path. + * + * @type {number} + * @constant + */ + GEODESIC: 1, + /** + * Follow rhumb or loxodrome path. + * + * @type {number} + * @constant + */ + RHUMB: 2 +}; +var ArcType_default = Object.freeze(ArcType); + +export { + ArcType_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-2NLMZNJI.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-2NLMZNJI.js new file mode 100644 index 0000000000000000000000000000000000000000..a3dfbcaa37c4a53d66e1dcfbf85e60adb23ff456 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-2NLMZNJI.js @@ -0,0 +1,138 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/VertexFormat.js +function VertexFormat(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + this.position = defaultValue_default(options.position, false); + this.normal = defaultValue_default(options.normal, false); + this.st = defaultValue_default(options.st, false); + this.bitangent = defaultValue_default(options.bitangent, false); + this.tangent = defaultValue_default(options.tangent, false); + this.color = defaultValue_default(options.color, false); +} +VertexFormat.POSITION_ONLY = Object.freeze( + new VertexFormat({ + position: true + }) +); +VertexFormat.POSITION_AND_NORMAL = Object.freeze( + new VertexFormat({ + position: true, + normal: true + }) +); +VertexFormat.POSITION_NORMAL_AND_ST = Object.freeze( + new VertexFormat({ + position: true, + normal: true, + st: true + }) +); +VertexFormat.POSITION_AND_ST = Object.freeze( + new VertexFormat({ + position: true, + st: true + }) +); +VertexFormat.POSITION_AND_COLOR = Object.freeze( + new VertexFormat({ + position: true, + color: true + }) +); +VertexFormat.ALL = Object.freeze( + new VertexFormat({ + position: true, + normal: true, + st: true, + tangent: true, + bitangent: true + }) +); +VertexFormat.DEFAULT = VertexFormat.POSITION_NORMAL_AND_ST; +VertexFormat.packedLength = 6; +VertexFormat.pack = function(value, array, startingIndex) { + if (!defined_default(value)) { + throw new DeveloperError_default("value is required"); + } + if (!defined_default(array)) { + throw new DeveloperError_default("array is required"); + } + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value.position ? 1 : 0; + array[startingIndex++] = value.normal ? 1 : 0; + array[startingIndex++] = value.st ? 1 : 0; + array[startingIndex++] = value.tangent ? 1 : 0; + array[startingIndex++] = value.bitangent ? 1 : 0; + array[startingIndex] = value.color ? 1 : 0; + return array; +}; +VertexFormat.unpack = function(array, startingIndex, result) { + if (!defined_default(array)) { + throw new DeveloperError_default("array is required"); + } + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new VertexFormat(); + } + result.position = array[startingIndex++] === 1; + result.normal = array[startingIndex++] === 1; + result.st = array[startingIndex++] === 1; + result.tangent = array[startingIndex++] === 1; + result.bitangent = array[startingIndex++] === 1; + result.color = array[startingIndex] === 1; + return result; +}; +VertexFormat.clone = function(vertexFormat, result) { + if (!defined_default(vertexFormat)) { + return void 0; + } + if (!defined_default(result)) { + result = new VertexFormat(); + } + result.position = vertexFormat.position; + result.normal = vertexFormat.normal; + result.st = vertexFormat.st; + result.tangent = vertexFormat.tangent; + result.bitangent = vertexFormat.bitangent; + result.color = vertexFormat.color; + return result; +}; +var VertexFormat_default = VertexFormat; + +export { + VertexFormat_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-4V6RCTVH.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-4V6RCTVH.js new file mode 100644 index 0000000000000000000000000000000000000000..d9206eeab44decfe905e9586f9db4be64e9a2ede --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-4V6RCTVH.js @@ -0,0 +1,289 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + AxisAlignedBoundingBox_default +} from "./chunk-G3MOT7BZ.js"; +import { + IntersectionTests_default, + Ray_default +} from "./chunk-QIS3NB7U.js"; +import { + Plane_default +} from "./chunk-PGB3EFR7.js"; +import { + Transforms_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default, + Cartesian4_default, + Matrix4_default +} from "./chunk-PW5CA4MJ.js"; +import { + Cartesian3_default, + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/EllipsoidTangentPlane.js +var scratchCart4 = new Cartesian4_default(); +function EllipsoidTangentPlane(origin, ellipsoid) { + Check_default.defined("origin", origin); + ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + origin = ellipsoid.scaleToGeodeticSurface(origin); + if (!defined_default(origin)) { + throw new DeveloperError_default( + "origin must not be at the center of the ellipsoid." + ); + } + const eastNorthUp = Transforms_default.eastNorthUpToFixedFrame(origin, ellipsoid); + this._ellipsoid = ellipsoid; + this._origin = origin; + this._xAxis = Cartesian3_default.fromCartesian4( + Matrix4_default.getColumn(eastNorthUp, 0, scratchCart4) + ); + this._yAxis = Cartesian3_default.fromCartesian4( + Matrix4_default.getColumn(eastNorthUp, 1, scratchCart4) + ); + const normal = Cartesian3_default.fromCartesian4( + Matrix4_default.getColumn(eastNorthUp, 2, scratchCart4) + ); + this._plane = Plane_default.fromPointNormal(origin, normal); +} +Object.defineProperties(EllipsoidTangentPlane.prototype, { + /** + * Gets the ellipsoid. + * @memberof EllipsoidTangentPlane.prototype + * @type {Ellipsoid} + */ + ellipsoid: { + get: function() { + return this._ellipsoid; + } + }, + /** + * Gets the origin. + * @memberof EllipsoidTangentPlane.prototype + * @type {Cartesian3} + */ + origin: { + get: function() { + return this._origin; + } + }, + /** + * Gets the plane which is tangent to the ellipsoid. + * @memberof EllipsoidTangentPlane.prototype + * @readonly + * @type {Plane} + */ + plane: { + get: function() { + return this._plane; + } + }, + /** + * Gets the local X-axis (east) of the tangent plane. + * @memberof EllipsoidTangentPlane.prototype + * @readonly + * @type {Cartesian3} + */ + xAxis: { + get: function() { + return this._xAxis; + } + }, + /** + * Gets the local Y-axis (north) of the tangent plane. + * @memberof EllipsoidTangentPlane.prototype + * @readonly + * @type {Cartesian3} + */ + yAxis: { + get: function() { + return this._yAxis; + } + }, + /** + * Gets the local Z-axis (up) of the tangent plane. + * @memberof EllipsoidTangentPlane.prototype + * @readonly + * @type {Cartesian3} + */ + zAxis: { + get: function() { + return this._plane.normal; + } + } +}); +var tmp = new AxisAlignedBoundingBox_default(); +EllipsoidTangentPlane.fromPoints = function(cartesians, ellipsoid) { + Check_default.defined("cartesians", cartesians); + const box = AxisAlignedBoundingBox_default.fromPoints(cartesians, tmp); + return new EllipsoidTangentPlane(box.center, ellipsoid); +}; +var scratchProjectPointOntoPlaneRay = new Ray_default(); +var scratchProjectPointOntoPlaneCartesian3 = new Cartesian3_default(); +EllipsoidTangentPlane.prototype.projectPointOntoPlane = function(cartesian, result) { + Check_default.defined("cartesian", cartesian); + const ray = scratchProjectPointOntoPlaneRay; + ray.origin = cartesian; + Cartesian3_default.normalize(cartesian, ray.direction); + let intersectionPoint = IntersectionTests_default.rayPlane( + ray, + this._plane, + scratchProjectPointOntoPlaneCartesian3 + ); + if (!defined_default(intersectionPoint)) { + Cartesian3_default.negate(ray.direction, ray.direction); + intersectionPoint = IntersectionTests_default.rayPlane( + ray, + this._plane, + scratchProjectPointOntoPlaneCartesian3 + ); + } + if (defined_default(intersectionPoint)) { + const v = Cartesian3_default.subtract( + intersectionPoint, + this._origin, + intersectionPoint + ); + const x = Cartesian3_default.dot(this._xAxis, v); + const y = Cartesian3_default.dot(this._yAxis, v); + if (!defined_default(result)) { + return new Cartesian2_default(x, y); + } + result.x = x; + result.y = y; + return result; + } + return void 0; +}; +EllipsoidTangentPlane.prototype.projectPointsOntoPlane = function(cartesians, result) { + Check_default.defined("cartesians", cartesians); + if (!defined_default(result)) { + result = []; + } + let count = 0; + const length = cartesians.length; + for (let i = 0; i < length; i++) { + const p = this.projectPointOntoPlane(cartesians[i], result[count]); + if (defined_default(p)) { + result[count] = p; + count++; + } + } + result.length = count; + return result; +}; +EllipsoidTangentPlane.prototype.projectPointToNearestOnPlane = function(cartesian, result) { + Check_default.defined("cartesian", cartesian); + if (!defined_default(result)) { + result = new Cartesian2_default(); + } + const ray = scratchProjectPointOntoPlaneRay; + ray.origin = cartesian; + Cartesian3_default.clone(this._plane.normal, ray.direction); + let intersectionPoint = IntersectionTests_default.rayPlane( + ray, + this._plane, + scratchProjectPointOntoPlaneCartesian3 + ); + if (!defined_default(intersectionPoint)) { + Cartesian3_default.negate(ray.direction, ray.direction); + intersectionPoint = IntersectionTests_default.rayPlane( + ray, + this._plane, + scratchProjectPointOntoPlaneCartesian3 + ); + } + const v = Cartesian3_default.subtract( + intersectionPoint, + this._origin, + intersectionPoint + ); + const x = Cartesian3_default.dot(this._xAxis, v); + const y = Cartesian3_default.dot(this._yAxis, v); + result.x = x; + result.y = y; + return result; +}; +EllipsoidTangentPlane.prototype.projectPointsToNearestOnPlane = function(cartesians, result) { + Check_default.defined("cartesians", cartesians); + if (!defined_default(result)) { + result = []; + } + const length = cartesians.length; + result.length = length; + for (let i = 0; i < length; i++) { + result[i] = this.projectPointToNearestOnPlane(cartesians[i], result[i]); + } + return result; +}; +var projectPointsOntoEllipsoidScratch = new Cartesian3_default(); +EllipsoidTangentPlane.prototype.projectPointOntoEllipsoid = function(cartesian, result) { + Check_default.defined("cartesian", cartesian); + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + const ellipsoid = this._ellipsoid; + const origin = this._origin; + const xAxis = this._xAxis; + const yAxis = this._yAxis; + const tmp2 = projectPointsOntoEllipsoidScratch; + Cartesian3_default.multiplyByScalar(xAxis, cartesian.x, tmp2); + result = Cartesian3_default.add(origin, tmp2, result); + Cartesian3_default.multiplyByScalar(yAxis, cartesian.y, tmp2); + Cartesian3_default.add(result, tmp2, result); + ellipsoid.scaleToGeocentricSurface(result, result); + return result; +}; +EllipsoidTangentPlane.prototype.projectPointsOntoEllipsoid = function(cartesians, result) { + Check_default.defined("cartesians", cartesians); + const length = cartesians.length; + if (!defined_default(result)) { + result = new Array(length); + } else { + result.length = length; + } + for (let i = 0; i < length; ++i) { + result[i] = this.projectPointOntoEllipsoid(cartesians[i], result[i]); + } + return result; +}; +var EllipsoidTangentPlane_default = EllipsoidTangentPlane; + +export { + EllipsoidTangentPlane_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-4VWUFKYW.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-4VWUFKYW.js new file mode 100644 index 0000000000000000000000000000000000000000..17705c01ee6374edfdb02b2e962a5bd5ed4ad79a --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-4VWUFKYW.js @@ -0,0 +1,368 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + GeometryOffsetAttribute_default +} from "./chunk-A6EA6KIE.js"; +import { + IndexDatatype_default +} from "./chunk-TF5D2H7B.js"; +import { + GeometryAttributes_default +} from "./chunk-N5MMDSD2.js"; +import { + GeometryAttribute_default, + Geometry_default, + PrimitiveType_default +} from "./chunk-UGZGTV5K.js"; +import { + BoundingSphere_default +} from "./chunk-5U4UHRZ2.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default, + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/EllipsoidOutlineGeometry.js +var defaultRadii = new Cartesian3_default(1, 1, 1); +var cos = Math.cos; +var sin = Math.sin; +function EllipsoidOutlineGeometry(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const radii = defaultValue_default(options.radii, defaultRadii); + const innerRadii = defaultValue_default(options.innerRadii, radii); + const minimumClock = defaultValue_default(options.minimumClock, 0); + const maximumClock = defaultValue_default(options.maximumClock, Math_default.TWO_PI); + const minimumCone = defaultValue_default(options.minimumCone, 0); + const maximumCone = defaultValue_default(options.maximumCone, Math_default.PI); + const stackPartitions = Math.round(defaultValue_default(options.stackPartitions, 10)); + const slicePartitions = Math.round(defaultValue_default(options.slicePartitions, 8)); + const subdivisions = Math.round(defaultValue_default(options.subdivisions, 128)); + if (stackPartitions < 1) { + throw new DeveloperError_default("options.stackPartitions cannot be less than 1"); + } + if (slicePartitions < 0) { + throw new DeveloperError_default("options.slicePartitions cannot be less than 0"); + } + if (subdivisions < 0) { + throw new DeveloperError_default( + "options.subdivisions must be greater than or equal to zero." + ); + } + if (defined_default(options.offsetAttribute) && options.offsetAttribute === GeometryOffsetAttribute_default.TOP) { + throw new DeveloperError_default( + "GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry." + ); + } + this._radii = Cartesian3_default.clone(radii); + this._innerRadii = Cartesian3_default.clone(innerRadii); + this._minimumClock = minimumClock; + this._maximumClock = maximumClock; + this._minimumCone = minimumCone; + this._maximumCone = maximumCone; + this._stackPartitions = stackPartitions; + this._slicePartitions = slicePartitions; + this._subdivisions = subdivisions; + this._offsetAttribute = options.offsetAttribute; + this._workerName = "createEllipsoidOutlineGeometry"; +} +EllipsoidOutlineGeometry.packedLength = 2 * Cartesian3_default.packedLength + 8; +EllipsoidOutlineGeometry.pack = function(value, array, startingIndex) { + if (!defined_default(value)) { + throw new DeveloperError_default("value is required"); + } + if (!defined_default(array)) { + throw new DeveloperError_default("array is required"); + } + startingIndex = defaultValue_default(startingIndex, 0); + Cartesian3_default.pack(value._radii, array, startingIndex); + startingIndex += Cartesian3_default.packedLength; + Cartesian3_default.pack(value._innerRadii, array, startingIndex); + startingIndex += Cartesian3_default.packedLength; + array[startingIndex++] = value._minimumClock; + array[startingIndex++] = value._maximumClock; + array[startingIndex++] = value._minimumCone; + array[startingIndex++] = value._maximumCone; + array[startingIndex++] = value._stackPartitions; + array[startingIndex++] = value._slicePartitions; + array[startingIndex++] = value._subdivisions; + array[startingIndex] = defaultValue_default(value._offsetAttribute, -1); + return array; +}; +var scratchRadii = new Cartesian3_default(); +var scratchInnerRadii = new Cartesian3_default(); +var scratchOptions = { + radii: scratchRadii, + innerRadii: scratchInnerRadii, + minimumClock: void 0, + maximumClock: void 0, + minimumCone: void 0, + maximumCone: void 0, + stackPartitions: void 0, + slicePartitions: void 0, + subdivisions: void 0, + offsetAttribute: void 0 +}; +EllipsoidOutlineGeometry.unpack = function(array, startingIndex, result) { + if (!defined_default(array)) { + throw new DeveloperError_default("array is required"); + } + startingIndex = defaultValue_default(startingIndex, 0); + const radii = Cartesian3_default.unpack(array, startingIndex, scratchRadii); + startingIndex += Cartesian3_default.packedLength; + const innerRadii = Cartesian3_default.unpack(array, startingIndex, scratchInnerRadii); + startingIndex += Cartesian3_default.packedLength; + const minimumClock = array[startingIndex++]; + const maximumClock = array[startingIndex++]; + const minimumCone = array[startingIndex++]; + const maximumCone = array[startingIndex++]; + const stackPartitions = array[startingIndex++]; + const slicePartitions = array[startingIndex++]; + const subdivisions = array[startingIndex++]; + const offsetAttribute = array[startingIndex]; + if (!defined_default(result)) { + scratchOptions.minimumClock = minimumClock; + scratchOptions.maximumClock = maximumClock; + scratchOptions.minimumCone = minimumCone; + scratchOptions.maximumCone = maximumCone; + scratchOptions.stackPartitions = stackPartitions; + scratchOptions.slicePartitions = slicePartitions; + scratchOptions.subdivisions = subdivisions; + scratchOptions.offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return new EllipsoidOutlineGeometry(scratchOptions); + } + result._radii = Cartesian3_default.clone(radii, result._radii); + result._innerRadii = Cartesian3_default.clone(innerRadii, result._innerRadii); + result._minimumClock = minimumClock; + result._maximumClock = maximumClock; + result._minimumCone = minimumCone; + result._maximumCone = maximumCone; + result._stackPartitions = stackPartitions; + result._slicePartitions = slicePartitions; + result._subdivisions = subdivisions; + result._offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return result; +}; +EllipsoidOutlineGeometry.createGeometry = function(ellipsoidGeometry) { + const radii = ellipsoidGeometry._radii; + if (radii.x <= 0 || radii.y <= 0 || radii.z <= 0) { + return; + } + const innerRadii = ellipsoidGeometry._innerRadii; + if (innerRadii.x <= 0 || innerRadii.y <= 0 || innerRadii.z <= 0) { + return; + } + const minimumClock = ellipsoidGeometry._minimumClock; + const maximumClock = ellipsoidGeometry._maximumClock; + const minimumCone = ellipsoidGeometry._minimumCone; + const maximumCone = ellipsoidGeometry._maximumCone; + const subdivisions = ellipsoidGeometry._subdivisions; + const ellipsoid = Ellipsoid_default.fromCartesian3(radii); + let slicePartitions = ellipsoidGeometry._slicePartitions + 1; + let stackPartitions = ellipsoidGeometry._stackPartitions + 1; + slicePartitions = Math.round( + slicePartitions * Math.abs(maximumClock - minimumClock) / Math_default.TWO_PI + ); + stackPartitions = Math.round( + stackPartitions * Math.abs(maximumCone - minimumCone) / Math_default.PI + ); + if (slicePartitions < 2) { + slicePartitions = 2; + } + if (stackPartitions < 2) { + stackPartitions = 2; + } + let extraIndices = 0; + let vertexMultiplier = 1; + const hasInnerSurface = innerRadii.x !== radii.x || innerRadii.y !== radii.y || innerRadii.z !== radii.z; + let isTopOpen = false; + let isBotOpen = false; + if (hasInnerSurface) { + vertexMultiplier = 2; + if (minimumCone > 0) { + isTopOpen = true; + extraIndices += slicePartitions; + } + if (maximumCone < Math.PI) { + isBotOpen = true; + extraIndices += slicePartitions; + } + } + const vertexCount = subdivisions * vertexMultiplier * (stackPartitions + slicePartitions); + const positions = new Float64Array(vertexCount * 3); + const numIndices = 2 * (vertexCount + extraIndices - (slicePartitions + stackPartitions) * vertexMultiplier); + const indices = IndexDatatype_default.createTypedArray(vertexCount, numIndices); + let i; + let j; + let theta; + let phi; + let index = 0; + const sinPhi = new Array(stackPartitions); + const cosPhi = new Array(stackPartitions); + for (i = 0; i < stackPartitions; i++) { + phi = minimumCone + i * (maximumCone - minimumCone) / (stackPartitions - 1); + sinPhi[i] = sin(phi); + cosPhi[i] = cos(phi); + } + const sinTheta = new Array(subdivisions); + const cosTheta = new Array(subdivisions); + for (i = 0; i < subdivisions; i++) { + theta = minimumClock + i * (maximumClock - minimumClock) / (subdivisions - 1); + sinTheta[i] = sin(theta); + cosTheta[i] = cos(theta); + } + for (i = 0; i < stackPartitions; i++) { + for (j = 0; j < subdivisions; j++) { + positions[index++] = radii.x * sinPhi[i] * cosTheta[j]; + positions[index++] = radii.y * sinPhi[i] * sinTheta[j]; + positions[index++] = radii.z * cosPhi[i]; + } + } + if (hasInnerSurface) { + for (i = 0; i < stackPartitions; i++) { + for (j = 0; j < subdivisions; j++) { + positions[index++] = innerRadii.x * sinPhi[i] * cosTheta[j]; + positions[index++] = innerRadii.y * sinPhi[i] * sinTheta[j]; + positions[index++] = innerRadii.z * cosPhi[i]; + } + } + } + sinPhi.length = subdivisions; + cosPhi.length = subdivisions; + for (i = 0; i < subdivisions; i++) { + phi = minimumCone + i * (maximumCone - minimumCone) / (subdivisions - 1); + sinPhi[i] = sin(phi); + cosPhi[i] = cos(phi); + } + sinTheta.length = slicePartitions; + cosTheta.length = slicePartitions; + for (i = 0; i < slicePartitions; i++) { + theta = minimumClock + i * (maximumClock - minimumClock) / (slicePartitions - 1); + sinTheta[i] = sin(theta); + cosTheta[i] = cos(theta); + } + for (i = 0; i < subdivisions; i++) { + for (j = 0; j < slicePartitions; j++) { + positions[index++] = radii.x * sinPhi[i] * cosTheta[j]; + positions[index++] = radii.y * sinPhi[i] * sinTheta[j]; + positions[index++] = radii.z * cosPhi[i]; + } + } + if (hasInnerSurface) { + for (i = 0; i < subdivisions; i++) { + for (j = 0; j < slicePartitions; j++) { + positions[index++] = innerRadii.x * sinPhi[i] * cosTheta[j]; + positions[index++] = innerRadii.y * sinPhi[i] * sinTheta[j]; + positions[index++] = innerRadii.z * cosPhi[i]; + } + } + } + index = 0; + for (i = 0; i < stackPartitions * vertexMultiplier; i++) { + const topOffset = i * subdivisions; + for (j = 0; j < subdivisions - 1; j++) { + indices[index++] = topOffset + j; + indices[index++] = topOffset + j + 1; + } + } + let offset = stackPartitions * subdivisions * vertexMultiplier; + for (i = 0; i < slicePartitions; i++) { + for (j = 0; j < subdivisions - 1; j++) { + indices[index++] = offset + i + j * slicePartitions; + indices[index++] = offset + i + (j + 1) * slicePartitions; + } + } + if (hasInnerSurface) { + offset = stackPartitions * subdivisions * vertexMultiplier + slicePartitions * subdivisions; + for (i = 0; i < slicePartitions; i++) { + for (j = 0; j < subdivisions - 1; j++) { + indices[index++] = offset + i + j * slicePartitions; + indices[index++] = offset + i + (j + 1) * slicePartitions; + } + } + } + if (hasInnerSurface) { + let outerOffset = stackPartitions * subdivisions * vertexMultiplier; + let innerOffset = outerOffset + subdivisions * slicePartitions; + if (isTopOpen) { + for (i = 0; i < slicePartitions; i++) { + indices[index++] = outerOffset + i; + indices[index++] = innerOffset + i; + } + } + if (isBotOpen) { + outerOffset += subdivisions * slicePartitions - slicePartitions; + innerOffset += subdivisions * slicePartitions - slicePartitions; + for (i = 0; i < slicePartitions; i++) { + indices[index++] = outerOffset + i; + indices[index++] = innerOffset + i; + } + } + } + const attributes = new GeometryAttributes_default({ + position: new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: positions + }) + }); + if (defined_default(ellipsoidGeometry._offsetAttribute)) { + const length = positions.length; + const offsetValue = ellipsoidGeometry._offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1; + const applyOffset = new Uint8Array(length / 3).fill(offsetValue); + attributes.applyOffset = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE, + componentsPerAttribute: 1, + values: applyOffset + }); + } + return new Geometry_default({ + attributes, + indices, + primitiveType: PrimitiveType_default.LINES, + boundingSphere: BoundingSphere_default.fromEllipsoid(ellipsoid), + offsetAttribute: ellipsoidGeometry._offsetAttribute + }); +}; +var EllipsoidOutlineGeometry_default = EllipsoidOutlineGeometry; + +export { + EllipsoidOutlineGeometry_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-527JG4D7.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-527JG4D7.js new file mode 100644 index 0000000000000000000000000000000000000000..8ee37035d360034262133102c19310aa6007b84b --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-527JG4D7.js @@ -0,0 +1,629 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + + +// packages/engine/Source/Core/WebGLConstants.js +var WebGLConstants = { + DEPTH_BUFFER_BIT: 256, + STENCIL_BUFFER_BIT: 1024, + COLOR_BUFFER_BIT: 16384, + POINTS: 0, + LINES: 1, + LINE_LOOP: 2, + LINE_STRIP: 3, + TRIANGLES: 4, + TRIANGLE_STRIP: 5, + TRIANGLE_FAN: 6, + ZERO: 0, + ONE: 1, + SRC_COLOR: 768, + ONE_MINUS_SRC_COLOR: 769, + SRC_ALPHA: 770, + ONE_MINUS_SRC_ALPHA: 771, + DST_ALPHA: 772, + ONE_MINUS_DST_ALPHA: 773, + DST_COLOR: 774, + ONE_MINUS_DST_COLOR: 775, + SRC_ALPHA_SATURATE: 776, + FUNC_ADD: 32774, + BLEND_EQUATION: 32777, + BLEND_EQUATION_RGB: 32777, + // same as BLEND_EQUATION + BLEND_EQUATION_ALPHA: 34877, + FUNC_SUBTRACT: 32778, + FUNC_REVERSE_SUBTRACT: 32779, + BLEND_DST_RGB: 32968, + BLEND_SRC_RGB: 32969, + BLEND_DST_ALPHA: 32970, + BLEND_SRC_ALPHA: 32971, + CONSTANT_COLOR: 32769, + ONE_MINUS_CONSTANT_COLOR: 32770, + CONSTANT_ALPHA: 32771, + ONE_MINUS_CONSTANT_ALPHA: 32772, + BLEND_COLOR: 32773, + ARRAY_BUFFER: 34962, + ELEMENT_ARRAY_BUFFER: 34963, + ARRAY_BUFFER_BINDING: 34964, + ELEMENT_ARRAY_BUFFER_BINDING: 34965, + STREAM_DRAW: 35040, + STATIC_DRAW: 35044, + DYNAMIC_DRAW: 35048, + BUFFER_SIZE: 34660, + BUFFER_USAGE: 34661, + CURRENT_VERTEX_ATTRIB: 34342, + FRONT: 1028, + BACK: 1029, + FRONT_AND_BACK: 1032, + CULL_FACE: 2884, + BLEND: 3042, + DITHER: 3024, + STENCIL_TEST: 2960, + DEPTH_TEST: 2929, + SCISSOR_TEST: 3089, + POLYGON_OFFSET_FILL: 32823, + SAMPLE_ALPHA_TO_COVERAGE: 32926, + SAMPLE_COVERAGE: 32928, + NO_ERROR: 0, + INVALID_ENUM: 1280, + INVALID_VALUE: 1281, + INVALID_OPERATION: 1282, + OUT_OF_MEMORY: 1285, + CW: 2304, + CCW: 2305, + LINE_WIDTH: 2849, + ALIASED_POINT_SIZE_RANGE: 33901, + ALIASED_LINE_WIDTH_RANGE: 33902, + CULL_FACE_MODE: 2885, + FRONT_FACE: 2886, + DEPTH_RANGE: 2928, + DEPTH_WRITEMASK: 2930, + DEPTH_CLEAR_VALUE: 2931, + DEPTH_FUNC: 2932, + STENCIL_CLEAR_VALUE: 2961, + STENCIL_FUNC: 2962, + STENCIL_FAIL: 2964, + STENCIL_PASS_DEPTH_FAIL: 2965, + STENCIL_PASS_DEPTH_PASS: 2966, + STENCIL_REF: 2967, + STENCIL_VALUE_MASK: 2963, + STENCIL_WRITEMASK: 2968, + STENCIL_BACK_FUNC: 34816, + STENCIL_BACK_FAIL: 34817, + STENCIL_BACK_PASS_DEPTH_FAIL: 34818, + STENCIL_BACK_PASS_DEPTH_PASS: 34819, + STENCIL_BACK_REF: 36003, + STENCIL_BACK_VALUE_MASK: 36004, + STENCIL_BACK_WRITEMASK: 36005, + VIEWPORT: 2978, + SCISSOR_BOX: 3088, + COLOR_CLEAR_VALUE: 3106, + COLOR_WRITEMASK: 3107, + UNPACK_ALIGNMENT: 3317, + PACK_ALIGNMENT: 3333, + MAX_TEXTURE_SIZE: 3379, + MAX_VIEWPORT_DIMS: 3386, + SUBPIXEL_BITS: 3408, + RED_BITS: 3410, + GREEN_BITS: 3411, + BLUE_BITS: 3412, + ALPHA_BITS: 3413, + DEPTH_BITS: 3414, + STENCIL_BITS: 3415, + POLYGON_OFFSET_UNITS: 10752, + POLYGON_OFFSET_FACTOR: 32824, + TEXTURE_BINDING_2D: 32873, + SAMPLE_BUFFERS: 32936, + SAMPLES: 32937, + SAMPLE_COVERAGE_VALUE: 32938, + SAMPLE_COVERAGE_INVERT: 32939, + COMPRESSED_TEXTURE_FORMATS: 34467, + DONT_CARE: 4352, + FASTEST: 4353, + NICEST: 4354, + GENERATE_MIPMAP_HINT: 33170, + BYTE: 5120, + UNSIGNED_BYTE: 5121, + SHORT: 5122, + UNSIGNED_SHORT: 5123, + INT: 5124, + UNSIGNED_INT: 5125, + FLOAT: 5126, + DEPTH_COMPONENT: 6402, + ALPHA: 6406, + RGB: 6407, + RGBA: 6408, + LUMINANCE: 6409, + LUMINANCE_ALPHA: 6410, + UNSIGNED_SHORT_4_4_4_4: 32819, + UNSIGNED_SHORT_5_5_5_1: 32820, + UNSIGNED_SHORT_5_6_5: 33635, + FRAGMENT_SHADER: 35632, + VERTEX_SHADER: 35633, + MAX_VERTEX_ATTRIBS: 34921, + MAX_VERTEX_UNIFORM_VECTORS: 36347, + MAX_VARYING_VECTORS: 36348, + MAX_COMBINED_TEXTURE_IMAGE_UNITS: 35661, + MAX_VERTEX_TEXTURE_IMAGE_UNITS: 35660, + MAX_TEXTURE_IMAGE_UNITS: 34930, + MAX_FRAGMENT_UNIFORM_VECTORS: 36349, + SHADER_TYPE: 35663, + DELETE_STATUS: 35712, + LINK_STATUS: 35714, + VALIDATE_STATUS: 35715, + ATTACHED_SHADERS: 35717, + ACTIVE_UNIFORMS: 35718, + ACTIVE_ATTRIBUTES: 35721, + SHADING_LANGUAGE_VERSION: 35724, + CURRENT_PROGRAM: 35725, + NEVER: 512, + LESS: 513, + EQUAL: 514, + LEQUAL: 515, + GREATER: 516, + NOTEQUAL: 517, + GEQUAL: 518, + ALWAYS: 519, + KEEP: 7680, + REPLACE: 7681, + INCR: 7682, + DECR: 7683, + INVERT: 5386, + INCR_WRAP: 34055, + DECR_WRAP: 34056, + VENDOR: 7936, + RENDERER: 7937, + VERSION: 7938, + NEAREST: 9728, + LINEAR: 9729, + NEAREST_MIPMAP_NEAREST: 9984, + LINEAR_MIPMAP_NEAREST: 9985, + NEAREST_MIPMAP_LINEAR: 9986, + LINEAR_MIPMAP_LINEAR: 9987, + TEXTURE_MAG_FILTER: 10240, + TEXTURE_MIN_FILTER: 10241, + TEXTURE_WRAP_S: 10242, + TEXTURE_WRAP_T: 10243, + TEXTURE_2D: 3553, + TEXTURE: 5890, + TEXTURE_CUBE_MAP: 34067, + TEXTURE_BINDING_CUBE_MAP: 34068, + TEXTURE_CUBE_MAP_POSITIVE_X: 34069, + TEXTURE_CUBE_MAP_NEGATIVE_X: 34070, + TEXTURE_CUBE_MAP_POSITIVE_Y: 34071, + TEXTURE_CUBE_MAP_NEGATIVE_Y: 34072, + TEXTURE_CUBE_MAP_POSITIVE_Z: 34073, + TEXTURE_CUBE_MAP_NEGATIVE_Z: 34074, + MAX_CUBE_MAP_TEXTURE_SIZE: 34076, + TEXTURE0: 33984, + TEXTURE1: 33985, + TEXTURE2: 33986, + TEXTURE3: 33987, + TEXTURE4: 33988, + TEXTURE5: 33989, + TEXTURE6: 33990, + TEXTURE7: 33991, + TEXTURE8: 33992, + TEXTURE9: 33993, + TEXTURE10: 33994, + TEXTURE11: 33995, + TEXTURE12: 33996, + TEXTURE13: 33997, + TEXTURE14: 33998, + TEXTURE15: 33999, + TEXTURE16: 34e3, + TEXTURE17: 34001, + TEXTURE18: 34002, + TEXTURE19: 34003, + TEXTURE20: 34004, + TEXTURE21: 34005, + TEXTURE22: 34006, + TEXTURE23: 34007, + TEXTURE24: 34008, + TEXTURE25: 34009, + TEXTURE26: 34010, + TEXTURE27: 34011, + TEXTURE28: 34012, + TEXTURE29: 34013, + TEXTURE30: 34014, + TEXTURE31: 34015, + ACTIVE_TEXTURE: 34016, + REPEAT: 10497, + CLAMP_TO_EDGE: 33071, + MIRRORED_REPEAT: 33648, + FLOAT_VEC2: 35664, + FLOAT_VEC3: 35665, + FLOAT_VEC4: 35666, + INT_VEC2: 35667, + INT_VEC3: 35668, + INT_VEC4: 35669, + BOOL: 35670, + BOOL_VEC2: 35671, + BOOL_VEC3: 35672, + BOOL_VEC4: 35673, + FLOAT_MAT2: 35674, + FLOAT_MAT3: 35675, + FLOAT_MAT4: 35676, + SAMPLER_2D: 35678, + SAMPLER_CUBE: 35680, + VERTEX_ATTRIB_ARRAY_ENABLED: 34338, + VERTEX_ATTRIB_ARRAY_SIZE: 34339, + VERTEX_ATTRIB_ARRAY_STRIDE: 34340, + VERTEX_ATTRIB_ARRAY_TYPE: 34341, + VERTEX_ATTRIB_ARRAY_NORMALIZED: 34922, + VERTEX_ATTRIB_ARRAY_POINTER: 34373, + VERTEX_ATTRIB_ARRAY_BUFFER_BINDING: 34975, + IMPLEMENTATION_COLOR_READ_TYPE: 35738, + IMPLEMENTATION_COLOR_READ_FORMAT: 35739, + COMPILE_STATUS: 35713, + LOW_FLOAT: 36336, + MEDIUM_FLOAT: 36337, + HIGH_FLOAT: 36338, + LOW_INT: 36339, + MEDIUM_INT: 36340, + HIGH_INT: 36341, + FRAMEBUFFER: 36160, + RENDERBUFFER: 36161, + RGBA4: 32854, + RGB5_A1: 32855, + RGB565: 36194, + DEPTH_COMPONENT16: 33189, + STENCIL_INDEX: 6401, + STENCIL_INDEX8: 36168, + DEPTH_STENCIL: 34041, + RENDERBUFFER_WIDTH: 36162, + RENDERBUFFER_HEIGHT: 36163, + RENDERBUFFER_INTERNAL_FORMAT: 36164, + RENDERBUFFER_RED_SIZE: 36176, + RENDERBUFFER_GREEN_SIZE: 36177, + RENDERBUFFER_BLUE_SIZE: 36178, + RENDERBUFFER_ALPHA_SIZE: 36179, + RENDERBUFFER_DEPTH_SIZE: 36180, + RENDERBUFFER_STENCIL_SIZE: 36181, + FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE: 36048, + FRAMEBUFFER_ATTACHMENT_OBJECT_NAME: 36049, + FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL: 36050, + FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE: 36051, + COLOR_ATTACHMENT0: 36064, + DEPTH_ATTACHMENT: 36096, + STENCIL_ATTACHMENT: 36128, + DEPTH_STENCIL_ATTACHMENT: 33306, + NONE: 0, + FRAMEBUFFER_COMPLETE: 36053, + FRAMEBUFFER_INCOMPLETE_ATTACHMENT: 36054, + FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT: 36055, + FRAMEBUFFER_INCOMPLETE_DIMENSIONS: 36057, + FRAMEBUFFER_UNSUPPORTED: 36061, + FRAMEBUFFER_BINDING: 36006, + RENDERBUFFER_BINDING: 36007, + MAX_RENDERBUFFER_SIZE: 34024, + INVALID_FRAMEBUFFER_OPERATION: 1286, + UNPACK_FLIP_Y_WEBGL: 37440, + UNPACK_PREMULTIPLY_ALPHA_WEBGL: 37441, + CONTEXT_LOST_WEBGL: 37442, + UNPACK_COLORSPACE_CONVERSION_WEBGL: 37443, + BROWSER_DEFAULT_WEBGL: 37444, + // WEBGL_compressed_texture_s3tc + COMPRESSED_RGB_S3TC_DXT1_EXT: 33776, + COMPRESSED_RGBA_S3TC_DXT1_EXT: 33777, + COMPRESSED_RGBA_S3TC_DXT3_EXT: 33778, + COMPRESSED_RGBA_S3TC_DXT5_EXT: 33779, + // WEBGL_compressed_texture_pvrtc + COMPRESSED_RGB_PVRTC_4BPPV1_IMG: 35840, + COMPRESSED_RGB_PVRTC_2BPPV1_IMG: 35841, + COMPRESSED_RGBA_PVRTC_4BPPV1_IMG: 35842, + COMPRESSED_RGBA_PVRTC_2BPPV1_IMG: 35843, + // WEBGL_compressed_texture_astc + COMPRESSED_RGBA_ASTC_4x4_WEBGL: 37808, + // WEBGL_compressed_texture_etc1 + COMPRESSED_RGB_ETC1_WEBGL: 36196, + // EXT_texture_compression_bptc + COMPRESSED_RGBA_BPTC_UNORM: 36492, + // EXT_color_buffer_half_float + HALF_FLOAT_OES: 36193, + // Desktop OpenGL + DOUBLE: 5130, + // WebGL 2 + READ_BUFFER: 3074, + UNPACK_ROW_LENGTH: 3314, + UNPACK_SKIP_ROWS: 3315, + UNPACK_SKIP_PIXELS: 3316, + PACK_ROW_LENGTH: 3330, + PACK_SKIP_ROWS: 3331, + PACK_SKIP_PIXELS: 3332, + COLOR: 6144, + DEPTH: 6145, + STENCIL: 6146, + RED: 6403, + RGB8: 32849, + RGBA8: 32856, + RGB10_A2: 32857, + TEXTURE_BINDING_3D: 32874, + UNPACK_SKIP_IMAGES: 32877, + UNPACK_IMAGE_HEIGHT: 32878, + TEXTURE_3D: 32879, + TEXTURE_WRAP_R: 32882, + MAX_3D_TEXTURE_SIZE: 32883, + UNSIGNED_INT_2_10_10_10_REV: 33640, + MAX_ELEMENTS_VERTICES: 33e3, + MAX_ELEMENTS_INDICES: 33001, + TEXTURE_MIN_LOD: 33082, + TEXTURE_MAX_LOD: 33083, + TEXTURE_BASE_LEVEL: 33084, + TEXTURE_MAX_LEVEL: 33085, + MIN: 32775, + MAX: 32776, + DEPTH_COMPONENT24: 33190, + MAX_TEXTURE_LOD_BIAS: 34045, + TEXTURE_COMPARE_MODE: 34892, + TEXTURE_COMPARE_FUNC: 34893, + CURRENT_QUERY: 34917, + QUERY_RESULT: 34918, + QUERY_RESULT_AVAILABLE: 34919, + STREAM_READ: 35041, + STREAM_COPY: 35042, + STATIC_READ: 35045, + STATIC_COPY: 35046, + DYNAMIC_READ: 35049, + DYNAMIC_COPY: 35050, + MAX_DRAW_BUFFERS: 34852, + DRAW_BUFFER0: 34853, + DRAW_BUFFER1: 34854, + DRAW_BUFFER2: 34855, + DRAW_BUFFER3: 34856, + DRAW_BUFFER4: 34857, + DRAW_BUFFER5: 34858, + DRAW_BUFFER6: 34859, + DRAW_BUFFER7: 34860, + DRAW_BUFFER8: 34861, + DRAW_BUFFER9: 34862, + DRAW_BUFFER10: 34863, + DRAW_BUFFER11: 34864, + DRAW_BUFFER12: 34865, + DRAW_BUFFER13: 34866, + DRAW_BUFFER14: 34867, + DRAW_BUFFER15: 34868, + MAX_FRAGMENT_UNIFORM_COMPONENTS: 35657, + MAX_VERTEX_UNIFORM_COMPONENTS: 35658, + SAMPLER_3D: 35679, + SAMPLER_2D_SHADOW: 35682, + FRAGMENT_SHADER_DERIVATIVE_HINT: 35723, + PIXEL_PACK_BUFFER: 35051, + PIXEL_UNPACK_BUFFER: 35052, + PIXEL_PACK_BUFFER_BINDING: 35053, + PIXEL_UNPACK_BUFFER_BINDING: 35055, + FLOAT_MAT2x3: 35685, + FLOAT_MAT2x4: 35686, + FLOAT_MAT3x2: 35687, + FLOAT_MAT3x4: 35688, + FLOAT_MAT4x2: 35689, + FLOAT_MAT4x3: 35690, + SRGB: 35904, + SRGB8: 35905, + SRGB8_ALPHA8: 35907, + COMPARE_REF_TO_TEXTURE: 34894, + RGBA32F: 34836, + RGB32F: 34837, + RGBA16F: 34842, + RGB16F: 34843, + VERTEX_ATTRIB_ARRAY_INTEGER: 35069, + MAX_ARRAY_TEXTURE_LAYERS: 35071, + MIN_PROGRAM_TEXEL_OFFSET: 35076, + MAX_PROGRAM_TEXEL_OFFSET: 35077, + MAX_VARYING_COMPONENTS: 35659, + TEXTURE_2D_ARRAY: 35866, + TEXTURE_BINDING_2D_ARRAY: 35869, + R11F_G11F_B10F: 35898, + UNSIGNED_INT_10F_11F_11F_REV: 35899, + RGB9_E5: 35901, + UNSIGNED_INT_5_9_9_9_REV: 35902, + TRANSFORM_FEEDBACK_BUFFER_MODE: 35967, + MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS: 35968, + TRANSFORM_FEEDBACK_VARYINGS: 35971, + TRANSFORM_FEEDBACK_BUFFER_START: 35972, + TRANSFORM_FEEDBACK_BUFFER_SIZE: 35973, + TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN: 35976, + RASTERIZER_DISCARD: 35977, + MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS: 35978, + MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS: 35979, + INTERLEAVED_ATTRIBS: 35980, + SEPARATE_ATTRIBS: 35981, + TRANSFORM_FEEDBACK_BUFFER: 35982, + TRANSFORM_FEEDBACK_BUFFER_BINDING: 35983, + RGBA32UI: 36208, + RGB32UI: 36209, + RGBA16UI: 36214, + RGB16UI: 36215, + RGBA8UI: 36220, + RGB8UI: 36221, + RGBA32I: 36226, + RGB32I: 36227, + RGBA16I: 36232, + RGB16I: 36233, + RGBA8I: 36238, + RGB8I: 36239, + RED_INTEGER: 36244, + RGB_INTEGER: 36248, + RGBA_INTEGER: 36249, + SAMPLER_2D_ARRAY: 36289, + SAMPLER_2D_ARRAY_SHADOW: 36292, + SAMPLER_CUBE_SHADOW: 36293, + UNSIGNED_INT_VEC2: 36294, + UNSIGNED_INT_VEC3: 36295, + UNSIGNED_INT_VEC4: 36296, + INT_SAMPLER_2D: 36298, + INT_SAMPLER_3D: 36299, + INT_SAMPLER_CUBE: 36300, + INT_SAMPLER_2D_ARRAY: 36303, + UNSIGNED_INT_SAMPLER_2D: 36306, + UNSIGNED_INT_SAMPLER_3D: 36307, + UNSIGNED_INT_SAMPLER_CUBE: 36308, + UNSIGNED_INT_SAMPLER_2D_ARRAY: 36311, + DEPTH_COMPONENT32F: 36012, + DEPTH32F_STENCIL8: 36013, + FLOAT_32_UNSIGNED_INT_24_8_REV: 36269, + FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING: 33296, + FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE: 33297, + FRAMEBUFFER_ATTACHMENT_RED_SIZE: 33298, + FRAMEBUFFER_ATTACHMENT_GREEN_SIZE: 33299, + FRAMEBUFFER_ATTACHMENT_BLUE_SIZE: 33300, + FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE: 33301, + FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE: 33302, + FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE: 33303, + FRAMEBUFFER_DEFAULT: 33304, + UNSIGNED_INT_24_8: 34042, + DEPTH24_STENCIL8: 35056, + UNSIGNED_NORMALIZED: 35863, + DRAW_FRAMEBUFFER_BINDING: 36006, + // Same as FRAMEBUFFER_BINDING + READ_FRAMEBUFFER: 36008, + DRAW_FRAMEBUFFER: 36009, + READ_FRAMEBUFFER_BINDING: 36010, + RENDERBUFFER_SAMPLES: 36011, + FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER: 36052, + MAX_COLOR_ATTACHMENTS: 36063, + COLOR_ATTACHMENT1: 36065, + COLOR_ATTACHMENT2: 36066, + COLOR_ATTACHMENT3: 36067, + COLOR_ATTACHMENT4: 36068, + COLOR_ATTACHMENT5: 36069, + COLOR_ATTACHMENT6: 36070, + COLOR_ATTACHMENT7: 36071, + COLOR_ATTACHMENT8: 36072, + COLOR_ATTACHMENT9: 36073, + COLOR_ATTACHMENT10: 36074, + COLOR_ATTACHMENT11: 36075, + COLOR_ATTACHMENT12: 36076, + COLOR_ATTACHMENT13: 36077, + COLOR_ATTACHMENT14: 36078, + COLOR_ATTACHMENT15: 36079, + FRAMEBUFFER_INCOMPLETE_MULTISAMPLE: 36182, + MAX_SAMPLES: 36183, + HALF_FLOAT: 5131, + RG: 33319, + RG_INTEGER: 33320, + R8: 33321, + RG8: 33323, + R16F: 33325, + R32F: 33326, + RG16F: 33327, + RG32F: 33328, + R8I: 33329, + R8UI: 33330, + R16I: 33331, + R16UI: 33332, + R32I: 33333, + R32UI: 33334, + RG8I: 33335, + RG8UI: 33336, + RG16I: 33337, + RG16UI: 33338, + RG32I: 33339, + RG32UI: 33340, + VERTEX_ARRAY_BINDING: 34229, + R8_SNORM: 36756, + RG8_SNORM: 36757, + RGB8_SNORM: 36758, + RGBA8_SNORM: 36759, + SIGNED_NORMALIZED: 36764, + COPY_READ_BUFFER: 36662, + COPY_WRITE_BUFFER: 36663, + COPY_READ_BUFFER_BINDING: 36662, + // Same as COPY_READ_BUFFER + COPY_WRITE_BUFFER_BINDING: 36663, + // Same as COPY_WRITE_BUFFER + UNIFORM_BUFFER: 35345, + UNIFORM_BUFFER_BINDING: 35368, + UNIFORM_BUFFER_START: 35369, + UNIFORM_BUFFER_SIZE: 35370, + MAX_VERTEX_UNIFORM_BLOCKS: 35371, + MAX_FRAGMENT_UNIFORM_BLOCKS: 35373, + MAX_COMBINED_UNIFORM_BLOCKS: 35374, + MAX_UNIFORM_BUFFER_BINDINGS: 35375, + MAX_UNIFORM_BLOCK_SIZE: 35376, + MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS: 35377, + MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS: 35379, + UNIFORM_BUFFER_OFFSET_ALIGNMENT: 35380, + ACTIVE_UNIFORM_BLOCKS: 35382, + UNIFORM_TYPE: 35383, + UNIFORM_SIZE: 35384, + UNIFORM_BLOCK_INDEX: 35386, + UNIFORM_OFFSET: 35387, + UNIFORM_ARRAY_STRIDE: 35388, + UNIFORM_MATRIX_STRIDE: 35389, + UNIFORM_IS_ROW_MAJOR: 35390, + UNIFORM_BLOCK_BINDING: 35391, + UNIFORM_BLOCK_DATA_SIZE: 35392, + UNIFORM_BLOCK_ACTIVE_UNIFORMS: 35394, + UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES: 35395, + UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER: 35396, + UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER: 35398, + INVALID_INDEX: 4294967295, + MAX_VERTEX_OUTPUT_COMPONENTS: 37154, + MAX_FRAGMENT_INPUT_COMPONENTS: 37157, + MAX_SERVER_WAIT_TIMEOUT: 37137, + OBJECT_TYPE: 37138, + SYNC_CONDITION: 37139, + SYNC_STATUS: 37140, + SYNC_FLAGS: 37141, + SYNC_FENCE: 37142, + SYNC_GPU_COMMANDS_COMPLETE: 37143, + UNSIGNALED: 37144, + SIGNALED: 37145, + ALREADY_SIGNALED: 37146, + TIMEOUT_EXPIRED: 37147, + CONDITION_SATISFIED: 37148, + WAIT_FAILED: 37149, + SYNC_FLUSH_COMMANDS_BIT: 1, + VERTEX_ATTRIB_ARRAY_DIVISOR: 35070, + ANY_SAMPLES_PASSED: 35887, + ANY_SAMPLES_PASSED_CONSERVATIVE: 36202, + SAMPLER_BINDING: 35097, + RGB10_A2UI: 36975, + INT_2_10_10_10_REV: 36255, + TRANSFORM_FEEDBACK: 36386, + TRANSFORM_FEEDBACK_PAUSED: 36387, + TRANSFORM_FEEDBACK_ACTIVE: 36388, + TRANSFORM_FEEDBACK_BINDING: 36389, + COMPRESSED_R11_EAC: 37488, + COMPRESSED_SIGNED_R11_EAC: 37489, + COMPRESSED_RG11_EAC: 37490, + COMPRESSED_SIGNED_RG11_EAC: 37491, + COMPRESSED_RGB8_ETC2: 37492, + COMPRESSED_SRGB8_ETC2: 37493, + COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2: 37494, + COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2: 37495, + COMPRESSED_RGBA8_ETC2_EAC: 37496, + COMPRESSED_SRGB8_ALPHA8_ETC2_EAC: 37497, + TEXTURE_IMMUTABLE_FORMAT: 37167, + MAX_ELEMENT_INDEX: 36203, + TEXTURE_IMMUTABLE_LEVELS: 33503, + // Extensions + MAX_TEXTURE_MAX_ANISOTROPY_EXT: 34047 +}; +var WebGLConstants_default = Object.freeze(WebGLConstants); + +export { + WebGLConstants_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-5U4UHRZ2.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-5U4UHRZ2.js new file mode 100644 index 0000000000000000000000000000000000000000..6b6690662323c34123e73222ee6d652cad91d04f --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-5U4UHRZ2.js @@ -0,0 +1,8644 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + combine_default +} from "./chunk-FE2XG3SS.js"; +import { + Cartesian2_default, + Cartesian4_default, + Matrix4_default, + Rectangle_default +} from "./chunk-PW5CA4MJ.js"; +import { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + RuntimeError_default +} from "./chunk-FVDTKX3F.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + __commonJS, + __require, + __toESM, + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// node_modules/urijs/src/punycode.js +var require_punycode = __commonJS({ + "node_modules/urijs/src/punycode.js"(exports, module) { + /*! https://mths.be/punycode v1.4.0 by @mathias */ + (function(root) { + var freeExports = typeof exports == "object" && exports && !exports.nodeType && exports; + var freeModule = typeof module == "object" && module && !module.nodeType && module; + var freeGlobal = typeof global == "object" && global; + if (freeGlobal.global === freeGlobal || freeGlobal.window === freeGlobal || freeGlobal.self === freeGlobal) { + root = freeGlobal; + } + var punycode, maxInt = 2147483647, base = 36, tMin = 1, tMax = 26, skew = 38, damp = 700, initialBias = 72, initialN = 128, delimiter = "-", regexPunycode = /^xn--/, regexNonASCII = /[^\x20-\x7E]/, regexSeparators = /[\x2E\u3002\uFF0E\uFF61]/g, errors = { + "overflow": "Overflow: input needs wider integers to process", + "not-basic": "Illegal input >= 0x80 (not a basic code point)", + "invalid-input": "Invalid input" + }, baseMinusTMin = base - tMin, floor = Math.floor, stringFromCharCode = String.fromCharCode, key; + function error(type) { + throw new RangeError(errors[type]); + } + function map(array, fn) { + var length = array.length; + var result = []; + while (length--) { + result[length] = fn(array[length]); + } + return result; + } + function mapDomain(string, fn) { + var parts = string.split("@"); + var result = ""; + if (parts.length > 1) { + result = parts[0] + "@"; + string = parts[1]; + } + string = string.replace(regexSeparators, "."); + var labels = string.split("."); + var encoded = map(labels, fn).join("."); + return result + encoded; + } + function ucs2decode(string) { + var output = [], counter = 0, length = string.length, value, extra; + while (counter < length) { + value = string.charCodeAt(counter++); + if (value >= 55296 && value <= 56319 && counter < length) { + extra = string.charCodeAt(counter++); + if ((extra & 64512) == 56320) { + output.push(((value & 1023) << 10) + (extra & 1023) + 65536); + } else { + output.push(value); + counter--; + } + } else { + output.push(value); + } + } + return output; + } + function ucs2encode(array) { + return map(array, function(value) { + var output = ""; + if (value > 65535) { + value -= 65536; + output += stringFromCharCode(value >>> 10 & 1023 | 55296); + value = 56320 | value & 1023; + } + output += stringFromCharCode(value); + return output; + }).join(""); + } + function basicToDigit(codePoint) { + if (codePoint - 48 < 10) { + return codePoint - 22; + } + if (codePoint - 65 < 26) { + return codePoint - 65; + } + if (codePoint - 97 < 26) { + return codePoint - 97; + } + return base; + } + function digitToBasic(digit, flag) { + return digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5); + } + function adapt(delta, numPoints, firstTime) { + var k = 0; + delta = firstTime ? floor(delta / damp) : delta >> 1; + delta += floor(delta / numPoints); + for (; delta > baseMinusTMin * tMax >> 1; k += base) { + delta = floor(delta / baseMinusTMin); + } + return floor(k + (baseMinusTMin + 1) * delta / (delta + skew)); + } + function decode(input) { + var output = [], inputLength = input.length, out, i = 0, n = initialN, bias = initialBias, basic, j, index, oldi, w, k, digit, t, baseMinusT; + basic = input.lastIndexOf(delimiter); + if (basic < 0) { + basic = 0; + } + for (j = 0; j < basic; ++j) { + if (input.charCodeAt(j) >= 128) { + error("not-basic"); + } + output.push(input.charCodeAt(j)); + } + for (index = basic > 0 ? basic + 1 : 0; index < inputLength; ) { + for (oldi = i, w = 1, k = base; ; k += base) { + if (index >= inputLength) { + error("invalid-input"); + } + digit = basicToDigit(input.charCodeAt(index++)); + if (digit >= base || digit > floor((maxInt - i) / w)) { + error("overflow"); + } + i += digit * w; + t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias; + if (digit < t) { + break; + } + baseMinusT = base - t; + if (w > floor(maxInt / baseMinusT)) { + error("overflow"); + } + w *= baseMinusT; + } + out = output.length + 1; + bias = adapt(i - oldi, out, oldi == 0); + if (floor(i / out) > maxInt - n) { + error("overflow"); + } + n += floor(i / out); + i %= out; + output.splice(i++, 0, n); + } + return ucs2encode(output); + } + function encode(input) { + var n, delta, handledCPCount, basicLength, bias, j, m, q, k, t, currentValue, output = [], inputLength, handledCPCountPlusOne, baseMinusT, qMinusT; + input = ucs2decode(input); + inputLength = input.length; + n = initialN; + delta = 0; + bias = initialBias; + for (j = 0; j < inputLength; ++j) { + currentValue = input[j]; + if (currentValue < 128) { + output.push(stringFromCharCode(currentValue)); + } + } + handledCPCount = basicLength = output.length; + if (basicLength) { + output.push(delimiter); + } + while (handledCPCount < inputLength) { + for (m = maxInt, j = 0; j < inputLength; ++j) { + currentValue = input[j]; + if (currentValue >= n && currentValue < m) { + m = currentValue; + } + } + handledCPCountPlusOne = handledCPCount + 1; + if (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) { + error("overflow"); + } + delta += (m - n) * handledCPCountPlusOne; + n = m; + for (j = 0; j < inputLength; ++j) { + currentValue = input[j]; + if (currentValue < n && ++delta > maxInt) { + error("overflow"); + } + if (currentValue == n) { + for (q = delta, k = base; ; k += base) { + t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias; + if (q < t) { + break; + } + qMinusT = q - t; + baseMinusT = base - t; + output.push( + stringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0)) + ); + q = floor(qMinusT / baseMinusT); + } + output.push(stringFromCharCode(digitToBasic(q, 0))); + bias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength); + delta = 0; + ++handledCPCount; + } + } + ++delta; + ++n; + } + return output.join(""); + } + function toUnicode(input) { + return mapDomain(input, function(string) { + return regexPunycode.test(string) ? decode(string.slice(4).toLowerCase()) : string; + }); + } + function toASCII(input) { + return mapDomain(input, function(string) { + return regexNonASCII.test(string) ? "xn--" + encode(string) : string; + }); + } + punycode = { + /** + * A string representing the current Punycode.js version number. + * @memberOf punycode + * @type String + */ + "version": "1.3.2", + /** + * An object of methods to convert from JavaScript's internal character + * representation (UCS-2) to Unicode code points, and back. + * @see + * @memberOf punycode + * @type Object + */ + "ucs2": { + "decode": ucs2decode, + "encode": ucs2encode + }, + "decode": decode, + "encode": encode, + "toASCII": toASCII, + "toUnicode": toUnicode + }; + if (typeof define == "function" && typeof define.amd == "object" && define.amd) { + define("punycode", function() { + return punycode; + }); + } else if (freeExports && freeModule) { + if (module.exports == freeExports) { + freeModule.exports = punycode; + } else { + for (key in punycode) { + punycode.hasOwnProperty(key) && (freeExports[key] = punycode[key]); + } + } + } else { + root.punycode = punycode; + } + })(exports); + } +}); + +// node_modules/urijs/src/IPv6.js +var require_IPv6 = __commonJS({ + "node_modules/urijs/src/IPv6.js"(exports, module) { + /*! + * URI.js - Mutating URLs + * IPv6 Support + * + * Version: 1.19.11 + * + * Author: Rodney Rehm + * Web: http://medialize.github.io/URI.js/ + * + * Licensed under + * MIT License http://www.opensource.org/licenses/mit-license + * + */ + (function(root, factory) { + "use strict"; + if (typeof module === "object" && module.exports) { + module.exports = factory(); + } else if (typeof define === "function" && define.amd) { + define(factory); + } else { + root.IPv6 = factory(root); + } + })(exports, function(root) { + "use strict"; + var _IPv6 = root && root.IPv6; + function bestPresentation(address) { + var _address = address.toLowerCase(); + var segments = _address.split(":"); + var length = segments.length; + var total = 8; + if (segments[0] === "" && segments[1] === "" && segments[2] === "") { + segments.shift(); + segments.shift(); + } else if (segments[0] === "" && segments[1] === "") { + segments.shift(); + } else if (segments[length - 1] === "" && segments[length - 2] === "") { + segments.pop(); + } + length = segments.length; + if (segments[length - 1].indexOf(".") !== -1) { + total = 7; + } + var pos; + for (pos = 0; pos < length; pos++) { + if (segments[pos] === "") { + break; + } + } + if (pos < total) { + segments.splice(pos, 1, "0000"); + while (segments.length < total) { + segments.splice(pos, 0, "0000"); + } + } + var _segments; + for (var i = 0; i < total; i++) { + _segments = segments[i].split(""); + for (var j = 0; j < 3; j++) { + if (_segments[0] === "0" && _segments.length > 1) { + _segments.splice(0, 1); + } else { + break; + } + } + segments[i] = _segments.join(""); + } + var best = -1; + var _best = 0; + var _current = 0; + var current = -1; + var inzeroes = false; + for (i = 0; i < total; i++) { + if (inzeroes) { + if (segments[i] === "0") { + _current += 1; + } else { + inzeroes = false; + if (_current > _best) { + best = current; + _best = _current; + } + } + } else { + if (segments[i] === "0") { + inzeroes = true; + current = i; + _current = 1; + } + } + } + if (_current > _best) { + best = current; + _best = _current; + } + if (_best > 1) { + segments.splice(best, _best, ""); + } + length = segments.length; + var result = ""; + if (segments[0] === "") { + result = ":"; + } + for (i = 0; i < length; i++) { + result += segments[i]; + if (i === length - 1) { + break; + } + result += ":"; + } + if (segments[length - 1] === "") { + result += ":"; + } + return result; + } + function noConflict() { + if (root.IPv6 === this) { + root.IPv6 = _IPv6; + } + return this; + } + return { + best: bestPresentation, + noConflict + }; + }); + } +}); + +// node_modules/urijs/src/SecondLevelDomains.js +var require_SecondLevelDomains = __commonJS({ + "node_modules/urijs/src/SecondLevelDomains.js"(exports, module) { + /*! + * URI.js - Mutating URLs + * Second Level Domain (SLD) Support + * + * Version: 1.19.11 + * + * Author: Rodney Rehm + * Web: http://medialize.github.io/URI.js/ + * + * Licensed under + * MIT License http://www.opensource.org/licenses/mit-license + * + */ + (function(root, factory) { + "use strict"; + if (typeof module === "object" && module.exports) { + module.exports = factory(); + } else if (typeof define === "function" && define.amd) { + define(factory); + } else { + root.SecondLevelDomains = factory(root); + } + })(exports, function(root) { + "use strict"; + var _SecondLevelDomains = root && root.SecondLevelDomains; + var SLD = { + // list of known Second Level Domains + // converted list of SLDs from https://github.com/gavingmiller/second-level-domains + // ---- + // publicsuffix.org is more current and actually used by a couple of browsers internally. + // downside is it also contains domains like "dyndns.org" - which is fine for the security + // issues browser have to deal with (SOP for cookies, etc) - but is way overboard for URI.js + // ---- + list: { + "ac": " com gov mil net org ", + "ae": " ac co gov mil name net org pro sch ", + "af": " com edu gov net org ", + "al": " com edu gov mil net org ", + "ao": " co ed gv it og pb ", + "ar": " com edu gob gov int mil net org tur ", + "at": " ac co gv or ", + "au": " asn com csiro edu gov id net org ", + "ba": " co com edu gov mil net org rs unbi unmo unsa untz unze ", + "bb": " biz co com edu gov info net org store tv ", + "bh": " biz cc com edu gov info net org ", + "bn": " com edu gov net org ", + "bo": " com edu gob gov int mil net org tv ", + "br": " adm adv agr am arq art ato b bio blog bmd cim cng cnt com coop ecn edu eng esp etc eti far flog fm fnd fot fst g12 ggf gov imb ind inf jor jus lel mat med mil mus net nom not ntr odo org ppg pro psc psi qsl rec slg srv tmp trd tur tv vet vlog wiki zlg ", + "bs": " com edu gov net org ", + "bz": " du et om ov rg ", + "ca": " ab bc mb nb nf nl ns nt nu on pe qc sk yk ", + "ck": " biz co edu gen gov info net org ", + "cn": " ac ah bj com cq edu fj gd gov gs gx gz ha hb he hi hl hn jl js jx ln mil net nm nx org qh sc sd sh sn sx tj tw xj xz yn zj ", + "co": " com edu gov mil net nom org ", + "cr": " ac c co ed fi go or sa ", + "cy": " ac biz com ekloges gov ltd name net org parliament press pro tm ", + "do": " art com edu gob gov mil net org sld web ", + "dz": " art asso com edu gov net org pol ", + "ec": " com edu fin gov info med mil net org pro ", + "eg": " com edu eun gov mil name net org sci ", + "er": " com edu gov ind mil net org rochest w ", + "es": " com edu gob nom org ", + "et": " biz com edu gov info name net org ", + "fj": " ac biz com info mil name net org pro ", + "fk": " ac co gov net nom org ", + "fr": " asso com f gouv nom prd presse tm ", + "gg": " co net org ", + "gh": " com edu gov mil org ", + "gn": " ac com gov net org ", + "gr": " com edu gov mil net org ", + "gt": " com edu gob ind mil net org ", + "gu": " com edu gov net org ", + "hk": " com edu gov idv net org ", + "hu": " 2000 agrar bolt casino city co erotica erotika film forum games hotel info ingatlan jogasz konyvelo lakas media news org priv reklam sex shop sport suli szex tm tozsde utazas video ", + "id": " ac co go mil net or sch web ", + "il": " ac co gov idf k12 muni net org ", + "in": " ac co edu ernet firm gen gov i ind mil net nic org res ", + "iq": " com edu gov i mil net org ", + "ir": " ac co dnssec gov i id net org sch ", + "it": " edu gov ", + "je": " co net org ", + "jo": " com edu gov mil name net org sch ", + "jp": " ac ad co ed go gr lg ne or ", + "ke": " ac co go info me mobi ne or sc ", + "kh": " com edu gov mil net org per ", + "ki": " biz com de edu gov info mob net org tel ", + "km": " asso com coop edu gouv k medecin mil nom notaires pharmaciens presse tm veterinaire ", + "kn": " edu gov net org ", + "kr": " ac busan chungbuk chungnam co daegu daejeon es gangwon go gwangju gyeongbuk gyeonggi gyeongnam hs incheon jeju jeonbuk jeonnam k kg mil ms ne or pe re sc seoul ulsan ", + "kw": " com edu gov net org ", + "ky": " com edu gov net org ", + "kz": " com edu gov mil net org ", + "lb": " com edu gov net org ", + "lk": " assn com edu gov grp hotel int ltd net ngo org sch soc web ", + "lr": " com edu gov net org ", + "lv": " asn com conf edu gov id mil net org ", + "ly": " com edu gov id med net org plc sch ", + "ma": " ac co gov m net org press ", + "mc": " asso tm ", + "me": " ac co edu gov its net org priv ", + "mg": " com edu gov mil nom org prd tm ", + "mk": " com edu gov inf name net org pro ", + "ml": " com edu gov net org presse ", + "mn": " edu gov org ", + "mo": " com edu gov net org ", + "mt": " com edu gov net org ", + "mv": " aero biz com coop edu gov info int mil museum name net org pro ", + "mw": " ac co com coop edu gov int museum net org ", + "mx": " com edu gob net org ", + "my": " com edu gov mil name net org sch ", + "nf": " arts com firm info net other per rec store web ", + "ng": " biz com edu gov mil mobi name net org sch ", + "ni": " ac co com edu gob mil net nom org ", + "np": " com edu gov mil net org ", + "nr": " biz com edu gov info net org ", + "om": " ac biz co com edu gov med mil museum net org pro sch ", + "pe": " com edu gob mil net nom org sld ", + "ph": " com edu gov i mil net ngo org ", + "pk": " biz com edu fam gob gok gon gop gos gov net org web ", + "pl": " art bialystok biz com edu gda gdansk gorzow gov info katowice krakow lodz lublin mil net ngo olsztyn org poznan pwr radom slupsk szczecin torun warszawa waw wroc wroclaw zgora ", + "pr": " ac biz com edu est gov info isla name net org pro prof ", + "ps": " com edu gov net org plo sec ", + "pw": " belau co ed go ne or ", + "ro": " arts com firm info nom nt org rec store tm www ", + "rs": " ac co edu gov in org ", + "sb": " com edu gov net org ", + "sc": " com edu gov net org ", + "sh": " co com edu gov net nom org ", + "sl": " com edu gov net org ", + "st": " co com consulado edu embaixada gov mil net org principe saotome store ", + "sv": " com edu gob org red ", + "sz": " ac co org ", + "tr": " av bbs bel biz com dr edu gen gov info k12 name net org pol tel tsk tv web ", + "tt": " aero biz cat co com coop edu gov info int jobs mil mobi museum name net org pro tel travel ", + "tw": " club com ebiz edu game gov idv mil net org ", + "mu": " ac co com gov net or org ", + "mz": " ac co edu gov org ", + "na": " co com ", + "nz": " ac co cri geek gen govt health iwi maori mil net org parliament school ", + "pa": " abo ac com edu gob ing med net nom org sld ", + "pt": " com edu gov int net nome org publ ", + "py": " com edu gov mil net org ", + "qa": " com edu gov mil net org ", + "re": " asso com nom ", + "ru": " ac adygeya altai amur arkhangelsk astrakhan bashkiria belgorod bir bryansk buryatia cbg chel chelyabinsk chita chukotka chuvashia com dagestan e-burg edu gov grozny int irkutsk ivanovo izhevsk jar joshkar-ola kalmykia kaluga kamchatka karelia kazan kchr kemerovo khabarovsk khakassia khv kirov koenig komi kostroma kranoyarsk kuban kurgan kursk lipetsk magadan mari mari-el marine mil mordovia mosreg msk murmansk nalchik net nnov nov novosibirsk nsk omsk orenburg org oryol penza perm pp pskov ptz rnd ryazan sakhalin samara saratov simbirsk smolensk spb stavropol stv surgut tambov tatarstan tom tomsk tsaritsyn tsk tula tuva tver tyumen udm udmurtia ulan-ude vladikavkaz vladimir vladivostok volgograd vologda voronezh vrn vyatka yakutia yamal yekaterinburg yuzhno-sakhalinsk ", + "rw": " ac co com edu gouv gov int mil net ", + "sa": " com edu gov med net org pub sch ", + "sd": " com edu gov info med net org tv ", + "se": " a ac b bd c d e f g h i k l m n o org p parti pp press r s t tm u w x y z ", + "sg": " com edu gov idn net org per ", + "sn": " art com edu gouv org perso univ ", + "sy": " com edu gov mil net news org ", + "th": " ac co go in mi net or ", + "tj": " ac biz co com edu go gov info int mil name net nic org test web ", + "tn": " agrinet com defense edunet ens fin gov ind info intl mincom nat net org perso rnrt rns rnu tourism ", + "tz": " ac co go ne or ", + "ua": " biz cherkassy chernigov chernovtsy ck cn co com crimea cv dn dnepropetrovsk donetsk dp edu gov if in ivano-frankivsk kh kharkov kherson khmelnitskiy kiev kirovograd km kr ks kv lg lugansk lutsk lviv me mk net nikolaev od odessa org pl poltava pp rovno rv sebastopol sumy te ternopil uzhgorod vinnica vn zaporizhzhe zhitomir zp zt ", + "ug": " ac co go ne or org sc ", + "uk": " ac bl british-library co cym gov govt icnet jet lea ltd me mil mod national-library-scotland nel net nhs nic nls org orgn parliament plc police sch scot soc ", + "us": " dni fed isa kids nsn ", + "uy": " com edu gub mil net org ", + "ve": " co com edu gob info mil net org web ", + "vi": " co com k12 net org ", + "vn": " ac biz com edu gov health info int name net org pro ", + "ye": " co com gov ltd me net org plc ", + "yu": " ac co edu gov org ", + "za": " ac agric alt bourse city co cybernet db edu gov grondar iaccess imt inca landesign law mil net ngo nis nom olivetti org pix school tm web ", + "zm": " ac co com edu gov net org sch ", + // https://en.wikipedia.org/wiki/CentralNic#Second-level_domains + "com": "ar br cn de eu gb gr hu jpn kr no qc ru sa se uk us uy za ", + "net": "gb jp se uk ", + "org": "ae", + "de": "com " + }, + // gorhill 2013-10-25: Using indexOf() instead Regexp(). Significant boost + // in both performance and memory footprint. No initialization required. + // http://jsperf.com/uri-js-sld-regex-vs-binary-search/4 + // Following methods use lastIndexOf() rather than array.split() in order + // to avoid any memory allocations. + has: function(domain) { + var tldOffset = domain.lastIndexOf("."); + if (tldOffset <= 0 || tldOffset >= domain.length - 1) { + return false; + } + var sldOffset = domain.lastIndexOf(".", tldOffset - 1); + if (sldOffset <= 0 || sldOffset >= tldOffset - 1) { + return false; + } + var sldList = SLD.list[domain.slice(tldOffset + 1)]; + if (!sldList) { + return false; + } + return sldList.indexOf(" " + domain.slice(sldOffset + 1, tldOffset) + " ") >= 0; + }, + is: function(domain) { + var tldOffset = domain.lastIndexOf("."); + if (tldOffset <= 0 || tldOffset >= domain.length - 1) { + return false; + } + var sldOffset = domain.lastIndexOf(".", tldOffset - 1); + if (sldOffset >= 0) { + return false; + } + var sldList = SLD.list[domain.slice(tldOffset + 1)]; + if (!sldList) { + return false; + } + return sldList.indexOf(" " + domain.slice(0, tldOffset) + " ") >= 0; + }, + get: function(domain) { + var tldOffset = domain.lastIndexOf("."); + if (tldOffset <= 0 || tldOffset >= domain.length - 1) { + return null; + } + var sldOffset = domain.lastIndexOf(".", tldOffset - 1); + if (sldOffset <= 0 || sldOffset >= tldOffset - 1) { + return null; + } + var sldList = SLD.list[domain.slice(tldOffset + 1)]; + if (!sldList) { + return null; + } + if (sldList.indexOf(" " + domain.slice(sldOffset + 1, tldOffset) + " ") < 0) { + return null; + } + return domain.slice(sldOffset + 1); + }, + noConflict: function() { + if (root.SecondLevelDomains === this) { + root.SecondLevelDomains = _SecondLevelDomains; + } + return this; + } + }; + return SLD; + }); + } +}); + +// node_modules/urijs/src/URI.js +var require_URI = __commonJS({ + "node_modules/urijs/src/URI.js"(exports, module) { + /*! + * URI.js - Mutating URLs + * + * Version: 1.19.11 + * + * Author: Rodney Rehm + * Web: http://medialize.github.io/URI.js/ + * + * Licensed under + * MIT License http://www.opensource.org/licenses/mit-license + * + */ + (function(root, factory) { + "use strict"; + if (typeof module === "object" && module.exports) { + module.exports = factory(require_punycode(), require_IPv6(), require_SecondLevelDomains()); + } else if (typeof define === "function" && define.amd) { + define(["./punycode", "./IPv6", "./SecondLevelDomains"], factory); + } else { + root.URI = factory(root.punycode, root.IPv6, root.SecondLevelDomains, root); + } + })(exports, function(punycode, IPv6, SLD, root) { + "use strict"; + var _URI = root && root.URI; + function URI(url, base) { + var _urlSupplied = arguments.length >= 1; + var _baseSupplied = arguments.length >= 2; + if (!(this instanceof URI)) { + if (_urlSupplied) { + if (_baseSupplied) { + return new URI(url, base); + } + return new URI(url); + } + return new URI(); + } + if (url === void 0) { + if (_urlSupplied) { + throw new TypeError("undefined is not a valid argument for URI"); + } + if (typeof location !== "undefined") { + url = location.href + ""; + } else { + url = ""; + } + } + if (url === null) { + if (_urlSupplied) { + throw new TypeError("null is not a valid argument for URI"); + } + } + this.href(url); + if (base !== void 0) { + return this.absoluteTo(base); + } + return this; + } + function isInteger(value) { + return /^[0-9]+$/.test(value); + } + URI.version = "1.19.11"; + var p = URI.prototype; + var hasOwn = Object.prototype.hasOwnProperty; + function escapeRegEx(string) { + return string.replace(/([.*+?^=!:${}()|[\]\/\\])/g, "\\$1"); + } + function getType(value) { + if (value === void 0) { + return "Undefined"; + } + return String(Object.prototype.toString.call(value)).slice(8, -1); + } + function isArray(obj) { + return getType(obj) === "Array"; + } + function filterArrayValues(data, value) { + var lookup = {}; + var i, length; + if (getType(value) === "RegExp") { + lookup = null; + } else if (isArray(value)) { + for (i = 0, length = value.length; i < length; i++) { + lookup[value[i]] = true; + } + } else { + lookup[value] = true; + } + for (i = 0, length = data.length; i < length; i++) { + var _match = lookup && lookup[data[i]] !== void 0 || !lookup && value.test(data[i]); + if (_match) { + data.splice(i, 1); + length--; + i--; + } + } + return data; + } + function arrayContains(list, value) { + var i, length; + if (isArray(value)) { + for (i = 0, length = value.length; i < length; i++) { + if (!arrayContains(list, value[i])) { + return false; + } + } + return true; + } + var _type = getType(value); + for (i = 0, length = list.length; i < length; i++) { + if (_type === "RegExp") { + if (typeof list[i] === "string" && list[i].match(value)) { + return true; + } + } else if (list[i] === value) { + return true; + } + } + return false; + } + function arraysEqual(one, two) { + if (!isArray(one) || !isArray(two)) { + return false; + } + if (one.length !== two.length) { + return false; + } + one.sort(); + two.sort(); + for (var i = 0, l = one.length; i < l; i++) { + if (one[i] !== two[i]) { + return false; + } + } + return true; + } + function trimSlashes(text) { + var trim_expression = /^\/+|\/+$/g; + return text.replace(trim_expression, ""); + } + URI._parts = function() { + return { + protocol: null, + username: null, + password: null, + hostname: null, + urn: null, + port: null, + path: null, + query: null, + fragment: null, + // state + preventInvalidHostname: URI.preventInvalidHostname, + duplicateQueryParameters: URI.duplicateQueryParameters, + escapeQuerySpace: URI.escapeQuerySpace + }; + }; + URI.preventInvalidHostname = false; + URI.duplicateQueryParameters = false; + URI.escapeQuerySpace = true; + URI.protocol_expression = /^[a-z][a-z0-9.+-]*$/i; + URI.idn_expression = /[^a-z0-9\._-]/i; + URI.punycode_expression = /(xn--)/i; + URI.ip4_expression = /^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/; + URI.ip6_expression = /^\s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(%.+)?\s*$/; + URI.find_uri_expression = /\b((?:[a-z][\w-]+:(?:\/{1,3}|[a-z0-9%])|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))/ig; + URI.findUri = { + // valid "scheme://" or "www." + start: /\b(?:([a-z][a-z0-9.+-]*:\/\/)|www\.)/gi, + // everything up to the next whitespace + end: /[\s\r\n]|$/, + // trim trailing punctuation captured by end RegExp + trim: /[`!()\[\]{};:'".,<>?«»“”„‘’]+$/, + // balanced parens inclusion (), [], {}, <> + parens: /(\([^\)]*\)|\[[^\]]*\]|\{[^}]*\}|<[^>]*>)/g + }; + URI.leading_whitespace_expression = /^[\x00-\x20\u00a0\u1680\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff]+/; + URI.ascii_tab_whitespace = /[\u0009\u000A\u000D]+/g; + URI.defaultPorts = { + http: "80", + https: "443", + ftp: "21", + gopher: "70", + ws: "80", + wss: "443" + }; + URI.hostProtocols = [ + "http", + "https" + ]; + URI.invalid_hostname_characters = /[^a-zA-Z0-9\.\-:_]/; + URI.domAttributes = { + "a": "href", + "blockquote": "cite", + "link": "href", + "base": "href", + "script": "src", + "form": "action", + "img": "src", + "area": "href", + "iframe": "src", + "embed": "src", + "source": "src", + "track": "src", + "input": "src", + // but only if type="image" + "audio": "src", + "video": "src" + }; + URI.getDomAttribute = function(node) { + if (!node || !node.nodeName) { + return void 0; + } + var nodeName = node.nodeName.toLowerCase(); + if (nodeName === "input" && node.type !== "image") { + return void 0; + } + return URI.domAttributes[nodeName]; + }; + function escapeForDumbFirefox36(value) { + return escape(value); + } + function strictEncodeURIComponent(string) { + return encodeURIComponent(string).replace(/[!'()*]/g, escapeForDumbFirefox36).replace(/\*/g, "%2A"); + } + URI.encode = strictEncodeURIComponent; + URI.decode = decodeURIComponent; + URI.iso8859 = function() { + URI.encode = escape; + URI.decode = unescape; + }; + URI.unicode = function() { + URI.encode = strictEncodeURIComponent; + URI.decode = decodeURIComponent; + }; + URI.characters = { + pathname: { + encode: { + // RFC3986 2.1: For consistency, URI producers and normalizers should + // use uppercase hexadecimal digits for all percent-encodings. + expression: /%(24|26|2B|2C|3B|3D|3A|40)/ig, + map: { + // -._~!'()* + "%24": "$", + "%26": "&", + "%2B": "+", + "%2C": ",", + "%3B": ";", + "%3D": "=", + "%3A": ":", + "%40": "@" + } + }, + decode: { + expression: /[\/\?#]/g, + map: { + "/": "%2F", + "?": "%3F", + "#": "%23" + } + } + }, + reserved: { + encode: { + // RFC3986 2.1: For consistency, URI producers and normalizers should + // use uppercase hexadecimal digits for all percent-encodings. + expression: /%(21|23|24|26|27|28|29|2A|2B|2C|2F|3A|3B|3D|3F|40|5B|5D)/ig, + map: { + // gen-delims + "%3A": ":", + "%2F": "/", + "%3F": "?", + "%23": "#", + "%5B": "[", + "%5D": "]", + "%40": "@", + // sub-delims + "%21": "!", + "%24": "$", + "%26": "&", + "%27": "'", + "%28": "(", + "%29": ")", + "%2A": "*", + "%2B": "+", + "%2C": ",", + "%3B": ";", + "%3D": "=" + } + } + }, + urnpath: { + // The characters under `encode` are the characters called out by RFC 2141 as being acceptable + // for usage in a URN. RFC2141 also calls out "-", ".", and "_" as acceptable characters, but + // these aren't encoded by encodeURIComponent, so we don't have to call them out here. Also + // note that the colon character is not featured in the encoding map; this is because URI.js + // gives the colons in URNs semantic meaning as the delimiters of path segements, and so it + // should not appear unencoded in a segment itself. + // See also the note above about RFC3986 and capitalalized hex digits. + encode: { + expression: /%(21|24|27|28|29|2A|2B|2C|3B|3D|40)/ig, + map: { + "%21": "!", + "%24": "$", + "%27": "'", + "%28": "(", + "%29": ")", + "%2A": "*", + "%2B": "+", + "%2C": ",", + "%3B": ";", + "%3D": "=", + "%40": "@" + } + }, + // These characters are the characters called out by RFC2141 as "reserved" characters that + // should never appear in a URN, plus the colon character (see note above). + decode: { + expression: /[\/\?#:]/g, + map: { + "/": "%2F", + "?": "%3F", + "#": "%23", + ":": "%3A" + } + } + } + }; + URI.encodeQuery = function(string, escapeQuerySpace) { + var escaped = URI.encode(string + ""); + if (escapeQuerySpace === void 0) { + escapeQuerySpace = URI.escapeQuerySpace; + } + return escapeQuerySpace ? escaped.replace(/%20/g, "+") : escaped; + }; + URI.decodeQuery = function(string, escapeQuerySpace) { + string += ""; + if (escapeQuerySpace === void 0) { + escapeQuerySpace = URI.escapeQuerySpace; + } + try { + return URI.decode(escapeQuerySpace ? string.replace(/\+/g, "%20") : string); + } catch (e) { + return string; + } + }; + var _parts = { "encode": "encode", "decode": "decode" }; + var _part; + var generateAccessor = function(_group, _part2) { + return function(string) { + try { + return URI[_part2](string + "").replace(URI.characters[_group][_part2].expression, function(c) { + return URI.characters[_group][_part2].map[c]; + }); + } catch (e) { + return string; + } + }; + }; + for (_part in _parts) { + URI[_part + "PathSegment"] = generateAccessor("pathname", _parts[_part]); + URI[_part + "UrnPathSegment"] = generateAccessor("urnpath", _parts[_part]); + } + var generateSegmentedPathFunction = function(_sep, _codingFuncName, _innerCodingFuncName) { + return function(string) { + var actualCodingFunc; + if (!_innerCodingFuncName) { + actualCodingFunc = URI[_codingFuncName]; + } else { + actualCodingFunc = function(string2) { + return URI[_codingFuncName](URI[_innerCodingFuncName](string2)); + }; + } + var segments = (string + "").split(_sep); + for (var i = 0, length = segments.length; i < length; i++) { + segments[i] = actualCodingFunc(segments[i]); + } + return segments.join(_sep); + }; + }; + URI.decodePath = generateSegmentedPathFunction("/", "decodePathSegment"); + URI.decodeUrnPath = generateSegmentedPathFunction(":", "decodeUrnPathSegment"); + URI.recodePath = generateSegmentedPathFunction("/", "encodePathSegment", "decode"); + URI.recodeUrnPath = generateSegmentedPathFunction(":", "encodeUrnPathSegment", "decode"); + URI.encodeReserved = generateAccessor("reserved", "encode"); + URI.parse = function(string, parts) { + var pos; + if (!parts) { + parts = { + preventInvalidHostname: URI.preventInvalidHostname + }; + } + string = string.replace(URI.leading_whitespace_expression, ""); + string = string.replace(URI.ascii_tab_whitespace, ""); + pos = string.indexOf("#"); + if (pos > -1) { + parts.fragment = string.substring(pos + 1) || null; + string = string.substring(0, pos); + } + pos = string.indexOf("?"); + if (pos > -1) { + parts.query = string.substring(pos + 1) || null; + string = string.substring(0, pos); + } + string = string.replace(/^(https?|ftp|wss?)?:+[/\\]*/i, "$1://"); + string = string.replace(/^[/\\]{2,}/i, "//"); + if (string.substring(0, 2) === "//") { + parts.protocol = null; + string = string.substring(2); + string = URI.parseAuthority(string, parts); + } else { + pos = string.indexOf(":"); + if (pos > -1) { + parts.protocol = string.substring(0, pos) || null; + if (parts.protocol && !parts.protocol.match(URI.protocol_expression)) { + parts.protocol = void 0; + } else if (string.substring(pos + 1, pos + 3).replace(/\\/g, "/") === "//") { + string = string.substring(pos + 3); + string = URI.parseAuthority(string, parts); + } else { + string = string.substring(pos + 1); + parts.urn = true; + } + } + } + parts.path = string; + return parts; + }; + URI.parseHost = function(string, parts) { + if (!string) { + string = ""; + } + string = string.replace(/\\/g, "/"); + var pos = string.indexOf("/"); + var bracketPos; + var t; + if (pos === -1) { + pos = string.length; + } + if (string.charAt(0) === "[") { + bracketPos = string.indexOf("]"); + parts.hostname = string.substring(1, bracketPos) || null; + parts.port = string.substring(bracketPos + 2, pos) || null; + if (parts.port === "/") { + parts.port = null; + } + } else { + var firstColon = string.indexOf(":"); + var firstSlash = string.indexOf("/"); + var nextColon = string.indexOf(":", firstColon + 1); + if (nextColon !== -1 && (firstSlash === -1 || nextColon < firstSlash)) { + parts.hostname = string.substring(0, pos) || null; + parts.port = null; + } else { + t = string.substring(0, pos).split(":"); + parts.hostname = t[0] || null; + parts.port = t[1] || null; + } + } + if (parts.hostname && string.substring(pos).charAt(0) !== "/") { + pos++; + string = "/" + string; + } + if (parts.preventInvalidHostname) { + URI.ensureValidHostname(parts.hostname, parts.protocol); + } + if (parts.port) { + URI.ensureValidPort(parts.port); + } + return string.substring(pos) || "/"; + }; + URI.parseAuthority = function(string, parts) { + string = URI.parseUserinfo(string, parts); + return URI.parseHost(string, parts); + }; + URI.parseUserinfo = function(string, parts) { + var _string = string; + var firstBackSlash = string.indexOf("\\"); + if (firstBackSlash !== -1) { + string = string.replace(/\\/g, "/"); + } + var firstSlash = string.indexOf("/"); + var pos = string.lastIndexOf("@", firstSlash > -1 ? firstSlash : string.length - 1); + var t; + if (pos > -1 && (firstSlash === -1 || pos < firstSlash)) { + t = string.substring(0, pos).split(":"); + parts.username = t[0] ? URI.decode(t[0]) : null; + t.shift(); + parts.password = t[0] ? URI.decode(t.join(":")) : null; + string = _string.substring(pos + 1); + } else { + parts.username = null; + parts.password = null; + } + return string; + }; + URI.parseQuery = function(string, escapeQuerySpace) { + if (!string) { + return {}; + } + string = string.replace(/&+/g, "&").replace(/^\?*&*|&+$/g, ""); + if (!string) { + return {}; + } + var items = {}; + var splits = string.split("&"); + var length = splits.length; + var v2, name, value; + for (var i = 0; i < length; i++) { + v2 = splits[i].split("="); + name = URI.decodeQuery(v2.shift(), escapeQuerySpace); + value = v2.length ? URI.decodeQuery(v2.join("="), escapeQuerySpace) : null; + if (name === "__proto__") { + continue; + } else if (hasOwn.call(items, name)) { + if (typeof items[name] === "string" || items[name] === null) { + items[name] = [items[name]]; + } + items[name].push(value); + } else { + items[name] = value; + } + } + return items; + }; + URI.build = function(parts) { + var t = ""; + var requireAbsolutePath = false; + if (parts.protocol) { + t += parts.protocol + ":"; + } + if (!parts.urn && (t || parts.hostname)) { + t += "//"; + requireAbsolutePath = true; + } + t += URI.buildAuthority(parts) || ""; + if (typeof parts.path === "string") { + if (parts.path.charAt(0) !== "/" && requireAbsolutePath) { + t += "/"; + } + t += parts.path; + } + if (typeof parts.query === "string" && parts.query) { + t += "?" + parts.query; + } + if (typeof parts.fragment === "string" && parts.fragment) { + t += "#" + parts.fragment; + } + return t; + }; + URI.buildHost = function(parts) { + var t = ""; + if (!parts.hostname) { + return ""; + } else if (URI.ip6_expression.test(parts.hostname)) { + t += "[" + parts.hostname + "]"; + } else { + t += parts.hostname; + } + if (parts.port) { + t += ":" + parts.port; + } + return t; + }; + URI.buildAuthority = function(parts) { + return URI.buildUserinfo(parts) + URI.buildHost(parts); + }; + URI.buildUserinfo = function(parts) { + var t = ""; + if (parts.username) { + t += URI.encode(parts.username); + } + if (parts.password) { + t += ":" + URI.encode(parts.password); + } + if (t) { + t += "@"; + } + return t; + }; + URI.buildQuery = function(data, duplicateQueryParameters, escapeQuerySpace) { + var t = ""; + var unique, key, i, length; + for (key in data) { + if (key === "__proto__") { + continue; + } else if (hasOwn.call(data, key)) { + if (isArray(data[key])) { + unique = {}; + for (i = 0, length = data[key].length; i < length; i++) { + if (data[key][i] !== void 0 && unique[data[key][i] + ""] === void 0) { + t += "&" + URI.buildQueryParameter(key, data[key][i], escapeQuerySpace); + if (duplicateQueryParameters !== true) { + unique[data[key][i] + ""] = true; + } + } + } + } else if (data[key] !== void 0) { + t += "&" + URI.buildQueryParameter(key, data[key], escapeQuerySpace); + } + } + } + return t.substring(1); + }; + URI.buildQueryParameter = function(name, value, escapeQuerySpace) { + return URI.encodeQuery(name, escapeQuerySpace) + (value !== null ? "=" + URI.encodeQuery(value, escapeQuerySpace) : ""); + }; + URI.addQuery = function(data, name, value) { + if (typeof name === "object") { + for (var key in name) { + if (hasOwn.call(name, key)) { + URI.addQuery(data, key, name[key]); + } + } + } else if (typeof name === "string") { + if (data[name] === void 0) { + data[name] = value; + return; + } else if (typeof data[name] === "string") { + data[name] = [data[name]]; + } + if (!isArray(value)) { + value = [value]; + } + data[name] = (data[name] || []).concat(value); + } else { + throw new TypeError("URI.addQuery() accepts an object, string as the name parameter"); + } + }; + URI.setQuery = function(data, name, value) { + if (typeof name === "object") { + for (var key in name) { + if (hasOwn.call(name, key)) { + URI.setQuery(data, key, name[key]); + } + } + } else if (typeof name === "string") { + data[name] = value === void 0 ? null : value; + } else { + throw new TypeError("URI.setQuery() accepts an object, string as the name parameter"); + } + }; + URI.removeQuery = function(data, name, value) { + var i, length, key; + if (isArray(name)) { + for (i = 0, length = name.length; i < length; i++) { + data[name[i]] = void 0; + } + } else if (getType(name) === "RegExp") { + for (key in data) { + if (name.test(key)) { + data[key] = void 0; + } + } + } else if (typeof name === "object") { + for (key in name) { + if (hasOwn.call(name, key)) { + URI.removeQuery(data, key, name[key]); + } + } + } else if (typeof name === "string") { + if (value !== void 0) { + if (getType(value) === "RegExp") { + if (!isArray(data[name]) && value.test(data[name])) { + data[name] = void 0; + } else { + data[name] = filterArrayValues(data[name], value); + } + } else if (data[name] === String(value) && (!isArray(value) || value.length === 1)) { + data[name] = void 0; + } else if (isArray(data[name])) { + data[name] = filterArrayValues(data[name], value); + } + } else { + data[name] = void 0; + } + } else { + throw new TypeError("URI.removeQuery() accepts an object, string, RegExp as the first parameter"); + } + }; + URI.hasQuery = function(data, name, value, withinArray) { + switch (getType(name)) { + case "String": + break; + case "RegExp": + for (var key in data) { + if (hasOwn.call(data, key)) { + if (name.test(key) && (value === void 0 || URI.hasQuery(data, key, value))) { + return true; + } + } + } + return false; + case "Object": + for (var _key in name) { + if (hasOwn.call(name, _key)) { + if (!URI.hasQuery(data, _key, name[_key])) { + return false; + } + } + } + return true; + default: + throw new TypeError("URI.hasQuery() accepts a string, regular expression or object as the name parameter"); + } + switch (getType(value)) { + case "Undefined": + return name in data; + case "Boolean": + var _booly = Boolean(isArray(data[name]) ? data[name].length : data[name]); + return value === _booly; + case "Function": + return !!value(data[name], name, data); + case "Array": + if (!isArray(data[name])) { + return false; + } + var op = withinArray ? arrayContains : arraysEqual; + return op(data[name], value); + case "RegExp": + if (!isArray(data[name])) { + return Boolean(data[name] && data[name].match(value)); + } + if (!withinArray) { + return false; + } + return arrayContains(data[name], value); + case "Number": + value = String(value); + case "String": + if (!isArray(data[name])) { + return data[name] === value; + } + if (!withinArray) { + return false; + } + return arrayContains(data[name], value); + default: + throw new TypeError("URI.hasQuery() accepts undefined, boolean, string, number, RegExp, Function as the value parameter"); + } + }; + URI.joinPaths = function() { + var input = []; + var segments = []; + var nonEmptySegments = 0; + for (var i = 0; i < arguments.length; i++) { + var url = new URI(arguments[i]); + input.push(url); + var _segments = url.segment(); + for (var s = 0; s < _segments.length; s++) { + if (typeof _segments[s] === "string") { + segments.push(_segments[s]); + } + if (_segments[s]) { + nonEmptySegments++; + } + } + } + if (!segments.length || !nonEmptySegments) { + return new URI(""); + } + var uri = new URI("").segment(segments); + if (input[0].path() === "" || input[0].path().slice(0, 1) === "/") { + uri.path("/" + uri.path()); + } + return uri.normalize(); + }; + URI.commonPath = function(one, two) { + var length = Math.min(one.length, two.length); + var pos; + for (pos = 0; pos < length; pos++) { + if (one.charAt(pos) !== two.charAt(pos)) { + pos--; + break; + } + } + if (pos < 1) { + return one.charAt(0) === two.charAt(0) && one.charAt(0) === "/" ? "/" : ""; + } + if (one.charAt(pos) !== "/" || two.charAt(pos) !== "/") { + pos = one.substring(0, pos).lastIndexOf("/"); + } + return one.substring(0, pos + 1); + }; + URI.withinString = function(string, callback, options) { + options || (options = {}); + var _start = options.start || URI.findUri.start; + var _end = options.end || URI.findUri.end; + var _trim = options.trim || URI.findUri.trim; + var _parens = options.parens || URI.findUri.parens; + var _attributeOpen = /[a-z0-9-]=["']?$/i; + _start.lastIndex = 0; + while (true) { + var match = _start.exec(string); + if (!match) { + break; + } + var start = match.index; + if (options.ignoreHtml) { + var attributeOpen = string.slice(Math.max(start - 3, 0), start); + if (attributeOpen && _attributeOpen.test(attributeOpen)) { + continue; + } + } + var end = start + string.slice(start).search(_end); + var slice = string.slice(start, end); + var parensEnd = -1; + while (true) { + var parensMatch = _parens.exec(slice); + if (!parensMatch) { + break; + } + var parensMatchEnd = parensMatch.index + parensMatch[0].length; + parensEnd = Math.max(parensEnd, parensMatchEnd); + } + if (parensEnd > -1) { + slice = slice.slice(0, parensEnd) + slice.slice(parensEnd).replace(_trim, ""); + } else { + slice = slice.replace(_trim, ""); + } + if (slice.length <= match[0].length) { + continue; + } + if (options.ignore && options.ignore.test(slice)) { + continue; + } + end = start + slice.length; + var result = callback(slice, start, end, string); + if (result === void 0) { + _start.lastIndex = end; + continue; + } + result = String(result); + string = string.slice(0, start) + result + string.slice(end); + _start.lastIndex = start + result.length; + } + _start.lastIndex = 0; + return string; + }; + URI.ensureValidHostname = function(v2, protocol) { + var hasHostname = !!v2; + var hasProtocol = !!protocol; + var rejectEmptyHostname = false; + if (hasProtocol) { + rejectEmptyHostname = arrayContains(URI.hostProtocols, protocol); + } + if (rejectEmptyHostname && !hasHostname) { + throw new TypeError("Hostname cannot be empty, if protocol is " + protocol); + } else if (v2 && v2.match(URI.invalid_hostname_characters)) { + if (!punycode) { + throw new TypeError('Hostname "' + v2 + '" contains characters other than [A-Z0-9.-:_] and Punycode.js is not available'); + } + if (punycode.toASCII(v2).match(URI.invalid_hostname_characters)) { + throw new TypeError('Hostname "' + v2 + '" contains characters other than [A-Z0-9.-:_]'); + } + } + }; + URI.ensureValidPort = function(v2) { + if (!v2) { + return; + } + var port = Number(v2); + if (isInteger(port) && port > 0 && port < 65536) { + return; + } + throw new TypeError('Port "' + v2 + '" is not a valid port'); + }; + URI.noConflict = function(removeAll) { + if (removeAll) { + var unconflicted = { + URI: this.noConflict() + }; + if (root.URITemplate && typeof root.URITemplate.noConflict === "function") { + unconflicted.URITemplate = root.URITemplate.noConflict(); + } + if (root.IPv6 && typeof root.IPv6.noConflict === "function") { + unconflicted.IPv6 = root.IPv6.noConflict(); + } + if (root.SecondLevelDomains && typeof root.SecondLevelDomains.noConflict === "function") { + unconflicted.SecondLevelDomains = root.SecondLevelDomains.noConflict(); + } + return unconflicted; + } else if (root.URI === this) { + root.URI = _URI; + } + return this; + }; + p.build = function(deferBuild) { + if (deferBuild === true) { + this._deferred_build = true; + } else if (deferBuild === void 0 || this._deferred_build) { + this._string = URI.build(this._parts); + this._deferred_build = false; + } + return this; + }; + p.clone = function() { + return new URI(this); + }; + p.valueOf = p.toString = function() { + return this.build(false)._string; + }; + function generateSimpleAccessor(_part2) { + return function(v2, build) { + if (v2 === void 0) { + return this._parts[_part2] || ""; + } else { + this._parts[_part2] = v2 || null; + this.build(!build); + return this; + } + }; + } + function generatePrefixAccessor(_part2, _key) { + return function(v2, build) { + if (v2 === void 0) { + return this._parts[_part2] || ""; + } else { + if (v2 !== null) { + v2 = v2 + ""; + if (v2.charAt(0) === _key) { + v2 = v2.substring(1); + } + } + this._parts[_part2] = v2; + this.build(!build); + return this; + } + }; + } + p.protocol = generateSimpleAccessor("protocol"); + p.username = generateSimpleAccessor("username"); + p.password = generateSimpleAccessor("password"); + p.hostname = generateSimpleAccessor("hostname"); + p.port = generateSimpleAccessor("port"); + p.query = generatePrefixAccessor("query", "?"); + p.fragment = generatePrefixAccessor("fragment", "#"); + p.search = function(v2, build) { + var t = this.query(v2, build); + return typeof t === "string" && t.length ? "?" + t : t; + }; + p.hash = function(v2, build) { + var t = this.fragment(v2, build); + return typeof t === "string" && t.length ? "#" + t : t; + }; + p.pathname = function(v2, build) { + if (v2 === void 0 || v2 === true) { + var res = this._parts.path || (this._parts.hostname ? "/" : ""); + return v2 ? (this._parts.urn ? URI.decodeUrnPath : URI.decodePath)(res) : res; + } else { + if (this._parts.urn) { + this._parts.path = v2 ? URI.recodeUrnPath(v2) : ""; + } else { + this._parts.path = v2 ? URI.recodePath(v2) : "/"; + } + this.build(!build); + return this; + } + }; + p.path = p.pathname; + p.href = function(href, build) { + var key; + if (href === void 0) { + return this.toString(); + } + this._string = ""; + this._parts = URI._parts(); + var _URI2 = href instanceof URI; + var _object = typeof href === "object" && (href.hostname || href.path || href.pathname); + if (href.nodeName) { + var attribute = URI.getDomAttribute(href); + href = href[attribute] || ""; + _object = false; + } + if (!_URI2 && _object && href.pathname !== void 0) { + href = href.toString(); + } + if (typeof href === "string" || href instanceof String) { + this._parts = URI.parse(String(href), this._parts); + } else if (_URI2 || _object) { + var src = _URI2 ? href._parts : href; + for (key in src) { + if (key === "query") { + continue; + } + if (hasOwn.call(this._parts, key)) { + this._parts[key] = src[key]; + } + } + if (src.query) { + this.query(src.query, false); + } + } else { + throw new TypeError("invalid input"); + } + this.build(!build); + return this; + }; + p.is = function(what) { + var ip = false; + var ip4 = false; + var ip6 = false; + var name = false; + var sld = false; + var idn = false; + var punycode2 = false; + var relative = !this._parts.urn; + if (this._parts.hostname) { + relative = false; + ip4 = URI.ip4_expression.test(this._parts.hostname); + ip6 = URI.ip6_expression.test(this._parts.hostname); + ip = ip4 || ip6; + name = !ip; + sld = name && SLD && SLD.has(this._parts.hostname); + idn = name && URI.idn_expression.test(this._parts.hostname); + punycode2 = name && URI.punycode_expression.test(this._parts.hostname); + } + switch (what.toLowerCase()) { + case "relative": + return relative; + case "absolute": + return !relative; + case "domain": + case "name": + return name; + case "sld": + return sld; + case "ip": + return ip; + case "ip4": + case "ipv4": + case "inet4": + return ip4; + case "ip6": + case "ipv6": + case "inet6": + return ip6; + case "idn": + return idn; + case "url": + return !this._parts.urn; + case "urn": + return !!this._parts.urn; + case "punycode": + return punycode2; + } + return null; + }; + var _protocol = p.protocol; + var _port = p.port; + var _hostname = p.hostname; + p.protocol = function(v2, build) { + if (v2) { + v2 = v2.replace(/:(\/\/)?$/, ""); + if (!v2.match(URI.protocol_expression)) { + throw new TypeError('Protocol "' + v2 + `" contains characters other than [A-Z0-9.+-] or doesn't start with [A-Z]`); + } + } + return _protocol.call(this, v2, build); + }; + p.scheme = p.protocol; + p.port = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (v2 !== void 0) { + if (v2 === 0) { + v2 = null; + } + if (v2) { + v2 += ""; + if (v2.charAt(0) === ":") { + v2 = v2.substring(1); + } + URI.ensureValidPort(v2); + } + } + return _port.call(this, v2, build); + }; + p.hostname = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (v2 !== void 0) { + var x = { preventInvalidHostname: this._parts.preventInvalidHostname }; + var res = URI.parseHost(v2, x); + if (res !== "/") { + throw new TypeError('Hostname "' + v2 + '" contains characters other than [A-Z0-9.-]'); + } + v2 = x.hostname; + if (this._parts.preventInvalidHostname) { + URI.ensureValidHostname(v2, this._parts.protocol); + } + } + return _hostname.call(this, v2, build); + }; + p.origin = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (v2 === void 0) { + var protocol = this.protocol(); + var authority = this.authority(); + if (!authority) { + return ""; + } + return (protocol ? protocol + "://" : "") + this.authority(); + } else { + var origin = URI(v2); + this.protocol(origin.protocol()).authority(origin.authority()).build(!build); + return this; + } + }; + p.host = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (v2 === void 0) { + return this._parts.hostname ? URI.buildHost(this._parts) : ""; + } else { + var res = URI.parseHost(v2, this._parts); + if (res !== "/") { + throw new TypeError('Hostname "' + v2 + '" contains characters other than [A-Z0-9.-]'); + } + this.build(!build); + return this; + } + }; + p.authority = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (v2 === void 0) { + return this._parts.hostname ? URI.buildAuthority(this._parts) : ""; + } else { + var res = URI.parseAuthority(v2, this._parts); + if (res !== "/") { + throw new TypeError('Hostname "' + v2 + '" contains characters other than [A-Z0-9.-]'); + } + this.build(!build); + return this; + } + }; + p.userinfo = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (v2 === void 0) { + var t = URI.buildUserinfo(this._parts); + return t ? t.substring(0, t.length - 1) : t; + } else { + if (v2[v2.length - 1] !== "@") { + v2 += "@"; + } + URI.parseUserinfo(v2, this._parts); + this.build(!build); + return this; + } + }; + p.resource = function(v2, build) { + var parts; + if (v2 === void 0) { + return this.path() + this.search() + this.hash(); + } + parts = URI.parse(v2); + this._parts.path = parts.path; + this._parts.query = parts.query; + this._parts.fragment = parts.fragment; + this.build(!build); + return this; + }; + p.subdomain = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (v2 === void 0) { + if (!this._parts.hostname || this.is("IP")) { + return ""; + } + var end = this._parts.hostname.length - this.domain().length - 1; + return this._parts.hostname.substring(0, end) || ""; + } else { + var e = this._parts.hostname.length - this.domain().length; + var sub = this._parts.hostname.substring(0, e); + var replace = new RegExp("^" + escapeRegEx(sub)); + if (v2 && v2.charAt(v2.length - 1) !== ".") { + v2 += "."; + } + if (v2.indexOf(":") !== -1) { + throw new TypeError("Domains cannot contain colons"); + } + if (v2) { + URI.ensureValidHostname(v2, this._parts.protocol); + } + this._parts.hostname = this._parts.hostname.replace(replace, v2); + this.build(!build); + return this; + } + }; + p.domain = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (typeof v2 === "boolean") { + build = v2; + v2 = void 0; + } + if (v2 === void 0) { + if (!this._parts.hostname || this.is("IP")) { + return ""; + } + var t = this._parts.hostname.match(/\./g); + if (t && t.length < 2) { + return this._parts.hostname; + } + var end = this._parts.hostname.length - this.tld(build).length - 1; + end = this._parts.hostname.lastIndexOf(".", end - 1) + 1; + return this._parts.hostname.substring(end) || ""; + } else { + if (!v2) { + throw new TypeError("cannot set domain empty"); + } + if (v2.indexOf(":") !== -1) { + throw new TypeError("Domains cannot contain colons"); + } + URI.ensureValidHostname(v2, this._parts.protocol); + if (!this._parts.hostname || this.is("IP")) { + this._parts.hostname = v2; + } else { + var replace = new RegExp(escapeRegEx(this.domain()) + "$"); + this._parts.hostname = this._parts.hostname.replace(replace, v2); + } + this.build(!build); + return this; + } + }; + p.tld = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (typeof v2 === "boolean") { + build = v2; + v2 = void 0; + } + if (v2 === void 0) { + if (!this._parts.hostname || this.is("IP")) { + return ""; + } + var pos = this._parts.hostname.lastIndexOf("."); + var tld = this._parts.hostname.substring(pos + 1); + if (build !== true && SLD && SLD.list[tld.toLowerCase()]) { + return SLD.get(this._parts.hostname) || tld; + } + return tld; + } else { + var replace; + if (!v2) { + throw new TypeError("cannot set TLD empty"); + } else if (v2.match(/[^a-zA-Z0-9-]/)) { + if (SLD && SLD.is(v2)) { + replace = new RegExp(escapeRegEx(this.tld()) + "$"); + this._parts.hostname = this._parts.hostname.replace(replace, v2); + } else { + throw new TypeError('TLD "' + v2 + '" contains characters other than [A-Z0-9]'); + } + } else if (!this._parts.hostname || this.is("IP")) { + throw new ReferenceError("cannot set TLD on non-domain host"); + } else { + replace = new RegExp(escapeRegEx(this.tld()) + "$"); + this._parts.hostname = this._parts.hostname.replace(replace, v2); + } + this.build(!build); + return this; + } + }; + p.directory = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (v2 === void 0 || v2 === true) { + if (!this._parts.path && !this._parts.hostname) { + return ""; + } + if (this._parts.path === "/") { + return "/"; + } + var end = this._parts.path.length - this.filename().length - 1; + var res = this._parts.path.substring(0, end) || (this._parts.hostname ? "/" : ""); + return v2 ? URI.decodePath(res) : res; + } else { + var e = this._parts.path.length - this.filename().length; + var directory = this._parts.path.substring(0, e); + var replace = new RegExp("^" + escapeRegEx(directory)); + if (!this.is("relative")) { + if (!v2) { + v2 = "/"; + } + if (v2.charAt(0) !== "/") { + v2 = "/" + v2; + } + } + if (v2 && v2.charAt(v2.length - 1) !== "/") { + v2 += "/"; + } + v2 = URI.recodePath(v2); + this._parts.path = this._parts.path.replace(replace, v2); + this.build(!build); + return this; + } + }; + p.filename = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (typeof v2 !== "string") { + if (!this._parts.path || this._parts.path === "/") { + return ""; + } + var pos = this._parts.path.lastIndexOf("/"); + var res = this._parts.path.substring(pos + 1); + return v2 ? URI.decodePathSegment(res) : res; + } else { + var mutatedDirectory = false; + if (v2.charAt(0) === "/") { + v2 = v2.substring(1); + } + if (v2.match(/\.?\//)) { + mutatedDirectory = true; + } + var replace = new RegExp(escapeRegEx(this.filename()) + "$"); + v2 = URI.recodePath(v2); + this._parts.path = this._parts.path.replace(replace, v2); + if (mutatedDirectory) { + this.normalizePath(build); + } else { + this.build(!build); + } + return this; + } + }; + p.suffix = function(v2, build) { + if (this._parts.urn) { + return v2 === void 0 ? "" : this; + } + if (v2 === void 0 || v2 === true) { + if (!this._parts.path || this._parts.path === "/") { + return ""; + } + var filename = this.filename(); + var pos = filename.lastIndexOf("."); + var s, res; + if (pos === -1) { + return ""; + } + s = filename.substring(pos + 1); + res = /^[a-z0-9%]+$/i.test(s) ? s : ""; + return v2 ? URI.decodePathSegment(res) : res; + } else { + if (v2.charAt(0) === ".") { + v2 = v2.substring(1); + } + var suffix = this.suffix(); + var replace; + if (!suffix) { + if (!v2) { + return this; + } + this._parts.path += "." + URI.recodePath(v2); + } else if (!v2) { + replace = new RegExp(escapeRegEx("." + suffix) + "$"); + } else { + replace = new RegExp(escapeRegEx(suffix) + "$"); + } + if (replace) { + v2 = URI.recodePath(v2); + this._parts.path = this._parts.path.replace(replace, v2); + } + this.build(!build); + return this; + } + }; + p.segment = function(segment, v2, build) { + var separator = this._parts.urn ? ":" : "/"; + var path = this.path(); + var absolute = path.substring(0, 1) === "/"; + var segments = path.split(separator); + if (segment !== void 0 && typeof segment !== "number") { + build = v2; + v2 = segment; + segment = void 0; + } + if (segment !== void 0 && typeof segment !== "number") { + throw new Error('Bad segment "' + segment + '", must be 0-based integer'); + } + if (absolute) { + segments.shift(); + } + if (segment < 0) { + segment = Math.max(segments.length + segment, 0); + } + if (v2 === void 0) { + return segment === void 0 ? segments : segments[segment]; + } else if (segment === null || segments[segment] === void 0) { + if (isArray(v2)) { + segments = []; + for (var i = 0, l = v2.length; i < l; i++) { + if (!v2[i].length && (!segments.length || !segments[segments.length - 1].length)) { + continue; + } + if (segments.length && !segments[segments.length - 1].length) { + segments.pop(); + } + segments.push(trimSlashes(v2[i])); + } + } else if (v2 || typeof v2 === "string") { + v2 = trimSlashes(v2); + if (segments[segments.length - 1] === "") { + segments[segments.length - 1] = v2; + } else { + segments.push(v2); + } + } + } else { + if (v2) { + segments[segment] = trimSlashes(v2); + } else { + segments.splice(segment, 1); + } + } + if (absolute) { + segments.unshift(""); + } + return this.path(segments.join(separator), build); + }; + p.segmentCoded = function(segment, v2, build) { + var segments, i, l; + if (typeof segment !== "number") { + build = v2; + v2 = segment; + segment = void 0; + } + if (v2 === void 0) { + segments = this.segment(segment, v2, build); + if (!isArray(segments)) { + segments = segments !== void 0 ? URI.decode(segments) : void 0; + } else { + for (i = 0, l = segments.length; i < l; i++) { + segments[i] = URI.decode(segments[i]); + } + } + return segments; + } + if (!isArray(v2)) { + v2 = typeof v2 === "string" || v2 instanceof String ? URI.encode(v2) : v2; + } else { + for (i = 0, l = v2.length; i < l; i++) { + v2[i] = URI.encode(v2[i]); + } + } + return this.segment(segment, v2, build); + }; + var q = p.query; + p.query = function(v2, build) { + if (v2 === true) { + return URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace); + } else if (typeof v2 === "function") { + var data = URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace); + var result = v2.call(this, data); + this._parts.query = URI.buildQuery(result || data, this._parts.duplicateQueryParameters, this._parts.escapeQuerySpace); + this.build(!build); + return this; + } else if (v2 !== void 0 && typeof v2 !== "string") { + this._parts.query = URI.buildQuery(v2, this._parts.duplicateQueryParameters, this._parts.escapeQuerySpace); + this.build(!build); + return this; + } else { + return q.call(this, v2, build); + } + }; + p.setQuery = function(name, value, build) { + var data = URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace); + if (typeof name === "string" || name instanceof String) { + data[name] = value !== void 0 ? value : null; + } else if (typeof name === "object") { + for (var key in name) { + if (hasOwn.call(name, key)) { + data[key] = name[key]; + } + } + } else { + throw new TypeError("URI.addQuery() accepts an object, string as the name parameter"); + } + this._parts.query = URI.buildQuery(data, this._parts.duplicateQueryParameters, this._parts.escapeQuerySpace); + if (typeof name !== "string") { + build = value; + } + this.build(!build); + return this; + }; + p.addQuery = function(name, value, build) { + var data = URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace); + URI.addQuery(data, name, value === void 0 ? null : value); + this._parts.query = URI.buildQuery(data, this._parts.duplicateQueryParameters, this._parts.escapeQuerySpace); + if (typeof name !== "string") { + build = value; + } + this.build(!build); + return this; + }; + p.removeQuery = function(name, value, build) { + var data = URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace); + URI.removeQuery(data, name, value); + this._parts.query = URI.buildQuery(data, this._parts.duplicateQueryParameters, this._parts.escapeQuerySpace); + if (typeof name !== "string") { + build = value; + } + this.build(!build); + return this; + }; + p.hasQuery = function(name, value, withinArray) { + var data = URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace); + return URI.hasQuery(data, name, value, withinArray); + }; + p.setSearch = p.setQuery; + p.addSearch = p.addQuery; + p.removeSearch = p.removeQuery; + p.hasSearch = p.hasQuery; + p.normalize = function() { + if (this._parts.urn) { + return this.normalizeProtocol(false).normalizePath(false).normalizeQuery(false).normalizeFragment(false).build(); + } + return this.normalizeProtocol(false).normalizeHostname(false).normalizePort(false).normalizePath(false).normalizeQuery(false).normalizeFragment(false).build(); + }; + p.normalizeProtocol = function(build) { + if (typeof this._parts.protocol === "string") { + this._parts.protocol = this._parts.protocol.toLowerCase(); + this.build(!build); + } + return this; + }; + p.normalizeHostname = function(build) { + if (this._parts.hostname) { + if (this.is("IDN") && punycode) { + this._parts.hostname = punycode.toASCII(this._parts.hostname); + } else if (this.is("IPv6") && IPv6) { + this._parts.hostname = IPv6.best(this._parts.hostname); + } + this._parts.hostname = this._parts.hostname.toLowerCase(); + this.build(!build); + } + return this; + }; + p.normalizePort = function(build) { + if (typeof this._parts.protocol === "string" && this._parts.port === URI.defaultPorts[this._parts.protocol]) { + this._parts.port = null; + this.build(!build); + } + return this; + }; + p.normalizePath = function(build) { + var _path = this._parts.path; + if (!_path) { + return this; + } + if (this._parts.urn) { + this._parts.path = URI.recodeUrnPath(this._parts.path); + this.build(!build); + return this; + } + if (this._parts.path === "/") { + return this; + } + _path = URI.recodePath(_path); + var _was_relative; + var _leadingParents = ""; + var _parent, _pos; + if (_path.charAt(0) !== "/") { + _was_relative = true; + _path = "/" + _path; + } + if (_path.slice(-3) === "/.." || _path.slice(-2) === "/.") { + _path += "/"; + } + _path = _path.replace(/(\/(\.\/)+)|(\/\.$)/g, "/").replace(/\/{2,}/g, "/"); + if (_was_relative) { + _leadingParents = _path.substring(1).match(/^(\.\.\/)+/) || ""; + if (_leadingParents) { + _leadingParents = _leadingParents[0]; + } + } + while (true) { + _parent = _path.search(/\/\.\.(\/|$)/); + if (_parent === -1) { + break; + } else if (_parent === 0) { + _path = _path.substring(3); + continue; + } + _pos = _path.substring(0, _parent).lastIndexOf("/"); + if (_pos === -1) { + _pos = _parent; + } + _path = _path.substring(0, _pos) + _path.substring(_parent + 3); + } + if (_was_relative && this.is("relative")) { + _path = _leadingParents + _path.substring(1); + } + this._parts.path = _path; + this.build(!build); + return this; + }; + p.normalizePathname = p.normalizePath; + p.normalizeQuery = function(build) { + if (typeof this._parts.query === "string") { + if (!this._parts.query.length) { + this._parts.query = null; + } else { + this.query(URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace)); + } + this.build(!build); + } + return this; + }; + p.normalizeFragment = function(build) { + if (!this._parts.fragment) { + this._parts.fragment = null; + this.build(!build); + } + return this; + }; + p.normalizeSearch = p.normalizeQuery; + p.normalizeHash = p.normalizeFragment; + p.iso8859 = function() { + var e = URI.encode; + var d = URI.decode; + URI.encode = escape; + URI.decode = decodeURIComponent; + try { + this.normalize(); + } finally { + URI.encode = e; + URI.decode = d; + } + return this; + }; + p.unicode = function() { + var e = URI.encode; + var d = URI.decode; + URI.encode = strictEncodeURIComponent; + URI.decode = unescape; + try { + this.normalize(); + } finally { + URI.encode = e; + URI.decode = d; + } + return this; + }; + p.readable = function() { + var uri = this.clone(); + uri.username("").password("").normalize(); + var t = ""; + if (uri._parts.protocol) { + t += uri._parts.protocol + "://"; + } + if (uri._parts.hostname) { + if (uri.is("punycode") && punycode) { + t += punycode.toUnicode(uri._parts.hostname); + if (uri._parts.port) { + t += ":" + uri._parts.port; + } + } else { + t += uri.host(); + } + } + if (uri._parts.hostname && uri._parts.path && uri._parts.path.charAt(0) !== "/") { + t += "/"; + } + t += uri.path(true); + if (uri._parts.query) { + var q2 = ""; + for (var i = 0, qp = uri._parts.query.split("&"), l = qp.length; i < l; i++) { + var kv = (qp[i] || "").split("="); + q2 += "&" + URI.decodeQuery(kv[0], this._parts.escapeQuerySpace).replace(/&/g, "%26"); + if (kv[1] !== void 0) { + q2 += "=" + URI.decodeQuery(kv[1], this._parts.escapeQuerySpace).replace(/&/g, "%26"); + } + } + t += "?" + q2.substring(1); + } + t += URI.decodeQuery(uri.hash(), true); + return t; + }; + p.absoluteTo = function(base) { + var resolved = this.clone(); + var properties = ["protocol", "username", "password", "hostname", "port"]; + var basedir, i, p2; + if (this._parts.urn) { + throw new Error("URNs do not have any generally defined hierarchical components"); + } + if (!(base instanceof URI)) { + base = new URI(base); + } + if (resolved._parts.protocol) { + return resolved; + } else { + resolved._parts.protocol = base._parts.protocol; + } + if (this._parts.hostname) { + return resolved; + } + for (i = 0; p2 = properties[i]; i++) { + resolved._parts[p2] = base._parts[p2]; + } + if (!resolved._parts.path) { + resolved._parts.path = base._parts.path; + if (!resolved._parts.query) { + resolved._parts.query = base._parts.query; + } + } else { + if (resolved._parts.path.substring(-2) === "..") { + resolved._parts.path += "/"; + } + if (resolved.path().charAt(0) !== "/") { + basedir = base.directory(); + basedir = basedir ? basedir : base.path().indexOf("/") === 0 ? "/" : ""; + resolved._parts.path = (basedir ? basedir + "/" : "") + resolved._parts.path; + resolved.normalizePath(); + } + } + resolved.build(); + return resolved; + }; + p.relativeTo = function(base) { + var relative = this.clone().normalize(); + var relativeParts, baseParts, common, relativePath, basePath; + if (relative._parts.urn) { + throw new Error("URNs do not have any generally defined hierarchical components"); + } + base = new URI(base).normalize(); + relativeParts = relative._parts; + baseParts = base._parts; + relativePath = relative.path(); + basePath = base.path(); + if (relativePath.charAt(0) !== "/") { + throw new Error("URI is already relative"); + } + if (basePath.charAt(0) !== "/") { + throw new Error("Cannot calculate a URI relative to another relative URI"); + } + if (relativeParts.protocol === baseParts.protocol) { + relativeParts.protocol = null; + } + if (relativeParts.username !== baseParts.username || relativeParts.password !== baseParts.password) { + return relative.build(); + } + if (relativeParts.protocol !== null || relativeParts.username !== null || relativeParts.password !== null) { + return relative.build(); + } + if (relativeParts.hostname === baseParts.hostname && relativeParts.port === baseParts.port) { + relativeParts.hostname = null; + relativeParts.port = null; + } else { + return relative.build(); + } + if (relativePath === basePath) { + relativeParts.path = ""; + return relative.build(); + } + common = URI.commonPath(relativePath, basePath); + if (!common) { + return relative.build(); + } + var parents = baseParts.path.substring(common.length).replace(/[^\/]*$/, "").replace(/.*?\//g, "../"); + relativeParts.path = parents + relativeParts.path.substring(common.length) || "./"; + return relative.build(); + }; + p.equals = function(uri) { + var one = this.clone(); + var two = new URI(uri); + var one_map = {}; + var two_map = {}; + var checked = {}; + var one_query, two_query, key; + one.normalize(); + two.normalize(); + if (one.toString() === two.toString()) { + return true; + } + one_query = one.query(); + two_query = two.query(); + one.query(""); + two.query(""); + if (one.toString() !== two.toString()) { + return false; + } + if (one_query.length !== two_query.length) { + return false; + } + one_map = URI.parseQuery(one_query, this._parts.escapeQuerySpace); + two_map = URI.parseQuery(two_query, this._parts.escapeQuerySpace); + for (key in one_map) { + if (hasOwn.call(one_map, key)) { + if (!isArray(one_map[key])) { + if (one_map[key] !== two_map[key]) { + return false; + } + } else if (!arraysEqual(one_map[key], two_map[key])) { + return false; + } + checked[key] = true; + } + } + for (key in two_map) { + if (hasOwn.call(two_map, key)) { + if (!checked[key]) { + return false; + } + } + } + return true; + }; + p.preventInvalidHostname = function(v2) { + this._parts.preventInvalidHostname = !!v2; + return this; + }; + p.duplicateQueryParameters = function(v2) { + this._parts.duplicateQueryParameters = !!v2; + return this; + }; + p.escapeQuerySpace = function(v2) { + this._parts.escapeQuerySpace = !!v2; + return this; + }; + return URI; + }); + } +}); + +// packages/engine/Source/Core/GeographicProjection.js +function GeographicProjection(ellipsoid) { + this._ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + this._semimajorAxis = this._ellipsoid.maximumRadius; + this._oneOverSemimajorAxis = 1 / this._semimajorAxis; +} +Object.defineProperties(GeographicProjection.prototype, { + /** + * Gets the {@link Ellipsoid}. + * + * @memberof GeographicProjection.prototype + * + * @type {Ellipsoid} + * @readonly + */ + ellipsoid: { + get: function() { + return this._ellipsoid; + } + } +}); +GeographicProjection.prototype.project = function(cartographic, result) { + const semimajorAxis = this._semimajorAxis; + const x = cartographic.longitude * semimajorAxis; + const y = cartographic.latitude * semimajorAxis; + const z = cartographic.height; + if (!defined_default(result)) { + return new Cartesian3_default(x, y, z); + } + result.x = x; + result.y = y; + result.z = z; + return result; +}; +GeographicProjection.prototype.unproject = function(cartesian, result) { + if (!defined_default(cartesian)) { + throw new DeveloperError_default("cartesian is required"); + } + const oneOverEarthSemimajorAxis = this._oneOverSemimajorAxis; + const longitude = cartesian.x * oneOverEarthSemimajorAxis; + const latitude = cartesian.y * oneOverEarthSemimajorAxis; + const height = cartesian.z; + if (!defined_default(result)) { + return new Cartographic_default(longitude, latitude, height); + } + result.longitude = longitude; + result.latitude = latitude; + result.height = height; + return result; +}; +var GeographicProjection_default = GeographicProjection; + +// packages/engine/Source/Core/Intersect.js +var Intersect = { + /** + * Represents that an object is not contained within the frustum. + * + * @type {number} + * @constant + */ + OUTSIDE: -1, + /** + * Represents that an object intersects one of the frustum's planes. + * + * @type {number} + * @constant + */ + INTERSECTING: 0, + /** + * Represents that an object is fully within the frustum. + * + * @type {number} + * @constant + */ + INSIDE: 1 +}; +var Intersect_default = Object.freeze(Intersect); + +// packages/engine/Source/Core/Interval.js +function Interval(start, stop) { + this.start = defaultValue_default(start, 0); + this.stop = defaultValue_default(stop, 0); +} +var Interval_default = Interval; + +// packages/engine/Source/Core/BoundingSphere.js +function BoundingSphere(center, radius) { + this.center = Cartesian3_default.clone(defaultValue_default(center, Cartesian3_default.ZERO)); + this.radius = defaultValue_default(radius, 0); +} +var fromPointsXMin = new Cartesian3_default(); +var fromPointsYMin = new Cartesian3_default(); +var fromPointsZMin = new Cartesian3_default(); +var fromPointsXMax = new Cartesian3_default(); +var fromPointsYMax = new Cartesian3_default(); +var fromPointsZMax = new Cartesian3_default(); +var fromPointsCurrentPos = new Cartesian3_default(); +var fromPointsScratch = new Cartesian3_default(); +var fromPointsRitterCenter = new Cartesian3_default(); +var fromPointsMinBoxPt = new Cartesian3_default(); +var fromPointsMaxBoxPt = new Cartesian3_default(); +var fromPointsNaiveCenterScratch = new Cartesian3_default(); +var volumeConstant = 4 / 3 * Math_default.PI; +BoundingSphere.fromPoints = function(positions, result) { + if (!defined_default(result)) { + result = new BoundingSphere(); + } + if (!defined_default(positions) || positions.length === 0) { + result.center = Cartesian3_default.clone(Cartesian3_default.ZERO, result.center); + result.radius = 0; + return result; + } + const currentPos = Cartesian3_default.clone(positions[0], fromPointsCurrentPos); + const xMin = Cartesian3_default.clone(currentPos, fromPointsXMin); + const yMin = Cartesian3_default.clone(currentPos, fromPointsYMin); + const zMin = Cartesian3_default.clone(currentPos, fromPointsZMin); + const xMax = Cartesian3_default.clone(currentPos, fromPointsXMax); + const yMax = Cartesian3_default.clone(currentPos, fromPointsYMax); + const zMax = Cartesian3_default.clone(currentPos, fromPointsZMax); + const numPositions = positions.length; + let i; + for (i = 1; i < numPositions; i++) { + Cartesian3_default.clone(positions[i], currentPos); + const x = currentPos.x; + const y = currentPos.y; + const z = currentPos.z; + if (x < xMin.x) { + Cartesian3_default.clone(currentPos, xMin); + } + if (x > xMax.x) { + Cartesian3_default.clone(currentPos, xMax); + } + if (y < yMin.y) { + Cartesian3_default.clone(currentPos, yMin); + } + if (y > yMax.y) { + Cartesian3_default.clone(currentPos, yMax); + } + if (z < zMin.z) { + Cartesian3_default.clone(currentPos, zMin); + } + if (z > zMax.z) { + Cartesian3_default.clone(currentPos, zMax); + } + } + const xSpan = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(xMax, xMin, fromPointsScratch) + ); + const ySpan = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(yMax, yMin, fromPointsScratch) + ); + const zSpan = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(zMax, zMin, fromPointsScratch) + ); + let diameter1 = xMin; + let diameter2 = xMax; + let maxSpan = xSpan; + if (ySpan > maxSpan) { + maxSpan = ySpan; + diameter1 = yMin; + diameter2 = yMax; + } + if (zSpan > maxSpan) { + maxSpan = zSpan; + diameter1 = zMin; + diameter2 = zMax; + } + const ritterCenter = fromPointsRitterCenter; + ritterCenter.x = (diameter1.x + diameter2.x) * 0.5; + ritterCenter.y = (diameter1.y + diameter2.y) * 0.5; + ritterCenter.z = (diameter1.z + diameter2.z) * 0.5; + let radiusSquared = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(diameter2, ritterCenter, fromPointsScratch) + ); + let ritterRadius = Math.sqrt(radiusSquared); + const minBoxPt = fromPointsMinBoxPt; + minBoxPt.x = xMin.x; + minBoxPt.y = yMin.y; + minBoxPt.z = zMin.z; + const maxBoxPt = fromPointsMaxBoxPt; + maxBoxPt.x = xMax.x; + maxBoxPt.y = yMax.y; + maxBoxPt.z = zMax.z; + const naiveCenter = Cartesian3_default.midpoint( + minBoxPt, + maxBoxPt, + fromPointsNaiveCenterScratch + ); + let naiveRadius = 0; + for (i = 0; i < numPositions; i++) { + Cartesian3_default.clone(positions[i], currentPos); + const r = Cartesian3_default.magnitude( + Cartesian3_default.subtract(currentPos, naiveCenter, fromPointsScratch) + ); + if (r > naiveRadius) { + naiveRadius = r; + } + const oldCenterToPointSquared = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(currentPos, ritterCenter, fromPointsScratch) + ); + if (oldCenterToPointSquared > radiusSquared) { + const oldCenterToPoint = Math.sqrt(oldCenterToPointSquared); + ritterRadius = (ritterRadius + oldCenterToPoint) * 0.5; + radiusSquared = ritterRadius * ritterRadius; + const oldToNew = oldCenterToPoint - ritterRadius; + ritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint; + ritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint; + ritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint; + } + } + if (ritterRadius < naiveRadius) { + Cartesian3_default.clone(ritterCenter, result.center); + result.radius = ritterRadius; + } else { + Cartesian3_default.clone(naiveCenter, result.center); + result.radius = naiveRadius; + } + return result; +}; +var defaultProjection = new GeographicProjection_default(); +var fromRectangle2DLowerLeft = new Cartesian3_default(); +var fromRectangle2DUpperRight = new Cartesian3_default(); +var fromRectangle2DSouthwest = new Cartographic_default(); +var fromRectangle2DNortheast = new Cartographic_default(); +BoundingSphere.fromRectangle2D = function(rectangle, projection, result) { + return BoundingSphere.fromRectangleWithHeights2D( + rectangle, + projection, + 0, + 0, + result + ); +}; +BoundingSphere.fromRectangleWithHeights2D = function(rectangle, projection, minimumHeight, maximumHeight, result) { + if (!defined_default(result)) { + result = new BoundingSphere(); + } + if (!defined_default(rectangle)) { + result.center = Cartesian3_default.clone(Cartesian3_default.ZERO, result.center); + result.radius = 0; + return result; + } + projection = defaultValue_default(projection, defaultProjection); + Rectangle_default.southwest(rectangle, fromRectangle2DSouthwest); + fromRectangle2DSouthwest.height = minimumHeight; + Rectangle_default.northeast(rectangle, fromRectangle2DNortheast); + fromRectangle2DNortheast.height = maximumHeight; + const lowerLeft = projection.project( + fromRectangle2DSouthwest, + fromRectangle2DLowerLeft + ); + const upperRight = projection.project( + fromRectangle2DNortheast, + fromRectangle2DUpperRight + ); + const width = upperRight.x - lowerLeft.x; + const height = upperRight.y - lowerLeft.y; + const elevation = upperRight.z - lowerLeft.z; + result.radius = Math.sqrt(width * width + height * height + elevation * elevation) * 0.5; + const center = result.center; + center.x = lowerLeft.x + width * 0.5; + center.y = lowerLeft.y + height * 0.5; + center.z = lowerLeft.z + elevation * 0.5; + return result; +}; +var fromRectangle3DScratch = []; +BoundingSphere.fromRectangle3D = function(rectangle, ellipsoid, surfaceHeight, result) { + ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + surfaceHeight = defaultValue_default(surfaceHeight, 0); + if (!defined_default(result)) { + result = new BoundingSphere(); + } + if (!defined_default(rectangle)) { + result.center = Cartesian3_default.clone(Cartesian3_default.ZERO, result.center); + result.radius = 0; + return result; + } + const positions = Rectangle_default.subsample( + rectangle, + ellipsoid, + surfaceHeight, + fromRectangle3DScratch + ); + return BoundingSphere.fromPoints(positions, result); +}; +BoundingSphere.fromVertices = function(positions, center, stride, result) { + if (!defined_default(result)) { + result = new BoundingSphere(); + } + if (!defined_default(positions) || positions.length === 0) { + result.center = Cartesian3_default.clone(Cartesian3_default.ZERO, result.center); + result.radius = 0; + return result; + } + center = defaultValue_default(center, Cartesian3_default.ZERO); + stride = defaultValue_default(stride, 3); + Check_default.typeOf.number.greaterThanOrEquals("stride", stride, 3); + const currentPos = fromPointsCurrentPos; + currentPos.x = positions[0] + center.x; + currentPos.y = positions[1] + center.y; + currentPos.z = positions[2] + center.z; + const xMin = Cartesian3_default.clone(currentPos, fromPointsXMin); + const yMin = Cartesian3_default.clone(currentPos, fromPointsYMin); + const zMin = Cartesian3_default.clone(currentPos, fromPointsZMin); + const xMax = Cartesian3_default.clone(currentPos, fromPointsXMax); + const yMax = Cartesian3_default.clone(currentPos, fromPointsYMax); + const zMax = Cartesian3_default.clone(currentPos, fromPointsZMax); + const numElements = positions.length; + let i; + for (i = 0; i < numElements; i += stride) { + const x = positions[i] + center.x; + const y = positions[i + 1] + center.y; + const z = positions[i + 2] + center.z; + currentPos.x = x; + currentPos.y = y; + currentPos.z = z; + if (x < xMin.x) { + Cartesian3_default.clone(currentPos, xMin); + } + if (x > xMax.x) { + Cartesian3_default.clone(currentPos, xMax); + } + if (y < yMin.y) { + Cartesian3_default.clone(currentPos, yMin); + } + if (y > yMax.y) { + Cartesian3_default.clone(currentPos, yMax); + } + if (z < zMin.z) { + Cartesian3_default.clone(currentPos, zMin); + } + if (z > zMax.z) { + Cartesian3_default.clone(currentPos, zMax); + } + } + const xSpan = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(xMax, xMin, fromPointsScratch) + ); + const ySpan = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(yMax, yMin, fromPointsScratch) + ); + const zSpan = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(zMax, zMin, fromPointsScratch) + ); + let diameter1 = xMin; + let diameter2 = xMax; + let maxSpan = xSpan; + if (ySpan > maxSpan) { + maxSpan = ySpan; + diameter1 = yMin; + diameter2 = yMax; + } + if (zSpan > maxSpan) { + maxSpan = zSpan; + diameter1 = zMin; + diameter2 = zMax; + } + const ritterCenter = fromPointsRitterCenter; + ritterCenter.x = (diameter1.x + diameter2.x) * 0.5; + ritterCenter.y = (diameter1.y + diameter2.y) * 0.5; + ritterCenter.z = (diameter1.z + diameter2.z) * 0.5; + let radiusSquared = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(diameter2, ritterCenter, fromPointsScratch) + ); + let ritterRadius = Math.sqrt(radiusSquared); + const minBoxPt = fromPointsMinBoxPt; + minBoxPt.x = xMin.x; + minBoxPt.y = yMin.y; + minBoxPt.z = zMin.z; + const maxBoxPt = fromPointsMaxBoxPt; + maxBoxPt.x = xMax.x; + maxBoxPt.y = yMax.y; + maxBoxPt.z = zMax.z; + const naiveCenter = Cartesian3_default.midpoint( + minBoxPt, + maxBoxPt, + fromPointsNaiveCenterScratch + ); + let naiveRadius = 0; + for (i = 0; i < numElements; i += stride) { + currentPos.x = positions[i] + center.x; + currentPos.y = positions[i + 1] + center.y; + currentPos.z = positions[i + 2] + center.z; + const r = Cartesian3_default.magnitude( + Cartesian3_default.subtract(currentPos, naiveCenter, fromPointsScratch) + ); + if (r > naiveRadius) { + naiveRadius = r; + } + const oldCenterToPointSquared = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(currentPos, ritterCenter, fromPointsScratch) + ); + if (oldCenterToPointSquared > radiusSquared) { + const oldCenterToPoint = Math.sqrt(oldCenterToPointSquared); + ritterRadius = (ritterRadius + oldCenterToPoint) * 0.5; + radiusSquared = ritterRadius * ritterRadius; + const oldToNew = oldCenterToPoint - ritterRadius; + ritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint; + ritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint; + ritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint; + } + } + if (ritterRadius < naiveRadius) { + Cartesian3_default.clone(ritterCenter, result.center); + result.radius = ritterRadius; + } else { + Cartesian3_default.clone(naiveCenter, result.center); + result.radius = naiveRadius; + } + return result; +}; +BoundingSphere.fromEncodedCartesianVertices = function(positionsHigh, positionsLow, result) { + if (!defined_default(result)) { + result = new BoundingSphere(); + } + if (!defined_default(positionsHigh) || !defined_default(positionsLow) || positionsHigh.length !== positionsLow.length || positionsHigh.length === 0) { + result.center = Cartesian3_default.clone(Cartesian3_default.ZERO, result.center); + result.radius = 0; + return result; + } + const currentPos = fromPointsCurrentPos; + currentPos.x = positionsHigh[0] + positionsLow[0]; + currentPos.y = positionsHigh[1] + positionsLow[1]; + currentPos.z = positionsHigh[2] + positionsLow[2]; + const xMin = Cartesian3_default.clone(currentPos, fromPointsXMin); + const yMin = Cartesian3_default.clone(currentPos, fromPointsYMin); + const zMin = Cartesian3_default.clone(currentPos, fromPointsZMin); + const xMax = Cartesian3_default.clone(currentPos, fromPointsXMax); + const yMax = Cartesian3_default.clone(currentPos, fromPointsYMax); + const zMax = Cartesian3_default.clone(currentPos, fromPointsZMax); + const numElements = positionsHigh.length; + let i; + for (i = 0; i < numElements; i += 3) { + const x = positionsHigh[i] + positionsLow[i]; + const y = positionsHigh[i + 1] + positionsLow[i + 1]; + const z = positionsHigh[i + 2] + positionsLow[i + 2]; + currentPos.x = x; + currentPos.y = y; + currentPos.z = z; + if (x < xMin.x) { + Cartesian3_default.clone(currentPos, xMin); + } + if (x > xMax.x) { + Cartesian3_default.clone(currentPos, xMax); + } + if (y < yMin.y) { + Cartesian3_default.clone(currentPos, yMin); + } + if (y > yMax.y) { + Cartesian3_default.clone(currentPos, yMax); + } + if (z < zMin.z) { + Cartesian3_default.clone(currentPos, zMin); + } + if (z > zMax.z) { + Cartesian3_default.clone(currentPos, zMax); + } + } + const xSpan = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(xMax, xMin, fromPointsScratch) + ); + const ySpan = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(yMax, yMin, fromPointsScratch) + ); + const zSpan = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(zMax, zMin, fromPointsScratch) + ); + let diameter1 = xMin; + let diameter2 = xMax; + let maxSpan = xSpan; + if (ySpan > maxSpan) { + maxSpan = ySpan; + diameter1 = yMin; + diameter2 = yMax; + } + if (zSpan > maxSpan) { + maxSpan = zSpan; + diameter1 = zMin; + diameter2 = zMax; + } + const ritterCenter = fromPointsRitterCenter; + ritterCenter.x = (diameter1.x + diameter2.x) * 0.5; + ritterCenter.y = (diameter1.y + diameter2.y) * 0.5; + ritterCenter.z = (diameter1.z + diameter2.z) * 0.5; + let radiusSquared = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(diameter2, ritterCenter, fromPointsScratch) + ); + let ritterRadius = Math.sqrt(radiusSquared); + const minBoxPt = fromPointsMinBoxPt; + minBoxPt.x = xMin.x; + minBoxPt.y = yMin.y; + minBoxPt.z = zMin.z; + const maxBoxPt = fromPointsMaxBoxPt; + maxBoxPt.x = xMax.x; + maxBoxPt.y = yMax.y; + maxBoxPt.z = zMax.z; + const naiveCenter = Cartesian3_default.midpoint( + minBoxPt, + maxBoxPt, + fromPointsNaiveCenterScratch + ); + let naiveRadius = 0; + for (i = 0; i < numElements; i += 3) { + currentPos.x = positionsHigh[i] + positionsLow[i]; + currentPos.y = positionsHigh[i + 1] + positionsLow[i + 1]; + currentPos.z = positionsHigh[i + 2] + positionsLow[i + 2]; + const r = Cartesian3_default.magnitude( + Cartesian3_default.subtract(currentPos, naiveCenter, fromPointsScratch) + ); + if (r > naiveRadius) { + naiveRadius = r; + } + const oldCenterToPointSquared = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(currentPos, ritterCenter, fromPointsScratch) + ); + if (oldCenterToPointSquared > radiusSquared) { + const oldCenterToPoint = Math.sqrt(oldCenterToPointSquared); + ritterRadius = (ritterRadius + oldCenterToPoint) * 0.5; + radiusSquared = ritterRadius * ritterRadius; + const oldToNew = oldCenterToPoint - ritterRadius; + ritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint; + ritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint; + ritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint; + } + } + if (ritterRadius < naiveRadius) { + Cartesian3_default.clone(ritterCenter, result.center); + result.radius = ritterRadius; + } else { + Cartesian3_default.clone(naiveCenter, result.center); + result.radius = naiveRadius; + } + return result; +}; +BoundingSphere.fromCornerPoints = function(corner, oppositeCorner, result) { + Check_default.typeOf.object("corner", corner); + Check_default.typeOf.object("oppositeCorner", oppositeCorner); + if (!defined_default(result)) { + result = new BoundingSphere(); + } + const center = Cartesian3_default.midpoint(corner, oppositeCorner, result.center); + result.radius = Cartesian3_default.distance(center, oppositeCorner); + return result; +}; +BoundingSphere.fromEllipsoid = function(ellipsoid, result) { + Check_default.typeOf.object("ellipsoid", ellipsoid); + if (!defined_default(result)) { + result = new BoundingSphere(); + } + Cartesian3_default.clone(Cartesian3_default.ZERO, result.center); + result.radius = ellipsoid.maximumRadius; + return result; +}; +var fromBoundingSpheresScratch = new Cartesian3_default(); +BoundingSphere.fromBoundingSpheres = function(boundingSpheres, result) { + if (!defined_default(result)) { + result = new BoundingSphere(); + } + if (!defined_default(boundingSpheres) || boundingSpheres.length === 0) { + result.center = Cartesian3_default.clone(Cartesian3_default.ZERO, result.center); + result.radius = 0; + return result; + } + const length = boundingSpheres.length; + if (length === 1) { + return BoundingSphere.clone(boundingSpheres[0], result); + } + if (length === 2) { + return BoundingSphere.union(boundingSpheres[0], boundingSpheres[1], result); + } + const positions = []; + let i; + for (i = 0; i < length; i++) { + positions.push(boundingSpheres[i].center); + } + result = BoundingSphere.fromPoints(positions, result); + const center = result.center; + let radius = result.radius; + for (i = 0; i < length; i++) { + const tmp = boundingSpheres[i]; + radius = Math.max( + radius, + Cartesian3_default.distance(center, tmp.center, fromBoundingSpheresScratch) + tmp.radius + ); + } + result.radius = radius; + return result; +}; +var fromOrientedBoundingBoxScratchU = new Cartesian3_default(); +var fromOrientedBoundingBoxScratchV = new Cartesian3_default(); +var fromOrientedBoundingBoxScratchW = new Cartesian3_default(); +BoundingSphere.fromOrientedBoundingBox = function(orientedBoundingBox, result) { + Check_default.defined("orientedBoundingBox", orientedBoundingBox); + if (!defined_default(result)) { + result = new BoundingSphere(); + } + const halfAxes = orientedBoundingBox.halfAxes; + const u2 = Matrix3_default.getColumn(halfAxes, 0, fromOrientedBoundingBoxScratchU); + const v2 = Matrix3_default.getColumn(halfAxes, 1, fromOrientedBoundingBoxScratchV); + const w = Matrix3_default.getColumn(halfAxes, 2, fromOrientedBoundingBoxScratchW); + Cartesian3_default.add(u2, v2, u2); + Cartesian3_default.add(u2, w, u2); + result.center = Cartesian3_default.clone(orientedBoundingBox.center, result.center); + result.radius = Cartesian3_default.magnitude(u2); + return result; +}; +var scratchFromTransformationCenter = new Cartesian3_default(); +var scratchFromTransformationScale = new Cartesian3_default(); +BoundingSphere.fromTransformation = function(transformation, result) { + Check_default.typeOf.object("transformation", transformation); + if (!defined_default(result)) { + result = new BoundingSphere(); + } + const center = Matrix4_default.getTranslation( + transformation, + scratchFromTransformationCenter + ); + const scale = Matrix4_default.getScale( + transformation, + scratchFromTransformationScale + ); + const radius = 0.5 * Cartesian3_default.magnitude(scale); + result.center = Cartesian3_default.clone(center, result.center); + result.radius = radius; + return result; +}; +BoundingSphere.clone = function(sphere, result) { + if (!defined_default(sphere)) { + return void 0; + } + if (!defined_default(result)) { + return new BoundingSphere(sphere.center, sphere.radius); + } + result.center = Cartesian3_default.clone(sphere.center, result.center); + result.radius = sphere.radius; + return result; +}; +BoundingSphere.packedLength = 4; +BoundingSphere.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + const center = value.center; + array[startingIndex++] = center.x; + array[startingIndex++] = center.y; + array[startingIndex++] = center.z; + array[startingIndex] = value.radius; + return array; +}; +BoundingSphere.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new BoundingSphere(); + } + const center = result.center; + center.x = array[startingIndex++]; + center.y = array[startingIndex++]; + center.z = array[startingIndex++]; + result.radius = array[startingIndex]; + return result; +}; +var unionScratch = new Cartesian3_default(); +var unionScratchCenter = new Cartesian3_default(); +BoundingSphere.union = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + if (!defined_default(result)) { + result = new BoundingSphere(); + } + const leftCenter = left.center; + const leftRadius = left.radius; + const rightCenter = right.center; + const rightRadius = right.radius; + const toRightCenter = Cartesian3_default.subtract( + rightCenter, + leftCenter, + unionScratch + ); + const centerSeparation = Cartesian3_default.magnitude(toRightCenter); + if (leftRadius >= centerSeparation + rightRadius) { + left.clone(result); + return result; + } + if (rightRadius >= centerSeparation + leftRadius) { + right.clone(result); + return result; + } + const halfDistanceBetweenTangentPoints = (leftRadius + centerSeparation + rightRadius) * 0.5; + const center = Cartesian3_default.multiplyByScalar( + toRightCenter, + (-leftRadius + halfDistanceBetweenTangentPoints) / centerSeparation, + unionScratchCenter + ); + Cartesian3_default.add(center, leftCenter, center); + Cartesian3_default.clone(center, result.center); + result.radius = halfDistanceBetweenTangentPoints; + return result; +}; +var expandScratch = new Cartesian3_default(); +BoundingSphere.expand = function(sphere, point, result) { + Check_default.typeOf.object("sphere", sphere); + Check_default.typeOf.object("point", point); + result = BoundingSphere.clone(sphere, result); + const radius = Cartesian3_default.magnitude( + Cartesian3_default.subtract(point, result.center, expandScratch) + ); + if (radius > result.radius) { + result.radius = radius; + } + return result; +}; +BoundingSphere.intersectPlane = function(sphere, plane) { + Check_default.typeOf.object("sphere", sphere); + Check_default.typeOf.object("plane", plane); + const center = sphere.center; + const radius = sphere.radius; + const normal = plane.normal; + const distanceToPlane = Cartesian3_default.dot(normal, center) + plane.distance; + if (distanceToPlane < -radius) { + return Intersect_default.OUTSIDE; + } else if (distanceToPlane < radius) { + return Intersect_default.INTERSECTING; + } + return Intersect_default.INSIDE; +}; +BoundingSphere.transform = function(sphere, transform, result) { + Check_default.typeOf.object("sphere", sphere); + Check_default.typeOf.object("transform", transform); + if (!defined_default(result)) { + result = new BoundingSphere(); + } + result.center = Matrix4_default.multiplyByPoint( + transform, + sphere.center, + result.center + ); + result.radius = Matrix4_default.getMaximumScale(transform) * sphere.radius; + return result; +}; +var distanceSquaredToScratch = new Cartesian3_default(); +BoundingSphere.distanceSquaredTo = function(sphere, cartesian) { + Check_default.typeOf.object("sphere", sphere); + Check_default.typeOf.object("cartesian", cartesian); + const diff = Cartesian3_default.subtract( + sphere.center, + cartesian, + distanceSquaredToScratch + ); + const distance = Cartesian3_default.magnitude(diff) - sphere.radius; + if (distance <= 0) { + return 0; + } + return distance * distance; +}; +BoundingSphere.transformWithoutScale = function(sphere, transform, result) { + Check_default.typeOf.object("sphere", sphere); + Check_default.typeOf.object("transform", transform); + if (!defined_default(result)) { + result = new BoundingSphere(); + } + result.center = Matrix4_default.multiplyByPoint( + transform, + sphere.center, + result.center + ); + result.radius = sphere.radius; + return result; +}; +var scratchCartesian3 = new Cartesian3_default(); +BoundingSphere.computePlaneDistances = function(sphere, position, direction, result) { + Check_default.typeOf.object("sphere", sphere); + Check_default.typeOf.object("position", position); + Check_default.typeOf.object("direction", direction); + if (!defined_default(result)) { + result = new Interval_default(); + } + const toCenter = Cartesian3_default.subtract( + sphere.center, + position, + scratchCartesian3 + ); + const mag = Cartesian3_default.dot(direction, toCenter); + result.start = mag - sphere.radius; + result.stop = mag + sphere.radius; + return result; +}; +var projectTo2DNormalScratch = new Cartesian3_default(); +var projectTo2DEastScratch = new Cartesian3_default(); +var projectTo2DNorthScratch = new Cartesian3_default(); +var projectTo2DWestScratch = new Cartesian3_default(); +var projectTo2DSouthScratch = new Cartesian3_default(); +var projectTo2DCartographicScratch = new Cartographic_default(); +var projectTo2DPositionsScratch = new Array(8); +for (let n = 0; n < 8; ++n) { + projectTo2DPositionsScratch[n] = new Cartesian3_default(); +} +var projectTo2DProjection = new GeographicProjection_default(); +BoundingSphere.projectTo2D = function(sphere, projection, result) { + Check_default.typeOf.object("sphere", sphere); + projection = defaultValue_default(projection, projectTo2DProjection); + const ellipsoid = projection.ellipsoid; + let center = sphere.center; + const radius = sphere.radius; + let normal; + if (Cartesian3_default.equals(center, Cartesian3_default.ZERO)) { + normal = Cartesian3_default.clone(Cartesian3_default.UNIT_X, projectTo2DNormalScratch); + } else { + normal = ellipsoid.geodeticSurfaceNormal(center, projectTo2DNormalScratch); + } + const east = Cartesian3_default.cross( + Cartesian3_default.UNIT_Z, + normal, + projectTo2DEastScratch + ); + Cartesian3_default.normalize(east, east); + const north = Cartesian3_default.cross(normal, east, projectTo2DNorthScratch); + Cartesian3_default.normalize(north, north); + Cartesian3_default.multiplyByScalar(normal, radius, normal); + Cartesian3_default.multiplyByScalar(north, radius, north); + Cartesian3_default.multiplyByScalar(east, radius, east); + const south = Cartesian3_default.negate(north, projectTo2DSouthScratch); + const west = Cartesian3_default.negate(east, projectTo2DWestScratch); + const positions = projectTo2DPositionsScratch; + let corner = positions[0]; + Cartesian3_default.add(normal, north, corner); + Cartesian3_default.add(corner, east, corner); + corner = positions[1]; + Cartesian3_default.add(normal, north, corner); + Cartesian3_default.add(corner, west, corner); + corner = positions[2]; + Cartesian3_default.add(normal, south, corner); + Cartesian3_default.add(corner, west, corner); + corner = positions[3]; + Cartesian3_default.add(normal, south, corner); + Cartesian3_default.add(corner, east, corner); + Cartesian3_default.negate(normal, normal); + corner = positions[4]; + Cartesian3_default.add(normal, north, corner); + Cartesian3_default.add(corner, east, corner); + corner = positions[5]; + Cartesian3_default.add(normal, north, corner); + Cartesian3_default.add(corner, west, corner); + corner = positions[6]; + Cartesian3_default.add(normal, south, corner); + Cartesian3_default.add(corner, west, corner); + corner = positions[7]; + Cartesian3_default.add(normal, south, corner); + Cartesian3_default.add(corner, east, corner); + const length = positions.length; + for (let i = 0; i < length; ++i) { + const position = positions[i]; + Cartesian3_default.add(center, position, position); + const cartographic = ellipsoid.cartesianToCartographic( + position, + projectTo2DCartographicScratch + ); + projection.project(cartographic, position); + } + result = BoundingSphere.fromPoints(positions, result); + center = result.center; + const x = center.x; + const y = center.y; + const z = center.z; + center.x = z; + center.y = x; + center.z = y; + return result; +}; +BoundingSphere.isOccluded = function(sphere, occluder) { + Check_default.typeOf.object("sphere", sphere); + Check_default.typeOf.object("occluder", occluder); + return !occluder.isBoundingSphereVisible(sphere); +}; +BoundingSphere.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && Cartesian3_default.equals(left.center, right.center) && left.radius === right.radius; +}; +BoundingSphere.prototype.intersectPlane = function(plane) { + return BoundingSphere.intersectPlane(this, plane); +}; +BoundingSphere.prototype.distanceSquaredTo = function(cartesian) { + return BoundingSphere.distanceSquaredTo(this, cartesian); +}; +BoundingSphere.prototype.computePlaneDistances = function(position, direction, result) { + return BoundingSphere.computePlaneDistances( + this, + position, + direction, + result + ); +}; +BoundingSphere.prototype.isOccluded = function(occluder) { + return BoundingSphere.isOccluded(this, occluder); +}; +BoundingSphere.prototype.equals = function(right) { + return BoundingSphere.equals(this, right); +}; +BoundingSphere.prototype.clone = function(result) { + return BoundingSphere.clone(this, result); +}; +BoundingSphere.prototype.volume = function() { + const radius = this.radius; + return volumeConstant * radius * radius * radius; +}; +var BoundingSphere_default = BoundingSphere; + +// packages/engine/Source/Core/binarySearch.js +function binarySearch(array, itemToFind, comparator) { + Check_default.defined("array", array); + Check_default.defined("itemToFind", itemToFind); + Check_default.defined("comparator", comparator); + let low = 0; + let high = array.length - 1; + let i; + let comparison; + while (low <= high) { + i = ~~((low + high) / 2); + comparison = comparator(array[i], itemToFind); + if (comparison < 0) { + low = i + 1; + continue; + } + if (comparison > 0) { + high = i - 1; + continue; + } + return i; + } + return ~(high + 1); +} +var binarySearch_default = binarySearch; + +// packages/engine/Source/Core/EarthOrientationParametersSample.js +function EarthOrientationParametersSample(xPoleWander, yPoleWander, xPoleOffset, yPoleOffset, ut1MinusUtc) { + this.xPoleWander = xPoleWander; + this.yPoleWander = yPoleWander; + this.xPoleOffset = xPoleOffset; + this.yPoleOffset = yPoleOffset; + this.ut1MinusUtc = ut1MinusUtc; +} +var EarthOrientationParametersSample_default = EarthOrientationParametersSample; + +// packages/engine/Source/Core/GregorianDate.js +function GregorianDate(year, month, day, hour, minute, second, millisecond, isLeapSecond) { + this.year = year; + this.month = month; + this.day = day; + this.hour = hour; + this.minute = minute; + this.second = second; + this.millisecond = millisecond; + this.isLeapSecond = isLeapSecond; +} +var GregorianDate_default = GregorianDate; + +// packages/engine/Source/Core/isLeapYear.js +function isLeapYear(year) { + if (year === null || isNaN(year)) { + throw new DeveloperError_default("year is required and must be a number."); + } + return year % 4 === 0 && year % 100 !== 0 || year % 400 === 0; +} +var isLeapYear_default = isLeapYear; + +// packages/engine/Source/Core/LeapSecond.js +function LeapSecond(date, offset) { + this.julianDate = date; + this.offset = offset; +} +var LeapSecond_default = LeapSecond; + +// packages/engine/Source/Core/TimeConstants.js +var TimeConstants = { + /** + * The number of seconds in one millisecond: 0.001 + * @type {number} + * @constant + */ + SECONDS_PER_MILLISECOND: 1e-3, + /** + * The number of seconds in one minute: 60. + * @type {number} + * @constant + */ + SECONDS_PER_MINUTE: 60, + /** + * The number of minutes in one hour: 60. + * @type {number} + * @constant + */ + MINUTES_PER_HOUR: 60, + /** + * The number of hours in one day: 24. + * @type {number} + * @constant + */ + HOURS_PER_DAY: 24, + /** + * The number of seconds in one hour: 3600. + * @type {number} + * @constant + */ + SECONDS_PER_HOUR: 3600, + /** + * The number of minutes in one day: 1440. + * @type {number} + * @constant + */ + MINUTES_PER_DAY: 1440, + /** + * The number of seconds in one day, ignoring leap seconds: 86400. + * @type {number} + * @constant + */ + SECONDS_PER_DAY: 86400, + /** + * The number of days in one Julian century: 36525. + * @type {number} + * @constant + */ + DAYS_PER_JULIAN_CENTURY: 36525, + /** + * One trillionth of a second. + * @type {number} + * @constant + */ + PICOSECOND: 1e-9, + /** + * The number of days to subtract from a Julian date to determine the + * modified Julian date, which gives the number of days since midnight + * on November 17, 1858. + * @type {number} + * @constant + */ + MODIFIED_JULIAN_DATE_DIFFERENCE: 24000005e-1 +}; +var TimeConstants_default = Object.freeze(TimeConstants); + +// packages/engine/Source/Core/TimeStandard.js +var TimeStandard = { + /** + * Represents the coordinated Universal Time (UTC) time standard. + * + * UTC is related to TAI according to the relationship + * UTC = TAI - deltaT where deltaT is the number of leap + * seconds which have been introduced as of the time in TAI. + * + * @type {number} + * @constant + */ + UTC: 0, + /** + * Represents the International Atomic Time (TAI) time standard. + * TAI is the principal time standard to which the other time standards are related. + * + * @type {number} + * @constant + */ + TAI: 1 +}; +var TimeStandard_default = Object.freeze(TimeStandard); + +// packages/engine/Source/Core/JulianDate.js +var gregorianDateScratch = new GregorianDate_default(); +var daysInMonth = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]; +var daysInLeapFeburary = 29; +function compareLeapSecondDates(leapSecond, dateToFind) { + return JulianDate.compare(leapSecond.julianDate, dateToFind.julianDate); +} +var binarySearchScratchLeapSecond = new LeapSecond_default(); +function convertUtcToTai(julianDate) { + binarySearchScratchLeapSecond.julianDate = julianDate; + const leapSeconds = JulianDate.leapSeconds; + let index = binarySearch_default( + leapSeconds, + binarySearchScratchLeapSecond, + compareLeapSecondDates + ); + if (index < 0) { + index = ~index; + } + if (index >= leapSeconds.length) { + index = leapSeconds.length - 1; + } + let offset = leapSeconds[index].offset; + if (index > 0) { + const difference = JulianDate.secondsDifference( + leapSeconds[index].julianDate, + julianDate + ); + if (difference > offset) { + index--; + offset = leapSeconds[index].offset; + } + } + JulianDate.addSeconds(julianDate, offset, julianDate); +} +function convertTaiToUtc(julianDate, result) { + binarySearchScratchLeapSecond.julianDate = julianDate; + const leapSeconds = JulianDate.leapSeconds; + let index = binarySearch_default( + leapSeconds, + binarySearchScratchLeapSecond, + compareLeapSecondDates + ); + if (index < 0) { + index = ~index; + } + if (index === 0) { + return JulianDate.addSeconds(julianDate, -leapSeconds[0].offset, result); + } + if (index >= leapSeconds.length) { + return JulianDate.addSeconds( + julianDate, + -leapSeconds[index - 1].offset, + result + ); + } + const difference = JulianDate.secondsDifference( + leapSeconds[index].julianDate, + julianDate + ); + if (difference === 0) { + return JulianDate.addSeconds( + julianDate, + -leapSeconds[index].offset, + result + ); + } + if (difference <= 1) { + return void 0; + } + return JulianDate.addSeconds( + julianDate, + -leapSeconds[--index].offset, + result + ); +} +function setComponents(wholeDays, secondsOfDay, julianDate) { + const extraDays = secondsOfDay / TimeConstants_default.SECONDS_PER_DAY | 0; + wholeDays += extraDays; + secondsOfDay -= TimeConstants_default.SECONDS_PER_DAY * extraDays; + if (secondsOfDay < 0) { + wholeDays--; + secondsOfDay += TimeConstants_default.SECONDS_PER_DAY; + } + julianDate.dayNumber = wholeDays; + julianDate.secondsOfDay = secondsOfDay; + return julianDate; +} +function computeJulianDateComponents(year, month, day, hour, minute, second, millisecond) { + const a3 = (month - 14) / 12 | 0; + const b = year + 4800 + a3; + let dayNumber = (1461 * b / 4 | 0) + (367 * (month - 2 - 12 * a3) / 12 | 0) - (3 * ((b + 100) / 100 | 0) / 4 | 0) + day - 32075; + hour = hour - 12; + if (hour < 0) { + hour += 24; + } + const secondsOfDay = second + (hour * TimeConstants_default.SECONDS_PER_HOUR + minute * TimeConstants_default.SECONDS_PER_MINUTE + millisecond * TimeConstants_default.SECONDS_PER_MILLISECOND); + if (secondsOfDay >= 43200) { + dayNumber -= 1; + } + return [dayNumber, secondsOfDay]; +} +var matchCalendarYear = /^(\d{4})$/; +var matchCalendarMonth = /^(\d{4})-(\d{2})$/; +var matchOrdinalDate = /^(\d{4})-?(\d{3})$/; +var matchWeekDate = /^(\d{4})-?W(\d{2})-?(\d{1})?$/; +var matchCalendarDate = /^(\d{4})-?(\d{2})-?(\d{2})$/; +var utcOffset = /([Z+\-])?(\d{2})?:?(\d{2})?$/; +var matchHours = /^(\d{2})(\.\d+)?/.source + utcOffset.source; +var matchHoursMinutes = /^(\d{2}):?(\d{2})(\.\d+)?/.source + utcOffset.source; +var matchHoursMinutesSeconds = /^(\d{2}):?(\d{2}):?(\d{2})(\.\d+)?/.source + utcOffset.source; +var iso8601ErrorMessage = "Invalid ISO 8601 date."; +function JulianDate(julianDayNumber, secondsOfDay, timeStandard) { + this.dayNumber = void 0; + this.secondsOfDay = void 0; + julianDayNumber = defaultValue_default(julianDayNumber, 0); + secondsOfDay = defaultValue_default(secondsOfDay, 0); + timeStandard = defaultValue_default(timeStandard, TimeStandard_default.UTC); + const wholeDays = julianDayNumber | 0; + secondsOfDay = secondsOfDay + (julianDayNumber - wholeDays) * TimeConstants_default.SECONDS_PER_DAY; + setComponents(wholeDays, secondsOfDay, this); + if (timeStandard === TimeStandard_default.UTC) { + convertUtcToTai(this); + } +} +JulianDate.fromGregorianDate = function(date, result) { + if (!(date instanceof GregorianDate_default)) { + throw new DeveloperError_default("date must be a valid GregorianDate."); + } + const components = computeJulianDateComponents( + date.year, + date.month, + date.day, + date.hour, + date.minute, + date.second, + date.millisecond + ); + if (!defined_default(result)) { + return new JulianDate(components[0], components[1], TimeStandard_default.UTC); + } + setComponents(components[0], components[1], result); + convertUtcToTai(result); + return result; +}; +JulianDate.fromDate = function(date, result) { + if (!(date instanceof Date) || isNaN(date.getTime())) { + throw new DeveloperError_default("date must be a valid JavaScript Date."); + } + const components = computeJulianDateComponents( + date.getUTCFullYear(), + date.getUTCMonth() + 1, + date.getUTCDate(), + date.getUTCHours(), + date.getUTCMinutes(), + date.getUTCSeconds(), + date.getUTCMilliseconds() + ); + if (!defined_default(result)) { + return new JulianDate(components[0], components[1], TimeStandard_default.UTC); + } + setComponents(components[0], components[1], result); + convertUtcToTai(result); + return result; +}; +JulianDate.fromIso8601 = function(iso8601String, result) { + if (typeof iso8601String !== "string") { + throw new DeveloperError_default(iso8601ErrorMessage); + } + iso8601String = iso8601String.replace(",", "."); + let tokens = iso8601String.split("T"); + let year; + let month = 1; + let day = 1; + let hour = 0; + let minute = 0; + let second = 0; + let millisecond = 0; + const date = tokens[0]; + const time = tokens[1]; + let tmp; + let inLeapYear; + if (!defined_default(date)) { + throw new DeveloperError_default(iso8601ErrorMessage); + } + let dashCount; + tokens = date.match(matchCalendarDate); + if (tokens !== null) { + dashCount = date.split("-").length - 1; + if (dashCount > 0 && dashCount !== 2) { + throw new DeveloperError_default(iso8601ErrorMessage); + } + year = +tokens[1]; + month = +tokens[2]; + day = +tokens[3]; + } else { + tokens = date.match(matchCalendarMonth); + if (tokens !== null) { + year = +tokens[1]; + month = +tokens[2]; + } else { + tokens = date.match(matchCalendarYear); + if (tokens !== null) { + year = +tokens[1]; + } else { + let dayOfYear; + tokens = date.match(matchOrdinalDate); + if (tokens !== null) { + year = +tokens[1]; + dayOfYear = +tokens[2]; + inLeapYear = isLeapYear_default(year); + if (dayOfYear < 1 || inLeapYear && dayOfYear > 366 || !inLeapYear && dayOfYear > 365) { + throw new DeveloperError_default(iso8601ErrorMessage); + } + } else { + tokens = date.match(matchWeekDate); + if (tokens !== null) { + year = +tokens[1]; + const weekNumber = +tokens[2]; + const dayOfWeek = +tokens[3] || 0; + dashCount = date.split("-").length - 1; + if (dashCount > 0 && (!defined_default(tokens[3]) && dashCount !== 1 || defined_default(tokens[3]) && dashCount !== 2)) { + throw new DeveloperError_default(iso8601ErrorMessage); + } + const january4 = new Date(Date.UTC(year, 0, 4)); + dayOfYear = weekNumber * 7 + dayOfWeek - january4.getUTCDay() - 3; + } else { + throw new DeveloperError_default(iso8601ErrorMessage); + } + } + tmp = new Date(Date.UTC(year, 0, 1)); + tmp.setUTCDate(dayOfYear); + month = tmp.getUTCMonth() + 1; + day = tmp.getUTCDate(); + } + } + } + inLeapYear = isLeapYear_default(year); + if (month < 1 || month > 12 || day < 1 || (month !== 2 || !inLeapYear) && day > daysInMonth[month - 1] || inLeapYear && month === 2 && day > daysInLeapFeburary) { + throw new DeveloperError_default(iso8601ErrorMessage); + } + let offsetIndex; + if (defined_default(time)) { + tokens = time.match(matchHoursMinutesSeconds); + if (tokens !== null) { + dashCount = time.split(":").length - 1; + if (dashCount > 0 && dashCount !== 2 && dashCount !== 3) { + throw new DeveloperError_default(iso8601ErrorMessage); + } + hour = +tokens[1]; + minute = +tokens[2]; + second = +tokens[3]; + millisecond = +(tokens[4] || 0) * 1e3; + offsetIndex = 5; + } else { + tokens = time.match(matchHoursMinutes); + if (tokens !== null) { + dashCount = time.split(":").length - 1; + if (dashCount > 2) { + throw new DeveloperError_default(iso8601ErrorMessage); + } + hour = +tokens[1]; + minute = +tokens[2]; + second = +(tokens[3] || 0) * 60; + offsetIndex = 4; + } else { + tokens = time.match(matchHours); + if (tokens !== null) { + hour = +tokens[1]; + minute = +(tokens[2] || 0) * 60; + offsetIndex = 3; + } else { + throw new DeveloperError_default(iso8601ErrorMessage); + } + } + } + if (minute >= 60 || second >= 61 || hour > 24 || hour === 24 && (minute > 0 || second > 0 || millisecond > 0)) { + throw new DeveloperError_default(iso8601ErrorMessage); + } + const offset = tokens[offsetIndex]; + const offsetHours = +tokens[offsetIndex + 1]; + const offsetMinutes = +(tokens[offsetIndex + 2] || 0); + switch (offset) { + case "+": + hour = hour - offsetHours; + minute = minute - offsetMinutes; + break; + case "-": + hour = hour + offsetHours; + minute = minute + offsetMinutes; + break; + case "Z": + break; + default: + minute = minute + new Date( + Date.UTC(year, month - 1, day, hour, minute) + ).getTimezoneOffset(); + break; + } + } + const isLeapSecond = second === 60; + if (isLeapSecond) { + second--; + } + while (minute >= 60) { + minute -= 60; + hour++; + } + while (hour >= 24) { + hour -= 24; + day++; + } + tmp = inLeapYear && month === 2 ? daysInLeapFeburary : daysInMonth[month - 1]; + while (day > tmp) { + day -= tmp; + month++; + if (month > 12) { + month -= 12; + year++; + } + tmp = inLeapYear && month === 2 ? daysInLeapFeburary : daysInMonth[month - 1]; + } + while (minute < 0) { + minute += 60; + hour--; + } + while (hour < 0) { + hour += 24; + day--; + } + while (day < 1) { + month--; + if (month < 1) { + month += 12; + year--; + } + tmp = inLeapYear && month === 2 ? daysInLeapFeburary : daysInMonth[month - 1]; + day += tmp; + } + const components = computeJulianDateComponents( + year, + month, + day, + hour, + minute, + second, + millisecond + ); + if (!defined_default(result)) { + result = new JulianDate(components[0], components[1], TimeStandard_default.UTC); + } else { + setComponents(components[0], components[1], result); + convertUtcToTai(result); + } + if (isLeapSecond) { + JulianDate.addSeconds(result, 1, result); + } + return result; +}; +JulianDate.now = function(result) { + return JulianDate.fromDate(/* @__PURE__ */ new Date(), result); +}; +var toGregorianDateScratch = new JulianDate(0, 0, TimeStandard_default.TAI); +JulianDate.toGregorianDate = function(julianDate, result) { + if (!defined_default(julianDate)) { + throw new DeveloperError_default("julianDate is required."); + } + let isLeapSecond = false; + let thisUtc = convertTaiToUtc(julianDate, toGregorianDateScratch); + if (!defined_default(thisUtc)) { + JulianDate.addSeconds(julianDate, -1, toGregorianDateScratch); + thisUtc = convertTaiToUtc(toGregorianDateScratch, toGregorianDateScratch); + isLeapSecond = true; + } + let julianDayNumber = thisUtc.dayNumber; + const secondsOfDay = thisUtc.secondsOfDay; + if (secondsOfDay >= 43200) { + julianDayNumber += 1; + } + let L = julianDayNumber + 68569 | 0; + const N = 4 * L / 146097 | 0; + L = L - ((146097 * N + 3) / 4 | 0) | 0; + const I = 4e3 * (L + 1) / 1461001 | 0; + L = L - (1461 * I / 4 | 0) + 31 | 0; + const J = 80 * L / 2447 | 0; + const day = L - (2447 * J / 80 | 0) | 0; + L = J / 11 | 0; + const month = J + 2 - 12 * L | 0; + const year = 100 * (N - 49) + I + L | 0; + let hour = secondsOfDay / TimeConstants_default.SECONDS_PER_HOUR | 0; + let remainingSeconds = secondsOfDay - hour * TimeConstants_default.SECONDS_PER_HOUR; + const minute = remainingSeconds / TimeConstants_default.SECONDS_PER_MINUTE | 0; + remainingSeconds = remainingSeconds - minute * TimeConstants_default.SECONDS_PER_MINUTE; + let second = remainingSeconds | 0; + const millisecond = (remainingSeconds - second) / TimeConstants_default.SECONDS_PER_MILLISECOND; + hour += 12; + if (hour > 23) { + hour -= 24; + } + if (isLeapSecond) { + second += 1; + } + if (!defined_default(result)) { + return new GregorianDate_default( + year, + month, + day, + hour, + minute, + second, + millisecond, + isLeapSecond + ); + } + result.year = year; + result.month = month; + result.day = day; + result.hour = hour; + result.minute = minute; + result.second = second; + result.millisecond = millisecond; + result.isLeapSecond = isLeapSecond; + return result; +}; +JulianDate.toDate = function(julianDate) { + if (!defined_default(julianDate)) { + throw new DeveloperError_default("julianDate is required."); + } + const gDate = JulianDate.toGregorianDate(julianDate, gregorianDateScratch); + let second = gDate.second; + if (gDate.isLeapSecond) { + second -= 1; + } + return new Date( + Date.UTC( + gDate.year, + gDate.month - 1, + gDate.day, + gDate.hour, + gDate.minute, + second, + gDate.millisecond + ) + ); +}; +JulianDate.toIso8601 = function(julianDate, precision) { + if (!defined_default(julianDate)) { + throw new DeveloperError_default("julianDate is required."); + } + const gDate = JulianDate.toGregorianDate(julianDate, gregorianDateScratch); + let year = gDate.year; + let month = gDate.month; + let day = gDate.day; + let hour = gDate.hour; + const minute = gDate.minute; + const second = gDate.second; + const millisecond = gDate.millisecond; + if (year === 1e4 && month === 1 && day === 1 && hour === 0 && minute === 0 && second === 0 && millisecond === 0) { + year = 9999; + month = 12; + day = 31; + hour = 24; + } + let millisecondStr; + if (!defined_default(precision) && millisecond !== 0) { + millisecondStr = (millisecond * 0.01).toString().replace(".", ""); + return `${year.toString().padStart(4, "0")}-${month.toString().padStart(2, "0")}-${day.toString().padStart(2, "0")}T${hour.toString().padStart(2, "0")}:${minute.toString().padStart(2, "0")}:${second.toString().padStart(2, "0")}.${millisecondStr}Z`; + } + if (!defined_default(precision) || precision === 0) { + return `${year.toString().padStart(4, "0")}-${month.toString().padStart(2, "0")}-${day.toString().padStart(2, "0")}T${hour.toString().padStart(2, "0")}:${minute.toString().padStart(2, "0")}:${second.toString().padStart(2, "0")}Z`; + } + millisecondStr = (millisecond * 0.01).toFixed(precision).replace(".", "").slice(0, precision); + return `${year.toString().padStart(4, "0")}-${month.toString().padStart(2, "0")}-${day.toString().padStart(2, "0")}T${hour.toString().padStart(2, "0")}:${minute.toString().padStart(2, "0")}:${second.toString().padStart(2, "0")}.${millisecondStr}Z`; +}; +JulianDate.clone = function(julianDate, result) { + if (!defined_default(julianDate)) { + return void 0; + } + if (!defined_default(result)) { + return new JulianDate( + julianDate.dayNumber, + julianDate.secondsOfDay, + TimeStandard_default.TAI + ); + } + result.dayNumber = julianDate.dayNumber; + result.secondsOfDay = julianDate.secondsOfDay; + return result; +}; +JulianDate.compare = function(left, right) { + if (!defined_default(left)) { + throw new DeveloperError_default("left is required."); + } + if (!defined_default(right)) { + throw new DeveloperError_default("right is required."); + } + const julianDayNumberDifference = left.dayNumber - right.dayNumber; + if (julianDayNumberDifference !== 0) { + return julianDayNumberDifference; + } + return left.secondsOfDay - right.secondsOfDay; +}; +JulianDate.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left.dayNumber === right.dayNumber && left.secondsOfDay === right.secondsOfDay; +}; +JulianDate.equalsEpsilon = function(left, right, epsilon) { + epsilon = defaultValue_default(epsilon, 0); + return left === right || defined_default(left) && defined_default(right) && Math.abs(JulianDate.secondsDifference(left, right)) <= epsilon; +}; +JulianDate.totalDays = function(julianDate) { + if (!defined_default(julianDate)) { + throw new DeveloperError_default("julianDate is required."); + } + return julianDate.dayNumber + julianDate.secondsOfDay / TimeConstants_default.SECONDS_PER_DAY; +}; +JulianDate.secondsDifference = function(left, right) { + if (!defined_default(left)) { + throw new DeveloperError_default("left is required."); + } + if (!defined_default(right)) { + throw new DeveloperError_default("right is required."); + } + const dayDifference = (left.dayNumber - right.dayNumber) * TimeConstants_default.SECONDS_PER_DAY; + return dayDifference + (left.secondsOfDay - right.secondsOfDay); +}; +JulianDate.daysDifference = function(left, right) { + if (!defined_default(left)) { + throw new DeveloperError_default("left is required."); + } + if (!defined_default(right)) { + throw new DeveloperError_default("right is required."); + } + const dayDifference = left.dayNumber - right.dayNumber; + const secondDifference = (left.secondsOfDay - right.secondsOfDay) / TimeConstants_default.SECONDS_PER_DAY; + return dayDifference + secondDifference; +}; +JulianDate.computeTaiMinusUtc = function(julianDate) { + binarySearchScratchLeapSecond.julianDate = julianDate; + const leapSeconds = JulianDate.leapSeconds; + let index = binarySearch_default( + leapSeconds, + binarySearchScratchLeapSecond, + compareLeapSecondDates + ); + if (index < 0) { + index = ~index; + --index; + if (index < 0) { + index = 0; + } + } + return leapSeconds[index].offset; +}; +JulianDate.addSeconds = function(julianDate, seconds, result) { + if (!defined_default(julianDate)) { + throw new DeveloperError_default("julianDate is required."); + } + if (!defined_default(seconds)) { + throw new DeveloperError_default("seconds is required."); + } + if (!defined_default(result)) { + throw new DeveloperError_default("result is required."); + } + return setComponents( + julianDate.dayNumber, + julianDate.secondsOfDay + seconds, + result + ); +}; +JulianDate.addMinutes = function(julianDate, minutes, result) { + if (!defined_default(julianDate)) { + throw new DeveloperError_default("julianDate is required."); + } + if (!defined_default(minutes)) { + throw new DeveloperError_default("minutes is required."); + } + if (!defined_default(result)) { + throw new DeveloperError_default("result is required."); + } + const newSecondsOfDay = julianDate.secondsOfDay + minutes * TimeConstants_default.SECONDS_PER_MINUTE; + return setComponents(julianDate.dayNumber, newSecondsOfDay, result); +}; +JulianDate.addHours = function(julianDate, hours, result) { + if (!defined_default(julianDate)) { + throw new DeveloperError_default("julianDate is required."); + } + if (!defined_default(hours)) { + throw new DeveloperError_default("hours is required."); + } + if (!defined_default(result)) { + throw new DeveloperError_default("result is required."); + } + const newSecondsOfDay = julianDate.secondsOfDay + hours * TimeConstants_default.SECONDS_PER_HOUR; + return setComponents(julianDate.dayNumber, newSecondsOfDay, result); +}; +JulianDate.addDays = function(julianDate, days, result) { + if (!defined_default(julianDate)) { + throw new DeveloperError_default("julianDate is required."); + } + if (!defined_default(days)) { + throw new DeveloperError_default("days is required."); + } + if (!defined_default(result)) { + throw new DeveloperError_default("result is required."); + } + const newJulianDayNumber = julianDate.dayNumber + days; + return setComponents(newJulianDayNumber, julianDate.secondsOfDay, result); +}; +JulianDate.lessThan = function(left, right) { + return JulianDate.compare(left, right) < 0; +}; +JulianDate.lessThanOrEquals = function(left, right) { + return JulianDate.compare(left, right) <= 0; +}; +JulianDate.greaterThan = function(left, right) { + return JulianDate.compare(left, right) > 0; +}; +JulianDate.greaterThanOrEquals = function(left, right) { + return JulianDate.compare(left, right) >= 0; +}; +JulianDate.prototype.clone = function(result) { + return JulianDate.clone(this, result); +}; +JulianDate.prototype.equals = function(right) { + return JulianDate.equals(this, right); +}; +JulianDate.prototype.equalsEpsilon = function(right, epsilon) { + return JulianDate.equalsEpsilon(this, right, epsilon); +}; +JulianDate.prototype.toString = function() { + return JulianDate.toIso8601(this); +}; +JulianDate.leapSeconds = [ + new LeapSecond_default(new JulianDate(2441317, 43210, TimeStandard_default.TAI), 10), + // January 1, 1972 00:00:00 UTC + new LeapSecond_default(new JulianDate(2441499, 43211, TimeStandard_default.TAI), 11), + // July 1, 1972 00:00:00 UTC + new LeapSecond_default(new JulianDate(2441683, 43212, TimeStandard_default.TAI), 12), + // January 1, 1973 00:00:00 UTC + new LeapSecond_default(new JulianDate(2442048, 43213, TimeStandard_default.TAI), 13), + // January 1, 1974 00:00:00 UTC + new LeapSecond_default(new JulianDate(2442413, 43214, TimeStandard_default.TAI), 14), + // January 1, 1975 00:00:00 UTC + new LeapSecond_default(new JulianDate(2442778, 43215, TimeStandard_default.TAI), 15), + // January 1, 1976 00:00:00 UTC + new LeapSecond_default(new JulianDate(2443144, 43216, TimeStandard_default.TAI), 16), + // January 1, 1977 00:00:00 UTC + new LeapSecond_default(new JulianDate(2443509, 43217, TimeStandard_default.TAI), 17), + // January 1, 1978 00:00:00 UTC + new LeapSecond_default(new JulianDate(2443874, 43218, TimeStandard_default.TAI), 18), + // January 1, 1979 00:00:00 UTC + new LeapSecond_default(new JulianDate(2444239, 43219, TimeStandard_default.TAI), 19), + // January 1, 1980 00:00:00 UTC + new LeapSecond_default(new JulianDate(2444786, 43220, TimeStandard_default.TAI), 20), + // July 1, 1981 00:00:00 UTC + new LeapSecond_default(new JulianDate(2445151, 43221, TimeStandard_default.TAI), 21), + // July 1, 1982 00:00:00 UTC + new LeapSecond_default(new JulianDate(2445516, 43222, TimeStandard_default.TAI), 22), + // July 1, 1983 00:00:00 UTC + new LeapSecond_default(new JulianDate(2446247, 43223, TimeStandard_default.TAI), 23), + // July 1, 1985 00:00:00 UTC + new LeapSecond_default(new JulianDate(2447161, 43224, TimeStandard_default.TAI), 24), + // January 1, 1988 00:00:00 UTC + new LeapSecond_default(new JulianDate(2447892, 43225, TimeStandard_default.TAI), 25), + // January 1, 1990 00:00:00 UTC + new LeapSecond_default(new JulianDate(2448257, 43226, TimeStandard_default.TAI), 26), + // January 1, 1991 00:00:00 UTC + new LeapSecond_default(new JulianDate(2448804, 43227, TimeStandard_default.TAI), 27), + // July 1, 1992 00:00:00 UTC + new LeapSecond_default(new JulianDate(2449169, 43228, TimeStandard_default.TAI), 28), + // July 1, 1993 00:00:00 UTC + new LeapSecond_default(new JulianDate(2449534, 43229, TimeStandard_default.TAI), 29), + // July 1, 1994 00:00:00 UTC + new LeapSecond_default(new JulianDate(2450083, 43230, TimeStandard_default.TAI), 30), + // January 1, 1996 00:00:00 UTC + new LeapSecond_default(new JulianDate(2450630, 43231, TimeStandard_default.TAI), 31), + // July 1, 1997 00:00:00 UTC + new LeapSecond_default(new JulianDate(2451179, 43232, TimeStandard_default.TAI), 32), + // January 1, 1999 00:00:00 UTC + new LeapSecond_default(new JulianDate(2453736, 43233, TimeStandard_default.TAI), 33), + // January 1, 2006 00:00:00 UTC + new LeapSecond_default(new JulianDate(2454832, 43234, TimeStandard_default.TAI), 34), + // January 1, 2009 00:00:00 UTC + new LeapSecond_default(new JulianDate(2456109, 43235, TimeStandard_default.TAI), 35), + // July 1, 2012 00:00:00 UTC + new LeapSecond_default(new JulianDate(2457204, 43236, TimeStandard_default.TAI), 36), + // July 1, 2015 00:00:00 UTC + new LeapSecond_default(new JulianDate(2457754, 43237, TimeStandard_default.TAI), 37) + // January 1, 2017 00:00:00 UTC +]; +var JulianDate_default = JulianDate; + +// packages/engine/Source/Core/Resource.js +var import_urijs6 = __toESM(require_URI(), 1); + +// packages/engine/Source/Core/appendForwardSlash.js +function appendForwardSlash(url) { + if (url.length === 0 || url[url.length - 1] !== "/") { + url = `${url}/`; + } + return url; +} +var appendForwardSlash_default = appendForwardSlash; + +// packages/engine/Source/Core/clone.js +function clone(object, deep) { + if (object === null || typeof object !== "object") { + return object; + } + deep = defaultValue_default(deep, false); + const result = new object.constructor(); + for (const propertyName in object) { + if (object.hasOwnProperty(propertyName)) { + let value = object[propertyName]; + if (deep) { + value = clone(value, deep); + } + result[propertyName] = value; + } + } + return result; +} +var clone_default = clone; + +// packages/engine/Source/Core/defer.js +function defer() { + let resolve; + let reject; + const promise = new Promise(function(res, rej) { + resolve = res; + reject = rej; + }); + return { + resolve, + reject, + promise + }; +} +var defer_default = defer; + +// packages/engine/Source/Core/getAbsoluteUri.js +var import_urijs = __toESM(require_URI(), 1); +function getAbsoluteUri(relative, base) { + let documentObject; + if (typeof document !== "undefined") { + documentObject = document; + } + return getAbsoluteUri._implementation(relative, base, documentObject); +} +getAbsoluteUri._implementation = function(relative, base, documentObject) { + if (!defined_default(relative)) { + throw new DeveloperError_default("relative uri is required."); + } + if (!defined_default(base)) { + if (typeof documentObject === "undefined") { + return relative; + } + base = defaultValue_default(documentObject.baseURI, documentObject.location.href); + } + const relativeUri = new import_urijs.default(relative); + if (relativeUri.scheme() !== "") { + return relativeUri.toString(); + } + return relativeUri.absoluteTo(base).toString(); +}; +var getAbsoluteUri_default = getAbsoluteUri; + +// packages/engine/Source/Core/getBaseUri.js +var import_urijs2 = __toESM(require_URI(), 1); +function getBaseUri(uri, includeQuery) { + if (!defined_default(uri)) { + throw new DeveloperError_default("uri is required."); + } + let basePath = ""; + const i = uri.lastIndexOf("/"); + if (i !== -1) { + basePath = uri.substring(0, i + 1); + } + if (!includeQuery) { + return basePath; + } + uri = new import_urijs2.default(uri); + if (uri.query().length !== 0) { + basePath += `?${uri.query()}`; + } + if (uri.fragment().length !== 0) { + basePath += `#${uri.fragment()}`; + } + return basePath; +} +var getBaseUri_default = getBaseUri; + +// packages/engine/Source/Core/getExtensionFromUri.js +var import_urijs3 = __toESM(require_URI(), 1); +function getExtensionFromUri(uri) { + if (!defined_default(uri)) { + throw new DeveloperError_default("uri is required."); + } + const uriObject = new import_urijs3.default(uri); + uriObject.normalize(); + let path = uriObject.path(); + let index = path.lastIndexOf("/"); + if (index !== -1) { + path = path.substr(index + 1); + } + index = path.lastIndexOf("."); + if (index === -1) { + path = ""; + } else { + path = path.substr(index + 1); + } + return path; +} +var getExtensionFromUri_default = getExtensionFromUri; + +// packages/engine/Source/Core/getImagePixels.js +var context2DsByWidthAndHeight = {}; +function getImagePixels(image, width, height) { + if (!defined_default(width)) { + width = image.width; + } + if (!defined_default(height)) { + height = image.height; + } + let context2DsByHeight = context2DsByWidthAndHeight[width]; + if (!defined_default(context2DsByHeight)) { + context2DsByHeight = {}; + context2DsByWidthAndHeight[width] = context2DsByHeight; + } + let context2d = context2DsByHeight[height]; + if (!defined_default(context2d)) { + const canvas = document.createElement("canvas"); + canvas.width = width; + canvas.height = height; + context2d = canvas.getContext("2d", { willReadFrequently: true }); + context2d.globalCompositeOperation = "copy"; + context2DsByHeight[height] = context2d; + } + context2d.drawImage(image, 0, 0, width, height); + return context2d.getImageData(0, 0, width, height).data; +} +var getImagePixels_default = getImagePixels; + +// packages/engine/Source/Core/isBlobUri.js +var blobUriRegex = /^blob:/i; +function isBlobUri(uri) { + Check_default.typeOf.string("uri", uri); + return blobUriRegex.test(uri); +} +var isBlobUri_default = isBlobUri; + +// packages/engine/Source/Core/isCrossOriginUrl.js +var a; +function isCrossOriginUrl(url) { + if (!defined_default(a)) { + a = document.createElement("a"); + } + a.href = window.location.href; + const host = a.host; + const protocol = a.protocol; + a.href = url; + a.href = a.href; + return protocol !== a.protocol || host !== a.host; +} +var isCrossOriginUrl_default = isCrossOriginUrl; + +// packages/engine/Source/Core/isDataUri.js +var dataUriRegex = /^data:/i; +function isDataUri(uri) { + Check_default.typeOf.string("uri", uri); + return dataUriRegex.test(uri); +} +var isDataUri_default = isDataUri; + +// packages/engine/Source/Core/loadAndExecuteScript.js +function loadAndExecuteScript(url) { + const script = document.createElement("script"); + script.async = true; + script.src = url; + return new Promise((resolve, reject) => { + if (window.crossOriginIsolated) { + script.setAttribute("crossorigin", "anonymous"); + } + const head = document.getElementsByTagName("head")[0]; + script.onload = function() { + script.onload = void 0; + head.removeChild(script); + resolve(); + }; + script.onerror = function(e) { + reject(e); + }; + head.appendChild(script); + }); +} +var loadAndExecuteScript_default = loadAndExecuteScript; + +// packages/engine/Source/Core/objectToQuery.js +function objectToQuery(obj) { + if (!defined_default(obj)) { + throw new DeveloperError_default("obj is required."); + } + let result = ""; + for (const propName in obj) { + if (obj.hasOwnProperty(propName)) { + const value = obj[propName]; + const part = `${encodeURIComponent(propName)}=`; + if (Array.isArray(value)) { + for (let i = 0, len = value.length; i < len; ++i) { + result += `${part + encodeURIComponent(value[i])}&`; + } + } else { + result += `${part + encodeURIComponent(value)}&`; + } + } + } + result = result.slice(0, -1); + return result; +} +var objectToQuery_default = objectToQuery; + +// packages/engine/Source/Core/queryToObject.js +function queryToObject(queryString) { + if (!defined_default(queryString)) { + throw new DeveloperError_default("queryString is required."); + } + const result = {}; + if (queryString === "") { + return result; + } + const parts = queryString.replace(/\+/g, "%20").split(/[&;]/); + for (let i = 0, len = parts.length; i < len; ++i) { + const subparts = parts[i].split("="); + const name = decodeURIComponent(subparts[0]); + let value = subparts[1]; + if (defined_default(value)) { + value = decodeURIComponent(value); + } else { + value = ""; + } + const resultValue = result[name]; + if (typeof resultValue === "string") { + result[name] = [resultValue, value]; + } else if (Array.isArray(resultValue)) { + resultValue.push(value); + } else { + result[name] = value; + } + } + return result; +} +var queryToObject_default = queryToObject; + +// packages/engine/Source/Core/RequestState.js +var RequestState = { + /** + * Initial unissued state. + * + * @type {number} + * @constant + */ + UNISSUED: 0, + /** + * Issued but not yet active. Will become active when open slots are available. + * + * @type {number} + * @constant + */ + ISSUED: 1, + /** + * Actual http request has been sent. + * + * @type {number} + * @constant + */ + ACTIVE: 2, + /** + * Request completed successfully. + * + * @type {number} + * @constant + */ + RECEIVED: 3, + /** + * Request was cancelled, either explicitly or automatically because of low priority. + * + * @type {number} + * @constant + */ + CANCELLED: 4, + /** + * Request failed. + * + * @type {number} + * @constant + */ + FAILED: 5 +}; +var RequestState_default = Object.freeze(RequestState); + +// packages/engine/Source/Core/RequestType.js +var RequestType = { + /** + * Terrain request. + * + * @type {number} + * @constant + */ + TERRAIN: 0, + /** + * Imagery request. + * + * @type {number} + * @constant + */ + IMAGERY: 1, + /** + * 3D Tiles request. + * + * @type {number} + * @constant + */ + TILES3D: 2, + /** + * Other request. + * + * @type {number} + * @constant + */ + OTHER: 3 +}; +var RequestType_default = Object.freeze(RequestType); + +// packages/engine/Source/Core/Request.js +function Request(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const throttleByServer = defaultValue_default(options.throttleByServer, false); + const throttle = defaultValue_default(options.throttle, false); + this.url = options.url; + this.requestFunction = options.requestFunction; + this.cancelFunction = options.cancelFunction; + this.priorityFunction = options.priorityFunction; + this.priority = defaultValue_default(options.priority, 0); + this.throttle = throttle; + this.throttleByServer = throttleByServer; + this.type = defaultValue_default(options.type, RequestType_default.OTHER); + this.serverKey = options.serverKey; + this.state = RequestState_default.UNISSUED; + this.deferred = void 0; + this.cancelled = false; +} +Request.prototype.cancel = function() { + this.cancelled = true; +}; +Request.prototype.clone = function(result) { + if (!defined_default(result)) { + return new Request(this); + } + result.url = this.url; + result.requestFunction = this.requestFunction; + result.cancelFunction = this.cancelFunction; + result.priorityFunction = this.priorityFunction; + result.priority = this.priority; + result.throttle = this.throttle; + result.throttleByServer = this.throttleByServer; + result.type = this.type; + result.serverKey = this.serverKey; + result.state = RequestState_default.UNISSUED; + result.deferred = void 0; + result.cancelled = false; + return result; +}; +var Request_default = Request; + +// packages/engine/Source/Core/parseResponseHeaders.js +function parseResponseHeaders(headerString) { + const headers = {}; + if (!headerString) { + return headers; + } + const headerPairs = headerString.split("\r\n"); + for (let i = 0; i < headerPairs.length; ++i) { + const headerPair = headerPairs[i]; + const index = headerPair.indexOf(": "); + if (index > 0) { + const key = headerPair.substring(0, index); + const val = headerPair.substring(index + 2); + headers[key] = val; + } + } + return headers; +} +var parseResponseHeaders_default = parseResponseHeaders; + +// packages/engine/Source/Core/RequestErrorEvent.js +function RequestErrorEvent(statusCode, response, responseHeaders) { + this.statusCode = statusCode; + this.response = response; + this.responseHeaders = responseHeaders; + if (typeof this.responseHeaders === "string") { + this.responseHeaders = parseResponseHeaders_default(this.responseHeaders); + } +} +RequestErrorEvent.prototype.toString = function() { + let str = "Request has failed."; + if (defined_default(this.statusCode)) { + str += ` Status Code: ${this.statusCode}`; + } + return str; +}; +var RequestErrorEvent_default = RequestErrorEvent; + +// packages/engine/Source/Core/RequestScheduler.js +var import_urijs4 = __toESM(require_URI(), 1); + +// packages/engine/Source/Core/Event.js +function Event() { + this._listeners = []; + this._scopes = []; + this._toRemove = []; + this._insideRaiseEvent = false; +} +Object.defineProperties(Event.prototype, { + /** + * The number of listeners currently subscribed to the event. + * @memberof Event.prototype + * @type {number} + * @readonly + */ + numberOfListeners: { + get: function() { + return this._listeners.length - this._toRemove.length; + } + } +}); +Event.prototype.addEventListener = function(listener, scope) { + Check_default.typeOf.func("listener", listener); + this._listeners.push(listener); + this._scopes.push(scope); + const event = this; + return function() { + event.removeEventListener(listener, scope); + }; +}; +Event.prototype.removeEventListener = function(listener, scope) { + Check_default.typeOf.func("listener", listener); + const listeners = this._listeners; + const scopes = this._scopes; + let index = -1; + for (let i = 0; i < listeners.length; i++) { + if (listeners[i] === listener && scopes[i] === scope) { + index = i; + break; + } + } + if (index !== -1) { + if (this._insideRaiseEvent) { + this._toRemove.push(index); + listeners[index] = void 0; + scopes[index] = void 0; + } else { + listeners.splice(index, 1); + scopes.splice(index, 1); + } + return true; + } + return false; +}; +function compareNumber(a3, b) { + return b - a3; +} +Event.prototype.raiseEvent = function() { + this._insideRaiseEvent = true; + let i; + const listeners = this._listeners; + const scopes = this._scopes; + let length = listeners.length; + for (i = 0; i < length; i++) { + const listener = listeners[i]; + if (defined_default(listener)) { + listeners[i].apply(scopes[i], arguments); + } + } + const toRemove = this._toRemove; + length = toRemove.length; + if (length > 0) { + toRemove.sort(compareNumber); + for (i = 0; i < length; i++) { + const index = toRemove[i]; + listeners.splice(index, 1); + scopes.splice(index, 1); + } + toRemove.length = 0; + } + this._insideRaiseEvent = false; +}; +var Event_default = Event; + +// packages/engine/Source/Core/Heap.js +function Heap(options) { + Check_default.typeOf.object("options", options); + Check_default.defined("options.comparator", options.comparator); + this._comparator = options.comparator; + this._array = []; + this._length = 0; + this._maximumLength = void 0; +} +Object.defineProperties(Heap.prototype, { + /** + * Gets the length of the heap. + * + * @memberof Heap.prototype + * + * @type {number} + * @readonly + */ + length: { + get: function() { + return this._length; + } + }, + /** + * Gets the internal array. + * + * @memberof Heap.prototype + * + * @type {Array} + * @readonly + */ + internalArray: { + get: function() { + return this._array; + } + }, + /** + * Gets and sets the maximum length of the heap. + * + * @memberof Heap.prototype + * + * @type {number} + */ + maximumLength: { + get: function() { + return this._maximumLength; + }, + set: function(value) { + Check_default.typeOf.number.greaterThanOrEquals("maximumLength", value, 0); + const originalLength = this._length; + if (value < originalLength) { + const array = this._array; + for (let i = value; i < originalLength; ++i) { + array[i] = void 0; + } + this._length = value; + array.length = value; + } + this._maximumLength = value; + } + }, + /** + * The comparator to use for the heap. If comparator(a, b) is less than 0, sort a to a lower index than b, otherwise sort to a higher index. + * + * @memberof Heap.prototype + * + * @type {Heap.ComparatorCallback} + */ + comparator: { + get: function() { + return this._comparator; + } + } +}); +function swap(array, a3, b) { + const temp = array[a3]; + array[a3] = array[b]; + array[b] = temp; +} +Heap.prototype.reserve = function(length) { + length = defaultValue_default(length, this._length); + this._array.length = length; +}; +Heap.prototype.heapify = function(index) { + index = defaultValue_default(index, 0); + const length = this._length; + const comparator = this._comparator; + const array = this._array; + let candidate = -1; + let inserting = true; + while (inserting) { + const right = 2 * (index + 1); + const left = right - 1; + if (left < length && comparator(array[left], array[index]) < 0) { + candidate = left; + } else { + candidate = index; + } + if (right < length && comparator(array[right], array[candidate]) < 0) { + candidate = right; + } + if (candidate !== index) { + swap(array, candidate, index); + index = candidate; + } else { + inserting = false; + } + } +}; +Heap.prototype.resort = function() { + const length = this._length; + for (let i = Math.ceil(length / 2); i >= 0; --i) { + this.heapify(i); + } +}; +Heap.prototype.insert = function(element) { + Check_default.defined("element", element); + const array = this._array; + const comparator = this._comparator; + const maximumLength = this._maximumLength; + let index = this._length++; + if (index < array.length) { + array[index] = element; + } else { + array.push(element); + } + while (index !== 0) { + const parent = Math.floor((index - 1) / 2); + if (comparator(array[index], array[parent]) < 0) { + swap(array, index, parent); + index = parent; + } else { + break; + } + } + let removedElement; + if (defined_default(maximumLength) && this._length > maximumLength) { + removedElement = array[maximumLength]; + this._length = maximumLength; + } + return removedElement; +}; +Heap.prototype.pop = function(index) { + index = defaultValue_default(index, 0); + if (this._length === 0) { + return void 0; + } + Check_default.typeOf.number.lessThan("index", index, this._length); + const array = this._array; + const root = array[index]; + swap(array, index, --this._length); + this.heapify(index); + array[this._length] = void 0; + return root; +}; +var Heap_default = Heap; + +// packages/engine/Source/Core/RequestScheduler.js +function sortRequests(a3, b) { + return a3.priority - b.priority; +} +var statistics = { + numberOfAttemptedRequests: 0, + numberOfActiveRequests: 0, + numberOfCancelledRequests: 0, + numberOfCancelledActiveRequests: 0, + numberOfFailedRequests: 0, + numberOfActiveRequestsEver: 0, + lastNumberOfActiveRequests: 0 +}; +var priorityHeapLength = 20; +var requestHeap = new Heap_default({ + comparator: sortRequests +}); +requestHeap.maximumLength = priorityHeapLength; +requestHeap.reserve(priorityHeapLength); +var activeRequests = []; +var numberOfActiveRequestsByServer = {}; +var pageUri = typeof document !== "undefined" ? new import_urijs4.default(document.location.href) : new import_urijs4.default(); +var requestCompletedEvent = new Event_default(); +function RequestScheduler() { +} +RequestScheduler.maximumRequests = 50; +RequestScheduler.maximumRequestsPerServer = 6; +RequestScheduler.requestsByServer = { + "api.cesium.com:443": 18, + "assets.ion.cesium.com:443": 18, + "ibasemaps-api.arcgis.com:443": 18, + "tile.googleapis.com:443": 18, + "tile.openstreetmap.org:443": 18 +}; +RequestScheduler.throttleRequests = true; +RequestScheduler.debugShowStatistics = false; +RequestScheduler.requestCompletedEvent = requestCompletedEvent; +Object.defineProperties(RequestScheduler, { + /** + * Returns the statistics used by the request scheduler. + * + * @memberof RequestScheduler + * + * @type {object} + * @readonly + * @private + */ + statistics: { + get: function() { + return statistics; + } + }, + /** + * The maximum size of the priority heap. This limits the number of requests that are sorted by priority. Only applies to requests that are not yet active. + * + * @memberof RequestScheduler + * + * @type {number} + * @default 20 + * @private + */ + priorityHeapLength: { + get: function() { + return priorityHeapLength; + }, + set: function(value) { + if (value < priorityHeapLength) { + while (requestHeap.length > value) { + const request = requestHeap.pop(); + cancelRequest(request); + } + } + priorityHeapLength = value; + requestHeap.maximumLength = value; + requestHeap.reserve(value); + } + } +}); +function updatePriority(request) { + if (defined_default(request.priorityFunction)) { + request.priority = request.priorityFunction(); + } +} +RequestScheduler.serverHasOpenSlots = function(serverKey, desiredRequests) { + desiredRequests = defaultValue_default(desiredRequests, 1); + const maxRequests = defaultValue_default( + RequestScheduler.requestsByServer[serverKey], + RequestScheduler.maximumRequestsPerServer + ); + const hasOpenSlotsServer = numberOfActiveRequestsByServer[serverKey] + desiredRequests <= maxRequests; + return hasOpenSlotsServer; +}; +RequestScheduler.heapHasOpenSlots = function(desiredRequests) { + const hasOpenSlotsHeap = requestHeap.length + desiredRequests <= priorityHeapLength; + return hasOpenSlotsHeap; +}; +function issueRequest(request) { + if (request.state === RequestState_default.UNISSUED) { + request.state = RequestState_default.ISSUED; + request.deferred = defer_default(); + } + return request.deferred.promise; +} +function getRequestReceivedFunction(request) { + return function(results) { + if (request.state === RequestState_default.CANCELLED) { + return; + } + const deferred = request.deferred; + --statistics.numberOfActiveRequests; + --numberOfActiveRequestsByServer[request.serverKey]; + requestCompletedEvent.raiseEvent(); + request.state = RequestState_default.RECEIVED; + request.deferred = void 0; + deferred.resolve(results); + }; +} +function getRequestFailedFunction(request) { + return function(error) { + if (request.state === RequestState_default.CANCELLED) { + return; + } + ++statistics.numberOfFailedRequests; + --statistics.numberOfActiveRequests; + --numberOfActiveRequestsByServer[request.serverKey]; + requestCompletedEvent.raiseEvent(error); + request.state = RequestState_default.FAILED; + request.deferred.reject(error); + }; +} +function startRequest(request) { + const promise = issueRequest(request); + request.state = RequestState_default.ACTIVE; + activeRequests.push(request); + ++statistics.numberOfActiveRequests; + ++statistics.numberOfActiveRequestsEver; + ++numberOfActiveRequestsByServer[request.serverKey]; + request.requestFunction().then(getRequestReceivedFunction(request)).catch(getRequestFailedFunction(request)); + return promise; +} +function cancelRequest(request) { + const active = request.state === RequestState_default.ACTIVE; + request.state = RequestState_default.CANCELLED; + ++statistics.numberOfCancelledRequests; + if (defined_default(request.deferred)) { + const deferred = request.deferred; + request.deferred = void 0; + deferred.reject(); + } + if (active) { + --statistics.numberOfActiveRequests; + --numberOfActiveRequestsByServer[request.serverKey]; + ++statistics.numberOfCancelledActiveRequests; + } + if (defined_default(request.cancelFunction)) { + request.cancelFunction(); + } +} +RequestScheduler.update = function() { + let i; + let request; + let removeCount = 0; + const activeLength = activeRequests.length; + for (i = 0; i < activeLength; ++i) { + request = activeRequests[i]; + if (request.cancelled) { + cancelRequest(request); + } + if (request.state !== RequestState_default.ACTIVE) { + ++removeCount; + continue; + } + if (removeCount > 0) { + activeRequests[i - removeCount] = request; + } + } + activeRequests.length -= removeCount; + const issuedRequests = requestHeap.internalArray; + const issuedLength = requestHeap.length; + for (i = 0; i < issuedLength; ++i) { + updatePriority(issuedRequests[i]); + } + requestHeap.resort(); + const openSlots = Math.max( + RequestScheduler.maximumRequests - activeRequests.length, + 0 + ); + let filledSlots = 0; + while (filledSlots < openSlots && requestHeap.length > 0) { + request = requestHeap.pop(); + if (request.cancelled) { + cancelRequest(request); + continue; + } + if (request.throttleByServer && !RequestScheduler.serverHasOpenSlots(request.serverKey)) { + cancelRequest(request); + continue; + } + startRequest(request); + ++filledSlots; + } + updateStatistics(); +}; +RequestScheduler.getServerKey = function(url) { + Check_default.typeOf.string("url", url); + let uri = new import_urijs4.default(url); + if (uri.scheme() === "") { + uri = uri.absoluteTo(pageUri); + uri.normalize(); + } + let serverKey = uri.authority(); + if (!/:/.test(serverKey)) { + serverKey = `${serverKey}:${uri.scheme() === "https" ? "443" : "80"}`; + } + const length = numberOfActiveRequestsByServer[serverKey]; + if (!defined_default(length)) { + numberOfActiveRequestsByServer[serverKey] = 0; + } + return serverKey; +}; +RequestScheduler.request = function(request) { + Check_default.typeOf.object("request", request); + Check_default.typeOf.string("request.url", request.url); + Check_default.typeOf.func("request.requestFunction", request.requestFunction); + if (isDataUri_default(request.url) || isBlobUri_default(request.url)) { + requestCompletedEvent.raiseEvent(); + request.state = RequestState_default.RECEIVED; + return request.requestFunction(); + } + ++statistics.numberOfAttemptedRequests; + if (!defined_default(request.serverKey)) { + request.serverKey = RequestScheduler.getServerKey(request.url); + } + if (RequestScheduler.throttleRequests && request.throttleByServer && !RequestScheduler.serverHasOpenSlots(request.serverKey)) { + return void 0; + } + if (!RequestScheduler.throttleRequests || !request.throttle) { + return startRequest(request); + } + if (activeRequests.length >= RequestScheduler.maximumRequests) { + return void 0; + } + updatePriority(request); + const removedRequest = requestHeap.insert(request); + if (defined_default(removedRequest)) { + if (removedRequest === request) { + return void 0; + } + cancelRequest(removedRequest); + } + return issueRequest(request); +}; +function updateStatistics() { + if (!RequestScheduler.debugShowStatistics) { + return; + } + if (statistics.numberOfActiveRequests === 0 && statistics.lastNumberOfActiveRequests > 0) { + if (statistics.numberOfAttemptedRequests > 0) { + console.log( + `Number of attempted requests: ${statistics.numberOfAttemptedRequests}` + ); + statistics.numberOfAttemptedRequests = 0; + } + if (statistics.numberOfCancelledRequests > 0) { + console.log( + `Number of cancelled requests: ${statistics.numberOfCancelledRequests}` + ); + statistics.numberOfCancelledRequests = 0; + } + if (statistics.numberOfCancelledActiveRequests > 0) { + console.log( + `Number of cancelled active requests: ${statistics.numberOfCancelledActiveRequests}` + ); + statistics.numberOfCancelledActiveRequests = 0; + } + if (statistics.numberOfFailedRequests > 0) { + console.log( + `Number of failed requests: ${statistics.numberOfFailedRequests}` + ); + statistics.numberOfFailedRequests = 0; + } + } + statistics.lastNumberOfActiveRequests = statistics.numberOfActiveRequests; +} +RequestScheduler.clearForSpecs = function() { + while (requestHeap.length > 0) { + const request = requestHeap.pop(); + cancelRequest(request); + } + const length = activeRequests.length; + for (let i = 0; i < length; ++i) { + cancelRequest(activeRequests[i]); + } + activeRequests.length = 0; + numberOfActiveRequestsByServer = {}; + statistics.numberOfAttemptedRequests = 0; + statistics.numberOfActiveRequests = 0; + statistics.numberOfCancelledRequests = 0; + statistics.numberOfCancelledActiveRequests = 0; + statistics.numberOfFailedRequests = 0; + statistics.numberOfActiveRequestsEver = 0; + statistics.lastNumberOfActiveRequests = 0; +}; +RequestScheduler.numberOfActiveRequestsByServer = function(serverKey) { + return numberOfActiveRequestsByServer[serverKey]; +}; +RequestScheduler.requestHeap = requestHeap; +var RequestScheduler_default = RequestScheduler; + +// packages/engine/Source/Core/TrustedServers.js +var import_urijs5 = __toESM(require_URI(), 1); +var TrustedServers = {}; +var _servers = {}; +TrustedServers.add = function(host, port) { + if (!defined_default(host)) { + throw new DeveloperError_default("host is required."); + } + if (!defined_default(port) || port <= 0) { + throw new DeveloperError_default("port is required to be greater than 0."); + } + const authority = `${host.toLowerCase()}:${port}`; + if (!defined_default(_servers[authority])) { + _servers[authority] = true; + } +}; +TrustedServers.remove = function(host, port) { + if (!defined_default(host)) { + throw new DeveloperError_default("host is required."); + } + if (!defined_default(port) || port <= 0) { + throw new DeveloperError_default("port is required to be greater than 0."); + } + const authority = `${host.toLowerCase()}:${port}`; + if (defined_default(_servers[authority])) { + delete _servers[authority]; + } +}; +function getAuthority(url) { + const uri = new import_urijs5.default(url); + uri.normalize(); + let authority = uri.authority(); + if (authority.length === 0) { + return void 0; + } + uri.authority(authority); + if (authority.indexOf("@") !== -1) { + const parts = authority.split("@"); + authority = parts[1]; + } + if (authority.indexOf(":") === -1) { + let scheme = uri.scheme(); + if (scheme.length === 0) { + scheme = window.location.protocol; + scheme = scheme.substring(0, scheme.length - 1); + } + if (scheme === "http") { + authority += ":80"; + } else if (scheme === "https") { + authority += ":443"; + } else { + return void 0; + } + } + return authority; +} +TrustedServers.contains = function(url) { + if (!defined_default(url)) { + throw new DeveloperError_default("url is required."); + } + const authority = getAuthority(url); + if (defined_default(authority) && defined_default(_servers[authority])) { + return true; + } + return false; +}; +TrustedServers.clear = function() { + _servers = {}; +}; +var TrustedServers_default = TrustedServers; + +// packages/engine/Source/Core/Resource.js +var xhrBlobSupported = function() { + try { + const xhr = new XMLHttpRequest(); + xhr.open("GET", "#", true); + xhr.responseType = "blob"; + return xhr.responseType === "blob"; + } catch (e) { + return false; + } +}(); +function Resource(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + if (typeof options === "string") { + options = { + url: options + }; + } + Check_default.typeOf.string("options.url", options.url); + this._url = void 0; + this._templateValues = defaultClone(options.templateValues, {}); + this._queryParameters = defaultClone(options.queryParameters, {}); + this.headers = defaultClone(options.headers, {}); + this.request = defaultValue_default(options.request, new Request_default()); + this.proxy = options.proxy; + this.retryCallback = options.retryCallback; + this.retryAttempts = defaultValue_default(options.retryAttempts, 0); + this._retryCount = 0; + const parseUrl = defaultValue_default(options.parseUrl, true); + if (parseUrl) { + this.parseUrl(options.url, true, true); + } else { + this._url = options.url; + } + this._credits = options.credits; +} +function defaultClone(value, defaultValue) { + return defined_default(value) ? clone_default(value) : defaultValue; +} +Resource.createIfNeeded = function(resource) { + if (resource instanceof Resource) { + return resource.getDerivedResource({ + request: resource.request + }); + } + if (typeof resource !== "string") { + return resource; + } + return new Resource({ + url: resource + }); +}; +var supportsImageBitmapOptionsPromise; +Resource.supportsImageBitmapOptions = function() { + if (defined_default(supportsImageBitmapOptionsPromise)) { + return supportsImageBitmapOptionsPromise; + } + if (typeof createImageBitmap !== "function") { + supportsImageBitmapOptionsPromise = Promise.resolve(false); + return supportsImageBitmapOptionsPromise; + } + const imageDataUri = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAABGdBTUEAAE4g3rEiDgAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAADElEQVQI12Ng6GAAAAEUAIngE3ZiAAAAAElFTkSuQmCC"; + supportsImageBitmapOptionsPromise = Resource.fetchBlob({ + url: imageDataUri + }).then(function(blob) { + const imageBitmapOptions = { + imageOrientation: "flipY", + // default is "none" + premultiplyAlpha: "none", + // default is "default" + colorSpaceConversion: "none" + // default is "default" + }; + return Promise.all([ + createImageBitmap(blob, imageBitmapOptions), + createImageBitmap(blob) + ]); + }).then(function(imageBitmaps) { + const colorWithOptions = getImagePixels_default(imageBitmaps[0]); + const colorWithDefaults = getImagePixels_default(imageBitmaps[1]); + return colorWithOptions[1] !== colorWithDefaults[1]; + }).catch(function() { + return false; + }); + return supportsImageBitmapOptionsPromise; +}; +Object.defineProperties(Resource, { + /** + * Returns true if blobs are supported. + * + * @memberof Resource + * @type {boolean} + * + * @readonly + */ + isBlobSupported: { + get: function() { + return xhrBlobSupported; + } + } +}); +Object.defineProperties(Resource.prototype, { + /** + * Query parameters appended to the url. + * + * @memberof Resource.prototype + * @type {object} + * + * @readonly + */ + queryParameters: { + get: function() { + return this._queryParameters; + } + }, + /** + * The key/value pairs used to replace template parameters in the url. + * + * @memberof Resource.prototype + * @type {object} + * + * @readonly + */ + templateValues: { + get: function() { + return this._templateValues; + } + }, + /** + * The url to the resource with template values replaced, query string appended and encoded by proxy if one was set. + * + * @memberof Resource.prototype + * @type {string} + */ + url: { + get: function() { + return this.getUrlComponent(true, true); + }, + set: function(value) { + this.parseUrl(value, false, false); + } + }, + /** + * The file extension of the resource. + * + * @memberof Resource.prototype + * @type {string} + * + * @readonly + */ + extension: { + get: function() { + return getExtensionFromUri_default(this._url); + } + }, + /** + * True if the Resource refers to a data URI. + * + * @memberof Resource.prototype + * @type {boolean} + */ + isDataUri: { + get: function() { + return isDataUri_default(this._url); + } + }, + /** + * True if the Resource refers to a blob URI. + * + * @memberof Resource.prototype + * @type {boolean} + */ + isBlobUri: { + get: function() { + return isBlobUri_default(this._url); + } + }, + /** + * True if the Resource refers to a cross origin URL. + * + * @memberof Resource.prototype + * @type {boolean} + */ + isCrossOriginUrl: { + get: function() { + return isCrossOriginUrl_default(this._url); + } + }, + /** + * True if the Resource has request headers. This is equivalent to checking if the headers property has any keys. + * + * @memberof Resource.prototype + * @type {boolean} + */ + hasHeaders: { + get: function() { + return Object.keys(this.headers).length > 0; + } + }, + /** + * Gets the credits required for attribution of an asset. + * @private + */ + credits: { + get: function() { + return this._credits; + } + } +}); +Resource.prototype.toString = function() { + return this.getUrlComponent(true, true); +}; +Resource.prototype.parseUrl = function(url, merge, preserveQuery, baseUrl) { + let uri = new import_urijs6.default(url); + const query = parseQueryString(uri.query()); + this._queryParameters = merge ? combineQueryParameters(query, this.queryParameters, preserveQuery) : query; + uri.search(""); + uri.fragment(""); + if (defined_default(baseUrl) && uri.scheme() === "") { + uri = uri.absoluteTo(getAbsoluteUri_default(baseUrl)); + } + this._url = uri.toString(); +}; +function parseQueryString(queryString) { + if (queryString.length === 0) { + return {}; + } + if (queryString.indexOf("=") === -1) { + return { [queryString]: void 0 }; + } + return queryToObject_default(queryString); +} +function combineQueryParameters(q1, q2, preserveQueryParameters) { + if (!preserveQueryParameters) { + return combine_default(q1, q2); + } + const result = clone_default(q1, true); + for (const param in q2) { + if (q2.hasOwnProperty(param)) { + let value = result[param]; + const q2Value = q2[param]; + if (defined_default(value)) { + if (!Array.isArray(value)) { + value = result[param] = [value]; + } + result[param] = value.concat(q2Value); + } else { + result[param] = Array.isArray(q2Value) ? q2Value.slice() : q2Value; + } + } + } + return result; +} +Resource.prototype.getUrlComponent = function(query, proxy) { + if (this.isDataUri) { + return this._url; + } + let url = this._url; + if (query) { + url = `${url}${stringifyQuery(this.queryParameters)}`; + } + url = url.replace(/%7B/g, "{").replace(/%7D/g, "}"); + const templateValues = this._templateValues; + if (Object.keys(templateValues).length > 0) { + url = url.replace(/{(.*?)}/g, function(match, key) { + const replacement = templateValues[key]; + if (defined_default(replacement)) { + return encodeURIComponent(replacement); + } + return match; + }); + } + if (proxy && defined_default(this.proxy)) { + url = this.proxy.getURL(url); + } + return url; +}; +function stringifyQuery(queryObject) { + const keys = Object.keys(queryObject); + if (keys.length === 0) { + return ""; + } + if (keys.length === 1 && !defined_default(queryObject[keys[0]])) { + return `?${keys[0]}`; + } + return `?${objectToQuery_default(queryObject)}`; +} +Resource.prototype.setQueryParameters = function(params, useAsDefault) { + if (useAsDefault) { + this._queryParameters = combineQueryParameters( + this._queryParameters, + params, + false + ); + } else { + this._queryParameters = combineQueryParameters( + params, + this._queryParameters, + false + ); + } +}; +Resource.prototype.appendQueryParameters = function(params) { + this._queryParameters = combineQueryParameters( + params, + this._queryParameters, + true + ); +}; +Resource.prototype.setTemplateValues = function(template, useAsDefault) { + if (useAsDefault) { + this._templateValues = combine_default(this._templateValues, template); + } else { + this._templateValues = combine_default(template, this._templateValues); + } +}; +Resource.prototype.getDerivedResource = function(options) { + const resource = this.clone(); + resource._retryCount = 0; + if (defined_default(options.url)) { + const preserveQuery = defaultValue_default(options.preserveQueryParameters, false); + resource.parseUrl(options.url, true, preserveQuery, this._url); + } + if (defined_default(options.queryParameters)) { + resource._queryParameters = combine_default( + options.queryParameters, + resource.queryParameters + ); + } + if (defined_default(options.templateValues)) { + resource._templateValues = combine_default( + options.templateValues, + resource.templateValues + ); + } + if (defined_default(options.headers)) { + resource.headers = combine_default(options.headers, resource.headers); + } + if (defined_default(options.proxy)) { + resource.proxy = options.proxy; + } + if (defined_default(options.request)) { + resource.request = options.request; + } + if (defined_default(options.retryCallback)) { + resource.retryCallback = options.retryCallback; + } + if (defined_default(options.retryAttempts)) { + resource.retryAttempts = options.retryAttempts; + } + return resource; +}; +Resource.prototype.retryOnError = function(error) { + const retryCallback = this.retryCallback; + if (typeof retryCallback !== "function" || this._retryCount >= this.retryAttempts) { + return Promise.resolve(false); + } + const that = this; + return Promise.resolve(retryCallback(this, error)).then(function(result) { + ++that._retryCount; + return result; + }); +}; +Resource.prototype.clone = function(result) { + if (!defined_default(result)) { + return new Resource({ + url: this._url, + queryParameters: this.queryParameters, + templateValues: this.templateValues, + headers: this.headers, + proxy: this.proxy, + retryCallback: this.retryCallback, + retryAttempts: this.retryAttempts, + request: this.request.clone(), + parseUrl: false, + credits: defined_default(this.credits) ? this.credits.slice() : void 0 + }); + } + result._url = this._url; + result._queryParameters = clone_default(this._queryParameters); + result._templateValues = clone_default(this._templateValues); + result.headers = clone_default(this.headers); + result.proxy = this.proxy; + result.retryCallback = this.retryCallback; + result.retryAttempts = this.retryAttempts; + result._retryCount = 0; + result.request = this.request.clone(); + return result; +}; +Resource.prototype.getBaseUri = function(includeQuery) { + return getBaseUri_default(this.getUrlComponent(includeQuery), includeQuery); +}; +Resource.prototype.appendForwardSlash = function() { + this._url = appendForwardSlash_default(this._url); +}; +Resource.prototype.fetchArrayBuffer = function() { + return this.fetch({ + responseType: "arraybuffer" + }); +}; +Resource.fetchArrayBuffer = function(options) { + const resource = new Resource(options); + return resource.fetchArrayBuffer(); +}; +Resource.prototype.fetchBlob = function() { + return this.fetch({ + responseType: "blob" + }); +}; +Resource.fetchBlob = function(options) { + const resource = new Resource(options); + return resource.fetchBlob(); +}; +Resource.prototype.fetchImage = function(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const preferImageBitmap = defaultValue_default(options.preferImageBitmap, false); + const preferBlob = defaultValue_default(options.preferBlob, false); + const flipY = defaultValue_default(options.flipY, false); + const skipColorSpaceConversion = defaultValue_default( + options.skipColorSpaceConversion, + false + ); + checkAndResetRequest(this.request); + if (!xhrBlobSupported || this.isDataUri || this.isBlobUri || !this.hasHeaders && !preferBlob) { + return fetchImage({ + resource: this, + flipY, + skipColorSpaceConversion, + preferImageBitmap + }); + } + const blobPromise = this.fetchBlob(); + if (!defined_default(blobPromise)) { + return; + } + let supportsImageBitmap; + let useImageBitmap; + let generatedBlobResource; + let generatedBlob; + return Resource.supportsImageBitmapOptions().then(function(result) { + supportsImageBitmap = result; + useImageBitmap = supportsImageBitmap && preferImageBitmap; + return blobPromise; + }).then(function(blob) { + if (!defined_default(blob)) { + return; + } + generatedBlob = blob; + if (useImageBitmap) { + return Resource.createImageBitmapFromBlob(blob, { + flipY, + premultiplyAlpha: false, + skipColorSpaceConversion + }); + } + const blobUrl = window.URL.createObjectURL(blob); + generatedBlobResource = new Resource({ + url: blobUrl + }); + return fetchImage({ + resource: generatedBlobResource, + flipY, + skipColorSpaceConversion, + preferImageBitmap: false + }); + }).then(function(image) { + if (!defined_default(image)) { + return; + } + image.blob = generatedBlob; + if (useImageBitmap) { + return image; + } + window.URL.revokeObjectURL(generatedBlobResource.url); + return image; + }).catch(function(error) { + if (defined_default(generatedBlobResource)) { + window.URL.revokeObjectURL(generatedBlobResource.url); + } + error.blob = generatedBlob; + return Promise.reject(error); + }); +}; +function fetchImage(options) { + const resource = options.resource; + const flipY = options.flipY; + const skipColorSpaceConversion = options.skipColorSpaceConversion; + const preferImageBitmap = options.preferImageBitmap; + const request = resource.request; + request.url = resource.url; + request.requestFunction = function() { + let crossOrigin = false; + if (!resource.isDataUri && !resource.isBlobUri) { + crossOrigin = resource.isCrossOriginUrl; + } + const deferred = defer_default(); + Resource._Implementations.createImage( + request, + crossOrigin, + deferred, + flipY, + skipColorSpaceConversion, + preferImageBitmap + ); + return deferred.promise; + }; + const promise = RequestScheduler_default.request(request); + if (!defined_default(promise)) { + return; + } + return promise.catch(function(e) { + if (request.state !== RequestState_default.FAILED) { + return Promise.reject(e); + } + return resource.retryOnError(e).then(function(retry) { + if (retry) { + request.state = RequestState_default.UNISSUED; + request.deferred = void 0; + return fetchImage({ + resource, + flipY, + skipColorSpaceConversion, + preferImageBitmap + }); + } + return Promise.reject(e); + }); + }); +} +Resource.fetchImage = function(options) { + const resource = new Resource(options); + return resource.fetchImage({ + flipY: options.flipY, + skipColorSpaceConversion: options.skipColorSpaceConversion, + preferBlob: options.preferBlob, + preferImageBitmap: options.preferImageBitmap + }); +}; +Resource.prototype.fetchText = function() { + return this.fetch({ + responseType: "text" + }); +}; +Resource.fetchText = function(options) { + const resource = new Resource(options); + return resource.fetchText(); +}; +Resource.prototype.fetchJson = function() { + const promise = this.fetch({ + responseType: "text", + headers: { + Accept: "application/json,*/*;q=0.01" + } + }); + if (!defined_default(promise)) { + return void 0; + } + return promise.then(function(value) { + if (!defined_default(value)) { + return; + } + return JSON.parse(value); + }); +}; +Resource.fetchJson = function(options) { + const resource = new Resource(options); + return resource.fetchJson(); +}; +Resource.prototype.fetchXML = function() { + return this.fetch({ + responseType: "document", + overrideMimeType: "text/xml" + }); +}; +Resource.fetchXML = function(options) { + const resource = new Resource(options); + return resource.fetchXML(); +}; +Resource.prototype.fetchJsonp = function(callbackParameterName) { + callbackParameterName = defaultValue_default(callbackParameterName, "callback"); + checkAndResetRequest(this.request); + let functionName; + do { + functionName = `loadJsonp${Math_default.nextRandomNumber().toString().substring(2, 8)}`; + } while (defined_default(window[functionName])); + return fetchJsonp(this, callbackParameterName, functionName); +}; +function fetchJsonp(resource, callbackParameterName, functionName) { + const callbackQuery = {}; + callbackQuery[callbackParameterName] = functionName; + resource.setQueryParameters(callbackQuery); + const request = resource.request; + const url = resource.url; + request.url = url; + request.requestFunction = function() { + const deferred = defer_default(); + window[functionName] = function(data) { + deferred.resolve(data); + try { + delete window[functionName]; + } catch (e) { + window[functionName] = void 0; + } + }; + Resource._Implementations.loadAndExecuteScript(url, functionName, deferred); + return deferred.promise; + }; + const promise = RequestScheduler_default.request(request); + if (!defined_default(promise)) { + return; + } + return promise.catch(function(e) { + if (request.state !== RequestState_default.FAILED) { + return Promise.reject(e); + } + return resource.retryOnError(e).then(function(retry) { + if (retry) { + request.state = RequestState_default.UNISSUED; + request.deferred = void 0; + return fetchJsonp(resource, callbackParameterName, functionName); + } + return Promise.reject(e); + }); + }); +} +Resource.fetchJsonp = function(options) { + const resource = new Resource(options); + return resource.fetchJsonp(options.callbackParameterName); +}; +Resource.prototype._makeRequest = function(options) { + const resource = this; + checkAndResetRequest(resource.request); + const request = resource.request; + const url = resource.url; + request.url = url; + request.requestFunction = function() { + const responseType = options.responseType; + const headers = combine_default(options.headers, resource.headers); + const overrideMimeType = options.overrideMimeType; + const method = options.method; + const data = options.data; + const deferred = defer_default(); + const xhr = Resource._Implementations.loadWithXhr( + url, + responseType, + method, + data, + headers, + deferred, + overrideMimeType + ); + if (defined_default(xhr) && defined_default(xhr.abort)) { + request.cancelFunction = function() { + xhr.abort(); + }; + } + return deferred.promise; + }; + const promise = RequestScheduler_default.request(request); + if (!defined_default(promise)) { + return; + } + return promise.then(function(data) { + request.cancelFunction = void 0; + return data; + }).catch(function(e) { + request.cancelFunction = void 0; + if (request.state !== RequestState_default.FAILED) { + return Promise.reject(e); + } + return resource.retryOnError(e).then(function(retry) { + if (retry) { + request.state = RequestState_default.UNISSUED; + request.deferred = void 0; + return resource.fetch(options); + } + return Promise.reject(e); + }); + }); +}; +function checkAndResetRequest(request) { + if (request.state === RequestState_default.ISSUED || request.state === RequestState_default.ACTIVE) { + throw new RuntimeError_default("The Resource is already being fetched."); + } + request.state = RequestState_default.UNISSUED; + request.deferred = void 0; +} +var dataUriRegex2 = /^data:(.*?)(;base64)?,(.*)$/; +function decodeDataUriText(isBase64, data) { + const result = decodeURIComponent(data); + if (isBase64) { + return atob(result); + } + return result; +} +function decodeDataUriArrayBuffer(isBase64, data) { + const byteString = decodeDataUriText(isBase64, data); + const buffer = new ArrayBuffer(byteString.length); + const view = new Uint8Array(buffer); + for (let i = 0; i < byteString.length; i++) { + view[i] = byteString.charCodeAt(i); + } + return buffer; +} +function decodeDataUri(dataUriRegexResult, responseType) { + responseType = defaultValue_default(responseType, ""); + const mimeType = dataUriRegexResult[1]; + const isBase64 = !!dataUriRegexResult[2]; + const data = dataUriRegexResult[3]; + let buffer; + let parser; + switch (responseType) { + case "": + case "text": + return decodeDataUriText(isBase64, data); + case "arraybuffer": + return decodeDataUriArrayBuffer(isBase64, data); + case "blob": + buffer = decodeDataUriArrayBuffer(isBase64, data); + return new Blob([buffer], { + type: mimeType + }); + case "document": + parser = new DOMParser(); + return parser.parseFromString( + decodeDataUriText(isBase64, data), + mimeType + ); + case "json": + return JSON.parse(decodeDataUriText(isBase64, data)); + default: + throw new DeveloperError_default(`Unhandled responseType: ${responseType}`); + } +} +Resource.prototype.fetch = function(options) { + options = defaultClone(options, {}); + options.method = "GET"; + return this._makeRequest(options); +}; +Resource.fetch = function(options) { + const resource = new Resource(options); + return resource.fetch({ + // 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 + }); +}; +Resource.prototype.delete = function(options) { + options = defaultClone(options, {}); + options.method = "DELETE"; + return this._makeRequest(options); +}; +Resource.delete = function(options) { + const resource = new Resource(options); + 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, + data: options.data + }); +}; +Resource.prototype.head = function(options) { + options = defaultClone(options, {}); + options.method = "HEAD"; + return this._makeRequest(options); +}; +Resource.head = function(options) { + const resource = new Resource(options); + return resource.head({ + // 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 + }); +}; +Resource.prototype.options = function(options) { + options = defaultClone(options, {}); + options.method = "OPTIONS"; + return this._makeRequest(options); +}; +Resource.options = function(options) { + const resource = new Resource(options); + return resource.options({ + // 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 + }); +}; +Resource.prototype.post = function(data, options) { + Check_default.defined("data", data); + options = defaultClone(options, {}); + options.method = "POST"; + options.data = data; + return this._makeRequest(options); +}; +Resource.post = function(options) { + const resource = new Resource(options); + return resource.post(options.data, { + // Make copy of just the needed fields because headers can be passed to both the constructor and to post + responseType: options.responseType, + overrideMimeType: options.overrideMimeType + }); +}; +Resource.prototype.put = function(data, options) { + Check_default.defined("data", data); + options = defaultClone(options, {}); + options.method = "PUT"; + options.data = data; + return this._makeRequest(options); +}; +Resource.put = function(options) { + const resource = new Resource(options); + return resource.put(options.data, { + // Make copy of just the needed fields because headers can be passed to both the constructor and to post + responseType: options.responseType, + overrideMimeType: options.overrideMimeType + }); +}; +Resource.prototype.patch = function(data, options) { + Check_default.defined("data", data); + options = defaultClone(options, {}); + options.method = "PATCH"; + options.data = data; + return this._makeRequest(options); +}; +Resource.patch = function(options) { + const resource = new Resource(options); + return resource.patch(options.data, { + // Make copy of just the needed fields because headers can be passed to both the constructor and to post + responseType: options.responseType, + overrideMimeType: options.overrideMimeType + }); +}; +Resource._Implementations = {}; +Resource._Implementations.loadImageElement = function(url, crossOrigin, deferred) { + const image = new Image(); + image.onload = function() { + if (image.naturalWidth === 0 && image.naturalHeight === 0 && image.width === 0 && image.height === 0) { + image.width = 300; + image.height = 150; + } + deferred.resolve(image); + }; + image.onerror = function(e) { + deferred.reject(e); + }; + if (crossOrigin) { + if (TrustedServers_default.contains(url)) { + image.crossOrigin = "use-credentials"; + } else { + image.crossOrigin = ""; + } + } + image.src = url; +}; +Resource._Implementations.createImage = function(request, crossOrigin, deferred, flipY, skipColorSpaceConversion, preferImageBitmap) { + const url = request.url; + Resource.supportsImageBitmapOptions().then(function(supportsImageBitmap) { + if (!(supportsImageBitmap && preferImageBitmap)) { + Resource._Implementations.loadImageElement(url, crossOrigin, deferred); + return; + } + const responseType = "blob"; + const method = "GET"; + const xhrDeferred = defer_default(); + const xhr = Resource._Implementations.loadWithXhr( + url, + responseType, + method, + void 0, + void 0, + xhrDeferred, + void 0, + void 0, + void 0 + ); + if (defined_default(xhr) && defined_default(xhr.abort)) { + request.cancelFunction = function() { + xhr.abort(); + }; + } + return xhrDeferred.promise.then(function(blob) { + if (!defined_default(blob)) { + deferred.reject( + new RuntimeError_default( + `Successfully retrieved ${url} but it contained no content.` + ) + ); + return; + } + return Resource.createImageBitmapFromBlob(blob, { + flipY, + premultiplyAlpha: false, + skipColorSpaceConversion + }); + }).then(function(image) { + deferred.resolve(image); + }); + }).catch(function(e) { + deferred.reject(e); + }); +}; +Resource.createImageBitmapFromBlob = function(blob, options) { + Check_default.defined("options", options); + Check_default.typeOf.bool("options.flipY", options.flipY); + Check_default.typeOf.bool("options.premultiplyAlpha", options.premultiplyAlpha); + Check_default.typeOf.bool( + "options.skipColorSpaceConversion", + options.skipColorSpaceConversion + ); + return createImageBitmap(blob, { + imageOrientation: options.flipY ? "flipY" : "none", + premultiplyAlpha: options.premultiplyAlpha ? "premultiply" : "none", + colorSpaceConversion: options.skipColorSpaceConversion ? "none" : "default" + }); +}; +function decodeResponse(loadWithHttpResponse, responseType) { + switch (responseType) { + case "text": + return loadWithHttpResponse.toString("utf8"); + case "json": + return JSON.parse(loadWithHttpResponse.toString("utf8")); + default: + return new Uint8Array(loadWithHttpResponse).buffer; + } +} +function loadWithHttpRequest(url, responseType, method, data, headers, deferred, overrideMimeType) { + let URL; + let zlib; + Promise.all([import("url"), import("zlib")]).then(([urlImport, zlibImport]) => { + URL = urlImport.parse(url); + zlib = zlibImport; + return URL.protocol === "https:" ? import("https") : import("http"); + }).then((http) => { + const options = { + protocol: URL.protocol, + hostname: URL.hostname, + port: URL.port, + path: URL.path, + query: URL.query, + method, + headers + }; + http.request(options).on("response", function(res) { + if (res.statusCode < 200 || res.statusCode >= 300) { + deferred.reject( + new RequestErrorEvent_default(res.statusCode, res, res.headers) + ); + return; + } + const chunkArray = []; + res.on("data", function(chunk) { + chunkArray.push(chunk); + }); + res.on("end", function() { + const result = Buffer.concat(chunkArray); + if (res.headers["content-encoding"] === "gzip") { + zlib.gunzip(result, function(error, resultUnzipped) { + if (error) { + deferred.reject( + new RuntimeError_default("Error decompressing response.") + ); + } else { + deferred.resolve( + decodeResponse(resultUnzipped, responseType) + ); + } + }); + } else { + deferred.resolve(decodeResponse(result, responseType)); + } + }); + }).on("error", function(e) { + deferred.reject(new RequestErrorEvent_default()); + }).end(); + }); +} +var noXMLHttpRequest = typeof XMLHttpRequest === "undefined"; +Resource._Implementations.loadWithXhr = function(url, responseType, method, data, headers, deferred, overrideMimeType) { + const dataUriRegexResult = dataUriRegex2.exec(url); + if (dataUriRegexResult !== null) { + deferred.resolve(decodeDataUri(dataUriRegexResult, responseType)); + return; + } + if (noXMLHttpRequest) { + loadWithHttpRequest( + url, + responseType, + method, + data, + headers, + deferred, + overrideMimeType + ); + return; + } + const xhr = new XMLHttpRequest(); + if (TrustedServers_default.contains(url)) { + xhr.withCredentials = true; + } + xhr.open(method, url, true); + if (defined_default(overrideMimeType) && defined_default(xhr.overrideMimeType)) { + xhr.overrideMimeType(overrideMimeType); + } + if (defined_default(headers)) { + for (const key in headers) { + if (headers.hasOwnProperty(key)) { + xhr.setRequestHeader(key, headers[key]); + } + } + } + if (defined_default(responseType)) { + xhr.responseType = responseType; + } + let localFile = false; + if (typeof url === "string") { + localFile = url.indexOf("file://") === 0 || typeof window !== "undefined" && window.location.origin === "file://"; + } + xhr.onload = function() { + if ((xhr.status < 200 || xhr.status >= 300) && !(localFile && xhr.status === 0)) { + deferred.reject( + new RequestErrorEvent_default( + xhr.status, + xhr.response, + xhr.getAllResponseHeaders() + ) + ); + return; + } + const response = xhr.response; + const browserResponseType = xhr.responseType; + if (method === "HEAD" || method === "OPTIONS") { + const responseHeaderString = xhr.getAllResponseHeaders(); + const splitHeaders = responseHeaderString.trim().split(/[\r\n]+/); + const responseHeaders = {}; + splitHeaders.forEach(function(line) { + const parts = line.split(": "); + const header = parts.shift(); + responseHeaders[header] = parts.join(": "); + }); + deferred.resolve(responseHeaders); + return; + } + if (xhr.status === 204) { + deferred.resolve(); + } else if (defined_default(response) && (!defined_default(responseType) || browserResponseType === responseType)) { + deferred.resolve(response); + } else if (responseType === "json" && typeof response === "string") { + try { + deferred.resolve(JSON.parse(response)); + } catch (e) { + deferred.reject(e); + } + } else if ((browserResponseType === "" || browserResponseType === "document") && defined_default(xhr.responseXML) && xhr.responseXML.hasChildNodes()) { + deferred.resolve(xhr.responseXML); + } else if ((browserResponseType === "" || browserResponseType === "text") && defined_default(xhr.responseText)) { + deferred.resolve(xhr.responseText); + } else { + deferred.reject( + new RuntimeError_default("Invalid XMLHttpRequest response type.") + ); + } + }; + xhr.onerror = function(e) { + deferred.reject(new RequestErrorEvent_default()); + }; + xhr.send(data); + return xhr; +}; +Resource._Implementations.loadAndExecuteScript = function(url, functionName, deferred) { + return loadAndExecuteScript_default(url, functionName).catch(function(e) { + deferred.reject(e); + }); +}; +Resource._DefaultImplementations = {}; +Resource._DefaultImplementations.createImage = Resource._Implementations.createImage; +Resource._DefaultImplementations.loadWithXhr = Resource._Implementations.loadWithXhr; +Resource._DefaultImplementations.loadAndExecuteScript = Resource._Implementations.loadAndExecuteScript; +Resource.DEFAULT = Object.freeze( + new Resource({ + url: typeof document === "undefined" ? "" : document.location.href.split("?")[0] + }) +); +var Resource_default = Resource; + +// packages/engine/Source/Core/EarthOrientationParameters.js +function EarthOrientationParameters(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + this._dates = void 0; + this._samples = void 0; + this._dateColumn = -1; + this._xPoleWanderRadiansColumn = -1; + this._yPoleWanderRadiansColumn = -1; + this._ut1MinusUtcSecondsColumn = -1; + this._xCelestialPoleOffsetRadiansColumn = -1; + this._yCelestialPoleOffsetRadiansColumn = -1; + this._taiMinusUtcSecondsColumn = -1; + this._columnCount = 0; + this._lastIndex = -1; + this._addNewLeapSeconds = defaultValue_default(options.addNewLeapSeconds, true); + if (defined_default(options.data)) { + onDataReady(this, options.data); + } else { + onDataReady(this, { + columnNames: [ + "dateIso8601", + "modifiedJulianDateUtc", + "xPoleWanderRadians", + "yPoleWanderRadians", + "ut1MinusUtcSeconds", + "lengthOfDayCorrectionSeconds", + "xCelestialPoleOffsetRadians", + "yCelestialPoleOffsetRadians", + "taiMinusUtcSeconds" + ], + samples: [] + }); + } +} +EarthOrientationParameters.fromUrl = async function(url, options) { + Check_default.defined("url", url); + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const resource = Resource_default.createIfNeeded(url); + let eopData; + try { + eopData = await resource.fetchJson(); + } catch (e) { + throw new RuntimeError_default( + `An error occurred while retrieving the EOP data from the URL ${resource.url}.` + ); + } + return new EarthOrientationParameters({ + addNewLeapSeconds: options.addNewLeapSeconds, + data: eopData + }); +}; +EarthOrientationParameters.NONE = Object.freeze({ + compute: function(date, result) { + if (!defined_default(result)) { + result = new EarthOrientationParametersSample_default(0, 0, 0, 0, 0); + } else { + result.xPoleWander = 0; + result.yPoleWander = 0; + result.xPoleOffset = 0; + result.yPoleOffset = 0; + result.ut1MinusUtc = 0; + } + return result; + } +}); +EarthOrientationParameters.prototype.compute = function(date, result) { + if (!defined_default(this._samples)) { + return void 0; + } + if (!defined_default(result)) { + result = new EarthOrientationParametersSample_default(0, 0, 0, 0, 0); + } + if (this._samples.length === 0) { + result.xPoleWander = 0; + result.yPoleWander = 0; + result.xPoleOffset = 0; + result.yPoleOffset = 0; + result.ut1MinusUtc = 0; + return result; + } + const dates = this._dates; + const lastIndex = this._lastIndex; + let before = 0; + let after = 0; + if (defined_default(lastIndex)) { + const previousIndexDate = dates[lastIndex]; + const nextIndexDate = dates[lastIndex + 1]; + const isAfterPrevious = JulianDate_default.lessThanOrEquals( + previousIndexDate, + date + ); + const isAfterLastSample = !defined_default(nextIndexDate); + const isBeforeNext = isAfterLastSample || JulianDate_default.greaterThanOrEquals(nextIndexDate, date); + if (isAfterPrevious && isBeforeNext) { + before = lastIndex; + if (!isAfterLastSample && nextIndexDate.equals(date)) { + ++before; + } + after = before + 1; + interpolate(this, dates, this._samples, date, before, after, result); + return result; + } + } + let index = binarySearch_default(dates, date, JulianDate_default.compare, this._dateColumn); + if (index >= 0) { + if (index < dates.length - 1 && dates[index + 1].equals(date)) { + ++index; + } + before = index; + after = index; + } else { + after = ~index; + before = after - 1; + if (before < 0) { + before = 0; + } + } + this._lastIndex = before; + interpolate(this, dates, this._samples, date, before, after, result); + return result; +}; +function compareLeapSecondDates2(leapSecond, dateToFind) { + return JulianDate_default.compare(leapSecond.julianDate, dateToFind); +} +function onDataReady(eop, eopData) { + if (!defined_default(eopData.columnNames)) { + throw new RuntimeError_default( + "Error in loaded EOP data: The columnNames property is required." + ); + } + if (!defined_default(eopData.samples)) { + throw new RuntimeError_default( + "Error in loaded EOP data: The samples property is required." + ); + } + const dateColumn = eopData.columnNames.indexOf("modifiedJulianDateUtc"); + const xPoleWanderRadiansColumn = eopData.columnNames.indexOf( + "xPoleWanderRadians" + ); + const yPoleWanderRadiansColumn = eopData.columnNames.indexOf( + "yPoleWanderRadians" + ); + const ut1MinusUtcSecondsColumn = eopData.columnNames.indexOf( + "ut1MinusUtcSeconds" + ); + const xCelestialPoleOffsetRadiansColumn = eopData.columnNames.indexOf( + "xCelestialPoleOffsetRadians" + ); + const yCelestialPoleOffsetRadiansColumn = eopData.columnNames.indexOf( + "yCelestialPoleOffsetRadians" + ); + const taiMinusUtcSecondsColumn = eopData.columnNames.indexOf( + "taiMinusUtcSeconds" + ); + if (dateColumn < 0 || xPoleWanderRadiansColumn < 0 || yPoleWanderRadiansColumn < 0 || ut1MinusUtcSecondsColumn < 0 || xCelestialPoleOffsetRadiansColumn < 0 || yCelestialPoleOffsetRadiansColumn < 0 || taiMinusUtcSecondsColumn < 0) { + throw new RuntimeError_default( + "Error in loaded EOP data: The columnNames property must include modifiedJulianDateUtc, xPoleWanderRadians, yPoleWanderRadians, ut1MinusUtcSeconds, xCelestialPoleOffsetRadians, yCelestialPoleOffsetRadians, and taiMinusUtcSeconds columns" + ); + } + const samples = eop._samples = eopData.samples; + const dates = eop._dates = []; + eop._dateColumn = dateColumn; + eop._xPoleWanderRadiansColumn = xPoleWanderRadiansColumn; + eop._yPoleWanderRadiansColumn = yPoleWanderRadiansColumn; + eop._ut1MinusUtcSecondsColumn = ut1MinusUtcSecondsColumn; + eop._xCelestialPoleOffsetRadiansColumn = xCelestialPoleOffsetRadiansColumn; + eop._yCelestialPoleOffsetRadiansColumn = yCelestialPoleOffsetRadiansColumn; + eop._taiMinusUtcSecondsColumn = taiMinusUtcSecondsColumn; + eop._columnCount = eopData.columnNames.length; + eop._lastIndex = void 0; + let lastTaiMinusUtc; + const addNewLeapSeconds = eop._addNewLeapSeconds; + for (let i = 0, len = samples.length; i < len; i += eop._columnCount) { + const mjd = samples[i + dateColumn]; + const taiMinusUtc = samples[i + taiMinusUtcSecondsColumn]; + const day = mjd + TimeConstants_default.MODIFIED_JULIAN_DATE_DIFFERENCE; + const date = new JulianDate_default(day, taiMinusUtc, TimeStandard_default.TAI); + dates.push(date); + if (addNewLeapSeconds) { + if (taiMinusUtc !== lastTaiMinusUtc && defined_default(lastTaiMinusUtc)) { + const leapSeconds = JulianDate_default.leapSeconds; + const leapSecondIndex = binarySearch_default( + leapSeconds, + date, + compareLeapSecondDates2 + ); + if (leapSecondIndex < 0) { + const leapSecond = new LeapSecond_default(date, taiMinusUtc); + leapSeconds.splice(~leapSecondIndex, 0, leapSecond); + } + } + lastTaiMinusUtc = taiMinusUtc; + } + } +} +function fillResultFromIndex(eop, samples, index, columnCount, result) { + const start = index * columnCount; + result.xPoleWander = samples[start + eop._xPoleWanderRadiansColumn]; + result.yPoleWander = samples[start + eop._yPoleWanderRadiansColumn]; + result.xPoleOffset = samples[start + eop._xCelestialPoleOffsetRadiansColumn]; + result.yPoleOffset = samples[start + eop._yCelestialPoleOffsetRadiansColumn]; + result.ut1MinusUtc = samples[start + eop._ut1MinusUtcSecondsColumn]; +} +function linearInterp(dx, y1, y2) { + return y1 + dx * (y2 - y1); +} +function interpolate(eop, dates, samples, date, before, after, result) { + const columnCount = eop._columnCount; + if (after > dates.length - 1) { + result.xPoleWander = 0; + result.yPoleWander = 0; + result.xPoleOffset = 0; + result.yPoleOffset = 0; + result.ut1MinusUtc = 0; + return result; + } + const beforeDate = dates[before]; + const afterDate = dates[after]; + if (beforeDate.equals(afterDate) || date.equals(beforeDate)) { + fillResultFromIndex(eop, samples, before, columnCount, result); + return result; + } else if (date.equals(afterDate)) { + fillResultFromIndex(eop, samples, after, columnCount, result); + return result; + } + const factor = JulianDate_default.secondsDifference(date, beforeDate) / JulianDate_default.secondsDifference(afterDate, beforeDate); + const startBefore = before * columnCount; + const startAfter = after * columnCount; + let beforeUt1MinusUtc = samples[startBefore + eop._ut1MinusUtcSecondsColumn]; + let afterUt1MinusUtc = samples[startAfter + eop._ut1MinusUtcSecondsColumn]; + const offsetDifference = afterUt1MinusUtc - beforeUt1MinusUtc; + if (offsetDifference > 0.5 || offsetDifference < -0.5) { + const beforeTaiMinusUtc = samples[startBefore + eop._taiMinusUtcSecondsColumn]; + const afterTaiMinusUtc = samples[startAfter + eop._taiMinusUtcSecondsColumn]; + if (beforeTaiMinusUtc !== afterTaiMinusUtc) { + if (afterDate.equals(date)) { + beforeUt1MinusUtc = afterUt1MinusUtc; + } else { + afterUt1MinusUtc -= afterTaiMinusUtc - beforeTaiMinusUtc; + } + } + } + result.xPoleWander = linearInterp( + factor, + samples[startBefore + eop._xPoleWanderRadiansColumn], + samples[startAfter + eop._xPoleWanderRadiansColumn] + ); + result.yPoleWander = linearInterp( + factor, + samples[startBefore + eop._yPoleWanderRadiansColumn], + samples[startAfter + eop._yPoleWanderRadiansColumn] + ); + result.xPoleOffset = linearInterp( + factor, + samples[startBefore + eop._xCelestialPoleOffsetRadiansColumn], + samples[startAfter + eop._xCelestialPoleOffsetRadiansColumn] + ); + result.yPoleOffset = linearInterp( + factor, + samples[startBefore + eop._yCelestialPoleOffsetRadiansColumn], + samples[startAfter + eop._yCelestialPoleOffsetRadiansColumn] + ); + result.ut1MinusUtc = linearInterp( + factor, + beforeUt1MinusUtc, + afterUt1MinusUtc + ); + return result; +} +var EarthOrientationParameters_default = EarthOrientationParameters; + +// packages/engine/Source/Core/HeadingPitchRoll.js +function HeadingPitchRoll(heading, pitch, roll) { + this.heading = defaultValue_default(heading, 0); + this.pitch = defaultValue_default(pitch, 0); + this.roll = defaultValue_default(roll, 0); +} +HeadingPitchRoll.fromQuaternion = function(quaternion, result) { + if (!defined_default(quaternion)) { + throw new DeveloperError_default("quaternion is required"); + } + if (!defined_default(result)) { + result = new HeadingPitchRoll(); + } + const test = 2 * (quaternion.w * quaternion.y - quaternion.z * quaternion.x); + const denominatorRoll = 1 - 2 * (quaternion.x * quaternion.x + quaternion.y * quaternion.y); + const numeratorRoll = 2 * (quaternion.w * quaternion.x + quaternion.y * quaternion.z); + const denominatorHeading = 1 - 2 * (quaternion.y * quaternion.y + quaternion.z * quaternion.z); + const numeratorHeading = 2 * (quaternion.w * quaternion.z + quaternion.x * quaternion.y); + result.heading = -Math.atan2(numeratorHeading, denominatorHeading); + result.roll = Math.atan2(numeratorRoll, denominatorRoll); + result.pitch = -Math_default.asinClamped(test); + return result; +}; +HeadingPitchRoll.fromDegrees = function(heading, pitch, roll, result) { + if (!defined_default(heading)) { + throw new DeveloperError_default("heading is required"); + } + if (!defined_default(pitch)) { + throw new DeveloperError_default("pitch is required"); + } + if (!defined_default(roll)) { + throw new DeveloperError_default("roll is required"); + } + if (!defined_default(result)) { + result = new HeadingPitchRoll(); + } + result.heading = heading * Math_default.RADIANS_PER_DEGREE; + result.pitch = pitch * Math_default.RADIANS_PER_DEGREE; + result.roll = roll * Math_default.RADIANS_PER_DEGREE; + return result; +}; +HeadingPitchRoll.clone = function(headingPitchRoll, result) { + if (!defined_default(headingPitchRoll)) { + return void 0; + } + if (!defined_default(result)) { + return new HeadingPitchRoll( + headingPitchRoll.heading, + headingPitchRoll.pitch, + headingPitchRoll.roll + ); + } + result.heading = headingPitchRoll.heading; + result.pitch = headingPitchRoll.pitch; + result.roll = headingPitchRoll.roll; + return result; +}; +HeadingPitchRoll.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left.heading === right.heading && left.pitch === right.pitch && left.roll === right.roll; +}; +HeadingPitchRoll.equalsEpsilon = function(left, right, relativeEpsilon, absoluteEpsilon) { + return left === right || defined_default(left) && defined_default(right) && Math_default.equalsEpsilon( + left.heading, + right.heading, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + left.pitch, + right.pitch, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + left.roll, + right.roll, + relativeEpsilon, + absoluteEpsilon + ); +}; +HeadingPitchRoll.prototype.clone = function(result) { + return HeadingPitchRoll.clone(this, result); +}; +HeadingPitchRoll.prototype.equals = function(right) { + return HeadingPitchRoll.equals(this, right); +}; +HeadingPitchRoll.prototype.equalsEpsilon = function(right, relativeEpsilon, absoluteEpsilon) { + return HeadingPitchRoll.equalsEpsilon( + this, + right, + relativeEpsilon, + absoluteEpsilon + ); +}; +HeadingPitchRoll.prototype.toString = function() { + return `(${this.heading}, ${this.pitch}, ${this.roll})`; +}; +var HeadingPitchRoll_default = HeadingPitchRoll; + +// packages/engine/Source/Core/buildModuleUrl.js +var cesiumScriptRegex = /((?:.*\/)|^)Cesium\.js(?:\?|\#|$)/; +function getBaseUrlFromCesiumScript() { + const scripts = document.getElementsByTagName("script"); + for (let i = 0, len = scripts.length; i < len; ++i) { + const src = scripts[i].getAttribute("src"); + const result = cesiumScriptRegex.exec(src); + if (result !== null) { + return result[1]; + } + } + return void 0; +} +var a2; +function tryMakeAbsolute(url) { + if (typeof document === "undefined") { + return url; + } + if (!defined_default(a2)) { + a2 = document.createElement("a"); + } + a2.href = url; + return a2.href; +} +var baseResource; +function getCesiumBaseUrl() { + if (defined_default(baseResource)) { + return baseResource; + } + let baseUrlString; + if (typeof CESIUM_BASE_URL !== "undefined") { + baseUrlString = CESIUM_BASE_URL; + } else if (defined_default(import.meta) && defined_default(import.meta.url)) { + baseUrlString = getAbsoluteUri_default(".", import.meta.url); + } else if (typeof define === "object" && defined_default(define.amd) && !define.amd.toUrlUndefined && defined_default(__require.toUrl)) { + baseUrlString = getAbsoluteUri_default( + "..", + buildModuleUrl("Core/buildModuleUrl.js") + ); + } else { + baseUrlString = getBaseUrlFromCesiumScript(); + } + if (!defined_default(baseUrlString)) { + throw new DeveloperError_default( + "Unable to determine Cesium base URL automatically, try defining a global variable called CESIUM_BASE_URL." + ); + } + baseResource = new Resource_default({ + url: tryMakeAbsolute(baseUrlString) + }); + baseResource.appendForwardSlash(); + return baseResource; +} +function buildModuleUrlFromRequireToUrl(moduleID) { + return tryMakeAbsolute(__require.toUrl(`../${moduleID}`)); +} +function buildModuleUrlFromBaseUrl(moduleID) { + const resource = getCesiumBaseUrl().getDerivedResource({ + url: moduleID + }); + return resource.url; +} +var implementation; +function buildModuleUrl(relativeUrl) { + if (!defined_default(implementation)) { + if (typeof define === "object" && defined_default(define.amd) && !define.amd.toUrlUndefined && defined_default(__require.toUrl)) { + implementation = buildModuleUrlFromRequireToUrl; + } else { + implementation = buildModuleUrlFromBaseUrl; + } + } + const url = implementation(relativeUrl); + return url; +} +buildModuleUrl._cesiumScriptRegex = cesiumScriptRegex; +buildModuleUrl._buildModuleUrlFromBaseUrl = buildModuleUrlFromBaseUrl; +buildModuleUrl._clearBaseResource = function() { + baseResource = void 0; +}; +buildModuleUrl.setBaseUrl = function(value) { + baseResource = Resource_default.DEFAULT.getDerivedResource({ + url: value + }); +}; +buildModuleUrl.getCesiumBaseUrl = getCesiumBaseUrl; +var buildModuleUrl_default = buildModuleUrl; + +// packages/engine/Source/Core/Iau2006XysSample.js +function Iau2006XysSample(x, y, s) { + this.x = x; + this.y = y; + this.s = s; +} +var Iau2006XysSample_default = Iau2006XysSample; + +// packages/engine/Source/Core/Iau2006XysData.js +function Iau2006XysData(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + this._xysFileUrlTemplate = Resource_default.createIfNeeded( + options.xysFileUrlTemplate + ); + this._interpolationOrder = defaultValue_default(options.interpolationOrder, 9); + this._sampleZeroJulianEphemerisDate = defaultValue_default( + options.sampleZeroJulianEphemerisDate, + 24423965e-1 + ); + this._sampleZeroDateTT = new JulianDate_default( + this._sampleZeroJulianEphemerisDate, + 0, + TimeStandard_default.TAI + ); + this._stepSizeDays = defaultValue_default(options.stepSizeDays, 1); + this._samplesPerXysFile = defaultValue_default(options.samplesPerXysFile, 1e3); + this._totalSamples = defaultValue_default(options.totalSamples, 27426); + this._samples = new Array(this._totalSamples * 3); + this._chunkDownloadsInProgress = []; + const order = this._interpolationOrder; + const denom = this._denominators = new Array(order + 1); + const xTable = this._xTable = new Array(order + 1); + const stepN = Math.pow(this._stepSizeDays, order); + for (let i = 0; i <= order; ++i) { + denom[i] = stepN; + xTable[i] = i * this._stepSizeDays; + for (let j = 0; j <= order; ++j) { + if (j !== i) { + denom[i] *= i - j; + } + } + denom[i] = 1 / denom[i]; + } + this._work = new Array(order + 1); + this._coef = new Array(order + 1); +} +var julianDateScratch = new JulianDate_default(0, 0, TimeStandard_default.TAI); +function getDaysSinceEpoch(xys, dayTT, secondTT) { + const dateTT = julianDateScratch; + dateTT.dayNumber = dayTT; + dateTT.secondsOfDay = secondTT; + return JulianDate_default.daysDifference(dateTT, xys._sampleZeroDateTT); +} +Iau2006XysData.prototype.preload = function(startDayTT, startSecondTT, stopDayTT, stopSecondTT) { + const startDaysSinceEpoch = getDaysSinceEpoch( + this, + startDayTT, + startSecondTT + ); + const stopDaysSinceEpoch = getDaysSinceEpoch(this, stopDayTT, stopSecondTT); + let startIndex = startDaysSinceEpoch / this._stepSizeDays - this._interpolationOrder / 2 | 0; + if (startIndex < 0) { + startIndex = 0; + } + let stopIndex = stopDaysSinceEpoch / this._stepSizeDays - this._interpolationOrder / 2 | 0 + this._interpolationOrder; + if (stopIndex >= this._totalSamples) { + stopIndex = this._totalSamples - 1; + } + const startChunk = startIndex / this._samplesPerXysFile | 0; + const stopChunk = stopIndex / this._samplesPerXysFile | 0; + const promises = []; + for (let i = startChunk; i <= stopChunk; ++i) { + promises.push(requestXysChunk(this, i)); + } + return Promise.all(promises); +}; +Iau2006XysData.prototype.computeXysRadians = function(dayTT, secondTT, result) { + const daysSinceEpoch = getDaysSinceEpoch(this, dayTT, secondTT); + if (daysSinceEpoch < 0) { + return void 0; + } + const centerIndex = daysSinceEpoch / this._stepSizeDays | 0; + if (centerIndex >= this._totalSamples) { + return void 0; + } + const degree = this._interpolationOrder; + let firstIndex = centerIndex - (degree / 2 | 0); + if (firstIndex < 0) { + firstIndex = 0; + } + let lastIndex = firstIndex + degree; + if (lastIndex >= this._totalSamples) { + lastIndex = this._totalSamples - 1; + firstIndex = lastIndex - degree; + if (firstIndex < 0) { + firstIndex = 0; + } + } + let isDataMissing = false; + const samples = this._samples; + if (!defined_default(samples[firstIndex * 3])) { + requestXysChunk(this, firstIndex / this._samplesPerXysFile | 0); + isDataMissing = true; + } + if (!defined_default(samples[lastIndex * 3])) { + requestXysChunk(this, lastIndex / this._samplesPerXysFile | 0); + isDataMissing = true; + } + if (isDataMissing) { + return void 0; + } + if (!defined_default(result)) { + result = new Iau2006XysSample_default(0, 0, 0); + } else { + result.x = 0; + result.y = 0; + result.s = 0; + } + const x = daysSinceEpoch - firstIndex * this._stepSizeDays; + const work = this._work; + const denom = this._denominators; + const coef = this._coef; + const xTable = this._xTable; + let i, j; + for (i = 0; i <= degree; ++i) { + work[i] = x - xTable[i]; + } + for (i = 0; i <= degree; ++i) { + coef[i] = 1; + for (j = 0; j <= degree; ++j) { + if (j !== i) { + coef[i] *= work[j]; + } + } + coef[i] *= denom[i]; + let sampleIndex = (firstIndex + i) * 3; + result.x += coef[i] * samples[sampleIndex++]; + result.y += coef[i] * samples[sampleIndex++]; + result.s += coef[i] * samples[sampleIndex]; + } + return result; +}; +function requestXysChunk(xysData, chunkIndex) { + if (xysData._chunkDownloadsInProgress[chunkIndex]) { + return xysData._chunkDownloadsInProgress[chunkIndex]; + } + let chunkUrl; + const xysFileUrlTemplate = xysData._xysFileUrlTemplate; + if (defined_default(xysFileUrlTemplate)) { + chunkUrl = xysFileUrlTemplate.getDerivedResource({ + templateValues: { + 0: chunkIndex + } + }); + } else { + chunkUrl = new Resource_default({ + url: buildModuleUrl_default(`Assets/IAU2006_XYS/IAU2006_XYS_${chunkIndex}.json`) + }); + } + const promise = chunkUrl.fetchJson().then(function(chunk) { + xysData._chunkDownloadsInProgress[chunkIndex] = false; + const samples = xysData._samples; + const newSamples = chunk.samples; + const startIndex = chunkIndex * xysData._samplesPerXysFile * 3; + for (let i = 0, len = newSamples.length; i < len; ++i) { + samples[startIndex + i] = newSamples[i]; + } + }); + xysData._chunkDownloadsInProgress[chunkIndex] = promise; + return promise; +} +var Iau2006XysData_default = Iau2006XysData; + +// packages/engine/Source/Core/Fullscreen.js +var _supportsFullscreen; +var _names = { + requestFullscreen: void 0, + exitFullscreen: void 0, + fullscreenEnabled: void 0, + fullscreenElement: void 0, + fullscreenchange: void 0, + fullscreenerror: void 0 +}; +var Fullscreen = {}; +Object.defineProperties(Fullscreen, { + /** + * The element that is currently fullscreen, if any. To simply check if the + * browser is in fullscreen mode or not, use {@link Fullscreen#fullscreen}. + * @memberof Fullscreen + * @type {object} + * @readonly + */ + element: { + get: function() { + if (!Fullscreen.supportsFullscreen()) { + return void 0; + } + return document[_names.fullscreenElement]; + } + }, + /** + * The name of the event on the document that is fired when fullscreen is + * entered or exited. This event name is intended for use with addEventListener. + * In your event handler, to determine if the browser is in fullscreen mode or not, + * use {@link Fullscreen#fullscreen}. + * @memberof Fullscreen + * @type {string} + * @readonly + */ + changeEventName: { + get: function() { + if (!Fullscreen.supportsFullscreen()) { + return void 0; + } + return _names.fullscreenchange; + } + }, + /** + * The name of the event that is fired when a fullscreen error + * occurs. This event name is intended for use with addEventListener. + * @memberof Fullscreen + * @type {string} + * @readonly + */ + errorEventName: { + get: function() { + if (!Fullscreen.supportsFullscreen()) { + return void 0; + } + return _names.fullscreenerror; + } + }, + /** + * Determine whether the browser will allow an element to be made fullscreen, or not. + * For example, by default, iframes cannot go fullscreen unless the containing page + * adds an "allowfullscreen" attribute (or prefixed equivalent). + * @memberof Fullscreen + * @type {boolean} + * @readonly + */ + enabled: { + get: function() { + if (!Fullscreen.supportsFullscreen()) { + return void 0; + } + return document[_names.fullscreenEnabled]; + } + }, + /** + * Determines if the browser is currently in fullscreen mode. + * @memberof Fullscreen + * @type {boolean} + * @readonly + */ + fullscreen: { + get: function() { + if (!Fullscreen.supportsFullscreen()) { + return void 0; + } + return Fullscreen.element !== null; + } + } +}); +Fullscreen.supportsFullscreen = function() { + if (defined_default(_supportsFullscreen)) { + return _supportsFullscreen; + } + _supportsFullscreen = false; + const body = document.body; + if (typeof body.requestFullscreen === "function") { + _names.requestFullscreen = "requestFullscreen"; + _names.exitFullscreen = "exitFullscreen"; + _names.fullscreenEnabled = "fullscreenEnabled"; + _names.fullscreenElement = "fullscreenElement"; + _names.fullscreenchange = "fullscreenchange"; + _names.fullscreenerror = "fullscreenerror"; + _supportsFullscreen = true; + return _supportsFullscreen; + } + const prefixes = ["webkit", "moz", "o", "ms", "khtml"]; + let name; + for (let i = 0, len = prefixes.length; i < len; ++i) { + const prefix = prefixes[i]; + name = `${prefix}RequestFullscreen`; + if (typeof body[name] === "function") { + _names.requestFullscreen = name; + _supportsFullscreen = true; + } else { + name = `${prefix}RequestFullScreen`; + if (typeof body[name] === "function") { + _names.requestFullscreen = name; + _supportsFullscreen = true; + } + } + name = `${prefix}ExitFullscreen`; + if (typeof document[name] === "function") { + _names.exitFullscreen = name; + } else { + name = `${prefix}CancelFullScreen`; + if (typeof document[name] === "function") { + _names.exitFullscreen = name; + } + } + name = `${prefix}FullscreenEnabled`; + if (document[name] !== void 0) { + _names.fullscreenEnabled = name; + } else { + name = `${prefix}FullScreenEnabled`; + if (document[name] !== void 0) { + _names.fullscreenEnabled = name; + } + } + name = `${prefix}FullscreenElement`; + if (document[name] !== void 0) { + _names.fullscreenElement = name; + } else { + name = `${prefix}FullScreenElement`; + if (document[name] !== void 0) { + _names.fullscreenElement = name; + } + } + name = `${prefix}fullscreenchange`; + if (document[`on${name}`] !== void 0) { + if (prefix === "ms") { + name = "MSFullscreenChange"; + } + _names.fullscreenchange = name; + } + name = `${prefix}fullscreenerror`; + if (document[`on${name}`] !== void 0) { + if (prefix === "ms") { + name = "MSFullscreenError"; + } + _names.fullscreenerror = name; + } + } + return _supportsFullscreen; +}; +Fullscreen.requestFullscreen = function(element, vrDevice) { + if (!Fullscreen.supportsFullscreen()) { + return; + } + element[_names.requestFullscreen]({ vrDisplay: vrDevice }); +}; +Fullscreen.exitFullscreen = function() { + if (!Fullscreen.supportsFullscreen()) { + return; + } + document[_names.exitFullscreen](); +}; +Fullscreen._names = _names; +var Fullscreen_default = Fullscreen; + +// packages/engine/Source/Core/FeatureDetection.js +var theNavigator; +if (typeof navigator !== "undefined") { + theNavigator = navigator; +} else { + theNavigator = {}; +} +function extractVersion(versionString) { + const parts = versionString.split("."); + for (let i = 0, len = parts.length; i < len; ++i) { + parts[i] = parseInt(parts[i], 10); + } + return parts; +} +var isChromeResult; +var chromeVersionResult; +function isChrome() { + if (!defined_default(isChromeResult)) { + isChromeResult = false; + if (!isEdge()) { + const fields = / Chrome\/([\.0-9]+)/.exec(theNavigator.userAgent); + if (fields !== null) { + isChromeResult = true; + chromeVersionResult = extractVersion(fields[1]); + } + } + } + return isChromeResult; +} +function chromeVersion() { + return isChrome() && chromeVersionResult; +} +var isSafariResult; +var safariVersionResult; +function isSafari() { + if (!defined_default(isSafariResult)) { + isSafariResult = false; + if (!isChrome() && !isEdge() && / Safari\/[\.0-9]+/.test(theNavigator.userAgent)) { + const fields = / Version\/([\.0-9]+)/.exec(theNavigator.userAgent); + if (fields !== null) { + isSafariResult = true; + safariVersionResult = extractVersion(fields[1]); + } + } + } + return isSafariResult; +} +function safariVersion() { + return isSafari() && safariVersionResult; +} +var isWebkitResult; +var webkitVersionResult; +function isWebkit() { + if (!defined_default(isWebkitResult)) { + isWebkitResult = false; + const fields = / AppleWebKit\/([\.0-9]+)(\+?)/.exec(theNavigator.userAgent); + if (fields !== null) { + isWebkitResult = true; + webkitVersionResult = extractVersion(fields[1]); + webkitVersionResult.isNightly = !!fields[2]; + } + } + return isWebkitResult; +} +function webkitVersion() { + return isWebkit() && webkitVersionResult; +} +var isInternetExplorerResult; +var internetExplorerVersionResult; +function isInternetExplorer() { + if (!defined_default(isInternetExplorerResult)) { + isInternetExplorerResult = false; + let fields; + if (theNavigator.appName === "Microsoft Internet Explorer") { + fields = /MSIE ([0-9]{1,}[\.0-9]{0,})/.exec(theNavigator.userAgent); + if (fields !== null) { + isInternetExplorerResult = true; + internetExplorerVersionResult = extractVersion(fields[1]); + } + } else if (theNavigator.appName === "Netscape") { + fields = /Trident\/.*rv:([0-9]{1,}[\.0-9]{0,})/.exec( + theNavigator.userAgent + ); + if (fields !== null) { + isInternetExplorerResult = true; + internetExplorerVersionResult = extractVersion(fields[1]); + } + } + } + return isInternetExplorerResult; +} +function internetExplorerVersion() { + return isInternetExplorer() && internetExplorerVersionResult; +} +var isEdgeResult; +var edgeVersionResult; +function isEdge() { + if (!defined_default(isEdgeResult)) { + isEdgeResult = false; + const fields = / Edg\/([\.0-9]+)/.exec(theNavigator.userAgent); + if (fields !== null) { + isEdgeResult = true; + edgeVersionResult = extractVersion(fields[1]); + } + } + return isEdgeResult; +} +function edgeVersion() { + return isEdge() && edgeVersionResult; +} +var isFirefoxResult; +var firefoxVersionResult; +function isFirefox() { + if (!defined_default(isFirefoxResult)) { + isFirefoxResult = false; + const fields = /Firefox\/([\.0-9]+)/.exec(theNavigator.userAgent); + if (fields !== null) { + isFirefoxResult = true; + firefoxVersionResult = extractVersion(fields[1]); + } + } + return isFirefoxResult; +} +var isWindowsResult; +function isWindows() { + if (!defined_default(isWindowsResult)) { + isWindowsResult = /Windows/i.test(theNavigator.appVersion); + } + return isWindowsResult; +} +var isIPadOrIOSResult; +function isIPadOrIOS() { + if (!defined_default(isIPadOrIOSResult)) { + isIPadOrIOSResult = navigator.platform === "iPhone" || navigator.platform === "iPod" || navigator.platform === "iPad"; + } + return isIPadOrIOSResult; +} +function firefoxVersion() { + return isFirefox() && firefoxVersionResult; +} +var hasPointerEvents; +function supportsPointerEvents() { + if (!defined_default(hasPointerEvents)) { + hasPointerEvents = !isFirefox() && typeof PointerEvent !== "undefined" && (!defined_default(theNavigator.pointerEnabled) || theNavigator.pointerEnabled); + } + return hasPointerEvents; +} +var imageRenderingValueResult; +var supportsImageRenderingPixelatedResult; +function supportsImageRenderingPixelated() { + if (!defined_default(supportsImageRenderingPixelatedResult)) { + const canvas = document.createElement("canvas"); + canvas.setAttribute( + "style", + "image-rendering: -moz-crisp-edges;image-rendering: pixelated;" + ); + const tmp = canvas.style.imageRendering; + supportsImageRenderingPixelatedResult = defined_default(tmp) && tmp !== ""; + if (supportsImageRenderingPixelatedResult) { + imageRenderingValueResult = tmp; + } + } + return supportsImageRenderingPixelatedResult; +} +function imageRenderingValue() { + return supportsImageRenderingPixelated() ? imageRenderingValueResult : void 0; +} +function supportsWebP() { + if (!supportsWebP.initialized) { + throw new DeveloperError_default( + "You must call FeatureDetection.supportsWebP.initialize and wait for the promise to resolve before calling FeatureDetection.supportsWebP" + ); + } + return supportsWebP._result; +} +supportsWebP._promise = void 0; +supportsWebP._result = void 0; +supportsWebP.initialize = function() { + if (defined_default(supportsWebP._promise)) { + return supportsWebP._promise; + } + supportsWebP._promise = new Promise((resolve) => { + const image = new Image(); + image.onload = function() { + supportsWebP._result = image.width > 0 && image.height > 0; + resolve(supportsWebP._result); + }; + image.onerror = function() { + supportsWebP._result = false; + resolve(supportsWebP._result); + }; + image.src = "data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA"; + }); + return supportsWebP._promise; +}; +Object.defineProperties(supportsWebP, { + initialized: { + get: function() { + return defined_default(supportsWebP._result); + } + } +}); +var typedArrayTypes = []; +if (typeof ArrayBuffer !== "undefined") { + typedArrayTypes.push( + Int8Array, + Uint8Array, + Int16Array, + Uint16Array, + Int32Array, + Uint32Array, + Float32Array, + Float64Array + ); + if (typeof Uint8ClampedArray !== "undefined") { + typedArrayTypes.push(Uint8ClampedArray); + } + if (typeof Uint8ClampedArray !== "undefined") { + typedArrayTypes.push(Uint8ClampedArray); + } + if (typeof BigInt64Array !== "undefined") { + typedArrayTypes.push(BigInt64Array); + } + if (typeof BigUint64Array !== "undefined") { + typedArrayTypes.push(BigUint64Array); + } +} +var FeatureDetection = { + isChrome, + chromeVersion, + isSafari, + safariVersion, + isWebkit, + webkitVersion, + isInternetExplorer, + internetExplorerVersion, + isEdge, + edgeVersion, + isFirefox, + firefoxVersion, + isWindows, + isIPadOrIOS, + hardwareConcurrency: defaultValue_default(theNavigator.hardwareConcurrency, 3), + supportsPointerEvents, + supportsImageRenderingPixelated, + supportsWebP, + imageRenderingValue, + typedArrayTypes +}; +FeatureDetection.supportsBasis = function(scene) { + return FeatureDetection.supportsWebAssembly() && scene.context.supportsBasis; +}; +FeatureDetection.supportsFullscreen = function() { + return Fullscreen_default.supportsFullscreen(); +}; +FeatureDetection.supportsTypedArrays = function() { + return typeof ArrayBuffer !== "undefined"; +}; +FeatureDetection.supportsBigInt64Array = function() { + return typeof BigInt64Array !== "undefined"; +}; +FeatureDetection.supportsBigUint64Array = function() { + return typeof BigUint64Array !== "undefined"; +}; +FeatureDetection.supportsBigInt = function() { + return typeof BigInt !== "undefined"; +}; +FeatureDetection.supportsWebWorkers = function() { + return typeof Worker !== "undefined"; +}; +FeatureDetection.supportsWebAssembly = function() { + return typeof WebAssembly !== "undefined"; +}; +FeatureDetection.supportsWebgl2 = function(scene) { + Check_default.defined("scene", scene); + return scene.context.webgl2; +}; +FeatureDetection.supportsEsmWebWorkers = function() { + return !isFirefox() || parseInt(firefoxVersionResult) >= 114; +}; +var FeatureDetection_default = FeatureDetection; + +// packages/engine/Source/Core/Quaternion.js +function Quaternion(x, y, z, w) { + this.x = defaultValue_default(x, 0); + this.y = defaultValue_default(y, 0); + this.z = defaultValue_default(z, 0); + this.w = defaultValue_default(w, 0); +} +var fromAxisAngleScratch = new Cartesian3_default(); +Quaternion.fromAxisAngle = function(axis, angle, result) { + Check_default.typeOf.object("axis", axis); + Check_default.typeOf.number("angle", angle); + const halfAngle = angle / 2; + const s = Math.sin(halfAngle); + fromAxisAngleScratch = Cartesian3_default.normalize(axis, fromAxisAngleScratch); + const x = fromAxisAngleScratch.x * s; + const y = fromAxisAngleScratch.y * s; + const z = fromAxisAngleScratch.z * s; + const w = Math.cos(halfAngle); + if (!defined_default(result)) { + return new Quaternion(x, y, z, w); + } + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; +}; +var fromRotationMatrixNext = [1, 2, 0]; +var fromRotationMatrixQuat = new Array(3); +Quaternion.fromRotationMatrix = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + let root; + let x; + let y; + let z; + let w; + const m00 = matrix[Matrix3_default.COLUMN0ROW0]; + const m11 = matrix[Matrix3_default.COLUMN1ROW1]; + const m22 = matrix[Matrix3_default.COLUMN2ROW2]; + const trace = m00 + m11 + m22; + if (trace > 0) { + root = Math.sqrt(trace + 1); + w = 0.5 * root; + root = 0.5 / root; + x = (matrix[Matrix3_default.COLUMN1ROW2] - matrix[Matrix3_default.COLUMN2ROW1]) * root; + y = (matrix[Matrix3_default.COLUMN2ROW0] - matrix[Matrix3_default.COLUMN0ROW2]) * root; + z = (matrix[Matrix3_default.COLUMN0ROW1] - matrix[Matrix3_default.COLUMN1ROW0]) * root; + } else { + const next = fromRotationMatrixNext; + let i = 0; + if (m11 > m00) { + i = 1; + } + if (m22 > m00 && m22 > m11) { + i = 2; + } + const j = next[i]; + const k = next[j]; + root = Math.sqrt( + matrix[Matrix3_default.getElementIndex(i, i)] - matrix[Matrix3_default.getElementIndex(j, j)] - matrix[Matrix3_default.getElementIndex(k, k)] + 1 + ); + const quat = fromRotationMatrixQuat; + quat[i] = 0.5 * root; + root = 0.5 / root; + w = (matrix[Matrix3_default.getElementIndex(k, j)] - matrix[Matrix3_default.getElementIndex(j, k)]) * root; + quat[j] = (matrix[Matrix3_default.getElementIndex(j, i)] + matrix[Matrix3_default.getElementIndex(i, j)]) * root; + quat[k] = (matrix[Matrix3_default.getElementIndex(k, i)] + matrix[Matrix3_default.getElementIndex(i, k)]) * root; + x = -quat[0]; + y = -quat[1]; + z = -quat[2]; + } + if (!defined_default(result)) { + return new Quaternion(x, y, z, w); + } + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; +}; +var scratchHPRQuaternion = new Quaternion(); +var scratchHeadingQuaternion = new Quaternion(); +var scratchPitchQuaternion = new Quaternion(); +var scratchRollQuaternion = new Quaternion(); +Quaternion.fromHeadingPitchRoll = function(headingPitchRoll, result) { + Check_default.typeOf.object("headingPitchRoll", headingPitchRoll); + scratchRollQuaternion = Quaternion.fromAxisAngle( + Cartesian3_default.UNIT_X, + headingPitchRoll.roll, + scratchHPRQuaternion + ); + scratchPitchQuaternion = Quaternion.fromAxisAngle( + Cartesian3_default.UNIT_Y, + -headingPitchRoll.pitch, + result + ); + result = Quaternion.multiply( + scratchPitchQuaternion, + scratchRollQuaternion, + scratchPitchQuaternion + ); + scratchHeadingQuaternion = Quaternion.fromAxisAngle( + Cartesian3_default.UNIT_Z, + -headingPitchRoll.heading, + scratchHPRQuaternion + ); + return Quaternion.multiply(scratchHeadingQuaternion, result, result); +}; +var sampledQuaternionAxis = new Cartesian3_default(); +var sampledQuaternionRotation = new Cartesian3_default(); +var sampledQuaternionTempQuaternion = new Quaternion(); +var sampledQuaternionQuaternion0 = new Quaternion(); +var sampledQuaternionQuaternion0Conjugate = new Quaternion(); +Quaternion.packedLength = 4; +Quaternion.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value.x; + array[startingIndex++] = value.y; + array[startingIndex++] = value.z; + array[startingIndex] = value.w; + return array; +}; +Quaternion.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new Quaternion(); + } + result.x = array[startingIndex]; + result.y = array[startingIndex + 1]; + result.z = array[startingIndex + 2]; + result.w = array[startingIndex + 3]; + return result; +}; +Quaternion.packedInterpolationLength = 3; +Quaternion.convertPackedArrayForInterpolation = function(packedArray, startingIndex, lastIndex, result) { + Quaternion.unpack( + packedArray, + lastIndex * 4, + sampledQuaternionQuaternion0Conjugate + ); + Quaternion.conjugate( + sampledQuaternionQuaternion0Conjugate, + sampledQuaternionQuaternion0Conjugate + ); + for (let i = 0, len = lastIndex - startingIndex + 1; i < len; i++) { + const offset = i * 3; + Quaternion.unpack( + packedArray, + (startingIndex + i) * 4, + sampledQuaternionTempQuaternion + ); + Quaternion.multiply( + sampledQuaternionTempQuaternion, + sampledQuaternionQuaternion0Conjugate, + sampledQuaternionTempQuaternion + ); + if (sampledQuaternionTempQuaternion.w < 0) { + Quaternion.negate( + sampledQuaternionTempQuaternion, + sampledQuaternionTempQuaternion + ); + } + Quaternion.computeAxis( + sampledQuaternionTempQuaternion, + sampledQuaternionAxis + ); + const angle = Quaternion.computeAngle(sampledQuaternionTempQuaternion); + if (!defined_default(result)) { + result = []; + } + result[offset] = sampledQuaternionAxis.x * angle; + result[offset + 1] = sampledQuaternionAxis.y * angle; + result[offset + 2] = sampledQuaternionAxis.z * angle; + } +}; +Quaternion.unpackInterpolationResult = function(array, sourceArray, firstIndex, lastIndex, result) { + if (!defined_default(result)) { + result = new Quaternion(); + } + Cartesian3_default.fromArray(array, 0, sampledQuaternionRotation); + const magnitude = Cartesian3_default.magnitude(sampledQuaternionRotation); + Quaternion.unpack(sourceArray, lastIndex * 4, sampledQuaternionQuaternion0); + if (magnitude === 0) { + Quaternion.clone(Quaternion.IDENTITY, sampledQuaternionTempQuaternion); + } else { + Quaternion.fromAxisAngle( + sampledQuaternionRotation, + magnitude, + sampledQuaternionTempQuaternion + ); + } + return Quaternion.multiply( + sampledQuaternionTempQuaternion, + sampledQuaternionQuaternion0, + result + ); +}; +Quaternion.clone = function(quaternion, result) { + if (!defined_default(quaternion)) { + return void 0; + } + if (!defined_default(result)) { + return new Quaternion( + quaternion.x, + quaternion.y, + quaternion.z, + quaternion.w + ); + } + result.x = quaternion.x; + result.y = quaternion.y; + result.z = quaternion.z; + result.w = quaternion.w; + return result; +}; +Quaternion.conjugate = function(quaternion, result) { + Check_default.typeOf.object("quaternion", quaternion); + Check_default.typeOf.object("result", result); + result.x = -quaternion.x; + result.y = -quaternion.y; + result.z = -quaternion.z; + result.w = quaternion.w; + return result; +}; +Quaternion.magnitudeSquared = function(quaternion) { + Check_default.typeOf.object("quaternion", quaternion); + return quaternion.x * quaternion.x + quaternion.y * quaternion.y + quaternion.z * quaternion.z + quaternion.w * quaternion.w; +}; +Quaternion.magnitude = function(quaternion) { + return Math.sqrt(Quaternion.magnitudeSquared(quaternion)); +}; +Quaternion.normalize = function(quaternion, result) { + Check_default.typeOf.object("result", result); + const inverseMagnitude = 1 / Quaternion.magnitude(quaternion); + const x = quaternion.x * inverseMagnitude; + const y = quaternion.y * inverseMagnitude; + const z = quaternion.z * inverseMagnitude; + const w = quaternion.w * inverseMagnitude; + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; +}; +Quaternion.inverse = function(quaternion, result) { + Check_default.typeOf.object("result", result); + const magnitudeSquared = Quaternion.magnitudeSquared(quaternion); + result = Quaternion.conjugate(quaternion, result); + return Quaternion.multiplyByScalar(result, 1 / magnitudeSquared, result); +}; +Quaternion.add = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x + right.x; + result.y = left.y + right.y; + result.z = left.z + right.z; + result.w = left.w + right.w; + return result; +}; +Quaternion.subtract = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x - right.x; + result.y = left.y - right.y; + result.z = left.z - right.z; + result.w = left.w - right.w; + return result; +}; +Quaternion.negate = function(quaternion, result) { + Check_default.typeOf.object("quaternion", quaternion); + Check_default.typeOf.object("result", result); + result.x = -quaternion.x; + result.y = -quaternion.y; + result.z = -quaternion.z; + result.w = -quaternion.w; + return result; +}; +Quaternion.dot = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + return left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w; +}; +Quaternion.multiply = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + const leftX = left.x; + const leftY = left.y; + const leftZ = left.z; + const leftW = left.w; + const rightX = right.x; + const rightY = right.y; + const rightZ = right.z; + const rightW = right.w; + const x = leftW * rightX + leftX * rightW + leftY * rightZ - leftZ * rightY; + const y = leftW * rightY - leftX * rightZ + leftY * rightW + leftZ * rightX; + const z = leftW * rightZ + leftX * rightY - leftY * rightX + leftZ * rightW; + const w = leftW * rightW - leftX * rightX - leftY * rightY - leftZ * rightZ; + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; +}; +Quaternion.multiplyByScalar = function(quaternion, scalar, result) { + Check_default.typeOf.object("quaternion", quaternion); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result.x = quaternion.x * scalar; + result.y = quaternion.y * scalar; + result.z = quaternion.z * scalar; + result.w = quaternion.w * scalar; + return result; +}; +Quaternion.divideByScalar = function(quaternion, scalar, result) { + Check_default.typeOf.object("quaternion", quaternion); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result.x = quaternion.x / scalar; + result.y = quaternion.y / scalar; + result.z = quaternion.z / scalar; + result.w = quaternion.w / scalar; + return result; +}; +Quaternion.computeAxis = function(quaternion, result) { + Check_default.typeOf.object("quaternion", quaternion); + Check_default.typeOf.object("result", result); + const w = quaternion.w; + if (Math.abs(w - 1) < Math_default.EPSILON6) { + result.x = result.y = result.z = 0; + return result; + } + const scalar = 1 / Math.sqrt(1 - w * w); + result.x = quaternion.x * scalar; + result.y = quaternion.y * scalar; + result.z = quaternion.z * scalar; + return result; +}; +Quaternion.computeAngle = function(quaternion) { + Check_default.typeOf.object("quaternion", quaternion); + if (Math.abs(quaternion.w - 1) < Math_default.EPSILON6) { + return 0; + } + return 2 * Math.acos(quaternion.w); +}; +var lerpScratch = new Quaternion(); +Quaternion.lerp = function(start, end, t, result) { + Check_default.typeOf.object("start", start); + Check_default.typeOf.object("end", end); + Check_default.typeOf.number("t", t); + Check_default.typeOf.object("result", result); + lerpScratch = Quaternion.multiplyByScalar(end, t, lerpScratch); + result = Quaternion.multiplyByScalar(start, 1 - t, result); + return Quaternion.add(lerpScratch, result, result); +}; +var slerpEndNegated = new Quaternion(); +var slerpScaledP = new Quaternion(); +var slerpScaledR = new Quaternion(); +Quaternion.slerp = function(start, end, t, result) { + Check_default.typeOf.object("start", start); + Check_default.typeOf.object("end", end); + Check_default.typeOf.number("t", t); + Check_default.typeOf.object("result", result); + let dot = Quaternion.dot(start, end); + let r = end; + if (dot < 0) { + dot = -dot; + r = slerpEndNegated = Quaternion.negate(end, slerpEndNegated); + } + if (1 - dot < Math_default.EPSILON6) { + return Quaternion.lerp(start, r, t, result); + } + const theta = Math.acos(dot); + slerpScaledP = Quaternion.multiplyByScalar( + start, + Math.sin((1 - t) * theta), + slerpScaledP + ); + slerpScaledR = Quaternion.multiplyByScalar( + r, + Math.sin(t * theta), + slerpScaledR + ); + result = Quaternion.add(slerpScaledP, slerpScaledR, result); + return Quaternion.multiplyByScalar(result, 1 / Math.sin(theta), result); +}; +Quaternion.log = function(quaternion, result) { + Check_default.typeOf.object("quaternion", quaternion); + Check_default.typeOf.object("result", result); + const theta = Math_default.acosClamped(quaternion.w); + let thetaOverSinTheta = 0; + if (theta !== 0) { + thetaOverSinTheta = theta / Math.sin(theta); + } + return Cartesian3_default.multiplyByScalar(quaternion, thetaOverSinTheta, result); +}; +Quaternion.exp = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const theta = Cartesian3_default.magnitude(cartesian); + let sinThetaOverTheta = 0; + if (theta !== 0) { + sinThetaOverTheta = Math.sin(theta) / theta; + } + result.x = cartesian.x * sinThetaOverTheta; + result.y = cartesian.y * sinThetaOverTheta; + result.z = cartesian.z * sinThetaOverTheta; + result.w = Math.cos(theta); + return result; +}; +var squadScratchCartesian0 = new Cartesian3_default(); +var squadScratchCartesian1 = new Cartesian3_default(); +var squadScratchQuaternion0 = new Quaternion(); +var squadScratchQuaternion1 = new Quaternion(); +Quaternion.computeInnerQuadrangle = function(q0, q1, q2, result) { + Check_default.typeOf.object("q0", q0); + Check_default.typeOf.object("q1", q1); + Check_default.typeOf.object("q2", q2); + Check_default.typeOf.object("result", result); + const qInv = Quaternion.conjugate(q1, squadScratchQuaternion0); + Quaternion.multiply(qInv, q2, squadScratchQuaternion1); + const cart0 = Quaternion.log(squadScratchQuaternion1, squadScratchCartesian0); + Quaternion.multiply(qInv, q0, squadScratchQuaternion1); + const cart1 = Quaternion.log(squadScratchQuaternion1, squadScratchCartesian1); + Cartesian3_default.add(cart0, cart1, cart0); + Cartesian3_default.multiplyByScalar(cart0, 0.25, cart0); + Cartesian3_default.negate(cart0, cart0); + Quaternion.exp(cart0, squadScratchQuaternion0); + return Quaternion.multiply(q1, squadScratchQuaternion0, result); +}; +Quaternion.squad = function(q0, q1, s0, s1, t, result) { + Check_default.typeOf.object("q0", q0); + Check_default.typeOf.object("q1", q1); + Check_default.typeOf.object("s0", s0); + Check_default.typeOf.object("s1", s1); + Check_default.typeOf.number("t", t); + Check_default.typeOf.object("result", result); + const slerp0 = Quaternion.slerp(q0, q1, t, squadScratchQuaternion0); + const slerp1 = Quaternion.slerp(s0, s1, t, squadScratchQuaternion1); + return Quaternion.slerp(slerp0, slerp1, 2 * t * (1 - t), result); +}; +var fastSlerpScratchQuaternion = new Quaternion(); +var opmu = 1.9011074535173003; +var u = FeatureDetection_default.supportsTypedArrays() ? new Float32Array(8) : []; +var v = FeatureDetection_default.supportsTypedArrays() ? new Float32Array(8) : []; +var bT = FeatureDetection_default.supportsTypedArrays() ? new Float32Array(8) : []; +var bD = FeatureDetection_default.supportsTypedArrays() ? new Float32Array(8) : []; +for (let i = 0; i < 7; ++i) { + const s = i + 1; + const t = 2 * s + 1; + u[i] = 1 / (s * t); + v[i] = s / t; +} +u[7] = opmu / (8 * 17); +v[7] = opmu * 8 / 17; +Quaternion.fastSlerp = function(start, end, t, result) { + Check_default.typeOf.object("start", start); + Check_default.typeOf.object("end", end); + Check_default.typeOf.number("t", t); + Check_default.typeOf.object("result", result); + let x = Quaternion.dot(start, end); + let sign; + if (x >= 0) { + sign = 1; + } else { + sign = -1; + x = -x; + } + const xm1 = x - 1; + const d = 1 - t; + const sqrT = t * t; + const sqrD = d * d; + for (let i = 7; i >= 0; --i) { + bT[i] = (u[i] * sqrT - v[i]) * xm1; + bD[i] = (u[i] * sqrD - v[i]) * xm1; + } + const cT = sign * t * (1 + bT[0] * (1 + bT[1] * (1 + bT[2] * (1 + bT[3] * (1 + bT[4] * (1 + bT[5] * (1 + bT[6] * (1 + bT[7])))))))); + const cD = d * (1 + bD[0] * (1 + bD[1] * (1 + bD[2] * (1 + bD[3] * (1 + bD[4] * (1 + bD[5] * (1 + bD[6] * (1 + bD[7])))))))); + const temp = Quaternion.multiplyByScalar( + start, + cD, + fastSlerpScratchQuaternion + ); + Quaternion.multiplyByScalar(end, cT, result); + return Quaternion.add(temp, result, result); +}; +Quaternion.fastSquad = function(q0, q1, s0, s1, t, result) { + Check_default.typeOf.object("q0", q0); + Check_default.typeOf.object("q1", q1); + Check_default.typeOf.object("s0", s0); + Check_default.typeOf.object("s1", s1); + Check_default.typeOf.number("t", t); + Check_default.typeOf.object("result", result); + const slerp0 = Quaternion.fastSlerp(q0, q1, t, squadScratchQuaternion0); + const slerp1 = Quaternion.fastSlerp(s0, s1, t, squadScratchQuaternion1); + return Quaternion.fastSlerp(slerp0, slerp1, 2 * t * (1 - t), result); +}; +Quaternion.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left.x === right.x && left.y === right.y && left.z === right.z && left.w === right.w; +}; +Quaternion.equalsEpsilon = function(left, right, epsilon) { + epsilon = defaultValue_default(epsilon, 0); + return left === right || defined_default(left) && defined_default(right) && Math.abs(left.x - right.x) <= epsilon && Math.abs(left.y - right.y) <= epsilon && Math.abs(left.z - right.z) <= epsilon && Math.abs(left.w - right.w) <= epsilon; +}; +Quaternion.ZERO = Object.freeze(new Quaternion(0, 0, 0, 0)); +Quaternion.IDENTITY = Object.freeze(new Quaternion(0, 0, 0, 1)); +Quaternion.prototype.clone = function(result) { + return Quaternion.clone(this, result); +}; +Quaternion.prototype.equals = function(right) { + return Quaternion.equals(this, right); +}; +Quaternion.prototype.equalsEpsilon = function(right, epsilon) { + return Quaternion.equalsEpsilon(this, right, epsilon); +}; +Quaternion.prototype.toString = function() { + return `(${this.x}, ${this.y}, ${this.z}, ${this.w})`; +}; +var Quaternion_default = Quaternion; + +// packages/engine/Source/Core/Transforms.js +var Transforms = {}; +var vectorProductLocalFrame = { + up: { + south: "east", + north: "west", + west: "south", + east: "north" + }, + down: { + south: "west", + north: "east", + west: "north", + east: "south" + }, + south: { + up: "west", + down: "east", + west: "down", + east: "up" + }, + north: { + up: "east", + down: "west", + west: "up", + east: "down" + }, + west: { + up: "north", + down: "south", + north: "down", + south: "up" + }, + east: { + up: "south", + down: "north", + north: "up", + south: "down" + } +}; +var degeneratePositionLocalFrame = { + north: [-1, 0, 0], + east: [0, 1, 0], + up: [0, 0, 1], + south: [1, 0, 0], + west: [0, -1, 0], + down: [0, 0, -1] +}; +var localFrameToFixedFrameCache = {}; +var scratchCalculateCartesian = { + east: new Cartesian3_default(), + north: new Cartesian3_default(), + up: new Cartesian3_default(), + west: new Cartesian3_default(), + south: new Cartesian3_default(), + down: new Cartesian3_default() +}; +var scratchFirstCartesian = new Cartesian3_default(); +var scratchSecondCartesian = new Cartesian3_default(); +var scratchThirdCartesian = new Cartesian3_default(); +Transforms.localFrameToFixedFrameGenerator = function(firstAxis, secondAxis) { + if (!vectorProductLocalFrame.hasOwnProperty(firstAxis) || !vectorProductLocalFrame[firstAxis].hasOwnProperty(secondAxis)) { + throw new DeveloperError_default( + "firstAxis and secondAxis must be east, north, up, west, south or down." + ); + } + const thirdAxis = vectorProductLocalFrame[firstAxis][secondAxis]; + let resultat; + const hashAxis = firstAxis + secondAxis; + if (defined_default(localFrameToFixedFrameCache[hashAxis])) { + resultat = localFrameToFixedFrameCache[hashAxis]; + } else { + resultat = function(origin, ellipsoid, result) { + if (!defined_default(origin)) { + throw new DeveloperError_default("origin is required."); + } + if (!defined_default(result)) { + result = new Matrix4_default(); + } + if (Cartesian3_default.equalsEpsilon(origin, Cartesian3_default.ZERO, Math_default.EPSILON14)) { + Cartesian3_default.unpack( + degeneratePositionLocalFrame[firstAxis], + 0, + scratchFirstCartesian + ); + Cartesian3_default.unpack( + degeneratePositionLocalFrame[secondAxis], + 0, + scratchSecondCartesian + ); + Cartesian3_default.unpack( + degeneratePositionLocalFrame[thirdAxis], + 0, + scratchThirdCartesian + ); + } else if (Math_default.equalsEpsilon(origin.x, 0, Math_default.EPSILON14) && Math_default.equalsEpsilon(origin.y, 0, Math_default.EPSILON14)) { + const sign = Math_default.sign(origin.z); + Cartesian3_default.unpack( + degeneratePositionLocalFrame[firstAxis], + 0, + scratchFirstCartesian + ); + if (firstAxis !== "east" && firstAxis !== "west") { + Cartesian3_default.multiplyByScalar( + scratchFirstCartesian, + sign, + scratchFirstCartesian + ); + } + Cartesian3_default.unpack( + degeneratePositionLocalFrame[secondAxis], + 0, + scratchSecondCartesian + ); + if (secondAxis !== "east" && secondAxis !== "west") { + Cartesian3_default.multiplyByScalar( + scratchSecondCartesian, + sign, + scratchSecondCartesian + ); + } + Cartesian3_default.unpack( + degeneratePositionLocalFrame[thirdAxis], + 0, + scratchThirdCartesian + ); + if (thirdAxis !== "east" && thirdAxis !== "west") { + Cartesian3_default.multiplyByScalar( + scratchThirdCartesian, + sign, + scratchThirdCartesian + ); + } + } else { + ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + ellipsoid.geodeticSurfaceNormal(origin, scratchCalculateCartesian.up); + const up = scratchCalculateCartesian.up; + const east = scratchCalculateCartesian.east; + east.x = -origin.y; + east.y = origin.x; + east.z = 0; + Cartesian3_default.normalize(east, scratchCalculateCartesian.east); + Cartesian3_default.cross(up, east, scratchCalculateCartesian.north); + Cartesian3_default.multiplyByScalar( + scratchCalculateCartesian.up, + -1, + scratchCalculateCartesian.down + ); + Cartesian3_default.multiplyByScalar( + scratchCalculateCartesian.east, + -1, + scratchCalculateCartesian.west + ); + Cartesian3_default.multiplyByScalar( + scratchCalculateCartesian.north, + -1, + scratchCalculateCartesian.south + ); + scratchFirstCartesian = scratchCalculateCartesian[firstAxis]; + scratchSecondCartesian = scratchCalculateCartesian[secondAxis]; + scratchThirdCartesian = scratchCalculateCartesian[thirdAxis]; + } + result[0] = scratchFirstCartesian.x; + result[1] = scratchFirstCartesian.y; + result[2] = scratchFirstCartesian.z; + result[3] = 0; + result[4] = scratchSecondCartesian.x; + result[5] = scratchSecondCartesian.y; + result[6] = scratchSecondCartesian.z; + result[7] = 0; + result[8] = scratchThirdCartesian.x; + result[9] = scratchThirdCartesian.y; + result[10] = scratchThirdCartesian.z; + result[11] = 0; + result[12] = origin.x; + result[13] = origin.y; + result[14] = origin.z; + result[15] = 1; + return result; + }; + localFrameToFixedFrameCache[hashAxis] = resultat; + } + return resultat; +}; +Transforms.eastNorthUpToFixedFrame = Transforms.localFrameToFixedFrameGenerator( + "east", + "north" +); +Transforms.northEastDownToFixedFrame = Transforms.localFrameToFixedFrameGenerator( + "north", + "east" +); +Transforms.northUpEastToFixedFrame = Transforms.localFrameToFixedFrameGenerator( + "north", + "up" +); +Transforms.northWestUpToFixedFrame = Transforms.localFrameToFixedFrameGenerator( + "north", + "west" +); +var scratchHPRQuaternion2 = new Quaternion_default(); +var scratchScale = new Cartesian3_default(1, 1, 1); +var scratchHPRMatrix4 = new Matrix4_default(); +Transforms.headingPitchRollToFixedFrame = function(origin, headingPitchRoll, ellipsoid, fixedFrameTransform, result) { + Check_default.typeOf.object("HeadingPitchRoll", headingPitchRoll); + fixedFrameTransform = defaultValue_default( + fixedFrameTransform, + Transforms.eastNorthUpToFixedFrame + ); + const hprQuaternion = Quaternion_default.fromHeadingPitchRoll( + headingPitchRoll, + scratchHPRQuaternion2 + ); + const hprMatrix = Matrix4_default.fromTranslationQuaternionRotationScale( + Cartesian3_default.ZERO, + hprQuaternion, + scratchScale, + scratchHPRMatrix4 + ); + result = fixedFrameTransform(origin, ellipsoid, result); + return Matrix4_default.multiply(result, hprMatrix, result); +}; +var scratchENUMatrix4 = new Matrix4_default(); +var scratchHPRMatrix3 = new Matrix3_default(); +Transforms.headingPitchRollQuaternion = function(origin, headingPitchRoll, ellipsoid, fixedFrameTransform, result) { + Check_default.typeOf.object("HeadingPitchRoll", headingPitchRoll); + const transform = Transforms.headingPitchRollToFixedFrame( + origin, + headingPitchRoll, + ellipsoid, + fixedFrameTransform, + scratchENUMatrix4 + ); + const rotation = Matrix4_default.getMatrix3(transform, scratchHPRMatrix3); + return Quaternion_default.fromRotationMatrix(rotation, result); +}; +var noScale = new Cartesian3_default(1, 1, 1); +var hprCenterScratch = new Cartesian3_default(); +var ffScratch = new Matrix4_default(); +var hprTransformScratch = new Matrix4_default(); +var hprRotationScratch = new Matrix3_default(); +var hprQuaternionScratch = new Quaternion_default(); +Transforms.fixedFrameToHeadingPitchRoll = function(transform, ellipsoid, fixedFrameTransform, result) { + Check_default.defined("transform", transform); + ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + fixedFrameTransform = defaultValue_default( + fixedFrameTransform, + Transforms.eastNorthUpToFixedFrame + ); + if (!defined_default(result)) { + result = new HeadingPitchRoll_default(); + } + const center = Matrix4_default.getTranslation(transform, hprCenterScratch); + if (Cartesian3_default.equals(center, Cartesian3_default.ZERO)) { + result.heading = 0; + result.pitch = 0; + result.roll = 0; + return result; + } + let toFixedFrame = Matrix4_default.inverseTransformation( + fixedFrameTransform(center, ellipsoid, ffScratch), + ffScratch + ); + let transformCopy = Matrix4_default.setScale(transform, noScale, hprTransformScratch); + transformCopy = Matrix4_default.setTranslation( + transformCopy, + Cartesian3_default.ZERO, + transformCopy + ); + toFixedFrame = Matrix4_default.multiply(toFixedFrame, transformCopy, toFixedFrame); + let quaternionRotation = Quaternion_default.fromRotationMatrix( + Matrix4_default.getMatrix3(toFixedFrame, hprRotationScratch), + hprQuaternionScratch + ); + quaternionRotation = Quaternion_default.normalize( + quaternionRotation, + quaternionRotation + ); + return HeadingPitchRoll_default.fromQuaternion(quaternionRotation, result); +}; +var gmstConstant0 = 6 * 3600 + 41 * 60 + 50.54841; +var gmstConstant1 = 8640184812866e-6; +var gmstConstant2 = 0.093104; +var gmstConstant3 = -62e-7; +var rateCoef = 11772758384668e-32; +var wgs84WRPrecessing = 72921158553e-15; +var twoPiOverSecondsInDay = Math_default.TWO_PI / 86400; +var dateInUtc = new JulianDate_default(); +Transforms.computeTemeToPseudoFixedMatrix = function(date, result) { + if (!defined_default(date)) { + throw new DeveloperError_default("date is required."); + } + dateInUtc = JulianDate_default.addSeconds( + date, + -JulianDate_default.computeTaiMinusUtc(date), + dateInUtc + ); + const utcDayNumber = dateInUtc.dayNumber; + const utcSecondsIntoDay = dateInUtc.secondsOfDay; + let t; + const diffDays = utcDayNumber - 2451545; + if (utcSecondsIntoDay >= 43200) { + t = (diffDays + 0.5) / TimeConstants_default.DAYS_PER_JULIAN_CENTURY; + } else { + t = (diffDays - 0.5) / TimeConstants_default.DAYS_PER_JULIAN_CENTURY; + } + const gmst0 = gmstConstant0 + t * (gmstConstant1 + t * (gmstConstant2 + t * gmstConstant3)); + const angle = gmst0 * twoPiOverSecondsInDay % Math_default.TWO_PI; + const ratio = wgs84WRPrecessing + rateCoef * (utcDayNumber - 24515455e-1); + const secondsSinceMidnight = (utcSecondsIntoDay + TimeConstants_default.SECONDS_PER_DAY * 0.5) % TimeConstants_default.SECONDS_PER_DAY; + const gha = angle + ratio * secondsSinceMidnight; + const cosGha = Math.cos(gha); + const sinGha = Math.sin(gha); + if (!defined_default(result)) { + return new Matrix3_default( + cosGha, + sinGha, + 0, + -sinGha, + cosGha, + 0, + 0, + 0, + 1 + ); + } + result[0] = cosGha; + result[1] = -sinGha; + result[2] = 0; + result[3] = sinGha; + result[4] = cosGha; + result[5] = 0; + result[6] = 0; + result[7] = 0; + result[8] = 1; + return result; +}; +Transforms.iau2006XysData = new Iau2006XysData_default(); +Transforms.earthOrientationParameters = EarthOrientationParameters_default.NONE; +var ttMinusTai = 32.184; +var j2000ttDays = 2451545; +Transforms.preloadIcrfFixed = function(timeInterval) { + const startDayTT = timeInterval.start.dayNumber; + const startSecondTT = timeInterval.start.secondsOfDay + ttMinusTai; + const stopDayTT = timeInterval.stop.dayNumber; + const stopSecondTT = timeInterval.stop.secondsOfDay + ttMinusTai; + return Transforms.iau2006XysData.preload( + startDayTT, + startSecondTT, + stopDayTT, + stopSecondTT + ); +}; +Transforms.computeIcrfToFixedMatrix = function(date, result) { + if (!defined_default(date)) { + throw new DeveloperError_default("date is required."); + } + if (!defined_default(result)) { + result = new Matrix3_default(); + } + const fixedToIcrfMtx = Transforms.computeFixedToIcrfMatrix(date, result); + if (!defined_default(fixedToIcrfMtx)) { + return void 0; + } + return Matrix3_default.transpose(fixedToIcrfMtx, result); +}; +var xysScratch = new Iau2006XysSample_default(0, 0, 0); +var eopScratch = new EarthOrientationParametersSample_default( + 0, + 0, + 0, + 0, + 0, + 0 +); +var rotation1Scratch = new Matrix3_default(); +var rotation2Scratch = new Matrix3_default(); +Transforms.computeFixedToIcrfMatrix = function(date, result) { + if (!defined_default(date)) { + throw new DeveloperError_default("date is required."); + } + if (!defined_default(result)) { + result = new Matrix3_default(); + } + const eop = Transforms.earthOrientationParameters.compute(date, eopScratch); + if (!defined_default(eop)) { + return void 0; + } + const dayTT = date.dayNumber; + const secondTT = date.secondsOfDay + ttMinusTai; + const xys = Transforms.iau2006XysData.computeXysRadians( + dayTT, + secondTT, + xysScratch + ); + if (!defined_default(xys)) { + return void 0; + } + const x = xys.x + eop.xPoleOffset; + const y = xys.y + eop.yPoleOffset; + const a3 = 1 / (1 + Math.sqrt(1 - x * x - y * y)); + const rotation1 = rotation1Scratch; + rotation1[0] = 1 - a3 * x * x; + rotation1[3] = -a3 * x * y; + rotation1[6] = x; + rotation1[1] = -a3 * x * y; + rotation1[4] = 1 - a3 * y * y; + rotation1[7] = y; + rotation1[2] = -x; + rotation1[5] = -y; + rotation1[8] = 1 - a3 * (x * x + y * y); + const rotation2 = Matrix3_default.fromRotationZ(-xys.s, rotation2Scratch); + const matrixQ = Matrix3_default.multiply(rotation1, rotation2, rotation1Scratch); + const dateUt1day = date.dayNumber; + const dateUt1sec = date.secondsOfDay - JulianDate_default.computeTaiMinusUtc(date) + eop.ut1MinusUtc; + const daysSinceJ2000 = dateUt1day - 2451545; + const fractionOfDay = dateUt1sec / TimeConstants_default.SECONDS_PER_DAY; + let era = 0.779057273264 + fractionOfDay + 0.00273781191135448 * (daysSinceJ2000 + fractionOfDay); + era = era % 1 * Math_default.TWO_PI; + const earthRotation = Matrix3_default.fromRotationZ(era, rotation2Scratch); + const pfToIcrf = Matrix3_default.multiply(matrixQ, earthRotation, rotation1Scratch); + const cosxp = Math.cos(eop.xPoleWander); + const cosyp = Math.cos(eop.yPoleWander); + const sinxp = Math.sin(eop.xPoleWander); + const sinyp = Math.sin(eop.yPoleWander); + let ttt = dayTT - j2000ttDays + secondTT / TimeConstants_default.SECONDS_PER_DAY; + ttt /= 36525; + const sp = -47e-6 * ttt * Math_default.RADIANS_PER_DEGREE / 3600; + const cossp = Math.cos(sp); + const sinsp = Math.sin(sp); + const fToPfMtx = rotation2Scratch; + fToPfMtx[0] = cosxp * cossp; + fToPfMtx[1] = cosxp * sinsp; + fToPfMtx[2] = sinxp; + fToPfMtx[3] = -cosyp * sinsp + sinyp * sinxp * cossp; + fToPfMtx[4] = cosyp * cossp + sinyp * sinxp * sinsp; + fToPfMtx[5] = -sinyp * cosxp; + fToPfMtx[6] = -sinyp * sinsp - cosyp * sinxp * cossp; + fToPfMtx[7] = sinyp * cossp - cosyp * sinxp * sinsp; + fToPfMtx[8] = cosyp * cosxp; + return Matrix3_default.multiply(pfToIcrf, fToPfMtx, result); +}; +var pointToWindowCoordinatesTemp = new Cartesian4_default(); +Transforms.pointToWindowCoordinates = function(modelViewProjectionMatrix, viewportTransformation, point, result) { + result = Transforms.pointToGLWindowCoordinates( + modelViewProjectionMatrix, + viewportTransformation, + point, + result + ); + result.y = 2 * viewportTransformation[5] - result.y; + return result; +}; +Transforms.pointToGLWindowCoordinates = function(modelViewProjectionMatrix, viewportTransformation, point, result) { + if (!defined_default(modelViewProjectionMatrix)) { + throw new DeveloperError_default("modelViewProjectionMatrix is required."); + } + if (!defined_default(viewportTransformation)) { + throw new DeveloperError_default("viewportTransformation is required."); + } + if (!defined_default(point)) { + throw new DeveloperError_default("point is required."); + } + if (!defined_default(result)) { + result = new Cartesian2_default(); + } + const tmp = pointToWindowCoordinatesTemp; + Matrix4_default.multiplyByVector( + modelViewProjectionMatrix, + Cartesian4_default.fromElements(point.x, point.y, point.z, 1, tmp), + tmp + ); + Cartesian4_default.multiplyByScalar(tmp, 1 / tmp.w, tmp); + Matrix4_default.multiplyByVector(viewportTransformation, tmp, tmp); + return Cartesian2_default.fromCartesian4(tmp, result); +}; +var normalScratch = new Cartesian3_default(); +var rightScratch = new Cartesian3_default(); +var upScratch = new Cartesian3_default(); +Transforms.rotationMatrixFromPositionVelocity = function(position, velocity, ellipsoid, result) { + if (!defined_default(position)) { + throw new DeveloperError_default("position is required."); + } + if (!defined_default(velocity)) { + throw new DeveloperError_default("velocity is required."); + } + const normal = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84).geodeticSurfaceNormal( + position, + normalScratch + ); + let right = Cartesian3_default.cross(velocity, normal, rightScratch); + if (Cartesian3_default.equalsEpsilon(right, Cartesian3_default.ZERO, Math_default.EPSILON6)) { + right = Cartesian3_default.clone(Cartesian3_default.UNIT_X, right); + } + const up = Cartesian3_default.cross(right, velocity, upScratch); + Cartesian3_default.normalize(up, up); + Cartesian3_default.cross(velocity, up, right); + Cartesian3_default.negate(right, right); + Cartesian3_default.normalize(right, right); + if (!defined_default(result)) { + result = new Matrix3_default(); + } + result[0] = velocity.x; + result[1] = velocity.y; + result[2] = velocity.z; + result[3] = right.x; + result[4] = right.y; + result[5] = right.z; + result[6] = up.x; + result[7] = up.y; + result[8] = up.z; + return result; +}; +var swizzleMatrix = new Matrix4_default( + 0, + 0, + 1, + 0, + 1, + 0, + 0, + 0, + 0, + 1, + 0, + 0, + 0, + 0, + 0, + 1 +); +var scratchCartographic = new Cartographic_default(); +var scratchCartesian3Projection = new Cartesian3_default(); +var scratchCenter = new Cartesian3_default(); +var scratchRotation = new Matrix3_default(); +var scratchFromENU = new Matrix4_default(); +var scratchToENU = new Matrix4_default(); +Transforms.basisTo2D = function(projection, matrix, result) { + if (!defined_default(projection)) { + throw new DeveloperError_default("projection is required."); + } + if (!defined_default(matrix)) { + throw new DeveloperError_default("matrix is required."); + } + if (!defined_default(result)) { + throw new DeveloperError_default("result is required."); + } + const rtcCenter = Matrix4_default.getTranslation(matrix, scratchCenter); + const ellipsoid = projection.ellipsoid; + const cartographic = ellipsoid.cartesianToCartographic( + rtcCenter, + scratchCartographic + ); + const projectedPosition = projection.project( + cartographic, + scratchCartesian3Projection + ); + Cartesian3_default.fromElements( + projectedPosition.z, + projectedPosition.x, + projectedPosition.y, + projectedPosition + ); + const fromENU = Transforms.eastNorthUpToFixedFrame( + rtcCenter, + ellipsoid, + scratchFromENU + ); + const toENU = Matrix4_default.inverseTransformation(fromENU, scratchToENU); + const rotation = Matrix4_default.getMatrix3(matrix, scratchRotation); + const local = Matrix4_default.multiplyByMatrix3(toENU, rotation, result); + Matrix4_default.multiply(swizzleMatrix, local, result); + Matrix4_default.setTranslation(result, projectedPosition, result); + return result; +}; +Transforms.wgs84To2DModelMatrix = function(projection, center, result) { + if (!defined_default(projection)) { + throw new DeveloperError_default("projection is required."); + } + if (!defined_default(center)) { + throw new DeveloperError_default("center is required."); + } + if (!defined_default(result)) { + throw new DeveloperError_default("result is required."); + } + const ellipsoid = projection.ellipsoid; + const fromENU = Transforms.eastNorthUpToFixedFrame( + center, + ellipsoid, + scratchFromENU + ); + const toENU = Matrix4_default.inverseTransformation(fromENU, scratchToENU); + const cartographic = ellipsoid.cartesianToCartographic( + center, + scratchCartographic + ); + const projectedPosition = projection.project( + cartographic, + scratchCartesian3Projection + ); + Cartesian3_default.fromElements( + projectedPosition.z, + projectedPosition.x, + projectedPosition.y, + projectedPosition + ); + const translation = Matrix4_default.fromTranslation( + projectedPosition, + scratchFromENU + ); + Matrix4_default.multiply(swizzleMatrix, toENU, result); + Matrix4_default.multiply(translation, result, result); + return result; +}; +var Transforms_default = Transforms; + +export { + GeographicProjection_default, + Intersect_default, + Interval_default, + BoundingSphere_default, + FeatureDetection_default, + Quaternion_default, + Resource_default, + buildModuleUrl_default, + Transforms_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-7CZEWQWE.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-7CZEWQWE.js new file mode 100644 index 0000000000000000000000000000000000000000..8b9147bf09ec8eb0d17079b5dff61d558c849953 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-7CZEWQWE.js @@ -0,0 +1,353 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/EllipsoidGeodesic.js +function setConstants(ellipsoidGeodesic) { + const uSquared = ellipsoidGeodesic._uSquared; + const a = ellipsoidGeodesic._ellipsoid.maximumRadius; + const b = ellipsoidGeodesic._ellipsoid.minimumRadius; + const f = (a - b) / a; + const cosineHeading = Math.cos(ellipsoidGeodesic._startHeading); + const sineHeading = Math.sin(ellipsoidGeodesic._startHeading); + const tanU = (1 - f) * Math.tan(ellipsoidGeodesic._start.latitude); + const cosineU = 1 / Math.sqrt(1 + tanU * tanU); + const sineU = cosineU * tanU; + const sigma = Math.atan2(tanU, cosineHeading); + const sineAlpha = cosineU * sineHeading; + const sineSquaredAlpha = sineAlpha * sineAlpha; + const cosineSquaredAlpha = 1 - sineSquaredAlpha; + const cosineAlpha = Math.sqrt(cosineSquaredAlpha); + const u2Over4 = uSquared / 4; + const u4Over16 = u2Over4 * u2Over4; + const u6Over64 = u4Over16 * u2Over4; + const u8Over256 = u4Over16 * u4Over16; + const a0 = 1 + u2Over4 - 3 * u4Over16 / 4 + 5 * u6Over64 / 4 - 175 * u8Over256 / 64; + const a1 = 1 - u2Over4 + 15 * u4Over16 / 8 - 35 * u6Over64 / 8; + const a2 = 1 - 3 * u2Over4 + 35 * u4Over16 / 4; + const a3 = 1 - 5 * u2Over4; + const distanceRatio = a0 * sigma - a1 * Math.sin(2 * sigma) * u2Over4 / 2 - a2 * Math.sin(4 * sigma) * u4Over16 / 16 - a3 * Math.sin(6 * sigma) * u6Over64 / 48 - Math.sin(8 * sigma) * 5 * u8Over256 / 512; + const constants = ellipsoidGeodesic._constants; + constants.a = a; + constants.b = b; + constants.f = f; + constants.cosineHeading = cosineHeading; + constants.sineHeading = sineHeading; + constants.tanU = tanU; + constants.cosineU = cosineU; + constants.sineU = sineU; + constants.sigma = sigma; + constants.sineAlpha = sineAlpha; + constants.sineSquaredAlpha = sineSquaredAlpha; + constants.cosineSquaredAlpha = cosineSquaredAlpha; + constants.cosineAlpha = cosineAlpha; + constants.u2Over4 = u2Over4; + constants.u4Over16 = u4Over16; + constants.u6Over64 = u6Over64; + constants.u8Over256 = u8Over256; + constants.a0 = a0; + constants.a1 = a1; + constants.a2 = a2; + constants.a3 = a3; + constants.distanceRatio = distanceRatio; +} +function computeC(f, cosineSquaredAlpha) { + return f * cosineSquaredAlpha * (4 + f * (4 - 3 * cosineSquaredAlpha)) / 16; +} +function computeDeltaLambda(f, sineAlpha, cosineSquaredAlpha, sigma, sineSigma, cosineSigma, cosineTwiceSigmaMidpoint) { + const C = computeC(f, cosineSquaredAlpha); + return (1 - C) * f * sineAlpha * (sigma + C * sineSigma * (cosineTwiceSigmaMidpoint + C * cosineSigma * (2 * cosineTwiceSigmaMidpoint * cosineTwiceSigmaMidpoint - 1))); +} +function vincentyInverseFormula(ellipsoidGeodesic, major, minor, firstLongitude, firstLatitude, secondLongitude, secondLatitude) { + const eff = (major - minor) / major; + const l = secondLongitude - firstLongitude; + const u1 = Math.atan((1 - eff) * Math.tan(firstLatitude)); + const u2 = Math.atan((1 - eff) * Math.tan(secondLatitude)); + const cosineU1 = Math.cos(u1); + const sineU1 = Math.sin(u1); + const cosineU2 = Math.cos(u2); + const sineU2 = Math.sin(u2); + const cc = cosineU1 * cosineU2; + const cs = cosineU1 * sineU2; + const ss = sineU1 * sineU2; + const sc = sineU1 * cosineU2; + let lambda = l; + let lambdaDot = Math_default.TWO_PI; + let cosineLambda = Math.cos(lambda); + let sineLambda = Math.sin(lambda); + let sigma; + let cosineSigma; + let sineSigma; + let cosineSquaredAlpha; + let cosineTwiceSigmaMidpoint; + do { + cosineLambda = Math.cos(lambda); + sineLambda = Math.sin(lambda); + const temp = cs - sc * cosineLambda; + sineSigma = Math.sqrt( + cosineU2 * cosineU2 * sineLambda * sineLambda + temp * temp + ); + cosineSigma = ss + cc * cosineLambda; + sigma = Math.atan2(sineSigma, cosineSigma); + let sineAlpha; + if (sineSigma === 0) { + sineAlpha = 0; + cosineSquaredAlpha = 1; + } else { + sineAlpha = cc * sineLambda / sineSigma; + cosineSquaredAlpha = 1 - sineAlpha * sineAlpha; + } + lambdaDot = lambda; + cosineTwiceSigmaMidpoint = cosineSigma - 2 * ss / cosineSquaredAlpha; + if (!isFinite(cosineTwiceSigmaMidpoint)) { + cosineTwiceSigmaMidpoint = 0; + } + lambda = l + computeDeltaLambda( + eff, + sineAlpha, + cosineSquaredAlpha, + sigma, + sineSigma, + cosineSigma, + cosineTwiceSigmaMidpoint + ); + } while (Math.abs(lambda - lambdaDot) > Math_default.EPSILON12); + const uSquared = cosineSquaredAlpha * (major * major - minor * minor) / (minor * minor); + const A = 1 + uSquared * (4096 + uSquared * (uSquared * (320 - 175 * uSquared) - 768)) / 16384; + const B = uSquared * (256 + uSquared * (uSquared * (74 - 47 * uSquared) - 128)) / 1024; + const cosineSquaredTwiceSigmaMidpoint = cosineTwiceSigmaMidpoint * cosineTwiceSigmaMidpoint; + const deltaSigma = B * sineSigma * (cosineTwiceSigmaMidpoint + B * (cosineSigma * (2 * cosineSquaredTwiceSigmaMidpoint - 1) - B * cosineTwiceSigmaMidpoint * (4 * sineSigma * sineSigma - 3) * (4 * cosineSquaredTwiceSigmaMidpoint - 3) / 6) / 4); + const distance = minor * A * (sigma - deltaSigma); + const startHeading = Math.atan2( + cosineU2 * sineLambda, + cs - sc * cosineLambda + ); + const endHeading = Math.atan2(cosineU1 * sineLambda, cs * cosineLambda - sc); + ellipsoidGeodesic._distance = distance; + ellipsoidGeodesic._startHeading = startHeading; + ellipsoidGeodesic._endHeading = endHeading; + ellipsoidGeodesic._uSquared = uSquared; +} +var scratchCart1 = new Cartesian3_default(); +var scratchCart2 = new Cartesian3_default(); +function computeProperties(ellipsoidGeodesic, start, end, ellipsoid) { + const firstCartesian = Cartesian3_default.normalize( + ellipsoid.cartographicToCartesian(start, scratchCart2), + scratchCart1 + ); + const lastCartesian = Cartesian3_default.normalize( + ellipsoid.cartographicToCartesian(end, scratchCart2), + scratchCart2 + ); + Check_default.typeOf.number.greaterThanOrEquals( + "value", + Math.abs( + Math.abs(Cartesian3_default.angleBetween(firstCartesian, lastCartesian)) - Math.PI + ), + 0.0125 + ); + vincentyInverseFormula( + ellipsoidGeodesic, + ellipsoid.maximumRadius, + ellipsoid.minimumRadius, + start.longitude, + start.latitude, + end.longitude, + end.latitude + ); + ellipsoidGeodesic._start = Cartographic_default.clone( + start, + ellipsoidGeodesic._start + ); + ellipsoidGeodesic._end = Cartographic_default.clone(end, ellipsoidGeodesic._end); + ellipsoidGeodesic._start.height = 0; + ellipsoidGeodesic._end.height = 0; + setConstants(ellipsoidGeodesic); +} +function EllipsoidGeodesic(start, end, ellipsoid) { + const e = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + this._ellipsoid = e; + this._start = new Cartographic_default(); + this._end = new Cartographic_default(); + this._constants = {}; + this._startHeading = void 0; + this._endHeading = void 0; + this._distance = void 0; + this._uSquared = void 0; + if (defined_default(start) && defined_default(end)) { + computeProperties(this, start, end, e); + } +} +Object.defineProperties(EllipsoidGeodesic.prototype, { + /** + * Gets the ellipsoid. + * @memberof EllipsoidGeodesic.prototype + * @type {Ellipsoid} + * @readonly + */ + ellipsoid: { + get: function() { + return this._ellipsoid; + } + }, + /** + * Gets the surface distance between the start and end point + * @memberof EllipsoidGeodesic.prototype + * @type {number} + * @readonly + */ + surfaceDistance: { + get: function() { + Check_default.defined("distance", this._distance); + return this._distance; + } + }, + /** + * Gets the initial planetodetic point on the path. + * @memberof EllipsoidGeodesic.prototype + * @type {Cartographic} + * @readonly + */ + start: { + get: function() { + return this._start; + } + }, + /** + * Gets the final planetodetic point on the path. + * @memberof EllipsoidGeodesic.prototype + * @type {Cartographic} + * @readonly + */ + end: { + get: function() { + return this._end; + } + }, + /** + * Gets the heading at the initial point. + * @memberof EllipsoidGeodesic.prototype + * @type {number} + * @readonly + */ + startHeading: { + get: function() { + Check_default.defined("distance", this._distance); + return this._startHeading; + } + }, + /** + * Gets the heading at the final point. + * @memberof EllipsoidGeodesic.prototype + * @type {number} + * @readonly + */ + endHeading: { + get: function() { + Check_default.defined("distance", this._distance); + return this._endHeading; + } + } +}); +EllipsoidGeodesic.prototype.setEndPoints = function(start, end) { + Check_default.defined("start", start); + Check_default.defined("end", end); + computeProperties(this, start, end, this._ellipsoid); +}; +EllipsoidGeodesic.prototype.interpolateUsingFraction = function(fraction, result) { + return this.interpolateUsingSurfaceDistance( + this._distance * fraction, + result + ); +}; +EllipsoidGeodesic.prototype.interpolateUsingSurfaceDistance = function(distance, result) { + Check_default.defined("distance", this._distance); + const constants = this._constants; + const s = constants.distanceRatio + distance / constants.b; + const cosine2S = Math.cos(2 * s); + const cosine4S = Math.cos(4 * s); + const cosine6S = Math.cos(6 * s); + const sine2S = Math.sin(2 * s); + const sine4S = Math.sin(4 * s); + const sine6S = Math.sin(6 * s); + const sine8S = Math.sin(8 * s); + const s2 = s * s; + const s3 = s * s2; + const u8Over256 = constants.u8Over256; + const u2Over4 = constants.u2Over4; + const u6Over64 = constants.u6Over64; + const u4Over16 = constants.u4Over16; + let sigma = 2 * s3 * u8Over256 * cosine2S / 3 + s * (1 - u2Over4 + 7 * u4Over16 / 4 - 15 * u6Over64 / 4 + 579 * u8Over256 / 64 - (u4Over16 - 15 * u6Over64 / 4 + 187 * u8Over256 / 16) * cosine2S - (5 * u6Over64 / 4 - 115 * u8Over256 / 16) * cosine4S - 29 * u8Over256 * cosine6S / 16) + (u2Over4 / 2 - u4Over16 + 71 * u6Over64 / 32 - 85 * u8Over256 / 16) * sine2S + (5 * u4Over16 / 16 - 5 * u6Over64 / 4 + 383 * u8Over256 / 96) * sine4S - s2 * ((u6Over64 - 11 * u8Over256 / 2) * sine2S + 5 * u8Over256 * sine4S / 2) + (29 * u6Over64 / 96 - 29 * u8Over256 / 16) * sine6S + 539 * u8Over256 * sine8S / 1536; + const theta = Math.asin(Math.sin(sigma) * constants.cosineAlpha); + const latitude = Math.atan(constants.a / constants.b * Math.tan(theta)); + sigma = sigma - constants.sigma; + const cosineTwiceSigmaMidpoint = Math.cos(2 * constants.sigma + sigma); + const sineSigma = Math.sin(sigma); + const cosineSigma = Math.cos(sigma); + const cc = constants.cosineU * cosineSigma; + const ss = constants.sineU * sineSigma; + const lambda = Math.atan2( + sineSigma * constants.sineHeading, + cc - ss * constants.cosineHeading + ); + const l = lambda - computeDeltaLambda( + constants.f, + constants.sineAlpha, + constants.cosineSquaredAlpha, + sigma, + sineSigma, + cosineSigma, + cosineTwiceSigmaMidpoint + ); + if (defined_default(result)) { + result.longitude = this._start.longitude + l; + result.latitude = latitude; + result.height = 0; + return result; + } + return new Cartographic_default(this._start.longitude + l, latitude, 0); +}; +var EllipsoidGeodesic_default = EllipsoidGeodesic; + +export { + EllipsoidGeodesic_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-7IMAWM6A.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-7IMAWM6A.js new file mode 100644 index 0000000000000000000000000000000000000000..d5ddebe4ad449cbc9f25f1ffb48fd9a81e462477 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-7IMAWM6A.js @@ -0,0 +1,842 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + ArcType_default +} from "./chunk-2C65EKYA.js"; +import { + GeometryPipeline_default +} from "./chunk-HCZR75II.js"; +import { + PolygonPipeline_default, + WindingOrder_default +} from "./chunk-RDM3BKNC.js"; +import { + arrayRemoveDuplicates_default +} from "./chunk-XZVQMPWG.js"; +import { + EllipsoidRhumbLine_default +} from "./chunk-RRUPTJ6P.js"; +import { + IndexDatatype_default +} from "./chunk-TF5D2H7B.js"; +import { + GeometryAttributes_default +} from "./chunk-N5MMDSD2.js"; +import { + GeometryAttribute_default, + Geometry_default, + PrimitiveType_default +} from "./chunk-UGZGTV5K.js"; +import { + Quaternion_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default +} from "./chunk-PW5CA4MJ.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/Queue.js +function Queue() { + this._array = []; + this._offset = 0; + this._length = 0; +} +Object.defineProperties(Queue.prototype, { + /** + * The length of the queue. + * + * @memberof Queue.prototype + * + * @type {number} + * @readonly + */ + length: { + get: function() { + return this._length; + } + } +}); +Queue.prototype.enqueue = function(item) { + this._array.push(item); + this._length++; +}; +Queue.prototype.dequeue = function() { + if (this._length === 0) { + return void 0; + } + const array = this._array; + let offset = this._offset; + const item = array[offset]; + array[offset] = void 0; + offset++; + if (offset > 10 && offset * 2 > array.length) { + this._array = array.slice(offset); + offset = 0; + } + this._offset = offset; + this._length--; + return item; +}; +Queue.prototype.peek = function() { + if (this._length === 0) { + return void 0; + } + return this._array[this._offset]; +}; +Queue.prototype.contains = function(item) { + return this._array.indexOf(item) !== -1; +}; +Queue.prototype.clear = function() { + this._array.length = this._offset = this._length = 0; +}; +Queue.prototype.sort = function(compareFunction) { + if (this._offset > 0) { + this._array = this._array.slice(this._offset); + this._offset = 0; + } + this._array.sort(compareFunction); +}; +var Queue_default = Queue; + +// packages/engine/Source/Core/PolygonGeometryLibrary.js +var PolygonGeometryLibrary = {}; +PolygonGeometryLibrary.computeHierarchyPackedLength = function(polygonHierarchy, CartesianX) { + let numComponents = 0; + const stack = [polygonHierarchy]; + while (stack.length > 0) { + const hierarchy = stack.pop(); + if (!defined_default(hierarchy)) { + continue; + } + numComponents += 2; + const positions = hierarchy.positions; + const holes = hierarchy.holes; + if (defined_default(positions) && positions.length > 0) { + numComponents += positions.length * CartesianX.packedLength; + } + if (defined_default(holes)) { + const length = holes.length; + for (let i = 0; i < length; ++i) { + stack.push(holes[i]); + } + } + } + return numComponents; +}; +PolygonGeometryLibrary.packPolygonHierarchy = function(polygonHierarchy, array, startingIndex, CartesianX) { + const stack = [polygonHierarchy]; + while (stack.length > 0) { + const hierarchy = stack.pop(); + if (!defined_default(hierarchy)) { + continue; + } + const positions = hierarchy.positions; + const holes = hierarchy.holes; + array[startingIndex++] = defined_default(positions) ? positions.length : 0; + array[startingIndex++] = defined_default(holes) ? holes.length : 0; + if (defined_default(positions)) { + const positionsLength = positions.length; + for (let i = 0; i < positionsLength; ++i, startingIndex += CartesianX.packedLength) { + CartesianX.pack(positions[i], array, startingIndex); + } + } + if (defined_default(holes)) { + const holesLength = holes.length; + for (let j = 0; j < holesLength; ++j) { + stack.push(holes[j]); + } + } + } + return startingIndex; +}; +PolygonGeometryLibrary.unpackPolygonHierarchy = function(array, startingIndex, CartesianX) { + const positionsLength = array[startingIndex++]; + const holesLength = array[startingIndex++]; + const positions = new Array(positionsLength); + const holes = holesLength > 0 ? new Array(holesLength) : void 0; + for (let i = 0; i < positionsLength; ++i, startingIndex += CartesianX.packedLength) { + positions[i] = CartesianX.unpack(array, startingIndex); + } + for (let j = 0; j < holesLength; ++j) { + holes[j] = PolygonGeometryLibrary.unpackPolygonHierarchy( + array, + startingIndex, + CartesianX + ); + startingIndex = holes[j].startingIndex; + delete holes[j].startingIndex; + } + return { + positions, + holes, + startingIndex + }; +}; +var distance2DScratch = new Cartesian2_default(); +function getPointAtDistance2D(p0, p1, distance, length) { + Cartesian2_default.subtract(p1, p0, distance2DScratch); + Cartesian2_default.multiplyByScalar( + distance2DScratch, + distance / length, + distance2DScratch + ); + Cartesian2_default.add(p0, distance2DScratch, distance2DScratch); + return [distance2DScratch.x, distance2DScratch.y]; +} +var distanceScratch = new Cartesian3_default(); +function getPointAtDistance(p0, p1, distance, length) { + Cartesian3_default.subtract(p1, p0, distanceScratch); + Cartesian3_default.multiplyByScalar( + distanceScratch, + distance / length, + distanceScratch + ); + Cartesian3_default.add(p0, distanceScratch, distanceScratch); + return [distanceScratch.x, distanceScratch.y, distanceScratch.z]; +} +PolygonGeometryLibrary.subdivideLineCount = function(p0, p1, minDistance) { + const distance = Cartesian3_default.distance(p0, p1); + const n = distance / minDistance; + const countDivide = Math.max(0, Math.ceil(Math_default.log2(n))); + return Math.pow(2, countDivide); +}; +var scratchCartographic0 = new Cartographic_default(); +var scratchCartographic1 = new Cartographic_default(); +var scratchCartographic2 = new Cartographic_default(); +var scratchCartesian0 = new Cartesian3_default(); +var scratchRhumbLine = new EllipsoidRhumbLine_default(); +PolygonGeometryLibrary.subdivideRhumbLineCount = function(ellipsoid, p0, p1, minDistance) { + const c0 = ellipsoid.cartesianToCartographic(p0, scratchCartographic0); + const c1 = ellipsoid.cartesianToCartographic(p1, scratchCartographic1); + const rhumb = new EllipsoidRhumbLine_default(c0, c1, ellipsoid); + const n = rhumb.surfaceDistance / minDistance; + const countDivide = Math.max(0, Math.ceil(Math_default.log2(n))); + return Math.pow(2, countDivide); +}; +PolygonGeometryLibrary.subdivideTexcoordLine = function(t0, t1, p0, p1, minDistance, result) { + const subdivisions = PolygonGeometryLibrary.subdivideLineCount( + p0, + p1, + minDistance + ); + const length2D = Cartesian2_default.distance(t0, t1); + const distanceBetweenCoords = length2D / subdivisions; + const texcoords = result; + texcoords.length = subdivisions * 2; + let index = 0; + for (let i = 0; i < subdivisions; i++) { + const t = getPointAtDistance2D(t0, t1, i * distanceBetweenCoords, length2D); + texcoords[index++] = t[0]; + texcoords[index++] = t[1]; + } + return texcoords; +}; +PolygonGeometryLibrary.subdivideLine = function(p0, p1, minDistance, result) { + const numVertices = PolygonGeometryLibrary.subdivideLineCount( + p0, + p1, + minDistance + ); + const length = Cartesian3_default.distance(p0, p1); + const distanceBetweenVertices = length / numVertices; + if (!defined_default(result)) { + result = []; + } + const positions = result; + positions.length = numVertices * 3; + let index = 0; + for (let i = 0; i < numVertices; i++) { + const p = getPointAtDistance(p0, p1, i * distanceBetweenVertices, length); + positions[index++] = p[0]; + positions[index++] = p[1]; + positions[index++] = p[2]; + } + return positions; +}; +PolygonGeometryLibrary.subdivideTexcoordRhumbLine = function(t0, t1, ellipsoid, p0, p1, minDistance, result) { + const c0 = ellipsoid.cartesianToCartographic(p0, scratchCartographic0); + const c1 = ellipsoid.cartesianToCartographic(p1, scratchCartographic1); + scratchRhumbLine.setEndPoints(c0, c1); + const n = scratchRhumbLine.surfaceDistance / minDistance; + const countDivide = Math.max(0, Math.ceil(Math_default.log2(n))); + const subdivisions = Math.pow(2, countDivide); + const length2D = Cartesian2_default.distance(t0, t1); + const distanceBetweenCoords = length2D / subdivisions; + const texcoords = result; + texcoords.length = subdivisions * 2; + let index = 0; + for (let i = 0; i < subdivisions; i++) { + const t = getPointAtDistance2D(t0, t1, i * distanceBetweenCoords, length2D); + texcoords[index++] = t[0]; + texcoords[index++] = t[1]; + } + return texcoords; +}; +PolygonGeometryLibrary.subdivideRhumbLine = function(ellipsoid, p0, p1, minDistance, result) { + const c0 = ellipsoid.cartesianToCartographic(p0, scratchCartographic0); + const c1 = ellipsoid.cartesianToCartographic(p1, scratchCartographic1); + const rhumb = new EllipsoidRhumbLine_default(c0, c1, ellipsoid); + const n = rhumb.surfaceDistance / minDistance; + const countDivide = Math.max(0, Math.ceil(Math_default.log2(n))); + const numVertices = Math.pow(2, countDivide); + const distanceBetweenVertices = rhumb.surfaceDistance / numVertices; + if (!defined_default(result)) { + result = []; + } + const positions = result; + positions.length = numVertices * 3; + let index = 0; + for (let i = 0; i < numVertices; i++) { + const c = rhumb.interpolateUsingSurfaceDistance( + i * distanceBetweenVertices, + scratchCartographic2 + ); + const p = ellipsoid.cartographicToCartesian(c, scratchCartesian0); + positions[index++] = p.x; + positions[index++] = p.y; + positions[index++] = p.z; + } + return positions; +}; +var scaleToGeodeticHeightN1 = new Cartesian3_default(); +var scaleToGeodeticHeightN2 = new Cartesian3_default(); +var scaleToGeodeticHeightP1 = new Cartesian3_default(); +var scaleToGeodeticHeightP2 = new Cartesian3_default(); +PolygonGeometryLibrary.scaleToGeodeticHeightExtruded = function(geometry, maxHeight, minHeight, ellipsoid, perPositionHeight) { + ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + const n1 = scaleToGeodeticHeightN1; + let n2 = scaleToGeodeticHeightN2; + const p = scaleToGeodeticHeightP1; + let p2 = scaleToGeodeticHeightP2; + if (defined_default(geometry) && defined_default(geometry.attributes) && defined_default(geometry.attributes.position)) { + const positions = geometry.attributes.position.values; + const length = positions.length / 2; + for (let i = 0; i < length; i += 3) { + Cartesian3_default.fromArray(positions, i, p); + ellipsoid.geodeticSurfaceNormal(p, n1); + p2 = ellipsoid.scaleToGeodeticSurface(p, p2); + n2 = Cartesian3_default.multiplyByScalar(n1, minHeight, n2); + n2 = Cartesian3_default.add(p2, n2, n2); + positions[i + length] = n2.x; + positions[i + 1 + length] = n2.y; + positions[i + 2 + length] = n2.z; + if (perPositionHeight) { + p2 = Cartesian3_default.clone(p, p2); + } + n2 = Cartesian3_default.multiplyByScalar(n1, maxHeight, n2); + n2 = Cartesian3_default.add(p2, n2, n2); + positions[i] = n2.x; + positions[i + 1] = n2.y; + positions[i + 2] = n2.z; + } + } + return geometry; +}; +PolygonGeometryLibrary.polygonOutlinesFromHierarchy = function(polygonHierarchy, scaleToEllipsoidSurface, ellipsoid) { + const polygons = []; + const queue = new Queue_default(); + queue.enqueue(polygonHierarchy); + let i; + let j; + let length; + while (queue.length !== 0) { + const outerNode = queue.dequeue(); + let outerRing = outerNode.positions; + if (scaleToEllipsoidSurface) { + length = outerRing.length; + for (i = 0; i < length; i++) { + ellipsoid.scaleToGeodeticSurface(outerRing[i], outerRing[i]); + } + } + outerRing = arrayRemoveDuplicates_default( + outerRing, + Cartesian3_default.equalsEpsilon, + true + ); + if (outerRing.length < 3) { + continue; + } + const numChildren = outerNode.holes ? outerNode.holes.length : 0; + for (i = 0; i < numChildren; i++) { + const hole = outerNode.holes[i]; + let holePositions = hole.positions; + if (scaleToEllipsoidSurface) { + length = holePositions.length; + for (j = 0; j < length; ++j) { + ellipsoid.scaleToGeodeticSurface(holePositions[j], holePositions[j]); + } + } + holePositions = arrayRemoveDuplicates_default( + holePositions, + Cartesian3_default.equalsEpsilon, + true + ); + if (holePositions.length < 3) { + continue; + } + polygons.push(holePositions); + let numGrandchildren = 0; + if (defined_default(hole.holes)) { + numGrandchildren = hole.holes.length; + } + for (j = 0; j < numGrandchildren; j++) { + queue.enqueue(hole.holes[j]); + } + } + polygons.push(outerRing); + } + return polygons; +}; +PolygonGeometryLibrary.polygonsFromHierarchy = function(polygonHierarchy, keepDuplicates, projectPointsTo2D, scaleToEllipsoidSurface, ellipsoid) { + const hierarchy = []; + const polygons = []; + const queue = new Queue_default(); + queue.enqueue(polygonHierarchy); + while (queue.length !== 0) { + const outerNode = queue.dequeue(); + let outerRing = outerNode.positions; + const holes = outerNode.holes; + let i; + let length; + if (scaleToEllipsoidSurface) { + length = outerRing.length; + for (i = 0; i < length; i++) { + ellipsoid.scaleToGeodeticSurface(outerRing[i], outerRing[i]); + } + } + if (!keepDuplicates) { + outerRing = arrayRemoveDuplicates_default( + outerRing, + Cartesian3_default.equalsEpsilon, + true + ); + } + if (outerRing.length < 3) { + continue; + } + let positions2D = projectPointsTo2D(outerRing); + if (!defined_default(positions2D)) { + continue; + } + const holeIndices = []; + let originalWindingOrder = PolygonPipeline_default.computeWindingOrder2D( + positions2D + ); + if (originalWindingOrder === WindingOrder_default.CLOCKWISE) { + positions2D.reverse(); + outerRing = outerRing.slice().reverse(); + } + let positions = outerRing.slice(); + const numChildren = defined_default(holes) ? holes.length : 0; + const polygonHoles = []; + let j; + for (i = 0; i < numChildren; i++) { + const hole = holes[i]; + let holePositions = hole.positions; + if (scaleToEllipsoidSurface) { + length = holePositions.length; + for (j = 0; j < length; ++j) { + ellipsoid.scaleToGeodeticSurface(holePositions[j], holePositions[j]); + } + } + if (!keepDuplicates) { + holePositions = arrayRemoveDuplicates_default( + holePositions, + Cartesian3_default.equalsEpsilon, + true + ); + } + if (holePositions.length < 3) { + continue; + } + const holePositions2D = projectPointsTo2D(holePositions); + if (!defined_default(holePositions2D)) { + continue; + } + originalWindingOrder = PolygonPipeline_default.computeWindingOrder2D( + holePositions2D + ); + if (originalWindingOrder === WindingOrder_default.CLOCKWISE) { + holePositions2D.reverse(); + holePositions = holePositions.slice().reverse(); + } + polygonHoles.push(holePositions); + holeIndices.push(positions.length); + positions = positions.concat(holePositions); + positions2D = positions2D.concat(holePositions2D); + let numGrandchildren = 0; + if (defined_default(hole.holes)) { + numGrandchildren = hole.holes.length; + } + for (j = 0; j < numGrandchildren; j++) { + queue.enqueue(hole.holes[j]); + } + } + hierarchy.push({ + outerRing, + holes: polygonHoles + }); + polygons.push({ + positions, + positions2D, + holes: holeIndices + }); + } + return { + hierarchy, + polygons + }; +}; +var computeBoundingRectangleCartesian2 = new Cartesian2_default(); +var computeBoundingRectangleCartesian3 = new Cartesian3_default(); +var computeBoundingRectangleQuaternion = new Quaternion_default(); +var computeBoundingRectangleMatrix3 = new Matrix3_default(); +PolygonGeometryLibrary.computeBoundingRectangle = function(planeNormal, projectPointTo2D, positions, angle, result) { + const rotation = Quaternion_default.fromAxisAngle( + planeNormal, + angle, + computeBoundingRectangleQuaternion + ); + const textureMatrix = Matrix3_default.fromQuaternion( + rotation, + computeBoundingRectangleMatrix3 + ); + let minX = Number.POSITIVE_INFINITY; + let maxX = Number.NEGATIVE_INFINITY; + let minY = Number.POSITIVE_INFINITY; + let maxY = Number.NEGATIVE_INFINITY; + const length = positions.length; + for (let i = 0; i < length; ++i) { + const p = Cartesian3_default.clone( + positions[i], + computeBoundingRectangleCartesian3 + ); + Matrix3_default.multiplyByVector(textureMatrix, p, p); + const st = projectPointTo2D(p, computeBoundingRectangleCartesian2); + if (defined_default(st)) { + minX = Math.min(minX, st.x); + maxX = Math.max(maxX, st.x); + minY = Math.min(minY, st.y); + maxY = Math.max(maxY, st.y); + } + } + result.x = minX; + result.y = minY; + result.width = maxX - minX; + result.height = maxY - minY; + return result; +}; +PolygonGeometryLibrary.createGeometryFromPositions = function(ellipsoid, polygon, textureCoordinates, granularity, perPositionHeight, vertexFormat, arcType) { + let indices = PolygonPipeline_default.triangulate(polygon.positions2D, polygon.holes); + if (indices.length < 3) { + indices = [0, 1, 2]; + } + const positions = polygon.positions; + const hasTexcoords = defined_default(textureCoordinates); + const texcoords = hasTexcoords ? textureCoordinates.positions : void 0; + if (perPositionHeight) { + const length = positions.length; + const flattenedPositions = new Array(length * 3); + let index = 0; + for (let i = 0; i < length; i++) { + const p = positions[i]; + flattenedPositions[index++] = p.x; + flattenedPositions[index++] = p.y; + flattenedPositions[index++] = p.z; + } + const geometryOptions = { + attributes: { + position: new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: flattenedPositions + }) + }, + indices, + primitiveType: PrimitiveType_default.TRIANGLES + }; + if (hasTexcoords) { + geometryOptions.attributes.st = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: Cartesian2_default.packArray(texcoords) + }); + } + const geometry = new Geometry_default(geometryOptions); + if (vertexFormat.normal) { + return GeometryPipeline_default.computeNormal(geometry); + } + return geometry; + } + if (arcType === ArcType_default.GEODESIC) { + return PolygonPipeline_default.computeSubdivision( + ellipsoid, + positions, + indices, + texcoords, + granularity + ); + } else if (arcType === ArcType_default.RHUMB) { + return PolygonPipeline_default.computeRhumbLineSubdivision( + ellipsoid, + positions, + indices, + texcoords, + granularity + ); + } +}; +var computeWallTexcoordsSubdivided = []; +var computeWallIndicesSubdivided = []; +var p1Scratch = new Cartesian3_default(); +var p2Scratch = new Cartesian3_default(); +PolygonGeometryLibrary.computeWallGeometry = function(positions, textureCoordinates, ellipsoid, granularity, perPositionHeight, arcType) { + let edgePositions; + let topEdgeLength; + let i; + let p1; + let p2; + let t1; + let t2; + let edgeTexcoords; + let topEdgeTexcoordLength; + let length = positions.length; + let index = 0; + let textureIndex = 0; + const hasTexcoords = defined_default(textureCoordinates); + const texcoords = hasTexcoords ? textureCoordinates.positions : void 0; + if (!perPositionHeight) { + const minDistance = Math_default.chordLength( + granularity, + ellipsoid.maximumRadius + ); + let numVertices = 0; + if (arcType === ArcType_default.GEODESIC) { + for (i = 0; i < length; i++) { + numVertices += PolygonGeometryLibrary.subdivideLineCount( + positions[i], + positions[(i + 1) % length], + minDistance + ); + } + } else if (arcType === ArcType_default.RHUMB) { + for (i = 0; i < length; i++) { + numVertices += PolygonGeometryLibrary.subdivideRhumbLineCount( + ellipsoid, + positions[i], + positions[(i + 1) % length], + minDistance + ); + } + } + topEdgeLength = (numVertices + length) * 3; + edgePositions = new Array(topEdgeLength * 2); + if (hasTexcoords) { + topEdgeTexcoordLength = (numVertices + length) * 2; + edgeTexcoords = new Array(topEdgeTexcoordLength * 2); + } + for (i = 0; i < length; i++) { + p1 = positions[i]; + p2 = positions[(i + 1) % length]; + let tempPositions; + let tempTexcoords; + if (hasTexcoords) { + t1 = texcoords[i]; + t2 = texcoords[(i + 1) % length]; + } + if (arcType === ArcType_default.GEODESIC) { + tempPositions = PolygonGeometryLibrary.subdivideLine( + p1, + p2, + minDistance, + computeWallIndicesSubdivided + ); + if (hasTexcoords) { + tempTexcoords = PolygonGeometryLibrary.subdivideTexcoordLine( + t1, + t2, + p1, + p2, + minDistance, + computeWallTexcoordsSubdivided + ); + } + } else if (arcType === ArcType_default.RHUMB) { + tempPositions = PolygonGeometryLibrary.subdivideRhumbLine( + ellipsoid, + p1, + p2, + minDistance, + computeWallIndicesSubdivided + ); + if (hasTexcoords) { + tempTexcoords = PolygonGeometryLibrary.subdivideTexcoordRhumbLine( + t1, + t2, + ellipsoid, + p1, + p2, + minDistance, + computeWallTexcoordsSubdivided + ); + } + } + const tempPositionsLength = tempPositions.length; + for (let j = 0; j < tempPositionsLength; ++j, ++index) { + edgePositions[index] = tempPositions[j]; + edgePositions[index + topEdgeLength] = tempPositions[j]; + } + edgePositions[index] = p2.x; + edgePositions[index + topEdgeLength] = p2.x; + ++index; + edgePositions[index] = p2.y; + edgePositions[index + topEdgeLength] = p2.y; + ++index; + edgePositions[index] = p2.z; + edgePositions[index + topEdgeLength] = p2.z; + ++index; + if (hasTexcoords) { + const tempTexcoordsLength = tempTexcoords.length; + for (let k = 0; k < tempTexcoordsLength; ++k, ++textureIndex) { + edgeTexcoords[textureIndex] = tempTexcoords[k]; + edgeTexcoords[textureIndex + topEdgeTexcoordLength] = tempTexcoords[k]; + } + edgeTexcoords[textureIndex] = t2.x; + edgeTexcoords[textureIndex + topEdgeTexcoordLength] = t2.x; + ++textureIndex; + edgeTexcoords[textureIndex] = t2.y; + edgeTexcoords[textureIndex + topEdgeTexcoordLength] = t2.y; + ++textureIndex; + } + } + } else { + topEdgeLength = length * 3 * 2; + edgePositions = new Array(topEdgeLength * 2); + if (hasTexcoords) { + topEdgeTexcoordLength = length * 2 * 2; + edgeTexcoords = new Array(topEdgeTexcoordLength * 2); + } + for (i = 0; i < length; i++) { + p1 = positions[i]; + p2 = positions[(i + 1) % length]; + edgePositions[index] = edgePositions[index + topEdgeLength] = p1.x; + ++index; + edgePositions[index] = edgePositions[index + topEdgeLength] = p1.y; + ++index; + edgePositions[index] = edgePositions[index + topEdgeLength] = p1.z; + ++index; + edgePositions[index] = edgePositions[index + topEdgeLength] = p2.x; + ++index; + edgePositions[index] = edgePositions[index + topEdgeLength] = p2.y; + ++index; + edgePositions[index] = edgePositions[index + topEdgeLength] = p2.z; + ++index; + if (hasTexcoords) { + t1 = texcoords[i]; + t2 = texcoords[(i + 1) % length]; + edgeTexcoords[textureIndex] = edgeTexcoords[textureIndex + topEdgeTexcoordLength] = t1.x; + ++textureIndex; + edgeTexcoords[textureIndex] = edgeTexcoords[textureIndex + topEdgeTexcoordLength] = t1.y; + ++textureIndex; + edgeTexcoords[textureIndex] = edgeTexcoords[textureIndex + topEdgeTexcoordLength] = t2.x; + ++textureIndex; + edgeTexcoords[textureIndex] = edgeTexcoords[textureIndex + topEdgeTexcoordLength] = t2.y; + ++textureIndex; + } + } + } + length = edgePositions.length; + const indices = IndexDatatype_default.createTypedArray( + length / 3, + length - positions.length * 6 + ); + let edgeIndex = 0; + length /= 6; + for (i = 0; i < length; i++) { + const UL = i; + const UR = UL + 1; + const LL = UL + length; + const LR = LL + 1; + p1 = Cartesian3_default.fromArray(edgePositions, UL * 3, p1Scratch); + p2 = Cartesian3_default.fromArray(edgePositions, UR * 3, p2Scratch); + if (Cartesian3_default.equalsEpsilon( + p1, + p2, + Math_default.EPSILON10, + Math_default.EPSILON10 + )) { + continue; + } + indices[edgeIndex++] = UL; + indices[edgeIndex++] = LL; + indices[edgeIndex++] = UR; + indices[edgeIndex++] = UR; + indices[edgeIndex++] = LL; + indices[edgeIndex++] = LR; + } + const geometryOptions = { + attributes: new GeometryAttributes_default({ + position: new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: edgePositions + }) + }), + indices, + primitiveType: PrimitiveType_default.TRIANGLES + }; + if (hasTexcoords) { + geometryOptions.attributes.st = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: edgeTexcoords + }); + } + const geometry = new Geometry_default(geometryOptions); + return geometry; +}; +var PolygonGeometryLibrary_default = PolygonGeometryLibrary; + +export { + PolygonGeometryLibrary_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-A6EA6KIE.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-A6EA6KIE.js new file mode 100644 index 0000000000000000000000000000000000000000..e30ccae9907454953e430eec64c05d606b4f1d85 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-A6EA6KIE.js @@ -0,0 +1,37 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + + +// packages/engine/Source/Core/GeometryOffsetAttribute.js +var GeometryOffsetAttribute = { + NONE: 0, + TOP: 1, + ALL: 2 +}; +var GeometryOffsetAttribute_default = Object.freeze(GeometryOffsetAttribute); + +export { + GeometryOffsetAttribute_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-AXGQUPXA.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-AXGQUPXA.js new file mode 100644 index 0000000000000000000000000000000000000000..f80e2cd023d5decabc7a07d7f13be259cd7f0ee4 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-AXGQUPXA.js @@ -0,0 +1,1075 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + EllipseGeometryLibrary_default +} from "./chunk-H6MBQ4W4.js"; +import { + GeometryInstance_default +} from "./chunk-V2LKNJGT.js"; +import { + GeometryPipeline_default +} from "./chunk-HCZR75II.js"; +import { + GeometryOffsetAttribute_default +} from "./chunk-A6EA6KIE.js"; +import { + VertexFormat_default +} from "./chunk-2NLMZNJI.js"; +import { + IndexDatatype_default +} from "./chunk-TF5D2H7B.js"; +import { + GeometryAttributes_default +} from "./chunk-N5MMDSD2.js"; +import { + GeometryAttribute_default, + Geometry_default, + PrimitiveType_default +} from "./chunk-UGZGTV5K.js"; +import { + BoundingSphere_default, + GeographicProjection_default, + Quaternion_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default, + Rectangle_default +} from "./chunk-PW5CA4MJ.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/EllipseGeometry.js +var scratchCartesian1 = new Cartesian3_default(); +var scratchCartesian2 = new Cartesian3_default(); +var scratchCartesian3 = new Cartesian3_default(); +var scratchCartesian4 = new Cartesian3_default(); +var texCoordScratch = new Cartesian2_default(); +var textureMatrixScratch = new Matrix3_default(); +var tangentMatrixScratch = new Matrix3_default(); +var quaternionScratch = new Quaternion_default(); +var scratchNormal = new Cartesian3_default(); +var scratchTangent = new Cartesian3_default(); +var scratchBitangent = new Cartesian3_default(); +var scratchCartographic = new Cartographic_default(); +var projectedCenterScratch = new Cartesian3_default(); +var scratchMinTexCoord = new Cartesian2_default(); +var scratchMaxTexCoord = new Cartesian2_default(); +function computeTopBottomAttributes(positions, options, extrude) { + const vertexFormat = options.vertexFormat; + const center = options.center; + const semiMajorAxis = options.semiMajorAxis; + const semiMinorAxis = options.semiMinorAxis; + const ellipsoid = options.ellipsoid; + const stRotation = options.stRotation; + const size = extrude ? positions.length / 3 * 2 : positions.length / 3; + const shadowVolume = options.shadowVolume; + const textureCoordinates = vertexFormat.st ? new Float32Array(size * 2) : void 0; + const normals = vertexFormat.normal ? new Float32Array(size * 3) : void 0; + const tangents = vertexFormat.tangent ? new Float32Array(size * 3) : void 0; + const bitangents = vertexFormat.bitangent ? new Float32Array(size * 3) : void 0; + const extrudeNormals = shadowVolume ? new Float32Array(size * 3) : void 0; + let textureCoordIndex = 0; + let normal = scratchNormal; + let tangent = scratchTangent; + let bitangent = scratchBitangent; + const projection = new GeographicProjection_default(ellipsoid); + const projectedCenter = projection.project( + ellipsoid.cartesianToCartographic(center, scratchCartographic), + projectedCenterScratch + ); + const geodeticNormal = ellipsoid.scaleToGeodeticSurface( + center, + scratchCartesian1 + ); + ellipsoid.geodeticSurfaceNormal(geodeticNormal, geodeticNormal); + let textureMatrix = textureMatrixScratch; + let tangentMatrix = tangentMatrixScratch; + if (stRotation !== 0) { + let rotation = Quaternion_default.fromAxisAngle( + geodeticNormal, + stRotation, + quaternionScratch + ); + textureMatrix = Matrix3_default.fromQuaternion(rotation, textureMatrix); + rotation = Quaternion_default.fromAxisAngle( + geodeticNormal, + -stRotation, + quaternionScratch + ); + tangentMatrix = Matrix3_default.fromQuaternion(rotation, tangentMatrix); + } else { + textureMatrix = Matrix3_default.clone(Matrix3_default.IDENTITY, textureMatrix); + tangentMatrix = Matrix3_default.clone(Matrix3_default.IDENTITY, tangentMatrix); + } + const minTexCoord = Cartesian2_default.fromElements( + Number.POSITIVE_INFINITY, + Number.POSITIVE_INFINITY, + scratchMinTexCoord + ); + const maxTexCoord = Cartesian2_default.fromElements( + Number.NEGATIVE_INFINITY, + Number.NEGATIVE_INFINITY, + scratchMaxTexCoord + ); + let length = positions.length; + const bottomOffset = extrude ? length : 0; + const stOffset = bottomOffset / 3 * 2; + for (let i = 0; i < length; i += 3) { + const i1 = i + 1; + const i2 = i + 2; + const position = Cartesian3_default.fromArray(positions, i, scratchCartesian1); + if (vertexFormat.st) { + const rotatedPoint = Matrix3_default.multiplyByVector( + textureMatrix, + position, + scratchCartesian2 + ); + const projectedPoint = projection.project( + ellipsoid.cartesianToCartographic(rotatedPoint, scratchCartographic), + scratchCartesian3 + ); + Cartesian3_default.subtract(projectedPoint, projectedCenter, projectedPoint); + texCoordScratch.x = (projectedPoint.x + semiMajorAxis) / (2 * semiMajorAxis); + texCoordScratch.y = (projectedPoint.y + semiMinorAxis) / (2 * semiMinorAxis); + minTexCoord.x = Math.min(texCoordScratch.x, minTexCoord.x); + minTexCoord.y = Math.min(texCoordScratch.y, minTexCoord.y); + maxTexCoord.x = Math.max(texCoordScratch.x, maxTexCoord.x); + maxTexCoord.y = Math.max(texCoordScratch.y, maxTexCoord.y); + if (extrude) { + textureCoordinates[textureCoordIndex + stOffset] = texCoordScratch.x; + textureCoordinates[textureCoordIndex + 1 + stOffset] = texCoordScratch.y; + } + textureCoordinates[textureCoordIndex++] = texCoordScratch.x; + textureCoordinates[textureCoordIndex++] = texCoordScratch.y; + } + if (vertexFormat.normal || vertexFormat.tangent || vertexFormat.bitangent || shadowVolume) { + normal = ellipsoid.geodeticSurfaceNormal(position, normal); + if (shadowVolume) { + extrudeNormals[i + bottomOffset] = -normal.x; + extrudeNormals[i1 + bottomOffset] = -normal.y; + extrudeNormals[i2 + bottomOffset] = -normal.z; + } + if (vertexFormat.normal || vertexFormat.tangent || vertexFormat.bitangent) { + if (vertexFormat.tangent || vertexFormat.bitangent) { + tangent = Cartesian3_default.normalize( + Cartesian3_default.cross(Cartesian3_default.UNIT_Z, normal, tangent), + tangent + ); + Matrix3_default.multiplyByVector(tangentMatrix, tangent, tangent); + } + if (vertexFormat.normal) { + normals[i] = normal.x; + normals[i1] = normal.y; + normals[i2] = normal.z; + if (extrude) { + normals[i + bottomOffset] = -normal.x; + normals[i1 + bottomOffset] = -normal.y; + normals[i2 + bottomOffset] = -normal.z; + } + } + if (vertexFormat.tangent) { + tangents[i] = tangent.x; + tangents[i1] = tangent.y; + tangents[i2] = tangent.z; + if (extrude) { + tangents[i + bottomOffset] = -tangent.x; + tangents[i1 + bottomOffset] = -tangent.y; + tangents[i2 + bottomOffset] = -tangent.z; + } + } + if (vertexFormat.bitangent) { + bitangent = Cartesian3_default.normalize( + Cartesian3_default.cross(normal, tangent, bitangent), + bitangent + ); + bitangents[i] = bitangent.x; + bitangents[i1] = bitangent.y; + bitangents[i2] = bitangent.z; + if (extrude) { + bitangents[i + bottomOffset] = bitangent.x; + bitangents[i1 + bottomOffset] = bitangent.y; + bitangents[i2 + bottomOffset] = bitangent.z; + } + } + } + } + } + if (vertexFormat.st) { + length = textureCoordinates.length; + for (let k = 0; k < length; k += 2) { + textureCoordinates[k] = (textureCoordinates[k] - minTexCoord.x) / (maxTexCoord.x - minTexCoord.x); + textureCoordinates[k + 1] = (textureCoordinates[k + 1] - minTexCoord.y) / (maxTexCoord.y - minTexCoord.y); + } + } + const attributes = new GeometryAttributes_default(); + if (vertexFormat.position) { + const finalPositions = EllipseGeometryLibrary_default.raisePositionsToHeight( + positions, + options, + extrude + ); + attributes.position = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: finalPositions + }); + } + if (vertexFormat.st) { + attributes.st = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: textureCoordinates + }); + } + if (vertexFormat.normal) { + attributes.normal = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: normals + }); + } + if (vertexFormat.tangent) { + attributes.tangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: tangents + }); + } + if (vertexFormat.bitangent) { + attributes.bitangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: bitangents + }); + } + if (shadowVolume) { + attributes.extrudeDirection = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: extrudeNormals + }); + } + if (extrude && defined_default(options.offsetAttribute)) { + let offsetAttribute = new Uint8Array(size); + if (options.offsetAttribute === GeometryOffsetAttribute_default.TOP) { + offsetAttribute = offsetAttribute.fill(1, 0, size / 2); + } else { + const offsetValue = options.offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1; + offsetAttribute = offsetAttribute.fill(offsetValue); + } + attributes.applyOffset = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE, + componentsPerAttribute: 1, + values: offsetAttribute + }); + } + return attributes; +} +function topIndices(numPts) { + const indices = new Array(12 * (numPts * (numPts + 1)) - 6); + let indicesIndex = 0; + let prevIndex; + let numInterior; + let positionIndex; + let i; + let j; + prevIndex = 0; + positionIndex = 1; + for (i = 0; i < 3; i++) { + indices[indicesIndex++] = positionIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex; + } + for (i = 2; i < numPts + 1; ++i) { + positionIndex = i * (i + 1) - 1; + prevIndex = (i - 1) * i - 1; + indices[indicesIndex++] = positionIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex; + numInterior = 2 * i; + for (j = 0; j < numInterior - 1; ++j) { + indices[indicesIndex++] = positionIndex; + indices[indicesIndex++] = prevIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex; + } + indices[indicesIndex++] = positionIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex; + } + numInterior = numPts * 2; + ++positionIndex; + ++prevIndex; + for (i = 0; i < numInterior - 1; ++i) { + indices[indicesIndex++] = positionIndex; + indices[indicesIndex++] = prevIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex; + } + indices[indicesIndex++] = positionIndex; + indices[indicesIndex++] = prevIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex++; + indices[indicesIndex++] = prevIndex++; + indices[indicesIndex++] = prevIndex; + ++prevIndex; + for (i = numPts - 1; i > 1; --i) { + indices[indicesIndex++] = prevIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex; + numInterior = 2 * i; + for (j = 0; j < numInterior - 1; ++j) { + indices[indicesIndex++] = positionIndex; + indices[indicesIndex++] = prevIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex; + } + indices[indicesIndex++] = prevIndex++; + indices[indicesIndex++] = prevIndex++; + indices[indicesIndex++] = positionIndex++; + } + for (i = 0; i < 3; i++) { + indices[indicesIndex++] = prevIndex++; + indices[indicesIndex++] = prevIndex; + indices[indicesIndex++] = positionIndex; + } + return indices; +} +var boundingSphereCenter = new Cartesian3_default(); +function computeEllipse(options) { + const center = options.center; + boundingSphereCenter = Cartesian3_default.multiplyByScalar( + options.ellipsoid.geodeticSurfaceNormal(center, boundingSphereCenter), + options.height, + boundingSphereCenter + ); + boundingSphereCenter = Cartesian3_default.add( + center, + boundingSphereCenter, + boundingSphereCenter + ); + const boundingSphere = new BoundingSphere_default( + boundingSphereCenter, + options.semiMajorAxis + ); + const cep = EllipseGeometryLibrary_default.computeEllipsePositions( + options, + true, + false + ); + const positions = cep.positions; + const numPts = cep.numPts; + const attributes = computeTopBottomAttributes(positions, options, false); + let indices = topIndices(numPts); + indices = IndexDatatype_default.createTypedArray(positions.length / 3, indices); + return { + boundingSphere, + attributes, + indices + }; +} +function computeWallAttributes(positions, options) { + const vertexFormat = options.vertexFormat; + const center = options.center; + const semiMajorAxis = options.semiMajorAxis; + const semiMinorAxis = options.semiMinorAxis; + const ellipsoid = options.ellipsoid; + const height = options.height; + const extrudedHeight = options.extrudedHeight; + const stRotation = options.stRotation; + const size = positions.length / 3 * 2; + const finalPositions = new Float64Array(size * 3); + const textureCoordinates = vertexFormat.st ? new Float32Array(size * 2) : void 0; + const normals = vertexFormat.normal ? new Float32Array(size * 3) : void 0; + const tangents = vertexFormat.tangent ? new Float32Array(size * 3) : void 0; + const bitangents = vertexFormat.bitangent ? new Float32Array(size * 3) : void 0; + const shadowVolume = options.shadowVolume; + const extrudeNormals = shadowVolume ? new Float32Array(size * 3) : void 0; + let textureCoordIndex = 0; + let normal = scratchNormal; + let tangent = scratchTangent; + let bitangent = scratchBitangent; + const projection = new GeographicProjection_default(ellipsoid); + const projectedCenter = projection.project( + ellipsoid.cartesianToCartographic(center, scratchCartographic), + projectedCenterScratch + ); + const geodeticNormal = ellipsoid.scaleToGeodeticSurface( + center, + scratchCartesian1 + ); + ellipsoid.geodeticSurfaceNormal(geodeticNormal, geodeticNormal); + const rotation = Quaternion_default.fromAxisAngle( + geodeticNormal, + stRotation, + quaternionScratch + ); + const textureMatrix = Matrix3_default.fromQuaternion(rotation, textureMatrixScratch); + const minTexCoord = Cartesian2_default.fromElements( + Number.POSITIVE_INFINITY, + Number.POSITIVE_INFINITY, + scratchMinTexCoord + ); + const maxTexCoord = Cartesian2_default.fromElements( + Number.NEGATIVE_INFINITY, + Number.NEGATIVE_INFINITY, + scratchMaxTexCoord + ); + let length = positions.length; + const stOffset = length / 3 * 2; + for (let i = 0; i < length; i += 3) { + const i1 = i + 1; + const i2 = i + 2; + let position = Cartesian3_default.fromArray(positions, i, scratchCartesian1); + let extrudedPosition; + if (vertexFormat.st) { + const rotatedPoint = Matrix3_default.multiplyByVector( + textureMatrix, + position, + scratchCartesian2 + ); + const projectedPoint = projection.project( + ellipsoid.cartesianToCartographic(rotatedPoint, scratchCartographic), + scratchCartesian3 + ); + Cartesian3_default.subtract(projectedPoint, projectedCenter, projectedPoint); + texCoordScratch.x = (projectedPoint.x + semiMajorAxis) / (2 * semiMajorAxis); + texCoordScratch.y = (projectedPoint.y + semiMinorAxis) / (2 * semiMinorAxis); + minTexCoord.x = Math.min(texCoordScratch.x, minTexCoord.x); + minTexCoord.y = Math.min(texCoordScratch.y, minTexCoord.y); + maxTexCoord.x = Math.max(texCoordScratch.x, maxTexCoord.x); + maxTexCoord.y = Math.max(texCoordScratch.y, maxTexCoord.y); + textureCoordinates[textureCoordIndex + stOffset] = texCoordScratch.x; + textureCoordinates[textureCoordIndex + 1 + stOffset] = texCoordScratch.y; + textureCoordinates[textureCoordIndex++] = texCoordScratch.x; + textureCoordinates[textureCoordIndex++] = texCoordScratch.y; + } + position = ellipsoid.scaleToGeodeticSurface(position, position); + extrudedPosition = Cartesian3_default.clone(position, scratchCartesian2); + normal = ellipsoid.geodeticSurfaceNormal(position, normal); + if (shadowVolume) { + extrudeNormals[i + length] = -normal.x; + extrudeNormals[i1 + length] = -normal.y; + extrudeNormals[i2 + length] = -normal.z; + } + let scaledNormal = Cartesian3_default.multiplyByScalar( + normal, + height, + scratchCartesian4 + ); + position = Cartesian3_default.add(position, scaledNormal, position); + scaledNormal = Cartesian3_default.multiplyByScalar( + normal, + extrudedHeight, + scaledNormal + ); + extrudedPosition = Cartesian3_default.add( + extrudedPosition, + scaledNormal, + extrudedPosition + ); + if (vertexFormat.position) { + finalPositions[i + length] = extrudedPosition.x; + finalPositions[i1 + length] = extrudedPosition.y; + finalPositions[i2 + length] = extrudedPosition.z; + finalPositions[i] = position.x; + finalPositions[i1] = position.y; + finalPositions[i2] = position.z; + } + if (vertexFormat.normal || vertexFormat.tangent || vertexFormat.bitangent) { + bitangent = Cartesian3_default.clone(normal, bitangent); + const next = Cartesian3_default.fromArray( + positions, + (i + 3) % length, + scratchCartesian4 + ); + Cartesian3_default.subtract(next, position, next); + const bottom = Cartesian3_default.subtract( + extrudedPosition, + position, + scratchCartesian3 + ); + normal = Cartesian3_default.normalize( + Cartesian3_default.cross(bottom, next, normal), + normal + ); + if (vertexFormat.normal) { + normals[i] = normal.x; + normals[i1] = normal.y; + normals[i2] = normal.z; + normals[i + length] = normal.x; + normals[i1 + length] = normal.y; + normals[i2 + length] = normal.z; + } + if (vertexFormat.tangent) { + tangent = Cartesian3_default.normalize( + Cartesian3_default.cross(bitangent, normal, tangent), + tangent + ); + tangents[i] = tangent.x; + tangents[i1] = tangent.y; + tangents[i2] = tangent.z; + tangents[i + length] = tangent.x; + tangents[i + 1 + length] = tangent.y; + tangents[i + 2 + length] = tangent.z; + } + if (vertexFormat.bitangent) { + bitangents[i] = bitangent.x; + bitangents[i1] = bitangent.y; + bitangents[i2] = bitangent.z; + bitangents[i + length] = bitangent.x; + bitangents[i1 + length] = bitangent.y; + bitangents[i2 + length] = bitangent.z; + } + } + } + if (vertexFormat.st) { + length = textureCoordinates.length; + for (let k = 0; k < length; k += 2) { + textureCoordinates[k] = (textureCoordinates[k] - minTexCoord.x) / (maxTexCoord.x - minTexCoord.x); + textureCoordinates[k + 1] = (textureCoordinates[k + 1] - minTexCoord.y) / (maxTexCoord.y - minTexCoord.y); + } + } + const attributes = new GeometryAttributes_default(); + if (vertexFormat.position) { + attributes.position = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: finalPositions + }); + } + if (vertexFormat.st) { + attributes.st = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: textureCoordinates + }); + } + if (vertexFormat.normal) { + attributes.normal = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: normals + }); + } + if (vertexFormat.tangent) { + attributes.tangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: tangents + }); + } + if (vertexFormat.bitangent) { + attributes.bitangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: bitangents + }); + } + if (shadowVolume) { + attributes.extrudeDirection = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: extrudeNormals + }); + } + if (defined_default(options.offsetAttribute)) { + let offsetAttribute = new Uint8Array(size); + if (options.offsetAttribute === GeometryOffsetAttribute_default.TOP) { + offsetAttribute = offsetAttribute.fill(1, 0, size / 2); + } else { + const offsetValue = options.offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1; + offsetAttribute = offsetAttribute.fill(offsetValue); + } + attributes.applyOffset = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE, + componentsPerAttribute: 1, + values: offsetAttribute + }); + } + return attributes; +} +function computeWallIndices(positions) { + const length = positions.length / 3; + const indices = IndexDatatype_default.createTypedArray(length, length * 6); + let index = 0; + for (let i = 0; i < length; i++) { + const UL = i; + const LL = i + length; + const UR = (UL + 1) % length; + const LR = UR + length; + indices[index++] = UL; + indices[index++] = LL; + indices[index++] = UR; + indices[index++] = UR; + indices[index++] = LL; + indices[index++] = LR; + } + return indices; +} +var topBoundingSphere = new BoundingSphere_default(); +var bottomBoundingSphere = new BoundingSphere_default(); +function computeExtrudedEllipse(options) { + const center = options.center; + const ellipsoid = options.ellipsoid; + const semiMajorAxis = options.semiMajorAxis; + let scaledNormal = Cartesian3_default.multiplyByScalar( + ellipsoid.geodeticSurfaceNormal(center, scratchCartesian1), + options.height, + scratchCartesian1 + ); + topBoundingSphere.center = Cartesian3_default.add( + center, + scaledNormal, + topBoundingSphere.center + ); + topBoundingSphere.radius = semiMajorAxis; + scaledNormal = Cartesian3_default.multiplyByScalar( + ellipsoid.geodeticSurfaceNormal(center, scaledNormal), + options.extrudedHeight, + scaledNormal + ); + bottomBoundingSphere.center = Cartesian3_default.add( + center, + scaledNormal, + bottomBoundingSphere.center + ); + bottomBoundingSphere.radius = semiMajorAxis; + const cep = EllipseGeometryLibrary_default.computeEllipsePositions( + options, + true, + true + ); + const positions = cep.positions; + const numPts = cep.numPts; + const outerPositions = cep.outerPositions; + const boundingSphere = BoundingSphere_default.union( + topBoundingSphere, + bottomBoundingSphere + ); + const topBottomAttributes = computeTopBottomAttributes( + positions, + options, + true + ); + let indices = topIndices(numPts); + const length = indices.length; + indices.length = length * 2; + const posLength = positions.length / 3; + for (let i = 0; i < length; i += 3) { + indices[i + length] = indices[i + 2] + posLength; + indices[i + 1 + length] = indices[i + 1] + posLength; + indices[i + 2 + length] = indices[i] + posLength; + } + const topBottomIndices = IndexDatatype_default.createTypedArray( + posLength * 2 / 3, + indices + ); + const topBottomGeo = new Geometry_default({ + attributes: topBottomAttributes, + indices: topBottomIndices, + primitiveType: PrimitiveType_default.TRIANGLES + }); + const wallAttributes = computeWallAttributes(outerPositions, options); + indices = computeWallIndices(outerPositions); + const wallIndices = IndexDatatype_default.createTypedArray( + outerPositions.length * 2 / 3, + indices + ); + const wallGeo = new Geometry_default({ + attributes: wallAttributes, + indices: wallIndices, + primitiveType: PrimitiveType_default.TRIANGLES + }); + const geo = GeometryPipeline_default.combineInstances([ + new GeometryInstance_default({ + geometry: topBottomGeo + }), + new GeometryInstance_default({ + geometry: wallGeo + }) + ]); + return { + boundingSphere, + attributes: geo[0].attributes, + indices: geo[0].indices + }; +} +function computeRectangle(center, semiMajorAxis, semiMinorAxis, rotation, granularity, ellipsoid, result) { + const cep = EllipseGeometryLibrary_default.computeEllipsePositions( + { + center, + semiMajorAxis, + semiMinorAxis, + rotation, + granularity + }, + false, + true + ); + const positionsFlat = cep.outerPositions; + const positionsCount = positionsFlat.length / 3; + const positions = new Array(positionsCount); + for (let i = 0; i < positionsCount; ++i) { + positions[i] = Cartesian3_default.fromArray(positionsFlat, i * 3); + } + const rectangle = Rectangle_default.fromCartesianArray(positions, ellipsoid, result); + if (rectangle.width > Math_default.PI) { + rectangle.north = rectangle.north > 0 ? Math_default.PI_OVER_TWO - Math_default.EPSILON7 : rectangle.north; + rectangle.south = rectangle.south < 0 ? Math_default.EPSILON7 - Math_default.PI_OVER_TWO : rectangle.south; + rectangle.east = Math_default.PI; + rectangle.west = -Math_default.PI; + } + return rectangle; +} +function EllipseGeometry(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const center = options.center; + const ellipsoid = defaultValue_default(options.ellipsoid, Ellipsoid_default.WGS84); + const semiMajorAxis = options.semiMajorAxis; + const semiMinorAxis = options.semiMinorAxis; + const granularity = defaultValue_default( + options.granularity, + Math_default.RADIANS_PER_DEGREE + ); + const vertexFormat = defaultValue_default(options.vertexFormat, VertexFormat_default.DEFAULT); + Check_default.defined("options.center", center); + Check_default.typeOf.number("options.semiMajorAxis", semiMajorAxis); + Check_default.typeOf.number("options.semiMinorAxis", semiMinorAxis); + if (semiMajorAxis < semiMinorAxis) { + throw new DeveloperError_default( + "semiMajorAxis must be greater than or equal to the semiMinorAxis." + ); + } + if (granularity <= 0) { + throw new DeveloperError_default("granularity must be greater than zero."); + } + const height = defaultValue_default(options.height, 0); + const extrudedHeight = defaultValue_default(options.extrudedHeight, height); + this._center = Cartesian3_default.clone(center); + this._semiMajorAxis = semiMajorAxis; + this._semiMinorAxis = semiMinorAxis; + this._ellipsoid = Ellipsoid_default.clone(ellipsoid); + this._rotation = defaultValue_default(options.rotation, 0); + this._stRotation = defaultValue_default(options.stRotation, 0); + this._height = Math.max(extrudedHeight, height); + this._granularity = granularity; + this._vertexFormat = VertexFormat_default.clone(vertexFormat); + this._extrudedHeight = Math.min(extrudedHeight, height); + this._shadowVolume = defaultValue_default(options.shadowVolume, false); + this._workerName = "createEllipseGeometry"; + this._offsetAttribute = options.offsetAttribute; + this._rectangle = void 0; + this._textureCoordinateRotationPoints = void 0; +} +EllipseGeometry.packedLength = Cartesian3_default.packedLength + Ellipsoid_default.packedLength + VertexFormat_default.packedLength + 9; +EllipseGeometry.pack = function(value, array, startingIndex) { + Check_default.defined("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + Cartesian3_default.pack(value._center, array, startingIndex); + startingIndex += Cartesian3_default.packedLength; + Ellipsoid_default.pack(value._ellipsoid, array, startingIndex); + startingIndex += Ellipsoid_default.packedLength; + VertexFormat_default.pack(value._vertexFormat, array, startingIndex); + startingIndex += VertexFormat_default.packedLength; + array[startingIndex++] = value._semiMajorAxis; + array[startingIndex++] = value._semiMinorAxis; + array[startingIndex++] = value._rotation; + array[startingIndex++] = value._stRotation; + array[startingIndex++] = value._height; + array[startingIndex++] = value._granularity; + array[startingIndex++] = value._extrudedHeight; + array[startingIndex++] = value._shadowVolume ? 1 : 0; + array[startingIndex] = defaultValue_default(value._offsetAttribute, -1); + return array; +}; +var scratchCenter = new Cartesian3_default(); +var scratchEllipsoid = new Ellipsoid_default(); +var scratchVertexFormat = new VertexFormat_default(); +var scratchOptions = { + center: scratchCenter, + ellipsoid: scratchEllipsoid, + vertexFormat: scratchVertexFormat, + semiMajorAxis: void 0, + semiMinorAxis: void 0, + rotation: void 0, + stRotation: void 0, + height: void 0, + granularity: void 0, + extrudedHeight: void 0, + shadowVolume: void 0, + offsetAttribute: void 0 +}; +EllipseGeometry.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + const center = Cartesian3_default.unpack(array, startingIndex, scratchCenter); + startingIndex += Cartesian3_default.packedLength; + const ellipsoid = Ellipsoid_default.unpack(array, startingIndex, scratchEllipsoid); + startingIndex += Ellipsoid_default.packedLength; + const vertexFormat = VertexFormat_default.unpack( + array, + startingIndex, + scratchVertexFormat + ); + startingIndex += VertexFormat_default.packedLength; + const semiMajorAxis = array[startingIndex++]; + const semiMinorAxis = array[startingIndex++]; + const rotation = array[startingIndex++]; + const stRotation = array[startingIndex++]; + const height = array[startingIndex++]; + const granularity = array[startingIndex++]; + const extrudedHeight = array[startingIndex++]; + const shadowVolume = array[startingIndex++] === 1; + const offsetAttribute = array[startingIndex]; + if (!defined_default(result)) { + scratchOptions.height = height; + scratchOptions.extrudedHeight = extrudedHeight; + scratchOptions.granularity = granularity; + scratchOptions.stRotation = stRotation; + scratchOptions.rotation = rotation; + scratchOptions.semiMajorAxis = semiMajorAxis; + scratchOptions.semiMinorAxis = semiMinorAxis; + scratchOptions.shadowVolume = shadowVolume; + scratchOptions.offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return new EllipseGeometry(scratchOptions); + } + result._center = Cartesian3_default.clone(center, result._center); + result._ellipsoid = Ellipsoid_default.clone(ellipsoid, result._ellipsoid); + result._vertexFormat = VertexFormat_default.clone(vertexFormat, result._vertexFormat); + result._semiMajorAxis = semiMajorAxis; + result._semiMinorAxis = semiMinorAxis; + result._rotation = rotation; + result._stRotation = stRotation; + result._height = height; + result._granularity = granularity; + result._extrudedHeight = extrudedHeight; + result._shadowVolume = shadowVolume; + result._offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return result; +}; +EllipseGeometry.computeRectangle = function(options, result) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const center = options.center; + const ellipsoid = defaultValue_default(options.ellipsoid, Ellipsoid_default.WGS84); + const semiMajorAxis = options.semiMajorAxis; + const semiMinorAxis = options.semiMinorAxis; + const granularity = defaultValue_default( + options.granularity, + Math_default.RADIANS_PER_DEGREE + ); + const rotation = defaultValue_default(options.rotation, 0); + Check_default.defined("options.center", center); + Check_default.typeOf.number("options.semiMajorAxis", semiMajorAxis); + Check_default.typeOf.number("options.semiMinorAxis", semiMinorAxis); + if (semiMajorAxis < semiMinorAxis) { + throw new DeveloperError_default( + "semiMajorAxis must be greater than or equal to the semiMinorAxis." + ); + } + if (granularity <= 0) { + throw new DeveloperError_default("granularity must be greater than zero."); + } + return computeRectangle( + center, + semiMajorAxis, + semiMinorAxis, + rotation, + granularity, + ellipsoid, + result + ); +}; +EllipseGeometry.createGeometry = function(ellipseGeometry) { + if (ellipseGeometry._semiMajorAxis <= 0 || ellipseGeometry._semiMinorAxis <= 0) { + return; + } + const height = ellipseGeometry._height; + const extrudedHeight = ellipseGeometry._extrudedHeight; + const extrude = !Math_default.equalsEpsilon( + height, + extrudedHeight, + 0, + Math_default.EPSILON2 + ); + ellipseGeometry._center = ellipseGeometry._ellipsoid.scaleToGeodeticSurface( + ellipseGeometry._center, + ellipseGeometry._center + ); + const options = { + center: ellipseGeometry._center, + semiMajorAxis: ellipseGeometry._semiMajorAxis, + semiMinorAxis: ellipseGeometry._semiMinorAxis, + ellipsoid: ellipseGeometry._ellipsoid, + rotation: ellipseGeometry._rotation, + height, + granularity: ellipseGeometry._granularity, + vertexFormat: ellipseGeometry._vertexFormat, + stRotation: ellipseGeometry._stRotation + }; + let geometry; + if (extrude) { + options.extrudedHeight = extrudedHeight; + options.shadowVolume = ellipseGeometry._shadowVolume; + options.offsetAttribute = ellipseGeometry._offsetAttribute; + geometry = computeExtrudedEllipse(options); + } else { + geometry = computeEllipse(options); + if (defined_default(ellipseGeometry._offsetAttribute)) { + const length = geometry.attributes.position.values.length; + const offsetValue = ellipseGeometry._offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1; + const applyOffset = new Uint8Array(length / 3).fill(offsetValue); + geometry.attributes.applyOffset = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE, + componentsPerAttribute: 1, + values: applyOffset + }); + } + } + return new Geometry_default({ + attributes: geometry.attributes, + indices: geometry.indices, + primitiveType: PrimitiveType_default.TRIANGLES, + boundingSphere: geometry.boundingSphere, + offsetAttribute: ellipseGeometry._offsetAttribute + }); +}; +EllipseGeometry.createShadowVolume = function(ellipseGeometry, minHeightFunc, maxHeightFunc) { + const granularity = ellipseGeometry._granularity; + const ellipsoid = ellipseGeometry._ellipsoid; + const minHeight = minHeightFunc(granularity, ellipsoid); + const maxHeight = maxHeightFunc(granularity, ellipsoid); + return new EllipseGeometry({ + center: ellipseGeometry._center, + semiMajorAxis: ellipseGeometry._semiMajorAxis, + semiMinorAxis: ellipseGeometry._semiMinorAxis, + ellipsoid, + rotation: ellipseGeometry._rotation, + stRotation: ellipseGeometry._stRotation, + granularity, + extrudedHeight: minHeight, + height: maxHeight, + vertexFormat: VertexFormat_default.POSITION_ONLY, + shadowVolume: true + }); +}; +function textureCoordinateRotationPoints(ellipseGeometry) { + const stRotation = -ellipseGeometry._stRotation; + if (stRotation === 0) { + return [0, 0, 0, 1, 1, 0]; + } + const cep = EllipseGeometryLibrary_default.computeEllipsePositions( + { + center: ellipseGeometry._center, + semiMajorAxis: ellipseGeometry._semiMajorAxis, + semiMinorAxis: ellipseGeometry._semiMinorAxis, + rotation: ellipseGeometry._rotation, + granularity: ellipseGeometry._granularity + }, + false, + true + ); + const positionsFlat = cep.outerPositions; + const positionsCount = positionsFlat.length / 3; + const positions = new Array(positionsCount); + for (let i = 0; i < positionsCount; ++i) { + positions[i] = Cartesian3_default.fromArray(positionsFlat, i * 3); + } + const ellipsoid = ellipseGeometry._ellipsoid; + const boundingRectangle = ellipseGeometry.rectangle; + return Geometry_default._textureCoordinateRotationPoints( + positions, + stRotation, + ellipsoid, + boundingRectangle + ); +} +Object.defineProperties(EllipseGeometry.prototype, { + /** + * @private + */ + rectangle: { + get: function() { + if (!defined_default(this._rectangle)) { + this._rectangle = computeRectangle( + this._center, + this._semiMajorAxis, + this._semiMinorAxis, + this._rotation, + this._granularity, + this._ellipsoid + ); + } + return this._rectangle; + } + }, + /** + * For remapping texture coordinates when rendering EllipseGeometries as GroundPrimitives. + * @private + */ + textureCoordinateRotationPoints: { + get: function() { + if (!defined_default(this._textureCoordinateRotationPoints)) { + this._textureCoordinateRotationPoints = textureCoordinateRotationPoints( + this + ); + } + return this._textureCoordinateRotationPoints; + } + } +}); +var EllipseGeometry_default = EllipseGeometry; + +export { + EllipseGeometry_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-BT6YIL2N.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-BT6YIL2N.js new file mode 100644 index 0000000000000000000000000000000000000000..2c9a2f283e9c10d3a2076c3c2edb867e8c34953e --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-BT6YIL2N.js @@ -0,0 +1,39 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + + +// packages/engine/Source/Core/defaultValue.js +function defaultValue(a, b) { + if (a !== void 0 && a !== null) { + return a; + } + return b; +} +defaultValue.EMPTY_OBJECT = Object.freeze({}); +var defaultValue_default = defaultValue; + +export { + defaultValue_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-C6MRR5YL.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-C6MRR5YL.js new file mode 100644 index 0000000000000000000000000000000000000000..12d7f744a06125df5795c5e95deaff4a571d6739 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-C6MRR5YL.js @@ -0,0 +1,476 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + CornerType_default, + PolylineVolumeGeometryLibrary_default +} from "./chunk-YMJPANZZ.js"; +import { + PolylinePipeline_default +} from "./chunk-H52L6U76.js"; +import { + Quaternion_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian3_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/CorridorGeometryLibrary.js +var CorridorGeometryLibrary = {}; +var scratch1 = new Cartesian3_default(); +var scratch2 = new Cartesian3_default(); +var scratch3 = new Cartesian3_default(); +var scratch4 = new Cartesian3_default(); +var scaleArray2 = [new Cartesian3_default(), new Cartesian3_default()]; +var cartesian1 = new Cartesian3_default(); +var cartesian2 = new Cartesian3_default(); +var cartesian3 = new Cartesian3_default(); +var cartesian4 = new Cartesian3_default(); +var cartesian5 = new Cartesian3_default(); +var cartesian6 = new Cartesian3_default(); +var cartesian7 = new Cartesian3_default(); +var cartesian8 = new Cartesian3_default(); +var cartesian9 = new Cartesian3_default(); +var cartesian10 = new Cartesian3_default(); +var quaterion = new Quaternion_default(); +var rotMatrix = new Matrix3_default(); +function computeRoundCorner(cornerPoint, startPoint, endPoint, cornerType, leftIsOutside) { + const angle = Cartesian3_default.angleBetween( + Cartesian3_default.subtract(startPoint, cornerPoint, scratch1), + Cartesian3_default.subtract(endPoint, cornerPoint, scratch2) + ); + const granularity = cornerType === CornerType_default.BEVELED ? 1 : Math.ceil(angle / Math_default.toRadians(5)) + 1; + const size = granularity * 3; + const array = new Array(size); + array[size - 3] = endPoint.x; + array[size - 2] = endPoint.y; + array[size - 1] = endPoint.z; + let m; + if (leftIsOutside) { + m = Matrix3_default.fromQuaternion( + Quaternion_default.fromAxisAngle( + Cartesian3_default.negate(cornerPoint, scratch1), + angle / granularity, + quaterion + ), + rotMatrix + ); + } else { + m = Matrix3_default.fromQuaternion( + Quaternion_default.fromAxisAngle(cornerPoint, angle / granularity, quaterion), + rotMatrix + ); + } + let index = 0; + startPoint = Cartesian3_default.clone(startPoint, scratch1); + for (let i = 0; i < granularity; i++) { + startPoint = Matrix3_default.multiplyByVector(m, startPoint, startPoint); + array[index++] = startPoint.x; + array[index++] = startPoint.y; + array[index++] = startPoint.z; + } + return array; +} +function addEndCaps(calculatedPositions) { + let cornerPoint = cartesian1; + let startPoint = cartesian2; + let endPoint = cartesian3; + let leftEdge = calculatedPositions[1]; + startPoint = Cartesian3_default.fromArray( + calculatedPositions[1], + leftEdge.length - 3, + startPoint + ); + endPoint = Cartesian3_default.fromArray(calculatedPositions[0], 0, endPoint); + cornerPoint = Cartesian3_default.midpoint(startPoint, endPoint, cornerPoint); + const firstEndCap = computeRoundCorner( + cornerPoint, + startPoint, + endPoint, + CornerType_default.ROUNDED, + false + ); + const length = calculatedPositions.length - 1; + const rightEdge = calculatedPositions[length - 1]; + leftEdge = calculatedPositions[length]; + startPoint = Cartesian3_default.fromArray( + rightEdge, + rightEdge.length - 3, + startPoint + ); + endPoint = Cartesian3_default.fromArray(leftEdge, 0, endPoint); + cornerPoint = Cartesian3_default.midpoint(startPoint, endPoint, cornerPoint); + const lastEndCap = computeRoundCorner( + cornerPoint, + startPoint, + endPoint, + CornerType_default.ROUNDED, + false + ); + return [firstEndCap, lastEndCap]; +} +function computeMiteredCorner(position, leftCornerDirection, lastPoint, leftIsOutside) { + let cornerPoint = scratch1; + if (leftIsOutside) { + cornerPoint = Cartesian3_default.add(position, leftCornerDirection, cornerPoint); + } else { + leftCornerDirection = Cartesian3_default.negate( + leftCornerDirection, + leftCornerDirection + ); + cornerPoint = Cartesian3_default.add(position, leftCornerDirection, cornerPoint); + } + return [ + cornerPoint.x, + cornerPoint.y, + cornerPoint.z, + lastPoint.x, + lastPoint.y, + lastPoint.z + ]; +} +function addShiftedPositions(positions, left, scalar, calculatedPositions) { + const rightPositions = new Array(positions.length); + const leftPositions = new Array(positions.length); + const scaledLeft = Cartesian3_default.multiplyByScalar(left, scalar, scratch1); + const scaledRight = Cartesian3_default.negate(scaledLeft, scratch2); + let rightIndex = 0; + let leftIndex = positions.length - 1; + for (let i = 0; i < positions.length; i += 3) { + const pos = Cartesian3_default.fromArray(positions, i, scratch3); + const rightPos = Cartesian3_default.add(pos, scaledRight, scratch4); + rightPositions[rightIndex++] = rightPos.x; + rightPositions[rightIndex++] = rightPos.y; + rightPositions[rightIndex++] = rightPos.z; + const leftPos = Cartesian3_default.add(pos, scaledLeft, scratch4); + leftPositions[leftIndex--] = leftPos.z; + leftPositions[leftIndex--] = leftPos.y; + leftPositions[leftIndex--] = leftPos.x; + } + calculatedPositions.push(rightPositions, leftPositions); + return calculatedPositions; +} +CorridorGeometryLibrary.addAttribute = function(attribute, value, front, back) { + const x = value.x; + const y = value.y; + const z = value.z; + if (defined_default(front)) { + attribute[front] = x; + attribute[front + 1] = y; + attribute[front + 2] = z; + } + if (defined_default(back)) { + attribute[back] = z; + attribute[back - 1] = y; + attribute[back - 2] = x; + } +}; +var scratchForwardProjection = new Cartesian3_default(); +var scratchBackwardProjection = new Cartesian3_default(); +CorridorGeometryLibrary.computePositions = function(params) { + const granularity = params.granularity; + const positions = params.positions; + const ellipsoid = params.ellipsoid; + const width = params.width / 2; + const cornerType = params.cornerType; + const saveAttributes = params.saveAttributes; + let normal = cartesian1; + let forward = cartesian2; + let backward = cartesian3; + let left = cartesian4; + let cornerDirection = cartesian5; + let startPoint = cartesian6; + let previousPos = cartesian7; + let rightPos = cartesian8; + let leftPos = cartesian9; + let center = cartesian10; + let calculatedPositions = []; + const calculatedLefts = saveAttributes ? [] : void 0; + const calculatedNormals = saveAttributes ? [] : void 0; + let position = positions[0]; + let nextPosition = positions[1]; + forward = Cartesian3_default.normalize( + Cartesian3_default.subtract(nextPosition, position, forward), + forward + ); + normal = ellipsoid.geodeticSurfaceNormal(position, normal); + left = Cartesian3_default.normalize(Cartesian3_default.cross(normal, forward, left), left); + if (saveAttributes) { + calculatedLefts.push(left.x, left.y, left.z); + calculatedNormals.push(normal.x, normal.y, normal.z); + } + previousPos = Cartesian3_default.clone(position, previousPos); + position = nextPosition; + backward = Cartesian3_default.negate(forward, backward); + let subdividedPositions; + const corners = []; + let i; + const length = positions.length; + for (i = 1; i < length - 1; i++) { + normal = ellipsoid.geodeticSurfaceNormal(position, normal); + nextPosition = positions[i + 1]; + forward = Cartesian3_default.normalize( + Cartesian3_default.subtract(nextPosition, position, forward), + forward + ); + cornerDirection = Cartesian3_default.normalize( + Cartesian3_default.add(forward, backward, cornerDirection), + cornerDirection + ); + const forwardProjection = Cartesian3_default.multiplyByScalar( + normal, + Cartesian3_default.dot(forward, normal), + scratchForwardProjection + ); + Cartesian3_default.subtract(forward, forwardProjection, forwardProjection); + Cartesian3_default.normalize(forwardProjection, forwardProjection); + const backwardProjection = Cartesian3_default.multiplyByScalar( + normal, + Cartesian3_default.dot(backward, normal), + scratchBackwardProjection + ); + Cartesian3_default.subtract(backward, backwardProjection, backwardProjection); + Cartesian3_default.normalize(backwardProjection, backwardProjection); + const doCorner = !Math_default.equalsEpsilon( + Math.abs(Cartesian3_default.dot(forwardProjection, backwardProjection)), + 1, + Math_default.EPSILON7 + ); + if (doCorner) { + cornerDirection = Cartesian3_default.cross( + cornerDirection, + normal, + cornerDirection + ); + cornerDirection = Cartesian3_default.cross( + normal, + cornerDirection, + cornerDirection + ); + cornerDirection = Cartesian3_default.normalize(cornerDirection, cornerDirection); + const scalar = width / Math.max( + 0.25, + Cartesian3_default.magnitude( + Cartesian3_default.cross(cornerDirection, backward, scratch1) + ) + ); + const leftIsOutside = PolylineVolumeGeometryLibrary_default.angleIsGreaterThanPi( + forward, + backward, + position, + ellipsoid + ); + cornerDirection = Cartesian3_default.multiplyByScalar( + cornerDirection, + scalar, + cornerDirection + ); + if (leftIsOutside) { + rightPos = Cartesian3_default.add(position, cornerDirection, rightPos); + center = Cartesian3_default.add( + rightPos, + Cartesian3_default.multiplyByScalar(left, width, center), + center + ); + leftPos = Cartesian3_default.add( + rightPos, + Cartesian3_default.multiplyByScalar(left, width * 2, leftPos), + leftPos + ); + scaleArray2[0] = Cartesian3_default.clone(previousPos, scaleArray2[0]); + scaleArray2[1] = Cartesian3_default.clone(center, scaleArray2[1]); + subdividedPositions = PolylinePipeline_default.generateArc({ + positions: scaleArray2, + granularity, + ellipsoid + }); + calculatedPositions = addShiftedPositions( + subdividedPositions, + left, + width, + calculatedPositions + ); + if (saveAttributes) { + calculatedLefts.push(left.x, left.y, left.z); + calculatedNormals.push(normal.x, normal.y, normal.z); + } + startPoint = Cartesian3_default.clone(leftPos, startPoint); + left = Cartesian3_default.normalize( + Cartesian3_default.cross(normal, forward, left), + left + ); + leftPos = Cartesian3_default.add( + rightPos, + Cartesian3_default.multiplyByScalar(left, width * 2, leftPos), + leftPos + ); + previousPos = Cartesian3_default.add( + rightPos, + Cartesian3_default.multiplyByScalar(left, width, previousPos), + previousPos + ); + if (cornerType === CornerType_default.ROUNDED || cornerType === CornerType_default.BEVELED) { + corners.push({ + leftPositions: computeRoundCorner( + rightPos, + startPoint, + leftPos, + cornerType, + leftIsOutside + ) + }); + } else { + corners.push({ + leftPositions: computeMiteredCorner( + position, + Cartesian3_default.negate(cornerDirection, cornerDirection), + leftPos, + leftIsOutside + ) + }); + } + } else { + leftPos = Cartesian3_default.add(position, cornerDirection, leftPos); + center = Cartesian3_default.add( + leftPos, + Cartesian3_default.negate( + Cartesian3_default.multiplyByScalar(left, width, center), + center + ), + center + ); + rightPos = Cartesian3_default.add( + leftPos, + Cartesian3_default.negate( + Cartesian3_default.multiplyByScalar(left, width * 2, rightPos), + rightPos + ), + rightPos + ); + scaleArray2[0] = Cartesian3_default.clone(previousPos, scaleArray2[0]); + scaleArray2[1] = Cartesian3_default.clone(center, scaleArray2[1]); + subdividedPositions = PolylinePipeline_default.generateArc({ + positions: scaleArray2, + granularity, + ellipsoid + }); + calculatedPositions = addShiftedPositions( + subdividedPositions, + left, + width, + calculatedPositions + ); + if (saveAttributes) { + calculatedLefts.push(left.x, left.y, left.z); + calculatedNormals.push(normal.x, normal.y, normal.z); + } + startPoint = Cartesian3_default.clone(rightPos, startPoint); + left = Cartesian3_default.normalize( + Cartesian3_default.cross(normal, forward, left), + left + ); + rightPos = Cartesian3_default.add( + leftPos, + Cartesian3_default.negate( + Cartesian3_default.multiplyByScalar(left, width * 2, rightPos), + rightPos + ), + rightPos + ); + previousPos = Cartesian3_default.add( + leftPos, + Cartesian3_default.negate( + Cartesian3_default.multiplyByScalar(left, width, previousPos), + previousPos + ), + previousPos + ); + if (cornerType === CornerType_default.ROUNDED || cornerType === CornerType_default.BEVELED) { + corners.push({ + rightPositions: computeRoundCorner( + leftPos, + startPoint, + rightPos, + cornerType, + leftIsOutside + ) + }); + } else { + corners.push({ + rightPositions: computeMiteredCorner( + position, + cornerDirection, + rightPos, + leftIsOutside + ) + }); + } + } + backward = Cartesian3_default.negate(forward, backward); + } + position = nextPosition; + } + normal = ellipsoid.geodeticSurfaceNormal(position, normal); + scaleArray2[0] = Cartesian3_default.clone(previousPos, scaleArray2[0]); + scaleArray2[1] = Cartesian3_default.clone(position, scaleArray2[1]); + subdividedPositions = PolylinePipeline_default.generateArc({ + positions: scaleArray2, + granularity, + ellipsoid + }); + calculatedPositions = addShiftedPositions( + subdividedPositions, + left, + width, + calculatedPositions + ); + if (saveAttributes) { + calculatedLefts.push(left.x, left.y, left.z); + calculatedNormals.push(normal.x, normal.y, normal.z); + } + let endPositions; + if (cornerType === CornerType_default.ROUNDED) { + endPositions = addEndCaps(calculatedPositions); + } + return { + positions: calculatedPositions, + corners, + lefts: calculatedLefts, + normals: calculatedNormals, + endPositions + }; +}; +var CorridorGeometryLibrary_default = CorridorGeometryLibrary; + +export { + CorridorGeometryLibrary_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-DJUTBX6A.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-DJUTBX6A.js new file mode 100644 index 0000000000000000000000000000000000000000..73340584342eaceb3f956c317cd53cb59bcb6db0 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-DJUTBX6A.js @@ -0,0 +1,1860 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + __commonJS, + __require +} from "./chunk-QVJ6IRKV.js"; + +// node_modules/draco3d/draco_decoder_nodejs.js +var require_draco_decoder_nodejs = __commonJS({ + "node_modules/draco3d/draco_decoder_nodejs.js"(exports, module) { + var $jscomp = $jscomp || {}; + $jscomp.scope = {}; + $jscomp.arrayIteratorImpl = function(k) { + var n = 0; + return function() { + return n < k.length ? { done: false, value: k[n++] } : { done: true }; + }; + }; + $jscomp.arrayIterator = function(k) { + return { next: $jscomp.arrayIteratorImpl(k) }; + }; + $jscomp.makeIterator = function(k) { + var n = "undefined" != typeof Symbol && Symbol.iterator && k[Symbol.iterator]; + return n ? n.call(k) : $jscomp.arrayIterator(k); + }; + $jscomp.ASSUME_ES5 = false; + $jscomp.ASSUME_NO_NATIVE_MAP = false; + $jscomp.ASSUME_NO_NATIVE_SET = false; + $jscomp.SIMPLE_FROUND_POLYFILL = false; + $jscomp.ISOLATE_POLYFILLS = false; + $jscomp.FORCE_POLYFILL_PROMISE = false; + $jscomp.FORCE_POLYFILL_PROMISE_WHEN_NO_UNHANDLED_REJECTION = false; + $jscomp.getGlobal = function(k) { + k = ["object" == typeof globalThis && globalThis, k, "object" == typeof window && window, "object" == typeof self && self, "object" == typeof global && global]; + for (var n = 0; n < k.length; ++n) { + var l = k[n]; + if (l && l.Math == Math) + return l; + } + throw Error("Cannot find global object"); + }; + $jscomp.global = $jscomp.getGlobal(exports); + $jscomp.defineProperty = $jscomp.ASSUME_ES5 || "function" == typeof Object.defineProperties ? Object.defineProperty : function(k, n, l) { + if (k == Array.prototype || k == Object.prototype) + return k; + k[n] = l.value; + return k; + }; + $jscomp.IS_SYMBOL_NATIVE = "function" === typeof Symbol && "symbol" === typeof Symbol("x"); + $jscomp.TRUST_ES6_POLYFILLS = !$jscomp.ISOLATE_POLYFILLS || $jscomp.IS_SYMBOL_NATIVE; + $jscomp.polyfills = {}; + $jscomp.propertyToPolyfillSymbol = {}; + $jscomp.POLYFILL_PREFIX = "$jscp$"; + $jscomp.polyfill = function(k, n, l, p) { + n && ($jscomp.ISOLATE_POLYFILLS ? $jscomp.polyfillIsolated(k, n, l, p) : $jscomp.polyfillUnisolated(k, n, l, p)); + }; + $jscomp.polyfillUnisolated = function(k, n, l, p) { + l = $jscomp.global; + k = k.split("."); + for (p = 0; p < k.length - 1; p++) { + var h = k[p]; + if (!(h in l)) + return; + l = l[h]; + } + k = k[k.length - 1]; + p = l[k]; + n = n(p); + n != p && null != n && $jscomp.defineProperty(l, k, { configurable: true, writable: true, value: n }); + }; + $jscomp.polyfillIsolated = function(k, n, l, p) { + var h = k.split("."); + k = 1 === h.length; + p = h[0]; + p = !k && p in $jscomp.polyfills ? $jscomp.polyfills : $jscomp.global; + for (var A = 0; A < h.length - 1; A++) { + var f = h[A]; + if (!(f in p)) + return; + p = p[f]; + } + h = h[h.length - 1]; + l = $jscomp.IS_SYMBOL_NATIVE && "es6" === l ? p[h] : null; + n = n(l); + null != n && (k ? $jscomp.defineProperty($jscomp.polyfills, h, { configurable: true, writable: true, value: n }) : n !== l && (void 0 === $jscomp.propertyToPolyfillSymbol[h] && (l = 1e9 * Math.random() >>> 0, $jscomp.propertyToPolyfillSymbol[h] = $jscomp.IS_SYMBOL_NATIVE ? $jscomp.global.Symbol(h) : $jscomp.POLYFILL_PREFIX + l + "$" + h), $jscomp.defineProperty(p, $jscomp.propertyToPolyfillSymbol[h], { configurable: true, writable: true, value: n }))); + }; + $jscomp.polyfill("Promise", function(k) { + function n() { + this.batch_ = null; + } + function l(f) { + return f instanceof h ? f : new h(function(q, v) { + q(f); + }); + } + if (k && (!($jscomp.FORCE_POLYFILL_PROMISE || $jscomp.FORCE_POLYFILL_PROMISE_WHEN_NO_UNHANDLED_REJECTION && "undefined" === typeof $jscomp.global.PromiseRejectionEvent) || !$jscomp.global.Promise || -1 === $jscomp.global.Promise.toString().indexOf("[native code]"))) + return k; + n.prototype.asyncExecute = function(f) { + if (null == this.batch_) { + this.batch_ = []; + var q = this; + this.asyncExecuteFunction(function() { + q.executeBatch_(); + }); + } + this.batch_.push(f); + }; + var p = $jscomp.global.setTimeout; + n.prototype.asyncExecuteFunction = function(f) { + p(f, 0); + }; + n.prototype.executeBatch_ = function() { + for (; this.batch_ && this.batch_.length; ) { + var f = this.batch_; + this.batch_ = []; + for (var q = 0; q < f.length; ++q) { + var v = f[q]; + f[q] = null; + try { + v(); + } catch (z) { + this.asyncThrow_(z); + } + } + } + this.batch_ = null; + }; + n.prototype.asyncThrow_ = function(f) { + this.asyncExecuteFunction(function() { + throw f; + }); + }; + var h = function(f) { + this.state_ = 0; + this.result_ = void 0; + this.onSettledCallbacks_ = []; + this.isRejectionHandled_ = false; + var q = this.createResolveAndReject_(); + try { + f(q.resolve, q.reject); + } catch (v) { + q.reject(v); + } + }; + h.prototype.createResolveAndReject_ = function() { + function f(z) { + return function(O) { + v || (v = true, z.call(q, O)); + }; + } + var q = this, v = false; + return { resolve: f(this.resolveTo_), reject: f(this.reject_) }; + }; + h.prototype.resolveTo_ = function(f) { + if (f === this) + this.reject_(new TypeError("A Promise cannot resolve to itself")); + else if (f instanceof h) + this.settleSameAsPromise_(f); + else { + a: + switch (typeof f) { + case "object": + var q = null != f; + break a; + case "function": + q = true; + break a; + default: + q = false; + } + q ? this.resolveToNonPromiseObj_(f) : this.fulfill_(f); + } + }; + h.prototype.resolveToNonPromiseObj_ = function(f) { + var q = void 0; + try { + q = f.then; + } catch (v) { + this.reject_(v); + return; + } + "function" == typeof q ? this.settleSameAsThenable_(q, f) : this.fulfill_(f); + }; + h.prototype.reject_ = function(f) { + this.settle_(2, f); + }; + h.prototype.fulfill_ = function(f) { + this.settle_(1, f); + }; + h.prototype.settle_ = function(f, q) { + if (0 != this.state_) + throw Error("Cannot settle(" + f + ", " + q + "): Promise already settled in state" + this.state_); + this.state_ = f; + this.result_ = q; + 2 === this.state_ && this.scheduleUnhandledRejectionCheck_(); + this.executeOnSettledCallbacks_(); + }; + h.prototype.scheduleUnhandledRejectionCheck_ = function() { + var f = this; + p(function() { + if (f.notifyUnhandledRejection_()) { + var q = $jscomp.global.console; + "undefined" !== typeof q && q.error(f.result_); + } + }, 1); + }; + h.prototype.notifyUnhandledRejection_ = function() { + if (this.isRejectionHandled_) + return false; + var f = $jscomp.global.CustomEvent, q = $jscomp.global.Event, v = $jscomp.global.dispatchEvent; + if ("undefined" === typeof v) + return true; + "function" === typeof f ? f = new f("unhandledrejection", { cancelable: true }) : "function" === typeof q ? f = new q("unhandledrejection", { cancelable: true }) : (f = $jscomp.global.document.createEvent("CustomEvent"), f.initCustomEvent("unhandledrejection", false, true, f)); + f.promise = this; + f.reason = this.result_; + return v(f); + }; + h.prototype.executeOnSettledCallbacks_ = function() { + if (null != this.onSettledCallbacks_) { + for (var f = 0; f < this.onSettledCallbacks_.length; ++f) + A.asyncExecute(this.onSettledCallbacks_[f]); + this.onSettledCallbacks_ = null; + } + }; + var A = new n(); + h.prototype.settleSameAsPromise_ = function(f) { + var q = this.createResolveAndReject_(); + f.callWhenSettled_(q.resolve, q.reject); + }; + h.prototype.settleSameAsThenable_ = function(f, q) { + var v = this.createResolveAndReject_(); + try { + f.call(q, v.resolve, v.reject); + } catch (z) { + v.reject(z); + } + }; + h.prototype.then = function(f, q) { + function v(t, x) { + return "function" == typeof t ? function(D) { + try { + z(t(D)); + } catch (R) { + O(R); + } + } : x; + } + var z, O, ba = new h(function(t, x) { + z = t; + O = x; + }); + this.callWhenSettled_(v(f, z), v(q, O)); + return ba; + }; + h.prototype.catch = function(f) { + return this.then(void 0, f); + }; + h.prototype.callWhenSettled_ = function(f, q) { + function v() { + switch (z.state_) { + case 1: + f(z.result_); + break; + case 2: + q(z.result_); + break; + default: + throw Error("Unexpected state: " + z.state_); + } + } + var z = this; + null == this.onSettledCallbacks_ ? A.asyncExecute(v) : this.onSettledCallbacks_.push(v); + this.isRejectionHandled_ = true; + }; + h.resolve = l; + h.reject = function(f) { + return new h(function(q, v) { + v(f); + }); + }; + h.race = function(f) { + return new h(function(q, v) { + for (var z = $jscomp.makeIterator(f), O = z.next(); !O.done; O = z.next()) + l(O.value).callWhenSettled_(q, v); + }); + }; + h.all = function(f) { + var q = $jscomp.makeIterator(f), v = q.next(); + return v.done ? l([]) : new h(function(z, O) { + function ba(D) { + return function(R) { + t[D] = R; + x--; + 0 == x && z(t); + }; + } + var t = [], x = 0; + do + t.push(void 0), x++, l(v.value).callWhenSettled_(ba(t.length - 1), O), v = q.next(); + while (!v.done); + }); + }; + return h; + }, "es6", "es3"); + $jscomp.owns = function(k, n) { + return Object.prototype.hasOwnProperty.call(k, n); + }; + $jscomp.assign = $jscomp.TRUST_ES6_POLYFILLS && "function" == typeof Object.assign ? Object.assign : function(k, n) { + for (var l = 1; l < arguments.length; l++) { + var p = arguments[l]; + if (p) + for (var h in p) + $jscomp.owns(p, h) && (k[h] = p[h]); + } + return k; + }; + $jscomp.polyfill("Object.assign", function(k) { + return k || $jscomp.assign; + }, "es6", "es3"); + $jscomp.checkStringArgs = function(k, n, l) { + if (null == k) + throw new TypeError("The 'this' value for String.prototype." + l + " must not be null or undefined"); + if (n instanceof RegExp) + throw new TypeError("First argument to String.prototype." + l + " must not be a regular expression"); + return k + ""; + }; + $jscomp.polyfill("String.prototype.startsWith", function(k) { + return k ? k : function(n, l) { + var p = $jscomp.checkStringArgs(this, n, "startsWith"); + n += ""; + var h = p.length, A = n.length; + l = Math.max(0, Math.min(l | 0, p.length)); + for (var f = 0; f < A && l < h; ) + if (p[l++] != n[f++]) + return false; + return f >= A; + }; + }, "es6", "es3"); + $jscomp.polyfill("Array.prototype.copyWithin", function(k) { + function n(l) { + l = Number(l); + return Infinity === l || -Infinity === l ? l : l | 0; + } + return k ? k : function(l, p, h) { + var A = this.length; + l = n(l); + p = n(p); + h = void 0 === h ? A : n(h); + l = 0 > l ? Math.max(A + l, 0) : Math.min(l, A); + p = 0 > p ? Math.max(A + p, 0) : Math.min(p, A); + h = 0 > h ? Math.max(A + h, 0) : Math.min(h, A); + if (l < p) + for (; p < h; ) + p in this ? this[l++] = this[p++] : (delete this[l++], p++); + else + for (h = Math.min(h, A + p - l), l += h - p; h > p; ) + --h in this ? this[--l] = this[h] : delete this[--l]; + return this; + }; + }, "es6", "es3"); + $jscomp.typedArrayCopyWithin = function(k) { + return k ? k : Array.prototype.copyWithin; + }; + $jscomp.polyfill("Int8Array.prototype.copyWithin", $jscomp.typedArrayCopyWithin, "es6", "es5"); + $jscomp.polyfill("Uint8Array.prototype.copyWithin", $jscomp.typedArrayCopyWithin, "es6", "es5"); + $jscomp.polyfill("Uint8ClampedArray.prototype.copyWithin", $jscomp.typedArrayCopyWithin, "es6", "es5"); + $jscomp.polyfill("Int16Array.prototype.copyWithin", $jscomp.typedArrayCopyWithin, "es6", "es5"); + $jscomp.polyfill("Uint16Array.prototype.copyWithin", $jscomp.typedArrayCopyWithin, "es6", "es5"); + $jscomp.polyfill("Int32Array.prototype.copyWithin", $jscomp.typedArrayCopyWithin, "es6", "es5"); + $jscomp.polyfill("Uint32Array.prototype.copyWithin", $jscomp.typedArrayCopyWithin, "es6", "es5"); + $jscomp.polyfill("Float32Array.prototype.copyWithin", $jscomp.typedArrayCopyWithin, "es6", "es5"); + $jscomp.polyfill("Float64Array.prototype.copyWithin", $jscomp.typedArrayCopyWithin, "es6", "es5"); + var DracoDecoderModule = function() { + var k = "undefined" !== typeof document && document.currentScript ? document.currentScript.src : void 0; + "undefined" !== typeof __filename && (k = k || __filename); + return function(n) { + function l(e) { + return a.locateFile ? a.locateFile(e, U) : U + e; + } + function p(e, b, c) { + var d = b + c; + for (c = b; e[c] && !(c >= d); ) + ++c; + if (16 < c - b && e.buffer && va) + return va.decode(e.subarray(b, c)); + for (d = ""; b < c; ) { + var g = e[b++]; + if (g & 128) { + var u = e[b++] & 63; + if (192 == (g & 224)) + d += String.fromCharCode((g & 31) << 6 | u); + else { + var X = e[b++] & 63; + g = 224 == (g & 240) ? (g & 15) << 12 | u << 6 | X : (g & 7) << 18 | u << 12 | X << 6 | e[b++] & 63; + 65536 > g ? d += String.fromCharCode(g) : (g -= 65536, d += String.fromCharCode(55296 | g >> 10, 56320 | g & 1023)); + } + } else + d += String.fromCharCode(g); + } + return d; + } + function h(e, b) { + return e ? p(ea, e, b) : ""; + } + function A() { + var e = ja.buffer; + a.HEAP8 = Y = new Int8Array(e); + a.HEAP16 = new Int16Array(e); + a.HEAP32 = ca = new Int32Array(e); + a.HEAPU8 = ea = new Uint8Array(e); + a.HEAPU16 = new Uint16Array(e); + a.HEAPU32 = V = new Uint32Array(e); + a.HEAPF32 = new Float32Array(e); + a.HEAPF64 = new Float64Array(e); + } + function f(e) { + if (a.onAbort) + a.onAbort(e); + e = "Aborted(" + e + ")"; + da(e); + wa = true; + e = new WebAssembly.RuntimeError(e + ". Build with -sASSERTIONS for more info."); + ka(e); + throw e; + } + function q(e) { + try { + if (e == P && fa) + return new Uint8Array(fa); + if (ma) + return ma(e); + throw "both async and sync fetching of the wasm failed"; + } catch (b) { + f(b); + } + } + function v() { + if (!fa && (xa || ha)) { + if ("function" == typeof fetch && !P.startsWith("file://")) + return fetch(P, { credentials: "same-origin" }).then(function(e) { + if (!e.ok) + throw "failed to load wasm binary file at '" + P + "'"; + return e.arrayBuffer(); + }).catch(function() { + return q(P); + }); + if (na) + return new Promise(function(e, b) { + na(P, function(c) { + e(new Uint8Array(c)); + }, b); + }); + } + return Promise.resolve().then(function() { + return q(P); + }); + } + function z(e) { + for (; 0 < e.length; ) + e.shift()(a); + } + function O(e) { + this.excPtr = e; + this.ptr = e - 24; + this.set_type = function(b) { + V[this.ptr + 4 >> 2] = b; + }; + this.get_type = function() { + return V[this.ptr + 4 >> 2]; + }; + this.set_destructor = function(b) { + V[this.ptr + 8 >> 2] = b; + }; + this.get_destructor = function() { + return V[this.ptr + 8 >> 2]; + }; + this.set_refcount = function(b) { + ca[this.ptr >> 2] = b; + }; + this.set_caught = function(b) { + Y[this.ptr + 12 >> 0] = b ? 1 : 0; + }; + this.get_caught = function() { + return 0 != Y[this.ptr + 12 >> 0]; + }; + this.set_rethrown = function(b) { + Y[this.ptr + 13 >> 0] = b ? 1 : 0; + }; + this.get_rethrown = function() { + return 0 != Y[this.ptr + 13 >> 0]; + }; + this.init = function(b, c) { + this.set_adjusted_ptr(0); + this.set_type(b); + this.set_destructor(c); + this.set_refcount(0); + this.set_caught(false); + this.set_rethrown(false); + }; + this.add_ref = function() { + ca[this.ptr >> 2] += 1; + }; + this.release_ref = function() { + var b = ca[this.ptr >> 2]; + ca[this.ptr >> 2] = b - 1; + return 1 === b; + }; + this.set_adjusted_ptr = function(b) { + V[this.ptr + 16 >> 2] = b; + }; + this.get_adjusted_ptr = function() { + return V[this.ptr + 16 >> 2]; + }; + this.get_exception_ptr = function() { + if (ya(this.get_type())) + return V[this.excPtr >> 2]; + var b = this.get_adjusted_ptr(); + return 0 !== b ? b : this.excPtr; + }; + } + function ba() { + function e() { + if (!la && (la = true, a.calledRun = true, !wa)) { + za = true; + z(oa); + Aa(a); + if (a.onRuntimeInitialized) + a.onRuntimeInitialized(); + if (a.postRun) + for ("function" == typeof a.postRun && (a.postRun = [a.postRun]); a.postRun.length; ) + Ba.unshift(a.postRun.shift()); + z(Ba); + } + } + if (!(0 < aa)) { + if (a.preRun) + for ("function" == typeof a.preRun && (a.preRun = [a.preRun]); a.preRun.length; ) + Ca.unshift(a.preRun.shift()); + z(Ca); + 0 < aa || (a.setStatus ? (a.setStatus("Running..."), setTimeout(function() { + setTimeout(function() { + a.setStatus(""); + }, 1); + e(); + }, 1)) : e()); + } + } + function t() { + } + function x(e) { + return (e || t).__cache__; + } + function D(e, b) { + var c = x(b), d = c[e]; + if (d) + return d; + d = Object.create((b || t).prototype); + d.ptr = e; + return c[e] = d; + } + function R(e) { + if ("string" === typeof e) { + for (var b = 0, c = 0; c < e.length; ++c) { + var d = e.charCodeAt(c); + 127 >= d ? b++ : 2047 >= d ? b += 2 : 55296 <= d && 57343 >= d ? (b += 4, ++c) : b += 3; + } + b = Array(b + 1); + c = 0; + d = b.length; + if (0 < d) { + d = c + d - 1; + for (var g = 0; g < e.length; ++g) { + var u = e.charCodeAt(g); + if (55296 <= u && 57343 >= u) { + var X = e.charCodeAt(++g); + u = 65536 + ((u & 1023) << 10) | X & 1023; + } + if (127 >= u) { + if (c >= d) + break; + b[c++] = u; + } else { + if (2047 >= u) { + if (c + 1 >= d) + break; + b[c++] = 192 | u >> 6; + } else { + if (65535 >= u) { + if (c + 2 >= d) + break; + b[c++] = 224 | u >> 12; + } else { + if (c + 3 >= d) + break; + b[c++] = 240 | u >> 18; + b[c++] = 128 | u >> 12 & 63; + } + b[c++] = 128 | u >> 6 & 63; + } + b[c++] = 128 | u & 63; + } + } + b[c] = 0; + } + e = r.alloc(b, Y); + r.copy(b, Y, e); + return e; + } + return e; + } + function pa(e) { + if ("object" === typeof e) { + var b = r.alloc(e, Y); + r.copy(e, Y, b); + return b; + } + return e; + } + function Z() { + throw "cannot construct a VoidPtr, no constructor in IDL"; + } + function S() { + this.ptr = Da(); + x(S)[this.ptr] = this; + } + function Q() { + this.ptr = Ea(); + x(Q)[this.ptr] = this; + } + function W() { + this.ptr = Fa(); + x(W)[this.ptr] = this; + } + function w() { + this.ptr = Ga(); + x(w)[this.ptr] = this; + } + function C() { + this.ptr = Ha(); + x(C)[this.ptr] = this; + } + function F() { + this.ptr = Ia(); + x(F)[this.ptr] = this; + } + function G() { + this.ptr = Ja(); + x(G)[this.ptr] = this; + } + function E() { + this.ptr = Ka(); + x(E)[this.ptr] = this; + } + function T() { + this.ptr = La(); + x(T)[this.ptr] = this; + } + function B() { + throw "cannot construct a Status, no constructor in IDL"; + } + function H() { + this.ptr = Ma(); + x(H)[this.ptr] = this; + } + function I() { + this.ptr = Na(); + x(I)[this.ptr] = this; + } + function J() { + this.ptr = Oa(); + x(J)[this.ptr] = this; + } + function K() { + this.ptr = Pa(); + x(K)[this.ptr] = this; + } + function L() { + this.ptr = Qa(); + x(L)[this.ptr] = this; + } + function M() { + this.ptr = Ra(); + x(M)[this.ptr] = this; + } + function N() { + this.ptr = Sa(); + x(N)[this.ptr] = this; + } + function y() { + this.ptr = Ta(); + x(y)[this.ptr] = this; + } + function m() { + this.ptr = Ua(); + x(m)[this.ptr] = this; + } + n = void 0 === n ? {} : n; + var a = "undefined" != typeof n ? n : {}, Aa, ka; + a.ready = new Promise(function(e, b) { + Aa = e; + ka = b; + }); + var Va = false, Wa = false; + a.onRuntimeInitialized = function() { + Va = true; + if (Wa && "function" === typeof a.onModuleLoaded) + a.onModuleLoaded(a); + }; + a.onModuleParsed = function() { + Wa = true; + if (Va && "function" === typeof a.onModuleLoaded) + a.onModuleLoaded(a); + }; + a.isVersionSupported = function(e) { + if ("string" !== typeof e) + return false; + e = e.split("."); + return 2 > e.length || 3 < e.length ? false : 1 == e[0] && 0 <= e[1] && 5 >= e[1] ? true : 0 != e[0] || 10 < e[1] ? false : true; + }; + var Xa = Object.assign({}, a), xa = "object" == typeof window, ha = "function" == typeof importScripts, Ya = "object" == typeof process && "object" == typeof process.versions && "string" == typeof process.versions.node, U = ""; + if (Ya) { + var Za = __require("fs"), qa = __require("path"); + U = ha ? qa.dirname(U) + "/" : __dirname + "/"; + var $a = function(e, b) { + e = e.startsWith("file://") ? new URL(e) : qa.normalize(e); + return Za.readFileSync(e, b ? void 0 : "utf8"); + }; + var ma = function(e) { + e = $a(e, true); + e.buffer || (e = new Uint8Array(e)); + return e; + }; + var na = function(e, b, c) { + e = e.startsWith("file://") ? new URL(e) : qa.normalize(e); + Za.readFile(e, function(d, g) { + d ? c(d) : b(g.buffer); + }); + }; + 1 < process.argv.length && process.argv[1].replace(/\\/g, "/"); + process.argv.slice(2); + a.inspect = function() { + return "[Emscripten Module object]"; + }; + } else if (xa || ha) + ha ? U = self.location.href : "undefined" != typeof document && document.currentScript && (U = document.currentScript.src), k && (U = k), U = 0 !== U.indexOf("blob:") ? U.substr(0, U.replace(/[?#].*/, "").lastIndexOf("/") + 1) : "", $a = function(e) { + var b = new XMLHttpRequest(); + b.open("GET", e, false); + b.send(null); + return b.responseText; + }, ha && (ma = function(e) { + var b = new XMLHttpRequest(); + b.open("GET", e, false); + b.responseType = "arraybuffer"; + b.send(null); + return new Uint8Array(b.response); + }), na = function(e, b, c) { + var d = new XMLHttpRequest(); + d.open("GET", e, true); + d.responseType = "arraybuffer"; + d.onload = function() { + 200 == d.status || 0 == d.status && d.response ? b(d.response) : c(); + }; + d.onerror = c; + d.send(null); + }; + var ud = a.print || console.log.bind(console), da = a.printErr || console.warn.bind(console); + Object.assign(a, Xa); + Xa = null; + var fa; + a.wasmBinary && (fa = a.wasmBinary); + "object" != typeof WebAssembly && f("no native wasm support detected"); + var ja, wa = false, va = "undefined" != typeof TextDecoder ? new TextDecoder("utf8") : void 0, Y, ea, ca, V, Ca = [], oa = [], Ba = [], za = false, aa = 0, ra = null, ia = null; + var P = "draco_decoder.wasm"; + P.startsWith("data:application/octet-stream;base64,") || (P = l(P)); + var vd = 0, wd = [null, [], []], xd = { b: function(e, b, c) { + new O(e).init(b, c); + vd++; + throw e; + }, a: function() { + f(""); + }, g: function(e, b, c) { + ea.copyWithin(e, b, b + c); + }, e: function(e) { + var b = ea.length; + e >>>= 0; + if (2147483648 < e) + return false; + for (var c = 1; 4 >= c; c *= 2) { + var d = b * (1 + 0.2 / c); + d = Math.min(d, e + 100663296); + var g = Math; + d = Math.max(e, d); + g = g.min.call(g, 2147483648, d + (65536 - d % 65536) % 65536); + a: { + d = ja.buffer; + try { + ja.grow(g - d.byteLength + 65535 >>> 16); + A(); + var u = 1; + break a; + } catch (X) { + } + u = void 0; + } + if (u) + return true; + } + return false; + }, f: function(e) { + return 52; + }, d: function(e, b, c, d, g) { + return 70; + }, c: function(e, b, c, d) { + for (var g = 0, u = 0; u < c; u++) { + var X = V[b >> 2], ab = V[b + 4 >> 2]; + b += 8; + for (var sa = 0; sa < ab; sa++) { + var ta = ea[X + sa], ua = wd[e]; + 0 === ta || 10 === ta ? ((1 === e ? ud : da)(p(ua, 0)), ua.length = 0) : ua.push(ta); + } + g += ab; + } + V[d >> 2] = g; + return 0; + } }; + (function() { + function e(g, u) { + a.asm = g.exports; + ja = a.asm.h; + A(); + oa.unshift(a.asm.i); + aa--; + a.monitorRunDependencies && a.monitorRunDependencies(aa); + 0 == aa && (null !== ra && (clearInterval(ra), ra = null), ia && (g = ia, ia = null, g())); + } + function b(g) { + e(g.instance); + } + function c(g) { + return v().then(function(u) { + return WebAssembly.instantiate(u, d); + }).then(function(u) { + return u; + }).then(g, function(u) { + da("failed to asynchronously prepare wasm: " + u); + f(u); + }); + } + var d = { a: xd }; + aa++; + a.monitorRunDependencies && a.monitorRunDependencies(aa); + if (a.instantiateWasm) + try { + return a.instantiateWasm(d, e); + } catch (g) { + da("Module.instantiateWasm callback failed with error: " + g), ka(g); + } + (function() { + return fa || "function" != typeof WebAssembly.instantiateStreaming || P.startsWith("data:application/octet-stream;base64,") || P.startsWith("file://") || Ya || "function" != typeof fetch ? c(b) : fetch(P, { credentials: "same-origin" }).then(function(g) { + return WebAssembly.instantiateStreaming(g, d).then(b, function(u) { + da("wasm streaming compile failed: " + u); + da("falling back to ArrayBuffer instantiation"); + return c(b); + }); + }); + })().catch(ka); + return {}; + })(); + var bb = a._emscripten_bind_VoidPtr___destroy___0 = function() { + return (bb = a._emscripten_bind_VoidPtr___destroy___0 = a.asm.k).apply(null, arguments); + }, Da = a._emscripten_bind_DecoderBuffer_DecoderBuffer_0 = function() { + return (Da = a._emscripten_bind_DecoderBuffer_DecoderBuffer_0 = a.asm.l).apply(null, arguments); + }, cb = a._emscripten_bind_DecoderBuffer_Init_2 = function() { + return (cb = a._emscripten_bind_DecoderBuffer_Init_2 = a.asm.m).apply(null, arguments); + }, db = a._emscripten_bind_DecoderBuffer___destroy___0 = function() { + return (db = a._emscripten_bind_DecoderBuffer___destroy___0 = a.asm.n).apply(null, arguments); + }, Ea = a._emscripten_bind_AttributeTransformData_AttributeTransformData_0 = function() { + return (Ea = a._emscripten_bind_AttributeTransformData_AttributeTransformData_0 = a.asm.o).apply(null, arguments); + }, eb = a._emscripten_bind_AttributeTransformData_transform_type_0 = function() { + return (eb = a._emscripten_bind_AttributeTransformData_transform_type_0 = a.asm.p).apply(null, arguments); + }, fb = a._emscripten_bind_AttributeTransformData___destroy___0 = function() { + return (fb = a._emscripten_bind_AttributeTransformData___destroy___0 = a.asm.q).apply(null, arguments); + }, Fa = a._emscripten_bind_GeometryAttribute_GeometryAttribute_0 = function() { + return (Fa = a._emscripten_bind_GeometryAttribute_GeometryAttribute_0 = a.asm.r).apply(null, arguments); + }, gb = a._emscripten_bind_GeometryAttribute___destroy___0 = function() { + return (gb = a._emscripten_bind_GeometryAttribute___destroy___0 = a.asm.s).apply(null, arguments); + }, Ga = a._emscripten_bind_PointAttribute_PointAttribute_0 = function() { + return (Ga = a._emscripten_bind_PointAttribute_PointAttribute_0 = a.asm.t).apply(null, arguments); + }, hb = a._emscripten_bind_PointAttribute_size_0 = function() { + return (hb = a._emscripten_bind_PointAttribute_size_0 = a.asm.u).apply(null, arguments); + }, ib = a._emscripten_bind_PointAttribute_GetAttributeTransformData_0 = function() { + return (ib = a._emscripten_bind_PointAttribute_GetAttributeTransformData_0 = a.asm.v).apply(null, arguments); + }, jb = a._emscripten_bind_PointAttribute_attribute_type_0 = function() { + return (jb = a._emscripten_bind_PointAttribute_attribute_type_0 = a.asm.w).apply(null, arguments); + }, kb = a._emscripten_bind_PointAttribute_data_type_0 = function() { + return (kb = a._emscripten_bind_PointAttribute_data_type_0 = a.asm.x).apply(null, arguments); + }, lb = a._emscripten_bind_PointAttribute_num_components_0 = function() { + return (lb = a._emscripten_bind_PointAttribute_num_components_0 = a.asm.y).apply(null, arguments); + }, mb = a._emscripten_bind_PointAttribute_normalized_0 = function() { + return (mb = a._emscripten_bind_PointAttribute_normalized_0 = a.asm.z).apply(null, arguments); + }, nb = a._emscripten_bind_PointAttribute_byte_stride_0 = function() { + return (nb = a._emscripten_bind_PointAttribute_byte_stride_0 = a.asm.A).apply(null, arguments); + }, ob = a._emscripten_bind_PointAttribute_byte_offset_0 = function() { + return (ob = a._emscripten_bind_PointAttribute_byte_offset_0 = a.asm.B).apply(null, arguments); + }, pb = a._emscripten_bind_PointAttribute_unique_id_0 = function() { + return (pb = a._emscripten_bind_PointAttribute_unique_id_0 = a.asm.C).apply(null, arguments); + }, qb = a._emscripten_bind_PointAttribute___destroy___0 = function() { + return (qb = a._emscripten_bind_PointAttribute___destroy___0 = a.asm.D).apply(null, arguments); + }, Ha = a._emscripten_bind_AttributeQuantizationTransform_AttributeQuantizationTransform_0 = function() { + return (Ha = a._emscripten_bind_AttributeQuantizationTransform_AttributeQuantizationTransform_0 = a.asm.E).apply(null, arguments); + }, rb = a._emscripten_bind_AttributeQuantizationTransform_InitFromAttribute_1 = function() { + return (rb = a._emscripten_bind_AttributeQuantizationTransform_InitFromAttribute_1 = a.asm.F).apply(null, arguments); + }, sb = a._emscripten_bind_AttributeQuantizationTransform_quantization_bits_0 = function() { + return (sb = a._emscripten_bind_AttributeQuantizationTransform_quantization_bits_0 = a.asm.G).apply(null, arguments); + }, tb = a._emscripten_bind_AttributeQuantizationTransform_min_value_1 = function() { + return (tb = a._emscripten_bind_AttributeQuantizationTransform_min_value_1 = a.asm.H).apply(null, arguments); + }, ub = a._emscripten_bind_AttributeQuantizationTransform_range_0 = function() { + return (ub = a._emscripten_bind_AttributeQuantizationTransform_range_0 = a.asm.I).apply(null, arguments); + }, vb = a._emscripten_bind_AttributeQuantizationTransform___destroy___0 = function() { + return (vb = a._emscripten_bind_AttributeQuantizationTransform___destroy___0 = a.asm.J).apply(null, arguments); + }, Ia = a._emscripten_bind_AttributeOctahedronTransform_AttributeOctahedronTransform_0 = function() { + return (Ia = a._emscripten_bind_AttributeOctahedronTransform_AttributeOctahedronTransform_0 = a.asm.K).apply(null, arguments); + }, wb = a._emscripten_bind_AttributeOctahedronTransform_InitFromAttribute_1 = function() { + return (wb = a._emscripten_bind_AttributeOctahedronTransform_InitFromAttribute_1 = a.asm.L).apply( + null, + arguments + ); + }, xb = a._emscripten_bind_AttributeOctahedronTransform_quantization_bits_0 = function() { + return (xb = a._emscripten_bind_AttributeOctahedronTransform_quantization_bits_0 = a.asm.M).apply(null, arguments); + }, yb = a._emscripten_bind_AttributeOctahedronTransform___destroy___0 = function() { + return (yb = a._emscripten_bind_AttributeOctahedronTransform___destroy___0 = a.asm.N).apply(null, arguments); + }, Ja = a._emscripten_bind_PointCloud_PointCloud_0 = function() { + return (Ja = a._emscripten_bind_PointCloud_PointCloud_0 = a.asm.O).apply( + null, + arguments + ); + }, zb = a._emscripten_bind_PointCloud_num_attributes_0 = function() { + return (zb = a._emscripten_bind_PointCloud_num_attributes_0 = a.asm.P).apply(null, arguments); + }, Ab = a._emscripten_bind_PointCloud_num_points_0 = function() { + return (Ab = a._emscripten_bind_PointCloud_num_points_0 = a.asm.Q).apply(null, arguments); + }, Bb = a._emscripten_bind_PointCloud___destroy___0 = function() { + return (Bb = a._emscripten_bind_PointCloud___destroy___0 = a.asm.R).apply(null, arguments); + }, Ka = a._emscripten_bind_Mesh_Mesh_0 = function() { + return (Ka = a._emscripten_bind_Mesh_Mesh_0 = a.asm.S).apply(null, arguments); + }, Cb = a._emscripten_bind_Mesh_num_faces_0 = function() { + return (Cb = a._emscripten_bind_Mesh_num_faces_0 = a.asm.T).apply(null, arguments); + }, Db = a._emscripten_bind_Mesh_num_attributes_0 = function() { + return (Db = a._emscripten_bind_Mesh_num_attributes_0 = a.asm.U).apply(null, arguments); + }, Eb = a._emscripten_bind_Mesh_num_points_0 = function() { + return (Eb = a._emscripten_bind_Mesh_num_points_0 = a.asm.V).apply(null, arguments); + }, Fb = a._emscripten_bind_Mesh___destroy___0 = function() { + return (Fb = a._emscripten_bind_Mesh___destroy___0 = a.asm.W).apply(null, arguments); + }, La = a._emscripten_bind_Metadata_Metadata_0 = function() { + return (La = a._emscripten_bind_Metadata_Metadata_0 = a.asm.X).apply(null, arguments); + }, Gb = a._emscripten_bind_Metadata___destroy___0 = function() { + return (Gb = a._emscripten_bind_Metadata___destroy___0 = a.asm.Y).apply(null, arguments); + }, Hb = a._emscripten_bind_Status_code_0 = function() { + return (Hb = a._emscripten_bind_Status_code_0 = a.asm.Z).apply(null, arguments); + }, Ib = a._emscripten_bind_Status_ok_0 = function() { + return (Ib = a._emscripten_bind_Status_ok_0 = a.asm._).apply(null, arguments); + }, Jb = a._emscripten_bind_Status_error_msg_0 = function() { + return (Jb = a._emscripten_bind_Status_error_msg_0 = a.asm.$).apply(null, arguments); + }, Kb = a._emscripten_bind_Status___destroy___0 = function() { + return (Kb = a._emscripten_bind_Status___destroy___0 = a.asm.aa).apply(null, arguments); + }, Ma = a._emscripten_bind_DracoFloat32Array_DracoFloat32Array_0 = function() { + return (Ma = a._emscripten_bind_DracoFloat32Array_DracoFloat32Array_0 = a.asm.ba).apply(null, arguments); + }, Lb = a._emscripten_bind_DracoFloat32Array_GetValue_1 = function() { + return (Lb = a._emscripten_bind_DracoFloat32Array_GetValue_1 = a.asm.ca).apply(null, arguments); + }, Mb = a._emscripten_bind_DracoFloat32Array_size_0 = function() { + return (Mb = a._emscripten_bind_DracoFloat32Array_size_0 = a.asm.da).apply(null, arguments); + }, Nb = a._emscripten_bind_DracoFloat32Array___destroy___0 = function() { + return (Nb = a._emscripten_bind_DracoFloat32Array___destroy___0 = a.asm.ea).apply(null, arguments); + }, Na = a._emscripten_bind_DracoInt8Array_DracoInt8Array_0 = function() { + return (Na = a._emscripten_bind_DracoInt8Array_DracoInt8Array_0 = a.asm.fa).apply(null, arguments); + }, Ob = a._emscripten_bind_DracoInt8Array_GetValue_1 = function() { + return (Ob = a._emscripten_bind_DracoInt8Array_GetValue_1 = a.asm.ga).apply(null, arguments); + }, Pb = a._emscripten_bind_DracoInt8Array_size_0 = function() { + return (Pb = a._emscripten_bind_DracoInt8Array_size_0 = a.asm.ha).apply(null, arguments); + }, Qb = a._emscripten_bind_DracoInt8Array___destroy___0 = function() { + return (Qb = a._emscripten_bind_DracoInt8Array___destroy___0 = a.asm.ia).apply(null, arguments); + }, Oa = a._emscripten_bind_DracoUInt8Array_DracoUInt8Array_0 = function() { + return (Oa = a._emscripten_bind_DracoUInt8Array_DracoUInt8Array_0 = a.asm.ja).apply(null, arguments); + }, Rb = a._emscripten_bind_DracoUInt8Array_GetValue_1 = function() { + return (Rb = a._emscripten_bind_DracoUInt8Array_GetValue_1 = a.asm.ka).apply(null, arguments); + }, Sb = a._emscripten_bind_DracoUInt8Array_size_0 = function() { + return (Sb = a._emscripten_bind_DracoUInt8Array_size_0 = a.asm.la).apply(null, arguments); + }, Tb = a._emscripten_bind_DracoUInt8Array___destroy___0 = function() { + return (Tb = a._emscripten_bind_DracoUInt8Array___destroy___0 = a.asm.ma).apply(null, arguments); + }, Pa = a._emscripten_bind_DracoInt16Array_DracoInt16Array_0 = function() { + return (Pa = a._emscripten_bind_DracoInt16Array_DracoInt16Array_0 = a.asm.na).apply(null, arguments); + }, Ub = a._emscripten_bind_DracoInt16Array_GetValue_1 = function() { + return (Ub = a._emscripten_bind_DracoInt16Array_GetValue_1 = a.asm.oa).apply(null, arguments); + }, Vb = a._emscripten_bind_DracoInt16Array_size_0 = function() { + return (Vb = a._emscripten_bind_DracoInt16Array_size_0 = a.asm.pa).apply(null, arguments); + }, Wb = a._emscripten_bind_DracoInt16Array___destroy___0 = function() { + return (Wb = a._emscripten_bind_DracoInt16Array___destroy___0 = a.asm.qa).apply(null, arguments); + }, Qa = a._emscripten_bind_DracoUInt16Array_DracoUInt16Array_0 = function() { + return (Qa = a._emscripten_bind_DracoUInt16Array_DracoUInt16Array_0 = a.asm.ra).apply(null, arguments); + }, Xb = a._emscripten_bind_DracoUInt16Array_GetValue_1 = function() { + return (Xb = a._emscripten_bind_DracoUInt16Array_GetValue_1 = a.asm.sa).apply(null, arguments); + }, Yb = a._emscripten_bind_DracoUInt16Array_size_0 = function() { + return (Yb = a._emscripten_bind_DracoUInt16Array_size_0 = a.asm.ta).apply(null, arguments); + }, Zb = a._emscripten_bind_DracoUInt16Array___destroy___0 = function() { + return (Zb = a._emscripten_bind_DracoUInt16Array___destroy___0 = a.asm.ua).apply(null, arguments); + }, Ra = a._emscripten_bind_DracoInt32Array_DracoInt32Array_0 = function() { + return (Ra = a._emscripten_bind_DracoInt32Array_DracoInt32Array_0 = a.asm.va).apply(null, arguments); + }, $b = a._emscripten_bind_DracoInt32Array_GetValue_1 = function() { + return ($b = a._emscripten_bind_DracoInt32Array_GetValue_1 = a.asm.wa).apply(null, arguments); + }, ac = a._emscripten_bind_DracoInt32Array_size_0 = function() { + return (ac = a._emscripten_bind_DracoInt32Array_size_0 = a.asm.xa).apply(null, arguments); + }, bc = a._emscripten_bind_DracoInt32Array___destroy___0 = function() { + return (bc = a._emscripten_bind_DracoInt32Array___destroy___0 = a.asm.ya).apply(null, arguments); + }, Sa = a._emscripten_bind_DracoUInt32Array_DracoUInt32Array_0 = function() { + return (Sa = a._emscripten_bind_DracoUInt32Array_DracoUInt32Array_0 = a.asm.za).apply(null, arguments); + }, cc = a._emscripten_bind_DracoUInt32Array_GetValue_1 = function() { + return (cc = a._emscripten_bind_DracoUInt32Array_GetValue_1 = a.asm.Aa).apply(null, arguments); + }, dc = a._emscripten_bind_DracoUInt32Array_size_0 = function() { + return (dc = a._emscripten_bind_DracoUInt32Array_size_0 = a.asm.Ba).apply(null, arguments); + }, ec = a._emscripten_bind_DracoUInt32Array___destroy___0 = function() { + return (ec = a._emscripten_bind_DracoUInt32Array___destroy___0 = a.asm.Ca).apply(null, arguments); + }, Ta = a._emscripten_bind_MetadataQuerier_MetadataQuerier_0 = function() { + return (Ta = a._emscripten_bind_MetadataQuerier_MetadataQuerier_0 = a.asm.Da).apply(null, arguments); + }, fc = a._emscripten_bind_MetadataQuerier_HasEntry_2 = function() { + return (fc = a._emscripten_bind_MetadataQuerier_HasEntry_2 = a.asm.Ea).apply(null, arguments); + }, gc = a._emscripten_bind_MetadataQuerier_GetIntEntry_2 = function() { + return (gc = a._emscripten_bind_MetadataQuerier_GetIntEntry_2 = a.asm.Fa).apply(null, arguments); + }, hc = a._emscripten_bind_MetadataQuerier_GetIntEntryArray_3 = function() { + return (hc = a._emscripten_bind_MetadataQuerier_GetIntEntryArray_3 = a.asm.Ga).apply(null, arguments); + }, ic = a._emscripten_bind_MetadataQuerier_GetDoubleEntry_2 = function() { + return (ic = a._emscripten_bind_MetadataQuerier_GetDoubleEntry_2 = a.asm.Ha).apply(null, arguments); + }, jc = a._emscripten_bind_MetadataQuerier_GetStringEntry_2 = function() { + return (jc = a._emscripten_bind_MetadataQuerier_GetStringEntry_2 = a.asm.Ia).apply(null, arguments); + }, kc = a._emscripten_bind_MetadataQuerier_NumEntries_1 = function() { + return (kc = a._emscripten_bind_MetadataQuerier_NumEntries_1 = a.asm.Ja).apply(null, arguments); + }, lc = a._emscripten_bind_MetadataQuerier_GetEntryName_2 = function() { + return (lc = a._emscripten_bind_MetadataQuerier_GetEntryName_2 = a.asm.Ka).apply(null, arguments); + }, mc = a._emscripten_bind_MetadataQuerier___destroy___0 = function() { + return (mc = a._emscripten_bind_MetadataQuerier___destroy___0 = a.asm.La).apply(null, arguments); + }, Ua = a._emscripten_bind_Decoder_Decoder_0 = function() { + return (Ua = a._emscripten_bind_Decoder_Decoder_0 = a.asm.Ma).apply(null, arguments); + }, nc = a._emscripten_bind_Decoder_DecodeArrayToPointCloud_3 = function() { + return (nc = a._emscripten_bind_Decoder_DecodeArrayToPointCloud_3 = a.asm.Na).apply(null, arguments); + }, oc = a._emscripten_bind_Decoder_DecodeArrayToMesh_3 = function() { + return (oc = a._emscripten_bind_Decoder_DecodeArrayToMesh_3 = a.asm.Oa).apply(null, arguments); + }, pc = a._emscripten_bind_Decoder_GetAttributeId_2 = function() { + return (pc = a._emscripten_bind_Decoder_GetAttributeId_2 = a.asm.Pa).apply(null, arguments); + }, qc = a._emscripten_bind_Decoder_GetAttributeIdByName_2 = function() { + return (qc = a._emscripten_bind_Decoder_GetAttributeIdByName_2 = a.asm.Qa).apply(null, arguments); + }, rc = a._emscripten_bind_Decoder_GetAttributeIdByMetadataEntry_3 = function() { + return (rc = a._emscripten_bind_Decoder_GetAttributeIdByMetadataEntry_3 = a.asm.Ra).apply(null, arguments); + }, sc = a._emscripten_bind_Decoder_GetAttribute_2 = function() { + return (sc = a._emscripten_bind_Decoder_GetAttribute_2 = a.asm.Sa).apply(null, arguments); + }, tc = a._emscripten_bind_Decoder_GetAttributeByUniqueId_2 = function() { + return (tc = a._emscripten_bind_Decoder_GetAttributeByUniqueId_2 = a.asm.Ta).apply(null, arguments); + }, uc = a._emscripten_bind_Decoder_GetMetadata_1 = function() { + return (uc = a._emscripten_bind_Decoder_GetMetadata_1 = a.asm.Ua).apply(null, arguments); + }, vc = a._emscripten_bind_Decoder_GetAttributeMetadata_2 = function() { + return (vc = a._emscripten_bind_Decoder_GetAttributeMetadata_2 = a.asm.Va).apply(null, arguments); + }, wc = a._emscripten_bind_Decoder_GetFaceFromMesh_3 = function() { + return (wc = a._emscripten_bind_Decoder_GetFaceFromMesh_3 = a.asm.Wa).apply(null, arguments); + }, xc = a._emscripten_bind_Decoder_GetTriangleStripsFromMesh_2 = function() { + return (xc = a._emscripten_bind_Decoder_GetTriangleStripsFromMesh_2 = a.asm.Xa).apply(null, arguments); + }, yc = a._emscripten_bind_Decoder_GetTrianglesUInt16Array_3 = function() { + return (yc = a._emscripten_bind_Decoder_GetTrianglesUInt16Array_3 = a.asm.Ya).apply(null, arguments); + }, zc = a._emscripten_bind_Decoder_GetTrianglesUInt32Array_3 = function() { + return (zc = a._emscripten_bind_Decoder_GetTrianglesUInt32Array_3 = a.asm.Za).apply(null, arguments); + }, Ac = a._emscripten_bind_Decoder_GetAttributeFloat_3 = function() { + return (Ac = a._emscripten_bind_Decoder_GetAttributeFloat_3 = a.asm._a).apply(null, arguments); + }, Bc = a._emscripten_bind_Decoder_GetAttributeFloatForAllPoints_3 = function() { + return (Bc = a._emscripten_bind_Decoder_GetAttributeFloatForAllPoints_3 = a.asm.$a).apply(null, arguments); + }, Cc = a._emscripten_bind_Decoder_GetAttributeIntForAllPoints_3 = function() { + return (Cc = a._emscripten_bind_Decoder_GetAttributeIntForAllPoints_3 = a.asm.ab).apply(null, arguments); + }, Dc = a._emscripten_bind_Decoder_GetAttributeInt8ForAllPoints_3 = function() { + return (Dc = a._emscripten_bind_Decoder_GetAttributeInt8ForAllPoints_3 = a.asm.bb).apply(null, arguments); + }, Ec = a._emscripten_bind_Decoder_GetAttributeUInt8ForAllPoints_3 = function() { + return (Ec = a._emscripten_bind_Decoder_GetAttributeUInt8ForAllPoints_3 = a.asm.cb).apply(null, arguments); + }, Fc = a._emscripten_bind_Decoder_GetAttributeInt16ForAllPoints_3 = function() { + return (Fc = a._emscripten_bind_Decoder_GetAttributeInt16ForAllPoints_3 = a.asm.db).apply(null, arguments); + }, Gc = a._emscripten_bind_Decoder_GetAttributeUInt16ForAllPoints_3 = function() { + return (Gc = a._emscripten_bind_Decoder_GetAttributeUInt16ForAllPoints_3 = a.asm.eb).apply(null, arguments); + }, Hc = a._emscripten_bind_Decoder_GetAttributeInt32ForAllPoints_3 = function() { + return (Hc = a._emscripten_bind_Decoder_GetAttributeInt32ForAllPoints_3 = a.asm.fb).apply(null, arguments); + }, Ic = a._emscripten_bind_Decoder_GetAttributeUInt32ForAllPoints_3 = function() { + return (Ic = a._emscripten_bind_Decoder_GetAttributeUInt32ForAllPoints_3 = a.asm.gb).apply(null, arguments); + }, Jc = a._emscripten_bind_Decoder_GetAttributeDataArrayForAllPoints_5 = function() { + return (Jc = a._emscripten_bind_Decoder_GetAttributeDataArrayForAllPoints_5 = a.asm.hb).apply(null, arguments); + }, Kc = a._emscripten_bind_Decoder_SkipAttributeTransform_1 = function() { + return (Kc = a._emscripten_bind_Decoder_SkipAttributeTransform_1 = a.asm.ib).apply(null, arguments); + }, Lc = a._emscripten_bind_Decoder_GetEncodedGeometryType_Deprecated_1 = function() { + return (Lc = a._emscripten_bind_Decoder_GetEncodedGeometryType_Deprecated_1 = a.asm.jb).apply(null, arguments); + }, Mc = a._emscripten_bind_Decoder_DecodeBufferToPointCloud_2 = function() { + return (Mc = a._emscripten_bind_Decoder_DecodeBufferToPointCloud_2 = a.asm.kb).apply(null, arguments); + }, Nc = a._emscripten_bind_Decoder_DecodeBufferToMesh_2 = function() { + return (Nc = a._emscripten_bind_Decoder_DecodeBufferToMesh_2 = a.asm.lb).apply(null, arguments); + }, Oc = a._emscripten_bind_Decoder___destroy___0 = function() { + return (Oc = a._emscripten_bind_Decoder___destroy___0 = a.asm.mb).apply(null, arguments); + }, Pc = a._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_INVALID_TRANSFORM = function() { + return (Pc = a._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_INVALID_TRANSFORM = a.asm.nb).apply(null, arguments); + }, Qc = a._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_NO_TRANSFORM = function() { + return (Qc = a._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_NO_TRANSFORM = a.asm.ob).apply(null, arguments); + }, Rc = a._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_QUANTIZATION_TRANSFORM = function() { + return (Rc = a._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_QUANTIZATION_TRANSFORM = a.asm.pb).apply(null, arguments); + }, Sc = a._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_OCTAHEDRON_TRANSFORM = function() { + return (Sc = a._emscripten_enum_draco_AttributeTransformType_ATTRIBUTE_OCTAHEDRON_TRANSFORM = a.asm.qb).apply(null, arguments); + }, Tc = a._emscripten_enum_draco_GeometryAttribute_Type_INVALID = function() { + return (Tc = a._emscripten_enum_draco_GeometryAttribute_Type_INVALID = a.asm.rb).apply(null, arguments); + }, Uc = a._emscripten_enum_draco_GeometryAttribute_Type_POSITION = function() { + return (Uc = a._emscripten_enum_draco_GeometryAttribute_Type_POSITION = a.asm.sb).apply(null, arguments); + }, Vc = a._emscripten_enum_draco_GeometryAttribute_Type_NORMAL = function() { + return (Vc = a._emscripten_enum_draco_GeometryAttribute_Type_NORMAL = a.asm.tb).apply(null, arguments); + }, Wc = a._emscripten_enum_draco_GeometryAttribute_Type_COLOR = function() { + return (Wc = a._emscripten_enum_draco_GeometryAttribute_Type_COLOR = a.asm.ub).apply(null, arguments); + }, Xc = a._emscripten_enum_draco_GeometryAttribute_Type_TEX_COORD = function() { + return (Xc = a._emscripten_enum_draco_GeometryAttribute_Type_TEX_COORD = a.asm.vb).apply(null, arguments); + }, Yc = a._emscripten_enum_draco_GeometryAttribute_Type_GENERIC = function() { + return (Yc = a._emscripten_enum_draco_GeometryAttribute_Type_GENERIC = a.asm.wb).apply(null, arguments); + }, Zc = a._emscripten_enum_draco_EncodedGeometryType_INVALID_GEOMETRY_TYPE = function() { + return (Zc = a._emscripten_enum_draco_EncodedGeometryType_INVALID_GEOMETRY_TYPE = a.asm.xb).apply(null, arguments); + }, $c = a._emscripten_enum_draco_EncodedGeometryType_POINT_CLOUD = function() { + return ($c = a._emscripten_enum_draco_EncodedGeometryType_POINT_CLOUD = a.asm.yb).apply(null, arguments); + }, ad = a._emscripten_enum_draco_EncodedGeometryType_TRIANGULAR_MESH = function() { + return (ad = a._emscripten_enum_draco_EncodedGeometryType_TRIANGULAR_MESH = a.asm.zb).apply(null, arguments); + }, bd = a._emscripten_enum_draco_DataType_DT_INVALID = function() { + return (bd = a._emscripten_enum_draco_DataType_DT_INVALID = a.asm.Ab).apply(null, arguments); + }, cd = a._emscripten_enum_draco_DataType_DT_INT8 = function() { + return (cd = a._emscripten_enum_draco_DataType_DT_INT8 = a.asm.Bb).apply(null, arguments); + }, dd = a._emscripten_enum_draco_DataType_DT_UINT8 = function() { + return (dd = a._emscripten_enum_draco_DataType_DT_UINT8 = a.asm.Cb).apply(null, arguments); + }, ed = a._emscripten_enum_draco_DataType_DT_INT16 = function() { + return (ed = a._emscripten_enum_draco_DataType_DT_INT16 = a.asm.Db).apply(null, arguments); + }, fd = a._emscripten_enum_draco_DataType_DT_UINT16 = function() { + return (fd = a._emscripten_enum_draco_DataType_DT_UINT16 = a.asm.Eb).apply(null, arguments); + }, gd = a._emscripten_enum_draco_DataType_DT_INT32 = function() { + return (gd = a._emscripten_enum_draco_DataType_DT_INT32 = a.asm.Fb).apply(null, arguments); + }, hd = a._emscripten_enum_draco_DataType_DT_UINT32 = function() { + return (hd = a._emscripten_enum_draco_DataType_DT_UINT32 = a.asm.Gb).apply(null, arguments); + }, id = a._emscripten_enum_draco_DataType_DT_INT64 = function() { + return (id = a._emscripten_enum_draco_DataType_DT_INT64 = a.asm.Hb).apply(null, arguments); + }, jd = a._emscripten_enum_draco_DataType_DT_UINT64 = function() { + return (jd = a._emscripten_enum_draco_DataType_DT_UINT64 = a.asm.Ib).apply(null, arguments); + }, kd = a._emscripten_enum_draco_DataType_DT_FLOAT32 = function() { + return (kd = a._emscripten_enum_draco_DataType_DT_FLOAT32 = a.asm.Jb).apply( + null, + arguments + ); + }, ld = a._emscripten_enum_draco_DataType_DT_FLOAT64 = function() { + return (ld = a._emscripten_enum_draco_DataType_DT_FLOAT64 = a.asm.Kb).apply(null, arguments); + }, md = a._emscripten_enum_draco_DataType_DT_BOOL = function() { + return (md = a._emscripten_enum_draco_DataType_DT_BOOL = a.asm.Lb).apply(null, arguments); + }, nd = a._emscripten_enum_draco_DataType_DT_TYPES_COUNT = function() { + return (nd = a._emscripten_enum_draco_DataType_DT_TYPES_COUNT = a.asm.Mb).apply(null, arguments); + }, od = a._emscripten_enum_draco_StatusCode_OK = function() { + return (od = a._emscripten_enum_draco_StatusCode_OK = a.asm.Nb).apply(null, arguments); + }, pd = a._emscripten_enum_draco_StatusCode_DRACO_ERROR = function() { + return (pd = a._emscripten_enum_draco_StatusCode_DRACO_ERROR = a.asm.Ob).apply(null, arguments); + }, qd = a._emscripten_enum_draco_StatusCode_IO_ERROR = function() { + return (qd = a._emscripten_enum_draco_StatusCode_IO_ERROR = a.asm.Pb).apply(null, arguments); + }, rd = a._emscripten_enum_draco_StatusCode_INVALID_PARAMETER = function() { + return (rd = a._emscripten_enum_draco_StatusCode_INVALID_PARAMETER = a.asm.Qb).apply(null, arguments); + }, sd = a._emscripten_enum_draco_StatusCode_UNSUPPORTED_VERSION = function() { + return (sd = a._emscripten_enum_draco_StatusCode_UNSUPPORTED_VERSION = a.asm.Rb).apply(null, arguments); + }, td = a._emscripten_enum_draco_StatusCode_UNKNOWN_VERSION = function() { + return (td = a._emscripten_enum_draco_StatusCode_UNKNOWN_VERSION = a.asm.Sb).apply(null, arguments); + }; + a._malloc = function() { + return (a._malloc = a.asm.Tb).apply(null, arguments); + }; + a._free = function() { + return (a._free = a.asm.Ub).apply(null, arguments); + }; + var ya = function() { + return (ya = a.asm.Vb).apply(null, arguments); + }; + a.___start_em_js = 15856; + a.___stop_em_js = 15954; + var la; + ia = function b() { + la || ba(); + la || (ia = b); + }; + if (a.preInit) + for ("function" == typeof a.preInit && (a.preInit = [a.preInit]); 0 < a.preInit.length; ) + a.preInit.pop()(); + ba(); + t.prototype = Object.create(t.prototype); + t.prototype.constructor = t; + t.prototype.__class__ = t; + t.__cache__ = {}; + a.WrapperObject = t; + a.getCache = x; + a.wrapPointer = D; + a.castObject = function(b, c) { + return D(b.ptr, c); + }; + a.NULL = D(0); + a.destroy = function(b) { + if (!b.__destroy__) + throw "Error: Cannot destroy object. (Did you create it yourself?)"; + b.__destroy__(); + delete x(b.__class__)[b.ptr]; + }; + a.compare = function(b, c) { + return b.ptr === c.ptr; + }; + a.getPointer = function(b) { + return b.ptr; + }; + a.getClass = function(b) { + return b.__class__; + }; + var r = { buffer: 0, size: 0, pos: 0, temps: [], needed: 0, prepare: function() { + if (r.needed) { + for (var b = 0; b < r.temps.length; b++) + a._free(r.temps[b]); + r.temps.length = 0; + a._free(r.buffer); + r.buffer = 0; + r.size += r.needed; + r.needed = 0; + } + r.buffer || (r.size += 128, r.buffer = a._malloc(r.size), r.buffer || f(void 0)); + r.pos = 0; + }, alloc: function(b, c) { + r.buffer || f(void 0); + b = b.length * c.BYTES_PER_ELEMENT; + b = b + 7 & -8; + r.pos + b >= r.size ? (0 < b || f(void 0), r.needed += b, c = a._malloc(b), r.temps.push(c)) : (c = r.buffer + r.pos, r.pos += b); + return c; + }, copy: function(b, c, d) { + d >>>= 0; + switch (c.BYTES_PER_ELEMENT) { + case 2: + d >>>= 1; + break; + case 4: + d >>>= 2; + break; + case 8: + d >>>= 3; + } + for (var g = 0; g < b.length; g++) + c[d + g] = b[g]; + } }; + Z.prototype = Object.create(t.prototype); + Z.prototype.constructor = Z; + Z.prototype.__class__ = Z; + Z.__cache__ = {}; + a.VoidPtr = Z; + Z.prototype.__destroy__ = Z.prototype.__destroy__ = function() { + bb(this.ptr); + }; + S.prototype = Object.create(t.prototype); + S.prototype.constructor = S; + S.prototype.__class__ = S; + S.__cache__ = {}; + a.DecoderBuffer = S; + S.prototype.Init = S.prototype.Init = function(b, c) { + var d = this.ptr; + r.prepare(); + "object" == typeof b && (b = pa(b)); + c && "object" === typeof c && (c = c.ptr); + cb(d, b, c); + }; + S.prototype.__destroy__ = S.prototype.__destroy__ = function() { + db(this.ptr); + }; + Q.prototype = Object.create(t.prototype); + Q.prototype.constructor = Q; + Q.prototype.__class__ = Q; + Q.__cache__ = {}; + a.AttributeTransformData = Q; + Q.prototype.transform_type = Q.prototype.transform_type = function() { + return eb(this.ptr); + }; + Q.prototype.__destroy__ = Q.prototype.__destroy__ = function() { + fb(this.ptr); + }; + W.prototype = Object.create(t.prototype); + W.prototype.constructor = W; + W.prototype.__class__ = W; + W.__cache__ = {}; + a.GeometryAttribute = W; + W.prototype.__destroy__ = W.prototype.__destroy__ = function() { + gb(this.ptr); + }; + w.prototype = Object.create(t.prototype); + w.prototype.constructor = w; + w.prototype.__class__ = w; + w.__cache__ = {}; + a.PointAttribute = w; + w.prototype.size = w.prototype.size = function() { + return hb(this.ptr); + }; + w.prototype.GetAttributeTransformData = w.prototype.GetAttributeTransformData = function() { + return D(ib(this.ptr), Q); + }; + w.prototype.attribute_type = w.prototype.attribute_type = function() { + return jb(this.ptr); + }; + w.prototype.data_type = w.prototype.data_type = function() { + return kb(this.ptr); + }; + w.prototype.num_components = w.prototype.num_components = function() { + return lb(this.ptr); + }; + w.prototype.normalized = w.prototype.normalized = function() { + return !!mb(this.ptr); + }; + w.prototype.byte_stride = w.prototype.byte_stride = function() { + return nb(this.ptr); + }; + w.prototype.byte_offset = w.prototype.byte_offset = function() { + return ob(this.ptr); + }; + w.prototype.unique_id = w.prototype.unique_id = function() { + return pb(this.ptr); + }; + w.prototype.__destroy__ = w.prototype.__destroy__ = function() { + qb(this.ptr); + }; + C.prototype = Object.create(t.prototype); + C.prototype.constructor = C; + C.prototype.__class__ = C; + C.__cache__ = {}; + a.AttributeQuantizationTransform = C; + C.prototype.InitFromAttribute = C.prototype.InitFromAttribute = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return !!rb(c, b); + }; + C.prototype.quantization_bits = C.prototype.quantization_bits = function() { + return sb(this.ptr); + }; + C.prototype.min_value = C.prototype.min_value = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return tb(c, b); + }; + C.prototype.range = C.prototype.range = function() { + return ub(this.ptr); + }; + C.prototype.__destroy__ = C.prototype.__destroy__ = function() { + vb(this.ptr); + }; + F.prototype = Object.create(t.prototype); + F.prototype.constructor = F; + F.prototype.__class__ = F; + F.__cache__ = {}; + a.AttributeOctahedronTransform = F; + F.prototype.InitFromAttribute = F.prototype.InitFromAttribute = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return !!wb(c, b); + }; + F.prototype.quantization_bits = F.prototype.quantization_bits = function() { + return xb(this.ptr); + }; + F.prototype.__destroy__ = F.prototype.__destroy__ = function() { + yb(this.ptr); + }; + G.prototype = Object.create(t.prototype); + G.prototype.constructor = G; + G.prototype.__class__ = G; + G.__cache__ = {}; + a.PointCloud = G; + G.prototype.num_attributes = G.prototype.num_attributes = function() { + return zb(this.ptr); + }; + G.prototype.num_points = G.prototype.num_points = function() { + return Ab(this.ptr); + }; + G.prototype.__destroy__ = G.prototype.__destroy__ = function() { + Bb(this.ptr); + }; + E.prototype = Object.create(t.prototype); + E.prototype.constructor = E; + E.prototype.__class__ = E; + E.__cache__ = {}; + a.Mesh = E; + E.prototype.num_faces = E.prototype.num_faces = function() { + return Cb(this.ptr); + }; + E.prototype.num_attributes = E.prototype.num_attributes = function() { + return Db(this.ptr); + }; + E.prototype.num_points = E.prototype.num_points = function() { + return Eb(this.ptr); + }; + E.prototype.__destroy__ = E.prototype.__destroy__ = function() { + Fb(this.ptr); + }; + T.prototype = Object.create(t.prototype); + T.prototype.constructor = T; + T.prototype.__class__ = T; + T.__cache__ = {}; + a.Metadata = T; + T.prototype.__destroy__ = T.prototype.__destroy__ = function() { + Gb(this.ptr); + }; + B.prototype = Object.create(t.prototype); + B.prototype.constructor = B; + B.prototype.__class__ = B; + B.__cache__ = {}; + a.Status = B; + B.prototype.code = B.prototype.code = function() { + return Hb(this.ptr); + }; + B.prototype.ok = B.prototype.ok = function() { + return !!Ib(this.ptr); + }; + B.prototype.error_msg = B.prototype.error_msg = function() { + return h(Jb(this.ptr)); + }; + B.prototype.__destroy__ = B.prototype.__destroy__ = function() { + Kb(this.ptr); + }; + H.prototype = Object.create(t.prototype); + H.prototype.constructor = H; + H.prototype.__class__ = H; + H.__cache__ = {}; + a.DracoFloat32Array = H; + H.prototype.GetValue = H.prototype.GetValue = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return Lb(c, b); + }; + H.prototype.size = H.prototype.size = function() { + return Mb(this.ptr); + }; + H.prototype.__destroy__ = H.prototype.__destroy__ = function() { + Nb(this.ptr); + }; + I.prototype = Object.create(t.prototype); + I.prototype.constructor = I; + I.prototype.__class__ = I; + I.__cache__ = {}; + a.DracoInt8Array = I; + I.prototype.GetValue = I.prototype.GetValue = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return Ob(c, b); + }; + I.prototype.size = I.prototype.size = function() { + return Pb(this.ptr); + }; + I.prototype.__destroy__ = I.prototype.__destroy__ = function() { + Qb(this.ptr); + }; + J.prototype = Object.create(t.prototype); + J.prototype.constructor = J; + J.prototype.__class__ = J; + J.__cache__ = {}; + a.DracoUInt8Array = J; + J.prototype.GetValue = J.prototype.GetValue = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return Rb(c, b); + }; + J.prototype.size = J.prototype.size = function() { + return Sb(this.ptr); + }; + J.prototype.__destroy__ = J.prototype.__destroy__ = function() { + Tb(this.ptr); + }; + K.prototype = Object.create(t.prototype); + K.prototype.constructor = K; + K.prototype.__class__ = K; + K.__cache__ = {}; + a.DracoInt16Array = K; + K.prototype.GetValue = K.prototype.GetValue = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return Ub(c, b); + }; + K.prototype.size = K.prototype.size = function() { + return Vb(this.ptr); + }; + K.prototype.__destroy__ = K.prototype.__destroy__ = function() { + Wb(this.ptr); + }; + L.prototype = Object.create(t.prototype); + L.prototype.constructor = L; + L.prototype.__class__ = L; + L.__cache__ = {}; + a.DracoUInt16Array = L; + L.prototype.GetValue = L.prototype.GetValue = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return Xb(c, b); + }; + L.prototype.size = L.prototype.size = function() { + return Yb(this.ptr); + }; + L.prototype.__destroy__ = L.prototype.__destroy__ = function() { + Zb(this.ptr); + }; + M.prototype = Object.create(t.prototype); + M.prototype.constructor = M; + M.prototype.__class__ = M; + M.__cache__ = {}; + a.DracoInt32Array = M; + M.prototype.GetValue = M.prototype.GetValue = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return $b(c, b); + }; + M.prototype.size = M.prototype.size = function() { + return ac(this.ptr); + }; + M.prototype.__destroy__ = M.prototype.__destroy__ = function() { + bc(this.ptr); + }; + N.prototype = Object.create(t.prototype); + N.prototype.constructor = N; + N.prototype.__class__ = N; + N.__cache__ = {}; + a.DracoUInt32Array = N; + N.prototype.GetValue = N.prototype.GetValue = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return cc(c, b); + }; + N.prototype.size = N.prototype.size = function() { + return dc(this.ptr); + }; + N.prototype.__destroy__ = N.prototype.__destroy__ = function() { + ec(this.ptr); + }; + y.prototype = Object.create(t.prototype); + y.prototype.constructor = y; + y.prototype.__class__ = y; + y.__cache__ = {}; + a.MetadataQuerier = y; + y.prototype.HasEntry = y.prototype.HasEntry = function(b, c) { + var d = this.ptr; + r.prepare(); + b && "object" === typeof b && (b = b.ptr); + c = c && "object" === typeof c ? c.ptr : R(c); + return !!fc(d, b, c); + }; + y.prototype.GetIntEntry = y.prototype.GetIntEntry = function(b, c) { + var d = this.ptr; + r.prepare(); + b && "object" === typeof b && (b = b.ptr); + c = c && "object" === typeof c ? c.ptr : R(c); + return gc(d, b, c); + }; + y.prototype.GetIntEntryArray = y.prototype.GetIntEntryArray = function(b, c, d) { + var g = this.ptr; + r.prepare(); + b && "object" === typeof b && (b = b.ptr); + c = c && "object" === typeof c ? c.ptr : R(c); + d && "object" === typeof d && (d = d.ptr); + hc(g, b, c, d); + }; + y.prototype.GetDoubleEntry = y.prototype.GetDoubleEntry = function(b, c) { + var d = this.ptr; + r.prepare(); + b && "object" === typeof b && (b = b.ptr); + c = c && "object" === typeof c ? c.ptr : R(c); + return ic(d, b, c); + }; + y.prototype.GetStringEntry = y.prototype.GetStringEntry = function(b, c) { + var d = this.ptr; + r.prepare(); + b && "object" === typeof b && (b = b.ptr); + c = c && "object" === typeof c ? c.ptr : R(c); + return h(jc(d, b, c)); + }; + y.prototype.NumEntries = y.prototype.NumEntries = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return kc(c, b); + }; + y.prototype.GetEntryName = y.prototype.GetEntryName = function(b, c) { + var d = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + return h(lc(d, b, c)); + }; + y.prototype.__destroy__ = y.prototype.__destroy__ = function() { + mc(this.ptr); + }; + m.prototype = Object.create(t.prototype); + m.prototype.constructor = m; + m.prototype.__class__ = m; + m.__cache__ = {}; + a.Decoder = m; + m.prototype.DecodeArrayToPointCloud = m.prototype.DecodeArrayToPointCloud = function(b, c, d) { + var g = this.ptr; + r.prepare(); + "object" == typeof b && (b = pa(b)); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return D(nc(g, b, c, d), B); + }; + m.prototype.DecodeArrayToMesh = m.prototype.DecodeArrayToMesh = function(b, c, d) { + var g = this.ptr; + r.prepare(); + "object" == typeof b && (b = pa(b)); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return D(oc(g, b, c, d), B); + }; + m.prototype.GetAttributeId = m.prototype.GetAttributeId = function(b, c) { + var d = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + return pc(d, b, c); + }; + m.prototype.GetAttributeIdByName = m.prototype.GetAttributeIdByName = function(b, c) { + var d = this.ptr; + r.prepare(); + b && "object" === typeof b && (b = b.ptr); + c = c && "object" === typeof c ? c.ptr : R(c); + return qc(d, b, c); + }; + m.prototype.GetAttributeIdByMetadataEntry = m.prototype.GetAttributeIdByMetadataEntry = function(b, c, d) { + var g = this.ptr; + r.prepare(); + b && "object" === typeof b && (b = b.ptr); + c = c && "object" === typeof c ? c.ptr : R(c); + d = d && "object" === typeof d ? d.ptr : R(d); + return rc(g, b, c, d); + }; + m.prototype.GetAttribute = m.prototype.GetAttribute = function(b, c) { + var d = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + return D(sc(d, b, c), w); + }; + m.prototype.GetAttributeByUniqueId = m.prototype.GetAttributeByUniqueId = function(b, c) { + var d = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + return D(tc(d, b, c), w); + }; + m.prototype.GetMetadata = m.prototype.GetMetadata = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return D(uc(c, b), T); + }; + m.prototype.GetAttributeMetadata = m.prototype.GetAttributeMetadata = function(b, c) { + var d = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + return D(vc(d, b, c), T); + }; + m.prototype.GetFaceFromMesh = m.prototype.GetFaceFromMesh = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!wc(g, b, c, d); + }; + m.prototype.GetTriangleStripsFromMesh = m.prototype.GetTriangleStripsFromMesh = function(b, c) { + var d = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + return xc(d, b, c); + }; + m.prototype.GetTrianglesUInt16Array = m.prototype.GetTrianglesUInt16Array = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!yc(g, b, c, d); + }; + m.prototype.GetTrianglesUInt32Array = m.prototype.GetTrianglesUInt32Array = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!zc(g, b, c, d); + }; + m.prototype.GetAttributeFloat = m.prototype.GetAttributeFloat = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!Ac(g, b, c, d); + }; + m.prototype.GetAttributeFloatForAllPoints = m.prototype.GetAttributeFloatForAllPoints = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!Bc(g, b, c, d); + }; + m.prototype.GetAttributeIntForAllPoints = m.prototype.GetAttributeIntForAllPoints = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!Cc(g, b, c, d); + }; + m.prototype.GetAttributeInt8ForAllPoints = m.prototype.GetAttributeInt8ForAllPoints = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!Dc(g, b, c, d); + }; + m.prototype.GetAttributeUInt8ForAllPoints = m.prototype.GetAttributeUInt8ForAllPoints = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!Ec(g, b, c, d); + }; + m.prototype.GetAttributeInt16ForAllPoints = m.prototype.GetAttributeInt16ForAllPoints = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!Fc(g, b, c, d); + }; + m.prototype.GetAttributeUInt16ForAllPoints = m.prototype.GetAttributeUInt16ForAllPoints = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!Gc(g, b, c, d); + }; + m.prototype.GetAttributeInt32ForAllPoints = m.prototype.GetAttributeInt32ForAllPoints = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!Hc(g, b, c, d); + }; + m.prototype.GetAttributeUInt32ForAllPoints = m.prototype.GetAttributeUInt32ForAllPoints = function(b, c, d) { + var g = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + return !!Ic(g, b, c, d); + }; + m.prototype.GetAttributeDataArrayForAllPoints = m.prototype.GetAttributeDataArrayForAllPoints = function(b, c, d, g, u) { + var X = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + d && "object" === typeof d && (d = d.ptr); + g && "object" === typeof g && (g = g.ptr); + u && "object" === typeof u && (u = u.ptr); + return !!Jc(X, b, c, d, g, u); + }; + m.prototype.SkipAttributeTransform = m.prototype.SkipAttributeTransform = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + Kc(c, b); + }; + m.prototype.GetEncodedGeometryType_Deprecated = m.prototype.GetEncodedGeometryType_Deprecated = function(b) { + var c = this.ptr; + b && "object" === typeof b && (b = b.ptr); + return Lc(c, b); + }; + m.prototype.DecodeBufferToPointCloud = m.prototype.DecodeBufferToPointCloud = function(b, c) { + var d = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + return D(Mc(d, b, c), B); + }; + m.prototype.DecodeBufferToMesh = m.prototype.DecodeBufferToMesh = function(b, c) { + var d = this.ptr; + b && "object" === typeof b && (b = b.ptr); + c && "object" === typeof c && (c = c.ptr); + return D(Nc(d, b, c), B); + }; + m.prototype.__destroy__ = m.prototype.__destroy__ = function() { + Oc(this.ptr); + }; + (function() { + function b() { + a.ATTRIBUTE_INVALID_TRANSFORM = Pc(); + a.ATTRIBUTE_NO_TRANSFORM = Qc(); + a.ATTRIBUTE_QUANTIZATION_TRANSFORM = Rc(); + a.ATTRIBUTE_OCTAHEDRON_TRANSFORM = Sc(); + a.INVALID = Tc(); + a.POSITION = Uc(); + a.NORMAL = Vc(); + a.COLOR = Wc(); + a.TEX_COORD = Xc(); + a.GENERIC = Yc(); + a.INVALID_GEOMETRY_TYPE = Zc(); + a.POINT_CLOUD = $c(); + a.TRIANGULAR_MESH = ad(); + a.DT_INVALID = bd(); + a.DT_INT8 = cd(); + a.DT_UINT8 = dd(); + a.DT_INT16 = ed(); + a.DT_UINT16 = fd(); + a.DT_INT32 = gd(); + a.DT_UINT32 = hd(); + a.DT_INT64 = id(); + a.DT_UINT64 = jd(); + a.DT_FLOAT32 = kd(); + a.DT_FLOAT64 = ld(); + a.DT_BOOL = md(); + a.DT_TYPES_COUNT = nd(); + a.OK = od(); + a.DRACO_ERROR = pd(); + a.IO_ERROR = qd(); + a.INVALID_PARAMETER = rd(); + a.UNSUPPORTED_VERSION = sd(); + a.UNKNOWN_VERSION = td(); + } + za ? b() : oa.unshift(b); + })(); + if ("function" === typeof a.onModuleParsed) + a.onModuleParsed(); + a.Decoder.prototype.GetEncodedGeometryType = function(b) { + if (b.__class__ && b.__class__ === a.DecoderBuffer) + return a.Decoder.prototype.GetEncodedGeometryType_Deprecated(b); + if (8 > b.byteLength) + return a.INVALID_GEOMETRY_TYPE; + switch (b[7]) { + case 0: + return a.POINT_CLOUD; + case 1: + return a.TRIANGULAR_MESH; + default: + return a.INVALID_GEOMETRY_TYPE; + } + }; + return n.ready; + }; + }(); + "object" === typeof exports && "object" === typeof module ? module.exports = DracoDecoderModule : "function" === typeof define && define.amd ? define([], function() { + return DracoDecoderModule; + }) : "object" === typeof exports && (exports.DracoDecoderModule = DracoDecoderModule); + } +}); + +export { + require_draco_decoder_nodejs +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-EQ6ZAP37.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-EQ6ZAP37.js new file mode 100644 index 0000000000000000000000000000000000000000..7a782b4578b6d11d1127fb3bcdca4cef7abc22d6 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-EQ6ZAP37.js @@ -0,0 +1,218 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + GeographicProjection_default, + Intersect_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default, + Rectangle_default +} from "./chunk-PW5CA4MJ.js"; +import { + Cartographic_default +} from "./chunk-XJCTFTBM.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/BoundingRectangle.js +function BoundingRectangle(x, y, width, height) { + this.x = defaultValue_default(x, 0); + this.y = defaultValue_default(y, 0); + this.width = defaultValue_default(width, 0); + this.height = defaultValue_default(height, 0); +} +BoundingRectangle.packedLength = 4; +BoundingRectangle.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value.x; + array[startingIndex++] = value.y; + array[startingIndex++] = value.width; + array[startingIndex] = value.height; + return array; +}; +BoundingRectangle.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new BoundingRectangle(); + } + result.x = array[startingIndex++]; + result.y = array[startingIndex++]; + result.width = array[startingIndex++]; + result.height = array[startingIndex]; + return result; +}; +BoundingRectangle.fromPoints = function(positions, result) { + if (!defined_default(result)) { + result = new BoundingRectangle(); + } + if (!defined_default(positions) || positions.length === 0) { + result.x = 0; + result.y = 0; + result.width = 0; + result.height = 0; + return result; + } + const length = positions.length; + let minimumX = positions[0].x; + let minimumY = positions[0].y; + let maximumX = positions[0].x; + let maximumY = positions[0].y; + for (let i = 1; i < length; i++) { + const p = positions[i]; + const x = p.x; + const y = p.y; + minimumX = Math.min(x, minimumX); + maximumX = Math.max(x, maximumX); + minimumY = Math.min(y, minimumY); + maximumY = Math.max(y, maximumY); + } + result.x = minimumX; + result.y = minimumY; + result.width = maximumX - minimumX; + result.height = maximumY - minimumY; + return result; +}; +var defaultProjection = new GeographicProjection_default(); +var fromRectangleLowerLeft = new Cartographic_default(); +var fromRectangleUpperRight = new Cartographic_default(); +BoundingRectangle.fromRectangle = function(rectangle, projection, result) { + if (!defined_default(result)) { + result = new BoundingRectangle(); + } + if (!defined_default(rectangle)) { + result.x = 0; + result.y = 0; + result.width = 0; + result.height = 0; + return result; + } + projection = defaultValue_default(projection, defaultProjection); + const lowerLeft = projection.project( + Rectangle_default.southwest(rectangle, fromRectangleLowerLeft) + ); + const upperRight = projection.project( + Rectangle_default.northeast(rectangle, fromRectangleUpperRight) + ); + Cartesian2_default.subtract(upperRight, lowerLeft, upperRight); + result.x = lowerLeft.x; + result.y = lowerLeft.y; + result.width = upperRight.x; + result.height = upperRight.y; + return result; +}; +BoundingRectangle.clone = function(rectangle, result) { + if (!defined_default(rectangle)) { + return void 0; + } + if (!defined_default(result)) { + return new BoundingRectangle( + rectangle.x, + rectangle.y, + rectangle.width, + rectangle.height + ); + } + result.x = rectangle.x; + result.y = rectangle.y; + result.width = rectangle.width; + result.height = rectangle.height; + return result; +}; +BoundingRectangle.union = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + if (!defined_default(result)) { + result = new BoundingRectangle(); + } + const lowerLeftX = Math.min(left.x, right.x); + const lowerLeftY = Math.min(left.y, right.y); + const upperRightX = Math.max(left.x + left.width, right.x + right.width); + const upperRightY = Math.max(left.y + left.height, right.y + right.height); + result.x = lowerLeftX; + result.y = lowerLeftY; + result.width = upperRightX - lowerLeftX; + result.height = upperRightY - lowerLeftY; + return result; +}; +BoundingRectangle.expand = function(rectangle, point, result) { + Check_default.typeOf.object("rectangle", rectangle); + Check_default.typeOf.object("point", point); + result = BoundingRectangle.clone(rectangle, result); + const width = point.x - result.x; + const height = point.y - result.y; + if (width > result.width) { + result.width = width; + } else if (width < 0) { + result.width -= width; + result.x = point.x; + } + if (height > result.height) { + result.height = height; + } else if (height < 0) { + result.height -= height; + result.y = point.y; + } + return result; +}; +BoundingRectangle.intersect = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + const leftX = left.x; + const leftY = left.y; + const rightX = right.x; + const rightY = right.y; + if (!(leftX > rightX + right.width || leftX + left.width < rightX || leftY + left.height < rightY || leftY > rightY + right.height)) { + return Intersect_default.INTERSECTING; + } + return Intersect_default.OUTSIDE; +}; +BoundingRectangle.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left.x === right.x && left.y === right.y && left.width === right.width && left.height === right.height; +}; +BoundingRectangle.prototype.clone = function(result) { + return BoundingRectangle.clone(this, result); +}; +BoundingRectangle.prototype.intersect = function(right) { + return BoundingRectangle.intersect(this, right); +}; +BoundingRectangle.prototype.equals = function(right) { + return BoundingRectangle.equals(this, right); +}; +var BoundingRectangle_default = BoundingRectangle; + +export { + BoundingRectangle_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-F7P2HCYZ.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-F7P2HCYZ.js new file mode 100644 index 0000000000000000000000000000000000000000..e57a53f2499dd556a6d75964b6040ddf64ec1654 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-F7P2HCYZ.js @@ -0,0 +1,73 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Math_default +} from "./chunk-PWDYKCNC.js"; + +// packages/engine/Source/Core/CylinderGeometryLibrary.js +var CylinderGeometryLibrary = {}; +CylinderGeometryLibrary.computePositions = function(length, topRadius, bottomRadius, slices, fill) { + const topZ = length * 0.5; + const bottomZ = -topZ; + const twoSlice = slices + slices; + const size = fill ? 2 * twoSlice : twoSlice; + const positions = new Float64Array(size * 3); + let i; + let index = 0; + let tbIndex = 0; + const bottomOffset = fill ? twoSlice * 3 : 0; + const topOffset = fill ? (twoSlice + slices) * 3 : slices * 3; + for (i = 0; i < slices; i++) { + const angle = i / slices * Math_default.TWO_PI; + const x = Math.cos(angle); + const y = Math.sin(angle); + const bottomX = x * bottomRadius; + const bottomY = y * bottomRadius; + const topX = x * topRadius; + const topY = y * topRadius; + positions[tbIndex + bottomOffset] = bottomX; + positions[tbIndex + bottomOffset + 1] = bottomY; + positions[tbIndex + bottomOffset + 2] = bottomZ; + positions[tbIndex + topOffset] = topX; + positions[tbIndex + topOffset + 1] = topY; + positions[tbIndex + topOffset + 2] = topZ; + tbIndex += 3; + if (fill) { + positions[index++] = bottomX; + positions[index++] = bottomY; + positions[index++] = bottomZ; + positions[index++] = topX; + positions[index++] = topY; + positions[index++] = topZ; + } + } + return positions; +}; +var CylinderGeometryLibrary_default = CylinderGeometryLibrary; + +export { + CylinderGeometryLibrary_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FE2XG3SS.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FE2XG3SS.js new file mode 100644 index 0000000000000000000000000000000000000000..150ba9b63ca40c56bf4f156d5478acbde3b6687d --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FE2XG3SS.js @@ -0,0 +1,73 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/combine.js +function combine(object1, object2, deep) { + deep = defaultValue_default(deep, false); + const result = {}; + const object1Defined = defined_default(object1); + const object2Defined = defined_default(object2); + let property; + let object1Value; + let object2Value; + if (object1Defined) { + for (property in object1) { + if (object1.hasOwnProperty(property)) { + object1Value = object1[property]; + if (object2Defined && deep && typeof object1Value === "object" && object2.hasOwnProperty(property)) { + object2Value = object2[property]; + if (typeof object2Value === "object") { + result[property] = combine(object1Value, object2Value, deep); + } else { + result[property] = object1Value; + } + } else { + result[property] = object1Value; + } + } + } + } + if (object2Defined) { + for (property in object2) { + if (object2.hasOwnProperty(property) && !result.hasOwnProperty(property)) { + object2Value = object2[property]; + result[property] = object2Value; + } + } + } + return result; +} +var combine_default = combine; + +export { + combine_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FKHRSGKP.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FKHRSGKP.js new file mode 100644 index 0000000000000000000000000000000000000000..3c9f15a50e61555e154d26d58e24fbec251e6550 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FKHRSGKP.js @@ -0,0 +1,781 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + WebMercatorProjection_default +} from "./chunk-RDCDRNJ7.js"; +import { + GeometryPipeline_default +} from "./chunk-HCZR75II.js"; +import { + IndexDatatype_default +} from "./chunk-TF5D2H7B.js"; +import { + GeometryAttributes_default +} from "./chunk-N5MMDSD2.js"; +import { + GeometryAttribute_default, + Geometry_default +} from "./chunk-UGZGTV5K.js"; +import { + BoundingSphere_default, + GeographicProjection_default +} from "./chunk-5U4UHRZ2.js"; +import { + Matrix4_default +} from "./chunk-PW5CA4MJ.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/OffsetGeometryInstanceAttribute.js +function OffsetGeometryInstanceAttribute(x, y, z) { + x = defaultValue_default(x, 0); + y = defaultValue_default(y, 0); + z = defaultValue_default(z, 0); + this.value = new Float32Array([x, y, z]); +} +Object.defineProperties(OffsetGeometryInstanceAttribute.prototype, { + /** + * The datatype of each component in the attribute, e.g., individual elements in + * {@link OffsetGeometryInstanceAttribute#value}. + * + * @memberof OffsetGeometryInstanceAttribute.prototype + * + * @type {ComponentDatatype} + * @readonly + * + * @default {@link ComponentDatatype.FLOAT} + */ + componentDatatype: { + get: function() { + return ComponentDatatype_default.FLOAT; + } + }, + /** + * The number of components in the attributes, i.e., {@link OffsetGeometryInstanceAttribute#value}. + * + * @memberof OffsetGeometryInstanceAttribute.prototype + * + * @type {number} + * @readonly + * + * @default 3 + */ + componentsPerAttribute: { + get: function() { + return 3; + } + }, + /** + * When true and componentDatatype is an integer format, + * indicate that the components should be mapped to the range [0, 1] (unsigned) + * or [-1, 1] (signed) when they are accessed as floating-point for rendering. + * + * @memberof OffsetGeometryInstanceAttribute.prototype + * + * @type {boolean} + * @readonly + * + * @default false + */ + normalize: { + get: function() { + return false; + } + } +}); +OffsetGeometryInstanceAttribute.fromCartesian3 = function(offset) { + Check_default.defined("offset", offset); + return new OffsetGeometryInstanceAttribute(offset.x, offset.y, offset.z); +}; +OffsetGeometryInstanceAttribute.toValue = function(offset, result) { + Check_default.defined("offset", offset); + if (!defined_default(result)) { + result = new Float32Array([offset.x, offset.y, offset.z]); + } + result[0] = offset.x; + result[1] = offset.y; + result[2] = offset.z; + return result; +}; +var OffsetGeometryInstanceAttribute_default = OffsetGeometryInstanceAttribute; + +// packages/engine/Source/Scene/PrimitivePipeline.js +function transformToWorldCoordinates(instances, primitiveModelMatrix, scene3DOnly) { + let toWorld = !scene3DOnly; + const length = instances.length; + let i; + if (!toWorld && length > 1) { + const modelMatrix = instances[0].modelMatrix; + for (i = 1; i < length; ++i) { + if (!Matrix4_default.equals(modelMatrix, instances[i].modelMatrix)) { + toWorld = true; + break; + } + } + } + if (toWorld) { + for (i = 0; i < length; ++i) { + if (defined_default(instances[i].geometry)) { + GeometryPipeline_default.transformToWorldCoordinates(instances[i]); + } + } + } else { + Matrix4_default.multiplyTransformation( + primitiveModelMatrix, + instances[0].modelMatrix, + primitiveModelMatrix + ); + } +} +function addGeometryBatchId(geometry, batchId) { + const attributes = geometry.attributes; + const positionAttr = attributes.position; + const numberOfComponents = positionAttr.values.length / positionAttr.componentsPerAttribute; + attributes.batchId = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 1, + values: new Float32Array(numberOfComponents) + }); + const values = attributes.batchId.values; + for (let j = 0; j < numberOfComponents; ++j) { + values[j] = batchId; + } +} +function addBatchIds(instances) { + const length = instances.length; + for (let i = 0; i < length; ++i) { + const instance = instances[i]; + if (defined_default(instance.geometry)) { + addGeometryBatchId(instance.geometry, i); + } else if (defined_default(instance.westHemisphereGeometry) && defined_default(instance.eastHemisphereGeometry)) { + addGeometryBatchId(instance.westHemisphereGeometry, i); + addGeometryBatchId(instance.eastHemisphereGeometry, i); + } + } +} +function geometryPipeline(parameters) { + const instances = parameters.instances; + const projection = parameters.projection; + const uintIndexSupport = parameters.elementIndexUintSupported; + const scene3DOnly = parameters.scene3DOnly; + const vertexCacheOptimize = parameters.vertexCacheOptimize; + const compressVertices = parameters.compressVertices; + const modelMatrix = parameters.modelMatrix; + let i; + let geometry; + let primitiveType; + let length = instances.length; + for (i = 0; i < length; ++i) { + if (defined_default(instances[i].geometry)) { + primitiveType = instances[i].geometry.primitiveType; + break; + } + } + for (i = 1; i < length; ++i) { + if (defined_default(instances[i].geometry) && instances[i].geometry.primitiveType !== primitiveType) { + throw new DeveloperError_default( + "All instance geometries must have the same primitiveType." + ); + } + } + transformToWorldCoordinates(instances, modelMatrix, scene3DOnly); + if (!scene3DOnly) { + for (i = 0; i < length; ++i) { + if (defined_default(instances[i].geometry)) { + GeometryPipeline_default.splitLongitude(instances[i]); + } + } + } + addBatchIds(instances); + if (vertexCacheOptimize) { + for (i = 0; i < length; ++i) { + const instance = instances[i]; + if (defined_default(instance.geometry)) { + GeometryPipeline_default.reorderForPostVertexCache(instance.geometry); + GeometryPipeline_default.reorderForPreVertexCache(instance.geometry); + } else if (defined_default(instance.westHemisphereGeometry) && defined_default(instance.eastHemisphereGeometry)) { + GeometryPipeline_default.reorderForPostVertexCache( + instance.westHemisphereGeometry + ); + GeometryPipeline_default.reorderForPreVertexCache( + instance.westHemisphereGeometry + ); + GeometryPipeline_default.reorderForPostVertexCache( + instance.eastHemisphereGeometry + ); + GeometryPipeline_default.reorderForPreVertexCache( + instance.eastHemisphereGeometry + ); + } + } + } + let geometries = GeometryPipeline_default.combineInstances(instances); + length = geometries.length; + for (i = 0; i < length; ++i) { + geometry = geometries[i]; + const attributes = geometry.attributes; + if (!scene3DOnly) { + for (const name in attributes) { + if (attributes.hasOwnProperty(name) && attributes[name].componentDatatype === ComponentDatatype_default.DOUBLE) { + const name3D = `${name}3D`; + const name2D = `${name}2D`; + GeometryPipeline_default.projectTo2D( + geometry, + name, + name3D, + name2D, + projection + ); + if (defined_default(geometry.boundingSphere) && name === "position") { + geometry.boundingSphereCV = BoundingSphere_default.fromVertices( + geometry.attributes.position2D.values + ); + } + GeometryPipeline_default.encodeAttribute( + geometry, + name3D, + `${name3D}High`, + `${name3D}Low` + ); + GeometryPipeline_default.encodeAttribute( + geometry, + name2D, + `${name2D}High`, + `${name2D}Low` + ); + } + } + } else { + for (const name in attributes) { + if (attributes.hasOwnProperty(name) && attributes[name].componentDatatype === ComponentDatatype_default.DOUBLE) { + GeometryPipeline_default.encodeAttribute( + geometry, + name, + `${name}3DHigh`, + `${name}3DLow` + ); + } + } + } + if (compressVertices) { + GeometryPipeline_default.compressVertices(geometry); + } + } + if (!uintIndexSupport) { + let splitGeometries = []; + length = geometries.length; + for (i = 0; i < length; ++i) { + geometry = geometries[i]; + splitGeometries = splitGeometries.concat( + GeometryPipeline_default.fitToUnsignedShortIndices(geometry) + ); + } + geometries = splitGeometries; + } + return geometries; +} +function createPickOffsets(instances, geometryName, geometries, pickOffsets) { + let offset; + let indexCount; + let geometryIndex; + const offsetIndex = pickOffsets.length - 1; + if (offsetIndex >= 0) { + const pickOffset = pickOffsets[offsetIndex]; + offset = pickOffset.offset + pickOffset.count; + geometryIndex = pickOffset.index; + indexCount = geometries[geometryIndex].indices.length; + } else { + offset = 0; + geometryIndex = 0; + indexCount = geometries[geometryIndex].indices.length; + } + const length = instances.length; + for (let i = 0; i < length; ++i) { + const instance = instances[i]; + const geometry = instance[geometryName]; + if (!defined_default(geometry)) { + continue; + } + const count = geometry.indices.length; + if (offset + count > indexCount) { + offset = 0; + indexCount = geometries[++geometryIndex].indices.length; + } + pickOffsets.push({ + index: geometryIndex, + offset, + count + }); + offset += count; + } +} +function createInstancePickOffsets(instances, geometries) { + const pickOffsets = []; + createPickOffsets(instances, "geometry", geometries, pickOffsets); + createPickOffsets( + instances, + "westHemisphereGeometry", + geometries, + pickOffsets + ); + createPickOffsets( + instances, + "eastHemisphereGeometry", + geometries, + pickOffsets + ); + return pickOffsets; +} +var PrimitivePipeline = {}; +PrimitivePipeline.combineGeometry = function(parameters) { + let geometries; + let attributeLocations; + const instances = parameters.instances; + const length = instances.length; + let pickOffsets; + let offsetInstanceExtend; + let hasOffset = false; + if (length > 0) { + geometries = geometryPipeline(parameters); + if (geometries.length > 0) { + attributeLocations = GeometryPipeline_default.createAttributeLocations( + geometries[0] + ); + if (parameters.createPickOffsets) { + pickOffsets = createInstancePickOffsets(instances, geometries); + } + } + if (defined_default(instances[0].attributes) && defined_default(instances[0].attributes.offset)) { + offsetInstanceExtend = new Array(length); + hasOffset = true; + } + } + const boundingSpheres = new Array(length); + const boundingSpheresCV = new Array(length); + for (let i = 0; i < length; ++i) { + const instance = instances[i]; + const geometry = instance.geometry; + if (defined_default(geometry)) { + boundingSpheres[i] = geometry.boundingSphere; + boundingSpheresCV[i] = geometry.boundingSphereCV; + if (hasOffset) { + offsetInstanceExtend[i] = instance.geometry.offsetAttribute; + } + } + const eastHemisphereGeometry = instance.eastHemisphereGeometry; + const westHemisphereGeometry = instance.westHemisphereGeometry; + if (defined_default(eastHemisphereGeometry) && defined_default(westHemisphereGeometry)) { + if (defined_default(eastHemisphereGeometry.boundingSphere) && defined_default(westHemisphereGeometry.boundingSphere)) { + boundingSpheres[i] = BoundingSphere_default.union( + eastHemisphereGeometry.boundingSphere, + westHemisphereGeometry.boundingSphere + ); + } + if (defined_default(eastHemisphereGeometry.boundingSphereCV) && defined_default(westHemisphereGeometry.boundingSphereCV)) { + boundingSpheresCV[i] = BoundingSphere_default.union( + eastHemisphereGeometry.boundingSphereCV, + westHemisphereGeometry.boundingSphereCV + ); + } + } + } + return { + geometries, + modelMatrix: parameters.modelMatrix, + attributeLocations, + pickOffsets, + offsetInstanceExtend, + boundingSpheres, + boundingSpheresCV + }; +}; +function transferGeometry(geometry, transferableObjects) { + const attributes = geometry.attributes; + for (const name in attributes) { + if (attributes.hasOwnProperty(name)) { + const attribute = attributes[name]; + if (defined_default(attribute) && defined_default(attribute.values)) { + transferableObjects.push(attribute.values.buffer); + } + } + } + if (defined_default(geometry.indices)) { + transferableObjects.push(geometry.indices.buffer); + } +} +function transferGeometries(geometries, transferableObjects) { + const length = geometries.length; + for (let i = 0; i < length; ++i) { + transferGeometry(geometries[i], transferableObjects); + } +} +function countCreateGeometryResults(items) { + let count = 1; + const length = items.length; + for (let i = 0; i < length; i++) { + const geometry = items[i]; + ++count; + if (!defined_default(geometry)) { + continue; + } + const attributes = geometry.attributes; + count += 7 + 2 * BoundingSphere_default.packedLength + (defined_default(geometry.indices) ? geometry.indices.length : 0); + for (const property in attributes) { + if (attributes.hasOwnProperty(property) && defined_default(attributes[property])) { + const attribute = attributes[property]; + count += 5 + attribute.values.length; + } + } + } + return count; +} +PrimitivePipeline.packCreateGeometryResults = function(items, transferableObjects) { + const packedData = new Float64Array(countCreateGeometryResults(items)); + const stringTable = []; + const stringHash = {}; + const length = items.length; + let count = 0; + packedData[count++] = length; + for (let i = 0; i < length; i++) { + const geometry = items[i]; + const validGeometry = defined_default(geometry); + packedData[count++] = validGeometry ? 1 : 0; + if (!validGeometry) { + continue; + } + packedData[count++] = geometry.primitiveType; + packedData[count++] = geometry.geometryType; + packedData[count++] = defaultValue_default(geometry.offsetAttribute, -1); + const validBoundingSphere = defined_default(geometry.boundingSphere) ? 1 : 0; + packedData[count++] = validBoundingSphere; + if (validBoundingSphere) { + BoundingSphere_default.pack(geometry.boundingSphere, packedData, count); + } + count += BoundingSphere_default.packedLength; + const validBoundingSphereCV = defined_default(geometry.boundingSphereCV) ? 1 : 0; + packedData[count++] = validBoundingSphereCV; + if (validBoundingSphereCV) { + BoundingSphere_default.pack(geometry.boundingSphereCV, packedData, count); + } + count += BoundingSphere_default.packedLength; + const attributes = geometry.attributes; + const attributesToWrite = []; + for (const property in attributes) { + if (attributes.hasOwnProperty(property) && defined_default(attributes[property])) { + attributesToWrite.push(property); + if (!defined_default(stringHash[property])) { + stringHash[property] = stringTable.length; + stringTable.push(property); + } + } + } + packedData[count++] = attributesToWrite.length; + for (let q = 0; q < attributesToWrite.length; q++) { + const name = attributesToWrite[q]; + const attribute = attributes[name]; + packedData[count++] = stringHash[name]; + packedData[count++] = attribute.componentDatatype; + packedData[count++] = attribute.componentsPerAttribute; + packedData[count++] = attribute.normalize ? 1 : 0; + packedData[count++] = attribute.values.length; + packedData.set(attribute.values, count); + count += attribute.values.length; + } + const indicesLength = defined_default(geometry.indices) ? geometry.indices.length : 0; + packedData[count++] = indicesLength; + if (indicesLength > 0) { + packedData.set(geometry.indices, count); + count += indicesLength; + } + } + transferableObjects.push(packedData.buffer); + return { + stringTable, + packedData + }; +}; +PrimitivePipeline.unpackCreateGeometryResults = function(createGeometryResult) { + const stringTable = createGeometryResult.stringTable; + const packedGeometry = createGeometryResult.packedData; + let i; + const result = new Array(packedGeometry[0]); + let resultIndex = 0; + let packedGeometryIndex = 1; + while (packedGeometryIndex < packedGeometry.length) { + const valid = packedGeometry[packedGeometryIndex++] === 1; + if (!valid) { + result[resultIndex++] = void 0; + continue; + } + const primitiveType = packedGeometry[packedGeometryIndex++]; + const geometryType = packedGeometry[packedGeometryIndex++]; + let offsetAttribute = packedGeometry[packedGeometryIndex++]; + if (offsetAttribute === -1) { + offsetAttribute = void 0; + } + let boundingSphere; + let boundingSphereCV; + const validBoundingSphere = packedGeometry[packedGeometryIndex++] === 1; + if (validBoundingSphere) { + boundingSphere = BoundingSphere_default.unpack( + packedGeometry, + packedGeometryIndex + ); + } + packedGeometryIndex += BoundingSphere_default.packedLength; + const validBoundingSphereCV = packedGeometry[packedGeometryIndex++] === 1; + if (validBoundingSphereCV) { + boundingSphereCV = BoundingSphere_default.unpack( + packedGeometry, + packedGeometryIndex + ); + } + packedGeometryIndex += BoundingSphere_default.packedLength; + let length; + let values; + let componentsPerAttribute; + const attributes = new GeometryAttributes_default(); + const numAttributes = packedGeometry[packedGeometryIndex++]; + for (i = 0; i < numAttributes; i++) { + const name = stringTable[packedGeometry[packedGeometryIndex++]]; + const componentDatatype = packedGeometry[packedGeometryIndex++]; + componentsPerAttribute = packedGeometry[packedGeometryIndex++]; + const normalize = packedGeometry[packedGeometryIndex++] !== 0; + length = packedGeometry[packedGeometryIndex++]; + values = ComponentDatatype_default.createTypedArray(componentDatatype, length); + for (let valuesIndex = 0; valuesIndex < length; valuesIndex++) { + values[valuesIndex] = packedGeometry[packedGeometryIndex++]; + } + attributes[name] = new GeometryAttribute_default({ + componentDatatype, + componentsPerAttribute, + normalize, + values + }); + } + let indices; + length = packedGeometry[packedGeometryIndex++]; + if (length > 0) { + const numberOfVertices = values.length / componentsPerAttribute; + indices = IndexDatatype_default.createTypedArray(numberOfVertices, length); + for (i = 0; i < length; i++) { + indices[i] = packedGeometry[packedGeometryIndex++]; + } + } + result[resultIndex++] = new Geometry_default({ + primitiveType, + geometryType, + boundingSphere, + boundingSphereCV, + indices, + attributes, + offsetAttribute + }); + } + return result; +}; +function packInstancesForCombine(instances, transferableObjects) { + const length = instances.length; + const packedData = new Float64Array(1 + length * 19); + let count = 0; + packedData[count++] = length; + for (let i = 0; i < length; i++) { + const instance = instances[i]; + Matrix4_default.pack(instance.modelMatrix, packedData, count); + count += Matrix4_default.packedLength; + if (defined_default(instance.attributes) && defined_default(instance.attributes.offset)) { + const values = instance.attributes.offset.value; + packedData[count] = values[0]; + packedData[count + 1] = values[1]; + packedData[count + 2] = values[2]; + } + count += 3; + } + transferableObjects.push(packedData.buffer); + return packedData; +} +function unpackInstancesForCombine(data) { + const packedInstances = data; + const result = new Array(packedInstances[0]); + let count = 0; + let i = 1; + while (i < packedInstances.length) { + const modelMatrix = Matrix4_default.unpack(packedInstances, i); + let attributes; + i += Matrix4_default.packedLength; + if (defined_default(packedInstances[i])) { + attributes = { + offset: new OffsetGeometryInstanceAttribute_default( + packedInstances[i], + packedInstances[i + 1], + packedInstances[i + 2] + ) + }; + } + i += 3; + result[count++] = { + modelMatrix, + attributes + }; + } + return result; +} +PrimitivePipeline.packCombineGeometryParameters = function(parameters, transferableObjects) { + const createGeometryResults = parameters.createGeometryResults; + const length = createGeometryResults.length; + for (let i = 0; i < length; i++) { + transferableObjects.push(createGeometryResults[i].packedData.buffer); + } + return { + createGeometryResults: parameters.createGeometryResults, + packedInstances: packInstancesForCombine( + parameters.instances, + transferableObjects + ), + ellipsoid: parameters.ellipsoid, + isGeographic: parameters.projection instanceof GeographicProjection_default, + elementIndexUintSupported: parameters.elementIndexUintSupported, + scene3DOnly: parameters.scene3DOnly, + vertexCacheOptimize: parameters.vertexCacheOptimize, + compressVertices: parameters.compressVertices, + modelMatrix: parameters.modelMatrix, + createPickOffsets: parameters.createPickOffsets + }; +}; +PrimitivePipeline.unpackCombineGeometryParameters = function(packedParameters) { + const instances = unpackInstancesForCombine(packedParameters.packedInstances); + const createGeometryResults = packedParameters.createGeometryResults; + const length = createGeometryResults.length; + let instanceIndex = 0; + for (let resultIndex = 0; resultIndex < length; resultIndex++) { + const geometries = PrimitivePipeline.unpackCreateGeometryResults( + createGeometryResults[resultIndex] + ); + const geometriesLength = geometries.length; + for (let geometryIndex = 0; geometryIndex < geometriesLength; geometryIndex++) { + const geometry = geometries[geometryIndex]; + const instance = instances[instanceIndex]; + instance.geometry = geometry; + ++instanceIndex; + } + } + const ellipsoid = Ellipsoid_default.clone(packedParameters.ellipsoid); + const projection = packedParameters.isGeographic ? new GeographicProjection_default(ellipsoid) : new WebMercatorProjection_default(ellipsoid); + return { + instances, + ellipsoid, + projection, + elementIndexUintSupported: packedParameters.elementIndexUintSupported, + scene3DOnly: packedParameters.scene3DOnly, + vertexCacheOptimize: packedParameters.vertexCacheOptimize, + compressVertices: packedParameters.compressVertices, + modelMatrix: Matrix4_default.clone(packedParameters.modelMatrix), + createPickOffsets: packedParameters.createPickOffsets + }; +}; +function packBoundingSpheres(boundingSpheres) { + const length = boundingSpheres.length; + const bufferLength = 1 + (BoundingSphere_default.packedLength + 1) * length; + const buffer = new Float32Array(bufferLength); + let bufferIndex = 0; + buffer[bufferIndex++] = length; + for (let i = 0; i < length; ++i) { + const bs = boundingSpheres[i]; + if (!defined_default(bs)) { + buffer[bufferIndex++] = 0; + } else { + buffer[bufferIndex++] = 1; + BoundingSphere_default.pack(boundingSpheres[i], buffer, bufferIndex); + } + bufferIndex += BoundingSphere_default.packedLength; + } + return buffer; +} +function unpackBoundingSpheres(buffer) { + const result = new Array(buffer[0]); + let count = 0; + let i = 1; + while (i < buffer.length) { + if (buffer[i++] === 1) { + result[count] = BoundingSphere_default.unpack(buffer, i); + } + ++count; + i += BoundingSphere_default.packedLength; + } + return result; +} +PrimitivePipeline.packCombineGeometryResults = function(results, transferableObjects) { + if (defined_default(results.geometries)) { + transferGeometries(results.geometries, transferableObjects); + } + const packedBoundingSpheres = packBoundingSpheres(results.boundingSpheres); + const packedBoundingSpheresCV = packBoundingSpheres( + results.boundingSpheresCV + ); + transferableObjects.push( + packedBoundingSpheres.buffer, + packedBoundingSpheresCV.buffer + ); + return { + geometries: results.geometries, + attributeLocations: results.attributeLocations, + modelMatrix: results.modelMatrix, + pickOffsets: results.pickOffsets, + offsetInstanceExtend: results.offsetInstanceExtend, + boundingSpheres: packedBoundingSpheres, + boundingSpheresCV: packedBoundingSpheresCV + }; +}; +PrimitivePipeline.unpackCombineGeometryResults = function(packedResult) { + return { + geometries: packedResult.geometries, + attributeLocations: packedResult.attributeLocations, + modelMatrix: packedResult.modelMatrix, + pickOffsets: packedResult.pickOffsets, + offsetInstanceExtend: packedResult.offsetInstanceExtend, + boundingSpheres: unpackBoundingSpheres(packedResult.boundingSpheres), + boundingSpheresCV: unpackBoundingSpheres(packedResult.boundingSpheresCV) + }; +}; +var PrimitivePipeline_default = PrimitivePipeline; + +export { + PrimitivePipeline_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FVDTKX3F.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FVDTKX3F.js new file mode 100644 index 0000000000000000000000000000000000000000..a406eadeb2a407c10132653c2635be8231b1ae99 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FVDTKX3F.js @@ -0,0 +1,58 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/RuntimeError.js +function RuntimeError(message) { + this.name = "RuntimeError"; + this.message = message; + let stack; + try { + throw new Error(); + } catch (e) { + stack = e.stack; + } + this.stack = stack; +} +if (defined_default(Object.create)) { + RuntimeError.prototype = Object.create(Error.prototype); + RuntimeError.prototype.constructor = RuntimeError; +} +RuntimeError.prototype.toString = function() { + let str = `${this.name}: ${this.message}`; + if (defined_default(this.stack)) { + str += ` +${this.stack.toString()}`; + } + return str; +}; +var RuntimeError_default = RuntimeError; + +export { + RuntimeError_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FYHCAKU6.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FYHCAKU6.js new file mode 100644 index 0000000000000000000000000000000000000000..f8e7b1be056fffa8e6b8f14627493d2dd67f2cd0 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-FYHCAKU6.js @@ -0,0 +1,684 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + GeometryOffsetAttribute_default +} from "./chunk-A6EA6KIE.js"; +import { + VertexFormat_default +} from "./chunk-2NLMZNJI.js"; +import { + GeometryAttributes_default +} from "./chunk-N5MMDSD2.js"; +import { + GeometryAttribute_default, + Geometry_default, + PrimitiveType_default +} from "./chunk-UGZGTV5K.js"; +import { + BoundingSphere_default +} from "./chunk-5U4UHRZ2.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default +} from "./chunk-XJCTFTBM.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/BoxGeometry.js +var diffScratch = new Cartesian3_default(); +function BoxGeometry(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const min = options.minimum; + const max = options.maximum; + Check_default.typeOf.object("min", min); + Check_default.typeOf.object("max", max); + if (defined_default(options.offsetAttribute) && options.offsetAttribute === GeometryOffsetAttribute_default.TOP) { + throw new DeveloperError_default( + "GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry." + ); + } + const vertexFormat = defaultValue_default(options.vertexFormat, VertexFormat_default.DEFAULT); + this._minimum = Cartesian3_default.clone(min); + this._maximum = Cartesian3_default.clone(max); + this._vertexFormat = vertexFormat; + this._offsetAttribute = options.offsetAttribute; + this._workerName = "createBoxGeometry"; +} +BoxGeometry.fromDimensions = function(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const dimensions = options.dimensions; + Check_default.typeOf.object("dimensions", dimensions); + Check_default.typeOf.number.greaterThanOrEquals("dimensions.x", dimensions.x, 0); + Check_default.typeOf.number.greaterThanOrEquals("dimensions.y", dimensions.y, 0); + Check_default.typeOf.number.greaterThanOrEquals("dimensions.z", dimensions.z, 0); + const corner = Cartesian3_default.multiplyByScalar(dimensions, 0.5, new Cartesian3_default()); + return new BoxGeometry({ + minimum: Cartesian3_default.negate(corner, new Cartesian3_default()), + maximum: corner, + vertexFormat: options.vertexFormat, + offsetAttribute: options.offsetAttribute + }); +}; +BoxGeometry.fromAxisAlignedBoundingBox = function(boundingBox) { + Check_default.typeOf.object("boundingBox", boundingBox); + return new BoxGeometry({ + minimum: boundingBox.minimum, + maximum: boundingBox.maximum + }); +}; +BoxGeometry.packedLength = 2 * Cartesian3_default.packedLength + VertexFormat_default.packedLength + 1; +BoxGeometry.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + Cartesian3_default.pack(value._minimum, array, startingIndex); + Cartesian3_default.pack( + value._maximum, + array, + startingIndex + Cartesian3_default.packedLength + ); + VertexFormat_default.pack( + value._vertexFormat, + array, + startingIndex + 2 * Cartesian3_default.packedLength + ); + array[startingIndex + 2 * Cartesian3_default.packedLength + VertexFormat_default.packedLength] = defaultValue_default(value._offsetAttribute, -1); + return array; +}; +var scratchMin = new Cartesian3_default(); +var scratchMax = new Cartesian3_default(); +var scratchVertexFormat = new VertexFormat_default(); +var scratchOptions = { + minimum: scratchMin, + maximum: scratchMax, + vertexFormat: scratchVertexFormat, + offsetAttribute: void 0 +}; +BoxGeometry.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + const min = Cartesian3_default.unpack(array, startingIndex, scratchMin); + const max = Cartesian3_default.unpack( + array, + startingIndex + Cartesian3_default.packedLength, + scratchMax + ); + const vertexFormat = VertexFormat_default.unpack( + array, + startingIndex + 2 * Cartesian3_default.packedLength, + scratchVertexFormat + ); + const offsetAttribute = array[startingIndex + 2 * Cartesian3_default.packedLength + VertexFormat_default.packedLength]; + if (!defined_default(result)) { + scratchOptions.offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return new BoxGeometry(scratchOptions); + } + result._minimum = Cartesian3_default.clone(min, result._minimum); + result._maximum = Cartesian3_default.clone(max, result._maximum); + result._vertexFormat = VertexFormat_default.clone(vertexFormat, result._vertexFormat); + result._offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return result; +}; +BoxGeometry.createGeometry = function(boxGeometry) { + const min = boxGeometry._minimum; + const max = boxGeometry._maximum; + const vertexFormat = boxGeometry._vertexFormat; + if (Cartesian3_default.equals(min, max)) { + return; + } + const attributes = new GeometryAttributes_default(); + let indices; + let positions; + if (vertexFormat.position && (vertexFormat.st || vertexFormat.normal || vertexFormat.tangent || vertexFormat.bitangent)) { + if (vertexFormat.position) { + positions = new Float64Array(6 * 4 * 3); + positions[0] = min.x; + positions[1] = min.y; + positions[2] = max.z; + positions[3] = max.x; + positions[4] = min.y; + positions[5] = max.z; + positions[6] = max.x; + positions[7] = max.y; + positions[8] = max.z; + positions[9] = min.x; + positions[10] = max.y; + positions[11] = max.z; + positions[12] = min.x; + positions[13] = min.y; + positions[14] = min.z; + positions[15] = max.x; + positions[16] = min.y; + positions[17] = min.z; + positions[18] = max.x; + positions[19] = max.y; + positions[20] = min.z; + positions[21] = min.x; + positions[22] = max.y; + positions[23] = min.z; + positions[24] = max.x; + positions[25] = min.y; + positions[26] = min.z; + positions[27] = max.x; + positions[28] = max.y; + positions[29] = min.z; + positions[30] = max.x; + positions[31] = max.y; + positions[32] = max.z; + positions[33] = max.x; + positions[34] = min.y; + positions[35] = max.z; + positions[36] = min.x; + positions[37] = min.y; + positions[38] = min.z; + positions[39] = min.x; + positions[40] = max.y; + positions[41] = min.z; + positions[42] = min.x; + positions[43] = max.y; + positions[44] = max.z; + positions[45] = min.x; + positions[46] = min.y; + positions[47] = max.z; + positions[48] = min.x; + positions[49] = max.y; + positions[50] = min.z; + positions[51] = max.x; + positions[52] = max.y; + positions[53] = min.z; + positions[54] = max.x; + positions[55] = max.y; + positions[56] = max.z; + positions[57] = min.x; + positions[58] = max.y; + positions[59] = max.z; + positions[60] = min.x; + positions[61] = min.y; + positions[62] = min.z; + positions[63] = max.x; + positions[64] = min.y; + positions[65] = min.z; + positions[66] = max.x; + positions[67] = min.y; + positions[68] = max.z; + positions[69] = min.x; + positions[70] = min.y; + positions[71] = max.z; + attributes.position = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: positions + }); + } + if (vertexFormat.normal) { + const normals = new Float32Array(6 * 4 * 3); + normals[0] = 0; + normals[1] = 0; + normals[2] = 1; + normals[3] = 0; + normals[4] = 0; + normals[5] = 1; + normals[6] = 0; + normals[7] = 0; + normals[8] = 1; + normals[9] = 0; + normals[10] = 0; + normals[11] = 1; + normals[12] = 0; + normals[13] = 0; + normals[14] = -1; + normals[15] = 0; + normals[16] = 0; + normals[17] = -1; + normals[18] = 0; + normals[19] = 0; + normals[20] = -1; + normals[21] = 0; + normals[22] = 0; + normals[23] = -1; + normals[24] = 1; + normals[25] = 0; + normals[26] = 0; + normals[27] = 1; + normals[28] = 0; + normals[29] = 0; + normals[30] = 1; + normals[31] = 0; + normals[32] = 0; + normals[33] = 1; + normals[34] = 0; + normals[35] = 0; + normals[36] = -1; + normals[37] = 0; + normals[38] = 0; + normals[39] = -1; + normals[40] = 0; + normals[41] = 0; + normals[42] = -1; + normals[43] = 0; + normals[44] = 0; + normals[45] = -1; + normals[46] = 0; + normals[47] = 0; + normals[48] = 0; + normals[49] = 1; + normals[50] = 0; + normals[51] = 0; + normals[52] = 1; + normals[53] = 0; + normals[54] = 0; + normals[55] = 1; + normals[56] = 0; + normals[57] = 0; + normals[58] = 1; + normals[59] = 0; + normals[60] = 0; + normals[61] = -1; + normals[62] = 0; + normals[63] = 0; + normals[64] = -1; + normals[65] = 0; + normals[66] = 0; + normals[67] = -1; + normals[68] = 0; + normals[69] = 0; + normals[70] = -1; + normals[71] = 0; + attributes.normal = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: normals + }); + } + if (vertexFormat.st) { + const texCoords = new Float32Array(6 * 4 * 2); + texCoords[0] = 0; + texCoords[1] = 0; + texCoords[2] = 1; + texCoords[3] = 0; + texCoords[4] = 1; + texCoords[5] = 1; + texCoords[6] = 0; + texCoords[7] = 1; + texCoords[8] = 1; + texCoords[9] = 0; + texCoords[10] = 0; + texCoords[11] = 0; + texCoords[12] = 0; + texCoords[13] = 1; + texCoords[14] = 1; + texCoords[15] = 1; + texCoords[16] = 0; + texCoords[17] = 0; + texCoords[18] = 1; + texCoords[19] = 0; + texCoords[20] = 1; + texCoords[21] = 1; + texCoords[22] = 0; + texCoords[23] = 1; + texCoords[24] = 1; + texCoords[25] = 0; + texCoords[26] = 0; + texCoords[27] = 0; + texCoords[28] = 0; + texCoords[29] = 1; + texCoords[30] = 1; + texCoords[31] = 1; + texCoords[32] = 1; + texCoords[33] = 0; + texCoords[34] = 0; + texCoords[35] = 0; + texCoords[36] = 0; + texCoords[37] = 1; + texCoords[38] = 1; + texCoords[39] = 1; + texCoords[40] = 0; + texCoords[41] = 0; + texCoords[42] = 1; + texCoords[43] = 0; + texCoords[44] = 1; + texCoords[45] = 1; + texCoords[46] = 0; + texCoords[47] = 1; + attributes.st = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: texCoords + }); + } + if (vertexFormat.tangent) { + const tangents = new Float32Array(6 * 4 * 3); + tangents[0] = 1; + tangents[1] = 0; + tangents[2] = 0; + tangents[3] = 1; + tangents[4] = 0; + tangents[5] = 0; + tangents[6] = 1; + tangents[7] = 0; + tangents[8] = 0; + tangents[9] = 1; + tangents[10] = 0; + tangents[11] = 0; + tangents[12] = -1; + tangents[13] = 0; + tangents[14] = 0; + tangents[15] = -1; + tangents[16] = 0; + tangents[17] = 0; + tangents[18] = -1; + tangents[19] = 0; + tangents[20] = 0; + tangents[21] = -1; + tangents[22] = 0; + tangents[23] = 0; + tangents[24] = 0; + tangents[25] = 1; + tangents[26] = 0; + tangents[27] = 0; + tangents[28] = 1; + tangents[29] = 0; + tangents[30] = 0; + tangents[31] = 1; + tangents[32] = 0; + tangents[33] = 0; + tangents[34] = 1; + tangents[35] = 0; + tangents[36] = 0; + tangents[37] = -1; + tangents[38] = 0; + tangents[39] = 0; + tangents[40] = -1; + tangents[41] = 0; + tangents[42] = 0; + tangents[43] = -1; + tangents[44] = 0; + tangents[45] = 0; + tangents[46] = -1; + tangents[47] = 0; + tangents[48] = -1; + tangents[49] = 0; + tangents[50] = 0; + tangents[51] = -1; + tangents[52] = 0; + tangents[53] = 0; + tangents[54] = -1; + tangents[55] = 0; + tangents[56] = 0; + tangents[57] = -1; + tangents[58] = 0; + tangents[59] = 0; + tangents[60] = 1; + tangents[61] = 0; + tangents[62] = 0; + tangents[63] = 1; + tangents[64] = 0; + tangents[65] = 0; + tangents[66] = 1; + tangents[67] = 0; + tangents[68] = 0; + tangents[69] = 1; + tangents[70] = 0; + tangents[71] = 0; + attributes.tangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: tangents + }); + } + if (vertexFormat.bitangent) { + const bitangents = new Float32Array(6 * 4 * 3); + bitangents[0] = 0; + bitangents[1] = 1; + bitangents[2] = 0; + bitangents[3] = 0; + bitangents[4] = 1; + bitangents[5] = 0; + bitangents[6] = 0; + bitangents[7] = 1; + bitangents[8] = 0; + bitangents[9] = 0; + bitangents[10] = 1; + bitangents[11] = 0; + bitangents[12] = 0; + bitangents[13] = 1; + bitangents[14] = 0; + bitangents[15] = 0; + bitangents[16] = 1; + bitangents[17] = 0; + bitangents[18] = 0; + bitangents[19] = 1; + bitangents[20] = 0; + bitangents[21] = 0; + bitangents[22] = 1; + bitangents[23] = 0; + bitangents[24] = 0; + bitangents[25] = 0; + bitangents[26] = 1; + bitangents[27] = 0; + bitangents[28] = 0; + bitangents[29] = 1; + bitangents[30] = 0; + bitangents[31] = 0; + bitangents[32] = 1; + bitangents[33] = 0; + bitangents[34] = 0; + bitangents[35] = 1; + bitangents[36] = 0; + bitangents[37] = 0; + bitangents[38] = 1; + bitangents[39] = 0; + bitangents[40] = 0; + bitangents[41] = 1; + bitangents[42] = 0; + bitangents[43] = 0; + bitangents[44] = 1; + bitangents[45] = 0; + bitangents[46] = 0; + bitangents[47] = 1; + bitangents[48] = 0; + bitangents[49] = 0; + bitangents[50] = 1; + bitangents[51] = 0; + bitangents[52] = 0; + bitangents[53] = 1; + bitangents[54] = 0; + bitangents[55] = 0; + bitangents[56] = 1; + bitangents[57] = 0; + bitangents[58] = 0; + bitangents[59] = 1; + bitangents[60] = 0; + bitangents[61] = 0; + bitangents[62] = 1; + bitangents[63] = 0; + bitangents[64] = 0; + bitangents[65] = 1; + bitangents[66] = 0; + bitangents[67] = 0; + bitangents[68] = 1; + bitangents[69] = 0; + bitangents[70] = 0; + bitangents[71] = 1; + attributes.bitangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: bitangents + }); + } + indices = new Uint16Array(6 * 2 * 3); + indices[0] = 0; + indices[1] = 1; + indices[2] = 2; + indices[3] = 0; + indices[4] = 2; + indices[5] = 3; + indices[6] = 4 + 2; + indices[7] = 4 + 1; + indices[8] = 4 + 0; + indices[9] = 4 + 3; + indices[10] = 4 + 2; + indices[11] = 4 + 0; + indices[12] = 8 + 0; + indices[13] = 8 + 1; + indices[14] = 8 + 2; + indices[15] = 8 + 0; + indices[16] = 8 + 2; + indices[17] = 8 + 3; + indices[18] = 12 + 2; + indices[19] = 12 + 1; + indices[20] = 12 + 0; + indices[21] = 12 + 3; + indices[22] = 12 + 2; + indices[23] = 12 + 0; + indices[24] = 16 + 2; + indices[25] = 16 + 1; + indices[26] = 16 + 0; + indices[27] = 16 + 3; + indices[28] = 16 + 2; + indices[29] = 16 + 0; + indices[30] = 20 + 0; + indices[31] = 20 + 1; + indices[32] = 20 + 2; + indices[33] = 20 + 0; + indices[34] = 20 + 2; + indices[35] = 20 + 3; + } else { + positions = new Float64Array(8 * 3); + positions[0] = min.x; + positions[1] = min.y; + positions[2] = min.z; + positions[3] = max.x; + positions[4] = min.y; + positions[5] = min.z; + positions[6] = max.x; + positions[7] = max.y; + positions[8] = min.z; + positions[9] = min.x; + positions[10] = max.y; + positions[11] = min.z; + positions[12] = min.x; + positions[13] = min.y; + positions[14] = max.z; + positions[15] = max.x; + positions[16] = min.y; + positions[17] = max.z; + positions[18] = max.x; + positions[19] = max.y; + positions[20] = max.z; + positions[21] = min.x; + positions[22] = max.y; + positions[23] = max.z; + attributes.position = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: positions + }); + indices = new Uint16Array(6 * 2 * 3); + indices[0] = 4; + indices[1] = 5; + indices[2] = 6; + indices[3] = 4; + indices[4] = 6; + indices[5] = 7; + indices[6] = 1; + indices[7] = 0; + indices[8] = 3; + indices[9] = 1; + indices[10] = 3; + indices[11] = 2; + indices[12] = 1; + indices[13] = 6; + indices[14] = 5; + indices[15] = 1; + indices[16] = 2; + indices[17] = 6; + indices[18] = 2; + indices[19] = 3; + indices[20] = 7; + indices[21] = 2; + indices[22] = 7; + indices[23] = 6; + indices[24] = 3; + indices[25] = 0; + indices[26] = 4; + indices[27] = 3; + indices[28] = 4; + indices[29] = 7; + indices[30] = 0; + indices[31] = 1; + indices[32] = 5; + indices[33] = 0; + indices[34] = 5; + indices[35] = 4; + } + const diff = Cartesian3_default.subtract(max, min, diffScratch); + const radius = Cartesian3_default.magnitude(diff) * 0.5; + if (defined_default(boxGeometry._offsetAttribute)) { + const length = positions.length; + const offsetValue = boxGeometry._offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1; + const applyOffset = new Uint8Array(length / 3).fill(offsetValue); + attributes.applyOffset = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE, + componentsPerAttribute: 1, + values: applyOffset + }); + } + return new Geometry_default({ + attributes, + indices, + primitiveType: PrimitiveType_default.TRIANGLES, + boundingSphere: new BoundingSphere_default(Cartesian3_default.ZERO, radius), + offsetAttribute: boxGeometry._offsetAttribute + }); +}; +var unitBoxGeometry; +BoxGeometry.getUnitBox = function() { + if (!defined_default(unitBoxGeometry)) { + unitBoxGeometry = BoxGeometry.createGeometry( + BoxGeometry.fromDimensions({ + dimensions: new Cartesian3_default(1, 1, 1), + vertexFormat: VertexFormat_default.POSITION_ONLY + }) + ); + } + return unitBoxGeometry; +}; +var BoxGeometry_default = BoxGeometry; + +export { + BoxGeometry_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-G3MOT7BZ.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-G3MOT7BZ.js new file mode 100644 index 0000000000000000000000000000000000000000..66d8c4a94b616a5d8d5f371ae7a06986dc7741cd --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-G3MOT7BZ.js @@ -0,0 +1,157 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Intersect_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian3_default +} from "./chunk-XJCTFTBM.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/AxisAlignedBoundingBox.js +function AxisAlignedBoundingBox(minimum, maximum, center) { + this.minimum = Cartesian3_default.clone(defaultValue_default(minimum, Cartesian3_default.ZERO)); + this.maximum = Cartesian3_default.clone(defaultValue_default(maximum, Cartesian3_default.ZERO)); + if (!defined_default(center)) { + center = Cartesian3_default.midpoint(this.minimum, this.maximum, new Cartesian3_default()); + } else { + center = Cartesian3_default.clone(center); + } + this.center = center; +} +AxisAlignedBoundingBox.fromCorners = function(minimum, maximum, result) { + Check_default.defined("minimum", minimum); + Check_default.defined("maximum", maximum); + if (!defined_default(result)) { + result = new AxisAlignedBoundingBox(); + } + result.minimum = Cartesian3_default.clone(minimum, result.minimum); + result.maximum = Cartesian3_default.clone(maximum, result.maximum); + result.center = Cartesian3_default.midpoint(minimum, maximum, result.center); + return result; +}; +AxisAlignedBoundingBox.fromPoints = function(positions, result) { + if (!defined_default(result)) { + result = new AxisAlignedBoundingBox(); + } + if (!defined_default(positions) || positions.length === 0) { + result.minimum = Cartesian3_default.clone(Cartesian3_default.ZERO, result.minimum); + result.maximum = Cartesian3_default.clone(Cartesian3_default.ZERO, result.maximum); + result.center = Cartesian3_default.clone(Cartesian3_default.ZERO, result.center); + return result; + } + let minimumX = positions[0].x; + let minimumY = positions[0].y; + let minimumZ = positions[0].z; + let maximumX = positions[0].x; + let maximumY = positions[0].y; + let maximumZ = positions[0].z; + const length = positions.length; + for (let i = 1; i < length; i++) { + const p = positions[i]; + const x = p.x; + const y = p.y; + const z = p.z; + minimumX = Math.min(x, minimumX); + maximumX = Math.max(x, maximumX); + minimumY = Math.min(y, minimumY); + maximumY = Math.max(y, maximumY); + minimumZ = Math.min(z, minimumZ); + maximumZ = Math.max(z, maximumZ); + } + const minimum = result.minimum; + minimum.x = minimumX; + minimum.y = minimumY; + minimum.z = minimumZ; + const maximum = result.maximum; + maximum.x = maximumX; + maximum.y = maximumY; + maximum.z = maximumZ; + result.center = Cartesian3_default.midpoint(minimum, maximum, result.center); + return result; +}; +AxisAlignedBoundingBox.clone = function(box, result) { + if (!defined_default(box)) { + return void 0; + } + if (!defined_default(result)) { + return new AxisAlignedBoundingBox(box.minimum, box.maximum, box.center); + } + result.minimum = Cartesian3_default.clone(box.minimum, result.minimum); + result.maximum = Cartesian3_default.clone(box.maximum, result.maximum); + result.center = Cartesian3_default.clone(box.center, result.center); + return result; +}; +AxisAlignedBoundingBox.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && Cartesian3_default.equals(left.center, right.center) && Cartesian3_default.equals(left.minimum, right.minimum) && Cartesian3_default.equals(left.maximum, right.maximum); +}; +var intersectScratch = new Cartesian3_default(); +AxisAlignedBoundingBox.intersectPlane = function(box, plane) { + Check_default.defined("box", box); + Check_default.defined("plane", plane); + intersectScratch = Cartesian3_default.subtract( + box.maximum, + box.minimum, + intersectScratch + ); + const h = Cartesian3_default.multiplyByScalar( + intersectScratch, + 0.5, + intersectScratch + ); + const normal = plane.normal; + const e = h.x * Math.abs(normal.x) + h.y * Math.abs(normal.y) + h.z * Math.abs(normal.z); + const s = Cartesian3_default.dot(box.center, normal) + plane.distance; + if (s - e > 0) { + return Intersect_default.INSIDE; + } + if (s + e < 0) { + return Intersect_default.OUTSIDE; + } + return Intersect_default.INTERSECTING; +}; +AxisAlignedBoundingBox.prototype.clone = function(result) { + return AxisAlignedBoundingBox.clone(this, result); +}; +AxisAlignedBoundingBox.prototype.intersectPlane = function(plane) { + return AxisAlignedBoundingBox.intersectPlane(this, plane); +}; +AxisAlignedBoundingBox.prototype.equals = function(right) { + return AxisAlignedBoundingBox.equals(this, right); +}; +var AxisAlignedBoundingBox_default = AxisAlignedBoundingBox; + +export { + AxisAlignedBoundingBox_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-H52L6U76.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-H52L6U76.js new file mode 100644 index 0000000000000000000000000000000000000000..7231c138e1e8c9d61361d460c37fee4d9f0387de --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-H52L6U76.js @@ -0,0 +1,421 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + EllipsoidGeodesic_default +} from "./chunk-7CZEWQWE.js"; +import { + EllipsoidRhumbLine_default +} from "./chunk-RRUPTJ6P.js"; +import { + IntersectionTests_default +} from "./chunk-QIS3NB7U.js"; +import { + Plane_default +} from "./chunk-PGB3EFR7.js"; +import { + Matrix4_default +} from "./chunk-PW5CA4MJ.js"; +import { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/PolylinePipeline.js +var PolylinePipeline = {}; +PolylinePipeline.numberOfPoints = function(p0, p1, minDistance) { + const distance = Cartesian3_default.distance(p0, p1); + return Math.ceil(distance / minDistance); +}; +PolylinePipeline.numberOfPointsRhumbLine = function(p0, p1, granularity) { + const radiansDistanceSquared = Math.pow(p0.longitude - p1.longitude, 2) + Math.pow(p0.latitude - p1.latitude, 2); + return Math.max( + 1, + Math.ceil(Math.sqrt(radiansDistanceSquared / (granularity * granularity))) + ); +}; +var cartoScratch = new Cartographic_default(); +PolylinePipeline.extractHeights = function(positions, ellipsoid) { + const length = positions.length; + const heights = new Array(length); + for (let i = 0; i < length; i++) { + const p = positions[i]; + heights[i] = ellipsoid.cartesianToCartographic(p, cartoScratch).height; + } + return heights; +}; +var wrapLongitudeInversMatrix = new Matrix4_default(); +var wrapLongitudeOrigin = new Cartesian3_default(); +var wrapLongitudeXZNormal = new Cartesian3_default(); +var wrapLongitudeXZPlane = new Plane_default(Cartesian3_default.UNIT_X, 0); +var wrapLongitudeYZNormal = new Cartesian3_default(); +var wrapLongitudeYZPlane = new Plane_default(Cartesian3_default.UNIT_X, 0); +var wrapLongitudeIntersection = new Cartesian3_default(); +var wrapLongitudeOffset = new Cartesian3_default(); +var subdivideHeightsScratchArray = []; +function subdivideHeights(numPoints, h0, h1) { + const heights = subdivideHeightsScratchArray; + heights.length = numPoints; + let i; + if (h0 === h1) { + for (i = 0; i < numPoints; i++) { + heights[i] = h0; + } + return heights; + } + const dHeight = h1 - h0; + const heightPerVertex = dHeight / numPoints; + for (i = 0; i < numPoints; i++) { + const h = h0 + i * heightPerVertex; + heights[i] = h; + } + return heights; +} +var carto1 = new Cartographic_default(); +var carto2 = new Cartographic_default(); +var cartesian = new Cartesian3_default(); +var scaleFirst = new Cartesian3_default(); +var scaleLast = new Cartesian3_default(); +var ellipsoidGeodesic = new EllipsoidGeodesic_default(); +var ellipsoidRhumb = new EllipsoidRhumbLine_default(); +function generateCartesianArc(p0, p1, minDistance, ellipsoid, h0, h1, array, offset) { + const first = ellipsoid.scaleToGeodeticSurface(p0, scaleFirst); + const last = ellipsoid.scaleToGeodeticSurface(p1, scaleLast); + const numPoints = PolylinePipeline.numberOfPoints(p0, p1, minDistance); + const start = ellipsoid.cartesianToCartographic(first, carto1); + const end = ellipsoid.cartesianToCartographic(last, carto2); + const heights = subdivideHeights(numPoints, h0, h1); + ellipsoidGeodesic.setEndPoints(start, end); + const surfaceDistanceBetweenPoints = ellipsoidGeodesic.surfaceDistance / numPoints; + let index = offset; + start.height = h0; + let cart = ellipsoid.cartographicToCartesian(start, cartesian); + Cartesian3_default.pack(cart, array, index); + index += 3; + for (let i = 1; i < numPoints; i++) { + const carto = ellipsoidGeodesic.interpolateUsingSurfaceDistance( + i * surfaceDistanceBetweenPoints, + carto2 + ); + carto.height = heights[i]; + cart = ellipsoid.cartographicToCartesian(carto, cartesian); + Cartesian3_default.pack(cart, array, index); + index += 3; + } + return index; +} +function generateCartesianRhumbArc(p0, p1, granularity, ellipsoid, h0, h1, array, offset) { + const start = ellipsoid.cartesianToCartographic(p0, carto1); + const end = ellipsoid.cartesianToCartographic(p1, carto2); + const numPoints = PolylinePipeline.numberOfPointsRhumbLine( + start, + end, + granularity + ); + start.height = 0; + end.height = 0; + const heights = subdivideHeights(numPoints, h0, h1); + if (!ellipsoidRhumb.ellipsoid.equals(ellipsoid)) { + ellipsoidRhumb = new EllipsoidRhumbLine_default(void 0, void 0, ellipsoid); + } + ellipsoidRhumb.setEndPoints(start, end); + const surfaceDistanceBetweenPoints = ellipsoidRhumb.surfaceDistance / numPoints; + let index = offset; + start.height = h0; + let cart = ellipsoid.cartographicToCartesian(start, cartesian); + Cartesian3_default.pack(cart, array, index); + index += 3; + for (let i = 1; i < numPoints; i++) { + const carto = ellipsoidRhumb.interpolateUsingSurfaceDistance( + i * surfaceDistanceBetweenPoints, + carto2 + ); + carto.height = heights[i]; + cart = ellipsoid.cartographicToCartesian(carto, cartesian); + Cartesian3_default.pack(cart, array, index); + index += 3; + } + return index; +} +PolylinePipeline.wrapLongitude = function(positions, modelMatrix) { + const cartesians = []; + const segments = []; + if (defined_default(positions) && positions.length > 0) { + modelMatrix = defaultValue_default(modelMatrix, Matrix4_default.IDENTITY); + const inverseModelMatrix = Matrix4_default.inverseTransformation( + modelMatrix, + wrapLongitudeInversMatrix + ); + const origin = Matrix4_default.multiplyByPoint( + inverseModelMatrix, + Cartesian3_default.ZERO, + wrapLongitudeOrigin + ); + const xzNormal = Cartesian3_default.normalize( + Matrix4_default.multiplyByPointAsVector( + inverseModelMatrix, + Cartesian3_default.UNIT_Y, + wrapLongitudeXZNormal + ), + wrapLongitudeXZNormal + ); + const xzPlane = Plane_default.fromPointNormal( + origin, + xzNormal, + wrapLongitudeXZPlane + ); + const yzNormal = Cartesian3_default.normalize( + Matrix4_default.multiplyByPointAsVector( + inverseModelMatrix, + Cartesian3_default.UNIT_X, + wrapLongitudeYZNormal + ), + wrapLongitudeYZNormal + ); + const yzPlane = Plane_default.fromPointNormal( + origin, + yzNormal, + wrapLongitudeYZPlane + ); + let count = 1; + cartesians.push(Cartesian3_default.clone(positions[0])); + let prev = cartesians[0]; + const length = positions.length; + for (let i = 1; i < length; ++i) { + const cur = positions[i]; + if (Plane_default.getPointDistance(yzPlane, prev) < 0 || Plane_default.getPointDistance(yzPlane, cur) < 0) { + const intersection = IntersectionTests_default.lineSegmentPlane( + prev, + cur, + xzPlane, + wrapLongitudeIntersection + ); + if (defined_default(intersection)) { + const offset = Cartesian3_default.multiplyByScalar( + xzNormal, + 5e-9, + wrapLongitudeOffset + ); + if (Plane_default.getPointDistance(xzPlane, prev) < 0) { + Cartesian3_default.negate(offset, offset); + } + cartesians.push( + Cartesian3_default.add(intersection, offset, new Cartesian3_default()) + ); + segments.push(count + 1); + Cartesian3_default.negate(offset, offset); + cartesians.push( + Cartesian3_default.add(intersection, offset, new Cartesian3_default()) + ); + count = 1; + } + } + cartesians.push(Cartesian3_default.clone(positions[i])); + count++; + prev = cur; + } + segments.push(count); + } + return { + positions: cartesians, + lengths: segments + }; +}; +PolylinePipeline.generateArc = function(options) { + if (!defined_default(options)) { + options = {}; + } + const positions = options.positions; + if (!defined_default(positions)) { + throw new DeveloperError_default("options.positions is required."); + } + const length = positions.length; + const ellipsoid = defaultValue_default(options.ellipsoid, Ellipsoid_default.WGS84); + let height = defaultValue_default(options.height, 0); + const hasHeightArray = Array.isArray(height); + if (length < 1) { + return []; + } else if (length === 1) { + const p = ellipsoid.scaleToGeodeticSurface(positions[0], scaleFirst); + height = hasHeightArray ? height[0] : height; + if (height !== 0) { + const n = ellipsoid.geodeticSurfaceNormal(p, cartesian); + Cartesian3_default.multiplyByScalar(n, height, n); + Cartesian3_default.add(p, n, p); + } + return [p.x, p.y, p.z]; + } + let minDistance = options.minDistance; + if (!defined_default(minDistance)) { + const granularity = defaultValue_default( + options.granularity, + Math_default.RADIANS_PER_DEGREE + ); + minDistance = Math_default.chordLength(granularity, ellipsoid.maximumRadius); + } + let numPoints = 0; + let i; + for (i = 0; i < length - 1; i++) { + numPoints += PolylinePipeline.numberOfPoints( + positions[i], + positions[i + 1], + minDistance + ); + } + const arrayLength = (numPoints + 1) * 3; + const newPositions = new Array(arrayLength); + let offset = 0; + for (i = 0; i < length - 1; i++) { + const p0 = positions[i]; + const p1 = positions[i + 1]; + const h0 = hasHeightArray ? height[i] : height; + const h1 = hasHeightArray ? height[i + 1] : height; + offset = generateCartesianArc( + p0, + p1, + minDistance, + ellipsoid, + h0, + h1, + newPositions, + offset + ); + } + subdivideHeightsScratchArray.length = 0; + const lastPoint = positions[length - 1]; + const carto = ellipsoid.cartesianToCartographic(lastPoint, carto1); + carto.height = hasHeightArray ? height[length - 1] : height; + const cart = ellipsoid.cartographicToCartesian(carto, cartesian); + Cartesian3_default.pack(cart, newPositions, arrayLength - 3); + return newPositions; +}; +var scratchCartographic0 = new Cartographic_default(); +var scratchCartographic1 = new Cartographic_default(); +PolylinePipeline.generateRhumbArc = function(options) { + if (!defined_default(options)) { + options = {}; + } + const positions = options.positions; + if (!defined_default(positions)) { + throw new DeveloperError_default("options.positions is required."); + } + const length = positions.length; + const ellipsoid = defaultValue_default(options.ellipsoid, Ellipsoid_default.WGS84); + let height = defaultValue_default(options.height, 0); + const hasHeightArray = Array.isArray(height); + if (length < 1) { + return []; + } else if (length === 1) { + const p = ellipsoid.scaleToGeodeticSurface(positions[0], scaleFirst); + height = hasHeightArray ? height[0] : height; + if (height !== 0) { + const n = ellipsoid.geodeticSurfaceNormal(p, cartesian); + Cartesian3_default.multiplyByScalar(n, height, n); + Cartesian3_default.add(p, n, p); + } + return [p.x, p.y, p.z]; + } + const granularity = defaultValue_default( + options.granularity, + Math_default.RADIANS_PER_DEGREE + ); + let numPoints = 0; + let i; + let c0 = ellipsoid.cartesianToCartographic( + positions[0], + scratchCartographic0 + ); + let c1; + for (i = 0; i < length - 1; i++) { + c1 = ellipsoid.cartesianToCartographic( + positions[i + 1], + scratchCartographic1 + ); + numPoints += PolylinePipeline.numberOfPointsRhumbLine(c0, c1, granularity); + c0 = Cartographic_default.clone(c1, scratchCartographic0); + } + const arrayLength = (numPoints + 1) * 3; + const newPositions = new Array(arrayLength); + let offset = 0; + for (i = 0; i < length - 1; i++) { + const p0 = positions[i]; + const p1 = positions[i + 1]; + const h0 = hasHeightArray ? height[i] : height; + const h1 = hasHeightArray ? height[i + 1] : height; + offset = generateCartesianRhumbArc( + p0, + p1, + granularity, + ellipsoid, + h0, + h1, + newPositions, + offset + ); + } + subdivideHeightsScratchArray.length = 0; + const lastPoint = positions[length - 1]; + const carto = ellipsoid.cartesianToCartographic(lastPoint, carto1); + carto.height = hasHeightArray ? height[length - 1] : height; + const cart = ellipsoid.cartographicToCartesian(carto, cartesian); + Cartesian3_default.pack(cart, newPositions, arrayLength - 3); + return newPositions; +}; +PolylinePipeline.generateCartesianArc = function(options) { + const numberArray = PolylinePipeline.generateArc(options); + const size = numberArray.length / 3; + const newPositions = new Array(size); + for (let i = 0; i < size; i++) { + newPositions[i] = Cartesian3_default.unpack(numberArray, i * 3); + } + return newPositions; +}; +PolylinePipeline.generateCartesianRhumbArc = function(options) { + const numberArray = PolylinePipeline.generateRhumbArc(options); + const size = numberArray.length / 3; + const newPositions = new Array(size); + for (let i = 0; i < size; i++) { + newPositions[i] = Cartesian3_default.unpack(numberArray, i * 3); + } + return newPositions; +}; +var PolylinePipeline_default = PolylinePipeline; + +export { + PolylinePipeline_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-H6MBQ4W4.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-H6MBQ4W4.js new file mode 100644 index 0000000000000000000000000000000000000000..2859c65ab916a1f53595168ab727ec356e1402e8 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-H6MBQ4W4.js @@ -0,0 +1,305 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Quaternion_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian3_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; + +// packages/engine/Source/Core/EllipseGeometryLibrary.js +var EllipseGeometryLibrary = {}; +var rotAxis = new Cartesian3_default(); +var tempVec = new Cartesian3_default(); +var unitQuat = new Quaternion_default(); +var rotMtx = new Matrix3_default(); +function pointOnEllipsoid(theta, rotation, northVec, eastVec, aSqr, ab, bSqr, mag, unitPos, result) { + const azimuth = theta + rotation; + Cartesian3_default.multiplyByScalar(eastVec, Math.cos(azimuth), rotAxis); + Cartesian3_default.multiplyByScalar(northVec, Math.sin(azimuth), tempVec); + Cartesian3_default.add(rotAxis, tempVec, rotAxis); + let cosThetaSquared = Math.cos(theta); + cosThetaSquared = cosThetaSquared * cosThetaSquared; + let sinThetaSquared = Math.sin(theta); + sinThetaSquared = sinThetaSquared * sinThetaSquared; + const radius = ab / Math.sqrt(bSqr * cosThetaSquared + aSqr * sinThetaSquared); + const angle = radius / mag; + Quaternion_default.fromAxisAngle(rotAxis, angle, unitQuat); + Matrix3_default.fromQuaternion(unitQuat, rotMtx); + Matrix3_default.multiplyByVector(rotMtx, unitPos, result); + Cartesian3_default.normalize(result, result); + Cartesian3_default.multiplyByScalar(result, mag, result); + return result; +} +var scratchCartesian1 = new Cartesian3_default(); +var scratchCartesian2 = new Cartesian3_default(); +var scratchCartesian3 = new Cartesian3_default(); +var scratchNormal = new Cartesian3_default(); +EllipseGeometryLibrary.raisePositionsToHeight = function(positions, options, extrude) { + const ellipsoid = options.ellipsoid; + const height = options.height; + const extrudedHeight = options.extrudedHeight; + const size = extrude ? positions.length / 3 * 2 : positions.length / 3; + const finalPositions = new Float64Array(size * 3); + const length = positions.length; + const bottomOffset = extrude ? length : 0; + for (let i = 0; i < length; i += 3) { + const i1 = i + 1; + const i2 = i + 2; + const position = Cartesian3_default.fromArray(positions, i, scratchCartesian1); + ellipsoid.scaleToGeodeticSurface(position, position); + const extrudedPosition = Cartesian3_default.clone(position, scratchCartesian2); + const normal = ellipsoid.geodeticSurfaceNormal(position, scratchNormal); + const scaledNormal = Cartesian3_default.multiplyByScalar( + normal, + height, + scratchCartesian3 + ); + Cartesian3_default.add(position, scaledNormal, position); + if (extrude) { + Cartesian3_default.multiplyByScalar(normal, extrudedHeight, scaledNormal); + Cartesian3_default.add(extrudedPosition, scaledNormal, extrudedPosition); + finalPositions[i + bottomOffset] = extrudedPosition.x; + finalPositions[i1 + bottomOffset] = extrudedPosition.y; + finalPositions[i2 + bottomOffset] = extrudedPosition.z; + } + finalPositions[i] = position.x; + finalPositions[i1] = position.y; + finalPositions[i2] = position.z; + } + return finalPositions; +}; +var unitPosScratch = new Cartesian3_default(); +var eastVecScratch = new Cartesian3_default(); +var northVecScratch = new Cartesian3_default(); +EllipseGeometryLibrary.computeEllipsePositions = function(options, addFillPositions, addEdgePositions) { + const semiMinorAxis = options.semiMinorAxis; + const semiMajorAxis = options.semiMajorAxis; + const rotation = options.rotation; + const center = options.center; + const granularity = options.granularity * 8; + const aSqr = semiMinorAxis * semiMinorAxis; + const bSqr = semiMajorAxis * semiMajorAxis; + const ab = semiMajorAxis * semiMinorAxis; + const mag = Cartesian3_default.magnitude(center); + const unitPos = Cartesian3_default.normalize(center, unitPosScratch); + let eastVec = Cartesian3_default.cross(Cartesian3_default.UNIT_Z, center, eastVecScratch); + eastVec = Cartesian3_default.normalize(eastVec, eastVec); + const northVec = Cartesian3_default.cross(unitPos, eastVec, northVecScratch); + let numPts = 1 + Math.ceil(Math_default.PI_OVER_TWO / granularity); + const deltaTheta = Math_default.PI_OVER_TWO / (numPts - 1); + let theta = Math_default.PI_OVER_TWO - numPts * deltaTheta; + if (theta < 0) { + numPts -= Math.ceil(Math.abs(theta) / deltaTheta); + } + const size = 2 * (numPts * (numPts + 2)); + const positions = addFillPositions ? new Array(size * 3) : void 0; + let positionIndex = 0; + let position = scratchCartesian1; + let reflectedPosition = scratchCartesian2; + const outerPositionsLength = numPts * 4 * 3; + let outerRightIndex = outerPositionsLength - 1; + let outerLeftIndex = 0; + const outerPositions = addEdgePositions ? new Array(outerPositionsLength) : void 0; + let i; + let j; + let numInterior; + let t; + let interiorPosition; + theta = Math_default.PI_OVER_TWO; + position = pointOnEllipsoid( + theta, + rotation, + northVec, + eastVec, + aSqr, + ab, + bSqr, + mag, + unitPos, + position + ); + if (addFillPositions) { + positions[positionIndex++] = position.x; + positions[positionIndex++] = position.y; + positions[positionIndex++] = position.z; + } + if (addEdgePositions) { + outerPositions[outerRightIndex--] = position.z; + outerPositions[outerRightIndex--] = position.y; + outerPositions[outerRightIndex--] = position.x; + } + theta = Math_default.PI_OVER_TWO - deltaTheta; + for (i = 1; i < numPts + 1; ++i) { + position = pointOnEllipsoid( + theta, + rotation, + northVec, + eastVec, + aSqr, + ab, + bSqr, + mag, + unitPos, + position + ); + reflectedPosition = pointOnEllipsoid( + Math.PI - theta, + rotation, + northVec, + eastVec, + aSqr, + ab, + bSqr, + mag, + unitPos, + reflectedPosition + ); + if (addFillPositions) { + positions[positionIndex++] = position.x; + positions[positionIndex++] = position.y; + positions[positionIndex++] = position.z; + numInterior = 2 * i + 2; + for (j = 1; j < numInterior - 1; ++j) { + t = j / (numInterior - 1); + interiorPosition = Cartesian3_default.lerp( + position, + reflectedPosition, + t, + scratchCartesian3 + ); + positions[positionIndex++] = interiorPosition.x; + positions[positionIndex++] = interiorPosition.y; + positions[positionIndex++] = interiorPosition.z; + } + positions[positionIndex++] = reflectedPosition.x; + positions[positionIndex++] = reflectedPosition.y; + positions[positionIndex++] = reflectedPosition.z; + } + if (addEdgePositions) { + outerPositions[outerRightIndex--] = position.z; + outerPositions[outerRightIndex--] = position.y; + outerPositions[outerRightIndex--] = position.x; + outerPositions[outerLeftIndex++] = reflectedPosition.x; + outerPositions[outerLeftIndex++] = reflectedPosition.y; + outerPositions[outerLeftIndex++] = reflectedPosition.z; + } + theta = Math_default.PI_OVER_TWO - (i + 1) * deltaTheta; + } + for (i = numPts; i > 1; --i) { + theta = Math_default.PI_OVER_TWO - (i - 1) * deltaTheta; + position = pointOnEllipsoid( + -theta, + rotation, + northVec, + eastVec, + aSqr, + ab, + bSqr, + mag, + unitPos, + position + ); + reflectedPosition = pointOnEllipsoid( + theta + Math.PI, + rotation, + northVec, + eastVec, + aSqr, + ab, + bSqr, + mag, + unitPos, + reflectedPosition + ); + if (addFillPositions) { + positions[positionIndex++] = position.x; + positions[positionIndex++] = position.y; + positions[positionIndex++] = position.z; + numInterior = 2 * (i - 1) + 2; + for (j = 1; j < numInterior - 1; ++j) { + t = j / (numInterior - 1); + interiorPosition = Cartesian3_default.lerp( + position, + reflectedPosition, + t, + scratchCartesian3 + ); + positions[positionIndex++] = interiorPosition.x; + positions[positionIndex++] = interiorPosition.y; + positions[positionIndex++] = interiorPosition.z; + } + positions[positionIndex++] = reflectedPosition.x; + positions[positionIndex++] = reflectedPosition.y; + positions[positionIndex++] = reflectedPosition.z; + } + if (addEdgePositions) { + outerPositions[outerRightIndex--] = position.z; + outerPositions[outerRightIndex--] = position.y; + outerPositions[outerRightIndex--] = position.x; + outerPositions[outerLeftIndex++] = reflectedPosition.x; + outerPositions[outerLeftIndex++] = reflectedPosition.y; + outerPositions[outerLeftIndex++] = reflectedPosition.z; + } + } + theta = Math_default.PI_OVER_TWO; + position = pointOnEllipsoid( + -theta, + rotation, + northVec, + eastVec, + aSqr, + ab, + bSqr, + mag, + unitPos, + position + ); + const r = {}; + if (addFillPositions) { + positions[positionIndex++] = position.x; + positions[positionIndex++] = position.y; + positions[positionIndex++] = position.z; + r.positions = positions; + r.numPts = numPts; + } + if (addEdgePositions) { + outerPositions[outerRightIndex--] = position.z; + outerPositions[outerRightIndex--] = position.y; + outerPositions[outerRightIndex--] = position.x; + r.outerPositions = outerPositions; + } + return r; +}; +var EllipseGeometryLibrary_default = EllipseGeometryLibrary; + +export { + EllipseGeometryLibrary_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-HCZR75II.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-HCZR75II.js new file mode 100644 index 0000000000000000000000000000000000000000..c6db3ebe2df85c5ca356a4111cc721a9a5ca3642 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-HCZR75II.js @@ -0,0 +1,2716 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + AttributeCompression_default +} from "./chunk-P7PWX5HR.js"; +import { + EncodedCartesian3_default +} from "./chunk-I5MQWHBR.js"; +import { + IntersectionTests_default +} from "./chunk-QIS3NB7U.js"; +import { + Plane_default +} from "./chunk-PGB3EFR7.js"; +import { + IndexDatatype_default +} from "./chunk-TF5D2H7B.js"; +import { + GeometryAttribute_default, + GeometryType_default, + Geometry_default, + PrimitiveType_default +} from "./chunk-UGZGTV5K.js"; +import { + BoundingSphere_default, + GeographicProjection_default, + Intersect_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default, + Cartesian4_default, + Matrix4_default +} from "./chunk-PW5CA4MJ.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default, + Cartographic_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/barycentricCoordinates.js +var scratchCartesian1 = new Cartesian3_default(); +var scratchCartesian2 = new Cartesian3_default(); +var scratchCartesian3 = new Cartesian3_default(); +function barycentricCoordinates(point, p0, p1, p2, result) { + Check_default.defined("point", point); + Check_default.defined("p0", p0); + Check_default.defined("p1", p1); + Check_default.defined("p2", p2); + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + let v02; + let v12; + let v22; + let dot00; + let dot01; + let dot02; + let dot11; + let dot12; + if (!defined_default(p0.z)) { + if (Cartesian2_default.equalsEpsilon(point, p0, Math_default.EPSILON14)) { + return Cartesian3_default.clone(Cartesian3_default.UNIT_X, result); + } + if (Cartesian2_default.equalsEpsilon(point, p1, Math_default.EPSILON14)) { + return Cartesian3_default.clone(Cartesian3_default.UNIT_Y, result); + } + if (Cartesian2_default.equalsEpsilon(point, p2, Math_default.EPSILON14)) { + return Cartesian3_default.clone(Cartesian3_default.UNIT_Z, result); + } + v02 = Cartesian2_default.subtract(p1, p0, scratchCartesian1); + v12 = Cartesian2_default.subtract(p2, p0, scratchCartesian2); + v22 = Cartesian2_default.subtract(point, p0, scratchCartesian3); + dot00 = Cartesian2_default.dot(v02, v02); + dot01 = Cartesian2_default.dot(v02, v12); + dot02 = Cartesian2_default.dot(v02, v22); + dot11 = Cartesian2_default.dot(v12, v12); + dot12 = Cartesian2_default.dot(v12, v22); + } else { + if (Cartesian3_default.equalsEpsilon(point, p0, Math_default.EPSILON14)) { + return Cartesian3_default.clone(Cartesian3_default.UNIT_X, result); + } + if (Cartesian3_default.equalsEpsilon(point, p1, Math_default.EPSILON14)) { + return Cartesian3_default.clone(Cartesian3_default.UNIT_Y, result); + } + if (Cartesian3_default.equalsEpsilon(point, p2, Math_default.EPSILON14)) { + return Cartesian3_default.clone(Cartesian3_default.UNIT_Z, result); + } + v02 = Cartesian3_default.subtract(p1, p0, scratchCartesian1); + v12 = Cartesian3_default.subtract(p2, p0, scratchCartesian2); + v22 = Cartesian3_default.subtract(point, p0, scratchCartesian3); + dot00 = Cartesian3_default.dot(v02, v02); + dot01 = Cartesian3_default.dot(v02, v12); + dot02 = Cartesian3_default.dot(v02, v22); + dot11 = Cartesian3_default.dot(v12, v12); + dot12 = Cartesian3_default.dot(v12, v22); + } + result.y = dot11 * dot02 - dot01 * dot12; + result.z = dot00 * dot12 - dot01 * dot02; + const q = dot00 * dot11 - dot01 * dot01; + if (q === 0) { + return void 0; + } + result.y /= q; + result.z /= q; + result.x = 1 - result.y - result.z; + return result; +} +var barycentricCoordinates_default = barycentricCoordinates; + +// packages/engine/Source/Core/Tipsify.js +var Tipsify = {}; +Tipsify.calculateACMR = function(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const indices = options.indices; + let maximumIndex = options.maximumIndex; + const cacheSize = defaultValue_default(options.cacheSize, 24); + if (!defined_default(indices)) { + throw new DeveloperError_default("indices is required."); + } + const numIndices = indices.length; + if (numIndices < 3 || numIndices % 3 !== 0) { + throw new DeveloperError_default("indices length must be a multiple of three."); + } + if (maximumIndex <= 0) { + throw new DeveloperError_default("maximumIndex must be greater than zero."); + } + if (cacheSize < 3) { + throw new DeveloperError_default("cacheSize must be greater than two."); + } + if (!defined_default(maximumIndex)) { + maximumIndex = 0; + let currentIndex = 0; + let intoIndices = indices[currentIndex]; + while (currentIndex < numIndices) { + if (intoIndices > maximumIndex) { + maximumIndex = intoIndices; + } + ++currentIndex; + intoIndices = indices[currentIndex]; + } + } + const vertexTimeStamps = []; + for (let i = 0; i < maximumIndex + 1; i++) { + vertexTimeStamps[i] = 0; + } + let s = cacheSize + 1; + for (let j = 0; j < numIndices; ++j) { + if (s - vertexTimeStamps[indices[j]] > cacheSize) { + vertexTimeStamps[indices[j]] = s; + ++s; + } + } + return (s - cacheSize + 1) / (numIndices / 3); +}; +Tipsify.tipsify = function(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const indices = options.indices; + const maximumIndex = options.maximumIndex; + const cacheSize = defaultValue_default(options.cacheSize, 24); + let cursor; + function skipDeadEnd(vertices2, deadEnd2, indices2, maximumIndexPlusOne2) { + while (deadEnd2.length >= 1) { + const d = deadEnd2[deadEnd2.length - 1]; + deadEnd2.splice(deadEnd2.length - 1, 1); + if (vertices2[d].numLiveTriangles > 0) { + return d; + } + } + while (cursor < maximumIndexPlusOne2) { + if (vertices2[cursor].numLiveTriangles > 0) { + ++cursor; + return cursor - 1; + } + ++cursor; + } + return -1; + } + function getNextVertex(indices2, cacheSize2, oneRing2, vertices2, s2, deadEnd2, maximumIndexPlusOne2) { + let n = -1; + let p; + let m = -1; + let itOneRing = 0; + while (itOneRing < oneRing2.length) { + const index2 = oneRing2[itOneRing]; + if (vertices2[index2].numLiveTriangles) { + p = 0; + if (s2 - vertices2[index2].timeStamp + 2 * vertices2[index2].numLiveTriangles <= cacheSize2) { + p = s2 - vertices2[index2].timeStamp; + } + if (p > m || m === -1) { + m = p; + n = index2; + } + } + ++itOneRing; + } + if (n === -1) { + return skipDeadEnd(vertices2, deadEnd2, indices2, maximumIndexPlusOne2); + } + return n; + } + if (!defined_default(indices)) { + throw new DeveloperError_default("indices is required."); + } + const numIndices = indices.length; + if (numIndices < 3 || numIndices % 3 !== 0) { + throw new DeveloperError_default("indices length must be a multiple of three."); + } + if (maximumIndex <= 0) { + throw new DeveloperError_default("maximumIndex must be greater than zero."); + } + if (cacheSize < 3) { + throw new DeveloperError_default("cacheSize must be greater than two."); + } + let maximumIndexPlusOne = 0; + let currentIndex = 0; + let intoIndices = indices[currentIndex]; + const endIndex = numIndices; + if (defined_default(maximumIndex)) { + maximumIndexPlusOne = maximumIndex + 1; + } else { + while (currentIndex < endIndex) { + if (intoIndices > maximumIndexPlusOne) { + maximumIndexPlusOne = intoIndices; + } + ++currentIndex; + intoIndices = indices[currentIndex]; + } + if (maximumIndexPlusOne === -1) { + return 0; + } + ++maximumIndexPlusOne; + } + const vertices = []; + let i; + for (i = 0; i < maximumIndexPlusOne; i++) { + vertices[i] = { + numLiveTriangles: 0, + timeStamp: 0, + vertexTriangles: [] + }; + } + currentIndex = 0; + let triangle = 0; + while (currentIndex < endIndex) { + vertices[indices[currentIndex]].vertexTriangles.push(triangle); + ++vertices[indices[currentIndex]].numLiveTriangles; + vertices[indices[currentIndex + 1]].vertexTriangles.push(triangle); + ++vertices[indices[currentIndex + 1]].numLiveTriangles; + vertices[indices[currentIndex + 2]].vertexTriangles.push(triangle); + ++vertices[indices[currentIndex + 2]].numLiveTriangles; + ++triangle; + currentIndex += 3; + } + let f = 0; + let s = cacheSize + 1; + cursor = 1; + let oneRing = []; + const deadEnd = []; + let vertex; + let intoVertices; + let currentOutputIndex = 0; + const outputIndices = []; + const numTriangles = numIndices / 3; + const triangleEmitted = []; + for (i = 0; i < numTriangles; i++) { + triangleEmitted[i] = false; + } + let index; + let limit; + while (f !== -1) { + oneRing = []; + intoVertices = vertices[f]; + limit = intoVertices.vertexTriangles.length; + for (let k = 0; k < limit; ++k) { + triangle = intoVertices.vertexTriangles[k]; + if (!triangleEmitted[triangle]) { + triangleEmitted[triangle] = true; + currentIndex = triangle + triangle + triangle; + for (let j = 0; j < 3; ++j) { + index = indices[currentIndex]; + oneRing.push(index); + deadEnd.push(index); + outputIndices[currentOutputIndex] = index; + ++currentOutputIndex; + vertex = vertices[index]; + --vertex.numLiveTriangles; + if (s - vertex.timeStamp > cacheSize) { + vertex.timeStamp = s; + ++s; + } + ++currentIndex; + } + } + } + f = getNextVertex( + indices, + cacheSize, + oneRing, + vertices, + s, + deadEnd, + maximumIndexPlusOne + ); + } + return outputIndices; +}; +var Tipsify_default = Tipsify; + +// packages/engine/Source/Core/GeometryPipeline.js +var GeometryPipeline = {}; +function addTriangle(lines, index, i0, i1, i2) { + lines[index++] = i0; + lines[index++] = i1; + lines[index++] = i1; + lines[index++] = i2; + lines[index++] = i2; + lines[index] = i0; +} +function trianglesToLines(triangles) { + const count = triangles.length; + const size = count / 3 * 6; + const lines = IndexDatatype_default.createTypedArray(count, size); + let index = 0; + for (let i = 0; i < count; i += 3, index += 6) { + addTriangle(lines, index, triangles[i], triangles[i + 1], triangles[i + 2]); + } + return lines; +} +function triangleStripToLines(triangles) { + const count = triangles.length; + if (count >= 3) { + const size = (count - 2) * 6; + const lines = IndexDatatype_default.createTypedArray(count, size); + addTriangle(lines, 0, triangles[0], triangles[1], triangles[2]); + let index = 6; + for (let i = 3; i < count; ++i, index += 6) { + addTriangle( + lines, + index, + triangles[i - 1], + triangles[i], + triangles[i - 2] + ); + } + return lines; + } + return new Uint16Array(); +} +function triangleFanToLines(triangles) { + if (triangles.length > 0) { + const count = triangles.length - 1; + const size = (count - 1) * 6; + const lines = IndexDatatype_default.createTypedArray(count, size); + const base = triangles[0]; + let index = 0; + for (let i = 1; i < count; ++i, index += 6) { + addTriangle(lines, index, base, triangles[i], triangles[i + 1]); + } + return lines; + } + return new Uint16Array(); +} +GeometryPipeline.toWireframe = function(geometry) { + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + const indices = geometry.indices; + if (defined_default(indices)) { + switch (geometry.primitiveType) { + case PrimitiveType_default.TRIANGLES: + geometry.indices = trianglesToLines(indices); + break; + case PrimitiveType_default.TRIANGLE_STRIP: + geometry.indices = triangleStripToLines(indices); + break; + case PrimitiveType_default.TRIANGLE_FAN: + geometry.indices = triangleFanToLines(indices); + break; + default: + throw new DeveloperError_default( + "geometry.primitiveType must be TRIANGLES, TRIANGLE_STRIP, or TRIANGLE_FAN." + ); + } + geometry.primitiveType = PrimitiveType_default.LINES; + } + return geometry; +}; +GeometryPipeline.createLineSegmentsForVectors = function(geometry, attributeName, length) { + attributeName = defaultValue_default(attributeName, "normal"); + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + if (!defined_default(geometry.attributes.position)) { + throw new DeveloperError_default("geometry.attributes.position is required."); + } + if (!defined_default(geometry.attributes[attributeName])) { + throw new DeveloperError_default( + `geometry.attributes must have an attribute with the same name as the attributeName parameter, ${attributeName}.` + ); + } + length = defaultValue_default(length, 1e4); + const positions = geometry.attributes.position.values; + const vectors = geometry.attributes[attributeName].values; + const positionsLength = positions.length; + const newPositions = new Float64Array(2 * positionsLength); + let j = 0; + for (let i = 0; i < positionsLength; i += 3) { + newPositions[j++] = positions[i]; + newPositions[j++] = positions[i + 1]; + newPositions[j++] = positions[i + 2]; + newPositions[j++] = positions[i] + vectors[i] * length; + newPositions[j++] = positions[i + 1] + vectors[i + 1] * length; + newPositions[j++] = positions[i + 2] + vectors[i + 2] * length; + } + let newBoundingSphere; + const bs = geometry.boundingSphere; + if (defined_default(bs)) { + newBoundingSphere = new BoundingSphere_default(bs.center, bs.radius + length); + } + return new Geometry_default({ + attributes: { + position: new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: newPositions + }) + }, + primitiveType: PrimitiveType_default.LINES, + boundingSphere: newBoundingSphere + }); +}; +GeometryPipeline.createAttributeLocations = function(geometry) { + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + const semantics = [ + "position", + "positionHigh", + "positionLow", + // From VertexFormat.position - after 2D projection and high-precision encoding + "position3DHigh", + "position3DLow", + "position2DHigh", + "position2DLow", + // From Primitive + "pickColor", + // From VertexFormat + "normal", + "st", + "tangent", + "bitangent", + // For shadow volumes + "extrudeDirection", + // From compressing texture coordinates and normals + "compressedAttributes" + ]; + const attributes = geometry.attributes; + const indices = {}; + let j = 0; + let i; + const len = semantics.length; + for (i = 0; i < len; ++i) { + const semantic = semantics[i]; + if (defined_default(attributes[semantic])) { + indices[semantic] = j++; + } + } + for (const name in attributes) { + if (attributes.hasOwnProperty(name) && !defined_default(indices[name])) { + indices[name] = j++; + } + } + return indices; +}; +GeometryPipeline.reorderForPreVertexCache = function(geometry) { + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + const numVertices = Geometry_default.computeNumberOfVertices(geometry); + const indices = geometry.indices; + if (defined_default(indices)) { + const indexCrossReferenceOldToNew = new Int32Array(numVertices); + for (let i = 0; i < numVertices; i++) { + indexCrossReferenceOldToNew[i] = -1; + } + const indicesIn = indices; + const numIndices = indicesIn.length; + const indicesOut = IndexDatatype_default.createTypedArray(numVertices, numIndices); + let intoIndicesIn = 0; + let intoIndicesOut = 0; + let nextIndex = 0; + let tempIndex; + while (intoIndicesIn < numIndices) { + tempIndex = indexCrossReferenceOldToNew[indicesIn[intoIndicesIn]]; + if (tempIndex !== -1) { + indicesOut[intoIndicesOut] = tempIndex; + } else { + tempIndex = indicesIn[intoIndicesIn]; + indexCrossReferenceOldToNew[tempIndex] = nextIndex; + indicesOut[intoIndicesOut] = nextIndex; + ++nextIndex; + } + ++intoIndicesIn; + ++intoIndicesOut; + } + geometry.indices = indicesOut; + const attributes = geometry.attributes; + for (const property in attributes) { + if (attributes.hasOwnProperty(property) && defined_default(attributes[property]) && defined_default(attributes[property].values)) { + const attribute = attributes[property]; + const elementsIn = attribute.values; + let intoElementsIn = 0; + const numComponents = attribute.componentsPerAttribute; + const elementsOut = ComponentDatatype_default.createTypedArray( + attribute.componentDatatype, + nextIndex * numComponents + ); + while (intoElementsIn < numVertices) { + const temp = indexCrossReferenceOldToNew[intoElementsIn]; + if (temp !== -1) { + for (let j = 0; j < numComponents; j++) { + elementsOut[numComponents * temp + j] = elementsIn[numComponents * intoElementsIn + j]; + } + } + ++intoElementsIn; + } + attribute.values = elementsOut; + } + } + } + return geometry; +}; +GeometryPipeline.reorderForPostVertexCache = function(geometry, cacheCapacity) { + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + const indices = geometry.indices; + if (geometry.primitiveType === PrimitiveType_default.TRIANGLES && defined_default(indices)) { + const numIndices = indices.length; + let maximumIndex = 0; + for (let j = 0; j < numIndices; j++) { + if (indices[j] > maximumIndex) { + maximumIndex = indices[j]; + } + } + geometry.indices = Tipsify_default.tipsify({ + indices, + maximumIndex, + cacheSize: cacheCapacity + }); + } + return geometry; +}; +function copyAttributesDescriptions(attributes) { + const newAttributes = {}; + for (const attribute in attributes) { + if (attributes.hasOwnProperty(attribute) && defined_default(attributes[attribute]) && defined_default(attributes[attribute].values)) { + const attr = attributes[attribute]; + newAttributes[attribute] = new GeometryAttribute_default({ + componentDatatype: attr.componentDatatype, + componentsPerAttribute: attr.componentsPerAttribute, + normalize: attr.normalize, + values: [] + }); + } + } + return newAttributes; +} +function copyVertex(destinationAttributes, sourceAttributes, index) { + for (const attribute in sourceAttributes) { + if (sourceAttributes.hasOwnProperty(attribute) && defined_default(sourceAttributes[attribute]) && defined_default(sourceAttributes[attribute].values)) { + const attr = sourceAttributes[attribute]; + for (let k = 0; k < attr.componentsPerAttribute; ++k) { + destinationAttributes[attribute].values.push( + attr.values[index * attr.componentsPerAttribute + k] + ); + } + } + } +} +GeometryPipeline.fitToUnsignedShortIndices = function(geometry) { + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + if (defined_default(geometry.indices) && geometry.primitiveType !== PrimitiveType_default.TRIANGLES && geometry.primitiveType !== PrimitiveType_default.LINES && geometry.primitiveType !== PrimitiveType_default.POINTS) { + throw new DeveloperError_default( + "geometry.primitiveType must equal to PrimitiveType.TRIANGLES, PrimitiveType.LINES, or PrimitiveType.POINTS." + ); + } + const geometries = []; + const numberOfVertices = Geometry_default.computeNumberOfVertices(geometry); + if (defined_default(geometry.indices) && numberOfVertices >= Math_default.SIXTY_FOUR_KILOBYTES) { + let oldToNewIndex = []; + let newIndices = []; + let currentIndex = 0; + let newAttributes = copyAttributesDescriptions(geometry.attributes); + const originalIndices = geometry.indices; + const numberOfIndices = originalIndices.length; + let indicesPerPrimitive; + if (geometry.primitiveType === PrimitiveType_default.TRIANGLES) { + indicesPerPrimitive = 3; + } else if (geometry.primitiveType === PrimitiveType_default.LINES) { + indicesPerPrimitive = 2; + } else if (geometry.primitiveType === PrimitiveType_default.POINTS) { + indicesPerPrimitive = 1; + } + for (let j = 0; j < numberOfIndices; j += indicesPerPrimitive) { + for (let k = 0; k < indicesPerPrimitive; ++k) { + const x = originalIndices[j + k]; + let i = oldToNewIndex[x]; + if (!defined_default(i)) { + i = currentIndex++; + oldToNewIndex[x] = i; + copyVertex(newAttributes, geometry.attributes, x); + } + newIndices.push(i); + } + if (currentIndex + indicesPerPrimitive >= Math_default.SIXTY_FOUR_KILOBYTES) { + geometries.push( + new Geometry_default({ + attributes: newAttributes, + indices: newIndices, + primitiveType: geometry.primitiveType, + boundingSphere: geometry.boundingSphere, + boundingSphereCV: geometry.boundingSphereCV + }) + ); + oldToNewIndex = []; + newIndices = []; + currentIndex = 0; + newAttributes = copyAttributesDescriptions(geometry.attributes); + } + } + if (newIndices.length !== 0) { + geometries.push( + new Geometry_default({ + attributes: newAttributes, + indices: newIndices, + primitiveType: geometry.primitiveType, + boundingSphere: geometry.boundingSphere, + boundingSphereCV: geometry.boundingSphereCV + }) + ); + } + } else { + geometries.push(geometry); + } + return geometries; +}; +var scratchProjectTo2DCartesian3 = new Cartesian3_default(); +var scratchProjectTo2DCartographic = new Cartographic_default(); +GeometryPipeline.projectTo2D = function(geometry, attributeName, attributeName3D, attributeName2D, projection) { + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + if (!defined_default(attributeName)) { + throw new DeveloperError_default("attributeName is required."); + } + if (!defined_default(attributeName3D)) { + throw new DeveloperError_default("attributeName3D is required."); + } + if (!defined_default(attributeName2D)) { + throw new DeveloperError_default("attributeName2D is required."); + } + if (!defined_default(geometry.attributes[attributeName])) { + throw new DeveloperError_default( + `geometry must have attribute matching the attributeName argument: ${attributeName}.` + ); + } + if (geometry.attributes[attributeName].componentDatatype !== ComponentDatatype_default.DOUBLE) { + throw new DeveloperError_default( + "The attribute componentDatatype must be ComponentDatatype.DOUBLE." + ); + } + const attribute = geometry.attributes[attributeName]; + projection = defined_default(projection) ? projection : new GeographicProjection_default(); + const ellipsoid = projection.ellipsoid; + const values3D = attribute.values; + const projectedValues = new Float64Array(values3D.length); + let index = 0; + for (let i = 0; i < values3D.length; i += 3) { + const value = Cartesian3_default.fromArray( + values3D, + i, + scratchProjectTo2DCartesian3 + ); + const lonLat = ellipsoid.cartesianToCartographic( + value, + scratchProjectTo2DCartographic + ); + if (!defined_default(lonLat)) { + throw new DeveloperError_default( + `Could not project point (${value.x}, ${value.y}, ${value.z}) to 2D.` + ); + } + const projectedLonLat = projection.project( + lonLat, + scratchProjectTo2DCartesian3 + ); + projectedValues[index++] = projectedLonLat.x; + projectedValues[index++] = projectedLonLat.y; + projectedValues[index++] = projectedLonLat.z; + } + geometry.attributes[attributeName3D] = attribute; + geometry.attributes[attributeName2D] = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: projectedValues + }); + delete geometry.attributes[attributeName]; + return geometry; +}; +var encodedResult = { + high: 0, + low: 0 +}; +GeometryPipeline.encodeAttribute = function(geometry, attributeName, attributeHighName, attributeLowName) { + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + if (!defined_default(attributeName)) { + throw new DeveloperError_default("attributeName is required."); + } + if (!defined_default(attributeHighName)) { + throw new DeveloperError_default("attributeHighName is required."); + } + if (!defined_default(attributeLowName)) { + throw new DeveloperError_default("attributeLowName is required."); + } + if (!defined_default(geometry.attributes[attributeName])) { + throw new DeveloperError_default( + `geometry must have attribute matching the attributeName argument: ${attributeName}.` + ); + } + if (geometry.attributes[attributeName].componentDatatype !== ComponentDatatype_default.DOUBLE) { + throw new DeveloperError_default( + "The attribute componentDatatype must be ComponentDatatype.DOUBLE." + ); + } + const attribute = geometry.attributes[attributeName]; + const values = attribute.values; + const length = values.length; + const highValues = new Float32Array(length); + const lowValues = new Float32Array(length); + for (let i = 0; i < length; ++i) { + EncodedCartesian3_default.encode(values[i], encodedResult); + highValues[i] = encodedResult.high; + lowValues[i] = encodedResult.low; + } + const componentsPerAttribute = attribute.componentsPerAttribute; + geometry.attributes[attributeHighName] = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute, + values: highValues + }); + geometry.attributes[attributeLowName] = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute, + values: lowValues + }); + delete geometry.attributes[attributeName]; + return geometry; +}; +var scratchCartesian32 = new Cartesian3_default(); +function transformPoint(matrix, attribute) { + if (defined_default(attribute)) { + const values = attribute.values; + const length = values.length; + for (let i = 0; i < length; i += 3) { + Cartesian3_default.unpack(values, i, scratchCartesian32); + Matrix4_default.multiplyByPoint(matrix, scratchCartesian32, scratchCartesian32); + Cartesian3_default.pack(scratchCartesian32, values, i); + } + } +} +function transformVector(matrix, attribute) { + if (defined_default(attribute)) { + const values = attribute.values; + const length = values.length; + for (let i = 0; i < length; i += 3) { + Cartesian3_default.unpack(values, i, scratchCartesian32); + Matrix3_default.multiplyByVector(matrix, scratchCartesian32, scratchCartesian32); + scratchCartesian32 = Cartesian3_default.normalize( + scratchCartesian32, + scratchCartesian32 + ); + Cartesian3_default.pack(scratchCartesian32, values, i); + } + } +} +var inverseTranspose = new Matrix4_default(); +var normalMatrix = new Matrix3_default(); +GeometryPipeline.transformToWorldCoordinates = function(instance) { + if (!defined_default(instance)) { + throw new DeveloperError_default("instance is required."); + } + const modelMatrix = instance.modelMatrix; + if (Matrix4_default.equals(modelMatrix, Matrix4_default.IDENTITY)) { + return instance; + } + const attributes = instance.geometry.attributes; + transformPoint(modelMatrix, attributes.position); + transformPoint(modelMatrix, attributes.prevPosition); + transformPoint(modelMatrix, attributes.nextPosition); + if (defined_default(attributes.normal) || defined_default(attributes.tangent) || defined_default(attributes.bitangent)) { + Matrix4_default.inverse(modelMatrix, inverseTranspose); + Matrix4_default.transpose(inverseTranspose, inverseTranspose); + Matrix4_default.getMatrix3(inverseTranspose, normalMatrix); + transformVector(normalMatrix, attributes.normal); + transformVector(normalMatrix, attributes.tangent); + transformVector(normalMatrix, attributes.bitangent); + } + const boundingSphere = instance.geometry.boundingSphere; + if (defined_default(boundingSphere)) { + instance.geometry.boundingSphere = BoundingSphere_default.transform( + boundingSphere, + modelMatrix, + boundingSphere + ); + } + instance.modelMatrix = Matrix4_default.clone(Matrix4_default.IDENTITY); + return instance; +}; +function findAttributesInAllGeometries(instances, propertyName) { + const length = instances.length; + const attributesInAllGeometries = {}; + const attributes0 = instances[0][propertyName].attributes; + let name; + for (name in attributes0) { + if (attributes0.hasOwnProperty(name) && defined_default(attributes0[name]) && defined_default(attributes0[name].values)) { + const attribute = attributes0[name]; + let numberOfComponents = attribute.values.length; + let inAllGeometries = true; + for (let i = 1; i < length; ++i) { + const otherAttribute = instances[i][propertyName].attributes[name]; + if (!defined_default(otherAttribute) || attribute.componentDatatype !== otherAttribute.componentDatatype || attribute.componentsPerAttribute !== otherAttribute.componentsPerAttribute || attribute.normalize !== otherAttribute.normalize) { + inAllGeometries = false; + break; + } + numberOfComponents += otherAttribute.values.length; + } + if (inAllGeometries) { + attributesInAllGeometries[name] = new GeometryAttribute_default({ + componentDatatype: attribute.componentDatatype, + componentsPerAttribute: attribute.componentsPerAttribute, + normalize: attribute.normalize, + values: ComponentDatatype_default.createTypedArray( + attribute.componentDatatype, + numberOfComponents + ) + }); + } + } + } + return attributesInAllGeometries; +} +var tempScratch = new Cartesian3_default(); +function combineGeometries(instances, propertyName) { + const length = instances.length; + let name; + let i; + let j; + let k; + const m = instances[0].modelMatrix; + const haveIndices = defined_default(instances[0][propertyName].indices); + const primitiveType = instances[0][propertyName].primitiveType; + for (i = 1; i < length; ++i) { + if (!Matrix4_default.equals(instances[i].modelMatrix, m)) { + throw new DeveloperError_default("All instances must have the same modelMatrix."); + } + if (defined_default(instances[i][propertyName].indices) !== haveIndices) { + throw new DeveloperError_default( + "All instance geometries must have an indices or not have one." + ); + } + if (instances[i][propertyName].primitiveType !== primitiveType) { + throw new DeveloperError_default( + "All instance geometries must have the same primitiveType." + ); + } + } + const attributes = findAttributesInAllGeometries(instances, propertyName); + let values; + let sourceValues; + let sourceValuesLength; + for (name in attributes) { + if (attributes.hasOwnProperty(name)) { + values = attributes[name].values; + k = 0; + for (i = 0; i < length; ++i) { + sourceValues = instances[i][propertyName].attributes[name].values; + sourceValuesLength = sourceValues.length; + for (j = 0; j < sourceValuesLength; ++j) { + values[k++] = sourceValues[j]; + } + } + } + } + let indices; + if (haveIndices) { + let numberOfIndices = 0; + for (i = 0; i < length; ++i) { + numberOfIndices += instances[i][propertyName].indices.length; + } + const numberOfVertices = Geometry_default.computeNumberOfVertices( + new Geometry_default({ + attributes, + primitiveType: PrimitiveType_default.POINTS + }) + ); + const destIndices = IndexDatatype_default.createTypedArray( + numberOfVertices, + numberOfIndices + ); + let destOffset = 0; + let offset = 0; + for (i = 0; i < length; ++i) { + const sourceIndices = instances[i][propertyName].indices; + const sourceIndicesLen = sourceIndices.length; + for (k = 0; k < sourceIndicesLen; ++k) { + destIndices[destOffset++] = offset + sourceIndices[k]; + } + offset += Geometry_default.computeNumberOfVertices(instances[i][propertyName]); + } + indices = destIndices; + } + let center = new Cartesian3_default(); + let radius = 0; + let bs; + for (i = 0; i < length; ++i) { + bs = instances[i][propertyName].boundingSphere; + if (!defined_default(bs)) { + center = void 0; + break; + } + Cartesian3_default.add(bs.center, center, center); + } + if (defined_default(center)) { + Cartesian3_default.divideByScalar(center, length, center); + for (i = 0; i < length; ++i) { + bs = instances[i][propertyName].boundingSphere; + const tempRadius = Cartesian3_default.magnitude( + Cartesian3_default.subtract(bs.center, center, tempScratch) + ) + bs.radius; + if (tempRadius > radius) { + radius = tempRadius; + } + } + } + return new Geometry_default({ + attributes, + indices, + primitiveType, + boundingSphere: defined_default(center) ? new BoundingSphere_default(center, radius) : void 0 + }); +} +GeometryPipeline.combineInstances = function(instances) { + if (!defined_default(instances) || instances.length < 1) { + throw new DeveloperError_default( + "instances is required and must have length greater than zero." + ); + } + const instanceGeometry = []; + const instanceSplitGeometry = []; + const length = instances.length; + for (let i = 0; i < length; ++i) { + const instance = instances[i]; + if (defined_default(instance.geometry)) { + instanceGeometry.push(instance); + } else if (defined_default(instance.westHemisphereGeometry) && defined_default(instance.eastHemisphereGeometry)) { + instanceSplitGeometry.push(instance); + } + } + const geometries = []; + if (instanceGeometry.length > 0) { + geometries.push(combineGeometries(instanceGeometry, "geometry")); + } + if (instanceSplitGeometry.length > 0) { + geometries.push( + combineGeometries(instanceSplitGeometry, "westHemisphereGeometry") + ); + geometries.push( + combineGeometries(instanceSplitGeometry, "eastHemisphereGeometry") + ); + } + return geometries; +}; +var normal = new Cartesian3_default(); +var v0 = new Cartesian3_default(); +var v1 = new Cartesian3_default(); +var v2 = new Cartesian3_default(); +GeometryPipeline.computeNormal = function(geometry) { + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + if (!defined_default(geometry.attributes.position) || !defined_default(geometry.attributes.position.values)) { + throw new DeveloperError_default( + "geometry.attributes.position.values is required." + ); + } + if (!defined_default(geometry.indices)) { + throw new DeveloperError_default("geometry.indices is required."); + } + if (geometry.indices.length < 2 || geometry.indices.length % 3 !== 0) { + throw new DeveloperError_default( + "geometry.indices length must be greater than 0 and be a multiple of 3." + ); + } + if (geometry.primitiveType !== PrimitiveType_default.TRIANGLES) { + throw new DeveloperError_default( + "geometry.primitiveType must be PrimitiveType.TRIANGLES." + ); + } + const indices = geometry.indices; + const attributes = geometry.attributes; + const vertices = attributes.position.values; + const numVertices = attributes.position.values.length / 3; + const numIndices = indices.length; + const normalsPerVertex = new Array(numVertices); + const normalsPerTriangle = new Array(numIndices / 3); + const normalIndices = new Array(numIndices); + let i; + for (i = 0; i < numVertices; i++) { + normalsPerVertex[i] = { + indexOffset: 0, + count: 0, + currentCount: 0 + }; + } + let j = 0; + for (i = 0; i < numIndices; i += 3) { + const i0 = indices[i]; + const i1 = indices[i + 1]; + const i2 = indices[i + 2]; + const i03 = i0 * 3; + const i13 = i1 * 3; + const i23 = i2 * 3; + v0.x = vertices[i03]; + v0.y = vertices[i03 + 1]; + v0.z = vertices[i03 + 2]; + v1.x = vertices[i13]; + v1.y = vertices[i13 + 1]; + v1.z = vertices[i13 + 2]; + v2.x = vertices[i23]; + v2.y = vertices[i23 + 1]; + v2.z = vertices[i23 + 2]; + normalsPerVertex[i0].count++; + normalsPerVertex[i1].count++; + normalsPerVertex[i2].count++; + Cartesian3_default.subtract(v1, v0, v1); + Cartesian3_default.subtract(v2, v0, v2); + normalsPerTriangle[j] = Cartesian3_default.cross(v1, v2, new Cartesian3_default()); + j++; + } + let indexOffset = 0; + for (i = 0; i < numVertices; i++) { + normalsPerVertex[i].indexOffset += indexOffset; + indexOffset += normalsPerVertex[i].count; + } + j = 0; + let vertexNormalData; + for (i = 0; i < numIndices; i += 3) { + vertexNormalData = normalsPerVertex[indices[i]]; + let index = vertexNormalData.indexOffset + vertexNormalData.currentCount; + normalIndices[index] = j; + vertexNormalData.currentCount++; + vertexNormalData = normalsPerVertex[indices[i + 1]]; + index = vertexNormalData.indexOffset + vertexNormalData.currentCount; + normalIndices[index] = j; + vertexNormalData.currentCount++; + vertexNormalData = normalsPerVertex[indices[i + 2]]; + index = vertexNormalData.indexOffset + vertexNormalData.currentCount; + normalIndices[index] = j; + vertexNormalData.currentCount++; + j++; + } + const normalValues = new Float32Array(numVertices * 3); + for (i = 0; i < numVertices; i++) { + const i3 = i * 3; + vertexNormalData = normalsPerVertex[i]; + Cartesian3_default.clone(Cartesian3_default.ZERO, normal); + if (vertexNormalData.count > 0) { + for (j = 0; j < vertexNormalData.count; j++) { + Cartesian3_default.add( + normal, + normalsPerTriangle[normalIndices[vertexNormalData.indexOffset + j]], + normal + ); + } + if (Cartesian3_default.equalsEpsilon(Cartesian3_default.ZERO, normal, Math_default.EPSILON10)) { + Cartesian3_default.clone( + normalsPerTriangle[normalIndices[vertexNormalData.indexOffset]], + normal + ); + } + } + if (Cartesian3_default.equalsEpsilon(Cartesian3_default.ZERO, normal, Math_default.EPSILON10)) { + normal.z = 1; + } + Cartesian3_default.normalize(normal, normal); + normalValues[i3] = normal.x; + normalValues[i3 + 1] = normal.y; + normalValues[i3 + 2] = normal.z; + } + geometry.attributes.normal = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: normalValues + }); + return geometry; +}; +var normalScratch = new Cartesian3_default(); +var normalScale = new Cartesian3_default(); +var tScratch = new Cartesian3_default(); +GeometryPipeline.computeTangentAndBitangent = function(geometry) { + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + const attributes = geometry.attributes; + const indices = geometry.indices; + if (!defined_default(attributes.position) || !defined_default(attributes.position.values)) { + throw new DeveloperError_default( + "geometry.attributes.position.values is required." + ); + } + if (!defined_default(attributes.normal) || !defined_default(attributes.normal.values)) { + throw new DeveloperError_default("geometry.attributes.normal.values is required."); + } + if (!defined_default(attributes.st) || !defined_default(attributes.st.values)) { + throw new DeveloperError_default("geometry.attributes.st.values is required."); + } + if (!defined_default(indices)) { + throw new DeveloperError_default("geometry.indices is required."); + } + if (indices.length < 2 || indices.length % 3 !== 0) { + throw new DeveloperError_default( + "geometry.indices length must be greater than 0 and be a multiple of 3." + ); + } + if (geometry.primitiveType !== PrimitiveType_default.TRIANGLES) { + throw new DeveloperError_default( + "geometry.primitiveType must be PrimitiveType.TRIANGLES." + ); + } + const vertices = geometry.attributes.position.values; + const normals = geometry.attributes.normal.values; + const st = geometry.attributes.st.values; + const numVertices = geometry.attributes.position.values.length / 3; + const numIndices = indices.length; + const tan1 = new Array(numVertices * 3); + let i; + for (i = 0; i < tan1.length; i++) { + tan1[i] = 0; + } + let i03; + let i13; + let i23; + for (i = 0; i < numIndices; i += 3) { + const i0 = indices[i]; + const i1 = indices[i + 1]; + const i2 = indices[i + 2]; + i03 = i0 * 3; + i13 = i1 * 3; + i23 = i2 * 3; + const i02 = i0 * 2; + const i12 = i1 * 2; + const i22 = i2 * 2; + const ux = vertices[i03]; + const uy = vertices[i03 + 1]; + const uz = vertices[i03 + 2]; + const wx = st[i02]; + const wy = st[i02 + 1]; + const t1 = st[i12 + 1] - wy; + const t2 = st[i22 + 1] - wy; + const r = 1 / ((st[i12] - wx) * t2 - (st[i22] - wx) * t1); + const sdirx = (t2 * (vertices[i13] - ux) - t1 * (vertices[i23] - ux)) * r; + const sdiry = (t2 * (vertices[i13 + 1] - uy) - t1 * (vertices[i23 + 1] - uy)) * r; + const sdirz = (t2 * (vertices[i13 + 2] - uz) - t1 * (vertices[i23 + 2] - uz)) * r; + tan1[i03] += sdirx; + tan1[i03 + 1] += sdiry; + tan1[i03 + 2] += sdirz; + tan1[i13] += sdirx; + tan1[i13 + 1] += sdiry; + tan1[i13 + 2] += sdirz; + tan1[i23] += sdirx; + tan1[i23 + 1] += sdiry; + tan1[i23 + 2] += sdirz; + } + const tangentValues = new Float32Array(numVertices * 3); + const bitangentValues = new Float32Array(numVertices * 3); + for (i = 0; i < numVertices; i++) { + i03 = i * 3; + i13 = i03 + 1; + i23 = i03 + 2; + const n = Cartesian3_default.fromArray(normals, i03, normalScratch); + const t = Cartesian3_default.fromArray(tan1, i03, tScratch); + const scalar = Cartesian3_default.dot(n, t); + Cartesian3_default.multiplyByScalar(n, scalar, normalScale); + Cartesian3_default.normalize(Cartesian3_default.subtract(t, normalScale, t), t); + tangentValues[i03] = t.x; + tangentValues[i13] = t.y; + tangentValues[i23] = t.z; + Cartesian3_default.normalize(Cartesian3_default.cross(n, t, t), t); + bitangentValues[i03] = t.x; + bitangentValues[i13] = t.y; + bitangentValues[i23] = t.z; + } + geometry.attributes.tangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: tangentValues + }); + geometry.attributes.bitangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: bitangentValues + }); + return geometry; +}; +var scratchCartesian22 = new Cartesian2_default(); +var toEncode1 = new Cartesian3_default(); +var toEncode2 = new Cartesian3_default(); +var toEncode3 = new Cartesian3_default(); +var encodeResult2 = new Cartesian2_default(); +GeometryPipeline.compressVertices = function(geometry) { + if (!defined_default(geometry)) { + throw new DeveloperError_default("geometry is required."); + } + const extrudeAttribute = geometry.attributes.extrudeDirection; + let i; + let numVertices; + if (defined_default(extrudeAttribute)) { + const extrudeDirections = extrudeAttribute.values; + numVertices = extrudeDirections.length / 3; + const compressedDirections = new Float32Array(numVertices * 2); + let i2 = 0; + for (i = 0; i < numVertices; ++i) { + Cartesian3_default.fromArray(extrudeDirections, i * 3, toEncode1); + if (Cartesian3_default.equals(toEncode1, Cartesian3_default.ZERO)) { + i2 += 2; + continue; + } + encodeResult2 = AttributeCompression_default.octEncodeInRange( + toEncode1, + 65535, + encodeResult2 + ); + compressedDirections[i2++] = encodeResult2.x; + compressedDirections[i2++] = encodeResult2.y; + } + geometry.attributes.compressedAttributes = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: compressedDirections + }); + delete geometry.attributes.extrudeDirection; + return geometry; + } + const normalAttribute = geometry.attributes.normal; + const stAttribute = geometry.attributes.st; + const hasNormal = defined_default(normalAttribute); + const hasSt = defined_default(stAttribute); + if (!hasNormal && !hasSt) { + return geometry; + } + const tangentAttribute = geometry.attributes.tangent; + const bitangentAttribute = geometry.attributes.bitangent; + const hasTangent = defined_default(tangentAttribute); + const hasBitangent = defined_default(bitangentAttribute); + let normals; + let st; + let tangents; + let bitangents; + if (hasNormal) { + normals = normalAttribute.values; + } + if (hasSt) { + st = stAttribute.values; + } + if (hasTangent) { + tangents = tangentAttribute.values; + } + if (hasBitangent) { + bitangents = bitangentAttribute.values; + } + const length = hasNormal ? normals.length : st.length; + const numComponents = hasNormal ? 3 : 2; + numVertices = length / numComponents; + let compressedLength = numVertices; + let numCompressedComponents = hasSt && hasNormal ? 2 : 1; + numCompressedComponents += hasTangent || hasBitangent ? 1 : 0; + compressedLength *= numCompressedComponents; + const compressedAttributes = new Float32Array(compressedLength); + let normalIndex = 0; + for (i = 0; i < numVertices; ++i) { + if (hasSt) { + Cartesian2_default.fromArray(st, i * 2, scratchCartesian22); + compressedAttributes[normalIndex++] = AttributeCompression_default.compressTextureCoordinates(scratchCartesian22); + } + const index = i * 3; + if (hasNormal && defined_default(tangents) && defined_default(bitangents)) { + Cartesian3_default.fromArray(normals, index, toEncode1); + Cartesian3_default.fromArray(tangents, index, toEncode2); + Cartesian3_default.fromArray(bitangents, index, toEncode3); + AttributeCompression_default.octPack( + toEncode1, + toEncode2, + toEncode3, + scratchCartesian22 + ); + compressedAttributes[normalIndex++] = scratchCartesian22.x; + compressedAttributes[normalIndex++] = scratchCartesian22.y; + } else { + if (hasNormal) { + Cartesian3_default.fromArray(normals, index, toEncode1); + compressedAttributes[normalIndex++] = AttributeCompression_default.octEncodeFloat(toEncode1); + } + if (hasTangent) { + Cartesian3_default.fromArray(tangents, index, toEncode1); + compressedAttributes[normalIndex++] = AttributeCompression_default.octEncodeFloat(toEncode1); + } + if (hasBitangent) { + Cartesian3_default.fromArray(bitangents, index, toEncode1); + compressedAttributes[normalIndex++] = AttributeCompression_default.octEncodeFloat(toEncode1); + } + } + } + geometry.attributes.compressedAttributes = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: numCompressedComponents, + values: compressedAttributes + }); + if (hasNormal) { + delete geometry.attributes.normal; + } + if (hasSt) { + delete geometry.attributes.st; + } + if (hasBitangent) { + delete geometry.attributes.bitangent; + } + if (hasTangent) { + delete geometry.attributes.tangent; + } + return geometry; +}; +function indexTriangles(geometry) { + if (defined_default(geometry.indices)) { + return geometry; + } + const numberOfVertices = Geometry_default.computeNumberOfVertices(geometry); + if (numberOfVertices < 3) { + throw new DeveloperError_default("The number of vertices must be at least three."); + } + if (numberOfVertices % 3 !== 0) { + throw new DeveloperError_default( + "The number of vertices must be a multiple of three." + ); + } + const indices = IndexDatatype_default.createTypedArray( + numberOfVertices, + numberOfVertices + ); + for (let i = 0; i < numberOfVertices; ++i) { + indices[i] = i; + } + geometry.indices = indices; + return geometry; +} +function indexTriangleFan(geometry) { + const numberOfVertices = Geometry_default.computeNumberOfVertices(geometry); + if (numberOfVertices < 3) { + throw new DeveloperError_default("The number of vertices must be at least three."); + } + const indices = IndexDatatype_default.createTypedArray( + numberOfVertices, + (numberOfVertices - 2) * 3 + ); + indices[0] = 1; + indices[1] = 0; + indices[2] = 2; + let indicesIndex = 3; + for (let i = 3; i < numberOfVertices; ++i) { + indices[indicesIndex++] = i - 1; + indices[indicesIndex++] = 0; + indices[indicesIndex++] = i; + } + geometry.indices = indices; + geometry.primitiveType = PrimitiveType_default.TRIANGLES; + return geometry; +} +function indexTriangleStrip(geometry) { + const numberOfVertices = Geometry_default.computeNumberOfVertices(geometry); + if (numberOfVertices < 3) { + throw new DeveloperError_default("The number of vertices must be at least 3."); + } + const indices = IndexDatatype_default.createTypedArray( + numberOfVertices, + (numberOfVertices - 2) * 3 + ); + indices[0] = 0; + indices[1] = 1; + indices[2] = 2; + if (numberOfVertices > 3) { + indices[3] = 0; + indices[4] = 2; + indices[5] = 3; + } + let indicesIndex = 6; + for (let i = 3; i < numberOfVertices - 1; i += 2) { + indices[indicesIndex++] = i; + indices[indicesIndex++] = i - 1; + indices[indicesIndex++] = i + 1; + if (i + 2 < numberOfVertices) { + indices[indicesIndex++] = i; + indices[indicesIndex++] = i + 1; + indices[indicesIndex++] = i + 2; + } + } + geometry.indices = indices; + geometry.primitiveType = PrimitiveType_default.TRIANGLES; + return geometry; +} +function indexLines(geometry) { + if (defined_default(geometry.indices)) { + return geometry; + } + const numberOfVertices = Geometry_default.computeNumberOfVertices(geometry); + if (numberOfVertices < 2) { + throw new DeveloperError_default("The number of vertices must be at least two."); + } + if (numberOfVertices % 2 !== 0) { + throw new DeveloperError_default("The number of vertices must be a multiple of 2."); + } + const indices = IndexDatatype_default.createTypedArray( + numberOfVertices, + numberOfVertices + ); + for (let i = 0; i < numberOfVertices; ++i) { + indices[i] = i; + } + geometry.indices = indices; + return geometry; +} +function indexLineStrip(geometry) { + const numberOfVertices = Geometry_default.computeNumberOfVertices(geometry); + if (numberOfVertices < 2) { + throw new DeveloperError_default("The number of vertices must be at least two."); + } + const indices = IndexDatatype_default.createTypedArray( + numberOfVertices, + (numberOfVertices - 1) * 2 + ); + indices[0] = 0; + indices[1] = 1; + let indicesIndex = 2; + for (let i = 2; i < numberOfVertices; ++i) { + indices[indicesIndex++] = i - 1; + indices[indicesIndex++] = i; + } + geometry.indices = indices; + geometry.primitiveType = PrimitiveType_default.LINES; + return geometry; +} +function indexLineLoop(geometry) { + const numberOfVertices = Geometry_default.computeNumberOfVertices(geometry); + if (numberOfVertices < 2) { + throw new DeveloperError_default("The number of vertices must be at least two."); + } + const indices = IndexDatatype_default.createTypedArray( + numberOfVertices, + numberOfVertices * 2 + ); + indices[0] = 0; + indices[1] = 1; + let indicesIndex = 2; + for (let i = 2; i < numberOfVertices; ++i) { + indices[indicesIndex++] = i - 1; + indices[indicesIndex++] = i; + } + indices[indicesIndex++] = numberOfVertices - 1; + indices[indicesIndex] = 0; + geometry.indices = indices; + geometry.primitiveType = PrimitiveType_default.LINES; + return geometry; +} +function indexPrimitive(geometry) { + switch (geometry.primitiveType) { + case PrimitiveType_default.TRIANGLE_FAN: + return indexTriangleFan(geometry); + case PrimitiveType_default.TRIANGLE_STRIP: + return indexTriangleStrip(geometry); + case PrimitiveType_default.TRIANGLES: + return indexTriangles(geometry); + case PrimitiveType_default.LINE_STRIP: + return indexLineStrip(geometry); + case PrimitiveType_default.LINE_LOOP: + return indexLineLoop(geometry); + case PrimitiveType_default.LINES: + return indexLines(geometry); + } + return geometry; +} +function offsetPointFromXZPlane(p, isBehind) { + if (Math.abs(p.y) < Math_default.EPSILON6) { + if (isBehind) { + p.y = -Math_default.EPSILON6; + } else { + p.y = Math_default.EPSILON6; + } + } +} +function offsetTriangleFromXZPlane(p0, p1, p2) { + if (p0.y !== 0 && p1.y !== 0 && p2.y !== 0) { + offsetPointFromXZPlane(p0, p0.y < 0); + offsetPointFromXZPlane(p1, p1.y < 0); + offsetPointFromXZPlane(p2, p2.y < 0); + return; + } + const p0y = Math.abs(p0.y); + const p1y = Math.abs(p1.y); + const p2y = Math.abs(p2.y); + let sign; + if (p0y > p1y) { + if (p0y > p2y) { + sign = Math_default.sign(p0.y); + } else { + sign = Math_default.sign(p2.y); + } + } else if (p1y > p2y) { + sign = Math_default.sign(p1.y); + } else { + sign = Math_default.sign(p2.y); + } + const isBehind = sign < 0; + offsetPointFromXZPlane(p0, isBehind); + offsetPointFromXZPlane(p1, isBehind); + offsetPointFromXZPlane(p2, isBehind); +} +var c3 = new Cartesian3_default(); +function getXZIntersectionOffsetPoints(p, p1, u12, v12) { + Cartesian3_default.add( + p, + Cartesian3_default.multiplyByScalar( + Cartesian3_default.subtract(p1, p, c3), + p.y / (p.y - p1.y), + c3 + ), + u12 + ); + Cartesian3_default.clone(u12, v12); + offsetPointFromXZPlane(u12, true); + offsetPointFromXZPlane(v12, false); +} +var u1 = new Cartesian3_default(); +var u2 = new Cartesian3_default(); +var q1 = new Cartesian3_default(); +var q2 = new Cartesian3_default(); +var splitTriangleResult = { + positions: new Array(7), + indices: new Array(3 * 3) +}; +function splitTriangle(p0, p1, p2) { + if (p0.x >= 0 || p1.x >= 0 || p2.x >= 0) { + return void 0; + } + offsetTriangleFromXZPlane(p0, p1, p2); + const p0Behind = p0.y < 0; + const p1Behind = p1.y < 0; + const p2Behind = p2.y < 0; + let numBehind = 0; + numBehind += p0Behind ? 1 : 0; + numBehind += p1Behind ? 1 : 0; + numBehind += p2Behind ? 1 : 0; + const indices = splitTriangleResult.indices; + if (numBehind === 1) { + indices[1] = 3; + indices[2] = 4; + indices[5] = 6; + indices[7] = 6; + indices[8] = 5; + if (p0Behind) { + getXZIntersectionOffsetPoints(p0, p1, u1, q1); + getXZIntersectionOffsetPoints(p0, p2, u2, q2); + indices[0] = 0; + indices[3] = 1; + indices[4] = 2; + indices[6] = 1; + } else if (p1Behind) { + getXZIntersectionOffsetPoints(p1, p2, u1, q1); + getXZIntersectionOffsetPoints(p1, p0, u2, q2); + indices[0] = 1; + indices[3] = 2; + indices[4] = 0; + indices[6] = 2; + } else if (p2Behind) { + getXZIntersectionOffsetPoints(p2, p0, u1, q1); + getXZIntersectionOffsetPoints(p2, p1, u2, q2); + indices[0] = 2; + indices[3] = 0; + indices[4] = 1; + indices[6] = 0; + } + } else if (numBehind === 2) { + indices[2] = 4; + indices[4] = 4; + indices[5] = 3; + indices[7] = 5; + indices[8] = 6; + if (!p0Behind) { + getXZIntersectionOffsetPoints(p0, p1, u1, q1); + getXZIntersectionOffsetPoints(p0, p2, u2, q2); + indices[0] = 1; + indices[1] = 2; + indices[3] = 1; + indices[6] = 0; + } else if (!p1Behind) { + getXZIntersectionOffsetPoints(p1, p2, u1, q1); + getXZIntersectionOffsetPoints(p1, p0, u2, q2); + indices[0] = 2; + indices[1] = 0; + indices[3] = 2; + indices[6] = 1; + } else if (!p2Behind) { + getXZIntersectionOffsetPoints(p2, p0, u1, q1); + getXZIntersectionOffsetPoints(p2, p1, u2, q2); + indices[0] = 0; + indices[1] = 1; + indices[3] = 0; + indices[6] = 2; + } + } + const positions = splitTriangleResult.positions; + positions[0] = p0; + positions[1] = p1; + positions[2] = p2; + positions.length = 3; + if (numBehind === 1 || numBehind === 2) { + positions[3] = u1; + positions[4] = u2; + positions[5] = q1; + positions[6] = q2; + positions.length = 7; + } + return splitTriangleResult; +} +function updateGeometryAfterSplit(geometry, computeBoundingSphere) { + const attributes = geometry.attributes; + if (attributes.position.values.length === 0) { + return void 0; + } + for (const property in attributes) { + if (attributes.hasOwnProperty(property) && defined_default(attributes[property]) && defined_default(attributes[property].values)) { + const attribute = attributes[property]; + attribute.values = ComponentDatatype_default.createTypedArray( + attribute.componentDatatype, + attribute.values + ); + } + } + const numberOfVertices = Geometry_default.computeNumberOfVertices(geometry); + geometry.indices = IndexDatatype_default.createTypedArray( + numberOfVertices, + geometry.indices + ); + if (computeBoundingSphere) { + geometry.boundingSphere = BoundingSphere_default.fromVertices( + attributes.position.values + ); + } + return geometry; +} +function copyGeometryForSplit(geometry) { + const attributes = geometry.attributes; + const copiedAttributes = {}; + for (const property in attributes) { + if (attributes.hasOwnProperty(property) && defined_default(attributes[property]) && defined_default(attributes[property].values)) { + const attribute = attributes[property]; + copiedAttributes[property] = new GeometryAttribute_default({ + componentDatatype: attribute.componentDatatype, + componentsPerAttribute: attribute.componentsPerAttribute, + normalize: attribute.normalize, + values: [] + }); + } + } + return new Geometry_default({ + attributes: copiedAttributes, + indices: [], + primitiveType: geometry.primitiveType + }); +} +function updateInstanceAfterSplit(instance, westGeometry, eastGeometry) { + const computeBoundingSphere = defined_default(instance.geometry.boundingSphere); + westGeometry = updateGeometryAfterSplit(westGeometry, computeBoundingSphere); + eastGeometry = updateGeometryAfterSplit(eastGeometry, computeBoundingSphere); + if (defined_default(eastGeometry) && !defined_default(westGeometry)) { + instance.geometry = eastGeometry; + } else if (!defined_default(eastGeometry) && defined_default(westGeometry)) { + instance.geometry = westGeometry; + } else { + instance.westHemisphereGeometry = westGeometry; + instance.eastHemisphereGeometry = eastGeometry; + instance.geometry = void 0; + } +} +function generateBarycentricInterpolateFunction(CartesianType, numberOfComponents) { + const v0Scratch = new CartesianType(); + const v1Scratch = new CartesianType(); + const v2Scratch = new CartesianType(); + return function(i0, i1, i2, coords, sourceValues, currentValues, insertedIndex, normalize) { + const v02 = CartesianType.fromArray( + sourceValues, + i0 * numberOfComponents, + v0Scratch + ); + const v12 = CartesianType.fromArray( + sourceValues, + i1 * numberOfComponents, + v1Scratch + ); + const v22 = CartesianType.fromArray( + sourceValues, + i2 * numberOfComponents, + v2Scratch + ); + CartesianType.multiplyByScalar(v02, coords.x, v02); + CartesianType.multiplyByScalar(v12, coords.y, v12); + CartesianType.multiplyByScalar(v22, coords.z, v22); + const value = CartesianType.add(v02, v12, v02); + CartesianType.add(value, v22, value); + if (normalize) { + CartesianType.normalize(value, value); + } + CartesianType.pack( + value, + currentValues, + insertedIndex * numberOfComponents + ); + }; +} +var interpolateAndPackCartesian4 = generateBarycentricInterpolateFunction( + Cartesian4_default, + 4 +); +var interpolateAndPackCartesian3 = generateBarycentricInterpolateFunction( + Cartesian3_default, + 3 +); +var interpolateAndPackCartesian2 = generateBarycentricInterpolateFunction( + Cartesian2_default, + 2 +); +var interpolateAndPackBoolean = function(i0, i1, i2, coords, sourceValues, currentValues, insertedIndex) { + const v12 = sourceValues[i0] * coords.x; + const v22 = sourceValues[i1] * coords.y; + const v3 = sourceValues[i2] * coords.z; + currentValues[insertedIndex] = v12 + v22 + v3 > Math_default.EPSILON6 ? 1 : 0; +}; +var p0Scratch = new Cartesian3_default(); +var p1Scratch = new Cartesian3_default(); +var p2Scratch = new Cartesian3_default(); +var barycentricScratch = new Cartesian3_default(); +function computeTriangleAttributes(i0, i1, i2, point, positions, normals, tangents, bitangents, texCoords, extrudeDirections, applyOffset, currentAttributes, customAttributeNames, customAttributesLength, allAttributes, insertedIndex) { + if (!defined_default(normals) && !defined_default(tangents) && !defined_default(bitangents) && !defined_default(texCoords) && !defined_default(extrudeDirections) && customAttributesLength === 0) { + return; + } + const p0 = Cartesian3_default.fromArray(positions, i0 * 3, p0Scratch); + const p1 = Cartesian3_default.fromArray(positions, i1 * 3, p1Scratch); + const p2 = Cartesian3_default.fromArray(positions, i2 * 3, p2Scratch); + const coords = barycentricCoordinates_default(point, p0, p1, p2, barycentricScratch); + if (!defined_default(coords)) { + return; + } + if (defined_default(normals)) { + interpolateAndPackCartesian3( + i0, + i1, + i2, + coords, + normals, + currentAttributes.normal.values, + insertedIndex, + true + ); + } + if (defined_default(extrudeDirections)) { + const d0 = Cartesian3_default.fromArray(extrudeDirections, i0 * 3, p0Scratch); + const d1 = Cartesian3_default.fromArray(extrudeDirections, i1 * 3, p1Scratch); + const d2 = Cartesian3_default.fromArray(extrudeDirections, i2 * 3, p2Scratch); + Cartesian3_default.multiplyByScalar(d0, coords.x, d0); + Cartesian3_default.multiplyByScalar(d1, coords.y, d1); + Cartesian3_default.multiplyByScalar(d2, coords.z, d2); + let direction; + if (!Cartesian3_default.equals(d0, Cartesian3_default.ZERO) || !Cartesian3_default.equals(d1, Cartesian3_default.ZERO) || !Cartesian3_default.equals(d2, Cartesian3_default.ZERO)) { + direction = Cartesian3_default.add(d0, d1, d0); + Cartesian3_default.add(direction, d2, direction); + Cartesian3_default.normalize(direction, direction); + } else { + direction = p0Scratch; + direction.x = 0; + direction.y = 0; + direction.z = 0; + } + Cartesian3_default.pack( + direction, + currentAttributes.extrudeDirection.values, + insertedIndex * 3 + ); + } + if (defined_default(applyOffset)) { + interpolateAndPackBoolean( + i0, + i1, + i2, + coords, + applyOffset, + currentAttributes.applyOffset.values, + insertedIndex + ); + } + if (defined_default(tangents)) { + interpolateAndPackCartesian3( + i0, + i1, + i2, + coords, + tangents, + currentAttributes.tangent.values, + insertedIndex, + true + ); + } + if (defined_default(bitangents)) { + interpolateAndPackCartesian3( + i0, + i1, + i2, + coords, + bitangents, + currentAttributes.bitangent.values, + insertedIndex, + true + ); + } + if (defined_default(texCoords)) { + interpolateAndPackCartesian2( + i0, + i1, + i2, + coords, + texCoords, + currentAttributes.st.values, + insertedIndex + ); + } + if (customAttributesLength > 0) { + for (let i = 0; i < customAttributesLength; i++) { + const attributeName = customAttributeNames[i]; + genericInterpolate( + i0, + i1, + i2, + coords, + insertedIndex, + allAttributes[attributeName], + currentAttributes[attributeName] + ); + } + } +} +function genericInterpolate(i0, i1, i2, coords, insertedIndex, sourceAttribute, currentAttribute) { + const componentsPerAttribute = sourceAttribute.componentsPerAttribute; + const sourceValues = sourceAttribute.values; + const currentValues = currentAttribute.values; + switch (componentsPerAttribute) { + case 4: + interpolateAndPackCartesian4( + i0, + i1, + i2, + coords, + sourceValues, + currentValues, + insertedIndex, + false + ); + break; + case 3: + interpolateAndPackCartesian3( + i0, + i1, + i2, + coords, + sourceValues, + currentValues, + insertedIndex, + false + ); + break; + case 2: + interpolateAndPackCartesian2( + i0, + i1, + i2, + coords, + sourceValues, + currentValues, + insertedIndex, + false + ); + break; + default: + currentValues[insertedIndex] = sourceValues[i0] * coords.x + sourceValues[i1] * coords.y + sourceValues[i2] * coords.z; + } +} +function insertSplitPoint(currentAttributes, currentIndices, currentIndexMap, indices, currentIndex, point) { + const insertIndex = currentAttributes.position.values.length / 3; + if (currentIndex !== -1) { + const prevIndex = indices[currentIndex]; + const newIndex = currentIndexMap[prevIndex]; + if (newIndex === -1) { + currentIndexMap[prevIndex] = insertIndex; + currentAttributes.position.values.push(point.x, point.y, point.z); + currentIndices.push(insertIndex); + return insertIndex; + } + currentIndices.push(newIndex); + return newIndex; + } + currentAttributes.position.values.push(point.x, point.y, point.z); + currentIndices.push(insertIndex); + return insertIndex; +} +var NAMED_ATTRIBUTES = { + position: true, + normal: true, + bitangent: true, + tangent: true, + st: true, + extrudeDirection: true, + applyOffset: true +}; +function splitLongitudeTriangles(instance) { + const geometry = instance.geometry; + const attributes = geometry.attributes; + const positions = attributes.position.values; + const normals = defined_default(attributes.normal) ? attributes.normal.values : void 0; + const bitangents = defined_default(attributes.bitangent) ? attributes.bitangent.values : void 0; + const tangents = defined_default(attributes.tangent) ? attributes.tangent.values : void 0; + const texCoords = defined_default(attributes.st) ? attributes.st.values : void 0; + const extrudeDirections = defined_default(attributes.extrudeDirection) ? attributes.extrudeDirection.values : void 0; + const applyOffset = defined_default(attributes.applyOffset) ? attributes.applyOffset.values : void 0; + const indices = geometry.indices; + const customAttributeNames = []; + for (const attributeName in attributes) { + if (attributes.hasOwnProperty(attributeName) && !NAMED_ATTRIBUTES[attributeName] && defined_default(attributes[attributeName])) { + customAttributeNames.push(attributeName); + } + } + const customAttributesLength = customAttributeNames.length; + const eastGeometry = copyGeometryForSplit(geometry); + const westGeometry = copyGeometryForSplit(geometry); + let currentAttributes; + let currentIndices; + let currentIndexMap; + let insertedIndex; + let i; + const westGeometryIndexMap = []; + westGeometryIndexMap.length = positions.length / 3; + const eastGeometryIndexMap = []; + eastGeometryIndexMap.length = positions.length / 3; + for (i = 0; i < westGeometryIndexMap.length; ++i) { + westGeometryIndexMap[i] = -1; + eastGeometryIndexMap[i] = -1; + } + const len = indices.length; + for (i = 0; i < len; i += 3) { + const i0 = indices[i]; + const i1 = indices[i + 1]; + const i2 = indices[i + 2]; + let p0 = Cartesian3_default.fromArray(positions, i0 * 3); + let p1 = Cartesian3_default.fromArray(positions, i1 * 3); + let p2 = Cartesian3_default.fromArray(positions, i2 * 3); + const result = splitTriangle(p0, p1, p2); + if (defined_default(result) && result.positions.length > 3) { + const resultPositions = result.positions; + const resultIndices = result.indices; + const resultLength = resultIndices.length; + for (let j = 0; j < resultLength; ++j) { + const resultIndex = resultIndices[j]; + const point = resultPositions[resultIndex]; + if (point.y < 0) { + currentAttributes = westGeometry.attributes; + currentIndices = westGeometry.indices; + currentIndexMap = westGeometryIndexMap; + } else { + currentAttributes = eastGeometry.attributes; + currentIndices = eastGeometry.indices; + currentIndexMap = eastGeometryIndexMap; + } + insertedIndex = insertSplitPoint( + currentAttributes, + currentIndices, + currentIndexMap, + indices, + resultIndex < 3 ? i + resultIndex : -1, + point + ); + computeTriangleAttributes( + i0, + i1, + i2, + point, + positions, + normals, + tangents, + bitangents, + texCoords, + extrudeDirections, + applyOffset, + currentAttributes, + customAttributeNames, + customAttributesLength, + attributes, + insertedIndex + ); + } + } else { + if (defined_default(result)) { + p0 = result.positions[0]; + p1 = result.positions[1]; + p2 = result.positions[2]; + } + if (p0.y < 0) { + currentAttributes = westGeometry.attributes; + currentIndices = westGeometry.indices; + currentIndexMap = westGeometryIndexMap; + } else { + currentAttributes = eastGeometry.attributes; + currentIndices = eastGeometry.indices; + currentIndexMap = eastGeometryIndexMap; + } + insertedIndex = insertSplitPoint( + currentAttributes, + currentIndices, + currentIndexMap, + indices, + i, + p0 + ); + computeTriangleAttributes( + i0, + i1, + i2, + p0, + positions, + normals, + tangents, + bitangents, + texCoords, + extrudeDirections, + applyOffset, + currentAttributes, + customAttributeNames, + customAttributesLength, + attributes, + insertedIndex + ); + insertedIndex = insertSplitPoint( + currentAttributes, + currentIndices, + currentIndexMap, + indices, + i + 1, + p1 + ); + computeTriangleAttributes( + i0, + i1, + i2, + p1, + positions, + normals, + tangents, + bitangents, + texCoords, + extrudeDirections, + applyOffset, + currentAttributes, + customAttributeNames, + customAttributesLength, + attributes, + insertedIndex + ); + insertedIndex = insertSplitPoint( + currentAttributes, + currentIndices, + currentIndexMap, + indices, + i + 2, + p2 + ); + computeTriangleAttributes( + i0, + i1, + i2, + p2, + positions, + normals, + tangents, + bitangents, + texCoords, + extrudeDirections, + applyOffset, + currentAttributes, + customAttributeNames, + customAttributesLength, + attributes, + insertedIndex + ); + } + } + updateInstanceAfterSplit(instance, westGeometry, eastGeometry); +} +var xzPlane = Plane_default.fromPointNormal(Cartesian3_default.ZERO, Cartesian3_default.UNIT_Y); +var offsetScratch = new Cartesian3_default(); +var offsetPointScratch = new Cartesian3_default(); +function computeLineAttributes(i0, i1, point, positions, insertIndex, currentAttributes, applyOffset) { + if (!defined_default(applyOffset)) { + return; + } + const p0 = Cartesian3_default.fromArray(positions, i0 * 3, p0Scratch); + if (Cartesian3_default.equalsEpsilon(p0, point, Math_default.EPSILON10)) { + currentAttributes.applyOffset.values[insertIndex] = applyOffset[i0]; + } else { + currentAttributes.applyOffset.values[insertIndex] = applyOffset[i1]; + } +} +function splitLongitudeLines(instance) { + const geometry = instance.geometry; + const attributes = geometry.attributes; + const positions = attributes.position.values; + const applyOffset = defined_default(attributes.applyOffset) ? attributes.applyOffset.values : void 0; + const indices = geometry.indices; + const eastGeometry = copyGeometryForSplit(geometry); + const westGeometry = copyGeometryForSplit(geometry); + let i; + const length = indices.length; + const westGeometryIndexMap = []; + westGeometryIndexMap.length = positions.length / 3; + const eastGeometryIndexMap = []; + eastGeometryIndexMap.length = positions.length / 3; + for (i = 0; i < westGeometryIndexMap.length; ++i) { + westGeometryIndexMap[i] = -1; + eastGeometryIndexMap[i] = -1; + } + for (i = 0; i < length; i += 2) { + const i0 = indices[i]; + const i1 = indices[i + 1]; + const p0 = Cartesian3_default.fromArray(positions, i0 * 3, p0Scratch); + const p1 = Cartesian3_default.fromArray(positions, i1 * 3, p1Scratch); + let insertIndex; + if (Math.abs(p0.y) < Math_default.EPSILON6) { + if (p0.y < 0) { + p0.y = -Math_default.EPSILON6; + } else { + p0.y = Math_default.EPSILON6; + } + } + if (Math.abs(p1.y) < Math_default.EPSILON6) { + if (p1.y < 0) { + p1.y = -Math_default.EPSILON6; + } else { + p1.y = Math_default.EPSILON6; + } + } + let p0Attributes = eastGeometry.attributes; + let p0Indices = eastGeometry.indices; + let p0IndexMap = eastGeometryIndexMap; + let p1Attributes = westGeometry.attributes; + let p1Indices = westGeometry.indices; + let p1IndexMap = westGeometryIndexMap; + const intersection = IntersectionTests_default.lineSegmentPlane( + p0, + p1, + xzPlane, + p2Scratch + ); + if (defined_default(intersection)) { + const offset = Cartesian3_default.multiplyByScalar( + Cartesian3_default.UNIT_Y, + 5 * Math_default.EPSILON9, + offsetScratch + ); + if (p0.y < 0) { + Cartesian3_default.negate(offset, offset); + p0Attributes = westGeometry.attributes; + p0Indices = westGeometry.indices; + p0IndexMap = westGeometryIndexMap; + p1Attributes = eastGeometry.attributes; + p1Indices = eastGeometry.indices; + p1IndexMap = eastGeometryIndexMap; + } + const offsetPoint = Cartesian3_default.add( + intersection, + offset, + offsetPointScratch + ); + insertIndex = insertSplitPoint( + p0Attributes, + p0Indices, + p0IndexMap, + indices, + i, + p0 + ); + computeLineAttributes( + i0, + i1, + p0, + positions, + insertIndex, + p0Attributes, + applyOffset + ); + insertIndex = insertSplitPoint( + p0Attributes, + p0Indices, + p0IndexMap, + indices, + -1, + offsetPoint + ); + computeLineAttributes( + i0, + i1, + offsetPoint, + positions, + insertIndex, + p0Attributes, + applyOffset + ); + Cartesian3_default.negate(offset, offset); + Cartesian3_default.add(intersection, offset, offsetPoint); + insertIndex = insertSplitPoint( + p1Attributes, + p1Indices, + p1IndexMap, + indices, + -1, + offsetPoint + ); + computeLineAttributes( + i0, + i1, + offsetPoint, + positions, + insertIndex, + p1Attributes, + applyOffset + ); + insertIndex = insertSplitPoint( + p1Attributes, + p1Indices, + p1IndexMap, + indices, + i + 1, + p1 + ); + computeLineAttributes( + i0, + i1, + p1, + positions, + insertIndex, + p1Attributes, + applyOffset + ); + } else { + let currentAttributes; + let currentIndices; + let currentIndexMap; + if (p0.y < 0) { + currentAttributes = westGeometry.attributes; + currentIndices = westGeometry.indices; + currentIndexMap = westGeometryIndexMap; + } else { + currentAttributes = eastGeometry.attributes; + currentIndices = eastGeometry.indices; + currentIndexMap = eastGeometryIndexMap; + } + insertIndex = insertSplitPoint( + currentAttributes, + currentIndices, + currentIndexMap, + indices, + i, + p0 + ); + computeLineAttributes( + i0, + i1, + p0, + positions, + insertIndex, + currentAttributes, + applyOffset + ); + insertIndex = insertSplitPoint( + currentAttributes, + currentIndices, + currentIndexMap, + indices, + i + 1, + p1 + ); + computeLineAttributes( + i0, + i1, + p1, + positions, + insertIndex, + currentAttributes, + applyOffset + ); + } + } + updateInstanceAfterSplit(instance, westGeometry, eastGeometry); +} +var cartesian2Scratch0 = new Cartesian2_default(); +var cartesian2Scratch1 = new Cartesian2_default(); +var cartesian3Scratch0 = new Cartesian3_default(); +var cartesian3Scratch2 = new Cartesian3_default(); +var cartesian3Scratch3 = new Cartesian3_default(); +var cartesian3Scratch4 = new Cartesian3_default(); +var cartesian3Scratch5 = new Cartesian3_default(); +var cartesian3Scratch6 = new Cartesian3_default(); +var cartesian4Scratch0 = new Cartesian4_default(); +function updateAdjacencyAfterSplit(geometry) { + const attributes = geometry.attributes; + const positions = attributes.position.values; + const prevPositions = attributes.prevPosition.values; + const nextPositions = attributes.nextPosition.values; + const length = positions.length; + for (let j = 0; j < length; j += 3) { + const position = Cartesian3_default.unpack(positions, j, cartesian3Scratch0); + if (position.x > 0) { + continue; + } + const prevPosition = Cartesian3_default.unpack( + prevPositions, + j, + cartesian3Scratch2 + ); + if (position.y < 0 && prevPosition.y > 0 || position.y > 0 && prevPosition.y < 0) { + if (j - 3 > 0) { + prevPositions[j] = positions[j - 3]; + prevPositions[j + 1] = positions[j - 2]; + prevPositions[j + 2] = positions[j - 1]; + } else { + Cartesian3_default.pack(position, prevPositions, j); + } + } + const nextPosition = Cartesian3_default.unpack( + nextPositions, + j, + cartesian3Scratch3 + ); + if (position.y < 0 && nextPosition.y > 0 || position.y > 0 && nextPosition.y < 0) { + if (j + 3 < length) { + nextPositions[j] = positions[j + 3]; + nextPositions[j + 1] = positions[j + 4]; + nextPositions[j + 2] = positions[j + 5]; + } else { + Cartesian3_default.pack(position, nextPositions, j); + } + } + } +} +var offsetScalar = 5 * Math_default.EPSILON9; +var coplanarOffset = Math_default.EPSILON6; +function splitLongitudePolyline(instance) { + const geometry = instance.geometry; + const attributes = geometry.attributes; + const positions = attributes.position.values; + const prevPositions = attributes.prevPosition.values; + const nextPositions = attributes.nextPosition.values; + const expandAndWidths = attributes.expandAndWidth.values; + const texCoords = defined_default(attributes.st) ? attributes.st.values : void 0; + const colors = defined_default(attributes.color) ? attributes.color.values : void 0; + const eastGeometry = copyGeometryForSplit(geometry); + const westGeometry = copyGeometryForSplit(geometry); + let i; + let j; + let index; + let intersectionFound = false; + const length = positions.length / 3; + for (i = 0; i < length; i += 4) { + const i0 = i; + const i2 = i + 2; + const p0 = Cartesian3_default.fromArray(positions, i0 * 3, cartesian3Scratch0); + const p2 = Cartesian3_default.fromArray(positions, i2 * 3, cartesian3Scratch2); + if (Math.abs(p0.y) < coplanarOffset) { + p0.y = coplanarOffset * (p2.y < 0 ? -1 : 1); + positions[i * 3 + 1] = p0.y; + positions[(i + 1) * 3 + 1] = p0.y; + for (j = i0 * 3; j < i0 * 3 + 4 * 3; j += 3) { + prevPositions[j] = positions[i * 3]; + prevPositions[j + 1] = positions[i * 3 + 1]; + prevPositions[j + 2] = positions[i * 3 + 2]; + } + } + if (Math.abs(p2.y) < coplanarOffset) { + p2.y = coplanarOffset * (p0.y < 0 ? -1 : 1); + positions[(i + 2) * 3 + 1] = p2.y; + positions[(i + 3) * 3 + 1] = p2.y; + for (j = i0 * 3; j < i0 * 3 + 4 * 3; j += 3) { + nextPositions[j] = positions[(i + 2) * 3]; + nextPositions[j + 1] = positions[(i + 2) * 3 + 1]; + nextPositions[j + 2] = positions[(i + 2) * 3 + 2]; + } + } + let p0Attributes = eastGeometry.attributes; + let p0Indices = eastGeometry.indices; + let p2Attributes = westGeometry.attributes; + let p2Indices = westGeometry.indices; + const intersection = IntersectionTests_default.lineSegmentPlane( + p0, + p2, + xzPlane, + cartesian3Scratch4 + ); + if (defined_default(intersection)) { + intersectionFound = true; + const offset = Cartesian3_default.multiplyByScalar( + Cartesian3_default.UNIT_Y, + offsetScalar, + cartesian3Scratch5 + ); + if (p0.y < 0) { + Cartesian3_default.negate(offset, offset); + p0Attributes = westGeometry.attributes; + p0Indices = westGeometry.indices; + p2Attributes = eastGeometry.attributes; + p2Indices = eastGeometry.indices; + } + const offsetPoint = Cartesian3_default.add( + intersection, + offset, + cartesian3Scratch6 + ); + p0Attributes.position.values.push(p0.x, p0.y, p0.z, p0.x, p0.y, p0.z); + p0Attributes.position.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p0Attributes.position.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p0Attributes.prevPosition.values.push( + prevPositions[i0 * 3], + prevPositions[i0 * 3 + 1], + prevPositions[i0 * 3 + 2] + ); + p0Attributes.prevPosition.values.push( + prevPositions[i0 * 3 + 3], + prevPositions[i0 * 3 + 4], + prevPositions[i0 * 3 + 5] + ); + p0Attributes.prevPosition.values.push(p0.x, p0.y, p0.z, p0.x, p0.y, p0.z); + p0Attributes.nextPosition.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p0Attributes.nextPosition.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p0Attributes.nextPosition.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p0Attributes.nextPosition.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + Cartesian3_default.negate(offset, offset); + Cartesian3_default.add(intersection, offset, offsetPoint); + p2Attributes.position.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p2Attributes.position.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p2Attributes.position.values.push(p2.x, p2.y, p2.z, p2.x, p2.y, p2.z); + p2Attributes.prevPosition.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p2Attributes.prevPosition.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p2Attributes.prevPosition.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p2Attributes.prevPosition.values.push( + offsetPoint.x, + offsetPoint.y, + offsetPoint.z + ); + p2Attributes.nextPosition.values.push(p2.x, p2.y, p2.z, p2.x, p2.y, p2.z); + p2Attributes.nextPosition.values.push( + nextPositions[i2 * 3], + nextPositions[i2 * 3 + 1], + nextPositions[i2 * 3 + 2] + ); + p2Attributes.nextPosition.values.push( + nextPositions[i2 * 3 + 3], + nextPositions[i2 * 3 + 4], + nextPositions[i2 * 3 + 5] + ); + const ew0 = Cartesian2_default.fromArray( + expandAndWidths, + i0 * 2, + cartesian2Scratch0 + ); + const width = Math.abs(ew0.y); + p0Attributes.expandAndWidth.values.push(-1, width, 1, width); + p0Attributes.expandAndWidth.values.push(-1, -width, 1, -width); + p2Attributes.expandAndWidth.values.push(-1, width, 1, width); + p2Attributes.expandAndWidth.values.push(-1, -width, 1, -width); + let t = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(intersection, p0, cartesian3Scratch3) + ); + t /= Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(p2, p0, cartesian3Scratch3) + ); + if (defined_default(colors)) { + const c0 = Cartesian4_default.fromArray(colors, i0 * 4, cartesian4Scratch0); + const c2 = Cartesian4_default.fromArray(colors, i2 * 4, cartesian4Scratch0); + const r = Math_default.lerp(c0.x, c2.x, t); + const g = Math_default.lerp(c0.y, c2.y, t); + const b = Math_default.lerp(c0.z, c2.z, t); + const a = Math_default.lerp(c0.w, c2.w, t); + for (j = i0 * 4; j < i0 * 4 + 2 * 4; ++j) { + p0Attributes.color.values.push(colors[j]); + } + p0Attributes.color.values.push(r, g, b, a); + p0Attributes.color.values.push(r, g, b, a); + p2Attributes.color.values.push(r, g, b, a); + p2Attributes.color.values.push(r, g, b, a); + for (j = i2 * 4; j < i2 * 4 + 2 * 4; ++j) { + p2Attributes.color.values.push(colors[j]); + } + } + if (defined_default(texCoords)) { + const s0 = Cartesian2_default.fromArray(texCoords, i0 * 2, cartesian2Scratch0); + const s3 = Cartesian2_default.fromArray( + texCoords, + (i + 3) * 2, + cartesian2Scratch1 + ); + const sx = Math_default.lerp(s0.x, s3.x, t); + for (j = i0 * 2; j < i0 * 2 + 2 * 2; ++j) { + p0Attributes.st.values.push(texCoords[j]); + } + p0Attributes.st.values.push(sx, s0.y); + p0Attributes.st.values.push(sx, s3.y); + p2Attributes.st.values.push(sx, s0.y); + p2Attributes.st.values.push(sx, s3.y); + for (j = i2 * 2; j < i2 * 2 + 2 * 2; ++j) { + p2Attributes.st.values.push(texCoords[j]); + } + } + index = p0Attributes.position.values.length / 3 - 4; + p0Indices.push(index, index + 2, index + 1); + p0Indices.push(index + 1, index + 2, index + 3); + index = p2Attributes.position.values.length / 3 - 4; + p2Indices.push(index, index + 2, index + 1); + p2Indices.push(index + 1, index + 2, index + 3); + } else { + let currentAttributes; + let currentIndices; + if (p0.y < 0) { + currentAttributes = westGeometry.attributes; + currentIndices = westGeometry.indices; + } else { + currentAttributes = eastGeometry.attributes; + currentIndices = eastGeometry.indices; + } + currentAttributes.position.values.push(p0.x, p0.y, p0.z); + currentAttributes.position.values.push(p0.x, p0.y, p0.z); + currentAttributes.position.values.push(p2.x, p2.y, p2.z); + currentAttributes.position.values.push(p2.x, p2.y, p2.z); + for (j = i * 3; j < i * 3 + 4 * 3; ++j) { + currentAttributes.prevPosition.values.push(prevPositions[j]); + currentAttributes.nextPosition.values.push(nextPositions[j]); + } + for (j = i * 2; j < i * 2 + 4 * 2; ++j) { + currentAttributes.expandAndWidth.values.push(expandAndWidths[j]); + if (defined_default(texCoords)) { + currentAttributes.st.values.push(texCoords[j]); + } + } + if (defined_default(colors)) { + for (j = i * 4; j < i * 4 + 4 * 4; ++j) { + currentAttributes.color.values.push(colors[j]); + } + } + index = currentAttributes.position.values.length / 3 - 4; + currentIndices.push(index, index + 2, index + 1); + currentIndices.push(index + 1, index + 2, index + 3); + } + } + if (intersectionFound) { + updateAdjacencyAfterSplit(westGeometry); + updateAdjacencyAfterSplit(eastGeometry); + } + updateInstanceAfterSplit(instance, westGeometry, eastGeometry); +} +GeometryPipeline.splitLongitude = function(instance) { + if (!defined_default(instance)) { + throw new DeveloperError_default("instance is required."); + } + const geometry = instance.geometry; + const boundingSphere = geometry.boundingSphere; + if (defined_default(boundingSphere)) { + const minX = boundingSphere.center.x - boundingSphere.radius; + if (minX > 0 || BoundingSphere_default.intersectPlane(boundingSphere, Plane_default.ORIGIN_ZX_PLANE) !== Intersect_default.INTERSECTING) { + return instance; + } + } + if (geometry.geometryType !== GeometryType_default.NONE) { + switch (geometry.geometryType) { + case GeometryType_default.POLYLINES: + splitLongitudePolyline(instance); + break; + case GeometryType_default.TRIANGLES: + splitLongitudeTriangles(instance); + break; + case GeometryType_default.LINES: + splitLongitudeLines(instance); + break; + } + } else { + indexPrimitive(geometry); + if (geometry.primitiveType === PrimitiveType_default.TRIANGLES) { + splitLongitudeTriangles(instance); + } else if (geometry.primitiveType === PrimitiveType_default.LINES) { + splitLongitudeLines(instance); + } + } + return instance; +}; +var GeometryPipeline_default = GeometryPipeline; + +export { + GeometryPipeline_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-I5MQWHBR.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-I5MQWHBR.js new file mode 100644 index 0000000000000000000000000000000000000000..065ca641115c815c682265924681c4747f84b777 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-I5MQWHBR.js @@ -0,0 +1,102 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Cartesian3_default +} from "./chunk-XJCTFTBM.js"; +import { + Check_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/EncodedCartesian3.js +function EncodedCartesian3() { + this.high = Cartesian3_default.clone(Cartesian3_default.ZERO); + this.low = Cartesian3_default.clone(Cartesian3_default.ZERO); +} +EncodedCartesian3.encode = function(value, result) { + Check_default.typeOf.number("value", value); + if (!defined_default(result)) { + result = { + high: 0, + low: 0 + }; + } + let doubleHigh; + if (value >= 0) { + doubleHigh = Math.floor(value / 65536) * 65536; + result.high = doubleHigh; + result.low = value - doubleHigh; + } else { + doubleHigh = Math.floor(-value / 65536) * 65536; + result.high = -doubleHigh; + result.low = value + doubleHigh; + } + return result; +}; +var scratchEncode = { + high: 0, + low: 0 +}; +EncodedCartesian3.fromCartesian = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + if (!defined_default(result)) { + result = new EncodedCartesian3(); + } + const high = result.high; + const low = result.low; + EncodedCartesian3.encode(cartesian.x, scratchEncode); + high.x = scratchEncode.high; + low.x = scratchEncode.low; + EncodedCartesian3.encode(cartesian.y, scratchEncode); + high.y = scratchEncode.high; + low.y = scratchEncode.low; + EncodedCartesian3.encode(cartesian.z, scratchEncode); + high.z = scratchEncode.high; + low.z = scratchEncode.low; + return result; +}; +var encodedP = new EncodedCartesian3(); +EncodedCartesian3.writeElements = function(cartesian, cartesianArray, index) { + Check_default.defined("cartesianArray", cartesianArray); + Check_default.typeOf.number("index", index); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + EncodedCartesian3.fromCartesian(cartesian, encodedP); + const high = encodedP.high; + const low = encodedP.low; + cartesianArray[index] = high.x; + cartesianArray[index + 1] = high.y; + cartesianArray[index + 2] = high.z; + cartesianArray[index + 3] = low.x; + cartesianArray[index + 4] = low.y; + cartesianArray[index + 5] = low.z; +}; +var EncodedCartesian3_default = EncodedCartesian3; + +export { + EncodedCartesian3_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-KAFF2QX3.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-KAFF2QX3.js new file mode 100644 index 0000000000000000000000000000000000000000..280fdf33691bed61500f5a17c276b64a3a85b0f2 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-KAFF2QX3.js @@ -0,0 +1,258 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + WebGLConstants_default +} from "./chunk-527JG4D7.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/ComponentDatatype.js +var ComponentDatatype = { + /** + * 8-bit signed byte corresponding to gl.BYTE and the type + * of an element in Int8Array. + * + * @type {number} + * @constant + */ + BYTE: WebGLConstants_default.BYTE, + /** + * 8-bit unsigned byte corresponding to UNSIGNED_BYTE and the type + * of an element in Uint8Array. + * + * @type {number} + * @constant + */ + UNSIGNED_BYTE: WebGLConstants_default.UNSIGNED_BYTE, + /** + * 16-bit signed short corresponding to SHORT and the type + * of an element in Int16Array. + * + * @type {number} + * @constant + */ + SHORT: WebGLConstants_default.SHORT, + /** + * 16-bit unsigned short corresponding to UNSIGNED_SHORT and the type + * of an element in Uint16Array. + * + * @type {number} + * @constant + */ + UNSIGNED_SHORT: WebGLConstants_default.UNSIGNED_SHORT, + /** + * 32-bit signed int corresponding to INT and the type + * of an element in Int32Array. + * + * @memberOf ComponentDatatype + * + * @type {number} + * @constant + */ + INT: WebGLConstants_default.INT, + /** + * 32-bit unsigned int corresponding to UNSIGNED_INT and the type + * of an element in Uint32Array. + * + * @memberOf ComponentDatatype + * + * @type {number} + * @constant + */ + UNSIGNED_INT: WebGLConstants_default.UNSIGNED_INT, + /** + * 32-bit floating-point corresponding to FLOAT and the type + * of an element in Float32Array. + * + * @type {number} + * @constant + */ + FLOAT: WebGLConstants_default.FLOAT, + /** + * 64-bit floating-point corresponding to gl.DOUBLE (in Desktop OpenGL; + * this is not supported in WebGL, and is emulated in Cesium via {@link GeometryPipeline.encodeAttribute}) + * and the type of an element in Float64Array. + * + * @memberOf ComponentDatatype + * + * @type {number} + * @constant + * @default 0x140A + */ + DOUBLE: WebGLConstants_default.DOUBLE +}; +ComponentDatatype.getSizeInBytes = function(componentDatatype) { + if (!defined_default(componentDatatype)) { + throw new DeveloperError_default("value is required."); + } + switch (componentDatatype) { + case ComponentDatatype.BYTE: + return Int8Array.BYTES_PER_ELEMENT; + case ComponentDatatype.UNSIGNED_BYTE: + return Uint8Array.BYTES_PER_ELEMENT; + case ComponentDatatype.SHORT: + return Int16Array.BYTES_PER_ELEMENT; + case ComponentDatatype.UNSIGNED_SHORT: + return Uint16Array.BYTES_PER_ELEMENT; + case ComponentDatatype.INT: + return Int32Array.BYTES_PER_ELEMENT; + case ComponentDatatype.UNSIGNED_INT: + return Uint32Array.BYTES_PER_ELEMENT; + case ComponentDatatype.FLOAT: + return Float32Array.BYTES_PER_ELEMENT; + case ComponentDatatype.DOUBLE: + return Float64Array.BYTES_PER_ELEMENT; + default: + throw new DeveloperError_default("componentDatatype is not a valid value."); + } +}; +ComponentDatatype.fromTypedArray = function(array) { + if (array instanceof Int8Array) { + return ComponentDatatype.BYTE; + } + if (array instanceof Uint8Array) { + return ComponentDatatype.UNSIGNED_BYTE; + } + if (array instanceof Int16Array) { + return ComponentDatatype.SHORT; + } + if (array instanceof Uint16Array) { + return ComponentDatatype.UNSIGNED_SHORT; + } + if (array instanceof Int32Array) { + return ComponentDatatype.INT; + } + if (array instanceof Uint32Array) { + return ComponentDatatype.UNSIGNED_INT; + } + if (array instanceof Float32Array) { + return ComponentDatatype.FLOAT; + } + if (array instanceof Float64Array) { + return ComponentDatatype.DOUBLE; + } + throw new DeveloperError_default( + "array must be an Int8Array, Uint8Array, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, or Float64Array." + ); +}; +ComponentDatatype.validate = function(componentDatatype) { + return defined_default(componentDatatype) && (componentDatatype === ComponentDatatype.BYTE || componentDatatype === ComponentDatatype.UNSIGNED_BYTE || componentDatatype === ComponentDatatype.SHORT || componentDatatype === ComponentDatatype.UNSIGNED_SHORT || componentDatatype === ComponentDatatype.INT || componentDatatype === ComponentDatatype.UNSIGNED_INT || componentDatatype === ComponentDatatype.FLOAT || componentDatatype === ComponentDatatype.DOUBLE); +}; +ComponentDatatype.createTypedArray = function(componentDatatype, valuesOrLength) { + if (!defined_default(componentDatatype)) { + throw new DeveloperError_default("componentDatatype is required."); + } + if (!defined_default(valuesOrLength)) { + throw new DeveloperError_default("valuesOrLength is required."); + } + switch (componentDatatype) { + case ComponentDatatype.BYTE: + return new Int8Array(valuesOrLength); + case ComponentDatatype.UNSIGNED_BYTE: + return new Uint8Array(valuesOrLength); + case ComponentDatatype.SHORT: + return new Int16Array(valuesOrLength); + case ComponentDatatype.UNSIGNED_SHORT: + return new Uint16Array(valuesOrLength); + case ComponentDatatype.INT: + return new Int32Array(valuesOrLength); + case ComponentDatatype.UNSIGNED_INT: + return new Uint32Array(valuesOrLength); + case ComponentDatatype.FLOAT: + return new Float32Array(valuesOrLength); + case ComponentDatatype.DOUBLE: + return new Float64Array(valuesOrLength); + default: + throw new DeveloperError_default("componentDatatype is not a valid value."); + } +}; +ComponentDatatype.createArrayBufferView = function(componentDatatype, buffer, byteOffset, length) { + if (!defined_default(componentDatatype)) { + throw new DeveloperError_default("componentDatatype is required."); + } + if (!defined_default(buffer)) { + throw new DeveloperError_default("buffer is required."); + } + byteOffset = defaultValue_default(byteOffset, 0); + length = defaultValue_default( + length, + (buffer.byteLength - byteOffset) / ComponentDatatype.getSizeInBytes(componentDatatype) + ); + switch (componentDatatype) { + case ComponentDatatype.BYTE: + return new Int8Array(buffer, byteOffset, length); + case ComponentDatatype.UNSIGNED_BYTE: + return new Uint8Array(buffer, byteOffset, length); + case ComponentDatatype.SHORT: + return new Int16Array(buffer, byteOffset, length); + case ComponentDatatype.UNSIGNED_SHORT: + return new Uint16Array(buffer, byteOffset, length); + case ComponentDatatype.INT: + return new Int32Array(buffer, byteOffset, length); + case ComponentDatatype.UNSIGNED_INT: + return new Uint32Array(buffer, byteOffset, length); + case ComponentDatatype.FLOAT: + return new Float32Array(buffer, byteOffset, length); + case ComponentDatatype.DOUBLE: + return new Float64Array(buffer, byteOffset, length); + default: + throw new DeveloperError_default("componentDatatype is not a valid value."); + } +}; +ComponentDatatype.fromName = function(name) { + switch (name) { + case "BYTE": + return ComponentDatatype.BYTE; + case "UNSIGNED_BYTE": + return ComponentDatatype.UNSIGNED_BYTE; + case "SHORT": + return ComponentDatatype.SHORT; + case "UNSIGNED_SHORT": + return ComponentDatatype.UNSIGNED_SHORT; + case "INT": + return ComponentDatatype.INT; + case "UNSIGNED_INT": + return ComponentDatatype.UNSIGNED_INT; + case "FLOAT": + return ComponentDatatype.FLOAT; + case "DOUBLE": + return ComponentDatatype.DOUBLE; + default: + throw new DeveloperError_default("name is not a valid value."); + } +}; +var ComponentDatatype_default = Object.freeze(ComponentDatatype); + +export { + ComponentDatatype_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-LGSGX2RH.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-LGSGX2RH.js new file mode 100644 index 0000000000000000000000000000000000000000..e848541ca9bc85f303f6abc0844db6e9fc7b756b --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-LGSGX2RH.js @@ -0,0 +1,757 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + AttributeCompression_default +} from "./chunk-P7PWX5HR.js"; +import { + BoundingSphere_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default, + Matrix4_default, + Rectangle_default +} from "./chunk-PW5CA4MJ.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default, + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/EllipsoidalOccluder.js +function EllipsoidalOccluder(ellipsoid, cameraPosition) { + Check_default.typeOf.object("ellipsoid", ellipsoid); + this._ellipsoid = ellipsoid; + this._cameraPosition = new Cartesian3_default(); + this._cameraPositionInScaledSpace = new Cartesian3_default(); + this._distanceToLimbInScaledSpaceSquared = 0; + if (defined_default(cameraPosition)) { + this.cameraPosition = cameraPosition; + } +} +Object.defineProperties(EllipsoidalOccluder.prototype, { + /** + * Gets the occluding ellipsoid. + * @memberof EllipsoidalOccluder.prototype + * @type {Ellipsoid} + */ + ellipsoid: { + get: function() { + return this._ellipsoid; + } + }, + /** + * Gets or sets the position of the camera. + * @memberof EllipsoidalOccluder.prototype + * @type {Cartesian3} + */ + cameraPosition: { + get: function() { + return this._cameraPosition; + }, + set: function(cameraPosition) { + const ellipsoid = this._ellipsoid; + const cv = ellipsoid.transformPositionToScaledSpace( + cameraPosition, + this._cameraPositionInScaledSpace + ); + const vhMagnitudeSquared = Cartesian3_default.magnitudeSquared(cv) - 1; + Cartesian3_default.clone(cameraPosition, this._cameraPosition); + this._cameraPositionInScaledSpace = cv; + this._distanceToLimbInScaledSpaceSquared = vhMagnitudeSquared; + } + } +}); +var scratchCartesian = new Cartesian3_default(); +EllipsoidalOccluder.prototype.isPointVisible = function(occludee) { + const ellipsoid = this._ellipsoid; + const occludeeScaledSpacePosition = ellipsoid.transformPositionToScaledSpace( + occludee, + scratchCartesian + ); + return isScaledSpacePointVisible( + occludeeScaledSpacePosition, + this._cameraPositionInScaledSpace, + this._distanceToLimbInScaledSpaceSquared + ); +}; +EllipsoidalOccluder.prototype.isScaledSpacePointVisible = function(occludeeScaledSpacePosition) { + return isScaledSpacePointVisible( + occludeeScaledSpacePosition, + this._cameraPositionInScaledSpace, + this._distanceToLimbInScaledSpaceSquared + ); +}; +var scratchCameraPositionInScaledSpaceShrunk = new Cartesian3_default(); +EllipsoidalOccluder.prototype.isScaledSpacePointVisiblePossiblyUnderEllipsoid = function(occludeeScaledSpacePosition, minimumHeight) { + const ellipsoid = this._ellipsoid; + let vhMagnitudeSquared; + let cv; + if (defined_default(minimumHeight) && minimumHeight < 0 && ellipsoid.minimumRadius > -minimumHeight) { + cv = scratchCameraPositionInScaledSpaceShrunk; + cv.x = this._cameraPosition.x / (ellipsoid.radii.x + minimumHeight); + cv.y = this._cameraPosition.y / (ellipsoid.radii.y + minimumHeight); + cv.z = this._cameraPosition.z / (ellipsoid.radii.z + minimumHeight); + vhMagnitudeSquared = cv.x * cv.x + cv.y * cv.y + cv.z * cv.z - 1; + } else { + cv = this._cameraPositionInScaledSpace; + vhMagnitudeSquared = this._distanceToLimbInScaledSpaceSquared; + } + return isScaledSpacePointVisible( + occludeeScaledSpacePosition, + cv, + vhMagnitudeSquared + ); +}; +EllipsoidalOccluder.prototype.computeHorizonCullingPoint = function(directionToPoint, positions, result) { + return computeHorizonCullingPointFromPositions( + this._ellipsoid, + directionToPoint, + positions, + result + ); +}; +var scratchEllipsoidShrunk = Ellipsoid_default.clone(Ellipsoid_default.UNIT_SPHERE); +EllipsoidalOccluder.prototype.computeHorizonCullingPointPossiblyUnderEllipsoid = function(directionToPoint, positions, minimumHeight, result) { + const possiblyShrunkEllipsoid = getPossiblyShrunkEllipsoid( + this._ellipsoid, + minimumHeight, + scratchEllipsoidShrunk + ); + return computeHorizonCullingPointFromPositions( + possiblyShrunkEllipsoid, + directionToPoint, + positions, + result + ); +}; +EllipsoidalOccluder.prototype.computeHorizonCullingPointFromVertices = function(directionToPoint, vertices, stride, center, result) { + return computeHorizonCullingPointFromVertices( + this._ellipsoid, + directionToPoint, + vertices, + stride, + center, + result + ); +}; +EllipsoidalOccluder.prototype.computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid = function(directionToPoint, vertices, stride, center, minimumHeight, result) { + const possiblyShrunkEllipsoid = getPossiblyShrunkEllipsoid( + this._ellipsoid, + minimumHeight, + scratchEllipsoidShrunk + ); + return computeHorizonCullingPointFromVertices( + possiblyShrunkEllipsoid, + directionToPoint, + vertices, + stride, + center, + result + ); +}; +var subsampleScratch = []; +EllipsoidalOccluder.prototype.computeHorizonCullingPointFromRectangle = function(rectangle, ellipsoid, result) { + Check_default.typeOf.object("rectangle", rectangle); + const positions = Rectangle_default.subsample( + rectangle, + ellipsoid, + 0, + subsampleScratch + ); + const bs = BoundingSphere_default.fromPoints(positions); + if (Cartesian3_default.magnitude(bs.center) < 0.1 * ellipsoid.minimumRadius) { + return void 0; + } + return this.computeHorizonCullingPoint(bs.center, positions, result); +}; +var scratchEllipsoidShrunkRadii = new Cartesian3_default(); +function getPossiblyShrunkEllipsoid(ellipsoid, minimumHeight, result) { + if (defined_default(minimumHeight) && minimumHeight < 0 && ellipsoid.minimumRadius > -minimumHeight) { + const ellipsoidShrunkRadii = Cartesian3_default.fromElements( + ellipsoid.radii.x + minimumHeight, + ellipsoid.radii.y + minimumHeight, + ellipsoid.radii.z + minimumHeight, + scratchEllipsoidShrunkRadii + ); + ellipsoid = Ellipsoid_default.fromCartesian3(ellipsoidShrunkRadii, result); + } + return ellipsoid; +} +function computeHorizonCullingPointFromPositions(ellipsoid, directionToPoint, positions, result) { + Check_default.typeOf.object("directionToPoint", directionToPoint); + Check_default.defined("positions", positions); + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + const scaledSpaceDirectionToPoint = computeScaledSpaceDirectionToPoint( + ellipsoid, + directionToPoint + ); + let resultMagnitude = 0; + for (let i = 0, len = positions.length; i < len; ++i) { + const position = positions[i]; + const candidateMagnitude = computeMagnitude( + ellipsoid, + position, + scaledSpaceDirectionToPoint + ); + if (candidateMagnitude < 0) { + return void 0; + } + resultMagnitude = Math.max(resultMagnitude, candidateMagnitude); + } + return magnitudeToPoint(scaledSpaceDirectionToPoint, resultMagnitude, result); +} +var positionScratch = new Cartesian3_default(); +function computeHorizonCullingPointFromVertices(ellipsoid, directionToPoint, vertices, stride, center, result) { + Check_default.typeOf.object("directionToPoint", directionToPoint); + Check_default.defined("vertices", vertices); + Check_default.typeOf.number("stride", stride); + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + stride = defaultValue_default(stride, 3); + center = defaultValue_default(center, Cartesian3_default.ZERO); + const scaledSpaceDirectionToPoint = computeScaledSpaceDirectionToPoint( + ellipsoid, + directionToPoint + ); + let resultMagnitude = 0; + for (let i = 0, len = vertices.length; i < len; i += stride) { + positionScratch.x = vertices[i] + center.x; + positionScratch.y = vertices[i + 1] + center.y; + positionScratch.z = vertices[i + 2] + center.z; + const candidateMagnitude = computeMagnitude( + ellipsoid, + positionScratch, + scaledSpaceDirectionToPoint + ); + if (candidateMagnitude < 0) { + return void 0; + } + resultMagnitude = Math.max(resultMagnitude, candidateMagnitude); + } + return magnitudeToPoint(scaledSpaceDirectionToPoint, resultMagnitude, result); +} +function isScaledSpacePointVisible(occludeeScaledSpacePosition, cameraPositionInScaledSpace, distanceToLimbInScaledSpaceSquared) { + const cv = cameraPositionInScaledSpace; + const vhMagnitudeSquared = distanceToLimbInScaledSpaceSquared; + const vt = Cartesian3_default.subtract( + occludeeScaledSpacePosition, + cv, + scratchCartesian + ); + const vtDotVc = -Cartesian3_default.dot(vt, cv); + const isOccluded = vhMagnitudeSquared < 0 ? vtDotVc > 0 : vtDotVc > vhMagnitudeSquared && vtDotVc * vtDotVc / Cartesian3_default.magnitudeSquared(vt) > vhMagnitudeSquared; + return !isOccluded; +} +var scaledSpaceScratch = new Cartesian3_default(); +var directionScratch = new Cartesian3_default(); +function computeMagnitude(ellipsoid, position, scaledSpaceDirectionToPoint) { + const scaledSpacePosition = ellipsoid.transformPositionToScaledSpace( + position, + scaledSpaceScratch + ); + let magnitudeSquared = Cartesian3_default.magnitudeSquared(scaledSpacePosition); + let magnitude = Math.sqrt(magnitudeSquared); + const direction = Cartesian3_default.divideByScalar( + scaledSpacePosition, + magnitude, + directionScratch + ); + magnitudeSquared = Math.max(1, magnitudeSquared); + magnitude = Math.max(1, magnitude); + const cosAlpha = Cartesian3_default.dot(direction, scaledSpaceDirectionToPoint); + const sinAlpha = Cartesian3_default.magnitude( + Cartesian3_default.cross(direction, scaledSpaceDirectionToPoint, direction) + ); + const cosBeta = 1 / magnitude; + const sinBeta = Math.sqrt(magnitudeSquared - 1) * cosBeta; + return 1 / (cosAlpha * cosBeta - sinAlpha * sinBeta); +} +function magnitudeToPoint(scaledSpaceDirectionToPoint, resultMagnitude, result) { + if (resultMagnitude <= 0 || resultMagnitude === 1 / 0 || resultMagnitude !== resultMagnitude) { + return void 0; + } + return Cartesian3_default.multiplyByScalar( + scaledSpaceDirectionToPoint, + resultMagnitude, + result + ); +} +var directionToPointScratch = new Cartesian3_default(); +function computeScaledSpaceDirectionToPoint(ellipsoid, directionToPoint) { + if (Cartesian3_default.equals(directionToPoint, Cartesian3_default.ZERO)) { + return directionToPoint; + } + ellipsoid.transformPositionToScaledSpace( + directionToPoint, + directionToPointScratch + ); + return Cartesian3_default.normalize(directionToPointScratch, directionToPointScratch); +} +var EllipsoidalOccluder_default = EllipsoidalOccluder; + +// packages/engine/Source/Core/TerrainExaggeration.js +var TerrainExaggeration = {}; +TerrainExaggeration.getHeight = function(height, scale, relativeHeight) { + return (height - relativeHeight) * scale + relativeHeight; +}; +var scratchCartographic = new Cartesian3_default(); +TerrainExaggeration.getPosition = function(position, ellipsoid, terrainExaggeration, terrainExaggerationRelativeHeight, result) { + const cartographic = ellipsoid.cartesianToCartographic( + position, + scratchCartographic + ); + const newHeight = TerrainExaggeration.getHeight( + cartographic.height, + terrainExaggeration, + terrainExaggerationRelativeHeight + ); + return Cartesian3_default.fromRadians( + cartographic.longitude, + cartographic.latitude, + newHeight, + ellipsoid, + result + ); +}; +var TerrainExaggeration_default = TerrainExaggeration; + +// packages/engine/Source/Core/TerrainQuantization.js +var TerrainQuantization = { + /** + * The vertices are not compressed. + * + * @type {number} + * @constant + */ + NONE: 0, + /** + * The vertices are compressed to 12 bits. + * + * @type {number} + * @constant + */ + BITS12: 1 +}; +var TerrainQuantization_default = Object.freeze(TerrainQuantization); + +// packages/engine/Source/Core/TerrainEncoding.js +var cartesian3Scratch = new Cartesian3_default(); +var cartesian3DimScratch = new Cartesian3_default(); +var cartesian2Scratch = new Cartesian2_default(); +var matrix4Scratch = new Matrix4_default(); +var matrix4Scratch2 = new Matrix4_default(); +var SHIFT_LEFT_12 = Math.pow(2, 12); +function TerrainEncoding(center, axisAlignedBoundingBox, minimumHeight, maximumHeight, fromENU, hasVertexNormals, hasWebMercatorT, hasGeodeticSurfaceNormals, exaggeration, exaggerationRelativeHeight) { + let quantization = TerrainQuantization_default.NONE; + let toENU; + let matrix; + if (defined_default(axisAlignedBoundingBox) && defined_default(minimumHeight) && defined_default(maximumHeight) && defined_default(fromENU)) { + const minimum = axisAlignedBoundingBox.minimum; + const maximum = axisAlignedBoundingBox.maximum; + const dimensions = Cartesian3_default.subtract( + maximum, + minimum, + cartesian3DimScratch + ); + const hDim = maximumHeight - minimumHeight; + const maxDim = Math.max(Cartesian3_default.maximumComponent(dimensions), hDim); + if (maxDim < SHIFT_LEFT_12 - 1) { + quantization = TerrainQuantization_default.BITS12; + } else { + quantization = TerrainQuantization_default.NONE; + } + toENU = Matrix4_default.inverseTransformation(fromENU, new Matrix4_default()); + const translation = Cartesian3_default.negate(minimum, cartesian3Scratch); + Matrix4_default.multiply( + Matrix4_default.fromTranslation(translation, matrix4Scratch), + toENU, + toENU + ); + const scale = cartesian3Scratch; + scale.x = 1 / dimensions.x; + scale.y = 1 / dimensions.y; + scale.z = 1 / dimensions.z; + Matrix4_default.multiply(Matrix4_default.fromScale(scale, matrix4Scratch), toENU, toENU); + matrix = Matrix4_default.clone(fromENU); + Matrix4_default.setTranslation(matrix, Cartesian3_default.ZERO, matrix); + fromENU = Matrix4_default.clone(fromENU, new Matrix4_default()); + const translationMatrix = Matrix4_default.fromTranslation(minimum, matrix4Scratch); + const scaleMatrix = Matrix4_default.fromScale(dimensions, matrix4Scratch2); + const st = Matrix4_default.multiply(translationMatrix, scaleMatrix, matrix4Scratch); + Matrix4_default.multiply(fromENU, st, fromENU); + Matrix4_default.multiply(matrix, st, matrix); + } + this.quantization = quantization; + this.minimumHeight = minimumHeight; + this.maximumHeight = maximumHeight; + this.center = Cartesian3_default.clone(center); + this.toScaledENU = toENU; + this.fromScaledENU = fromENU; + this.matrix = matrix; + this.hasVertexNormals = hasVertexNormals; + this.hasWebMercatorT = defaultValue_default(hasWebMercatorT, false); + this.hasGeodeticSurfaceNormals = defaultValue_default( + hasGeodeticSurfaceNormals, + false + ); + this.exaggeration = defaultValue_default(exaggeration, 1); + this.exaggerationRelativeHeight = defaultValue_default( + exaggerationRelativeHeight, + 0 + ); + this.stride = 0; + this._offsetGeodeticSurfaceNormal = 0; + this._offsetVertexNormal = 0; + this._calculateStrideAndOffsets(); +} +TerrainEncoding.prototype.encode = function(vertexBuffer, bufferIndex, position, uv, height, normalToPack, webMercatorT, geodeticSurfaceNormal) { + const u = uv.x; + const v = uv.y; + if (this.quantization === TerrainQuantization_default.BITS12) { + position = Matrix4_default.multiplyByPoint( + this.toScaledENU, + position, + cartesian3Scratch + ); + position.x = Math_default.clamp(position.x, 0, 1); + position.y = Math_default.clamp(position.y, 0, 1); + position.z = Math_default.clamp(position.z, 0, 1); + const hDim = this.maximumHeight - this.minimumHeight; + const h = Math_default.clamp((height - this.minimumHeight) / hDim, 0, 1); + Cartesian2_default.fromElements(position.x, position.y, cartesian2Scratch); + const compressed0 = AttributeCompression_default.compressTextureCoordinates( + cartesian2Scratch + ); + Cartesian2_default.fromElements(position.z, h, cartesian2Scratch); + const compressed1 = AttributeCompression_default.compressTextureCoordinates( + cartesian2Scratch + ); + Cartesian2_default.fromElements(u, v, cartesian2Scratch); + const compressed2 = AttributeCompression_default.compressTextureCoordinates( + cartesian2Scratch + ); + vertexBuffer[bufferIndex++] = compressed0; + vertexBuffer[bufferIndex++] = compressed1; + vertexBuffer[bufferIndex++] = compressed2; + if (this.hasWebMercatorT) { + Cartesian2_default.fromElements(webMercatorT, 0, cartesian2Scratch); + const compressed3 = AttributeCompression_default.compressTextureCoordinates( + cartesian2Scratch + ); + vertexBuffer[bufferIndex++] = compressed3; + } + } else { + Cartesian3_default.subtract(position, this.center, cartesian3Scratch); + vertexBuffer[bufferIndex++] = cartesian3Scratch.x; + vertexBuffer[bufferIndex++] = cartesian3Scratch.y; + vertexBuffer[bufferIndex++] = cartesian3Scratch.z; + vertexBuffer[bufferIndex++] = height; + vertexBuffer[bufferIndex++] = u; + vertexBuffer[bufferIndex++] = v; + if (this.hasWebMercatorT) { + vertexBuffer[bufferIndex++] = webMercatorT; + } + } + if (this.hasVertexNormals) { + vertexBuffer[bufferIndex++] = AttributeCompression_default.octPackFloat( + normalToPack + ); + } + if (this.hasGeodeticSurfaceNormals) { + vertexBuffer[bufferIndex++] = geodeticSurfaceNormal.x; + vertexBuffer[bufferIndex++] = geodeticSurfaceNormal.y; + vertexBuffer[bufferIndex++] = geodeticSurfaceNormal.z; + } + return bufferIndex; +}; +var scratchPosition = new Cartesian3_default(); +var scratchGeodeticSurfaceNormal = new Cartesian3_default(); +TerrainEncoding.prototype.addGeodeticSurfaceNormals = function(oldBuffer, newBuffer, ellipsoid) { + if (this.hasGeodeticSurfaceNormals) { + return; + } + const oldStride = this.stride; + const vertexCount = oldBuffer.length / oldStride; + this.hasGeodeticSurfaceNormals = true; + this._calculateStrideAndOffsets(); + const newStride = this.stride; + for (let index = 0; index < vertexCount; index++) { + for (let offset = 0; offset < oldStride; offset++) { + const oldIndex = index * oldStride + offset; + const newIndex = index * newStride + offset; + newBuffer[newIndex] = oldBuffer[oldIndex]; + } + const position = this.decodePosition(newBuffer, index, scratchPosition); + const geodeticSurfaceNormal = ellipsoid.geodeticSurfaceNormal( + position, + scratchGeodeticSurfaceNormal + ); + const bufferIndex = index * newStride + this._offsetGeodeticSurfaceNormal; + newBuffer[bufferIndex] = geodeticSurfaceNormal.x; + newBuffer[bufferIndex + 1] = geodeticSurfaceNormal.y; + newBuffer[bufferIndex + 2] = geodeticSurfaceNormal.z; + } +}; +TerrainEncoding.prototype.removeGeodeticSurfaceNormals = function(oldBuffer, newBuffer) { + if (!this.hasGeodeticSurfaceNormals) { + return; + } + const oldStride = this.stride; + const vertexCount = oldBuffer.length / oldStride; + this.hasGeodeticSurfaceNormals = false; + this._calculateStrideAndOffsets(); + const newStride = this.stride; + for (let index = 0; index < vertexCount; index++) { + for (let offset = 0; offset < newStride; offset++) { + const oldIndex = index * oldStride + offset; + const newIndex = index * newStride + offset; + newBuffer[newIndex] = oldBuffer[oldIndex]; + } + } +}; +TerrainEncoding.prototype.decodePosition = function(buffer, index, result) { + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + index *= this.stride; + if (this.quantization === TerrainQuantization_default.BITS12) { + const xy = AttributeCompression_default.decompressTextureCoordinates( + buffer[index], + cartesian2Scratch + ); + result.x = xy.x; + result.y = xy.y; + const zh = AttributeCompression_default.decompressTextureCoordinates( + buffer[index + 1], + cartesian2Scratch + ); + result.z = zh.x; + return Matrix4_default.multiplyByPoint(this.fromScaledENU, result, result); + } + result.x = buffer[index]; + result.y = buffer[index + 1]; + result.z = buffer[index + 2]; + return Cartesian3_default.add(result, this.center, result); +}; +TerrainEncoding.prototype.getExaggeratedPosition = function(buffer, index, result) { + result = this.decodePosition(buffer, index, result); + const exaggeration = this.exaggeration; + const exaggerationRelativeHeight = this.exaggerationRelativeHeight; + const hasExaggeration = exaggeration !== 1; + if (hasExaggeration && this.hasGeodeticSurfaceNormals) { + const geodeticSurfaceNormal = this.decodeGeodeticSurfaceNormal( + buffer, + index, + scratchGeodeticSurfaceNormal + ); + const rawHeight = this.decodeHeight(buffer, index); + const heightDifference = TerrainExaggeration_default.getHeight( + rawHeight, + exaggeration, + exaggerationRelativeHeight + ) - rawHeight; + result.x += geodeticSurfaceNormal.x * heightDifference; + result.y += geodeticSurfaceNormal.y * heightDifference; + result.z += geodeticSurfaceNormal.z * heightDifference; + } + return result; +}; +TerrainEncoding.prototype.decodeTextureCoordinates = function(buffer, index, result) { + if (!defined_default(result)) { + result = new Cartesian2_default(); + } + index *= this.stride; + if (this.quantization === TerrainQuantization_default.BITS12) { + return AttributeCompression_default.decompressTextureCoordinates( + buffer[index + 2], + result + ); + } + return Cartesian2_default.fromElements(buffer[index + 4], buffer[index + 5], result); +}; +TerrainEncoding.prototype.decodeHeight = function(buffer, index) { + index *= this.stride; + if (this.quantization === TerrainQuantization_default.BITS12) { + const zh = AttributeCompression_default.decompressTextureCoordinates( + buffer[index + 1], + cartesian2Scratch + ); + return zh.y * (this.maximumHeight - this.minimumHeight) + this.minimumHeight; + } + return buffer[index + 3]; +}; +TerrainEncoding.prototype.decodeWebMercatorT = function(buffer, index) { + index *= this.stride; + if (this.quantization === TerrainQuantization_default.BITS12) { + return AttributeCompression_default.decompressTextureCoordinates( + buffer[index + 3], + cartesian2Scratch + ).x; + } + return buffer[index + 6]; +}; +TerrainEncoding.prototype.getOctEncodedNormal = function(buffer, index, result) { + index = index * this.stride + this._offsetVertexNormal; + const temp = buffer[index] / 256; + const x = Math.floor(temp); + const y = (temp - x) * 256; + return Cartesian2_default.fromElements(x, y, result); +}; +TerrainEncoding.prototype.decodeGeodeticSurfaceNormal = function(buffer, index, result) { + index = index * this.stride + this._offsetGeodeticSurfaceNormal; + result.x = buffer[index]; + result.y = buffer[index + 1]; + result.z = buffer[index + 2]; + return result; +}; +TerrainEncoding.prototype._calculateStrideAndOffsets = function() { + let vertexStride = 0; + switch (this.quantization) { + case TerrainQuantization_default.BITS12: + vertexStride += 3; + break; + default: + vertexStride += 6; + } + if (this.hasWebMercatorT) { + vertexStride += 1; + } + if (this.hasVertexNormals) { + this._offsetVertexNormal = vertexStride; + vertexStride += 1; + } + if (this.hasGeodeticSurfaceNormals) { + this._offsetGeodeticSurfaceNormal = vertexStride; + vertexStride += 3; + } + this.stride = vertexStride; +}; +var attributesIndicesNone = { + position3DAndHeight: 0, + textureCoordAndEncodedNormals: 1, + geodeticSurfaceNormal: 2 +}; +var attributesIndicesBits12 = { + compressed0: 0, + compressed1: 1, + geodeticSurfaceNormal: 2 +}; +TerrainEncoding.prototype.getAttributes = function(buffer) { + const datatype = ComponentDatatype_default.FLOAT; + const sizeInBytes = ComponentDatatype_default.getSizeInBytes(datatype); + const strideInBytes = this.stride * sizeInBytes; + let offsetInBytes = 0; + const attributes = []; + function addAttribute(index, componentsPerAttribute) { + attributes.push({ + index, + vertexBuffer: buffer, + componentDatatype: datatype, + componentsPerAttribute, + offsetInBytes, + strideInBytes + }); + offsetInBytes += componentsPerAttribute * sizeInBytes; + } + if (this.quantization === TerrainQuantization_default.NONE) { + addAttribute(attributesIndicesNone.position3DAndHeight, 4); + let componentsTexCoordAndNormals = 2; + componentsTexCoordAndNormals += this.hasWebMercatorT ? 1 : 0; + componentsTexCoordAndNormals += this.hasVertexNormals ? 1 : 0; + addAttribute( + attributesIndicesNone.textureCoordAndEncodedNormals, + componentsTexCoordAndNormals + ); + if (this.hasGeodeticSurfaceNormals) { + addAttribute(attributesIndicesNone.geodeticSurfaceNormal, 3); + } + } else { + const usingAttribute0Component4 = this.hasWebMercatorT || this.hasVertexNormals; + const usingAttribute1Component1 = this.hasWebMercatorT && this.hasVertexNormals; + addAttribute( + attributesIndicesBits12.compressed0, + usingAttribute0Component4 ? 4 : 3 + ); + if (usingAttribute1Component1) { + addAttribute(attributesIndicesBits12.compressed1, 1); + } + if (this.hasGeodeticSurfaceNormals) { + addAttribute(attributesIndicesBits12.geodeticSurfaceNormal, 3); + } + } + return attributes; +}; +TerrainEncoding.prototype.getAttributeLocations = function() { + if (this.quantization === TerrainQuantization_default.NONE) { + return attributesIndicesNone; + } + return attributesIndicesBits12; +}; +TerrainEncoding.clone = function(encoding, result) { + if (!defined_default(encoding)) { + return void 0; + } + if (!defined_default(result)) { + result = new TerrainEncoding(); + } + result.quantization = encoding.quantization; + result.minimumHeight = encoding.minimumHeight; + result.maximumHeight = encoding.maximumHeight; + result.center = Cartesian3_default.clone(encoding.center); + result.toScaledENU = Matrix4_default.clone(encoding.toScaledENU); + result.fromScaledENU = Matrix4_default.clone(encoding.fromScaledENU); + result.matrix = Matrix4_default.clone(encoding.matrix); + result.hasVertexNormals = encoding.hasVertexNormals; + result.hasWebMercatorT = encoding.hasWebMercatorT; + result.hasGeodeticSurfaceNormals = encoding.hasGeodeticSurfaceNormals; + result.exaggeration = encoding.exaggeration; + result.exaggerationRelativeHeight = encoding.exaggerationRelativeHeight; + result._calculateStrideAndOffsets(); + return result; +}; +var TerrainEncoding_default = TerrainEncoding; + +export { + EllipsoidalOccluder_default, + TerrainEncoding_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-LQRFWCNX.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-LQRFWCNX.js new file mode 100644 index 0000000000000000000000000000000000000000..bdbaa465f46e0098e89540d9f2c6d279fa7eb994 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-LQRFWCNX.js @@ -0,0 +1,124 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + OrientedBoundingBox_default +} from "./chunk-YLAFWVOW.js"; +import { + Cartesian2_default +} from "./chunk-PW5CA4MJ.js"; +import { + Cartesian3_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Check_default +} from "./chunk-UN7AK64D.js"; + +// packages/engine/Source/Core/CoplanarPolygonGeometryLibrary.js +var CoplanarPolygonGeometryLibrary = {}; +var scratchIntersectionPoint = new Cartesian3_default(); +var scratchXAxis = new Cartesian3_default(); +var scratchYAxis = new Cartesian3_default(); +var scratchZAxis = new Cartesian3_default(); +var obbScratch = new OrientedBoundingBox_default(); +CoplanarPolygonGeometryLibrary.validOutline = function(positions) { + Check_default.defined("positions", positions); + const orientedBoundingBox = OrientedBoundingBox_default.fromPoints( + positions, + obbScratch + ); + const halfAxes = orientedBoundingBox.halfAxes; + const xAxis = Matrix3_default.getColumn(halfAxes, 0, scratchXAxis); + const yAxis = Matrix3_default.getColumn(halfAxes, 1, scratchYAxis); + const zAxis = Matrix3_default.getColumn(halfAxes, 2, scratchZAxis); + const xMag = Cartesian3_default.magnitude(xAxis); + const yMag = Cartesian3_default.magnitude(yAxis); + const zMag = Cartesian3_default.magnitude(zAxis); + return !(xMag === 0 && (yMag === 0 || zMag === 0) || yMag === 0 && zMag === 0); +}; +CoplanarPolygonGeometryLibrary.computeProjectTo2DArguments = function(positions, centerResult, planeAxis1Result, planeAxis2Result) { + Check_default.defined("positions", positions); + Check_default.defined("centerResult", centerResult); + Check_default.defined("planeAxis1Result", planeAxis1Result); + Check_default.defined("planeAxis2Result", planeAxis2Result); + const orientedBoundingBox = OrientedBoundingBox_default.fromPoints( + positions, + obbScratch + ); + const halfAxes = orientedBoundingBox.halfAxes; + const xAxis = Matrix3_default.getColumn(halfAxes, 0, scratchXAxis); + const yAxis = Matrix3_default.getColumn(halfAxes, 1, scratchYAxis); + const zAxis = Matrix3_default.getColumn(halfAxes, 2, scratchZAxis); + const xMag = Cartesian3_default.magnitude(xAxis); + const yMag = Cartesian3_default.magnitude(yAxis); + const zMag = Cartesian3_default.magnitude(zAxis); + const min = Math.min(xMag, yMag, zMag); + if (xMag === 0 && (yMag === 0 || zMag === 0) || yMag === 0 && zMag === 0) { + return false; + } + let planeAxis1; + let planeAxis2; + if (min === yMag || min === zMag) { + planeAxis1 = xAxis; + } + if (min === xMag) { + planeAxis1 = yAxis; + } else if (min === zMag) { + planeAxis2 = yAxis; + } + if (min === xMag || min === yMag) { + planeAxis2 = zAxis; + } + Cartesian3_default.normalize(planeAxis1, planeAxis1Result); + Cartesian3_default.normalize(planeAxis2, planeAxis2Result); + Cartesian3_default.clone(orientedBoundingBox.center, centerResult); + return true; +}; +function projectTo2D(position, center, axis1, axis2, result) { + const v = Cartesian3_default.subtract(position, center, scratchIntersectionPoint); + const x = Cartesian3_default.dot(axis1, v); + const y = Cartesian3_default.dot(axis2, v); + return Cartesian2_default.fromElements(x, y, result); +} +CoplanarPolygonGeometryLibrary.createProjectPointsTo2DFunction = function(center, axis1, axis2) { + return function(positions) { + const positionResults = new Array(positions.length); + for (let i = 0; i < positions.length; i++) { + positionResults[i] = projectTo2D(positions[i], center, axis1, axis2); + } + return positionResults; + }; +}; +CoplanarPolygonGeometryLibrary.createProjectPointTo2DFunction = function(center, axis1, axis2) { + return function(position, result) { + return projectTo2D(position, center, axis1, axis2, result); + }; +}; +var CoplanarPolygonGeometryLibrary_default = CoplanarPolygonGeometryLibrary; + +export { + CoplanarPolygonGeometryLibrary_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-N5MMDSD2.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-N5MMDSD2.js new file mode 100644 index 0000000000000000000000000000000000000000..50d9d3ef601b3d614a96d014aa5686c81717079b --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-N5MMDSD2.js @@ -0,0 +1,44 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; + +// packages/engine/Source/Core/GeometryAttributes.js +function GeometryAttributes(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + this.position = options.position; + this.normal = options.normal; + this.st = options.st; + this.bitangent = options.bitangent; + this.tangent = options.tangent; + this.color = options.color; +} +var GeometryAttributes_default = GeometryAttributes; + +export { + GeometryAttributes_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-NRETMGYL.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-NRETMGYL.js new file mode 100644 index 0000000000000000000000000000000000000000..77abdf2b11ba094bf5e68dc208e0a66f502599fc --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-NRETMGYL.js @@ -0,0 +1,390 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + EllipseGeometryLibrary_default +} from "./chunk-H6MBQ4W4.js"; +import { + GeometryOffsetAttribute_default +} from "./chunk-A6EA6KIE.js"; +import { + IndexDatatype_default +} from "./chunk-TF5D2H7B.js"; +import { + GeometryAttributes_default +} from "./chunk-N5MMDSD2.js"; +import { + GeometryAttribute_default, + Geometry_default, + PrimitiveType_default +} from "./chunk-UGZGTV5K.js"; +import { + BoundingSphere_default +} from "./chunk-5U4UHRZ2.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default, + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/EllipseOutlineGeometry.js +var scratchCartesian1 = new Cartesian3_default(); +var boundingSphereCenter = new Cartesian3_default(); +function computeEllipse(options) { + const center = options.center; + boundingSphereCenter = Cartesian3_default.multiplyByScalar( + options.ellipsoid.geodeticSurfaceNormal(center, boundingSphereCenter), + options.height, + boundingSphereCenter + ); + boundingSphereCenter = Cartesian3_default.add( + center, + boundingSphereCenter, + boundingSphereCenter + ); + const boundingSphere = new BoundingSphere_default( + boundingSphereCenter, + options.semiMajorAxis + ); + const positions = EllipseGeometryLibrary_default.computeEllipsePositions( + options, + false, + true + ).outerPositions; + const attributes = new GeometryAttributes_default({ + position: new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: EllipseGeometryLibrary_default.raisePositionsToHeight( + positions, + options, + false + ) + }) + }); + const length = positions.length / 3; + const indices = IndexDatatype_default.createTypedArray(length, length * 2); + let index = 0; + for (let i = 0; i < length; ++i) { + indices[index++] = i; + indices[index++] = (i + 1) % length; + } + return { + boundingSphere, + attributes, + indices + }; +} +var topBoundingSphere = new BoundingSphere_default(); +var bottomBoundingSphere = new BoundingSphere_default(); +function computeExtrudedEllipse(options) { + const center = options.center; + const ellipsoid = options.ellipsoid; + const semiMajorAxis = options.semiMajorAxis; + let scaledNormal = Cartesian3_default.multiplyByScalar( + ellipsoid.geodeticSurfaceNormal(center, scratchCartesian1), + options.height, + scratchCartesian1 + ); + topBoundingSphere.center = Cartesian3_default.add( + center, + scaledNormal, + topBoundingSphere.center + ); + topBoundingSphere.radius = semiMajorAxis; + scaledNormal = Cartesian3_default.multiplyByScalar( + ellipsoid.geodeticSurfaceNormal(center, scaledNormal), + options.extrudedHeight, + scaledNormal + ); + bottomBoundingSphere.center = Cartesian3_default.add( + center, + scaledNormal, + bottomBoundingSphere.center + ); + bottomBoundingSphere.radius = semiMajorAxis; + let positions = EllipseGeometryLibrary_default.computeEllipsePositions( + options, + false, + true + ).outerPositions; + const attributes = new GeometryAttributes_default({ + position: new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: EllipseGeometryLibrary_default.raisePositionsToHeight( + positions, + options, + true + ) + }) + }); + positions = attributes.position.values; + const boundingSphere = BoundingSphere_default.union( + topBoundingSphere, + bottomBoundingSphere + ); + let length = positions.length / 3; + if (defined_default(options.offsetAttribute)) { + let applyOffset = new Uint8Array(length); + if (options.offsetAttribute === GeometryOffsetAttribute_default.TOP) { + applyOffset = applyOffset.fill(1, 0, length / 2); + } else { + const offsetValue = options.offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1; + applyOffset = applyOffset.fill(offsetValue); + } + attributes.applyOffset = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE, + componentsPerAttribute: 1, + values: applyOffset + }); + } + let numberOfVerticalLines = defaultValue_default(options.numberOfVerticalLines, 16); + numberOfVerticalLines = Math_default.clamp( + numberOfVerticalLines, + 0, + length / 2 + ); + const indices = IndexDatatype_default.createTypedArray( + length, + length * 2 + numberOfVerticalLines * 2 + ); + length /= 2; + let index = 0; + let i; + for (i = 0; i < length; ++i) { + indices[index++] = i; + indices[index++] = (i + 1) % length; + indices[index++] = i + length; + indices[index++] = (i + 1) % length + length; + } + let numSide; + if (numberOfVerticalLines > 0) { + const numSideLines = Math.min(numberOfVerticalLines, length); + numSide = Math.round(length / numSideLines); + const maxI = Math.min(numSide * numberOfVerticalLines, length); + for (i = 0; i < maxI; i += numSide) { + indices[index++] = i; + indices[index++] = i + length; + } + } + return { + boundingSphere, + attributes, + indices + }; +} +function EllipseOutlineGeometry(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const center = options.center; + const ellipsoid = defaultValue_default(options.ellipsoid, Ellipsoid_default.WGS84); + const semiMajorAxis = options.semiMajorAxis; + const semiMinorAxis = options.semiMinorAxis; + const granularity = defaultValue_default( + options.granularity, + Math_default.RADIANS_PER_DEGREE + ); + if (!defined_default(center)) { + throw new DeveloperError_default("center is required."); + } + if (!defined_default(semiMajorAxis)) { + throw new DeveloperError_default("semiMajorAxis is required."); + } + if (!defined_default(semiMinorAxis)) { + throw new DeveloperError_default("semiMinorAxis is required."); + } + if (semiMajorAxis < semiMinorAxis) { + throw new DeveloperError_default( + "semiMajorAxis must be greater than or equal to the semiMinorAxis." + ); + } + if (granularity <= 0) { + throw new DeveloperError_default("granularity must be greater than zero."); + } + const height = defaultValue_default(options.height, 0); + const extrudedHeight = defaultValue_default(options.extrudedHeight, height); + this._center = Cartesian3_default.clone(center); + this._semiMajorAxis = semiMajorAxis; + this._semiMinorAxis = semiMinorAxis; + this._ellipsoid = Ellipsoid_default.clone(ellipsoid); + this._rotation = defaultValue_default(options.rotation, 0); + this._height = Math.max(extrudedHeight, height); + this._granularity = granularity; + this._extrudedHeight = Math.min(extrudedHeight, height); + this._numberOfVerticalLines = Math.max( + defaultValue_default(options.numberOfVerticalLines, 16), + 0 + ); + this._offsetAttribute = options.offsetAttribute; + this._workerName = "createEllipseOutlineGeometry"; +} +EllipseOutlineGeometry.packedLength = Cartesian3_default.packedLength + Ellipsoid_default.packedLength + 8; +EllipseOutlineGeometry.pack = function(value, array, startingIndex) { + if (!defined_default(value)) { + throw new DeveloperError_default("value is required"); + } + if (!defined_default(array)) { + throw new DeveloperError_default("array is required"); + } + startingIndex = defaultValue_default(startingIndex, 0); + Cartesian3_default.pack(value._center, array, startingIndex); + startingIndex += Cartesian3_default.packedLength; + Ellipsoid_default.pack(value._ellipsoid, array, startingIndex); + startingIndex += Ellipsoid_default.packedLength; + array[startingIndex++] = value._semiMajorAxis; + array[startingIndex++] = value._semiMinorAxis; + array[startingIndex++] = value._rotation; + array[startingIndex++] = value._height; + array[startingIndex++] = value._granularity; + array[startingIndex++] = value._extrudedHeight; + array[startingIndex++] = value._numberOfVerticalLines; + array[startingIndex] = defaultValue_default(value._offsetAttribute, -1); + return array; +}; +var scratchCenter = new Cartesian3_default(); +var scratchEllipsoid = new Ellipsoid_default(); +var scratchOptions = { + center: scratchCenter, + ellipsoid: scratchEllipsoid, + semiMajorAxis: void 0, + semiMinorAxis: void 0, + rotation: void 0, + height: void 0, + granularity: void 0, + extrudedHeight: void 0, + numberOfVerticalLines: void 0, + offsetAttribute: void 0 +}; +EllipseOutlineGeometry.unpack = function(array, startingIndex, result) { + if (!defined_default(array)) { + throw new DeveloperError_default("array is required"); + } + startingIndex = defaultValue_default(startingIndex, 0); + const center = Cartesian3_default.unpack(array, startingIndex, scratchCenter); + startingIndex += Cartesian3_default.packedLength; + const ellipsoid = Ellipsoid_default.unpack(array, startingIndex, scratchEllipsoid); + startingIndex += Ellipsoid_default.packedLength; + const semiMajorAxis = array[startingIndex++]; + const semiMinorAxis = array[startingIndex++]; + const rotation = array[startingIndex++]; + const height = array[startingIndex++]; + const granularity = array[startingIndex++]; + const extrudedHeight = array[startingIndex++]; + const numberOfVerticalLines = array[startingIndex++]; + const offsetAttribute = array[startingIndex]; + if (!defined_default(result)) { + scratchOptions.height = height; + scratchOptions.extrudedHeight = extrudedHeight; + scratchOptions.granularity = granularity; + scratchOptions.rotation = rotation; + scratchOptions.semiMajorAxis = semiMajorAxis; + scratchOptions.semiMinorAxis = semiMinorAxis; + scratchOptions.numberOfVerticalLines = numberOfVerticalLines; + scratchOptions.offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return new EllipseOutlineGeometry(scratchOptions); + } + result._center = Cartesian3_default.clone(center, result._center); + result._ellipsoid = Ellipsoid_default.clone(ellipsoid, result._ellipsoid); + result._semiMajorAxis = semiMajorAxis; + result._semiMinorAxis = semiMinorAxis; + result._rotation = rotation; + result._height = height; + result._granularity = granularity; + result._extrudedHeight = extrudedHeight; + result._numberOfVerticalLines = numberOfVerticalLines; + result._offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return result; +}; +EllipseOutlineGeometry.createGeometry = function(ellipseGeometry) { + if (ellipseGeometry._semiMajorAxis <= 0 || ellipseGeometry._semiMinorAxis <= 0) { + return; + } + const height = ellipseGeometry._height; + const extrudedHeight = ellipseGeometry._extrudedHeight; + const extrude = !Math_default.equalsEpsilon( + height, + extrudedHeight, + 0, + Math_default.EPSILON2 + ); + ellipseGeometry._center = ellipseGeometry._ellipsoid.scaleToGeodeticSurface( + ellipseGeometry._center, + ellipseGeometry._center + ); + const options = { + center: ellipseGeometry._center, + semiMajorAxis: ellipseGeometry._semiMajorAxis, + semiMinorAxis: ellipseGeometry._semiMinorAxis, + ellipsoid: ellipseGeometry._ellipsoid, + rotation: ellipseGeometry._rotation, + height, + granularity: ellipseGeometry._granularity, + numberOfVerticalLines: ellipseGeometry._numberOfVerticalLines + }; + let geometry; + if (extrude) { + options.extrudedHeight = extrudedHeight; + options.offsetAttribute = ellipseGeometry._offsetAttribute; + geometry = computeExtrudedEllipse(options); + } else { + geometry = computeEllipse(options); + if (defined_default(ellipseGeometry._offsetAttribute)) { + const length = geometry.attributes.position.values.length; + const offsetValue = ellipseGeometry._offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1; + const applyOffset = new Uint8Array(length / 3).fill(offsetValue); + geometry.attributes.applyOffset = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE, + componentsPerAttribute: 1, + values: applyOffset + }); + } + } + return new Geometry_default({ + attributes: geometry.attributes, + indices: geometry.indices, + primitiveType: PrimitiveType_default.LINES, + boundingSphere: geometry.boundingSphere, + offsetAttribute: ellipseGeometry._offsetAttribute + }); +}; +var EllipseOutlineGeometry_default = EllipseOutlineGeometry; + +export { + EllipseOutlineGeometry_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-P4M4QUNQ.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-P4M4QUNQ.js new file mode 100644 index 0000000000000000000000000000000000000000..211d4e30b37a24e00be50ee068f520cb3f37982d --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-P4M4QUNQ.js @@ -0,0 +1,196 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + PolylinePipeline_default +} from "./chunk-H52L6U76.js"; +import { + arrayRemoveDuplicates_default +} from "./chunk-XZVQMPWG.js"; +import { + Cartesian3_default, + Cartographic_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/WallGeometryLibrary.js +var WallGeometryLibrary = {}; +function latLonEquals(c0, c1) { + return Math_default.equalsEpsilon(c0.latitude, c1.latitude, Math_default.EPSILON10) && Math_default.equalsEpsilon(c0.longitude, c1.longitude, Math_default.EPSILON10); +} +var scratchCartographic1 = new Cartographic_default(); +var scratchCartographic2 = new Cartographic_default(); +function removeDuplicates(ellipsoid, positions, topHeights, bottomHeights) { + positions = arrayRemoveDuplicates_default(positions, Cartesian3_default.equalsEpsilon); + const length = positions.length; + if (length < 2) { + return; + } + const hasBottomHeights = defined_default(bottomHeights); + const hasTopHeights = defined_default(topHeights); + const cleanedPositions = new Array(length); + const cleanedTopHeights = new Array(length); + const cleanedBottomHeights = new Array(length); + const v0 = positions[0]; + cleanedPositions[0] = v0; + const c0 = ellipsoid.cartesianToCartographic(v0, scratchCartographic1); + if (hasTopHeights) { + c0.height = topHeights[0]; + } + cleanedTopHeights[0] = c0.height; + if (hasBottomHeights) { + cleanedBottomHeights[0] = bottomHeights[0]; + } else { + cleanedBottomHeights[0] = 0; + } + const startTopHeight = cleanedTopHeights[0]; + const startBottomHeight = cleanedBottomHeights[0]; + let hasAllSameHeights = startTopHeight === startBottomHeight; + let index = 1; + for (let i = 1; i < length; ++i) { + const v1 = positions[i]; + const c1 = ellipsoid.cartesianToCartographic(v1, scratchCartographic2); + if (hasTopHeights) { + c1.height = topHeights[i]; + } + hasAllSameHeights = hasAllSameHeights && c1.height === 0; + if (!latLonEquals(c0, c1)) { + cleanedPositions[index] = v1; + cleanedTopHeights[index] = c1.height; + if (hasBottomHeights) { + cleanedBottomHeights[index] = bottomHeights[i]; + } else { + cleanedBottomHeights[index] = 0; + } + hasAllSameHeights = hasAllSameHeights && cleanedTopHeights[index] === cleanedBottomHeights[index]; + Cartographic_default.clone(c1, c0); + ++index; + } else if (c0.height < c1.height) { + cleanedTopHeights[index - 1] = c1.height; + } + } + if (hasAllSameHeights || index < 2) { + return; + } + cleanedPositions.length = index; + cleanedTopHeights.length = index; + cleanedBottomHeights.length = index; + return { + positions: cleanedPositions, + topHeights: cleanedTopHeights, + bottomHeights: cleanedBottomHeights + }; +} +var positionsArrayScratch = new Array(2); +var heightsArrayScratch = new Array(2); +var generateArcOptionsScratch = { + positions: void 0, + height: void 0, + granularity: void 0, + ellipsoid: void 0 +}; +WallGeometryLibrary.computePositions = function(ellipsoid, wallPositions, maximumHeights, minimumHeights, granularity, duplicateCorners) { + const o = removeDuplicates( + ellipsoid, + wallPositions, + maximumHeights, + minimumHeights + ); + if (!defined_default(o)) { + return; + } + wallPositions = o.positions; + maximumHeights = o.topHeights; + minimumHeights = o.bottomHeights; + const length = wallPositions.length; + const numCorners = length - 2; + let topPositions; + let bottomPositions; + const minDistance = Math_default.chordLength( + granularity, + ellipsoid.maximumRadius + ); + const generateArcOptions = generateArcOptionsScratch; + generateArcOptions.minDistance = minDistance; + generateArcOptions.ellipsoid = ellipsoid; + if (duplicateCorners) { + let count = 0; + let i; + for (i = 0; i < length - 1; i++) { + count += PolylinePipeline_default.numberOfPoints( + wallPositions[i], + wallPositions[i + 1], + minDistance + ) + 1; + } + topPositions = new Float64Array(count * 3); + bottomPositions = new Float64Array(count * 3); + const generateArcPositions = positionsArrayScratch; + const generateArcHeights = heightsArrayScratch; + generateArcOptions.positions = generateArcPositions; + generateArcOptions.height = generateArcHeights; + let offset = 0; + for (i = 0; i < length - 1; i++) { + generateArcPositions[0] = wallPositions[i]; + generateArcPositions[1] = wallPositions[i + 1]; + generateArcHeights[0] = maximumHeights[i]; + generateArcHeights[1] = maximumHeights[i + 1]; + const pos = PolylinePipeline_default.generateArc(generateArcOptions); + topPositions.set(pos, offset); + generateArcHeights[0] = minimumHeights[i]; + generateArcHeights[1] = minimumHeights[i + 1]; + bottomPositions.set( + PolylinePipeline_default.generateArc(generateArcOptions), + offset + ); + offset += pos.length; + } + } else { + generateArcOptions.positions = wallPositions; + generateArcOptions.height = maximumHeights; + topPositions = new Float64Array( + PolylinePipeline_default.generateArc(generateArcOptions) + ); + generateArcOptions.height = minimumHeights; + bottomPositions = new Float64Array( + PolylinePipeline_default.generateArc(generateArcOptions) + ); + } + return { + bottomPositions, + topPositions, + numCorners + }; +}; +var WallGeometryLibrary_default = WallGeometryLibrary; + +export { + WallGeometryLibrary_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-P7PWX5HR.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-P7PWX5HR.js new file mode 100644 index 0000000000000000000000000000000000000000..c6c92b872999c2b19cf434da3268fd4845cf0a79 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-P7PWX5HR.js @@ -0,0 +1,430 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Cartesian2_default, + Cartesian4_default, + Matrix2_default, + Matrix4_default +} from "./chunk-PW5CA4MJ.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Scene/AttributeType.js +var AttributeType = { + /** + * The attribute is a single component. + * + * @type {string} + * @constant + */ + SCALAR: "SCALAR", + /** + * The attribute is a two-component vector. + * + * @type {string} + * @constant + */ + VEC2: "VEC2", + /** + * The attribute is a three-component vector. + * + * @type {string} + * @constant + */ + VEC3: "VEC3", + /** + * The attribute is a four-component vector. + * + * @type {string} + * @constant + */ + VEC4: "VEC4", + /** + * The attribute is a 2x2 matrix. + * + * @type {string} + * @constant + */ + MAT2: "MAT2", + /** + * The attribute is a 3x3 matrix. + * + * @type {string} + * @constant + */ + MAT3: "MAT3", + /** + * The attribute is a 4x4 matrix. + * + * @type {string} + * @constant + */ + MAT4: "MAT4" +}; +AttributeType.getMathType = function(attributeType) { + switch (attributeType) { + case AttributeType.SCALAR: + return Number; + case AttributeType.VEC2: + return Cartesian2_default; + case AttributeType.VEC3: + return Cartesian3_default; + case AttributeType.VEC4: + return Cartesian4_default; + case AttributeType.MAT2: + return Matrix2_default; + case AttributeType.MAT3: + return Matrix3_default; + case AttributeType.MAT4: + return Matrix4_default; + default: + throw new DeveloperError_default("attributeType is not a valid value."); + } +}; +AttributeType.getNumberOfComponents = function(attributeType) { + switch (attributeType) { + case AttributeType.SCALAR: + return 1; + case AttributeType.VEC2: + return 2; + case AttributeType.VEC3: + return 3; + case AttributeType.VEC4: + case AttributeType.MAT2: + return 4; + case AttributeType.MAT3: + return 9; + case AttributeType.MAT4: + return 16; + default: + throw new DeveloperError_default("attributeType is not a valid value."); + } +}; +AttributeType.getAttributeLocationCount = function(attributeType) { + switch (attributeType) { + case AttributeType.SCALAR: + case AttributeType.VEC2: + case AttributeType.VEC3: + case AttributeType.VEC4: + return 1; + case AttributeType.MAT2: + return 2; + case AttributeType.MAT3: + return 3; + case AttributeType.MAT4: + return 4; + default: + throw new DeveloperError_default("attributeType is not a valid value."); + } +}; +AttributeType.getGlslType = function(attributeType) { + Check_default.typeOf.string("attributeType", attributeType); + switch (attributeType) { + case AttributeType.SCALAR: + return "float"; + case AttributeType.VEC2: + return "vec2"; + case AttributeType.VEC3: + return "vec3"; + case AttributeType.VEC4: + return "vec4"; + case AttributeType.MAT2: + return "mat2"; + case AttributeType.MAT3: + return "mat3"; + case AttributeType.MAT4: + return "mat4"; + default: + throw new DeveloperError_default("attributeType is not a valid value."); + } +}; +var AttributeType_default = Object.freeze(AttributeType); + +// packages/engine/Source/Core/AttributeCompression.js +var RIGHT_SHIFT = 1 / 256; +var LEFT_SHIFT = 256; +var AttributeCompression = {}; +AttributeCompression.octEncodeInRange = function(vector, rangeMax, result) { + Check_default.defined("vector", vector); + Check_default.defined("result", result); + const magSquared = Cartesian3_default.magnitudeSquared(vector); + if (Math.abs(magSquared - 1) > Math_default.EPSILON6) { + throw new DeveloperError_default("vector must be normalized."); + } + result.x = vector.x / (Math.abs(vector.x) + Math.abs(vector.y) + Math.abs(vector.z)); + result.y = vector.y / (Math.abs(vector.x) + Math.abs(vector.y) + Math.abs(vector.z)); + if (vector.z < 0) { + const x = result.x; + const y = result.y; + result.x = (1 - Math.abs(y)) * Math_default.signNotZero(x); + result.y = (1 - Math.abs(x)) * Math_default.signNotZero(y); + } + result.x = Math_default.toSNorm(result.x, rangeMax); + result.y = Math_default.toSNorm(result.y, rangeMax); + return result; +}; +AttributeCompression.octEncode = function(vector, result) { + return AttributeCompression.octEncodeInRange(vector, 255, result); +}; +var octEncodeScratch = new Cartesian2_default(); +var uint8ForceArray = new Uint8Array(1); +function forceUint8(value) { + uint8ForceArray[0] = value; + return uint8ForceArray[0]; +} +AttributeCompression.octEncodeToCartesian4 = function(vector, result) { + AttributeCompression.octEncodeInRange(vector, 65535, octEncodeScratch); + result.x = forceUint8(octEncodeScratch.x * RIGHT_SHIFT); + result.y = forceUint8(octEncodeScratch.x); + result.z = forceUint8(octEncodeScratch.y * RIGHT_SHIFT); + result.w = forceUint8(octEncodeScratch.y); + return result; +}; +AttributeCompression.octDecodeInRange = function(x, y, rangeMax, result) { + Check_default.defined("result", result); + if (x < 0 || x > rangeMax || y < 0 || y > rangeMax) { + throw new DeveloperError_default( + `x and y must be unsigned normalized integers between 0 and ${rangeMax}` + ); + } + result.x = Math_default.fromSNorm(x, rangeMax); + result.y = Math_default.fromSNorm(y, rangeMax); + result.z = 1 - (Math.abs(result.x) + Math.abs(result.y)); + if (result.z < 0) { + const oldVX = result.x; + result.x = (1 - Math.abs(result.y)) * Math_default.signNotZero(oldVX); + result.y = (1 - Math.abs(oldVX)) * Math_default.signNotZero(result.y); + } + return Cartesian3_default.normalize(result, result); +}; +AttributeCompression.octDecode = function(x, y, result) { + return AttributeCompression.octDecodeInRange(x, y, 255, result); +}; +AttributeCompression.octDecodeFromCartesian4 = function(encoded, result) { + Check_default.typeOf.object("encoded", encoded); + Check_default.typeOf.object("result", result); + const x = encoded.x; + const y = encoded.y; + const z = encoded.z; + const w = encoded.w; + if (x < 0 || x > 255 || y < 0 || y > 255 || z < 0 || z > 255 || w < 0 || w > 255) { + throw new DeveloperError_default( + "x, y, z, and w must be unsigned normalized integers between 0 and 255" + ); + } + const xOct16 = x * LEFT_SHIFT + y; + const yOct16 = z * LEFT_SHIFT + w; + return AttributeCompression.octDecodeInRange(xOct16, yOct16, 65535, result); +}; +AttributeCompression.octPackFloat = function(encoded) { + Check_default.defined("encoded", encoded); + return 256 * encoded.x + encoded.y; +}; +var scratchEncodeCart2 = new Cartesian2_default(); +AttributeCompression.octEncodeFloat = function(vector) { + AttributeCompression.octEncode(vector, scratchEncodeCart2); + return AttributeCompression.octPackFloat(scratchEncodeCart2); +}; +AttributeCompression.octDecodeFloat = function(value, result) { + Check_default.defined("value", value); + const temp = value / 256; + const x = Math.floor(temp); + const y = (temp - x) * 256; + return AttributeCompression.octDecode(x, y, result); +}; +AttributeCompression.octPack = function(v1, v2, v3, result) { + Check_default.defined("v1", v1); + Check_default.defined("v2", v2); + Check_default.defined("v3", v3); + Check_default.defined("result", result); + const encoded1 = AttributeCompression.octEncodeFloat(v1); + const encoded2 = AttributeCompression.octEncodeFloat(v2); + const encoded3 = AttributeCompression.octEncode(v3, scratchEncodeCart2); + result.x = 65536 * encoded3.x + encoded1; + result.y = 65536 * encoded3.y + encoded2; + return result; +}; +AttributeCompression.octUnpack = function(packed, v1, v2, v3) { + Check_default.defined("packed", packed); + Check_default.defined("v1", v1); + Check_default.defined("v2", v2); + Check_default.defined("v3", v3); + let temp = packed.x / 65536; + const x = Math.floor(temp); + const encodedFloat1 = (temp - x) * 65536; + temp = packed.y / 65536; + const y = Math.floor(temp); + const encodedFloat2 = (temp - y) * 65536; + AttributeCompression.octDecodeFloat(encodedFloat1, v1); + AttributeCompression.octDecodeFloat(encodedFloat2, v2); + AttributeCompression.octDecode(x, y, v3); +}; +AttributeCompression.compressTextureCoordinates = function(textureCoordinates) { + Check_default.defined("textureCoordinates", textureCoordinates); + const x = textureCoordinates.x * 4095 | 0; + const y = textureCoordinates.y * 4095 | 0; + return 4096 * x + y; +}; +AttributeCompression.decompressTextureCoordinates = function(compressed, result) { + Check_default.defined("compressed", compressed); + Check_default.defined("result", result); + const temp = compressed / 4096; + const xZeroTo4095 = Math.floor(temp); + result.x = xZeroTo4095 / 4095; + result.y = (compressed - xZeroTo4095 * 4096) / 4095; + return result; +}; +function zigZagDecode(value) { + return value >> 1 ^ -(value & 1); +} +AttributeCompression.zigZagDeltaDecode = function(uBuffer, vBuffer, heightBuffer) { + Check_default.defined("uBuffer", uBuffer); + Check_default.defined("vBuffer", vBuffer); + Check_default.typeOf.number.equals( + "uBuffer.length", + "vBuffer.length", + uBuffer.length, + vBuffer.length + ); + if (defined_default(heightBuffer)) { + Check_default.typeOf.number.equals( + "uBuffer.length", + "heightBuffer.length", + uBuffer.length, + heightBuffer.length + ); + } + const count = uBuffer.length; + let u = 0; + let v = 0; + let height = 0; + for (let i = 0; i < count; ++i) { + u += zigZagDecode(uBuffer[i]); + v += zigZagDecode(vBuffer[i]); + uBuffer[i] = u; + vBuffer[i] = v; + if (defined_default(heightBuffer)) { + height += zigZagDecode(heightBuffer[i]); + heightBuffer[i] = height; + } + } +}; +AttributeCompression.dequantize = function(typedArray, componentDatatype, type, count) { + Check_default.defined("typedArray", typedArray); + Check_default.defined("componentDatatype", componentDatatype); + Check_default.defined("type", type); + Check_default.defined("count", count); + const componentsPerAttribute = AttributeType_default.getNumberOfComponents(type); + let divisor; + switch (componentDatatype) { + case ComponentDatatype_default.BYTE: + divisor = 127; + break; + case ComponentDatatype_default.UNSIGNED_BYTE: + divisor = 255; + break; + case ComponentDatatype_default.SHORT: + divisor = 32767; + break; + case ComponentDatatype_default.UNSIGNED_SHORT: + divisor = 65535; + break; + case ComponentDatatype_default.INT: + divisor = 2147483647; + break; + case ComponentDatatype_default.UNSIGNED_INT: + divisor = 4294967295; + break; + default: + throw new DeveloperError_default( + `Cannot dequantize component datatype: ${componentDatatype}` + ); + } + const dequantizedTypedArray = new Float32Array( + count * componentsPerAttribute + ); + for (let i = 0; i < count; i++) { + for (let j = 0; j < componentsPerAttribute; j++) { + const index = i * componentsPerAttribute + j; + dequantizedTypedArray[index] = Math.max( + typedArray[index] / divisor, + -1 + ); + } + } + return dequantizedTypedArray; +}; +AttributeCompression.decodeRGB565 = function(typedArray, result) { + Check_default.defined("typedArray", typedArray); + const expectedLength = typedArray.length * 3; + if (defined_default(result)) { + Check_default.typeOf.number.equals( + "result.length", + "typedArray.length * 3", + result.length, + expectedLength + ); + } + const count = typedArray.length; + if (!defined_default(result)) { + result = new Float32Array(count * 3); + } + const mask5 = (1 << 5) - 1; + const mask6 = (1 << 6) - 1; + const normalize5 = 1 / 31; + const normalize6 = 1 / 63; + for (let i = 0; i < count; i++) { + const value = typedArray[i]; + const red = value >> 11; + const green = value >> 5 & mask6; + const blue = value & mask5; + const offset = 3 * i; + result[offset] = red * normalize5; + result[offset + 1] = green * normalize6; + result[offset + 2] = blue * normalize5; + } + return result; +}; +var AttributeCompression_default = AttributeCompression; + +export { + AttributeCompression_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-PGB3EFR7.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-PGB3EFR7.js new file mode 100644 index 0000000000000000000000000000000000000000..c9e5dc342c350ab91e599a6d5ede78a9f8beb5d1 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-PGB3EFR7.js @@ -0,0 +1,171 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Cartesian4_default, + Matrix4_default +} from "./chunk-PW5CA4MJ.js"; +import { + Cartesian3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/Plane.js +function Plane(normal, distance) { + Check_default.typeOf.object("normal", normal); + if (!Math_default.equalsEpsilon( + Cartesian3_default.magnitude(normal), + 1, + Math_default.EPSILON6 + )) { + throw new DeveloperError_default("normal must be normalized."); + } + Check_default.typeOf.number("distance", distance); + this.normal = Cartesian3_default.clone(normal); + this.distance = distance; +} +Plane.fromPointNormal = function(point, normal, result) { + Check_default.typeOf.object("point", point); + Check_default.typeOf.object("normal", normal); + if (!Math_default.equalsEpsilon( + Cartesian3_default.magnitude(normal), + 1, + Math_default.EPSILON6 + )) { + throw new DeveloperError_default("normal must be normalized."); + } + const distance = -Cartesian3_default.dot(normal, point); + if (!defined_default(result)) { + return new Plane(normal, distance); + } + Cartesian3_default.clone(normal, result.normal); + result.distance = distance; + return result; +}; +var scratchNormal = new Cartesian3_default(); +Plane.fromCartesian4 = function(coefficients, result) { + Check_default.typeOf.object("coefficients", coefficients); + const normal = Cartesian3_default.fromCartesian4(coefficients, scratchNormal); + const distance = coefficients.w; + if (!Math_default.equalsEpsilon( + Cartesian3_default.magnitude(normal), + 1, + Math_default.EPSILON6 + )) { + throw new DeveloperError_default("normal must be normalized."); + } + if (!defined_default(result)) { + return new Plane(normal, distance); + } + Cartesian3_default.clone(normal, result.normal); + result.distance = distance; + return result; +}; +Plane.getPointDistance = function(plane, point) { + Check_default.typeOf.object("plane", plane); + Check_default.typeOf.object("point", point); + return Cartesian3_default.dot(plane.normal, point) + plane.distance; +}; +var scratchCartesian = new Cartesian3_default(); +Plane.projectPointOntoPlane = function(plane, point, result) { + Check_default.typeOf.object("plane", plane); + Check_default.typeOf.object("point", point); + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + const pointDistance = Plane.getPointDistance(plane, point); + const scaledNormal = Cartesian3_default.multiplyByScalar( + plane.normal, + pointDistance, + scratchCartesian + ); + return Cartesian3_default.subtract(point, scaledNormal, result); +}; +var scratchInverseTranspose = new Matrix4_default(); +var scratchPlaneCartesian4 = new Cartesian4_default(); +var scratchTransformNormal = new Cartesian3_default(); +Plane.transform = function(plane, transform, result) { + Check_default.typeOf.object("plane", plane); + Check_default.typeOf.object("transform", transform); + const normal = plane.normal; + const distance = plane.distance; + const inverseTranspose = Matrix4_default.inverseTranspose( + transform, + scratchInverseTranspose + ); + let planeAsCartesian4 = Cartesian4_default.fromElements( + normal.x, + normal.y, + normal.z, + distance, + scratchPlaneCartesian4 + ); + planeAsCartesian4 = Matrix4_default.multiplyByVector( + inverseTranspose, + planeAsCartesian4, + planeAsCartesian4 + ); + const transformedNormal = Cartesian3_default.fromCartesian4( + planeAsCartesian4, + scratchTransformNormal + ); + planeAsCartesian4 = Cartesian4_default.divideByScalar( + planeAsCartesian4, + Cartesian3_default.magnitude(transformedNormal), + planeAsCartesian4 + ); + return Plane.fromCartesian4(planeAsCartesian4, result); +}; +Plane.clone = function(plane, result) { + Check_default.typeOf.object("plane", plane); + if (!defined_default(result)) { + return new Plane(plane.normal, plane.distance); + } + Cartesian3_default.clone(plane.normal, result.normal); + result.distance = plane.distance; + return result; +}; +Plane.equals = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + return left.distance === right.distance && Cartesian3_default.equals(left.normal, right.normal); +}; +Plane.ORIGIN_XY_PLANE = Object.freeze(new Plane(Cartesian3_default.UNIT_Z, 0)); +Plane.ORIGIN_YZ_PLANE = Object.freeze(new Plane(Cartesian3_default.UNIT_X, 0)); +Plane.ORIGIN_ZX_PLANE = Object.freeze(new Plane(Cartesian3_default.UNIT_Y, 0)); +var Plane_default = Plane; + +export { + Plane_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-PW5CA4MJ.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-PW5CA4MJ.js new file mode 100644 index 0000000000000000000000000000000000000000..fb32825f02917f309cbb84ac62f8397f47d2db97 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-PW5CA4MJ.js @@ -0,0 +1,3273 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + RuntimeError_default +} from "./chunk-FVDTKX3F.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/Cartesian4.js +function Cartesian4(x, y, z, w) { + this.x = defaultValue_default(x, 0); + this.y = defaultValue_default(y, 0); + this.z = defaultValue_default(z, 0); + this.w = defaultValue_default(w, 0); +} +Cartesian4.fromElements = function(x, y, z, w, result) { + if (!defined_default(result)) { + return new Cartesian4(x, y, z, w); + } + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; +}; +Cartesian4.fromColor = function(color, result) { + Check_default.typeOf.object("color", color); + if (!defined_default(result)) { + return new Cartesian4(color.red, color.green, color.blue, color.alpha); + } + result.x = color.red; + result.y = color.green; + result.z = color.blue; + result.w = color.alpha; + return result; +}; +Cartesian4.clone = function(cartesian, result) { + if (!defined_default(cartesian)) { + return void 0; + } + if (!defined_default(result)) { + return new Cartesian4(cartesian.x, cartesian.y, cartesian.z, cartesian.w); + } + result.x = cartesian.x; + result.y = cartesian.y; + result.z = cartesian.z; + result.w = cartesian.w; + return result; +}; +Cartesian4.packedLength = 4; +Cartesian4.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value.x; + array[startingIndex++] = value.y; + array[startingIndex++] = value.z; + array[startingIndex] = value.w; + return array; +}; +Cartesian4.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new Cartesian4(); + } + result.x = array[startingIndex++]; + result.y = array[startingIndex++]; + result.z = array[startingIndex++]; + result.w = array[startingIndex]; + return result; +}; +Cartesian4.packArray = function(array, result) { + Check_default.defined("array", array); + const length = array.length; + const resultLength = length * 4; + if (!defined_default(result)) { + result = new Array(resultLength); + } else if (!Array.isArray(result) && result.length !== resultLength) { + throw new DeveloperError_default( + "If result is a typed array, it must have exactly array.length * 4 elements" + ); + } else if (result.length !== resultLength) { + result.length = resultLength; + } + for (let i = 0; i < length; ++i) { + Cartesian4.pack(array[i], result, i * 4); + } + return result; +}; +Cartesian4.unpackArray = function(array, result) { + Check_default.defined("array", array); + Check_default.typeOf.number.greaterThanOrEquals("array.length", array.length, 4); + if (array.length % 4 !== 0) { + throw new DeveloperError_default("array length must be a multiple of 4."); + } + const length = array.length; + if (!defined_default(result)) { + result = new Array(length / 4); + } else { + result.length = length / 4; + } + for (let i = 0; i < length; i += 4) { + const index = i / 4; + result[index] = Cartesian4.unpack(array, i, result[index]); + } + return result; +}; +Cartesian4.fromArray = Cartesian4.unpack; +Cartesian4.maximumComponent = function(cartesian) { + Check_default.typeOf.object("cartesian", cartesian); + return Math.max(cartesian.x, cartesian.y, cartesian.z, cartesian.w); +}; +Cartesian4.minimumComponent = function(cartesian) { + Check_default.typeOf.object("cartesian", cartesian); + return Math.min(cartesian.x, cartesian.y, cartesian.z, cartesian.w); +}; +Cartesian4.minimumByComponent = function(first, second, result) { + Check_default.typeOf.object("first", first); + Check_default.typeOf.object("second", second); + Check_default.typeOf.object("result", result); + result.x = Math.min(first.x, second.x); + result.y = Math.min(first.y, second.y); + result.z = Math.min(first.z, second.z); + result.w = Math.min(first.w, second.w); + return result; +}; +Cartesian4.maximumByComponent = function(first, second, result) { + Check_default.typeOf.object("first", first); + Check_default.typeOf.object("second", second); + Check_default.typeOf.object("result", result); + result.x = Math.max(first.x, second.x); + result.y = Math.max(first.y, second.y); + result.z = Math.max(first.z, second.z); + result.w = Math.max(first.w, second.w); + return result; +}; +Cartesian4.clamp = function(value, min, max, result) { + Check_default.typeOf.object("value", value); + Check_default.typeOf.object("min", min); + Check_default.typeOf.object("max", max); + Check_default.typeOf.object("result", result); + const x = Math_default.clamp(value.x, min.x, max.x); + const y = Math_default.clamp(value.y, min.y, max.y); + const z = Math_default.clamp(value.z, min.z, max.z); + const w = Math_default.clamp(value.w, min.w, max.w); + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; +}; +Cartesian4.magnitudeSquared = function(cartesian) { + Check_default.typeOf.object("cartesian", cartesian); + return cartesian.x * cartesian.x + cartesian.y * cartesian.y + cartesian.z * cartesian.z + cartesian.w * cartesian.w; +}; +Cartesian4.magnitude = function(cartesian) { + return Math.sqrt(Cartesian4.magnitudeSquared(cartesian)); +}; +var distanceScratch = new Cartesian4(); +Cartesian4.distance = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Cartesian4.subtract(left, right, distanceScratch); + return Cartesian4.magnitude(distanceScratch); +}; +Cartesian4.distanceSquared = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Cartesian4.subtract(left, right, distanceScratch); + return Cartesian4.magnitudeSquared(distanceScratch); +}; +Cartesian4.normalize = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const magnitude = Cartesian4.magnitude(cartesian); + result.x = cartesian.x / magnitude; + result.y = cartesian.y / magnitude; + result.z = cartesian.z / magnitude; + result.w = cartesian.w / magnitude; + if (isNaN(result.x) || isNaN(result.y) || isNaN(result.z) || isNaN(result.w)) { + throw new DeveloperError_default("normalized result is not a number"); + } + return result; +}; +Cartesian4.dot = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + return left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w; +}; +Cartesian4.multiplyComponents = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x * right.x; + result.y = left.y * right.y; + result.z = left.z * right.z; + result.w = left.w * right.w; + return result; +}; +Cartesian4.divideComponents = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x / right.x; + result.y = left.y / right.y; + result.z = left.z / right.z; + result.w = left.w / right.w; + return result; +}; +Cartesian4.add = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x + right.x; + result.y = left.y + right.y; + result.z = left.z + right.z; + result.w = left.w + right.w; + return result; +}; +Cartesian4.subtract = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x - right.x; + result.y = left.y - right.y; + result.z = left.z - right.z; + result.w = left.w - right.w; + return result; +}; +Cartesian4.multiplyByScalar = function(cartesian, scalar, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result.x = cartesian.x * scalar; + result.y = cartesian.y * scalar; + result.z = cartesian.z * scalar; + result.w = cartesian.w * scalar; + return result; +}; +Cartesian4.divideByScalar = function(cartesian, scalar, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result.x = cartesian.x / scalar; + result.y = cartesian.y / scalar; + result.z = cartesian.z / scalar; + result.w = cartesian.w / scalar; + return result; +}; +Cartesian4.negate = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result.x = -cartesian.x; + result.y = -cartesian.y; + result.z = -cartesian.z; + result.w = -cartesian.w; + return result; +}; +Cartesian4.abs = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result.x = Math.abs(cartesian.x); + result.y = Math.abs(cartesian.y); + result.z = Math.abs(cartesian.z); + result.w = Math.abs(cartesian.w); + return result; +}; +var lerpScratch = new Cartesian4(); +Cartesian4.lerp = function(start, end, t, result) { + Check_default.typeOf.object("start", start); + Check_default.typeOf.object("end", end); + Check_default.typeOf.number("t", t); + Check_default.typeOf.object("result", result); + Cartesian4.multiplyByScalar(end, t, lerpScratch); + result = Cartesian4.multiplyByScalar(start, 1 - t, result); + return Cartesian4.add(lerpScratch, result, result); +}; +var mostOrthogonalAxisScratch = new Cartesian4(); +Cartesian4.mostOrthogonalAxis = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const f = Cartesian4.normalize(cartesian, mostOrthogonalAxisScratch); + Cartesian4.abs(f, f); + if (f.x <= f.y) { + if (f.x <= f.z) { + if (f.x <= f.w) { + result = Cartesian4.clone(Cartesian4.UNIT_X, result); + } else { + result = Cartesian4.clone(Cartesian4.UNIT_W, result); + } + } else if (f.z <= f.w) { + result = Cartesian4.clone(Cartesian4.UNIT_Z, result); + } else { + result = Cartesian4.clone(Cartesian4.UNIT_W, result); + } + } else if (f.y <= f.z) { + if (f.y <= f.w) { + result = Cartesian4.clone(Cartesian4.UNIT_Y, result); + } else { + result = Cartesian4.clone(Cartesian4.UNIT_W, result); + } + } else if (f.z <= f.w) { + result = Cartesian4.clone(Cartesian4.UNIT_Z, result); + } else { + result = Cartesian4.clone(Cartesian4.UNIT_W, result); + } + return result; +}; +Cartesian4.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left.x === right.x && left.y === right.y && left.z === right.z && left.w === right.w; +}; +Cartesian4.equalsArray = function(cartesian, array, offset) { + return cartesian.x === array[offset] && cartesian.y === array[offset + 1] && cartesian.z === array[offset + 2] && cartesian.w === array[offset + 3]; +}; +Cartesian4.equalsEpsilon = function(left, right, relativeEpsilon, absoluteEpsilon) { + return left === right || defined_default(left) && defined_default(right) && Math_default.equalsEpsilon( + left.x, + right.x, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + left.y, + right.y, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + left.z, + right.z, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + left.w, + right.w, + relativeEpsilon, + absoluteEpsilon + ); +}; +Cartesian4.ZERO = Object.freeze(new Cartesian4(0, 0, 0, 0)); +Cartesian4.ONE = Object.freeze(new Cartesian4(1, 1, 1, 1)); +Cartesian4.UNIT_X = Object.freeze(new Cartesian4(1, 0, 0, 0)); +Cartesian4.UNIT_Y = Object.freeze(new Cartesian4(0, 1, 0, 0)); +Cartesian4.UNIT_Z = Object.freeze(new Cartesian4(0, 0, 1, 0)); +Cartesian4.UNIT_W = Object.freeze(new Cartesian4(0, 0, 0, 1)); +Cartesian4.prototype.clone = function(result) { + return Cartesian4.clone(this, result); +}; +Cartesian4.prototype.equals = function(right) { + return Cartesian4.equals(this, right); +}; +Cartesian4.prototype.equalsEpsilon = function(right, relativeEpsilon, absoluteEpsilon) { + return Cartesian4.equalsEpsilon( + this, + right, + relativeEpsilon, + absoluteEpsilon + ); +}; +Cartesian4.prototype.toString = function() { + return `(${this.x}, ${this.y}, ${this.z}, ${this.w})`; +}; +var scratchF32Array = new Float32Array(1); +var scratchU8Array = new Uint8Array(scratchF32Array.buffer); +var testU32 = new Uint32Array([287454020]); +var testU8 = new Uint8Array(testU32.buffer); +var littleEndian = testU8[0] === 68; +Cartesian4.packFloat = function(value, result) { + Check_default.typeOf.number("value", value); + if (!defined_default(result)) { + result = new Cartesian4(); + } + scratchF32Array[0] = value; + if (littleEndian) { + result.x = scratchU8Array[0]; + result.y = scratchU8Array[1]; + result.z = scratchU8Array[2]; + result.w = scratchU8Array[3]; + } else { + result.x = scratchU8Array[3]; + result.y = scratchU8Array[2]; + result.z = scratchU8Array[1]; + result.w = scratchU8Array[0]; + } + return result; +}; +Cartesian4.unpackFloat = function(packedFloat) { + Check_default.typeOf.object("packedFloat", packedFloat); + if (littleEndian) { + scratchU8Array[0] = packedFloat.x; + scratchU8Array[1] = packedFloat.y; + scratchU8Array[2] = packedFloat.z; + scratchU8Array[3] = packedFloat.w; + } else { + scratchU8Array[0] = packedFloat.w; + scratchU8Array[1] = packedFloat.z; + scratchU8Array[2] = packedFloat.y; + scratchU8Array[3] = packedFloat.x; + } + return scratchF32Array[0]; +}; +var Cartesian4_default = Cartesian4; + +// packages/engine/Source/Core/Matrix4.js +function Matrix4(column0Row0, column1Row0, column2Row0, column3Row0, column0Row1, column1Row1, column2Row1, column3Row1, column0Row2, column1Row2, column2Row2, column3Row2, column0Row3, column1Row3, column2Row3, column3Row3) { + this[0] = defaultValue_default(column0Row0, 0); + this[1] = defaultValue_default(column0Row1, 0); + this[2] = defaultValue_default(column0Row2, 0); + this[3] = defaultValue_default(column0Row3, 0); + this[4] = defaultValue_default(column1Row0, 0); + this[5] = defaultValue_default(column1Row1, 0); + this[6] = defaultValue_default(column1Row2, 0); + this[7] = defaultValue_default(column1Row3, 0); + this[8] = defaultValue_default(column2Row0, 0); + this[9] = defaultValue_default(column2Row1, 0); + this[10] = defaultValue_default(column2Row2, 0); + this[11] = defaultValue_default(column2Row3, 0); + this[12] = defaultValue_default(column3Row0, 0); + this[13] = defaultValue_default(column3Row1, 0); + this[14] = defaultValue_default(column3Row2, 0); + this[15] = defaultValue_default(column3Row3, 0); +} +Matrix4.packedLength = 16; +Matrix4.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value[0]; + array[startingIndex++] = value[1]; + array[startingIndex++] = value[2]; + array[startingIndex++] = value[3]; + array[startingIndex++] = value[4]; + array[startingIndex++] = value[5]; + array[startingIndex++] = value[6]; + array[startingIndex++] = value[7]; + array[startingIndex++] = value[8]; + array[startingIndex++] = value[9]; + array[startingIndex++] = value[10]; + array[startingIndex++] = value[11]; + array[startingIndex++] = value[12]; + array[startingIndex++] = value[13]; + array[startingIndex++] = value[14]; + array[startingIndex] = value[15]; + return array; +}; +Matrix4.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new Matrix4(); + } + result[0] = array[startingIndex++]; + result[1] = array[startingIndex++]; + result[2] = array[startingIndex++]; + result[3] = array[startingIndex++]; + result[4] = array[startingIndex++]; + result[5] = array[startingIndex++]; + result[6] = array[startingIndex++]; + result[7] = array[startingIndex++]; + result[8] = array[startingIndex++]; + result[9] = array[startingIndex++]; + result[10] = array[startingIndex++]; + result[11] = array[startingIndex++]; + result[12] = array[startingIndex++]; + result[13] = array[startingIndex++]; + result[14] = array[startingIndex++]; + result[15] = array[startingIndex]; + return result; +}; +Matrix4.packArray = function(array, result) { + Check_default.defined("array", array); + const length = array.length; + const resultLength = length * 16; + if (!defined_default(result)) { + result = new Array(resultLength); + } else if (!Array.isArray(result) && result.length !== resultLength) { + throw new DeveloperError_default( + "If result is a typed array, it must have exactly array.length * 16 elements" + ); + } else if (result.length !== resultLength) { + result.length = resultLength; + } + for (let i = 0; i < length; ++i) { + Matrix4.pack(array[i], result, i * 16); + } + return result; +}; +Matrix4.unpackArray = function(array, result) { + Check_default.defined("array", array); + Check_default.typeOf.number.greaterThanOrEquals("array.length", array.length, 16); + if (array.length % 16 !== 0) { + throw new DeveloperError_default("array length must be a multiple of 16."); + } + const length = array.length; + if (!defined_default(result)) { + result = new Array(length / 16); + } else { + result.length = length / 16; + } + for (let i = 0; i < length; i += 16) { + const index = i / 16; + result[index] = Matrix4.unpack(array, i, result[index]); + } + return result; +}; +Matrix4.clone = function(matrix, result) { + if (!defined_default(matrix)) { + return void 0; + } + if (!defined_default(result)) { + return new Matrix4( + matrix[0], + matrix[4], + matrix[8], + matrix[12], + matrix[1], + matrix[5], + matrix[9], + matrix[13], + matrix[2], + matrix[6], + matrix[10], + matrix[14], + matrix[3], + matrix[7], + matrix[11], + matrix[15] + ); + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + result[9] = matrix[9]; + result[10] = matrix[10]; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; +}; +Matrix4.fromArray = Matrix4.unpack; +Matrix4.fromColumnMajorArray = function(values, result) { + Check_default.defined("values", values); + return Matrix4.clone(values, result); +}; +Matrix4.fromRowMajorArray = function(values, result) { + Check_default.defined("values", values); + if (!defined_default(result)) { + return new Matrix4( + values[0], + values[1], + values[2], + values[3], + values[4], + values[5], + values[6], + values[7], + values[8], + values[9], + values[10], + values[11], + values[12], + values[13], + values[14], + values[15] + ); + } + result[0] = values[0]; + result[1] = values[4]; + result[2] = values[8]; + result[3] = values[12]; + result[4] = values[1]; + result[5] = values[5]; + result[6] = values[9]; + result[7] = values[13]; + result[8] = values[2]; + result[9] = values[6]; + result[10] = values[10]; + result[11] = values[14]; + result[12] = values[3]; + result[13] = values[7]; + result[14] = values[11]; + result[15] = values[15]; + return result; +}; +Matrix4.fromRotationTranslation = function(rotation, translation, result) { + Check_default.typeOf.object("rotation", rotation); + translation = defaultValue_default(translation, Cartesian3_default.ZERO); + if (!defined_default(result)) { + return new Matrix4( + rotation[0], + rotation[3], + rotation[6], + translation.x, + rotation[1], + rotation[4], + rotation[7], + translation.y, + rotation[2], + rotation[5], + rotation[8], + translation.z, + 0, + 0, + 0, + 1 + ); + } + result[0] = rotation[0]; + result[1] = rotation[1]; + result[2] = rotation[2]; + result[3] = 0; + result[4] = rotation[3]; + result[5] = rotation[4]; + result[6] = rotation[5]; + result[7] = 0; + result[8] = rotation[6]; + result[9] = rotation[7]; + result[10] = rotation[8]; + result[11] = 0; + result[12] = translation.x; + result[13] = translation.y; + result[14] = translation.z; + result[15] = 1; + return result; +}; +Matrix4.fromTranslationQuaternionRotationScale = function(translation, rotation, scale, result) { + Check_default.typeOf.object("translation", translation); + Check_default.typeOf.object("rotation", rotation); + Check_default.typeOf.object("scale", scale); + if (!defined_default(result)) { + result = new Matrix4(); + } + const scaleX = scale.x; + const scaleY = scale.y; + const scaleZ = scale.z; + const x2 = rotation.x * rotation.x; + const xy = rotation.x * rotation.y; + const xz = rotation.x * rotation.z; + const xw = rotation.x * rotation.w; + const y2 = rotation.y * rotation.y; + const yz = rotation.y * rotation.z; + const yw = rotation.y * rotation.w; + const z2 = rotation.z * rotation.z; + const zw = rotation.z * rotation.w; + const w2 = rotation.w * rotation.w; + const m00 = x2 - y2 - z2 + w2; + const m01 = 2 * (xy - zw); + const m02 = 2 * (xz + yw); + const m10 = 2 * (xy + zw); + const m11 = -x2 + y2 - z2 + w2; + const m12 = 2 * (yz - xw); + const m20 = 2 * (xz - yw); + const m21 = 2 * (yz + xw); + const m22 = -x2 - y2 + z2 + w2; + result[0] = m00 * scaleX; + result[1] = m10 * scaleX; + result[2] = m20 * scaleX; + result[3] = 0; + result[4] = m01 * scaleY; + result[5] = m11 * scaleY; + result[6] = m21 * scaleY; + result[7] = 0; + result[8] = m02 * scaleZ; + result[9] = m12 * scaleZ; + result[10] = m22 * scaleZ; + result[11] = 0; + result[12] = translation.x; + result[13] = translation.y; + result[14] = translation.z; + result[15] = 1; + return result; +}; +Matrix4.fromTranslationRotationScale = function(translationRotationScale, result) { + Check_default.typeOf.object("translationRotationScale", translationRotationScale); + return Matrix4.fromTranslationQuaternionRotationScale( + translationRotationScale.translation, + translationRotationScale.rotation, + translationRotationScale.scale, + result + ); +}; +Matrix4.fromTranslation = function(translation, result) { + Check_default.typeOf.object("translation", translation); + return Matrix4.fromRotationTranslation(Matrix3_default.IDENTITY, translation, result); +}; +Matrix4.fromScale = function(scale, result) { + Check_default.typeOf.object("scale", scale); + if (!defined_default(result)) { + return new Matrix4( + scale.x, + 0, + 0, + 0, + 0, + scale.y, + 0, + 0, + 0, + 0, + scale.z, + 0, + 0, + 0, + 0, + 1 + ); + } + result[0] = scale.x; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = 0; + result[5] = scale.y; + result[6] = 0; + result[7] = 0; + result[8] = 0; + result[9] = 0; + result[10] = scale.z; + result[11] = 0; + result[12] = 0; + result[13] = 0; + result[14] = 0; + result[15] = 1; + return result; +}; +Matrix4.fromUniformScale = function(scale, result) { + Check_default.typeOf.number("scale", scale); + if (!defined_default(result)) { + return new Matrix4( + scale, + 0, + 0, + 0, + 0, + scale, + 0, + 0, + 0, + 0, + scale, + 0, + 0, + 0, + 0, + 1 + ); + } + result[0] = scale; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = 0; + result[5] = scale; + result[6] = 0; + result[7] = 0; + result[8] = 0; + result[9] = 0; + result[10] = scale; + result[11] = 0; + result[12] = 0; + result[13] = 0; + result[14] = 0; + result[15] = 1; + return result; +}; +Matrix4.fromRotation = function(rotation, result) { + Check_default.typeOf.object("rotation", rotation); + if (!defined_default(result)) { + result = new Matrix4(); + } + result[0] = rotation[0]; + result[1] = rotation[1]; + result[2] = rotation[2]; + result[3] = 0; + result[4] = rotation[3]; + result[5] = rotation[4]; + result[6] = rotation[5]; + result[7] = 0; + result[8] = rotation[6]; + result[9] = rotation[7]; + result[10] = rotation[8]; + result[11] = 0; + result[12] = 0; + result[13] = 0; + result[14] = 0; + result[15] = 1; + return result; +}; +var fromCameraF = new Cartesian3_default(); +var fromCameraR = new Cartesian3_default(); +var fromCameraU = new Cartesian3_default(); +Matrix4.fromCamera = function(camera, result) { + Check_default.typeOf.object("camera", camera); + const position = camera.position; + const direction = camera.direction; + const up = camera.up; + Check_default.typeOf.object("camera.position", position); + Check_default.typeOf.object("camera.direction", direction); + Check_default.typeOf.object("camera.up", up); + Cartesian3_default.normalize(direction, fromCameraF); + Cartesian3_default.normalize( + Cartesian3_default.cross(fromCameraF, up, fromCameraR), + fromCameraR + ); + Cartesian3_default.normalize( + Cartesian3_default.cross(fromCameraR, fromCameraF, fromCameraU), + fromCameraU + ); + const sX = fromCameraR.x; + const sY = fromCameraR.y; + const sZ = fromCameraR.z; + const fX = fromCameraF.x; + const fY = fromCameraF.y; + const fZ = fromCameraF.z; + const uX = fromCameraU.x; + const uY = fromCameraU.y; + const uZ = fromCameraU.z; + const positionX = position.x; + const positionY = position.y; + const positionZ = position.z; + const t0 = sX * -positionX + sY * -positionY + sZ * -positionZ; + const t1 = uX * -positionX + uY * -positionY + uZ * -positionZ; + const t2 = fX * positionX + fY * positionY + fZ * positionZ; + if (!defined_default(result)) { + return new Matrix4( + sX, + sY, + sZ, + t0, + uX, + uY, + uZ, + t1, + -fX, + -fY, + -fZ, + t2, + 0, + 0, + 0, + 1 + ); + } + result[0] = sX; + result[1] = uX; + result[2] = -fX; + result[3] = 0; + result[4] = sY; + result[5] = uY; + result[6] = -fY; + result[7] = 0; + result[8] = sZ; + result[9] = uZ; + result[10] = -fZ; + result[11] = 0; + result[12] = t0; + result[13] = t1; + result[14] = t2; + result[15] = 1; + return result; +}; +Matrix4.computePerspectiveFieldOfView = function(fovY, aspectRatio, near, far, result) { + Check_default.typeOf.number.greaterThan("fovY", fovY, 0); + Check_default.typeOf.number.lessThan("fovY", fovY, Math.PI); + Check_default.typeOf.number.greaterThan("near", near, 0); + Check_default.typeOf.number.greaterThan("far", far, 0); + Check_default.typeOf.object("result", result); + const bottom = Math.tan(fovY * 0.5); + const column1Row1 = 1 / bottom; + const column0Row0 = column1Row1 / aspectRatio; + const column2Row2 = (far + near) / (near - far); + const column3Row2 = 2 * far * near / (near - far); + result[0] = column0Row0; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = 0; + result[5] = column1Row1; + result[6] = 0; + result[7] = 0; + result[8] = 0; + result[9] = 0; + result[10] = column2Row2; + result[11] = -1; + result[12] = 0; + result[13] = 0; + result[14] = column3Row2; + result[15] = 0; + return result; +}; +Matrix4.computeOrthographicOffCenter = function(left, right, bottom, top, near, far, result) { + Check_default.typeOf.number("left", left); + Check_default.typeOf.number("right", right); + Check_default.typeOf.number("bottom", bottom); + Check_default.typeOf.number("top", top); + Check_default.typeOf.number("near", near); + Check_default.typeOf.number("far", far); + Check_default.typeOf.object("result", result); + let a = 1 / (right - left); + let b = 1 / (top - bottom); + let c = 1 / (far - near); + const tx = -(right + left) * a; + const ty = -(top + bottom) * b; + const tz = -(far + near) * c; + a *= 2; + b *= 2; + c *= -2; + result[0] = a; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = 0; + result[5] = b; + result[6] = 0; + result[7] = 0; + result[8] = 0; + result[9] = 0; + result[10] = c; + result[11] = 0; + result[12] = tx; + result[13] = ty; + result[14] = tz; + result[15] = 1; + return result; +}; +Matrix4.computePerspectiveOffCenter = function(left, right, bottom, top, near, far, result) { + Check_default.typeOf.number("left", left); + Check_default.typeOf.number("right", right); + Check_default.typeOf.number("bottom", bottom); + Check_default.typeOf.number("top", top); + Check_default.typeOf.number("near", near); + Check_default.typeOf.number("far", far); + Check_default.typeOf.object("result", result); + const column0Row0 = 2 * near / (right - left); + const column1Row1 = 2 * near / (top - bottom); + const column2Row0 = (right + left) / (right - left); + const column2Row1 = (top + bottom) / (top - bottom); + const column2Row2 = -(far + near) / (far - near); + const column2Row3 = -1; + const column3Row2 = -2 * far * near / (far - near); + result[0] = column0Row0; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = 0; + result[5] = column1Row1; + result[6] = 0; + result[7] = 0; + result[8] = column2Row0; + result[9] = column2Row1; + result[10] = column2Row2; + result[11] = column2Row3; + result[12] = 0; + result[13] = 0; + result[14] = column3Row2; + result[15] = 0; + return result; +}; +Matrix4.computeInfinitePerspectiveOffCenter = function(left, right, bottom, top, near, result) { + Check_default.typeOf.number("left", left); + Check_default.typeOf.number("right", right); + Check_default.typeOf.number("bottom", bottom); + Check_default.typeOf.number("top", top); + Check_default.typeOf.number("near", near); + Check_default.typeOf.object("result", result); + const column0Row0 = 2 * near / (right - left); + const column1Row1 = 2 * near / (top - bottom); + const column2Row0 = (right + left) / (right - left); + const column2Row1 = (top + bottom) / (top - bottom); + const column2Row2 = -1; + const column2Row3 = -1; + const column3Row2 = -2 * near; + result[0] = column0Row0; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = 0; + result[5] = column1Row1; + result[6] = 0; + result[7] = 0; + result[8] = column2Row0; + result[9] = column2Row1; + result[10] = column2Row2; + result[11] = column2Row3; + result[12] = 0; + result[13] = 0; + result[14] = column3Row2; + result[15] = 0; + return result; +}; +Matrix4.computeViewportTransformation = function(viewport, nearDepthRange, farDepthRange, result) { + if (!defined_default(result)) { + result = new Matrix4(); + } + viewport = defaultValue_default(viewport, defaultValue_default.EMPTY_OBJECT); + const x = defaultValue_default(viewport.x, 0); + const y = defaultValue_default(viewport.y, 0); + const width = defaultValue_default(viewport.width, 0); + const height = defaultValue_default(viewport.height, 0); + nearDepthRange = defaultValue_default(nearDepthRange, 0); + farDepthRange = defaultValue_default(farDepthRange, 1); + const halfWidth = width * 0.5; + const halfHeight = height * 0.5; + const halfDepth = (farDepthRange - nearDepthRange) * 0.5; + const column0Row0 = halfWidth; + const column1Row1 = halfHeight; + const column2Row2 = halfDepth; + const column3Row0 = x + halfWidth; + const column3Row1 = y + halfHeight; + const column3Row2 = nearDepthRange + halfDepth; + const column3Row3 = 1; + result[0] = column0Row0; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = 0; + result[5] = column1Row1; + result[6] = 0; + result[7] = 0; + result[8] = 0; + result[9] = 0; + result[10] = column2Row2; + result[11] = 0; + result[12] = column3Row0; + result[13] = column3Row1; + result[14] = column3Row2; + result[15] = column3Row3; + return result; +}; +Matrix4.computeView = function(position, direction, up, right, result) { + Check_default.typeOf.object("position", position); + Check_default.typeOf.object("direction", direction); + Check_default.typeOf.object("up", up); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result[0] = right.x; + result[1] = up.x; + result[2] = -direction.x; + result[3] = 0; + result[4] = right.y; + result[5] = up.y; + result[6] = -direction.y; + result[7] = 0; + result[8] = right.z; + result[9] = up.z; + result[10] = -direction.z; + result[11] = 0; + result[12] = -Cartesian3_default.dot(right, position); + result[13] = -Cartesian3_default.dot(up, position); + result[14] = Cartesian3_default.dot(direction, position); + result[15] = 1; + return result; +}; +Matrix4.toArray = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + if (!defined_default(result)) { + return [ + matrix[0], + matrix[1], + matrix[2], + matrix[3], + matrix[4], + matrix[5], + matrix[6], + matrix[7], + matrix[8], + matrix[9], + matrix[10], + matrix[11], + matrix[12], + matrix[13], + matrix[14], + matrix[15] + ]; + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + result[9] = matrix[9]; + result[10] = matrix[10]; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; +}; +Matrix4.getElementIndex = function(column, row) { + Check_default.typeOf.number.greaterThanOrEquals("row", row, 0); + Check_default.typeOf.number.lessThanOrEquals("row", row, 3); + Check_default.typeOf.number.greaterThanOrEquals("column", column, 0); + Check_default.typeOf.number.lessThanOrEquals("column", column, 3); + return column * 4 + row; +}; +Matrix4.getColumn = function(matrix, index, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 3); + Check_default.typeOf.object("result", result); + const startIndex = index * 4; + const x = matrix[startIndex]; + const y = matrix[startIndex + 1]; + const z = matrix[startIndex + 2]; + const w = matrix[startIndex + 3]; + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; +}; +Matrix4.setColumn = function(matrix, index, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 3); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result = Matrix4.clone(matrix, result); + const startIndex = index * 4; + result[startIndex] = cartesian.x; + result[startIndex + 1] = cartesian.y; + result[startIndex + 2] = cartesian.z; + result[startIndex + 3] = cartesian.w; + return result; +}; +Matrix4.getRow = function(matrix, index, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 3); + Check_default.typeOf.object("result", result); + const x = matrix[index]; + const y = matrix[index + 4]; + const z = matrix[index + 8]; + const w = matrix[index + 12]; + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; +}; +Matrix4.setRow = function(matrix, index, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 3); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result = Matrix4.clone(matrix, result); + result[index] = cartesian.x; + result[index + 4] = cartesian.y; + result[index + 8] = cartesian.z; + result[index + 12] = cartesian.w; + return result; +}; +Matrix4.setTranslation = function(matrix, translation, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("translation", translation); + Check_default.typeOf.object("result", result); + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + result[9] = matrix[9]; + result[10] = matrix[10]; + result[11] = matrix[11]; + result[12] = translation.x; + result[13] = translation.y; + result[14] = translation.z; + result[15] = matrix[15]; + return result; +}; +var scaleScratch1 = new Cartesian3_default(); +Matrix4.setScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("scale", scale); + Check_default.typeOf.object("result", result); + const existingScale = Matrix4.getScale(matrix, scaleScratch1); + const scaleRatioX = scale.x / existingScale.x; + const scaleRatioY = scale.y / existingScale.y; + const scaleRatioZ = scale.z / existingScale.z; + result[0] = matrix[0] * scaleRatioX; + result[1] = matrix[1] * scaleRatioX; + result[2] = matrix[2] * scaleRatioX; + result[3] = matrix[3]; + result[4] = matrix[4] * scaleRatioY; + result[5] = matrix[5] * scaleRatioY; + result[6] = matrix[6] * scaleRatioY; + result[7] = matrix[7]; + result[8] = matrix[8] * scaleRatioZ; + result[9] = matrix[9] * scaleRatioZ; + result[10] = matrix[10] * scaleRatioZ; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; +}; +var scaleScratch2 = new Cartesian3_default(); +Matrix4.setUniformScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number("scale", scale); + Check_default.typeOf.object("result", result); + const existingScale = Matrix4.getScale(matrix, scaleScratch2); + const scaleRatioX = scale / existingScale.x; + const scaleRatioY = scale / existingScale.y; + const scaleRatioZ = scale / existingScale.z; + result[0] = matrix[0] * scaleRatioX; + result[1] = matrix[1] * scaleRatioX; + result[2] = matrix[2] * scaleRatioX; + result[3] = matrix[3]; + result[4] = matrix[4] * scaleRatioY; + result[5] = matrix[5] * scaleRatioY; + result[6] = matrix[6] * scaleRatioY; + result[7] = matrix[7]; + result[8] = matrix[8] * scaleRatioZ; + result[9] = matrix[9] * scaleRatioZ; + result[10] = matrix[10] * scaleRatioZ; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; +}; +var scratchColumn = new Cartesian3_default(); +Matrix4.getScale = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result.x = Cartesian3_default.magnitude( + Cartesian3_default.fromElements(matrix[0], matrix[1], matrix[2], scratchColumn) + ); + result.y = Cartesian3_default.magnitude( + Cartesian3_default.fromElements(matrix[4], matrix[5], matrix[6], scratchColumn) + ); + result.z = Cartesian3_default.magnitude( + Cartesian3_default.fromElements(matrix[8], matrix[9], matrix[10], scratchColumn) + ); + return result; +}; +var scaleScratch3 = new Cartesian3_default(); +Matrix4.getMaximumScale = function(matrix) { + Matrix4.getScale(matrix, scaleScratch3); + return Cartesian3_default.maximumComponent(scaleScratch3); +}; +var scaleScratch4 = new Cartesian3_default(); +Matrix4.setRotation = function(matrix, rotation, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const scale = Matrix4.getScale(matrix, scaleScratch4); + result[0] = rotation[0] * scale.x; + result[1] = rotation[1] * scale.x; + result[2] = rotation[2] * scale.x; + result[3] = matrix[3]; + result[4] = rotation[3] * scale.y; + result[5] = rotation[4] * scale.y; + result[6] = rotation[5] * scale.y; + result[7] = matrix[7]; + result[8] = rotation[6] * scale.z; + result[9] = rotation[7] * scale.z; + result[10] = rotation[8] * scale.z; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; +}; +var scaleScratch5 = new Cartesian3_default(); +Matrix4.getRotation = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const scale = Matrix4.getScale(matrix, scaleScratch5); + result[0] = matrix[0] / scale.x; + result[1] = matrix[1] / scale.x; + result[2] = matrix[2] / scale.x; + result[3] = matrix[4] / scale.y; + result[4] = matrix[5] / scale.y; + result[5] = matrix[6] / scale.y; + result[6] = matrix[8] / scale.z; + result[7] = matrix[9] / scale.z; + result[8] = matrix[10] / scale.z; + return result; +}; +Matrix4.multiply = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + const left0 = left[0]; + const left1 = left[1]; + const left2 = left[2]; + const left3 = left[3]; + const left4 = left[4]; + const left5 = left[5]; + const left6 = left[6]; + const left7 = left[7]; + const left8 = left[8]; + const left9 = left[9]; + const left10 = left[10]; + const left11 = left[11]; + const left12 = left[12]; + const left13 = left[13]; + const left14 = left[14]; + const left15 = left[15]; + const right0 = right[0]; + const right1 = right[1]; + const right2 = right[2]; + const right3 = right[3]; + const right4 = right[4]; + const right5 = right[5]; + const right6 = right[6]; + const right7 = right[7]; + const right8 = right[8]; + const right9 = right[9]; + const right10 = right[10]; + const right11 = right[11]; + const right12 = right[12]; + const right13 = right[13]; + const right14 = right[14]; + const right15 = right[15]; + const column0Row0 = left0 * right0 + left4 * right1 + left8 * right2 + left12 * right3; + const column0Row1 = left1 * right0 + left5 * right1 + left9 * right2 + left13 * right3; + const column0Row2 = left2 * right0 + left6 * right1 + left10 * right2 + left14 * right3; + const column0Row3 = left3 * right0 + left7 * right1 + left11 * right2 + left15 * right3; + const column1Row0 = left0 * right4 + left4 * right5 + left8 * right6 + left12 * right7; + const column1Row1 = left1 * right4 + left5 * right5 + left9 * right6 + left13 * right7; + const column1Row2 = left2 * right4 + left6 * right5 + left10 * right6 + left14 * right7; + const column1Row3 = left3 * right4 + left7 * right5 + left11 * right6 + left15 * right7; + const column2Row0 = left0 * right8 + left4 * right9 + left8 * right10 + left12 * right11; + const column2Row1 = left1 * right8 + left5 * right9 + left9 * right10 + left13 * right11; + const column2Row2 = left2 * right8 + left6 * right9 + left10 * right10 + left14 * right11; + const column2Row3 = left3 * right8 + left7 * right9 + left11 * right10 + left15 * right11; + const column3Row0 = left0 * right12 + left4 * right13 + left8 * right14 + left12 * right15; + const column3Row1 = left1 * right12 + left5 * right13 + left9 * right14 + left13 * right15; + const column3Row2 = left2 * right12 + left6 * right13 + left10 * right14 + left14 * right15; + const column3Row3 = left3 * right12 + left7 * right13 + left11 * right14 + left15 * right15; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column0Row2; + result[3] = column0Row3; + result[4] = column1Row0; + result[5] = column1Row1; + result[6] = column1Row2; + result[7] = column1Row3; + result[8] = column2Row0; + result[9] = column2Row1; + result[10] = column2Row2; + result[11] = column2Row3; + result[12] = column3Row0; + result[13] = column3Row1; + result[14] = column3Row2; + result[15] = column3Row3; + return result; +}; +Matrix4.add = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result[0] = left[0] + right[0]; + result[1] = left[1] + right[1]; + result[2] = left[2] + right[2]; + result[3] = left[3] + right[3]; + result[4] = left[4] + right[4]; + result[5] = left[5] + right[5]; + result[6] = left[6] + right[6]; + result[7] = left[7] + right[7]; + result[8] = left[8] + right[8]; + result[9] = left[9] + right[9]; + result[10] = left[10] + right[10]; + result[11] = left[11] + right[11]; + result[12] = left[12] + right[12]; + result[13] = left[13] + right[13]; + result[14] = left[14] + right[14]; + result[15] = left[15] + right[15]; + return result; +}; +Matrix4.subtract = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result[0] = left[0] - right[0]; + result[1] = left[1] - right[1]; + result[2] = left[2] - right[2]; + result[3] = left[3] - right[3]; + result[4] = left[4] - right[4]; + result[5] = left[5] - right[5]; + result[6] = left[6] - right[6]; + result[7] = left[7] - right[7]; + result[8] = left[8] - right[8]; + result[9] = left[9] - right[9]; + result[10] = left[10] - right[10]; + result[11] = left[11] - right[11]; + result[12] = left[12] - right[12]; + result[13] = left[13] - right[13]; + result[14] = left[14] - right[14]; + result[15] = left[15] - right[15]; + return result; +}; +Matrix4.multiplyTransformation = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + const left0 = left[0]; + const left1 = left[1]; + const left2 = left[2]; + const left4 = left[4]; + const left5 = left[5]; + const left6 = left[6]; + const left8 = left[8]; + const left9 = left[9]; + const left10 = left[10]; + const left12 = left[12]; + const left13 = left[13]; + const left14 = left[14]; + const right0 = right[0]; + const right1 = right[1]; + const right2 = right[2]; + const right4 = right[4]; + const right5 = right[5]; + const right6 = right[6]; + const right8 = right[8]; + const right9 = right[9]; + const right10 = right[10]; + const right12 = right[12]; + const right13 = right[13]; + const right14 = right[14]; + const column0Row0 = left0 * right0 + left4 * right1 + left8 * right2; + const column0Row1 = left1 * right0 + left5 * right1 + left9 * right2; + const column0Row2 = left2 * right0 + left6 * right1 + left10 * right2; + const column1Row0 = left0 * right4 + left4 * right5 + left8 * right6; + const column1Row1 = left1 * right4 + left5 * right5 + left9 * right6; + const column1Row2 = left2 * right4 + left6 * right5 + left10 * right6; + const column2Row0 = left0 * right8 + left4 * right9 + left8 * right10; + const column2Row1 = left1 * right8 + left5 * right9 + left9 * right10; + const column2Row2 = left2 * right8 + left6 * right9 + left10 * right10; + const column3Row0 = left0 * right12 + left4 * right13 + left8 * right14 + left12; + const column3Row1 = left1 * right12 + left5 * right13 + left9 * right14 + left13; + const column3Row2 = left2 * right12 + left6 * right13 + left10 * right14 + left14; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column0Row2; + result[3] = 0; + result[4] = column1Row0; + result[5] = column1Row1; + result[6] = column1Row2; + result[7] = 0; + result[8] = column2Row0; + result[9] = column2Row1; + result[10] = column2Row2; + result[11] = 0; + result[12] = column3Row0; + result[13] = column3Row1; + result[14] = column3Row2; + result[15] = 1; + return result; +}; +Matrix4.multiplyByMatrix3 = function(matrix, rotation, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("rotation", rotation); + Check_default.typeOf.object("result", result); + const left0 = matrix[0]; + const left1 = matrix[1]; + const left2 = matrix[2]; + const left4 = matrix[4]; + const left5 = matrix[5]; + const left6 = matrix[6]; + const left8 = matrix[8]; + const left9 = matrix[9]; + const left10 = matrix[10]; + const right0 = rotation[0]; + const right1 = rotation[1]; + const right2 = rotation[2]; + const right4 = rotation[3]; + const right5 = rotation[4]; + const right6 = rotation[5]; + const right8 = rotation[6]; + const right9 = rotation[7]; + const right10 = rotation[8]; + const column0Row0 = left0 * right0 + left4 * right1 + left8 * right2; + const column0Row1 = left1 * right0 + left5 * right1 + left9 * right2; + const column0Row2 = left2 * right0 + left6 * right1 + left10 * right2; + const column1Row0 = left0 * right4 + left4 * right5 + left8 * right6; + const column1Row1 = left1 * right4 + left5 * right5 + left9 * right6; + const column1Row2 = left2 * right4 + left6 * right5 + left10 * right6; + const column2Row0 = left0 * right8 + left4 * right9 + left8 * right10; + const column2Row1 = left1 * right8 + left5 * right9 + left9 * right10; + const column2Row2 = left2 * right8 + left6 * right9 + left10 * right10; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column0Row2; + result[3] = 0; + result[4] = column1Row0; + result[5] = column1Row1; + result[6] = column1Row2; + result[7] = 0; + result[8] = column2Row0; + result[9] = column2Row1; + result[10] = column2Row2; + result[11] = 0; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; +}; +Matrix4.multiplyByTranslation = function(matrix, translation, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("translation", translation); + Check_default.typeOf.object("result", result); + const x = translation.x; + const y = translation.y; + const z = translation.z; + const tx = x * matrix[0] + y * matrix[4] + z * matrix[8] + matrix[12]; + const ty = x * matrix[1] + y * matrix[5] + z * matrix[9] + matrix[13]; + const tz = x * matrix[2] + y * matrix[6] + z * matrix[10] + matrix[14]; + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + result[9] = matrix[9]; + result[10] = matrix[10]; + result[11] = matrix[11]; + result[12] = tx; + result[13] = ty; + result[14] = tz; + result[15] = matrix[15]; + return result; +}; +Matrix4.multiplyByScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("scale", scale); + Check_default.typeOf.object("result", result); + const scaleX = scale.x; + const scaleY = scale.y; + const scaleZ = scale.z; + if (scaleX === 1 && scaleY === 1 && scaleZ === 1) { + return Matrix4.clone(matrix, result); + } + result[0] = scaleX * matrix[0]; + result[1] = scaleX * matrix[1]; + result[2] = scaleX * matrix[2]; + result[3] = matrix[3]; + result[4] = scaleY * matrix[4]; + result[5] = scaleY * matrix[5]; + result[6] = scaleY * matrix[6]; + result[7] = matrix[7]; + result[8] = scaleZ * matrix[8]; + result[9] = scaleZ * matrix[9]; + result[10] = scaleZ * matrix[10]; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; +}; +Matrix4.multiplyByUniformScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number("scale", scale); + Check_default.typeOf.object("result", result); + result[0] = matrix[0] * scale; + result[1] = matrix[1] * scale; + result[2] = matrix[2] * scale; + result[3] = matrix[3]; + result[4] = matrix[4] * scale; + result[5] = matrix[5] * scale; + result[6] = matrix[6] * scale; + result[7] = matrix[7]; + result[8] = matrix[8] * scale; + result[9] = matrix[9] * scale; + result[10] = matrix[10] * scale; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; +}; +Matrix4.multiplyByVector = function(matrix, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const vX = cartesian.x; + const vY = cartesian.y; + const vZ = cartesian.z; + const vW = cartesian.w; + const x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ + matrix[12] * vW; + const y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ + matrix[13] * vW; + const z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ + matrix[14] * vW; + const w = matrix[3] * vX + matrix[7] * vY + matrix[11] * vZ + matrix[15] * vW; + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; +}; +Matrix4.multiplyByPointAsVector = function(matrix, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const vX = cartesian.x; + const vY = cartesian.y; + const vZ = cartesian.z; + const x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ; + const y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ; + const z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ; + result.x = x; + result.y = y; + result.z = z; + return result; +}; +Matrix4.multiplyByPoint = function(matrix, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const vX = cartesian.x; + const vY = cartesian.y; + const vZ = cartesian.z; + const x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ + matrix[12]; + const y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ + matrix[13]; + const z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ + matrix[14]; + result.x = x; + result.y = y; + result.z = z; + return result; +}; +Matrix4.multiplyByScalar = function(matrix, scalar, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result[0] = matrix[0] * scalar; + result[1] = matrix[1] * scalar; + result[2] = matrix[2] * scalar; + result[3] = matrix[3] * scalar; + result[4] = matrix[4] * scalar; + result[5] = matrix[5] * scalar; + result[6] = matrix[6] * scalar; + result[7] = matrix[7] * scalar; + result[8] = matrix[8] * scalar; + result[9] = matrix[9] * scalar; + result[10] = matrix[10] * scalar; + result[11] = matrix[11] * scalar; + result[12] = matrix[12] * scalar; + result[13] = matrix[13] * scalar; + result[14] = matrix[14] * scalar; + result[15] = matrix[15] * scalar; + return result; +}; +Matrix4.negate = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result[0] = -matrix[0]; + result[1] = -matrix[1]; + result[2] = -matrix[2]; + result[3] = -matrix[3]; + result[4] = -matrix[4]; + result[5] = -matrix[5]; + result[6] = -matrix[6]; + result[7] = -matrix[7]; + result[8] = -matrix[8]; + result[9] = -matrix[9]; + result[10] = -matrix[10]; + result[11] = -matrix[11]; + result[12] = -matrix[12]; + result[13] = -matrix[13]; + result[14] = -matrix[14]; + result[15] = -matrix[15]; + return result; +}; +Matrix4.transpose = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const matrix1 = matrix[1]; + const matrix2 = matrix[2]; + const matrix3 = matrix[3]; + const matrix6 = matrix[6]; + const matrix7 = matrix[7]; + const matrix11 = matrix[11]; + result[0] = matrix[0]; + result[1] = matrix[4]; + result[2] = matrix[8]; + result[3] = matrix[12]; + result[4] = matrix1; + result[5] = matrix[5]; + result[6] = matrix[9]; + result[7] = matrix[13]; + result[8] = matrix2; + result[9] = matrix6; + result[10] = matrix[10]; + result[11] = matrix[14]; + result[12] = matrix3; + result[13] = matrix7; + result[14] = matrix11; + result[15] = matrix[15]; + return result; +}; +Matrix4.abs = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result[0] = Math.abs(matrix[0]); + result[1] = Math.abs(matrix[1]); + result[2] = Math.abs(matrix[2]); + result[3] = Math.abs(matrix[3]); + result[4] = Math.abs(matrix[4]); + result[5] = Math.abs(matrix[5]); + result[6] = Math.abs(matrix[6]); + result[7] = Math.abs(matrix[7]); + result[8] = Math.abs(matrix[8]); + result[9] = Math.abs(matrix[9]); + result[10] = Math.abs(matrix[10]); + result[11] = Math.abs(matrix[11]); + result[12] = Math.abs(matrix[12]); + result[13] = Math.abs(matrix[13]); + result[14] = Math.abs(matrix[14]); + result[15] = Math.abs(matrix[15]); + return result; +}; +Matrix4.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && // Translation + left[12] === right[12] && left[13] === right[13] && left[14] === right[14] && // Rotation/scale + left[0] === right[0] && left[1] === right[1] && left[2] === right[2] && left[4] === right[4] && left[5] === right[5] && left[6] === right[6] && left[8] === right[8] && left[9] === right[9] && left[10] === right[10] && // Bottom row + left[3] === right[3] && left[7] === right[7] && left[11] === right[11] && left[15] === right[15]; +}; +Matrix4.equalsEpsilon = function(left, right, epsilon) { + epsilon = defaultValue_default(epsilon, 0); + return left === right || defined_default(left) && defined_default(right) && Math.abs(left[0] - right[0]) <= epsilon && Math.abs(left[1] - right[1]) <= epsilon && Math.abs(left[2] - right[2]) <= epsilon && Math.abs(left[3] - right[3]) <= epsilon && Math.abs(left[4] - right[4]) <= epsilon && Math.abs(left[5] - right[5]) <= epsilon && Math.abs(left[6] - right[6]) <= epsilon && Math.abs(left[7] - right[7]) <= epsilon && Math.abs(left[8] - right[8]) <= epsilon && Math.abs(left[9] - right[9]) <= epsilon && Math.abs(left[10] - right[10]) <= epsilon && Math.abs(left[11] - right[11]) <= epsilon && Math.abs(left[12] - right[12]) <= epsilon && Math.abs(left[13] - right[13]) <= epsilon && Math.abs(left[14] - right[14]) <= epsilon && Math.abs(left[15] - right[15]) <= epsilon; +}; +Matrix4.getTranslation = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result.x = matrix[12]; + result.y = matrix[13]; + result.z = matrix[14]; + return result; +}; +Matrix4.getMatrix3 = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[4]; + result[4] = matrix[5]; + result[5] = matrix[6]; + result[6] = matrix[8]; + result[7] = matrix[9]; + result[8] = matrix[10]; + return result; +}; +var scratchInverseRotation = new Matrix3_default(); +var scratchMatrix3Zero = new Matrix3_default(); +var scratchBottomRow = new Cartesian4_default(); +var scratchExpectedBottomRow = new Cartesian4_default(0, 0, 0, 1); +Matrix4.inverse = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const src0 = matrix[0]; + const src1 = matrix[4]; + const src2 = matrix[8]; + const src3 = matrix[12]; + const src4 = matrix[1]; + const src5 = matrix[5]; + const src6 = matrix[9]; + const src7 = matrix[13]; + const src8 = matrix[2]; + const src9 = matrix[6]; + const src10 = matrix[10]; + const src11 = matrix[14]; + const src12 = matrix[3]; + const src13 = matrix[7]; + const src14 = matrix[11]; + const src15 = matrix[15]; + let tmp0 = src10 * src15; + let tmp1 = src11 * src14; + let tmp2 = src9 * src15; + let tmp3 = src11 * src13; + let tmp4 = src9 * src14; + let tmp5 = src10 * src13; + let tmp6 = src8 * src15; + let tmp7 = src11 * src12; + let tmp8 = src8 * src14; + let tmp9 = src10 * src12; + let tmp10 = src8 * src13; + let tmp11 = src9 * src12; + const dst0 = tmp0 * src5 + tmp3 * src6 + tmp4 * src7 - (tmp1 * src5 + tmp2 * src6 + tmp5 * src7); + const dst1 = tmp1 * src4 + tmp6 * src6 + tmp9 * src7 - (tmp0 * src4 + tmp7 * src6 + tmp8 * src7); + const dst2 = tmp2 * src4 + tmp7 * src5 + tmp10 * src7 - (tmp3 * src4 + tmp6 * src5 + tmp11 * src7); + const dst3 = tmp5 * src4 + tmp8 * src5 + tmp11 * src6 - (tmp4 * src4 + tmp9 * src5 + tmp10 * src6); + const dst4 = tmp1 * src1 + tmp2 * src2 + tmp5 * src3 - (tmp0 * src1 + tmp3 * src2 + tmp4 * src3); + const dst5 = tmp0 * src0 + tmp7 * src2 + tmp8 * src3 - (tmp1 * src0 + tmp6 * src2 + tmp9 * src3); + const dst6 = tmp3 * src0 + tmp6 * src1 + tmp11 * src3 - (tmp2 * src0 + tmp7 * src1 + tmp10 * src3); + const dst7 = tmp4 * src0 + tmp9 * src1 + tmp10 * src2 - (tmp5 * src0 + tmp8 * src1 + tmp11 * src2); + tmp0 = src2 * src7; + tmp1 = src3 * src6; + tmp2 = src1 * src7; + tmp3 = src3 * src5; + tmp4 = src1 * src6; + tmp5 = src2 * src5; + tmp6 = src0 * src7; + tmp7 = src3 * src4; + tmp8 = src0 * src6; + tmp9 = src2 * src4; + tmp10 = src0 * src5; + tmp11 = src1 * src4; + const dst8 = tmp0 * src13 + tmp3 * src14 + tmp4 * src15 - (tmp1 * src13 + tmp2 * src14 + tmp5 * src15); + const dst9 = tmp1 * src12 + tmp6 * src14 + tmp9 * src15 - (tmp0 * src12 + tmp7 * src14 + tmp8 * src15); + const dst10 = tmp2 * src12 + tmp7 * src13 + tmp10 * src15 - (tmp3 * src12 + tmp6 * src13 + tmp11 * src15); + const dst11 = tmp5 * src12 + tmp8 * src13 + tmp11 * src14 - (tmp4 * src12 + tmp9 * src13 + tmp10 * src14); + const dst12 = tmp2 * src10 + tmp5 * src11 + tmp1 * src9 - (tmp4 * src11 + tmp0 * src9 + tmp3 * src10); + const dst13 = tmp8 * src11 + tmp0 * src8 + tmp7 * src10 - (tmp6 * src10 + tmp9 * src11 + tmp1 * src8); + const dst14 = tmp6 * src9 + tmp11 * src11 + tmp3 * src8 - (tmp10 * src11 + tmp2 * src8 + tmp7 * src9); + const dst15 = tmp10 * src10 + tmp4 * src8 + tmp9 * src9 - (tmp8 * src9 + tmp11 * src10 + tmp5 * src8); + let det = src0 * dst0 + src1 * dst1 + src2 * dst2 + src3 * dst3; + if (Math.abs(det) < Math_default.EPSILON21) { + if (Matrix3_default.equalsEpsilon( + Matrix4.getMatrix3(matrix, scratchInverseRotation), + scratchMatrix3Zero, + Math_default.EPSILON7 + ) && Cartesian4_default.equals( + Matrix4.getRow(matrix, 3, scratchBottomRow), + scratchExpectedBottomRow + )) { + result[0] = 0; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = 0; + result[5] = 0; + result[6] = 0; + result[7] = 0; + result[8] = 0; + result[9] = 0; + result[10] = 0; + result[11] = 0; + result[12] = -matrix[12]; + result[13] = -matrix[13]; + result[14] = -matrix[14]; + result[15] = 1; + return result; + } + throw new RuntimeError_default( + "matrix is not invertible because its determinate is zero." + ); + } + det = 1 / det; + result[0] = dst0 * det; + result[1] = dst1 * det; + result[2] = dst2 * det; + result[3] = dst3 * det; + result[4] = dst4 * det; + result[5] = dst5 * det; + result[6] = dst6 * det; + result[7] = dst7 * det; + result[8] = dst8 * det; + result[9] = dst9 * det; + result[10] = dst10 * det; + result[11] = dst11 * det; + result[12] = dst12 * det; + result[13] = dst13 * det; + result[14] = dst14 * det; + result[15] = dst15 * det; + return result; +}; +Matrix4.inverseTransformation = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const matrix0 = matrix[0]; + const matrix1 = matrix[1]; + const matrix2 = matrix[2]; + const matrix4 = matrix[4]; + const matrix5 = matrix[5]; + const matrix6 = matrix[6]; + const matrix8 = matrix[8]; + const matrix9 = matrix[9]; + const matrix10 = matrix[10]; + const vX = matrix[12]; + const vY = matrix[13]; + const vZ = matrix[14]; + const x = -matrix0 * vX - matrix1 * vY - matrix2 * vZ; + const y = -matrix4 * vX - matrix5 * vY - matrix6 * vZ; + const z = -matrix8 * vX - matrix9 * vY - matrix10 * vZ; + result[0] = matrix0; + result[1] = matrix4; + result[2] = matrix8; + result[3] = 0; + result[4] = matrix1; + result[5] = matrix5; + result[6] = matrix9; + result[7] = 0; + result[8] = matrix2; + result[9] = matrix6; + result[10] = matrix10; + result[11] = 0; + result[12] = x; + result[13] = y; + result[14] = z; + result[15] = 1; + return result; +}; +var scratchTransposeMatrix = new Matrix4(); +Matrix4.inverseTranspose = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + return Matrix4.inverse( + Matrix4.transpose(matrix, scratchTransposeMatrix), + result + ); +}; +Matrix4.IDENTITY = Object.freeze( + new Matrix4( + 1, + 0, + 0, + 0, + 0, + 1, + 0, + 0, + 0, + 0, + 1, + 0, + 0, + 0, + 0, + 1 + ) +); +Matrix4.ZERO = Object.freeze( + new Matrix4( + 0, + 0, + 0, + 0, + 0, + 0, + 0, + 0, + 0, + 0, + 0, + 0, + 0, + 0, + 0, + 0 + ) +); +Matrix4.COLUMN0ROW0 = 0; +Matrix4.COLUMN0ROW1 = 1; +Matrix4.COLUMN0ROW2 = 2; +Matrix4.COLUMN0ROW3 = 3; +Matrix4.COLUMN1ROW0 = 4; +Matrix4.COLUMN1ROW1 = 5; +Matrix4.COLUMN1ROW2 = 6; +Matrix4.COLUMN1ROW3 = 7; +Matrix4.COLUMN2ROW0 = 8; +Matrix4.COLUMN2ROW1 = 9; +Matrix4.COLUMN2ROW2 = 10; +Matrix4.COLUMN2ROW3 = 11; +Matrix4.COLUMN3ROW0 = 12; +Matrix4.COLUMN3ROW1 = 13; +Matrix4.COLUMN3ROW2 = 14; +Matrix4.COLUMN3ROW3 = 15; +Object.defineProperties(Matrix4.prototype, { + /** + * Gets the number of items in the collection. + * @memberof Matrix4.prototype + * + * @type {number} + */ + length: { + get: function() { + return Matrix4.packedLength; + } + } +}); +Matrix4.prototype.clone = function(result) { + return Matrix4.clone(this, result); +}; +Matrix4.prototype.equals = function(right) { + return Matrix4.equals(this, right); +}; +Matrix4.equalsArray = function(matrix, array, offset) { + return matrix[0] === array[offset] && matrix[1] === array[offset + 1] && matrix[2] === array[offset + 2] && matrix[3] === array[offset + 3] && matrix[4] === array[offset + 4] && matrix[5] === array[offset + 5] && matrix[6] === array[offset + 6] && matrix[7] === array[offset + 7] && matrix[8] === array[offset + 8] && matrix[9] === array[offset + 9] && matrix[10] === array[offset + 10] && matrix[11] === array[offset + 11] && matrix[12] === array[offset + 12] && matrix[13] === array[offset + 13] && matrix[14] === array[offset + 14] && matrix[15] === array[offset + 15]; +}; +Matrix4.prototype.equalsEpsilon = function(right, epsilon) { + return Matrix4.equalsEpsilon(this, right, epsilon); +}; +Matrix4.prototype.toString = function() { + return `(${this[0]}, ${this[4]}, ${this[8]}, ${this[12]}) +(${this[1]}, ${this[5]}, ${this[9]}, ${this[13]}) +(${this[2]}, ${this[6]}, ${this[10]}, ${this[14]}) +(${this[3]}, ${this[7]}, ${this[11]}, ${this[15]})`; +}; +var Matrix4_default = Matrix4; + +// packages/engine/Source/Core/Rectangle.js +function Rectangle(west, south, east, north) { + this.west = defaultValue_default(west, 0); + this.south = defaultValue_default(south, 0); + this.east = defaultValue_default(east, 0); + this.north = defaultValue_default(north, 0); +} +Object.defineProperties(Rectangle.prototype, { + /** + * Gets the width of the rectangle in radians. + * @memberof Rectangle.prototype + * @type {number} + * @readonly + */ + width: { + get: function() { + return Rectangle.computeWidth(this); + } + }, + /** + * Gets the height of the rectangle in radians. + * @memberof Rectangle.prototype + * @type {number} + * @readonly + */ + height: { + get: function() { + return Rectangle.computeHeight(this); + } + } +}); +Rectangle.packedLength = 4; +Rectangle.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value.west; + array[startingIndex++] = value.south; + array[startingIndex++] = value.east; + array[startingIndex] = value.north; + return array; +}; +Rectangle.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new Rectangle(); + } + result.west = array[startingIndex++]; + result.south = array[startingIndex++]; + result.east = array[startingIndex++]; + result.north = array[startingIndex]; + return result; +}; +Rectangle.computeWidth = function(rectangle) { + Check_default.typeOf.object("rectangle", rectangle); + let east = rectangle.east; + const west = rectangle.west; + if (east < west) { + east += Math_default.TWO_PI; + } + return east - west; +}; +Rectangle.computeHeight = function(rectangle) { + Check_default.typeOf.object("rectangle", rectangle); + return rectangle.north - rectangle.south; +}; +Rectangle.fromDegrees = function(west, south, east, north, result) { + west = Math_default.toRadians(defaultValue_default(west, 0)); + south = Math_default.toRadians(defaultValue_default(south, 0)); + east = Math_default.toRadians(defaultValue_default(east, 0)); + north = Math_default.toRadians(defaultValue_default(north, 0)); + if (!defined_default(result)) { + return new Rectangle(west, south, east, north); + } + result.west = west; + result.south = south; + result.east = east; + result.north = north; + return result; +}; +Rectangle.fromRadians = function(west, south, east, north, result) { + if (!defined_default(result)) { + return new Rectangle(west, south, east, north); + } + result.west = defaultValue_default(west, 0); + result.south = defaultValue_default(south, 0); + result.east = defaultValue_default(east, 0); + result.north = defaultValue_default(north, 0); + return result; +}; +Rectangle.fromCartographicArray = function(cartographics, result) { + Check_default.defined("cartographics", cartographics); + let west = Number.MAX_VALUE; + let east = -Number.MAX_VALUE; + let westOverIDL = Number.MAX_VALUE; + let eastOverIDL = -Number.MAX_VALUE; + let south = Number.MAX_VALUE; + let north = -Number.MAX_VALUE; + for (let i = 0, len = cartographics.length; i < len; i++) { + const position = cartographics[i]; + west = Math.min(west, position.longitude); + east = Math.max(east, position.longitude); + south = Math.min(south, position.latitude); + north = Math.max(north, position.latitude); + const lonAdjusted = position.longitude >= 0 ? position.longitude : position.longitude + Math_default.TWO_PI; + westOverIDL = Math.min(westOverIDL, lonAdjusted); + eastOverIDL = Math.max(eastOverIDL, lonAdjusted); + } + if (east - west > eastOverIDL - westOverIDL) { + west = westOverIDL; + east = eastOverIDL; + if (east > Math_default.PI) { + east = east - Math_default.TWO_PI; + } + if (west > Math_default.PI) { + west = west - Math_default.TWO_PI; + } + } + if (!defined_default(result)) { + return new Rectangle(west, south, east, north); + } + result.west = west; + result.south = south; + result.east = east; + result.north = north; + return result; +}; +Rectangle.fromCartesianArray = function(cartesians, ellipsoid, result) { + Check_default.defined("cartesians", cartesians); + ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + let west = Number.MAX_VALUE; + let east = -Number.MAX_VALUE; + let westOverIDL = Number.MAX_VALUE; + let eastOverIDL = -Number.MAX_VALUE; + let south = Number.MAX_VALUE; + let north = -Number.MAX_VALUE; + for (let i = 0, len = cartesians.length; i < len; i++) { + const position = ellipsoid.cartesianToCartographic(cartesians[i]); + west = Math.min(west, position.longitude); + east = Math.max(east, position.longitude); + south = Math.min(south, position.latitude); + north = Math.max(north, position.latitude); + const lonAdjusted = position.longitude >= 0 ? position.longitude : position.longitude + Math_default.TWO_PI; + westOverIDL = Math.min(westOverIDL, lonAdjusted); + eastOverIDL = Math.max(eastOverIDL, lonAdjusted); + } + if (east - west > eastOverIDL - westOverIDL) { + west = westOverIDL; + east = eastOverIDL; + if (east > Math_default.PI) { + east = east - Math_default.TWO_PI; + } + if (west > Math_default.PI) { + west = west - Math_default.TWO_PI; + } + } + if (!defined_default(result)) { + return new Rectangle(west, south, east, north); + } + result.west = west; + result.south = south; + result.east = east; + result.north = north; + return result; +}; +Rectangle.clone = function(rectangle, result) { + if (!defined_default(rectangle)) { + return void 0; + } + if (!defined_default(result)) { + return new Rectangle( + rectangle.west, + rectangle.south, + rectangle.east, + rectangle.north + ); + } + result.west = rectangle.west; + result.south = rectangle.south; + result.east = rectangle.east; + result.north = rectangle.north; + return result; +}; +Rectangle.equalsEpsilon = function(left, right, absoluteEpsilon) { + absoluteEpsilon = defaultValue_default(absoluteEpsilon, 0); + return left === right || defined_default(left) && defined_default(right) && Math.abs(left.west - right.west) <= absoluteEpsilon && Math.abs(left.south - right.south) <= absoluteEpsilon && Math.abs(left.east - right.east) <= absoluteEpsilon && Math.abs(left.north - right.north) <= absoluteEpsilon; +}; +Rectangle.prototype.clone = function(result) { + return Rectangle.clone(this, result); +}; +Rectangle.prototype.equals = function(other) { + return Rectangle.equals(this, other); +}; +Rectangle.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left.west === right.west && left.south === right.south && left.east === right.east && left.north === right.north; +}; +Rectangle.prototype.equalsEpsilon = function(other, epsilon) { + return Rectangle.equalsEpsilon(this, other, epsilon); +}; +Rectangle.validate = function(rectangle) { + Check_default.typeOf.object("rectangle", rectangle); + const north = rectangle.north; + Check_default.typeOf.number.greaterThanOrEquals( + "north", + north, + -Math_default.PI_OVER_TWO + ); + Check_default.typeOf.number.lessThanOrEquals("north", north, Math_default.PI_OVER_TWO); + const south = rectangle.south; + Check_default.typeOf.number.greaterThanOrEquals( + "south", + south, + -Math_default.PI_OVER_TWO + ); + Check_default.typeOf.number.lessThanOrEquals("south", south, Math_default.PI_OVER_TWO); + const west = rectangle.west; + Check_default.typeOf.number.greaterThanOrEquals("west", west, -Math.PI); + Check_default.typeOf.number.lessThanOrEquals("west", west, Math.PI); + const east = rectangle.east; + Check_default.typeOf.number.greaterThanOrEquals("east", east, -Math.PI); + Check_default.typeOf.number.lessThanOrEquals("east", east, Math.PI); +}; +Rectangle.southwest = function(rectangle, result) { + Check_default.typeOf.object("rectangle", rectangle); + if (!defined_default(result)) { + return new Cartographic_default(rectangle.west, rectangle.south); + } + result.longitude = rectangle.west; + result.latitude = rectangle.south; + result.height = 0; + return result; +}; +Rectangle.northwest = function(rectangle, result) { + Check_default.typeOf.object("rectangle", rectangle); + if (!defined_default(result)) { + return new Cartographic_default(rectangle.west, rectangle.north); + } + result.longitude = rectangle.west; + result.latitude = rectangle.north; + result.height = 0; + return result; +}; +Rectangle.northeast = function(rectangle, result) { + Check_default.typeOf.object("rectangle", rectangle); + if (!defined_default(result)) { + return new Cartographic_default(rectangle.east, rectangle.north); + } + result.longitude = rectangle.east; + result.latitude = rectangle.north; + result.height = 0; + return result; +}; +Rectangle.southeast = function(rectangle, result) { + Check_default.typeOf.object("rectangle", rectangle); + if (!defined_default(result)) { + return new Cartographic_default(rectangle.east, rectangle.south); + } + result.longitude = rectangle.east; + result.latitude = rectangle.south; + result.height = 0; + return result; +}; +Rectangle.center = function(rectangle, result) { + Check_default.typeOf.object("rectangle", rectangle); + let east = rectangle.east; + const west = rectangle.west; + if (east < west) { + east += Math_default.TWO_PI; + } + const longitude = Math_default.negativePiToPi((west + east) * 0.5); + const latitude = (rectangle.south + rectangle.north) * 0.5; + if (!defined_default(result)) { + return new Cartographic_default(longitude, latitude); + } + result.longitude = longitude; + result.latitude = latitude; + result.height = 0; + return result; +}; +Rectangle.intersection = function(rectangle, otherRectangle, result) { + Check_default.typeOf.object("rectangle", rectangle); + Check_default.typeOf.object("otherRectangle", otherRectangle); + let rectangleEast = rectangle.east; + let rectangleWest = rectangle.west; + let otherRectangleEast = otherRectangle.east; + let otherRectangleWest = otherRectangle.west; + if (rectangleEast < rectangleWest && otherRectangleEast > 0) { + rectangleEast += Math_default.TWO_PI; + } else if (otherRectangleEast < otherRectangleWest && rectangleEast > 0) { + otherRectangleEast += Math_default.TWO_PI; + } + if (rectangleEast < rectangleWest && otherRectangleWest < 0) { + otherRectangleWest += Math_default.TWO_PI; + } else if (otherRectangleEast < otherRectangleWest && rectangleWest < 0) { + rectangleWest += Math_default.TWO_PI; + } + const west = Math_default.negativePiToPi( + Math.max(rectangleWest, otherRectangleWest) + ); + const east = Math_default.negativePiToPi( + Math.min(rectangleEast, otherRectangleEast) + ); + if ((rectangle.west < rectangle.east || otherRectangle.west < otherRectangle.east) && east <= west) { + return void 0; + } + const south = Math.max(rectangle.south, otherRectangle.south); + const north = Math.min(rectangle.north, otherRectangle.north); + if (south >= north) { + return void 0; + } + if (!defined_default(result)) { + return new Rectangle(west, south, east, north); + } + result.west = west; + result.south = south; + result.east = east; + result.north = north; + return result; +}; +Rectangle.simpleIntersection = function(rectangle, otherRectangle, result) { + Check_default.typeOf.object("rectangle", rectangle); + Check_default.typeOf.object("otherRectangle", otherRectangle); + const west = Math.max(rectangle.west, otherRectangle.west); + const south = Math.max(rectangle.south, otherRectangle.south); + const east = Math.min(rectangle.east, otherRectangle.east); + const north = Math.min(rectangle.north, otherRectangle.north); + if (south >= north || west >= east) { + return void 0; + } + if (!defined_default(result)) { + return new Rectangle(west, south, east, north); + } + result.west = west; + result.south = south; + result.east = east; + result.north = north; + return result; +}; +Rectangle.union = function(rectangle, otherRectangle, result) { + Check_default.typeOf.object("rectangle", rectangle); + Check_default.typeOf.object("otherRectangle", otherRectangle); + if (!defined_default(result)) { + result = new Rectangle(); + } + let rectangleEast = rectangle.east; + let rectangleWest = rectangle.west; + let otherRectangleEast = otherRectangle.east; + let otherRectangleWest = otherRectangle.west; + if (rectangleEast < rectangleWest && otherRectangleEast > 0) { + rectangleEast += Math_default.TWO_PI; + } else if (otherRectangleEast < otherRectangleWest && rectangleEast > 0) { + otherRectangleEast += Math_default.TWO_PI; + } + if (rectangleEast < rectangleWest && otherRectangleWest < 0) { + otherRectangleWest += Math_default.TWO_PI; + } else if (otherRectangleEast < otherRectangleWest && rectangleWest < 0) { + rectangleWest += Math_default.TWO_PI; + } + const west = Math_default.negativePiToPi( + Math.min(rectangleWest, otherRectangleWest) + ); + const east = Math_default.negativePiToPi( + Math.max(rectangleEast, otherRectangleEast) + ); + result.west = west; + result.south = Math.min(rectangle.south, otherRectangle.south); + result.east = east; + result.north = Math.max(rectangle.north, otherRectangle.north); + return result; +}; +Rectangle.expand = function(rectangle, cartographic, result) { + Check_default.typeOf.object("rectangle", rectangle); + Check_default.typeOf.object("cartographic", cartographic); + if (!defined_default(result)) { + result = new Rectangle(); + } + result.west = Math.min(rectangle.west, cartographic.longitude); + result.south = Math.min(rectangle.south, cartographic.latitude); + result.east = Math.max(rectangle.east, cartographic.longitude); + result.north = Math.max(rectangle.north, cartographic.latitude); + return result; +}; +Rectangle.contains = function(rectangle, cartographic) { + Check_default.typeOf.object("rectangle", rectangle); + Check_default.typeOf.object("cartographic", cartographic); + let longitude = cartographic.longitude; + const latitude = cartographic.latitude; + const west = rectangle.west; + let east = rectangle.east; + if (east < west) { + east += Math_default.TWO_PI; + if (longitude < 0) { + longitude += Math_default.TWO_PI; + } + } + return (longitude > west || Math_default.equalsEpsilon(longitude, west, Math_default.EPSILON14)) && (longitude < east || Math_default.equalsEpsilon(longitude, east, Math_default.EPSILON14)) && latitude >= rectangle.south && latitude <= rectangle.north; +}; +var subsampleLlaScratch = new Cartographic_default(); +Rectangle.subsample = function(rectangle, ellipsoid, surfaceHeight, result) { + Check_default.typeOf.object("rectangle", rectangle); + ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + surfaceHeight = defaultValue_default(surfaceHeight, 0); + if (!defined_default(result)) { + result = []; + } + let length = 0; + const north = rectangle.north; + const south = rectangle.south; + const east = rectangle.east; + const west = rectangle.west; + const lla = subsampleLlaScratch; + lla.height = surfaceHeight; + lla.longitude = west; + lla.latitude = north; + result[length] = ellipsoid.cartographicToCartesian(lla, result[length]); + length++; + lla.longitude = east; + result[length] = ellipsoid.cartographicToCartesian(lla, result[length]); + length++; + lla.latitude = south; + result[length] = ellipsoid.cartographicToCartesian(lla, result[length]); + length++; + lla.longitude = west; + result[length] = ellipsoid.cartographicToCartesian(lla, result[length]); + length++; + if (north < 0) { + lla.latitude = north; + } else if (south > 0) { + lla.latitude = south; + } else { + lla.latitude = 0; + } + for (let i = 1; i < 8; ++i) { + lla.longitude = -Math.PI + i * Math_default.PI_OVER_TWO; + if (Rectangle.contains(rectangle, lla)) { + result[length] = ellipsoid.cartographicToCartesian(lla, result[length]); + length++; + } + } + if (lla.latitude === 0) { + lla.longitude = west; + result[length] = ellipsoid.cartographicToCartesian(lla, result[length]); + length++; + lla.longitude = east; + result[length] = ellipsoid.cartographicToCartesian(lla, result[length]); + length++; + } + result.length = length; + return result; +}; +Rectangle.subsection = function(rectangle, westLerp, southLerp, eastLerp, northLerp, result) { + Check_default.typeOf.object("rectangle", rectangle); + Check_default.typeOf.number.greaterThanOrEquals("westLerp", westLerp, 0); + Check_default.typeOf.number.lessThanOrEquals("westLerp", westLerp, 1); + Check_default.typeOf.number.greaterThanOrEquals("southLerp", southLerp, 0); + Check_default.typeOf.number.lessThanOrEquals("southLerp", southLerp, 1); + Check_default.typeOf.number.greaterThanOrEquals("eastLerp", eastLerp, 0); + Check_default.typeOf.number.lessThanOrEquals("eastLerp", eastLerp, 1); + Check_default.typeOf.number.greaterThanOrEquals("northLerp", northLerp, 0); + Check_default.typeOf.number.lessThanOrEquals("northLerp", northLerp, 1); + Check_default.typeOf.number.lessThanOrEquals("westLerp", westLerp, eastLerp); + Check_default.typeOf.number.lessThanOrEquals("southLerp", southLerp, northLerp); + if (!defined_default(result)) { + result = new Rectangle(); + } + if (rectangle.west <= rectangle.east) { + const width = rectangle.east - rectangle.west; + result.west = rectangle.west + westLerp * width; + result.east = rectangle.west + eastLerp * width; + } else { + const width = Math_default.TWO_PI + rectangle.east - rectangle.west; + result.west = Math_default.negativePiToPi(rectangle.west + westLerp * width); + result.east = Math_default.negativePiToPi(rectangle.west + eastLerp * width); + } + const height = rectangle.north - rectangle.south; + result.south = rectangle.south + southLerp * height; + result.north = rectangle.south + northLerp * height; + if (westLerp === 1) { + result.west = rectangle.east; + } + if (eastLerp === 1) { + result.east = rectangle.east; + } + if (southLerp === 1) { + result.south = rectangle.north; + } + if (northLerp === 1) { + result.north = rectangle.north; + } + return result; +}; +Rectangle.MAX_VALUE = Object.freeze( + new Rectangle( + -Math.PI, + -Math_default.PI_OVER_TWO, + Math.PI, + Math_default.PI_OVER_TWO + ) +); +var Rectangle_default = Rectangle; + +// packages/engine/Source/Core/Cartesian2.js +function Cartesian2(x, y) { + this.x = defaultValue_default(x, 0); + this.y = defaultValue_default(y, 0); +} +Cartesian2.fromElements = function(x, y, result) { + if (!defined_default(result)) { + return new Cartesian2(x, y); + } + result.x = x; + result.y = y; + return result; +}; +Cartesian2.clone = function(cartesian, result) { + if (!defined_default(cartesian)) { + return void 0; + } + if (!defined_default(result)) { + return new Cartesian2(cartesian.x, cartesian.y); + } + result.x = cartesian.x; + result.y = cartesian.y; + return result; +}; +Cartesian2.fromCartesian3 = Cartesian2.clone; +Cartesian2.fromCartesian4 = Cartesian2.clone; +Cartesian2.packedLength = 2; +Cartesian2.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value.x; + array[startingIndex] = value.y; + return array; +}; +Cartesian2.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new Cartesian2(); + } + result.x = array[startingIndex++]; + result.y = array[startingIndex]; + return result; +}; +Cartesian2.packArray = function(array, result) { + Check_default.defined("array", array); + const length = array.length; + const resultLength = length * 2; + if (!defined_default(result)) { + result = new Array(resultLength); + } else if (!Array.isArray(result) && result.length !== resultLength) { + throw new DeveloperError_default( + "If result is a typed array, it must have exactly array.length * 2 elements" + ); + } else if (result.length !== resultLength) { + result.length = resultLength; + } + for (let i = 0; i < length; ++i) { + Cartesian2.pack(array[i], result, i * 2); + } + return result; +}; +Cartesian2.unpackArray = function(array, result) { + Check_default.defined("array", array); + Check_default.typeOf.number.greaterThanOrEquals("array.length", array.length, 2); + if (array.length % 2 !== 0) { + throw new DeveloperError_default("array length must be a multiple of 2."); + } + const length = array.length; + if (!defined_default(result)) { + result = new Array(length / 2); + } else { + result.length = length / 2; + } + for (let i = 0; i < length; i += 2) { + const index = i / 2; + result[index] = Cartesian2.unpack(array, i, result[index]); + } + return result; +}; +Cartesian2.fromArray = Cartesian2.unpack; +Cartesian2.maximumComponent = function(cartesian) { + Check_default.typeOf.object("cartesian", cartesian); + return Math.max(cartesian.x, cartesian.y); +}; +Cartesian2.minimumComponent = function(cartesian) { + Check_default.typeOf.object("cartesian", cartesian); + return Math.min(cartesian.x, cartesian.y); +}; +Cartesian2.minimumByComponent = function(first, second, result) { + Check_default.typeOf.object("first", first); + Check_default.typeOf.object("second", second); + Check_default.typeOf.object("result", result); + result.x = Math.min(first.x, second.x); + result.y = Math.min(first.y, second.y); + return result; +}; +Cartesian2.maximumByComponent = function(first, second, result) { + Check_default.typeOf.object("first", first); + Check_default.typeOf.object("second", second); + Check_default.typeOf.object("result", result); + result.x = Math.max(first.x, second.x); + result.y = Math.max(first.y, second.y); + return result; +}; +Cartesian2.clamp = function(value, min, max, result) { + Check_default.typeOf.object("value", value); + Check_default.typeOf.object("min", min); + Check_default.typeOf.object("max", max); + Check_default.typeOf.object("result", result); + const x = Math_default.clamp(value.x, min.x, max.x); + const y = Math_default.clamp(value.y, min.y, max.y); + result.x = x; + result.y = y; + return result; +}; +Cartesian2.magnitudeSquared = function(cartesian) { + Check_default.typeOf.object("cartesian", cartesian); + return cartesian.x * cartesian.x + cartesian.y * cartesian.y; +}; +Cartesian2.magnitude = function(cartesian) { + return Math.sqrt(Cartesian2.magnitudeSquared(cartesian)); +}; +var distanceScratch2 = new Cartesian2(); +Cartesian2.distance = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Cartesian2.subtract(left, right, distanceScratch2); + return Cartesian2.magnitude(distanceScratch2); +}; +Cartesian2.distanceSquared = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Cartesian2.subtract(left, right, distanceScratch2); + return Cartesian2.magnitudeSquared(distanceScratch2); +}; +Cartesian2.normalize = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const magnitude = Cartesian2.magnitude(cartesian); + result.x = cartesian.x / magnitude; + result.y = cartesian.y / magnitude; + if (isNaN(result.x) || isNaN(result.y)) { + throw new DeveloperError_default("normalized result is not a number"); + } + return result; +}; +Cartesian2.dot = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + return left.x * right.x + left.y * right.y; +}; +Cartesian2.cross = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + return left.x * right.y - left.y * right.x; +}; +Cartesian2.multiplyComponents = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x * right.x; + result.y = left.y * right.y; + return result; +}; +Cartesian2.divideComponents = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x / right.x; + result.y = left.y / right.y; + return result; +}; +Cartesian2.add = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x + right.x; + result.y = left.y + right.y; + return result; +}; +Cartesian2.subtract = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x - right.x; + result.y = left.y - right.y; + return result; +}; +Cartesian2.multiplyByScalar = function(cartesian, scalar, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result.x = cartesian.x * scalar; + result.y = cartesian.y * scalar; + return result; +}; +Cartesian2.divideByScalar = function(cartesian, scalar, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result.x = cartesian.x / scalar; + result.y = cartesian.y / scalar; + return result; +}; +Cartesian2.negate = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result.x = -cartesian.x; + result.y = -cartesian.y; + return result; +}; +Cartesian2.abs = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result.x = Math.abs(cartesian.x); + result.y = Math.abs(cartesian.y); + return result; +}; +var lerpScratch2 = new Cartesian2(); +Cartesian2.lerp = function(start, end, t, result) { + Check_default.typeOf.object("start", start); + Check_default.typeOf.object("end", end); + Check_default.typeOf.number("t", t); + Check_default.typeOf.object("result", result); + Cartesian2.multiplyByScalar(end, t, lerpScratch2); + result = Cartesian2.multiplyByScalar(start, 1 - t, result); + return Cartesian2.add(lerpScratch2, result, result); +}; +var angleBetweenScratch = new Cartesian2(); +var angleBetweenScratch2 = new Cartesian2(); +Cartesian2.angleBetween = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Cartesian2.normalize(left, angleBetweenScratch); + Cartesian2.normalize(right, angleBetweenScratch2); + return Math_default.acosClamped( + Cartesian2.dot(angleBetweenScratch, angleBetweenScratch2) + ); +}; +var mostOrthogonalAxisScratch2 = new Cartesian2(); +Cartesian2.mostOrthogonalAxis = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const f = Cartesian2.normalize(cartesian, mostOrthogonalAxisScratch2); + Cartesian2.abs(f, f); + if (f.x <= f.y) { + result = Cartesian2.clone(Cartesian2.UNIT_X, result); + } else { + result = Cartesian2.clone(Cartesian2.UNIT_Y, result); + } + return result; +}; +Cartesian2.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left.x === right.x && left.y === right.y; +}; +Cartesian2.equalsArray = function(cartesian, array, offset) { + return cartesian.x === array[offset] && cartesian.y === array[offset + 1]; +}; +Cartesian2.equalsEpsilon = function(left, right, relativeEpsilon, absoluteEpsilon) { + return left === right || defined_default(left) && defined_default(right) && Math_default.equalsEpsilon( + left.x, + right.x, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + left.y, + right.y, + relativeEpsilon, + absoluteEpsilon + ); +}; +Cartesian2.ZERO = Object.freeze(new Cartesian2(0, 0)); +Cartesian2.ONE = Object.freeze(new Cartesian2(1, 1)); +Cartesian2.UNIT_X = Object.freeze(new Cartesian2(1, 0)); +Cartesian2.UNIT_Y = Object.freeze(new Cartesian2(0, 1)); +Cartesian2.prototype.clone = function(result) { + return Cartesian2.clone(this, result); +}; +Cartesian2.prototype.equals = function(right) { + return Cartesian2.equals(this, right); +}; +Cartesian2.prototype.equalsEpsilon = function(right, relativeEpsilon, absoluteEpsilon) { + return Cartesian2.equalsEpsilon( + this, + right, + relativeEpsilon, + absoluteEpsilon + ); +}; +Cartesian2.prototype.toString = function() { + return `(${this.x}, ${this.y})`; +}; +var Cartesian2_default = Cartesian2; + +// packages/engine/Source/Core/Matrix2.js +function Matrix2(column0Row0, column1Row0, column0Row1, column1Row1) { + this[0] = defaultValue_default(column0Row0, 0); + this[1] = defaultValue_default(column0Row1, 0); + this[2] = defaultValue_default(column1Row0, 0); + this[3] = defaultValue_default(column1Row1, 0); +} +Matrix2.packedLength = 4; +Matrix2.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value[0]; + array[startingIndex++] = value[1]; + array[startingIndex++] = value[2]; + array[startingIndex++] = value[3]; + return array; +}; +Matrix2.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new Matrix2(); + } + result[0] = array[startingIndex++]; + result[1] = array[startingIndex++]; + result[2] = array[startingIndex++]; + result[3] = array[startingIndex++]; + return result; +}; +Matrix2.packArray = function(array, result) { + Check_default.defined("array", array); + const length = array.length; + const resultLength = length * 4; + if (!defined_default(result)) { + result = new Array(resultLength); + } else if (!Array.isArray(result) && result.length !== resultLength) { + throw new DeveloperError_default( + "If result is a typed array, it must have exactly array.length * 4 elements" + ); + } else if (result.length !== resultLength) { + result.length = resultLength; + } + for (let i = 0; i < length; ++i) { + Matrix2.pack(array[i], result, i * 4); + } + return result; +}; +Matrix2.unpackArray = function(array, result) { + Check_default.defined("array", array); + Check_default.typeOf.number.greaterThanOrEquals("array.length", array.length, 4); + if (array.length % 4 !== 0) { + throw new DeveloperError_default("array length must be a multiple of 4."); + } + const length = array.length; + if (!defined_default(result)) { + result = new Array(length / 4); + } else { + result.length = length / 4; + } + for (let i = 0; i < length; i += 4) { + const index = i / 4; + result[index] = Matrix2.unpack(array, i, result[index]); + } + return result; +}; +Matrix2.clone = function(matrix, result) { + if (!defined_default(matrix)) { + return void 0; + } + if (!defined_default(result)) { + return new Matrix2(matrix[0], matrix[2], matrix[1], matrix[3]); + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + return result; +}; +Matrix2.fromArray = Matrix2.unpack; +Matrix2.fromColumnMajorArray = function(values, result) { + Check_default.defined("values", values); + return Matrix2.clone(values, result); +}; +Matrix2.fromRowMajorArray = function(values, result) { + Check_default.defined("values", values); + if (!defined_default(result)) { + return new Matrix2(values[0], values[1], values[2], values[3]); + } + result[0] = values[0]; + result[1] = values[2]; + result[2] = values[1]; + result[3] = values[3]; + return result; +}; +Matrix2.fromScale = function(scale, result) { + Check_default.typeOf.object("scale", scale); + if (!defined_default(result)) { + return new Matrix2(scale.x, 0, 0, scale.y); + } + result[0] = scale.x; + result[1] = 0; + result[2] = 0; + result[3] = scale.y; + return result; +}; +Matrix2.fromUniformScale = function(scale, result) { + Check_default.typeOf.number("scale", scale); + if (!defined_default(result)) { + return new Matrix2(scale, 0, 0, scale); + } + result[0] = scale; + result[1] = 0; + result[2] = 0; + result[3] = scale; + return result; +}; +Matrix2.fromRotation = function(angle, result) { + Check_default.typeOf.number("angle", angle); + const cosAngle = Math.cos(angle); + const sinAngle = Math.sin(angle); + if (!defined_default(result)) { + return new Matrix2(cosAngle, -sinAngle, sinAngle, cosAngle); + } + result[0] = cosAngle; + result[1] = sinAngle; + result[2] = -sinAngle; + result[3] = cosAngle; + return result; +}; +Matrix2.toArray = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + if (!defined_default(result)) { + return [matrix[0], matrix[1], matrix[2], matrix[3]]; + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + return result; +}; +Matrix2.getElementIndex = function(column, row) { + Check_default.typeOf.number.greaterThanOrEquals("row", row, 0); + Check_default.typeOf.number.lessThanOrEquals("row", row, 1); + Check_default.typeOf.number.greaterThanOrEquals("column", column, 0); + Check_default.typeOf.number.lessThanOrEquals("column", column, 1); + return column * 2 + row; +}; +Matrix2.getColumn = function(matrix, index, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 1); + Check_default.typeOf.object("result", result); + const startIndex = index * 2; + const x = matrix[startIndex]; + const y = matrix[startIndex + 1]; + result.x = x; + result.y = y; + return result; +}; +Matrix2.setColumn = function(matrix, index, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 1); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result = Matrix2.clone(matrix, result); + const startIndex = index * 2; + result[startIndex] = cartesian.x; + result[startIndex + 1] = cartesian.y; + return result; +}; +Matrix2.getRow = function(matrix, index, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 1); + Check_default.typeOf.object("result", result); + const x = matrix[index]; + const y = matrix[index + 2]; + result.x = x; + result.y = y; + return result; +}; +Matrix2.setRow = function(matrix, index, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 1); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result = Matrix2.clone(matrix, result); + result[index] = cartesian.x; + result[index + 2] = cartesian.y; + return result; +}; +var scaleScratch12 = new Cartesian2_default(); +Matrix2.setScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("scale", scale); + Check_default.typeOf.object("result", result); + const existingScale = Matrix2.getScale(matrix, scaleScratch12); + const scaleRatioX = scale.x / existingScale.x; + const scaleRatioY = scale.y / existingScale.y; + result[0] = matrix[0] * scaleRatioX; + result[1] = matrix[1] * scaleRatioX; + result[2] = matrix[2] * scaleRatioY; + result[3] = matrix[3] * scaleRatioY; + return result; +}; +var scaleScratch22 = new Cartesian2_default(); +Matrix2.setUniformScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number("scale", scale); + Check_default.typeOf.object("result", result); + const existingScale = Matrix2.getScale(matrix, scaleScratch22); + const scaleRatioX = scale / existingScale.x; + const scaleRatioY = scale / existingScale.y; + result[0] = matrix[0] * scaleRatioX; + result[1] = matrix[1] * scaleRatioX; + result[2] = matrix[2] * scaleRatioY; + result[3] = matrix[3] * scaleRatioY; + return result; +}; +var scratchColumn2 = new Cartesian2_default(); +Matrix2.getScale = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result.x = Cartesian2_default.magnitude( + Cartesian2_default.fromElements(matrix[0], matrix[1], scratchColumn2) + ); + result.y = Cartesian2_default.magnitude( + Cartesian2_default.fromElements(matrix[2], matrix[3], scratchColumn2) + ); + return result; +}; +var scaleScratch32 = new Cartesian2_default(); +Matrix2.getMaximumScale = function(matrix) { + Matrix2.getScale(matrix, scaleScratch32); + return Cartesian2_default.maximumComponent(scaleScratch32); +}; +var scaleScratch42 = new Cartesian2_default(); +Matrix2.setRotation = function(matrix, rotation, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const scale = Matrix2.getScale(matrix, scaleScratch42); + result[0] = rotation[0] * scale.x; + result[1] = rotation[1] * scale.x; + result[2] = rotation[2] * scale.y; + result[3] = rotation[3] * scale.y; + return result; +}; +var scaleScratch52 = new Cartesian2_default(); +Matrix2.getRotation = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const scale = Matrix2.getScale(matrix, scaleScratch52); + result[0] = matrix[0] / scale.x; + result[1] = matrix[1] / scale.x; + result[2] = matrix[2] / scale.y; + result[3] = matrix[3] / scale.y; + return result; +}; +Matrix2.multiply = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + const column0Row0 = left[0] * right[0] + left[2] * right[1]; + const column1Row0 = left[0] * right[2] + left[2] * right[3]; + const column0Row1 = left[1] * right[0] + left[3] * right[1]; + const column1Row1 = left[1] * right[2] + left[3] * right[3]; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column1Row0; + result[3] = column1Row1; + return result; +}; +Matrix2.add = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result[0] = left[0] + right[0]; + result[1] = left[1] + right[1]; + result[2] = left[2] + right[2]; + result[3] = left[3] + right[3]; + return result; +}; +Matrix2.subtract = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result[0] = left[0] - right[0]; + result[1] = left[1] - right[1]; + result[2] = left[2] - right[2]; + result[3] = left[3] - right[3]; + return result; +}; +Matrix2.multiplyByVector = function(matrix, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const x = matrix[0] * cartesian.x + matrix[2] * cartesian.y; + const y = matrix[1] * cartesian.x + matrix[3] * cartesian.y; + result.x = x; + result.y = y; + return result; +}; +Matrix2.multiplyByScalar = function(matrix, scalar, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result[0] = matrix[0] * scalar; + result[1] = matrix[1] * scalar; + result[2] = matrix[2] * scalar; + result[3] = matrix[3] * scalar; + return result; +}; +Matrix2.multiplyByScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("scale", scale); + Check_default.typeOf.object("result", result); + result[0] = matrix[0] * scale.x; + result[1] = matrix[1] * scale.x; + result[2] = matrix[2] * scale.y; + result[3] = matrix[3] * scale.y; + return result; +}; +Matrix2.multiplyByUniformScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number("scale", scale); + Check_default.typeOf.object("result", result); + result[0] = matrix[0] * scale; + result[1] = matrix[1] * scale; + result[2] = matrix[2] * scale; + result[3] = matrix[3] * scale; + return result; +}; +Matrix2.negate = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result[0] = -matrix[0]; + result[1] = -matrix[1]; + result[2] = -matrix[2]; + result[3] = -matrix[3]; + return result; +}; +Matrix2.transpose = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const column0Row0 = matrix[0]; + const column0Row1 = matrix[2]; + const column1Row0 = matrix[1]; + const column1Row1 = matrix[3]; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column1Row0; + result[3] = column1Row1; + return result; +}; +Matrix2.abs = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result[0] = Math.abs(matrix[0]); + result[1] = Math.abs(matrix[1]); + result[2] = Math.abs(matrix[2]); + result[3] = Math.abs(matrix[3]); + return result; +}; +Matrix2.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left[0] === right[0] && left[1] === right[1] && left[2] === right[2] && left[3] === right[3]; +}; +Matrix2.equalsArray = function(matrix, array, offset) { + return matrix[0] === array[offset] && matrix[1] === array[offset + 1] && matrix[2] === array[offset + 2] && matrix[3] === array[offset + 3]; +}; +Matrix2.equalsEpsilon = function(left, right, epsilon) { + epsilon = defaultValue_default(epsilon, 0); + return left === right || defined_default(left) && defined_default(right) && Math.abs(left[0] - right[0]) <= epsilon && Math.abs(left[1] - right[1]) <= epsilon && Math.abs(left[2] - right[2]) <= epsilon && Math.abs(left[3] - right[3]) <= epsilon; +}; +Matrix2.IDENTITY = Object.freeze(new Matrix2(1, 0, 0, 1)); +Matrix2.ZERO = Object.freeze(new Matrix2(0, 0, 0, 0)); +Matrix2.COLUMN0ROW0 = 0; +Matrix2.COLUMN0ROW1 = 1; +Matrix2.COLUMN1ROW0 = 2; +Matrix2.COLUMN1ROW1 = 3; +Object.defineProperties(Matrix2.prototype, { + /** + * Gets the number of items in the collection. + * @memberof Matrix2.prototype + * + * @type {number} + */ + length: { + get: function() { + return Matrix2.packedLength; + } + } +}); +Matrix2.prototype.clone = function(result) { + return Matrix2.clone(this, result); +}; +Matrix2.prototype.equals = function(right) { + return Matrix2.equals(this, right); +}; +Matrix2.prototype.equalsEpsilon = function(right, epsilon) { + return Matrix2.equalsEpsilon(this, right, epsilon); +}; +Matrix2.prototype.toString = function() { + return `(${this[0]}, ${this[2]}) +(${this[1]}, ${this[3]})`; +}; +var Matrix2_default = Matrix2; + +export { + Cartesian4_default, + Matrix4_default, + Rectangle_default, + Cartesian2_default, + Matrix2_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-PWDYKCNC.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-PWDYKCNC.js new file mode 100644 index 0000000000000000000000000000000000000000..29acd6fc9e22d566bf926f154ccacc1b0c882bb8 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-PWDYKCNC.js @@ -0,0 +1,501 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + __commonJS, + __toESM, + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// node_modules/mersenne-twister/src/mersenne-twister.js +var require_mersenne_twister = __commonJS({ + "node_modules/mersenne-twister/src/mersenne-twister.js"(exports, module) { + var MersenneTwister2 = function(seed) { + if (seed == void 0) { + seed = (/* @__PURE__ */ new Date()).getTime(); + } + this.N = 624; + this.M = 397; + this.MATRIX_A = 2567483615; + this.UPPER_MASK = 2147483648; + this.LOWER_MASK = 2147483647; + this.mt = new Array(this.N); + this.mti = this.N + 1; + if (seed.constructor == Array) { + this.init_by_array(seed, seed.length); + } else { + this.init_seed(seed); + } + }; + MersenneTwister2.prototype.init_seed = function(s) { + this.mt[0] = s >>> 0; + for (this.mti = 1; this.mti < this.N; this.mti++) { + var s = this.mt[this.mti - 1] ^ this.mt[this.mti - 1] >>> 30; + this.mt[this.mti] = (((s & 4294901760) >>> 16) * 1812433253 << 16) + (s & 65535) * 1812433253 + this.mti; + this.mt[this.mti] >>>= 0; + } + }; + MersenneTwister2.prototype.init_by_array = function(init_key, key_length) { + var i, j, k; + this.init_seed(19650218); + i = 1; + j = 0; + k = this.N > key_length ? this.N : key_length; + for (; k; k--) { + var s = this.mt[i - 1] ^ this.mt[i - 1] >>> 30; + this.mt[i] = (this.mt[i] ^ (((s & 4294901760) >>> 16) * 1664525 << 16) + (s & 65535) * 1664525) + init_key[j] + j; + this.mt[i] >>>= 0; + i++; + j++; + if (i >= this.N) { + this.mt[0] = this.mt[this.N - 1]; + i = 1; + } + if (j >= key_length) + j = 0; + } + for (k = this.N - 1; k; k--) { + var s = this.mt[i - 1] ^ this.mt[i - 1] >>> 30; + this.mt[i] = (this.mt[i] ^ (((s & 4294901760) >>> 16) * 1566083941 << 16) + (s & 65535) * 1566083941) - i; + this.mt[i] >>>= 0; + i++; + if (i >= this.N) { + this.mt[0] = this.mt[this.N - 1]; + i = 1; + } + } + this.mt[0] = 2147483648; + }; + MersenneTwister2.prototype.random_int = function() { + var y; + var mag01 = new Array(0, this.MATRIX_A); + if (this.mti >= this.N) { + var kk; + if (this.mti == this.N + 1) + this.init_seed(5489); + for (kk = 0; kk < this.N - this.M; kk++) { + y = this.mt[kk] & this.UPPER_MASK | this.mt[kk + 1] & this.LOWER_MASK; + this.mt[kk] = this.mt[kk + this.M] ^ y >>> 1 ^ mag01[y & 1]; + } + for (; kk < this.N - 1; kk++) { + y = this.mt[kk] & this.UPPER_MASK | this.mt[kk + 1] & this.LOWER_MASK; + this.mt[kk] = this.mt[kk + (this.M - this.N)] ^ y >>> 1 ^ mag01[y & 1]; + } + y = this.mt[this.N - 1] & this.UPPER_MASK | this.mt[0] & this.LOWER_MASK; + this.mt[this.N - 1] = this.mt[this.M - 1] ^ y >>> 1 ^ mag01[y & 1]; + this.mti = 0; + } + y = this.mt[this.mti++]; + y ^= y >>> 11; + y ^= y << 7 & 2636928640; + y ^= y << 15 & 4022730752; + y ^= y >>> 18; + return y >>> 0; + }; + MersenneTwister2.prototype.random_int31 = function() { + return this.random_int() >>> 1; + }; + MersenneTwister2.prototype.random_incl = function() { + return this.random_int() * (1 / 4294967295); + }; + MersenneTwister2.prototype.random = function() { + return this.random_int() * (1 / 4294967296); + }; + MersenneTwister2.prototype.random_excl = function() { + return (this.random_int() + 0.5) * (1 / 4294967296); + }; + MersenneTwister2.prototype.random_long = function() { + var a = this.random_int() >>> 5, b = this.random_int() >>> 6; + return (a * 67108864 + b) * (1 / 9007199254740992); + }; + module.exports = MersenneTwister2; + } +}); + +// packages/engine/Source/Core/Math.js +var import_mersenne_twister = __toESM(require_mersenne_twister(), 1); +var CesiumMath = {}; +CesiumMath.EPSILON1 = 0.1; +CesiumMath.EPSILON2 = 0.01; +CesiumMath.EPSILON3 = 1e-3; +CesiumMath.EPSILON4 = 1e-4; +CesiumMath.EPSILON5 = 1e-5; +CesiumMath.EPSILON6 = 1e-6; +CesiumMath.EPSILON7 = 1e-7; +CesiumMath.EPSILON8 = 1e-8; +CesiumMath.EPSILON9 = 1e-9; +CesiumMath.EPSILON10 = 1e-10; +CesiumMath.EPSILON11 = 1e-11; +CesiumMath.EPSILON12 = 1e-12; +CesiumMath.EPSILON13 = 1e-13; +CesiumMath.EPSILON14 = 1e-14; +CesiumMath.EPSILON15 = 1e-15; +CesiumMath.EPSILON16 = 1e-16; +CesiumMath.EPSILON17 = 1e-17; +CesiumMath.EPSILON18 = 1e-18; +CesiumMath.EPSILON19 = 1e-19; +CesiumMath.EPSILON20 = 1e-20; +CesiumMath.EPSILON21 = 1e-21; +CesiumMath.GRAVITATIONALPARAMETER = 3986004418e5; +CesiumMath.SOLAR_RADIUS = 6955e5; +CesiumMath.LUNAR_RADIUS = 1737400; +CesiumMath.SIXTY_FOUR_KILOBYTES = 64 * 1024; +CesiumMath.FOUR_GIGABYTES = 4 * 1024 * 1024 * 1024; +CesiumMath.sign = defaultValue_default(Math.sign, function sign(value) { + value = +value; + if (value === 0 || value !== value) { + return value; + } + return value > 0 ? 1 : -1; +}); +CesiumMath.signNotZero = function(value) { + return value < 0 ? -1 : 1; +}; +CesiumMath.toSNorm = function(value, rangeMaximum) { + rangeMaximum = defaultValue_default(rangeMaximum, 255); + return Math.round( + (CesiumMath.clamp(value, -1, 1) * 0.5 + 0.5) * rangeMaximum + ); +}; +CesiumMath.fromSNorm = function(value, rangeMaximum) { + rangeMaximum = defaultValue_default(rangeMaximum, 255); + return CesiumMath.clamp(value, 0, rangeMaximum) / rangeMaximum * 2 - 1; +}; +CesiumMath.normalize = function(value, rangeMinimum, rangeMaximum) { + rangeMaximum = Math.max(rangeMaximum - rangeMinimum, 0); + return rangeMaximum === 0 ? 0 : CesiumMath.clamp((value - rangeMinimum) / rangeMaximum, 0, 1); +}; +CesiumMath.sinh = defaultValue_default(Math.sinh, function sinh(value) { + return (Math.exp(value) - Math.exp(-value)) / 2; +}); +CesiumMath.cosh = defaultValue_default(Math.cosh, function cosh(value) { + return (Math.exp(value) + Math.exp(-value)) / 2; +}); +CesiumMath.lerp = function(p, q, time) { + return (1 - time) * p + time * q; +}; +CesiumMath.PI = Math.PI; +CesiumMath.ONE_OVER_PI = 1 / Math.PI; +CesiumMath.PI_OVER_TWO = Math.PI / 2; +CesiumMath.PI_OVER_THREE = Math.PI / 3; +CesiumMath.PI_OVER_FOUR = Math.PI / 4; +CesiumMath.PI_OVER_SIX = Math.PI / 6; +CesiumMath.THREE_PI_OVER_TWO = 3 * Math.PI / 2; +CesiumMath.TWO_PI = 2 * Math.PI; +CesiumMath.ONE_OVER_TWO_PI = 1 / (2 * Math.PI); +CesiumMath.RADIANS_PER_DEGREE = Math.PI / 180; +CesiumMath.DEGREES_PER_RADIAN = 180 / Math.PI; +CesiumMath.RADIANS_PER_ARCSECOND = CesiumMath.RADIANS_PER_DEGREE / 3600; +CesiumMath.toRadians = function(degrees) { + if (!defined_default(degrees)) { + throw new DeveloperError_default("degrees is required."); + } + return degrees * CesiumMath.RADIANS_PER_DEGREE; +}; +CesiumMath.toDegrees = function(radians) { + if (!defined_default(radians)) { + throw new DeveloperError_default("radians is required."); + } + return radians * CesiumMath.DEGREES_PER_RADIAN; +}; +CesiumMath.convertLongitudeRange = function(angle) { + if (!defined_default(angle)) { + throw new DeveloperError_default("angle is required."); + } + const twoPi = CesiumMath.TWO_PI; + const simplified = angle - Math.floor(angle / twoPi) * twoPi; + if (simplified < -Math.PI) { + return simplified + twoPi; + } + if (simplified >= Math.PI) { + return simplified - twoPi; + } + return simplified; +}; +CesiumMath.clampToLatitudeRange = function(angle) { + if (!defined_default(angle)) { + throw new DeveloperError_default("angle is required."); + } + return CesiumMath.clamp( + angle, + -1 * CesiumMath.PI_OVER_TWO, + CesiumMath.PI_OVER_TWO + ); +}; +CesiumMath.negativePiToPi = function(angle) { + if (!defined_default(angle)) { + throw new DeveloperError_default("angle is required."); + } + if (angle >= -CesiumMath.PI && angle <= CesiumMath.PI) { + return angle; + } + return CesiumMath.zeroToTwoPi(angle + CesiumMath.PI) - CesiumMath.PI; +}; +CesiumMath.zeroToTwoPi = function(angle) { + if (!defined_default(angle)) { + throw new DeveloperError_default("angle is required."); + } + if (angle >= 0 && angle <= CesiumMath.TWO_PI) { + return angle; + } + const mod = CesiumMath.mod(angle, CesiumMath.TWO_PI); + if (Math.abs(mod) < CesiumMath.EPSILON14 && Math.abs(angle) > CesiumMath.EPSILON14) { + return CesiumMath.TWO_PI; + } + return mod; +}; +CesiumMath.mod = function(m, n) { + if (!defined_default(m)) { + throw new DeveloperError_default("m is required."); + } + if (!defined_default(n)) { + throw new DeveloperError_default("n is required."); + } + if (n === 0) { + throw new DeveloperError_default("divisor cannot be 0."); + } + if (CesiumMath.sign(m) === CesiumMath.sign(n) && Math.abs(m) < Math.abs(n)) { + return m; + } + return (m % n + n) % n; +}; +CesiumMath.equalsEpsilon = function(left, right, relativeEpsilon, absoluteEpsilon) { + if (!defined_default(left)) { + throw new DeveloperError_default("left is required."); + } + if (!defined_default(right)) { + throw new DeveloperError_default("right is required."); + } + relativeEpsilon = defaultValue_default(relativeEpsilon, 0); + absoluteEpsilon = defaultValue_default(absoluteEpsilon, relativeEpsilon); + const absDiff = Math.abs(left - right); + return absDiff <= absoluteEpsilon || absDiff <= relativeEpsilon * Math.max(Math.abs(left), Math.abs(right)); +}; +CesiumMath.lessThan = function(left, right, absoluteEpsilon) { + if (!defined_default(left)) { + throw new DeveloperError_default("first is required."); + } + if (!defined_default(right)) { + throw new DeveloperError_default("second is required."); + } + if (!defined_default(absoluteEpsilon)) { + throw new DeveloperError_default("absoluteEpsilon is required."); + } + return left - right < -absoluteEpsilon; +}; +CesiumMath.lessThanOrEquals = function(left, right, absoluteEpsilon) { + if (!defined_default(left)) { + throw new DeveloperError_default("first is required."); + } + if (!defined_default(right)) { + throw new DeveloperError_default("second is required."); + } + if (!defined_default(absoluteEpsilon)) { + throw new DeveloperError_default("absoluteEpsilon is required."); + } + return left - right < absoluteEpsilon; +}; +CesiumMath.greaterThan = function(left, right, absoluteEpsilon) { + if (!defined_default(left)) { + throw new DeveloperError_default("first is required."); + } + if (!defined_default(right)) { + throw new DeveloperError_default("second is required."); + } + if (!defined_default(absoluteEpsilon)) { + throw new DeveloperError_default("absoluteEpsilon is required."); + } + return left - right > absoluteEpsilon; +}; +CesiumMath.greaterThanOrEquals = function(left, right, absoluteEpsilon) { + if (!defined_default(left)) { + throw new DeveloperError_default("first is required."); + } + if (!defined_default(right)) { + throw new DeveloperError_default("second is required."); + } + if (!defined_default(absoluteEpsilon)) { + throw new DeveloperError_default("absoluteEpsilon is required."); + } + return left - right > -absoluteEpsilon; +}; +var factorials = [1]; +CesiumMath.factorial = function(n) { + if (typeof n !== "number" || n < 0) { + throw new DeveloperError_default( + "A number greater than or equal to 0 is required." + ); + } + const length = factorials.length; + if (n >= length) { + let sum = factorials[length - 1]; + for (let i = length; i <= n; i++) { + const next = sum * i; + factorials.push(next); + sum = next; + } + } + return factorials[n]; +}; +CesiumMath.incrementWrap = function(n, maximumValue, minimumValue) { + minimumValue = defaultValue_default(minimumValue, 0); + if (!defined_default(n)) { + throw new DeveloperError_default("n is required."); + } + if (maximumValue <= minimumValue) { + throw new DeveloperError_default("maximumValue must be greater than minimumValue."); + } + ++n; + if (n > maximumValue) { + n = minimumValue; + } + return n; +}; +CesiumMath.isPowerOfTwo = function(n) { + if (typeof n !== "number" || n < 0 || n > 4294967295) { + throw new DeveloperError_default("A number between 0 and (2^32)-1 is required."); + } + return n !== 0 && (n & n - 1) === 0; +}; +CesiumMath.nextPowerOfTwo = function(n) { + if (typeof n !== "number" || n < 0 || n > 2147483648) { + throw new DeveloperError_default("A number between 0 and 2^31 is required."); + } + --n; + n |= n >> 1; + n |= n >> 2; + n |= n >> 4; + n |= n >> 8; + n |= n >> 16; + ++n; + return n; +}; +CesiumMath.previousPowerOfTwo = function(n) { + if (typeof n !== "number" || n < 0 || n > 4294967295) { + throw new DeveloperError_default("A number between 0 and (2^32)-1 is required."); + } + n |= n >> 1; + n |= n >> 2; + n |= n >> 4; + n |= n >> 8; + n |= n >> 16; + n |= n >> 32; + n = (n >>> 0) - (n >>> 1); + return n; +}; +CesiumMath.clamp = function(value, min, max) { + Check_default.typeOf.number("value", value); + Check_default.typeOf.number("min", min); + Check_default.typeOf.number("max", max); + return value < min ? min : value > max ? max : value; +}; +var randomNumberGenerator = new import_mersenne_twister.default(); +CesiumMath.setRandomNumberSeed = function(seed) { + if (!defined_default(seed)) { + throw new DeveloperError_default("seed is required."); + } + randomNumberGenerator = new import_mersenne_twister.default(seed); +}; +CesiumMath.nextRandomNumber = function() { + return randomNumberGenerator.random(); +}; +CesiumMath.randomBetween = function(min, max) { + return CesiumMath.nextRandomNumber() * (max - min) + min; +}; +CesiumMath.acosClamped = function(value) { + if (!defined_default(value)) { + throw new DeveloperError_default("value is required."); + } + return Math.acos(CesiumMath.clamp(value, -1, 1)); +}; +CesiumMath.asinClamped = function(value) { + if (!defined_default(value)) { + throw new DeveloperError_default("value is required."); + } + return Math.asin(CesiumMath.clamp(value, -1, 1)); +}; +CesiumMath.chordLength = function(angle, radius) { + if (!defined_default(angle)) { + throw new DeveloperError_default("angle is required."); + } + if (!defined_default(radius)) { + throw new DeveloperError_default("radius is required."); + } + return 2 * radius * Math.sin(angle * 0.5); +}; +CesiumMath.logBase = function(number, base) { + if (!defined_default(number)) { + throw new DeveloperError_default("number is required."); + } + if (!defined_default(base)) { + throw new DeveloperError_default("base is required."); + } + return Math.log(number) / Math.log(base); +}; +CesiumMath.cbrt = defaultValue_default(Math.cbrt, function cbrt(number) { + const result = Math.pow(Math.abs(number), 1 / 3); + return number < 0 ? -result : result; +}); +CesiumMath.log2 = defaultValue_default(Math.log2, function log2(number) { + return Math.log(number) * Math.LOG2E; +}); +CesiumMath.fog = function(distanceToCamera, density) { + const scalar = distanceToCamera * density; + return 1 - Math.exp(-(scalar * scalar)); +}; +CesiumMath.fastApproximateAtan = function(x) { + Check_default.typeOf.number("x", x); + return x * (-0.1784 * Math.abs(x) - 0.0663 * x * x + 1.0301); +}; +CesiumMath.fastApproximateAtan2 = function(x, y) { + Check_default.typeOf.number("x", x); + Check_default.typeOf.number("y", y); + let opposite; + let t = Math.abs(x); + opposite = Math.abs(y); + const adjacent = Math.max(t, opposite); + opposite = Math.min(t, opposite); + const oppositeOverAdjacent = opposite / adjacent; + if (isNaN(oppositeOverAdjacent)) { + throw new DeveloperError_default("either x or y must be nonzero"); + } + t = CesiumMath.fastApproximateAtan(oppositeOverAdjacent); + t = Math.abs(y) > Math.abs(x) ? CesiumMath.PI_OVER_TWO - t : t; + t = x < 0 ? CesiumMath.PI - t : t; + t = y < 0 ? -t : t; + return t; +}; +var Math_default = CesiumMath; + +export { + Math_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-QIS3NB7U.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-QIS3NB7U.js new file mode 100644 index 0000000000000000000000000000000000000000..c45ce7037c7e2008744a04fd6729541b537cf04c --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-QIS3NB7U.js @@ -0,0 +1,1258 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Interval_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian3_default, + Cartographic_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/QuadraticRealPolynomial.js +var QuadraticRealPolynomial = {}; +QuadraticRealPolynomial.computeDiscriminant = function(a, b, c) { + if (typeof a !== "number") { + throw new DeveloperError_default("a is a required number."); + } + if (typeof b !== "number") { + throw new DeveloperError_default("b is a required number."); + } + if (typeof c !== "number") { + throw new DeveloperError_default("c is a required number."); + } + const discriminant = b * b - 4 * a * c; + return discriminant; +}; +function addWithCancellationCheck(left, right, tolerance) { + const difference = left + right; + if (Math_default.sign(left) !== Math_default.sign(right) && Math.abs(difference / Math.max(Math.abs(left), Math.abs(right))) < tolerance) { + return 0; + } + return difference; +} +QuadraticRealPolynomial.computeRealRoots = function(a, b, c) { + if (typeof a !== "number") { + throw new DeveloperError_default("a is a required number."); + } + if (typeof b !== "number") { + throw new DeveloperError_default("b is a required number."); + } + if (typeof c !== "number") { + throw new DeveloperError_default("c is a required number."); + } + let ratio; + if (a === 0) { + if (b === 0) { + return []; + } + return [-c / b]; + } else if (b === 0) { + if (c === 0) { + return [0, 0]; + } + const cMagnitude = Math.abs(c); + const aMagnitude = Math.abs(a); + if (cMagnitude < aMagnitude && cMagnitude / aMagnitude < Math_default.EPSILON14) { + return [0, 0]; + } else if (cMagnitude > aMagnitude && aMagnitude / cMagnitude < Math_default.EPSILON14) { + return []; + } + ratio = -c / a; + if (ratio < 0) { + return []; + } + const root = Math.sqrt(ratio); + return [-root, root]; + } else if (c === 0) { + ratio = -b / a; + if (ratio < 0) { + return [ratio, 0]; + } + return [0, ratio]; + } + const b2 = b * b; + const four_ac = 4 * a * c; + const radicand = addWithCancellationCheck(b2, -four_ac, Math_default.EPSILON14); + if (radicand < 0) { + return []; + } + const q = -0.5 * addWithCancellationCheck( + b, + Math_default.sign(b) * Math.sqrt(radicand), + Math_default.EPSILON14 + ); + if (b > 0) { + return [q / a, c / q]; + } + return [c / q, q / a]; +}; +var QuadraticRealPolynomial_default = QuadraticRealPolynomial; + +// packages/engine/Source/Core/CubicRealPolynomial.js +var CubicRealPolynomial = {}; +CubicRealPolynomial.computeDiscriminant = function(a, b, c, d) { + if (typeof a !== "number") { + throw new DeveloperError_default("a is a required number."); + } + if (typeof b !== "number") { + throw new DeveloperError_default("b is a required number."); + } + if (typeof c !== "number") { + throw new DeveloperError_default("c is a required number."); + } + if (typeof d !== "number") { + throw new DeveloperError_default("d is a required number."); + } + const a2 = a * a; + const b2 = b * b; + const c2 = c * c; + const d2 = d * d; + const discriminant = 18 * a * b * c * d + b2 * c2 - 27 * a2 * d2 - 4 * (a * c2 * c + b2 * b * d); + return discriminant; +}; +function computeRealRoots(a, b, c, d) { + const A = a; + const B = b / 3; + const C = c / 3; + const D = d; + const AC = A * C; + const BD = B * D; + const B2 = B * B; + const C2 = C * C; + const delta1 = A * C - B2; + const delta2 = A * D - B * C; + const delta3 = B * D - C2; + const discriminant = 4 * delta1 * delta3 - delta2 * delta2; + let temp; + let temp1; + if (discriminant < 0) { + let ABar; + let CBar; + let DBar; + if (B2 * BD >= AC * C2) { + ABar = A; + CBar = delta1; + DBar = -2 * B * delta1 + A * delta2; + } else { + ABar = D; + CBar = delta3; + DBar = -D * delta2 + 2 * C * delta3; + } + const s = DBar < 0 ? -1 : 1; + const temp0 = -s * Math.abs(ABar) * Math.sqrt(-discriminant); + temp1 = -DBar + temp0; + const x = temp1 / 2; + const p = x < 0 ? -Math.pow(-x, 1 / 3) : Math.pow(x, 1 / 3); + const q = temp1 === temp0 ? -p : -CBar / p; + temp = CBar <= 0 ? p + q : -DBar / (p * p + q * q + CBar); + if (B2 * BD >= AC * C2) { + return [(temp - B) / A]; + } + return [-D / (temp + C)]; + } + const CBarA = delta1; + const DBarA = -2 * B * delta1 + A * delta2; + const CBarD = delta3; + const DBarD = -D * delta2 + 2 * C * delta3; + const squareRootOfDiscriminant = Math.sqrt(discriminant); + const halfSquareRootOf3 = Math.sqrt(3) / 2; + let theta = Math.abs(Math.atan2(A * squareRootOfDiscriminant, -DBarA) / 3); + temp = 2 * Math.sqrt(-CBarA); + let cosine = Math.cos(theta); + temp1 = temp * cosine; + let temp3 = temp * (-cosine / 2 - halfSquareRootOf3 * Math.sin(theta)); + const numeratorLarge = temp1 + temp3 > 2 * B ? temp1 - B : temp3 - B; + const denominatorLarge = A; + const root1 = numeratorLarge / denominatorLarge; + theta = Math.abs(Math.atan2(D * squareRootOfDiscriminant, -DBarD) / 3); + temp = 2 * Math.sqrt(-CBarD); + cosine = Math.cos(theta); + temp1 = temp * cosine; + temp3 = temp * (-cosine / 2 - halfSquareRootOf3 * Math.sin(theta)); + const numeratorSmall = -D; + const denominatorSmall = temp1 + temp3 < 2 * C ? temp1 + C : temp3 + C; + const root3 = numeratorSmall / denominatorSmall; + const E = denominatorLarge * denominatorSmall; + const F = -numeratorLarge * denominatorSmall - denominatorLarge * numeratorSmall; + const G = numeratorLarge * numeratorSmall; + const root2 = (C * F - B * G) / (-B * F + C * E); + if (root1 <= root2) { + if (root1 <= root3) { + if (root2 <= root3) { + return [root1, root2, root3]; + } + return [root1, root3, root2]; + } + return [root3, root1, root2]; + } + if (root1 <= root3) { + return [root2, root1, root3]; + } + if (root2 <= root3) { + return [root2, root3, root1]; + } + return [root3, root2, root1]; +} +CubicRealPolynomial.computeRealRoots = function(a, b, c, d) { + if (typeof a !== "number") { + throw new DeveloperError_default("a is a required number."); + } + if (typeof b !== "number") { + throw new DeveloperError_default("b is a required number."); + } + if (typeof c !== "number") { + throw new DeveloperError_default("c is a required number."); + } + if (typeof d !== "number") { + throw new DeveloperError_default("d is a required number."); + } + let roots; + let ratio; + if (a === 0) { + return QuadraticRealPolynomial_default.computeRealRoots(b, c, d); + } else if (b === 0) { + if (c === 0) { + if (d === 0) { + return [0, 0, 0]; + } + ratio = -d / a; + const root = ratio < 0 ? -Math.pow(-ratio, 1 / 3) : Math.pow(ratio, 1 / 3); + return [root, root, root]; + } else if (d === 0) { + roots = QuadraticRealPolynomial_default.computeRealRoots(a, 0, c); + if (roots.Length === 0) { + return [0]; + } + return [roots[0], 0, roots[1]]; + } + return computeRealRoots(a, 0, c, d); + } else if (c === 0) { + if (d === 0) { + ratio = -b / a; + if (ratio < 0) { + return [ratio, 0, 0]; + } + return [0, 0, ratio]; + } + return computeRealRoots(a, b, 0, d); + } else if (d === 0) { + roots = QuadraticRealPolynomial_default.computeRealRoots(a, b, c); + if (roots.length === 0) { + return [0]; + } else if (roots[1] <= 0) { + return [roots[0], roots[1], 0]; + } else if (roots[0] >= 0) { + return [0, roots[0], roots[1]]; + } + return [roots[0], 0, roots[1]]; + } + return computeRealRoots(a, b, c, d); +}; +var CubicRealPolynomial_default = CubicRealPolynomial; + +// packages/engine/Source/Core/QuarticRealPolynomial.js +var QuarticRealPolynomial = {}; +QuarticRealPolynomial.computeDiscriminant = function(a, b, c, d, e) { + if (typeof a !== "number") { + throw new DeveloperError_default("a is a required number."); + } + if (typeof b !== "number") { + throw new DeveloperError_default("b is a required number."); + } + if (typeof c !== "number") { + throw new DeveloperError_default("c is a required number."); + } + if (typeof d !== "number") { + throw new DeveloperError_default("d is a required number."); + } + if (typeof e !== "number") { + throw new DeveloperError_default("e is a required number."); + } + const a2 = a * a; + const a3 = a2 * a; + const b2 = b * b; + const b3 = b2 * b; + const c2 = c * c; + const c3 = c2 * c; + const d2 = d * d; + const d3 = d2 * d; + const e2 = e * e; + const e3 = e2 * e; + const discriminant = b2 * c2 * d2 - 4 * b3 * d3 - 4 * a * c3 * d2 + 18 * a * b * c * d3 - 27 * a2 * d2 * d2 + 256 * a3 * e3 + e * (18 * b3 * c * d - 4 * b2 * c3 + 16 * a * c2 * c2 - 80 * a * b * c2 * d - 6 * a * b2 * d2 + 144 * a2 * c * d2) + e2 * (144 * a * b2 * c - 27 * b2 * b2 - 128 * a2 * c2 - 192 * a2 * b * d); + return discriminant; +}; +function original(a3, a2, a1, a0) { + const a3Squared = a3 * a3; + const p = a2 - 3 * a3Squared / 8; + const q = a1 - a2 * a3 / 2 + a3Squared * a3 / 8; + const r = a0 - a1 * a3 / 4 + a2 * a3Squared / 16 - 3 * a3Squared * a3Squared / 256; + const cubicRoots = CubicRealPolynomial_default.computeRealRoots( + 1, + 2 * p, + p * p - 4 * r, + -q * q + ); + if (cubicRoots.length > 0) { + const temp = -a3 / 4; + const hSquared = cubicRoots[cubicRoots.length - 1]; + if (Math.abs(hSquared) < Math_default.EPSILON14) { + const roots = QuadraticRealPolynomial_default.computeRealRoots(1, p, r); + if (roots.length === 2) { + const root0 = roots[0]; + const root1 = roots[1]; + let y; + if (root0 >= 0 && root1 >= 0) { + const y0 = Math.sqrt(root0); + const y1 = Math.sqrt(root1); + return [temp - y1, temp - y0, temp + y0, temp + y1]; + } else if (root0 >= 0 && root1 < 0) { + y = Math.sqrt(root0); + return [temp - y, temp + y]; + } else if (root0 < 0 && root1 >= 0) { + y = Math.sqrt(root1); + return [temp - y, temp + y]; + } + } + return []; + } else if (hSquared > 0) { + const h = Math.sqrt(hSquared); + const m = (p + hSquared - q / h) / 2; + const n = (p + hSquared + q / h) / 2; + const roots1 = QuadraticRealPolynomial_default.computeRealRoots(1, h, m); + const roots2 = QuadraticRealPolynomial_default.computeRealRoots(1, -h, n); + if (roots1.length !== 0) { + roots1[0] += temp; + roots1[1] += temp; + if (roots2.length !== 0) { + roots2[0] += temp; + roots2[1] += temp; + if (roots1[1] <= roots2[0]) { + return [roots1[0], roots1[1], roots2[0], roots2[1]]; + } else if (roots2[1] <= roots1[0]) { + return [roots2[0], roots2[1], roots1[0], roots1[1]]; + } else if (roots1[0] >= roots2[0] && roots1[1] <= roots2[1]) { + return [roots2[0], roots1[0], roots1[1], roots2[1]]; + } else if (roots2[0] >= roots1[0] && roots2[1] <= roots1[1]) { + return [roots1[0], roots2[0], roots2[1], roots1[1]]; + } else if (roots1[0] > roots2[0] && roots1[0] < roots2[1]) { + return [roots2[0], roots1[0], roots2[1], roots1[1]]; + } + return [roots1[0], roots2[0], roots1[1], roots2[1]]; + } + return roots1; + } + if (roots2.length !== 0) { + roots2[0] += temp; + roots2[1] += temp; + return roots2; + } + return []; + } + } + return []; +} +function neumark(a3, a2, a1, a0) { + const a1Squared = a1 * a1; + const a2Squared = a2 * a2; + const a3Squared = a3 * a3; + const p = -2 * a2; + const q = a1 * a3 + a2Squared - 4 * a0; + const r = a3Squared * a0 - a1 * a2 * a3 + a1Squared; + const cubicRoots = CubicRealPolynomial_default.computeRealRoots(1, p, q, r); + if (cubicRoots.length > 0) { + const y = cubicRoots[0]; + const temp = a2 - y; + const tempSquared = temp * temp; + const g1 = a3 / 2; + const h1 = temp / 2; + const m = tempSquared - 4 * a0; + const mError = tempSquared + 4 * Math.abs(a0); + const n = a3Squared - 4 * y; + const nError = a3Squared + 4 * Math.abs(y); + let g2; + let h2; + if (y < 0 || m * nError < n * mError) { + const squareRootOfN = Math.sqrt(n); + g2 = squareRootOfN / 2; + h2 = squareRootOfN === 0 ? 0 : (a3 * h1 - a1) / squareRootOfN; + } else { + const squareRootOfM = Math.sqrt(m); + g2 = squareRootOfM === 0 ? 0 : (a3 * h1 - a1) / squareRootOfM; + h2 = squareRootOfM / 2; + } + let G; + let g; + if (g1 === 0 && g2 === 0) { + G = 0; + g = 0; + } else if (Math_default.sign(g1) === Math_default.sign(g2)) { + G = g1 + g2; + g = y / G; + } else { + g = g1 - g2; + G = y / g; + } + let H; + let h; + if (h1 === 0 && h2 === 0) { + H = 0; + h = 0; + } else if (Math_default.sign(h1) === Math_default.sign(h2)) { + H = h1 + h2; + h = a0 / H; + } else { + h = h1 - h2; + H = a0 / h; + } + const roots1 = QuadraticRealPolynomial_default.computeRealRoots(1, G, H); + const roots2 = QuadraticRealPolynomial_default.computeRealRoots(1, g, h); + if (roots1.length !== 0) { + if (roots2.length !== 0) { + if (roots1[1] <= roots2[0]) { + return [roots1[0], roots1[1], roots2[0], roots2[1]]; + } else if (roots2[1] <= roots1[0]) { + return [roots2[0], roots2[1], roots1[0], roots1[1]]; + } else if (roots1[0] >= roots2[0] && roots1[1] <= roots2[1]) { + return [roots2[0], roots1[0], roots1[1], roots2[1]]; + } else if (roots2[0] >= roots1[0] && roots2[1] <= roots1[1]) { + return [roots1[0], roots2[0], roots2[1], roots1[1]]; + } else if (roots1[0] > roots2[0] && roots1[0] < roots2[1]) { + return [roots2[0], roots1[0], roots2[1], roots1[1]]; + } + return [roots1[0], roots2[0], roots1[1], roots2[1]]; + } + return roots1; + } + if (roots2.length !== 0) { + return roots2; + } + } + return []; +} +QuarticRealPolynomial.computeRealRoots = function(a, b, c, d, e) { + if (typeof a !== "number") { + throw new DeveloperError_default("a is a required number."); + } + if (typeof b !== "number") { + throw new DeveloperError_default("b is a required number."); + } + if (typeof c !== "number") { + throw new DeveloperError_default("c is a required number."); + } + if (typeof d !== "number") { + throw new DeveloperError_default("d is a required number."); + } + if (typeof e !== "number") { + throw new DeveloperError_default("e is a required number."); + } + if (Math.abs(a) < Math_default.EPSILON15) { + return CubicRealPolynomial_default.computeRealRoots(b, c, d, e); + } + const a3 = b / a; + const a2 = c / a; + const a1 = d / a; + const a0 = e / a; + let k = a3 < 0 ? 1 : 0; + k += a2 < 0 ? k + 1 : k; + k += a1 < 0 ? k + 1 : k; + k += a0 < 0 ? k + 1 : k; + switch (k) { + case 0: + return original(a3, a2, a1, a0); + case 1: + return neumark(a3, a2, a1, a0); + case 2: + return neumark(a3, a2, a1, a0); + case 3: + return original(a3, a2, a1, a0); + case 4: + return original(a3, a2, a1, a0); + case 5: + return neumark(a3, a2, a1, a0); + case 6: + return original(a3, a2, a1, a0); + case 7: + return original(a3, a2, a1, a0); + case 8: + return neumark(a3, a2, a1, a0); + case 9: + return original(a3, a2, a1, a0); + case 10: + return original(a3, a2, a1, a0); + case 11: + return neumark(a3, a2, a1, a0); + case 12: + return original(a3, a2, a1, a0); + case 13: + return original(a3, a2, a1, a0); + case 14: + return original(a3, a2, a1, a0); + case 15: + return original(a3, a2, a1, a0); + default: + return void 0; + } +}; +var QuarticRealPolynomial_default = QuarticRealPolynomial; + +// packages/engine/Source/Core/Ray.js +function Ray(origin, direction) { + direction = Cartesian3_default.clone(defaultValue_default(direction, Cartesian3_default.ZERO)); + if (!Cartesian3_default.equals(direction, Cartesian3_default.ZERO)) { + Cartesian3_default.normalize(direction, direction); + } + this.origin = Cartesian3_default.clone(defaultValue_default(origin, Cartesian3_default.ZERO)); + this.direction = direction; +} +Ray.clone = function(ray, result) { + if (!defined_default(ray)) { + return void 0; + } + if (!defined_default(result)) { + return new Ray(ray.origin, ray.direction); + } + result.origin = Cartesian3_default.clone(ray.origin); + result.direction = Cartesian3_default.clone(ray.direction); + return result; +}; +Ray.getPoint = function(ray, t, result) { + Check_default.typeOf.object("ray", ray); + Check_default.typeOf.number("t", t); + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + result = Cartesian3_default.multiplyByScalar(ray.direction, t, result); + return Cartesian3_default.add(ray.origin, result, result); +}; +var Ray_default = Ray; + +// packages/engine/Source/Core/IntersectionTests.js +var IntersectionTests = {}; +IntersectionTests.rayPlane = function(ray, plane, result) { + if (!defined_default(ray)) { + throw new DeveloperError_default("ray is required."); + } + if (!defined_default(plane)) { + throw new DeveloperError_default("plane is required."); + } + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + const origin = ray.origin; + const direction = ray.direction; + const normal = plane.normal; + const denominator = Cartesian3_default.dot(normal, direction); + if (Math.abs(denominator) < Math_default.EPSILON15) { + return void 0; + } + const t = (-plane.distance - Cartesian3_default.dot(normal, origin)) / denominator; + if (t < 0) { + return void 0; + } + result = Cartesian3_default.multiplyByScalar(direction, t, result); + return Cartesian3_default.add(origin, result, result); +}; +var scratchEdge0 = new Cartesian3_default(); +var scratchEdge1 = new Cartesian3_default(); +var scratchPVec = new Cartesian3_default(); +var scratchTVec = new Cartesian3_default(); +var scratchQVec = new Cartesian3_default(); +IntersectionTests.rayTriangleParametric = function(ray, p0, p1, p2, cullBackFaces) { + if (!defined_default(ray)) { + throw new DeveloperError_default("ray is required."); + } + if (!defined_default(p0)) { + throw new DeveloperError_default("p0 is required."); + } + if (!defined_default(p1)) { + throw new DeveloperError_default("p1 is required."); + } + if (!defined_default(p2)) { + throw new DeveloperError_default("p2 is required."); + } + cullBackFaces = defaultValue_default(cullBackFaces, false); + const origin = ray.origin; + const direction = ray.direction; + const edge0 = Cartesian3_default.subtract(p1, p0, scratchEdge0); + const edge1 = Cartesian3_default.subtract(p2, p0, scratchEdge1); + const p = Cartesian3_default.cross(direction, edge1, scratchPVec); + const det = Cartesian3_default.dot(edge0, p); + let tvec; + let q; + let u; + let v; + let t; + if (cullBackFaces) { + if (det < Math_default.EPSILON6) { + return void 0; + } + tvec = Cartesian3_default.subtract(origin, p0, scratchTVec); + u = Cartesian3_default.dot(tvec, p); + if (u < 0 || u > det) { + return void 0; + } + q = Cartesian3_default.cross(tvec, edge0, scratchQVec); + v = Cartesian3_default.dot(direction, q); + if (v < 0 || u + v > det) { + return void 0; + } + t = Cartesian3_default.dot(edge1, q) / det; + } else { + if (Math.abs(det) < Math_default.EPSILON6) { + return void 0; + } + const invDet = 1 / det; + tvec = Cartesian3_default.subtract(origin, p0, scratchTVec); + u = Cartesian3_default.dot(tvec, p) * invDet; + if (u < 0 || u > 1) { + return void 0; + } + q = Cartesian3_default.cross(tvec, edge0, scratchQVec); + v = Cartesian3_default.dot(direction, q) * invDet; + if (v < 0 || u + v > 1) { + return void 0; + } + t = Cartesian3_default.dot(edge1, q) * invDet; + } + return t; +}; +IntersectionTests.rayTriangle = function(ray, p0, p1, p2, cullBackFaces, result) { + const t = IntersectionTests.rayTriangleParametric( + ray, + p0, + p1, + p2, + cullBackFaces + ); + if (!defined_default(t) || t < 0) { + return void 0; + } + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + Cartesian3_default.multiplyByScalar(ray.direction, t, result); + return Cartesian3_default.add(ray.origin, result, result); +}; +var scratchLineSegmentTriangleRay = new Ray_default(); +IntersectionTests.lineSegmentTriangle = function(v0, v1, p0, p1, p2, cullBackFaces, result) { + if (!defined_default(v0)) { + throw new DeveloperError_default("v0 is required."); + } + if (!defined_default(v1)) { + throw new DeveloperError_default("v1 is required."); + } + if (!defined_default(p0)) { + throw new DeveloperError_default("p0 is required."); + } + if (!defined_default(p1)) { + throw new DeveloperError_default("p1 is required."); + } + if (!defined_default(p2)) { + throw new DeveloperError_default("p2 is required."); + } + const ray = scratchLineSegmentTriangleRay; + Cartesian3_default.clone(v0, ray.origin); + Cartesian3_default.subtract(v1, v0, ray.direction); + Cartesian3_default.normalize(ray.direction, ray.direction); + const t = IntersectionTests.rayTriangleParametric( + ray, + p0, + p1, + p2, + cullBackFaces + ); + if (!defined_default(t) || t < 0 || t > Cartesian3_default.distance(v0, v1)) { + return void 0; + } + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + Cartesian3_default.multiplyByScalar(ray.direction, t, result); + return Cartesian3_default.add(ray.origin, result, result); +}; +function solveQuadratic(a, b, c, result) { + const det = b * b - 4 * a * c; + if (det < 0) { + return void 0; + } else if (det > 0) { + const denom = 1 / (2 * a); + const disc = Math.sqrt(det); + const root0 = (-b + disc) * denom; + const root1 = (-b - disc) * denom; + if (root0 < root1) { + result.root0 = root0; + result.root1 = root1; + } else { + result.root0 = root1; + result.root1 = root0; + } + return result; + } + const root = -b / (2 * a); + if (root === 0) { + return void 0; + } + result.root0 = result.root1 = root; + return result; +} +var raySphereRoots = { + root0: 0, + root1: 0 +}; +function raySphere(ray, sphere, result) { + if (!defined_default(result)) { + result = new Interval_default(); + } + const origin = ray.origin; + const direction = ray.direction; + const center = sphere.center; + const radiusSquared = sphere.radius * sphere.radius; + const diff = Cartesian3_default.subtract(origin, center, scratchPVec); + const a = Cartesian3_default.dot(direction, direction); + const b = 2 * Cartesian3_default.dot(direction, diff); + const c = Cartesian3_default.magnitudeSquared(diff) - radiusSquared; + const roots = solveQuadratic(a, b, c, raySphereRoots); + if (!defined_default(roots)) { + return void 0; + } + result.start = roots.root0; + result.stop = roots.root1; + return result; +} +IntersectionTests.raySphere = function(ray, sphere, result) { + if (!defined_default(ray)) { + throw new DeveloperError_default("ray is required."); + } + if (!defined_default(sphere)) { + throw new DeveloperError_default("sphere is required."); + } + result = raySphere(ray, sphere, result); + if (!defined_default(result) || result.stop < 0) { + return void 0; + } + result.start = Math.max(result.start, 0); + return result; +}; +var scratchLineSegmentRay = new Ray_default(); +IntersectionTests.lineSegmentSphere = function(p0, p1, sphere, result) { + if (!defined_default(p0)) { + throw new DeveloperError_default("p0 is required."); + } + if (!defined_default(p1)) { + throw new DeveloperError_default("p1 is required."); + } + if (!defined_default(sphere)) { + throw new DeveloperError_default("sphere is required."); + } + const ray = scratchLineSegmentRay; + Cartesian3_default.clone(p0, ray.origin); + const direction = Cartesian3_default.subtract(p1, p0, ray.direction); + const maxT = Cartesian3_default.magnitude(direction); + Cartesian3_default.normalize(direction, direction); + result = raySphere(ray, sphere, result); + if (!defined_default(result) || result.stop < 0 || result.start > maxT) { + return void 0; + } + result.start = Math.max(result.start, 0); + result.stop = Math.min(result.stop, maxT); + return result; +}; +var scratchQ = new Cartesian3_default(); +var scratchW = new Cartesian3_default(); +IntersectionTests.rayEllipsoid = function(ray, ellipsoid) { + if (!defined_default(ray)) { + throw new DeveloperError_default("ray is required."); + } + if (!defined_default(ellipsoid)) { + throw new DeveloperError_default("ellipsoid is required."); + } + const inverseRadii = ellipsoid.oneOverRadii; + const q = Cartesian3_default.multiplyComponents(inverseRadii, ray.origin, scratchQ); + const w = Cartesian3_default.multiplyComponents( + inverseRadii, + ray.direction, + scratchW + ); + const q2 = Cartesian3_default.magnitudeSquared(q); + const qw = Cartesian3_default.dot(q, w); + let difference, w2, product, discriminant, temp; + if (q2 > 1) { + if (qw >= 0) { + return void 0; + } + const qw2 = qw * qw; + difference = q2 - 1; + w2 = Cartesian3_default.magnitudeSquared(w); + product = w2 * difference; + if (qw2 < product) { + return void 0; + } else if (qw2 > product) { + discriminant = qw * qw - product; + temp = -qw + Math.sqrt(discriminant); + const root0 = temp / w2; + const root1 = difference / temp; + if (root0 < root1) { + return new Interval_default(root0, root1); + } + return { + start: root1, + stop: root0 + }; + } + const root = Math.sqrt(difference / w2); + return new Interval_default(root, root); + } else if (q2 < 1) { + difference = q2 - 1; + w2 = Cartesian3_default.magnitudeSquared(w); + product = w2 * difference; + discriminant = qw * qw - product; + temp = -qw + Math.sqrt(discriminant); + return new Interval_default(0, temp / w2); + } + if (qw < 0) { + w2 = Cartesian3_default.magnitudeSquared(w); + return new Interval_default(0, -qw / w2); + } + return void 0; +}; +function addWithCancellationCheck2(left, right, tolerance) { + const difference = left + right; + if (Math_default.sign(left) !== Math_default.sign(right) && Math.abs(difference / Math.max(Math.abs(left), Math.abs(right))) < tolerance) { + return 0; + } + return difference; +} +function quadraticVectorExpression(A, b, c, x, w) { + const xSquared = x * x; + const wSquared = w * w; + const l2 = (A[Matrix3_default.COLUMN1ROW1] - A[Matrix3_default.COLUMN2ROW2]) * wSquared; + const l1 = w * (x * addWithCancellationCheck2( + A[Matrix3_default.COLUMN1ROW0], + A[Matrix3_default.COLUMN0ROW1], + Math_default.EPSILON15 + ) + b.y); + const l0 = A[Matrix3_default.COLUMN0ROW0] * xSquared + A[Matrix3_default.COLUMN2ROW2] * wSquared + x * b.x + c; + const r1 = wSquared * addWithCancellationCheck2( + A[Matrix3_default.COLUMN2ROW1], + A[Matrix3_default.COLUMN1ROW2], + Math_default.EPSILON15 + ); + const r0 = w * (x * addWithCancellationCheck2(A[Matrix3_default.COLUMN2ROW0], A[Matrix3_default.COLUMN0ROW2]) + b.z); + let cosines; + const solutions = []; + if (r0 === 0 && r1 === 0) { + cosines = QuadraticRealPolynomial_default.computeRealRoots(l2, l1, l0); + if (cosines.length === 0) { + return solutions; + } + const cosine0 = cosines[0]; + const sine0 = Math.sqrt(Math.max(1 - cosine0 * cosine0, 0)); + solutions.push(new Cartesian3_default(x, w * cosine0, w * -sine0)); + solutions.push(new Cartesian3_default(x, w * cosine0, w * sine0)); + if (cosines.length === 2) { + const cosine1 = cosines[1]; + const sine1 = Math.sqrt(Math.max(1 - cosine1 * cosine1, 0)); + solutions.push(new Cartesian3_default(x, w * cosine1, w * -sine1)); + solutions.push(new Cartesian3_default(x, w * cosine1, w * sine1)); + } + return solutions; + } + const r0Squared = r0 * r0; + const r1Squared = r1 * r1; + const l2Squared = l2 * l2; + const r0r1 = r0 * r1; + const c4 = l2Squared + r1Squared; + const c3 = 2 * (l1 * l2 + r0r1); + const c2 = 2 * l0 * l2 + l1 * l1 - r1Squared + r0Squared; + const c1 = 2 * (l0 * l1 - r0r1); + const c0 = l0 * l0 - r0Squared; + if (c4 === 0 && c3 === 0 && c2 === 0 && c1 === 0) { + return solutions; + } + cosines = QuarticRealPolynomial_default.computeRealRoots(c4, c3, c2, c1, c0); + const length = cosines.length; + if (length === 0) { + return solutions; + } + for (let i = 0; i < length; ++i) { + const cosine = cosines[i]; + const cosineSquared = cosine * cosine; + const sineSquared = Math.max(1 - cosineSquared, 0); + const sine = Math.sqrt(sineSquared); + let left; + if (Math_default.sign(l2) === Math_default.sign(l0)) { + left = addWithCancellationCheck2( + l2 * cosineSquared + l0, + l1 * cosine, + Math_default.EPSILON12 + ); + } else if (Math_default.sign(l0) === Math_default.sign(l1 * cosine)) { + left = addWithCancellationCheck2( + l2 * cosineSquared, + l1 * cosine + l0, + Math_default.EPSILON12 + ); + } else { + left = addWithCancellationCheck2( + l2 * cosineSquared + l1 * cosine, + l0, + Math_default.EPSILON12 + ); + } + const right = addWithCancellationCheck2( + r1 * cosine, + r0, + Math_default.EPSILON15 + ); + const product = left * right; + if (product < 0) { + solutions.push(new Cartesian3_default(x, w * cosine, w * sine)); + } else if (product > 0) { + solutions.push(new Cartesian3_default(x, w * cosine, w * -sine)); + } else if (sine !== 0) { + solutions.push(new Cartesian3_default(x, w * cosine, w * -sine)); + solutions.push(new Cartesian3_default(x, w * cosine, w * sine)); + ++i; + } else { + solutions.push(new Cartesian3_default(x, w * cosine, w * sine)); + } + } + return solutions; +} +var firstAxisScratch = new Cartesian3_default(); +var secondAxisScratch = new Cartesian3_default(); +var thirdAxisScratch = new Cartesian3_default(); +var referenceScratch = new Cartesian3_default(); +var bCart = new Cartesian3_default(); +var bScratch = new Matrix3_default(); +var btScratch = new Matrix3_default(); +var diScratch = new Matrix3_default(); +var dScratch = new Matrix3_default(); +var cScratch = new Matrix3_default(); +var tempMatrix = new Matrix3_default(); +var aScratch = new Matrix3_default(); +var sScratch = new Cartesian3_default(); +var closestScratch = new Cartesian3_default(); +var surfPointScratch = new Cartographic_default(); +IntersectionTests.grazingAltitudeLocation = function(ray, ellipsoid) { + if (!defined_default(ray)) { + throw new DeveloperError_default("ray is required."); + } + if (!defined_default(ellipsoid)) { + throw new DeveloperError_default("ellipsoid is required."); + } + const position = ray.origin; + const direction = ray.direction; + if (!Cartesian3_default.equals(position, Cartesian3_default.ZERO)) { + const normal = ellipsoid.geodeticSurfaceNormal(position, firstAxisScratch); + if (Cartesian3_default.dot(direction, normal) >= 0) { + return position; + } + } + const intersects = defined_default(this.rayEllipsoid(ray, ellipsoid)); + const f = ellipsoid.transformPositionToScaledSpace( + direction, + firstAxisScratch + ); + const firstAxis = Cartesian3_default.normalize(f, f); + const reference = Cartesian3_default.mostOrthogonalAxis(f, referenceScratch); + const secondAxis = Cartesian3_default.normalize( + Cartesian3_default.cross(reference, firstAxis, secondAxisScratch), + secondAxisScratch + ); + const thirdAxis = Cartesian3_default.normalize( + Cartesian3_default.cross(firstAxis, secondAxis, thirdAxisScratch), + thirdAxisScratch + ); + const B = bScratch; + B[0] = firstAxis.x; + B[1] = firstAxis.y; + B[2] = firstAxis.z; + B[3] = secondAxis.x; + B[4] = secondAxis.y; + B[5] = secondAxis.z; + B[6] = thirdAxis.x; + B[7] = thirdAxis.y; + B[8] = thirdAxis.z; + const B_T = Matrix3_default.transpose(B, btScratch); + const D_I = Matrix3_default.fromScale(ellipsoid.radii, diScratch); + const D = Matrix3_default.fromScale(ellipsoid.oneOverRadii, dScratch); + const C = cScratch; + C[0] = 0; + C[1] = -direction.z; + C[2] = direction.y; + C[3] = direction.z; + C[4] = 0; + C[5] = -direction.x; + C[6] = -direction.y; + C[7] = direction.x; + C[8] = 0; + const temp = Matrix3_default.multiply( + Matrix3_default.multiply(B_T, D, tempMatrix), + C, + tempMatrix + ); + const A = Matrix3_default.multiply( + Matrix3_default.multiply(temp, D_I, aScratch), + B, + aScratch + ); + const b = Matrix3_default.multiplyByVector(temp, position, bCart); + const solutions = quadraticVectorExpression( + A, + Cartesian3_default.negate(b, firstAxisScratch), + 0, + 0, + 1 + ); + let s; + let altitude; + const length = solutions.length; + if (length > 0) { + let closest = Cartesian3_default.clone(Cartesian3_default.ZERO, closestScratch); + let maximumValue = Number.NEGATIVE_INFINITY; + for (let i = 0; i < length; ++i) { + s = Matrix3_default.multiplyByVector( + D_I, + Matrix3_default.multiplyByVector(B, solutions[i], sScratch), + sScratch + ); + const v = Cartesian3_default.normalize( + Cartesian3_default.subtract(s, position, referenceScratch), + referenceScratch + ); + const dotProduct = Cartesian3_default.dot(v, direction); + if (dotProduct > maximumValue) { + maximumValue = dotProduct; + closest = Cartesian3_default.clone(s, closest); + } + } + const surfacePoint = ellipsoid.cartesianToCartographic( + closest, + surfPointScratch + ); + maximumValue = Math_default.clamp(maximumValue, 0, 1); + altitude = Cartesian3_default.magnitude( + Cartesian3_default.subtract(closest, position, referenceScratch) + ) * Math.sqrt(1 - maximumValue * maximumValue); + altitude = intersects ? -altitude : altitude; + surfacePoint.height = altitude; + return ellipsoid.cartographicToCartesian(surfacePoint, new Cartesian3_default()); + } + return void 0; +}; +var lineSegmentPlaneDifference = new Cartesian3_default(); +IntersectionTests.lineSegmentPlane = function(endPoint0, endPoint1, plane, result) { + if (!defined_default(endPoint0)) { + throw new DeveloperError_default("endPoint0 is required."); + } + if (!defined_default(endPoint1)) { + throw new DeveloperError_default("endPoint1 is required."); + } + if (!defined_default(plane)) { + throw new DeveloperError_default("plane is required."); + } + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + const difference = Cartesian3_default.subtract( + endPoint1, + endPoint0, + lineSegmentPlaneDifference + ); + const normal = plane.normal; + const nDotDiff = Cartesian3_default.dot(normal, difference); + if (Math.abs(nDotDiff) < Math_default.EPSILON6) { + return void 0; + } + const nDotP0 = Cartesian3_default.dot(normal, endPoint0); + const t = -(plane.distance + nDotP0) / nDotDiff; + if (t < 0 || t > 1) { + return void 0; + } + Cartesian3_default.multiplyByScalar(difference, t, result); + Cartesian3_default.add(endPoint0, result, result); + return result; +}; +IntersectionTests.trianglePlaneIntersection = function(p0, p1, p2, plane) { + if (!defined_default(p0) || !defined_default(p1) || !defined_default(p2) || !defined_default(plane)) { + throw new DeveloperError_default("p0, p1, p2, and plane are required."); + } + const planeNormal = plane.normal; + const planeD = plane.distance; + const p0Behind = Cartesian3_default.dot(planeNormal, p0) + planeD < 0; + const p1Behind = Cartesian3_default.dot(planeNormal, p1) + planeD < 0; + const p2Behind = Cartesian3_default.dot(planeNormal, p2) + planeD < 0; + let numBehind = 0; + numBehind += p0Behind ? 1 : 0; + numBehind += p1Behind ? 1 : 0; + numBehind += p2Behind ? 1 : 0; + let u1, u2; + if (numBehind === 1 || numBehind === 2) { + u1 = new Cartesian3_default(); + u2 = new Cartesian3_default(); + } + if (numBehind === 1) { + if (p0Behind) { + IntersectionTests.lineSegmentPlane(p0, p1, plane, u1); + IntersectionTests.lineSegmentPlane(p0, p2, plane, u2); + return { + positions: [p0, p1, p2, u1, u2], + indices: [ + // Behind + 0, + 3, + 4, + // In front + 1, + 2, + 4, + 1, + 4, + 3 + ] + }; + } else if (p1Behind) { + IntersectionTests.lineSegmentPlane(p1, p2, plane, u1); + IntersectionTests.lineSegmentPlane(p1, p0, plane, u2); + return { + positions: [p0, p1, p2, u1, u2], + indices: [ + // Behind + 1, + 3, + 4, + // In front + 2, + 0, + 4, + 2, + 4, + 3 + ] + }; + } else if (p2Behind) { + IntersectionTests.lineSegmentPlane(p2, p0, plane, u1); + IntersectionTests.lineSegmentPlane(p2, p1, plane, u2); + return { + positions: [p0, p1, p2, u1, u2], + indices: [ + // Behind + 2, + 3, + 4, + // In front + 0, + 1, + 4, + 0, + 4, + 3 + ] + }; + } + } else if (numBehind === 2) { + if (!p0Behind) { + IntersectionTests.lineSegmentPlane(p1, p0, plane, u1); + IntersectionTests.lineSegmentPlane(p2, p0, plane, u2); + return { + positions: [p0, p1, p2, u1, u2], + indices: [ + // Behind + 1, + 2, + 4, + 1, + 4, + 3, + // In front + 0, + 3, + 4 + ] + }; + } else if (!p1Behind) { + IntersectionTests.lineSegmentPlane(p2, p1, plane, u1); + IntersectionTests.lineSegmentPlane(p0, p1, plane, u2); + return { + positions: [p0, p1, p2, u1, u2], + indices: [ + // Behind + 2, + 0, + 4, + 2, + 4, + 3, + // In front + 1, + 3, + 4 + ] + }; + } else if (!p2Behind) { + IntersectionTests.lineSegmentPlane(p0, p2, plane, u1); + IntersectionTests.lineSegmentPlane(p1, p2, plane, u2); + return { + positions: [p0, p1, p2, u1, u2], + indices: [ + // Behind + 0, + 1, + 4, + 0, + 4, + 3, + // In front + 2, + 3, + 4 + ] + }; + } + } + return void 0; +}; +var IntersectionTests_default = IntersectionTests; + +export { + Ray_default, + IntersectionTests_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-QVJ6IRKV.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-QVJ6IRKV.js new file mode 100644 index 0000000000000000000000000000000000000000..e88f97f16cf99773e48fe08924a8699f4105cecc --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-QVJ6IRKV.js @@ -0,0 +1,77 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +var __create = Object.create; +var __defProp = Object.defineProperty; +var __getOwnPropDesc = Object.getOwnPropertyDescriptor; +var __getOwnPropNames = Object.getOwnPropertyNames; +var __getProtoOf = Object.getPrototypeOf; +var __hasOwnProp = Object.prototype.hasOwnProperty; +var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, { + get: (a, b) => (typeof require !== "undefined" ? require : a)[b] +}) : x)(function(x) { + if (typeof require !== "undefined") + return require.apply(this, arguments); + throw Error('Dynamic require of "' + x + '" is not supported'); +}); +var __glob = (map) => (path) => { + var fn = map[path]; + if (fn) + return fn(); + throw new Error("Module not found in bundle: " + path); +}; +var __commonJS = (cb, mod) => function __require2() { + return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; +}; +var __copyProps = (to, from, except, desc) => { + if (from && typeof from === "object" || typeof from === "function") { + for (let key of __getOwnPropNames(from)) + if (!__hasOwnProp.call(to, key) && key !== except) + __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); + } + return to; +}; +var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( + // If the importer is in node compatibility mode or this is not an ESM + // file that has been converted to a CommonJS file using a Babel- + // compatible transform (i.e. "__esModule" has not been set), then set + // "default" to the CommonJS "module.exports" for node compatibility. + isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, + mod +)); + +// packages/engine/Source/Core/defined.js +function defined(value) { + return value !== void 0 && value !== null; +} +var defined_default = defined; + +export { + __require, + __glob, + __commonJS, + __toESM, + defined_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-RDCDRNJ7.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-RDCDRNJ7.js new file mode 100644 index 0000000000000000000000000000000000000000..756e77352efc26560a5e405f3c8b68fbd6f47081 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-RDCDRNJ7.js @@ -0,0 +1,117 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/WebMercatorProjection.js +function WebMercatorProjection(ellipsoid) { + this._ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + this._semimajorAxis = this._ellipsoid.maximumRadius; + this._oneOverSemimajorAxis = 1 / this._semimajorAxis; +} +Object.defineProperties(WebMercatorProjection.prototype, { + /** + * Gets the {@link Ellipsoid}. + * + * @memberof WebMercatorProjection.prototype + * + * @type {Ellipsoid} + * @readonly + */ + ellipsoid: { + get: function() { + return this._ellipsoid; + } + } +}); +WebMercatorProjection.mercatorAngleToGeodeticLatitude = function(mercatorAngle) { + return Math_default.PI_OVER_TWO - 2 * Math.atan(Math.exp(-mercatorAngle)); +}; +WebMercatorProjection.geodeticLatitudeToMercatorAngle = function(latitude) { + if (latitude > WebMercatorProjection.MaximumLatitude) { + latitude = WebMercatorProjection.MaximumLatitude; + } else if (latitude < -WebMercatorProjection.MaximumLatitude) { + latitude = -WebMercatorProjection.MaximumLatitude; + } + const sinLatitude = Math.sin(latitude); + return 0.5 * Math.log((1 + sinLatitude) / (1 - sinLatitude)); +}; +WebMercatorProjection.MaximumLatitude = WebMercatorProjection.mercatorAngleToGeodeticLatitude( + Math.PI +); +WebMercatorProjection.prototype.project = function(cartographic, result) { + const semimajorAxis = this._semimajorAxis; + const x = cartographic.longitude * semimajorAxis; + const y = WebMercatorProjection.geodeticLatitudeToMercatorAngle( + cartographic.latitude + ) * semimajorAxis; + const z = cartographic.height; + if (!defined_default(result)) { + return new Cartesian3_default(x, y, z); + } + result.x = x; + result.y = y; + result.z = z; + return result; +}; +WebMercatorProjection.prototype.unproject = function(cartesian, result) { + if (!defined_default(cartesian)) { + throw new DeveloperError_default("cartesian is required"); + } + const oneOverEarthSemimajorAxis = this._oneOverSemimajorAxis; + const longitude = cartesian.x * oneOverEarthSemimajorAxis; + const latitude = WebMercatorProjection.mercatorAngleToGeodeticLatitude( + cartesian.y * oneOverEarthSemimajorAxis + ); + const height = cartesian.z; + if (!defined_default(result)) { + return new Cartographic_default(longitude, latitude, height); + } + result.longitude = longitude; + result.latitude = latitude; + result.height = height; + return result; +}; +var WebMercatorProjection_default = WebMercatorProjection; + +export { + WebMercatorProjection_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-RDM3BKNC.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-RDM3BKNC.js new file mode 100644 index 0000000000000000000000000000000000000000..0d55c1c55fc5e48a7057f8289e7d0b1521501485 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-RDM3BKNC.js @@ -0,0 +1,1009 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + EllipsoidRhumbLine_default +} from "./chunk-RRUPTJ6P.js"; +import { + GeometryAttribute_default, + Geometry_default, + PrimitiveType_default +} from "./chunk-UGZGTV5K.js"; +import { + Cartesian2_default +} from "./chunk-PW5CA4MJ.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + WebGLConstants_default +} from "./chunk-527JG4D7.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default +} from "./chunk-UN7AK64D.js"; +import { + __commonJS, + __toESM, + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// node_modules/earcut/src/earcut.js +var require_earcut = __commonJS({ + "node_modules/earcut/src/earcut.js"(exports, module) { + "use strict"; + module.exports = earcut2; + module.exports.default = earcut2; + function earcut2(data, holeIndices, dim) { + dim = dim || 2; + var hasHoles = holeIndices && holeIndices.length, outerLen = hasHoles ? holeIndices[0] * dim : data.length, outerNode = linkedList(data, 0, outerLen, dim, true), triangles = []; + if (!outerNode || outerNode.next === outerNode.prev) + return triangles; + var minX, minY, maxX, maxY, x, y, invSize; + if (hasHoles) + outerNode = eliminateHoles(data, holeIndices, outerNode, dim); + if (data.length > 80 * dim) { + minX = maxX = data[0]; + minY = maxY = data[1]; + for (var i = dim; i < outerLen; i += dim) { + x = data[i]; + y = data[i + 1]; + if (x < minX) + minX = x; + if (y < minY) + minY = y; + if (x > maxX) + maxX = x; + if (y > maxY) + maxY = y; + } + invSize = Math.max(maxX - minX, maxY - minY); + invSize = invSize !== 0 ? 32767 / invSize : 0; + } + earcutLinked(outerNode, triangles, dim, minX, minY, invSize, 0); + return triangles; + } + function linkedList(data, start, end, dim, clockwise) { + var i, last; + if (clockwise === signedArea(data, start, end, dim) > 0) { + for (i = start; i < end; i += dim) + last = insertNode(i, data[i], data[i + 1], last); + } else { + for (i = end - dim; i >= start; i -= dim) + last = insertNode(i, data[i], data[i + 1], last); + } + if (last && equals(last, last.next)) { + removeNode(last); + last = last.next; + } + return last; + } + function filterPoints(start, end) { + if (!start) + return start; + if (!end) + end = start; + var p = start, again; + do { + again = false; + if (!p.steiner && (equals(p, p.next) || area(p.prev, p, p.next) === 0)) { + removeNode(p); + p = end = p.prev; + if (p === p.next) + break; + again = true; + } else { + p = p.next; + } + } while (again || p !== end); + return end; + } + function earcutLinked(ear, triangles, dim, minX, minY, invSize, pass) { + if (!ear) + return; + if (!pass && invSize) + indexCurve(ear, minX, minY, invSize); + var stop = ear, prev, next; + while (ear.prev !== ear.next) { + prev = ear.prev; + next = ear.next; + if (invSize ? isEarHashed(ear, minX, minY, invSize) : isEar(ear)) { + triangles.push(prev.i / dim | 0); + triangles.push(ear.i / dim | 0); + triangles.push(next.i / dim | 0); + removeNode(ear); + ear = next.next; + stop = next.next; + continue; + } + ear = next; + if (ear === stop) { + if (!pass) { + earcutLinked(filterPoints(ear), triangles, dim, minX, minY, invSize, 1); + } else if (pass === 1) { + ear = cureLocalIntersections(filterPoints(ear), triangles, dim); + earcutLinked(ear, triangles, dim, minX, minY, invSize, 2); + } else if (pass === 2) { + splitEarcut(ear, triangles, dim, minX, minY, invSize); + } + break; + } + } + } + function isEar(ear) { + var a = ear.prev, b = ear, c = ear.next; + if (area(a, b, c) >= 0) + return false; + var ax = a.x, bx = b.x, cx = c.x, ay = a.y, by = b.y, cy = c.y; + var x0 = ax < bx ? ax < cx ? ax : cx : bx < cx ? bx : cx, y0 = ay < by ? ay < cy ? ay : cy : by < cy ? by : cy, x1 = ax > bx ? ax > cx ? ax : cx : bx > cx ? bx : cx, y1 = ay > by ? ay > cy ? ay : cy : by > cy ? by : cy; + var p = c.next; + while (p !== a) { + if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 && pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) && area(p.prev, p, p.next) >= 0) + return false; + p = p.next; + } + return true; + } + function isEarHashed(ear, minX, minY, invSize) { + var a = ear.prev, b = ear, c = ear.next; + if (area(a, b, c) >= 0) + return false; + var ax = a.x, bx = b.x, cx = c.x, ay = a.y, by = b.y, cy = c.y; + var x0 = ax < bx ? ax < cx ? ax : cx : bx < cx ? bx : cx, y0 = ay < by ? ay < cy ? ay : cy : by < cy ? by : cy, x1 = ax > bx ? ax > cx ? ax : cx : bx > cx ? bx : cx, y1 = ay > by ? ay > cy ? ay : cy : by > cy ? by : cy; + var minZ = zOrder(x0, y0, minX, minY, invSize), maxZ = zOrder(x1, y1, minX, minY, invSize); + var p = ear.prevZ, n = ear.nextZ; + while (p && p.z >= minZ && n && n.z <= maxZ) { + if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 && p !== a && p !== c && pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) && area(p.prev, p, p.next) >= 0) + return false; + p = p.prevZ; + if (n.x >= x0 && n.x <= x1 && n.y >= y0 && n.y <= y1 && n !== a && n !== c && pointInTriangle(ax, ay, bx, by, cx, cy, n.x, n.y) && area(n.prev, n, n.next) >= 0) + return false; + n = n.nextZ; + } + while (p && p.z >= minZ) { + if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 && p !== a && p !== c && pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) && area(p.prev, p, p.next) >= 0) + return false; + p = p.prevZ; + } + while (n && n.z <= maxZ) { + if (n.x >= x0 && n.x <= x1 && n.y >= y0 && n.y <= y1 && n !== a && n !== c && pointInTriangle(ax, ay, bx, by, cx, cy, n.x, n.y) && area(n.prev, n, n.next) >= 0) + return false; + n = n.nextZ; + } + return true; + } + function cureLocalIntersections(start, triangles, dim) { + var p = start; + do { + var a = p.prev, b = p.next.next; + if (!equals(a, b) && intersects(a, p, p.next, b) && locallyInside(a, b) && locallyInside(b, a)) { + triangles.push(a.i / dim | 0); + triangles.push(p.i / dim | 0); + triangles.push(b.i / dim | 0); + removeNode(p); + removeNode(p.next); + p = start = b; + } + p = p.next; + } while (p !== start); + return filterPoints(p); + } + function splitEarcut(start, triangles, dim, minX, minY, invSize) { + var a = start; + do { + var b = a.next.next; + while (b !== a.prev) { + if (a.i !== b.i && isValidDiagonal(a, b)) { + var c = splitPolygon(a, b); + a = filterPoints(a, a.next); + c = filterPoints(c, c.next); + earcutLinked(a, triangles, dim, minX, minY, invSize, 0); + earcutLinked(c, triangles, dim, minX, minY, invSize, 0); + return; + } + b = b.next; + } + a = a.next; + } while (a !== start); + } + function eliminateHoles(data, holeIndices, outerNode, dim) { + var queue = [], i, len, start, end, list; + for (i = 0, len = holeIndices.length; i < len; i++) { + start = holeIndices[i] * dim; + end = i < len - 1 ? holeIndices[i + 1] * dim : data.length; + list = linkedList(data, start, end, dim, false); + if (list === list.next) + list.steiner = true; + queue.push(getLeftmost(list)); + } + queue.sort(compareX); + for (i = 0; i < queue.length; i++) { + outerNode = eliminateHole(queue[i], outerNode); + } + return outerNode; + } + function compareX(a, b) { + return a.x - b.x; + } + function eliminateHole(hole, outerNode) { + var bridge = findHoleBridge(hole, outerNode); + if (!bridge) { + return outerNode; + } + var bridgeReverse = splitPolygon(bridge, hole); + filterPoints(bridgeReverse, bridgeReverse.next); + return filterPoints(bridge, bridge.next); + } + function findHoleBridge(hole, outerNode) { + var p = outerNode, hx = hole.x, hy = hole.y, qx = -Infinity, m; + do { + if (hy <= p.y && hy >= p.next.y && p.next.y !== p.y) { + var x = p.x + (hy - p.y) * (p.next.x - p.x) / (p.next.y - p.y); + if (x <= hx && x > qx) { + qx = x; + m = p.x < p.next.x ? p : p.next; + if (x === hx) + return m; + } + } + p = p.next; + } while (p !== outerNode); + if (!m) + return null; + var stop = m, mx = m.x, my = m.y, tanMin = Infinity, tan; + p = m; + do { + if (hx >= p.x && p.x >= mx && hx !== p.x && pointInTriangle(hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y)) { + tan = Math.abs(hy - p.y) / (hx - p.x); + if (locallyInside(p, hole) && (tan < tanMin || tan === tanMin && (p.x > m.x || p.x === m.x && sectorContainsSector(m, p)))) { + m = p; + tanMin = tan; + } + } + p = p.next; + } while (p !== stop); + return m; + } + function sectorContainsSector(m, p) { + return area(m.prev, m, p.prev) < 0 && area(p.next, m, m.next) < 0; + } + function indexCurve(start, minX, minY, invSize) { + var p = start; + do { + if (p.z === 0) + p.z = zOrder(p.x, p.y, minX, minY, invSize); + p.prevZ = p.prev; + p.nextZ = p.next; + p = p.next; + } while (p !== start); + p.prevZ.nextZ = null; + p.prevZ = null; + sortLinked(p); + } + function sortLinked(list) { + var i, p, q, e, tail, numMerges, pSize, qSize, inSize = 1; + do { + p = list; + list = null; + tail = null; + numMerges = 0; + while (p) { + numMerges++; + q = p; + pSize = 0; + for (i = 0; i < inSize; i++) { + pSize++; + q = q.nextZ; + if (!q) + break; + } + qSize = inSize; + while (pSize > 0 || qSize > 0 && q) { + if (pSize !== 0 && (qSize === 0 || !q || p.z <= q.z)) { + e = p; + p = p.nextZ; + pSize--; + } else { + e = q; + q = q.nextZ; + qSize--; + } + if (tail) + tail.nextZ = e; + else + list = e; + e.prevZ = tail; + tail = e; + } + p = q; + } + tail.nextZ = null; + inSize *= 2; + } while (numMerges > 1); + return list; + } + function zOrder(x, y, minX, minY, invSize) { + x = (x - minX) * invSize | 0; + y = (y - minY) * invSize | 0; + x = (x | x << 8) & 16711935; + x = (x | x << 4) & 252645135; + x = (x | x << 2) & 858993459; + x = (x | x << 1) & 1431655765; + y = (y | y << 8) & 16711935; + y = (y | y << 4) & 252645135; + y = (y | y << 2) & 858993459; + y = (y | y << 1) & 1431655765; + return x | y << 1; + } + function getLeftmost(start) { + var p = start, leftmost = start; + do { + if (p.x < leftmost.x || p.x === leftmost.x && p.y < leftmost.y) + leftmost = p; + p = p.next; + } while (p !== start); + return leftmost; + } + function pointInTriangle(ax, ay, bx, by, cx, cy, px, py) { + return (cx - px) * (ay - py) >= (ax - px) * (cy - py) && (ax - px) * (by - py) >= (bx - px) * (ay - py) && (bx - px) * (cy - py) >= (cx - px) * (by - py); + } + function isValidDiagonal(a, b) { + return a.next.i !== b.i && a.prev.i !== b.i && !intersectsPolygon(a, b) && // dones't intersect other edges + (locallyInside(a, b) && locallyInside(b, a) && middleInside(a, b) && // locally visible + (area(a.prev, a, b.prev) || area(a, b.prev, b)) || // does not create opposite-facing sectors + equals(a, b) && area(a.prev, a, a.next) > 0 && area(b.prev, b, b.next) > 0); + } + function area(p, q, r) { + return (q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y); + } + function equals(p1, p2) { + return p1.x === p2.x && p1.y === p2.y; + } + function intersects(p1, q1, p2, q2) { + var o1 = sign(area(p1, q1, p2)); + var o2 = sign(area(p1, q1, q2)); + var o3 = sign(area(p2, q2, p1)); + var o4 = sign(area(p2, q2, q1)); + if (o1 !== o2 && o3 !== o4) + return true; + if (o1 === 0 && onSegment(p1, p2, q1)) + return true; + if (o2 === 0 && onSegment(p1, q2, q1)) + return true; + if (o3 === 0 && onSegment(p2, p1, q2)) + return true; + if (o4 === 0 && onSegment(p2, q1, q2)) + return true; + return false; + } + function onSegment(p, q, r) { + return q.x <= Math.max(p.x, r.x) && q.x >= Math.min(p.x, r.x) && q.y <= Math.max(p.y, r.y) && q.y >= Math.min(p.y, r.y); + } + function sign(num) { + return num > 0 ? 1 : num < 0 ? -1 : 0; + } + function intersectsPolygon(a, b) { + var p = a; + do { + if (p.i !== a.i && p.next.i !== a.i && p.i !== b.i && p.next.i !== b.i && intersects(p, p.next, a, b)) + return true; + p = p.next; + } while (p !== a); + return false; + } + function locallyInside(a, b) { + return area(a.prev, a, a.next) < 0 ? area(a, b, a.next) >= 0 && area(a, a.prev, b) >= 0 : area(a, b, a.prev) < 0 || area(a, a.next, b) < 0; + } + function middleInside(a, b) { + var p = a, inside = false, px = (a.x + b.x) / 2, py = (a.y + b.y) / 2; + do { + if (p.y > py !== p.next.y > py && p.next.y !== p.y && px < (p.next.x - p.x) * (py - p.y) / (p.next.y - p.y) + p.x) + inside = !inside; + p = p.next; + } while (p !== a); + return inside; + } + function splitPolygon(a, b) { + var a2 = new Node(a.i, a.x, a.y), b2 = new Node(b.i, b.x, b.y), an = a.next, bp = b.prev; + a.next = b; + b.prev = a; + a2.next = an; + an.prev = a2; + b2.next = a2; + a2.prev = b2; + bp.next = b2; + b2.prev = bp; + return b2; + } + function insertNode(i, x, y, last) { + var p = new Node(i, x, y); + if (!last) { + p.prev = p; + p.next = p; + } else { + p.next = last.next; + p.prev = last; + last.next.prev = p; + last.next = p; + } + return p; + } + function removeNode(p) { + p.next.prev = p.prev; + p.prev.next = p.next; + if (p.prevZ) + p.prevZ.nextZ = p.nextZ; + if (p.nextZ) + p.nextZ.prevZ = p.prevZ; + } + function Node(i, x, y) { + this.i = i; + this.x = x; + this.y = y; + this.prev = null; + this.next = null; + this.z = 0; + this.prevZ = null; + this.nextZ = null; + this.steiner = false; + } + earcut2.deviation = function(data, holeIndices, dim, triangles) { + var hasHoles = holeIndices && holeIndices.length; + var outerLen = hasHoles ? holeIndices[0] * dim : data.length; + var polygonArea = Math.abs(signedArea(data, 0, outerLen, dim)); + if (hasHoles) { + for (var i = 0, len = holeIndices.length; i < len; i++) { + var start = holeIndices[i] * dim; + var end = i < len - 1 ? holeIndices[i + 1] * dim : data.length; + polygonArea -= Math.abs(signedArea(data, start, end, dim)); + } + } + var trianglesArea = 0; + for (i = 0; i < triangles.length; i += 3) { + var a = triangles[i] * dim; + var b = triangles[i + 1] * dim; + var c = triangles[i + 2] * dim; + trianglesArea += Math.abs( + (data[a] - data[c]) * (data[b + 1] - data[a + 1]) - (data[a] - data[b]) * (data[c + 1] - data[a + 1]) + ); + } + return polygonArea === 0 && trianglesArea === 0 ? 0 : Math.abs((trianglesArea - polygonArea) / polygonArea); + }; + function signedArea(data, start, end, dim) { + var sum = 0; + for (var i = start, j = end - dim; i < end; i += dim) { + sum += (data[j] - data[i]) * (data[i + 1] + data[j + 1]); + j = i; + } + return sum; + } + earcut2.flatten = function(data) { + var dim = data[0][0].length, result = { vertices: [], holes: [], dimensions: dim }, holeIndex = 0; + for (var i = 0; i < data.length; i++) { + for (var j = 0; j < data[i].length; j++) { + for (var d = 0; d < dim; d++) + result.vertices.push(data[i][j][d]); + } + if (i > 0) { + holeIndex += data[i - 1].length; + result.holes.push(holeIndex); + } + } + return result; + }; + } +}); + +// packages/engine/Source/Core/WindingOrder.js +var WindingOrder = { + /** + * Vertices are in clockwise order. + * + * @type {number} + * @constant + */ + CLOCKWISE: WebGLConstants_default.CW, + /** + * Vertices are in counter-clockwise order. + * + * @type {number} + * @constant + */ + COUNTER_CLOCKWISE: WebGLConstants_default.CCW +}; +WindingOrder.validate = function(windingOrder) { + return windingOrder === WindingOrder.CLOCKWISE || windingOrder === WindingOrder.COUNTER_CLOCKWISE; +}; +var WindingOrder_default = Object.freeze(WindingOrder); + +// packages/engine/Source/Core/PolygonPipeline.js +var import_earcut = __toESM(require_earcut(), 1); +var scaleToGeodeticHeightN = new Cartesian3_default(); +var scaleToGeodeticHeightP = new Cartesian3_default(); +var PolygonPipeline = {}; +PolygonPipeline.computeArea2D = function(positions) { + Check_default.defined("positions", positions); + Check_default.typeOf.number.greaterThanOrEquals( + "positions.length", + positions.length, + 3 + ); + const length = positions.length; + let area = 0; + for (let i0 = length - 1, i1 = 0; i1 < length; i0 = i1++) { + const v0 = positions[i0]; + const v1 = positions[i1]; + area += v0.x * v1.y - v1.x * v0.y; + } + return area * 0.5; +}; +PolygonPipeline.computeWindingOrder2D = function(positions) { + const area = PolygonPipeline.computeArea2D(positions); + return area > 0 ? WindingOrder_default.COUNTER_CLOCKWISE : WindingOrder_default.CLOCKWISE; +}; +PolygonPipeline.triangulate = function(positions, holes) { + Check_default.defined("positions", positions); + const flattenedPositions = Cartesian2_default.packArray(positions); + return (0, import_earcut.default)(flattenedPositions, holes, 2); +}; +var subdivisionV0Scratch = new Cartesian3_default(); +var subdivisionV1Scratch = new Cartesian3_default(); +var subdivisionV2Scratch = new Cartesian3_default(); +var subdivisionS0Scratch = new Cartesian3_default(); +var subdivisionS1Scratch = new Cartesian3_default(); +var subdivisionS2Scratch = new Cartesian3_default(); +var subdivisionMidScratch = new Cartesian3_default(); +var subdivisionT0Scratch = new Cartesian2_default(); +var subdivisionT1Scratch = new Cartesian2_default(); +var subdivisionT2Scratch = new Cartesian2_default(); +var subdivisionTexcoordMidScratch = new Cartesian2_default(); +PolygonPipeline.computeSubdivision = function(ellipsoid, positions, indices, texcoords, granularity) { + granularity = defaultValue_default(granularity, Math_default.RADIANS_PER_DEGREE); + const hasTexcoords = defined_default(texcoords); + Check_default.typeOf.object("ellipsoid", ellipsoid); + Check_default.defined("positions", positions); + Check_default.defined("indices", indices); + Check_default.typeOf.number.greaterThanOrEquals("indices.length", indices.length, 3); + Check_default.typeOf.number.equals("indices.length % 3", "0", indices.length % 3, 0); + Check_default.typeOf.number.greaterThan("granularity", granularity, 0); + const triangles = indices.slice(0); + let i; + const length = positions.length; + const subdividedPositions = new Array(length * 3); + const subdividedTexcoords = new Array(length * 2); + let q = 0; + let p = 0; + for (i = 0; i < length; i++) { + const item = positions[i]; + subdividedPositions[q++] = item.x; + subdividedPositions[q++] = item.y; + subdividedPositions[q++] = item.z; + if (hasTexcoords) { + const texcoordItem = texcoords[i]; + subdividedTexcoords[p++] = texcoordItem.x; + subdividedTexcoords[p++] = texcoordItem.y; + } + } + const subdividedIndices = []; + const edges = {}; + const radius = ellipsoid.maximumRadius; + const minDistance = Math_default.chordLength(granularity, radius); + const minDistanceSqrd = minDistance * minDistance; + while (triangles.length > 0) { + const i2 = triangles.pop(); + const i1 = triangles.pop(); + const i0 = triangles.pop(); + const v0 = Cartesian3_default.fromArray( + subdividedPositions, + i0 * 3, + subdivisionV0Scratch + ); + const v1 = Cartesian3_default.fromArray( + subdividedPositions, + i1 * 3, + subdivisionV1Scratch + ); + const v2 = Cartesian3_default.fromArray( + subdividedPositions, + i2 * 3, + subdivisionV2Scratch + ); + let t0, t1, t2; + if (hasTexcoords) { + t0 = Cartesian2_default.fromArray( + subdividedTexcoords, + i0 * 2, + subdivisionT0Scratch + ); + t1 = Cartesian2_default.fromArray( + subdividedTexcoords, + i1 * 2, + subdivisionT1Scratch + ); + t2 = Cartesian2_default.fromArray( + subdividedTexcoords, + i2 * 2, + subdivisionT2Scratch + ); + } + const s0 = Cartesian3_default.multiplyByScalar( + Cartesian3_default.normalize(v0, subdivisionS0Scratch), + radius, + subdivisionS0Scratch + ); + const s1 = Cartesian3_default.multiplyByScalar( + Cartesian3_default.normalize(v1, subdivisionS1Scratch), + radius, + subdivisionS1Scratch + ); + const s2 = Cartesian3_default.multiplyByScalar( + Cartesian3_default.normalize(v2, subdivisionS2Scratch), + radius, + subdivisionS2Scratch + ); + const g0 = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(s0, s1, subdivisionMidScratch) + ); + const g1 = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(s1, s2, subdivisionMidScratch) + ); + const g2 = Cartesian3_default.magnitudeSquared( + Cartesian3_default.subtract(s2, s0, subdivisionMidScratch) + ); + const max = Math.max(g0, g1, g2); + let edge; + let mid; + let midTexcoord; + if (max > minDistanceSqrd) { + if (g0 === max) { + edge = `${Math.min(i0, i1)} ${Math.max(i0, i1)}`; + i = edges[edge]; + if (!defined_default(i)) { + mid = Cartesian3_default.add(v0, v1, subdivisionMidScratch); + Cartesian3_default.multiplyByScalar(mid, 0.5, mid); + subdividedPositions.push(mid.x, mid.y, mid.z); + i = subdividedPositions.length / 3 - 1; + edges[edge] = i; + if (hasTexcoords) { + midTexcoord = Cartesian2_default.add(t0, t1, subdivisionTexcoordMidScratch); + Cartesian2_default.multiplyByScalar(midTexcoord, 0.5, midTexcoord); + subdividedTexcoords.push(midTexcoord.x, midTexcoord.y); + } + } + triangles.push(i0, i, i2); + triangles.push(i, i1, i2); + } else if (g1 === max) { + edge = `${Math.min(i1, i2)} ${Math.max(i1, i2)}`; + i = edges[edge]; + if (!defined_default(i)) { + mid = Cartesian3_default.add(v1, v2, subdivisionMidScratch); + Cartesian3_default.multiplyByScalar(mid, 0.5, mid); + subdividedPositions.push(mid.x, mid.y, mid.z); + i = subdividedPositions.length / 3 - 1; + edges[edge] = i; + if (hasTexcoords) { + midTexcoord = Cartesian2_default.add(t1, t2, subdivisionTexcoordMidScratch); + Cartesian2_default.multiplyByScalar(midTexcoord, 0.5, midTexcoord); + subdividedTexcoords.push(midTexcoord.x, midTexcoord.y); + } + } + triangles.push(i1, i, i0); + triangles.push(i, i2, i0); + } else if (g2 === max) { + edge = `${Math.min(i2, i0)} ${Math.max(i2, i0)}`; + i = edges[edge]; + if (!defined_default(i)) { + mid = Cartesian3_default.add(v2, v0, subdivisionMidScratch); + Cartesian3_default.multiplyByScalar(mid, 0.5, mid); + subdividedPositions.push(mid.x, mid.y, mid.z); + i = subdividedPositions.length / 3 - 1; + edges[edge] = i; + if (hasTexcoords) { + midTexcoord = Cartesian2_default.add(t2, t0, subdivisionTexcoordMidScratch); + Cartesian2_default.multiplyByScalar(midTexcoord, 0.5, midTexcoord); + subdividedTexcoords.push(midTexcoord.x, midTexcoord.y); + } + } + triangles.push(i2, i, i1); + triangles.push(i, i0, i1); + } + } else { + subdividedIndices.push(i0); + subdividedIndices.push(i1); + subdividedIndices.push(i2); + } + } + const geometryOptions = { + attributes: { + position: new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: subdividedPositions + }) + }, + indices: subdividedIndices, + primitiveType: PrimitiveType_default.TRIANGLES + }; + if (hasTexcoords) { + geometryOptions.attributes.st = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: subdividedTexcoords + }); + } + return new Geometry_default(geometryOptions); +}; +var subdivisionC0Scratch = new Cartographic_default(); +var subdivisionC1Scratch = new Cartographic_default(); +var subdivisionC2Scratch = new Cartographic_default(); +var subdivisionCartographicScratch = new Cartographic_default(); +PolygonPipeline.computeRhumbLineSubdivision = function(ellipsoid, positions, indices, texcoords, granularity) { + granularity = defaultValue_default(granularity, Math_default.RADIANS_PER_DEGREE); + const hasTexcoords = defined_default(texcoords); + Check_default.typeOf.object("ellipsoid", ellipsoid); + Check_default.defined("positions", positions); + Check_default.defined("indices", indices); + Check_default.typeOf.number.greaterThanOrEquals("indices.length", indices.length, 3); + Check_default.typeOf.number.equals("indices.length % 3", "0", indices.length % 3, 0); + Check_default.typeOf.number.greaterThan("granularity", granularity, 0); + const triangles = indices.slice(0); + let i; + const length = positions.length; + const subdividedPositions = new Array(length * 3); + const subdividedTexcoords = new Array(length * 2); + let q = 0; + let p = 0; + for (i = 0; i < length; i++) { + const item = positions[i]; + subdividedPositions[q++] = item.x; + subdividedPositions[q++] = item.y; + subdividedPositions[q++] = item.z; + if (hasTexcoords) { + const texcoordItem = texcoords[i]; + subdividedTexcoords[p++] = texcoordItem.x; + subdividedTexcoords[p++] = texcoordItem.y; + } + } + const subdividedIndices = []; + const edges = {}; + const radius = ellipsoid.maximumRadius; + const minDistance = Math_default.chordLength(granularity, radius); + const rhumb0 = new EllipsoidRhumbLine_default(void 0, void 0, ellipsoid); + const rhumb1 = new EllipsoidRhumbLine_default(void 0, void 0, ellipsoid); + const rhumb2 = new EllipsoidRhumbLine_default(void 0, void 0, ellipsoid); + while (triangles.length > 0) { + const i2 = triangles.pop(); + const i1 = triangles.pop(); + const i0 = triangles.pop(); + const v0 = Cartesian3_default.fromArray( + subdividedPositions, + i0 * 3, + subdivisionV0Scratch + ); + const v1 = Cartesian3_default.fromArray( + subdividedPositions, + i1 * 3, + subdivisionV1Scratch + ); + const v2 = Cartesian3_default.fromArray( + subdividedPositions, + i2 * 3, + subdivisionV2Scratch + ); + let t0, t1, t2; + if (hasTexcoords) { + t0 = Cartesian2_default.fromArray( + subdividedTexcoords, + i0 * 2, + subdivisionT0Scratch + ); + t1 = Cartesian2_default.fromArray( + subdividedTexcoords, + i1 * 2, + subdivisionT1Scratch + ); + t2 = Cartesian2_default.fromArray( + subdividedTexcoords, + i2 * 2, + subdivisionT2Scratch + ); + } + const c0 = ellipsoid.cartesianToCartographic(v0, subdivisionC0Scratch); + const c1 = ellipsoid.cartesianToCartographic(v1, subdivisionC1Scratch); + const c2 = ellipsoid.cartesianToCartographic(v2, subdivisionC2Scratch); + rhumb0.setEndPoints(c0, c1); + const g0 = rhumb0.surfaceDistance; + rhumb1.setEndPoints(c1, c2); + const g1 = rhumb1.surfaceDistance; + rhumb2.setEndPoints(c2, c0); + const g2 = rhumb2.surfaceDistance; + const max = Math.max(g0, g1, g2); + let edge; + let mid; + let midHeight; + let midCartesian3; + let midTexcoord; + if (max > minDistance) { + if (g0 === max) { + edge = `${Math.min(i0, i1)} ${Math.max(i0, i1)}`; + i = edges[edge]; + if (!defined_default(i)) { + mid = rhumb0.interpolateUsingFraction( + 0.5, + subdivisionCartographicScratch + ); + midHeight = (c0.height + c1.height) * 0.5; + midCartesian3 = Cartesian3_default.fromRadians( + mid.longitude, + mid.latitude, + midHeight, + ellipsoid, + subdivisionMidScratch + ); + subdividedPositions.push( + midCartesian3.x, + midCartesian3.y, + midCartesian3.z + ); + i = subdividedPositions.length / 3 - 1; + edges[edge] = i; + if (hasTexcoords) { + midTexcoord = Cartesian2_default.add(t0, t1, subdivisionTexcoordMidScratch); + Cartesian2_default.multiplyByScalar(midTexcoord, 0.5, midTexcoord); + subdividedTexcoords.push(midTexcoord.x, midTexcoord.y); + } + } + triangles.push(i0, i, i2); + triangles.push(i, i1, i2); + } else if (g1 === max) { + edge = `${Math.min(i1, i2)} ${Math.max(i1, i2)}`; + i = edges[edge]; + if (!defined_default(i)) { + mid = rhumb1.interpolateUsingFraction( + 0.5, + subdivisionCartographicScratch + ); + midHeight = (c1.height + c2.height) * 0.5; + midCartesian3 = Cartesian3_default.fromRadians( + mid.longitude, + mid.latitude, + midHeight, + ellipsoid, + subdivisionMidScratch + ); + subdividedPositions.push( + midCartesian3.x, + midCartesian3.y, + midCartesian3.z + ); + i = subdividedPositions.length / 3 - 1; + edges[edge] = i; + if (hasTexcoords) { + midTexcoord = Cartesian2_default.add(t1, t2, subdivisionTexcoordMidScratch); + Cartesian2_default.multiplyByScalar(midTexcoord, 0.5, midTexcoord); + subdividedTexcoords.push(midTexcoord.x, midTexcoord.y); + } + } + triangles.push(i1, i, i0); + triangles.push(i, i2, i0); + } else if (g2 === max) { + edge = `${Math.min(i2, i0)} ${Math.max(i2, i0)}`; + i = edges[edge]; + if (!defined_default(i)) { + mid = rhumb2.interpolateUsingFraction( + 0.5, + subdivisionCartographicScratch + ); + midHeight = (c2.height + c0.height) * 0.5; + midCartesian3 = Cartesian3_default.fromRadians( + mid.longitude, + mid.latitude, + midHeight, + ellipsoid, + subdivisionMidScratch + ); + subdividedPositions.push( + midCartesian3.x, + midCartesian3.y, + midCartesian3.z + ); + i = subdividedPositions.length / 3 - 1; + edges[edge] = i; + if (hasTexcoords) { + midTexcoord = Cartesian2_default.add(t2, t0, subdivisionTexcoordMidScratch); + Cartesian2_default.multiplyByScalar(midTexcoord, 0.5, midTexcoord); + subdividedTexcoords.push(midTexcoord.x, midTexcoord.y); + } + } + triangles.push(i2, i, i1); + triangles.push(i, i0, i1); + } + } else { + subdividedIndices.push(i0); + subdividedIndices.push(i1); + subdividedIndices.push(i2); + } + } + const geometryOptions = { + attributes: { + position: new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: subdividedPositions + }) + }, + indices: subdividedIndices, + primitiveType: PrimitiveType_default.TRIANGLES + }; + if (hasTexcoords) { + geometryOptions.attributes.st = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: subdividedTexcoords + }); + } + return new Geometry_default(geometryOptions); +}; +PolygonPipeline.scaleToGeodeticHeight = function(positions, height, ellipsoid, scaleToSurface) { + ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + let n = scaleToGeodeticHeightN; + let p = scaleToGeodeticHeightP; + height = defaultValue_default(height, 0); + scaleToSurface = defaultValue_default(scaleToSurface, true); + if (defined_default(positions)) { + const length = positions.length; + for (let i = 0; i < length; i += 3) { + Cartesian3_default.fromArray(positions, i, p); + if (scaleToSurface) { + p = ellipsoid.scaleToGeodeticSurface(p, p); + } + if (height !== 0) { + n = ellipsoid.geodeticSurfaceNormal(p, n); + Cartesian3_default.multiplyByScalar(n, height, n); + Cartesian3_default.add(p, n, p); + } + positions[i] = p.x; + positions[i + 1] = p.y; + positions[i + 2] = p.z; + } + } + return positions; +}; +var PolygonPipeline_default = PolygonPipeline; + +export { + WindingOrder_default, + PolygonPipeline_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-RRUPTJ6P.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-RRUPTJ6P.js new file mode 100644 index 0000000000000000000000000000000000000000..c18de9b883ca6388c433d4b5eaeb1b22105d1ac8 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-RRUPTJ6P.js @@ -0,0 +1,452 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/EllipsoidRhumbLine.js +function calculateM(ellipticity, major, latitude) { + if (ellipticity === 0) { + return major * latitude; + } + const e2 = ellipticity * ellipticity; + const e4 = e2 * e2; + const e6 = e4 * e2; + const e8 = e6 * e2; + const e10 = e8 * e2; + const e12 = e10 * e2; + const phi = latitude; + const sin2Phi = Math.sin(2 * phi); + const sin4Phi = Math.sin(4 * phi); + const sin6Phi = Math.sin(6 * phi); + const sin8Phi = Math.sin(8 * phi); + const sin10Phi = Math.sin(10 * phi); + const sin12Phi = Math.sin(12 * phi); + return major * ((1 - e2 / 4 - 3 * e4 / 64 - 5 * e6 / 256 - 175 * e8 / 16384 - 441 * e10 / 65536 - 4851 * e12 / 1048576) * phi - (3 * e2 / 8 + 3 * e4 / 32 + 45 * e6 / 1024 + 105 * e8 / 4096 + 2205 * e10 / 131072 + 6237 * e12 / 524288) * sin2Phi + (15 * e4 / 256 + 45 * e6 / 1024 + 525 * e8 / 16384 + 1575 * e10 / 65536 + 155925 * e12 / 8388608) * sin4Phi - (35 * e6 / 3072 + 175 * e8 / 12288 + 3675 * e10 / 262144 + 13475 * e12 / 1048576) * sin6Phi + (315 * e8 / 131072 + 2205 * e10 / 524288 + 43659 * e12 / 8388608) * sin8Phi - (693 * e10 / 1310720 + 6237 * e12 / 5242880) * sin10Phi + 1001 * e12 / 8388608 * sin12Phi); +} +function calculateInverseM(M, ellipticity, major) { + const d = M / major; + if (ellipticity === 0) { + return d; + } + const d2 = d * d; + const d3 = d2 * d; + const d4 = d3 * d; + const e = ellipticity; + const e2 = e * e; + const e4 = e2 * e2; + const e6 = e4 * e2; + const e8 = e6 * e2; + const e10 = e8 * e2; + const e12 = e10 * e2; + const sin2D = Math.sin(2 * d); + const cos2D = Math.cos(2 * d); + const sin4D = Math.sin(4 * d); + const cos4D = Math.cos(4 * d); + const sin6D = Math.sin(6 * d); + const cos6D = Math.cos(6 * d); + const sin8D = Math.sin(8 * d); + const cos8D = Math.cos(8 * d); + const sin10D = Math.sin(10 * d); + const cos10D = Math.cos(10 * d); + const sin12D = Math.sin(12 * d); + return d + d * e2 / 4 + 7 * d * e4 / 64 + 15 * d * e6 / 256 + 579 * d * e8 / 16384 + 1515 * d * e10 / 65536 + 16837 * d * e12 / 1048576 + (3 * d * e4 / 16 + 45 * d * e6 / 256 - d * (32 * d2 - 561) * e8 / 4096 - d * (232 * d2 - 1677) * e10 / 16384 + d * (399985 - 90560 * d2 + 512 * d4) * e12 / 5242880) * cos2D + (21 * d * e6 / 256 + 483 * d * e8 / 4096 - d * (224 * d2 - 1969) * e10 / 16384 - d * (33152 * d2 - 112599) * e12 / 1048576) * cos4D + (151 * d * e8 / 4096 + 4681 * d * e10 / 65536 + 1479 * d * e12 / 16384 - 453 * d3 * e12 / 32768) * cos6D + (1097 * d * e10 / 65536 + 42783 * d * e12 / 1048576) * cos8D + 8011 * d * e12 / 1048576 * cos10D + (3 * e2 / 8 + 3 * e4 / 16 + 213 * e6 / 2048 - 3 * d2 * e6 / 64 + 255 * e8 / 4096 - 33 * d2 * e8 / 512 + 20861 * e10 / 524288 - 33 * d2 * e10 / 512 + d4 * e10 / 1024 + 28273 * e12 / 1048576 - 471 * d2 * e12 / 8192 + 9 * d4 * e12 / 4096) * sin2D + (21 * e4 / 256 + 21 * e6 / 256 + 533 * e8 / 8192 - 21 * d2 * e8 / 512 + 197 * e10 / 4096 - 315 * d2 * e10 / 4096 + 584039 * e12 / 16777216 - 12517 * d2 * e12 / 131072 + 7 * d4 * e12 / 2048) * sin4D + (151 * e6 / 6144 + 151 * e8 / 4096 + 5019 * e10 / 131072 - 453 * d2 * e10 / 16384 + 26965 * e12 / 786432 - 8607 * d2 * e12 / 131072) * sin6D + (1097 * e8 / 131072 + 1097 * e10 / 65536 + 225797 * e12 / 10485760 - 1097 * d2 * e12 / 65536) * sin8D + (8011 * e10 / 2621440 + 8011 * e12 / 1048576) * sin10D + 293393 * e12 / 251658240 * sin12D; +} +function calculateSigma(ellipticity, latitude) { + if (ellipticity === 0) { + return Math.log(Math.tan(0.5 * (Math_default.PI_OVER_TWO + latitude))); + } + const eSinL = ellipticity * Math.sin(latitude); + return Math.log(Math.tan(0.5 * (Math_default.PI_OVER_TWO + latitude))) - ellipticity / 2 * Math.log((1 + eSinL) / (1 - eSinL)); +} +function calculateHeading(ellipsoidRhumbLine, firstLongitude, firstLatitude, secondLongitude, secondLatitude) { + const sigma1 = calculateSigma(ellipsoidRhumbLine._ellipticity, firstLatitude); + const sigma2 = calculateSigma( + ellipsoidRhumbLine._ellipticity, + secondLatitude + ); + return Math.atan2( + Math_default.negativePiToPi(secondLongitude - firstLongitude), + sigma2 - sigma1 + ); +} +function calculateArcLength(ellipsoidRhumbLine, major, minor, firstLongitude, firstLatitude, secondLongitude, secondLatitude) { + const heading = ellipsoidRhumbLine._heading; + const deltaLongitude = secondLongitude - firstLongitude; + let distance = 0; + if (Math_default.equalsEpsilon( + Math.abs(heading), + Math_default.PI_OVER_TWO, + Math_default.EPSILON8 + )) { + if (major === minor) { + distance = major * Math.cos(firstLatitude) * Math_default.negativePiToPi(deltaLongitude); + } else { + const sinPhi = Math.sin(firstLatitude); + distance = major * Math.cos(firstLatitude) * Math_default.negativePiToPi(deltaLongitude) / Math.sqrt(1 - ellipsoidRhumbLine._ellipticitySquared * sinPhi * sinPhi); + } + } else { + const M1 = calculateM( + ellipsoidRhumbLine._ellipticity, + major, + firstLatitude + ); + const M2 = calculateM( + ellipsoidRhumbLine._ellipticity, + major, + secondLatitude + ); + distance = (M2 - M1) / Math.cos(heading); + } + return Math.abs(distance); +} +var scratchCart1 = new Cartesian3_default(); +var scratchCart2 = new Cartesian3_default(); +function computeProperties(ellipsoidRhumbLine, start, end, ellipsoid) { + const firstCartesian = Cartesian3_default.normalize( + ellipsoid.cartographicToCartesian(start, scratchCart2), + scratchCart1 + ); + const lastCartesian = Cartesian3_default.normalize( + ellipsoid.cartographicToCartesian(end, scratchCart2), + scratchCart2 + ); + Check_default.typeOf.number.greaterThanOrEquals( + "value", + Math.abs( + Math.abs(Cartesian3_default.angleBetween(firstCartesian, lastCartesian)) - Math.PI + ), + 0.0125 + ); + const major = ellipsoid.maximumRadius; + const minor = ellipsoid.minimumRadius; + const majorSquared = major * major; + const minorSquared = minor * minor; + ellipsoidRhumbLine._ellipticitySquared = (majorSquared - minorSquared) / majorSquared; + ellipsoidRhumbLine._ellipticity = Math.sqrt( + ellipsoidRhumbLine._ellipticitySquared + ); + ellipsoidRhumbLine._start = Cartographic_default.clone( + start, + ellipsoidRhumbLine._start + ); + ellipsoidRhumbLine._start.height = 0; + ellipsoidRhumbLine._end = Cartographic_default.clone(end, ellipsoidRhumbLine._end); + ellipsoidRhumbLine._end.height = 0; + ellipsoidRhumbLine._heading = calculateHeading( + ellipsoidRhumbLine, + start.longitude, + start.latitude, + end.longitude, + end.latitude + ); + ellipsoidRhumbLine._distance = calculateArcLength( + ellipsoidRhumbLine, + ellipsoid.maximumRadius, + ellipsoid.minimumRadius, + start.longitude, + start.latitude, + end.longitude, + end.latitude + ); +} +function interpolateUsingSurfaceDistance(start, heading, distance, major, ellipticity, result) { + if (distance === 0) { + return Cartographic_default.clone(start, result); + } + const ellipticitySquared = ellipticity * ellipticity; + let longitude; + let latitude; + let deltaLongitude; + if (Math.abs(Math_default.PI_OVER_TWO - Math.abs(heading)) > Math_default.EPSILON8) { + const M1 = calculateM(ellipticity, major, start.latitude); + const deltaM = distance * Math.cos(heading); + const M2 = M1 + deltaM; + latitude = calculateInverseM(M2, ellipticity, major); + const sigma1 = calculateSigma(ellipticity, start.latitude); + const sigma2 = calculateSigma(ellipticity, latitude); + deltaLongitude = Math.tan(heading) * (sigma2 - sigma1); + longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude); + } else { + latitude = start.latitude; + let localRad; + if (ellipticity === 0) { + localRad = major * Math.cos(start.latitude); + } else { + const sinPhi = Math.sin(start.latitude); + localRad = major * Math.cos(start.latitude) / Math.sqrt(1 - ellipticitySquared * sinPhi * sinPhi); + } + deltaLongitude = distance / localRad; + if (heading > 0) { + longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude); + } else { + longitude = Math_default.negativePiToPi(start.longitude - deltaLongitude); + } + } + if (defined_default(result)) { + result.longitude = longitude; + result.latitude = latitude; + result.height = 0; + return result; + } + return new Cartographic_default(longitude, latitude, 0); +} +function EllipsoidRhumbLine(start, end, ellipsoid) { + const e = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + this._ellipsoid = e; + this._start = new Cartographic_default(); + this._end = new Cartographic_default(); + this._heading = void 0; + this._distance = void 0; + this._ellipticity = void 0; + this._ellipticitySquared = void 0; + if (defined_default(start) && defined_default(end)) { + computeProperties(this, start, end, e); + } +} +Object.defineProperties(EllipsoidRhumbLine.prototype, { + /** + * Gets the ellipsoid. + * @memberof EllipsoidRhumbLine.prototype + * @type {Ellipsoid} + * @readonly + */ + ellipsoid: { + get: function() { + return this._ellipsoid; + } + }, + /** + * Gets the surface distance between the start and end point + * @memberof EllipsoidRhumbLine.prototype + * @type {number} + * @readonly + */ + surfaceDistance: { + get: function() { + Check_default.defined("distance", this._distance); + return this._distance; + } + }, + /** + * Gets the initial planetodetic point on the path. + * @memberof EllipsoidRhumbLine.prototype + * @type {Cartographic} + * @readonly + */ + start: { + get: function() { + return this._start; + } + }, + /** + * Gets the final planetodetic point on the path. + * @memberof EllipsoidRhumbLine.prototype + * @type {Cartographic} + * @readonly + */ + end: { + get: function() { + return this._end; + } + }, + /** + * Gets the heading from the start point to the end point. + * @memberof EllipsoidRhumbLine.prototype + * @type {number} + * @readonly + */ + heading: { + get: function() { + Check_default.defined("distance", this._distance); + return this._heading; + } + } +}); +EllipsoidRhumbLine.fromStartHeadingDistance = function(start, heading, distance, ellipsoid, result) { + Check_default.defined("start", start); + Check_default.defined("heading", heading); + Check_default.defined("distance", distance); + Check_default.typeOf.number.greaterThan("distance", distance, 0); + const e = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + const major = e.maximumRadius; + const minor = e.minimumRadius; + const majorSquared = major * major; + const minorSquared = minor * minor; + const ellipticity = Math.sqrt((majorSquared - minorSquared) / majorSquared); + heading = Math_default.negativePiToPi(heading); + const end = interpolateUsingSurfaceDistance( + start, + heading, + distance, + e.maximumRadius, + ellipticity + ); + if (!defined_default(result) || defined_default(ellipsoid) && !ellipsoid.equals(result.ellipsoid)) { + return new EllipsoidRhumbLine(start, end, e); + } + result.setEndPoints(start, end); + return result; +}; +EllipsoidRhumbLine.prototype.setEndPoints = function(start, end) { + Check_default.defined("start", start); + Check_default.defined("end", end); + computeProperties(this, start, end, this._ellipsoid); +}; +EllipsoidRhumbLine.prototype.interpolateUsingFraction = function(fraction, result) { + return this.interpolateUsingSurfaceDistance( + fraction * this._distance, + result + ); +}; +EllipsoidRhumbLine.prototype.interpolateUsingSurfaceDistance = function(distance, result) { + Check_default.typeOf.number("distance", distance); + if (!defined_default(this._distance) || this._distance === 0) { + throw new DeveloperError_default( + "EllipsoidRhumbLine must have distinct start and end set." + ); + } + return interpolateUsingSurfaceDistance( + this._start, + this._heading, + distance, + this._ellipsoid.maximumRadius, + this._ellipticity, + result + ); +}; +EllipsoidRhumbLine.prototype.findIntersectionWithLongitude = function(intersectionLongitude, result) { + Check_default.typeOf.number("intersectionLongitude", intersectionLongitude); + if (!defined_default(this._distance) || this._distance === 0) { + throw new DeveloperError_default( + "EllipsoidRhumbLine must have distinct start and end set." + ); + } + const ellipticity = this._ellipticity; + const heading = this._heading; + const absHeading = Math.abs(heading); + const start = this._start; + intersectionLongitude = Math_default.negativePiToPi(intersectionLongitude); + if (Math_default.equalsEpsilon( + Math.abs(intersectionLongitude), + Math.PI, + Math_default.EPSILON14 + )) { + intersectionLongitude = Math_default.sign(start.longitude) * Math.PI; + } + if (!defined_default(result)) { + result = new Cartographic_default(); + } + if (Math.abs(Math_default.PI_OVER_TWO - absHeading) <= Math_default.EPSILON8) { + result.longitude = intersectionLongitude; + result.latitude = start.latitude; + result.height = 0; + return result; + } else if (Math_default.equalsEpsilon( + Math.abs(Math_default.PI_OVER_TWO - absHeading), + Math_default.PI_OVER_TWO, + Math_default.EPSILON8 + )) { + if (Math_default.equalsEpsilon( + intersectionLongitude, + start.longitude, + Math_default.EPSILON12 + )) { + return void 0; + } + result.longitude = intersectionLongitude; + result.latitude = Math_default.PI_OVER_TWO * Math_default.sign(Math_default.PI_OVER_TWO - heading); + result.height = 0; + return result; + } + const phi1 = start.latitude; + const eSinPhi1 = ellipticity * Math.sin(phi1); + const leftComponent = Math.tan(0.5 * (Math_default.PI_OVER_TWO + phi1)) * Math.exp((intersectionLongitude - start.longitude) / Math.tan(heading)); + const denominator = (1 + eSinPhi1) / (1 - eSinPhi1); + let newPhi = start.latitude; + let phi; + do { + phi = newPhi; + const eSinPhi = ellipticity * Math.sin(phi); + const numerator = (1 + eSinPhi) / (1 - eSinPhi); + newPhi = 2 * Math.atan( + leftComponent * Math.pow(numerator / denominator, ellipticity / 2) + ) - Math_default.PI_OVER_TWO; + } while (!Math_default.equalsEpsilon(newPhi, phi, Math_default.EPSILON12)); + result.longitude = intersectionLongitude; + result.latitude = newPhi; + result.height = 0; + return result; +}; +EllipsoidRhumbLine.prototype.findIntersectionWithLatitude = function(intersectionLatitude, result) { + Check_default.typeOf.number("intersectionLatitude", intersectionLatitude); + if (!defined_default(this._distance) || this._distance === 0) { + throw new DeveloperError_default( + "EllipsoidRhumbLine must have distinct start and end set." + ); + } + const ellipticity = this._ellipticity; + const heading = this._heading; + const start = this._start; + if (Math_default.equalsEpsilon( + Math.abs(heading), + Math_default.PI_OVER_TWO, + Math_default.EPSILON8 + )) { + return; + } + const sigma1 = calculateSigma(ellipticity, start.latitude); + const sigma2 = calculateSigma(ellipticity, intersectionLatitude); + const deltaLongitude = Math.tan(heading) * (sigma2 - sigma1); + const longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude); + if (defined_default(result)) { + result.longitude = longitude; + result.latitude = intersectionLatitude; + result.height = 0; + return result; + } + return new Cartographic_default(longitude, intersectionLatitude, 0); +}; +var EllipsoidRhumbLine_default = EllipsoidRhumbLine; + +export { + EllipsoidRhumbLine_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-SGRWJKNO.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-SGRWJKNO.js new file mode 100644 index 0000000000000000000000000000000000000000..6600c2e5a54d5c5e0a5477cea2f44c1d75e7db14 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-SGRWJKNO.js @@ -0,0 +1,400 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + CylinderGeometryLibrary_default +} from "./chunk-F7P2HCYZ.js"; +import { + GeometryOffsetAttribute_default +} from "./chunk-A6EA6KIE.js"; +import { + VertexFormat_default +} from "./chunk-2NLMZNJI.js"; +import { + IndexDatatype_default +} from "./chunk-TF5D2H7B.js"; +import { + GeometryAttributes_default +} from "./chunk-N5MMDSD2.js"; +import { + GeometryAttribute_default, + Geometry_default, + PrimitiveType_default +} from "./chunk-UGZGTV5K.js"; +import { + BoundingSphere_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default +} from "./chunk-PW5CA4MJ.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/CylinderGeometry.js +var radiusScratch = new Cartesian2_default(); +var normalScratch = new Cartesian3_default(); +var bitangentScratch = new Cartesian3_default(); +var tangentScratch = new Cartesian3_default(); +var positionScratch = new Cartesian3_default(); +function CylinderGeometry(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const length = options.length; + const topRadius = options.topRadius; + const bottomRadius = options.bottomRadius; + const vertexFormat = defaultValue_default(options.vertexFormat, VertexFormat_default.DEFAULT); + const slices = defaultValue_default(options.slices, 128); + if (!defined_default(length)) { + throw new DeveloperError_default("options.length must be defined."); + } + if (!defined_default(topRadius)) { + throw new DeveloperError_default("options.topRadius must be defined."); + } + if (!defined_default(bottomRadius)) { + throw new DeveloperError_default("options.bottomRadius must be defined."); + } + if (slices < 3) { + throw new DeveloperError_default( + "options.slices must be greater than or equal to 3." + ); + } + if (defined_default(options.offsetAttribute) && options.offsetAttribute === GeometryOffsetAttribute_default.TOP) { + throw new DeveloperError_default( + "GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry." + ); + } + this._length = length; + this._topRadius = topRadius; + this._bottomRadius = bottomRadius; + this._vertexFormat = VertexFormat_default.clone(vertexFormat); + this._slices = slices; + this._offsetAttribute = options.offsetAttribute; + this._workerName = "createCylinderGeometry"; +} +CylinderGeometry.packedLength = VertexFormat_default.packedLength + 5; +CylinderGeometry.pack = function(value, array, startingIndex) { + if (!defined_default(value)) { + throw new DeveloperError_default("value is required"); + } + if (!defined_default(array)) { + throw new DeveloperError_default("array is required"); + } + startingIndex = defaultValue_default(startingIndex, 0); + VertexFormat_default.pack(value._vertexFormat, array, startingIndex); + startingIndex += VertexFormat_default.packedLength; + array[startingIndex++] = value._length; + array[startingIndex++] = value._topRadius; + array[startingIndex++] = value._bottomRadius; + array[startingIndex++] = value._slices; + array[startingIndex] = defaultValue_default(value._offsetAttribute, -1); + return array; +}; +var scratchVertexFormat = new VertexFormat_default(); +var scratchOptions = { + vertexFormat: scratchVertexFormat, + length: void 0, + topRadius: void 0, + bottomRadius: void 0, + slices: void 0, + offsetAttribute: void 0 +}; +CylinderGeometry.unpack = function(array, startingIndex, result) { + if (!defined_default(array)) { + throw new DeveloperError_default("array is required"); + } + startingIndex = defaultValue_default(startingIndex, 0); + const vertexFormat = VertexFormat_default.unpack( + array, + startingIndex, + scratchVertexFormat + ); + startingIndex += VertexFormat_default.packedLength; + const length = array[startingIndex++]; + const topRadius = array[startingIndex++]; + const bottomRadius = array[startingIndex++]; + const slices = array[startingIndex++]; + const offsetAttribute = array[startingIndex]; + if (!defined_default(result)) { + scratchOptions.length = length; + scratchOptions.topRadius = topRadius; + scratchOptions.bottomRadius = bottomRadius; + scratchOptions.slices = slices; + scratchOptions.offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return new CylinderGeometry(scratchOptions); + } + result._vertexFormat = VertexFormat_default.clone(vertexFormat, result._vertexFormat); + result._length = length; + result._topRadius = topRadius; + result._bottomRadius = bottomRadius; + result._slices = slices; + result._offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return result; +}; +CylinderGeometry.createGeometry = function(cylinderGeometry) { + let length = cylinderGeometry._length; + const topRadius = cylinderGeometry._topRadius; + const bottomRadius = cylinderGeometry._bottomRadius; + const vertexFormat = cylinderGeometry._vertexFormat; + const slices = cylinderGeometry._slices; + if (length <= 0 || topRadius < 0 || bottomRadius < 0 || topRadius === 0 && bottomRadius === 0) { + return; + } + const twoSlices = slices + slices; + const threeSlices = slices + twoSlices; + const numVertices = twoSlices + twoSlices; + const positions = CylinderGeometryLibrary_default.computePositions( + length, + topRadius, + bottomRadius, + slices, + true + ); + const st = vertexFormat.st ? new Float32Array(numVertices * 2) : void 0; + const normals = vertexFormat.normal ? new Float32Array(numVertices * 3) : void 0; + const tangents = vertexFormat.tangent ? new Float32Array(numVertices * 3) : void 0; + const bitangents = vertexFormat.bitangent ? new Float32Array(numVertices * 3) : void 0; + let i; + const computeNormal = vertexFormat.normal || vertexFormat.tangent || vertexFormat.bitangent; + if (computeNormal) { + const computeTangent = vertexFormat.tangent || vertexFormat.bitangent; + let normalIndex = 0; + let tangentIndex = 0; + let bitangentIndex = 0; + const theta = Math.atan2(bottomRadius - topRadius, length); + const normal = normalScratch; + normal.z = Math.sin(theta); + const normalScale = Math.cos(theta); + let tangent = tangentScratch; + let bitangent = bitangentScratch; + for (i = 0; i < slices; i++) { + const angle = i / slices * Math_default.TWO_PI; + const x = normalScale * Math.cos(angle); + const y = normalScale * Math.sin(angle); + if (computeNormal) { + normal.x = x; + normal.y = y; + if (computeTangent) { + tangent = Cartesian3_default.normalize( + Cartesian3_default.cross(Cartesian3_default.UNIT_Z, normal, tangent), + tangent + ); + } + if (vertexFormat.normal) { + normals[normalIndex++] = normal.x; + normals[normalIndex++] = normal.y; + normals[normalIndex++] = normal.z; + normals[normalIndex++] = normal.x; + normals[normalIndex++] = normal.y; + normals[normalIndex++] = normal.z; + } + if (vertexFormat.tangent) { + tangents[tangentIndex++] = tangent.x; + tangents[tangentIndex++] = tangent.y; + tangents[tangentIndex++] = tangent.z; + tangents[tangentIndex++] = tangent.x; + tangents[tangentIndex++] = tangent.y; + tangents[tangentIndex++] = tangent.z; + } + if (vertexFormat.bitangent) { + bitangent = Cartesian3_default.normalize( + Cartesian3_default.cross(normal, tangent, bitangent), + bitangent + ); + bitangents[bitangentIndex++] = bitangent.x; + bitangents[bitangentIndex++] = bitangent.y; + bitangents[bitangentIndex++] = bitangent.z; + bitangents[bitangentIndex++] = bitangent.x; + bitangents[bitangentIndex++] = bitangent.y; + bitangents[bitangentIndex++] = bitangent.z; + } + } + } + for (i = 0; i < slices; i++) { + if (vertexFormat.normal) { + normals[normalIndex++] = 0; + normals[normalIndex++] = 0; + normals[normalIndex++] = -1; + } + if (vertexFormat.tangent) { + tangents[tangentIndex++] = 1; + tangents[tangentIndex++] = 0; + tangents[tangentIndex++] = 0; + } + if (vertexFormat.bitangent) { + bitangents[bitangentIndex++] = 0; + bitangents[bitangentIndex++] = -1; + bitangents[bitangentIndex++] = 0; + } + } + for (i = 0; i < slices; i++) { + if (vertexFormat.normal) { + normals[normalIndex++] = 0; + normals[normalIndex++] = 0; + normals[normalIndex++] = 1; + } + if (vertexFormat.tangent) { + tangents[tangentIndex++] = 1; + tangents[tangentIndex++] = 0; + tangents[tangentIndex++] = 0; + } + if (vertexFormat.bitangent) { + bitangents[bitangentIndex++] = 0; + bitangents[bitangentIndex++] = 1; + bitangents[bitangentIndex++] = 0; + } + } + } + const numIndices = 12 * slices - 12; + const indices = IndexDatatype_default.createTypedArray(numVertices, numIndices); + let index = 0; + let j = 0; + for (i = 0; i < slices - 1; i++) { + indices[index++] = j; + indices[index++] = j + 2; + indices[index++] = j + 3; + indices[index++] = j; + indices[index++] = j + 3; + indices[index++] = j + 1; + j += 2; + } + indices[index++] = twoSlices - 2; + indices[index++] = 0; + indices[index++] = 1; + indices[index++] = twoSlices - 2; + indices[index++] = 1; + indices[index++] = twoSlices - 1; + for (i = 1; i < slices - 1; i++) { + indices[index++] = twoSlices + i + 1; + indices[index++] = twoSlices + i; + indices[index++] = twoSlices; + } + for (i = 1; i < slices - 1; i++) { + indices[index++] = threeSlices; + indices[index++] = threeSlices + i; + indices[index++] = threeSlices + i + 1; + } + let textureCoordIndex = 0; + if (vertexFormat.st) { + const rad = Math.max(topRadius, bottomRadius); + for (i = 0; i < numVertices; i++) { + const position = Cartesian3_default.fromArray(positions, i * 3, positionScratch); + st[textureCoordIndex++] = (position.x + rad) / (2 * rad); + st[textureCoordIndex++] = (position.y + rad) / (2 * rad); + } + } + const attributes = new GeometryAttributes_default(); + if (vertexFormat.position) { + attributes.position = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: positions + }); + } + if (vertexFormat.normal) { + attributes.normal = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: normals + }); + } + if (vertexFormat.tangent) { + attributes.tangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: tangents + }); + } + if (vertexFormat.bitangent) { + attributes.bitangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: bitangents + }); + } + if (vertexFormat.st) { + attributes.st = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: st + }); + } + radiusScratch.x = length * 0.5; + radiusScratch.y = Math.max(bottomRadius, topRadius); + const boundingSphere = new BoundingSphere_default( + Cartesian3_default.ZERO, + Cartesian2_default.magnitude(radiusScratch) + ); + if (defined_default(cylinderGeometry._offsetAttribute)) { + length = positions.length; + const offsetValue = cylinderGeometry._offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1; + const applyOffset = new Uint8Array(length / 3).fill(offsetValue); + attributes.applyOffset = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE, + componentsPerAttribute: 1, + values: applyOffset + }); + } + return new Geometry_default({ + attributes, + indices, + primitiveType: PrimitiveType_default.TRIANGLES, + boundingSphere, + offsetAttribute: cylinderGeometry._offsetAttribute + }); +}; +var unitCylinderGeometry; +CylinderGeometry.getUnitCylinder = function() { + if (!defined_default(unitCylinderGeometry)) { + unitCylinderGeometry = CylinderGeometry.createGeometry( + new CylinderGeometry({ + topRadius: 1, + bottomRadius: 1, + length: 1, + vertexFormat: VertexFormat_default.POSITION_ONLY + }) + ); + } + return unitCylinderGeometry; +}; +var CylinderGeometry_default = CylinderGeometry; + +export { + CylinderGeometry_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-TF5D2H7B.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-TF5D2H7B.js new file mode 100644 index 0000000000000000000000000000000000000000..007dc1160889ebeaa2098b6c8f6fbbd815c8a14c --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-TF5D2H7B.js @@ -0,0 +1,138 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + WebGLConstants_default +} from "./chunk-527JG4D7.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/IndexDatatype.js +var IndexDatatype = { + /** + * 8-bit unsigned byte corresponding to UNSIGNED_BYTE and the type + * of an element in Uint8Array. + * + * @type {number} + * @constant + */ + UNSIGNED_BYTE: WebGLConstants_default.UNSIGNED_BYTE, + /** + * 16-bit unsigned short corresponding to UNSIGNED_SHORT and the type + * of an element in Uint16Array. + * + * @type {number} + * @constant + */ + UNSIGNED_SHORT: WebGLConstants_default.UNSIGNED_SHORT, + /** + * 32-bit unsigned int corresponding to UNSIGNED_INT and the type + * of an element in Uint32Array. + * + * @type {number} + * @constant + */ + UNSIGNED_INT: WebGLConstants_default.UNSIGNED_INT +}; +IndexDatatype.getSizeInBytes = function(indexDatatype) { + switch (indexDatatype) { + case IndexDatatype.UNSIGNED_BYTE: + return Uint8Array.BYTES_PER_ELEMENT; + case IndexDatatype.UNSIGNED_SHORT: + return Uint16Array.BYTES_PER_ELEMENT; + case IndexDatatype.UNSIGNED_INT: + return Uint32Array.BYTES_PER_ELEMENT; + } + throw new DeveloperError_default( + "indexDatatype is required and must be a valid IndexDatatype constant." + ); +}; +IndexDatatype.fromSizeInBytes = function(sizeInBytes) { + switch (sizeInBytes) { + case 2: + return IndexDatatype.UNSIGNED_SHORT; + case 4: + return IndexDatatype.UNSIGNED_INT; + case 1: + return IndexDatatype.UNSIGNED_BYTE; + default: + throw new DeveloperError_default( + "Size in bytes cannot be mapped to an IndexDatatype" + ); + } +}; +IndexDatatype.validate = function(indexDatatype) { + return defined_default(indexDatatype) && (indexDatatype === IndexDatatype.UNSIGNED_BYTE || indexDatatype === IndexDatatype.UNSIGNED_SHORT || indexDatatype === IndexDatatype.UNSIGNED_INT); +}; +IndexDatatype.createTypedArray = function(numberOfVertices, indicesLengthOrArray) { + if (!defined_default(numberOfVertices)) { + throw new DeveloperError_default("numberOfVertices is required."); + } + if (numberOfVertices >= Math_default.SIXTY_FOUR_KILOBYTES) { + return new Uint32Array(indicesLengthOrArray); + } + return new Uint16Array(indicesLengthOrArray); +}; +IndexDatatype.createTypedArrayFromArrayBuffer = function(numberOfVertices, sourceArray, byteOffset, length) { + if (!defined_default(numberOfVertices)) { + throw new DeveloperError_default("numberOfVertices is required."); + } + if (!defined_default(sourceArray)) { + throw new DeveloperError_default("sourceArray is required."); + } + if (!defined_default(byteOffset)) { + throw new DeveloperError_default("byteOffset is required."); + } + if (numberOfVertices >= Math_default.SIXTY_FOUR_KILOBYTES) { + return new Uint32Array(sourceArray, byteOffset, length); + } + return new Uint16Array(sourceArray, byteOffset, length); +}; +IndexDatatype.fromTypedArray = function(array) { + if (array instanceof Uint8Array) { + return IndexDatatype.UNSIGNED_BYTE; + } + if (array instanceof Uint16Array) { + return IndexDatatype.UNSIGNED_SHORT; + } + if (array instanceof Uint32Array) { + return IndexDatatype.UNSIGNED_INT; + } + throw new DeveloperError_default( + "array must be a Uint8Array, Uint16Array, or Uint32Array." + ); +}; +var IndexDatatype_default = Object.freeze(IndexDatatype); + +export { + IndexDatatype_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-TVYIHH4V.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-TVYIHH4V.js new file mode 100644 index 0000000000000000000000000000000000000000..b0d480a5466136d8a63e4209c0833ec9faae7cbf --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-TVYIHH4V.js @@ -0,0 +1,513 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + GeometryOffsetAttribute_default +} from "./chunk-A6EA6KIE.js"; +import { + VertexFormat_default +} from "./chunk-2NLMZNJI.js"; +import { + IndexDatatype_default +} from "./chunk-TF5D2H7B.js"; +import { + GeometryAttributes_default +} from "./chunk-N5MMDSD2.js"; +import { + GeometryAttribute_default, + Geometry_default, + PrimitiveType_default +} from "./chunk-UGZGTV5K.js"; +import { + BoundingSphere_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default +} from "./chunk-PW5CA4MJ.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default, + Ellipsoid_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/EllipsoidGeometry.js +var scratchPosition = new Cartesian3_default(); +var scratchNormal = new Cartesian3_default(); +var scratchTangent = new Cartesian3_default(); +var scratchBitangent = new Cartesian3_default(); +var scratchNormalST = new Cartesian3_default(); +var defaultRadii = new Cartesian3_default(1, 1, 1); +var cos = Math.cos; +var sin = Math.sin; +function EllipsoidGeometry(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + const radii = defaultValue_default(options.radii, defaultRadii); + const innerRadii = defaultValue_default(options.innerRadii, radii); + const minimumClock = defaultValue_default(options.minimumClock, 0); + const maximumClock = defaultValue_default(options.maximumClock, Math_default.TWO_PI); + const minimumCone = defaultValue_default(options.minimumCone, 0); + const maximumCone = defaultValue_default(options.maximumCone, Math_default.PI); + const stackPartitions = Math.round(defaultValue_default(options.stackPartitions, 64)); + const slicePartitions = Math.round(defaultValue_default(options.slicePartitions, 64)); + const vertexFormat = defaultValue_default(options.vertexFormat, VertexFormat_default.DEFAULT); + if (slicePartitions < 3) { + throw new DeveloperError_default( + "options.slicePartitions cannot be less than three." + ); + } + if (stackPartitions < 3) { + throw new DeveloperError_default( + "options.stackPartitions cannot be less than three." + ); + } + this._radii = Cartesian3_default.clone(radii); + this._innerRadii = Cartesian3_default.clone(innerRadii); + this._minimumClock = minimumClock; + this._maximumClock = maximumClock; + this._minimumCone = minimumCone; + this._maximumCone = maximumCone; + this._stackPartitions = stackPartitions; + this._slicePartitions = slicePartitions; + this._vertexFormat = VertexFormat_default.clone(vertexFormat); + this._offsetAttribute = options.offsetAttribute; + this._workerName = "createEllipsoidGeometry"; +} +EllipsoidGeometry.packedLength = 2 * Cartesian3_default.packedLength + VertexFormat_default.packedLength + 7; +EllipsoidGeometry.pack = function(value, array, startingIndex) { + if (!defined_default(value)) { + throw new DeveloperError_default("value is required"); + } + if (!defined_default(array)) { + throw new DeveloperError_default("array is required"); + } + startingIndex = defaultValue_default(startingIndex, 0); + Cartesian3_default.pack(value._radii, array, startingIndex); + startingIndex += Cartesian3_default.packedLength; + Cartesian3_default.pack(value._innerRadii, array, startingIndex); + startingIndex += Cartesian3_default.packedLength; + VertexFormat_default.pack(value._vertexFormat, array, startingIndex); + startingIndex += VertexFormat_default.packedLength; + array[startingIndex++] = value._minimumClock; + array[startingIndex++] = value._maximumClock; + array[startingIndex++] = value._minimumCone; + array[startingIndex++] = value._maximumCone; + array[startingIndex++] = value._stackPartitions; + array[startingIndex++] = value._slicePartitions; + array[startingIndex] = defaultValue_default(value._offsetAttribute, -1); + return array; +}; +var scratchRadii = new Cartesian3_default(); +var scratchInnerRadii = new Cartesian3_default(); +var scratchVertexFormat = new VertexFormat_default(); +var scratchOptions = { + radii: scratchRadii, + innerRadii: scratchInnerRadii, + vertexFormat: scratchVertexFormat, + minimumClock: void 0, + maximumClock: void 0, + minimumCone: void 0, + maximumCone: void 0, + stackPartitions: void 0, + slicePartitions: void 0, + offsetAttribute: void 0 +}; +EllipsoidGeometry.unpack = function(array, startingIndex, result) { + if (!defined_default(array)) { + throw new DeveloperError_default("array is required"); + } + startingIndex = defaultValue_default(startingIndex, 0); + const radii = Cartesian3_default.unpack(array, startingIndex, scratchRadii); + startingIndex += Cartesian3_default.packedLength; + const innerRadii = Cartesian3_default.unpack(array, startingIndex, scratchInnerRadii); + startingIndex += Cartesian3_default.packedLength; + const vertexFormat = VertexFormat_default.unpack( + array, + startingIndex, + scratchVertexFormat + ); + startingIndex += VertexFormat_default.packedLength; + const minimumClock = array[startingIndex++]; + const maximumClock = array[startingIndex++]; + const minimumCone = array[startingIndex++]; + const maximumCone = array[startingIndex++]; + const stackPartitions = array[startingIndex++]; + const slicePartitions = array[startingIndex++]; + const offsetAttribute = array[startingIndex]; + if (!defined_default(result)) { + scratchOptions.minimumClock = minimumClock; + scratchOptions.maximumClock = maximumClock; + scratchOptions.minimumCone = minimumCone; + scratchOptions.maximumCone = maximumCone; + scratchOptions.stackPartitions = stackPartitions; + scratchOptions.slicePartitions = slicePartitions; + scratchOptions.offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return new EllipsoidGeometry(scratchOptions); + } + result._radii = Cartesian3_default.clone(radii, result._radii); + result._innerRadii = Cartesian3_default.clone(innerRadii, result._innerRadii); + result._vertexFormat = VertexFormat_default.clone(vertexFormat, result._vertexFormat); + result._minimumClock = minimumClock; + result._maximumClock = maximumClock; + result._minimumCone = minimumCone; + result._maximumCone = maximumCone; + result._stackPartitions = stackPartitions; + result._slicePartitions = slicePartitions; + result._offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute; + return result; +}; +EllipsoidGeometry.createGeometry = function(ellipsoidGeometry) { + const radii = ellipsoidGeometry._radii; + if (radii.x <= 0 || radii.y <= 0 || radii.z <= 0) { + return; + } + const innerRadii = ellipsoidGeometry._innerRadii; + if (innerRadii.x <= 0 || innerRadii.y <= 0 || innerRadii.z <= 0) { + return; + } + const minimumClock = ellipsoidGeometry._minimumClock; + const maximumClock = ellipsoidGeometry._maximumClock; + const minimumCone = ellipsoidGeometry._minimumCone; + const maximumCone = ellipsoidGeometry._maximumCone; + const vertexFormat = ellipsoidGeometry._vertexFormat; + let slicePartitions = ellipsoidGeometry._slicePartitions + 1; + let stackPartitions = ellipsoidGeometry._stackPartitions + 1; + slicePartitions = Math.round( + slicePartitions * Math.abs(maximumClock - minimumClock) / Math_default.TWO_PI + ); + stackPartitions = Math.round( + stackPartitions * Math.abs(maximumCone - minimumCone) / Math_default.PI + ); + if (slicePartitions < 2) { + slicePartitions = 2; + } + if (stackPartitions < 2) { + stackPartitions = 2; + } + let i; + let j; + let index = 0; + const phis = [minimumCone]; + const thetas = [minimumClock]; + for (i = 0; i < stackPartitions; i++) { + phis.push( + minimumCone + i * (maximumCone - minimumCone) / (stackPartitions - 1) + ); + } + phis.push(maximumCone); + for (j = 0; j < slicePartitions; j++) { + thetas.push( + minimumClock + j * (maximumClock - minimumClock) / (slicePartitions - 1) + ); + } + thetas.push(maximumClock); + const numPhis = phis.length; + const numThetas = thetas.length; + let extraIndices = 0; + let vertexMultiplier = 1; + const hasInnerSurface = innerRadii.x !== radii.x || innerRadii.y !== radii.y || innerRadii.z !== radii.z; + let isTopOpen = false; + let isBotOpen = false; + let isClockOpen = false; + if (hasInnerSurface) { + vertexMultiplier = 2; + if (minimumCone > 0) { + isTopOpen = true; + extraIndices += slicePartitions - 1; + } + if (maximumCone < Math.PI) { + isBotOpen = true; + extraIndices += slicePartitions - 1; + } + if ((maximumClock - minimumClock) % Math_default.TWO_PI) { + isClockOpen = true; + extraIndices += (stackPartitions - 1) * 2 + 1; + } else { + extraIndices += 1; + } + } + const vertexCount = numThetas * numPhis * vertexMultiplier; + const positions = new Float64Array(vertexCount * 3); + const isInner = new Array(vertexCount).fill(false); + const negateNormal = new Array(vertexCount).fill(false); + const indexCount = slicePartitions * stackPartitions * vertexMultiplier; + const numIndices = 6 * (indexCount + extraIndices + 1 - (slicePartitions + stackPartitions) * vertexMultiplier); + const indices = IndexDatatype_default.createTypedArray(indexCount, numIndices); + const normals = vertexFormat.normal ? new Float32Array(vertexCount * 3) : void 0; + const tangents = vertexFormat.tangent ? new Float32Array(vertexCount * 3) : void 0; + const bitangents = vertexFormat.bitangent ? new Float32Array(vertexCount * 3) : void 0; + const st = vertexFormat.st ? new Float32Array(vertexCount * 2) : void 0; + const sinPhi = new Array(numPhis); + const cosPhi = new Array(numPhis); + for (i = 0; i < numPhis; i++) { + sinPhi[i] = sin(phis[i]); + cosPhi[i] = cos(phis[i]); + } + const sinTheta = new Array(numThetas); + const cosTheta = new Array(numThetas); + for (j = 0; j < numThetas; j++) { + cosTheta[j] = cos(thetas[j]); + sinTheta[j] = sin(thetas[j]); + } + for (i = 0; i < numPhis; i++) { + for (j = 0; j < numThetas; j++) { + positions[index++] = radii.x * sinPhi[i] * cosTheta[j]; + positions[index++] = radii.y * sinPhi[i] * sinTheta[j]; + positions[index++] = radii.z * cosPhi[i]; + } + } + let vertexIndex = vertexCount / 2; + if (hasInnerSurface) { + for (i = 0; i < numPhis; i++) { + for (j = 0; j < numThetas; j++) { + positions[index++] = innerRadii.x * sinPhi[i] * cosTheta[j]; + positions[index++] = innerRadii.y * sinPhi[i] * sinTheta[j]; + positions[index++] = innerRadii.z * cosPhi[i]; + isInner[vertexIndex] = true; + if (i > 0 && i !== numPhis - 1 && j !== 0 && j !== numThetas - 1) { + negateNormal[vertexIndex] = true; + } + vertexIndex++; + } + } + } + index = 0; + let topOffset; + let bottomOffset; + for (i = 1; i < numPhis - 2; i++) { + topOffset = i * numThetas; + bottomOffset = (i + 1) * numThetas; + for (j = 1; j < numThetas - 2; j++) { + indices[index++] = bottomOffset + j; + indices[index++] = bottomOffset + j + 1; + indices[index++] = topOffset + j + 1; + indices[index++] = bottomOffset + j; + indices[index++] = topOffset + j + 1; + indices[index++] = topOffset + j; + } + } + if (hasInnerSurface) { + const offset = numPhis * numThetas; + for (i = 1; i < numPhis - 2; i++) { + topOffset = offset + i * numThetas; + bottomOffset = offset + (i + 1) * numThetas; + for (j = 1; j < numThetas - 2; j++) { + indices[index++] = bottomOffset + j; + indices[index++] = topOffset + j; + indices[index++] = topOffset + j + 1; + indices[index++] = bottomOffset + j; + indices[index++] = topOffset + j + 1; + indices[index++] = bottomOffset + j + 1; + } + } + } + let outerOffset; + let innerOffset; + if (hasInnerSurface) { + if (isTopOpen) { + innerOffset = numPhis * numThetas; + for (i = 1; i < numThetas - 2; i++) { + indices[index++] = i; + indices[index++] = i + 1; + indices[index++] = innerOffset + i + 1; + indices[index++] = i; + indices[index++] = innerOffset + i + 1; + indices[index++] = innerOffset + i; + } + } + if (isBotOpen) { + outerOffset = numPhis * numThetas - numThetas; + innerOffset = numPhis * numThetas * vertexMultiplier - numThetas; + for (i = 1; i < numThetas - 2; i++) { + indices[index++] = outerOffset + i + 1; + indices[index++] = outerOffset + i; + indices[index++] = innerOffset + i; + indices[index++] = outerOffset + i + 1; + indices[index++] = innerOffset + i; + indices[index++] = innerOffset + i + 1; + } + } + } + if (isClockOpen) { + for (i = 1; i < numPhis - 2; i++) { + innerOffset = numThetas * numPhis + numThetas * i; + outerOffset = numThetas * i; + indices[index++] = innerOffset; + indices[index++] = outerOffset + numThetas; + indices[index++] = outerOffset; + indices[index++] = innerOffset; + indices[index++] = innerOffset + numThetas; + indices[index++] = outerOffset + numThetas; + } + for (i = 1; i < numPhis - 2; i++) { + innerOffset = numThetas * numPhis + numThetas * (i + 1) - 1; + outerOffset = numThetas * (i + 1) - 1; + indices[index++] = outerOffset + numThetas; + indices[index++] = innerOffset; + indices[index++] = outerOffset; + indices[index++] = outerOffset + numThetas; + indices[index++] = innerOffset + numThetas; + indices[index++] = innerOffset; + } + } + const attributes = new GeometryAttributes_default(); + if (vertexFormat.position) { + attributes.position = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: positions + }); + } + let stIndex = 0; + let normalIndex = 0; + let tangentIndex = 0; + let bitangentIndex = 0; + const vertexCountHalf = vertexCount / 2; + let ellipsoid; + const ellipsoidOuter = Ellipsoid_default.fromCartesian3(radii); + const ellipsoidInner = Ellipsoid_default.fromCartesian3(innerRadii); + if (vertexFormat.st || vertexFormat.normal || vertexFormat.tangent || vertexFormat.bitangent) { + for (i = 0; i < vertexCount; i++) { + ellipsoid = isInner[i] ? ellipsoidInner : ellipsoidOuter; + const position = Cartesian3_default.fromArray(positions, i * 3, scratchPosition); + const normal = ellipsoid.geodeticSurfaceNormal(position, scratchNormal); + if (negateNormal[i]) { + Cartesian3_default.negate(normal, normal); + } + if (vertexFormat.st) { + const normalST = Cartesian2_default.negate(normal, scratchNormalST); + st[stIndex++] = Math.atan2(normalST.y, normalST.x) / Math_default.TWO_PI + 0.5; + st[stIndex++] = Math.asin(normal.z) / Math.PI + 0.5; + } + if (vertexFormat.normal) { + normals[normalIndex++] = normal.x; + normals[normalIndex++] = normal.y; + normals[normalIndex++] = normal.z; + } + if (vertexFormat.tangent || vertexFormat.bitangent) { + const tangent = scratchTangent; + let tangetOffset = 0; + let unit; + if (isInner[i]) { + tangetOffset = vertexCountHalf; + } + if (!isTopOpen && i >= tangetOffset && i < tangetOffset + numThetas * 2) { + unit = Cartesian3_default.UNIT_X; + } else { + unit = Cartesian3_default.UNIT_Z; + } + Cartesian3_default.cross(unit, normal, tangent); + Cartesian3_default.normalize(tangent, tangent); + if (vertexFormat.tangent) { + tangents[tangentIndex++] = tangent.x; + tangents[tangentIndex++] = tangent.y; + tangents[tangentIndex++] = tangent.z; + } + if (vertexFormat.bitangent) { + const bitangent = Cartesian3_default.cross(normal, tangent, scratchBitangent); + Cartesian3_default.normalize(bitangent, bitangent); + bitangents[bitangentIndex++] = bitangent.x; + bitangents[bitangentIndex++] = bitangent.y; + bitangents[bitangentIndex++] = bitangent.z; + } + } + } + if (vertexFormat.st) { + attributes.st = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: st + }); + } + if (vertexFormat.normal) { + attributes.normal = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: normals + }); + } + if (vertexFormat.tangent) { + attributes.tangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: tangents + }); + } + if (vertexFormat.bitangent) { + attributes.bitangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: bitangents + }); + } + } + if (defined_default(ellipsoidGeometry._offsetAttribute)) { + const length = positions.length; + const offsetValue = ellipsoidGeometry._offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1; + const applyOffset = new Uint8Array(length / 3).fill(offsetValue); + attributes.applyOffset = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE, + componentsPerAttribute: 1, + values: applyOffset + }); + } + return new Geometry_default({ + attributes, + indices, + primitiveType: PrimitiveType_default.TRIANGLES, + boundingSphere: BoundingSphere_default.fromEllipsoid(ellipsoidOuter), + offsetAttribute: ellipsoidGeometry._offsetAttribute + }); +}; +var unitEllipsoidGeometry; +EllipsoidGeometry.getUnitEllipsoid = function() { + if (!defined_default(unitEllipsoidGeometry)) { + unitEllipsoidGeometry = EllipsoidGeometry.createGeometry( + new EllipsoidGeometry({ + radii: new Cartesian3_default(1, 1, 1), + vertexFormat: VertexFormat_default.POSITION_ONLY + }) + ); + } + return unitEllipsoidGeometry; +}; +var EllipsoidGeometry_default = EllipsoidGeometry; + +export { + EllipsoidGeometry_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-U5LKG6LX.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-U5LKG6LX.js new file mode 100644 index 0000000000000000000000000000000000000000..de6f8bb91557fbc582644f124e64f783a85abd17 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-U5LKG6LX.js @@ -0,0 +1,101 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/formatError.js +function formatError(object) { + let result; + const name = object.name; + const message = object.message; + if (defined_default(name) && defined_default(message)) { + result = `${name}: ${message}`; + } else { + result = object.toString(); + } + const stack = object.stack; + if (defined_default(stack)) { + result += ` +${stack}`; + } + return result; +} +var formatError_default = formatError; + +// packages/engine/Source/Workers/createTaskProcessorWorker.js +function createTaskProcessorWorker(workerFunction) { + async function onMessageHandler({ data }) { + const transferableObjects = []; + const responseMessage = { + id: data.id, + result: void 0, + error: void 0 + }; + self.CESIUM_BASE_URL = data.baseUrl; + try { + const result = await workerFunction(data.parameters, transferableObjects); + responseMessage.result = result; + } catch (error) { + if (error instanceof Error) { + responseMessage.error = { + name: error.name, + message: error.message, + stack: error.stack + }; + } else { + responseMessage.error = error; + } + } + if (!data.canTransferArrayBuffer) { + transferableObjects.length = 0; + } + try { + postMessage(responseMessage, transferableObjects); + } catch (error) { + responseMessage.result = void 0; + responseMessage.error = `postMessage failed with error: ${formatError_default( + error + )} + with responseMessage: ${JSON.stringify(responseMessage)}`; + postMessage(responseMessage); + } + } + function onMessageErrorHandler(event) { + postMessage({ + id: event.data?.id, + error: `postMessage failed with error: ${JSON.stringify(event)}` + }); + } + self.onmessage = onMessageHandler; + self.onmessageerror = onMessageErrorHandler; + return self; +} +var createTaskProcessorWorker_default = createTaskProcessorWorker; + +export { + createTaskProcessorWorker_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-UGZGTV5K.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-UGZGTV5K.js new file mode 100644 index 0000000000000000000000000000000000000000..6545246767d0cc9ee8434af140d67fde51641f4f --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-UGZGTV5K.js @@ -0,0 +1,302 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Quaternion_default, + Transforms_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default, + Matrix2_default, + Matrix4_default, + Rectangle_default +} from "./chunk-PW5CA4MJ.js"; +import { + Cartesian3_default, + Cartographic_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + WebGLConstants_default +} from "./chunk-527JG4D7.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/GeometryType.js +var GeometryType = { + NONE: 0, + TRIANGLES: 1, + LINES: 2, + POLYLINES: 3 +}; +var GeometryType_default = Object.freeze(GeometryType); + +// packages/engine/Source/Core/PrimitiveType.js +var PrimitiveType = { + /** + * Points primitive where each vertex (or index) is a separate point. + * + * @type {number} + * @constant + */ + POINTS: WebGLConstants_default.POINTS, + /** + * Lines primitive where each two vertices (or indices) is a line segment. Line segments are not necessarily connected. + * + * @type {number} + * @constant + */ + LINES: WebGLConstants_default.LINES, + /** + * Line loop primitive where each vertex (or index) after the first connects a line to + * the previous vertex, and the last vertex implicitly connects to the first. + * + * @type {number} + * @constant + */ + LINE_LOOP: WebGLConstants_default.LINE_LOOP, + /** + * Line strip primitive where each vertex (or index) after the first connects a line to the previous vertex. + * + * @type {number} + * @constant + */ + LINE_STRIP: WebGLConstants_default.LINE_STRIP, + /** + * Triangles primitive where each three vertices (or indices) is a triangle. Triangles do not necessarily share edges. + * + * @type {number} + * @constant + */ + TRIANGLES: WebGLConstants_default.TRIANGLES, + /** + * Triangle strip primitive where each vertex (or index) after the first two connect to + * the previous two vertices forming a triangle. For example, this can be used to model a wall. + * + * @type {number} + * @constant + */ + TRIANGLE_STRIP: WebGLConstants_default.TRIANGLE_STRIP, + /** + * Triangle fan primitive where each vertex (or index) after the first two connect to + * the previous vertex and the first vertex forming a triangle. For example, this can be used + * to model a cone or circle. + * + * @type {number} + * @constant + */ + TRIANGLE_FAN: WebGLConstants_default.TRIANGLE_FAN +}; +PrimitiveType.isLines = function(primitiveType) { + return primitiveType === PrimitiveType.LINES || primitiveType === PrimitiveType.LINE_LOOP || primitiveType === PrimitiveType.LINE_STRIP; +}; +PrimitiveType.isTriangles = function(primitiveType) { + return primitiveType === PrimitiveType.TRIANGLES || primitiveType === PrimitiveType.TRIANGLE_STRIP || primitiveType === PrimitiveType.TRIANGLE_FAN; +}; +PrimitiveType.validate = function(primitiveType) { + return primitiveType === PrimitiveType.POINTS || primitiveType === PrimitiveType.LINES || primitiveType === PrimitiveType.LINE_LOOP || primitiveType === PrimitiveType.LINE_STRIP || primitiveType === PrimitiveType.TRIANGLES || primitiveType === PrimitiveType.TRIANGLE_STRIP || primitiveType === PrimitiveType.TRIANGLE_FAN; +}; +var PrimitiveType_default = Object.freeze(PrimitiveType); + +// packages/engine/Source/Core/Geometry.js +function Geometry(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + Check_default.typeOf.object("options.attributes", options.attributes); + this.attributes = options.attributes; + this.indices = options.indices; + this.primitiveType = defaultValue_default( + options.primitiveType, + PrimitiveType_default.TRIANGLES + ); + this.boundingSphere = options.boundingSphere; + this.geometryType = defaultValue_default(options.geometryType, GeometryType_default.NONE); + this.boundingSphereCV = options.boundingSphereCV; + this.offsetAttribute = options.offsetAttribute; +} +Geometry.computeNumberOfVertices = function(geometry) { + Check_default.typeOf.object("geometry", geometry); + let numberOfVertices = -1; + for (const property in geometry.attributes) { + if (geometry.attributes.hasOwnProperty(property) && defined_default(geometry.attributes[property]) && defined_default(geometry.attributes[property].values)) { + const attribute = geometry.attributes[property]; + const num = attribute.values.length / attribute.componentsPerAttribute; + if (numberOfVertices !== num && numberOfVertices !== -1) { + throw new DeveloperError_default( + "All attribute lists must have the same number of attributes." + ); + } + numberOfVertices = num; + } + } + return numberOfVertices; +}; +var rectangleCenterScratch = new Cartographic_default(); +var enuCenterScratch = new Cartesian3_default(); +var fixedFrameToEnuScratch = new Matrix4_default(); +var boundingRectanglePointsCartographicScratch = [ + new Cartographic_default(), + new Cartographic_default(), + new Cartographic_default() +]; +var boundingRectanglePointsEnuScratch = [ + new Cartesian2_default(), + new Cartesian2_default(), + new Cartesian2_default() +]; +var points2DScratch = [new Cartesian2_default(), new Cartesian2_default(), new Cartesian2_default()]; +var pointEnuScratch = new Cartesian3_default(); +var enuRotationScratch = new Quaternion_default(); +var enuRotationMatrixScratch = new Matrix4_default(); +var rotation2DScratch = new Matrix2_default(); +Geometry._textureCoordinateRotationPoints = function(positions, stRotation, ellipsoid, boundingRectangle) { + let i; + const rectangleCenter = Rectangle_default.center( + boundingRectangle, + rectangleCenterScratch + ); + const enuCenter = Cartographic_default.toCartesian( + rectangleCenter, + ellipsoid, + enuCenterScratch + ); + const enuToFixedFrame = Transforms_default.eastNorthUpToFixedFrame( + enuCenter, + ellipsoid, + fixedFrameToEnuScratch + ); + const fixedFrameToEnu = Matrix4_default.inverse( + enuToFixedFrame, + fixedFrameToEnuScratch + ); + const boundingPointsEnu = boundingRectanglePointsEnuScratch; + const boundingPointsCarto = boundingRectanglePointsCartographicScratch; + boundingPointsCarto[0].longitude = boundingRectangle.west; + boundingPointsCarto[0].latitude = boundingRectangle.south; + boundingPointsCarto[1].longitude = boundingRectangle.west; + boundingPointsCarto[1].latitude = boundingRectangle.north; + boundingPointsCarto[2].longitude = boundingRectangle.east; + boundingPointsCarto[2].latitude = boundingRectangle.south; + let posEnu = pointEnuScratch; + for (i = 0; i < 3; i++) { + Cartographic_default.toCartesian(boundingPointsCarto[i], ellipsoid, posEnu); + posEnu = Matrix4_default.multiplyByPointAsVector(fixedFrameToEnu, posEnu, posEnu); + boundingPointsEnu[i].x = posEnu.x; + boundingPointsEnu[i].y = posEnu.y; + } + const rotation = Quaternion_default.fromAxisAngle( + Cartesian3_default.UNIT_Z, + -stRotation, + enuRotationScratch + ); + const textureMatrix = Matrix3_default.fromQuaternion( + rotation, + enuRotationMatrixScratch + ); + const positionsLength = positions.length; + let enuMinX = Number.POSITIVE_INFINITY; + let enuMinY = Number.POSITIVE_INFINITY; + let enuMaxX = Number.NEGATIVE_INFINITY; + let enuMaxY = Number.NEGATIVE_INFINITY; + for (i = 0; i < positionsLength; i++) { + posEnu = Matrix4_default.multiplyByPointAsVector( + fixedFrameToEnu, + positions[i], + posEnu + ); + posEnu = Matrix3_default.multiplyByVector(textureMatrix, posEnu, posEnu); + enuMinX = Math.min(enuMinX, posEnu.x); + enuMinY = Math.min(enuMinY, posEnu.y); + enuMaxX = Math.max(enuMaxX, posEnu.x); + enuMaxY = Math.max(enuMaxY, posEnu.y); + } + const toDesiredInComputed = Matrix2_default.fromRotation( + stRotation, + rotation2DScratch + ); + const points2D = points2DScratch; + points2D[0].x = enuMinX; + points2D[0].y = enuMinY; + points2D[1].x = enuMinX; + points2D[1].y = enuMaxY; + points2D[2].x = enuMaxX; + points2D[2].y = enuMinY; + const boundingEnuMin = boundingPointsEnu[0]; + const boundingPointsWidth = boundingPointsEnu[2].x - boundingEnuMin.x; + const boundingPointsHeight = boundingPointsEnu[1].y - boundingEnuMin.y; + for (i = 0; i < 3; i++) { + const point2D = points2D[i]; + Matrix2_default.multiplyByVector(toDesiredInComputed, point2D, point2D); + point2D.x = (point2D.x - boundingEnuMin.x) / boundingPointsWidth; + point2D.y = (point2D.y - boundingEnuMin.y) / boundingPointsHeight; + } + const minXYCorner = points2D[0]; + const maxYCorner = points2D[1]; + const maxXCorner = points2D[2]; + const result = new Array(6); + Cartesian2_default.pack(minXYCorner, result); + Cartesian2_default.pack(maxYCorner, result, 2); + Cartesian2_default.pack(maxXCorner, result, 4); + return result; +}; +var Geometry_default = Geometry; + +// packages/engine/Source/Core/GeometryAttribute.js +function GeometryAttribute(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + if (!defined_default(options.componentDatatype)) { + throw new DeveloperError_default("options.componentDatatype is required."); + } + if (!defined_default(options.componentsPerAttribute)) { + throw new DeveloperError_default("options.componentsPerAttribute is required."); + } + if (options.componentsPerAttribute < 1 || options.componentsPerAttribute > 4) { + throw new DeveloperError_default( + "options.componentsPerAttribute must be between 1 and 4." + ); + } + if (!defined_default(options.values)) { + throw new DeveloperError_default("options.values is required."); + } + this.componentDatatype = options.componentDatatype; + this.componentsPerAttribute = options.componentsPerAttribute; + this.normalize = defaultValue_default(options.normalize, false); + this.values = options.values; +} +var GeometryAttribute_default = GeometryAttribute; + +export { + GeometryType_default, + PrimitiveType_default, + Geometry_default, + GeometryAttribute_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-UN7AK64D.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-UN7AK64D.js new file mode 100644 index 0000000000000000000000000000000000000000..01c5fac2732e28eb4e52f86b51e9966701709340 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-UN7AK64D.js @@ -0,0 +1,163 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/DeveloperError.js +function DeveloperError(message) { + this.name = "DeveloperError"; + this.message = message; + let stack; + try { + throw new Error(); + } catch (e) { + stack = e.stack; + } + this.stack = stack; +} +if (defined_default(Object.create)) { + DeveloperError.prototype = Object.create(Error.prototype); + DeveloperError.prototype.constructor = DeveloperError; +} +DeveloperError.prototype.toString = function() { + let str = `${this.name}: ${this.message}`; + if (defined_default(this.stack)) { + str += ` +${this.stack.toString()}`; + } + return str; +}; +DeveloperError.throwInstantiationError = function() { + throw new DeveloperError( + "This function defines an interface and should not be called directly." + ); +}; +var DeveloperError_default = DeveloperError; + +// packages/engine/Source/Core/Check.js +var Check = {}; +Check.typeOf = {}; +function getUndefinedErrorMessage(name) { + return `${name} is required, actual value was undefined`; +} +function getFailedTypeErrorMessage(actual, expected, name) { + return `Expected ${name} to be typeof ${expected}, actual typeof was ${actual}`; +} +Check.defined = function(name, test) { + if (!defined_default(test)) { + throw new DeveloperError_default(getUndefinedErrorMessage(name)); + } +}; +Check.typeOf.func = function(name, test) { + if (typeof test !== "function") { + throw new DeveloperError_default( + getFailedTypeErrorMessage(typeof test, "function", name) + ); + } +}; +Check.typeOf.string = function(name, test) { + if (typeof test !== "string") { + throw new DeveloperError_default( + getFailedTypeErrorMessage(typeof test, "string", name) + ); + } +}; +Check.typeOf.number = function(name, test) { + if (typeof test !== "number") { + throw new DeveloperError_default( + getFailedTypeErrorMessage(typeof test, "number", name) + ); + } +}; +Check.typeOf.number.lessThan = function(name, test, limit) { + Check.typeOf.number(name, test); + if (test >= limit) { + throw new DeveloperError_default( + `Expected ${name} to be less than ${limit}, actual value was ${test}` + ); + } +}; +Check.typeOf.number.lessThanOrEquals = function(name, test, limit) { + Check.typeOf.number(name, test); + if (test > limit) { + throw new DeveloperError_default( + `Expected ${name} to be less than or equal to ${limit}, actual value was ${test}` + ); + } +}; +Check.typeOf.number.greaterThan = function(name, test, limit) { + Check.typeOf.number(name, test); + if (test <= limit) { + throw new DeveloperError_default( + `Expected ${name} to be greater than ${limit}, actual value was ${test}` + ); + } +}; +Check.typeOf.number.greaterThanOrEquals = function(name, test, limit) { + Check.typeOf.number(name, test); + if (test < limit) { + throw new DeveloperError_default( + `Expected ${name} to be greater than or equal to ${limit}, actual value was ${test}` + ); + } +}; +Check.typeOf.object = function(name, test) { + if (typeof test !== "object") { + throw new DeveloperError_default( + getFailedTypeErrorMessage(typeof test, "object", name) + ); + } +}; +Check.typeOf.bool = function(name, test) { + if (typeof test !== "boolean") { + throw new DeveloperError_default( + getFailedTypeErrorMessage(typeof test, "boolean", name) + ); + } +}; +Check.typeOf.bigint = function(name, test) { + if (typeof test !== "bigint") { + throw new DeveloperError_default( + getFailedTypeErrorMessage(typeof test, "bigint", name) + ); + } +}; +Check.typeOf.number.equals = function(name1, name2, test1, test2) { + Check.typeOf.number(name1, test1); + Check.typeOf.number(name2, test2); + if (test1 !== test2) { + throw new DeveloperError_default( + `${name1} must be equal to ${name2}, the actual values are ${test1} and ${test2}` + ); + } +}; +var Check_default = Check; + +export { + DeveloperError_default, + Check_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-V2LKNJGT.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-V2LKNJGT.js new file mode 100644 index 0000000000000000000000000000000000000000..84a685e07ae086768afbe6c58c52f467265b5adc --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-V2LKNJGT.js @@ -0,0 +1,59 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Matrix4_default +} from "./chunk-PW5CA4MJ.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/GeometryInstance.js +function GeometryInstance(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + if (!defined_default(options.geometry)) { + throw new DeveloperError_default("options.geometry is required."); + } + this.geometry = options.geometry; + this.modelMatrix = Matrix4_default.clone( + defaultValue_default(options.modelMatrix, Matrix4_default.IDENTITY) + ); + this.id = options.id; + this.pickPrimitive = options.pickPrimitive; + this.attributes = defaultValue_default(options.attributes, {}); + this.westHemisphereGeometry = void 0; + this.eastHemisphereGeometry = void 0; +} +var GeometryInstance_default = GeometryInstance; + +export { + GeometryInstance_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-VSCXSFHE.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-VSCXSFHE.js new file mode 100644 index 0000000000000000000000000000000000000000..ac77da0d01d873d8a96472a212afb3a303a90dbd --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-VSCXSFHE.js @@ -0,0 +1,1477 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + VertexFormat_default +} from "./chunk-2NLMZNJI.js"; +import { + Plane_default +} from "./chunk-PGB3EFR7.js"; +import { + GeometryAttributes_default +} from "./chunk-N5MMDSD2.js"; +import { + GeometryAttribute_default, + Geometry_default, + PrimitiveType_default +} from "./chunk-UGZGTV5K.js"; +import { + BoundingSphere_default, + Intersect_default, + Quaternion_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian4_default, + Matrix4_default +} from "./chunk-PW5CA4MJ.js"; +import { + ComponentDatatype_default +} from "./chunk-KAFF2QX3.js"; +import { + Cartesian3_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/CullingVolume.js +function CullingVolume(planes) { + this.planes = defaultValue_default(planes, []); +} +var faces = [new Cartesian3_default(), new Cartesian3_default(), new Cartesian3_default()]; +Cartesian3_default.clone(Cartesian3_default.UNIT_X, faces[0]); +Cartesian3_default.clone(Cartesian3_default.UNIT_Y, faces[1]); +Cartesian3_default.clone(Cartesian3_default.UNIT_Z, faces[2]); +var scratchPlaneCenter = new Cartesian3_default(); +var scratchPlaneNormal = new Cartesian3_default(); +var scratchPlane = new Plane_default(new Cartesian3_default(1, 0, 0), 0); +CullingVolume.fromBoundingSphere = function(boundingSphere, result) { + if (!defined_default(boundingSphere)) { + throw new DeveloperError_default("boundingSphere is required."); + } + if (!defined_default(result)) { + result = new CullingVolume(); + } + const length = faces.length; + const planes = result.planes; + planes.length = 2 * length; + const center = boundingSphere.center; + const radius = boundingSphere.radius; + let planeIndex = 0; + for (let i = 0; i < length; ++i) { + const faceNormal = faces[i]; + let plane0 = planes[planeIndex]; + let plane1 = planes[planeIndex + 1]; + if (!defined_default(plane0)) { + plane0 = planes[planeIndex] = new Cartesian4_default(); + } + if (!defined_default(plane1)) { + plane1 = planes[planeIndex + 1] = new Cartesian4_default(); + } + Cartesian3_default.multiplyByScalar(faceNormal, -radius, scratchPlaneCenter); + Cartesian3_default.add(center, scratchPlaneCenter, scratchPlaneCenter); + plane0.x = faceNormal.x; + plane0.y = faceNormal.y; + plane0.z = faceNormal.z; + plane0.w = -Cartesian3_default.dot(faceNormal, scratchPlaneCenter); + Cartesian3_default.multiplyByScalar(faceNormal, radius, scratchPlaneCenter); + Cartesian3_default.add(center, scratchPlaneCenter, scratchPlaneCenter); + plane1.x = -faceNormal.x; + plane1.y = -faceNormal.y; + plane1.z = -faceNormal.z; + plane1.w = -Cartesian3_default.dot( + Cartesian3_default.negate(faceNormal, scratchPlaneNormal), + scratchPlaneCenter + ); + planeIndex += 2; + } + return result; +}; +CullingVolume.prototype.computeVisibility = function(boundingVolume) { + if (!defined_default(boundingVolume)) { + throw new DeveloperError_default("boundingVolume is required."); + } + const planes = this.planes; + let intersecting = false; + for (let k = 0, len = planes.length; k < len; ++k) { + const result = boundingVolume.intersectPlane( + Plane_default.fromCartesian4(planes[k], scratchPlane) + ); + if (result === Intersect_default.OUTSIDE) { + return Intersect_default.OUTSIDE; + } else if (result === Intersect_default.INTERSECTING) { + intersecting = true; + } + } + return intersecting ? Intersect_default.INTERSECTING : Intersect_default.INSIDE; +}; +CullingVolume.prototype.computeVisibilityWithPlaneMask = function(boundingVolume, parentPlaneMask) { + if (!defined_default(boundingVolume)) { + throw new DeveloperError_default("boundingVolume is required."); + } + if (!defined_default(parentPlaneMask)) { + throw new DeveloperError_default("parentPlaneMask is required."); + } + if (parentPlaneMask === CullingVolume.MASK_OUTSIDE || parentPlaneMask === CullingVolume.MASK_INSIDE) { + return parentPlaneMask; + } + let mask = CullingVolume.MASK_INSIDE; + const planes = this.planes; + for (let k = 0, len = planes.length; k < len; ++k) { + const flag = k < 31 ? 1 << k : 0; + if (k < 31 && (parentPlaneMask & flag) === 0) { + continue; + } + const result = boundingVolume.intersectPlane( + Plane_default.fromCartesian4(planes[k], scratchPlane) + ); + if (result === Intersect_default.OUTSIDE) { + return CullingVolume.MASK_OUTSIDE; + } else if (result === Intersect_default.INTERSECTING) { + mask |= flag; + } + } + return mask; +}; +CullingVolume.MASK_OUTSIDE = 4294967295; +CullingVolume.MASK_INSIDE = 0; +CullingVolume.MASK_INDETERMINATE = 2147483647; +var CullingVolume_default = CullingVolume; + +// packages/engine/Source/Core/OrthographicOffCenterFrustum.js +function OrthographicOffCenterFrustum(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + this.left = options.left; + this._left = void 0; + this.right = options.right; + this._right = void 0; + this.top = options.top; + this._top = void 0; + this.bottom = options.bottom; + this._bottom = void 0; + this.near = defaultValue_default(options.near, 1); + this._near = this.near; + this.far = defaultValue_default(options.far, 5e8); + this._far = this.far; + this._cullingVolume = new CullingVolume_default(); + this._orthographicMatrix = new Matrix4_default(); +} +function update(frustum) { + if (!defined_default(frustum.right) || !defined_default(frustum.left) || !defined_default(frustum.top) || !defined_default(frustum.bottom) || !defined_default(frustum.near) || !defined_default(frustum.far)) { + throw new DeveloperError_default( + "right, left, top, bottom, near, or far parameters are not set." + ); + } + if (frustum.top !== frustum._top || frustum.bottom !== frustum._bottom || frustum.left !== frustum._left || frustum.right !== frustum._right || frustum.near !== frustum._near || frustum.far !== frustum._far) { + if (frustum.left > frustum.right) { + throw new DeveloperError_default("right must be greater than left."); + } + if (frustum.bottom > frustum.top) { + throw new DeveloperError_default("top must be greater than bottom."); + } + if (frustum.near <= 0 || frustum.near > frustum.far) { + throw new DeveloperError_default( + "near must be greater than zero and less than far." + ); + } + frustum._left = frustum.left; + frustum._right = frustum.right; + frustum._top = frustum.top; + frustum._bottom = frustum.bottom; + frustum._near = frustum.near; + frustum._far = frustum.far; + frustum._orthographicMatrix = Matrix4_default.computeOrthographicOffCenter( + frustum.left, + frustum.right, + frustum.bottom, + frustum.top, + frustum.near, + frustum.far, + frustum._orthographicMatrix + ); + } +} +Object.defineProperties(OrthographicOffCenterFrustum.prototype, { + /** + * Gets the orthographic projection matrix computed from the view frustum. + * @memberof OrthographicOffCenterFrustum.prototype + * @type {Matrix4} + * @readonly + */ + projectionMatrix: { + get: function() { + update(this); + return this._orthographicMatrix; + } + } +}); +var getPlanesRight = new Cartesian3_default(); +var getPlanesNearCenter = new Cartesian3_default(); +var getPlanesPoint = new Cartesian3_default(); +var negateScratch = new Cartesian3_default(); +OrthographicOffCenterFrustum.prototype.computeCullingVolume = function(position, direction, up) { + if (!defined_default(position)) { + throw new DeveloperError_default("position is required."); + } + if (!defined_default(direction)) { + throw new DeveloperError_default("direction is required."); + } + if (!defined_default(up)) { + throw new DeveloperError_default("up is required."); + } + const planes = this._cullingVolume.planes; + const t = this.top; + const b = this.bottom; + const r = this.right; + const l = this.left; + const n = this.near; + const f = this.far; + const right = Cartesian3_default.cross(direction, up, getPlanesRight); + Cartesian3_default.normalize(right, right); + const nearCenter = getPlanesNearCenter; + Cartesian3_default.multiplyByScalar(direction, n, nearCenter); + Cartesian3_default.add(position, nearCenter, nearCenter); + const point = getPlanesPoint; + Cartesian3_default.multiplyByScalar(right, l, point); + Cartesian3_default.add(nearCenter, point, point); + let plane = planes[0]; + if (!defined_default(plane)) { + plane = planes[0] = new Cartesian4_default(); + } + plane.x = right.x; + plane.y = right.y; + plane.z = right.z; + plane.w = -Cartesian3_default.dot(right, point); + Cartesian3_default.multiplyByScalar(right, r, point); + Cartesian3_default.add(nearCenter, point, point); + plane = planes[1]; + if (!defined_default(plane)) { + plane = planes[1] = new Cartesian4_default(); + } + plane.x = -right.x; + plane.y = -right.y; + plane.z = -right.z; + plane.w = -Cartesian3_default.dot(Cartesian3_default.negate(right, negateScratch), point); + Cartesian3_default.multiplyByScalar(up, b, point); + Cartesian3_default.add(nearCenter, point, point); + plane = planes[2]; + if (!defined_default(plane)) { + plane = planes[2] = new Cartesian4_default(); + } + plane.x = up.x; + plane.y = up.y; + plane.z = up.z; + plane.w = -Cartesian3_default.dot(up, point); + Cartesian3_default.multiplyByScalar(up, t, point); + Cartesian3_default.add(nearCenter, point, point); + plane = planes[3]; + if (!defined_default(plane)) { + plane = planes[3] = new Cartesian4_default(); + } + plane.x = -up.x; + plane.y = -up.y; + plane.z = -up.z; + plane.w = -Cartesian3_default.dot(Cartesian3_default.negate(up, negateScratch), point); + plane = planes[4]; + if (!defined_default(plane)) { + plane = planes[4] = new Cartesian4_default(); + } + plane.x = direction.x; + plane.y = direction.y; + plane.z = direction.z; + plane.w = -Cartesian3_default.dot(direction, nearCenter); + Cartesian3_default.multiplyByScalar(direction, f, point); + Cartesian3_default.add(position, point, point); + plane = planes[5]; + if (!defined_default(plane)) { + plane = planes[5] = new Cartesian4_default(); + } + plane.x = -direction.x; + plane.y = -direction.y; + plane.z = -direction.z; + plane.w = -Cartesian3_default.dot(Cartesian3_default.negate(direction, negateScratch), point); + return this._cullingVolume; +}; +OrthographicOffCenterFrustum.prototype.getPixelDimensions = function(drawingBufferWidth, drawingBufferHeight, distance, pixelRatio, result) { + update(this); + if (!defined_default(drawingBufferWidth) || !defined_default(drawingBufferHeight)) { + throw new DeveloperError_default( + "Both drawingBufferWidth and drawingBufferHeight are required." + ); + } + if (drawingBufferWidth <= 0) { + throw new DeveloperError_default("drawingBufferWidth must be greater than zero."); + } + if (drawingBufferHeight <= 0) { + throw new DeveloperError_default("drawingBufferHeight must be greater than zero."); + } + if (!defined_default(distance)) { + throw new DeveloperError_default("distance is required."); + } + if (!defined_default(pixelRatio)) { + throw new DeveloperError_default("pixelRatio is required."); + } + if (pixelRatio <= 0) { + throw new DeveloperError_default("pixelRatio must be greater than zero."); + } + if (!defined_default(result)) { + throw new DeveloperError_default("A result object is required."); + } + const frustumWidth = this.right - this.left; + const frustumHeight = this.top - this.bottom; + const pixelWidth = pixelRatio * frustumWidth / drawingBufferWidth; + const pixelHeight = pixelRatio * frustumHeight / drawingBufferHeight; + result.x = pixelWidth; + result.y = pixelHeight; + return result; +}; +OrthographicOffCenterFrustum.prototype.clone = function(result) { + if (!defined_default(result)) { + result = new OrthographicOffCenterFrustum(); + } + result.left = this.left; + result.right = this.right; + result.top = this.top; + result.bottom = this.bottom; + result.near = this.near; + result.far = this.far; + result._left = void 0; + result._right = void 0; + result._top = void 0; + result._bottom = void 0; + result._near = void 0; + result._far = void 0; + return result; +}; +OrthographicOffCenterFrustum.prototype.equals = function(other) { + return defined_default(other) && other instanceof OrthographicOffCenterFrustum && this.right === other.right && this.left === other.left && this.top === other.top && this.bottom === other.bottom && this.near === other.near && this.far === other.far; +}; +OrthographicOffCenterFrustum.prototype.equalsEpsilon = function(other, relativeEpsilon, absoluteEpsilon) { + return other === this || defined_default(other) && other instanceof OrthographicOffCenterFrustum && Math_default.equalsEpsilon( + this.right, + other.right, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.left, + other.left, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.top, + other.top, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.bottom, + other.bottom, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.near, + other.near, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.far, + other.far, + relativeEpsilon, + absoluteEpsilon + ); +}; +var OrthographicOffCenterFrustum_default = OrthographicOffCenterFrustum; + +// packages/engine/Source/Core/OrthographicFrustum.js +function OrthographicFrustum(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + this._offCenterFrustum = new OrthographicOffCenterFrustum_default(); + this.width = options.width; + this._width = void 0; + this.aspectRatio = options.aspectRatio; + this._aspectRatio = void 0; + this.near = defaultValue_default(options.near, 1); + this._near = this.near; + this.far = defaultValue_default(options.far, 5e8); + this._far = this.far; +} +OrthographicFrustum.packedLength = 4; +OrthographicFrustum.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value.width; + array[startingIndex++] = value.aspectRatio; + array[startingIndex++] = value.near; + array[startingIndex] = value.far; + return array; +}; +OrthographicFrustum.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new OrthographicFrustum(); + } + result.width = array[startingIndex++]; + result.aspectRatio = array[startingIndex++]; + result.near = array[startingIndex++]; + result.far = array[startingIndex]; + return result; +}; +function update2(frustum) { + if (!defined_default(frustum.width) || !defined_default(frustum.aspectRatio) || !defined_default(frustum.near) || !defined_default(frustum.far)) { + throw new DeveloperError_default( + "width, aspectRatio, near, or far parameters are not set." + ); + } + const f = frustum._offCenterFrustum; + if (frustum.width !== frustum._width || frustum.aspectRatio !== frustum._aspectRatio || frustum.near !== frustum._near || frustum.far !== frustum._far) { + if (frustum.aspectRatio < 0) { + throw new DeveloperError_default("aspectRatio must be positive."); + } + if (frustum.near < 0 || frustum.near > frustum.far) { + throw new DeveloperError_default( + "near must be greater than zero and less than far." + ); + } + frustum._aspectRatio = frustum.aspectRatio; + frustum._width = frustum.width; + frustum._near = frustum.near; + frustum._far = frustum.far; + const ratio = 1 / frustum.aspectRatio; + f.right = frustum.width * 0.5; + f.left = -f.right; + f.top = ratio * f.right; + f.bottom = -f.top; + f.near = frustum.near; + f.far = frustum.far; + } +} +Object.defineProperties(OrthographicFrustum.prototype, { + /** + * Gets the orthographic projection matrix computed from the view frustum. + * @memberof OrthographicFrustum.prototype + * @type {Matrix4} + * @readonly + */ + projectionMatrix: { + get: function() { + update2(this); + return this._offCenterFrustum.projectionMatrix; + } + }, + /** + * Gets the orthographic projection matrix computed from the view frustum. + * @memberof OrthographicFrustum.prototype + * @type {OrthographicOffCenterFrustum} + * @readonly + * @private + */ + offCenterFrustum: { + get: function() { + update2(this); + return this._offCenterFrustum; + } + } +}); +OrthographicFrustum.prototype.computeCullingVolume = function(position, direction, up) { + update2(this); + return this._offCenterFrustum.computeCullingVolume(position, direction, up); +}; +OrthographicFrustum.prototype.getPixelDimensions = function(drawingBufferWidth, drawingBufferHeight, distance, pixelRatio, result) { + update2(this); + return this._offCenterFrustum.getPixelDimensions( + drawingBufferWidth, + drawingBufferHeight, + distance, + pixelRatio, + result + ); +}; +OrthographicFrustum.prototype.clone = function(result) { + if (!defined_default(result)) { + result = new OrthographicFrustum(); + } + result.aspectRatio = this.aspectRatio; + result.width = this.width; + result.near = this.near; + result.far = this.far; + result._aspectRatio = void 0; + result._width = void 0; + result._near = void 0; + result._far = void 0; + this._offCenterFrustum.clone(result._offCenterFrustum); + return result; +}; +OrthographicFrustum.prototype.equals = function(other) { + if (!defined_default(other) || !(other instanceof OrthographicFrustum)) { + return false; + } + update2(this); + update2(other); + return this.width === other.width && this.aspectRatio === other.aspectRatio && this._offCenterFrustum.equals(other._offCenterFrustum); +}; +OrthographicFrustum.prototype.equalsEpsilon = function(other, relativeEpsilon, absoluteEpsilon) { + if (!defined_default(other) || !(other instanceof OrthographicFrustum)) { + return false; + } + update2(this); + update2(other); + return Math_default.equalsEpsilon( + this.width, + other.width, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.aspectRatio, + other.aspectRatio, + relativeEpsilon, + absoluteEpsilon + ) && this._offCenterFrustum.equalsEpsilon( + other._offCenterFrustum, + relativeEpsilon, + absoluteEpsilon + ); +}; +var OrthographicFrustum_default = OrthographicFrustum; + +// packages/engine/Source/Core/PerspectiveOffCenterFrustum.js +function PerspectiveOffCenterFrustum(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + this.left = options.left; + this._left = void 0; + this.right = options.right; + this._right = void 0; + this.top = options.top; + this._top = void 0; + this.bottom = options.bottom; + this._bottom = void 0; + this.near = defaultValue_default(options.near, 1); + this._near = this.near; + this.far = defaultValue_default(options.far, 5e8); + this._far = this.far; + this._cullingVolume = new CullingVolume_default(); + this._perspectiveMatrix = new Matrix4_default(); + this._infinitePerspective = new Matrix4_default(); +} +function update3(frustum) { + if (!defined_default(frustum.right) || !defined_default(frustum.left) || !defined_default(frustum.top) || !defined_default(frustum.bottom) || !defined_default(frustum.near) || !defined_default(frustum.far)) { + throw new DeveloperError_default( + "right, left, top, bottom, near, or far parameters are not set." + ); + } + const t = frustum.top; + const b = frustum.bottom; + const r = frustum.right; + const l = frustum.left; + const n = frustum.near; + const f = frustum.far; + if (t !== frustum._top || b !== frustum._bottom || l !== frustum._left || r !== frustum._right || n !== frustum._near || f !== frustum._far) { + if (frustum.near <= 0 || frustum.near > frustum.far) { + throw new DeveloperError_default( + "near must be greater than zero and less than far." + ); + } + frustum._left = l; + frustum._right = r; + frustum._top = t; + frustum._bottom = b; + frustum._near = n; + frustum._far = f; + frustum._perspectiveMatrix = Matrix4_default.computePerspectiveOffCenter( + l, + r, + b, + t, + n, + f, + frustum._perspectiveMatrix + ); + frustum._infinitePerspective = Matrix4_default.computeInfinitePerspectiveOffCenter( + l, + r, + b, + t, + n, + frustum._infinitePerspective + ); + } +} +Object.defineProperties(PerspectiveOffCenterFrustum.prototype, { + /** + * Gets the perspective projection matrix computed from the view frustum. + * @memberof PerspectiveOffCenterFrustum.prototype + * @type {Matrix4} + * @readonly + * + * @see PerspectiveOffCenterFrustum#infiniteProjectionMatrix + */ + projectionMatrix: { + get: function() { + update3(this); + return this._perspectiveMatrix; + } + }, + /** + * Gets the perspective projection matrix computed from the view frustum with an infinite far plane. + * @memberof PerspectiveOffCenterFrustum.prototype + * @type {Matrix4} + * @readonly + * + * @see PerspectiveOffCenterFrustum#projectionMatrix + */ + infiniteProjectionMatrix: { + get: function() { + update3(this); + return this._infinitePerspective; + } + } +}); +var getPlanesRight2 = new Cartesian3_default(); +var getPlanesNearCenter2 = new Cartesian3_default(); +var getPlanesFarCenter = new Cartesian3_default(); +var getPlanesNormal = new Cartesian3_default(); +PerspectiveOffCenterFrustum.prototype.computeCullingVolume = function(position, direction, up) { + if (!defined_default(position)) { + throw new DeveloperError_default("position is required."); + } + if (!defined_default(direction)) { + throw new DeveloperError_default("direction is required."); + } + if (!defined_default(up)) { + throw new DeveloperError_default("up is required."); + } + const planes = this._cullingVolume.planes; + const t = this.top; + const b = this.bottom; + const r = this.right; + const l = this.left; + const n = this.near; + const f = this.far; + const right = Cartesian3_default.cross(direction, up, getPlanesRight2); + const nearCenter = getPlanesNearCenter2; + Cartesian3_default.multiplyByScalar(direction, n, nearCenter); + Cartesian3_default.add(position, nearCenter, nearCenter); + const farCenter = getPlanesFarCenter; + Cartesian3_default.multiplyByScalar(direction, f, farCenter); + Cartesian3_default.add(position, farCenter, farCenter); + const normal = getPlanesNormal; + Cartesian3_default.multiplyByScalar(right, l, normal); + Cartesian3_default.add(nearCenter, normal, normal); + Cartesian3_default.subtract(normal, position, normal); + Cartesian3_default.normalize(normal, normal); + Cartesian3_default.cross(normal, up, normal); + Cartesian3_default.normalize(normal, normal); + let plane = planes[0]; + if (!defined_default(plane)) { + plane = planes[0] = new Cartesian4_default(); + } + plane.x = normal.x; + plane.y = normal.y; + plane.z = normal.z; + plane.w = -Cartesian3_default.dot(normal, position); + Cartesian3_default.multiplyByScalar(right, r, normal); + Cartesian3_default.add(nearCenter, normal, normal); + Cartesian3_default.subtract(normal, position, normal); + Cartesian3_default.cross(up, normal, normal); + Cartesian3_default.normalize(normal, normal); + plane = planes[1]; + if (!defined_default(plane)) { + plane = planes[1] = new Cartesian4_default(); + } + plane.x = normal.x; + plane.y = normal.y; + plane.z = normal.z; + plane.w = -Cartesian3_default.dot(normal, position); + Cartesian3_default.multiplyByScalar(up, b, normal); + Cartesian3_default.add(nearCenter, normal, normal); + Cartesian3_default.subtract(normal, position, normal); + Cartesian3_default.cross(right, normal, normal); + Cartesian3_default.normalize(normal, normal); + plane = planes[2]; + if (!defined_default(plane)) { + plane = planes[2] = new Cartesian4_default(); + } + plane.x = normal.x; + plane.y = normal.y; + plane.z = normal.z; + plane.w = -Cartesian3_default.dot(normal, position); + Cartesian3_default.multiplyByScalar(up, t, normal); + Cartesian3_default.add(nearCenter, normal, normal); + Cartesian3_default.subtract(normal, position, normal); + Cartesian3_default.cross(normal, right, normal); + Cartesian3_default.normalize(normal, normal); + plane = planes[3]; + if (!defined_default(plane)) { + plane = planes[3] = new Cartesian4_default(); + } + plane.x = normal.x; + plane.y = normal.y; + plane.z = normal.z; + plane.w = -Cartesian3_default.dot(normal, position); + plane = planes[4]; + if (!defined_default(plane)) { + plane = planes[4] = new Cartesian4_default(); + } + plane.x = direction.x; + plane.y = direction.y; + plane.z = direction.z; + plane.w = -Cartesian3_default.dot(direction, nearCenter); + Cartesian3_default.negate(direction, normal); + plane = planes[5]; + if (!defined_default(plane)) { + plane = planes[5] = new Cartesian4_default(); + } + plane.x = normal.x; + plane.y = normal.y; + plane.z = normal.z; + plane.w = -Cartesian3_default.dot(normal, farCenter); + return this._cullingVolume; +}; +PerspectiveOffCenterFrustum.prototype.getPixelDimensions = function(drawingBufferWidth, drawingBufferHeight, distance, pixelRatio, result) { + update3(this); + if (!defined_default(drawingBufferWidth) || !defined_default(drawingBufferHeight)) { + throw new DeveloperError_default( + "Both drawingBufferWidth and drawingBufferHeight are required." + ); + } + if (drawingBufferWidth <= 0) { + throw new DeveloperError_default("drawingBufferWidth must be greater than zero."); + } + if (drawingBufferHeight <= 0) { + throw new DeveloperError_default("drawingBufferHeight must be greater than zero."); + } + if (!defined_default(distance)) { + throw new DeveloperError_default("distance is required."); + } + if (!defined_default(pixelRatio)) { + throw new DeveloperError_default("pixelRatio is required"); + } + if (pixelRatio <= 0) { + throw new DeveloperError_default("pixelRatio must be greater than zero."); + } + if (!defined_default(result)) { + throw new DeveloperError_default("A result object is required."); + } + const inverseNear = 1 / this.near; + let tanTheta = this.top * inverseNear; + const pixelHeight = 2 * pixelRatio * distance * tanTheta / drawingBufferHeight; + tanTheta = this.right * inverseNear; + const pixelWidth = 2 * pixelRatio * distance * tanTheta / drawingBufferWidth; + result.x = pixelWidth; + result.y = pixelHeight; + return result; +}; +PerspectiveOffCenterFrustum.prototype.clone = function(result) { + if (!defined_default(result)) { + result = new PerspectiveOffCenterFrustum(); + } + result.right = this.right; + result.left = this.left; + result.top = this.top; + result.bottom = this.bottom; + result.near = this.near; + result.far = this.far; + result._left = void 0; + result._right = void 0; + result._top = void 0; + result._bottom = void 0; + result._near = void 0; + result._far = void 0; + return result; +}; +PerspectiveOffCenterFrustum.prototype.equals = function(other) { + return defined_default(other) && other instanceof PerspectiveOffCenterFrustum && this.right === other.right && this.left === other.left && this.top === other.top && this.bottom === other.bottom && this.near === other.near && this.far === other.far; +}; +PerspectiveOffCenterFrustum.prototype.equalsEpsilon = function(other, relativeEpsilon, absoluteEpsilon) { + return other === this || defined_default(other) && other instanceof PerspectiveOffCenterFrustum && Math_default.equalsEpsilon( + this.right, + other.right, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.left, + other.left, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.top, + other.top, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.bottom, + other.bottom, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.near, + other.near, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.far, + other.far, + relativeEpsilon, + absoluteEpsilon + ); +}; +var PerspectiveOffCenterFrustum_default = PerspectiveOffCenterFrustum; + +// packages/engine/Source/Core/PerspectiveFrustum.js +function PerspectiveFrustum(options) { + options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT); + this._offCenterFrustum = new PerspectiveOffCenterFrustum_default(); + this.fov = options.fov; + this._fov = void 0; + this._fovy = void 0; + this._sseDenominator = void 0; + this.aspectRatio = options.aspectRatio; + this._aspectRatio = void 0; + this.near = defaultValue_default(options.near, 1); + this._near = this.near; + this.far = defaultValue_default(options.far, 5e8); + this._far = this.far; + this.xOffset = defaultValue_default(options.xOffset, 0); + this._xOffset = this.xOffset; + this.yOffset = defaultValue_default(options.yOffset, 0); + this._yOffset = this.yOffset; +} +PerspectiveFrustum.packedLength = 6; +PerspectiveFrustum.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value.fov; + array[startingIndex++] = value.aspectRatio; + array[startingIndex++] = value.near; + array[startingIndex++] = value.far; + array[startingIndex++] = value.xOffset; + array[startingIndex] = value.yOffset; + return array; +}; +PerspectiveFrustum.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new PerspectiveFrustum(); + } + result.fov = array[startingIndex++]; + result.aspectRatio = array[startingIndex++]; + result.near = array[startingIndex++]; + result.far = array[startingIndex++]; + result.xOffset = array[startingIndex++]; + result.yOffset = array[startingIndex]; + return result; +}; +function update4(frustum) { + if (!defined_default(frustum.fov) || !defined_default(frustum.aspectRatio) || !defined_default(frustum.near) || !defined_default(frustum.far)) { + throw new DeveloperError_default( + "fov, aspectRatio, near, or far parameters are not set." + ); + } + const f = frustum._offCenterFrustum; + if (frustum.fov !== frustum._fov || frustum.aspectRatio !== frustum._aspectRatio || frustum.near !== frustum._near || frustum.far !== frustum._far || frustum.xOffset !== frustum._xOffset || frustum.yOffset !== frustum._yOffset) { + if (frustum.fov < 0 || frustum.fov >= Math.PI) { + throw new DeveloperError_default("fov must be in the range [0, PI)."); + } + if (frustum.aspectRatio < 0) { + throw new DeveloperError_default("aspectRatio must be positive."); + } + if (frustum.near < 0 || frustum.near > frustum.far) { + throw new DeveloperError_default( + "near must be greater than zero and less than far." + ); + } + frustum._aspectRatio = frustum.aspectRatio; + frustum._fov = frustum.fov; + frustum._fovy = frustum.aspectRatio <= 1 ? frustum.fov : Math.atan(Math.tan(frustum.fov * 0.5) / frustum.aspectRatio) * 2; + frustum._near = frustum.near; + frustum._far = frustum.far; + frustum._sseDenominator = 2 * Math.tan(0.5 * frustum._fovy); + frustum._xOffset = frustum.xOffset; + frustum._yOffset = frustum.yOffset; + f.top = frustum.near * Math.tan(0.5 * frustum._fovy); + f.bottom = -f.top; + f.right = frustum.aspectRatio * f.top; + f.left = -f.right; + f.near = frustum.near; + f.far = frustum.far; + f.right += frustum.xOffset; + f.left += frustum.xOffset; + f.top += frustum.yOffset; + f.bottom += frustum.yOffset; + } +} +Object.defineProperties(PerspectiveFrustum.prototype, { + /** + * Gets the perspective projection matrix computed from the view frustum. + * @memberof PerspectiveFrustum.prototype + * @type {Matrix4} + * @readonly + * + * @see PerspectiveFrustum#infiniteProjectionMatrix + */ + projectionMatrix: { + get: function() { + update4(this); + return this._offCenterFrustum.projectionMatrix; + } + }, + /** + * The perspective projection matrix computed from the view frustum with an infinite far plane. + * @memberof PerspectiveFrustum.prototype + * @type {Matrix4} + * @readonly + * + * @see PerspectiveFrustum#projectionMatrix + */ + infiniteProjectionMatrix: { + get: function() { + update4(this); + return this._offCenterFrustum.infiniteProjectionMatrix; + } + }, + /** + * Gets the angle of the vertical field of view, in radians. + * @memberof PerspectiveFrustum.prototype + * @type {number} + * @readonly + * @default undefined + */ + fovy: { + get: function() { + update4(this); + return this._fovy; + } + }, + /** + * @readonly + * @private + */ + sseDenominator: { + get: function() { + update4(this); + return this._sseDenominator; + } + }, + /** + * Gets the orthographic projection matrix computed from the view frustum. + * @memberof PerspectiveFrustum.prototype + * @type {PerspectiveOffCenterFrustum} + * @readonly + * @private + */ + offCenterFrustum: { + get: function() { + update4(this); + return this._offCenterFrustum; + } + } +}); +PerspectiveFrustum.prototype.computeCullingVolume = function(position, direction, up) { + update4(this); + return this._offCenterFrustum.computeCullingVolume(position, direction, up); +}; +PerspectiveFrustum.prototype.getPixelDimensions = function(drawingBufferWidth, drawingBufferHeight, distance, pixelRatio, result) { + update4(this); + return this._offCenterFrustum.getPixelDimensions( + drawingBufferWidth, + drawingBufferHeight, + distance, + pixelRatio, + result + ); +}; +PerspectiveFrustum.prototype.clone = function(result) { + if (!defined_default(result)) { + result = new PerspectiveFrustum(); + } + result.aspectRatio = this.aspectRatio; + result.fov = this.fov; + result.near = this.near; + result.far = this.far; + result._aspectRatio = void 0; + result._fov = void 0; + result._near = void 0; + result._far = void 0; + this._offCenterFrustum.clone(result._offCenterFrustum); + return result; +}; +PerspectiveFrustum.prototype.equals = function(other) { + if (!defined_default(other) || !(other instanceof PerspectiveFrustum)) { + return false; + } + update4(this); + update4(other); + return this.fov === other.fov && this.aspectRatio === other.aspectRatio && this._offCenterFrustum.equals(other._offCenterFrustum); +}; +PerspectiveFrustum.prototype.equalsEpsilon = function(other, relativeEpsilon, absoluteEpsilon) { + if (!defined_default(other) || !(other instanceof PerspectiveFrustum)) { + return false; + } + update4(this); + update4(other); + return Math_default.equalsEpsilon( + this.fov, + other.fov, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + this.aspectRatio, + other.aspectRatio, + relativeEpsilon, + absoluteEpsilon + ) && this._offCenterFrustum.equalsEpsilon( + other._offCenterFrustum, + relativeEpsilon, + absoluteEpsilon + ); +}; +var PerspectiveFrustum_default = PerspectiveFrustum; + +// packages/engine/Source/Core/FrustumGeometry.js +var PERSPECTIVE = 0; +var ORTHOGRAPHIC = 1; +function FrustumGeometry(options) { + Check_default.typeOf.object("options", options); + Check_default.typeOf.object("options.frustum", options.frustum); + Check_default.typeOf.object("options.origin", options.origin); + Check_default.typeOf.object("options.orientation", options.orientation); + const frustum = options.frustum; + const orientation = options.orientation; + const origin = options.origin; + const vertexFormat = defaultValue_default(options.vertexFormat, VertexFormat_default.DEFAULT); + const drawNearPlane = defaultValue_default(options._drawNearPlane, true); + let frustumType; + let frustumPackedLength; + if (frustum instanceof PerspectiveFrustum_default) { + frustumType = PERSPECTIVE; + frustumPackedLength = PerspectiveFrustum_default.packedLength; + } else if (frustum instanceof OrthographicFrustum_default) { + frustumType = ORTHOGRAPHIC; + frustumPackedLength = OrthographicFrustum_default.packedLength; + } + this._frustumType = frustumType; + this._frustum = frustum.clone(); + this._origin = Cartesian3_default.clone(origin); + this._orientation = Quaternion_default.clone(orientation); + this._drawNearPlane = drawNearPlane; + this._vertexFormat = vertexFormat; + this._workerName = "createFrustumGeometry"; + this.packedLength = 2 + frustumPackedLength + Cartesian3_default.packedLength + Quaternion_default.packedLength + VertexFormat_default.packedLength; +} +FrustumGeometry.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + const frustumType = value._frustumType; + const frustum = value._frustum; + array[startingIndex++] = frustumType; + if (frustumType === PERSPECTIVE) { + PerspectiveFrustum_default.pack(frustum, array, startingIndex); + startingIndex += PerspectiveFrustum_default.packedLength; + } else { + OrthographicFrustum_default.pack(frustum, array, startingIndex); + startingIndex += OrthographicFrustum_default.packedLength; + } + Cartesian3_default.pack(value._origin, array, startingIndex); + startingIndex += Cartesian3_default.packedLength; + Quaternion_default.pack(value._orientation, array, startingIndex); + startingIndex += Quaternion_default.packedLength; + VertexFormat_default.pack(value._vertexFormat, array, startingIndex); + startingIndex += VertexFormat_default.packedLength; + array[startingIndex] = value._drawNearPlane ? 1 : 0; + return array; +}; +var scratchPackPerspective = new PerspectiveFrustum_default(); +var scratchPackOrthographic = new OrthographicFrustum_default(); +var scratchPackQuaternion = new Quaternion_default(); +var scratchPackorigin = new Cartesian3_default(); +var scratchVertexFormat = new VertexFormat_default(); +FrustumGeometry.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + const frustumType = array[startingIndex++]; + let frustum; + if (frustumType === PERSPECTIVE) { + frustum = PerspectiveFrustum_default.unpack( + array, + startingIndex, + scratchPackPerspective + ); + startingIndex += PerspectiveFrustum_default.packedLength; + } else { + frustum = OrthographicFrustum_default.unpack( + array, + startingIndex, + scratchPackOrthographic + ); + startingIndex += OrthographicFrustum_default.packedLength; + } + const origin = Cartesian3_default.unpack(array, startingIndex, scratchPackorigin); + startingIndex += Cartesian3_default.packedLength; + const orientation = Quaternion_default.unpack( + array, + startingIndex, + scratchPackQuaternion + ); + startingIndex += Quaternion_default.packedLength; + const vertexFormat = VertexFormat_default.unpack( + array, + startingIndex, + scratchVertexFormat + ); + startingIndex += VertexFormat_default.packedLength; + const drawNearPlane = array[startingIndex] === 1; + if (!defined_default(result)) { + return new FrustumGeometry({ + frustum, + origin, + orientation, + vertexFormat, + _drawNearPlane: drawNearPlane + }); + } + const frustumResult = frustumType === result._frustumType ? result._frustum : void 0; + result._frustum = frustum.clone(frustumResult); + result._frustumType = frustumType; + result._origin = Cartesian3_default.clone(origin, result._origin); + result._orientation = Quaternion_default.clone(orientation, result._orientation); + result._vertexFormat = VertexFormat_default.clone(vertexFormat, result._vertexFormat); + result._drawNearPlane = drawNearPlane; + return result; +}; +function getAttributes(offset, normals, tangents, bitangents, st, normal, tangent, bitangent) { + const stOffset = offset / 3 * 2; + for (let i = 0; i < 4; ++i) { + if (defined_default(normals)) { + normals[offset] = normal.x; + normals[offset + 1] = normal.y; + normals[offset + 2] = normal.z; + } + if (defined_default(tangents)) { + tangents[offset] = tangent.x; + tangents[offset + 1] = tangent.y; + tangents[offset + 2] = tangent.z; + } + if (defined_default(bitangents)) { + bitangents[offset] = bitangent.x; + bitangents[offset + 1] = bitangent.y; + bitangents[offset + 2] = bitangent.z; + } + offset += 3; + } + st[stOffset] = 0; + st[stOffset + 1] = 0; + st[stOffset + 2] = 1; + st[stOffset + 3] = 0; + st[stOffset + 4] = 1; + st[stOffset + 5] = 1; + st[stOffset + 6] = 0; + st[stOffset + 7] = 1; +} +var scratchRotationMatrix = new Matrix3_default(); +var scratchViewMatrix = new Matrix4_default(); +var scratchInverseMatrix = new Matrix4_default(); +var scratchXDirection = new Cartesian3_default(); +var scratchYDirection = new Cartesian3_default(); +var scratchZDirection = new Cartesian3_default(); +var scratchNegativeX = new Cartesian3_default(); +var scratchNegativeY = new Cartesian3_default(); +var scratchNegativeZ = new Cartesian3_default(); +var frustumSplits = new Array(3); +var frustumCornersNDC = new Array(4); +frustumCornersNDC[0] = new Cartesian4_default(-1, -1, 1, 1); +frustumCornersNDC[1] = new Cartesian4_default(1, -1, 1, 1); +frustumCornersNDC[2] = new Cartesian4_default(1, 1, 1, 1); +frustumCornersNDC[3] = new Cartesian4_default(-1, 1, 1, 1); +var scratchFrustumCorners = new Array(4); +for (let i = 0; i < 4; ++i) { + scratchFrustumCorners[i] = new Cartesian4_default(); +} +FrustumGeometry._computeNearFarPlanes = function(origin, orientation, frustumType, frustum, positions, xDirection, yDirection, zDirection) { + const rotationMatrix = Matrix3_default.fromQuaternion( + orientation, + scratchRotationMatrix + ); + let x = defaultValue_default(xDirection, scratchXDirection); + let y = defaultValue_default(yDirection, scratchYDirection); + let z = defaultValue_default(zDirection, scratchZDirection); + x = Matrix3_default.getColumn(rotationMatrix, 0, x); + y = Matrix3_default.getColumn(rotationMatrix, 1, y); + z = Matrix3_default.getColumn(rotationMatrix, 2, z); + Cartesian3_default.normalize(x, x); + Cartesian3_default.normalize(y, y); + Cartesian3_default.normalize(z, z); + Cartesian3_default.negate(x, x); + const view = Matrix4_default.computeView(origin, z, y, x, scratchViewMatrix); + let inverseView; + let inverseViewProjection; + const projection = frustum.projectionMatrix; + if (frustumType === PERSPECTIVE) { + const viewProjection = Matrix4_default.multiply( + projection, + view, + scratchInverseMatrix + ); + inverseViewProjection = Matrix4_default.inverse( + viewProjection, + scratchInverseMatrix + ); + } else { + inverseView = Matrix4_default.inverseTransformation(view, scratchInverseMatrix); + } + if (defined_default(inverseViewProjection)) { + frustumSplits[0] = frustum.near; + frustumSplits[1] = frustum.far; + } else { + frustumSplits[0] = 0; + frustumSplits[1] = frustum.near; + frustumSplits[2] = frustum.far; + } + for (let i = 0; i < 2; ++i) { + for (let j = 0; j < 4; ++j) { + let corner = Cartesian4_default.clone( + frustumCornersNDC[j], + scratchFrustumCorners[j] + ); + if (!defined_default(inverseViewProjection)) { + const offCenterFrustum = frustum.offCenterFrustum; + if (defined_default(offCenterFrustum)) { + frustum = offCenterFrustum; + } + const near = frustumSplits[i]; + const far = frustumSplits[i + 1]; + corner.x = (corner.x * (frustum.right - frustum.left) + frustum.left + frustum.right) * 0.5; + corner.y = (corner.y * (frustum.top - frustum.bottom) + frustum.bottom + frustum.top) * 0.5; + corner.z = (corner.z * (near - far) - near - far) * 0.5; + corner.w = 1; + Matrix4_default.multiplyByVector(inverseView, corner, corner); + } else { + corner = Matrix4_default.multiplyByVector( + inverseViewProjection, + corner, + corner + ); + const w = 1 / corner.w; + Cartesian3_default.multiplyByScalar(corner, w, corner); + Cartesian3_default.subtract(corner, origin, corner); + Cartesian3_default.normalize(corner, corner); + const fac = Cartesian3_default.dot(z, corner); + Cartesian3_default.multiplyByScalar(corner, frustumSplits[i] / fac, corner); + Cartesian3_default.add(corner, origin, corner); + } + positions[12 * i + j * 3] = corner.x; + positions[12 * i + j * 3 + 1] = corner.y; + positions[12 * i + j * 3 + 2] = corner.z; + } + } +}; +FrustumGeometry.createGeometry = function(frustumGeometry) { + const frustumType = frustumGeometry._frustumType; + const frustum = frustumGeometry._frustum; + const origin = frustumGeometry._origin; + const orientation = frustumGeometry._orientation; + const drawNearPlane = frustumGeometry._drawNearPlane; + const vertexFormat = frustumGeometry._vertexFormat; + const numberOfPlanes = drawNearPlane ? 6 : 5; + let positions = new Float64Array(3 * 4 * 6); + FrustumGeometry._computeNearFarPlanes( + origin, + orientation, + frustumType, + frustum, + positions + ); + let offset = 3 * 4 * 2; + positions[offset] = positions[3 * 4]; + positions[offset + 1] = positions[3 * 4 + 1]; + positions[offset + 2] = positions[3 * 4 + 2]; + positions[offset + 3] = positions[0]; + positions[offset + 4] = positions[1]; + positions[offset + 5] = positions[2]; + positions[offset + 6] = positions[3 * 3]; + positions[offset + 7] = positions[3 * 3 + 1]; + positions[offset + 8] = positions[3 * 3 + 2]; + positions[offset + 9] = positions[3 * 7]; + positions[offset + 10] = positions[3 * 7 + 1]; + positions[offset + 11] = positions[3 * 7 + 2]; + offset += 3 * 4; + positions[offset] = positions[3 * 5]; + positions[offset + 1] = positions[3 * 5 + 1]; + positions[offset + 2] = positions[3 * 5 + 2]; + positions[offset + 3] = positions[3]; + positions[offset + 4] = positions[3 + 1]; + positions[offset + 5] = positions[3 + 2]; + positions[offset + 6] = positions[0]; + positions[offset + 7] = positions[1]; + positions[offset + 8] = positions[2]; + positions[offset + 9] = positions[3 * 4]; + positions[offset + 10] = positions[3 * 4 + 1]; + positions[offset + 11] = positions[3 * 4 + 2]; + offset += 3 * 4; + positions[offset] = positions[3]; + positions[offset + 1] = positions[3 + 1]; + positions[offset + 2] = positions[3 + 2]; + positions[offset + 3] = positions[3 * 5]; + positions[offset + 4] = positions[3 * 5 + 1]; + positions[offset + 5] = positions[3 * 5 + 2]; + positions[offset + 6] = positions[3 * 6]; + positions[offset + 7] = positions[3 * 6 + 1]; + positions[offset + 8] = positions[3 * 6 + 2]; + positions[offset + 9] = positions[3 * 2]; + positions[offset + 10] = positions[3 * 2 + 1]; + positions[offset + 11] = positions[3 * 2 + 2]; + offset += 3 * 4; + positions[offset] = positions[3 * 2]; + positions[offset + 1] = positions[3 * 2 + 1]; + positions[offset + 2] = positions[3 * 2 + 2]; + positions[offset + 3] = positions[3 * 6]; + positions[offset + 4] = positions[3 * 6 + 1]; + positions[offset + 5] = positions[3 * 6 + 2]; + positions[offset + 6] = positions[3 * 7]; + positions[offset + 7] = positions[3 * 7 + 1]; + positions[offset + 8] = positions[3 * 7 + 2]; + positions[offset + 9] = positions[3 * 3]; + positions[offset + 10] = positions[3 * 3 + 1]; + positions[offset + 11] = positions[3 * 3 + 2]; + if (!drawNearPlane) { + positions = positions.subarray(3 * 4); + } + const attributes = new GeometryAttributes_default({ + position: new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.DOUBLE, + componentsPerAttribute: 3, + values: positions + }) + }); + if (defined_default(vertexFormat.normal) || defined_default(vertexFormat.tangent) || defined_default(vertexFormat.bitangent) || defined_default(vertexFormat.st)) { + const normals = defined_default(vertexFormat.normal) ? new Float32Array(3 * 4 * numberOfPlanes) : void 0; + const tangents = defined_default(vertexFormat.tangent) ? new Float32Array(3 * 4 * numberOfPlanes) : void 0; + const bitangents = defined_default(vertexFormat.bitangent) ? new Float32Array(3 * 4 * numberOfPlanes) : void 0; + const st = defined_default(vertexFormat.st) ? new Float32Array(2 * 4 * numberOfPlanes) : void 0; + const x = scratchXDirection; + const y = scratchYDirection; + const z = scratchZDirection; + const negativeX = Cartesian3_default.negate(x, scratchNegativeX); + const negativeY = Cartesian3_default.negate(y, scratchNegativeY); + const negativeZ = Cartesian3_default.negate(z, scratchNegativeZ); + offset = 0; + if (drawNearPlane) { + getAttributes(offset, normals, tangents, bitangents, st, negativeZ, x, y); + offset += 3 * 4; + } + getAttributes(offset, normals, tangents, bitangents, st, z, negativeX, y); + offset += 3 * 4; + getAttributes( + offset, + normals, + tangents, + bitangents, + st, + negativeX, + negativeZ, + y + ); + offset += 3 * 4; + getAttributes( + offset, + normals, + tangents, + bitangents, + st, + negativeY, + negativeZ, + negativeX + ); + offset += 3 * 4; + getAttributes(offset, normals, tangents, bitangents, st, x, z, y); + offset += 3 * 4; + getAttributes(offset, normals, tangents, bitangents, st, y, z, negativeX); + if (defined_default(normals)) { + attributes.normal = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: normals + }); + } + if (defined_default(tangents)) { + attributes.tangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: tangents + }); + } + if (defined_default(bitangents)) { + attributes.bitangent = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 3, + values: bitangents + }); + } + if (defined_default(st)) { + attributes.st = new GeometryAttribute_default({ + componentDatatype: ComponentDatatype_default.FLOAT, + componentsPerAttribute: 2, + values: st + }); + } + } + const indices = new Uint16Array(6 * numberOfPlanes); + for (let i = 0; i < numberOfPlanes; ++i) { + const indexOffset = i * 6; + const index = i * 4; + indices[indexOffset] = index; + indices[indexOffset + 1] = index + 1; + indices[indexOffset + 2] = index + 2; + indices[indexOffset + 3] = index; + indices[indexOffset + 4] = index + 2; + indices[indexOffset + 5] = index + 3; + } + return new Geometry_default({ + attributes, + indices, + primitiveType: PrimitiveType_default.TRIANGLES, + boundingSphere: BoundingSphere_default.fromVertices(positions) + }); +}; +var FrustumGeometry_default = FrustumGeometry; + +export { + OrthographicFrustum_default, + PerspectiveFrustum_default, + FrustumGeometry_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-XJCTFTBM.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-XJCTFTBM.js new file mode 100644 index 0000000000000000000000000000000000000000..b2fa3bc97ee94b0f91747727323d2666a008a6ba --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-XJCTFTBM.js @@ -0,0 +1,2041 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/Cartesian3.js +function Cartesian3(x, y, z) { + this.x = defaultValue_default(x, 0); + this.y = defaultValue_default(y, 0); + this.z = defaultValue_default(z, 0); +} +Cartesian3.fromSpherical = function(spherical, result) { + Check_default.typeOf.object("spherical", spherical); + if (!defined_default(result)) { + result = new Cartesian3(); + } + const clock = spherical.clock; + const cone = spherical.cone; + const magnitude = defaultValue_default(spherical.magnitude, 1); + const radial = magnitude * Math.sin(cone); + result.x = radial * Math.cos(clock); + result.y = radial * Math.sin(clock); + result.z = magnitude * Math.cos(cone); + return result; +}; +Cartesian3.fromElements = function(x, y, z, result) { + if (!defined_default(result)) { + return new Cartesian3(x, y, z); + } + result.x = x; + result.y = y; + result.z = z; + return result; +}; +Cartesian3.clone = function(cartesian, result) { + if (!defined_default(cartesian)) { + return void 0; + } + if (!defined_default(result)) { + return new Cartesian3(cartesian.x, cartesian.y, cartesian.z); + } + result.x = cartesian.x; + result.y = cartesian.y; + result.z = cartesian.z; + return result; +}; +Cartesian3.fromCartesian4 = Cartesian3.clone; +Cartesian3.packedLength = 3; +Cartesian3.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value.x; + array[startingIndex++] = value.y; + array[startingIndex] = value.z; + return array; +}; +Cartesian3.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new Cartesian3(); + } + result.x = array[startingIndex++]; + result.y = array[startingIndex++]; + result.z = array[startingIndex]; + return result; +}; +Cartesian3.packArray = function(array, result) { + Check_default.defined("array", array); + const length = array.length; + const resultLength = length * 3; + if (!defined_default(result)) { + result = new Array(resultLength); + } else if (!Array.isArray(result) && result.length !== resultLength) { + throw new DeveloperError_default( + "If result is a typed array, it must have exactly array.length * 3 elements" + ); + } else if (result.length !== resultLength) { + result.length = resultLength; + } + for (let i = 0; i < length; ++i) { + Cartesian3.pack(array[i], result, i * 3); + } + return result; +}; +Cartesian3.unpackArray = function(array, result) { + Check_default.defined("array", array); + Check_default.typeOf.number.greaterThanOrEquals("array.length", array.length, 3); + if (array.length % 3 !== 0) { + throw new DeveloperError_default("array length must be a multiple of 3."); + } + const length = array.length; + if (!defined_default(result)) { + result = new Array(length / 3); + } else { + result.length = length / 3; + } + for (let i = 0; i < length; i += 3) { + const index = i / 3; + result[index] = Cartesian3.unpack(array, i, result[index]); + } + return result; +}; +Cartesian3.fromArray = Cartesian3.unpack; +Cartesian3.maximumComponent = function(cartesian) { + Check_default.typeOf.object("cartesian", cartesian); + return Math.max(cartesian.x, cartesian.y, cartesian.z); +}; +Cartesian3.minimumComponent = function(cartesian) { + Check_default.typeOf.object("cartesian", cartesian); + return Math.min(cartesian.x, cartesian.y, cartesian.z); +}; +Cartesian3.minimumByComponent = function(first, second, result) { + Check_default.typeOf.object("first", first); + Check_default.typeOf.object("second", second); + Check_default.typeOf.object("result", result); + result.x = Math.min(first.x, second.x); + result.y = Math.min(first.y, second.y); + result.z = Math.min(first.z, second.z); + return result; +}; +Cartesian3.maximumByComponent = function(first, second, result) { + Check_default.typeOf.object("first", first); + Check_default.typeOf.object("second", second); + Check_default.typeOf.object("result", result); + result.x = Math.max(first.x, second.x); + result.y = Math.max(first.y, second.y); + result.z = Math.max(first.z, second.z); + return result; +}; +Cartesian3.clamp = function(value, min, max, result) { + Check_default.typeOf.object("value", value); + Check_default.typeOf.object("min", min); + Check_default.typeOf.object("max", max); + Check_default.typeOf.object("result", result); + const x = Math_default.clamp(value.x, min.x, max.x); + const y = Math_default.clamp(value.y, min.y, max.y); + const z = Math_default.clamp(value.z, min.z, max.z); + result.x = x; + result.y = y; + result.z = z; + return result; +}; +Cartesian3.magnitudeSquared = function(cartesian) { + Check_default.typeOf.object("cartesian", cartesian); + return cartesian.x * cartesian.x + cartesian.y * cartesian.y + cartesian.z * cartesian.z; +}; +Cartesian3.magnitude = function(cartesian) { + return Math.sqrt(Cartesian3.magnitudeSquared(cartesian)); +}; +var distanceScratch = new Cartesian3(); +Cartesian3.distance = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Cartesian3.subtract(left, right, distanceScratch); + return Cartesian3.magnitude(distanceScratch); +}; +Cartesian3.distanceSquared = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Cartesian3.subtract(left, right, distanceScratch); + return Cartesian3.magnitudeSquared(distanceScratch); +}; +Cartesian3.normalize = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const magnitude = Cartesian3.magnitude(cartesian); + result.x = cartesian.x / magnitude; + result.y = cartesian.y / magnitude; + result.z = cartesian.z / magnitude; + if (isNaN(result.x) || isNaN(result.y) || isNaN(result.z)) { + throw new DeveloperError_default("normalized result is not a number"); + } + return result; +}; +Cartesian3.dot = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + return left.x * right.x + left.y * right.y + left.z * right.z; +}; +Cartesian3.multiplyComponents = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x * right.x; + result.y = left.y * right.y; + result.z = left.z * right.z; + return result; +}; +Cartesian3.divideComponents = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x / right.x; + result.y = left.y / right.y; + result.z = left.z / right.z; + return result; +}; +Cartesian3.add = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x + right.x; + result.y = left.y + right.y; + result.z = left.z + right.z; + return result; +}; +Cartesian3.subtract = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = left.x - right.x; + result.y = left.y - right.y; + result.z = left.z - right.z; + return result; +}; +Cartesian3.multiplyByScalar = function(cartesian, scalar, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result.x = cartesian.x * scalar; + result.y = cartesian.y * scalar; + result.z = cartesian.z * scalar; + return result; +}; +Cartesian3.divideByScalar = function(cartesian, scalar, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result.x = cartesian.x / scalar; + result.y = cartesian.y / scalar; + result.z = cartesian.z / scalar; + return result; +}; +Cartesian3.negate = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result.x = -cartesian.x; + result.y = -cartesian.y; + result.z = -cartesian.z; + return result; +}; +Cartesian3.abs = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result.x = Math.abs(cartesian.x); + result.y = Math.abs(cartesian.y); + result.z = Math.abs(cartesian.z); + return result; +}; +var lerpScratch = new Cartesian3(); +Cartesian3.lerp = function(start, end, t, result) { + Check_default.typeOf.object("start", start); + Check_default.typeOf.object("end", end); + Check_default.typeOf.number("t", t); + Check_default.typeOf.object("result", result); + Cartesian3.multiplyByScalar(end, t, lerpScratch); + result = Cartesian3.multiplyByScalar(start, 1 - t, result); + return Cartesian3.add(lerpScratch, result, result); +}; +var angleBetweenScratch = new Cartesian3(); +var angleBetweenScratch2 = new Cartesian3(); +Cartesian3.angleBetween = function(left, right) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Cartesian3.normalize(left, angleBetweenScratch); + Cartesian3.normalize(right, angleBetweenScratch2); + const cosine = Cartesian3.dot(angleBetweenScratch, angleBetweenScratch2); + const sine = Cartesian3.magnitude( + Cartesian3.cross( + angleBetweenScratch, + angleBetweenScratch2, + angleBetweenScratch + ) + ); + return Math.atan2(sine, cosine); +}; +var mostOrthogonalAxisScratch = new Cartesian3(); +Cartesian3.mostOrthogonalAxis = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const f = Cartesian3.normalize(cartesian, mostOrthogonalAxisScratch); + Cartesian3.abs(f, f); + if (f.x <= f.y) { + if (f.x <= f.z) { + result = Cartesian3.clone(Cartesian3.UNIT_X, result); + } else { + result = Cartesian3.clone(Cartesian3.UNIT_Z, result); + } + } else if (f.y <= f.z) { + result = Cartesian3.clone(Cartesian3.UNIT_Y, result); + } else { + result = Cartesian3.clone(Cartesian3.UNIT_Z, result); + } + return result; +}; +Cartesian3.projectVector = function(a, b, result) { + Check_default.defined("a", a); + Check_default.defined("b", b); + Check_default.defined("result", result); + const scalar = Cartesian3.dot(a, b) / Cartesian3.dot(b, b); + return Cartesian3.multiplyByScalar(b, scalar, result); +}; +Cartesian3.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left.x === right.x && left.y === right.y && left.z === right.z; +}; +Cartesian3.equalsArray = function(cartesian, array, offset) { + return cartesian.x === array[offset] && cartesian.y === array[offset + 1] && cartesian.z === array[offset + 2]; +}; +Cartesian3.equalsEpsilon = function(left, right, relativeEpsilon, absoluteEpsilon) { + return left === right || defined_default(left) && defined_default(right) && Math_default.equalsEpsilon( + left.x, + right.x, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + left.y, + right.y, + relativeEpsilon, + absoluteEpsilon + ) && Math_default.equalsEpsilon( + left.z, + right.z, + relativeEpsilon, + absoluteEpsilon + ); +}; +Cartesian3.cross = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + const leftX = left.x; + const leftY = left.y; + const leftZ = left.z; + const rightX = right.x; + const rightY = right.y; + const rightZ = right.z; + const x = leftY * rightZ - leftZ * rightY; + const y = leftZ * rightX - leftX * rightZ; + const z = leftX * rightY - leftY * rightX; + result.x = x; + result.y = y; + result.z = z; + return result; +}; +Cartesian3.midpoint = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result.x = (left.x + right.x) * 0.5; + result.y = (left.y + right.y) * 0.5; + result.z = (left.z + right.z) * 0.5; + return result; +}; +Cartesian3.fromDegrees = function(longitude, latitude, height, ellipsoid, result) { + Check_default.typeOf.number("longitude", longitude); + Check_default.typeOf.number("latitude", latitude); + longitude = Math_default.toRadians(longitude); + latitude = Math_default.toRadians(latitude); + return Cartesian3.fromRadians(longitude, latitude, height, ellipsoid, result); +}; +var scratchN = new Cartesian3(); +var scratchK = new Cartesian3(); +var wgs84RadiiSquared = new Cartesian3( + 6378137 * 6378137, + 6378137 * 6378137, + 6356752314245179e-9 * 6356752314245179e-9 +); +Cartesian3.fromRadians = function(longitude, latitude, height, ellipsoid, result) { + Check_default.typeOf.number("longitude", longitude); + Check_default.typeOf.number("latitude", latitude); + height = defaultValue_default(height, 0); + const radiiSquared = defined_default(ellipsoid) ? ellipsoid.radiiSquared : wgs84RadiiSquared; + const cosLatitude = Math.cos(latitude); + scratchN.x = cosLatitude * Math.cos(longitude); + scratchN.y = cosLatitude * Math.sin(longitude); + scratchN.z = Math.sin(latitude); + scratchN = Cartesian3.normalize(scratchN, scratchN); + Cartesian3.multiplyComponents(radiiSquared, scratchN, scratchK); + const gamma = Math.sqrt(Cartesian3.dot(scratchN, scratchK)); + scratchK = Cartesian3.divideByScalar(scratchK, gamma, scratchK); + scratchN = Cartesian3.multiplyByScalar(scratchN, height, scratchN); + if (!defined_default(result)) { + result = new Cartesian3(); + } + return Cartesian3.add(scratchK, scratchN, result); +}; +Cartesian3.fromDegreesArray = function(coordinates, ellipsoid, result) { + Check_default.defined("coordinates", coordinates); + if (coordinates.length < 2 || coordinates.length % 2 !== 0) { + throw new DeveloperError_default( + "the number of coordinates must be a multiple of 2 and at least 2" + ); + } + const length = coordinates.length; + if (!defined_default(result)) { + result = new Array(length / 2); + } else { + result.length = length / 2; + } + for (let i = 0; i < length; i += 2) { + const longitude = coordinates[i]; + const latitude = coordinates[i + 1]; + const index = i / 2; + result[index] = Cartesian3.fromDegrees( + longitude, + latitude, + 0, + ellipsoid, + result[index] + ); + } + return result; +}; +Cartesian3.fromRadiansArray = function(coordinates, ellipsoid, result) { + Check_default.defined("coordinates", coordinates); + if (coordinates.length < 2 || coordinates.length % 2 !== 0) { + throw new DeveloperError_default( + "the number of coordinates must be a multiple of 2 and at least 2" + ); + } + const length = coordinates.length; + if (!defined_default(result)) { + result = new Array(length / 2); + } else { + result.length = length / 2; + } + for (let i = 0; i < length; i += 2) { + const longitude = coordinates[i]; + const latitude = coordinates[i + 1]; + const index = i / 2; + result[index] = Cartesian3.fromRadians( + longitude, + latitude, + 0, + ellipsoid, + result[index] + ); + } + return result; +}; +Cartesian3.fromDegreesArrayHeights = function(coordinates, ellipsoid, result) { + Check_default.defined("coordinates", coordinates); + if (coordinates.length < 3 || coordinates.length % 3 !== 0) { + throw new DeveloperError_default( + "the number of coordinates must be a multiple of 3 and at least 3" + ); + } + const length = coordinates.length; + if (!defined_default(result)) { + result = new Array(length / 3); + } else { + result.length = length / 3; + } + for (let i = 0; i < length; i += 3) { + const longitude = coordinates[i]; + const latitude = coordinates[i + 1]; + const height = coordinates[i + 2]; + const index = i / 3; + result[index] = Cartesian3.fromDegrees( + longitude, + latitude, + height, + ellipsoid, + result[index] + ); + } + return result; +}; +Cartesian3.fromRadiansArrayHeights = function(coordinates, ellipsoid, result) { + Check_default.defined("coordinates", coordinates); + if (coordinates.length < 3 || coordinates.length % 3 !== 0) { + throw new DeveloperError_default( + "the number of coordinates must be a multiple of 3 and at least 3" + ); + } + const length = coordinates.length; + if (!defined_default(result)) { + result = new Array(length / 3); + } else { + result.length = length / 3; + } + for (let i = 0; i < length; i += 3) { + const longitude = coordinates[i]; + const latitude = coordinates[i + 1]; + const height = coordinates[i + 2]; + const index = i / 3; + result[index] = Cartesian3.fromRadians( + longitude, + latitude, + height, + ellipsoid, + result[index] + ); + } + return result; +}; +Cartesian3.ZERO = Object.freeze(new Cartesian3(0, 0, 0)); +Cartesian3.ONE = Object.freeze(new Cartesian3(1, 1, 1)); +Cartesian3.UNIT_X = Object.freeze(new Cartesian3(1, 0, 0)); +Cartesian3.UNIT_Y = Object.freeze(new Cartesian3(0, 1, 0)); +Cartesian3.UNIT_Z = Object.freeze(new Cartesian3(0, 0, 1)); +Cartesian3.prototype.clone = function(result) { + return Cartesian3.clone(this, result); +}; +Cartesian3.prototype.equals = function(right) { + return Cartesian3.equals(this, right); +}; +Cartesian3.prototype.equalsEpsilon = function(right, relativeEpsilon, absoluteEpsilon) { + return Cartesian3.equalsEpsilon( + this, + right, + relativeEpsilon, + absoluteEpsilon + ); +}; +Cartesian3.prototype.toString = function() { + return `(${this.x}, ${this.y}, ${this.z})`; +}; +var Cartesian3_default = Cartesian3; + +// packages/engine/Source/Core/scaleToGeodeticSurface.js +var scaleToGeodeticSurfaceIntersection = new Cartesian3_default(); +var scaleToGeodeticSurfaceGradient = new Cartesian3_default(); +function scaleToGeodeticSurface(cartesian, oneOverRadii, oneOverRadiiSquared, centerToleranceSquared, result) { + if (!defined_default(cartesian)) { + throw new DeveloperError_default("cartesian is required."); + } + if (!defined_default(oneOverRadii)) { + throw new DeveloperError_default("oneOverRadii is required."); + } + if (!defined_default(oneOverRadiiSquared)) { + throw new DeveloperError_default("oneOverRadiiSquared is required."); + } + if (!defined_default(centerToleranceSquared)) { + throw new DeveloperError_default("centerToleranceSquared is required."); + } + const positionX = cartesian.x; + const positionY = cartesian.y; + const positionZ = cartesian.z; + const oneOverRadiiX = oneOverRadii.x; + const oneOverRadiiY = oneOverRadii.y; + const oneOverRadiiZ = oneOverRadii.z; + const x2 = positionX * positionX * oneOverRadiiX * oneOverRadiiX; + const y2 = positionY * positionY * oneOverRadiiY * oneOverRadiiY; + const z2 = positionZ * positionZ * oneOverRadiiZ * oneOverRadiiZ; + const squaredNorm = x2 + y2 + z2; + const ratio = Math.sqrt(1 / squaredNorm); + const intersection = Cartesian3_default.multiplyByScalar( + cartesian, + ratio, + scaleToGeodeticSurfaceIntersection + ); + if (squaredNorm < centerToleranceSquared) { + return !isFinite(ratio) ? void 0 : Cartesian3_default.clone(intersection, result); + } + const oneOverRadiiSquaredX = oneOverRadiiSquared.x; + const oneOverRadiiSquaredY = oneOverRadiiSquared.y; + const oneOverRadiiSquaredZ = oneOverRadiiSquared.z; + const gradient = scaleToGeodeticSurfaceGradient; + gradient.x = intersection.x * oneOverRadiiSquaredX * 2; + gradient.y = intersection.y * oneOverRadiiSquaredY * 2; + gradient.z = intersection.z * oneOverRadiiSquaredZ * 2; + let lambda = (1 - ratio) * Cartesian3_default.magnitude(cartesian) / (0.5 * Cartesian3_default.magnitude(gradient)); + let correction = 0; + let func; + let denominator; + let xMultiplier; + let yMultiplier; + let zMultiplier; + let xMultiplier2; + let yMultiplier2; + let zMultiplier2; + let xMultiplier3; + let yMultiplier3; + let zMultiplier3; + do { + lambda -= correction; + xMultiplier = 1 / (1 + lambda * oneOverRadiiSquaredX); + yMultiplier = 1 / (1 + lambda * oneOverRadiiSquaredY); + zMultiplier = 1 / (1 + lambda * oneOverRadiiSquaredZ); + xMultiplier2 = xMultiplier * xMultiplier; + yMultiplier2 = yMultiplier * yMultiplier; + zMultiplier2 = zMultiplier * zMultiplier; + xMultiplier3 = xMultiplier2 * xMultiplier; + yMultiplier3 = yMultiplier2 * yMultiplier; + zMultiplier3 = zMultiplier2 * zMultiplier; + func = x2 * xMultiplier2 + y2 * yMultiplier2 + z2 * zMultiplier2 - 1; + denominator = x2 * xMultiplier3 * oneOverRadiiSquaredX + y2 * yMultiplier3 * oneOverRadiiSquaredY + z2 * zMultiplier3 * oneOverRadiiSquaredZ; + const derivative = -2 * denominator; + correction = func / derivative; + } while (Math.abs(func) > Math_default.EPSILON12); + if (!defined_default(result)) { + return new Cartesian3_default( + positionX * xMultiplier, + positionY * yMultiplier, + positionZ * zMultiplier + ); + } + result.x = positionX * xMultiplier; + result.y = positionY * yMultiplier; + result.z = positionZ * zMultiplier; + return result; +} +var scaleToGeodeticSurface_default = scaleToGeodeticSurface; + +// packages/engine/Source/Core/Cartographic.js +function Cartographic(longitude, latitude, height) { + this.longitude = defaultValue_default(longitude, 0); + this.latitude = defaultValue_default(latitude, 0); + this.height = defaultValue_default(height, 0); +} +Cartographic.fromRadians = function(longitude, latitude, height, result) { + Check_default.typeOf.number("longitude", longitude); + Check_default.typeOf.number("latitude", latitude); + height = defaultValue_default(height, 0); + if (!defined_default(result)) { + return new Cartographic(longitude, latitude, height); + } + result.longitude = longitude; + result.latitude = latitude; + result.height = height; + return result; +}; +Cartographic.fromDegrees = function(longitude, latitude, height, result) { + Check_default.typeOf.number("longitude", longitude); + Check_default.typeOf.number("latitude", latitude); + longitude = Math_default.toRadians(longitude); + latitude = Math_default.toRadians(latitude); + return Cartographic.fromRadians(longitude, latitude, height, result); +}; +var cartesianToCartographicN = new Cartesian3_default(); +var cartesianToCartographicP = new Cartesian3_default(); +var cartesianToCartographicH = new Cartesian3_default(); +var wgs84OneOverRadii = new Cartesian3_default( + 1 / 6378137, + 1 / 6378137, + 1 / 6356752314245179e-9 +); +var wgs84OneOverRadiiSquared = new Cartesian3_default( + 1 / (6378137 * 6378137), + 1 / (6378137 * 6378137), + 1 / (6356752314245179e-9 * 6356752314245179e-9) +); +var wgs84CenterToleranceSquared = Math_default.EPSILON1; +Cartographic.fromCartesian = function(cartesian, ellipsoid, result) { + const oneOverRadii = defined_default(ellipsoid) ? ellipsoid.oneOverRadii : wgs84OneOverRadii; + const oneOverRadiiSquared = defined_default(ellipsoid) ? ellipsoid.oneOverRadiiSquared : wgs84OneOverRadiiSquared; + const centerToleranceSquared = defined_default(ellipsoid) ? ellipsoid._centerToleranceSquared : wgs84CenterToleranceSquared; + const p = scaleToGeodeticSurface_default( + cartesian, + oneOverRadii, + oneOverRadiiSquared, + centerToleranceSquared, + cartesianToCartographicP + ); + if (!defined_default(p)) { + return void 0; + } + let n = Cartesian3_default.multiplyComponents( + p, + oneOverRadiiSquared, + cartesianToCartographicN + ); + n = Cartesian3_default.normalize(n, n); + const h = Cartesian3_default.subtract(cartesian, p, cartesianToCartographicH); + const longitude = Math.atan2(n.y, n.x); + const latitude = Math.asin(n.z); + const height = Math_default.sign(Cartesian3_default.dot(h, cartesian)) * Cartesian3_default.magnitude(h); + if (!defined_default(result)) { + return new Cartographic(longitude, latitude, height); + } + result.longitude = longitude; + result.latitude = latitude; + result.height = height; + return result; +}; +Cartographic.toCartesian = function(cartographic, ellipsoid, result) { + Check_default.defined("cartographic", cartographic); + return Cartesian3_default.fromRadians( + cartographic.longitude, + cartographic.latitude, + cartographic.height, + ellipsoid, + result + ); +}; +Cartographic.clone = function(cartographic, result) { + if (!defined_default(cartographic)) { + return void 0; + } + if (!defined_default(result)) { + return new Cartographic( + cartographic.longitude, + cartographic.latitude, + cartographic.height + ); + } + result.longitude = cartographic.longitude; + result.latitude = cartographic.latitude; + result.height = cartographic.height; + return result; +}; +Cartographic.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left.longitude === right.longitude && left.latitude === right.latitude && left.height === right.height; +}; +Cartographic.equalsEpsilon = function(left, right, epsilon) { + epsilon = defaultValue_default(epsilon, 0); + return left === right || defined_default(left) && defined_default(right) && Math.abs(left.longitude - right.longitude) <= epsilon && Math.abs(left.latitude - right.latitude) <= epsilon && Math.abs(left.height - right.height) <= epsilon; +}; +Cartographic.ZERO = Object.freeze(new Cartographic(0, 0, 0)); +Cartographic.prototype.clone = function(result) { + return Cartographic.clone(this, result); +}; +Cartographic.prototype.equals = function(right) { + return Cartographic.equals(this, right); +}; +Cartographic.prototype.equalsEpsilon = function(right, epsilon) { + return Cartographic.equalsEpsilon(this, right, epsilon); +}; +Cartographic.prototype.toString = function() { + return `(${this.longitude}, ${this.latitude}, ${this.height})`; +}; +var Cartographic_default = Cartographic; + +// packages/engine/Source/Core/Ellipsoid.js +function initialize(ellipsoid, x, y, z) { + x = defaultValue_default(x, 0); + y = defaultValue_default(y, 0); + z = defaultValue_default(z, 0); + Check_default.typeOf.number.greaterThanOrEquals("x", x, 0); + Check_default.typeOf.number.greaterThanOrEquals("y", y, 0); + Check_default.typeOf.number.greaterThanOrEquals("z", z, 0); + ellipsoid._radii = new Cartesian3_default(x, y, z); + ellipsoid._radiiSquared = new Cartesian3_default(x * x, y * y, z * z); + ellipsoid._radiiToTheFourth = new Cartesian3_default( + x * x * x * x, + y * y * y * y, + z * z * z * z + ); + ellipsoid._oneOverRadii = new Cartesian3_default( + x === 0 ? 0 : 1 / x, + y === 0 ? 0 : 1 / y, + z === 0 ? 0 : 1 / z + ); + ellipsoid._oneOverRadiiSquared = new Cartesian3_default( + x === 0 ? 0 : 1 / (x * x), + y === 0 ? 0 : 1 / (y * y), + z === 0 ? 0 : 1 / (z * z) + ); + ellipsoid._minimumRadius = Math.min(x, y, z); + ellipsoid._maximumRadius = Math.max(x, y, z); + ellipsoid._centerToleranceSquared = Math_default.EPSILON1; + if (ellipsoid._radiiSquared.z !== 0) { + ellipsoid._squaredXOverSquaredZ = ellipsoid._radiiSquared.x / ellipsoid._radiiSquared.z; + } +} +function Ellipsoid(x, y, z) { + this._radii = void 0; + this._radiiSquared = void 0; + this._radiiToTheFourth = void 0; + this._oneOverRadii = void 0; + this._oneOverRadiiSquared = void 0; + this._minimumRadius = void 0; + this._maximumRadius = void 0; + this._centerToleranceSquared = void 0; + this._squaredXOverSquaredZ = void 0; + initialize(this, x, y, z); +} +Object.defineProperties(Ellipsoid.prototype, { + /** + * Gets the radii of the ellipsoid. + * @memberof Ellipsoid.prototype + * @type {Cartesian3} + * @readonly + */ + radii: { + get: function() { + return this._radii; + } + }, + /** + * Gets the squared radii of the ellipsoid. + * @memberof Ellipsoid.prototype + * @type {Cartesian3} + * @readonly + */ + radiiSquared: { + get: function() { + return this._radiiSquared; + } + }, + /** + * Gets the radii of the ellipsoid raise to the fourth power. + * @memberof Ellipsoid.prototype + * @type {Cartesian3} + * @readonly + */ + radiiToTheFourth: { + get: function() { + return this._radiiToTheFourth; + } + }, + /** + * Gets one over the radii of the ellipsoid. + * @memberof Ellipsoid.prototype + * @type {Cartesian3} + * @readonly + */ + oneOverRadii: { + get: function() { + return this._oneOverRadii; + } + }, + /** + * Gets one over the squared radii of the ellipsoid. + * @memberof Ellipsoid.prototype + * @type {Cartesian3} + * @readonly + */ + oneOverRadiiSquared: { + get: function() { + return this._oneOverRadiiSquared; + } + }, + /** + * Gets the minimum radius of the ellipsoid. + * @memberof Ellipsoid.prototype + * @type {number} + * @readonly + */ + minimumRadius: { + get: function() { + return this._minimumRadius; + } + }, + /** + * Gets the maximum radius of the ellipsoid. + * @memberof Ellipsoid.prototype + * @type {number} + * @readonly + */ + maximumRadius: { + get: function() { + return this._maximumRadius; + } + } +}); +Ellipsoid.clone = function(ellipsoid, result) { + if (!defined_default(ellipsoid)) { + return void 0; + } + const radii = ellipsoid._radii; + if (!defined_default(result)) { + return new Ellipsoid(radii.x, radii.y, radii.z); + } + Cartesian3_default.clone(radii, result._radii); + Cartesian3_default.clone(ellipsoid._radiiSquared, result._radiiSquared); + Cartesian3_default.clone(ellipsoid._radiiToTheFourth, result._radiiToTheFourth); + Cartesian3_default.clone(ellipsoid._oneOverRadii, result._oneOverRadii); + Cartesian3_default.clone(ellipsoid._oneOverRadiiSquared, result._oneOverRadiiSquared); + result._minimumRadius = ellipsoid._minimumRadius; + result._maximumRadius = ellipsoid._maximumRadius; + result._centerToleranceSquared = ellipsoid._centerToleranceSquared; + return result; +}; +Ellipsoid.fromCartesian3 = function(cartesian, result) { + if (!defined_default(result)) { + result = new Ellipsoid(); + } + if (!defined_default(cartesian)) { + return result; + } + initialize(result, cartesian.x, cartesian.y, cartesian.z); + return result; +}; +Ellipsoid.WGS84 = Object.freeze( + new Ellipsoid(6378137, 6378137, 6356752314245179e-9) +); +Ellipsoid.UNIT_SPHERE = Object.freeze(new Ellipsoid(1, 1, 1)); +Ellipsoid.MOON = Object.freeze( + new Ellipsoid( + Math_default.LUNAR_RADIUS, + Math_default.LUNAR_RADIUS, + Math_default.LUNAR_RADIUS + ) +); +Ellipsoid.prototype.clone = function(result) { + return Ellipsoid.clone(this, result); +}; +Ellipsoid.packedLength = Cartesian3_default.packedLength; +Ellipsoid.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + Cartesian3_default.pack(value._radii, array, startingIndex); + return array; +}; +Ellipsoid.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + const radii = Cartesian3_default.unpack(array, startingIndex); + return Ellipsoid.fromCartesian3(radii, result); +}; +Ellipsoid.prototype.geocentricSurfaceNormal = Cartesian3_default.normalize; +Ellipsoid.prototype.geodeticSurfaceNormalCartographic = function(cartographic, result) { + Check_default.typeOf.object("cartographic", cartographic); + const longitude = cartographic.longitude; + const latitude = cartographic.latitude; + const cosLatitude = Math.cos(latitude); + const x = cosLatitude * Math.cos(longitude); + const y = cosLatitude * Math.sin(longitude); + const z = Math.sin(latitude); + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + result.x = x; + result.y = y; + result.z = z; + return Cartesian3_default.normalize(result, result); +}; +Ellipsoid.prototype.geodeticSurfaceNormal = function(cartesian, result) { + if (Cartesian3_default.equalsEpsilon(cartesian, Cartesian3_default.ZERO, Math_default.EPSILON14)) { + return void 0; + } + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + result = Cartesian3_default.multiplyComponents( + cartesian, + this._oneOverRadiiSquared, + result + ); + return Cartesian3_default.normalize(result, result); +}; +var cartographicToCartesianNormal = new Cartesian3_default(); +var cartographicToCartesianK = new Cartesian3_default(); +Ellipsoid.prototype.cartographicToCartesian = function(cartographic, result) { + const n = cartographicToCartesianNormal; + const k = cartographicToCartesianK; + this.geodeticSurfaceNormalCartographic(cartographic, n); + Cartesian3_default.multiplyComponents(this._radiiSquared, n, k); + const gamma = Math.sqrt(Cartesian3_default.dot(n, k)); + Cartesian3_default.divideByScalar(k, gamma, k); + Cartesian3_default.multiplyByScalar(n, cartographic.height, n); + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + return Cartesian3_default.add(k, n, result); +}; +Ellipsoid.prototype.cartographicArrayToCartesianArray = function(cartographics, result) { + Check_default.defined("cartographics", cartographics); + const length = cartographics.length; + if (!defined_default(result)) { + result = new Array(length); + } else { + result.length = length; + } + for (let i = 0; i < length; i++) { + result[i] = this.cartographicToCartesian(cartographics[i], result[i]); + } + return result; +}; +var cartesianToCartographicN2 = new Cartesian3_default(); +var cartesianToCartographicP2 = new Cartesian3_default(); +var cartesianToCartographicH2 = new Cartesian3_default(); +Ellipsoid.prototype.cartesianToCartographic = function(cartesian, result) { + const p = this.scaleToGeodeticSurface(cartesian, cartesianToCartographicP2); + if (!defined_default(p)) { + return void 0; + } + const n = this.geodeticSurfaceNormal(p, cartesianToCartographicN2); + const h = Cartesian3_default.subtract(cartesian, p, cartesianToCartographicH2); + const longitude = Math.atan2(n.y, n.x); + const latitude = Math.asin(n.z); + const height = Math_default.sign(Cartesian3_default.dot(h, cartesian)) * Cartesian3_default.magnitude(h); + if (!defined_default(result)) { + return new Cartographic_default(longitude, latitude, height); + } + result.longitude = longitude; + result.latitude = latitude; + result.height = height; + return result; +}; +Ellipsoid.prototype.cartesianArrayToCartographicArray = function(cartesians, result) { + Check_default.defined("cartesians", cartesians); + const length = cartesians.length; + if (!defined_default(result)) { + result = new Array(length); + } else { + result.length = length; + } + for (let i = 0; i < length; ++i) { + result[i] = this.cartesianToCartographic(cartesians[i], result[i]); + } + return result; +}; +Ellipsoid.prototype.scaleToGeodeticSurface = function(cartesian, result) { + return scaleToGeodeticSurface_default( + cartesian, + this._oneOverRadii, + this._oneOverRadiiSquared, + this._centerToleranceSquared, + result + ); +}; +Ellipsoid.prototype.scaleToGeocentricSurface = function(cartesian, result) { + Check_default.typeOf.object("cartesian", cartesian); + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + const positionX = cartesian.x; + const positionY = cartesian.y; + const positionZ = cartesian.z; + const oneOverRadiiSquared = this._oneOverRadiiSquared; + const beta = 1 / Math.sqrt( + positionX * positionX * oneOverRadiiSquared.x + positionY * positionY * oneOverRadiiSquared.y + positionZ * positionZ * oneOverRadiiSquared.z + ); + return Cartesian3_default.multiplyByScalar(cartesian, beta, result); +}; +Ellipsoid.prototype.transformPositionToScaledSpace = function(position, result) { + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + return Cartesian3_default.multiplyComponents(position, this._oneOverRadii, result); +}; +Ellipsoid.prototype.transformPositionFromScaledSpace = function(position, result) { + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + return Cartesian3_default.multiplyComponents(position, this._radii, result); +}; +Ellipsoid.prototype.equals = function(right) { + return this === right || defined_default(right) && Cartesian3_default.equals(this._radii, right._radii); +}; +Ellipsoid.prototype.toString = function() { + return this._radii.toString(); +}; +Ellipsoid.prototype.getSurfaceNormalIntersectionWithZAxis = function(position, buffer, result) { + Check_default.typeOf.object("position", position); + if (!Math_default.equalsEpsilon( + this._radii.x, + this._radii.y, + Math_default.EPSILON15 + )) { + throw new DeveloperError_default( + "Ellipsoid must be an ellipsoid of revolution (radii.x == radii.y)" + ); + } + Check_default.typeOf.number.greaterThan("Ellipsoid.radii.z", this._radii.z, 0); + buffer = defaultValue_default(buffer, 0); + const squaredXOverSquaredZ = this._squaredXOverSquaredZ; + if (!defined_default(result)) { + result = new Cartesian3_default(); + } + result.x = 0; + result.y = 0; + result.z = position.z * (1 - squaredXOverSquaredZ); + if (Math.abs(result.z) >= this._radii.z - buffer) { + return void 0; + } + return result; +}; +var abscissas = [ + 0.14887433898163, + 0.43339539412925, + 0.67940956829902, + 0.86506336668898, + 0.97390652851717, + 0 +]; +var weights = [ + 0.29552422471475, + 0.26926671930999, + 0.21908636251598, + 0.14945134915058, + 0.066671344308684, + 0 +]; +function gaussLegendreQuadrature(a, b, func) { + Check_default.typeOf.number("a", a); + Check_default.typeOf.number("b", b); + Check_default.typeOf.func("func", func); + const xMean = 0.5 * (b + a); + const xRange = 0.5 * (b - a); + let sum = 0; + for (let i = 0; i < 5; i++) { + const dx = xRange * abscissas[i]; + sum += weights[i] * (func(xMean + dx) + func(xMean - dx)); + } + sum *= xRange; + return sum; +} +Ellipsoid.prototype.surfaceArea = function(rectangle) { + Check_default.typeOf.object("rectangle", rectangle); + const minLongitude = rectangle.west; + let maxLongitude = rectangle.east; + const minLatitude = rectangle.south; + const maxLatitude = rectangle.north; + while (maxLongitude < minLongitude) { + maxLongitude += Math_default.TWO_PI; + } + const radiiSquared = this._radiiSquared; + const a2 = radiiSquared.x; + const b2 = radiiSquared.y; + const c2 = radiiSquared.z; + const a2b2 = a2 * b2; + return gaussLegendreQuadrature(minLatitude, maxLatitude, function(lat) { + const sinPhi = Math.cos(lat); + const cosPhi = Math.sin(lat); + return Math.cos(lat) * gaussLegendreQuadrature(minLongitude, maxLongitude, function(lon) { + const cosTheta = Math.cos(lon); + const sinTheta = Math.sin(lon); + return Math.sqrt( + a2b2 * cosPhi * cosPhi + c2 * (b2 * cosTheta * cosTheta + a2 * sinTheta * sinTheta) * sinPhi * sinPhi + ); + }); + }); +}; +var Ellipsoid_default = Ellipsoid; + +// packages/engine/Source/Core/Matrix3.js +function Matrix3(column0Row0, column1Row0, column2Row0, column0Row1, column1Row1, column2Row1, column0Row2, column1Row2, column2Row2) { + this[0] = defaultValue_default(column0Row0, 0); + this[1] = defaultValue_default(column0Row1, 0); + this[2] = defaultValue_default(column0Row2, 0); + this[3] = defaultValue_default(column1Row0, 0); + this[4] = defaultValue_default(column1Row1, 0); + this[5] = defaultValue_default(column1Row2, 0); + this[6] = defaultValue_default(column2Row0, 0); + this[7] = defaultValue_default(column2Row1, 0); + this[8] = defaultValue_default(column2Row2, 0); +} +Matrix3.packedLength = 9; +Matrix3.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + array[startingIndex++] = value[0]; + array[startingIndex++] = value[1]; + array[startingIndex++] = value[2]; + array[startingIndex++] = value[3]; + array[startingIndex++] = value[4]; + array[startingIndex++] = value[5]; + array[startingIndex++] = value[6]; + array[startingIndex++] = value[7]; + array[startingIndex++] = value[8]; + return array; +}; +Matrix3.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new Matrix3(); + } + result[0] = array[startingIndex++]; + result[1] = array[startingIndex++]; + result[2] = array[startingIndex++]; + result[3] = array[startingIndex++]; + result[4] = array[startingIndex++]; + result[5] = array[startingIndex++]; + result[6] = array[startingIndex++]; + result[7] = array[startingIndex++]; + result[8] = array[startingIndex++]; + return result; +}; +Matrix3.packArray = function(array, result) { + Check_default.defined("array", array); + const length = array.length; + const resultLength = length * 9; + if (!defined_default(result)) { + result = new Array(resultLength); + } else if (!Array.isArray(result) && result.length !== resultLength) { + throw new DeveloperError_default( + "If result is a typed array, it must have exactly array.length * 9 elements" + ); + } else if (result.length !== resultLength) { + result.length = resultLength; + } + for (let i = 0; i < length; ++i) { + Matrix3.pack(array[i], result, i * 9); + } + return result; +}; +Matrix3.unpackArray = function(array, result) { + Check_default.defined("array", array); + Check_default.typeOf.number.greaterThanOrEquals("array.length", array.length, 9); + if (array.length % 9 !== 0) { + throw new DeveloperError_default("array length must be a multiple of 9."); + } + const length = array.length; + if (!defined_default(result)) { + result = new Array(length / 9); + } else { + result.length = length / 9; + } + for (let i = 0; i < length; i += 9) { + const index = i / 9; + result[index] = Matrix3.unpack(array, i, result[index]); + } + return result; +}; +Matrix3.clone = function(matrix, result) { + if (!defined_default(matrix)) { + return void 0; + } + if (!defined_default(result)) { + return new Matrix3( + matrix[0], + matrix[3], + matrix[6], + matrix[1], + matrix[4], + matrix[7], + matrix[2], + matrix[5], + matrix[8] + ); + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + return result; +}; +Matrix3.fromArray = Matrix3.unpack; +Matrix3.fromColumnMajorArray = function(values, result) { + Check_default.defined("values", values); + return Matrix3.clone(values, result); +}; +Matrix3.fromRowMajorArray = function(values, result) { + Check_default.defined("values", values); + if (!defined_default(result)) { + return new Matrix3( + values[0], + values[1], + values[2], + values[3], + values[4], + values[5], + values[6], + values[7], + values[8] + ); + } + result[0] = values[0]; + result[1] = values[3]; + result[2] = values[6]; + result[3] = values[1]; + result[4] = values[4]; + result[5] = values[7]; + result[6] = values[2]; + result[7] = values[5]; + result[8] = values[8]; + return result; +}; +Matrix3.fromQuaternion = function(quaternion, result) { + Check_default.typeOf.object("quaternion", quaternion); + const x2 = quaternion.x * quaternion.x; + const xy = quaternion.x * quaternion.y; + const xz = quaternion.x * quaternion.z; + const xw = quaternion.x * quaternion.w; + const y2 = quaternion.y * quaternion.y; + const yz = quaternion.y * quaternion.z; + const yw = quaternion.y * quaternion.w; + const z2 = quaternion.z * quaternion.z; + const zw = quaternion.z * quaternion.w; + const w2 = quaternion.w * quaternion.w; + const m00 = x2 - y2 - z2 + w2; + const m01 = 2 * (xy - zw); + const m02 = 2 * (xz + yw); + const m10 = 2 * (xy + zw); + const m11 = -x2 + y2 - z2 + w2; + const m12 = 2 * (yz - xw); + const m20 = 2 * (xz - yw); + const m21 = 2 * (yz + xw); + const m22 = -x2 - y2 + z2 + w2; + if (!defined_default(result)) { + return new Matrix3(m00, m01, m02, m10, m11, m12, m20, m21, m22); + } + result[0] = m00; + result[1] = m10; + result[2] = m20; + result[3] = m01; + result[4] = m11; + result[5] = m21; + result[6] = m02; + result[7] = m12; + result[8] = m22; + return result; +}; +Matrix3.fromHeadingPitchRoll = function(headingPitchRoll, result) { + Check_default.typeOf.object("headingPitchRoll", headingPitchRoll); + const cosTheta = Math.cos(-headingPitchRoll.pitch); + const cosPsi = Math.cos(-headingPitchRoll.heading); + const cosPhi = Math.cos(headingPitchRoll.roll); + const sinTheta = Math.sin(-headingPitchRoll.pitch); + const sinPsi = Math.sin(-headingPitchRoll.heading); + const sinPhi = Math.sin(headingPitchRoll.roll); + const m00 = cosTheta * cosPsi; + const m01 = -cosPhi * sinPsi + sinPhi * sinTheta * cosPsi; + const m02 = sinPhi * sinPsi + cosPhi * sinTheta * cosPsi; + const m10 = cosTheta * sinPsi; + const m11 = cosPhi * cosPsi + sinPhi * sinTheta * sinPsi; + const m12 = -sinPhi * cosPsi + cosPhi * sinTheta * sinPsi; + const m20 = -sinTheta; + const m21 = sinPhi * cosTheta; + const m22 = cosPhi * cosTheta; + if (!defined_default(result)) { + return new Matrix3(m00, m01, m02, m10, m11, m12, m20, m21, m22); + } + result[0] = m00; + result[1] = m10; + result[2] = m20; + result[3] = m01; + result[4] = m11; + result[5] = m21; + result[6] = m02; + result[7] = m12; + result[8] = m22; + return result; +}; +Matrix3.fromScale = function(scale, result) { + Check_default.typeOf.object("scale", scale); + if (!defined_default(result)) { + return new Matrix3(scale.x, 0, 0, 0, scale.y, 0, 0, 0, scale.z); + } + result[0] = scale.x; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = scale.y; + result[5] = 0; + result[6] = 0; + result[7] = 0; + result[8] = scale.z; + return result; +}; +Matrix3.fromUniformScale = function(scale, result) { + Check_default.typeOf.number("scale", scale); + if (!defined_default(result)) { + return new Matrix3(scale, 0, 0, 0, scale, 0, 0, 0, scale); + } + result[0] = scale; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = scale; + result[5] = 0; + result[6] = 0; + result[7] = 0; + result[8] = scale; + return result; +}; +Matrix3.fromCrossProduct = function(vector, result) { + Check_default.typeOf.object("vector", vector); + if (!defined_default(result)) { + return new Matrix3( + 0, + -vector.z, + vector.y, + vector.z, + 0, + -vector.x, + -vector.y, + vector.x, + 0 + ); + } + result[0] = 0; + result[1] = vector.z; + result[2] = -vector.y; + result[3] = -vector.z; + result[4] = 0; + result[5] = vector.x; + result[6] = vector.y; + result[7] = -vector.x; + result[8] = 0; + return result; +}; +Matrix3.fromRotationX = function(angle, result) { + Check_default.typeOf.number("angle", angle); + const cosAngle = Math.cos(angle); + const sinAngle = Math.sin(angle); + if (!defined_default(result)) { + return new Matrix3( + 1, + 0, + 0, + 0, + cosAngle, + -sinAngle, + 0, + sinAngle, + cosAngle + ); + } + result[0] = 1; + result[1] = 0; + result[2] = 0; + result[3] = 0; + result[4] = cosAngle; + result[5] = sinAngle; + result[6] = 0; + result[7] = -sinAngle; + result[8] = cosAngle; + return result; +}; +Matrix3.fromRotationY = function(angle, result) { + Check_default.typeOf.number("angle", angle); + const cosAngle = Math.cos(angle); + const sinAngle = Math.sin(angle); + if (!defined_default(result)) { + return new Matrix3( + cosAngle, + 0, + sinAngle, + 0, + 1, + 0, + -sinAngle, + 0, + cosAngle + ); + } + result[0] = cosAngle; + result[1] = 0; + result[2] = -sinAngle; + result[3] = 0; + result[4] = 1; + result[5] = 0; + result[6] = sinAngle; + result[7] = 0; + result[8] = cosAngle; + return result; +}; +Matrix3.fromRotationZ = function(angle, result) { + Check_default.typeOf.number("angle", angle); + const cosAngle = Math.cos(angle); + const sinAngle = Math.sin(angle); + if (!defined_default(result)) { + return new Matrix3( + cosAngle, + -sinAngle, + 0, + sinAngle, + cosAngle, + 0, + 0, + 0, + 1 + ); + } + result[0] = cosAngle; + result[1] = sinAngle; + result[2] = 0; + result[3] = -sinAngle; + result[4] = cosAngle; + result[5] = 0; + result[6] = 0; + result[7] = 0; + result[8] = 1; + return result; +}; +Matrix3.toArray = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + if (!defined_default(result)) { + return [ + matrix[0], + matrix[1], + matrix[2], + matrix[3], + matrix[4], + matrix[5], + matrix[6], + matrix[7], + matrix[8] + ]; + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + return result; +}; +Matrix3.getElementIndex = function(column, row) { + Check_default.typeOf.number.greaterThanOrEquals("row", row, 0); + Check_default.typeOf.number.lessThanOrEquals("row", row, 2); + Check_default.typeOf.number.greaterThanOrEquals("column", column, 0); + Check_default.typeOf.number.lessThanOrEquals("column", column, 2); + return column * 3 + row; +}; +Matrix3.getColumn = function(matrix, index, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 2); + Check_default.typeOf.object("result", result); + const startIndex = index * 3; + const x = matrix[startIndex]; + const y = matrix[startIndex + 1]; + const z = matrix[startIndex + 2]; + result.x = x; + result.y = y; + result.z = z; + return result; +}; +Matrix3.setColumn = function(matrix, index, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 2); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result = Matrix3.clone(matrix, result); + const startIndex = index * 3; + result[startIndex] = cartesian.x; + result[startIndex + 1] = cartesian.y; + result[startIndex + 2] = cartesian.z; + return result; +}; +Matrix3.getRow = function(matrix, index, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 2); + Check_default.typeOf.object("result", result); + const x = matrix[index]; + const y = matrix[index + 3]; + const z = matrix[index + 6]; + result.x = x; + result.y = y; + result.z = z; + return result; +}; +Matrix3.setRow = function(matrix, index, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number.greaterThanOrEquals("index", index, 0); + Check_default.typeOf.number.lessThanOrEquals("index", index, 2); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + result = Matrix3.clone(matrix, result); + result[index] = cartesian.x; + result[index + 3] = cartesian.y; + result[index + 6] = cartesian.z; + return result; +}; +var scaleScratch1 = new Cartesian3_default(); +Matrix3.setScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("scale", scale); + Check_default.typeOf.object("result", result); + const existingScale = Matrix3.getScale(matrix, scaleScratch1); + const scaleRatioX = scale.x / existingScale.x; + const scaleRatioY = scale.y / existingScale.y; + const scaleRatioZ = scale.z / existingScale.z; + result[0] = matrix[0] * scaleRatioX; + result[1] = matrix[1] * scaleRatioX; + result[2] = matrix[2] * scaleRatioX; + result[3] = matrix[3] * scaleRatioY; + result[4] = matrix[4] * scaleRatioY; + result[5] = matrix[5] * scaleRatioY; + result[6] = matrix[6] * scaleRatioZ; + result[7] = matrix[7] * scaleRatioZ; + result[8] = matrix[8] * scaleRatioZ; + return result; +}; +var scaleScratch2 = new Cartesian3_default(); +Matrix3.setUniformScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number("scale", scale); + Check_default.typeOf.object("result", result); + const existingScale = Matrix3.getScale(matrix, scaleScratch2); + const scaleRatioX = scale / existingScale.x; + const scaleRatioY = scale / existingScale.y; + const scaleRatioZ = scale / existingScale.z; + result[0] = matrix[0] * scaleRatioX; + result[1] = matrix[1] * scaleRatioX; + result[2] = matrix[2] * scaleRatioX; + result[3] = matrix[3] * scaleRatioY; + result[4] = matrix[4] * scaleRatioY; + result[5] = matrix[5] * scaleRatioY; + result[6] = matrix[6] * scaleRatioZ; + result[7] = matrix[7] * scaleRatioZ; + result[8] = matrix[8] * scaleRatioZ; + return result; +}; +var scratchColumn = new Cartesian3_default(); +Matrix3.getScale = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result.x = Cartesian3_default.magnitude( + Cartesian3_default.fromElements(matrix[0], matrix[1], matrix[2], scratchColumn) + ); + result.y = Cartesian3_default.magnitude( + Cartesian3_default.fromElements(matrix[3], matrix[4], matrix[5], scratchColumn) + ); + result.z = Cartesian3_default.magnitude( + Cartesian3_default.fromElements(matrix[6], matrix[7], matrix[8], scratchColumn) + ); + return result; +}; +var scaleScratch3 = new Cartesian3_default(); +Matrix3.getMaximumScale = function(matrix) { + Matrix3.getScale(matrix, scaleScratch3); + return Cartesian3_default.maximumComponent(scaleScratch3); +}; +var scaleScratch4 = new Cartesian3_default(); +Matrix3.setRotation = function(matrix, rotation, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const scale = Matrix3.getScale(matrix, scaleScratch4); + result[0] = rotation[0] * scale.x; + result[1] = rotation[1] * scale.x; + result[2] = rotation[2] * scale.x; + result[3] = rotation[3] * scale.y; + result[4] = rotation[4] * scale.y; + result[5] = rotation[5] * scale.y; + result[6] = rotation[6] * scale.z; + result[7] = rotation[7] * scale.z; + result[8] = rotation[8] * scale.z; + return result; +}; +var scaleScratch5 = new Cartesian3_default(); +Matrix3.getRotation = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const scale = Matrix3.getScale(matrix, scaleScratch5); + result[0] = matrix[0] / scale.x; + result[1] = matrix[1] / scale.x; + result[2] = matrix[2] / scale.x; + result[3] = matrix[3] / scale.y; + result[4] = matrix[4] / scale.y; + result[5] = matrix[5] / scale.y; + result[6] = matrix[6] / scale.z; + result[7] = matrix[7] / scale.z; + result[8] = matrix[8] / scale.z; + return result; +}; +Matrix3.multiply = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + const column0Row0 = left[0] * right[0] + left[3] * right[1] + left[6] * right[2]; + const column0Row1 = left[1] * right[0] + left[4] * right[1] + left[7] * right[2]; + const column0Row2 = left[2] * right[0] + left[5] * right[1] + left[8] * right[2]; + const column1Row0 = left[0] * right[3] + left[3] * right[4] + left[6] * right[5]; + const column1Row1 = left[1] * right[3] + left[4] * right[4] + left[7] * right[5]; + const column1Row2 = left[2] * right[3] + left[5] * right[4] + left[8] * right[5]; + const column2Row0 = left[0] * right[6] + left[3] * right[7] + left[6] * right[8]; + const column2Row1 = left[1] * right[6] + left[4] * right[7] + left[7] * right[8]; + const column2Row2 = left[2] * right[6] + left[5] * right[7] + left[8] * right[8]; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column0Row2; + result[3] = column1Row0; + result[4] = column1Row1; + result[5] = column1Row2; + result[6] = column2Row0; + result[7] = column2Row1; + result[8] = column2Row2; + return result; +}; +Matrix3.add = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result[0] = left[0] + right[0]; + result[1] = left[1] + right[1]; + result[2] = left[2] + right[2]; + result[3] = left[3] + right[3]; + result[4] = left[4] + right[4]; + result[5] = left[5] + right[5]; + result[6] = left[6] + right[6]; + result[7] = left[7] + right[7]; + result[8] = left[8] + right[8]; + return result; +}; +Matrix3.subtract = function(left, right, result) { + Check_default.typeOf.object("left", left); + Check_default.typeOf.object("right", right); + Check_default.typeOf.object("result", result); + result[0] = left[0] - right[0]; + result[1] = left[1] - right[1]; + result[2] = left[2] - right[2]; + result[3] = left[3] - right[3]; + result[4] = left[4] - right[4]; + result[5] = left[5] - right[5]; + result[6] = left[6] - right[6]; + result[7] = left[7] - right[7]; + result[8] = left[8] - right[8]; + return result; +}; +Matrix3.multiplyByVector = function(matrix, cartesian, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("cartesian", cartesian); + Check_default.typeOf.object("result", result); + const vX = cartesian.x; + const vY = cartesian.y; + const vZ = cartesian.z; + const x = matrix[0] * vX + matrix[3] * vY + matrix[6] * vZ; + const y = matrix[1] * vX + matrix[4] * vY + matrix[7] * vZ; + const z = matrix[2] * vX + matrix[5] * vY + matrix[8] * vZ; + result.x = x; + result.y = y; + result.z = z; + return result; +}; +Matrix3.multiplyByScalar = function(matrix, scalar, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number("scalar", scalar); + Check_default.typeOf.object("result", result); + result[0] = matrix[0] * scalar; + result[1] = matrix[1] * scalar; + result[2] = matrix[2] * scalar; + result[3] = matrix[3] * scalar; + result[4] = matrix[4] * scalar; + result[5] = matrix[5] * scalar; + result[6] = matrix[6] * scalar; + result[7] = matrix[7] * scalar; + result[8] = matrix[8] * scalar; + return result; +}; +Matrix3.multiplyByScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("scale", scale); + Check_default.typeOf.object("result", result); + result[0] = matrix[0] * scale.x; + result[1] = matrix[1] * scale.x; + result[2] = matrix[2] * scale.x; + result[3] = matrix[3] * scale.y; + result[4] = matrix[4] * scale.y; + result[5] = matrix[5] * scale.y; + result[6] = matrix[6] * scale.z; + result[7] = matrix[7] * scale.z; + result[8] = matrix[8] * scale.z; + return result; +}; +Matrix3.multiplyByUniformScale = function(matrix, scale, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.number("scale", scale); + Check_default.typeOf.object("result", result); + result[0] = matrix[0] * scale; + result[1] = matrix[1] * scale; + result[2] = matrix[2] * scale; + result[3] = matrix[3] * scale; + result[4] = matrix[4] * scale; + result[5] = matrix[5] * scale; + result[6] = matrix[6] * scale; + result[7] = matrix[7] * scale; + result[8] = matrix[8] * scale; + return result; +}; +Matrix3.negate = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result[0] = -matrix[0]; + result[1] = -matrix[1]; + result[2] = -matrix[2]; + result[3] = -matrix[3]; + result[4] = -matrix[4]; + result[5] = -matrix[5]; + result[6] = -matrix[6]; + result[7] = -matrix[7]; + result[8] = -matrix[8]; + return result; +}; +Matrix3.transpose = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const column0Row0 = matrix[0]; + const column0Row1 = matrix[3]; + const column0Row2 = matrix[6]; + const column1Row0 = matrix[1]; + const column1Row1 = matrix[4]; + const column1Row2 = matrix[7]; + const column2Row0 = matrix[2]; + const column2Row1 = matrix[5]; + const column2Row2 = matrix[8]; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column0Row2; + result[3] = column1Row0; + result[4] = column1Row1; + result[5] = column1Row2; + result[6] = column2Row0; + result[7] = column2Row1; + result[8] = column2Row2; + return result; +}; +function computeFrobeniusNorm(matrix) { + let norm = 0; + for (let i = 0; i < 9; ++i) { + const temp = matrix[i]; + norm += temp * temp; + } + return Math.sqrt(norm); +} +var rowVal = [1, 0, 0]; +var colVal = [2, 2, 1]; +function offDiagonalFrobeniusNorm(matrix) { + let norm = 0; + for (let i = 0; i < 3; ++i) { + const temp = matrix[Matrix3.getElementIndex(colVal[i], rowVal[i])]; + norm += 2 * temp * temp; + } + return Math.sqrt(norm); +} +function shurDecomposition(matrix, result) { + const tolerance = Math_default.EPSILON15; + let maxDiagonal = 0; + let rotAxis = 1; + for (let i = 0; i < 3; ++i) { + const temp = Math.abs( + matrix[Matrix3.getElementIndex(colVal[i], rowVal[i])] + ); + if (temp > maxDiagonal) { + rotAxis = i; + maxDiagonal = temp; + } + } + let c = 1; + let s = 0; + const p = rowVal[rotAxis]; + const q = colVal[rotAxis]; + if (Math.abs(matrix[Matrix3.getElementIndex(q, p)]) > tolerance) { + const qq = matrix[Matrix3.getElementIndex(q, q)]; + const pp = matrix[Matrix3.getElementIndex(p, p)]; + const qp = matrix[Matrix3.getElementIndex(q, p)]; + const tau = (qq - pp) / 2 / qp; + let t; + if (tau < 0) { + t = -1 / (-tau + Math.sqrt(1 + tau * tau)); + } else { + t = 1 / (tau + Math.sqrt(1 + tau * tau)); + } + c = 1 / Math.sqrt(1 + t * t); + s = t * c; + } + result = Matrix3.clone(Matrix3.IDENTITY, result); + result[Matrix3.getElementIndex(p, p)] = result[Matrix3.getElementIndex(q, q)] = c; + result[Matrix3.getElementIndex(q, p)] = s; + result[Matrix3.getElementIndex(p, q)] = -s; + return result; +} +var jMatrix = new Matrix3(); +var jMatrixTranspose = new Matrix3(); +Matrix3.computeEigenDecomposition = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + const tolerance = Math_default.EPSILON20; + const maxSweeps = 10; + let count = 0; + let sweep = 0; + if (!defined_default(result)) { + result = {}; + } + const unitaryMatrix = result.unitary = Matrix3.clone( + Matrix3.IDENTITY, + result.unitary + ); + const diagMatrix = result.diagonal = Matrix3.clone(matrix, result.diagonal); + const epsilon = tolerance * computeFrobeniusNorm(diagMatrix); + while (sweep < maxSweeps && offDiagonalFrobeniusNorm(diagMatrix) > epsilon) { + shurDecomposition(diagMatrix, jMatrix); + Matrix3.transpose(jMatrix, jMatrixTranspose); + Matrix3.multiply(diagMatrix, jMatrix, diagMatrix); + Matrix3.multiply(jMatrixTranspose, diagMatrix, diagMatrix); + Matrix3.multiply(unitaryMatrix, jMatrix, unitaryMatrix); + if (++count > 2) { + ++sweep; + count = 0; + } + } + return result; +}; +Matrix3.abs = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + result[0] = Math.abs(matrix[0]); + result[1] = Math.abs(matrix[1]); + result[2] = Math.abs(matrix[2]); + result[3] = Math.abs(matrix[3]); + result[4] = Math.abs(matrix[4]); + result[5] = Math.abs(matrix[5]); + result[6] = Math.abs(matrix[6]); + result[7] = Math.abs(matrix[7]); + result[8] = Math.abs(matrix[8]); + return result; +}; +Matrix3.determinant = function(matrix) { + Check_default.typeOf.object("matrix", matrix); + const m11 = matrix[0]; + const m21 = matrix[3]; + const m31 = matrix[6]; + const m12 = matrix[1]; + const m22 = matrix[4]; + const m32 = matrix[7]; + const m13 = matrix[2]; + const m23 = matrix[5]; + const m33 = matrix[8]; + return m11 * (m22 * m33 - m23 * m32) + m12 * (m23 * m31 - m21 * m33) + m13 * (m21 * m32 - m22 * m31); +}; +Matrix3.inverse = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + const m11 = matrix[0]; + const m21 = matrix[1]; + const m31 = matrix[2]; + const m12 = matrix[3]; + const m22 = matrix[4]; + const m32 = matrix[5]; + const m13 = matrix[6]; + const m23 = matrix[7]; + const m33 = matrix[8]; + const determinant = Matrix3.determinant(matrix); + if (Math.abs(determinant) <= Math_default.EPSILON15) { + throw new DeveloperError_default("matrix is not invertible"); + } + result[0] = m22 * m33 - m23 * m32; + result[1] = m23 * m31 - m21 * m33; + result[2] = m21 * m32 - m22 * m31; + result[3] = m13 * m32 - m12 * m33; + result[4] = m11 * m33 - m13 * m31; + result[5] = m12 * m31 - m11 * m32; + result[6] = m12 * m23 - m13 * m22; + result[7] = m13 * m21 - m11 * m23; + result[8] = m11 * m22 - m12 * m21; + const scale = 1 / determinant; + return Matrix3.multiplyByScalar(result, scale, result); +}; +var scratchTransposeMatrix = new Matrix3(); +Matrix3.inverseTranspose = function(matrix, result) { + Check_default.typeOf.object("matrix", matrix); + Check_default.typeOf.object("result", result); + return Matrix3.inverse( + Matrix3.transpose(matrix, scratchTransposeMatrix), + result + ); +}; +Matrix3.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && left[0] === right[0] && left[1] === right[1] && left[2] === right[2] && left[3] === right[3] && left[4] === right[4] && left[5] === right[5] && left[6] === right[6] && left[7] === right[7] && left[8] === right[8]; +}; +Matrix3.equalsEpsilon = function(left, right, epsilon) { + epsilon = defaultValue_default(epsilon, 0); + return left === right || defined_default(left) && defined_default(right) && Math.abs(left[0] - right[0]) <= epsilon && Math.abs(left[1] - right[1]) <= epsilon && Math.abs(left[2] - right[2]) <= epsilon && Math.abs(left[3] - right[3]) <= epsilon && Math.abs(left[4] - right[4]) <= epsilon && Math.abs(left[5] - right[5]) <= epsilon && Math.abs(left[6] - right[6]) <= epsilon && Math.abs(left[7] - right[7]) <= epsilon && Math.abs(left[8] - right[8]) <= epsilon; +}; +Matrix3.IDENTITY = Object.freeze( + new Matrix3(1, 0, 0, 0, 1, 0, 0, 0, 1) +); +Matrix3.ZERO = Object.freeze( + new Matrix3(0, 0, 0, 0, 0, 0, 0, 0, 0) +); +Matrix3.COLUMN0ROW0 = 0; +Matrix3.COLUMN0ROW1 = 1; +Matrix3.COLUMN0ROW2 = 2; +Matrix3.COLUMN1ROW0 = 3; +Matrix3.COLUMN1ROW1 = 4; +Matrix3.COLUMN1ROW2 = 5; +Matrix3.COLUMN2ROW0 = 6; +Matrix3.COLUMN2ROW1 = 7; +Matrix3.COLUMN2ROW2 = 8; +Object.defineProperties(Matrix3.prototype, { + /** + * Gets the number of items in the collection. + * @memberof Matrix3.prototype + * + * @type {number} + */ + length: { + get: function() { + return Matrix3.packedLength; + } + } +}); +Matrix3.prototype.clone = function(result) { + return Matrix3.clone(this, result); +}; +Matrix3.prototype.equals = function(right) { + return Matrix3.equals(this, right); +}; +Matrix3.equalsArray = function(matrix, array, offset) { + return matrix[0] === array[offset] && matrix[1] === array[offset + 1] && matrix[2] === array[offset + 2] && matrix[3] === array[offset + 3] && matrix[4] === array[offset + 4] && matrix[5] === array[offset + 5] && matrix[6] === array[offset + 6] && matrix[7] === array[offset + 7] && matrix[8] === array[offset + 8]; +}; +Matrix3.prototype.equalsEpsilon = function(right, epsilon) { + return Matrix3.equalsEpsilon(this, right, epsilon); +}; +Matrix3.prototype.toString = function() { + return `(${this[0]}, ${this[3]}, ${this[6]}) +(${this[1]}, ${this[4]}, ${this[7]}) +(${this[2]}, ${this[5]}, ${this[8]})`; +}; +var Matrix3_default = Matrix3; + +export { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default, + Matrix3_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-XZVQMPWG.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-XZVQMPWG.js new file mode 100644 index 0000000000000000000000000000000000000000..c9eab59bf70df90fbc22372774f79c3d35323b7e --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-XZVQMPWG.js @@ -0,0 +1,100 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/arrayRemoveDuplicates.js +var removeDuplicatesEpsilon = Math_default.EPSILON10; +function arrayRemoveDuplicates(values, equalsEpsilon, wrapAround, removedIndices) { + Check_default.defined("equalsEpsilon", equalsEpsilon); + if (!defined_default(values)) { + return void 0; + } + wrapAround = defaultValue_default(wrapAround, false); + const storeRemovedIndices = defined_default(removedIndices); + const length = values.length; + if (length < 2) { + return values; + } + let i; + let v0 = values[0]; + let v1; + let cleanedValues; + let lastCleanIndex = 0; + let removedIndexLCI = -1; + for (i = 1; i < length; ++i) { + v1 = values[i]; + if (equalsEpsilon(v0, v1, removeDuplicatesEpsilon)) { + if (!defined_default(cleanedValues)) { + cleanedValues = values.slice(0, i); + lastCleanIndex = i - 1; + removedIndexLCI = 0; + } + if (storeRemovedIndices) { + removedIndices.push(i); + } + } else { + if (defined_default(cleanedValues)) { + cleanedValues.push(v1); + lastCleanIndex = i; + if (storeRemovedIndices) { + removedIndexLCI = removedIndices.length; + } + } + v0 = v1; + } + } + if (wrapAround && equalsEpsilon(values[0], values[length - 1], removeDuplicatesEpsilon)) { + if (storeRemovedIndices) { + if (defined_default(cleanedValues)) { + removedIndices.splice(removedIndexLCI, 0, lastCleanIndex); + } else { + removedIndices.push(length - 1); + } + } + if (defined_default(cleanedValues)) { + cleanedValues.length -= 1; + } else { + cleanedValues = values.slice(0, -1); + } + } + return defined_default(cleanedValues) ? cleanedValues : values; +} +var arrayRemoveDuplicates_default = arrayRemoveDuplicates; + +export { + arrayRemoveDuplicates_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-YLAFWVOW.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-YLAFWVOW.js new file mode 100644 index 0000000000000000000000000000000000000000..c28ed97892e38d3a42030e2fb7535d437a689492 --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-YLAFWVOW.js @@ -0,0 +1,834 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + EllipsoidTangentPlane_default +} from "./chunk-4V6RCTVH.js"; +import { + Plane_default +} from "./chunk-PGB3EFR7.js"; +import { + BoundingSphere_default, + Intersect_default, + Interval_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default, + Matrix4_default, + Rectangle_default +} from "./chunk-PW5CA4MJ.js"; +import { + Cartesian3_default, + Cartographic_default, + Ellipsoid_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + Check_default, + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/OrientedBoundingBox.js +function OrientedBoundingBox(center, halfAxes) { + this.center = Cartesian3_default.clone(defaultValue_default(center, Cartesian3_default.ZERO)); + this.halfAxes = Matrix3_default.clone(defaultValue_default(halfAxes, Matrix3_default.ZERO)); +} +OrientedBoundingBox.packedLength = Cartesian3_default.packedLength + Matrix3_default.packedLength; +OrientedBoundingBox.pack = function(value, array, startingIndex) { + Check_default.typeOf.object("value", value); + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + Cartesian3_default.pack(value.center, array, startingIndex); + Matrix3_default.pack(value.halfAxes, array, startingIndex + Cartesian3_default.packedLength); + return array; +}; +OrientedBoundingBox.unpack = function(array, startingIndex, result) { + Check_default.defined("array", array); + startingIndex = defaultValue_default(startingIndex, 0); + if (!defined_default(result)) { + result = new OrientedBoundingBox(); + } + Cartesian3_default.unpack(array, startingIndex, result.center); + Matrix3_default.unpack( + array, + startingIndex + Cartesian3_default.packedLength, + result.halfAxes + ); + return result; +}; +var scratchCartesian1 = new Cartesian3_default(); +var scratchCartesian2 = new Cartesian3_default(); +var scratchCartesian3 = new Cartesian3_default(); +var scratchCartesian4 = new Cartesian3_default(); +var scratchCartesian5 = new Cartesian3_default(); +var scratchCartesian6 = new Cartesian3_default(); +var scratchCovarianceResult = new Matrix3_default(); +var scratchEigenResult = { + unitary: new Matrix3_default(), + diagonal: new Matrix3_default() +}; +OrientedBoundingBox.fromPoints = function(positions, result) { + if (!defined_default(result)) { + result = new OrientedBoundingBox(); + } + if (!defined_default(positions) || positions.length === 0) { + result.halfAxes = Matrix3_default.ZERO; + result.center = Cartesian3_default.ZERO; + return result; + } + let i; + const length = positions.length; + const meanPoint = Cartesian3_default.clone(positions[0], scratchCartesian1); + for (i = 1; i < length; i++) { + Cartesian3_default.add(meanPoint, positions[i], meanPoint); + } + const invLength = 1 / length; + Cartesian3_default.multiplyByScalar(meanPoint, invLength, meanPoint); + let exx = 0; + let exy = 0; + let exz = 0; + let eyy = 0; + let eyz = 0; + let ezz = 0; + let p; + for (i = 0; i < length; i++) { + p = Cartesian3_default.subtract(positions[i], meanPoint, scratchCartesian2); + exx += p.x * p.x; + exy += p.x * p.y; + exz += p.x * p.z; + eyy += p.y * p.y; + eyz += p.y * p.z; + ezz += p.z * p.z; + } + exx *= invLength; + exy *= invLength; + exz *= invLength; + eyy *= invLength; + eyz *= invLength; + ezz *= invLength; + const covarianceMatrix = scratchCovarianceResult; + covarianceMatrix[0] = exx; + covarianceMatrix[1] = exy; + covarianceMatrix[2] = exz; + covarianceMatrix[3] = exy; + covarianceMatrix[4] = eyy; + covarianceMatrix[5] = eyz; + covarianceMatrix[6] = exz; + covarianceMatrix[7] = eyz; + covarianceMatrix[8] = ezz; + const eigenDecomposition = Matrix3_default.computeEigenDecomposition( + covarianceMatrix, + scratchEigenResult + ); + const rotation = Matrix3_default.clone(eigenDecomposition.unitary, result.halfAxes); + let v1 = Matrix3_default.getColumn(rotation, 0, scratchCartesian4); + let v2 = Matrix3_default.getColumn(rotation, 1, scratchCartesian5); + let v3 = Matrix3_default.getColumn(rotation, 2, scratchCartesian6); + let u1 = -Number.MAX_VALUE; + let u2 = -Number.MAX_VALUE; + let u3 = -Number.MAX_VALUE; + let l1 = Number.MAX_VALUE; + let l2 = Number.MAX_VALUE; + let l3 = Number.MAX_VALUE; + for (i = 0; i < length; i++) { + p = positions[i]; + u1 = Math.max(Cartesian3_default.dot(v1, p), u1); + u2 = Math.max(Cartesian3_default.dot(v2, p), u2); + u3 = Math.max(Cartesian3_default.dot(v3, p), u3); + l1 = Math.min(Cartesian3_default.dot(v1, p), l1); + l2 = Math.min(Cartesian3_default.dot(v2, p), l2); + l3 = Math.min(Cartesian3_default.dot(v3, p), l3); + } + v1 = Cartesian3_default.multiplyByScalar(v1, 0.5 * (l1 + u1), v1); + v2 = Cartesian3_default.multiplyByScalar(v2, 0.5 * (l2 + u2), v2); + v3 = Cartesian3_default.multiplyByScalar(v3, 0.5 * (l3 + u3), v3); + const center = Cartesian3_default.add(v1, v2, result.center); + Cartesian3_default.add(center, v3, center); + const scale = scratchCartesian3; + scale.x = u1 - l1; + scale.y = u2 - l2; + scale.z = u3 - l3; + Cartesian3_default.multiplyByScalar(scale, 0.5, scale); + Matrix3_default.multiplyByScale(result.halfAxes, scale, result.halfAxes); + return result; +}; +var scratchOffset = new Cartesian3_default(); +var scratchScale = new Cartesian3_default(); +function fromPlaneExtents(planeOrigin, planeXAxis, planeYAxis, planeZAxis, minimumX, maximumX, minimumY, maximumY, minimumZ, maximumZ, result) { + if (!defined_default(minimumX) || !defined_default(maximumX) || !defined_default(minimumY) || !defined_default(maximumY) || !defined_default(minimumZ) || !defined_default(maximumZ)) { + throw new DeveloperError_default( + "all extents (minimum/maximum X/Y/Z) are required." + ); + } + if (!defined_default(result)) { + result = new OrientedBoundingBox(); + } + const halfAxes = result.halfAxes; + Matrix3_default.setColumn(halfAxes, 0, planeXAxis, halfAxes); + Matrix3_default.setColumn(halfAxes, 1, planeYAxis, halfAxes); + Matrix3_default.setColumn(halfAxes, 2, planeZAxis, halfAxes); + let centerOffset = scratchOffset; + centerOffset.x = (minimumX + maximumX) / 2; + centerOffset.y = (minimumY + maximumY) / 2; + centerOffset.z = (minimumZ + maximumZ) / 2; + const scale = scratchScale; + scale.x = (maximumX - minimumX) / 2; + scale.y = (maximumY - minimumY) / 2; + scale.z = (maximumZ - minimumZ) / 2; + const center = result.center; + centerOffset = Matrix3_default.multiplyByVector(halfAxes, centerOffset, centerOffset); + Cartesian3_default.add(planeOrigin, centerOffset, center); + Matrix3_default.multiplyByScale(halfAxes, scale, halfAxes); + return result; +} +var scratchRectangleCenterCartographic = new Cartographic_default(); +var scratchRectangleCenter = new Cartesian3_default(); +var scratchPerimeterCartographicNC = new Cartographic_default(); +var scratchPerimeterCartographicNW = new Cartographic_default(); +var scratchPerimeterCartographicCW = new Cartographic_default(); +var scratchPerimeterCartographicSW = new Cartographic_default(); +var scratchPerimeterCartographicSC = new Cartographic_default(); +var scratchPerimeterCartesianNC = new Cartesian3_default(); +var scratchPerimeterCartesianNW = new Cartesian3_default(); +var scratchPerimeterCartesianCW = new Cartesian3_default(); +var scratchPerimeterCartesianSW = new Cartesian3_default(); +var scratchPerimeterCartesianSC = new Cartesian3_default(); +var scratchPerimeterProjectedNC = new Cartesian2_default(); +var scratchPerimeterProjectedNW = new Cartesian2_default(); +var scratchPerimeterProjectedCW = new Cartesian2_default(); +var scratchPerimeterProjectedSW = new Cartesian2_default(); +var scratchPerimeterProjectedSC = new Cartesian2_default(); +var scratchPlaneOrigin = new Cartesian3_default(); +var scratchPlaneNormal = new Cartesian3_default(); +var scratchPlaneXAxis = new Cartesian3_default(); +var scratchHorizonCartesian = new Cartesian3_default(); +var scratchHorizonProjected = new Cartesian2_default(); +var scratchMaxY = new Cartesian3_default(); +var scratchMinY = new Cartesian3_default(); +var scratchZ = new Cartesian3_default(); +var scratchPlane = new Plane_default(Cartesian3_default.UNIT_X, 0); +OrientedBoundingBox.fromRectangle = function(rectangle, minimumHeight, maximumHeight, ellipsoid, result) { + if (!defined_default(rectangle)) { + throw new DeveloperError_default("rectangle is required"); + } + if (rectangle.width < 0 || rectangle.width > Math_default.TWO_PI) { + throw new DeveloperError_default("Rectangle width must be between 0 and 2 * pi"); + } + if (rectangle.height < 0 || rectangle.height > Math_default.PI) { + throw new DeveloperError_default("Rectangle height must be between 0 and pi"); + } + if (defined_default(ellipsoid) && !Math_default.equalsEpsilon( + ellipsoid.radii.x, + ellipsoid.radii.y, + Math_default.EPSILON15 + )) { + throw new DeveloperError_default( + "Ellipsoid must be an ellipsoid of revolution (radii.x == radii.y)" + ); + } + minimumHeight = defaultValue_default(minimumHeight, 0); + maximumHeight = defaultValue_default(maximumHeight, 0); + ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84); + let minX, maxX, minY, maxY, minZ, maxZ, plane; + if (rectangle.width <= Math_default.PI) { + const tangentPointCartographic = Rectangle_default.center( + rectangle, + scratchRectangleCenterCartographic + ); + const tangentPoint = ellipsoid.cartographicToCartesian( + tangentPointCartographic, + scratchRectangleCenter + ); + const tangentPlane = new EllipsoidTangentPlane_default(tangentPoint, ellipsoid); + plane = tangentPlane.plane; + const lonCenter = tangentPointCartographic.longitude; + const latCenter = rectangle.south < 0 && rectangle.north > 0 ? 0 : tangentPointCartographic.latitude; + const perimeterCartographicNC = Cartographic_default.fromRadians( + lonCenter, + rectangle.north, + maximumHeight, + scratchPerimeterCartographicNC + ); + const perimeterCartographicNW = Cartographic_default.fromRadians( + rectangle.west, + rectangle.north, + maximumHeight, + scratchPerimeterCartographicNW + ); + const perimeterCartographicCW = Cartographic_default.fromRadians( + rectangle.west, + latCenter, + maximumHeight, + scratchPerimeterCartographicCW + ); + const perimeterCartographicSW = Cartographic_default.fromRadians( + rectangle.west, + rectangle.south, + maximumHeight, + scratchPerimeterCartographicSW + ); + const perimeterCartographicSC = Cartographic_default.fromRadians( + lonCenter, + rectangle.south, + maximumHeight, + scratchPerimeterCartographicSC + ); + const perimeterCartesianNC = ellipsoid.cartographicToCartesian( + perimeterCartographicNC, + scratchPerimeterCartesianNC + ); + let perimeterCartesianNW = ellipsoid.cartographicToCartesian( + perimeterCartographicNW, + scratchPerimeterCartesianNW + ); + const perimeterCartesianCW = ellipsoid.cartographicToCartesian( + perimeterCartographicCW, + scratchPerimeterCartesianCW + ); + let perimeterCartesianSW = ellipsoid.cartographicToCartesian( + perimeterCartographicSW, + scratchPerimeterCartesianSW + ); + const perimeterCartesianSC = ellipsoid.cartographicToCartesian( + perimeterCartographicSC, + scratchPerimeterCartesianSC + ); + const perimeterProjectedNC = tangentPlane.projectPointToNearestOnPlane( + perimeterCartesianNC, + scratchPerimeterProjectedNC + ); + const perimeterProjectedNW = tangentPlane.projectPointToNearestOnPlane( + perimeterCartesianNW, + scratchPerimeterProjectedNW + ); + const perimeterProjectedCW = tangentPlane.projectPointToNearestOnPlane( + perimeterCartesianCW, + scratchPerimeterProjectedCW + ); + const perimeterProjectedSW = tangentPlane.projectPointToNearestOnPlane( + perimeterCartesianSW, + scratchPerimeterProjectedSW + ); + const perimeterProjectedSC = tangentPlane.projectPointToNearestOnPlane( + perimeterCartesianSC, + scratchPerimeterProjectedSC + ); + minX = Math.min( + perimeterProjectedNW.x, + perimeterProjectedCW.x, + perimeterProjectedSW.x + ); + maxX = -minX; + maxY = Math.max(perimeterProjectedNW.y, perimeterProjectedNC.y); + minY = Math.min(perimeterProjectedSW.y, perimeterProjectedSC.y); + perimeterCartographicNW.height = perimeterCartographicSW.height = minimumHeight; + perimeterCartesianNW = ellipsoid.cartographicToCartesian( + perimeterCartographicNW, + scratchPerimeterCartesianNW + ); + perimeterCartesianSW = ellipsoid.cartographicToCartesian( + perimeterCartographicSW, + scratchPerimeterCartesianSW + ); + minZ = Math.min( + Plane_default.getPointDistance(plane, perimeterCartesianNW), + Plane_default.getPointDistance(plane, perimeterCartesianSW) + ); + maxZ = maximumHeight; + return fromPlaneExtents( + tangentPlane.origin, + tangentPlane.xAxis, + tangentPlane.yAxis, + tangentPlane.zAxis, + minX, + maxX, + minY, + maxY, + minZ, + maxZ, + result + ); + } + const fullyAboveEquator = rectangle.south > 0; + const fullyBelowEquator = rectangle.north < 0; + const latitudeNearestToEquator = fullyAboveEquator ? rectangle.south : fullyBelowEquator ? rectangle.north : 0; + const centerLongitude = Rectangle_default.center( + rectangle, + scratchRectangleCenterCartographic + ).longitude; + const planeOrigin = Cartesian3_default.fromRadians( + centerLongitude, + latitudeNearestToEquator, + maximumHeight, + ellipsoid, + scratchPlaneOrigin + ); + planeOrigin.z = 0; + const isPole = Math.abs(planeOrigin.x) < Math_default.EPSILON10 && Math.abs(planeOrigin.y) < Math_default.EPSILON10; + const planeNormal = !isPole ? Cartesian3_default.normalize(planeOrigin, scratchPlaneNormal) : Cartesian3_default.UNIT_X; + const planeYAxis = Cartesian3_default.UNIT_Z; + const planeXAxis = Cartesian3_default.cross( + planeNormal, + planeYAxis, + scratchPlaneXAxis + ); + plane = Plane_default.fromPointNormal(planeOrigin, planeNormal, scratchPlane); + const horizonCartesian = Cartesian3_default.fromRadians( + centerLongitude + Math_default.PI_OVER_TWO, + latitudeNearestToEquator, + maximumHeight, + ellipsoid, + scratchHorizonCartesian + ); + maxX = Cartesian3_default.dot( + Plane_default.projectPointOntoPlane( + plane, + horizonCartesian, + scratchHorizonProjected + ), + planeXAxis + ); + minX = -maxX; + maxY = Cartesian3_default.fromRadians( + 0, + rectangle.north, + fullyBelowEquator ? minimumHeight : maximumHeight, + ellipsoid, + scratchMaxY + ).z; + minY = Cartesian3_default.fromRadians( + 0, + rectangle.south, + fullyAboveEquator ? minimumHeight : maximumHeight, + ellipsoid, + scratchMinY + ).z; + const farZ = Cartesian3_default.fromRadians( + rectangle.east, + latitudeNearestToEquator, + maximumHeight, + ellipsoid, + scratchZ + ); + minZ = Plane_default.getPointDistance(plane, farZ); + maxZ = 0; + return fromPlaneExtents( + planeOrigin, + planeXAxis, + planeYAxis, + planeNormal, + minX, + maxX, + minY, + maxY, + minZ, + maxZ, + result + ); +}; +OrientedBoundingBox.fromTransformation = function(transformation, result) { + Check_default.typeOf.object("transformation", transformation); + if (!defined_default(result)) { + result = new OrientedBoundingBox(); + } + result.center = Matrix4_default.getTranslation(transformation, result.center); + result.halfAxes = Matrix4_default.getMatrix3(transformation, result.halfAxes); + result.halfAxes = Matrix3_default.multiplyByScalar( + result.halfAxes, + 0.5, + result.halfAxes + ); + return result; +}; +OrientedBoundingBox.clone = function(box, result) { + if (!defined_default(box)) { + return void 0; + } + if (!defined_default(result)) { + return new OrientedBoundingBox(box.center, box.halfAxes); + } + Cartesian3_default.clone(box.center, result.center); + Matrix3_default.clone(box.halfAxes, result.halfAxes); + return result; +}; +OrientedBoundingBox.intersectPlane = function(box, plane) { + if (!defined_default(box)) { + throw new DeveloperError_default("box is required."); + } + if (!defined_default(plane)) { + throw new DeveloperError_default("plane is required."); + } + const center = box.center; + const normal = plane.normal; + const halfAxes = box.halfAxes; + const normalX = normal.x, normalY = normal.y, normalZ = normal.z; + const radEffective = Math.abs( + normalX * halfAxes[Matrix3_default.COLUMN0ROW0] + normalY * halfAxes[Matrix3_default.COLUMN0ROW1] + normalZ * halfAxes[Matrix3_default.COLUMN0ROW2] + ) + Math.abs( + normalX * halfAxes[Matrix3_default.COLUMN1ROW0] + normalY * halfAxes[Matrix3_default.COLUMN1ROW1] + normalZ * halfAxes[Matrix3_default.COLUMN1ROW2] + ) + Math.abs( + normalX * halfAxes[Matrix3_default.COLUMN2ROW0] + normalY * halfAxes[Matrix3_default.COLUMN2ROW1] + normalZ * halfAxes[Matrix3_default.COLUMN2ROW2] + ); + const distanceToPlane = Cartesian3_default.dot(normal, center) + plane.distance; + if (distanceToPlane <= -radEffective) { + return Intersect_default.OUTSIDE; + } else if (distanceToPlane >= radEffective) { + return Intersect_default.INSIDE; + } + return Intersect_default.INTERSECTING; +}; +var scratchCartesianU = new Cartesian3_default(); +var scratchCartesianV = new Cartesian3_default(); +var scratchCartesianW = new Cartesian3_default(); +var scratchValidAxis2 = new Cartesian3_default(); +var scratchValidAxis3 = new Cartesian3_default(); +var scratchPPrime = new Cartesian3_default(); +OrientedBoundingBox.distanceSquaredTo = function(box, cartesian) { + if (!defined_default(box)) { + throw new DeveloperError_default("box is required."); + } + if (!defined_default(cartesian)) { + throw new DeveloperError_default("cartesian is required."); + } + const offset = Cartesian3_default.subtract(cartesian, box.center, scratchOffset); + const halfAxes = box.halfAxes; + let u = Matrix3_default.getColumn(halfAxes, 0, scratchCartesianU); + let v = Matrix3_default.getColumn(halfAxes, 1, scratchCartesianV); + let w = Matrix3_default.getColumn(halfAxes, 2, scratchCartesianW); + const uHalf = Cartesian3_default.magnitude(u); + const vHalf = Cartesian3_default.magnitude(v); + const wHalf = Cartesian3_default.magnitude(w); + let uValid = true; + let vValid = true; + let wValid = true; + if (uHalf > 0) { + Cartesian3_default.divideByScalar(u, uHalf, u); + } else { + uValid = false; + } + if (vHalf > 0) { + Cartesian3_default.divideByScalar(v, vHalf, v); + } else { + vValid = false; + } + if (wHalf > 0) { + Cartesian3_default.divideByScalar(w, wHalf, w); + } else { + wValid = false; + } + const numberOfDegenerateAxes = !uValid + !vValid + !wValid; + let validAxis1; + let validAxis2; + let validAxis3; + if (numberOfDegenerateAxes === 1) { + let degenerateAxis = u; + validAxis1 = v; + validAxis2 = w; + if (!vValid) { + degenerateAxis = v; + validAxis1 = u; + } else if (!wValid) { + degenerateAxis = w; + validAxis2 = u; + } + validAxis3 = Cartesian3_default.cross(validAxis1, validAxis2, scratchValidAxis3); + if (degenerateAxis === u) { + u = validAxis3; + } else if (degenerateAxis === v) { + v = validAxis3; + } else if (degenerateAxis === w) { + w = validAxis3; + } + } else if (numberOfDegenerateAxes === 2) { + validAxis1 = u; + if (vValid) { + validAxis1 = v; + } else if (wValid) { + validAxis1 = w; + } + let crossVector = Cartesian3_default.UNIT_Y; + if (crossVector.equalsEpsilon(validAxis1, Math_default.EPSILON3)) { + crossVector = Cartesian3_default.UNIT_X; + } + validAxis2 = Cartesian3_default.cross(validAxis1, crossVector, scratchValidAxis2); + Cartesian3_default.normalize(validAxis2, validAxis2); + validAxis3 = Cartesian3_default.cross(validAxis1, validAxis2, scratchValidAxis3); + Cartesian3_default.normalize(validAxis3, validAxis3); + if (validAxis1 === u) { + v = validAxis2; + w = validAxis3; + } else if (validAxis1 === v) { + w = validAxis2; + u = validAxis3; + } else if (validAxis1 === w) { + u = validAxis2; + v = validAxis3; + } + } else if (numberOfDegenerateAxes === 3) { + u = Cartesian3_default.UNIT_X; + v = Cartesian3_default.UNIT_Y; + w = Cartesian3_default.UNIT_Z; + } + const pPrime = scratchPPrime; + pPrime.x = Cartesian3_default.dot(offset, u); + pPrime.y = Cartesian3_default.dot(offset, v); + pPrime.z = Cartesian3_default.dot(offset, w); + let distanceSquared = 0; + let d; + if (pPrime.x < -uHalf) { + d = pPrime.x + uHalf; + distanceSquared += d * d; + } else if (pPrime.x > uHalf) { + d = pPrime.x - uHalf; + distanceSquared += d * d; + } + if (pPrime.y < -vHalf) { + d = pPrime.y + vHalf; + distanceSquared += d * d; + } else if (pPrime.y > vHalf) { + d = pPrime.y - vHalf; + distanceSquared += d * d; + } + if (pPrime.z < -wHalf) { + d = pPrime.z + wHalf; + distanceSquared += d * d; + } else if (pPrime.z > wHalf) { + d = pPrime.z - wHalf; + distanceSquared += d * d; + } + return distanceSquared; +}; +var scratchCorner = new Cartesian3_default(); +var scratchToCenter = new Cartesian3_default(); +OrientedBoundingBox.computePlaneDistances = function(box, position, direction, result) { + if (!defined_default(box)) { + throw new DeveloperError_default("box is required."); + } + if (!defined_default(position)) { + throw new DeveloperError_default("position is required."); + } + if (!defined_default(direction)) { + throw new DeveloperError_default("direction is required."); + } + if (!defined_default(result)) { + result = new Interval_default(); + } + let minDist = Number.POSITIVE_INFINITY; + let maxDist = Number.NEGATIVE_INFINITY; + const center = box.center; + const halfAxes = box.halfAxes; + const u = Matrix3_default.getColumn(halfAxes, 0, scratchCartesianU); + const v = Matrix3_default.getColumn(halfAxes, 1, scratchCartesianV); + const w = Matrix3_default.getColumn(halfAxes, 2, scratchCartesianW); + const corner = Cartesian3_default.add(u, v, scratchCorner); + Cartesian3_default.add(corner, w, corner); + Cartesian3_default.add(corner, center, corner); + const toCenter = Cartesian3_default.subtract(corner, position, scratchToCenter); + let mag = Cartesian3_default.dot(direction, toCenter); + minDist = Math.min(mag, minDist); + maxDist = Math.max(mag, maxDist); + Cartesian3_default.add(center, u, corner); + Cartesian3_default.add(corner, v, corner); + Cartesian3_default.subtract(corner, w, corner); + Cartesian3_default.subtract(corner, position, toCenter); + mag = Cartesian3_default.dot(direction, toCenter); + minDist = Math.min(mag, minDist); + maxDist = Math.max(mag, maxDist); + Cartesian3_default.add(center, u, corner); + Cartesian3_default.subtract(corner, v, corner); + Cartesian3_default.add(corner, w, corner); + Cartesian3_default.subtract(corner, position, toCenter); + mag = Cartesian3_default.dot(direction, toCenter); + minDist = Math.min(mag, minDist); + maxDist = Math.max(mag, maxDist); + Cartesian3_default.add(center, u, corner); + Cartesian3_default.subtract(corner, v, corner); + Cartesian3_default.subtract(corner, w, corner); + Cartesian3_default.subtract(corner, position, toCenter); + mag = Cartesian3_default.dot(direction, toCenter); + minDist = Math.min(mag, minDist); + maxDist = Math.max(mag, maxDist); + Cartesian3_default.subtract(center, u, corner); + Cartesian3_default.add(corner, v, corner); + Cartesian3_default.add(corner, w, corner); + Cartesian3_default.subtract(corner, position, toCenter); + mag = Cartesian3_default.dot(direction, toCenter); + minDist = Math.min(mag, minDist); + maxDist = Math.max(mag, maxDist); + Cartesian3_default.subtract(center, u, corner); + Cartesian3_default.add(corner, v, corner); + Cartesian3_default.subtract(corner, w, corner); + Cartesian3_default.subtract(corner, position, toCenter); + mag = Cartesian3_default.dot(direction, toCenter); + minDist = Math.min(mag, minDist); + maxDist = Math.max(mag, maxDist); + Cartesian3_default.subtract(center, u, corner); + Cartesian3_default.subtract(corner, v, corner); + Cartesian3_default.add(corner, w, corner); + Cartesian3_default.subtract(corner, position, toCenter); + mag = Cartesian3_default.dot(direction, toCenter); + minDist = Math.min(mag, minDist); + maxDist = Math.max(mag, maxDist); + Cartesian3_default.subtract(center, u, corner); + Cartesian3_default.subtract(corner, v, corner); + Cartesian3_default.subtract(corner, w, corner); + Cartesian3_default.subtract(corner, position, toCenter); + mag = Cartesian3_default.dot(direction, toCenter); + minDist = Math.min(mag, minDist); + maxDist = Math.max(mag, maxDist); + result.start = minDist; + result.stop = maxDist; + return result; +}; +var scratchXAxis = new Cartesian3_default(); +var scratchYAxis = new Cartesian3_default(); +var scratchZAxis = new Cartesian3_default(); +OrientedBoundingBox.computeCorners = function(box, result) { + Check_default.typeOf.object("box", box); + if (!defined_default(result)) { + result = [ + new Cartesian3_default(), + new Cartesian3_default(), + new Cartesian3_default(), + new Cartesian3_default(), + new Cartesian3_default(), + new Cartesian3_default(), + new Cartesian3_default(), + new Cartesian3_default() + ]; + } + const center = box.center; + const halfAxes = box.halfAxes; + const xAxis = Matrix3_default.getColumn(halfAxes, 0, scratchXAxis); + const yAxis = Matrix3_default.getColumn(halfAxes, 1, scratchYAxis); + const zAxis = Matrix3_default.getColumn(halfAxes, 2, scratchZAxis); + Cartesian3_default.clone(center, result[0]); + Cartesian3_default.subtract(result[0], xAxis, result[0]); + Cartesian3_default.subtract(result[0], yAxis, result[0]); + Cartesian3_default.subtract(result[0], zAxis, result[0]); + Cartesian3_default.clone(center, result[1]); + Cartesian3_default.subtract(result[1], xAxis, result[1]); + Cartesian3_default.subtract(result[1], yAxis, result[1]); + Cartesian3_default.add(result[1], zAxis, result[1]); + Cartesian3_default.clone(center, result[2]); + Cartesian3_default.subtract(result[2], xAxis, result[2]); + Cartesian3_default.add(result[2], yAxis, result[2]); + Cartesian3_default.subtract(result[2], zAxis, result[2]); + Cartesian3_default.clone(center, result[3]); + Cartesian3_default.subtract(result[3], xAxis, result[3]); + Cartesian3_default.add(result[3], yAxis, result[3]); + Cartesian3_default.add(result[3], zAxis, result[3]); + Cartesian3_default.clone(center, result[4]); + Cartesian3_default.add(result[4], xAxis, result[4]); + Cartesian3_default.subtract(result[4], yAxis, result[4]); + Cartesian3_default.subtract(result[4], zAxis, result[4]); + Cartesian3_default.clone(center, result[5]); + Cartesian3_default.add(result[5], xAxis, result[5]); + Cartesian3_default.subtract(result[5], yAxis, result[5]); + Cartesian3_default.add(result[5], zAxis, result[5]); + Cartesian3_default.clone(center, result[6]); + Cartesian3_default.add(result[6], xAxis, result[6]); + Cartesian3_default.add(result[6], yAxis, result[6]); + Cartesian3_default.subtract(result[6], zAxis, result[6]); + Cartesian3_default.clone(center, result[7]); + Cartesian3_default.add(result[7], xAxis, result[7]); + Cartesian3_default.add(result[7], yAxis, result[7]); + Cartesian3_default.add(result[7], zAxis, result[7]); + return result; +}; +var scratchRotationScale = new Matrix3_default(); +OrientedBoundingBox.computeTransformation = function(box, result) { + Check_default.typeOf.object("box", box); + if (!defined_default(result)) { + result = new Matrix4_default(); + } + const translation = box.center; + const rotationScale = Matrix3_default.multiplyByUniformScale( + box.halfAxes, + 2, + scratchRotationScale + ); + return Matrix4_default.fromRotationTranslation(rotationScale, translation, result); +}; +var scratchBoundingSphere = new BoundingSphere_default(); +OrientedBoundingBox.isOccluded = function(box, occluder) { + if (!defined_default(box)) { + throw new DeveloperError_default("box is required."); + } + if (!defined_default(occluder)) { + throw new DeveloperError_default("occluder is required."); + } + const sphere = BoundingSphere_default.fromOrientedBoundingBox( + box, + scratchBoundingSphere + ); + return !occluder.isBoundingSphereVisible(sphere); +}; +OrientedBoundingBox.prototype.intersectPlane = function(plane) { + return OrientedBoundingBox.intersectPlane(this, plane); +}; +OrientedBoundingBox.prototype.distanceSquaredTo = function(cartesian) { + return OrientedBoundingBox.distanceSquaredTo(this, cartesian); +}; +OrientedBoundingBox.prototype.computePlaneDistances = function(position, direction, result) { + return OrientedBoundingBox.computePlaneDistances( + this, + position, + direction, + result + ); +}; +OrientedBoundingBox.prototype.computeCorners = function(result) { + return OrientedBoundingBox.computeCorners(this, result); +}; +OrientedBoundingBox.prototype.computeTransformation = function(result) { + return OrientedBoundingBox.computeTransformation(this, result); +}; +OrientedBoundingBox.prototype.isOccluded = function(occluder) { + return OrientedBoundingBox.isOccluded(this, occluder); +}; +OrientedBoundingBox.equals = function(left, right) { + return left === right || defined_default(left) && defined_default(right) && Cartesian3_default.equals(left.center, right.center) && Matrix3_default.equals(left.halfAxes, right.halfAxes); +}; +OrientedBoundingBox.prototype.clone = function(result) { + return OrientedBoundingBox.clone(this, result); +}; +OrientedBoundingBox.prototype.equals = function(right) { + return OrientedBoundingBox.equals(this, right); +}; +var OrientedBoundingBox_default = OrientedBoundingBox; + +export { + OrientedBoundingBox_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-YLS3FX3U.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-YLS3FX3U.js new file mode 100644 index 0000000000000000000000000000000000000000..b61d62c0c773bd50f64b9f5f27523f90c5d945dc --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-YLS3FX3U.js @@ -0,0 +1,236 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + GeographicProjection_default +} from "./chunk-5U4UHRZ2.js"; +import { + Matrix2_default, + Rectangle_default +} from "./chunk-PW5CA4MJ.js"; +import { + Cartesian3_default, + Cartographic_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/RectangleGeometryLibrary.js +var cos = Math.cos; +var sin = Math.sin; +var sqrt = Math.sqrt; +var RectangleGeometryLibrary = {}; +RectangleGeometryLibrary.computePosition = function(computedOptions, ellipsoid, computeST, row, col, position, st) { + const radiiSquared = ellipsoid.radiiSquared; + const nwCorner = computedOptions.nwCorner; + const rectangle = computedOptions.boundingRectangle; + let stLatitude = nwCorner.latitude - computedOptions.granYCos * row + col * computedOptions.granXSin; + const cosLatitude = cos(stLatitude); + const nZ = sin(stLatitude); + const kZ = radiiSquared.z * nZ; + let stLongitude = nwCorner.longitude + row * computedOptions.granYSin + col * computedOptions.granXCos; + const nX = cosLatitude * cos(stLongitude); + const nY = cosLatitude * sin(stLongitude); + const kX = radiiSquared.x * nX; + const kY = radiiSquared.y * nY; + const gamma = sqrt(kX * nX + kY * nY + kZ * nZ); + position.x = kX / gamma; + position.y = kY / gamma; + position.z = kZ / gamma; + if (computeST) { + const stNwCorner = computedOptions.stNwCorner; + if (defined_default(stNwCorner)) { + stLatitude = stNwCorner.latitude - computedOptions.stGranYCos * row + col * computedOptions.stGranXSin; + stLongitude = stNwCorner.longitude + row * computedOptions.stGranYSin + col * computedOptions.stGranXCos; + st.x = (stLongitude - computedOptions.stWest) * computedOptions.lonScalar; + st.y = (stLatitude - computedOptions.stSouth) * computedOptions.latScalar; + } else { + st.x = (stLongitude - rectangle.west) * computedOptions.lonScalar; + st.y = (stLatitude - rectangle.south) * computedOptions.latScalar; + } + } +}; +var rotationMatrixScratch = new Matrix2_default(); +var nwCartesian = new Cartesian3_default(); +var centerScratch = new Cartographic_default(); +var centerCartesian = new Cartesian3_default(); +var proj = new GeographicProjection_default(); +function getRotationOptions(nwCorner, rotation, granularityX, granularityY, center, width, height) { + const cosRotation = Math.cos(rotation); + const granYCos = granularityY * cosRotation; + const granXCos = granularityX * cosRotation; + const sinRotation = Math.sin(rotation); + const granYSin = granularityY * sinRotation; + const granXSin = granularityX * sinRotation; + nwCartesian = proj.project(nwCorner, nwCartesian); + nwCartesian = Cartesian3_default.subtract(nwCartesian, centerCartesian, nwCartesian); + const rotationMatrix = Matrix2_default.fromRotation(rotation, rotationMatrixScratch); + nwCartesian = Matrix2_default.multiplyByVector( + rotationMatrix, + nwCartesian, + nwCartesian + ); + nwCartesian = Cartesian3_default.add(nwCartesian, centerCartesian, nwCartesian); + nwCorner = proj.unproject(nwCartesian, nwCorner); + width -= 1; + height -= 1; + const latitude = nwCorner.latitude; + const latitude0 = latitude + width * granXSin; + const latitude1 = latitude - granYCos * height; + const latitude2 = latitude - granYCos * height + width * granXSin; + const north = Math.max(latitude, latitude0, latitude1, latitude2); + const south = Math.min(latitude, latitude0, latitude1, latitude2); + const longitude = nwCorner.longitude; + const longitude0 = longitude + width * granXCos; + const longitude1 = longitude + height * granYSin; + const longitude2 = longitude + height * granYSin + width * granXCos; + const east = Math.max(longitude, longitude0, longitude1, longitude2); + const west = Math.min(longitude, longitude0, longitude1, longitude2); + return { + north, + south, + east, + west, + granYCos, + granYSin, + granXCos, + granXSin, + nwCorner + }; +} +RectangleGeometryLibrary.computeOptions = function(rectangle, granularity, rotation, stRotation, boundingRectangleScratch, nwCornerResult, stNwCornerResult) { + let east = rectangle.east; + let west = rectangle.west; + let north = rectangle.north; + let south = rectangle.south; + let northCap = false; + let southCap = false; + if (north === Math_default.PI_OVER_TWO) { + northCap = true; + } + if (south === -Math_default.PI_OVER_TWO) { + southCap = true; + } + let dx; + const dy = north - south; + if (west > east) { + dx = Math_default.TWO_PI - west + east; + } else { + dx = east - west; + } + const width = Math.ceil(dx / granularity) + 1; + const height = Math.ceil(dy / granularity) + 1; + const granularityX = dx / (width - 1); + const granularityY = dy / (height - 1); + const nwCorner = Rectangle_default.northwest(rectangle, nwCornerResult); + const center = Rectangle_default.center(rectangle, centerScratch); + if (rotation !== 0 || stRotation !== 0) { + if (center.longitude < nwCorner.longitude) { + center.longitude += Math_default.TWO_PI; + } + centerCartesian = proj.project(center, centerCartesian); + } + const granYCos = granularityY; + const granXCos = granularityX; + const granYSin = 0; + const granXSin = 0; + const boundingRectangle = Rectangle_default.clone( + rectangle, + boundingRectangleScratch + ); + const computedOptions = { + granYCos, + granYSin, + granXCos, + granXSin, + nwCorner, + boundingRectangle, + width, + height, + northCap, + southCap + }; + if (rotation !== 0) { + const rotationOptions = getRotationOptions( + nwCorner, + rotation, + granularityX, + granularityY, + center, + width, + height + ); + north = rotationOptions.north; + south = rotationOptions.south; + east = rotationOptions.east; + west = rotationOptions.west; + if (north < -Math_default.PI_OVER_TWO || north > Math_default.PI_OVER_TWO || south < -Math_default.PI_OVER_TWO || south > Math_default.PI_OVER_TWO) { + throw new DeveloperError_default( + "Rotated rectangle is invalid. It crosses over either the north or south pole." + ); + } + computedOptions.granYCos = rotationOptions.granYCos; + computedOptions.granYSin = rotationOptions.granYSin; + computedOptions.granXCos = rotationOptions.granXCos; + computedOptions.granXSin = rotationOptions.granXSin; + boundingRectangle.north = north; + boundingRectangle.south = south; + boundingRectangle.east = east; + boundingRectangle.west = west; + } + if (stRotation !== 0) { + rotation = rotation - stRotation; + const stNwCorner = Rectangle_default.northwest(boundingRectangle, stNwCornerResult); + const stRotationOptions = getRotationOptions( + stNwCorner, + rotation, + granularityX, + granularityY, + center, + width, + height + ); + computedOptions.stGranYCos = stRotationOptions.granYCos; + computedOptions.stGranXCos = stRotationOptions.granXCos; + computedOptions.stGranYSin = stRotationOptions.granYSin; + computedOptions.stGranXSin = stRotationOptions.granXSin; + computedOptions.stNwCorner = stNwCorner; + computedOptions.stWest = stRotationOptions.west; + computedOptions.stSouth = stRotationOptions.south; + } + return computedOptions; +}; +var RectangleGeometryLibrary_default = RectangleGeometryLibrary; + +export { + RectangleGeometryLibrary_default +}; diff --git a/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-YMJPANZZ.js b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-YMJPANZZ.js new file mode 100644 index 0000000000000000000000000000000000000000..569aedf1528544b88ed3c90e54e84025b4d0b32d --- /dev/null +++ b/cesiumjs4gwt-main/src/main/resources/org/cesiumjs/public/cs/CesiumUnminified/Workers/chunk-YMJPANZZ.js @@ -0,0 +1,693 @@ +/** + * @license + * Cesium - https://github.com/CesiumGS/cesium + * Version 1.109 + * + * Copyright 2011-2022 Cesium Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * Columbus View (Pat. Pend.) + * + * Portions licensed separately. + * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details. + */ + +import { + PolylinePipeline_default +} from "./chunk-H52L6U76.js"; +import { + EllipsoidTangentPlane_default +} from "./chunk-4V6RCTVH.js"; +import { + Quaternion_default, + Transforms_default +} from "./chunk-5U4UHRZ2.js"; +import { + Cartesian2_default, + Cartesian4_default, + Matrix4_default +} from "./chunk-PW5CA4MJ.js"; +import { + Cartesian3_default, + Cartographic_default, + Matrix3_default +} from "./chunk-XJCTFTBM.js"; +import { + Math_default +} from "./chunk-PWDYKCNC.js"; +import { + defaultValue_default +} from "./chunk-BT6YIL2N.js"; +import { + DeveloperError_default +} from "./chunk-UN7AK64D.js"; +import { + defined_default +} from "./chunk-QVJ6IRKV.js"; + +// packages/engine/Source/Core/CornerType.js +var CornerType = { + /** + * + * + * Corner has a smooth edge. + * @type {number} + * @constant + */ + ROUNDED: 0, + /** + * + * + * Corner point is the intersection of adjacent edges. + * @type {number} + * @constant + */ + MITERED: 1, + /** + * + * + * Corner is clipped. + * @type {number} + * @constant + */ + BEVELED: 2 +}; +var CornerType_default = Object.freeze(CornerType); + +// packages/engine/Source/Core/oneTimeWarning.js +var warnings = {}; +function oneTimeWarning(identifier, message) { + if (!defined_default(identifier)) { + throw new DeveloperError_default("identifier is required."); + } + if (!defined_default(warnings[identifier])) { + warnings[identifier] = true; + console.warn(defaultValue_default(message, identifier)); + } +} +oneTimeWarning.geometryOutlines = "Entity geometry outlines are unsupported on terrain. Outlines will be disabled. To enable outlines, disable geometry terrain clamping by explicitly setting height to 0."; +oneTimeWarning.geometryZIndex = "Entity geometry with zIndex are unsupported when height or extrudedHeight are defined. zIndex will be ignored"; +oneTimeWarning.geometryHeightReference = "Entity corridor, ellipse, polygon or rectangle with heightReference must also have a defined height. heightReference will be ignored"; +oneTimeWarning.geometryExtrudedHeightReference = "Entity corridor, ellipse, polygon or rectangle with extrudedHeightReference must also have a defined extrudedHeight. extrudedHeightReference will be ignored"; +var oneTimeWarning_default = oneTimeWarning; + +// packages/engine/Source/Core/PolylineVolumeGeometryLibrary.js +var scratch2Array = [new Cartesian3_default(), new Cartesian3_default()]; +var scratchCartesian1 = new Cartesian3_default(); +var scratchCartesian2 = new Cartesian3_default(); +var scratchCartesian3 = new Cartesian3_default(); +var scratchCartesian4 = new Cartesian3_default(); +var scratchCartesian5 = new Cartesian3_default(); +var scratchCartesian6 = new Cartesian3_default(); +var scratchCartesian7 = new Cartesian3_default(); +var scratchCartesian8 = new Cartesian3_default(); +var scratchCartesian9 = new Cartesian3_default(); +var scratch1 = new Cartesian3_default(); +var scratch2 = new Cartesian3_default(); +var PolylineVolumeGeometryLibrary = {}; +var cartographic = new Cartographic_default(); +function scaleToSurface(positions, ellipsoid) { + const heights = new Array(positions.length); + for (let i = 0; i < positions.length; i++) { + const pos = positions[i]; + cartographic = ellipsoid.cartesianToCartographic(pos, cartographic); + heights[i] = cartographic.height; + positions[i] = ellipsoid.scaleToGeodeticSurface(pos, pos); + } + return heights; +} +function subdivideHeights(points, h0, h1, granularity) { + const p0 = points[0]; + const p1 = points[1]; + const angleBetween = Cartesian3_default.angleBetween(p0, p1); + const numPoints = Math.ceil(angleBetween / granularity); + const heights = new Array(numPoints); + let i; + if (h0 === h1) { + for (i = 0; i < numPoints; i++) { + heights[i] = h0; + } + heights.push(h1); + return heights; + } + const dHeight = h1 - h0; + const heightPerVertex = dHeight / numPoints; + for (i = 1; i < numPoints; i++) { + const h = h0 + i * heightPerVertex; + heights[i] = h; + } + heights[0] = h0; + heights.push(h1); + return heights; +} +var nextScratch = new Cartesian3_default(); +var prevScratch = new Cartesian3_default(); +function computeRotationAngle(start, end, position, ellipsoid) { + const tangentPlane = new EllipsoidTangentPlane_default(position, ellipsoid); + const next = tangentPlane.projectPointOntoPlane( + Cartesian3_default.add(position, start, nextScratch), + nextScratch + ); + const prev = tangentPlane.projectPointOntoPlane( + Cartesian3_default.add(position, end, prevScratch), + prevScratch + ); + const angle = Cartesian2_default.angleBetween(next, prev); + return prev.x * next.y - prev.y * next.x >= 0 ? -angle : angle; +} +var negativeX = new Cartesian3_default(-1, 0, 0); +var transform = new Matrix4_default(); +var translation = new Matrix4_default(); +var rotationZ = new Matrix3_default(); +var scaleMatrix = Matrix3_default.IDENTITY.clone(); +var westScratch = new Cartesian3_default(); +var finalPosScratch = new Cartesian4_default(); +var heightCartesian = new Cartesian3_default(); +function addPosition(center, left, shape, finalPositions, ellipsoid, height, xScalar, repeat) { + let west = westScratch; + let finalPosition = finalPosScratch; + transform = Transforms_default.eastNorthUpToFixedFrame(center, ellipsoid, transform); + west = Matrix4_default.multiplyByPointAsVector(transform, negativeX, west); + west = Cartesian3_default.normalize(west, west); + const angle = computeRotationAngle(west, left, center, ellipsoid); + rotationZ = Matrix3_default.fromRotationZ(angle, rotationZ); + heightCartesian.z = height; + transform = Matrix4_default.multiplyTransformation( + transform, + Matrix4_default.fromRotationTranslation(rotationZ, heightCartesian, translation), + transform + ); + const scale = scaleMatrix; + scale[0] = xScalar; + for (let j = 0; j < repeat; j++) { + for (let i = 0; i < shape.length; i += 3) { + finalPosition = Cartesian3_default.fromArray(shape, i, finalPosition); + finalPosition = Matrix3_default.multiplyByVector( + scale, + finalPosition, + finalPosition + ); + finalPosition = Matrix4_default.multiplyByPoint( + transform, + finalPosition, + finalPosition + ); + finalPositions.push(finalPosition.x, finalPosition.y, finalPosition.z); + } + } + return finalPositions; +} +var centerScratch = new Cartesian3_default(); +function addPositions(centers, left, shape, finalPositions, ellipsoid, heights, xScalar) { + for (let i = 0; i < centers.length; i += 3) { + const center = Cartesian3_default.fromArray(centers, i, centerScratch); + finalPositions = addPosition( + center, + left, + shape, + finalPositions, + ellipsoid, + heights[i / 3], + xScalar, + 1 + ); + } + return finalPositions; +} +function convertShapeTo3DDuplicate(shape2D, boundingRectangle) { + const length = shape2D.length; + const shape = new Array(length * 6); + let index = 0; + const xOffset = boundingRectangle.x + boundingRectangle.width / 2; + const yOffset = boundingRectangle.y + boundingRectangle.height / 2; + let point = shape2D[0]; + shape[index++] = point.x - xOffset; + shape[index++] = 0; + shape[index++] = point.y - yOffset; + for (let i = 1; i < length; i++) { + point = shape2D[i]; + const x = point.x - xOffset; + const z = point.y - yOffset; + shape[index++] = x; + shape[index++] = 0; + shape[index++] = z; + shape[index++] = x; + shape[index++] = 0; + shape[index++] = z; + } + point = shape2D[0]; + shape[index++] = point.x - xOffset; + shape[index++] = 0; + shape[index++] = point.y - yOffset; + return shape; +} +function convertShapeTo3D(shape2D, boundingRectangle) { + const length = shape2D.length; + const shape = new Array(length * 3); + let index = 0; + const xOffset = boundingRectangle.x + boundingRectangle.width / 2; + const yOffset = boundingRectangle.y + boundingRectangle.height / 2; + for (let i = 0; i < length; i++) { + shape[index++] = shape2D[i].x - xOffset; + shape[index++] = 0; + shape[index++] = shape2D[i].y - yOffset; + } + return shape; +} +var quaterion = new Quaternion_default(); +var startPointScratch = new Cartesian3_default(); +var rotMatrix = new Matrix3_default(); +function computeRoundCorner(pivot, startPoint, endPoint, cornerType, leftIsOutside, ellipsoid, finalPositions, shape, height, duplicatePoints) { + const angle = Cartesian3_default.angleBetween( + Cartesian3_default.subtract(startPoint, pivot, scratch1), + Cartesian3_default.subtract(endPoint, pivot, scratch2) + ); + const granularity = cornerType === CornerType_default.BEVELED ? 0 : Math.ceil(angle / Math_default.toRadians(5)); + let m; + if (leftIsOutside) { + m = Matrix3_default.fromQuaternion( + Quaternion_default.fromAxisAngle( + Cartesian3_default.negate(pivot, scratch1), + angle / (granularity + 1), + quaterion + ), + rotMatrix + ); + } else { + m = Matrix3_default.fromQuaternion( + Quaternion_default.fromAxisAngle(pivot, angle / (granularity + 1), quaterion), + rotMatrix + ); + } + let left; + let surfacePoint; + startPoint = Cartesian3_default.clone(startPoint, startPointScratch); + if (granularity > 0) { + const repeat = duplicatePoints ? 2 : 1; + for (let i = 0; i < granularity; i++) { + startPoint = Matrix3_default.multiplyByVector(m, startPoint, startPoint); + left = Cartesian3_default.subtract(startPoint, pivot, scratch1); + left = Cartesian3_default.normalize(left, left); + if (!leftIsOutside) { + left = Cartesian3_default.negate(left, left); + } + surfacePoint = ellipsoid.scaleToGeodeticSurface(startPoint, scratch2); + finalPositions = addPosition( + surfacePoint, + left, + shape, + finalPositions, + ellipsoid, + height, + 1, + repeat + ); + } + } else { + left = Cartesian3_default.subtract(startPoint, pivot, scratch1); + left = Cartesian3_default.normalize(left, left); + if (!leftIsOutside) { + left = Cartesian3_default.negate(left, left); + } + surfacePoint = ellipsoid.scaleToGeodeticSurface(startPoint, scratch2); + finalPositions = addPosition( + surfacePoint, + left, + shape, + finalPositions, + ellipsoid, + height, + 1, + 1 + ); + endPoint = Cartesian3_default.clone(endPoint, startPointScratch); + left = Cartesian3_default.subtract(endPoint, pivot, scratch1); + left = Cartesian3_default.normalize(left, left); + if (!leftIsOutside) { + left = Cartesian3_default.negate(left, left); + } + surfacePoint = ellipsoid.scaleToGeodeticSurface(endPoint, scratch2); + finalPositions = addPosition( + surfacePoint, + left, + shape, + finalPositions, + ellipsoid, + height, + 1, + 1 + ); + } + return finalPositions; +} +PolylineVolumeGeometryLibrary.removeDuplicatesFromShape = function(shapePositions) { + const length = shapePositions.length; + const cleanedPositions = []; + for (let i0 = length - 1, i1 = 0; i1 < length; i0 = i1++) { + const v0 = shapePositions[i0]; + const v1 = shapePositions[i1]; + if (!Cartesian2_default.equals(v0, v1)) { + cleanedPositions.push(v1); + } + } + return cleanedPositions; +}; +PolylineVolumeGeometryLibrary.angleIsGreaterThanPi = function(forward, backward, position, ellipsoid) { + const tangentPlane = new EllipsoidTangentPlane_default(position, ellipsoid); + const next = tangentPlane.projectPointOntoPlane( + Cartesian3_default.add(position, forward, nextScratch), + nextScratch + ); + const prev = tangentPlane.projectPointOntoPlane( + Cartesian3_default.add(position, backward, prevScratch), + prevScratch + ); + return prev.x * next.y - prev.y * next.x >= 0; +}; +var scratchForwardProjection = new Cartesian3_default(); +var scratchBackwardProjection = new Cartesian3_default(); +PolylineVolumeGeometryLibrary.computePositions = function(positions, shape2D, boundingRectangle, geometry, duplicatePoints) { + const ellipsoid = geometry._ellipsoid; + const heights = scaleToSurface(positions, ellipsoid); + const granularity = geometry._granularity; + const cornerType = geometry._cornerType; + const shapeForSides = duplicatePoints ? convertShapeTo3DDuplicate(shape2D, boundingRectangle) : convertShapeTo3D(shape2D, boundingRectangle); + const shapeForEnds = duplicatePoints ? convertShapeTo3D(shape2D, boundingRectangle) : void 0; + const heightOffset = boundingRectangle.height / 2; + const width = boundingRectangle.width / 2; + let length = positions.length; + let finalPositions = []; + let ends = duplicatePoints ? [] : void 0; + let forward = scratchCartesian1; + let backward = scratchCartesian2; + let cornerDirection = scratchCartesian3; + let surfaceNormal = scratchCartesian4; + let pivot = scratchCartesian5; + let start = scratchCartesian6; + let end = scratchCartesian7; + let left = scratchCartesian8; + let previousPosition = scratchCartesian9; + let position = positions[0]; + let nextPosition = positions[1]; + surfaceNormal = ellipsoid.geodeticSurfaceNormal(position, surfaceNormal); + forward = Cartesian3_default.subtract(nextPosition, position, forward); + forward = Cartesian3_default.normalize(forward, forward); + left = Cartesian3_default.cross(surfaceNormal, forward, left); + left = Cartesian3_default.normalize(left, left); + let h0 = heights[0]; + let h1 = heights[1]; + if (duplicatePoints) { + ends = addPosition( + position, + left, + shapeForEnds, + ends, + ellipsoid, + h0 + heightOffset, + 1, + 1 + ); + } + previousPosition = Cartesian3_default.clone(position, previousPosition); + position = nextPosition; + backward = Cartesian3_default.negate(forward, backward); + let subdividedHeights; + let subdividedPositions; + for (let i = 1; i < length - 1; i++) { + const repeat = duplicatePoints ? 2 : 1; + nextPosition = positions[i + 1]; + if (position.equals(nextPosition)) { + oneTimeWarning_default( + "Positions are too close and are considered equivalent with rounding error." + ); + continue; + } + forward = Cartesian3_default.subtract(nextPosition, position, forward); + forward = Cartesian3_default.normalize(forward, forward); + cornerDirection = Cartesian3_default.add(forward, backward, cornerDirection); + cornerDirection = Cartesian3_default.normalize(cornerDirection, cornerDirection); + surfaceNormal = ellipsoid.geodeticSurfaceNormal(position, surfaceNormal); + const forwardProjection = Cartesian3_default.multiplyByScalar( + surfaceNormal, + Cartesian3_default.dot(forward, surfaceNormal), + scratchForwardProjection + ); + Cartesian3_default.subtract(forward, forwardProjection, forwardProjection); + Cartesian3_default.normalize(forwardProjection, forwardProjection); + const backwardProjection = Cartesian3_default.multiplyByScalar( + surfaceNormal, + Cartesian3_default.dot(backward, surfaceNormal), + scratchBackwardProjection + ); + Cartesian3_default.subtract(backward, backwardProjection, backwardProjection); + Cartesian3_default.normalize(backwardProjection, backwardProjection); + const doCorner = !Math_default.equalsEpsilon( + Math.abs(Cartesian3_default.dot(forwardProjection, backwardProjection)), + 1, + Math_default.EPSILON7 + ); + if (doCorner) { + cornerDirection = Cartesian3_default.cross( + cornerDirection, + surfaceNormal, + cornerDirection + ); + cornerDirection = Cartesian3_default.cross( + surfaceNormal, + cornerDirection, + cornerDirection + ); + cornerDirection = Cartesian3_default.normalize(cornerDirection, cornerDirection); + const scalar = 1 / Math.max( + 0.25, + Cartesian3_default.magnitude( + Cartesian3_default.cross(cornerDirection, backward, scratch1) + ) + ); + const leftIsOutside = PolylineVolumeGeometryLibrary.angleIsGreaterThanPi( + forward, + backward, + position, + ellipsoid + ); + if (leftIsOutside) { + pivot = Cartesian3_default.add( + position, + Cartesian3_default.multiplyByScalar( + cornerDirection, + scalar * width, + cornerDirection + ), + pivot + ); + start = Cartesian3_default.add( + pivot, + Cartesian3_default.multiplyByScalar(left, width, start), + start + ); + scratch2Array[0] = Cartesian3_default.clone(previousPosition, scratch2Array[0]); + scratch2Array[1] = Cartesian3_default.clone(start, scratch2Array[1]); + subdividedHeights = subdivideHeights( + scratch2Array, + h0 + heightOffset, + h1 + heightOffset, + granularity + ); + subdividedPositions = PolylinePipeline_default.generateArc({ + positions: scratch2Array, + granularity, + ellipsoid + }); + finalPositions = addPositions( + subdividedPositions, + left, + shapeForSides, + finalPositions, + ellipsoid, + subdividedHeights, + 1 + ); + left = Cartesian3_default.cross(surfaceNormal, forward, left); + left = Cartesian3_default.normalize(left, left); + end = Cartesian3_default.add( + pivot, + Cartesian3_default.multiplyByScalar(left, width, end), + end + ); + if (cornerType === CornerType_default.ROUNDED || cornerType === CornerType_default.BEVELED) { + computeRoundCorner( + pivot, + start, + end, + cornerType, + leftIsOutside, + ellipsoid, + finalPositions, + shapeForSides, + h1 + heightOffset, + duplicatePoints + ); + } else { + cornerDirection = Cartesian3_default.negate(cornerDirection, cornerDirection); + finalPositions = addPosition( + position, + cornerDirection, + shapeForSides, + finalPositions, + ellipsoid, + h1 + heightOffset, + scalar, + repeat + ); + } + previousPosition = Cartesian3_default.clone(end, previousPosition); + } else { + pivot = Cartesian3_default.add( + position, + Cartesian3_default.multiplyByScalar( + cornerDirection, + scalar * width, + cornerDirection + ), + pivot + ); + start = Cartesian3_default.add( + pivot, + Cartesian3_default.multiplyByScalar(left, -width, start), + start + ); + scratch2Array[0] = Cartesian3_default.clone(previousPosition, scratch2Array[0]); + scratch2Array[1] = Cartesian3_default.clone(start, scratch2Array[1]); + subdividedHeights = subdivideHeights( + scratch2Array, + h0 + heightOffset, + h1 + heightOffset, + granularity + ); + subdividedPositions = PolylinePipeline_default.generateArc({ + positions: scratch2Array, + granularity, + ellipsoid + }); + finalPositions = addPositions( + subdividedPositions, + left, + shapeForSides, + finalPositions, + ellipsoid, + subdividedHeights, + 1 + ); + left = Cartesian3_default.cross(surfaceNormal, forward, left); + left = Cartesian3_default.normalize(left, left); + end = Cartesian3_default.add( + pivot, + Cartesian3_default.multiplyByScalar(left, -width, end), + end + ); + if (cornerType === CornerType_default.ROUNDED || cornerType === CornerType_default.BEVELED) { + computeRoundCorner( + pivot, + start, + end, + cornerType, + leftIsOutside, + ellipsoid, + finalPositions, + shapeForSides, + h1 + heightOffset, + duplicatePoints + ); + } else { + finalPositions = addPosition( + position, + cornerDirection, + shapeForSides, + finalPositions, + ellipsoid, + h1 + heightOffset, + scalar, + repeat + ); + } + previousPosition = Cartesian3_default.clone(end, previousPosition); + } + backward = Cartesian3_default.negate(forward, backward); + } else { + finalPositions = addPosition( + previousPosition, + left, + shapeForSides, + finalPositions, + ellipsoid, + h0 + heightOffset, + 1, + 1 + ); + previousPosition = position; + } + h0 = h1; + h1 = heights[i + 1]; + position = nextPosition; + } + scratch2Array[0] = Cartesian3_default.clone(previousPosition, scratch2Array[0]); + scratch2Array[1] = Cartesian3_default.clone(position, scratch2Array[1]); + subdividedHeights = subdivideHeights( + scratch2Array, + h0 + heightOffset, + h1 + heightOffset, + granularity + ); + subdividedPositions = PolylinePipeline_default.generateArc({ + positions: scratch2Array, + granularity, + ellipsoid + }); + finalPositions = addPositions( + subdividedPositions, + left, + shapeForSides, + finalPositions, + ellipsoid, + subdividedHeights, + 1 + ); + if (duplicatePoints) { + ends = addPosition( + position, + left, + shapeForEnds, + ends, + ellipsoid, + h1 + heightOffset, + 1, + 1 + ); + } + length = finalPositions.length; + const posLength = duplicatePoints ? length + ends.length : length; + const combinedPositions = new Float64Array(posLength); + combinedPositions.set(finalPositions); + if (duplicatePoints) { + combinedPositions.set(ends, length); + } + return combinedPositions; +}; +var PolylineVolumeGeometryLibrary_default = PolylineVolumeGeometryLibrary; + +export { + CornerType_default, + oneTimeWarning_default, + PolylineVolumeGeometryLibrary_default +};