@realsee/five 6.0.0-alpha.65 → 6.0.0-alpha.66
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/five/index.js +5 -5
- package/five/index.mjs +33 -15
- package/gltf-loader/index.js +2 -2
- package/gltf-loader/index.mjs +2 -2
- package/line/index.js +2 -2
- package/line/index.mjs +2 -2
- package/package.json +1 -1
- package/react/index.js +1 -1
- package/react/index.mjs +1 -1
- package/sticker/index.js +2 -2
- package/sticker/index.mjs +2 -2
- package/umd/five-gltf-loader.js +2 -2
- package/umd/five-line.js +2 -2
- package/umd/five-react.js +1 -1
- package/umd/five-sticker.js +2 -2
- package/umd/five-vfx.js +1 -1
- package/umd/five-vue.js +1 -1
- package/umd/five.js +5 -5
- package/vfx/index.js +1 -1
- package/vfx/index.mjs +1 -1
- package/vue/index.js +1 -1
- package/vue/index.mjs +1 -1
package/five/index.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
* @license
|
|
3
3
|
* @realsee/five
|
|
4
4
|
* Generated: 12/14/2023
|
|
5
|
-
* Version: 6.0.0-alpha.
|
|
5
|
+
* Version: 6.0.0-alpha.66
|
|
6
6
|
* Terms:
|
|
7
7
|
* Realsee SDK License Agreement
|
|
8
8
|
* Update: July 28, 2021
|
|
@@ -414,7 +414,7 @@ varying vec2 vUv;
|
|
|
414
414
|
void main() {
|
|
415
415
|
gl_FragColor = texture2D(map, vUv);
|
|
416
416
|
}
|
|
417
|
-
`,uu=[];function cc(){var n=uu.pop();return n||new d.ShaderMaterial({uniforms:{map:{value:null},flipY:{value:0}},vertexShader:uc,fragmentShader:lc,depthTest:!1,depthWrite:!1,stencilWrite:!1,blending:d.NoBlending,lights:!1,toneMapped:!1,fog:!1})}function dc(n){n.uniforms.map.value=null,uu.push(n)}function fc(n,t,e){var r=new d.Scene;r.matrixAutoUpdate=!1;var i=new d.Group;i.scale.set(1,1,-1),r.add(i);for(var a=[],o=0,s=n;o<s.length;o++){var u=s[o],c=cc();a.push(c),c.uniforms.map.value=u.texture,c.uniforms.flipY.value=u.flipY?1:0;var l=new d.Group,h=new d.Mesh(sc,c);h.position.set(u.position.x+u.size.x/2-.5,1-(u.position.y+u.size.y/2)-.5,-.5),h.scale.set(u.size.x,u.size.y,1),l.quaternion.copy(oc[u.face]),l.add(h),i.add(l)}var p=e.autoClear;e.autoClear=!1;var v=new d.CubeCamera(.1,2,t);v.matrixAutoUpdate=!1,v.update(e,r),e.autoClear=p;for(var m=0,A=a;m<A.length;m++){var c=A[m];dc(c)}}var ma=[],hc=6,zi=0;it.shared.add(function(){if(zi=hc,ma.length)for(var n=ma.splice(0,zi),t=0,e=n;t<e.length;t++){var r=e[t];zi--,r()}});var ga=function(){return!1}();function fi(){var n=Object.assign(document.createElementNS("http://www.w3.org/1999/xhtml","img"),{crossOrigin:"",close:function(){n.onerror=n.onload=n.close=Q;var t=n.src;n.removeAttribute("src"),/^blob\:/.test(t)&&URL.revokeObjectURL(t)}});return n}function lu(n){return new Promise(function(t,e){var r=fi();r.onload=function(){/^blob\:/.test(r.src)&&URL.revokeObjectURL(r.src),r.onload=r.onerror=Q,setTimeout(function(){t(r)},0)},r.onerror=function(){var i=r.src;r.onload=r.onerror=Q,r.close(),e(new Error("image load error: ".concat(i)))},r.src=URL.createObjectURL(n)})}function So(n){return new Promise(function(t){ma.push(function(){t(lu(n))})})}var To=[];function pc(n,t){var e=To.shift();if(e)return e.width=n,e.height=t,e;var r=Object.assign(document.createElementNS("http://www.w3.org/1999/xhtml","canvas"),{close:function(){r.close=Q,To.push(r)}});return r}function Po(n,t){if(t&&(n.width>t.width||n.height>t.height)){var e=pc(Math.min(n.width,t.width),Math.min(n.height,t.height)),r=e.getContext("2d");r.clearRect(0,0,e.width,e.height),r.drawImage(n,0,0,e.width,e.height),n.close();var i=new d.Texture(e);i.needsUpdate=!0,i.flipY=!0;var a=i.dispose;return i.dispose=function(){e.close(),a.call(i),i.dispose=a},i}else{var o=new d.Texture(n);o.needsUpdate=!0,typeof ImageBitmap<"u"&&n instanceof ImageBitmap?o.flipY=!1:o.flipY=!0;var s=o.dispose;return o.dispose=function(){n.close(),s.call(o),o.dispose=s},o}}function vc(n){var t=new d.CubeTexture(n);t.needsUpdate=!0,t.flipY=!1;var e=t.dispose;return t.dispose=function(){for(var r=0,i=n;r<i.length;r++){var a=i[r];a.close()}e.call(t),t.dispose=e},t}var Hr=["right","left","up","down","front","back"],Ac=4,Qe=function(){function n(t,e,r,i,a){this.tileTree=e,this.tileSources=r,this.options=i,this.renderer=a,this.name="",this.needsRender=!1,this.disposed=!1,this.loadedCubeNodes=new Set,this.loadingCubeNodes=new Set,this.baseCubeTexture=null,this._cubeRenderTarget=null,this.textures=[],this.baseCubeTexture=t}return Object.defineProperty(n.prototype,"cubeRenderTarget",{get:function(){return this._cubeRenderTarget},set:function(t){var e,r,i,a,o;if(t===null)throw new Error("cannot set cubeRenderTarget to null.");t.width!==this.options.textureSize&&t.setSize(this.options.textureSize,this.options.textureSize),t.texture.format=(e=this.options.format)!==null&&e!==void 0?e:d.RGBAFormat,t.texture.minFilter=(r=this.options.minFilter)!==null&&r!==void 0?r:d.LinearFilter,t.texture.magFilter=(i=this.options.magFilter)!==null&&i!==void 0?i:d.LinearFilter,t.texture.wrapS=(a=this.options.wrapS)!==null&&a!==void 0?a:d.ClampToEdgeWrapping,t.texture.wrapT=(o=this.options.wrapT)!==null&&o!==void 0?o:d.ClampToEdgeWrapping,this.baseCubeTexture&&(Aa(this.baseCubeTexture,t,this.renderer),this.baseCubeTexture.dispose(),this.baseCubeTexture=null),this._cubeRenderTarget&&Aa(this._cubeRenderTarget.texture,t,this.renderer),this._cubeRenderTarget=t},enumerable:!1,configurable:!0}),n.prototype.requestTile=function(t){var e=this,r,i,a,o,s,u,c=this.tileSources.filter(function(A){return A.level===t.level})[0];if(!c){this.loadedCubeNodes.add(t);return}var l=c.size,h=Math.pow(2,t.level)*t.position.y,p=Math.pow(2,t.level)*t.position.x,v="".concat(((a=(i=(r=this.options.imageURL)===null||r===void 0?void 0:r.options)===null||i===void 0?void 0:i.key)!==null&&a!==void 0?a:"pano.0").replace(/^pano/,"pano_tile"),".").concat(t.face,".").concat(t.level,".").concat(h,".").concat(p),m=R(R({},(s=(o=this.options.imageURL)===null||o===void 0?void 0:o.options)!==null&&s!==void 0?s:{key:"unknown"}),{key:v,size:l*t.size===this.options.tileImageSize?void 0:this.options.tileImageSize,quality:void 0,cut:[l*t.position.x,l*t.position.y,l*t.size,l*t.size]});this.loadingCubeNodes.add(t),this.options.textureLoader.loadTexture(c[t.face],{imageURL:{transform:(u=this.options.imageURL)===null||u===void 0?void 0:u.transform,options:R({},m)},format:d.RGBAFormat,viaAjax:ga,timeout:this.options.timeout,fetcher:this.options.fetcher}).then(function(A){if(e.disposed){A.body.dispose();return}e.textures.push({face:t.face,level:t.level,position:t.position,size:new d.Vector2(t.size,t.size),texture:A.body,flipY:!A.body.flipY}),e.loadedCubeNodes.add(t)}).catch(Q).then(function(){e.disposed||e.loadingCubeNodes.delete(t)})},n.prototype.update=function(t,e){var r=this;if(!this.disposed){var i=[];Ha(this.tileTree,function(p){if(r.loadingCubeNodes.has(p)||p.level>e||!t.intersectsBox(p.box))return!1;if(!r.loadedCubeNodes.has(p))return i.push(p),!1});for(var a=0,o=i;a<o.length;a++){var s=o[a];this.requestTile(s)}if(this.cubeRenderTarget&&this.textures.length){var u=this.textures.splice(0,Ac);fc(u,this.cubeRenderTarget,this.renderer),this.needsRender=!0;for(var c=0,l=u;c<l.length;c++){var h=l[c];h.texture.dispose()}}}},Object.defineProperty(n.prototype,"tilePending",{get:function(){return this.loadingCubeNodes.size},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"texture",{get:function(){if(!this._cubeRenderTarget)throw new Error("cubeRenderTarget never set.");return this._cubeRenderTarget.texture},enumerable:!1,configurable:!0}),n.prototype.dispose=function(){if(!this.disposed){this.disposed=!0,this.baseCubeTexture&&(this.baseCubeTexture.dispose(),this.baseCubeTexture=null),this.loadingCubeNodes.clear(),this.loadedCubeNodes.clear();for(var t=0,e=this.textures;t<e.length;t++){var r=e[t];r.texture.dispose()}this.textures.length=0}},n}(),An=function(){function n(){}return n.prototype.loadTexture=function(t,e,r,i,a,o){var s,u,c,l;r===void 0&&(r=Q),i===void 0&&(i=Q),a===void 0&&(a=Q);var h={};typeof e.flipY<"u"&&(h.flipY=e.flipY),typeof e.format<"u"&&(h.format=e.format),typeof e.minFilter<"u"&&(h.minFilter=e.minFilter),typeof e.magFilter<"u"&&(h.magFilter=e.magFilter);var p=(u=(s=e.imageURL)===null||s===void 0?void 0:s.options)!==null&&u!==void 0?u:{key:"unknown"};t=di(t,(c=e.imageURL)===null||c===void 0?void 0:c.transform,p);var v=Co(t),m=(l=e.viaAjax)!==null&&l!==void 0?l:!1,A=Mo(t),y=/^https?:/.test(v);if(A?m=!0:y||(m=!1),m){var f=null,g="blob";return e.fetcher.ajax(t,{timeout:e.timeout,responseType:g},void 0,void 0,a).then(function(E){return So(E.body)}).then(function(E){return Po(E,e.maxSize)}).then(function(E){return Object.assign(E,h),E}).then(function(E){var x={meta:f,body:E};return r(x),x}).catch(function(E){return i(E),Promise.reject(E)})}else{var b=null,w;return Promise.resolve().then(function(){return fi()}).then(function(E){return w=E,e.fetcher.loadImage(t,{timeout:e.timeout},void 0,void 0,a,E)}).then(function(E){return b=E.meta,Po(E.body,e.maxSize)}).then(function(E){return Object.assign(E,h),E}).then(function(E){var x={meta:b,body:E};return r(x),x}).catch(function(E){return w&&w.close(),i(E),Promise.reject(E)})}},n.prototype.loadCubeTexture=function(t,e,r,i,a,o){var s,u,c,l;r===void 0&&(r=Q),i===void 0&&(i=Q),a===void 0&&(a=Q),typeof e.format<"u"&&e.format,typeof e.minFilter<"u"&&e.minFilter,typeof e.magFilter<"u"&&e.magFilter;for(var h=[t[Hr[0]],t[Hr[1]],t[Hr[2]],t[Hr[3]],t[Hr[4]],t[Hr[5]]],p=[],v=[0,0,0,0,0,0],m=[],A=function(f){var g=(u=(s=e.imageURL)===null||s===void 0?void 0:s.options)!==null&&u!==void 0?u:{key:"unknown"},b=di(h[f],(c=e.imageURL)===null||c===void 0?void 0:c.transform,R(R({},g),{key:g.key+"."+Hr[f]})),w=Co(b),E=function(F){v[f]=F,a(v.reduce(function(k,O){return k+O},0)/6)},x=(l=e.viaAjax)!==null&&l!==void 0?l:!1,M=/^https?:$/.test(w),C=Mo(b);if(C?x=!0:M||(x=!1),x){var I="blob",P=e.fetcher.ajax(b,{timeout:e.timeout,responseType:I},void 0,void 0,E).then(function(F){return m[f]=F.meta,So(F.body)});p.push(P)}else{var S,P=Promise.resolve().then(function(){return fi()}).then(function(k){return S=k,e.fetcher.loadImage(b,{timeout:e.timeout},void 0,void 0,E,k)}).then(function(k){return m[f]=k.meta,k.body}).catch(function(k){return S&&S.close(),Promise.reject(k)});p.push(P)}},y=0;y<6;y++)A(y);return Promise.all(p).then(function(f){return vc(f)}).then(function(f){return Object.assign(f,R({encoding:d.sRGBEncoding},e)),f}).then(function(f){var g={body:f,meta:m};return r(g),g}).catch(function(f){for(var g=0,b=p;g<b.length;g++){var w=b[g];w.then(function(E){return E.close()}).catch(Q)}return i(f),Promise.reject(f)})},n.prototype.loadTiledCubeTexture=function(t,e,r,i,a,o,s){var u=this;return i===void 0&&(i=Q),a===void 0&&(a=Q),o===void 0&&(o=Q),new Promise(function(c,l){var h,p;u.loadCubeTexture(t,{imageURL:{transform:(h=r.imageURL)===null||h===void 0?void 0:h.transform,options:(p=r.imageURL)===null||p===void 0?void 0:p.options},format:d.RGBAFormat,viaAjax:r.viaAjax,timeout:r.timeout,fetcher:r.fetcher},function(v){var m,A,y=v.meta,f=v.body,g=(m=r.tileImageSize)!==null&&m!==void 0?m:512,b=(A=r.tileMaxLevel)!==null&&A!==void 0?A:2,w=Math.max(1024*b,512),E=pa(b),x=new Qe(f,E,e,{textureSize:w,tileImageSize:g,textureLoader:u,imageURL:r.imageURL,timeout:r.timeout,fetcher:r.fetcher},s),M={meta:y,body:x};i(M),c(M)},function(v){a(v),l(v)},o,s).catch(Q)})},n}();const mc=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,a=0,o="";return t[a].split(o).map(function(s){return s.charCodeAt(a)>i?s:String.fromCharCode((s.charCodeAt(a)+r)%i)}).join(o)}("0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6--nvor-sy|n-sy||H--n\bv{t-sy|n-Sy||H0r{qvsnvor-sy|n-v_||sZnxHn\bv{t-sy|n-V_||sZnxHn\bv{t-rp@-[|znyHn\bv{t-rp@-cvr]|vv|{Hn\bv{t-rpA-|yq]|vv|{Hn\bv{t-sy|n-Y|tQr}uHn\bv{t-znA-cvrZnv\x07H0v{pyqr-Ip|zz|{K0v{pyqr-Il}nlrr\x07K0v{pyqr-I?l}nlrr\x07K0v{pyqr-Ip|y|l}nlrr\x07K0v{pyqr-Iunq|zn}l}nlrr\x07K|vq-znv{56-\n--0v{pyqr-Ilrr\x07K--0v{pyqr-I?lrr\x07K--0v{pyqr-Ip|y|lrr\x07K--0v{pyqr-Iortv{{|znylrr\x07K--0v{pyqr-Iqrsny{|znylrr\x07K--rpA-n{s|zrq-J-rpA5}|vv|{9->;=6H--rpA-z]|vv|{-J-z|qrycvrZnv\x07-7-n{s|zrqH--[|zny-J-{|znyv r5n{s|zrq[|zny6H--0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6----Sy||-J-sy||H--0r{qvs--cvr]|vv|{-J-:z]|vv|{;\x07\b H--|yq]|vv|{-J-z|qryZnv\x07-7-n{s|zrqH--tyl]|vv|{-J-}|wrpv|{Znv\x07-7-z|qrycvrZnv\x07-7-n{s|zrqH--0v{pyqr-Iunq|zn}lrr\x07K--Y|tQr}u-J-y|t?5:z]|vv|{; 6H--cvrZnv\x07-J-vrZnv\x07H--V_||sZnx-J-v_||sZnxH\f"),gc=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,a=0,o="";return t[a].split(o).map(function(s){return s.charCodeAt(a)>i?s:String.fromCharCode((s.charCodeAt(a)+r)%i)}).join(o)}("0qrsv{r-OYNPXlP\\Y\\_-rpA5=;=EC9-=;>=C9-=;>AF9->;=60qrsv{r-aNb-C;?E@>EB?{vs|z-nz}yrPor-}n{|=lzn}H{vs|z-znA-}n{|=lznv\x07H0vs-qrsv{rq5b`RlYbZV[N[PR6--{vs|z-nz}yrPor-}n{|=lyzv{n{prZn}H0r{qvs{vs|z-nz}yrPor-}n{|>lzn}H{vs|z-znA-}n{|>lznv\x07H0vs-qrsv{rq5b`RlYbZV[N[PR6--{vs|z-nz}yrPor-}n{|>lyzv{n{prZn}H0r{qvs{vs|z-rp@-qvssrH{vs|z-rp@-rzvvrH{vs|z-rp@-}rpynH{vs|z-sy|n-uv{v{rH{vs|z-sy|n-r\x07}|rH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-}|trH{vs|z-sy|n-u|{Sy||V{qr\x07Hn\bv{t-sy|n-V_||sZnxH0vs-qrsv{rq5b`RlP\\[`aN[alP\\Y\\_6--{vs|z-rp@-p|{n{P|y|H0r{qvs0vs-qrsv{rq5b`Rl]N[\\lcVQR\\6--{vs|z-rp?-}n{|cvqr|lv rH--{vs|z-znA-}n{|cvqr|lznv\x07H--{vs|z-sy|n-}n{|cvqr|lny}unH--{vs|z-nz}yr?Q-}n{|cvqr|lzn}H0r{qvs0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6--n\bv{t-sy|n-Sy||H0ryr--{vs|z-sy|n-sy||H0r{qvsn\bv{t-rpA-|yq]|vv|{Hn\bv{t-sy|n-Y|tQr}uHn\bv{t-znA-cvrZnv\x07Hp-Pyv}}r-\n--znA-znv\x07V{rrH--sy|n-sy||V{qr\x07H\fH0vs-[bZlPYV]]R_`-K-=--{vs|z-Pyv}}r-pyv}}rh[bZlPYV]]R_`jH0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-I}npxv{tK0v{pyqr-Ip|y|l}nlsntzr{K0v{pyqr-Il}nlsntzr{K0v{pyqr-I?l}nlsntzr{K0v{pyqr-Izn}l}nlsntzr{K0v{pyqr-Iny}unzn}l}nlsntzr{K0v{pyqr-In|zn}l}nlsntzr{K0v{pyqr-Iyvtuzn}l}nlsntzr{K0v{pyqr-Irzvvrzn}l}nlsntzr{K0v{pyqr-Ir{zn}l}nlsntzr{K0v{pyqr-Itnqvr{zn}l}nlsntzr{K0v{pyqr-Is|tl}nlsntzr{K0v{pyqr-IoqsK0v{pyqr-Iyvtul}nlortv{K0v{pyqr-Iyvtul}u|{tl}nlsntzr{K0v{pyqr-Iunq|zn}l}nlsntzr{Krp?-|P||q5rp@-rp|6-\n--sy|n--J-yr{tu5rp|6H--sy|n-urn-J-np|5rp|;\b-<-6H--sy|n-}uv-J-nn{5rp|;\x079-rp|; 6H--r{-rp?5=;B-8-}uv-<-aNb9-urn-<-]V6H\f|vq-znv{56-\n--sy|n-ory|{tv{tSY||-J-=;=H--0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6----ory|{tv{tSY||-J-Sy||H--0ryr----ory|{tv{tSY||-J-sy||H--0r{qvs--zn@-pnzrn_|nv|{Znv\x07-J-zn@5cvrZnv\x07h=jh=j9-cvrZnv\x07h>jh=j9-cvrZnv\x07h?jh=j9cvrZnv\x07h=jh>j9-cvrZnv\x07h>jh>j9-cvrZnv\x07h?jh>j9cvrZnv\x07h=jh?j9-cvrZnv\x07h>jh?j9-cvrZnv\x07h?jh?j6H--rp@-pnzrnQvrpv|{-J-{|znyv r5pnzrn_|nv|{Znv\x07-7-rp@5=;=9=;=9>;=66H--vs5pnzrnQvrpv|{;\b-K-=;E-33-V_||sZnx-JJ->;=6-\n----qvpnqH--\f--<<前置裁切计算--0vs-[bZlPYV]]R_`-K-=----o||y-pyv}}rqH----rpA-pyv}}r]|vv|{H----0}ntzn-{|yyly||}ln----s|-5-v{-v-J-=H-v-I-[bZlPYV]]R_`H-v-88-6-\n------pyv}}r]|vv|{-J-pyv}}rh-v-j;znv\x07V{rr-7-|yq]|vv|{H------pyv}}rq-J-5pyv}}rh-v-j;sy||V{qr\x07-I-=;=-\v\v-no5ory|{tv{tSY||-:-pyv}}rh-v-j;sy||V{qr\x076-I->;=6H------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{;\x07-K-:=;B-33-pyv}}r]|vv|{;\x07-I-=;BH------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{;\b-K-:=;B-33-pyv}}r]|vv|{;\b-I-=;BH------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{; -K-:=;B-33-pyv}}r]|vv|{; -I-=;BH------vs-5pyv}}rq6-\n--------qvpnqH------\f----\f----0}ntzn-{|yyly||}lr{q--0r{qvs--0vs-qrsv{rq5b`RlP\\[`aN[alP\\Y\\_6----tylSntP|y|-J-rpA5p|{n{P|y|;9-p|{n{P|y|;t9-p|{n{P|y|;o9->;=6H----r{H--0r{qvs--<<楼层选择计算--sy|n-sy||\\}npv\b-J->;=H--vs-5u|{Sy||V{qr\x07-KJ-=;=-33-no5ory|{tv{tSY||-:-u|{Sy||V{qr\x076-KJ->;=6-\n----sy||\\}npv\b-J-=;>H--\f--rpA-qvssrP|y|-J-rpA5qvssr;to9-|}npv\b6H--_rsyrprqYvtu-rsyrprqYvtu-J-_rsyrprqYvtu5rp@5=;=69-rp@5=;=69-rp@5=;=69-rp@5=;=66H--rp@-|nyRzvvr_nqvn{pr-J-rzvvrH--0v{pyqr-Izn}lsntzr{K--0v{pyqr-Ip|y|lsntzr{K--0v{pyqr-Iny}unzn}lsntzr{K--0v{pyqr-Iny}unrlsntzr{K--0v{pyqr-I}rpynzn}lsntzr{K--0v{pyqr-I{|znylsntzr{lortv{K--0v{pyqr-I{|znylsntzr{lzn}K--0v{pyqr-Irzvvrzn}lsntzr{K--0v{pyqr-Iyvtul}u|{tlsntzr{K--0v{pyqr-Iyvtulsntzr{lortv{K--<<-调整曝光值--vnqvn{pr-J-vnqvn{pr-7-r\x07}|rH--0v{pyqr-Iyvtulsntzr{lzn}K--0v{pyqr-Iyvtulsntzr{lr{qK--0v{pyqr-In|zn}lsntzr{K--<<-减少方向光对模型的影响--rp@-|t|v{tYvtu-J-5rsyrprqYvtu;qvrpQvssr-7-=;?6-8----rsyrprqYvtu;v{qvrpQvssr-8----rsyrprqYvtu;v{qvrp`}rpyn-8----|nyRzvvr_nqvn{prH--<<-修复黑色面片的问题--vs-5|t|v{tYvtu;-K-=;=-\v\v-|t|v{tYvtu;t-K-=;=-\v\v-|t|v{tYvtu;o-K-=;=6-\n----tylSntP|y|-J-rpA5|t|v{tYvtu9-qvssrP|y|;n6H--\f-ryr-\n----tylSntP|y|-J-rpA5OYNPXlP\\Y\\_;\x07\b 9-qvssrP|y|;n6H--\f--rp@-}n{|=a|crr\x07-J-5|yq]|vv|{;\x07\b -:-}n{|=lznv\x07h@j;\x07\b 6-7-zn@5}n{|=lznv\x076H--rp@-}n{|>a|crr\x07-J-5|yq]|vv|{;\x07\b -:-}n{|>lznv\x07h@j;\x07\b 6-7-zn@5}n{|>lznv\x076H--rpA-}n{|P|y|H--rpA-}n{|=P|y|-J-r\x07rPor5}n{|=lzn}9-}n{|=a|crr\x076H--rpA-}n{|>P|y|-J-r\x07rPor5}n{|>lzn}9-}n{|>a|crr\x076H--0vs-qrsv{rq5b`RlYbZV[N[PR6----}n{|=P|y|;n-J->;=-:-r\x07rPor5}n{|=lyzv{n{prZn}9-}n{|=a|crr\x076;H----}n{|>P|y|;n-J->;=-:-r\x07rPor5}n{|>lyzv{n{prZn}9-}n{|>a|crr\x076;H--0r{qvs--0vs-qrsv{rq5b`RlOYNPXla_N[`VaV\\[6----sy|n-oynpx]|tr-J-np|5:?;=-7-}|tr-8->;=6H----}n{|P|y|-J-zv\x075}n{|=P|y|9-OYNPXlP\\Y\\_9-zv{5>;=9-oynpx]|tr66H----}n{|P|y|-J-zv\x075}n{|P|y|9-}n{|>P|y|9-zn\x075=;=9-oynpx]|tr-:-?;=66H--0ryr----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-}|tr6H--0r{qvs--0vs-qrsv{rq5b`Rl]N[\\lcVQR\\6----rp@-pnzrna|crr\x07-J-|yq]|vv|{;\x07\b -:-pnzrn]|vv|{H----rpA-zn}P||q-J-rpA5pnzrna|crr\x079->;=6-7-}n{|cvqr|lznv\x07H----rp?--J-rp?5------=;B-8-zn}P||q;\x07-<-zn}P||q; -<-}n{|cvqr|lv r;\x079------=;B-:-zn}P||q;\b-<-zn}P||q; -<-}n{|cvqr|lv r;\b----6H----rpA-vqr|P|y|-J-r\x07r?Q5}n{|cvqr|lzn}9-6H----sy|n-znpu-J-5>;=-:-r}5=;=9-zn}P||q; 66-7-5>;=-:-r}5=;B9-no5;\x07-:-=;B666-7-5>;=-:-r}5=;B9-no5;\b-:-=;B666H----sy|n-ny}un-J-pynz}5=;=9->;=9-B;=-7-5>;=-:-pynz}5qvn{pr59-rp?5=;B9-=;B66-<-=;BB-9-=;=9->;=666H----}n{|P|y|-J-zv\x075}n{|P|y|9-vqr|P|y|9-znpu-7-ny}un-7-}n{|cvqr|lny}un6H--0r{qvs--0vs-qrsv{rq5b`Rl]N[\\l\\]NPVaf6----tylSntP|y|-J-zv\x075}n{|P|y|9-tylSntP|y|9-z|qryNy}un6H----tylSntP|y|;n-J-|}npv\bH--0ryr----tylSntP|y|-J-rpA5tylSntP|y|;to9-|}npv\b-7-sy||\\}npv\b6H----tylSntP|y|-J-zv\x075}n{|P|y|9-tylSntP|y|9-z|qryNy}un6H--0r{qvs--0vs-qrsv{rq5b`RlRQY6----tylSntP|y|;n-J-Y|tQr}uH--0r{qvs\f");var Ln=new d.WebGLCubeRenderTarget(1).texture;Ln.name="EMPTY_TEXTURE";var yc=Object.assign({modelAlpha:new d.Uniform(0),progress:new d.Uniform(0),pano0_map:new d.Uniform(Ln),pano0_luminanceMap:new d.Uniform(null),pano0_matrix:new d.Uniform(new d.Matrix4),pano1_map:new d.Uniform(Ln),pano1_luminanceMap:new d.Uniform(null),pano1_matrix:new d.Uniform(new d.Matrix4),clippers:new d.Uniform([]),shownFloorIndex:new d.Uniform(-1),constantColor:new d.Uniform(null),floor:new d.Uniform(0)},{exposure:new d.Uniform(1),emissive:new d.Uniform(new d.Color(0)),emissiveMap:new d.Uniform(null),specular:new d.Uniform(new d.Color(1118481)),specularMap:new d.Uniform(null),normalMap:new d.Uniform(null),bumpMap:new d.Uniform(null),shininess:new d.Uniform(30)},d.UniformsUtils.clone(d.UniformsLib.common),d.UniformsUtils.clone(d.UniformsLib.lights)),Vn=function(n){de(t,n);function t(e){e===void 0&&(e={});var r,i,a,o,s,u,c,l,h,p,v,m,A,y,f,g,b,w,E,x,M=n.call(this,{vertexShader:mc,fragmentShader:gc,uniforms:d.UniformsUtils.clone(yc),defines:{USE_CONSTANT_COLOR:!1,USE_EDL:!1,USE_HQ_WEIGHT:!1,USE_HQ_DEPTH:!1,NUM_CLIPPING_BOX:!1,USE_CLIPFLOOR:!1,USE_VERTEX_FLOOR:!1,USE_MAP:!0,USE_UV:!0,USE_LUMINANCE:!1,USE_PANO_OPACITY:!1,USE_BLACK_TRANSITION:!1,USE_PANO_VIDEO:!1,USE_POINT_NORMAL:!1,USE_POINT_CIRCLE:!1,USE_POINT_ADAPTIVE_SIZE:!1,USE_POINT_COLOR_ALTITUDE:!1},lights:!0})||this,C,I=null,P=null;return Object.defineProperties(M,{pano0:{get:function(){return I},set:function(S){if(I!==S){I=S,S===null?(this.uniforms.pano0_map.value=Ln,this.uniforms.pano0_luminanceMap.value=null,this.uniforms.pano0_matrix.value.identity()):(this.uniforms.pano0_map.value=S.map instanceof Qe?S.map.texture:S.map,this.uniforms.pano0_luminanceMap.value=S.luminanceMap instanceof Qe?S.luminanceMap.texture:S.luminanceMap,this.uniforms.pano0_matrix.value.copy(S.matrix));var F=this.uniforms.pano0_luminanceMap.value!==null&&this.uniforms.pano1_luminanceMap.value!==null,k=this.defines.USE_LUMINANCE;k!==F&&(this.defines.USE_LUMINANCE=F,this.needsUpdate=!0)}}},pano1:{get:function(){return P},set:function(S){if(P!==S){P=S,S===null?(this.uniforms.pano1_map.value=Ln,this.uniforms.pano1_luminanceMap.value=null,this.uniforms.pano1_matrix.value.identity()):(this.uniforms.pano1_map.value=S.map instanceof Qe?S.map.texture:S.map,this.uniforms.pano1_luminanceMap.value=S.luminanceMap instanceof Qe?S.luminanceMap.texture:S.luminanceMap,this.uniforms.pano1_matrix.value.copy(S.matrix));var F=this.uniforms.pano0_luminanceMap.value!==null&&this.uniforms.pano1_luminanceMap.value!==null,k=this.defines.USE_LUMINANCE;k!==F&&(this.defines.USE_LUMINANCE=F,this.needsUpdate=!0)}}},modelAlpha:{get:function(){return this.uniforms.modelAlpha.value},set:function(S){this.uniforms.modelAlpha.value=S}},progress:{get:function(){return this.uniforms.progress.value},set:function(S){this.uniforms.progress.value=S}},useBlackTransition:{get:function(){return this.defines.USE_BLACK_TRANSITION},set:function(S){var F=this.defines.USE_BLACK_TRANSITION;F!==S&&(this.defines.USE_BLACK_TRANSITION=S,this.needsUpdate=!0)}},constantColor:{get:function(){return this.uniforms.constantColor.value},set:function(S){this.uniforms.constantColor.value=S;var F=this.defines.USE_CONSTANT_COLOR,k=S!==null;F!==k&&(this.defines.USE_CONSTANT_COLOR=k,this.needsUpdate=!0)}},opacity:{get:function(){return this.uniforms.opacity.value},set:function(S){this.uniforms.opacity.value=S}},shownFloorIndex:{get:function(){return this.uniforms.shownFloorIndex.value},set:function(S){this.uniforms.shownFloorIndex.value=S}},clippers:{get:function(){return C},set:function(S){C!==S&&(C=S,this.uniforms.clippers.value=(C||[]).map(function(F){var k=typeof F.floorIndex=="number"?F.floorIndex:-1,O=new d.Matrix4().getInverse(F.clippingBoxMatrix);return{matrixInverse:O,floorIndex:k}}),this.needsUpdate=!0)}},useEDL:{get:function(){return this.defines.USE_EDL},set:function(S){S!==this.defines.USE_EDL&&(this.defines.USE_EDL=S,this.needsUpdate=!0)}},useHQWeight:{get:function(){return this.defines.USE_HQ_WEIGHT},set:function(S){S!==this.defines.USE_HQ_WEIGHT&&(this.defines.USE_HQ_WEIGHT=S,this.needsUpdate=!0)}},useHQDepth:{get:function(){return this.defines.USE_HQ_DEPTH},set:function(S){S!==this.defines.USE_HQ_DEPTH&&(this.defines.USE_HQ_DEPTH=S,this.needsUpdate=!0)}},floor:{get:function(){return this.uniforms.floor.value},set:function(S){this.uniforms.floor.value=S}}}),M.pano0=(r=e.pano0)!==null&&r!==void 0?r:be.pano0,M.pano1=(i=e.pano1)!==null&&i!==void 0?i:be.pano1,M.modelAlpha=(a=e.modelAlpha)!==null&&a!==void 0?a:be.modelAlpha,M.progress=(o=e.progress)!==null&&o!==void 0?o:be.progress,M.useBlackTransition=(s=e.useBlackTransition)!==null&&s!==void 0?s:be.useBlackTransition,M.constantColor=(u=e.constantColor)!==null&&u!==void 0?u:be.constantColor,M.opacity=(c=e.opacity)!==null&&c!==void 0?c:be.opacity,M.shownFloorIndex=(l=e.shownFloorIndex)!==null&&l!==void 0?l:be.shownFloorIndex,M.clippers=(h=e.clippers)!==null&&h!==void 0?h:be.clippers,M.useEDL=(p=e.useEDL)!==null&&p!==void 0?p:be.useEDL,M.useHQWeight=(v=e.useHQWeight)!==null&&v!==void 0?v:be.useHQWeight,M.useHQDepth=(m=e.useHQDepth)!==null&&m!==void 0?m:be.useHQDepth,M.pointSize=(A=e.pointSize)!==null&&A!==void 0?A:be.pointSize,M.pointColor=(y=e.pointColor)!==null&&y!==void 0?y:be.pointColor,M.pointShape=(f=e.pointShape)!==null&&f!==void 0?f:be.pointShape,M.pointScale=(g=e.pointScale)!==null&&g!==void 0?g:be.pointScale,M.pointBack=(b=e.pointBack)!==null&&b!==void 0?b:be.pointBack,M.pointMinPixel=(w=e.pointMinPixel)!==null&&w!==void 0?w:be.pointMinPixel,M.pointMaxPixel=(E=e.pointMaxPixel)!==null&&E!==void 0?E:be.pointMaxPixel,M.gradientTexture=(x=e.gradientTexture)!==null&&x!==void 0?x:be.gradientTexture,M.floor=0,M}return t.prototype.onBeforeCompile=function(e,r){var i,a,o=String((a=(i=this.clippers)===null||i===void 0?void 0:i.length)!==null&&a!==void 0?a:0);e.vertexShader=e.vertexShader.replace(/NUM_CLIPPERS/g,o),e.fragmentShader=e.fragmentShader.replace(/NUM_CLIPPERS/g,o)},t.prototype.update=function(e,r){this.transparent=this.shownFloorIndex>-1||this.opacity<1,this.blending=this.transparent?d.NormalBlending:d.NoBlending},t.prototype.syncModel=function(e){var r="".concat(e.id,":").concat(e.materialVersion);r!==this.syncModelVersion&&(Object.assign(this,e.getMaterial()),this.syncModelVersion=r)},t}(d.ShaderMaterial),_r=function(n){de(t,n);function t(e){var r=e.preserveDrawingBuffer,i=r===void 0?!0:r,a=e.backgroundColor,o=a===void 0?1579548:a,s=e.backgroundAlpha,u=s===void 0?1:s,c=e.pixelRatio,l=c===void 0?1:c,h=e.antialias,p=h===void 0?!1:h,v=e.webgl2,m=v===void 0?!1:v,A=this,y=u<1;if(m){var f=document.createElement("canvas"),g=f.getContext("webgl2");g?A=n.call(this,{antialias:p,preserveDrawingBuffer:i,alpha:y,canvas:f,context:g})||this:(console.error("error occurred when getting webgl2 canvas context, mybe webgl2 not support, fallback to webgl."),A=n.call(this,{antialias:p,preserveDrawingBuffer:i,alpha:y})||this)}else A=n.call(this,{antialias:p,preserveDrawingBuffer:i,alpha:y})||this;return A.setPixelRatio(l),A.setClearColor(o,u),A.outputEncoding=d.sRGBEncoding,A.autoClear=!0,A}return t}(d.WebGLRenderer),cu=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.add=function(){for(var e=[],r=0;r<arguments.length;r++)e[r]=arguments[r];return n.prototype.add.apply(this,e)},t.prototype.remove=function(){for(var e=[],r=0;r<arguments.length;r++)e[r]=arguments[r];return n.prototype.remove.apply(this,e)},t}(d.Scene);function Rr(n,t){var e=Math.abs(Math.cos(n.latitude)),r=-Math.sin(n.longitude)*e,i=-Math.sin(n.latitude),a=-Math.cos(n.longitude)*e;return t?t.set(r,i,a):new d.Vector3(r,i,a)}var bc=1,wc=.1,Ec=1e3,Gn=Math.PI*2,Bo=Math.PI/2;function Ro(n){return n>0&&n<=Gn?n:(n%Gn+Gn)%Gn}function xc(n,t,e,r){e=Math.pow(e,4);for(var i=0;i<16;i++)r.elements[i]=n.elements[i]+(t.elements[i]-n.elements[i])*e;return r}var hi=function(n){de(t,n);function t(e,r,i,a,o,s,u){r===void 0&&(r=bc),i===void 0&&(i=wc),a===void 0&&(a=Ec),o===void 0&&(o=new d.Vector2),s===void 0&&(s=512),u===void 0&&(u=1);var c=n.call(this)||this;c.fov=e,c.aspect=r,c.near=i,c.far=a,c.perspToOrtho=o,c.screenHeight=s,c.pixelRatio=u,c.needsRender=!0,c.pose={longitude:0,latitude:0,fov:e,distance:0,offset:new d.Vector3},c.computePose(),c.perspectiveCamera=new d.PerspectiveCamera(c.fov,c.aspect,.001,c.far);var l=Math.max(c.orthoDistance,.01)*Math.tan(.5*c.fov/180*Math.PI),h=-.5*c.aspect*2*l;return c.orthographicCamera=new d.OrthographicCamera(h,-h,l,-l,.001,c.far),c.computeProjectionMatrix(),c.lastValues={position:c.position.clone(),quaternion:c.quaternion.clone(),scale:c.scale.clone(),fov:c.fov,aspect:c.aspect,near:c.near,far:c.far,perspToOrtho:c.perspToOrtho.clone()},c.type=c.perspToOrtho.x<1?"PerspectiveCamera":"OrthographicCamera",c}return Object.defineProperty(t.prototype,"orthoDistance",{get:function(){return this.pose.distance>1?this.pose.distance:1+(this.pose.distance-1)*this.perspToOrtho.x},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"zoom",{get:function(){return this.type==="OrthographicCamera"?this.orthographicCamera.zoom:this.type==="PerspectiveCamera"?this.perspectiveCamera.zoom:1},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"top",{get:function(){return this.type==="OrthographicCamera"?this.orthographicCamera.top:0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"bottom",{get:function(){return this.type==="OrthographicCamera"?this.orthographicCamera.bottom:0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"left",{get:function(){return this.type==="OrthographicCamera"?this.orthographicCamera.left:0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"right",{get:function(){return this.type==="OrthographicCamera"?this.orthographicCamera.right:0},enumerable:!1,configurable:!0}),t.prototype.getDirection=function(e){return Rr(this.pose,e)},t.prototype.computePose=function(e){e===void 0&&(e=0);var r=this.getDirection(new d.Vector3);this.pose.longitude=Ro(-Math.atan2(r.x,-r.z)),this.pose.latitude=-Math.asin(r.y/1),this.pose.fov=this.fov,this.pose.distance=e;var i=new d.Vector3().add(this.position).add(r.clone().setLength(this.pose.distance));return this.pose.offset.copy(i),this},t.prototype.setFromPose=function(e){var r,i,a,o,s,u=Ro((r=e.longitude)!==null&&r!==void 0?r:this.pose.longitude),c=Math.max(-Bo+1e-4,Math.min(Bo-1e-4,(i=e.latitude)!==null&&i!==void 0?i:this.pose.latitude)),l=(a=e.fov)!==null&&a!==void 0?a:this.pose.fov,h=(o=e.distance)!==null&&o!==void 0?o:this.pose.distance,p=(s=e.offset)!==null&&s!==void 0?s:this.pose.offset,v=Rr({longitude:u,latitude:c}).normalize();return this.position.set(0,0,0),this.lookAt(v),this.position.add(p).sub(v.clone().setLength(h)),this.fov!==l&&(this.fov=l,this.updateProjectionMatrix()),this.updateMatrixWorld(),this.pose.longitude=u,this.pose.latitude=c,this.pose.fov=l,this.pose.distance=h,this.pose.offset.copy(p),this.needsRender=!0,this},t.prototype.copyPose=function(){return{longitude:this.pose.longitude,latitude:this.pose.latitude,fov:this.pose.fov,distance:this.pose.distance,offset:this.pose.offset.clone()}},t.prototype.computeProjectionMatrix=function(){xc(this.orthographicCamera.projectionMatrix,this.perspectiveCamera.projectionMatrix,1-this.perspToOrtho.x,this.projectionMatrix),this.projectionMatrixInverse.getInverse(this.projectionMatrix),this.needsRender=!0},t.prototype.setViewOffset=function(e,r,i,a,o,s){this.perspectiveCamera.setViewOffset(e,r,i,a,o,s),this.orthographicCamera.setViewOffset(e,r,i,a,o,s),this.computeProjectionMatrix()},t.prototype.clearViewOffset=function(){this.perspectiveCamera.clearViewOffset(),this.orthographicCamera.clearViewOffset(),this.computeProjectionMatrix()},t.prototype.updateProjectionMatrix=function(){this.perspectiveCamera.updateProjectionMatrix(),this.orthographicCamera.updateProjectionMatrix(),this.computeProjectionMatrix()},Object.defineProperty(t.prototype,"perspectiveProjectionMatrix",{get:function(){return this.perspectiveCamera.projectionMatrix},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"perspectiveProjectionMatrixInverse",{get:function(){return this.perspectiveCamera.projectionMatrixInverse},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"orthographicProjectionMatrix",{get:function(){return this.orthographicCamera.projectionMatrix},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"orthographicProjectionMatrixInverse",{get:function(){return this.orthographicCamera.projectionMatrixInverse},enumerable:!1,configurable:!0}),t.prototype.updateTime=function(e,r){var i=!1;if((this.lastValues.fov!==this.fov||this.lastValues.near!==this.near||this.lastValues.far!==this.far||this.lastValues.aspect!==this.aspect)&&(this.perspectiveCamera.fov=this.fov,this.perspectiveCamera.near=this.near,this.perspectiveCamera.far=this.far,this.perspectiveCamera.aspect=this.aspect,this.perspectiveCamera.updateProjectionMatrix(),i=!0),!this.lastValues.position.equals(this.position)||!this.lastValues.quaternion.equals(this.quaternion)||!this.lastValues.scale.equals(this.scale)||!this.lastValues.perspToOrtho.equals(this.perspToOrtho)||this.lastValues.fov!==this.fov||this.lastValues.near!==this.near||this.lastValues.far!==this.far||this.lastValues.aspect!==this.aspect){var a=Math.max(this.orthoDistance,.01)*Math.tan(.5*this.fov/180*Math.PI),o=-.5*this.aspect*2*a;this.orthographicCamera.left=o,this.orthographicCamera.right=-o,this.orthographicCamera.top=a,this.orthographicCamera.bottom=-a,this.orthographicCamera.updateProjectionMatrix(),i=!0}i&&this.computeProjectionMatrix(),this.lastValues.position.copy(this.position),this.lastValues.quaternion.copy(this.quaternion),this.lastValues.scale.copy(this.scale),this.lastValues.fov=this.fov,this.lastValues.aspect=this.aspect,this.lastValues.near=this.near,this.lastValues.far=this.far,this.lastValues.perspToOrtho.copy(this.perspToOrtho),this.type=this.perspToOrtho.x<1?"PerspectiveCamera":"OrthographicCamera"},Object.defineProperty(t.prototype,"isPerspectiveCamera",{get:function(){return this.perspToOrtho.x<1},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isOrthographicCamera",{get:function(){return this.perspToOrtho.x>=1},enumerable:!1,configurable:!0}),t.prototype.copy=function(e,r){return n.prototype.copy.call(this,e,r),this.fov=e.fov,this.aspect=e.aspect,this.near=e.near,this.far=e.far,this.perspToOrtho.copy(e.perspToOrtho),this.updateTime(ve(),0),this},t}(d.Camera),bt;(function(n){n[n.Outside=-1]="Outside",n[n.Intersecting=0]="Intersecting",n[n.Inside=1]="Inside"})(bt||(bt={}));var du=1e-6,Ne=new d.Vector3,Br=new d.Matrix4,Mr=new d.Vector3,Cr=new d.Vector3,Ir=new d.Vector3,ya=new d.Vector3,Fo=new d.Box3,Oo=new d.Sphere,ko=new d.Matrix4,Lo=new d.Ray,gt=new d.Object3D,Do=new d.Frustum;function fu(n,t){var e=n.elements;return t.setFromRotationMatrix(Br.set(e[0],e[3],e[6],0,e[1],e[4],e[7],0,e[2],e[5],e[8],0,0,0,0,1)),t}var Pn=function(){function n(t){t===void 0&&(t=[]),this.planes=t}return Object.defineProperty(n,"MASK_OUTSIDE",{get:function(){return 4294967295},enumerable:!1,configurable:!0}),Object.defineProperty(n,"MASK_INSIDE",{get:function(){return 0},enumerable:!1,configurable:!0}),Object.defineProperty(n,"MASK_INDETERMINATE",{get:function(){return 2147483647},enumerable:!1,configurable:!0}),n.prototype.setFromFrustum=function(t){return this.planes=t.planes.map(function(e){return e.clone()}),this},n.prototype.setFromCamera=function(t){return Br.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse),Do.setFromProjectionMatrix(Br),this.setFromFrustum(Do),this},n.prototype.computeVisibility=function(t){for(var e=bt.Inside,r=0,i=this.planes;r<i.length;r++){var a=i[r],o=t.intersectPlane(a);switch(o){case bt.Outside:return bt.Outside;case bt.Intersecting:e=bt.Intersecting;break}}return e},n.prototype.computeVisibilityWithPlaneMask=function(t,e){if(e===n.MASK_OUTSIDE||e===n.MASK_INSIDE)return e;for(var r=n.MASK_INSIDE,i=Math.min(32,this.planes.length),a=0;a<i;++a){var o=1<<a;if(e&o){var s=this.planes[a],u=t.intersectPlane(s);if(u===bt.Outside)return n.MASK_OUTSIDE;u===bt.Intersecting&&(r|=o)}}return r},n}(),hu=function(){function n(){this.type="box",this.center=new d.Vector3,this.halfSize=new d.Vector3,this.rotation=new d.Matrix3}return n.prototype.fromJson=function(t){var e=t.box;this.center.set(e[0],e[1],e[2]);var r=e[3],i=e[4],a=e[5],o=e[6],s=e[7],u=e[8],c=e[9],l=e[10],h=e[11],p=Math.sqrt(r*r+i*i+a*a),v=Math.sqrt(o*o+s*s+u*u),m=Math.sqrt(c*c+l*l+h*h);this.halfSize.set(p,v,m);var A=this.halfSize.toArray().reduce(function(y,f){return y+f},0);return(isNaN(A)||A<=0)&&this.halfSize.setScalar(du),this.rotation.fromArray([r/p,i/p,a/p,o/v,s/v,u/v,c/m,l/m,h/m]),isNaN(this.rotation.toArray().reduce(function(y,f){return y+f},0))&&this.rotation.identity(),this},n.prototype.toJson=function(){return this.rotation.extractBasis(Mr,Cr,Ir),{box:at(at(at(at([],this.center.toArray(),!0),Mr.multiplyScalar(this.halfSize.x).toArray(),!0),Cr.multiplyScalar(this.halfSize.y).toArray(),!0),Ir.multiplyScalar(this.halfSize.z).toArray(),!0)}},n.prototype.copy=function(t){return this.center.copy(t.center),this.halfSize.copy(t.halfSize),this.rotation.copy(t.rotation),this},n.prototype.clone=function(){return new n().copy(this)},n.prototype.applyMatrix4=function(t){return gt.position.copy(this.center),fu(this.rotation,gt.quaternion),gt.scale.copy(this.halfSize),gt.matrix.compose(gt.position,gt.quaternion,gt.scale),gt.matrix.premultiply(t),gt.matrix.decompose(gt.position,gt.quaternion,gt.scale),this.center.copy(gt.position),this.rotation.setFromMatrix4(Br.makeRotationFromQuaternion(gt.quaternion)),this.halfSize.copy(gt.scale),this},n.prototype.getCenter=function(t){return t.copy(this.center)},n.prototype.distanceSquaredTo=function(t){var e=this.rotation.elements,r=t.x-this.center.x,i=t.y-this.center.y,a=t.z-this.center.z,o=0,s;return s=r*e[0]+i*e[1]+a*e[2],s<0&&(s=-s),s-=this.halfSize.x,s>0&&(o+=s*s),s=r*e[3]+i*e[4]+a*e[5],s<0&&(s=-s),s-=this.halfSize.y,s>0&&(o+=s*s),s=r*e[6]+i*e[7]+a*e[8],s<0&&(s=-s),s-=this.halfSize.z,s>0&&(o+=s*s),o},n.prototype.distanceTo=function(t){return Math.sqrt(this.distanceSquaredTo(t))},n.prototype.getBoundingBox=function(t){return t.makeEmpty(),this.rotation.extractBasis(Mr,Cr,Ir),Mr.setLength(this.halfSize.x),Cr.setLength(this.halfSize.y),Ir.setLength(this.halfSize.z),t.expandByPoint(Ne.copy(this.center).add(Mr)),t.expandByPoint(Ne.copy(this.center).sub(Mr)),t.expandByPoint(Ne.copy(this.center).add(Cr)),t.expandByPoint(Ne.copy(this.center).sub(Cr)),t.expandByPoint(Ne.copy(this.center).add(Ir)),t.expandByPoint(Ne.copy(this.center).sub(Ir)),t},n.prototype.toGeometry=function(){var t=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]),e=new Float32Array(8*3);Ne.set(this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,0),Ne.set(-this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,3),Ne.set(-this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,6),Ne.set(this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,9),Ne.set(this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,12),Ne.set(-this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,15),Ne.set(-this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,18),Ne.set(this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,21);var r=new d.BufferGeometry;return r.setIndex(new d.BufferAttribute(t,1)),r.setAttribute("position",new d.BufferAttribute(e,3)),r.computeBoundingBox(),r.computeBoundingSphere(),r},n.prototype.intersectPlane=function(t){var e=this.center,r=t.normal,i=this.rotation.elements,a=this.halfSize,o=r.x,s=r.y,u=r.z,c=Math.abs(o*i[0]*a.x+s*i[1]*a.x+u*i[2]*a.x)+Math.abs(o*i[3]*a.y+s*i[4]*a.y+u*i[5]*a.y)+Math.abs(o*i[6]*a.z+s*i[7]*a.z+u*i[8]*a.z),l=r.dot(e)+t.constant;return l<=-c?bt.Outside:l>=c?bt.Inside:bt.Intersecting},n.prototype.intersectRay=function(t,e){ya.copy(this.halfSize).multiplyScalar(2),Fo.setFromCenterAndSize(Ne.set(0,0,0),ya),this.rotation.extractBasis(Mr,Cr,Ir),Br.makeBasis(Mr,Cr,Ir),Br.setPosition(this.center),ko.getInverse(Br),Lo.copy(t).applyMatrix4(ko);var r=Lo.intersectBox(Fo,Ne);return r?e!==void 0?r.applyMatrix4(Br).distanceTo(t.origin)<e:!0:!1},n}(),pu=function(){function n(){this.type="sphere",this.center=new d.Vector3,this.radius=-1}return n.prototype.fromJson=function(t){var e=t.sphere;return this.center.set(e[0],e[1],e[2]),this.radius=Math.max(e[3],du),this},n.prototype.toJson=function(){return{sphere:at(at([],this.center.toArray(),!0),[this.radius],!1)}},n.prototype.copy=function(t){return this.center.copy(t.center),this.radius=t.radius,this},n.prototype.clone=function(){return new n().copy(this)},n.prototype.getBoundingBox=function(t){return t.setFromCenterAndSize(this.center,ya.set(1,1,1).multiplyScalar(this.radius*2)),t},n.prototype.toGeometry=function(){for(var t=32,e=new Float32Array(t*3*2*2),r=0;r<=t;r++){var i=0;i=r/t*Math.PI*2,e[r*6+0]=this.center.x+Math.cos(i)*this.radius,e[r*6+1]=this.center.y+Math.sin(i)*this.radius,e[r*6+2]=this.center.z+0,i=(r+1)/t*Math.PI*2,e[r*6+3]=this.center.x+Math.cos(i)*this.radius,e[r*6+4]=this.center.y+Math.sin(i)*this.radius,e[r*6+5]=this.center.z+0}for(var r=t;r<=t*2;r++){var i=0;i=r/t*Math.PI*2,e[r*6+0]=this.center.x+Math.cos(i)*this.radius,e[r*6+1]=this.center.y+0,e[r*6+2]=this.center.z+Math.sin(i)*this.radius,i=(r+1)/t*Math.PI*2,e[r*6+3]=this.center.x+Math.cos(i)*this.radius,e[r*6+4]=this.center.y+0,e[r*6+5]=this.center.z+Math.sin(i)*this.radius}var a=new d.BufferGeometry;return a.setAttribute("position",new d.BufferAttribute(e,3)),a.computeBoundingBox(),a.computeBoundingSphere(),a},n.prototype.applyMatrix4=function(t){return this.center.applyMatrix4(t),this.radius=this.radius*t.getMaxScaleOnAxis(),this},n.prototype.getCenter=function(t){return t.copy(this.center)},n.prototype.distanceSquaredTo=function(t){var e=this.distanceTo(t);return e*e},n.prototype.distanceTo=function(t){var e=this.center.distanceTo(t)-this.radius;return e<=0?0:e},n.prototype.intersectPlane=function(t){var e=this.center,r=this.radius,i=t.normal,a=i.dot(e)+t.constant;return a<-r?bt.Outside:a<r?bt.Intersecting:bt.Inside},n.prototype.intersectRay=function(t,e){Oo.set(this.center,this.radius);var r=t.intersectSphere(Oo,Ne);return r?e!==void 0?t.origin.distanceTo(r)<e:!0:!1},n}(),Mc=function(){function n(){throw this.type="regin",this.west=0,this.south=0,this.east=0,this.north=0,this.minHeight=0,this.maxHeight=0,new Error("Region bounding volume not supported.")}return n.prototype.fromJson=function(t){var e=t.region;return this.west=e[0],this.south=e[1],this.east=e[2],this.north=e[3],this.minHeight=e[4],this.maxHeight=e[5],this},n.prototype.toJson=function(){return{region:[this.west,this.south,this.east,this.north,this.minHeight,this.maxHeight]}},n.prototype.copy=function(t){return this.west=t.west,this.south=t.south,this.east=t.east,this.north=t.north,this.minHeight=t.minHeight,this.maxHeight=t.maxHeight,this},n.prototype.clone=function(){return new n().copy(this)},n.prototype.getBoundingBox=function(t){throw new Error("not implemented")},n.prototype.toGeometry=function(){throw new Error("not implemented")},n.prototype.applyMatrix4=function(t){throw new Error("not implemented")},n.prototype.getCenter=function(t){throw new Error("not implemented")},n.prototype.distanceTo=function(t){throw new Error("not implemented")},n.prototype.distanceSquaredTo=function(t){throw new Error("not implemented")},n.prototype.intersectPlane=function(t){throw new Error("not implemented")},n.prototype.intersectRay=function(t){throw new Error("not implemented")},n}();function Bn(n){if("box"in n)return new hu().fromJson(n);if("sphere"in n)return new pu().fromJson(n);if("region"in n)return new Mc().fromJson(n);throw new Error("BoundingVolume ".concat(JSON.stringify(n)," never suppored."))}var Kn=[2621517,3801199,4915345,5963950,7274706,8782079,9575167,10434047,11623423,12482559,13274879,13870335,14464511,15125247,15852031,16446719].map(function(n){return new d.LineBasicMaterial({color:n,depthWrite:!1,transparent:!0})}),Cc=function(){var n=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]),t=new Float32Array(8*3);Ne.set(1,1,1).toArray(t,0),Ne.set(-1,1,1).toArray(t,3),Ne.set(-1,-1,1).toArray(t,6),Ne.set(1,-1,1).toArray(t,9),Ne.set(1,1,-1).toArray(t,12),Ne.set(-1,1,-1).toArray(t,15),Ne.set(-1,-1,-1).toArray(t,18),Ne.set(1,-1,-1).toArray(t,21);var e=new d.BufferGeometry;return e.setIndex(new d.BufferAttribute(n,1)),e.setAttribute("position",new d.BufferAttribute(t,3)),e.computeBoundingBox(),e.computeBoundingSphere(),e}(),Ic=function(){for(var n=32,t=new Float32Array(n*3*2*2),e=0;e<=n;e++){var r=0;r=e/n*Math.PI*2,t[e*6+0]=Math.cos(r),t[e*6+1]=Math.sin(r),t[e*6+2]=0,r=(e+1)/n*Math.PI*2,t[e*6+3]=Math.cos(r),t[e*6+4]=Math.sin(r),t[e*6+5]=0}for(var e=n;e<=n*2;e++){var r=0;r=e/n*Math.PI*2,t[e*6+0]=Math.cos(r),t[e*6+1]=0,t[e*6+2]=Math.sin(r),r=(e+1)/n*Math.PI*2,t[e*6+3]=Math.cos(r),t[e*6+4]=0,t[e*6+5]=Math.sin(r)}var i=new d.BufferGeometry;return i.setAttribute("position",new d.BufferAttribute(t,3)),i.computeBoundingBox(),i.computeBoundingSphere(),i}();function Sc(n,t){if(n instanceof hu){var e=new d.LineSegments(Cc,Kn[Math.min(t,Kn.length-1)]);return e.position.copy(n.center),fu(n.rotation,e.quaternion),e.scale.set(n.halfSize.x,n.halfSize.y,n.halfSize.z),e.matrix.compose(e.position,e.quaternion,e.scale),e}else if(n instanceof pu){var e=new d.LineSegments(Ic,Kn[Math.min(t,Kn.length-1)]);return e.position.copy(n.center),e.scale.set(n.radius,n.radius,n.radius),e.matrix.compose(e.position,e.quaternion,e.scale),e}throw new Error("never")}var _a=function(){function n(t,e,r,i){var a=this,o,s,u;this.parent=null,this.id=t,this.state={visible:!1,frameNumber:0,selectedFrameNumber:0,requestedFrameNumber:0,touchedFrameNumber:0,selectionDepth:0,shouldRefine:!1,distanceToCamera:0,screenSpaceError:0,visibilityPlaneMask:0,inRequestVolume:!1},this.parent=i??null,this.tileset=r,this.refine=(o=e.refine)!==null&&o!==void 0?o:this.parent?this.parent.refine:"REPLACE",this.transform=new d.Matrix4,e.transform&&this.transform.fromArray(e.transform),this.parent&&this.transform.premultiply(this.parent.transform),typeof e.geometricError=="number"?this.geometricError=e.geometricError*this.transform.getMaxScaleOnAxis():this.geometricError=(u=(s=this.parent)===null||s===void 0?void 0:s.geometricError)!==null&&u!==void 0?u:0,e.content&&e.content.uri?(this.content={uri:e.content.uri,loadState:"UNLOADED",byteLength:0},e.content.group!==void 0&&(this.content.group=e.content.group),e.content.boundingVolume&&(this.content.boundingVolume=Bn(e.content.boundingVolume).applyMatrix4(this.transform)),/\.json$/.test(this.content.uri)?this.type="TILESET":this.type="SCENEGRAPH"):(this.content=null,this.type="EMPTY"),e.boundingVolume&&(this.boundingVolume=Bn(e.boundingVolume).applyMatrix4(this.transform)),e.viewerRequestVolume&&(this.viewerRequestVolume=Bn(e.viewerRequestVolume).applyMatrix4(this.transform)),this.extras=e.extras||{},e.children?this.children=e.children.map(function(c,l){return new n("".concat(a.id,".").concat(l),c,r,a)}):this.children=[]}return n.prototype.updateState=function(t){this.state.frameNumber=t.frameNumber;var e=this.tileset.transformIsIdentity?null:this.tileset.transform;if(this.boundingVolume){var r=e?this.boundingVolume.clone().applyMatrix4(e):this.boundingVolume;this.state.distanceToCamera=r.distanceTo(t.camera.position);var i=this.parent?this.parent.state.visibilityPlaneMask:Pn.MASK_INDETERMINATE;this.state.visibilityPlaneMask=t.cullingVolume.computeVisibilityWithPlaneMask(r,i),this.state.visible=this.state.visibilityPlaneMask!==Pn.MASK_OUTSIDE}else this.state.distanceToCamera=0,this.state.visibilityPlaneMask=Pn.MASK_INDETERMINATE,this.state.visible=!0;if(this.viewerRequestVolume){var a=e?this.viewerRequestVolume.clone().applyMatrix4(e):this.viewerRequestVolume;this.state.inRequestVolume=a.distanceSquaredTo(t.camera.position)<=0}else this.state.inRequestVolume=!0;this.state.screenSpaceError=this.getScreenSpaceError(t,this.state.distanceToCamera,!1)},Object.defineProperty(n.prototype,"selected",{get:function(){return this.state.selectedFrameNumber===this.tileset.frameNumber},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"hasChildren",{get:function(){return this.children.length>0},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"siblingIndex",{get:function(){var t,e;return(e=(t=this.parent)===null||t===void 0?void 0:t.children.indexOf(this))!==null&&e!==void 0?e:0},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"hasTilesetContent",{get:function(){return this.children.length>0&&this.type==="TILESET"},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"hasRenderContent",{get:function(){return this.type==="MESH"||this.type==="SCENEGRAPH"},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"contentAvailable",{get:function(){var t;return this.hasRenderContent&&((t=this.content)===null||t===void 0?void 0:t.loadState)==="READY"},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"hasUnloadedContent",{get:function(){var t;return((t=this.content)===null||t===void 0?void 0:t.loadState)==="UNLOADED"},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"hasEmptyContent",{get:function(){return this.type==="EMPTY"},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"contentReady",{get:function(){var t;return((t=this.content)===null||t===void 0?void 0:t.loadState)==="READY"||this.hasEmptyContent},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"contentByteLength",{get:function(){return this.content?this.content.byteLength:0},enumerable:!1,configurable:!0}),n.prototype.loadContent=function(){var t=this,e;if(this.hasEmptyContent||!(!((e=this.content)===null||e===void 0)&&e.uri))return Promise.resolve(!1);var r=this.content;return r.data?Promise.resolve(!0):(r.loadState="LOADING",this.tileset.requestScheduler.scheduleRequest(this.id,function(){return t.getPriority()}).then(function(i){return i?t.tileset.options.contentLoader(t).then(function(a){return i.done(),r.loadState=a?"READY":"UNLOADED",a}).catch(function(a){return r.loadState="FAILED",i.done(),Promise.reject(a)}):(r.loadState="UNLOADED",Promise.resolve(!1))}))},n.prototype.unloadContent=function(){return this.content&&(this.content.loadState="UNLOADED",this.content.byteLength=0),!0},n.prototype.getScreenSpaceError=function(t,e,r){var i=this.tileset.transformIsIdentity?1:this.tileset.transform.getMaxScaleOnAxis(),a=this.parent?this.parent.geometricError:this.tileset.geometricError,o=i*(r?a:this.geometricError);if(o===0)return 0;var s=Math.max(e,.001),u=o*t.height/(s*t.sseDenominator);return u},n.prototype.getPriority=function(){var t=this.refine==="ADD"||this.tileset.skipLevelOfDetail;if(t&&!this.state.visible||this.tileset.frameNumber-this.state.touchedFrameNumber>=1||this.content.loadState==="UNLOADED")return-1;var e=this.parent,r=e&&(!t||this.state.screenSpaceError===0),i=r?e.state.screenSpaceError:this.state.screenSpaceError,a=this.tileset.root?this.tileset.root.state.screenSpaceError:0,o=Math.max(a-i,0);return o},n}(),ba=function(){function n(){this.maxRequests=n.DEFAULT_MAX_REQUESTS,this.activeRequests=0,this.requestQueue=[],this.requestMap=new Map,this.deferred=null}return n.prototype.scheduleRequest=function(t,e){var r=this.requestMap.get(t);if(r)return r;var i={identiy:t,priority:0,getPriority:e,resolve:function(){}},a=new Promise(function(o){return i.resolve=o});return this.requestQueue.push(i),this.requestMap.set(t,a),this.issueNewRequests(),a},n.prototype.reset=function(){for(var t=0,e=this.requestQueue;t<e.length;t++){var r=e[t];r.resolve(null)}this.requestQueue.length=0,this.requestMap.clear(),this.activeRequests=0},n.prototype.issueRequest=function(t){var e=this,r=t.identiy,i=t.resolve,a=!1,o=function(){a||(a=!0,e.requestMap.delete(r),e.activeRequests--,e.issueNewRequests())};this.activeRequests++,i({done:o})},n.prototype.issueNewRequests=function(){var t=this;this.deferred||(this.deferred=setTimeout(function(){return t.issueNewRequestsAsync()},0))},n.prototype.issueNewRequestsAsync=function(){this.deferred=null;var t=Math.max(this.maxRequests-this.activeRequests,0);if(t!==0){this.updateAllRequests();for(var e=0;e<t;e++){var r=this.requestQueue.shift();if(r)this.issueRequest(r);else break}}},n.prototype.updateAllRequests=function(){for(var t=this.requestQueue,e=0;e<t.length;e++){var r=t[e];this.updateRequest(r)===!1&&(t.splice(e,1),this.requestMap.delete(r.identiy),e--)}t.sort(function(i,a){return i.priority-a.priority})},n.prototype.updateRequest=function(t){return t.priority=t.getPriority(t.identiy),t.priority<0?(t.resolve(null),!1):!0},n.DEFAULT_MAX_REQUESTS=6,n}(),Tc=function(){function n(t,e,r){this.item=t,this.previous=e,this.next=r}return n}(),Pc=function(){function n(){this.head=null,this.tail=null,this._length=0}return Object.defineProperty(n.prototype,"length",{get:function(){return this._length},enumerable:!1,configurable:!0}),n.prototype.add=function(t){var e=new Tc(t,this.tail,null);return this.tail?(this.tail.next=e,this.tail=e):(this.head=e,this.tail=e),this._length++,e},n.prototype.remove=function(t){t.previous&&t.next?(t.previous.next=t.next,t.next.previous=t.previous):t.previous?(t.previous.next=null,this.tail=t.previous):t.next?(t.next.previous=null,this.head=t.next):(this.head=null,this.tail=null),t.next=null,t.previous=null,this._length--},n.prototype.splice=function(t,e){t!==e&&(this.remove(e),this.insert(t,e))},n.prototype.insert=function(t,e){var r=t.next;t.next=e,this.tail===t?this.tail=e:r.previous=e,e.next=r,e.previous=t,this._length++},n.prototype.toArray=function(){for(var t=[],e=this.head;e;)t.push(e),e=e.next;return t},n}(),vu=function(){function n(){this.cacheNodeMap=new Map,this.list=new Pc,this.sentinel=this.list.add("sentinel")}return n.prototype.reset=function(){this.list.tail&&this.list.splice(this.list.tail,this.sentinel)},n.prototype.touch=function(t){var e=this.cacheNodeMap.get(t);e&&this.list.splice(this.sentinel,e)},n.prototype.add=function(t,e){if(!this.cacheNodeMap.has(t)){var r=this.list.add(t);this.cacheNodeMap.set(t,r),e&&e(t)}},n.prototype.unloadTile=function(t,e){var r=this.cacheNodeMap.get(t);r&&(this.list.remove(r),this.cacheNodeMap.delete(t),e&&e(t))},n.prototype.unloadTiles=function(t,e){for(var r=this.list.head;r!==this.sentinel&&t();){var i=r.item;r=r.next,this.unloadTile(i,e)}},n.prototype.toArray=function(){for(var t=[],e=0,r=this.list.toArray();e<r.length;e++){var i=r[e];i.item!=="sentinel"&&t.push(i.item)}return t},n}(),No=function(){function n(){this.map=new Map,this.array=[],this._length=0}return Object.defineProperty(n.prototype,"length",{get:function(){return this._length},enumerable:!1,configurable:!0}),n.prototype.get=function(t){return this.array[t]},n.prototype.set=function(t,e){t>=this.length&&(this._length=t+1),this.map.has(this.array[t])&&this.map.delete(this.array[t]),this.array[t]=e,this.map.set(e,t)},n.prototype.delete=function(t){var e=this.map.get(t);e!==void 0&&e>=0&&(this.array.splice(e,1),this.map.delete(t),this._length--)},n.prototype.push=function(t){if(!this.map.has(t)){var e=this._length++;this.array[e]=t,this.map.set(t,e)}},n.prototype.pop=function(){var t=this.array[--this._length];return this.map.delete(t),t},n.prototype.reset=function(){this.array=[],this.map=new Map,this._length=0},n.prototype.find=function(t){return this.map.has(t)},n}(),wa=function(){function n(){this.loadSiblings=n.DEFAULT_LOAD_SIBLINGS,this.skipLevelOfDetail=n.DEFAULT_SKIP_LEVEL_OF_DETAIL,this.maxScreenSpaceError=n.DEFAULT_MAX_SCREEN_SPACE_ERROR,this._canSelectTile=!0,this._traversalStack=new No,this._emptyTraversalStack=new No,this.root=null,this.selectedTiles=new Map,this.requestedTiles=new Map,this.needsRefinedTiles=new Map,this.emptyTiles=new Map}return n.prototype.traverse=function(t,e,r){r===void 0&&(r=[]),this.root=t,this.reset();for(var i=0,a=r;i<a.length;i++){var o=a[i];this._traversalStack.reset(),this._emptyTraversalStack.reset(),this._canSelectTile=o.camera.visible,this.updateTile(t,o),this.executeTraversal(t,o)}this._traversalStack.reset(),this._emptyTraversalStack.reset(),this._canSelectTile=!0,this.updateTile(t,e),this.executeTraversal(t,e)},n.prototype.reset=function(){this.needsRefinedTiles.clear(),this.requestedTiles.clear(),this.selectedTiles.clear(),this.emptyTiles.clear(),this._traversalStack.reset(),this._emptyTraversalStack.reset()},n.prototype.executeTraversal=function(t,e){var r=this._traversalStack;if(t.state.selectionDepth=0,e.maxLevelOfDetail>=0)for(t.state.visible&&t.state.inRequestVolume&&r.push(t);r.length>0;){var i=r.pop(),a=!1;if(this.canTraverse(i,e,!1,!1)){var o=i.hasRenderContent?i.state.selectionDepth+1:i.state.selectionDepth;this.updateChildTiles(i,e,o),a=this.updateAndPushChildren(i,e,r)}var s=i.parent,u=!s||s.state.shouldRefine,c=!a;i.hasRenderContent?i.refine==="ADD"?(this.loadTile(i,e.frameNumber),this.selectTile(i,e)):i.refine==="REPLACE"&&(this.loadTile(i,e.frameNumber),c&&this.selectTile(i,e)):(this.emptyTiles.set(i.id,i),this.loadTile(i,e.frameNumber),c&&this.selectTile(i,e)),this.touchTile(i,e),i.state.shouldRefine=a&&u}},n.prototype.updateChildTiles=function(t,e,r){for(var i=t.children,a=0,o=i;a<o.length;a++){var s=o[a];s.state.selectionDepth=r,this.updateTile(s,e)}return!0},n.prototype.updateAndPushChildren=function(t,e,r){for(var i=t.children,a=t.refine==="REPLACE"&&t.hasRenderContent&&!this.skipLevelOfDetail,o=!1,s=!0,u=0,c=i;u<c.length;u++){var l=c[u];if(l.state.visible&&l.state.inRequestVolume?(r.find(l)&&r.delete(l),r.push(l),o=!0):(a||this.loadSiblings)&&(this.loadTile(l,e.frameNumber),this.touchTile(l,e)),a){var h=void 0;l.state.inRequestVolume?l.hasRenderContent?h=l.contentAvailable:h=this.executeEmptyTraversal(l,e):h=!1,s=s&&h}}return o||(s=!1),s},n.prototype.updateTile=function(t,e){this.updateTileVisibility(t,e)},n.prototype.selectTile=function(t,e){this.shouldSelectTile(t)&&(t.state.selectedFrameNumber=e.frameNumber,this.selectedTiles.set(t.id,t)),this.needsRefinedTiles.set(t.id,t)},n.prototype.loadTile=function(t,e){this.shouldLoadTile(t)&&(t.state.requestedFrameNumber=e,this.requestedTiles.set(t.id,t)),this.needsRefinedTiles.set(t.id,t)},n.prototype.touchTile=function(t,e){t.tileset.cache.touch(t),t.state.touchedFrameNumber=e.frameNumber},n.prototype.canTraverse=function(t,e,r,i){return t.hasChildren?t.hasTilesetContent?!0:!i&&!t.state.visible?!1:this.shouldRefine(t,e,r):!1},n.prototype.shouldLoadTile=function(t){return t.hasUnloadedContent},n.prototype.shouldSelectTile=function(t){return t.contentAvailable&&!this.skipLevelOfDetail&&this._canSelectTile},n.prototype.shouldRefine=function(t,e,r){if(t.hasEmptyContent)return!0;if(t.hasRenderContent){if(t.state.selectionDepth>=e.maxLevelOfDetail)return!1;if(t.state.selectionDepth<e.minLevelOfDetail)return!0}var i=t.state.screenSpaceError;return r&&(i=t.getScreenSpaceError(e,t.state.distanceToCamera,!0)),i>this.maxScreenSpaceError},n.prototype.updateTileVisibility=function(t,e){if(t.updateState(e),!(!t.state.visible||!t.state.inRequestVolume)){var r=t.children.length>0;if(t.hasTilesetContent&&r){var i=t.children[0];this.updateTileVisibility(i,e),t.state.visible=i.state.visible;return}if(this.meetsScreenSpaceErrorEarly(t,e)){t.state.visible=!1;return}}},n.prototype.meetsScreenSpaceErrorEarly=function(t,e){var r=t.parent;return!r||r.refine!=="ADD"?!1:!this.shouldRefine(t,e,!0)},n.prototype.compareDistanceToCamera=function(t,e){return e.state.distanceToCamera-t.state.distanceToCamera},n.prototype.executeEmptyTraversal=function(t,e){var r=!0,i=this._emptyTraversalStack;for(i.push(t);i.length>0&&r;){var a=i.pop();this.updateTile(a,e),a.state.visible||this.loadTile(a,e.frameNumber),this.touchTile(a,e);var o=!a.hasRenderContent&&this.canTraverse(a,e,!1,!0);if(o)for(var s=a.children,u=0,c=s;u<c.length;u++){var l=c[u];i.find(l)&&i.delete(l),i.push(l)}else a.contentAvailable||(r=!1)}return r},n.DEFAULT_SKIP_LEVEL_OF_DETAIL=!1,n.DEFAULT_LOAD_SIBLINGS=!1,n.DEFAULT_MAX_SCREEN_SPACE_ERROR=4,n}(),Bc=new d.Matrix4,ii=function(){function n(t,e,r){var i,a;this.id=t,this.transform=new d.Matrix4,this.transformIsIdentity=!0,this.asset={version:e.asset.version,tilesetVersion:e.asset.tilesetVersion||"",gltfUpAxis:(i=e.asset.gltfUpAxis)!==null&&i!==void 0?i:"Y",overview:e.asset.overview},this.properties=(a=e.properties)!==null&&a!==void 0?a:{},this.options=r,this.traverser=new wa,this.cache=new vu,this.requestScheduler=new ba,this.frameNumber=0,this.pendingCount=0,this.tiles=new Map,this.memoryUsageInBytes=0,this.root=new _a("".concat(this.id,".0"),e.root,this),this.geometricError=e.geometricError,this.maxMemoryUsage=n.DEFAULT_MAX_MEMORY_USAGE}return Object.defineProperty(n.prototype,"maxRequests",{get:function(){return this.requestScheduler.maxRequests},set:function(t){this.requestScheduler.maxRequests=t},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"skipLevelOfDetail",{get:function(){return this.traverser.skipLevelOfDetail},set:function(t){this.traverser.skipLevelOfDetail=t},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"maxScreenSpaceError",{get:function(){return this.traverser.maxScreenSpaceError},set:function(t){this.traverser.maxScreenSpaceError=t},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"selectedTiles",{get:function(){return this.traverser.selectedTiles},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"needsRefinedTiles",{get:function(){return this.traverser.needsRefinedTiles},enumerable:!1,configurable:!0}),n.prototype.reset=function(){for(var t=this,e=[this.root],r;r=e.pop();){for(var i=0,a=r.children.length;i<a;i++)e.push(r.children[i]);this.cache.unloadTile(r,function(o){return t.unloadTile(o)})}this.cache.reset(),this.traverser.reset(),this.requestScheduler.reset(),this.tiles.clear()},n.prototype.isLoaded=function(){return this.pendingCount===0&&this.frameNumber!==0},n.prototype.traverse=function(t,e){var r=this;e===void 0&&(e=[]),this.transformIsIdentity=this.transform.equals(Bc),this.traverser.traverse(this.root,t,e),this.selectedTiles.forEach(function(i){r.tiles.set(i.id,i)}),this.traverser.requestedTiles.forEach(function(i){i.hasUnloadedContent&&r.loadTile(i)}),this.cache.unloadTiles(function(){var i=r.memoryUsageInBytes>r.maxMemoryUsage*1024*1024;return i},function(i){r.unloadTile(i),r.tiles.delete(i.id)})},n.prototype.loadTile=function(t){var e=this;this.pendingCount++,t.loadContent().catch(function(r){return e.options.onTileError(t,r),!1}).then(function(r){var i;e.pendingCount--,r&&(!((i=t.content)===null||i===void 0)&&i.data&&e.cache.add(t,function(){e.memoryUsageInBytes+=t.contentByteLength}),e.options.onTileLoad(t))})},n.prototype.unloadTile=function(t){this.memoryUsageInBytes-=t.contentByteLength,this.options.onTileUnload(t),t.unloadContent()},n.DEFAULT_VIEW_DISTANCE_SCALE=1,n.DEFAULT_MAX_MEMORY_USAGE=16,n.DEFAULT_MAX_SCREEN_SPACE_ERROR=wa.DEFAULT_MAX_SCREEN_SPACE_ERROR,n.DEFAULT_MAX_REQUESTS=ba.DEFAULT_MAX_REQUESTS,n}(),cn=function(){function n(t,e,r,i){this.extents=t,this.startIndex=e,this.endIndex=r,this.deepth=i}return n}();function Au(n,t,e,r){r===void 0&&(r=0);var i=e.extents[0]-r,a=e.extents[1]-r,o=e.extents[2]-r,s=e.extents[3]+r,u=e.extents[4]+r,c=e.extents[5]+r,l={min:0,max:0};t.x>=0?(l.min=(i-n.x)*t.x,l.max=(s-n.x)*t.x):(l.min=(s-n.x)*t.x,l.max=(i-n.x)*t.x);var h={min:0,max:0};if(t.y>=0?(h.min=(a-n.y)*t.y,h.max=(u-n.y)*t.y):(h.min=(u-n.y)*t.y,h.max=(a-n.y)*t.y),l.min>h.max||h.min>l.max)return!1;h.min>l.min&&(l.min=h.min),h.max<l.max&&(l.max=h.max);var p={min:0,max:0};return t.z>=0?(p.min=(o-n.z)*t.z,p.max=(c-n.z)*t.z):(p.min=(c-n.z)*t.z,p.max=(o-n.z)*t.z),!(l.min>p.max||p.min>l.max||(p.min>l.min&&(l.min=p.min),p.max<l.max&&(l.max=p.max),l.max<0))}var mu=function(){function n(t,e,r){this.x=t,this.y=e,this.z=r}return n.prototype.copy=function(t){return this.x=t.x,this.y=t.y,this.z=t.z,this},n.prototype.set=function(t,e,r){return this.x=t,this.y=e,this.z=r,this},n.prototype.fromArray=function(t,e){return e===void 0&&(e=0),this.x=t[e],this.y=t[e+1],this.z=t[e+2],this},n.prototype.toArray=function(t,e){return t===void 0&&(t=[]),e===void 0&&(e=0),t[e]=this.x,t[e+1]=this.y,t[e+2]=this.z,t},n.prototype.add=function(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z,this},n.prototype.multiplyScalar=function(t){return this.x*=t,this.y*=t,this.z*=t,this},n.prototype.subVectors=function(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this.z=t.z-e.z,this},n.prototype.addScaledVector=function(t,e){return this.x+=t.x*e,this.y+=t.y*e,this.z+=t.z*e,this},n.prototype.dot=function(t){return this.x*t.x+this.y*t.y+this.z*t.z},n.prototype.cross=function(t){var e=this.x,r=this.y,i=this.z;return this.x=r*t.z-i*t.y,this.y=i*t.x-e*t.z,this.z=e*t.y-r*t.x,this},n.prototype.crossVectors=function(t,e){var r=t.x,i=t.y,a=t.z,o=e.x,s=e.y,u=e.z;return this.x=i*u-a*s,this.y=a*o-r*u,this.z=r*s-i*o,this},n.prototype.distanceTo=function(t){return Math.sqrt(this.distanceToSquared(t))},n.prototype.distanceToSquared=function(t){var e=this.x-t.x,r=this.y-t.y,i=this.z-t.z;return e*e+r*r+i*i},n.prototype.clone=function(){return new n(this.x,this.y,this.z)},n}(),gu=function(){function n(t,e,r){this.triangle=t,this.intersectionPoint=e,this.index=r}return n}(),Qo=1e-6,Rc=function(){function n(t,e){if(this.positionArray=t,e)this.indicesArray=e;else{for(var r=t.length/3,i=new Uint32Array(r),a=0;a<r;a++)i[a]=a;this.indicesArray=i}}return n.prototype.createTree=function(t,e,r){var i=this.positionArray,a=this.indicesArray,o=a.length/3,s=new Uint32Array(o),u=new Float32Array(o*6),c=[],l=0;if(r)for(var h=0,p=0,v=0,m=void 0,A=void 0,y=void 0,f=void 0,g=void 0,b=void 0,w=void 0;h<o;h+=1,p+=3,v+=6)s[h]=h,m=f=i[a[p]*3],w=i[a[p+1]*3],w<m&&(m=w),w>f&&(f=w),w=i[a[p+2]*3],w<m&&(m=w),w>f&&(f=w),A=g=i[a[p]*3+1],w=i[a[p+1]*3+1],w<A&&(A=w),w>g&&(g=w),w=i[a[p+2]*3+1],w<A&&(A=w),w>g&&(g=w),y=b=i[a[p]*3+2],w=i[a[p+1]*3+2],w<y&&(y=w),w>b&&(b=w),w=i[a[p+2]*3+2],w<y&&(y=w),w>b&&(b=w),u[v]=m,u[v+1]=A,u[v+2]=y,u[v+3]=f,u[v+4]=g,u[v+5]=b;else{for(var E=1/0,x=1/0,M=1/0,C=-1/0,I=-1/0,P=-1/0,h=0,p=0,v=0,m=void 0,A=void 0,y=void 0,f=void 0,g=void 0,b=void 0,w=void 0;h<o;h+=1,p+=3,v+=6)s[h]=h,m=f=i[a[p]*3],w=i[a[p+1]*3],w<m&&(m=w),w>f&&(f=w),w=i[a[p+2]*3],w<m&&(m=w),w>f&&(f=w),A=g=i[a[p]*3+1],w=i[a[p+1]*3+1],w<A&&(A=w),w>g&&(g=w),w=i[a[p+2]*3+1],w<A&&(A=w),w>g&&(g=w),y=b=i[a[p]*3+2],w=i[a[p+1]*3+2],w<y&&(y=w),w>b&&(b=w),w=i[a[p+2]*3+2],w<y&&(y=w),w>b&&(b=w),u[v]=m,u[v+1]=A,u[v+2]=y,u[v+3]=f,u[v+4]=g,u[v+5]=b,m<E&&(E=m),f>C&&(C=f),A<x&&(x=A),g>I&&(I=g),y<M&&(M=y),b>P&&(P=b);r=[E,x,M,C,I,P]}var S=new cn(r,0,o,0);c[l++]=S;function F(k){for(var O=k.startIndex,L=k.endIndex,N=k.extents,V=[N[3]-N[0],N[4]-N[1],N[5]-N[2]],j=[0,1,2].sort(function($,te){return V[te]-V[$]}),z=0;z<3;z++){for(var U=j[z],X=N[U]+N[U+3],G=O,K=L-1,Y=-1,H=void 0;G<=K;)Y===-1?(H=s[G],u[H*6+U]+u[H*6+U+3]<X?G++:Y=H):(H=s[K],u[H*6+U]+u[H*6+U+3]>=X||(s[G]=H,s[K]=Y,Y=-1,G++),K--);if(G>O&&G<L){var J=new cn(Vo(s,u,O,G,Qo),O,G,k.deepth+1);J.deepth<e&&J.endIndex-J.startIndex>t&&(c[l++]=J);var ne=new cn(Vo(s,u,G,L,Qo),G,L,k.deepth+1);ne.deepth<e&&ne.endIndex-ne.startIndex>t&&(c[l++]=ne),k.node0=J,k.node1=ne,k.startIndex=0,k.endIndex=0;break}}}for(;l;)F(c[--l]);return this.offsetArray=s,this.rootNode=S,c.length=0,this},n.prototype.trianglesInSphere=function(t,e){for(var r=this.positionArray,i=this.indicesArray,a=this.offsetArray,o=this.rootNode,s=[o],u=[],c;c=s.pop();){var l=Hi(t.x,c.extents[0],c.extents[3])-t.x,h=Hi(t.y,c.extents[1],c.extents[4])-t.y,p=Hi(t.z,c.extents[2],c.extents[5])-t.z;if(l*l+h*h+p*p<=e*e){c.node0&&s.push(c.node0),c.node1&&s.push(c.node1);for(var v=c.startIndex;v<c.endIndex;v++)u.push(a[v])}}for(var m=u.length,A=new Float32Array(m*9),v=0;v<m;v++){var y=u[v];A[v*9]=r[i[y]*3],A[v*9+1]=r[i[y]*3+1],A[v*9+2]=r[i[y]*3+2],A[v*9+3]=r[i[y+1]*3],A[v*9+4]=r[i[y+1]*3+1],A[v*9+5]=r[i[y+1]*3+2],A[v*9+6]=r[i[y+2]*3],A[v*9+7]=r[i[y+2]*3+1],A[v*9+8]=r[i[y+2]*3+2]}return A},n.prototype.intersectRay=function(t,e,r){for(var i=this.positionArray,a=this.indicesArray,o=this.offsetArray,s=this.rootNode,u=new mu(1/e.x,1/e.y,1/e.z),c=[s],l;l=c.pop();)if(Au(t,u,l)){for(var h=l.startIndex,p=l.endIndex,v=void 0,m=void 0,A=void 0,y=t.x,f=t.y,g=t.z,b=e.x,w=e.y,E=e.z,x=void 0,M=void 0,C=void 0,I=void 0,P=void 0,S=void 0,F=void 0,k=void 0,O=void 0,L=void 0,N=void 0,V=void 0,j=void 0,z=void 0,U=void 0,X=void 0,G=void 0,K=void 0,Y=void 0,H=void 0,J=void 0,ne=void 0,$=void 0,te=void 0,ae=void 0,ce=void 0,oe=void 0;h<p;h++){if(v=o[h],m=v*3,A=a[m]*3,x=i[A],M=i[++A],C=i[++A],A=a[m+1]*3,I=i[A],P=i[++A],S=i[++A],A=a[m+2]*3,F=i[A],k=i[++A],O=i[++A],L=I-x,N=P-M,V=S-C,j=F-x,z=k-M,U=O-C,X=N*U-V*z,G=V*j-L*U,K=L*z-N*j,$=b*X+w*G+E*K,$>0)ne=1;else if($<0)ne=-1,$=-$;else continue;Y=y-x,H=f-M,J=g-C,te=ne*(b*(H*U-J*z)+w*(J*j-Y*U)+E*(Y*z-H*j)),!(te<0)&&(ae=ne*(b*(N*J-V*H)+w*(V*Y-L*J)+E*(L*H-N*Y)),!(ae<0)&&(te+ae>$||(ce=-ne*(Y*X+H*G+J*K),!(ce<0)&&(oe=ce/$,r.push(new gu([x,M,C,I,P,S,F,k,O],[y+b*oe,f+w*oe,g+E*oe],v))))))}l.node0&&c.push(l.node0),l.node1&&c.push(l.node1)}return r},n}();function Hi(n,t,e){return n<t?t:n>e?e:n}function Vo(n,t,e,r,i){if(e>=r)return[0,0,0,0,0,0];for(var a=1/0,o=1/0,s=1/0,u=-1/0,c=-1/0,l=-1/0,h=e,p=void 0,v=void 0;h<r;h++)p=n[h]*6,v=t[p],v<a&&(a=v),v=t[p+1],v<o&&(o=v),v=t[p+2],v<s&&(s=v),v=t[p+3],v>u&&(u=v),v=t[p+4],v>c&&(c=v),v=t[p+5],v>l&&(l=v);return[a-i,o-i,s-i,u+i,c+i,l+i]}var Uo=1e-6,Fc=function(){function n(t,e){if(this.positionArray=t,e)this.indicesArray=e;else{for(var r=t.length/3,i=new Uint32Array(r),a=0;a<r;a++)i[a]=a;this.indicesArray=i}}return n.prototype.createTree=function(t,e,r){var i=this.positionArray,a=this.indicesArray,o=a.length,s=new Uint32Array(o),u=[],c=0;if(r)for(var l=0;l<o;l+=1)s[l]=l;else{for(var h=a[0]*3,p=i[h],v=i[h+1],m=i[h+2],A=p,y=v,f=m,l=0,g=0,b=void 0,w=void 0,E=void 0;l<o;l+=1,g+=3)s[l]=l,h=a[g]*3,b=i[h],w=i[h+1],E=i[h+2],b<p?p=b:b>A&&(A=b),w<v?v=w:w>y&&(y=w),E<m?m=E:E>f&&(f=E);r=[p,v,m,A,y,f]}var x=new cn(r,0,o,0);u[c++]=x;function M(C){for(var I=C.startIndex,P=C.endIndex,S=C.extents,F=[S[3]-S[0],S[4]-S[1],S[5]-S[2]],k=[0,1,2].sort(function(K,Y){return F[Y]-F[K]})[0],O=(S[k]+S[k+3])/2,L=I,N=P-1,V=-1,j;L<=N;)V===-1?(j=s[L],i[a[j]*3+k]<O?L++:V=j):(j=s[N],i[a[j]*3+k]>=O||(s[L]=j,s[N]=V,V=-1,L++),N--);if(L>I){var z=S.slice();z[k+3]=O+Uo;var U=new cn(z,I,L,C.deepth+1);U.deepth<e&&U.endIndex-U.startIndex>t&&(u[c++]=U),C.node0=U}if(P>L){var X=S.slice();X[k]=O-Uo;var G=new cn(X,L,P,C.deepth+1);G.deepth<e&&G.endIndex-G.startIndex>t&&(u[c++]=G),C.node1=G}C.startIndex=0,C.endIndex=0}for(;c;)M(u[--c]);return this.offsetArray=s,this.rootNode=x,u.length=0,this},n.prototype.intersectRay=function(t,e,r,i){for(var a=this.positionArray,o=this.indicesArray,s=this.offsetArray,u=this.rootNode,c=r*r,l=new mu(1/e.x,1/e.y,1/e.z),h=[u],p;p=h.pop();)if(Au(t,l,p,r)){for(var v=p.startIndex,m=p.endIndex,A=void 0,y=void 0,f=void 0,g=void 0,b=void 0,w=void 0,E=void 0,x=void 0,M=void 0,C=void 0,I=void 0,P=void 0,S=void 0;v<m;v++)A=s[v],y=o[A]*3,f=a[y],g=a[++y],b=a[++y],w=t.x,E=t.y,x=t.z,M=e.x,C=e.y,I=e.z,P=M*(f-w)+C*(g-E)+I*(b-x),P>0&&(w+=M*P,E+=C*P,x+=I*P),M=f-w,C=g-E,I=b-x,P=M*M+C*C+I*I,P<=c&&i.push(new gu([f,g,b,f,g,b,f,g,b],[w,E,x],A));p.node0&&h.push(p.node0),p.node1&&h.push(p.node1)}return i},n}(),ai=new Map,ji=new Map,dn=new d.Ray,qo=new d.Matrix3,Rn=new d.Matrix4,yu=new d.Vector3,Oc=new d.Vector3,kc=new d.Vector3,Lc=new d.Triangle;function Dc(n,t,e,r){var i,a=n.matrixWorld;Rn.getInverse(a),dn.copy(e.ray).applyMatrix4(Rn);for(var o=t.intersectRay(dn.origin,dn.direction,[]),s=n.geometry,u=n.material,c=s.groups,l=s.index,h=0,p=o.length;h<p;h++){var v=o[h],m=v.triangle,A=v.index,y=v.intersectionPoint,f=new d.Vector3(y[0],y[1],y[2]).applyMatrix4(a),g=e.ray.origin.distanceTo(f);if(!(g<e.near||g>e.far)){var b=void 0;if(Array.isArray(u)){if(c)for(var w=A*3,E=0,x=c;E<x.length;E++){var M=x[E];if(w>=M.start&&w-M.start<M.count){b=u[(i=M.materialIndex)!==null&&i!==void 0?i:0];break}}}else b=u;if(b){var C=Lc.set(yu.set(m[0],m[1],m[2]).applyMatrix4(a),Oc.set(m[3],m[4],m[5]).applyMatrix4(a),kc.set(m[6],m[7],m[8]).applyMatrix4(a)).getNormal(new d.Vector3),I=A*3,P=new d.Face3(l?l.array[I]:I,l?l.array[I+1]:I+1,l?l.array[I+2]:I+2,C),S=e.ray.direction.dot(C);b.side===d.FrontSide&&S>=0||b.side===d.BackSide&&S<=0||r.push({distance:g,object:n,face:P,point:f,distanceToRay:0,faceIndex:A})}}}}function Nc(n,t,e,r){var i,a,o=n.matrixWorld;qo.getNormalMatrix(o),Rn.getInverse(o);var s=((a=(i=e.params.Points)===null||i===void 0?void 0:i.threshold)!==null&&a!==void 0?a:1)*Rn.getMaxScaleOnAxis();dn.copy(e.ray).applyMatrix4(Rn);for(var u=t.intersectRay(dn.origin,dn.direction,s,[]),c=n.geometry,l=c.index,h=c.getAttribute("normal"),p=0,v=u.length;p<v;p++){var m=u[p],A=m.triangle,y=m.index,f=m.intersectionPoint,g=new d.Vector3(f[0],f[1],f[2]).applyMatrix4(o),b=e.ray.origin.distanceTo(g);if(!(b<e.near||b>e.far)){var w=yu.set(A[0],A[1],A[2]).applyMatrix4(o),E=l?l.array[y]:y,x=void 0;h instanceof d.BufferAttribute&&(x=new d.Vector3().fromBufferAttribute(h,E).applyNormalMatrix(qo));var M=new d.Face3(E,E,E,x);r.push({distance:b,object:n,face:M,point:g,distanceToRay:g.distanceTo(w),index:y})}}}function Qc(n,t,e){var r;if(t===void 0&&(t=100),e===void 0&&(e=10),n.geometry instanceof d.BufferGeometry){var i=n.geometry.getAttribute("position");if(i instanceof d.BufferAttribute){var a=n.raycast,o=function(p,v){var m=ai.get(this);m?Dc(this,m,p,v):a.call(this,p,v)};n.raycast=o;var s=i.array,u=(r=n.geometry.getIndex())===null||r===void 0?void 0:r.array,c=n.geometry.boundingBox,l=c?[c.min.x,c.min.y,c.min.z,c.max.x,c.max.y,c.max.z]:void 0,h=new Rc(s,u);return h.createTree(t,e,l),ai.set(n,h),function(){ai.delete(n),n.raycast===o&&(n.raycast=a)}}}return function(){}}function Vc(n,t,e){var r;if(t===void 0&&(t=100),e===void 0&&(e=10),n.geometry instanceof d.BufferGeometry){var i=n.geometry.getAttribute("position");if(i instanceof d.BufferAttribute){var a=n.raycast,o=function(p,v){var m=ji.get(this);m?Nc(this,m,p,v):a.call(this,p,v)};n.raycast=o;var s=i.array,u=(r=n.geometry.getIndex())===null||r===void 0?void 0:r.array,c=n.geometry.boundingBox,l=c?[c.min.x,c.min.y,c.min.z,c.max.x,c.max.y,c.max.z]:void 0,h=new Fc(s,u);return h.createTree(t,e,l),ji.set(n,h),function(){ji.delete(n),n.raycast===o&&(n.raycast=a)}}}return function(){}}function Uc(n,t,e){t===void 0&&(t=100),e===void 0&&(e=10);var r=[];return n.traverse(function(i){if(i instanceof d.Mesh){var a=Qc(i,t,e);r.push(a)}else if(i instanceof d.Points){var a=Vc(i,t,e);r.push(a)}}),function(){for(var i=0,a=r;i<a.length;i++){var o=a[i];o()}}}var qc=new d.Vector3,zc=new d.Vector3,Hc=new d.Vector3,bu=function(n){de(t,n);function t(e,r){var i=n.call(this)||this;i.renderOrder=-4;var a=Uc(e,200,10);return i.disposers=[r,a],i.add(e),i}return t.prototype.intersectRaycaster=function(e,r,i){var a=this;r===void 0&&(r=!0),i===void 0&&(i=[]);for(var o=this.children.slice(),s;s=o.pop();)if(s.visible){s.raycast(e,i);for(var u=0,c=s.children.length;u<c;u++)o.push(s.children[u])}return i.forEach(function(l){var h,p,v=0;if((l.object instanceof _t||l.object instanceof Lr)&&l.face){var m=Array.isArray(l.object.material)?l.object.material[l.face.materialIndex]:l.object.material;if(m)if(m.defines.USE_VERTEX_FLOOR){var A=(h=l.object.geometry.attributes.position)===null||h===void 0?void 0:h.array,y=(p=l.object.geometry.attributes.floor)===null||p===void 0?void 0:p.array;if(A&&y){var f=qc.set(A[l.face.a*3],A[l.face.a*3+1],A[l.face.a*3+2]).applyMatrix4(a.matrixWorld),g=zc.set(A[l.face.b*3],A[l.face.b*3+1],A[l.face.b*3+2]).applyMatrix4(a.matrixWorld),b=Hc.set(A[l.face.c*3],A[l.face.c*3+1],A[l.face.c*3+2]).applyMatrix4(a.matrixWorld),w=l.point.distanceTo(f),E=l.point.distanceTo(g),x=l.point.distanceTo(b);v=Math.round((w*y[l.face.a]+E*y[l.face.b]+x*y[l.face.c])/(w+E+x))}}else v=m.floor}l.floor=v}),r&&i.sort(function(l,h){return l.distance-h.distance}),i},t.prototype.dispose=function(){for(var e=0,r=this.disposers;e<r.length;e++){var i=r[e];i()}},t}(d.Group);function It(){for(var n=[],t=0;t<arguments.length;t++)n[t]=arguments[t];var e=[];n=n.map(function(s){return(s??"").trim()}).filter(function(s){return s.length>0&&!/^\/+$/.test(s)});for(var r=0;r<n.length;r++){var i=r===0,a=r===n.length-1,o=n[r];i||(o=o.replace(/^\.\//,"").replace(/^\/+/,"")),a||(o=o.replace(/\/+$/,"")),e.push(o)}return e.join("/")}function yr(n){return n.indexOf("//")===0||/^[0-9a-z]+\:/i.test(n)}function wu(n,t){if(n.content&&n.content.uri&&(yr(n.content.uri)||(n.content.uri=It(t,n.content.uri))),n.children)for(var e=0,r=n.children;e<r.length;e++){var i=r[e];wu(i,t)}return n}function zo(n,t){return n.asset.overview&&(yr(n.asset.overview.imageFile)||(n.asset.overview.imageFile=It(t,n.asset.overview.imageFile)),yr(n.asset.overview.worldFile)||(n.asset.overview.worldFile=It(t,n.asset.overview.worldFile))),wu(n.root,t),n}function Eu(n,t){return(t[0]==="?"||t[0]==="&")&&(t=t.slice(1)),t?((n[n.length-1]==="?"||n[n.length-1]==="&")&&(n=n.slice(0,-1)),n.indexOf("?")>=0?"".concat(n,"&").concat(t):"".concat(n,"?").concat(t)):n}var _i=4;function xu(n,t,e){var r=new DataView(t);if(n.magic=r.getUint32(e,!0),e+=_i,n.version=r.getUint32(e,!0),e+=_i,n.byteLength=r.getUint32(e,!0),e+=_i,n.version!==1)throw new Error("3D Tile Version ".concat(n.version," not supported"));return e}var nr,xe;(function(n){n[n.BYTE=5120]="BYTE",n[n.UNSIGNED_BYTE=5121]="UNSIGNED_BYTE",n[n.SHORT=5122]="SHORT",n[n.UNSIGNED_SHORT=5123]="UNSIGNED_SHORT",n[n.INT=5124]="INT",n[n.UNSIGNED_INT=5125]="UNSIGNED_INT",n[n.FLOAT=5126]="FLOAT",n[n.DOUBLE=5130]="DOUBLE"})(xe||(xe={}));var jc=(nr={},nr[xe.DOUBLE]=Float64Array,nr[xe.FLOAT]=Float32Array,nr[xe.UNSIGNED_SHORT]=Uint16Array,nr[xe.UNSIGNED_INT]=Uint32Array,nr[xe.UNSIGNED_BYTE]=Uint8Array,nr[xe.BYTE]=Int8Array,nr[xe.SHORT]=Int16Array,nr[xe.INT]=Int32Array,nr),_c={DOUBLE:xe.DOUBLE,FLOAT:xe.FLOAT,UNSIGNED_SHORT:xe.UNSIGNED_SHORT,UNSIGNED_INT:xe.UNSIGNED_INT,UNSIGNED_BYTE:xe.UNSIGNED_BYTE,BYTE:xe.BYTE,SHORT:xe.SHORT,INT:xe.INT};function pi(n){var t=jc[n];if(!t)throw new Error("Failed to convert GL type");return t}function Gi(n){var t=pi(n);return t.BYTES_PER_ELEMENT}function Ho(n,t,e,r){e===void 0&&(e=0);var i=pi(n);if(e%Gi(n)!==0){var a=r?t.slice(e,e+r*Gi(n)):t.slice(e);return new i(a)}else return new i(t,e,r??(t.byteLength-e)/Gi(n))}function Gc(n){var t=_c[n];if(!t)throw new Error("Failed to convert GL type");return t}var Mu=function(){function n(t,e){this.featuresLength=0,this.cachedTypedArrays={},this.json=t,this.buffer=e;var r=this.getGlobalProperty("POINTS_LENGTH",xe.UNSIGNED_INT,1);r&&r.length&&(this.featuresLength=r[0])}return n.prototype.getExtension=function(t){return this.json.extensions&&this.json.extensions[t]},n.prototype.hasProperty=function(t){return!!this.json[t]},n.prototype.getGlobalProperty=function(t,e,r){var i=this.json[t];if(typeof i=="number"){var a=pi(e);return new a([i])}else if(Array.isArray(i)){var a=pi(e);return new a(i)}else if(i&&Number.isFinite(i.byteOffset))return this.getTypedArrayFromBinary(t,e,r,1,i.byteOffset);return null},n.prototype.getPropertyArray=function(t,e,r){var i=this.json[t];return i&&Number.isFinite(i.byteOffset)?("componentType"in i&&(e=Gc(i.componentType)),this.getTypedArrayFromBinary(t,e,r,this.featuresLength,i.byteOffset)):this.getTypedArrayFromArray(t,e,i)},n.prototype.getProperty=function(t,e,r,i,a){var o=this.json[t];if(!o)return null;var s=this.getPropertyArray(t,e,r);if(r===1)return a[0]=s[i],a;for(var u=0;u<r;++u)a[u]=s[r*i+u];return a},n.prototype.getTypedArrayFromBinary=function(t,e,r,i,a){var o=this.cachedTypedArrays,s=o[t];return s||(s=Ho(e,this.buffer.buffer,this.buffer.byteOffset+a,i*r),o[t]=s),s},n.prototype.getTypedArrayFromArray=function(t,e,r){var i=this.cachedTypedArrays,a=i[t];return a||(a=Ho(e,r),i[t]=a),a},n}(),tn=4,jo="b3dm tile in legacy format.";function Cu(n,t,e){var r=new TextDecoder("utf8"),i=new Uint8Array(n,t,e),a=r.decode(i);return a}function Iu(n,t,e){return e=Kc(n,t,e),e=Wc(n,t,e),e=Xc(n,t,e),e}function Kc(n,t,e){var r=new DataView(t),i=0;n.header=n.header||{};var a=r.getUint32(e,!0);e+=tn;var o=r.getUint32(e,!0);e+=tn;var s=r.getUint32(e,!0);e+=tn;var u=r.getUint32(e,!0);return e+=tn,s>=570425344?(e-=tn*2,i=a,s=o,u=0,a=0,o=0,console.warn(jo)):u>=570425344&&(e-=tn,i=s,s=a,u=o,a=0,o=0,console.warn(jo)),n.header.featureTableJsonByteLength=a,n.header.featureTableBinaryByteLength=o,n.header.batchTableJsonByteLength=s,n.header.batchTableBinaryByteLength=u,n.header.batchLength=i,e}function Wc(n,t,e){var r=n.header||{},i=r.featureTableJsonByteLength,a=r.featureTableBinaryByteLength,o=r.batchLength;if(n.featureTableJson={BATCH_LENGTH:o||0},i&&i>0){var s=Cu(t,e,i);n.featureTableJson=JSON.parse(s)}e+=i||0,n.featureTableBinary=new Uint8Array(t,e,a),e+=a||0,n.rtcCenter=new d.Vector3;var u=new Mu(n.featureTableJson,n.featureTableBinary);if(Array.isArray(u.json.RTC_CENTER))n.rtcCenter.fromArray(u.json.RTC_CENTER);else{var c=u.getGlobalProperty("RTC_CENTER",xe.FLOAT,3);c&&n.rtcCenter.fromArray(c)}return e}function Xc(n,t,e){var r=n.header||{},i=r.batchTableJsonByteLength,a=r.batchTableBinaryByteLength;if(i&&i>0){var o=Cu(t,e,i);n.batchTableJson=JSON.parse(o),e+=i,a&&a>0&&(n.batchTableBinary=new Uint8Array(t,e,a),n.batchTableBinary=new Uint8Array(n.batchTableBinary),e+=a)}return e}function Yc(n,t,e){var r=e!==void 0?new Uint8Array(n).subarray(t,t+e):new Uint8Array(n).subarray(t),i=new Uint8Array(r);return i.buffer}function Jc(n,t,e){var r=n.byteLength-e;if(r===0)throw new Error("glTF byte length must be greater than 0.");return e%4!==0&&console.warn("".concat(n.type,": embedded glb is not aligned to a 4-byte boundary.")),n.gltfArrayBuffer=Yc(t,e,r),n.byteLength}function Ea(n){if(typeof TextDecoder<"u")return new TextDecoder().decode(n);for(var t="",e=0,r=n.length;e<r;e++)t+=String.fromCharCode(n[e]);try{return decodeURIComponent(escape(t))}catch{return t}}var Re={FLOAT:5126,FLOAT_MAT3:35675,FLOAT_MAT4:35676,FLOAT_VEC2:35664,FLOAT_VEC3:35665,FLOAT_VEC4:35666,LINEAR:9729,REPEAT:10497,SAMPLER_2D:35678,POINTS:0,LINES:1,LINE_LOOP:2,LINE_STRIP:3,TRIANGLES:4,TRIANGLE_STRIP:5,TRIANGLE_FAN:6,UNSIGNED_BYTE:5121,UNSIGNED_SHORT:5123},wn={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array},vi={9728:d.NearestFilter,9729:d.LinearFilter,9984:d.NearestMipmapNearestFilter,9985:d.LinearMipmapNearestFilter,9986:d.NearestMipmapLinearFilter,9987:d.LinearMipmapLinearFilter},Ai={33071:d.ClampToEdgeWrapping,33648:d.MirroredRepeatWrapping,10497:d.RepeatWrapping},_o={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},Rt={POSITION:"position",NORMAL:"normal",TANGENT:"tangent",TEXCOORD_0:"uv",TEXCOORD_1:"uv2",COLOR_0:"color",WEIGHTS_0:"skinWeight",JOINTS_0:"skinIndex"},Sr={scale:"scale",translation:"position",rotation:"quaternion",weights:"morphTargetInfluences"},Zc={CUBICSPLINE:void 0,LINEAR:d.InterpolateLinear,STEP:d.InterpolateDiscrete},pr={OPAQUE:"OPAQUE",MASK:"MASK",BLEND:"BLEND"};function yt(n){var t=[];for(var e in n)t.push(n[e]);return t}var $c=function(){function n(t,e,r){this.json=t,this.extensions=e,this.options=r,this.cache=new Map,this.disposeSet=new Set,this.nodeNamesUsed={}}return n.prototype.dispose=function(){this.cache.clear(),this.disposeSet.forEach(function(t){t.dispose()}),this.disposeSet.clear()},n.prototype.markDefs=function(){for(var t=this.json.nodes||[],e=this.json.skins||[],r=this.json.meshes||[],i=0,a=e.length;i<a;i++)for(var o=e[i].joints,s=0,u=o.length;s<u;s++)t[o[s]].isBone=!0;for(var c=0,l=t.length;c<l;c++){var h=t[c];h.mesh!==void 0&&h.skin!==void 0&&(r[h.mesh].isSkinnedMesh=!0)}},n.prototype.parse=function(){var t=this,e=this.json,r=this.extensions;this.dispose(),this.markDefs();for(var i=0,a=yt(r);i<a.length;i++){var o=a[i];o.markDefs(this)}return Promise.all(yt(r).map(function(s){return s.prepare(t)})).then(function(){var s,u,c;return Promise.all([Promise.all(((s=e.scenes)!==null&&s!==void 0?s:[]).map(function(l,h){return t.loadScene(h)})),Promise.all(((u=e.animations)!==null&&u!==void 0?u:[]).map(function(l,h){return t.loadAnimation(h)})),Promise.all(((c=e.cameras)!==null&&c!==void 0?c:[]).map(function(l,h){return t.loadCamera(h)}))])}).then(function(s){var u=s[0],c=s[1],l=s[2],h={json:t.json,scene:u[e.scene||0],scenes:u,animations:c,cameras:l,dispose:function(){return t.dispose()}};return Promise.all(yt(r).map(function(p){return p.emitResult(h,t)})).then(function(){return h})})},n.prototype.loadCamera=function(t){var e="camera:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,a=0,o=yt(this.extensions);a<o.length;a++){var s=o[a];if(i=s.loadCamera(t,this),i)break}if(!i){var u=void 0,c=this.json.cameras[t],l=c[c.type];l?c.type==="perspective"?u=new d.PerspectiveCamera(d.MathUtils.radToDeg(l.yfov),l.aspectRatio||1,l.znear||1,l.zfar||2e6):c.type==="orthographic"?u=new d.OrthographicCamera(-l.xmag,l.xmag,l.ymag,-l.ymag,l.znear,l.zfar):(console.warn("glTF: Invalid camera type ".concat(c.type,".")),u=new d.Camera):(console.warn("glTF: Missing camera parameters."),u=new d.Camera),c.name&&(u.name=this.createUniqueName(c.name)),i=Promise.resolve(u)}return this.cache.set(e,i),i},n.prototype.loadSkin=function(t){var e="animation:"+t,r=this.cache.get(e);if(r)return r;var i,a=this.json.skins[t],o={joints:a.joints};return a.inverseBindMatrices===void 0?i=Promise.resolve(o):i=this.loadAccessor(a.inverseBindMatrices).then(function(s){return s&&(o.inverseBindMatrices=s),o}),this.cache.set(e,i),i},n.prototype.loadAnimation=function(t){var e="animation:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,a=0,o=yt(this.extensions);a<o.length;a++){var s=o[a];if(i=s.loadAnimation(t,this),i)break}if(!i){for(var u=this.json,c=u.animations[t],l=[],h=[],p=[],v=[],m=[],A=0,y=c.channels.length;A<y;A++){var f=c.channels[A],g=c.samplers[f.sampler],b=f.target,w=b.node!==void 0?b.node:b.id,E=c.parameters!==void 0?c.parameters[g.input]:g.input,x=c.parameters!==void 0?c.parameters[g.output]:g.output;l.push(this.loadNode(w)),h.push(this.loadAccessor(E)),p.push(this.loadAccessor(x)),v.push(g),m.push(b)}i=Promise.all([Promise.all(l),Promise.all(h),Promise.all(p),Promise.all(v),Promise.all(m)]).then(function(M){for(var C=M[0],I=M[1],P=M[2],S=M[3],F=M[4],k=[],O=function(j,z){var U=C[j],X=I[j],G=P[j],K=S[j],Y=F[j];if(U===void 0)return"continue";U.updateMatrix(),U.matrixAutoUpdate=!0;var H=void 0;switch(Sr[Y.path]){case Sr.weights:H=d.NumberKeyframeTrack;break;case Sr.rotation:H=d.QuaternionKeyframeTrack;break;case Sr.position:case Sr.scale:default:H=d.VectorKeyframeTrack;break}var J=U.name?U.name:U.uuid,ne=K.interpolation!==void 0?Zc[K.interpolation]:d.InterpolateLinear,$=[];Sr[Y.path]===Sr.weights?U.traverse(function(Ae){Ae.morphTargetInfluences&&$.push(Ae.name?Ae.name:Ae.uuid)}):$.push(J);var te=G.array;if(G.normalized){for(var ae=Ki(te.constructor),ce=new Float32Array(te.length),oe=0,fe=te.length;oe<fe;oe++)ce[oe]=te[oe]*ae;te=ce}for(var oe=0,fe=$.length;oe<fe;oe++){var Ie=new H($[oe]+"."+Sr[Y.path],X.array,te,ne);k.push(Ie)}},L=0,N=C.length;L<N;L++)O(L);var V=c.name?c.name:"animation_"+t;return new d.AnimationClip(V,void 0,k)})}return this.cache.set(e,i),i},n.prototype.loadBuffer=function(t){var e=this.json.buffers[t];if(e.type&&e.type!=="arraybuffer")throw new Error("glTF: "+e.type+" buffer type is not supported.");var r="buffer:"+t,i=this.cache.get(r);if(i)return i;for(var a=null,o=0,s=yt(this.extensions);o<s.length;o++){var u=s[o];if(a=u.loadBuffer(t,this),a)break}if(!a){var c=this.json.buffers[t];a=this.options.fetcher.ajax(this.resolveResouce(c.uri),{responseType:"arraybuffer"}).then(function(l){return l.body})}return this.cache.set(r,a),a},n.prototype.loadBufferView=function(t){var e="bufferView:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,a=0,o=yt(this.extensions);a<o.length;a++){var s=o[a];if(i=s.loadBufferView(t,this),i)break}if(!i){var u=this.json.bufferViews[t];i=this.loadBuffer(u.buffer).then(function(c){var l=u.byteLength||0,h=u.byteOffset||0;return c.slice(h,h+l)})}return this.cache.set(e,i),i},n.prototype.loadAccessor=function(t){var e=this,r="accessor:"+t,i=this.cache.get(r);if(i)return i;var a=null;if(!a){var o=this.json.accessors[t];if(o.bufferView===void 0&&o.sparse===void 0)a=Promise.resolve(null);else{var s=[];o.bufferView!==void 0?s.push(this.loadBufferView(o.bufferView)):s.push(Promise.resolve(null)),o.sparse!==void 0&&(s.push(this.loadBufferView(o.sparse.indices.bufferView)),s.push(this.loadBufferView(o.sparse.values.bufferView))),a=Promise.all(s).then(function(u){var c=u[0],l=_o[o.type],h=wn[o.componentType],p=h.BYTES_PER_ELEMENT,v=p*l,m=o.byteOffset||0,A=o.bufferView!==void 0?e.json.bufferViews[o.bufferView].byteStride:void 0,y=o.normalized===!0,f,g;if(A&&A!==v){var b=Math.floor(m/A),w="InterleavedBuffer:"+o.bufferView+":"+o.componentType+":"+b+":"+o.count,E=e.cache.get(w);E||(f=new h(c,b*A,o.count*A/p),E=new d.InterleavedBuffer(f,A/p),e.cache.set(w,E)),g=new d.InterleavedBufferAttribute(E,l,m%A/p,y)}else c===null?f=new h(o.count*l):f=new h(c,m,o.count*l),g=new d.BufferAttribute(f,l,y);if(o.sparse!==void 0){var x=_o.SCALAR,M=wn[o.sparse.indices.componentType],C=o.sparse.indices.byteOffset||0,I=o.sparse.values.byteOffset||0,P=new M(u[1],C,o.sparse.count*x),S=new h(u[2],I,o.sparse.count*l);c!==null&&(g=new d.BufferAttribute(g.array.slice(),g.itemSize,g.normalized));for(var F=0,k=P.length;F<k;F++){var O=P[F];if(g.setX(O,S[F*l]),l>=2&&g.setY(O,S[F*l+1]),l>=3&&g.setZ(O,S[F*l+2]),l>=4&&g.setW(O,S[F*l+3]),l>=5)throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.")}}return g})}}return this.cache.set(r,a),a},n.prototype.createPrimitiveKey=function(t){for(var e=0,r=yt(this.extensions);e<r.length;e++){var i=r[e],a=i.createPrimitiveKey(t,this);if(a)return a}for(var o="",s=Object.keys(t.attributes).sort(),u=0,c=s.length;u<c;u++)o+=s[u]+":"+t.attributes[s[u]]+";";return t.indices+":"+o+":"+t.mode},n.prototype.loadGeometry=function(t){var e=this,r="geometry:"+this.createPrimitiveKey(t),i=this.cache.get(r);if(i)return i;for(var a=null,o=0,s=yt(this.extensions);o<s.length;o++){var u=s[o];if(a=u.loadGeometry(t,this),a)break}return a||(a=this.addGeometryPrimitiveAttributes(new d.BufferGeometry,t)),a=a.then(function(c){return e.disposeSet.add(c),c}),this.cache.set(r,a),a},n.prototype.loadImage=function(t){var e="image:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,a=0,o=yt(this.extensions);a<o.length;a++){var s=o[a];if(i=s.loadImage(t,this),i)break}if(!i){var u=this.json.images[t];if(u.bufferView)i=this.loadBufferView(u.bufferView).then(function(l){var h=new Blob([l],{type:u.mimeType});return lu(h)});else if(u.uri){var c=this.resolveResouce(u.uri);i=this.options.fetcher.loadImage(c,{},void 0,void 0,void 0,fi()).then(function(l){return l.body})}else throw new Error("glTF: Invalid image defs.")}return this.cache.set(e,i),i},n.prototype.loadMaterialAsMeshStandardMaterial=function(t){var e=this,r=[],i=new d.MeshStandardMaterial;if(i.color=new d.Color(1,1,1),i.opacity=1,Object.keys(t.attributes).filter(function(l){return Rt[l]==="color"}).length>0&&(i.vertexColors=!0),Object.keys(t.attributes).filter(function(l){return Rt[l]==="normal"}).length===0&&(i.flatShading=!0),Object.keys(t.attributes).filter(function(l){return Rt[l]==="tangent"}).length===0&&(i.normalScale&&(i.normalScale.y*=-1),i.clearcoatNormalScale&&(i.clearcoatNormalScale.y*=-1)),t.material!==void 0){var a=this.json.materials[t.material];a.name&&(i.name=a.name);var o=a.pbrMetallicRoughness||{};if(Array.isArray(o.baseColorFactor)){var s=o.baseColorFactor;i.color.fromArray(s),i.opacity=s[3]}o.baseColorTexture!==void 0&&r.push(this.createMaterialTexture(o.baseColorTexture).then(function(l){l.encoding=d.sRGBEncoding,i.map=l,e.disposeSet.add(l)})),i.metalness=o.metallicFactor!==void 0?o.metallicFactor:1,i.roughness=o.roughnessFactor!==void 0?o.roughnessFactor:1,o.metallicRoughnessTexture!==void 0&&r.push(this.createMaterialTexture(o.metallicRoughnessTexture).then(function(l){l.encoding=d.sRGBEncoding,i.metalnessMap=l,i.roughnessMap=l,e.disposeSet.add(l)})),a.doubleSided===!0&&(i.side=d.DoubleSide);var u=a.alphaMode||pr.OPAQUE;if(u===pr.BLEND?(i.transparent=!0,i.depthWrite=!1):(i.transparent=!1,u===pr.MASK&&(i.alphaTest=a.alphaCutoff!==void 0?a.alphaCutoff:.5)),a.normalTexture!==void 0&&(r.push(this.createMaterialTexture(a.normalTexture).then(function(l){i.normalMap=l,e.disposeSet.add(l)})),i.normalScale=new d.Vector2(1,1),a.normalTexture.scale!==void 0)){var c=a.normalTexture.scale;i.normalScale.set(c,c)}a.occlusionTexture!==void 0&&(r.push(this.createMaterialTexture(a.occlusionTexture).then(function(l){i.aoMap=l,e.disposeSet.add(l)})),a.occlusionTexture.strength!==void 0&&(i.aoMapIntensity=a.occlusionTexture.strength)),a.emissiveFactor!==void 0&&(i.emissive=new d.Color().fromArray(a.emissiveFactor)),a.emissiveTexture!==void 0&&r.push(this.createMaterialTexture(a.emissiveTexture).then(function(l){i.emissiveMap=l,e.disposeSet.add(l)}))}return this.disposeSet.add(i),Promise.all(r).then(function(){return i})},n.prototype.loadMaterialAsLineBasicMaterial=function(t){var e=[],r=new d.LineBasicMaterial;if(r.color=new d.Color(1,1,1),r.opacity=1,Object.keys(t.attributes).filter(function(u){return Rt[u]==="color"}).length>0&&(r.vertexColors=!0),Object.keys(t.attributes).filter(function(u){return Rt[u]==="tangent"}).length===0&&(r.normalScale&&(r.normalScale.y*=-1),r.clearcoatNormalScale&&(r.clearcoatNormalScale.y*=-1)),t.material!==void 0){var i=this.json.materials[t.material];i.name&&(r.name=i.name);var a=i.pbrMetallicRoughness||{};if(Array.isArray(a.baseColorFactor)){var o=a.baseColorFactor;r.color.fromArray(o),r.opacity=o[3]}i.doubleSided===!0&&(r.side=d.DoubleSide);var s=i.alphaMode||pr.OPAQUE;s===pr.BLEND?(r.transparent=!0,r.depthWrite=!1):(r.transparent=!1,s===pr.MASK&&(r.alphaTest=i.alphaCutoff!==void 0?i.alphaCutoff:.5))}return this.disposeSet.add(r),Promise.all(e).then(function(){return r})},n.prototype.loadMaterialAsPointsMaterial=function(t){var e=this,r=[],i=new d.PointsMaterial;if(i.color=new d.Color(1,1,1),i.opacity=1,i.sizeAttenuation=!1,Object.keys(t.attributes).filter(function(c){return Rt[c]==="color"}).length>0&&(i.vertexColors=!0),Object.keys(t.attributes).filter(function(c){return Rt[c]==="tangent"}).length===0&&(i.normalScale&&(i.normalScale.y*=-1),i.clearcoatNormalScale&&(i.clearcoatNormalScale.y*=-1)),t.material!==void 0){var a=this.json.materials[t.material];a.name&&(i.name=a.name);var o=a.pbrMetallicRoughness||{};if(Array.isArray(o.baseColorFactor)){var s=o.baseColorFactor;i.color.fromArray(s),i.opacity=s[3]}o.baseColorTexture!==void 0&&r.push(this.createMaterialTexture(o.baseColorTexture).then(function(c){c.encoding=d.sRGBEncoding,i.map=c,e.disposeSet.add(c)})),a.doubleSided===!0&&(i.side=d.DoubleSide);var u=a.alphaMode||pr.OPAQUE;u===pr.BLEND?(i.transparent=!0,i.depthWrite=!1):(i.transparent=!1,u===pr.MASK&&(i.alphaTest=a.alphaCutoff!==void 0?a.alphaCutoff:.5))}return this.disposeSet.add(i),Promise.all(r).then(function(){return i})},n.prototype.loadMaterial=function(t){var e=this,r,i=(r=t.mode)!==null&&r!==void 0?r:Re.TRIANGLES,a="material:"+this.createPrimitiveKey(t),o=this.cache.get(a);if(o)return o;for(var s=null,u=0,c=yt(this.extensions);u<c.length;u++){var l=c[u];if(s=l.loadMaterial(t,this),s)break}if(i===Re.TRIANGLES||i===Re.TRIANGLE_STRIP||i===Re.TRIANGLE_FAN)s=this.loadMaterialAsMeshStandardMaterial(t);else if(i===Re.LINES||i===Re.LINE_STRIP||i===Re.LINE_LOOP)s=this.loadMaterialAsLineBasicMaterial(t);else if(i===Re.POINTS)s=this.loadMaterialAsPointsMaterial(t);else throw new Error("glTF: Primitive mode unsupported: "+i);return s=s.then(function(h){return e.disposeSet.add(h),h}),this.cache.set(a,s),s},n.prototype.loadTexture=function(t){var e=this,r="texture:"+t,i=this.cache.get(r);if(i)return i;for(var a=null,o=0,s=yt(this.extensions);o<s.length;o++){var u=s[o];if(a=u.loadTexture(t,this),a)break}if(!a){var c=this.json.textures[t];a=this.loadImage(c.source).then(function(l){var h=new d.Texture(l);h.needsUpdate=!0,h.flipY=!1,c.name&&(h.name=c.name);var p=e.json.samplers||{},v=p[c.sampler]||{};h.magFilter=vi[v.magFilter]||d.LinearFilter,h.minFilter=vi[v.minFilter]||d.LinearMipmapLinearFilter,h.wrapS=Ai[v.wrapS]||d.RepeatWrapping,h.wrapT=Ai[v.wrapT]||d.RepeatWrapping;var m=h.dispose;return h.dispose=function(){return h.dispose=m,l.close(),m.call(this)},h})}return a=a.then(function(l){return e.disposeSet.add(l),l}),this.cache.set(r,a),a},n.prototype.loadMesh=function(t){for(var e=this,r=null,i=0,a=yt(this.extensions);i<a.length;i++){var o=a[i];if(r=o.loadMesh(t,this),r)break}if(!r){var s=this.json.meshes[t],u=s.primitives,c=Promise.all(u.map(function(h){return e.loadGeometry(h)})),l=Promise.all(u.map(function(h){return e.loadMaterial(h)}));r=Promise.all([c,l]).then(function(h){for(var p=h[0],v=h[1],m=[],A=0;A<u.length;A++){var y=u[A],f=p[A],g=v[A],b=y.mode||Re.TRIANGLES,w=void 0;if(b===Re.TRIANGLES||b===Re.TRIANGLE_STRIP||b===Re.TRIANGLE_FAN)if(b===Re.TRIANGLE_STRIP?f=e.toGeometryTrianglesDrawMode(f,d.TriangleStripDrawMode):b===Re.TRIANGLE_FAN&&(f=e.toGeometryTrianglesDrawMode(f,d.TriangleFanDrawMode)),s.isSkinnedMesh){var E=new d.SkinnedMesh(f,g);f.attributes.skinWeight.normalized||E.normalizeSkinWeights(),w=E}else w=new d.Mesh(f,g);else if(b===Re.POINTS)w=new d.Points(f,g);else if(b===Re.LINES)w=new d.LineSegments(f,g);else if(b===Re.LINE_STRIP)w=new d.Line(f,g);else if(b===Re.LINE_LOOP)w=new d.LineLoop(f,g);else throw new Error("glTF: Primitive mode unsupported: "+b);if(Object.keys(f.morphAttributes).length>0){if(s.weights!==void 0)for(var x=0,M=s.weights.length;x<M;x++)w.morphTargetInfluences[x]=s.weights[x];if(s.extras&&Array.isArray(s.extras.targetNames)){var C=s.extras.targetNames;if(w.morphTargetInfluences.length===C.length){w.morphTargetDictionary={};for(var x=0,M=C.length;x<M;x++)w.morphTargetDictionary[C[x]]=x}else console.warn("glTF: Invalid extras.targetNames length. Ignoring names.")}}w.name=e.createUniqueName(s.name||"mesh_"+t),m.push(w)}if(m.length===1)return m[0];for(var I=new d.Group,P=0,S=m;P<S.length;P++){var w=S[P];I.add(w)}return I})}return r},n.prototype.loadNodeAttachments=function(t){for(var e=[],r=0,i=yt(this.extensions);r<i.length;r++){var a=i[r],o=a.loadNodeAttachments(t,this);o&&e.push(o)}return e},n.prototype.loadNode=function(t){var e="node:"+t,r=this.cache.get(e);if(r)return r;var i=this.json,a=i.nodes[t],o=a.name?this.createUniqueName(a.name):"",s=[];a.mesh!==void 0&&s.push(this.loadMesh(a.mesh).then(function(p){if(a.weights!==void 0){var v=a.weights;p.traverse(function(m){if(m instanceof d.Mesh||m instanceof d.Line||m instanceof d.Points)for(var A=0,y=v.length;A<y;A++)m.morphTargetInfluences[A]=v[A]})}return p})),a.camera!==void 0&&s.push(this.loadCamera(a.camera));for(var u=this.loadNodeAttachments(t),c=0,l=u;c<l.length;c++){var h=l[c];s.push(h)}return Promise.all(s).then(function(p){var v;if(a.isBone===!0?v=new d.Bone:p.length>1?v=new d.Group:p.length===1?v=p[0]:v=new d.Object3D,v!==p[0])for(var m=0,A=p.length;m<A;m++)v.add(p[m]);if(a.name&&(v.name=o),a.matrix!==void 0){var y=new d.Matrix4;y.fromArray(a.matrix),v.applyMatrix4(y)}else a.translation!==void 0&&v.position.fromArray(a.translation),a.rotation!==void 0&&v.quaternion.fromArray(a.rotation),a.scale!==void 0&&v.scale.fromArray(a.scale);return v})},n.prototype.loadScene=function(t){var e=this.json,r=e.scenes[t],i=new d.Group;r.name&&(i.name=this.createUniqueName(r.name));for(var a=r.nodes||[],o=[],s=0,u=a.length;s<u;s++)o.push(this.buildNodeHierarchy(a[s],i));return Promise.all(o).then(function(){return i})},n.prototype.createMaterialTexture=function(t){var e=this;return this.loadTexture(t.index).then(function(r){for(var i=0,a=yt(e.extensions);i<a.length;i++){var o=a[i],s=o.extendTexture(r,t,e);s&&(r=s)}return r})},n.prototype.addGeometryPrimitiveAttributes=function(t,e){var r=this,i=e.attributes,a=[],o=function(E){var x=Rt[E]||E.toLowerCase();if(x in t.attributes)return"continue";a.push(s.loadAccessor(i[E]).then(function(M){M&&t.setAttribute(x,M)}))},s=this;for(var u in i)o(u);e.indices!==void 0&&!t.index&&a.push(this.loadAccessor(e.indices).then(function(E){E&&t.setIndex(E)}));var c=new d.Box3;if(i.POSITION!==void 0){var l=this.json.accessors[i.POSITION],h=l.min,p=l.max;if(h!==void 0&&p!==void 0){if(c.set(new d.Vector3(h[0],h[1],h[2]),new d.Vector3(p[0],p[1],p[2])),l.normalized){var v=Ki(wn[l.componentType]);c.min.multiplyScalar(v),c.max.multiplyScalar(v)}}else console.warn("glTF: Missing min/max properties for accessor POSITION.")}var m=e.targets;if(m!==void 0){for(var A=new d.Vector3,y=new d.Vector3,f=0,g=m.length;f<g;f++){var b=m[f];if(b.POSITION!==void 0){var l=this.json.accessors[b.POSITION],h=l.min,p=l.max;if(h!==void 0&&p!==void 0){if(y.setX(Math.max(Math.abs(h[0]),Math.abs(p[0]))),y.setY(Math.max(Math.abs(h[1]),Math.abs(p[1]))),y.setZ(Math.max(Math.abs(h[2]),Math.abs(p[2]))),l.normalized){var v=Ki(wn[l.componentType]);y.multiplyScalar(v)}A.max(y)}else console.warn("glTF: Missing min/max properties for accessor POSITION.")}}c.expandByVector(A)}t.boundingBox=c;var w=new d.Sphere;return c.getCenter(w.center),w.radius=c.min.distanceTo(c.max)/2,t.boundingSphere=w,Promise.all(a).then(function(){if(t.attributes.uv&&!t.attributes.uv2&&r.options.copyUV2&&t.setAttribute("uv2",t.attributes.uv),e.targets){for(var E=!1,x=!1,M=0,C=e.targets.length;M<C;M++){var I=e.targets[M];if(I.POSITION!==void 0&&(E=!0),I.NORMAL!==void 0&&(x=!0),E&&x)break}if(!E&&!x)return t;var P=[];t.morphTargetsRelative=!0;for(var S=function(F,k){var O=e.targets[F];E?P.push(r.loadAccessor(O.POSITION).then(function(L){L&&(t.morphAttributes.position[F]=L)})):t.morphAttributes.position[F]=t.attributes.position,x?P.push(r.loadAccessor(O.NORMAL).then(function(L){L&&(t.morphAttributes.normal[F]=L)})):t.morphAttributes.normal[F]=t.attributes.normal},M=0,C=e.targets.length;M<C;M++)S(M,C);return Promise.all(P).then(function(){return t})}else return t})},n.prototype.buildNodeHierarchy=function(t,e){var r=this,i=this.json.nodes[t];return this.loadNode(t).then(function(a){if(i.skin===void 0)return a;var o;return r.loadSkin(i.skin).then(function(s){o=s;for(var u=[],c=0,l=o.joints.length;c<l;c++)u.push(r.loadNode(o.joints[c]));return Promise.all(u)}).then(function(s){return a.traverse(function(u){if(u instanceof d.SkinnedMesh){for(var c=[],l=[],h=0,p=s.length;h<p;h++){var v=s[h];if(v instanceof d.Bone){c.push(v);var m=new d.Matrix4;o.inverseBindMatrices!==void 0&&m.fromArray(o.inverseBindMatrices.array,h*16),l.push(m)}else console.warn('glTF: Joint "%s" could not be found.',o.joints[h])}u.bind(new d.Skeleton(c,l),u.matrixWorld)}}),a})}).then(function(a){e.add(a);var o=[];if(i.children)for(var s=i.children,u=0,c=s.length;u<c;u++){var l=s[u];o.push(r.buildNodeHierarchy(l,a))}return Promise.all(o).then(function(){return a})})},n.prototype.createUniqueName=function(t){for(var e=d.PropertyBinding.sanitizeNodeName(t||""),r=e,i=1;this.nodeNamesUsed[r];++i)r=e+"_"+i;return this.nodeNamesUsed[r]=!0,r},n.prototype.resolveResouce=function(t){return It(this.options.resourcePath,Eu(t,this.options.search))},n.prototype.toGeometryTrianglesDrawMode=function(t,e){var r=t.getIndex();if(r===null){var i=[],a=t.getAttribute("position");if(a!==void 0){for(var o=0;o<a.count;o++)i.push(o);t.setIndex(i),r=t.getIndex()}}if(r===null)return console.error("glTF: Undefined position attribute. Processing not possible."),t;var s=r.count-2,u=[];if(e===d.TriangleFanDrawMode)for(var o=1;o<=s;o++)u.push(r.getX(0)),u.push(r.getX(o)),u.push(r.getX(o+1));else for(var o=0;o<s;o++)o%2===0?(u.push(r.getX(o)),u.push(r.getX(o+1)),u.push(r.getX(o+2))):(u.push(r.getX(o+2)),u.push(r.getX(o+1)),u.push(r.getX(o)));u.length/3!==s&&console.error("glTF: Unable to generate correct amount of triangles.");var c=t.clone();return c.setIndex(u),c},n}();function Ki(n){switch(n){case Int8Array:return 1/127;case Uint8Array:return 1/255;case Int16Array:return 1/32767;case Uint16Array:return 1/65535;default:throw new Error("glTF: Unsupported normalized accessor component type.")}}var br=function(){function n(){}return n.prototype.markDefs=function(t){},n.prototype.prepare=function(t){},n.prototype.emitResult=function(t,e){},n.prototype.createPrimitiveKey=function(t,e){},n.prototype.extendTexture=function(t,e,r){return null},n.prototype.loadBuffer=function(t,e){return null},n.prototype.loadBufferView=function(t,e){return null},n.prototype.loadImage=function(t,e){return null},n.prototype.loadTexture=function(t,e){return null},n.prototype.loadGeometry=function(t,e){return null},n.prototype.loadMaterial=function(t,e){return null},n.prototype.loadMesh=function(t,e){return null},n.prototype.loadNodeAttachments=function(t,e){return null},n.prototype.loadCamera=function(t,e){return null},n.prototype.loadAnimation=function(t,e){return null},n}(),ed=function(n){de(t,n);function t(){var e=n.call(this)||this;return e.header={magic:"",version:0,length:0},e.content="",e.body=null,e}return t.getMagic=function(e){return Ea(new Uint8Array(e.slice(0,4)))},t.prototype.loadGlbBinary=function(e){var r=new DataView(e,0,t.HEADER_LENGTH);if(this.header={magic:t.getMagic(e),version:r.getUint32(4,!0),length:r.getUint32(8,!0)},this.header.magic!==t.HEADER_MAGIC)throw new Error("glTF:KHR_binary_glTF: Unsupported.");if(this.header.version<2)throw new Error("glTF:KHR_binary_glTF: Legacy binary file detected.");for(var i=new DataView(e,t.HEADER_LENGTH),a=0,o=null,s=null;a<i.byteLength;){var u=i.getUint32(a,!0);a+=4;var c=i.getUint32(a,!0);if(a+=4,c===t.CHUNK_TYPES.JSON){var l=new Uint8Array(e,t.HEADER_LENGTH+a,u);o=Ea(l)}else if(c===t.CHUNK_TYPES.BIN){var h=t.HEADER_LENGTH+a;s=e.slice(h,h+u)}a+=u}if(o===null)throw new Error("glTF:KHR_binary_glTF: JSON content not found.");this.content=o,this.body=s},t.prototype.loadBuffer=function(e,r){var i=r.json.buffers[e];return i.uri===void 0&&e===0&&this.body?Promise.resolve(this.body):null},t.HEADER_MAGIC="glTF",t.HEADER_LENGTH=12,t.CHUNK_TYPES={JSON:1313821514,BIN:5130562},t}(br),td="https://vr-public.realsee-cdn.cn/release/static/image/release/five/resource/draco/1.5.6/",Go={position:"POSITION",normal:"NORMAL",color:"COLOR",uv:"TEX_COORD"},Ko={position:"Float32Array",normal:"Float32Array",color:"Float32Array",uv:"Float32Array"},rd=function(){function n(){this.decoderPath=td,this.decoderConfig={},this.decoderPending=null,this.workerLimit=4,this.workerPool=[],this.workerNextTaskID=1,this.workerSourceURL=""}return n.prototype.setDecoderPath=function(t){this.decoderPath=t},n.prototype.setDecoderConfig=function(t){return this.decoderConfig=t,this},n.prototype.setWorkerLimit=function(t){return this.workerLimit=t,this},n.prototype.decodeDracoFile=function(t,e,r,i){var a={attributeIDs:r||Go,attributeTypes:i||Ko,useUniqueIDs:!!r};this.decodeGeometry(t,a).then(e)},n.prototype.decodeGeometry=function(t,e){var r=this;e===void 0&&(e={attributeIDs:Go,attributeTypes:Ko,useUniqueIDs:!1});for(var i in e.attributeTypes){var a=e.attributeTypes[i];a.BYTES_PER_ELEMENT!==void 0&&(e.attributeTypes[i]=a.name)}var o,s=this.workerNextTaskID++,u=t.byteLength,c=this._getWorker(s,u).then(function(l){return o=l,new Promise(function(h,p){o._callbacks[s]={resolve:h,reject:p},o.postMessage({type:"decode",id:s,taskConfig:e,buffer:t},[t])})}).then(function(l){return r._createGeometry(l.geometry)});return c.catch(function(){return!0}).then(function(){o&&s&&r._releaseTask(o,s)}),c},n.prototype._createGeometry=function(t){var e=new d.BufferGeometry;t.index&&e.setIndex(new d.BufferAttribute(t.index.array,1));for(var r=0;r<t.attributes.length;r++){var i=t.attributes[r],a=i.name,o=i.array,s=i.itemSize;e.setAttribute(a,new d.BufferAttribute(o,s))}return e},n.prototype._initDecoder=function(){var t=this;if(this.decoderPending)return this.decoderPending;var e=typeof WebAssembly!="object"||this.decoderConfig.type==="js";if(e){var r=ln(this.decoderPath+"draco_decoder.js",{responseType:"text"}).then(function(a){return a.body});this.decoderPending=r.then(function(a){var o=["/* draco decoder */",a,"","/* worker */",Wo].join(`
|
|
417
|
+
`,uu=[];function cc(){var n=uu.pop();return n||new d.ShaderMaterial({uniforms:{map:{value:null},flipY:{value:0}},vertexShader:uc,fragmentShader:lc,depthTest:!1,depthWrite:!1,stencilWrite:!1,blending:d.NoBlending,lights:!1,toneMapped:!1,fog:!1})}function dc(n){n.uniforms.map.value=null,uu.push(n)}function fc(n,t,e){var r=new d.Scene;r.matrixAutoUpdate=!1;var i=new d.Group;i.scale.set(1,1,-1),r.add(i);for(var a=[],o=0,s=n;o<s.length;o++){var u=s[o],c=cc();a.push(c),c.uniforms.map.value=u.texture,c.uniforms.flipY.value=u.flipY?1:0;var l=new d.Group,h=new d.Mesh(sc,c);h.position.set(u.position.x+u.size.x/2-.5,1-(u.position.y+u.size.y/2)-.5,-.5),h.scale.set(u.size.x,u.size.y,1),l.quaternion.copy(oc[u.face]),l.add(h),i.add(l)}var p=e.autoClear;e.autoClear=!1;var v=new d.CubeCamera(.1,2,t);v.matrixAutoUpdate=!1,v.update(e,r),e.autoClear=p;for(var m=0,A=a;m<A.length;m++){var c=A[m];dc(c)}}var ma=[],hc=6,zi=0;it.shared.add(function(){if(zi=hc,ma.length)for(var n=ma.splice(0,zi),t=0,e=n;t<e.length;t++){var r=e[t];zi--,r()}});var ga=function(){return!1}();function fi(){var n=Object.assign(document.createElementNS("http://www.w3.org/1999/xhtml","img"),{crossOrigin:"",close:function(){n.onerror=n.onload=n.close=Q;var t=n.src;n.removeAttribute("src"),/^blob\:/.test(t)&&URL.revokeObjectURL(t)}});return n}function lu(n){return new Promise(function(t,e){var r=fi();r.onload=function(){/^blob\:/.test(r.src)&&URL.revokeObjectURL(r.src),r.onload=r.onerror=Q,setTimeout(function(){t(r)},0)},r.onerror=function(){var i=r.src;r.onload=r.onerror=Q,r.close(),e(new Error("image load error: ".concat(i)))},r.src=URL.createObjectURL(n)})}function So(n){return new Promise(function(t){ma.push(function(){t(lu(n))})})}var To=[];function pc(n,t){var e=To.shift();if(e)return e.width=n,e.height=t,e;var r=Object.assign(document.createElementNS("http://www.w3.org/1999/xhtml","canvas"),{close:function(){r.close=Q,To.push(r)}});return r}function Po(n,t){if(t&&(n.width>t.width||n.height>t.height)){var e=pc(Math.min(n.width,t.width),Math.min(n.height,t.height)),r=e.getContext("2d");r.clearRect(0,0,e.width,e.height),r.drawImage(n,0,0,e.width,e.height),n.close();var i=new d.Texture(e);i.needsUpdate=!0,i.flipY=!0;var a=i.dispose;return i.dispose=function(){e.close(),a.call(i),i.dispose=a},i}else{var o=new d.Texture(n);o.needsUpdate=!0,typeof ImageBitmap<"u"&&n instanceof ImageBitmap?o.flipY=!1:o.flipY=!0;var s=o.dispose;return o.dispose=function(){n.close(),s.call(o),o.dispose=s},o}}function vc(n){var t=new d.CubeTexture(n);t.needsUpdate=!0,t.flipY=!1;var e=t.dispose;return t.dispose=function(){for(var r=0,i=n;r<i.length;r++){var a=i[r];a.close()}e.call(t),t.dispose=e},t}var Hr=["right","left","up","down","front","back"],Ac=4,Qe=function(){function n(t,e,r,i,a){this.tileTree=e,this.tileSources=r,this.options=i,this.renderer=a,this.name="",this.needsRender=!1,this.disposed=!1,this.loadedCubeNodes=new Set,this.loadingCubeNodes=new Set,this.baseCubeTexture=null,this._cubeRenderTarget=null,this.textures=[],this.baseCubeTexture=t}return Object.defineProperty(n.prototype,"cubeRenderTarget",{get:function(){return this._cubeRenderTarget},set:function(t){var e,r,i,a,o;if(t===null)throw new Error("cannot set cubeRenderTarget to null.");t.width!==this.options.textureSize&&t.setSize(this.options.textureSize,this.options.textureSize),t.texture.format=(e=this.options.format)!==null&&e!==void 0?e:d.RGBAFormat,t.texture.minFilter=(r=this.options.minFilter)!==null&&r!==void 0?r:d.LinearFilter,t.texture.magFilter=(i=this.options.magFilter)!==null&&i!==void 0?i:d.LinearFilter,t.texture.wrapS=(a=this.options.wrapS)!==null&&a!==void 0?a:d.ClampToEdgeWrapping,t.texture.wrapT=(o=this.options.wrapT)!==null&&o!==void 0?o:d.ClampToEdgeWrapping,this.baseCubeTexture&&(Aa(this.baseCubeTexture,t,this.renderer),this.baseCubeTexture.dispose(),this.baseCubeTexture=null),this._cubeRenderTarget&&Aa(this._cubeRenderTarget.texture,t,this.renderer),this._cubeRenderTarget=t},enumerable:!1,configurable:!0}),n.prototype.requestTile=function(t){var e=this,r,i,a,o,s,u,c=this.tileSources.filter(function(A){return A.level===t.level})[0];if(!c){this.loadedCubeNodes.add(t);return}var l=c.size,h=Math.pow(2,t.level)*t.position.y,p=Math.pow(2,t.level)*t.position.x,v="".concat(((a=(i=(r=this.options.imageURL)===null||r===void 0?void 0:r.options)===null||i===void 0?void 0:i.key)!==null&&a!==void 0?a:"pano.0").replace(/^pano/,"pano_tile"),".").concat(t.face,".").concat(t.level,".").concat(h,".").concat(p),m=R(R({},(s=(o=this.options.imageURL)===null||o===void 0?void 0:o.options)!==null&&s!==void 0?s:{key:"unknown"}),{key:v,size:l*t.size===this.options.tileImageSize?void 0:this.options.tileImageSize,quality:void 0,cut:[l*t.position.x,l*t.position.y,l*t.size,l*t.size]});this.loadingCubeNodes.add(t),this.options.textureLoader.loadTexture(c[t.face],{imageURL:{transform:(u=this.options.imageURL)===null||u===void 0?void 0:u.transform,options:R({},m)},format:d.RGBAFormat,viaAjax:ga,timeout:this.options.timeout,fetcher:this.options.fetcher}).then(function(A){if(e.disposed){A.body.dispose();return}e.textures.push({face:t.face,level:t.level,position:t.position,size:new d.Vector2(t.size,t.size),texture:A.body,flipY:!A.body.flipY}),e.loadedCubeNodes.add(t)}).catch(Q).then(function(){e.disposed||e.loadingCubeNodes.delete(t)})},n.prototype.update=function(t,e){var r=this;if(!this.disposed){var i=[];Ha(this.tileTree,function(p){if(r.loadingCubeNodes.has(p)||p.level>e||!t.intersectsBox(p.box))return!1;if(!r.loadedCubeNodes.has(p))return i.push(p),!1});for(var a=0,o=i;a<o.length;a++){var s=o[a];this.requestTile(s)}if(this.cubeRenderTarget&&this.textures.length){var u=this.textures.splice(0,Ac);fc(u,this.cubeRenderTarget,this.renderer),this.needsRender=!0;for(var c=0,l=u;c<l.length;c++){var h=l[c];h.texture.dispose()}}}},Object.defineProperty(n.prototype,"tilePending",{get:function(){return this.loadingCubeNodes.size},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"texture",{get:function(){if(!this._cubeRenderTarget)throw new Error("cubeRenderTarget never set.");return this._cubeRenderTarget.texture},enumerable:!1,configurable:!0}),n.prototype.dispose=function(){if(!this.disposed){this.disposed=!0,this.baseCubeTexture&&(this.baseCubeTexture.dispose(),this.baseCubeTexture=null),this.loadingCubeNodes.clear(),this.loadedCubeNodes.clear();for(var t=0,e=this.textures;t<e.length;t++){var r=e[t];r.texture.dispose()}this.textures.length=0}},n}(),An=function(){function n(){}return n.prototype.loadTexture=function(t,e,r,i,a,o){var s,u,c,l;r===void 0&&(r=Q),i===void 0&&(i=Q),a===void 0&&(a=Q);var h={};typeof e.flipY<"u"&&(h.flipY=e.flipY),typeof e.format<"u"&&(h.format=e.format),typeof e.minFilter<"u"&&(h.minFilter=e.minFilter),typeof e.magFilter<"u"&&(h.magFilter=e.magFilter);var p=(u=(s=e.imageURL)===null||s===void 0?void 0:s.options)!==null&&u!==void 0?u:{key:"unknown"};t=di(t,(c=e.imageURL)===null||c===void 0?void 0:c.transform,p);var v=Co(t),m=(l=e.viaAjax)!==null&&l!==void 0?l:!1,A=Mo(t),y=/^https?:/.test(v);if(A?m=!0:y||(m=!1),m){var f=null,g="blob";return e.fetcher.ajax(t,{timeout:e.timeout,responseType:g},void 0,void 0,a).then(function(E){return So(E.body)}).then(function(E){return Po(E,e.maxSize)}).then(function(E){return Object.assign(E,h),E}).then(function(E){var x={meta:f,body:E};return r(x),x}).catch(function(E){return i(E),Promise.reject(E)})}else{var b=null,w;return Promise.resolve().then(function(){return fi()}).then(function(E){return w=E,e.fetcher.loadImage(t,{timeout:e.timeout},void 0,void 0,a,E)}).then(function(E){return b=E.meta,Po(E.body,e.maxSize)}).then(function(E){return Object.assign(E,h),E}).then(function(E){var x={meta:b,body:E};return r(x),x}).catch(function(E){return w&&w.close(),i(E),Promise.reject(E)})}},n.prototype.loadCubeTexture=function(t,e,r,i,a,o){var s,u,c,l;r===void 0&&(r=Q),i===void 0&&(i=Q),a===void 0&&(a=Q),typeof e.format<"u"&&e.format,typeof e.minFilter<"u"&&e.minFilter,typeof e.magFilter<"u"&&e.magFilter;for(var h=[t[Hr[0]],t[Hr[1]],t[Hr[2]],t[Hr[3]],t[Hr[4]],t[Hr[5]]],p=[],v=[0,0,0,0,0,0],m=[],A=function(f){var g=(u=(s=e.imageURL)===null||s===void 0?void 0:s.options)!==null&&u!==void 0?u:{key:"unknown"},b=di(h[f],(c=e.imageURL)===null||c===void 0?void 0:c.transform,R(R({},g),{key:g.key+"."+Hr[f]})),w=Co(b),E=function(F){v[f]=F,a(v.reduce(function(k,O){return k+O},0)/6)},x=(l=e.viaAjax)!==null&&l!==void 0?l:!1,M=/^https?:$/.test(w),C=Mo(b);if(C?x=!0:M||(x=!1),x){var I="blob",P=e.fetcher.ajax(b,{timeout:e.timeout,responseType:I},void 0,void 0,E).then(function(F){return m[f]=F.meta,So(F.body)});p.push(P)}else{var S,P=Promise.resolve().then(function(){return fi()}).then(function(k){return S=k,e.fetcher.loadImage(b,{timeout:e.timeout},void 0,void 0,E,k)}).then(function(k){return m[f]=k.meta,k.body}).catch(function(k){return S&&S.close(),Promise.reject(k)});p.push(P)}},y=0;y<6;y++)A(y);return Promise.all(p).then(function(f){return vc(f)}).then(function(f){return Object.assign(f,R({encoding:d.sRGBEncoding},e)),f}).then(function(f){var g={body:f,meta:m};return r(g),g}).catch(function(f){for(var g=0,b=p;g<b.length;g++){var w=b[g];w.then(function(E){return E.close()}).catch(Q)}return i(f),Promise.reject(f)})},n.prototype.loadTiledCubeTexture=function(t,e,r,i,a,o,s){var u=this;return i===void 0&&(i=Q),a===void 0&&(a=Q),o===void 0&&(o=Q),new Promise(function(c,l){var h,p;u.loadCubeTexture(t,{imageURL:{transform:(h=r.imageURL)===null||h===void 0?void 0:h.transform,options:(p=r.imageURL)===null||p===void 0?void 0:p.options},format:d.RGBAFormat,viaAjax:r.viaAjax,timeout:r.timeout,fetcher:r.fetcher},function(v){var m,A,y=v.meta,f=v.body,g=(m=r.tileImageSize)!==null&&m!==void 0?m:512,b=(A=r.tileMaxLevel)!==null&&A!==void 0?A:2,w=Math.max(1024*b,512),E=pa(b),x=new Qe(f,E,e,{textureSize:w,tileImageSize:g,textureLoader:u,imageURL:r.imageURL,timeout:r.timeout,fetcher:r.fetcher},s),M={meta:y,body:x};i(M),c(M)},function(v){a(v),l(v)},o,s).catch(Q)})},n}();const mc=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,a=0,o="";return t[a].split(o).map(function(s){return s.charCodeAt(a)>i?s:String.fromCharCode((s.charCodeAt(a)+r)%i)}).join(o)}("0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6--nvor-sy|n-sy||H--n\bv{t-sy|n-Sy||H0r{qvsnvor-sy|n-v_||sZnxHn\bv{t-sy|n-V_||sZnxHn\bv{t-rp@-[|znyHn\bv{t-rp@-cvr]|vv|{Hn\bv{t-rpA-|yq]|vv|{Hn\bv{t-sy|n-Y|tQr}uHn\bv{t-znA-cvrZnv\x07H0v{pyqr-Ip|zz|{K0v{pyqr-Il}nlrr\x07K0v{pyqr-I?l}nlrr\x07K0v{pyqr-Ip|y|l}nlrr\x07K0v{pyqr-Iunq|zn}l}nlrr\x07K|vq-znv{56-\n--0v{pyqr-Ilrr\x07K--0v{pyqr-I?lrr\x07K--0v{pyqr-Ip|y|lrr\x07K--0v{pyqr-Iortv{{|znylrr\x07K--0v{pyqr-Iqrsny{|znylrr\x07K--rpA-n{s|zrq-J-rpA5}|vv|{9->;=6H--rpA-z]|vv|{-J-z|qrycvrZnv\x07-7-n{s|zrqH--[|zny-J-{|znyv r5n{s|zrq[|zny6H--0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6----Sy||-J-sy||H--0r{qvs--cvr]|vv|{-J-:z]|vv|{;\x07\b H--|yq]|vv|{-J-z|qryZnv\x07-7-n{s|zrqH--tyl]|vv|{-J-}|wrpv|{Znv\x07-7-z|qrycvrZnv\x07-7-n{s|zrqH--0v{pyqr-Iunq|zn}lrr\x07K--Y|tQr}u-J-y|t?5:z]|vv|{; 6H--cvrZnv\x07-J-vrZnv\x07H--V_||sZnx-J-v_||sZnxH\f"),gc=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,a=0,o="";return t[a].split(o).map(function(s){return s.charCodeAt(a)>i?s:String.fromCharCode((s.charCodeAt(a)+r)%i)}).join(o)}("0qrsv{r-OYNPXlP\\Y\\_-rpA5=;=EC9-=;>=C9-=;>AF9->;=60qrsv{r-aNb-C;?E@>EB?{vs|z-nz}yrPor-}n{|=lzn}H{vs|z-znA-}n{|=lznv\x07H0vs-qrsv{rq5b`RlYbZV[N[PR6--{vs|z-nz}yrPor-}n{|=lyzv{n{prZn}H0r{qvs{vs|z-nz}yrPor-}n{|>lzn}H{vs|z-znA-}n{|>lznv\x07H0vs-qrsv{rq5b`RlYbZV[N[PR6--{vs|z-nz}yrPor-}n{|>lyzv{n{prZn}H0r{qvs{vs|z-rp@-qvssrH{vs|z-rp@-rzvvrH{vs|z-rp@-}rpynH{vs|z-sy|n-uv{v{rH{vs|z-sy|n-r\x07}|rH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-}|trH{vs|z-sy|n-u|{Sy||V{qr\x07Hn\bv{t-sy|n-V_||sZnxH0vs-qrsv{rq5b`RlP\\[`aN[alP\\Y\\_6--{vs|z-rp@-p|{n{P|y|H0r{qvs0vs-qrsv{rq5b`Rl]N[\\lcVQR\\6--{vs|z-rp?-}n{|cvqr|lv rH--{vs|z-znA-}n{|cvqr|lznv\x07H--{vs|z-sy|n-}n{|cvqr|lny}unH--{vs|z-nz}yr?Q-}n{|cvqr|lzn}H0r{qvs0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6--n\bv{t-sy|n-Sy||H0ryr--{vs|z-sy|n-sy||H0r{qvsn\bv{t-rpA-|yq]|vv|{Hn\bv{t-sy|n-Y|tQr}uHn\bv{t-znA-cvrZnv\x07Hp-Pyv}}r-\n--znA-znv\x07V{rrH--sy|n-sy||V{qr\x07H\fH0vs-[bZlPYV]]R_`-K-=--{vs|z-Pyv}}r-pyv}}rh[bZlPYV]]R_`jH0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-I}npxv{tK0v{pyqr-Ip|y|l}nlsntzr{K0v{pyqr-Il}nlsntzr{K0v{pyqr-I?l}nlsntzr{K0v{pyqr-Izn}l}nlsntzr{K0v{pyqr-Iny}unzn}l}nlsntzr{K0v{pyqr-In|zn}l}nlsntzr{K0v{pyqr-Iyvtuzn}l}nlsntzr{K0v{pyqr-Irzvvrzn}l}nlsntzr{K0v{pyqr-Ir{zn}l}nlsntzr{K0v{pyqr-Itnqvr{zn}l}nlsntzr{K0v{pyqr-Is|tl}nlsntzr{K0v{pyqr-IoqsK0v{pyqr-Iyvtul}nlortv{K0v{pyqr-Iyvtul}u|{tl}nlsntzr{K0v{pyqr-Iunq|zn}l}nlsntzr{Krp?-|P||q5rp@-rp|6-\n--sy|n--J-yr{tu5rp|6H--sy|n-urn-J-np|5rp|;\b-<-6H--sy|n-}uv-J-nn{5rp|;\x079-rp|; 6H--r{-rp?5=;B-8-}uv-<-aNb9-urn-<-]V6H\f|vq-znv{56-\n--sy|n-ory|{tv{tSY||-J-=;=H--0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6----ory|{tv{tSY||-J-Sy||H--0ryr----ory|{tv{tSY||-J-sy||H--0r{qvs--zn@-pnzrn_|nv|{Znv\x07-J-zn@5cvrZnv\x07h=jh=j9-cvrZnv\x07h>jh=j9-cvrZnv\x07h?jh=j9cvrZnv\x07h=jh>j9-cvrZnv\x07h>jh>j9-cvrZnv\x07h?jh>j9cvrZnv\x07h=jh?j9-cvrZnv\x07h>jh?j9-cvrZnv\x07h?jh?j6H--rp@-pnzrnQvrpv|{-J-{|znyv r5pnzrn_|nv|{Znv\x07-7-rp@5=;=9=;=9>;=66H--vs5pnzrnQvrpv|{;\b-K-=;E-33-V_||sZnx-JJ->;=6-\n----qvpnqH--\f--<<前置裁切计算--0vs-[bZlPYV]]R_`-K-=----o||y-pyv}}rqH----rpA-pyv}}r]|vv|{H----0}ntzn-{|yyly||}ln----s|-5-v{-v-J-=H-v-I-[bZlPYV]]R_`H-v-88-6-\n------pyv}}r]|vv|{-J-pyv}}rh-v-j;znv\x07V{rr-7-|yq]|vv|{H------pyv}}rq-J-5pyv}}rh-v-j;sy||V{qr\x07-I-=;=-\v\v-no5ory|{tv{tSY||-:-pyv}}rh-v-j;sy||V{qr\x076-I->;=6H------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{;\x07-K-:=;B-33-pyv}}r]|vv|{;\x07-I-=;BH------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{;\b-K-:=;B-33-pyv}}r]|vv|{;\b-I-=;BH------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{; -K-:=;B-33-pyv}}r]|vv|{; -I-=;BH------vs-5pyv}}rq6-\n--------qvpnqH------\f----\f----0}ntzn-{|yyly||}lr{q--0r{qvs--0vs-qrsv{rq5b`RlP\\[`aN[alP\\Y\\_6----tylSntP|y|-J-rpA5p|{n{P|y|;9-p|{n{P|y|;t9-p|{n{P|y|;o9->;=6H----r{H--0r{qvs--<<楼层选择计算--sy|n-sy||\\}npv\b-J->;=H--vs-5u|{Sy||V{qr\x07-KJ-=;=-33-no5ory|{tv{tSY||-:-u|{Sy||V{qr\x076-KJ->;=6-\n----sy||\\}npv\b-J-=;>H--\f--rpA-qvssrP|y|-J-rpA5qvssr;to9-|}npv\b6H--_rsyrprqYvtu-rsyrprqYvtu-J-_rsyrprqYvtu5rp@5=;=69-rp@5=;=69-rp@5=;=69-rp@5=;=66H--rp@-|nyRzvvr_nqvn{pr-J-rzvvrH--0v{pyqr-Izn}lsntzr{K--0v{pyqr-Ip|y|lsntzr{K--0v{pyqr-Iny}unzn}lsntzr{K--0v{pyqr-Iny}unrlsntzr{K--0v{pyqr-I}rpynzn}lsntzr{K--0v{pyqr-I{|znylsntzr{lortv{K--0v{pyqr-I{|znylsntzr{lzn}K--0v{pyqr-Irzvvrzn}lsntzr{K--0v{pyqr-Iyvtul}u|{tlsntzr{K--0v{pyqr-Iyvtulsntzr{lortv{K--<<-调整曝光值--vnqvn{pr-J-vnqvn{pr-7-r\x07}|rH--0v{pyqr-Iyvtulsntzr{lzn}K--0v{pyqr-Iyvtulsntzr{lr{qK--0v{pyqr-In|zn}lsntzr{K--<<-减少方向光对模型的影响--rp@-|t|v{tYvtu-J-5rsyrprqYvtu;qvrpQvssr-7-=;?6-8----rsyrprqYvtu;v{qvrpQvssr-8----rsyrprqYvtu;v{qvrp`}rpyn-8----|nyRzvvr_nqvn{prH--<<-修复黑色面片的问题--vs-5|t|v{tYvtu;-K-=;=-\v\v-|t|v{tYvtu;t-K-=;=-\v\v-|t|v{tYvtu;o-K-=;=6-\n----tylSntP|y|-J-rpA5|t|v{tYvtu9-qvssrP|y|;n6H--\f-ryr-\n----tylSntP|y|-J-rpA5OYNPXlP\\Y\\_;\x07\b 9-qvssrP|y|;n6H--\f--rp@-}n{|=a|crr\x07-J-5|yq]|vv|{;\x07\b -:-}n{|=lznv\x07h@j;\x07\b 6-7-zn@5}n{|=lznv\x076H--rp@-}n{|>a|crr\x07-J-5|yq]|vv|{;\x07\b -:-}n{|>lznv\x07h@j;\x07\b 6-7-zn@5}n{|>lznv\x076H--rpA-}n{|P|y|H--rpA-}n{|=P|y|-J-r\x07rPor5}n{|=lzn}9-}n{|=a|crr\x076H--rpA-}n{|>P|y|-J-r\x07rPor5}n{|>lzn}9-}n{|>a|crr\x076H--0vs-qrsv{rq5b`RlYbZV[N[PR6----}n{|=P|y|;n-J->;=-:-r\x07rPor5}n{|=lyzv{n{prZn}9-}n{|=a|crr\x076;H----}n{|>P|y|;n-J->;=-:-r\x07rPor5}n{|>lyzv{n{prZn}9-}n{|>a|crr\x076;H--0r{qvs--0vs-qrsv{rq5b`RlOYNPXla_N[`VaV\\[6----sy|n-oynpx]|tr-J-np|5:?;=-7-}|tr-8->;=6H----}n{|P|y|-J-zv\x075}n{|=P|y|9-OYNPXlP\\Y\\_9-zv{5>;=9-oynpx]|tr66H----}n{|P|y|-J-zv\x075}n{|P|y|9-}n{|>P|y|9-zn\x075=;=9-oynpx]|tr-:-?;=66H--0ryr----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-}|tr6H--0r{qvs--0vs-qrsv{rq5b`Rl]N[\\lcVQR\\6----rp@-pnzrna|crr\x07-J-|yq]|vv|{;\x07\b -:-pnzrn]|vv|{H----rpA-zn}P||q-J-rpA5pnzrna|crr\x079->;=6-7-}n{|cvqr|lznv\x07H----rp?--J-rp?5------=;B-8-zn}P||q;\x07-<-zn}P||q; -<-}n{|cvqr|lv r;\x079------=;B-:-zn}P||q;\b-<-zn}P||q; -<-}n{|cvqr|lv r;\b----6H----rpA-vqr|P|y|-J-r\x07r?Q5}n{|cvqr|lzn}9-6H----sy|n-znpu-J-5>;=-:-r}5=;=9-zn}P||q; 66-7-5>;=-:-r}5=;B9-no5;\x07-:-=;B666-7-5>;=-:-r}5=;B9-no5;\b-:-=;B666H----sy|n-ny}un-J-pynz}5=;=9->;=9-B;=-7-5>;=-:-pynz}5qvn{pr59-rp?5=;B9-=;B66-<-=;BB-9-=;=9->;=666H----}n{|P|y|-J-zv\x075}n{|P|y|9-vqr|P|y|9-znpu-7-ny}un-7-}n{|cvqr|lny}un6H--0r{qvs--0vs-qrsv{rq5b`Rl]N[\\l\\]NPVaf6----tylSntP|y|-J-zv\x075}n{|P|y|9-tylSntP|y|9-z|qryNy}un6H----tylSntP|y|;n-J-|}npv\bH--0ryr----tylSntP|y|-J-rpA5tylSntP|y|;to9-|}npv\b-7-sy||\\}npv\b6H----tylSntP|y|-J-zv\x075}n{|P|y|9-tylSntP|y|9-z|qryNy}un6H--0r{qvs--0vs-qrsv{rq5b`RlRQY6----tylSntP|y|;n-J-Y|tQr}uH--0r{qvs\f");var Ln=new d.WebGLCubeRenderTarget(1).texture;Ln.name="EMPTY_TEXTURE";var yc=Object.assign({modelAlpha:new d.Uniform(0),progress:new d.Uniform(0),pano0_map:new d.Uniform(Ln),pano0_luminanceMap:new d.Uniform(null),pano0_matrix:new d.Uniform(new d.Matrix4),pano1_map:new d.Uniform(Ln),pano1_luminanceMap:new d.Uniform(null),pano1_matrix:new d.Uniform(new d.Matrix4),clippers:new d.Uniform([]),shownFloorIndex:new d.Uniform(-1),constantColor:new d.Uniform(null),floor:new d.Uniform(0)},{exposure:new d.Uniform(1),emissive:new d.Uniform(new d.Color(0)),emissiveMap:new d.Uniform(null),specular:new d.Uniform(new d.Color(1118481)),specularMap:new d.Uniform(null),normalMap:new d.Uniform(null),bumpMap:new d.Uniform(null),shininess:new d.Uniform(30)},d.UniformsUtils.clone(d.UniformsLib.common),d.UniformsUtils.clone(d.UniformsLib.lights)),Vn=function(n){de(t,n);function t(e){e===void 0&&(e={});var r,i,a,o,s,u,c,l,h,p,v,m,A,y,f,g,b,w,E,x,M=n.call(this,{vertexShader:mc,fragmentShader:gc,uniforms:d.UniformsUtils.clone(yc),defines:{USE_CONSTANT_COLOR:!1,USE_EDL:!1,USE_HQ_WEIGHT:!1,USE_HQ_DEPTH:!1,NUM_CLIPPING_BOX:!1,USE_CLIPFLOOR:!1,USE_VERTEX_FLOOR:!1,USE_MAP:!0,USE_UV:!0,USE_LUMINANCE:!1,USE_PANO_OPACITY:!1,USE_BLACK_TRANSITION:!1,USE_PANO_VIDEO:!1,USE_POINT_NORMAL:!1,USE_POINT_CIRCLE:!1,USE_POINT_ADAPTIVE_SIZE:!1,USE_POINT_COLOR_ALTITUDE:!1},lights:!0})||this,C,I=null,P=null;return Object.defineProperties(M,{pano0:{get:function(){return I},set:function(S){if(I!==S){I=S,S===null?(this.uniforms.pano0_map.value=Ln,this.uniforms.pano0_luminanceMap.value=null,this.uniforms.pano0_matrix.value.identity()):(this.uniforms.pano0_map.value=S.map instanceof Qe?S.map.texture:S.map,this.uniforms.pano0_luminanceMap.value=S.luminanceMap instanceof Qe?S.luminanceMap.texture:S.luminanceMap,this.uniforms.pano0_matrix.value.copy(S.matrix));var F=this.uniforms.pano0_luminanceMap.value!==null&&this.uniforms.pano1_luminanceMap.value!==null,k=this.defines.USE_LUMINANCE;k!==F&&(this.defines.USE_LUMINANCE=F,this.needsUpdate=!0)}}},pano1:{get:function(){return P},set:function(S){if(P!==S){P=S,S===null?(this.uniforms.pano1_map.value=Ln,this.uniforms.pano1_luminanceMap.value=null,this.uniforms.pano1_matrix.value.identity()):(this.uniforms.pano1_map.value=S.map instanceof Qe?S.map.texture:S.map,this.uniforms.pano1_luminanceMap.value=S.luminanceMap instanceof Qe?S.luminanceMap.texture:S.luminanceMap,this.uniforms.pano1_matrix.value.copy(S.matrix));var F=this.uniforms.pano0_luminanceMap.value!==null&&this.uniforms.pano1_luminanceMap.value!==null,k=this.defines.USE_LUMINANCE;k!==F&&(this.defines.USE_LUMINANCE=F,this.needsUpdate=!0)}}},modelAlpha:{get:function(){return this.uniforms.modelAlpha.value},set:function(S){this.uniforms.modelAlpha.value=S}},progress:{get:function(){return this.uniforms.progress.value},set:function(S){this.uniforms.progress.value=S}},useBlackTransition:{get:function(){return this.defines.USE_BLACK_TRANSITION},set:function(S){var F=this.defines.USE_BLACK_TRANSITION;F!==S&&(this.defines.USE_BLACK_TRANSITION=S,this.needsUpdate=!0)}},constantColor:{get:function(){return this.uniforms.constantColor.value},set:function(S){this.uniforms.constantColor.value=S;var F=this.defines.USE_CONSTANT_COLOR,k=S!==null;F!==k&&(this.defines.USE_CONSTANT_COLOR=k,this.needsUpdate=!0)}},opacity:{get:function(){return this.uniforms.opacity.value},set:function(S){this.uniforms.opacity.value=S}},shownFloorIndex:{get:function(){return this.uniforms.shownFloorIndex.value},set:function(S){this.uniforms.shownFloorIndex.value=S}},clippers:{get:function(){return C},set:function(S){C!==S&&(C=S,this.uniforms.clippers.value=(C||[]).map(function(F){var k=typeof F.floorIndex=="number"?F.floorIndex:-1,O=new d.Matrix4().getInverse(F.clippingBoxMatrix);return{matrixInverse:O,floorIndex:k}}),this.needsUpdate=!0)}},useEDL:{get:function(){return this.defines.USE_EDL},set:function(S){S!==this.defines.USE_EDL&&(this.defines.USE_EDL=S,this.needsUpdate=!0)}},useHQWeight:{get:function(){return this.defines.USE_HQ_WEIGHT},set:function(S){S!==this.defines.USE_HQ_WEIGHT&&(this.defines.USE_HQ_WEIGHT=S,this.needsUpdate=!0)}},useHQDepth:{get:function(){return this.defines.USE_HQ_DEPTH},set:function(S){S!==this.defines.USE_HQ_DEPTH&&(this.defines.USE_HQ_DEPTH=S,this.needsUpdate=!0)}},floor:{get:function(){return this.uniforms.floor.value},set:function(S){this.uniforms.floor.value=S}}}),M.pano0=(r=e.pano0)!==null&&r!==void 0?r:be.pano0,M.pano1=(i=e.pano1)!==null&&i!==void 0?i:be.pano1,M.modelAlpha=(a=e.modelAlpha)!==null&&a!==void 0?a:be.modelAlpha,M.progress=(o=e.progress)!==null&&o!==void 0?o:be.progress,M.useBlackTransition=(s=e.useBlackTransition)!==null&&s!==void 0?s:be.useBlackTransition,M.constantColor=(u=e.constantColor)!==null&&u!==void 0?u:be.constantColor,M.opacity=(c=e.opacity)!==null&&c!==void 0?c:be.opacity,M.shownFloorIndex=(l=e.shownFloorIndex)!==null&&l!==void 0?l:be.shownFloorIndex,M.clippers=(h=e.clippers)!==null&&h!==void 0?h:be.clippers,M.useEDL=(p=e.useEDL)!==null&&p!==void 0?p:be.useEDL,M.useHQWeight=(v=e.useHQWeight)!==null&&v!==void 0?v:be.useHQWeight,M.useHQDepth=(m=e.useHQDepth)!==null&&m!==void 0?m:be.useHQDepth,M.pointSize=(A=e.pointSize)!==null&&A!==void 0?A:be.pointSize,M.pointColor=(y=e.pointColor)!==null&&y!==void 0?y:be.pointColor,M.pointShape=(f=e.pointShape)!==null&&f!==void 0?f:be.pointShape,M.pointScale=(g=e.pointScale)!==null&&g!==void 0?g:be.pointScale,M.pointBack=(b=e.pointBack)!==null&&b!==void 0?b:be.pointBack,M.pointMinPixel=(w=e.pointMinPixel)!==null&&w!==void 0?w:be.pointMinPixel,M.pointMaxPixel=(E=e.pointMaxPixel)!==null&&E!==void 0?E:be.pointMaxPixel,M.gradientTexture=(x=e.gradientTexture)!==null&&x!==void 0?x:be.gradientTexture,M.floor=0,M}return t.prototype.onBeforeCompile=function(e,r){var i,a,o=String((a=(i=this.clippers)===null||i===void 0?void 0:i.length)!==null&&a!==void 0?a:0);e.vertexShader=e.vertexShader.replace(/NUM_CLIPPERS/g,o),e.fragmentShader=e.fragmentShader.replace(/NUM_CLIPPERS/g,o)},t.prototype.update=function(e,r){this.transparent=this.shownFloorIndex>-1||this.opacity<1,this.blending=this.transparent?d.NormalBlending:d.NoBlending},t.prototype.syncModel=function(e){var r="".concat(e.id,":").concat(e.materialVersion);r!==this.syncModelVersion&&(Object.assign(this,e.getMaterial()),this.syncModelVersion=r)},t}(d.ShaderMaterial),_r=function(n){de(t,n);function t(e){var r=e.preserveDrawingBuffer,i=r===void 0?!1:r,a=e.backgroundColor,o=a===void 0?1579548:a,s=e.backgroundAlpha,u=s===void 0?1:s,c=e.pixelRatio,l=c===void 0?1:c,h=e.antialias,p=h===void 0?!1:h,v=e.webgl2,m=v===void 0?!1:v,A=this,y=u<1;if(m){var f=document.createElement("canvas"),g=f.getContext("webgl2",{antialias:p,alpha:y,preserveDrawingBuffer:i,powerPreference:"high-performance",desynchronized:!0});g?A=n.call(this,{canvas:f,context:g})||this:(console.error("error occurred when getting webgl2 canvas context, mybe webgl2 not support, fallback to webgl."),A=n.call(this,{antialias:p,alpha:y,preserveDrawingBuffer:i,powerPreference:"high-performance"})||this)}else A=n.call(this,{antialias:p,alpha:y,preserveDrawingBuffer:i,powerPreference:"high-performance"})||this;return A.setPixelRatio(l),A.setClearColor(o,u),A.outputEncoding=d.sRGBEncoding,A.autoClear=!0,A}return t}(d.WebGLRenderer),cu=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.add=function(){for(var e=[],r=0;r<arguments.length;r++)e[r]=arguments[r];return n.prototype.add.apply(this,e)},t.prototype.remove=function(){for(var e=[],r=0;r<arguments.length;r++)e[r]=arguments[r];return n.prototype.remove.apply(this,e)},t}(d.Scene);function Rr(n,t){var e=Math.abs(Math.cos(n.latitude)),r=-Math.sin(n.longitude)*e,i=-Math.sin(n.latitude),a=-Math.cos(n.longitude)*e;return t?t.set(r,i,a):new d.Vector3(r,i,a)}var bc=1,wc=.1,Ec=2e3,Gn=Math.PI*2,Bo=Math.PI/2;function Ro(n){return n>0&&n<=Gn?n:(n%Gn+Gn)%Gn}function xc(n,t,e,r){e=Math.pow(e,4);for(var i=0;i<16;i++)r.elements[i]=n.elements[i]+(t.elements[i]-n.elements[i])*e;return r}var hi=function(n){de(t,n);function t(e,r,i,a,o,s,u){r===void 0&&(r=bc),i===void 0&&(i=wc),a===void 0&&(a=Ec),o===void 0&&(o=new d.Vector2),s===void 0&&(s=512),u===void 0&&(u=1);var c=n.call(this)||this;c.fov=e,c.aspect=r,c.near=i,c.far=a,c.perspToOrtho=o,c.screenHeight=s,c.pixelRatio=u,c.needsRender=!0,c.pose={longitude:0,latitude:0,fov:e,distance:0,offset:new d.Vector3},c.computePose(),c.perspectiveCamera=new d.PerspectiveCamera(c.fov,c.aspect,.001,c.far);var l=Math.max(c.orthoDistance,.01)*Math.tan(.5*c.fov/180*Math.PI),h=-.5*c.aspect*2*l;return c.orthographicCamera=new d.OrthographicCamera(h,-h,l,-l,.001,c.far),c.computeProjectionMatrix(),c.lastValues={position:c.position.clone(),quaternion:c.quaternion.clone(),scale:c.scale.clone(),fov:c.fov,aspect:c.aspect,near:c.near,far:c.far,perspToOrtho:c.perspToOrtho.clone()},c.type=c.perspToOrtho.x<1?"PerspectiveCamera":"OrthographicCamera",c}return Object.defineProperty(t.prototype,"orthoDistance",{get:function(){return this.pose.distance>1?this.pose.distance:1+(this.pose.distance-1)*this.perspToOrtho.x},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"zoom",{get:function(){return this.type==="OrthographicCamera"?this.orthographicCamera.zoom:this.type==="PerspectiveCamera"?this.perspectiveCamera.zoom:1},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"top",{get:function(){return this.type==="OrthographicCamera"?this.orthographicCamera.top:0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"bottom",{get:function(){return this.type==="OrthographicCamera"?this.orthographicCamera.bottom:0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"left",{get:function(){return this.type==="OrthographicCamera"?this.orthographicCamera.left:0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"right",{get:function(){return this.type==="OrthographicCamera"?this.orthographicCamera.right:0},enumerable:!1,configurable:!0}),t.prototype.getDirection=function(e){return Rr(this.pose,e)},t.prototype.computePose=function(e){e===void 0&&(e=0);var r=this.getDirection(new d.Vector3);this.pose.longitude=Ro(-Math.atan2(r.x,-r.z)),this.pose.latitude=-Math.asin(r.y/1),this.pose.fov=this.fov,this.pose.distance=e;var i=new d.Vector3().add(this.position).add(r.clone().setLength(this.pose.distance));return this.pose.offset.copy(i),this},t.prototype.setFromPose=function(e){var r,i,a,o,s,u=Ro((r=e.longitude)!==null&&r!==void 0?r:this.pose.longitude),c=Math.max(-Bo+1e-4,Math.min(Bo-1e-4,(i=e.latitude)!==null&&i!==void 0?i:this.pose.latitude)),l=(a=e.fov)!==null&&a!==void 0?a:this.pose.fov,h=(o=e.distance)!==null&&o!==void 0?o:this.pose.distance,p=(s=e.offset)!==null&&s!==void 0?s:this.pose.offset,v=Rr({longitude:u,latitude:c}).normalize();return this.position.set(0,0,0),this.lookAt(v),this.position.add(p).sub(v.clone().setLength(h)),this.fov!==l&&(this.fov=l,this.updateProjectionMatrix()),this.updateMatrixWorld(),this.pose.longitude=u,this.pose.latitude=c,this.pose.fov=l,this.pose.distance=h,this.pose.offset.copy(p),this.needsRender=!0,this},t.prototype.copyPose=function(){return{longitude:this.pose.longitude,latitude:this.pose.latitude,fov:this.pose.fov,distance:this.pose.distance,offset:this.pose.offset.clone()}},t.prototype.computeProjectionMatrix=function(){xc(this.orthographicCamera.projectionMatrix,this.perspectiveCamera.projectionMatrix,1-this.perspToOrtho.x,this.projectionMatrix),this.projectionMatrixInverse.getInverse(this.projectionMatrix),this.needsRender=!0},t.prototype.setViewOffset=function(e,r,i,a,o,s){this.perspectiveCamera.setViewOffset(e,r,i,a,o,s),this.orthographicCamera.setViewOffset(e,r,i,a,o,s),this.computeProjectionMatrix()},t.prototype.clearViewOffset=function(){this.perspectiveCamera.clearViewOffset(),this.orthographicCamera.clearViewOffset(),this.computeProjectionMatrix()},t.prototype.updateProjectionMatrix=function(){this.perspectiveCamera.updateProjectionMatrix(),this.orthographicCamera.updateProjectionMatrix(),this.computeProjectionMatrix()},Object.defineProperty(t.prototype,"perspectiveProjectionMatrix",{get:function(){return this.perspectiveCamera.projectionMatrix},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"perspectiveProjectionMatrixInverse",{get:function(){return this.perspectiveCamera.projectionMatrixInverse},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"orthographicProjectionMatrix",{get:function(){return this.orthographicCamera.projectionMatrix},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"orthographicProjectionMatrixInverse",{get:function(){return this.orthographicCamera.projectionMatrixInverse},enumerable:!1,configurable:!0}),t.prototype.updateTime=function(e,r){var i=!1;if((this.lastValues.fov!==this.fov||this.lastValues.near!==this.near||this.lastValues.far!==this.far||this.lastValues.aspect!==this.aspect)&&(this.perspectiveCamera.fov=this.fov,this.perspectiveCamera.near=this.near,this.perspectiveCamera.far=this.far,this.perspectiveCamera.aspect=this.aspect,this.perspectiveCamera.updateProjectionMatrix(),i=!0),!this.lastValues.position.equals(this.position)||!this.lastValues.quaternion.equals(this.quaternion)||!this.lastValues.scale.equals(this.scale)||!this.lastValues.perspToOrtho.equals(this.perspToOrtho)||this.lastValues.fov!==this.fov||this.lastValues.near!==this.near||this.lastValues.far!==this.far||this.lastValues.aspect!==this.aspect){var a=Math.max(this.orthoDistance,.01)*Math.tan(.5*this.fov/180*Math.PI),o=-.5*this.aspect*2*a;this.orthographicCamera.left=o,this.orthographicCamera.right=-o,this.orthographicCamera.top=a,this.orthographicCamera.bottom=-a,this.orthographicCamera.updateProjectionMatrix(),i=!0}i&&this.computeProjectionMatrix(),this.lastValues.position.copy(this.position),this.lastValues.quaternion.copy(this.quaternion),this.lastValues.scale.copy(this.scale),this.lastValues.fov=this.fov,this.lastValues.aspect=this.aspect,this.lastValues.near=this.near,this.lastValues.far=this.far,this.lastValues.perspToOrtho.copy(this.perspToOrtho),this.type=this.perspToOrtho.x<1?"PerspectiveCamera":"OrthographicCamera"},Object.defineProperty(t.prototype,"isPerspectiveCamera",{get:function(){return this.perspToOrtho.x<1},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"isOrthographicCamera",{get:function(){return this.perspToOrtho.x>=1},enumerable:!1,configurable:!0}),t.prototype.copy=function(e,r){return n.prototype.copy.call(this,e,r),this.fov=e.fov,this.aspect=e.aspect,this.near=e.near,this.far=e.far,this.perspToOrtho.copy(e.perspToOrtho),this.updateTime(ve(),0),this},t}(d.Camera),bt;(function(n){n[n.Outside=-1]="Outside",n[n.Intersecting=0]="Intersecting",n[n.Inside=1]="Inside"})(bt||(bt={}));var du=1e-6,Ne=new d.Vector3,Br=new d.Matrix4,Mr=new d.Vector3,Cr=new d.Vector3,Ir=new d.Vector3,ya=new d.Vector3,Fo=new d.Box3,Oo=new d.Sphere,ko=new d.Matrix4,Lo=new d.Ray,gt=new d.Object3D,Do=new d.Frustum;function fu(n,t){var e=n.elements;return t.setFromRotationMatrix(Br.set(e[0],e[3],e[6],0,e[1],e[4],e[7],0,e[2],e[5],e[8],0,0,0,0,1)),t}var Pn=function(){function n(t){t===void 0&&(t=[]),this.planes=t}return Object.defineProperty(n,"MASK_OUTSIDE",{get:function(){return 4294967295},enumerable:!1,configurable:!0}),Object.defineProperty(n,"MASK_INSIDE",{get:function(){return 0},enumerable:!1,configurable:!0}),Object.defineProperty(n,"MASK_INDETERMINATE",{get:function(){return 2147483647},enumerable:!1,configurable:!0}),n.prototype.setFromFrustum=function(t){return this.planes=t.planes.map(function(e){return e.clone()}),this},n.prototype.setFromCamera=function(t){return Br.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse),Do.setFromProjectionMatrix(Br),this.setFromFrustum(Do),this},n.prototype.computeVisibility=function(t){for(var e=bt.Inside,r=0,i=this.planes;r<i.length;r++){var a=i[r],o=t.intersectPlane(a);switch(o){case bt.Outside:return bt.Outside;case bt.Intersecting:e=bt.Intersecting;break}}return e},n.prototype.computeVisibilityWithPlaneMask=function(t,e){if(e===n.MASK_OUTSIDE||e===n.MASK_INSIDE)return e;for(var r=n.MASK_INSIDE,i=Math.min(32,this.planes.length),a=0;a<i;++a){var o=1<<a;if(e&o){var s=this.planes[a],u=t.intersectPlane(s);if(u===bt.Outside)return n.MASK_OUTSIDE;u===bt.Intersecting&&(r|=o)}}return r},n}(),hu=function(){function n(){this.type="box",this.center=new d.Vector3,this.halfSize=new d.Vector3,this.rotation=new d.Matrix3}return n.prototype.fromJson=function(t){var e=t.box;this.center.set(e[0],e[1],e[2]);var r=e[3],i=e[4],a=e[5],o=e[6],s=e[7],u=e[8],c=e[9],l=e[10],h=e[11],p=Math.sqrt(r*r+i*i+a*a),v=Math.sqrt(o*o+s*s+u*u),m=Math.sqrt(c*c+l*l+h*h);this.halfSize.set(p,v,m);var A=this.halfSize.toArray().reduce(function(y,f){return y+f},0);return(isNaN(A)||A<=0)&&this.halfSize.setScalar(du),this.rotation.fromArray([r/p,i/p,a/p,o/v,s/v,u/v,c/m,l/m,h/m]),isNaN(this.rotation.toArray().reduce(function(y,f){return y+f},0))&&this.rotation.identity(),this},n.prototype.toJson=function(){return this.rotation.extractBasis(Mr,Cr,Ir),{box:at(at(at(at([],this.center.toArray(),!0),Mr.multiplyScalar(this.halfSize.x).toArray(),!0),Cr.multiplyScalar(this.halfSize.y).toArray(),!0),Ir.multiplyScalar(this.halfSize.z).toArray(),!0)}},n.prototype.copy=function(t){return this.center.copy(t.center),this.halfSize.copy(t.halfSize),this.rotation.copy(t.rotation),this},n.prototype.clone=function(){return new n().copy(this)},n.prototype.applyMatrix4=function(t){return gt.position.copy(this.center),fu(this.rotation,gt.quaternion),gt.scale.copy(this.halfSize),gt.matrix.compose(gt.position,gt.quaternion,gt.scale),gt.matrix.premultiply(t),gt.matrix.decompose(gt.position,gt.quaternion,gt.scale),this.center.copy(gt.position),this.rotation.setFromMatrix4(Br.makeRotationFromQuaternion(gt.quaternion)),this.halfSize.copy(gt.scale),this},n.prototype.getCenter=function(t){return t.copy(this.center)},n.prototype.distanceSquaredTo=function(t){var e=this.rotation.elements,r=t.x-this.center.x,i=t.y-this.center.y,a=t.z-this.center.z,o=0,s;return s=r*e[0]+i*e[1]+a*e[2],s<0&&(s=-s),s-=this.halfSize.x,s>0&&(o+=s*s),s=r*e[3]+i*e[4]+a*e[5],s<0&&(s=-s),s-=this.halfSize.y,s>0&&(o+=s*s),s=r*e[6]+i*e[7]+a*e[8],s<0&&(s=-s),s-=this.halfSize.z,s>0&&(o+=s*s),o},n.prototype.distanceTo=function(t){return Math.sqrt(this.distanceSquaredTo(t))},n.prototype.getBoundingBox=function(t){return t.makeEmpty(),this.rotation.extractBasis(Mr,Cr,Ir),Mr.setLength(this.halfSize.x),Cr.setLength(this.halfSize.y),Ir.setLength(this.halfSize.z),t.expandByPoint(Ne.copy(this.center).add(Mr)),t.expandByPoint(Ne.copy(this.center).sub(Mr)),t.expandByPoint(Ne.copy(this.center).add(Cr)),t.expandByPoint(Ne.copy(this.center).sub(Cr)),t.expandByPoint(Ne.copy(this.center).add(Ir)),t.expandByPoint(Ne.copy(this.center).sub(Ir)),t},n.prototype.toGeometry=function(){var t=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]),e=new Float32Array(8*3);Ne.set(this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,0),Ne.set(-this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,3),Ne.set(-this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,6),Ne.set(this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,9),Ne.set(this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,12),Ne.set(-this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,15),Ne.set(-this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,18),Ne.set(this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,21);var r=new d.BufferGeometry;return r.setIndex(new d.BufferAttribute(t,1)),r.setAttribute("position",new d.BufferAttribute(e,3)),r.computeBoundingBox(),r.computeBoundingSphere(),r},n.prototype.intersectPlane=function(t){var e=this.center,r=t.normal,i=this.rotation.elements,a=this.halfSize,o=r.x,s=r.y,u=r.z,c=Math.abs(o*i[0]*a.x+s*i[1]*a.x+u*i[2]*a.x)+Math.abs(o*i[3]*a.y+s*i[4]*a.y+u*i[5]*a.y)+Math.abs(o*i[6]*a.z+s*i[7]*a.z+u*i[8]*a.z),l=r.dot(e)+t.constant;return l<=-c?bt.Outside:l>=c?bt.Inside:bt.Intersecting},n.prototype.intersectRay=function(t,e){ya.copy(this.halfSize).multiplyScalar(2),Fo.setFromCenterAndSize(Ne.set(0,0,0),ya),this.rotation.extractBasis(Mr,Cr,Ir),Br.makeBasis(Mr,Cr,Ir),Br.setPosition(this.center),ko.getInverse(Br),Lo.copy(t).applyMatrix4(ko);var r=Lo.intersectBox(Fo,Ne);return r?e!==void 0?r.applyMatrix4(Br).distanceTo(t.origin)<e:!0:!1},n}(),pu=function(){function n(){this.type="sphere",this.center=new d.Vector3,this.radius=-1}return n.prototype.fromJson=function(t){var e=t.sphere;return this.center.set(e[0],e[1],e[2]),this.radius=Math.max(e[3],du),this},n.prototype.toJson=function(){return{sphere:at(at([],this.center.toArray(),!0),[this.radius],!1)}},n.prototype.copy=function(t){return this.center.copy(t.center),this.radius=t.radius,this},n.prototype.clone=function(){return new n().copy(this)},n.prototype.getBoundingBox=function(t){return t.setFromCenterAndSize(this.center,ya.set(1,1,1).multiplyScalar(this.radius*2)),t},n.prototype.toGeometry=function(){for(var t=32,e=new Float32Array(t*3*2*2),r=0;r<=t;r++){var i=0;i=r/t*Math.PI*2,e[r*6+0]=this.center.x+Math.cos(i)*this.radius,e[r*6+1]=this.center.y+Math.sin(i)*this.radius,e[r*6+2]=this.center.z+0,i=(r+1)/t*Math.PI*2,e[r*6+3]=this.center.x+Math.cos(i)*this.radius,e[r*6+4]=this.center.y+Math.sin(i)*this.radius,e[r*6+5]=this.center.z+0}for(var r=t;r<=t*2;r++){var i=0;i=r/t*Math.PI*2,e[r*6+0]=this.center.x+Math.cos(i)*this.radius,e[r*6+1]=this.center.y+0,e[r*6+2]=this.center.z+Math.sin(i)*this.radius,i=(r+1)/t*Math.PI*2,e[r*6+3]=this.center.x+Math.cos(i)*this.radius,e[r*6+4]=this.center.y+0,e[r*6+5]=this.center.z+Math.sin(i)*this.radius}var a=new d.BufferGeometry;return a.setAttribute("position",new d.BufferAttribute(e,3)),a.computeBoundingBox(),a.computeBoundingSphere(),a},n.prototype.applyMatrix4=function(t){return this.center.applyMatrix4(t),this.radius=this.radius*t.getMaxScaleOnAxis(),this},n.prototype.getCenter=function(t){return t.copy(this.center)},n.prototype.distanceSquaredTo=function(t){var e=this.distanceTo(t);return e*e},n.prototype.distanceTo=function(t){var e=this.center.distanceTo(t)-this.radius;return e<=0?0:e},n.prototype.intersectPlane=function(t){var e=this.center,r=this.radius,i=t.normal,a=i.dot(e)+t.constant;return a<-r?bt.Outside:a<r?bt.Intersecting:bt.Inside},n.prototype.intersectRay=function(t,e){Oo.set(this.center,this.radius);var r=t.intersectSphere(Oo,Ne);return r?e!==void 0?t.origin.distanceTo(r)<e:!0:!1},n}(),Mc=function(){function n(){throw this.type="regin",this.west=0,this.south=0,this.east=0,this.north=0,this.minHeight=0,this.maxHeight=0,new Error("Region bounding volume not supported.")}return n.prototype.fromJson=function(t){var e=t.region;return this.west=e[0],this.south=e[1],this.east=e[2],this.north=e[3],this.minHeight=e[4],this.maxHeight=e[5],this},n.prototype.toJson=function(){return{region:[this.west,this.south,this.east,this.north,this.minHeight,this.maxHeight]}},n.prototype.copy=function(t){return this.west=t.west,this.south=t.south,this.east=t.east,this.north=t.north,this.minHeight=t.minHeight,this.maxHeight=t.maxHeight,this},n.prototype.clone=function(){return new n().copy(this)},n.prototype.getBoundingBox=function(t){throw new Error("not implemented")},n.prototype.toGeometry=function(){throw new Error("not implemented")},n.prototype.applyMatrix4=function(t){throw new Error("not implemented")},n.prototype.getCenter=function(t){throw new Error("not implemented")},n.prototype.distanceTo=function(t){throw new Error("not implemented")},n.prototype.distanceSquaredTo=function(t){throw new Error("not implemented")},n.prototype.intersectPlane=function(t){throw new Error("not implemented")},n.prototype.intersectRay=function(t){throw new Error("not implemented")},n}();function Bn(n){if("box"in n)return new hu().fromJson(n);if("sphere"in n)return new pu().fromJson(n);if("region"in n)return new Mc().fromJson(n);throw new Error("BoundingVolume ".concat(JSON.stringify(n)," never suppored."))}var Kn=[2621517,3801199,4915345,5963950,7274706,8782079,9575167,10434047,11623423,12482559,13274879,13870335,14464511,15125247,15852031,16446719].map(function(n){return new d.LineBasicMaterial({color:n,depthWrite:!1,transparent:!0})}),Cc=function(){var n=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]),t=new Float32Array(8*3);Ne.set(1,1,1).toArray(t,0),Ne.set(-1,1,1).toArray(t,3),Ne.set(-1,-1,1).toArray(t,6),Ne.set(1,-1,1).toArray(t,9),Ne.set(1,1,-1).toArray(t,12),Ne.set(-1,1,-1).toArray(t,15),Ne.set(-1,-1,-1).toArray(t,18),Ne.set(1,-1,-1).toArray(t,21);var e=new d.BufferGeometry;return e.setIndex(new d.BufferAttribute(n,1)),e.setAttribute("position",new d.BufferAttribute(t,3)),e.computeBoundingBox(),e.computeBoundingSphere(),e}(),Ic=function(){for(var n=32,t=new Float32Array(n*3*2*2),e=0;e<=n;e++){var r=0;r=e/n*Math.PI*2,t[e*6+0]=Math.cos(r),t[e*6+1]=Math.sin(r),t[e*6+2]=0,r=(e+1)/n*Math.PI*2,t[e*6+3]=Math.cos(r),t[e*6+4]=Math.sin(r),t[e*6+5]=0}for(var e=n;e<=n*2;e++){var r=0;r=e/n*Math.PI*2,t[e*6+0]=Math.cos(r),t[e*6+1]=0,t[e*6+2]=Math.sin(r),r=(e+1)/n*Math.PI*2,t[e*6+3]=Math.cos(r),t[e*6+4]=0,t[e*6+5]=Math.sin(r)}var i=new d.BufferGeometry;return i.setAttribute("position",new d.BufferAttribute(t,3)),i.computeBoundingBox(),i.computeBoundingSphere(),i}();function Sc(n,t){if(n instanceof hu){var e=new d.LineSegments(Cc,Kn[Math.min(t,Kn.length-1)]);return e.position.copy(n.center),fu(n.rotation,e.quaternion),e.scale.set(n.halfSize.x,n.halfSize.y,n.halfSize.z),e.matrix.compose(e.position,e.quaternion,e.scale),e}else if(n instanceof pu){var e=new d.LineSegments(Ic,Kn[Math.min(t,Kn.length-1)]);return e.position.copy(n.center),e.scale.set(n.radius,n.radius,n.radius),e.matrix.compose(e.position,e.quaternion,e.scale),e}throw new Error("never")}var _a=function(){function n(t,e,r,i){var a=this,o,s,u;this.parent=null,this.id=t,this.state={visible:!1,frameNumber:0,selectedFrameNumber:0,requestedFrameNumber:0,touchedFrameNumber:0,selectionDepth:0,shouldRefine:!1,distanceToCamera:0,screenSpaceError:0,visibilityPlaneMask:0,inRequestVolume:!1},this.parent=i??null,this.tileset=r,this.refine=(o=e.refine)!==null&&o!==void 0?o:this.parent?this.parent.refine:"REPLACE",this.transform=new d.Matrix4,e.transform&&this.transform.fromArray(e.transform),this.parent&&this.transform.premultiply(this.parent.transform),typeof e.geometricError=="number"?this.geometricError=e.geometricError*this.transform.getMaxScaleOnAxis():this.geometricError=(u=(s=this.parent)===null||s===void 0?void 0:s.geometricError)!==null&&u!==void 0?u:0,e.content&&e.content.uri?(this.content={uri:e.content.uri,loadState:"UNLOADED",byteLength:0},e.content.group!==void 0&&(this.content.group=e.content.group),e.content.boundingVolume&&(this.content.boundingVolume=Bn(e.content.boundingVolume).applyMatrix4(this.transform)),/\.json$/.test(this.content.uri)?this.type="TILESET":this.type="SCENEGRAPH"):(this.content=null,this.type="EMPTY"),e.boundingVolume&&(this.boundingVolume=Bn(e.boundingVolume).applyMatrix4(this.transform)),e.viewerRequestVolume&&(this.viewerRequestVolume=Bn(e.viewerRequestVolume).applyMatrix4(this.transform)),this.extras=e.extras||{},e.children?this.children=e.children.map(function(c,l){return new n("".concat(a.id,".").concat(l),c,r,a)}):this.children=[]}return n.prototype.updateState=function(t){this.state.frameNumber=t.frameNumber;var e=this.tileset.transformIsIdentity?null:this.tileset.transform;if(this.boundingVolume){var r=e?this.boundingVolume.clone().applyMatrix4(e):this.boundingVolume;this.state.distanceToCamera=r.distanceTo(t.camera.position);var i=this.parent?this.parent.state.visibilityPlaneMask:Pn.MASK_INDETERMINATE;this.state.visibilityPlaneMask=t.cullingVolume.computeVisibilityWithPlaneMask(r,i),this.state.visible=this.state.visibilityPlaneMask!==Pn.MASK_OUTSIDE}else this.state.distanceToCamera=0,this.state.visibilityPlaneMask=Pn.MASK_INDETERMINATE,this.state.visible=!0;if(this.viewerRequestVolume){var a=e?this.viewerRequestVolume.clone().applyMatrix4(e):this.viewerRequestVolume;this.state.inRequestVolume=a.distanceSquaredTo(t.camera.position)<=0}else this.state.inRequestVolume=!0;this.state.screenSpaceError=this.getScreenSpaceError(t,this.state.distanceToCamera,!1)},Object.defineProperty(n.prototype,"selected",{get:function(){return this.state.selectedFrameNumber===this.tileset.frameNumber},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"hasChildren",{get:function(){return this.children.length>0},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"siblingIndex",{get:function(){var t,e;return(e=(t=this.parent)===null||t===void 0?void 0:t.children.indexOf(this))!==null&&e!==void 0?e:0},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"hasTilesetContent",{get:function(){return this.children.length>0&&this.type==="TILESET"},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"hasRenderContent",{get:function(){return this.type==="MESH"||this.type==="SCENEGRAPH"},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"contentAvailable",{get:function(){var t;return this.hasRenderContent&&((t=this.content)===null||t===void 0?void 0:t.loadState)==="READY"},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"hasUnloadedContent",{get:function(){var t;return((t=this.content)===null||t===void 0?void 0:t.loadState)==="UNLOADED"},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"hasEmptyContent",{get:function(){return this.type==="EMPTY"},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"contentReady",{get:function(){var t;return((t=this.content)===null||t===void 0?void 0:t.loadState)==="READY"||this.hasEmptyContent},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"contentByteLength",{get:function(){return this.content?this.content.byteLength:0},enumerable:!1,configurable:!0}),n.prototype.loadContent=function(){var t=this,e;if(this.hasEmptyContent||!(!((e=this.content)===null||e===void 0)&&e.uri))return Promise.resolve(!1);var r=this.content;return r.data?Promise.resolve(!0):(r.loadState="LOADING",this.tileset.requestScheduler.scheduleRequest(this.id,function(){return t.getPriority()}).then(function(i){return i?t.tileset.options.contentLoader(t).then(function(a){return i.done(),r.loadState=a?"READY":"UNLOADED",a}).catch(function(a){return r.loadState="FAILED",i.done(),Promise.reject(a)}):(r.loadState="UNLOADED",Promise.resolve(!1))}))},n.prototype.unloadContent=function(){return this.content&&(this.content.loadState="UNLOADED",this.content.byteLength=0),!0},n.prototype.getScreenSpaceError=function(t,e,r){var i=this.tileset.transformIsIdentity?1:this.tileset.transform.getMaxScaleOnAxis(),a=this.parent?this.parent.geometricError:this.tileset.geometricError,o=i*(r?a:this.geometricError);if(o===0)return 0;var s=Math.max(e,.001),u=o*t.height/(s*t.sseDenominator);return u},n.prototype.getPriority=function(){var t=this.refine==="ADD"||this.tileset.skipLevelOfDetail;if(t&&!this.state.visible||this.tileset.frameNumber-this.state.touchedFrameNumber>=1||this.content.loadState==="UNLOADED")return-1;var e=this.parent,r=e&&(!t||this.state.screenSpaceError===0),i=r?e.state.screenSpaceError:this.state.screenSpaceError,a=this.tileset.root?this.tileset.root.state.screenSpaceError:0,o=Math.max(a-i,0);return o},n}(),ba=function(){function n(){this.maxRequests=n.DEFAULT_MAX_REQUESTS,this.activeRequests=0,this.requestQueue=[],this.requestMap=new Map,this.deferred=null}return n.prototype.scheduleRequest=function(t,e){var r=this.requestMap.get(t);if(r)return r;var i={identiy:t,priority:0,getPriority:e,resolve:function(){}},a=new Promise(function(o){return i.resolve=o});return this.requestQueue.push(i),this.requestMap.set(t,a),this.issueNewRequests(),a},n.prototype.reset=function(){for(var t=0,e=this.requestQueue;t<e.length;t++){var r=e[t];r.resolve(null)}this.requestQueue.length=0,this.requestMap.clear(),this.activeRequests=0},n.prototype.issueRequest=function(t){var e=this,r=t.identiy,i=t.resolve,a=!1,o=function(){a||(a=!0,e.requestMap.delete(r),e.activeRequests--,e.issueNewRequests())};this.activeRequests++,i({done:o})},n.prototype.issueNewRequests=function(){var t=this;this.deferred||(this.deferred=setTimeout(function(){return t.issueNewRequestsAsync()},0))},n.prototype.issueNewRequestsAsync=function(){this.deferred=null;var t=Math.max(this.maxRequests-this.activeRequests,0);if(t!==0){this.updateAllRequests();for(var e=0;e<t;e++){var r=this.requestQueue.shift();if(r)this.issueRequest(r);else break}}},n.prototype.updateAllRequests=function(){for(var t=this.requestQueue,e=0;e<t.length;e++){var r=t[e];this.updateRequest(r)===!1&&(t.splice(e,1),this.requestMap.delete(r.identiy),e--)}t.sort(function(i,a){return i.priority-a.priority})},n.prototype.updateRequest=function(t){return t.priority=t.getPriority(t.identiy),t.priority<0?(t.resolve(null),!1):!0},n.DEFAULT_MAX_REQUESTS=6,n}(),Tc=function(){function n(t,e,r){this.item=t,this.previous=e,this.next=r}return n}(),Pc=function(){function n(){this.head=null,this.tail=null,this._length=0}return Object.defineProperty(n.prototype,"length",{get:function(){return this._length},enumerable:!1,configurable:!0}),n.prototype.add=function(t){var e=new Tc(t,this.tail,null);return this.tail?(this.tail.next=e,this.tail=e):(this.head=e,this.tail=e),this._length++,e},n.prototype.remove=function(t){t.previous&&t.next?(t.previous.next=t.next,t.next.previous=t.previous):t.previous?(t.previous.next=null,this.tail=t.previous):t.next?(t.next.previous=null,this.head=t.next):(this.head=null,this.tail=null),t.next=null,t.previous=null,this._length--},n.prototype.splice=function(t,e){t!==e&&(this.remove(e),this.insert(t,e))},n.prototype.insert=function(t,e){var r=t.next;t.next=e,this.tail===t?this.tail=e:r.previous=e,e.next=r,e.previous=t,this._length++},n.prototype.toArray=function(){for(var t=[],e=this.head;e;)t.push(e),e=e.next;return t},n}(),vu=function(){function n(){this.cacheNodeMap=new Map,this.list=new Pc,this.sentinel=this.list.add("sentinel")}return n.prototype.reset=function(){this.list.tail&&this.list.splice(this.list.tail,this.sentinel)},n.prototype.touch=function(t){var e=this.cacheNodeMap.get(t);e&&this.list.splice(this.sentinel,e)},n.prototype.add=function(t,e){if(!this.cacheNodeMap.has(t)){var r=this.list.add(t);this.cacheNodeMap.set(t,r),e&&e(t)}},n.prototype.unloadTile=function(t,e){var r=this.cacheNodeMap.get(t);r&&(this.list.remove(r),this.cacheNodeMap.delete(t),e&&e(t))},n.prototype.unloadTiles=function(t,e){for(var r=this.list.head;r!==this.sentinel&&t();){var i=r.item;r=r.next,this.unloadTile(i,e)}},n.prototype.toArray=function(){for(var t=[],e=0,r=this.list.toArray();e<r.length;e++){var i=r[e];i.item!=="sentinel"&&t.push(i.item)}return t},n}(),No=function(){function n(){this.map=new Map,this.array=[],this._length=0}return Object.defineProperty(n.prototype,"length",{get:function(){return this._length},enumerable:!1,configurable:!0}),n.prototype.get=function(t){return this.array[t]},n.prototype.set=function(t,e){t>=this.length&&(this._length=t+1),this.map.has(this.array[t])&&this.map.delete(this.array[t]),this.array[t]=e,this.map.set(e,t)},n.prototype.delete=function(t){var e=this.map.get(t);e!==void 0&&e>=0&&(this.array.splice(e,1),this.map.delete(t),this._length--)},n.prototype.push=function(t){if(!this.map.has(t)){var e=this._length++;this.array[e]=t,this.map.set(t,e)}},n.prototype.pop=function(){var t=this.array[--this._length];return this.map.delete(t),t},n.prototype.reset=function(){this.array=[],this.map=new Map,this._length=0},n.prototype.find=function(t){return this.map.has(t)},n}(),wa=function(){function n(){this.loadSiblings=n.DEFAULT_LOAD_SIBLINGS,this.skipLevelOfDetail=n.DEFAULT_SKIP_LEVEL_OF_DETAIL,this.maxScreenSpaceError=n.DEFAULT_MAX_SCREEN_SPACE_ERROR,this._canSelectTile=!0,this._traversalStack=new No,this._emptyTraversalStack=new No,this.root=null,this.selectedTiles=new Map,this.requestedTiles=new Map,this.needsRefinedTiles=new Map,this.emptyTiles=new Map}return n.prototype.traverse=function(t,e,r){r===void 0&&(r=[]),this.root=t,this.reset();for(var i=0,a=r;i<a.length;i++){var o=a[i];this._traversalStack.reset(),this._emptyTraversalStack.reset(),this._canSelectTile=o.camera.visible,this.updateTile(t,o),this.executeTraversal(t,o)}this._traversalStack.reset(),this._emptyTraversalStack.reset(),this._canSelectTile=!0,this.updateTile(t,e),this.executeTraversal(t,e)},n.prototype.reset=function(){this.needsRefinedTiles.clear(),this.requestedTiles.clear(),this.selectedTiles.clear(),this.emptyTiles.clear(),this._traversalStack.reset(),this._emptyTraversalStack.reset()},n.prototype.executeTraversal=function(t,e){var r=this._traversalStack;if(t.state.selectionDepth=0,e.maxLevelOfDetail>=0)for(t.state.visible&&t.state.inRequestVolume&&r.push(t);r.length>0;){var i=r.pop(),a=!1;if(this.canTraverse(i,e,!1,!1)){var o=i.hasRenderContent?i.state.selectionDepth+1:i.state.selectionDepth;this.updateChildTiles(i,e,o),a=this.updateAndPushChildren(i,e,r)}var s=i.parent,u=!s||s.state.shouldRefine,c=!a;i.hasRenderContent?i.refine==="ADD"?(this.loadTile(i,e.frameNumber),this.selectTile(i,e)):i.refine==="REPLACE"&&(this.loadTile(i,e.frameNumber),c&&this.selectTile(i,e)):(this.emptyTiles.set(i.id,i),this.loadTile(i,e.frameNumber),c&&this.selectTile(i,e)),this.touchTile(i,e),i.state.shouldRefine=a&&u}},n.prototype.updateChildTiles=function(t,e,r){for(var i=t.children,a=0,o=i;a<o.length;a++){var s=o[a];s.state.selectionDepth=r,this.updateTile(s,e)}return!0},n.prototype.updateAndPushChildren=function(t,e,r){for(var i=t.children,a=t.refine==="REPLACE"&&t.hasRenderContent&&!this.skipLevelOfDetail,o=!1,s=!0,u=0,c=i;u<c.length;u++){var l=c[u];if(l.state.visible&&l.state.inRequestVolume?(r.find(l)&&r.delete(l),r.push(l),o=!0):(a||this.loadSiblings)&&(this.loadTile(l,e.frameNumber),this.touchTile(l,e)),a){var h=void 0;l.state.inRequestVolume?l.hasRenderContent?h=l.contentAvailable:h=this.executeEmptyTraversal(l,e):h=!1,s=s&&h}}return o||(s=!1),s},n.prototype.updateTile=function(t,e){this.updateTileVisibility(t,e)},n.prototype.selectTile=function(t,e){this.shouldSelectTile(t)&&(t.state.selectedFrameNumber=e.frameNumber,this.selectedTiles.set(t.id,t)),this.needsRefinedTiles.set(t.id,t)},n.prototype.loadTile=function(t,e){this.shouldLoadTile(t)&&(t.state.requestedFrameNumber=e,this.requestedTiles.set(t.id,t)),this.needsRefinedTiles.set(t.id,t)},n.prototype.touchTile=function(t,e){t.tileset.cache.touch(t),t.state.touchedFrameNumber=e.frameNumber},n.prototype.canTraverse=function(t,e,r,i){return t.hasChildren?t.hasTilesetContent?!0:!i&&!t.state.visible?!1:this.shouldRefine(t,e,r):!1},n.prototype.shouldLoadTile=function(t){return t.hasUnloadedContent},n.prototype.shouldSelectTile=function(t){return t.contentAvailable&&!this.skipLevelOfDetail&&this._canSelectTile},n.prototype.shouldRefine=function(t,e,r){if(t.hasEmptyContent)return!0;if(t.hasRenderContent){if(t.state.selectionDepth>=e.maxLevelOfDetail)return!1;if(t.state.selectionDepth<e.minLevelOfDetail)return!0}var i=t.state.screenSpaceError;return r&&(i=t.getScreenSpaceError(e,t.state.distanceToCamera,!0)),i>this.maxScreenSpaceError},n.prototype.updateTileVisibility=function(t,e){if(t.updateState(e),!(!t.state.visible||!t.state.inRequestVolume)){var r=t.children.length>0;if(t.hasTilesetContent&&r){var i=t.children[0];this.updateTileVisibility(i,e),t.state.visible=i.state.visible;return}if(this.meetsScreenSpaceErrorEarly(t,e)){t.state.visible=!1;return}}},n.prototype.meetsScreenSpaceErrorEarly=function(t,e){var r=t.parent;return!r||r.refine!=="ADD"?!1:!this.shouldRefine(t,e,!0)},n.prototype.compareDistanceToCamera=function(t,e){return e.state.distanceToCamera-t.state.distanceToCamera},n.prototype.executeEmptyTraversal=function(t,e){var r=!0,i=this._emptyTraversalStack;for(i.push(t);i.length>0&&r;){var a=i.pop();this.updateTile(a,e),a.state.visible||this.loadTile(a,e.frameNumber),this.touchTile(a,e);var o=!a.hasRenderContent&&this.canTraverse(a,e,!1,!0);if(o)for(var s=a.children,u=0,c=s;u<c.length;u++){var l=c[u];i.find(l)&&i.delete(l),i.push(l)}else a.contentAvailable||(r=!1)}return r},n.DEFAULT_SKIP_LEVEL_OF_DETAIL=!1,n.DEFAULT_LOAD_SIBLINGS=!1,n.DEFAULT_MAX_SCREEN_SPACE_ERROR=4,n}(),Bc=new d.Matrix4,ii=function(){function n(t,e,r){var i,a;this.id=t,this.transform=new d.Matrix4,this.transformIsIdentity=!0,this.asset={version:e.asset.version,tilesetVersion:e.asset.tilesetVersion||"",gltfUpAxis:(i=e.asset.gltfUpAxis)!==null&&i!==void 0?i:"Y",overview:e.asset.overview},this.properties=(a=e.properties)!==null&&a!==void 0?a:{},this.options=r,this.traverser=new wa,this.cache=new vu,this.requestScheduler=new ba,this.frameNumber=0,this.pendingCount=0,this.tiles=new Map,this.memoryUsageInBytes=0,this.root=new _a("".concat(this.id,".0"),e.root,this),this.geometricError=e.geometricError,this.maxMemoryUsage=n.DEFAULT_MAX_MEMORY_USAGE}return Object.defineProperty(n.prototype,"maxRequests",{get:function(){return this.requestScheduler.maxRequests},set:function(t){this.requestScheduler.maxRequests=t},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"skipLevelOfDetail",{get:function(){return this.traverser.skipLevelOfDetail},set:function(t){this.traverser.skipLevelOfDetail=t},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"maxScreenSpaceError",{get:function(){return this.traverser.maxScreenSpaceError},set:function(t){this.traverser.maxScreenSpaceError=t},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"selectedTiles",{get:function(){return this.traverser.selectedTiles},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"needsRefinedTiles",{get:function(){return this.traverser.needsRefinedTiles},enumerable:!1,configurable:!0}),n.prototype.reset=function(){for(var t=this,e=[this.root],r;r=e.pop();){for(var i=0,a=r.children.length;i<a;i++)e.push(r.children[i]);this.cache.unloadTile(r,function(o){return t.unloadTile(o)})}this.cache.reset(),this.traverser.reset(),this.requestScheduler.reset(),this.tiles.clear()},n.prototype.isLoaded=function(){return this.pendingCount===0&&this.frameNumber!==0},n.prototype.traverse=function(t,e){var r=this;e===void 0&&(e=[]),this.transformIsIdentity=this.transform.equals(Bc),this.traverser.traverse(this.root,t,e),this.selectedTiles.forEach(function(i){r.tiles.set(i.id,i)}),this.traverser.requestedTiles.forEach(function(i){i.hasUnloadedContent&&r.loadTile(i)}),this.cache.unloadTiles(function(){var i=r.memoryUsageInBytes>r.maxMemoryUsage*1024*1024;return i},function(i){r.unloadTile(i),r.tiles.delete(i.id)})},n.prototype.loadTile=function(t){var e=this;this.pendingCount++,t.loadContent().catch(function(r){return e.options.onTileError(t,r),!1}).then(function(r){var i;e.pendingCount--,r&&(!((i=t.content)===null||i===void 0)&&i.data&&e.cache.add(t,function(){e.memoryUsageInBytes+=t.contentByteLength}),e.options.onTileLoad(t))})},n.prototype.unloadTile=function(t){this.memoryUsageInBytes-=t.contentByteLength,this.options.onTileUnload(t),t.unloadContent()},n.DEFAULT_VIEW_DISTANCE_SCALE=1,n.DEFAULT_MAX_MEMORY_USAGE=16,n.DEFAULT_MAX_SCREEN_SPACE_ERROR=wa.DEFAULT_MAX_SCREEN_SPACE_ERROR,n.DEFAULT_MAX_REQUESTS=ba.DEFAULT_MAX_REQUESTS,n}(),cn=function(){function n(t,e,r,i){this.extents=t,this.startIndex=e,this.endIndex=r,this.deepth=i}return n}();function Au(n,t,e,r){r===void 0&&(r=0);var i=e.extents[0]-r,a=e.extents[1]-r,o=e.extents[2]-r,s=e.extents[3]+r,u=e.extents[4]+r,c=e.extents[5]+r,l={min:0,max:0};t.x>=0?(l.min=(i-n.x)*t.x,l.max=(s-n.x)*t.x):(l.min=(s-n.x)*t.x,l.max=(i-n.x)*t.x);var h={min:0,max:0};if(t.y>=0?(h.min=(a-n.y)*t.y,h.max=(u-n.y)*t.y):(h.min=(u-n.y)*t.y,h.max=(a-n.y)*t.y),l.min>h.max||h.min>l.max)return!1;h.min>l.min&&(l.min=h.min),h.max<l.max&&(l.max=h.max);var p={min:0,max:0};return t.z>=0?(p.min=(o-n.z)*t.z,p.max=(c-n.z)*t.z):(p.min=(c-n.z)*t.z,p.max=(o-n.z)*t.z),!(l.min>p.max||p.min>l.max||(p.min>l.min&&(l.min=p.min),p.max<l.max&&(l.max=p.max),l.max<0))}var mu=function(){function n(t,e,r){this.x=t,this.y=e,this.z=r}return n.prototype.copy=function(t){return this.x=t.x,this.y=t.y,this.z=t.z,this},n.prototype.set=function(t,e,r){return this.x=t,this.y=e,this.z=r,this},n.prototype.fromArray=function(t,e){return e===void 0&&(e=0),this.x=t[e],this.y=t[e+1],this.z=t[e+2],this},n.prototype.toArray=function(t,e){return t===void 0&&(t=[]),e===void 0&&(e=0),t[e]=this.x,t[e+1]=this.y,t[e+2]=this.z,t},n.prototype.add=function(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z,this},n.prototype.multiplyScalar=function(t){return this.x*=t,this.y*=t,this.z*=t,this},n.prototype.subVectors=function(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this.z=t.z-e.z,this},n.prototype.addScaledVector=function(t,e){return this.x+=t.x*e,this.y+=t.y*e,this.z+=t.z*e,this},n.prototype.dot=function(t){return this.x*t.x+this.y*t.y+this.z*t.z},n.prototype.cross=function(t){var e=this.x,r=this.y,i=this.z;return this.x=r*t.z-i*t.y,this.y=i*t.x-e*t.z,this.z=e*t.y-r*t.x,this},n.prototype.crossVectors=function(t,e){var r=t.x,i=t.y,a=t.z,o=e.x,s=e.y,u=e.z;return this.x=i*u-a*s,this.y=a*o-r*u,this.z=r*s-i*o,this},n.prototype.distanceTo=function(t){return Math.sqrt(this.distanceToSquared(t))},n.prototype.distanceToSquared=function(t){var e=this.x-t.x,r=this.y-t.y,i=this.z-t.z;return e*e+r*r+i*i},n.prototype.clone=function(){return new n(this.x,this.y,this.z)},n}(),gu=function(){function n(t,e,r){this.triangle=t,this.intersectionPoint=e,this.index=r}return n}(),Qo=1e-6,Rc=function(){function n(t,e){if(this.positionArray=t,e)this.indicesArray=e;else{for(var r=t.length/3,i=new Uint32Array(r),a=0;a<r;a++)i[a]=a;this.indicesArray=i}}return n.prototype.createTree=function(t,e,r){var i=this.positionArray,a=this.indicesArray,o=a.length/3,s=new Uint32Array(o),u=new Float32Array(o*6),c=[],l=0;if(r)for(var h=0,p=0,v=0,m=void 0,A=void 0,y=void 0,f=void 0,g=void 0,b=void 0,w=void 0;h<o;h+=1,p+=3,v+=6)s[h]=h,m=f=i[a[p]*3],w=i[a[p+1]*3],w<m&&(m=w),w>f&&(f=w),w=i[a[p+2]*3],w<m&&(m=w),w>f&&(f=w),A=g=i[a[p]*3+1],w=i[a[p+1]*3+1],w<A&&(A=w),w>g&&(g=w),w=i[a[p+2]*3+1],w<A&&(A=w),w>g&&(g=w),y=b=i[a[p]*3+2],w=i[a[p+1]*3+2],w<y&&(y=w),w>b&&(b=w),w=i[a[p+2]*3+2],w<y&&(y=w),w>b&&(b=w),u[v]=m,u[v+1]=A,u[v+2]=y,u[v+3]=f,u[v+4]=g,u[v+5]=b;else{for(var E=1/0,x=1/0,M=1/0,C=-1/0,I=-1/0,P=-1/0,h=0,p=0,v=0,m=void 0,A=void 0,y=void 0,f=void 0,g=void 0,b=void 0,w=void 0;h<o;h+=1,p+=3,v+=6)s[h]=h,m=f=i[a[p]*3],w=i[a[p+1]*3],w<m&&(m=w),w>f&&(f=w),w=i[a[p+2]*3],w<m&&(m=w),w>f&&(f=w),A=g=i[a[p]*3+1],w=i[a[p+1]*3+1],w<A&&(A=w),w>g&&(g=w),w=i[a[p+2]*3+1],w<A&&(A=w),w>g&&(g=w),y=b=i[a[p]*3+2],w=i[a[p+1]*3+2],w<y&&(y=w),w>b&&(b=w),w=i[a[p+2]*3+2],w<y&&(y=w),w>b&&(b=w),u[v]=m,u[v+1]=A,u[v+2]=y,u[v+3]=f,u[v+4]=g,u[v+5]=b,m<E&&(E=m),f>C&&(C=f),A<x&&(x=A),g>I&&(I=g),y<M&&(M=y),b>P&&(P=b);r=[E,x,M,C,I,P]}var S=new cn(r,0,o,0);c[l++]=S;function F(k){for(var O=k.startIndex,L=k.endIndex,N=k.extents,V=[N[3]-N[0],N[4]-N[1],N[5]-N[2]],j=[0,1,2].sort(function($,te){return V[te]-V[$]}),z=0;z<3;z++){for(var U=j[z],X=N[U]+N[U+3],G=O,K=L-1,Y=-1,H=void 0;G<=K;)Y===-1?(H=s[G],u[H*6+U]+u[H*6+U+3]<X?G++:Y=H):(H=s[K],u[H*6+U]+u[H*6+U+3]>=X||(s[G]=H,s[K]=Y,Y=-1,G++),K--);if(G>O&&G<L){var J=new cn(Vo(s,u,O,G,Qo),O,G,k.deepth+1);J.deepth<e&&J.endIndex-J.startIndex>t&&(c[l++]=J);var ne=new cn(Vo(s,u,G,L,Qo),G,L,k.deepth+1);ne.deepth<e&&ne.endIndex-ne.startIndex>t&&(c[l++]=ne),k.node0=J,k.node1=ne,k.startIndex=0,k.endIndex=0;break}}}for(;l;)F(c[--l]);return this.offsetArray=s,this.rootNode=S,c.length=0,this},n.prototype.trianglesInSphere=function(t,e){for(var r=this.positionArray,i=this.indicesArray,a=this.offsetArray,o=this.rootNode,s=[o],u=[],c;c=s.pop();){var l=Hi(t.x,c.extents[0],c.extents[3])-t.x,h=Hi(t.y,c.extents[1],c.extents[4])-t.y,p=Hi(t.z,c.extents[2],c.extents[5])-t.z;if(l*l+h*h+p*p<=e*e){c.node0&&s.push(c.node0),c.node1&&s.push(c.node1);for(var v=c.startIndex;v<c.endIndex;v++)u.push(a[v])}}for(var m=u.length,A=new Float32Array(m*9),v=0;v<m;v++){var y=u[v];A[v*9]=r[i[y]*3],A[v*9+1]=r[i[y]*3+1],A[v*9+2]=r[i[y]*3+2],A[v*9+3]=r[i[y+1]*3],A[v*9+4]=r[i[y+1]*3+1],A[v*9+5]=r[i[y+1]*3+2],A[v*9+6]=r[i[y+2]*3],A[v*9+7]=r[i[y+2]*3+1],A[v*9+8]=r[i[y+2]*3+2]}return A},n.prototype.intersectRay=function(t,e,r){for(var i=this.positionArray,a=this.indicesArray,o=this.offsetArray,s=this.rootNode,u=new mu(1/e.x,1/e.y,1/e.z),c=[s],l;l=c.pop();)if(Au(t,u,l)){for(var h=l.startIndex,p=l.endIndex,v=void 0,m=void 0,A=void 0,y=t.x,f=t.y,g=t.z,b=e.x,w=e.y,E=e.z,x=void 0,M=void 0,C=void 0,I=void 0,P=void 0,S=void 0,F=void 0,k=void 0,O=void 0,L=void 0,N=void 0,V=void 0,j=void 0,z=void 0,U=void 0,X=void 0,G=void 0,K=void 0,Y=void 0,H=void 0,J=void 0,ne=void 0,$=void 0,te=void 0,ae=void 0,ce=void 0,oe=void 0;h<p;h++){if(v=o[h],m=v*3,A=a[m]*3,x=i[A],M=i[++A],C=i[++A],A=a[m+1]*3,I=i[A],P=i[++A],S=i[++A],A=a[m+2]*3,F=i[A],k=i[++A],O=i[++A],L=I-x,N=P-M,V=S-C,j=F-x,z=k-M,U=O-C,X=N*U-V*z,G=V*j-L*U,K=L*z-N*j,$=b*X+w*G+E*K,$>0)ne=1;else if($<0)ne=-1,$=-$;else continue;Y=y-x,H=f-M,J=g-C,te=ne*(b*(H*U-J*z)+w*(J*j-Y*U)+E*(Y*z-H*j)),!(te<0)&&(ae=ne*(b*(N*J-V*H)+w*(V*Y-L*J)+E*(L*H-N*Y)),!(ae<0)&&(te+ae>$||(ce=-ne*(Y*X+H*G+J*K),!(ce<0)&&(oe=ce/$,r.push(new gu([x,M,C,I,P,S,F,k,O],[y+b*oe,f+w*oe,g+E*oe],v))))))}l.node0&&c.push(l.node0),l.node1&&c.push(l.node1)}return r},n}();function Hi(n,t,e){return n<t?t:n>e?e:n}function Vo(n,t,e,r,i){if(e>=r)return[0,0,0,0,0,0];for(var a=1/0,o=1/0,s=1/0,u=-1/0,c=-1/0,l=-1/0,h=e,p=void 0,v=void 0;h<r;h++)p=n[h]*6,v=t[p],v<a&&(a=v),v=t[p+1],v<o&&(o=v),v=t[p+2],v<s&&(s=v),v=t[p+3],v>u&&(u=v),v=t[p+4],v>c&&(c=v),v=t[p+5],v>l&&(l=v);return[a-i,o-i,s-i,u+i,c+i,l+i]}var Uo=1e-6,Fc=function(){function n(t,e){if(this.positionArray=t,e)this.indicesArray=e;else{for(var r=t.length/3,i=new Uint32Array(r),a=0;a<r;a++)i[a]=a;this.indicesArray=i}}return n.prototype.createTree=function(t,e,r){var i=this.positionArray,a=this.indicesArray,o=a.length,s=new Uint32Array(o),u=[],c=0;if(r)for(var l=0;l<o;l+=1)s[l]=l;else{for(var h=a[0]*3,p=i[h],v=i[h+1],m=i[h+2],A=p,y=v,f=m,l=0,g=0,b=void 0,w=void 0,E=void 0;l<o;l+=1,g+=3)s[l]=l,h=a[g]*3,b=i[h],w=i[h+1],E=i[h+2],b<p?p=b:b>A&&(A=b),w<v?v=w:w>y&&(y=w),E<m?m=E:E>f&&(f=E);r=[p,v,m,A,y,f]}var x=new cn(r,0,o,0);u[c++]=x;function M(C){for(var I=C.startIndex,P=C.endIndex,S=C.extents,F=[S[3]-S[0],S[4]-S[1],S[5]-S[2]],k=[0,1,2].sort(function(K,Y){return F[Y]-F[K]})[0],O=(S[k]+S[k+3])/2,L=I,N=P-1,V=-1,j;L<=N;)V===-1?(j=s[L],i[a[j]*3+k]<O?L++:V=j):(j=s[N],i[a[j]*3+k]>=O||(s[L]=j,s[N]=V,V=-1,L++),N--);if(L>I){var z=S.slice();z[k+3]=O+Uo;var U=new cn(z,I,L,C.deepth+1);U.deepth<e&&U.endIndex-U.startIndex>t&&(u[c++]=U),C.node0=U}if(P>L){var X=S.slice();X[k]=O-Uo;var G=new cn(X,L,P,C.deepth+1);G.deepth<e&&G.endIndex-G.startIndex>t&&(u[c++]=G),C.node1=G}C.startIndex=0,C.endIndex=0}for(;c;)M(u[--c]);return this.offsetArray=s,this.rootNode=x,u.length=0,this},n.prototype.intersectRay=function(t,e,r,i){for(var a=this.positionArray,o=this.indicesArray,s=this.offsetArray,u=this.rootNode,c=r*r,l=new mu(1/e.x,1/e.y,1/e.z),h=[u],p;p=h.pop();)if(Au(t,l,p,r)){for(var v=p.startIndex,m=p.endIndex,A=void 0,y=void 0,f=void 0,g=void 0,b=void 0,w=void 0,E=void 0,x=void 0,M=void 0,C=void 0,I=void 0,P=void 0,S=void 0;v<m;v++)A=s[v],y=o[A]*3,f=a[y],g=a[++y],b=a[++y],w=t.x,E=t.y,x=t.z,M=e.x,C=e.y,I=e.z,P=M*(f-w)+C*(g-E)+I*(b-x),P>0&&(w+=M*P,E+=C*P,x+=I*P),M=f-w,C=g-E,I=b-x,P=M*M+C*C+I*I,P<=c&&i.push(new gu([f,g,b,f,g,b,f,g,b],[w,E,x],A));p.node0&&h.push(p.node0),p.node1&&h.push(p.node1)}return i},n}(),ai=new Map,ji=new Map,dn=new d.Ray,qo=new d.Matrix3,Rn=new d.Matrix4,yu=new d.Vector3,Oc=new d.Vector3,kc=new d.Vector3,Lc=new d.Triangle;function Dc(n,t,e,r){var i,a=n.matrixWorld;Rn.getInverse(a),dn.copy(e.ray).applyMatrix4(Rn);for(var o=t.intersectRay(dn.origin,dn.direction,[]),s=n.geometry,u=n.material,c=s.groups,l=s.index,h=0,p=o.length;h<p;h++){var v=o[h],m=v.triangle,A=v.index,y=v.intersectionPoint,f=new d.Vector3(y[0],y[1],y[2]).applyMatrix4(a),g=e.ray.origin.distanceTo(f);if(!(g<e.near||g>e.far)){var b=void 0;if(Array.isArray(u)){if(c)for(var w=A*3,E=0,x=c;E<x.length;E++){var M=x[E];if(w>=M.start&&w-M.start<M.count){b=u[(i=M.materialIndex)!==null&&i!==void 0?i:0];break}}}else b=u;if(b){var C=Lc.set(yu.set(m[0],m[1],m[2]).applyMatrix4(a),Oc.set(m[3],m[4],m[5]).applyMatrix4(a),kc.set(m[6],m[7],m[8]).applyMatrix4(a)).getNormal(new d.Vector3),I=A*3,P=new d.Face3(l?l.array[I]:I,l?l.array[I+1]:I+1,l?l.array[I+2]:I+2,C),S=e.ray.direction.dot(C);b.side===d.FrontSide&&S>=0||b.side===d.BackSide&&S<=0||r.push({distance:g,object:n,face:P,point:f,distanceToRay:0,faceIndex:A})}}}}function Nc(n,t,e,r){var i,a,o=n.matrixWorld;qo.getNormalMatrix(o),Rn.getInverse(o);var s=((a=(i=e.params.Points)===null||i===void 0?void 0:i.threshold)!==null&&a!==void 0?a:1)*Rn.getMaxScaleOnAxis();dn.copy(e.ray).applyMatrix4(Rn);for(var u=t.intersectRay(dn.origin,dn.direction,s,[]),c=n.geometry,l=c.index,h=c.getAttribute("normal"),p=0,v=u.length;p<v;p++){var m=u[p],A=m.triangle,y=m.index,f=m.intersectionPoint,g=new d.Vector3(f[0],f[1],f[2]).applyMatrix4(o),b=e.ray.origin.distanceTo(g);if(!(b<e.near||b>e.far)){var w=yu.set(A[0],A[1],A[2]).applyMatrix4(o),E=l?l.array[y]:y,x=void 0;h instanceof d.BufferAttribute&&(x=new d.Vector3().fromBufferAttribute(h,E).applyNormalMatrix(qo));var M=new d.Face3(E,E,E,x);r.push({distance:b,object:n,face:M,point:g,distanceToRay:g.distanceTo(w),index:y})}}}function Qc(n,t,e){var r;if(t===void 0&&(t=100),e===void 0&&(e=10),n.geometry instanceof d.BufferGeometry){var i=n.geometry.getAttribute("position");if(i instanceof d.BufferAttribute){var a=n.raycast,o=function(p,v){var m=ai.get(this);m?Dc(this,m,p,v):a.call(this,p,v)};n.raycast=o;var s=i.array,u=(r=n.geometry.getIndex())===null||r===void 0?void 0:r.array,c=n.geometry.boundingBox,l=c?[c.min.x,c.min.y,c.min.z,c.max.x,c.max.y,c.max.z]:void 0,h=new Rc(s,u);return h.createTree(t,e,l),ai.set(n,h),function(){ai.delete(n),n.raycast===o&&(n.raycast=a)}}}return function(){}}function Vc(n,t,e){var r;if(t===void 0&&(t=100),e===void 0&&(e=10),n.geometry instanceof d.BufferGeometry){var i=n.geometry.getAttribute("position");if(i instanceof d.BufferAttribute){var a=n.raycast,o=function(p,v){var m=ji.get(this);m?Nc(this,m,p,v):a.call(this,p,v)};n.raycast=o;var s=i.array,u=(r=n.geometry.getIndex())===null||r===void 0?void 0:r.array,c=n.geometry.boundingBox,l=c?[c.min.x,c.min.y,c.min.z,c.max.x,c.max.y,c.max.z]:void 0,h=new Fc(s,u);return h.createTree(t,e,l),ji.set(n,h),function(){ji.delete(n),n.raycast===o&&(n.raycast=a)}}}return function(){}}function Uc(n,t,e){t===void 0&&(t=100),e===void 0&&(e=10);var r=[];return n.traverse(function(i){if(i instanceof d.Mesh){var a=Qc(i,t,e);r.push(a)}else if(i instanceof d.Points){var a=Vc(i,t,e);r.push(a)}}),function(){for(var i=0,a=r;i<a.length;i++){var o=a[i];o()}}}var qc=new d.Vector3,zc=new d.Vector3,Hc=new d.Vector3,bu=function(n){de(t,n);function t(e,r){var i=n.call(this)||this;i.renderOrder=-4;var a=Uc(e,200,10);return i.disposers=[r,a],i.add(e),i}return t.prototype.intersectRaycaster=function(e,r,i){var a=this;r===void 0&&(r=!0),i===void 0&&(i=[]);for(var o=this.children.slice(),s;s=o.pop();)if(s.visible){s.raycast(e,i);for(var u=0,c=s.children.length;u<c;u++)o.push(s.children[u])}return i.forEach(function(l){var h,p,v=0;if((l.object instanceof _t||l.object instanceof Lr)&&l.face){var m=Array.isArray(l.object.material)?l.object.material[l.face.materialIndex]:l.object.material;if(m)if(m.defines.USE_VERTEX_FLOOR){var A=(h=l.object.geometry.attributes.position)===null||h===void 0?void 0:h.array,y=(p=l.object.geometry.attributes.floor)===null||p===void 0?void 0:p.array;if(A&&y){var f=qc.set(A[l.face.a*3],A[l.face.a*3+1],A[l.face.a*3+2]).applyMatrix4(a.matrixWorld),g=zc.set(A[l.face.b*3],A[l.face.b*3+1],A[l.face.b*3+2]).applyMatrix4(a.matrixWorld),b=Hc.set(A[l.face.c*3],A[l.face.c*3+1],A[l.face.c*3+2]).applyMatrix4(a.matrixWorld),w=l.point.distanceTo(f),E=l.point.distanceTo(g),x=l.point.distanceTo(b);v=Math.round((w*y[l.face.a]+E*y[l.face.b]+x*y[l.face.c])/(w+E+x))}}else v=m.floor}l.floor=v}),r&&i.sort(function(l,h){return l.distance-h.distance}),i},t.prototype.dispose=function(){for(var e=0,r=this.disposers;e<r.length;e++){var i=r[e];i()}},t}(d.Group);function It(){for(var n=[],t=0;t<arguments.length;t++)n[t]=arguments[t];var e=[];n=n.map(function(s){return(s??"").trim()}).filter(function(s){return s.length>0&&!/^\/+$/.test(s)});for(var r=0;r<n.length;r++){var i=r===0,a=r===n.length-1,o=n[r];i||(o=o.replace(/^\.\//,"").replace(/^\/+/,"")),a||(o=o.replace(/\/+$/,"")),e.push(o)}return e.join("/")}function yr(n){return n.indexOf("//")===0||/^[0-9a-z]+\:/i.test(n)}function wu(n,t){if(n.content&&n.content.uri&&(yr(n.content.uri)||(n.content.uri=It(t,n.content.uri))),n.children)for(var e=0,r=n.children;e<r.length;e++){var i=r[e];wu(i,t)}return n}function zo(n,t){return n.asset.overview&&(yr(n.asset.overview.imageFile)||(n.asset.overview.imageFile=It(t,n.asset.overview.imageFile)),yr(n.asset.overview.worldFile)||(n.asset.overview.worldFile=It(t,n.asset.overview.worldFile))),wu(n.root,t),n}function Eu(n,t){return(t[0]==="?"||t[0]==="&")&&(t=t.slice(1)),t?((n[n.length-1]==="?"||n[n.length-1]==="&")&&(n=n.slice(0,-1)),n.indexOf("?")>=0?"".concat(n,"&").concat(t):"".concat(n,"?").concat(t)):n}var _i=4;function xu(n,t,e){var r=new DataView(t);if(n.magic=r.getUint32(e,!0),e+=_i,n.version=r.getUint32(e,!0),e+=_i,n.byteLength=r.getUint32(e,!0),e+=_i,n.version!==1)throw new Error("3D Tile Version ".concat(n.version," not supported"));return e}var nr,xe;(function(n){n[n.BYTE=5120]="BYTE",n[n.UNSIGNED_BYTE=5121]="UNSIGNED_BYTE",n[n.SHORT=5122]="SHORT",n[n.UNSIGNED_SHORT=5123]="UNSIGNED_SHORT",n[n.INT=5124]="INT",n[n.UNSIGNED_INT=5125]="UNSIGNED_INT",n[n.FLOAT=5126]="FLOAT",n[n.DOUBLE=5130]="DOUBLE"})(xe||(xe={}));var jc=(nr={},nr[xe.DOUBLE]=Float64Array,nr[xe.FLOAT]=Float32Array,nr[xe.UNSIGNED_SHORT]=Uint16Array,nr[xe.UNSIGNED_INT]=Uint32Array,nr[xe.UNSIGNED_BYTE]=Uint8Array,nr[xe.BYTE]=Int8Array,nr[xe.SHORT]=Int16Array,nr[xe.INT]=Int32Array,nr),_c={DOUBLE:xe.DOUBLE,FLOAT:xe.FLOAT,UNSIGNED_SHORT:xe.UNSIGNED_SHORT,UNSIGNED_INT:xe.UNSIGNED_INT,UNSIGNED_BYTE:xe.UNSIGNED_BYTE,BYTE:xe.BYTE,SHORT:xe.SHORT,INT:xe.INT};function pi(n){var t=jc[n];if(!t)throw new Error("Failed to convert GL type");return t}function Gi(n){var t=pi(n);return t.BYTES_PER_ELEMENT}function Ho(n,t,e,r){e===void 0&&(e=0);var i=pi(n);if(e%Gi(n)!==0){var a=r?t.slice(e,e+r*Gi(n)):t.slice(e);return new i(a)}else return new i(t,e,r??(t.byteLength-e)/Gi(n))}function Gc(n){var t=_c[n];if(!t)throw new Error("Failed to convert GL type");return t}var Mu=function(){function n(t,e){this.featuresLength=0,this.cachedTypedArrays={},this.json=t,this.buffer=e;var r=this.getGlobalProperty("POINTS_LENGTH",xe.UNSIGNED_INT,1);r&&r.length&&(this.featuresLength=r[0])}return n.prototype.getExtension=function(t){return this.json.extensions&&this.json.extensions[t]},n.prototype.hasProperty=function(t){return!!this.json[t]},n.prototype.getGlobalProperty=function(t,e,r){var i=this.json[t];if(typeof i=="number"){var a=pi(e);return new a([i])}else if(Array.isArray(i)){var a=pi(e);return new a(i)}else if(i&&Number.isFinite(i.byteOffset))return this.getTypedArrayFromBinary(t,e,r,1,i.byteOffset);return null},n.prototype.getPropertyArray=function(t,e,r){var i=this.json[t];return i&&Number.isFinite(i.byteOffset)?("componentType"in i&&(e=Gc(i.componentType)),this.getTypedArrayFromBinary(t,e,r,this.featuresLength,i.byteOffset)):this.getTypedArrayFromArray(t,e,i)},n.prototype.getProperty=function(t,e,r,i,a){var o=this.json[t];if(!o)return null;var s=this.getPropertyArray(t,e,r);if(r===1)return a[0]=s[i],a;for(var u=0;u<r;++u)a[u]=s[r*i+u];return a},n.prototype.getTypedArrayFromBinary=function(t,e,r,i,a){var o=this.cachedTypedArrays,s=o[t];return s||(s=Ho(e,this.buffer.buffer,this.buffer.byteOffset+a,i*r),o[t]=s),s},n.prototype.getTypedArrayFromArray=function(t,e,r){var i=this.cachedTypedArrays,a=i[t];return a||(a=Ho(e,r),i[t]=a),a},n}(),tn=4,jo="b3dm tile in legacy format.";function Cu(n,t,e){var r=new TextDecoder("utf8"),i=new Uint8Array(n,t,e),a=r.decode(i);return a}function Iu(n,t,e){return e=Kc(n,t,e),e=Wc(n,t,e),e=Xc(n,t,e),e}function Kc(n,t,e){var r=new DataView(t),i=0;n.header=n.header||{};var a=r.getUint32(e,!0);e+=tn;var o=r.getUint32(e,!0);e+=tn;var s=r.getUint32(e,!0);e+=tn;var u=r.getUint32(e,!0);return e+=tn,s>=570425344?(e-=tn*2,i=a,s=o,u=0,a=0,o=0,console.warn(jo)):u>=570425344&&(e-=tn,i=s,s=a,u=o,a=0,o=0,console.warn(jo)),n.header.featureTableJsonByteLength=a,n.header.featureTableBinaryByteLength=o,n.header.batchTableJsonByteLength=s,n.header.batchTableBinaryByteLength=u,n.header.batchLength=i,e}function Wc(n,t,e){var r=n.header||{},i=r.featureTableJsonByteLength,a=r.featureTableBinaryByteLength,o=r.batchLength;if(n.featureTableJson={BATCH_LENGTH:o||0},i&&i>0){var s=Cu(t,e,i);n.featureTableJson=JSON.parse(s)}e+=i||0,n.featureTableBinary=new Uint8Array(t,e,a),e+=a||0,n.rtcCenter=new d.Vector3;var u=new Mu(n.featureTableJson,n.featureTableBinary);if(Array.isArray(u.json.RTC_CENTER))n.rtcCenter.fromArray(u.json.RTC_CENTER);else{var c=u.getGlobalProperty("RTC_CENTER",xe.FLOAT,3);c&&n.rtcCenter.fromArray(c)}return e}function Xc(n,t,e){var r=n.header||{},i=r.batchTableJsonByteLength,a=r.batchTableBinaryByteLength;if(i&&i>0){var o=Cu(t,e,i);n.batchTableJson=JSON.parse(o),e+=i,a&&a>0&&(n.batchTableBinary=new Uint8Array(t,e,a),n.batchTableBinary=new Uint8Array(n.batchTableBinary),e+=a)}return e}function Yc(n,t,e){var r=e!==void 0?new Uint8Array(n).subarray(t,t+e):new Uint8Array(n).subarray(t),i=new Uint8Array(r);return i.buffer}function Jc(n,t,e){var r=n.byteLength-e;if(r===0)throw new Error("glTF byte length must be greater than 0.");return e%4!==0&&console.warn("".concat(n.type,": embedded glb is not aligned to a 4-byte boundary.")),n.gltfArrayBuffer=Yc(t,e,r),n.byteLength}function Ea(n){if(typeof TextDecoder<"u")return new TextDecoder().decode(n);for(var t="",e=0,r=n.length;e<r;e++)t+=String.fromCharCode(n[e]);try{return decodeURIComponent(escape(t))}catch{return t}}var Re={FLOAT:5126,FLOAT_MAT3:35675,FLOAT_MAT4:35676,FLOAT_VEC2:35664,FLOAT_VEC3:35665,FLOAT_VEC4:35666,LINEAR:9729,REPEAT:10497,SAMPLER_2D:35678,POINTS:0,LINES:1,LINE_LOOP:2,LINE_STRIP:3,TRIANGLES:4,TRIANGLE_STRIP:5,TRIANGLE_FAN:6,UNSIGNED_BYTE:5121,UNSIGNED_SHORT:5123},wn={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array},vi={9728:d.NearestFilter,9729:d.LinearFilter,9984:d.NearestMipmapNearestFilter,9985:d.LinearMipmapNearestFilter,9986:d.NearestMipmapLinearFilter,9987:d.LinearMipmapLinearFilter},Ai={33071:d.ClampToEdgeWrapping,33648:d.MirroredRepeatWrapping,10497:d.RepeatWrapping},_o={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},Rt={POSITION:"position",NORMAL:"normal",TANGENT:"tangent",TEXCOORD_0:"uv",TEXCOORD_1:"uv2",COLOR_0:"color",WEIGHTS_0:"skinWeight",JOINTS_0:"skinIndex"},Sr={scale:"scale",translation:"position",rotation:"quaternion",weights:"morphTargetInfluences"},Zc={CUBICSPLINE:void 0,LINEAR:d.InterpolateLinear,STEP:d.InterpolateDiscrete},pr={OPAQUE:"OPAQUE",MASK:"MASK",BLEND:"BLEND"};function yt(n){var t=[];for(var e in n)t.push(n[e]);return t}var $c=function(){function n(t,e,r){this.json=t,this.extensions=e,this.options=r,this.cache=new Map,this.disposeSet=new Set,this.nodeNamesUsed={}}return n.prototype.dispose=function(){this.cache.clear(),this.disposeSet.forEach(function(t){t.dispose()}),this.disposeSet.clear()},n.prototype.markDefs=function(){for(var t=this.json.nodes||[],e=this.json.skins||[],r=this.json.meshes||[],i=0,a=e.length;i<a;i++)for(var o=e[i].joints,s=0,u=o.length;s<u;s++)t[o[s]].isBone=!0;for(var c=0,l=t.length;c<l;c++){var h=t[c];h.mesh!==void 0&&h.skin!==void 0&&(r[h.mesh].isSkinnedMesh=!0)}},n.prototype.parse=function(){var t=this,e=this.json,r=this.extensions;this.dispose(),this.markDefs();for(var i=0,a=yt(r);i<a.length;i++){var o=a[i];o.markDefs(this)}return Promise.all(yt(r).map(function(s){return s.prepare(t)})).then(function(){var s,u,c;return Promise.all([Promise.all(((s=e.scenes)!==null&&s!==void 0?s:[]).map(function(l,h){return t.loadScene(h)})),Promise.all(((u=e.animations)!==null&&u!==void 0?u:[]).map(function(l,h){return t.loadAnimation(h)})),Promise.all(((c=e.cameras)!==null&&c!==void 0?c:[]).map(function(l,h){return t.loadCamera(h)}))])}).then(function(s){var u=s[0],c=s[1],l=s[2],h={json:t.json,scene:u[e.scene||0],scenes:u,animations:c,cameras:l,dispose:function(){return t.dispose()}};return Promise.all(yt(r).map(function(p){return p.emitResult(h,t)})).then(function(){return h})})},n.prototype.loadCamera=function(t){var e="camera:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,a=0,o=yt(this.extensions);a<o.length;a++){var s=o[a];if(i=s.loadCamera(t,this),i)break}if(!i){var u=void 0,c=this.json.cameras[t],l=c[c.type];l?c.type==="perspective"?u=new d.PerspectiveCamera(d.MathUtils.radToDeg(l.yfov),l.aspectRatio||1,l.znear||1,l.zfar||2e6):c.type==="orthographic"?u=new d.OrthographicCamera(-l.xmag,l.xmag,l.ymag,-l.ymag,l.znear,l.zfar):(console.warn("glTF: Invalid camera type ".concat(c.type,".")),u=new d.Camera):(console.warn("glTF: Missing camera parameters."),u=new d.Camera),c.name&&(u.name=this.createUniqueName(c.name)),i=Promise.resolve(u)}return this.cache.set(e,i),i},n.prototype.loadSkin=function(t){var e="animation:"+t,r=this.cache.get(e);if(r)return r;var i,a=this.json.skins[t],o={joints:a.joints};return a.inverseBindMatrices===void 0?i=Promise.resolve(o):i=this.loadAccessor(a.inverseBindMatrices).then(function(s){return s&&(o.inverseBindMatrices=s),o}),this.cache.set(e,i),i},n.prototype.loadAnimation=function(t){var e="animation:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,a=0,o=yt(this.extensions);a<o.length;a++){var s=o[a];if(i=s.loadAnimation(t,this),i)break}if(!i){for(var u=this.json,c=u.animations[t],l=[],h=[],p=[],v=[],m=[],A=0,y=c.channels.length;A<y;A++){var f=c.channels[A],g=c.samplers[f.sampler],b=f.target,w=b.node!==void 0?b.node:b.id,E=c.parameters!==void 0?c.parameters[g.input]:g.input,x=c.parameters!==void 0?c.parameters[g.output]:g.output;l.push(this.loadNode(w)),h.push(this.loadAccessor(E)),p.push(this.loadAccessor(x)),v.push(g),m.push(b)}i=Promise.all([Promise.all(l),Promise.all(h),Promise.all(p),Promise.all(v),Promise.all(m)]).then(function(M){for(var C=M[0],I=M[1],P=M[2],S=M[3],F=M[4],k=[],O=function(j,z){var U=C[j],X=I[j],G=P[j],K=S[j],Y=F[j];if(U===void 0)return"continue";U.updateMatrix(),U.matrixAutoUpdate=!0;var H=void 0;switch(Sr[Y.path]){case Sr.weights:H=d.NumberKeyframeTrack;break;case Sr.rotation:H=d.QuaternionKeyframeTrack;break;case Sr.position:case Sr.scale:default:H=d.VectorKeyframeTrack;break}var J=U.name?U.name:U.uuid,ne=K.interpolation!==void 0?Zc[K.interpolation]:d.InterpolateLinear,$=[];Sr[Y.path]===Sr.weights?U.traverse(function(Ae){Ae.morphTargetInfluences&&$.push(Ae.name?Ae.name:Ae.uuid)}):$.push(J);var te=G.array;if(G.normalized){for(var ae=Ki(te.constructor),ce=new Float32Array(te.length),oe=0,fe=te.length;oe<fe;oe++)ce[oe]=te[oe]*ae;te=ce}for(var oe=0,fe=$.length;oe<fe;oe++){var Ie=new H($[oe]+"."+Sr[Y.path],X.array,te,ne);k.push(Ie)}},L=0,N=C.length;L<N;L++)O(L);var V=c.name?c.name:"animation_"+t;return new d.AnimationClip(V,void 0,k)})}return this.cache.set(e,i),i},n.prototype.loadBuffer=function(t){var e=this.json.buffers[t];if(e.type&&e.type!=="arraybuffer")throw new Error("glTF: "+e.type+" buffer type is not supported.");var r="buffer:"+t,i=this.cache.get(r);if(i)return i;for(var a=null,o=0,s=yt(this.extensions);o<s.length;o++){var u=s[o];if(a=u.loadBuffer(t,this),a)break}if(!a){var c=this.json.buffers[t];a=this.options.fetcher.ajax(this.resolveResouce(c.uri),{responseType:"arraybuffer"}).then(function(l){return l.body})}return this.cache.set(r,a),a},n.prototype.loadBufferView=function(t){var e="bufferView:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,a=0,o=yt(this.extensions);a<o.length;a++){var s=o[a];if(i=s.loadBufferView(t,this),i)break}if(!i){var u=this.json.bufferViews[t];i=this.loadBuffer(u.buffer).then(function(c){var l=u.byteLength||0,h=u.byteOffset||0;return c.slice(h,h+l)})}return this.cache.set(e,i),i},n.prototype.loadAccessor=function(t){var e=this,r="accessor:"+t,i=this.cache.get(r);if(i)return i;var a=null;if(!a){var o=this.json.accessors[t];if(o.bufferView===void 0&&o.sparse===void 0)a=Promise.resolve(null);else{var s=[];o.bufferView!==void 0?s.push(this.loadBufferView(o.bufferView)):s.push(Promise.resolve(null)),o.sparse!==void 0&&(s.push(this.loadBufferView(o.sparse.indices.bufferView)),s.push(this.loadBufferView(o.sparse.values.bufferView))),a=Promise.all(s).then(function(u){var c=u[0],l=_o[o.type],h=wn[o.componentType],p=h.BYTES_PER_ELEMENT,v=p*l,m=o.byteOffset||0,A=o.bufferView!==void 0?e.json.bufferViews[o.bufferView].byteStride:void 0,y=o.normalized===!0,f,g;if(A&&A!==v){var b=Math.floor(m/A),w="InterleavedBuffer:"+o.bufferView+":"+o.componentType+":"+b+":"+o.count,E=e.cache.get(w);E||(f=new h(c,b*A,o.count*A/p),E=new d.InterleavedBuffer(f,A/p),e.cache.set(w,E)),g=new d.InterleavedBufferAttribute(E,l,m%A/p,y)}else c===null?f=new h(o.count*l):f=new h(c,m,o.count*l),g=new d.BufferAttribute(f,l,y);if(o.sparse!==void 0){var x=_o.SCALAR,M=wn[o.sparse.indices.componentType],C=o.sparse.indices.byteOffset||0,I=o.sparse.values.byteOffset||0,P=new M(u[1],C,o.sparse.count*x),S=new h(u[2],I,o.sparse.count*l);c!==null&&(g=new d.BufferAttribute(g.array.slice(),g.itemSize,g.normalized));for(var F=0,k=P.length;F<k;F++){var O=P[F];if(g.setX(O,S[F*l]),l>=2&&g.setY(O,S[F*l+1]),l>=3&&g.setZ(O,S[F*l+2]),l>=4&&g.setW(O,S[F*l+3]),l>=5)throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.")}}return g})}}return this.cache.set(r,a),a},n.prototype.createPrimitiveKey=function(t){for(var e=0,r=yt(this.extensions);e<r.length;e++){var i=r[e],a=i.createPrimitiveKey(t,this);if(a)return a}for(var o="",s=Object.keys(t.attributes).sort(),u=0,c=s.length;u<c;u++)o+=s[u]+":"+t.attributes[s[u]]+";";return t.indices+":"+o+":"+t.mode},n.prototype.loadGeometry=function(t){var e=this,r="geometry:"+this.createPrimitiveKey(t),i=this.cache.get(r);if(i)return i;for(var a=null,o=0,s=yt(this.extensions);o<s.length;o++){var u=s[o];if(a=u.loadGeometry(t,this),a)break}return a||(a=this.addGeometryPrimitiveAttributes(new d.BufferGeometry,t)),a=a.then(function(c){return e.disposeSet.add(c),c}),this.cache.set(r,a),a},n.prototype.loadImage=function(t){var e="image:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,a=0,o=yt(this.extensions);a<o.length;a++){var s=o[a];if(i=s.loadImage(t,this),i)break}if(!i){var u=this.json.images[t];if(u.bufferView)i=this.loadBufferView(u.bufferView).then(function(l){var h=new Blob([l],{type:u.mimeType});return lu(h)});else if(u.uri){var c=this.resolveResouce(u.uri);i=this.options.fetcher.loadImage(c,{},void 0,void 0,void 0,fi()).then(function(l){return l.body})}else throw new Error("glTF: Invalid image defs.")}return this.cache.set(e,i),i},n.prototype.loadMaterialAsMeshStandardMaterial=function(t){var e=this,r=[],i=new d.MeshStandardMaterial;if(i.color=new d.Color(1,1,1),i.opacity=1,Object.keys(t.attributes).filter(function(l){return Rt[l]==="color"}).length>0&&(i.vertexColors=!0),Object.keys(t.attributes).filter(function(l){return Rt[l]==="normal"}).length===0&&(i.flatShading=!0),Object.keys(t.attributes).filter(function(l){return Rt[l]==="tangent"}).length===0&&(i.normalScale&&(i.normalScale.y*=-1),i.clearcoatNormalScale&&(i.clearcoatNormalScale.y*=-1)),t.material!==void 0){var a=this.json.materials[t.material];a.name&&(i.name=a.name);var o=a.pbrMetallicRoughness||{};if(Array.isArray(o.baseColorFactor)){var s=o.baseColorFactor;i.color.fromArray(s),i.opacity=s[3]}o.baseColorTexture!==void 0&&r.push(this.createMaterialTexture(o.baseColorTexture).then(function(l){l.encoding=d.sRGBEncoding,i.map=l,e.disposeSet.add(l)})),i.metalness=o.metallicFactor!==void 0?o.metallicFactor:1,i.roughness=o.roughnessFactor!==void 0?o.roughnessFactor:1,o.metallicRoughnessTexture!==void 0&&r.push(this.createMaterialTexture(o.metallicRoughnessTexture).then(function(l){l.encoding=d.sRGBEncoding,i.metalnessMap=l,i.roughnessMap=l,e.disposeSet.add(l)})),a.doubleSided===!0&&(i.side=d.DoubleSide);var u=a.alphaMode||pr.OPAQUE;if(u===pr.BLEND?(i.transparent=!0,i.depthWrite=!1):(i.transparent=!1,u===pr.MASK&&(i.alphaTest=a.alphaCutoff!==void 0?a.alphaCutoff:.5)),a.normalTexture!==void 0&&(r.push(this.createMaterialTexture(a.normalTexture).then(function(l){i.normalMap=l,e.disposeSet.add(l)})),i.normalScale=new d.Vector2(1,1),a.normalTexture.scale!==void 0)){var c=a.normalTexture.scale;i.normalScale.set(c,c)}a.occlusionTexture!==void 0&&(r.push(this.createMaterialTexture(a.occlusionTexture).then(function(l){i.aoMap=l,e.disposeSet.add(l)})),a.occlusionTexture.strength!==void 0&&(i.aoMapIntensity=a.occlusionTexture.strength)),a.emissiveFactor!==void 0&&(i.emissive=new d.Color().fromArray(a.emissiveFactor)),a.emissiveTexture!==void 0&&r.push(this.createMaterialTexture(a.emissiveTexture).then(function(l){i.emissiveMap=l,e.disposeSet.add(l)}))}return this.disposeSet.add(i),Promise.all(r).then(function(){return i})},n.prototype.loadMaterialAsLineBasicMaterial=function(t){var e=[],r=new d.LineBasicMaterial;if(r.color=new d.Color(1,1,1),r.opacity=1,Object.keys(t.attributes).filter(function(u){return Rt[u]==="color"}).length>0&&(r.vertexColors=!0),Object.keys(t.attributes).filter(function(u){return Rt[u]==="tangent"}).length===0&&(r.normalScale&&(r.normalScale.y*=-1),r.clearcoatNormalScale&&(r.clearcoatNormalScale.y*=-1)),t.material!==void 0){var i=this.json.materials[t.material];i.name&&(r.name=i.name);var a=i.pbrMetallicRoughness||{};if(Array.isArray(a.baseColorFactor)){var o=a.baseColorFactor;r.color.fromArray(o),r.opacity=o[3]}i.doubleSided===!0&&(r.side=d.DoubleSide);var s=i.alphaMode||pr.OPAQUE;s===pr.BLEND?(r.transparent=!0,r.depthWrite=!1):(r.transparent=!1,s===pr.MASK&&(r.alphaTest=i.alphaCutoff!==void 0?i.alphaCutoff:.5))}return this.disposeSet.add(r),Promise.all(e).then(function(){return r})},n.prototype.loadMaterialAsPointsMaterial=function(t){var e=this,r=[],i=new d.PointsMaterial;if(i.color=new d.Color(1,1,1),i.opacity=1,i.sizeAttenuation=!1,Object.keys(t.attributes).filter(function(c){return Rt[c]==="color"}).length>0&&(i.vertexColors=!0),Object.keys(t.attributes).filter(function(c){return Rt[c]==="tangent"}).length===0&&(i.normalScale&&(i.normalScale.y*=-1),i.clearcoatNormalScale&&(i.clearcoatNormalScale.y*=-1)),t.material!==void 0){var a=this.json.materials[t.material];a.name&&(i.name=a.name);var o=a.pbrMetallicRoughness||{};if(Array.isArray(o.baseColorFactor)){var s=o.baseColorFactor;i.color.fromArray(s),i.opacity=s[3]}o.baseColorTexture!==void 0&&r.push(this.createMaterialTexture(o.baseColorTexture).then(function(c){c.encoding=d.sRGBEncoding,i.map=c,e.disposeSet.add(c)})),a.doubleSided===!0&&(i.side=d.DoubleSide);var u=a.alphaMode||pr.OPAQUE;u===pr.BLEND?(i.transparent=!0,i.depthWrite=!1):(i.transparent=!1,u===pr.MASK&&(i.alphaTest=a.alphaCutoff!==void 0?a.alphaCutoff:.5))}return this.disposeSet.add(i),Promise.all(r).then(function(){return i})},n.prototype.loadMaterial=function(t){var e=this,r,i=(r=t.mode)!==null&&r!==void 0?r:Re.TRIANGLES,a="material:"+this.createPrimitiveKey(t),o=this.cache.get(a);if(o)return o;for(var s=null,u=0,c=yt(this.extensions);u<c.length;u++){var l=c[u];if(s=l.loadMaterial(t,this),s)break}if(i===Re.TRIANGLES||i===Re.TRIANGLE_STRIP||i===Re.TRIANGLE_FAN)s=this.loadMaterialAsMeshStandardMaterial(t);else if(i===Re.LINES||i===Re.LINE_STRIP||i===Re.LINE_LOOP)s=this.loadMaterialAsLineBasicMaterial(t);else if(i===Re.POINTS)s=this.loadMaterialAsPointsMaterial(t);else throw new Error("glTF: Primitive mode unsupported: "+i);return s=s.then(function(h){return e.disposeSet.add(h),h}),this.cache.set(a,s),s},n.prototype.loadTexture=function(t){var e=this,r="texture:"+t,i=this.cache.get(r);if(i)return i;for(var a=null,o=0,s=yt(this.extensions);o<s.length;o++){var u=s[o];if(a=u.loadTexture(t,this),a)break}if(!a){var c=this.json.textures[t];a=this.loadImage(c.source).then(function(l){var h=new d.Texture(l);h.needsUpdate=!0,h.flipY=!1,c.name&&(h.name=c.name);var p=e.json.samplers||{},v=p[c.sampler]||{};h.magFilter=vi[v.magFilter]||d.LinearFilter,h.minFilter=vi[v.minFilter]||d.LinearMipmapLinearFilter,h.wrapS=Ai[v.wrapS]||d.RepeatWrapping,h.wrapT=Ai[v.wrapT]||d.RepeatWrapping;var m=h.dispose;return h.dispose=function(){return h.dispose=m,l.close(),m.call(this)},h})}return a=a.then(function(l){return e.disposeSet.add(l),l}),this.cache.set(r,a),a},n.prototype.loadMesh=function(t){for(var e=this,r=null,i=0,a=yt(this.extensions);i<a.length;i++){var o=a[i];if(r=o.loadMesh(t,this),r)break}if(!r){var s=this.json.meshes[t],u=s.primitives,c=Promise.all(u.map(function(h){return e.loadGeometry(h)})),l=Promise.all(u.map(function(h){return e.loadMaterial(h)}));r=Promise.all([c,l]).then(function(h){for(var p=h[0],v=h[1],m=[],A=0;A<u.length;A++){var y=u[A],f=p[A],g=v[A],b=y.mode||Re.TRIANGLES,w=void 0;if(b===Re.TRIANGLES||b===Re.TRIANGLE_STRIP||b===Re.TRIANGLE_FAN)if(b===Re.TRIANGLE_STRIP?f=e.toGeometryTrianglesDrawMode(f,d.TriangleStripDrawMode):b===Re.TRIANGLE_FAN&&(f=e.toGeometryTrianglesDrawMode(f,d.TriangleFanDrawMode)),s.isSkinnedMesh){var E=new d.SkinnedMesh(f,g);f.attributes.skinWeight.normalized||E.normalizeSkinWeights(),w=E}else w=new d.Mesh(f,g);else if(b===Re.POINTS)w=new d.Points(f,g);else if(b===Re.LINES)w=new d.LineSegments(f,g);else if(b===Re.LINE_STRIP)w=new d.Line(f,g);else if(b===Re.LINE_LOOP)w=new d.LineLoop(f,g);else throw new Error("glTF: Primitive mode unsupported: "+b);if(Object.keys(f.morphAttributes).length>0){if(s.weights!==void 0)for(var x=0,M=s.weights.length;x<M;x++)w.morphTargetInfluences[x]=s.weights[x];if(s.extras&&Array.isArray(s.extras.targetNames)){var C=s.extras.targetNames;if(w.morphTargetInfluences.length===C.length){w.morphTargetDictionary={};for(var x=0,M=C.length;x<M;x++)w.morphTargetDictionary[C[x]]=x}else console.warn("glTF: Invalid extras.targetNames length. Ignoring names.")}}w.name=e.createUniqueName(s.name||"mesh_"+t),m.push(w)}if(m.length===1)return m[0];for(var I=new d.Group,P=0,S=m;P<S.length;P++){var w=S[P];I.add(w)}return I})}return r},n.prototype.loadNodeAttachments=function(t){for(var e=[],r=0,i=yt(this.extensions);r<i.length;r++){var a=i[r],o=a.loadNodeAttachments(t,this);o&&e.push(o)}return e},n.prototype.loadNode=function(t){var e="node:"+t,r=this.cache.get(e);if(r)return r;var i=this.json,a=i.nodes[t],o=a.name?this.createUniqueName(a.name):"",s=[];a.mesh!==void 0&&s.push(this.loadMesh(a.mesh).then(function(p){if(a.weights!==void 0){var v=a.weights;p.traverse(function(m){if(m instanceof d.Mesh||m instanceof d.Line||m instanceof d.Points)for(var A=0,y=v.length;A<y;A++)m.morphTargetInfluences[A]=v[A]})}return p})),a.camera!==void 0&&s.push(this.loadCamera(a.camera));for(var u=this.loadNodeAttachments(t),c=0,l=u;c<l.length;c++){var h=l[c];s.push(h)}return Promise.all(s).then(function(p){var v;if(a.isBone===!0?v=new d.Bone:p.length>1?v=new d.Group:p.length===1?v=p[0]:v=new d.Object3D,v!==p[0])for(var m=0,A=p.length;m<A;m++)v.add(p[m]);if(a.name&&(v.name=o),a.matrix!==void 0){var y=new d.Matrix4;y.fromArray(a.matrix),v.applyMatrix4(y)}else a.translation!==void 0&&v.position.fromArray(a.translation),a.rotation!==void 0&&v.quaternion.fromArray(a.rotation),a.scale!==void 0&&v.scale.fromArray(a.scale);return v})},n.prototype.loadScene=function(t){var e=this.json,r=e.scenes[t],i=new d.Group;r.name&&(i.name=this.createUniqueName(r.name));for(var a=r.nodes||[],o=[],s=0,u=a.length;s<u;s++)o.push(this.buildNodeHierarchy(a[s],i));return Promise.all(o).then(function(){return i})},n.prototype.createMaterialTexture=function(t){var e=this;return this.loadTexture(t.index).then(function(r){for(var i=0,a=yt(e.extensions);i<a.length;i++){var o=a[i],s=o.extendTexture(r,t,e);s&&(r=s)}return r})},n.prototype.addGeometryPrimitiveAttributes=function(t,e){var r=this,i=e.attributes,a=[],o=function(E){var x=Rt[E]||E.toLowerCase();if(x in t.attributes)return"continue";a.push(s.loadAccessor(i[E]).then(function(M){M&&t.setAttribute(x,M)}))},s=this;for(var u in i)o(u);e.indices!==void 0&&!t.index&&a.push(this.loadAccessor(e.indices).then(function(E){E&&t.setIndex(E)}));var c=new d.Box3;if(i.POSITION!==void 0){var l=this.json.accessors[i.POSITION],h=l.min,p=l.max;if(h!==void 0&&p!==void 0){if(c.set(new d.Vector3(h[0],h[1],h[2]),new d.Vector3(p[0],p[1],p[2])),l.normalized){var v=Ki(wn[l.componentType]);c.min.multiplyScalar(v),c.max.multiplyScalar(v)}}else console.warn("glTF: Missing min/max properties for accessor POSITION.")}var m=e.targets;if(m!==void 0){for(var A=new d.Vector3,y=new d.Vector3,f=0,g=m.length;f<g;f++){var b=m[f];if(b.POSITION!==void 0){var l=this.json.accessors[b.POSITION],h=l.min,p=l.max;if(h!==void 0&&p!==void 0){if(y.setX(Math.max(Math.abs(h[0]),Math.abs(p[0]))),y.setY(Math.max(Math.abs(h[1]),Math.abs(p[1]))),y.setZ(Math.max(Math.abs(h[2]),Math.abs(p[2]))),l.normalized){var v=Ki(wn[l.componentType]);y.multiplyScalar(v)}A.max(y)}else console.warn("glTF: Missing min/max properties for accessor POSITION.")}}c.expandByVector(A)}t.boundingBox=c;var w=new d.Sphere;return c.getCenter(w.center),w.radius=c.min.distanceTo(c.max)/2,t.boundingSphere=w,Promise.all(a).then(function(){if(t.attributes.uv&&!t.attributes.uv2&&r.options.copyUV2&&t.setAttribute("uv2",t.attributes.uv),e.targets){for(var E=!1,x=!1,M=0,C=e.targets.length;M<C;M++){var I=e.targets[M];if(I.POSITION!==void 0&&(E=!0),I.NORMAL!==void 0&&(x=!0),E&&x)break}if(!E&&!x)return t;var P=[];t.morphTargetsRelative=!0;for(var S=function(F,k){var O=e.targets[F];E?P.push(r.loadAccessor(O.POSITION).then(function(L){L&&(t.morphAttributes.position[F]=L)})):t.morphAttributes.position[F]=t.attributes.position,x?P.push(r.loadAccessor(O.NORMAL).then(function(L){L&&(t.morphAttributes.normal[F]=L)})):t.morphAttributes.normal[F]=t.attributes.normal},M=0,C=e.targets.length;M<C;M++)S(M,C);return Promise.all(P).then(function(){return t})}else return t})},n.prototype.buildNodeHierarchy=function(t,e){var r=this,i=this.json.nodes[t];return this.loadNode(t).then(function(a){if(i.skin===void 0)return a;var o;return r.loadSkin(i.skin).then(function(s){o=s;for(var u=[],c=0,l=o.joints.length;c<l;c++)u.push(r.loadNode(o.joints[c]));return Promise.all(u)}).then(function(s){return a.traverse(function(u){if(u instanceof d.SkinnedMesh){for(var c=[],l=[],h=0,p=s.length;h<p;h++){var v=s[h];if(v instanceof d.Bone){c.push(v);var m=new d.Matrix4;o.inverseBindMatrices!==void 0&&m.fromArray(o.inverseBindMatrices.array,h*16),l.push(m)}else console.warn('glTF: Joint "%s" could not be found.',o.joints[h])}u.bind(new d.Skeleton(c,l),u.matrixWorld)}}),a})}).then(function(a){e.add(a);var o=[];if(i.children)for(var s=i.children,u=0,c=s.length;u<c;u++){var l=s[u];o.push(r.buildNodeHierarchy(l,a))}return Promise.all(o).then(function(){return a})})},n.prototype.createUniqueName=function(t){for(var e=d.PropertyBinding.sanitizeNodeName(t||""),r=e,i=1;this.nodeNamesUsed[r];++i)r=e+"_"+i;return this.nodeNamesUsed[r]=!0,r},n.prototype.resolveResouce=function(t){return It(this.options.resourcePath,Eu(t,this.options.search))},n.prototype.toGeometryTrianglesDrawMode=function(t,e){var r=t.getIndex();if(r===null){var i=[],a=t.getAttribute("position");if(a!==void 0){for(var o=0;o<a.count;o++)i.push(o);t.setIndex(i),r=t.getIndex()}}if(r===null)return console.error("glTF: Undefined position attribute. Processing not possible."),t;var s=r.count-2,u=[];if(e===d.TriangleFanDrawMode)for(var o=1;o<=s;o++)u.push(r.getX(0)),u.push(r.getX(o)),u.push(r.getX(o+1));else for(var o=0;o<s;o++)o%2===0?(u.push(r.getX(o)),u.push(r.getX(o+1)),u.push(r.getX(o+2))):(u.push(r.getX(o+2)),u.push(r.getX(o+1)),u.push(r.getX(o)));u.length/3!==s&&console.error("glTF: Unable to generate correct amount of triangles.");var c=t.clone();return c.setIndex(u),c},n}();function Ki(n){switch(n){case Int8Array:return 1/127;case Uint8Array:return 1/255;case Int16Array:return 1/32767;case Uint16Array:return 1/65535;default:throw new Error("glTF: Unsupported normalized accessor component type.")}}var br=function(){function n(){}return n.prototype.markDefs=function(t){},n.prototype.prepare=function(t){},n.prototype.emitResult=function(t,e){},n.prototype.createPrimitiveKey=function(t,e){},n.prototype.extendTexture=function(t,e,r){return null},n.prototype.loadBuffer=function(t,e){return null},n.prototype.loadBufferView=function(t,e){return null},n.prototype.loadImage=function(t,e){return null},n.prototype.loadTexture=function(t,e){return null},n.prototype.loadGeometry=function(t,e){return null},n.prototype.loadMaterial=function(t,e){return null},n.prototype.loadMesh=function(t,e){return null},n.prototype.loadNodeAttachments=function(t,e){return null},n.prototype.loadCamera=function(t,e){return null},n.prototype.loadAnimation=function(t,e){return null},n}(),ed=function(n){de(t,n);function t(){var e=n.call(this)||this;return e.header={magic:"",version:0,length:0},e.content="",e.body=null,e}return t.getMagic=function(e){return Ea(new Uint8Array(e.slice(0,4)))},t.prototype.loadGlbBinary=function(e){var r=new DataView(e,0,t.HEADER_LENGTH);if(this.header={magic:t.getMagic(e),version:r.getUint32(4,!0),length:r.getUint32(8,!0)},this.header.magic!==t.HEADER_MAGIC)throw new Error("glTF:KHR_binary_glTF: Unsupported.");if(this.header.version<2)throw new Error("glTF:KHR_binary_glTF: Legacy binary file detected.");for(var i=new DataView(e,t.HEADER_LENGTH),a=0,o=null,s=null;a<i.byteLength;){var u=i.getUint32(a,!0);a+=4;var c=i.getUint32(a,!0);if(a+=4,c===t.CHUNK_TYPES.JSON){var l=new Uint8Array(e,t.HEADER_LENGTH+a,u);o=Ea(l)}else if(c===t.CHUNK_TYPES.BIN){var h=t.HEADER_LENGTH+a;s=e.slice(h,h+u)}a+=u}if(o===null)throw new Error("glTF:KHR_binary_glTF: JSON content not found.");this.content=o,this.body=s},t.prototype.loadBuffer=function(e,r){var i=r.json.buffers[e];return i.uri===void 0&&e===0&&this.body?Promise.resolve(this.body):null},t.HEADER_MAGIC="glTF",t.HEADER_LENGTH=12,t.CHUNK_TYPES={JSON:1313821514,BIN:5130562},t}(br),td="https://vr-public.realsee-cdn.cn/release/static/image/release/five/resource/draco/1.5.6/",Go={position:"POSITION",normal:"NORMAL",color:"COLOR",uv:"TEX_COORD"},Ko={position:"Float32Array",normal:"Float32Array",color:"Float32Array",uv:"Float32Array"},rd=function(){function n(){this.decoderPath=td,this.decoderConfig={},this.decoderPending=null,this.workerLimit=4,this.workerPool=[],this.workerNextTaskID=1,this.workerSourceURL=""}return n.prototype.setDecoderPath=function(t){this.decoderPath=t},n.prototype.setDecoderConfig=function(t){return this.decoderConfig=t,this},n.prototype.setWorkerLimit=function(t){return this.workerLimit=t,this},n.prototype.decodeDracoFile=function(t,e,r,i){var a={attributeIDs:r||Go,attributeTypes:i||Ko,useUniqueIDs:!!r};this.decodeGeometry(t,a).then(e)},n.prototype.decodeGeometry=function(t,e){var r=this;e===void 0&&(e={attributeIDs:Go,attributeTypes:Ko,useUniqueIDs:!1});for(var i in e.attributeTypes){var a=e.attributeTypes[i];a.BYTES_PER_ELEMENT!==void 0&&(e.attributeTypes[i]=a.name)}var o,s=this.workerNextTaskID++,u=t.byteLength,c=this._getWorker(s,u).then(function(l){return o=l,new Promise(function(h,p){o._callbacks[s]={resolve:h,reject:p},o.postMessage({type:"decode",id:s,taskConfig:e,buffer:t},[t])})}).then(function(l){return r._createGeometry(l.geometry)});return c.catch(function(){return!0}).then(function(){o&&s&&r._releaseTask(o,s)}),c},n.prototype._createGeometry=function(t){var e=new d.BufferGeometry;t.index&&e.setIndex(new d.BufferAttribute(t.index.array,1));for(var r=0;r<t.attributes.length;r++){var i=t.attributes[r],a=i.name,o=i.array,s=i.itemSize;e.setAttribute(a,new d.BufferAttribute(o,s))}return e},n.prototype._initDecoder=function(){var t=this;if(this.decoderPending)return this.decoderPending;var e=typeof WebAssembly!="object"||this.decoderConfig.type==="js";if(e){var r=ln(this.decoderPath+"draco_decoder.js",{responseType:"text"}).then(function(a){return a.body});this.decoderPending=r.then(function(a){var o=["/* draco decoder */",a,"","/* worker */",Wo].join(`
|
|
418
418
|
`);t.workerSourceURL=URL.createObjectURL(new Blob([o]))})}else{var r=ln(this.decoderPath+"draco_wasm_wrapper.js",{responseType:"text"}).then(function(o){return o.body}),i=ln(this.decoderPath+"draco_decoder.wasm",{responseType:"arraybuffer"}).then(function(o){return o.body});this.decoderPending=Promise.all([r,i]).then(function(o){var s=o[0],u=o[1];t.decoderConfig.wasmBinary=u;var c=["/* draco decoder */",s,"","/* worker */",Wo].join(`
|
|
419
419
|
`);t.workerSourceURL=URL.createObjectURL(new Blob([c]))})}return this.decoderPending},n.prototype._getWorker=function(t,e){var r=this;return this._initDecoder().then(function(){if(r.workerPool.length<r.workerLimit){var i=new Worker(r.workerSourceURL);i._callbacks={},i._taskCosts={},i._taskLoad=0,i.postMessage({type:"init",decoderConfig:r.decoderConfig}),i.onmessage=function(o){var s=o.data;switch(s.type){case"decode":i._callbacks[s.id].resolve(s);break;case"error":i._callbacks[s.id].reject(s);break;default:console.error('DRACO: Unexpected message, "'+s.type+'"')}},r.workerPool.push(i)}else r.workerPool.sort(function(o,s){return o._taskLoad>s._taskLoad?-1:1});var a=r.workerPool[r.workerPool.length-1];return a._taskCosts[t]=e,a._taskLoad+=e,a})},n.prototype._releaseTask=function(t,e){t._taskLoad-=t._taskCosts[e],delete t._callbacks[e],delete t._taskCosts[e]},n.prototype.dispose=function(){for(var t=0;t<this.workerPool.length;++t)this.workerPool[t].terminate();return this.workerPool.length=0,this},n}(),mi=new rd,Wo=`
|
|
420
420
|
let decoderConfig;
|
|
@@ -880,7 +880,7 @@ void main() {
|
|
|
880
880
|
return ( value & ( value - 1 ) ) === 0 && value !== 0;
|
|
881
881
|
|
|
882
882
|
}
|
|
883
|
-
`,Xo="KHR_texture_basisu",hd=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.loadTexture=function(e,r){var i=r.json.textures[e];if(!i.extensions||!i.extensions[Xo])return null;var a=i.extensions[Xo],o=r.json.images[a.source],s=null;if(o.bufferView)s=r.loadBufferView(o.bufferView).then(function(u){return Fn.parse(u)});else if(o.uri)s=r.options.fetcher.ajax(r.resolveResouce(o.uri),{responseType:"arraybuffer"}).then(function(u){return Fn.parse(u.body)});else throw new Error("glTF: Invalid image defs.");return s},t}(br),Yo="KHR_texture_transform",pd=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.extendTexture=function(e,r,i){var a=r.extensions!==void 0?r.extensions[Yo]:void 0;return a?(a.texCoord!==void 0&&console.warn('glTF: Custom UV sets in "'+Yo+'" extension not yet supported.'),a.offset===void 0&&a.rotation===void 0&&a.scale===void 0||(e=e.clone(),e.needsUpdate=!0,a.offset!==void 0&&e.offset.fromArray(a.offset),a.rotation!==void 0&&(e.rotation=a.rotation),a.scale!==void 0&&e.repeat.fromArray(a.scale)),e):null},t}(br),vd=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t}(br),Xi=function(){var n="b9H79Tebbbe8Fv9Gbb9Gvuuuuueu9Giuuub9Geueu9Giuuueuikqbeeedddillviebeoweuec:q;iekr;leDo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbeY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVbdE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbiL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtblK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949Wbol79IV9Rbrq:78Yqdbk:qzezu8Jjjjjbcj;eb9Rgv8Kjjjjbc9:hodnadcefal0mbcuhoaiRbbc:Ge9hmbavaialfgrad9Radz1jjjbhwcj;abad9UhlaicefhodnadTmbalc;WFbGglcjdalcjd6EhDcbhqinaqae9pmeaDaeaq9RaqaDfae6Egkcsfglcl4cifcd4hxdndndndnalc9WGgmTmbcbhPcehsawcjdfhzaohHinaraH9Rax6midnaraHaxfgo9RcK6mbczhlinalgic9Wfglawcj;cbffhOdndndndndnaHalco4fRbbalci4coG4ciGPlbedibkaO9cb83ibaOcwf9cb83ibxikaOaoRblaoRbbgAco4glalciSgCE86bbawcj;cbfaifglcGfaoclfaCfgORbbaAcl4ciGgCaCciSgCE86bbalcVfaOaCfgORbbaAcd4ciGgCaCciSgCE86bbalc7faOaCfgORbbaAciGgAaAciSgAE86bbalctfaOaAfgARbbaoRbegOco4gCaCciSgCE86bbalc91faAaCfgARbbaOcl4ciGgCaCciSgCE86bbalc4faAaCfgARbbaOcd4ciGgCaCciSgCE86bbalc93faAaCfgARbbaOciGgOaOciSgOE86bbalc94faAaOfgARbbaoRbdgOco4gCaCciSgCE86bbalc95faAaCfgARbbaOcl4ciGgCaCciSgCE86bbalc96faAaCfgARbbaOcd4ciGgCaCciSgCE86bbalc97faAaCfgARbbaOciGgOaOciSgOE86bbalc98faAaOfgORbbaoRbigoco4gAaAciSgAE86bbalc99faOaAfgORbbaocl4ciGgAaAciSgAE86bbalc9:faOaAfgORbbaocd4ciGgAaAciSgAE86bbalcufaOaAfglRbbaociGgoaociSgoE86bbalaofhoxdkaOaoRbwaoRbbgAcl4glalcsSgCE86bbawcj;cbfaifglcGfaocwfaCfgORbbaAcsGgAaAcsSgAE86bbalcVfaOaAfgORbbaoRbegAcl4gCaCcsSgCE86bbalc7faOaCfgORbbaAcsGgAaAcsSgAE86bbalctfaOaAfgORbbaoRbdgAcl4gCaCcsSgCE86bbalc91faOaCfgORbbaAcsGgAaAcsSgAE86bbalc4faOaAfgORbbaoRbigAcl4gCaCcsSgCE86bbalc93faOaCfgORbbaAcsGgAaAcsSgAE86bbalc94faOaAfgORbbaoRblgAcl4gCaCcsSgCE86bbalc95faOaCfgORbbaAcsGgAaAcsSgAE86bbalc96faOaAfgORbbaoRbvgAcl4gCaCcsSgCE86bbalc97faOaCfgORbbaAcsGgAaAcsSgAE86bbalc98faOaAfgORbbaoRbogAcl4gCaCcsSgCE86bbalc99faOaCfgORbbaAcsGgAaAcsSgAE86bbalc9:faOaAfgORbbaoRbrgocl4gAaAcsSgAE86bbalcufaOaAfglRbbaocsGgoaocsSgoE86bbalaofhoxekaOao8Pbb83bbaOcwfaocwf8Pbb83bbaoczfhokdnaiam9pmbaiczfhlarao9RcL0mekkaiam6miaoTmidnakTmbawaPfRbbhOawcj;cbfhlazhiakhHinaialRbbgAce4cbaAceG9R7aOfgO86bbaiadfhialcefhlaHcufgHmbkkazcefhzaPcefgPad6hsaohHaPad9hmexvkkcbhoasceGmdxikaoaxad2fhPdnakTmbcbhmcehsawcjdfhCinarao9Rax6miaoTmdaoaxfhoawamfRbbhOawcj;cbfhlaChiakhHinaialRbbgAce4cbaAceG9R7aOfgO86bbaiadfhialcefhlaHcufgHmbkaCcefhCamcefgmad6hsamad9hmbkaPhoxikcbhlcehsinarao9Rax6mdaoTmeaoaxfhoalcefglad6hsadal9hmbkaPhoxdkcbhoasceGTmekc9:hoxikabaqad2fawcjdfakad2z1jjjb8Aawawcjdfakcufad2fadz1jjjb8Aakaqfhqaombkc9:hoxekcbc99arao9Radcaadca0ESEhokavcj;ebf8Kjjjjbaok;xzeHu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnaeci9UgrcHfal0mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecjez:jjjjb8AavcUf9cu83ibavc8Wf9cu83ibavcyf9cu83ibavcaf9cu83ibavcKf9cu83ibavczf9cu83ibav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhodnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhlindnaoaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfalaDcu7gPcl4fcsGcitfgsydlhzasydbhHdnaDcsGgDak9pmbavaiaPfcsGcdtfydbaxaDEhsaDThDdndnadcd9hmbabarcetfgPaH87ebaPcdfaz87ebaPclfas87ebxekabarcdtfgPaHBdbaPclfazBdbaPcwfasBdbkaxaDfhxavc;abfalcitfgPasBdbaPazBdlavaicdtfasBdbavc;abfalcefcsGglcitfgPaHBdbaPasBdlaiaDfhialcefhlxdkdndnaDcsSmbamaDfaDc987fcefhmxekaocefhDao8SbbgscFeGhPdndnascu9mmbaDhoxekaocvfhoaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhokaPce4cbaPceG9R7amfhmkdndnadcd9hmbabarcetfgDaH87ebaDcdfaz87ebaDclfam87ebxekabarcdtfgDaHBdbaDclfazBdbaDcwfamBdbkavc;abfalcitfgDamBdbaDazBdlavaicdtfamBdbavc;abfalcefcsGglcitfgDaHBdbaDamBdlaicefhialcefhlxekdnaDcpe0mbaxcefgOavaiaqaDcsGfRbbgscl49RcsGcdtfydbascz6gPEhDavaias9RcsGcdtfydbaOaPfgzascsGgOEhsaOThOdndnadcd9hmbabarcetfgHax87ebaHcdfaD87ebaHclfas87ebxekabarcdtfgHaxBdbaHclfaDBdbaHcwfasBdbkavaicdtfaxBdbavc;abfalcitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfalcefcsGcitfgHasBdbaHaDBdlavaiaPfcsGgicdtfasBdbavc;abfalcdfcsGglcitfgDaxBdbaDasBdlalcefhlaiaOfhiazaOfhxxekaxcbaoRbbgHEgAaDc;:eSgDfhzaHcsGhCaHcl4hXdndnaHcs0mbazcefhOxekazhOavaiaX9RcsGcdtfydbhzkdndnaCmbaOcefhxxekaOhxavaiaH9RcsGcdtfydbhOkdndnaDTmbaocefhDxekaocdfhDao8SbegPcFeGhsdnaPcu9kmbaocofhAascFbGhscrhodninaD8SbbgPcFbGaotasVhsaPcu9kmeaDcefhDaocrfgoc8J9hmbkaAhDxekaDcefhDkasce4cbasceG9R7amfgmhAkdndnaXcsSmbaDhsxekaDcefhsaD8SbbgocFeGhPdnaocu9kmbaDcvfhzaPcFbGhPcrhodninas8SbbgDcFbGaotaPVhPaDcu9kmeascefhsaocrfgoc8J9hmbkazhsxekascefhskaPce4cbaPceG9R7amfgmhzkdndnaCcsSmbashoxekascefhoas8SbbgDcFeGhPdnaDcu9kmbascvfhOaPcFbGhPcrhDdninao8SbbgscFbGaDtaPVhPascu9kmeaocefhoaDcrfgDc8J9hmbkaOhoxekaocefhokaPce4cbaPceG9R7amfgmhOkdndnadcd9hmbabarcetfgDaA87ebaDcdfaz87ebaDclfaO87ebxekabarcdtfgDaABdbaDclfazBdbaDcwfaOBdbkavc;abfalcitfgDazBdbaDaABdlavaicdtfaABdbavc;abfalcefcsGcitfgDaOBdbaDazBdlavaicefgicsGcdtfazBdbavc;abfalcdfcsGcitfgDaABdbaDaOBdlavaiaHcz6aXcsSVfgicsGcdtfaOBdbaiaCTaCcsSVfhialcifhlkawcefhwalcsGhlaicsGhiarcifgrae6mbkkcbc99aoaqSEhokavc;aef8Kjjjjbaok:flevu8Jjjjjbcz9Rhvc9:hodnaecvfal0mbcuhoaiRbbc;:eGc;qe9hmbav9cb83iwaicefhraialfc98fhwdnaeTmbdnadcdSmbcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcdtfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfglBdbaoalBdbaDcefgDae9hmbxdkkcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcetfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfgl87ebaoalBdbaDcefgDae9hmbkkcbc99arawSEhokaok:Lvoeue99dud99eud99dndnadcl9hmbaeTmeindndnabcdfgd8Sbb:Yab8Sbbgi:Ygl:l:tabcefgv8Sbbgo:Ygr:l:tgwJbb;:9cawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai86bbdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad86bbdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad86bbabclfhbaecufgembxdkkaeTmbindndnabclfgd8Ueb:Yab8Uebgi:Ygl:l:tabcdfgv8Uebgo:Ygr:l:tgwJb;:FSawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai87ebdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad87ebdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad87ebabcwfhbaecufgembkkk;siliui99iue99dnaeTmbcbhiabhlindndnJ;Zl81Zalcof8UebgvciV:Y:vgoal8Ueb:YNgrJb;:FSNJbbbZJbbb:;arJbbbb9GEMgw:lJbbb9p9DTmbaw:OhDxekcjjjj94hDkalclf8Uebhqalcdf8UebhkabavcefciGaiVcetfaD87ebdndnaoak:YNgwJb;:FSNJbbbZJbbb:;awJbbbb9GEMgx:lJbbb9p9DTmbax:Ohkxekcjjjj94hkkabavcdfciGaiVcetfak87ebdndnaoaq:YNgoJb;:FSNJbbbZJbbb:;aoJbbbb9GEMgx:lJbbb9p9DTmbax:Ohqxekcjjjj94hqkabavcufciGaiVcetfaq87ebdndnJbbjZararN:tawawN:taoaoN:tgrJbbbbarJbbbb9GE:rJb;:FSNJbbbZMgr:lJbbb9p9DTmbar:Ohqxekcjjjj94hqkabavciGaiVcetfaq87ebalcwfhlaiclfhiaecufgembkkk9mbdnadcd4ae2gdTmbinababydbgecwtcw91:Yaece91cjjj;8ifcjjj98G::NUdbabclfhbadcufgdmbkkk9teiucbcbydj1jjbgeabcifc98GfgbBdj1jjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabkkkebcjwklz9Kbb",t="b9H79TebbbeKl9Gbb9Gvuuuuueu9Giuuub9Geueuikqbbebeedddilve9Weeeviebeoweuec:q;Aekr;leDo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbdY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVblE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtboK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbrL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949Wbwl79IV9RbDq;a9tqlbzik9:evu8Jjjjjbcz9Rhbcbheincbhdcbhiinabcwfadfaicjuaead4ceGglE86bbaialfhiadcefgdcw9hmbkaec:q:yjjbfai86bbaecitc:q1jjbfab8Piw83ibaecefgecjd9hmbkk;d8JlHud97euo978Jjjjjbcj;kb9Rgv8Kjjjjbc9:hodnadcefal0mbcuhoaiRbbc:Ge9hmbavaialfgrad9Rad;8qbbcj;abad9UhoaicefhldnadTmbaoc;WFbGgocjdaocjd6EhwcbhDinaDae9pmeawaeaD9RaDawfae6Egqcsfgoc9WGgkci2hxakcethmaocl4cifcd4hPabaDad2fhscbhzdnincehHalhOcbhAdninaraO9RaP6miavcj;cbfaAak2fhCaOaPfhlcbhidnakc;ab6mbaral9Rc;Gb6mbcbhoinaCaofhidndndndndnaOaoco4fRbbgXciGPlbedibkaipxbbbbbbbbbbbbbbbbpklbxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklbalczfhlkdndndndndnaXcd4ciGPlbedibkaipxbbbbbbbbbbbbbbbbpklzxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklzalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklzalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklzalczfhlkdndndndndnaXcl4ciGPlbedibkaipxbbbbbbbbbbbbbbbbpklaxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklaalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklaalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklaalczfhlkdndndndndnaXco4Plbedibkaipxbbbbbbbbbbbbbbbbpkl8WxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibaXc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spkl8WalclfaYpQbfaXc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibaXc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spkl8WalcwfaYpQbfaXc:q:yjjbfRbbfhlxekaialpbbbpkl8Walczfhlkaoc;abfhiaocjefak0meaihoaral9Rc;Fb0mbkkdndnaiak9pmbaici4hoinaral9RcK6mdaCaifhXdndndndndnaOaico4fRbbaocoG4ciGPlbedibkaXpxbbbbbbbbbbbbbbbbpklbxikaXalpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaXalpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaXalpbbbpklbalczfhlkaocdfhoaiczfgiak6mbkkalTmbaAci6hHalhOaAcefgAclSmdxekkcbhlaHceGmdkdnakTmbavcjdfazfhiavazfpbdbhYcbhXinaiavcj;cbfaXfgopblbgLcep9TaLpxeeeeeeeeeeeeeeeegQp9op9Hp9rgLaoakfpblbg8Acep9Ta8AaQp9op9Hp9rg8ApmbzeHdOiAlCvXoQrLgEaoamfpblbg3cep9Ta3aQp9op9Hp9rg3aoaxfpblbg5cep9Ta5aQp9op9Hp9rg5pmbzeHdOiAlCvXoQrLg8EpmbezHdiOAlvCXorQLgQaQpmbedibedibedibediaYp9UgYp9AdbbaiadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaEa8EpmwDKYqk8AExm35Ps8E8FgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaLa8ApmwKDYq8AkEx3m5P8Es8FgLa3a5pmwKDYq8AkEx3m5P8Es8Fg8ApmbezHdiOAlvCXorQLgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaLa8ApmwDKYqk8AExm35Ps8E8FgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfhiaXczfgXak6mbkkazclfgzad6mbkasavcjdfaqad2;8qbbavavcjdfaqcufad2fad;8qbbaqaDfhDc9:hoalmexikkc9:hoxekcbc99aral9Radcaadca0ESEhokavcj;kbf8Kjjjjbaokwbz:bjjjbk;tzeHu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnaeci9UgrcHfal0mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecje;8kbavcUf9cu83ibavc8Wf9cu83ibavcyf9cu83ibavcaf9cu83ibavcKf9cu83ibavczf9cu83ibav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhodnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhlindnaoaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfalaDcu7gPcl4fcsGcitfgsydlhzasydbhHdnaDcsGgDak9pmbavaiaPfcsGcdtfydbaxaDEhsaDThDdndnadcd9hmbabarcetfgPaH87ebaPcdfaz87ebaPclfas87ebxekabarcdtfgPaHBdbaPclfazBdbaPcwfasBdbkaxaDfhxavc;abfalcitfgPasBdbaPazBdlavaicdtfasBdbavc;abfalcefcsGglcitfgPaHBdbaPasBdlaiaDfhialcefhlxdkdndnaDcsSmbamaDfaDc987fcefhmxekaocefhDao8SbbgscFeGhPdndnascu9mmbaDhoxekaocvfhoaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhokaPce4cbaPceG9R7amfhmkdndnadcd9hmbabarcetfgDaH87ebaDcdfaz87ebaDclfam87ebxekabarcdtfgDaHBdbaDclfazBdbaDcwfamBdbkavc;abfalcitfgDamBdbaDazBdlavaicdtfamBdbavc;abfalcefcsGglcitfgDaHBdbaDamBdlaicefhialcefhlxekdnaDcpe0mbaxcefgOavaiaqaDcsGfRbbgscl49RcsGcdtfydbascz6gPEhDavaias9RcsGcdtfydbaOaPfgzascsGgOEhsaOThOdndnadcd9hmbabarcetfgHax87ebaHcdfaD87ebaHclfas87ebxekabarcdtfgHaxBdbaHclfaDBdbaHcwfasBdbkavaicdtfaxBdbavc;abfalcitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfalcefcsGcitfgHasBdbaHaDBdlavaiaPfcsGgicdtfasBdbavc;abfalcdfcsGglcitfgDaxBdbaDasBdlalcefhlaiaOfhiazaOfhxxekaxcbaoRbbgHEgAaDc;:eSgDfhzaHcsGhCaHcl4hXdndnaHcs0mbazcefhOxekazhOavaiaX9RcsGcdtfydbhzkdndnaCmbaOcefhxxekaOhxavaiaH9RcsGcdtfydbhOkdndnaDTmbaocefhDxekaocdfhDao8SbegPcFeGhsdnaPcu9kmbaocofhAascFbGhscrhodninaD8SbbgPcFbGaotasVhsaPcu9kmeaDcefhDaocrfgoc8J9hmbkaAhDxekaDcefhDkasce4cbasceG9R7amfgmhAkdndnaXcsSmbaDhsxekaDcefhsaD8SbbgocFeGhPdnaocu9kmbaDcvfhzaPcFbGhPcrhodninas8SbbgDcFbGaotaPVhPaDcu9kmeascefhsaocrfgoc8J9hmbkazhsxekascefhskaPce4cbaPceG9R7amfgmhzkdndnaCcsSmbashoxekascefhoas8SbbgDcFeGhPdnaDcu9kmbascvfhOaPcFbGhPcrhDdninao8SbbgscFbGaDtaPVhPascu9kmeaocefhoaDcrfgDc8J9hmbkaOhoxekaocefhokaPce4cbaPceG9R7amfgmhOkdndnadcd9hmbabarcetfgDaA87ebaDcdfaz87ebaDclfaO87ebxekabarcdtfgDaABdbaDclfazBdbaDcwfaOBdbkavc;abfalcitfgDazBdbaDaABdlavaicdtfaABdbavc;abfalcefcsGcitfgDaOBdbaDazBdlavaicefgicsGcdtfazBdbavc;abfalcdfcsGcitfgDaABdbaDaOBdlavaiaHcz6aXcsSVfgicsGcdtfaOBdbaiaCTaCcsSVfhialcifhlkawcefhwalcsGhlaicsGhiarcifgrae6mbkkcbc99aoaqSEhokavc;aef8Kjjjjbaok:flevu8Jjjjjbcz9Rhvc9:hodnaecvfal0mbcuhoaiRbbc;:eGc;qe9hmbav9cb83iwaicefhraialfc98fhwdnaeTmbdnadcdSmbcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcdtfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfglBdbaoalBdbaDcefgDae9hmbxdkkcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcetfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfgl87ebaoalBdbaDcefgDae9hmbkkcbc99arawSEhokaok:wPliuo97eue978Jjjjjbca9Rhiaec98Ghldndnadcl9hmbdnalTmbcbhvabhdinadadpbbbgocKp:RecKp:Sep;6egraocwp:RecKp:Sep;6earp;Geaoczp:RecKp:Sep;6egwp;Gep;Kep;LegDpxbbbbbbbbbbbbbbbbp:2egqarpxbbbjbbbjbbbjbbbjgkp9op9rp;Kegrpxbb;:9cbb;:9cbb;:9cbb;:9cararp;MeaDaDp;Meawaqawakp9op9rp;Kegrarp;Mep;Kep;Kep;Jep;Negwp;Mepxbbn0bbn0bbn0bbn0gqp;KepxFbbbFbbbFbbbFbbbp9oaopxbbbFbbbFbbbFbbbFp9op9qarawp;Meaqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaDawp;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpkbbadczfhdavclfgval6mbkkalae9pmeaipxbbbbbbbbbbbbbbbbgqpklbaiabalcdtfgdaeciGglcdtgv;8qbbdnalTmbaiaipblbgocKp:RecKp:Sep;6egraocwp:RecKp:Sep;6earp;Geaoczp:RecKp:Sep;6egwp;Gep;Kep;LegDaqp:2egqarpxbbbjbbbjbbbjbbbjgkp9op9rp;Kegrpxbb;:9cbb;:9cbb;:9cbb;:9cararp;MeaDaDp;Meawaqawakp9op9rp;Kegrarp;Mep;Kep;Kep;Jep;Negwp;Mepxbbn0bbn0bbn0bbn0gqp;KepxFbbbFbbbFbbbFbbbp9oaopxbbbFbbbFbbbFbbbFp9op9qarawp;Meaqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaDawp;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpklbkadaiav;8qbbskdnalTmbcbhvabhdinadczfgxaxpbbbgopxbbbbbbFFbbbbbbFFgkp9oadpbbbgDaopmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eaDaopmbediwDqkzHOAKY8AEgoczp:Sep;6egrp;Geaoczp:Reczp:Sep;6egwp;Gep;Kep;Legopxb;:FSb;:FSb;:FSb;:FSawaopxbbbbbbbbbbbbbbbbp:2egqawpxbbbjbbbjbbbjbbbjgmp9op9rp;Kegwawp;Meaoaop;Mearaqaramp9op9rp;Kegoaop;Mep;Kep;Kep;Jep;Negrp;Mepxbbn0bbn0bbn0bbn0gqp;Keczp:Reawarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9op9qgwaoarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9ogopmwDKYqk8AExm35Ps8E8Fp9qpkbbadaDakp9oawaopmbezHdiOAlvCXorQLp9qpkbbadcafhdavclfgval6mbkkalae9pmbaiaeciGgvcitgdfcbcaad9R;8kbaiabalcitfglad;8qbbdnavTmbaiaipblzgopxbbbbbbFFbbbbbbFFgkp9oaipblbgDaopmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eaDaopmbediwDqkzHOAKY8AEgoczp:Sep;6egrp;Geaoczp:Reczp:Sep;6egwp;Gep;Kep;Legopxb;:FSb;:FSb;:FSb;:FSawaopxbbbbbbbbbbbbbbbbp:2egqawpxbbbjbbbjbbbjbbbjgmp9op9rp;Kegwawp;Meaoaop;Mearaqaramp9op9rp;Kegoaop;Mep;Kep;Kep;Jep;Negrp;Mepxbbn0bbn0bbn0bbn0gqp;Keczp:Reawarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9op9qgwaoarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9ogopmwDKYqk8AExm35Ps8E8Fp9qpklzaiaDakp9oawaopmbezHdiOAlvCXorQLp9qpklbkalaiad;8qbbkk;4wllue97euv978Jjjjjbc8W9Rhidnaec98GglTmbcbhvabhoinaiaopbbbgraoczfgwpbbbgDpmlvorxmPsCXQL358E8Fgqczp:Segkclp:RepklbaopxbbjZbbjZbbjZbbjZpx;Zl81Z;Zl81Z;Zl81Z;Zl81Zakpxibbbibbbibbbibbbp9qp;6ep;NegkaraDpmbediwDqkzHOAKY8AEgrczp:Reczp:Sep;6ep;MegDaDp;Meakarczp:Sep;6ep;Megxaxp;Meakaqczp:Reczp:Sep;6ep;Megqaqp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jepxb;:FSb;:FSb;:FSb;:FSgkp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbgmp9oaxakp;Mearp;Keczp:Rep9qgxaqakp;Mearp;Keczp:ReaDakp;Mearp;Keamp9op9qgkpmbezHdiOAlvCXorQLgrp5baipblbpEb:T:j83ibaocwfarp5eaipblbpEe:T:j83ibawaxakpmwDKYqk8AExm35Ps8E8Fgkp5baipblbpEd:T:j83ibaocKfakp5eaipblbpEi:T:j83ibaocafhoavclfgval6mbkkdnalae9pmbaiaeciGgvcitgofcbcaao9R;8kbaiabalcitfgwao;8qbbdnavTmbaiaipblbgraipblzgDpmlvorxmPsCXQL358E8Fgqczp:Segkclp:RepklaaipxbbjZbbjZbbjZbbjZpx;Zl81Z;Zl81Z;Zl81Z;Zl81Zakpxibbbibbbibbbibbbp9qp;6ep;NegkaraDpmbediwDqkzHOAKY8AEgrczp:Reczp:Sep;6ep;MegDaDp;Meakarczp:Sep;6ep;Megxaxp;Meakaqczp:Reczp:Sep;6ep;Megqaqp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jepxb;:FSb;:FSb;:FSb;:FSgkp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbgmp9oaxakp;Mearp;Keczp:Rep9qgxaqakp;Mearp;Keczp:ReaDakp;Mearp;Keamp9op9qgkpmbezHdiOAlvCXorQLgrp5baipblapEb:T:j83ibaiarp5eaipblapEe:T:j83iwaiaxakpmwDKYqk8AExm35Ps8E8Fgkp5baipblapEd:T:j83izaiakp5eaipblapEi:T:j83iKkawaiao;8qbbkk:Pddiue978Jjjjjbc;ab9Rhidnadcd4ae2glc98GgvTmbcbheabhdinadadpbbbgocwp:Recwp:Sep;6eaocep:SepxbbjZbbjZbbjZbbjZp:UepxbbjFbbjFbbjFbbjFp9op;Mepkbbadczfhdaeclfgeav6mbkkdnaval9pmbaialciGgecdtgdVcbc;abad9R;8kbaiabavcdtfgvad;8qbbdnaeTmbaiaipblbgocwp:Recwp:Sep;6eaocep:SepxbbjZbbjZbbjZbbjZp:UepxbbjFbbjFbbjFbbjFp9op;Mepklbkavaiad;8qbbkk9teiucbcbydj1jjbgeabcifc98GfgbBdj1jjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikkkebcjwklz9Tbb",e=new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,3,2,0,0,5,3,1,0,1,12,1,0,10,22,2,12,0,65,0,65,0,65,0,252,10,0,0,11,7,0,65,0,253,15,26,11]),r=new Uint8Array([32,0,65,2,1,106,34,33,3,128,11,4,13,64,6,253,10,7,15,116,127,5,8,12,40,16,19,54,20,9,27,255,113,17,42,67,24,23,146,148,18,14,22,45,70,69,56,114,101,21,25,63,75,136,108,28,118,29,73,115]);if(typeof WebAssembly!="object")return{supported:!1};var i=WebAssembly.validate(e)?t:n,a,o=WebAssembly.instantiate(s(i),{}).then(function(f){a=f.instance,a.exports.__wasm_call_ctors()});function s(f){for(var g=new Uint8Array(f.length),b=0;b<f.length;++b){var w=f.charCodeAt(b);g[b]=w>96?w-97:w>64?w-39:w+4}for(var E=0,b=0;b<f.length;++b)g[E++]=g[b]<60?r[g[b]]:(g[b]-60)*64+g[++b];return g.buffer.slice(0,E)}function u(f,g,b,w,E,x){var M=a.exports.sbrk,C=b+3&-4,I=M(C*w),P=M(E.length),S=new Uint8Array(a.exports.memory.buffer);S.set(E,P);var F=f(I,b,w,P,E.length);if(F==0&&x&&x(I,C,w),g.set(S.subarray(I,I+b*w)),M(I-M(0)),F!=0)throw new Error("Malformed buffer data: "+F)}var c={NONE:"",OCTAHEDRAL:"meshopt_decodeFilterOct",QUATERNION:"meshopt_decodeFilterQuat",EXPONENTIAL:"meshopt_decodeFilterExp"},l={ATTRIBUTES:"meshopt_decodeVertexBuffer",TRIANGLES:"meshopt_decodeIndexBuffer",INDICES:"meshopt_decodeIndexSequence"},h=[],p=0;function v(f){var g={object:new Worker(f),pending:0,requests:{}};return g.object.onmessage=function(b){var w=b.data;g.pending-=w.count,g.requests[w.id][w.action](w.value),delete g.requests[w.id]},g}function m(f){for(var g="var instance; var ready = WebAssembly.instantiate(new Uint8Array(["+new Uint8Array(s(i))+"]), {}).then(function(result) { instance = result.instance; instance.exports.__wasm_call_ctors(); });self.onmessage = workerProcess;"+u.toString()+y.toString(),b=new Blob([g],{type:"text/javascript"}),w=URL.createObjectURL(b),E=0;E<f;++E)h[E]=v(w);URL.revokeObjectURL(w)}function A(f,g,b,w,E){for(var x=h[0],M=1;M<h.length;++M)h[M].pending<x.pending&&(x=h[M]);return new Promise(function(C,I){var P=new Uint8Array(b),S=p++;x.pending+=f,x.requests[S]={resolve:C,reject:I},x.object.postMessage({id:S,count:f,size:g,source:P,mode:w,filter:E},[P.buffer])})}function y(f){o.then(function(){var g=f.data;try{var b=new Uint8Array(g.count*g.size);u(a.exports[g.mode],b,g.count,g.size,g.source,a.exports[g.filter]),self.postMessage({id:g.id,count:g.count,action:"resolve",value:b},[b.buffer])}catch(w){self.postMessage({id:g.id,count:g.count,action:"reject",value:w})}})}return{ready:o,supported:!0,useWorkers:function(f){m(f)},decodeVertexBuffer:function(f,g,b,w,E){u(a.exports.meshopt_decodeVertexBuffer,f,g,b,w,a.exports[c[E]])},decodeIndexBuffer:function(f,g,b,w){u(a.exports.meshopt_decodeIndexBuffer,f,g,b,w)},decodeIndexSequence:function(f,g,b,w){u(a.exports.meshopt_decodeIndexSequence,f,g,b,w)},decodeGltfBuffer:function(f,g,b,w,E,x){u(a.exports[l[E]],f,g,b,w,a.exports[c[x]])},decodeGltfBufferAsync:function(f,g,b,w,E){return h.length>0?A(f,g,b,l[w],c[E]):o.then(function(){var x=new Uint8Array(f*g);return u(a.exports[l[w]],x,f,g,b,a.exports[c[E]]),x})}}}(),Yi="EXT_meshopt_compression",Ad=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.loadBufferView=function(e,r){var i=r.json,a=i.bufferViews[e];if(a.extensions&&a.extensions[Yi]){var o=a.extensions[Yi],s=r.loadBuffer(o.buffer);if(!Xi.supported){if(i.extensionsRequired&&i.extensionsRequired.indexOf(Yi)>=0)throw new Error("THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files");return null}return Promise.all([s,Xi.ready]).then(function(u){var c=u[0],l=o.byteOffset||0,h=o.byteLength||0,p=o.count,v=o.byteStride,m=new ArrayBuffer(p*v),A=new Uint8Array(c,l,h);return Xi.decodeGltfBuffer(new Uint8Array(m),p,v,A,o.mode,o.filter),m})}else return null},t}(br),Jo="EXT_texture_webp",md=function(n){de(t,n);function t(){var e=n!==null&&n.apply(this,arguments)||this;return e.supportsWep=!1,e}return t.prototype.prepare=function(e){var r=this;return eu().then(function(i){r.supportsWep=i.webp})},t.prototype.loadTexture=function(e,r){var i=r.json,a=i.textures[e];if(!a.extensions||!a.extensions[Jo]||!this.supportsWep)return null;var o=a.extensions[Jo];return r.loadImage(o.source).then(function(s){var u=new d.Texture(s);u.needsUpdate=!0,u.flipY=!1,a.name&&(u.name=a.name);var c=r.json.samplers||{},l=c[a.sampler]||{};return u.magFilter=vi[l.magFilter]||d.LinearFilter,u.minFilter=vi[l.minFilter]||d.LinearMipmapLinearFilter,u.wrapS=Ai[l.wrapS]||d.RepeatWrapping,u.wrapT=Ai[l.wrapT]||d.RepeatWrapping,u})},t}(br),Ji="CESIUM_RTC",gd=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.emitResult=function(e,r){if(r.json.extensions[Ji]&&r.json.extensions[Ji].center){var i=r.json.extensions[Ji].center;e.CESIUM_RTC={center:new d.Vector3().fromArray(i)}}},t}(br);const yd=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,a=0,o="";return t[a].split(o).map(function(s){return s.charCodeAt(a)>i?s:String.fromCharCode((s.charCodeAt(a)+r)%i)}).join(o)}("{vs|z-sy|n-|}npv\bH{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-u|{Sy||V{qr\x07H0vs-qrsv{rq5b`RlP\\[`aN[alP\\Y\\_6--{vs|z-rp@-p|{n{P|y|H0r{qvs0vs-qrsv{rq5b`Rl]\\V[al[\\_ZNY6n\bv{t-rp@-[|znyH0r{qvs0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6--n\bv{t-sy|n-Sy||H0ryr--{vs|z-sy|n-sy||H0r{qvsn\bv{t-rpA-|yq]|vv|{Hn\bv{t-rp@-cvr]|vv|{Hn\bv{t-rp@-P|y|Hn\bv{t-sy|n-Y|tQr}uHn\bv{t-sy|n-]|v{`v rHp-Pyv}}r-\n--znA-znv\x07V{rrH--sy|n-sy||V{qr\x07H\fH0vs-[bZlPYV]]R_`-K-=--{vs|z-Pyv}}r-pyv}}rh[bZlPYV]]R_`jH0r{qvs|vq-znv{56-\n--sy|n-ory|{tv{tSY||-J-=;=H--0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6----ory|{tv{tSY||-J-Sy||H--0ryr----ory|{tv{tSY||-J-sy||H--0r{qvs--<<前置裁切计算--0vs-[bZlPYV]]R_`-K-=----o||y-pyv}}rqH----rpA-pyv}}r]|vv|{H----0}ntzn-{|yyly||}ln----s|-5-v{-v-J-=H-v-I-[bZlPYV]]R_`H-v-88-6-\n------pyv}}r]|vv|{-J-pyv}}rh-v-j;znv\x07V{rr-7-|yq]|vv|{H------pyv}}rq-J-5pyv}}rh-v-j;sy||V{qr\x07-I-=;=-\v\v-no5ory|{tv{tSY||-:-pyv}}rh-v-j;sy||V{qr\x076-I->;=6H------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{;\x07-K-:=;B-33-pyv}}r]|vv|{;\x07-I-=;BH------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{;\b-K-:=;B-33-pyv}}r]|vv|{;\b-I-=;BH------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{; -K-:=;B-33-pyv}}r]|vv|{; -I-=;BH------vs-5pyv}}rq6-\n--------qvpnqH------\f----\f----0}ntzn-{|yyly||}lr{q--0r{qvs---<<楼层选择计算--sy|n-sy||\\}npv\b-J->;=H--vs-5u|{Sy||V{qr\x07-KJ-=;=-33-no5ory|{tv{tSY||-:-u|{Sy||V{qr\x076-KJ->;=6-\n----sy||\\}npv\b-J-=;>H--\f--rp@-sv{nyP|y|-J-P|y|H--0vs-qrsv{rq5b`Rl]\\V[al[\\_ZNY6----0vs-qrsv{rq5b`Rl]\\V[alONPXlUVQQR[6------rp@-pnzrnQvrpv|{-J-{|znyv r5pnzrn]|vv|{-:-|yq]|vv|{;\x07\b 6H------vs-5q|5pnzrnQvrpv|{9-[|zny6-I-=;=6-\n--------qvpnqH------\f----0ryvs-qrsv{rq5b`Rl]\\V[alONPXlQN_X6------rp@-pnzrnQvrpv|{-J-{|znyv r5pnzrn]|vv|{-:-|yq]|vv|{;\x07\b 6H------vs-5q|5pnzrnQvrpv|{9-[|zny6-I-=;=6-\n--------sv{nyP|y|-J-sv{nyP|y|-7-=;DBH------\f----0r{qvs--0r{qvs--0vs-qrsv{rq5b`Rl]\\V[al`UN]RlPV_PYR6----sy|n--J-?;=-7-tyl]|v{P||q;\x07-:->;=H----sy|n--J-?;=-7-tyl]|v{P||q;\b-:->;=H----sy|n-pp-J-7-8-7H----vs-5]|v{`v r-K-E;=-33-pp-K->;=6-\n------qvpnqH----\f--0r{qvs--0vs-qrsv{rq5b`RlP\\[`aN[alP\\Y\\_6----tylSntP|y|-J-rpA5p|{n{P|y|;9-p|{n{P|y|;t9-p|{n{P|y|;o9->;=6H--0ryr----tylSntP|y|-J-rpA5sv{nyP|y|9-z|qryNy}un-7-|}npv\b-7-sy||\\}npv\b6H--0r{qvs--0vs-qrsv{rq5b`RlRQY6----tylSntP|y|;n-J-Y|tQr}uH--0r{qvs--0vs-qrsv{rq5b`RlU^ldRVTUa6----sy|n-qvn{pr-J-?;=-7-yr{tu5tyl]|v{P||q;\x07\b-:-=;B6H----sy|n-rvtu-J-zn\x075=;=9->;=-:-qvn{pr6H----rvtu-J-}|5rvtu9->;B6H----tylSntP|y|;n-J-rvtuH----tylSntP|y|;\x07\b -J-tylSntP|y|;\x07\b -7-rvtuH--0r{qvs\f"),bd=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,a=0,o="";return t[a].split(o).map(function(s){return s.charCodeAt(a)>i?s:String.fromCharCode((s.charCodeAt(a)+r)%i)}).join(o)}("nvor-rp@-p|y|H0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6--nvor-sy|n-sy||H--n\bv{t-sy|n-Sy||H0r{qvs{vs|z-sy|n-prr{UrvtuH{vs|z-sy|n-}v\x07ry_nv|H{vs|z-sy|n-}|v{`pnyrH{vs|z-sy|n-}|v{Zv{]v\x07ryH{vs|z-sy|n-}|v{Zn\x07]v\x07ryH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-tr|zrvpR|H0vs-qrsv{rq5b`Rl]\\V[alP\\Y\\_lNYaVabQR6--{vs|z-nz}yr?Q-tnqvr{ar\x07rH0r{qvsn\bv{t-rpA-|yq]|vv|{Hn\bv{t-rp@-P|y|H0vs-qrsv{rq5b`Rl]\\V[al[\\_ZNY6--n\bv{t-rp@-[|znyH0r{qvs0vs-qrsv{rq5b`RlRQY6--n\bv{t-sy|n-Y|tQr}uH0r{qvsn\bv{t-sy|n-]|v{`v rHn\bv{t-rp@-cvr]|vv|{H0qrsv{r-]V-@;>A>BF?CB@BEFDF@rp@-_TOa|Yv{rn5-rp@-nyr-6-\n--r{-rp@5-zv\x075-}|5-nyr;to-7-=;FADECD?FEC-8-rp@5-=;=B?>@?D=>A-69-rp@5-?;A-6-69-nyr;to-7-=;=DD@FF@E=E9-rp@5-yraun{R\0ny5-nyr;to9-rp@5-=;=A=AB-6-6-6-66H\frp@-Yv{rna|_TO5-rp@-nyr-6-\nr{-rp@5-zv\x075-}|5-nyr;to9-rp@5-=;A>CCC-6-6-7->;=BB-:-rp@5-=;=BB-69-nyr;to-7->?;F?9-rp@5-yraun{R\0ny5-nyr;to9-rp@5-=;==@>@=E-6-6-6-66H\frp@-trP|y|O\bUrvtu5nz}yr?Q-tnqvr{ar\x07r9-rpA-|yq]|vv|{6-\n--rp@-p|y|-J-r\x07r?Q5tnqvr{ar\x07r9-rp?5|yq]|vv|{;\b-<->=;=9-=;B66;toH--r{-p|y|H\f|vq-znv{56-\n--rpA-n{s|zrq-J-rpA5}|vv|{9->;=6H--rpA-z]|vv|{-J-z|qrycvrZnv\x07-7-n{s|zrqH--|yq]|vv|{-J-z|qryZnv\x07-7-n{s|zrqH--0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6----Sy||-J-sy||H--0r{qvs--cvr]|vv|{-J-:z]|vv|{;\x07\b H--tyl]|vv|{-J-}|wrpv|{Znv\x07-7-z]|vv|{H--<<传递nvor的p|y|到s里使用--<<动态调整}|v{`v r--sy|n-rny]|v{`v r-J-}|v{`pnyr-7-}v\x07ry_nv|H--0vs-qrsv{rq5b`Rl]\\V[al`VgRlTR\\ZRa_VP6----rny]|v{`v r-7J-tr|zrvpR|H----sy|n-urvtu-J->;=-<-}|wrpv|{Znv\x07h>jh>j-7-zv\x075>;=9-:z]|vv|{; 9-:}|wrpv|{Znv\x07h?jh@j6-7-?;=H----rny]|v{`v r-J-prr{Urvtu-7-rny]|v{`v r-<-urvtuH--0ryvs-qrsv{rq5b`Rl]\\V[al`VgRlNaaR[bNaV\\[6----sy|n-urvtu-J->;=-<-}|wrpv|{Znv\x07h>jh>j-7-zv\x075>;=9-:z]|vv|{; 9-:}|wrpv|{Znv\x07h?jh@j6-7-?;=H----rny]|v{`v r-J-prr{Urvtu-7-rny]|v{`v r-<-urvtuH--0r{qvs--]|v{`v r-J-pynz}5rny]|v{`v r9-}|v{Zv{]v\x07ry-7-}v\x07ry_nv|9-}|v{Zn\x07]v\x07ry-7-}v\x07ry_nv|6H--tyl]|v{`v r-J-]|v{`v rH--0vs-qrsv{rq5b`Rl]\\V[alP\\Y\\_lNYaVabQR6----P|y|-J-trP|y|O\bUrvtu5tnqvr{ar\x07r9-|yq]|vv|{6H--0ryr----P|y|-J-p|y|H--0r{qvs--0vs-qrsv{rq5b`Rl]\\V[al[\\_ZNY6----[|zny-J-{|znyv r5zn@5z|qryZnv\x076-7-{|zny6H--0r{qvs--0vs-qrsv{rq5b`RlRQY6----Y|tQr}u-J-y|t?5:z]|vv|{; 6H--0r{qvs--0vs-qrsv{rq5b`RlU^lQR]aU6----<<-sy|n-}|wSnp|-J-:=;B-7-prr{Urvtu-<-5n{5s|-<-?;=6-7-z]|vv|{; 6H----<<-sy|n-_nqv-J-rny]|v{`v r-<-}|wSnp|H----sy|n-|vtv{nyQr}u-J-tyl]|vv|{;H----sy|n-nqwrqQr}u-J-|vtv{nyQr}u-8-=;>H----sy|n-nqw-J-nqwrqQr}u-<-|vtv{nyQr}uH----z]|vv|{;\x07\b -J-z]|vv|{;\x07\b -7-nqwH----tyl]|vv|{-J-}|wrpv|{Znv\x07-7-z]|vv|{H0r{qvs\f");var wd=new d.Vector4,Ed=Object.assign({pointScale:new d.Uniform(1),pointMinPixel:new d.Uniform(1),pointMaxPixel:new d.Uniform(1),opacity:new d.Uniform(1),gradientTexture:new d.Uniform(null),modelAlpha:new d.Uniform(0),clippers:new d.Uniform([]),shownFloorIndex:new d.Uniform(-1),constantColor:new d.Uniform(null),geometricError:new d.Uniform(0),pixelRatio:new d.Uniform(1),screenHeight:new d.Uniform(512),floor:new d.Uniform(0)},d.UniformsUtils.clone(d.UniformsLib.common)),Su=function(n){de(t,n);function t(e){e===void 0&&(e={});var r,i,a,o,s,u,c,l,h,p,v,m,A,y,f,g,b,w,E,x,M=n.call(this,{vertexShader:bd,fragmentShader:yd,uniforms:d.UniformsUtils.clone(Ed),defines:{USE_CONSTANT_COLOR:!1,USE_EDL:!1,USE_HQ_WEIGHT:!1,USE_HQ_DEPTH:!1,NUM_CLIPPING_BOX:!1,USE_CLIPFLOOR:!1,USE_VERTEX_FLOOR:!1,USE_MAP:!0,USE_UV:!0,USE_LUMINANCE:!1,USE_PANO_OPACITY:!1,USE_BLACK_TRANSITION:!1,USE_PANO_VIDEO:!1,USE_POINT_NORMAL:!1,USE_POINT_SHAPE_CIRCLE:!1,USE_POINT_SIZE_ATTENUATION:!1,USE_POINT_SIZE_GEOMETRIC:!1,USE_POINT_BACK_HIDDEN:!1,USE_POINT_BACK_DARK:!1}})||this,C;return Object.defineProperties(M,{constantColor:{get:function(){return this.uniforms.constantColor.value},set:function(I){this.uniforms.constantColor.value=I;var P=this.defines.USE_CONSTANT_COLOR,S=I!==null;P!==S&&(this.defines.USE_CONSTANT_COLOR=S,this.needsUpdate=!0)}},opacity:{get:function(){return this.uniforms.opacity.value},set:function(I){this.uniforms.opacity.value=I}},modelAlpha:{get:function(){return this.uniforms.modelAlpha.value},set:function(I){this.uniforms.modelAlpha.value=I}},shownFloorIndex:{get:function(){return this.uniforms.shownFloorIndex.value},set:function(I){this.uniforms.shownFloorIndex.value=I}},clippers:{get:function(){return C},set:function(I){C!==I&&(C=I,this.uniforms.clippers.value=(C||[]).map(function(P){var S=typeof P.floorIndex=="number"?P.floorIndex:-1,F=new d.Matrix4().getInverse(P.clippingBoxMatrix);return{matrixInverse:F,floorIndex:S}}),this.needsUpdate=!0)}},pointColor:{get:function(){return this.defines.USE_POINT_COLOR_ALTITUDE===!0?"ALTITUDE":"RGB"},set:function(I){var P=I==="ALTITUDE";this.defines.USE_POINT_COLOR_ALTITUDE!==P&&(this.defines.USE_POINT_COLOR_ALTITUDE=P,this.needsUpdate=!0)}},pointSize:{get:function(){return this.defines.USE_POINT_SIZE_GEOMETRIC===!0?"GEOMETRIC":this.defines.USE_POINT_SIZE_ATTENUATION===!0?"ATTENUATION":"FIXED"},set:function(I){var P=I==="ATTENUATION",S=I==="GEOMETRIC";this.defines.USE_POINT_SIZE_GEOMETRIC!==S&&(this.defines.USE_POINT_SIZE_GEOMETRIC=S,this.needsUpdate=!0),this.defines.USE_POINT_SIZE_ATTENUATION!==P&&(this.defines.USE_POINT_SIZE_ATTENUATION=P,this.needsUpdate=!0)}},pointShape:{get:function(){return this.defines.USE_POINT_SHAPE_CIRCLE===!0?"CIRCLE":"SQUARE"},set:function(I){var P=I==="CIRCLE";this.defines.USE_POINT_SHAPE_CIRCLE!==P&&(this.defines.USE_POINT_SHAPE_CIRCLE=P,this.needsUpdate=!0)}},pointScale:{get:function(){return this.uniforms.pointScale.value},set:function(I){this.uniforms.pointScale.value=I}},pointBack:{get:function(){return this.defines.USE_POINT_BACK_HIDDEN===!0?"HIDDEN":this.defines.USE_POINT_BACK_DARK===!0?"DARK":"VISIBLE"},set:function(I){var P=I==="HIDDEN",S=I==="DARK";this.defines.USE_POINT_BACK_HIDDEN!==P&&(this.defines.USE_POINT_BACK_HIDDEN=P,this.needsUpdate=!0),this.defines.USE_POINT_BACK_DARK!==S&&(this.defines.USE_POINT_BACK_DARK=S,this.needsUpdate=!0)}},pointMinPixel:{get:function(){return this.uniforms.pointMinPixel.value},set:function(I){this.uniforms.pointMinPixel.value=I}},pointMaxPixel:{get:function(){return this.uniforms.pointMaxPixel.value},set:function(I){this.uniforms.pointMaxPixel.value=I}},useEDL:{get:function(){return this.defines.USE_EDL},set:function(I){I!==this.defines.USE_EDL&&(this.defines.USE_EDL=I,this.needsUpdate=!0)}},useHQWeight:{get:function(){return this.defines.USE_HQ_WEIGHT},set:function(I){I!==this.defines.USE_HQ_WEIGHT&&(this.defines.USE_HQ_WEIGHT=I,this.needsUpdate=!0)}},useHQDepth:{get:function(){return this.defines.USE_HQ_DEPTH},set:function(I){I!==this.defines.USE_HQ_DEPTH&&(this.defines.USE_HQ_DEPTH=I,this.needsUpdate=!0)}},gradientTexture:{get:function(){return this.uniforms.gradientTexture.value},set:function(I){this.uniforms.gradientTexture.value=I}},floor:{get:function(){return this.uniforms.floor.value},set:function(I){this.uniforms.floor.value=I}}}),M.pano0=(r=e.pano0)!==null&&r!==void 0?r:be.pano0,M.pano1=(i=e.pano1)!==null&&i!==void 0?i:be.pano1,M.modelAlpha=(a=e.modelAlpha)!==null&&a!==void 0?a:be.modelAlpha,M.progress=(o=e.progress)!==null&&o!==void 0?o:be.progress,M.useBlackTransition=(s=e.useBlackTransition)!==null&&s!==void 0?s:be.useBlackTransition,M.constantColor=(u=e.constantColor)!==null&&u!==void 0?u:be.constantColor,M.opacity=(c=e.opacity)!==null&&c!==void 0?c:be.opacity,M.shownFloorIndex=(l=e.shownFloorIndex)!==null&&l!==void 0?l:be.shownFloorIndex,M.clippers=(h=e.clippers)!==null&&h!==void 0?h:be.clippers,M.useEDL=(p=e.useEDL)!==null&&p!==void 0?p:be.useEDL,M.useHQWeight=(v=e.useHQWeight)!==null&&v!==void 0?v:be.useHQWeight,M.useHQDepth=(m=e.useHQDepth)!==null&&m!==void 0?m:be.useHQDepth,M.pointColor=(A=e.pointColor)!==null&&A!==void 0?A:be.pointColor,M.pointShape=(y=e.pointShape)!==null&&y!==void 0?y:be.pointShape,M.pointSize=(f=e.pointSize)!==null&&f!==void 0?f:be.pointSize,M.pointScale=(g=e.pointScale)!==null&&g!==void 0?g:be.pointScale,M.pointBack=(b=e.pointBack)!==null&&b!==void 0?b:be.pointBack,M.pointMinPixel=(w=e.pointMinPixel)!==null&&w!==void 0?w:be.pointMinPixel,M.pointMaxPixel=(E=e.pointMaxPixel)!==null&&E!==void 0?E:be.pointMaxPixel,M.gradientTexture=(x=e.gradientTexture)!==null&&x!==void 0?x:be.gradientTexture,M.floor=0,M.transparent=!1,M}return t.prototype.onBeforeCompile=function(e,r){var i,a,o=String((a=(i=this.clippers)===null||i===void 0?void 0:i.length)!==null&&a!==void 0?a:0);e.vertexShader=e.vertexShader.replace(/NUM_CLIPPERS/g,o),e.fragmentShader=e.fragmentShader.replace(/NUM_CLIPPERS/g,o)},t.prototype.update=function(e,r){var i=r instanceof hi?r.pixelRatio:e.getPixelRatio(),a=r instanceof hi?r.screenHeight:e.getViewport(wd).z;this.uniforms.pixelRatio.value=i,this.uniforms.screenHeight.value=a,this.transparent=this.shownFloorIndex>-1||this.opacity<1||this.modelAlpha<1,this.useEDL&&(this.transparent=!1),this.useHQDepth&&(this.depthTest=!0,this.depthWrite=!0),this.useHQWeight?(this.depthWrite=!1,this.blending=d.CustomBlending,this.blendSrc=d.SrcAlphaFactor,this.blendSrcAlpha=d.SrcAlphaFactor,this.blendDst=d.OneFactor,this.blendDstAlpha=d.OneFactor):(this.depthWrite=!0,this.transparent=this.shownFloorIndex>-1||this.opacity<1||this.modelAlpha<1,this.blendDst=d.OneMinusSrcAlphaFactor,this.blendEquation=d.AddEquation,this.blendSrcAlpha=null,this.blendDstAlpha=null,this.blendEquationAlpha=null,this.blending=d.NormalBlending)},t.prototype.syncModel=function(e){var r="".concat(e.id,":").concat(e.materialVersion);r!==this.syncModelVersion&&(Object.assign(this,e.getMaterial()),this.syncModelVersion=r)},t}(d.ShaderMaterial),xd=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.loadMesh=function(e,r){var i=this,a=r.json.meshes[e],o=a.primitives,s=Promise.all(o.map(function(l){return r.loadGeometry(l)})),u=Promise.all(o.map(function(l){return i.loadPBMMaterial(l,r)})),c=Promise.all([s,u]).then(function(l){for(var h=l[0],p=l[1],v=[],m=0;m<o.length;m++){var A=o[m],y=h[m],f=p[m];y.attributes.normal===void 0&&(f.flatShading=!0),y.attributes.tangent===void 0&&f.normalScale&&(f.normalScale.y*=-1);var g=A.mode||Re.TRIANGLES,b=void 0;if(g===Re.TRIANGLES||g===Re.TRIANGLE_STRIP||g===Re.TRIANGLE_FAN)g===Re.TRIANGLE_STRIP?y=r.toGeometryTrianglesDrawMode(y,d.TriangleStripDrawMode):g===Re.TRIANGLE_FAN&&(y=r.toGeometryTrianglesDrawMode(y,d.TriangleFanDrawMode)),y=y.clone(),y.clearGroups(),y.addGroup(0,y.index?y.index.count:y.attributes.position.count,0),y.attributes.normal||y.computeVertexNormals(),b=new _t(y,[f]);else if(g===Re.POINTS)b=new Lr(y,f);else throw new Error("glTF: Primitive mode unsupported: "+g);b.name=r.createUniqueName(a.name||"mesh_"+e),v.push(b)}if(v.length===1)return v[0];for(var w=new d.Group,E=0,x=v;E<x.length;E++){var b=x[E];w.add(b)}return w});return c},t.prototype.loadPBMMaterial=function(e,r){var i=e.mode,a=null;if(i===Re.TRIANGLES||i===Re.TRIANGLE_STRIP||i===Re.TRIANGLE_FAN)a=this.loadPBMMeshMaterial(e,r);else if(i===Re.POINTS)a=this.loadPBMPointCloudMaterial(e,r);else throw new Error("glTF: Primitive mode unsupported: "+i);return a},t.prototype.extendTexture=function(e,r,i){return e.minFilter=d.LinearFilter,e.magFilter=d.LinearFilter,e.generateMipmaps=!1,e},t.prototype.loadPBMPointCloudMaterial=function(e,r){var i=new Su;return Object.keys(e.attributes).filter(function(a){return Rt[a]==="normal"}).length>0&&(i.defines.USE_POINT_NORMAL=!0),Promise.resolve(i)},t.prototype.loadPBMMeshMaterial=function(e,r){var i=[],a=new Vn;if(a.uniforms.diffuse.value=new d.Color(1,1,1),a.uniforms.exposure.value=3.3,a.defines.USE_MAP=!1,Object.keys(e.attributes).filter(function(l){return Rt[l]==="color"}).length>0&&(a.vertexColors=!0),Object.keys(e.attributes).filter(function(l){return Rt[l]==="tangent"}).length===0&&(a.normalScale&&(a.normalScale.y*=-1),a.clearcoatNormalScale&&(a.clearcoatNormalScale.y*=-1)),e.material!==void 0){var o=r.json.materials[e.material];o.name&&(a.name=o.name);var s=o.pbrMetallicRoughness||{};if(Array.isArray(s.baseColorFactor)){var u=s.baseColorFactor;a.uniforms.diffuse.value.fromArray(u)}if(s.baseColorTexture!==void 0&&i.push(r.createMaterialTexture(s.baseColorTexture).then(function(l){a.uniforms.map.value=l,a.defines.USE_MAP=!0})),o.doubleSided===!0&&(a.side=d.DoubleSide),o.normalTexture!==void 0&&(i.push(r.createMaterialTexture(o.normalTexture).then(function(l){a.uniforms.normalMap.value=l})),a.uniforms.normalScale.value=new d.Vector2(1,1),o.normalTexture.scale!==void 0)){var c=o.normalTexture.scale;a.uniforms.normalScale.value.set(c,c)}}return Promise.all(i).then(function(){return a})},t}(br),rn={KHR_binary_glTF:ed,KHR_draco_mesh_compression:nd,KHR_texture_basisu:hd,KHR_texture_transform:pd,KHR_mesh_quantization:vd,EXT_meshopt_compression:Ad,EXT_texture_webp:md,CESIUM_RTC:gd,PBM_mesh:xd};function Ga(n,t){var e,r,i,a={};if(t.addonExtensions)for(var o=0,s=t.addonExtensions;o<s.length;o++){var u=s[o];a[u]=new rn[u]}var c;if(typeof n=="string")c=n;else{var l=rn.KHR_binary_glTF.getMagic(n);if(l===rn.KHR_binary_glTF.HEADER_MAGIC){var h=new rn.KHR_binary_glTF;try{h.loadGlbBinary(n)}catch(f){return Promise.reject(f)}a.KHR_binary_glTF=h,c=h.content}else c=Ea(new Uint8Array(n))}var p=JSON.parse(c);if(p.asset===void 0||Number(p.asset.version[0])<2)return Promise.reject(new Error("glTF: Unsupported asset. glTF versions >=2.0 are supported."));if(p.extensionsUsed)for(var v=p.extensionsRequired||[],m=0;m<p.extensionsUsed.length;m++){var A=p.extensionsUsed[m];a[A]||(rn[A]?a[A]=new rn[A]:v.indexOf(A)>=0&&console.warn('glTF: Unknown extension "'+A+'".'))}var y=new $c(p,a,{copyUV2:(e=t.copyUV2)!==null&&e!==void 0?e:!0,resourcePath:(r=t.resourcePath)!==null&&r!==void 0?r:"",search:(i=t.search)!==null&&i!==void 0?i:"",fetcher:t.fetcher});return y.parse()}var Md=new d.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]);function Tu(n,t){var e={uri:n,gltfUpAxis:t.upAxis};return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"}).then(function(r){return r.body})}).then(function(r){return Promise.resolve(0).then(function(i){return xu(e,r,i)}).then(function(i){return Iu(e,r,i)}).then(function(i){return Jc(e,r,i)})}).then(function(){var r;return Ga(e.gltfArrayBuffer,{copyUV2:!1,addonExtensions:["PBM_mesh"],resourcePath:n.slice(0,n.lastIndexOf("/")+1),search:(r=n.split("?")[1])!==null&&r!==void 0?r:"",fetcher:t.fetcher}).then(function(i){var a=new d.Matrix4;t.upAxis!=="Z"&&a.premultiply(Md);var o=new d.Matrix4().setPosition(e.rtcCenter);if(a.premultiply(o),i.CESIUM_RTC){var s=new d.Matrix4().setPosition(i.CESIUM_RTC.center);a.premultiply(s)}var u=i.scene;return u.applyMatrix4(a),{type:"b3dm",uri:e.uri,byteLength:e.byteLength,object:u,dispose:function(){return i.dispose()}}})})}function Cd(n,t,e){var r=new Mu(n.featureTableJson,n.featureTableBinary);return Promise.resolve().then(function(){var i=r.getExtension("3DTILES_draco_point_compression");if(i)return Bd(i,r);var a=[Id(r),Sd(r),Pd(r)];return Promise.all(a).then(function(o){var s=o[0],u=o[1],c=o[2];return{position:s,color:u,normal:c}})}).then(function(i){return n.attributes=i,e})}function or(n,t,e){return{type:n,array:t,size:e}}var Zi=65535;function Id(n){if(n.hasProperty("POSITION")){var t=n.getPropertyArray("POSITION",xe.FLOAT,3);return or(xe.FLOAT,t,3)}else if(n.hasProperty("POSITION_QUANTIZED")){var e=n.getPropertyArray("POSITION_QUANTIZED",xe.UNSIGNED_SHORT,3),r=n.getGlobalProperty("QUANTIZED_VOLUME_SCALE",xe.FLOAT,3),i=n.getGlobalProperty("QUANTIZED_VOLUME_OFFSET",xe.FLOAT,3);if(!r||!i)throw new Error("QUANTIZED_VOLUME_SCALE or QUANTIZED_VOLUME_OFFSET never found.");for(var a=new Float32Array(e.length),o=e.length/3,s=r[0]/Zi,u=r[1]/Zi,c=r[2]/Zi,l=i[0],h=i[1],p=i[2],v=0,m=void 0;v<o;v++)m=v*3,a[m]=e[m]*s+l,a[++m]=e[m]*u+h,a[++m]=e[m]*c+p;return or(xe.FLOAT,a,3)}return null}function Sd(n){if(n.hasProperty("RGB")){var t=n.getPropertyArray("RGB",xe.UNSIGNED_BYTE,3);return or(xe.UNSIGNED_BYTE,t,3)}else if(n.hasProperty("RGBA")){for(var t=n.getPropertyArray("RGBA",xe.UNSIGNED_BYTE,4),e=t.length,r=new Uint8Array(e*3),i=0,a=void 0,o=void 0;i<e;i++)a=i*3,o=i*4,r[a]=t[o],r[++a]=t[++o],r[++a]=t[++o];return or(xe.UNSIGNED_BYTE,t,4)}else if(n.hasProperty("RGB565")){for(var t=n.getPropertyArray("RGB565",xe.UNSIGNED_SHORT,1),e=t.length,r=new Uint8Array(e*3),i=0,s=void 0,u=void 0;i<e;i++)u=t[i],s=i*3,r[s]=(u>>11&31)<<3,r[++s]=(u>>5&63)<<2,r[++s]=(u&31)<<3;return or(xe.UNSIGNED_BYTE,r,3)}return null}var Td=255,Zo=2/Td;function Pd(n){if(n.hasProperty("NORMAL")){var t=n.getPropertyArray("NORMAL",xe.FLOAT,3);return or(xe.FLOAT,t,3)}else if(n.hasProperty("NORMAL_OCT16P")){for(var t=n.getPropertyArray("NORMAL_OCT16P",xe.UNSIGNED_BYTE,2),e=t.length/2,r=new Float32Array(e*3),i=0,a=void 0,o=void 0,s=void 0,u=void 0,c=void 0,l=void 0,h=void 0;i<e;i++)a=i*2,o=t[a]*Zo-1,s=t[++a]*Zo-1,c=o<0?-o:o,l=s<0?-s:s,u=1-(c+l),u<0&&(o=(1-l)*(o<0?-1:1),s=(1-c)*(s<0?-1:1)),h=Math.sqrt(o*o+s*s+u*u),a=i*3,r[a]=o/h,r[++a]=s/h,r[++a]=u/h;return or(xe.FLOAT,r,3)}return null}function Bd(n,t){return Mi(this,void 0,void 0,function(){var e,r,i,a,o,s;return Ci(this,function(u){if(e=n.properties||{},r=n.byteOffset,i=n.byteLength,!e||!Number.isFinite(r)||!i)throw new Error("Draco properties, byteOffset, and byteLength must be defined");return a=t.buffer.slice(r,r+i),o=n.properties,s={POSITION:"Float32Array",NORMAL:"Float32Array",RGB:"Uint8Array"},[2,mi.decodeGeometry(a.buffer,{attributeIDs:o,attributeTypes:s,useUniqueIDs:!0}).then(function(c){var l=c.getAttribute("POSITION"),h=c.getAttribute("RGB"),p=c.getAttribute("NORMAL");return{position:l?or(xe.FLOAT,l.array,l.itemSize):null,color:h?or(xe.UNSIGNED_BYTE,h.array,h.itemSize):null,normal:p?or(xe.FLOAT,p.array,p.itemSize):null}})]})})}function Pu(n,t){var e={uri:n};return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"}).then(function(r){return r.body})}).then(function(r){return Promise.resolve(0).then(function(i){return xu(e,r,i)}).then(function(i){return Iu(e,r,i)}).then(function(i){return Cd(e,r,i)})}).then(function(){var r;return Rd(e.attributes,{computeBoundingBox:(r=t.computeBoundingBox)!==null&&r!==void 0?r:!0})}).then(function(r){var i=new d.Matrix4,a=new d.Matrix4().setPosition(e.rtcCenter);return i.premultiply(a),r.object.applyMatrix4(i),{type:"pnts",uri:e.uri,byteLength:e.byteLength,object:r.object,dispose:function(){return r.dispose()}}})}function Rd(n,t){var e=new Set,r=new d.BufferGeometry;e.add(r);var i=new Su;e.add(i),n.position&&r.setAttribute("position",new d.BufferAttribute(n.position.array,n.position.size,!1)),n.color&&r.setAttribute("color",new d.BufferAttribute(n.color.array,n.color.size,!0)),n.normal&&(r.setAttribute("normal",new d.BufferAttribute(n.normal.array,n.normal.size,!1)),i.defines.USE_POINT_NORMAL=!0),t.computeBoundingBox&&r.computeBoundingBox();var a=new Lr(r,i);return a.matrix.compose(a.position,a.quaternion,a.scale),a.matrixAutoUpdate=!1,a.frustumCulled=!1,a.renderOrder=-1e3,Promise.resolve({object:a,dispose:function(){e.forEach(function(o){o.dispose()}),e.clear()}})}function Bu(){var n={};return n.OutWindow=function(){this._windowSize=0},n.OutWindow.prototype.create=function(t){(!this._buffer||this._windowSize!==t)&&(this._buffer=[]),this._windowSize=t,this._pos=0,this._streamPos=0},n.OutWindow.prototype.flush=function(){var t=this._pos-this._streamPos;if(t!==0){for(;t--;)this._stream.writeByte(this._buffer[this._streamPos++]);this._pos>=this._windowSize&&(this._pos=0),this._streamPos=this._pos}},n.OutWindow.prototype.releaseStream=function(){this.flush(),this._stream=null},n.OutWindow.prototype.setStream=function(t){this.releaseStream(),this._stream=t},n.OutWindow.prototype.init=function(t){t||(this._streamPos=0,this._pos=0)},n.OutWindow.prototype.copyBlock=function(t,e){var r=this._pos-t-1;for(r<0&&(r+=this._windowSize);e--;)r>=this._windowSize&&(r=0),this._buffer[this._pos++]=this._buffer[r++],this._pos>=this._windowSize&&this.flush()},n.OutWindow.prototype.putByte=function(t){this._buffer[this._pos++]=t,this._pos>=this._windowSize&&this.flush()},n.OutWindow.prototype.getByte=function(t){var e=this._pos-t-1;return e<0&&(e+=this._windowSize),this._buffer[e]},n.RangeDecoder=function(){},n.RangeDecoder.prototype.setStream=function(t){this._stream=t},n.RangeDecoder.prototype.releaseStream=function(){this._stream=null},n.RangeDecoder.prototype.init=function(){var t=5;for(this._code=0,this._range=-1;t--;)this._code=this._code<<8|this._stream.readByte()},n.RangeDecoder.prototype.decodeDirectBits=function(t){for(var e=0,r=t,i;r--;)this._range>>>=1,i=this._code-this._range>>>31,this._code-=this._range&i-1,e=e<<1|1-i,this._range&4278190080||(this._code=this._code<<8|this._stream.readByte(),this._range<<=8);return e},n.RangeDecoder.prototype.decodeBit=function(t,e){var r=t[e],i=(this._range>>>11)*r;return(this._code^2147483648)<(i^2147483648)?(this._range=i,t[e]+=2048-r>>>5,this._range&4278190080||(this._code=this._code<<8|this._stream.readByte(),this._range<<=8),0):(this._range-=i,this._code-=i,t[e]-=r>>>5,this._range&4278190080||(this._code=this._code<<8|this._stream.readByte(),this._range<<=8),1)},n.initBitModels=function(t,e){for(;e--;)t[e]=1024},n.BitTreeDecoder=function(t){this._models=[],this._numBitLevels=t},n.BitTreeDecoder.prototype.init=function(){n.initBitModels(this._models,1<<this._numBitLevels)},n.BitTreeDecoder.prototype.decode=function(t){for(var e=1,r=this._numBitLevels;r--;)e=e<<1|t.decodeBit(this._models,e);return e-(1<<this._numBitLevels)},n.BitTreeDecoder.prototype.reverseDecode=function(t){for(var e=1,r=0,i=0,a;i<this._numBitLevels;++i)a=t.decodeBit(this._models,e),e=e<<1|a,r|=a<<i;return r},n.reverseDecode2=function(t,e,r,i){for(var a=1,o=0,s=0,u;s<i;++s)u=r.decodeBit(t,e+a),a=a<<1|u,o|=u<<s;return o},n.LenDecoder=function(){this._choice=[],this._lowCoder=[],this._midCoder=[],this._highCoder=new n.BitTreeDecoder(8),this._numPosStates=0},n.LenDecoder.prototype.create=function(t){for(;this._numPosStates<t;++this._numPosStates)this._lowCoder[this._numPosStates]=new n.BitTreeDecoder(3),this._midCoder[this._numPosStates]=new n.BitTreeDecoder(3)},n.LenDecoder.prototype.init=function(){var t=this._numPosStates;for(n.initBitModels(this._choice,2);t--;)this._lowCoder[t].init(),this._midCoder[t].init();this._highCoder.init()},n.LenDecoder.prototype.decode=function(t,e){return t.decodeBit(this._choice,0)===0?this._lowCoder[e].decode(t):t.decodeBit(this._choice,1)===0?8+this._midCoder[e].decode(t):16+this._highCoder.decode(t)},n.Decoder2=function(){this._decoders=[]},n.Decoder2.prototype.init=function(){n.initBitModels(this._decoders,768)},n.Decoder2.prototype.decodeNormal=function(t){var e=1;do e=e<<1|t.decodeBit(this._decoders,e);while(e<256);return e&255},n.Decoder2.prototype.decodeWithMatchByte=function(t,e){var r=1,i,a;do if(i=e>>7&1,e<<=1,a=t.decodeBit(this._decoders,(1+i<<8)+r),r=r<<1|a,i!==a){for(;r<256;)r=r<<1|t.decodeBit(this._decoders,r);break}while(r<256);return r&255},n.LiteralDecoder=function(){},n.LiteralDecoder.prototype.create=function(t,e){var r;if(!(this._coders&&this._numPrevBits===e&&this._numPosBits===t))for(this._numPosBits=t,this._posMask=(1<<t)-1,this._numPrevBits=e,this._coders=[],r=1<<this._numPrevBits+this._numPosBits;r--;)this._coders[r]=new n.Decoder2},n.LiteralDecoder.prototype.init=function(){for(var t=1<<this._numPrevBits+this._numPosBits;t--;)this._coders[t].init()},n.LiteralDecoder.prototype.getDecoder=function(t,e){return this._coders[((t&this._posMask)<<this._numPrevBits)+((e&255)>>>8-this._numPrevBits)]},n.Decoder=function(){this._outWindow=new n.OutWindow,this._rangeDecoder=new n.RangeDecoder,this._isMatchDecoders=[],this._isRepDecoders=[],this._isRepG0Decoders=[],this._isRepG1Decoders=[],this._isRepG2Decoders=[],this._isRep0LongDecoders=[],this._posSlotDecoder=[],this._posDecoders=[],this._posAlignDecoder=new n.BitTreeDecoder(4),this._lenDecoder=new n.LenDecoder,this._repLenDecoder=new n.LenDecoder,this._literalDecoder=new n.LiteralDecoder,this._dictionarySize=-1,this._dictionarySizeCheck=-1,this._posSlotDecoder[0]=new n.BitTreeDecoder(6),this._posSlotDecoder[1]=new n.BitTreeDecoder(6),this._posSlotDecoder[2]=new n.BitTreeDecoder(6),this._posSlotDecoder[3]=new n.BitTreeDecoder(6)},n.Decoder.prototype.setDictionarySize=function(t){return t<0?!1:(this._dictionarySize!==t&&(this._dictionarySize=t,this._dictionarySizeCheck=Math.max(this._dictionarySize,1),this._outWindow.create(Math.max(this._dictionarySizeCheck,4096))),!0)},n.Decoder.prototype.setLcLpPb=function(t,e,r){var i=1<<r;return t>8||e>4||r>4?!1:(this._literalDecoder.create(e,t),this._lenDecoder.create(i),this._repLenDecoder.create(i),this._posStateMask=i-1,!0)},n.Decoder.prototype.init=function(){var t=4;for(this._outWindow.init(!1),n.initBitModels(this._isMatchDecoders,192),n.initBitModels(this._isRep0LongDecoders,192),n.initBitModels(this._isRepDecoders,12),n.initBitModels(this._isRepG0Decoders,12),n.initBitModels(this._isRepG1Decoders,12),n.initBitModels(this._isRepG2Decoders,12),n.initBitModels(this._posDecoders,114),this._literalDecoder.init();t--;)this._posSlotDecoder[t].init();this._lenDecoder.init(),this._repLenDecoder.init(),this._posAlignDecoder.init(),this._rangeDecoder.init()},n.Decoder.prototype.decode=function(t,e,r){var i=0,a=0,o=0,s=0,u=0,c=0,l=0,h,p,v,m,A,y;for(this._rangeDecoder.setStream(t),this._outWindow.setStream(e),this.init();r<0||c<r;)if(h=c&this._posStateMask,this._rangeDecoder.decodeBit(this._isMatchDecoders,(i<<4)+h)===0)p=this._literalDecoder.getDecoder(c++,l),i>=7?l=p.decodeWithMatchByte(this._rangeDecoder,this._outWindow.getByte(a)):l=p.decodeNormal(this._rangeDecoder),this._outWindow.putByte(l),i=i<4?0:i-(i<10?3:6);else{if(this._rangeDecoder.decodeBit(this._isRepDecoders,i)===1)v=0,this._rangeDecoder.decodeBit(this._isRepG0Decoders,i)===0?this._rangeDecoder.decodeBit(this._isRep0LongDecoders,(i<<4)+h)===0&&(i=i<7?9:11,v=1):(this._rangeDecoder.decodeBit(this._isRepG1Decoders,i)===0?m=o:(this._rangeDecoder.decodeBit(this._isRepG2Decoders,i)===0?m=s:(m=u,u=s),s=o),o=a,a=m),v===0&&(v=2+this._repLenDecoder.decode(this._rangeDecoder,h),i=i<7?8:11);else if(u=s,s=o,o=a,v=2+this._lenDecoder.decode(this._rangeDecoder,h),i=i<7?7:10,A=this._posSlotDecoder[v<=5?v-2:3].decode(this._rangeDecoder),A>=4){if(y=(A>>1)-1,a=(2|A&1)<<y,A<14)a+=n.reverseDecode2(this._posDecoders,a-A-1,this._rangeDecoder,y);else if(a+=this._rangeDecoder.decodeDirectBits(y-4)<<4,a+=this._posAlignDecoder.reverseDecode(this._rangeDecoder),a<0){if(a===-1)break;return!1}}else a=A;if(a>=c||a>=this._dictionarySizeCheck)return!1;this._outWindow.copyBlock(a,v),c+=v,l=this._outWindow.getByte(0)}return this._outWindow.flush(),this._outWindow.releaseStream(),this._rangeDecoder.releaseStream(),!0},n.Decoder.prototype.setDecoderProperties=function(t){var e,r,i,a,o;return t.size<5||(e=t.readByte(),r=e%9,e=~~(e/9),i=e%5,a=~~(e/5),!this.setLcLpPb(r,i,a))?!1:(o=t.readByte(),o|=t.readByte()<<8,o|=t.readByte()<<16,o+=t.readByte()*16777216,this.setDictionarySize(o))},n.decompress=function(t,e,r,i){var a=new n.Decoder;if(!a.setDecoderProperties(t))throw"Incorrect stream properties";if(!a.decode(e,r,i))throw"Error in data stream";return!0},n.decompressFile=function(t,e){var r=new n.Decoder,i;if(!r.setDecoderProperties(t))throw"Incorrect stream properties";if(i=t.readByte(),i|=t.readByte()<<8,i|=t.readByte()<<16,i+=t.readByte()*16777216,t.readByte(),t.readByte(),t.readByte(),t.readByte(),!r.decode(t,e,i))throw"Error in data stream";return!0},n}var Fd=Bu();function Od(){function n(e){for(var r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",i=new Uint8Array(256),a=0;a<r.length;a++)i[r.charCodeAt(a)]=a;var o=e.length*.75,s=e.length,u,c=0,l,h,p,v;e[e.length-1]==="="&&(o--,e[e.length-2]==="="&&o--);var m=new ArrayBuffer(o),A=new Uint8Array(m);for(u=0;u<s;u+=4)l=i[e.charCodeAt(u)],h=i[e.charCodeAt(u+1)],p=i[e.charCodeAt(u+2)],v=i[e.charCodeAt(u+3)],A[c++]=l<<2|h>>4,A[c++]=(h&15)<<4|p>>2,A[c++]=(p&3)<<6|v&63;return m}var t="AGFzbQEAAAABSg1gAABgAX8Bf2ACf38Bf2AEf39/fwBgA39/fwBgAX8AYAJ/fwBgA39/fwF/YAR/f39/AX9gAn9/AGABfwF/YAABf2AEf39/fwF/AhsCA2VudgVhYm9ydAADA2VudgZtZW1vcnkCAAEDJiUBAQkKAgoKCwsLCwsAAgoBAgQKAQYFCAoFBQQEBwgCBwwCAQAABAQBcAABBhoFfwFBAAt/AUEAC38BQQALfwFBAAt/AUEACwc9BgZtZW1vcnkCAAV0YWJsZQEABXJlc2V0AA0KbmV3VThBcnJheQAQCnVucGFja1NpemUAFAZkZWNvZGUAIwgBJAkHAQBBAAsBJQqAViVoAQN/IABBgICAgARLBEAACyMBIgEgAEEBIABBAUsbakEHakF4cSICPwAiA0EQdEsEQCADIAIgAWtB//8DakGAgHxxQRB2IgAgAyAAShtAAEEASARAIABAAEEASARAAAsLCyACJAEgAQsbAQF/QQFBICAAQQdqZ2t0EAEiASAANgIAIAELkQMBAX8gAUUEQA8LIABBADoAACAAIAFqQQFrQQA6AAAgAUECTQRADwsgAEEBakEAOgAAIABBAmpBADoAACAAIAFqIgJBAmtBADoAACACQQNrQQA6AAAgAUEGTQRADwsgAEEDakEAOgAAIAAgAWpBBGtBADoAACABQQhNBEAPC0EAIABrQQNxIgIgAGoiAEEANgIAIAEgAmtBfHEiASAAakEEa0EANgIAIAFBCE0EQA8LIABBBGpBADYCACAAQQhqQQA2AgAgACABaiICQQxrQQA2AgAgAkEIa0EANgIAIAFBGE0EQA8LIABBDGpBADYCACAAQRBqQQA2AgAgAEEUakEANgIAIABBGGpBADYCACAAIAFqIgJBHGtBADYCACACQRhrQQA2AgAgAkEUa0EANgIAIAJBEGtBADYCACAAQQRxQRhqIgIgAGohACABIAJrIQEDQCABQSBPBEAgAEIANwMAIABBCGpCADcDACAAQRBqQgA3AwAgAEEYakIANwMAIAFBIGshASAAQSBqIQAMAQsLC1EBA38gAEH+////AEsEQEEAQSBBLUEnEAAACyAAQQJ0IgMQAiECQQgQASIBQQA2AgAgAUEANgIEIAEgAjYCACABIAA2AgQgAkEIaiADEAMgAQtmAQF/IAFB/P///wFLBEBBAEHAAEEXQSIQAAALIAFBAXQiARACIgJBCGogARADIABFBEBBDBABIQALIABBADYCACAAQQA2AgQgAEEANgIIIAAgAjYCACAAQQA2AgQgACABNgIIIAALCgBBDBABIAAQBQsuAQF/QQgQASIBQQA2AgAgAUEANgIEIAEgADYCBCABQQEgASgCBHQQBjYCACABC6EBAQR/QRAQASIBQQA2AgAgAUEANgIEIAFBADYCCCABQQA2AgxBEBAEIQIDQCAAQRBIBEBBAxAHIQMgAigCACAAQQJ0aiADNgIIIABBAWohAAwBCwsgASACNgIEQRAQBCECQQAhAANAIABBEEgEQEEDEAchAyACKAIAIABBAnRqIAM2AgggAEEBaiEADAELCyABIAI2AgggAUEIEAc2AgwgAQs0AQF/QRQQASIAQQA2AgAgAEEAOgAEIABBADYCCCAAQQA2AgwgAEEANgIQIABBDTYCCCAAC0IBAX9BGRABIgBBADYCACAAQQA2AgQgAEEANgIIIABBADYCDCAAQQA2AhAgAEEANgIUIABBADoAGCAAQQA2AhAgAAu1AgEEf0HQABABIgBBADoAACAAQQA2AgQgAEEANgIIIABBADYCDCAAQQA2AhAgAEEAOgAUIABBADYCGCAAQQA2AhwgAEEANgIgIABBADYCJCAAQQA2AiggAEEANgIsIABBADYCMCAAQQA2AjQgAEEANgI4IABBADYCPCAAQQA2AkAgAEEANgJEIABBADYCSCAAQQA2AkxBBBAEIQIDQCABQQRIBEBBBhAHIQMgAigCACABQQJ0aiADNgIIIAFBAWohAQwBCwsgACACNgIkIABBBBAHNgIoIABB8wAQBjYCLCAAQcABEAY2AjAgAEEMEAY2AjQgAEEMEAY2AjggAEEMEAY2AjwgAEEMEAY2AkAgAEHAARAGNgJEIAAQCDYCSCAAEAg2AkwgABAJNgIEIAAQCjYCCCAACx8BAX9BCBABIgBBADYCACAAQQA2AgQgABALNgIAIAALCgAjACQBEAwkAwthAQF/IAFB+P///wNLBEBBAEHAAEEXQSIQAAALIAEQAiICQQhqIAEQAyAARQRAQQwQASEACyAAQQA2AgAgAEEANgIEIABBADYCCCAAIAI2AgAgAEEANgIEIAAgATYCCCAACwoAQQwQASAAEA4LBgAgABAPCyoAIAEgACgCCE8EQEEAQcAAQSdBPxAAAAsgACgCBCABIAAoAgBqai0ACAssACABIAAoAghPBEBBAEHAAEEyQT8QAAALIAAoAgQgASAAKAIAamogAjoACAtkAQJ/QQ0QDyECA0AgAUENSARAIAIgASAAIAEQEUH/AXEQEiABQQFqIQEMAQsLQQAhAEEAIQEDQCABQQhIBEAgAiABQQVqEBFB/wFxIAFBA3R0IAByIQAgAUEBaiEBDAELCyAACwYAIAAQEwsnACAAIAEQDzYCCCAAQQA2AgwgACABNgIUIABBADoAGCAAQQA2AgALJAAgACgCCCAAKAIYEBUgAEGABiAAKAIMIAAtABRqdBAGNgIgC5UBAQR/IAEhBSAAIgYoAgAhASAAKAIEIQcgACgCCEEBdiEEIAJBAEgEfyACIARqIgBBACAAQQBKGwUgAiIAIAQgACAESBsLIQIgA0EASAR/IAMgBGoiAEEAIABBAEobBSADIgAgBCAAIARIGwshAwNAIAIgA05FBEAgAkEBdCABaiAHaiAFOwEIIAJBAWohAgwBCwsgBgssAQF/AkACQAJAIwRBAWsOAwEBAgALAAtB/////wchAQsgAEGACEEAIAEQFwvBAQECfyAAQQIQBjYCACAAKAIAIgEoAgAgASgCBGpBgAg7AQggACgCACICKAIAIQEgAigCBCABQQJqakGACDsBCCAAKAIMKAIAQQEkBBAYGkEAIQIDQCACQRBIBEAgAiAAKAIEKAIAIgEoAgBBAnZJBH8gAkECdCABaigCCAUACygCAEEBJAQQGBogAiAAKAIIKAIAIgEoAgBBAnZJBH8gAkECdCABaigCCAUACygCAEEBJAQQGBogAkEBaiECDAELCwuHAgEFfyAAIQJBgAYgACgCDCAALQAUanQhAQNAIAMgAUgEQCACKAIgIgQoAgAhBSAEKAIEIANBAXQgBWpqQYAIOwEIIANBAWohAwwBCwsgAiEBQQAhAgNAIAJBBEkEQCACIAEoAiQoAgAiAygCAEECdkkEfyACQQJ0IANqKAIIBQALKAIAQQEkBBAYGiACQQFqIQIMAQsLIAEoAigoAgBBASQEEBgaIAEoAixBASQEEBgaIAAoAjBBASQEEBgaIAAoAjRBASQEEBgaIAAoAjhBASQEEBgaIAAoAjxBASQEEBgaIAAoAkBBASQEEBgaIAAoAkRBASQEEBgaIAAoAkgQGSAAKAJMEBkLyAwBA38DQCABQQNxIAIgAhsEQCAAIgRBAWohACABIgNBAWohASAEIAMtAAA6AAAgAkEBayECDAELCyAAQQNxRQRAA0AgAkEQTwRAIAAgASgCADYCACAAQQRqIAFBBGooAgA2AgAgAEEIaiABQQhqKAIANgIAIABBDGogAUEMaigCADYCACABQRBqIQEgAEEQaiEAIAJBEGshAgwBCwsgAkEIcQRAIAAgASgCADYCACAAQQRqIAFBBGooAgA2AgAgAUEIaiEBIABBCGohAAsgAkEEcQRAIAAgASgCADYCACABQQRqIQEgAEEEaiEACyACQQJxBEAgACABLwEAOwEAIAFBAmohASAAQQJqIQALIAJBAXEEQCAAIAEtAAA6AAALDwsgAkEgTwRAAkACQAJAIABBA3EiA0EBRwRAIANBAkYNASADQQNGDQIMAwsgASgCACEFIAAgASIDLQAAOgAAIABBAWoiASABIANBAWoiAS0AADoAAEEBaiIEQQFqIQAgAUEBaiIDQQFqIQEgBCADLQAAOgAAIAJBA2shAgNAIAJBEU8EQCAAIAFBAWooAgAiA0EIdCAFQRh2cjYCACAAQQRqIAFBBWooAgAiBUEIdCADQRh2cjYCACAAQQhqIAFBCWooAgAiA0EIdCAFQRh2cjYCACAAQQxqIAFBDWooAgAiBUEIdCADQRh2cjYCACABQRBqIQEgAEEQaiEAIAJBEGshAgwBCwsMAgsgASgCACEFIAAgAS0AADoAACAAQQFqIgRBAWohACABQQFqIgNBAWohASAEIAMtAAA6AAAgAkECayECA0AgAkESTwRAIAAgAUECaigCACIDQRB0IAVBEHZyNgIAIABBBGogAUEGaigCACIFQRB0IANBEHZyNgIAIABBCGogAUEKaigCACIDQRB0IAVBEHZyNgIAIABBDGogAUEOaigCACIFQRB0IANBEHZyNgIAIAFBEGohASAAQRBqIQAgAkEQayECDAELCwwBCyABKAIAIQUgACIEQQFqIQAgASIDQQFqIQEgBCADLQAAOgAAIAJBAWshAgNAIAJBE08EQCAAIAFBA2ooAgAiA0EYdCAFQQh2cjYCACAAQQRqIAFBB2ooAgAiBUEYdCADQQh2cjYCACAAQQhqIAFBC2ooAgAiA0EYdCAFQQh2cjYCACAAQQxqIAFBD2ooAgAiBUEYdCADQQh2cjYCACABQRBqIQEgAEEQaiEAIAJBEGshAgwBCwsLCyACQRBxBEAgACABIgMtAAA6AAAgAEEBaiIBIAEgA0EBaiIBLQAAOgAAQQFqIgMgAyABQQFqIgEtAAA6AABBAWoiAyADIAFBAWoiAS0AADoAAEEBaiIDIAMgAUEBaiIBLQAAOgAAQQFqIgMgAyABQQFqIgEtAAA6AABBAWoiAyADIAFBAWoiAS0AADoAAEEBaiIDIAMgAUEBaiIBLQAAOgAAQQFqIgMgAyABQQFqIgEtAAA6AABBAWoiAyADIAFBAWoiAS0AADoAAEEBaiIDIAMgAUEBaiIBLQAAOgAAQQFqIgMgAyABQQFqIgEtAAA6AABBAWoiAyADIAFBAWoiAS0AADoAAEEBaiIDIAMgAUEBaiIBLQAAOgAAQQFqIgMgAyABQQFqIgEtAAA6AABBAWoiBEEBaiEAIAFBAWoiA0EBaiEBIAQgAy0AADoAAAsgAkEIcQRAIAAgASIDLQAAOgAAIABBAWoiASABIANBAWoiAS0AADoAAEEBaiIDIAMgAUEBaiIBLQAAOgAAQQFqIgMgAyABQQFqIgEtAAA6AABBAWoiAyADIAFBAWoiAS0AADoAAEEBaiIDIAMgAUEBaiIBLQAAOgAAQQFqIgMgAyABQQFqIgEtAAA6AABBAWoiBEEBaiEAIAFBAWoiA0EBaiEBIAQgAy0AADoAAAsgAkEEcQRAIAAgASIDLQAAOgAAIABBAWoiASABIANBAWoiAS0AADoAAEEBaiIDIAMgAUEBaiIBLQAAOgAAQQFqIgRBAWohACABQQFqIgNBAWohASAEIAMtAAA6AAALIAJBAnEEQCAAIAEtAAA6AAAgAEEBaiIEQQFqIQAgAUEBaiIDQQFqIQEgBCADLQAAOgAACyACQQFxBEAgACABLQAAOgAACwvVAgECfyAAIAFGBEAPCyABIAJqIABNIgNFBEAgACACaiABTSEDCyADBEAgACABIAIQGw8LIAAgAUkEQCABQQdxIABBB3FGBEADQCAAQQdxBEAgAkUEQA8LIAJBAWshAiAAIgRBAWohACABIgNBAWohASAEIAMtAAA6AAAMAQsLA0AgAkEITwRAIAAgASkDADcDACACQQhrIQIgAEEIaiEAIAFBCGohAQwBCwsLA0AgAgRAIAAiBEEBaiEAIAEiA0EBaiEBIAQgAy0AADoAACACQQFrIQIMAQsLBSABQQdxIABBB3FGBEADQCAAIAJqQQdxBEAgAkUEQA8LIAJBAWsiAiAAaiABIAJqLQAAOgAADAELCwNAIAJBCE8EQCACQQhrIgIgAGogASACaikDADcDAAwBCwsLA0AgAgRAIAJBAWsiAiAAaiABIAJqLQAAOgAADAELCwsL4AoBCH8gACgCACIGIgQoAgAgBCgCBGovAQgiCCABIgcoAgxBC3ZsIQQgBygCECAESQR/QYAQIAhrQf//A3FBBXYgCGohCCAHIAQ2AgxBAAUgCCAIQf//A3FBBXZrIQggByAHKAIQIARrNgIQIAcgBygCDCAEazYCDEEBCyAGKAIEIAYoAgBqIAg7AQggByIFKAIMIwJJBEAgBSAFKAIMQQh0NgIMIAUoAhBBCHQhByAFKAIAIQYgBSAFKAIIIglBAWo2AgggBSAGIAkQEUH/AXEgB3I2AhALQf//A3FFBEAgAiAAKAIEKAIAIgAoAgBBAnZJBH8gAkECdCAAaigCCAUACyEDIAEhBEEBIQgDQCAKIAMoAgRJBEAgAygCACIHKAIAIQEgBCgCECAHKAIEIAgiBUEBdCIIIAFqai8BCCIGIAQoAgxBC3ZsIglJBH9BgBAgBmtB//8DcUEFdiAGaiEGIAQgCTYCDEEABSAGIAZB//8DcUEFdmshBiAEIAQoAhAgCWs2AhAgBCAEKAIMIAlrNgIMQQELIAcoAgQgBygCACAFQQF0amogBjsBCCAEKAIMIwJJBEAgBCAEKAIMQQh0NgIMIAQoAhBBCHQhACAEKAIAIQUgBCAEKAIIIgFBAWo2AgggBCAFIAEQEUH/AXEgAHI2AhALQf//A3EgCGohCCAKQQFqIQoMAQsLIAhBASADKAIEdGsPCyAAKAIAIgooAgAhCCAFKAIQIAooAgQgCEECamovAQgiBCABKAIMQQt2bCIDSQR/IAUgAzYCDEEAIQlBgBAgBGtB//8DcUEFdiAEagUgBSAFKAIQIANrNgIQIAUgBSgCDCADazYCDEEBIQkgBCAEQf//A3FBBXZrCyEEIAoiBygCBCAHKAIAQQJqaiAEOwEIIAUiBigCDCMCSQRAIAYgBigCDEEIdDYCDCAGKAIQQQh0IQUgBigCACEHIAYgBigCCCIIQQFqNgIIIAYgByAIEBFB/wFxIAVyNgIQCyAJQf//A3FFBEAgAiAAKAIIKAIAIgAoAgBBAnZJBH8gAkECdCAAaigCCAUACyEJIAEhA0EBIQRBACECA0AgAiAJKAIESQRAIAMoAhAgCSgCACIFKAIEIAQiBkEBdCIEIAUoAgBqai8BCCIHIAMoAgxBC3ZsIghJBH9BgBAgB2tB//8DcUEFdiAHaiEHIAMgCDYCDEEABSAHIAdB//8DcUEFdmshByADIAMoAhAgCGs2AhAgAyADKAIMIAhrNgIMQQELIAUoAgQgBSgCACAGQQF0amogBzsBCCADKAIMIwJJBEAgAyADKAIMQQh0NgIMIAMoAhBBCHQhBSADKAIAIQcgAyADKAIIIgZBAWo2AgggAyAHIAYQEUH/AXEgBXI2AhALQf//A3EgBGohBCACQQFqIQIMAQsLIARBASAJKAIEdGtBCGoPCyAAKAIMIQQgASEDQQEhCUEAIQIDQCACIAQoAgRJBEAgBCgCACIIKAIAIQogAygCECAIKAIEIAogCSIHQQF0IgFqai8BCCIFIAMoAgxBC3ZsIgZJBH8gAyAGNgIMQQAhBkGAECAFa0H//wNxQQV2IAVqBSADIAMoAhAgBms2AhAgAyADKAIMIAZrNgIMQQEhBiAFIAVB//8DcUEFdmsLIQUgCCgCBCAIKAIAIAdBAXRqaiAFOwEIIAMoAgwjAkkEQCADIAMoAgxBCHQ2AgwgAygCEEEIdCEAIAMoAgAhBSADIAMoAggiCkEBajYCCCADIAUgChARQf8BcSAAcjYCEAsgBkH//wNxIAFqIQkgAkEBaiECDAELCyAJQQEgBCgCBHRrQRBqC5YCAQh/QQEhBwNAAkAgBiABTg0AIAIoAhAgACgCBCAAKAIAIAMgB2oiCUEBdGpqLwEIIgQgAigCDEELdmwiBUkEfyACIAU2AgxBACEFQYAQIARrQf//A3FBBXYgBGoFIAIgAigCECAFazYCECACIAIoAgwgBWs2AgxBASEFIAQgBEH//wNxQQV2awshBCAAKAIEIAAoAgAgCUEBdGpqIAQ7AQggAiIEKAIMIwJJBEAgBCAEKAIMQQh0NgIMIAQoAhBBCHQhCiAEKAIAIQsgBCAEKAIIIglBAWo2AgggBCALIAkQEUH/AXEgCnI2AhALIAVB//8DcSIEIAdBAXRqIQcgBCAGdCAIciEIIAZBAWohBgwBCwsgCAvwBAEIf0EDIAEgAUEDSxsiAiAAKAIkKAIAIgEoAgBBAnZJBH8gAkECdCABaigCCAUACyEEIAAoAgQhAkEBIQEDQCAHIAQoAgRJBEAgBCgCACIFKAIAIQMgAigCECAFKAIEIAFBAXQiCSADamovAQgiAyACKAIMQQt2bCIGSQR/IAIgBjYCDEEAIQhBgBAgA2tB//8DcUEFdiADagUgAiACKAIQIAZrNgIQIAIgAigCDCAGazYCDEEBIQggAyADQf//A3FBBXZrCyEDIAUoAgQgBSgCACABQQF0amogAzsBCCACKAIMIwJJBEAgAiACKAIMQQh0NgIMIAIoAhBBCHQhBiACKAIAIQUgAiACKAIIIgNBAWo2AgggAiAFIAMQEUH/AXEgBnI2AhALIAhB//8DcSAJaiEBIAdBAWohBwwBCwsgAUEBIAQoAgR0ayIBQQRJBEAgAQ8LIAFBAXFBAnIgAUEBdkEBayICdCEDIAFBDkkEfyAAKAIsIAIgACgCBCADIAFrEB4gA2oFIAAoAgQhASACQQRrIQJBACEEA0AgASABKAIMQQF2NgIMIAEgASgCECABKAIMazYCECABIAEoAhBBACABKAIQQR92ayIHIAEoAgxxajYCECABKAIQIAEoAgxGBEAgAUEBOgAECyABKAIMIwJJBEAgASABKAIMQQh0NgIMIAEoAhBBCHQhBSABKAIAIQggASABKAIIIgZBAWo2AgggASAIIAYQEUH/AXEgBXI2AhALIAdBAWogBEEBdGohBCACQQFrIgINAAsgBEEEdCADaiAAKAIoIgQoAgAgBCgCBCAAKAIEQQAQHmoLC9AcAQ9/IAAQGiAAKAIEIgdBADoABCAHKAIAIAcgBygCCCIDQQFqNgIIIAMQEUH/AXEEQCAHQQE6AAQLIAdBfzYCDCAHQQA2AhBBACEDA0AgA0EESARAIAcoAhBBCHQhBSAHKAIAIQwgByAHKAIIIghBAWo2AgggByAMIAgQEUH/AXEgBXI2AhAgA0EBaiEDDAELCyAHKAIQIAcoAgxGBEAgB0EBOgAECyABBEAgACgCCCACEA82AgQFIAAoAghBBBAPNgIEC0EAIQwDQAJAIAJFIAEgARsiBwR/IAAtAABFBSAHCwRAIAAoAgQoAhBFBEBBAw8LCyAAKAIwIgUoAgAhByAFKAIEIAAoAggoAgBBASAAKAIQdEEBa3EiCyAMQQR0Qf8BcWoiBkEBdCAHamovAQghAyAGIQcgACgCBCIEKAIMQQt2IANsIQggBCgCECAISQR/IAQgCDYCDEEAIQlBgBAgA2tB//8DcUEFdiADagUgBCAEKAIQIAhrNgIQIAQgBCgCDCAIazYCDEEBIQkgAyADQf//A3FBBXZrCyEIIAUiAygCBCADKAIAIAdBAXRqaiAIOwEIIAQiBigCDCMCSQRAIAYgBigCDEEIdDYCDCAGKAIQQQh0IQggBigCACEDIAYgBigCCCIHQQFqNgIIIAYgAyAHEBFB/wFxIAhyNgIQCyAJQf//A3FFBEAgAkUgASABGw0BIAwhCEEAIQYgACgCCCIFKAIMRSIEBH8gBS0AGEUFIAQLRQRAIAAoAggiBSgCCCIGKAIEQQEgBSgCDEwEfyAFKAIMQQFrBSAFKAIMIAUoAhRBAWtqCyAGKAIAamotAAghBgtBASEEIAAoAggoAgBBASAALQAUdEEBa3EgACgCDHQgBkEIIAAoAgxrdmpBgAZsIQcgCEEHTwRAIAAoAggiBigCCCIJKAIEIA5BAWoiDSAGKAIMTAR/IAYoAgwgDWsFIAYoAgwgBigCFCANa2oLIAkoAgBqai0ACCENA0ACQCANQf8BcUEHdiEGIA1BAXQhDSAAKAIgIgkoAgAhCyAJKAIEIAZBAWpBCHQgB2ogBGoiDEEBdCALamovAQgiCyAAKAIEIgMoAgxBC3ZsIQogAygCECAKSQR/QYAQIAtrQf//A3FBBXYgC2ohCyADIAo2AgxBAAUgCyALQf//A3FBBXZrIQsgAyADKAIQIAprNgIQIAMgAygCDCAKazYCDEEBCyEFIAkoAgQgCSgCACAMQQF0amogCzsBCCADIgooAgwjAkkEQCAKIAooAgxBCHQ2AgwgCigCEEEIdCEDIAooAgAhDCAKIAooAggiC0EBajYCCCAKIAwgCxARQf8BcSADcjYCEAsgBEEBdCAFciEEIAVB//8DcSAGRw0AIARB//8DcUGAAkkNAQsLCwNAIARBgAJJBEAgBEEBdCEJIAAoAiAiBSgCACEMIAUoAgQgBCAHaiIGQQF0IAxqai8BCCILIAAoAgQiDSgCDEELdmwhCiANKAIQIApJBH9BgBAgC2tB//8DcUEFdiALaiELIA0gCjYCDEEABSALIAtB//8DcUEFdmshCyANIA0oAhAgCms2AhAgDSANKAIMIAprNgIMQQELIAUoAgQgBSgCACAGQQF0amogCzsBCCANIgooAgwjAkkEQCAKIAooAgxBCHQ2AgwgCigCEEEIdCEGIAooAgAhBSAKIAooAggiDEEBajYCCCAKIAUgDBARQf8BcSAGcjYCEAsgCXIhBAwBCwsgACgCCCIDIAMoAgBBAWo2AgAgAygCCCELIAMgAygCDCIGQQFqNgIMIAsoAgQgCygCACAGamogBEGAAmsiCjoACCADKAIMIAMoAhRGBEAgA0EANgIMIANBAToAGAsgAygCBCgCCCADKAIQRgRAIAMgAygCBCIGKAIIQQF0EA82AgQgAygCBCgCACADKAIEKAIEakEIaiAGKAIAIAYoAgRqQQhqIAYoAggQHCAGKAIAGgsgAygCBCEJIAMgAygCECIMQQFqNgIQIAkoAgQgCSgCACAMamogCjoACCAIIgVBBEkEf0EABSAFQQNrIAVBBmsgBUEKSRsLIQwgAkEBayECDAILIAAoAjQiBigCACEFIAYoAgQgDCIDQQF0IAVqai8BCCIHIAAoAgQiCigCDEELdmwhBCAKKAIQIARJBH9BgBAgB2tB//8DcUEFdiAHaiEHIAogBDYCDEEABSAHIAdB//8DcUEFdmshByAKIAooAhAgBGs2AhAgCiAKKAIMIARrNgIMQQELIAMhBSAGIgMoAgAhDSADKAIEIAVBAXQgDWpqIAc7AQggCiIJKAIMIwJJBEAgCSAJKAIMQQh0NgIMIAkoAhBBCHQhBiAJKAIAIQMgCSAJKAIIIgVBAWo2AgggCSADIAUQEUH/AXEgBnI2AhALQf//A3EEQCACRSABIAEbDQEgACgCCCIIKAIMRSIEBH8gCC0AGEUFIAQLDQEgACgCOCIDKAIAIQggAygCBCAMQQF0IAhqai8BCCIEIAAoAgQiBSgCDEELdmwhByAFKAIQIAdJBH9BgBAgBGtB//8DcUEFdiAEaiEEIAUgBzYCDEEABSAEIARB//8DcUEFdmshBCAFIAUoAhAgB2s2AhAgBSAFKAIMIAdrNgIMQQELIAMoAgQgAygCACAMQQF0amogBDsBCCAFIgkoAgwjAkkEQCAJIAkoAgxBCHQ2AgwgCSgCEEEIdCEFIAkoAgAhAyAJIAkoAggiCEEBajYCCCAJIAMgCBARQf8BcSAFcjYCEAtB//8DcQRAIAAoAjwiCCgCACEHIAgoAgQgDEEBdCAHamovAQgiBCAAKAIEIgUoAgxBC3ZsIQYgBSgCECAGSQR/QYAQIARrQf//A3FBBXYgBGohBCAFIAY2AgxBAAUgBCAEQf//A3FBBXZrIQQgBSAFKAIQIAZrNgIQIAUgBSgCDCAGazYCDEEBCyAIIgMoAgQgAygCACAMQQF0amogBDsBCCAFIgkoAgwjAkkEQCAJIAkoAgxBCHQ2AgwgCSgCEEEIdCEIIAkoAgAhAyAJIAkoAggiB0EBajYCCCAJIAMgBxARQf8BcSAIcjYCEAtB//8DcQRAIAAoAkAiAygCACEKIAMoAgQgDEEBdCAKamovAQgiBiAAKAIEIgcoAgxBC3ZsIQQgBygCECAESQR/QYAQIAZrQf//A3FBBXYgBmohBiAHIAQ2AgxBAAUgBiAGQf//A3FBBXZrIQYgByAHKAIQIARrNgIQIAcgBygCDCAEazYCDEEBCyADKAIEIAMoAgAgDEEBdGpqIAY7AQggByIJKAIMIwJJBEAgCSAJKAIMQQh0NgIMIAkoAhBBCHQhCCAJKAIAIQMgCSAJKAIIIgpBAWo2AgggCSADIAoQEUH/AXEgCHI2AhALQf//A3EEQCARIQMgDyERBSAPIQMLIBAhDwUgECEDCyAOIRAgAyEOBSAAKAJEIgYoAgAhCiAGKAIEIAxBBHRB/wFxIAtqIgNBAXQgCmpqLwEIIgcgACgCBCIIKAIMQQt2bCEEIAgoAhAgBEkEf0GAECAHa0H//wNxQQV2IAdqIQcgCCAENgIMQQAFIAcgB0H//wNxQQV2ayEHIAggCCgCECAEazYCECAIIAgoAgwgBGs2AgxBAQsgAyEKIAYiAygCACENIAMoAgQgCkEBdCANamogBzsBCCAIIgkoAgwjAkkEQCAJIAkoAgxBCHQ2AgwgCSgCEEEIdCEIIAkoAgAhAyAJIAkoAggiCkEBajYCCCAJIAMgChARQf8BcSAIcjYCEAtB//8DcUUEQEEJQQsgDEEHSRshDCAAKAIIIQQgACgCCCIFKAIIIgMoAgQgDkEBaiIHIAUoAgxMBH8gBSgCDCAHawUgBSgCDCAFKAIUIAdragsgAygCAGpqLQAIIQcgBCAEKAIAQQFqNgIAIAQoAgghBSAEIAQoAgwiBkEBajYCDCAFKAIEIAUoAgAgBmpqIAc6AAggBCgCDCAEKAIURgRAIARBADYCDCAEQQE6ABgLIAQoAgQoAgggBCgCEEYEQCAEIAQoAgQiBigCCEEBdBAPNgIEIAQoAgQoAgAgBCgCBCgCBGpBCGogBigCACAGKAIEakEIaiAGKAIIEBwgBigCABoLIAQoAgQhAyAEIAQoAhAiCEEBajYCECADKAIEIAMoAgAgCGpqIAc6AAggAkEBayECDAQLCyAAKAJMIAAoAgQgCxAdIQtBCEELIAxBB0kbIQwFIA8hESAQIQ8gDiEQQQdBCiAMQQdJGyEMIAAgACgCSCAAKAIEIAsQHSILEB8iDkF/RgRAIAAoAgQoAhAEf0EBBUECCw8LIAJFIAEgARsNASAOIAAoAhhPIgUEfyAFBSAOIAAoAggiBCgCDEwiBgR/IAYFIAQtABgLRQsNAQtBACENIAAoAgghBSAOQQFqIQQgAiALQQJqIgtIIAEgARsEQEEBIQ0gAiELCyALIQYDQCAGQQBKBEAgBSIIKAIIIgkoAgQgBCAFKAIMTAR/IAUoAgwgBGsFIAUoAgwgBSgCFCAEa2oLIAkoAgBqai0ACCEHIAggCCgCAEEBajYCACAIKAIIIQMgCCAIKAIMIgpBAWo2AgwgAygCBCADKAIAIApqaiAHOgAIIAgoAgwgCCgCFEYEQCAIQQA2AgwgCEEBOgAYCyAIKAIEKAIIIAgoAhBGBEAgCCAIKAIEIgMoAghBAXQQDzYCBCAIKAIEKAIAIAgoAgQoAgRqQQhqIAMoAgAgAygCBGpBCGogAygCCBAcIAMoAgAaCyAIKAIEIQkgCCAIKAIQIgNBAWo2AhAgCSgCBCAJKAIAIANqaiAHOgAIIAZBAWshBgwBCwsgAiALayECIA1FDQELC0EBCyYBAX9BEBABIgQgADYCACAEIAE2AgQgBCACNgIIIAQgAzYCDCAEC7YEAQZ/IAAgATYCBEENEA8hAgNAAkAgA0ENTg0AIAIgAyABIAMQEUH/AXEQEiADQQFqIQMMAQsLIAAoAgAhBCACIQZBBBAPIgIoAgQgAigCAGogBigCBCAGKAIAai0ACCIDOgAIIANB/wFxQeEBTwRAQQBBgAFBoQFBDBAAAAsgAigCBCACKAIAQQFqaiADQf8BcUEJcCIHOgAIIAIoAgQgAigCAGogA0H/AXFBCW4iAzoACCADQQVwIQUgAigCBCACKAIAQQJqaiADQQVuIgM6AAggAigCBCACKAIAQQNqaiAFOgAIIAQgBzYCDCAEIAM2AhAgBCAFOgAUIARBADYCHEEAIQIDQAJAIAJBBE8NACAEIAQoAhwgBigCBCAGKAIAIAJBAWpqai0ACCACQQN0dHI2AhwgAkEBaiECDAELCyAEIAQoAhw2AhggBCgCGEGAIEkEQCAEQYAgNgIYC0EAIQJBACEFQQAhAwNAAkAgA0EITg0AIAYgA0EFahARQf8BcSIEQf8BRwRAQQEhBQsgBCADQQN0dCACciECIANBAWohAwwBCwsgACgCACAFRToAACAAKAIAKAIEIAE2AgAgACgCABAWAkAgACgCACAFIAIQICIBQQFGDQAgAUEDRwRAIAFBAkYEQCAFBEAgACgCACgCCCgCECACRw0DCwUMAgsLIAAoAgAoAgQtAAQaQQFBACAAKAIAKAIIKAIQIAAoAgAoAggoAgQQIQ8LQQBBAUEAQQAQIQsIACMDIAAQIgsWAEG4ASQAIwAkAUGAgIAIJAIQDCQDCwMAAQsLtwEEAEEICxcKAAAAdQBzAGUAIABzAHQAcgBpAGMAdABBIAsdDQAAAH4AbABpAGIALwBhAHIAcgBhAHkALgB0AHMAQcAACzkbAAAAfgBsAGkAYgAvAGkAbgB0AGUAcgBuAGEAbAAvAHQAeQBwAGUAZABhAHIAcgBhAHkALgB0AHMAQYABCzMYAAAAcwByAGMALwBsAHoAbQBhAC8AbAB6AG0AYQAtAGQAZQBjAG8AZABlAHIALgB0AHM=";return n(t)}function kd(n,t,e){try{var r={data:t,offset:0,readByte:function(){return this.data[this.offset++]}},i=r.data.length,a={data:[],offset:0,writeByte:function(u){var c=Math.floor(this.offset/i);this.data[c]||(this.data[c]=new Uint8Array(i)),this.data[c][this.offset%i]=u,this.offset++}};n.decompressFile(r,a);for(var o=new Uint8Array(a.offset),s=0;s<a.offset;s++)o[s]=a.data[Math.floor(s/i)][s%i];e(null,o)}catch(u){e(u)}}function Ld(n,t,e){var r=24;try{var i=new WebAssembly.Memory({initial:16}),a=new WebAssembly.Module(n),o=new WebAssembly.Instance(a,{env:{memory:i,abort:function(){e(new Error("webAssembly abort"))}}}),s=o.exports,u=s.newU8Array(t.length),c=new Uint8Array(i.buffer,u+r,t.length);c.set(t);var l=s.decode(u),h=new Uint32Array(i.buffer,l,4),p=h[0],v=h[2],m=h[3];p?e(null,new Uint8Array(i.buffer,m+r,v).slice(0,v)):e(new Error("lzma deocder error"))}catch(A){e(A)}}var Dd=`
|
|
883
|
+
`,Xo="KHR_texture_basisu",hd=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.loadTexture=function(e,r){var i=r.json.textures[e];if(!i.extensions||!i.extensions[Xo])return null;var a=i.extensions[Xo],o=r.json.images[a.source],s=null;if(o.bufferView)s=r.loadBufferView(o.bufferView).then(function(u){return Fn.parse(u)});else if(o.uri)s=r.options.fetcher.ajax(r.resolveResouce(o.uri),{responseType:"arraybuffer"}).then(function(u){return Fn.parse(u.body)});else throw new Error("glTF: Invalid image defs.");return s},t}(br),Yo="KHR_texture_transform",pd=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.extendTexture=function(e,r,i){var a=r.extensions!==void 0?r.extensions[Yo]:void 0;return a?(a.texCoord!==void 0&&console.warn('glTF: Custom UV sets in "'+Yo+'" extension not yet supported.'),a.offset===void 0&&a.rotation===void 0&&a.scale===void 0||(e=e.clone(),e.needsUpdate=!0,a.offset!==void 0&&e.offset.fromArray(a.offset),a.rotation!==void 0&&(e.rotation=a.rotation),a.scale!==void 0&&e.repeat.fromArray(a.scale)),e):null},t}(br),vd=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t}(br),Xi=function(){var n="b9H79Tebbbe8Fv9Gbb9Gvuuuuueu9Giuuub9Geueu9Giuuueuikqbeeedddillviebeoweuec:q;iekr;leDo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbeY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVbdE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbiL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtblK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949Wbol79IV9Rbrq:78Yqdbk:qzezu8Jjjjjbcj;eb9Rgv8Kjjjjbc9:hodnadcefal0mbcuhoaiRbbc:Ge9hmbavaialfgrad9Radz1jjjbhwcj;abad9UhlaicefhodnadTmbalc;WFbGglcjdalcjd6EhDcbhqinaqae9pmeaDaeaq9RaqaDfae6Egkcsfglcl4cifcd4hxdndndndnalc9WGgmTmbcbhPcehsawcjdfhzaohHinaraH9Rax6midnaraHaxfgo9RcK6mbczhlinalgic9Wfglawcj;cbffhOdndndndndnaHalco4fRbbalci4coG4ciGPlbedibkaO9cb83ibaOcwf9cb83ibxikaOaoRblaoRbbgAco4glalciSgCE86bbawcj;cbfaifglcGfaoclfaCfgORbbaAcl4ciGgCaCciSgCE86bbalcVfaOaCfgORbbaAcd4ciGgCaCciSgCE86bbalc7faOaCfgORbbaAciGgAaAciSgAE86bbalctfaOaAfgARbbaoRbegOco4gCaCciSgCE86bbalc91faAaCfgARbbaOcl4ciGgCaCciSgCE86bbalc4faAaCfgARbbaOcd4ciGgCaCciSgCE86bbalc93faAaCfgARbbaOciGgOaOciSgOE86bbalc94faAaOfgARbbaoRbdgOco4gCaCciSgCE86bbalc95faAaCfgARbbaOcl4ciGgCaCciSgCE86bbalc96faAaCfgARbbaOcd4ciGgCaCciSgCE86bbalc97faAaCfgARbbaOciGgOaOciSgOE86bbalc98faAaOfgORbbaoRbigoco4gAaAciSgAE86bbalc99faOaAfgORbbaocl4ciGgAaAciSgAE86bbalc9:faOaAfgORbbaocd4ciGgAaAciSgAE86bbalcufaOaAfglRbbaociGgoaociSgoE86bbalaofhoxdkaOaoRbwaoRbbgAcl4glalcsSgCE86bbawcj;cbfaifglcGfaocwfaCfgORbbaAcsGgAaAcsSgAE86bbalcVfaOaAfgORbbaoRbegAcl4gCaCcsSgCE86bbalc7faOaCfgORbbaAcsGgAaAcsSgAE86bbalctfaOaAfgORbbaoRbdgAcl4gCaCcsSgCE86bbalc91faOaCfgORbbaAcsGgAaAcsSgAE86bbalc4faOaAfgORbbaoRbigAcl4gCaCcsSgCE86bbalc93faOaCfgORbbaAcsGgAaAcsSgAE86bbalc94faOaAfgORbbaoRblgAcl4gCaCcsSgCE86bbalc95faOaCfgORbbaAcsGgAaAcsSgAE86bbalc96faOaAfgORbbaoRbvgAcl4gCaCcsSgCE86bbalc97faOaCfgORbbaAcsGgAaAcsSgAE86bbalc98faOaAfgORbbaoRbogAcl4gCaCcsSgCE86bbalc99faOaCfgORbbaAcsGgAaAcsSgAE86bbalc9:faOaAfgORbbaoRbrgocl4gAaAcsSgAE86bbalcufaOaAfglRbbaocsGgoaocsSgoE86bbalaofhoxekaOao8Pbb83bbaOcwfaocwf8Pbb83bbaoczfhokdnaiam9pmbaiczfhlarao9RcL0mekkaiam6miaoTmidnakTmbawaPfRbbhOawcj;cbfhlazhiakhHinaialRbbgAce4cbaAceG9R7aOfgO86bbaiadfhialcefhlaHcufgHmbkkazcefhzaPcefgPad6hsaohHaPad9hmexvkkcbhoasceGmdxikaoaxad2fhPdnakTmbcbhmcehsawcjdfhCinarao9Rax6miaoTmdaoaxfhoawamfRbbhOawcj;cbfhlaChiakhHinaialRbbgAce4cbaAceG9R7aOfgO86bbaiadfhialcefhlaHcufgHmbkaCcefhCamcefgmad6hsamad9hmbkaPhoxikcbhlcehsinarao9Rax6mdaoTmeaoaxfhoalcefglad6hsadal9hmbkaPhoxdkcbhoasceGTmekc9:hoxikabaqad2fawcjdfakad2z1jjjb8Aawawcjdfakcufad2fadz1jjjb8Aakaqfhqaombkc9:hoxekcbc99arao9Radcaadca0ESEhokavcj;ebf8Kjjjjbaok;xzeHu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnaeci9UgrcHfal0mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecjez:jjjjb8AavcUf9cu83ibavc8Wf9cu83ibavcyf9cu83ibavcaf9cu83ibavcKf9cu83ibavczf9cu83ibav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhodnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhlindnaoaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfalaDcu7gPcl4fcsGcitfgsydlhzasydbhHdnaDcsGgDak9pmbavaiaPfcsGcdtfydbaxaDEhsaDThDdndnadcd9hmbabarcetfgPaH87ebaPcdfaz87ebaPclfas87ebxekabarcdtfgPaHBdbaPclfazBdbaPcwfasBdbkaxaDfhxavc;abfalcitfgPasBdbaPazBdlavaicdtfasBdbavc;abfalcefcsGglcitfgPaHBdbaPasBdlaiaDfhialcefhlxdkdndnaDcsSmbamaDfaDc987fcefhmxekaocefhDao8SbbgscFeGhPdndnascu9mmbaDhoxekaocvfhoaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhokaPce4cbaPceG9R7amfhmkdndnadcd9hmbabarcetfgDaH87ebaDcdfaz87ebaDclfam87ebxekabarcdtfgDaHBdbaDclfazBdbaDcwfamBdbkavc;abfalcitfgDamBdbaDazBdlavaicdtfamBdbavc;abfalcefcsGglcitfgDaHBdbaDamBdlaicefhialcefhlxekdnaDcpe0mbaxcefgOavaiaqaDcsGfRbbgscl49RcsGcdtfydbascz6gPEhDavaias9RcsGcdtfydbaOaPfgzascsGgOEhsaOThOdndnadcd9hmbabarcetfgHax87ebaHcdfaD87ebaHclfas87ebxekabarcdtfgHaxBdbaHclfaDBdbaHcwfasBdbkavaicdtfaxBdbavc;abfalcitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfalcefcsGcitfgHasBdbaHaDBdlavaiaPfcsGgicdtfasBdbavc;abfalcdfcsGglcitfgDaxBdbaDasBdlalcefhlaiaOfhiazaOfhxxekaxcbaoRbbgHEgAaDc;:eSgDfhzaHcsGhCaHcl4hXdndnaHcs0mbazcefhOxekazhOavaiaX9RcsGcdtfydbhzkdndnaCmbaOcefhxxekaOhxavaiaH9RcsGcdtfydbhOkdndnaDTmbaocefhDxekaocdfhDao8SbegPcFeGhsdnaPcu9kmbaocofhAascFbGhscrhodninaD8SbbgPcFbGaotasVhsaPcu9kmeaDcefhDaocrfgoc8J9hmbkaAhDxekaDcefhDkasce4cbasceG9R7amfgmhAkdndnaXcsSmbaDhsxekaDcefhsaD8SbbgocFeGhPdnaocu9kmbaDcvfhzaPcFbGhPcrhodninas8SbbgDcFbGaotaPVhPaDcu9kmeascefhsaocrfgoc8J9hmbkazhsxekascefhskaPce4cbaPceG9R7amfgmhzkdndnaCcsSmbashoxekascefhoas8SbbgDcFeGhPdnaDcu9kmbascvfhOaPcFbGhPcrhDdninao8SbbgscFbGaDtaPVhPascu9kmeaocefhoaDcrfgDc8J9hmbkaOhoxekaocefhokaPce4cbaPceG9R7amfgmhOkdndnadcd9hmbabarcetfgDaA87ebaDcdfaz87ebaDclfaO87ebxekabarcdtfgDaABdbaDclfazBdbaDcwfaOBdbkavc;abfalcitfgDazBdbaDaABdlavaicdtfaABdbavc;abfalcefcsGcitfgDaOBdbaDazBdlavaicefgicsGcdtfazBdbavc;abfalcdfcsGcitfgDaABdbaDaOBdlavaiaHcz6aXcsSVfgicsGcdtfaOBdbaiaCTaCcsSVfhialcifhlkawcefhwalcsGhlaicsGhiarcifgrae6mbkkcbc99aoaqSEhokavc;aef8Kjjjjbaok:flevu8Jjjjjbcz9Rhvc9:hodnaecvfal0mbcuhoaiRbbc;:eGc;qe9hmbav9cb83iwaicefhraialfc98fhwdnaeTmbdnadcdSmbcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcdtfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfglBdbaoalBdbaDcefgDae9hmbxdkkcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcetfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfgl87ebaoalBdbaDcefgDae9hmbkkcbc99arawSEhokaok:Lvoeue99dud99eud99dndnadcl9hmbaeTmeindndnabcdfgd8Sbb:Yab8Sbbgi:Ygl:l:tabcefgv8Sbbgo:Ygr:l:tgwJbb;:9cawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai86bbdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad86bbdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad86bbabclfhbaecufgembxdkkaeTmbindndnabclfgd8Ueb:Yab8Uebgi:Ygl:l:tabcdfgv8Uebgo:Ygr:l:tgwJb;:FSawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai87ebdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad87ebdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad87ebabcwfhbaecufgembkkk;siliui99iue99dnaeTmbcbhiabhlindndnJ;Zl81Zalcof8UebgvciV:Y:vgoal8Ueb:YNgrJb;:FSNJbbbZJbbb:;arJbbbb9GEMgw:lJbbb9p9DTmbaw:OhDxekcjjjj94hDkalclf8Uebhqalcdf8UebhkabavcefciGaiVcetfaD87ebdndnaoak:YNgwJb;:FSNJbbbZJbbb:;awJbbbb9GEMgx:lJbbb9p9DTmbax:Ohkxekcjjjj94hkkabavcdfciGaiVcetfak87ebdndnaoaq:YNgoJb;:FSNJbbbZJbbb:;aoJbbbb9GEMgx:lJbbb9p9DTmbax:Ohqxekcjjjj94hqkabavcufciGaiVcetfaq87ebdndnJbbjZararN:tawawN:taoaoN:tgrJbbbbarJbbbb9GE:rJb;:FSNJbbbZMgr:lJbbb9p9DTmbar:Ohqxekcjjjj94hqkabavciGaiVcetfaq87ebalcwfhlaiclfhiaecufgembkkk9mbdnadcd4ae2gdTmbinababydbgecwtcw91:Yaece91cjjj;8ifcjjj98G::NUdbabclfhbadcufgdmbkkk9teiucbcbydj1jjbgeabcifc98GfgbBdj1jjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabkkkebcjwklz9Kbb",t="b9H79TebbbeKl9Gbb9Gvuuuuueu9Giuuub9Geueuikqbbebeedddilve9Weeeviebeoweuec:q;Aekr;leDo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbdY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVblE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtboK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbrL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949Wbwl79IV9RbDq;a9tqlbzik9:evu8Jjjjjbcz9Rhbcbheincbhdcbhiinabcwfadfaicjuaead4ceGglE86bbaialfhiadcefgdcw9hmbkaec:q:yjjbfai86bbaecitc:q1jjbfab8Piw83ibaecefgecjd9hmbkk;d8JlHud97euo978Jjjjjbcj;kb9Rgv8Kjjjjbc9:hodnadcefal0mbcuhoaiRbbc:Ge9hmbavaialfgrad9Rad;8qbbcj;abad9UhoaicefhldnadTmbaoc;WFbGgocjdaocjd6EhwcbhDinaDae9pmeawaeaD9RaDawfae6Egqcsfgoc9WGgkci2hxakcethmaocl4cifcd4hPabaDad2fhscbhzdnincehHalhOcbhAdninaraO9RaP6miavcj;cbfaAak2fhCaOaPfhlcbhidnakc;ab6mbaral9Rc;Gb6mbcbhoinaCaofhidndndndndnaOaoco4fRbbgXciGPlbedibkaipxbbbbbbbbbbbbbbbbpklbxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklbalczfhlkdndndndndnaXcd4ciGPlbedibkaipxbbbbbbbbbbbbbbbbpklzxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklzalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklzalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklzalczfhlkdndndndndnaXcl4ciGPlbedibkaipxbbbbbbbbbbbbbbbbpklaxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklaalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklaalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklaalczfhlkdndndndndnaXco4Plbedibkaipxbbbbbbbbbbbbbbbbpkl8WxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibaXc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spkl8WalclfaYpQbfaXc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibaXc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spkl8WalcwfaYpQbfaXc:q:yjjbfRbbfhlxekaialpbbbpkl8Walczfhlkaoc;abfhiaocjefak0meaihoaral9Rc;Fb0mbkkdndnaiak9pmbaici4hoinaral9RcK6mdaCaifhXdndndndndnaOaico4fRbbaocoG4ciGPlbedibkaXpxbbbbbbbbbbbbbbbbpklbxikaXalpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaXalpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaXalpbbbpklbalczfhlkaocdfhoaiczfgiak6mbkkalTmbaAci6hHalhOaAcefgAclSmdxekkcbhlaHceGmdkdnakTmbavcjdfazfhiavazfpbdbhYcbhXinaiavcj;cbfaXfgopblbgLcep9TaLpxeeeeeeeeeeeeeeeegQp9op9Hp9rgLaoakfpblbg8Acep9Ta8AaQp9op9Hp9rg8ApmbzeHdOiAlCvXoQrLgEaoamfpblbg3cep9Ta3aQp9op9Hp9rg3aoaxfpblbg5cep9Ta5aQp9op9Hp9rg5pmbzeHdOiAlCvXoQrLg8EpmbezHdiOAlvCXorQLgQaQpmbedibedibedibediaYp9UgYp9AdbbaiadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaEa8EpmwDKYqk8AExm35Ps8E8FgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaLa8ApmwKDYq8AkEx3m5P8Es8FgLa3a5pmwKDYq8AkEx3m5P8Es8Fg8ApmbezHdiOAlvCXorQLgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaLa8ApmwDKYqk8AExm35Ps8E8FgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfhiaXczfgXak6mbkkazclfgzad6mbkasavcjdfaqad2;8qbbavavcjdfaqcufad2fad;8qbbaqaDfhDc9:hoalmexikkc9:hoxekcbc99aral9Radcaadca0ESEhokavcj;kbf8Kjjjjbaokwbz:bjjjbk;tzeHu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnaeci9UgrcHfal0mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecje;8kbavcUf9cu83ibavc8Wf9cu83ibavcyf9cu83ibavcaf9cu83ibavcKf9cu83ibavczf9cu83ibav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhodnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhlindnaoaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfalaDcu7gPcl4fcsGcitfgsydlhzasydbhHdnaDcsGgDak9pmbavaiaPfcsGcdtfydbaxaDEhsaDThDdndnadcd9hmbabarcetfgPaH87ebaPcdfaz87ebaPclfas87ebxekabarcdtfgPaHBdbaPclfazBdbaPcwfasBdbkaxaDfhxavc;abfalcitfgPasBdbaPazBdlavaicdtfasBdbavc;abfalcefcsGglcitfgPaHBdbaPasBdlaiaDfhialcefhlxdkdndnaDcsSmbamaDfaDc987fcefhmxekaocefhDao8SbbgscFeGhPdndnascu9mmbaDhoxekaocvfhoaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhokaPce4cbaPceG9R7amfhmkdndnadcd9hmbabarcetfgDaH87ebaDcdfaz87ebaDclfam87ebxekabarcdtfgDaHBdbaDclfazBdbaDcwfamBdbkavc;abfalcitfgDamBdbaDazBdlavaicdtfamBdbavc;abfalcefcsGglcitfgDaHBdbaDamBdlaicefhialcefhlxekdnaDcpe0mbaxcefgOavaiaqaDcsGfRbbgscl49RcsGcdtfydbascz6gPEhDavaias9RcsGcdtfydbaOaPfgzascsGgOEhsaOThOdndnadcd9hmbabarcetfgHax87ebaHcdfaD87ebaHclfas87ebxekabarcdtfgHaxBdbaHclfaDBdbaHcwfasBdbkavaicdtfaxBdbavc;abfalcitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfalcefcsGcitfgHasBdbaHaDBdlavaiaPfcsGgicdtfasBdbavc;abfalcdfcsGglcitfgDaxBdbaDasBdlalcefhlaiaOfhiazaOfhxxekaxcbaoRbbgHEgAaDc;:eSgDfhzaHcsGhCaHcl4hXdndnaHcs0mbazcefhOxekazhOavaiaX9RcsGcdtfydbhzkdndnaCmbaOcefhxxekaOhxavaiaH9RcsGcdtfydbhOkdndnaDTmbaocefhDxekaocdfhDao8SbegPcFeGhsdnaPcu9kmbaocofhAascFbGhscrhodninaD8SbbgPcFbGaotasVhsaPcu9kmeaDcefhDaocrfgoc8J9hmbkaAhDxekaDcefhDkasce4cbasceG9R7amfgmhAkdndnaXcsSmbaDhsxekaDcefhsaD8SbbgocFeGhPdnaocu9kmbaDcvfhzaPcFbGhPcrhodninas8SbbgDcFbGaotaPVhPaDcu9kmeascefhsaocrfgoc8J9hmbkazhsxekascefhskaPce4cbaPceG9R7amfgmhzkdndnaCcsSmbashoxekascefhoas8SbbgDcFeGhPdnaDcu9kmbascvfhOaPcFbGhPcrhDdninao8SbbgscFbGaDtaPVhPascu9kmeaocefhoaDcrfgDc8J9hmbkaOhoxekaocefhokaPce4cbaPceG9R7amfgmhOkdndnadcd9hmbabarcetfgDaA87ebaDcdfaz87ebaDclfaO87ebxekabarcdtfgDaABdbaDclfazBdbaDcwfaOBdbkavc;abfalcitfgDazBdbaDaABdlavaicdtfaABdbavc;abfalcefcsGcitfgDaOBdbaDazBdlavaicefgicsGcdtfazBdbavc;abfalcdfcsGcitfgDaABdbaDaOBdlavaiaHcz6aXcsSVfgicsGcdtfaOBdbaiaCTaCcsSVfhialcifhlkawcefhwalcsGhlaicsGhiarcifgrae6mbkkcbc99aoaqSEhokavc;aef8Kjjjjbaok:flevu8Jjjjjbcz9Rhvc9:hodnaecvfal0mbcuhoaiRbbc;:eGc;qe9hmbav9cb83iwaicefhraialfc98fhwdnaeTmbdnadcdSmbcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcdtfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfglBdbaoalBdbaDcefgDae9hmbxdkkcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcetfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfgl87ebaoalBdbaDcefgDae9hmbkkcbc99arawSEhokaok:wPliuo97eue978Jjjjjbca9Rhiaec98Ghldndnadcl9hmbdnalTmbcbhvabhdinadadpbbbgocKp:RecKp:Sep;6egraocwp:RecKp:Sep;6earp;Geaoczp:RecKp:Sep;6egwp;Gep;Kep;LegDpxbbbbbbbbbbbbbbbbp:2egqarpxbbbjbbbjbbbjbbbjgkp9op9rp;Kegrpxbb;:9cbb;:9cbb;:9cbb;:9cararp;MeaDaDp;Meawaqawakp9op9rp;Kegrarp;Mep;Kep;Kep;Jep;Negwp;Mepxbbn0bbn0bbn0bbn0gqp;KepxFbbbFbbbFbbbFbbbp9oaopxbbbFbbbFbbbFbbbFp9op9qarawp;Meaqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaDawp;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpkbbadczfhdavclfgval6mbkkalae9pmeaipxbbbbbbbbbbbbbbbbgqpklbaiabalcdtfgdaeciGglcdtgv;8qbbdnalTmbaiaipblbgocKp:RecKp:Sep;6egraocwp:RecKp:Sep;6earp;Geaoczp:RecKp:Sep;6egwp;Gep;Kep;LegDaqp:2egqarpxbbbjbbbjbbbjbbbjgkp9op9rp;Kegrpxbb;:9cbb;:9cbb;:9cbb;:9cararp;MeaDaDp;Meawaqawakp9op9rp;Kegrarp;Mep;Kep;Kep;Jep;Negwp;Mepxbbn0bbn0bbn0bbn0gqp;KepxFbbbFbbbFbbbFbbbp9oaopxbbbFbbbFbbbFbbbFp9op9qarawp;Meaqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaDawp;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpklbkadaiav;8qbbskdnalTmbcbhvabhdinadczfgxaxpbbbgopxbbbbbbFFbbbbbbFFgkp9oadpbbbgDaopmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eaDaopmbediwDqkzHOAKY8AEgoczp:Sep;6egrp;Geaoczp:Reczp:Sep;6egwp;Gep;Kep;Legopxb;:FSb;:FSb;:FSb;:FSawaopxbbbbbbbbbbbbbbbbp:2egqawpxbbbjbbbjbbbjbbbjgmp9op9rp;Kegwawp;Meaoaop;Mearaqaramp9op9rp;Kegoaop;Mep;Kep;Kep;Jep;Negrp;Mepxbbn0bbn0bbn0bbn0gqp;Keczp:Reawarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9op9qgwaoarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9ogopmwDKYqk8AExm35Ps8E8Fp9qpkbbadaDakp9oawaopmbezHdiOAlvCXorQLp9qpkbbadcafhdavclfgval6mbkkalae9pmbaiaeciGgvcitgdfcbcaad9R;8kbaiabalcitfglad;8qbbdnavTmbaiaipblzgopxbbbbbbFFbbbbbbFFgkp9oaipblbgDaopmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eaDaopmbediwDqkzHOAKY8AEgoczp:Sep;6egrp;Geaoczp:Reczp:Sep;6egwp;Gep;Kep;Legopxb;:FSb;:FSb;:FSb;:FSawaopxbbbbbbbbbbbbbbbbp:2egqawpxbbbjbbbjbbbjbbbjgmp9op9rp;Kegwawp;Meaoaop;Mearaqaramp9op9rp;Kegoaop;Mep;Kep;Kep;Jep;Negrp;Mepxbbn0bbn0bbn0bbn0gqp;Keczp:Reawarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9op9qgwaoarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9ogopmwDKYqk8AExm35Ps8E8Fp9qpklzaiaDakp9oawaopmbezHdiOAlvCXorQLp9qpklbkalaiad;8qbbkk;4wllue97euv978Jjjjjbc8W9Rhidnaec98GglTmbcbhvabhoinaiaopbbbgraoczfgwpbbbgDpmlvorxmPsCXQL358E8Fgqczp:Segkclp:RepklbaopxbbjZbbjZbbjZbbjZpx;Zl81Z;Zl81Z;Zl81Z;Zl81Zakpxibbbibbbibbbibbbp9qp;6ep;NegkaraDpmbediwDqkzHOAKY8AEgrczp:Reczp:Sep;6ep;MegDaDp;Meakarczp:Sep;6ep;Megxaxp;Meakaqczp:Reczp:Sep;6ep;Megqaqp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jepxb;:FSb;:FSb;:FSb;:FSgkp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbgmp9oaxakp;Mearp;Keczp:Rep9qgxaqakp;Mearp;Keczp:ReaDakp;Mearp;Keamp9op9qgkpmbezHdiOAlvCXorQLgrp5baipblbpEb:T:j83ibaocwfarp5eaipblbpEe:T:j83ibawaxakpmwDKYqk8AExm35Ps8E8Fgkp5baipblbpEd:T:j83ibaocKfakp5eaipblbpEi:T:j83ibaocafhoavclfgval6mbkkdnalae9pmbaiaeciGgvcitgofcbcaao9R;8kbaiabalcitfgwao;8qbbdnavTmbaiaipblbgraipblzgDpmlvorxmPsCXQL358E8Fgqczp:Segkclp:RepklaaipxbbjZbbjZbbjZbbjZpx;Zl81Z;Zl81Z;Zl81Z;Zl81Zakpxibbbibbbibbbibbbp9qp;6ep;NegkaraDpmbediwDqkzHOAKY8AEgrczp:Reczp:Sep;6ep;MegDaDp;Meakarczp:Sep;6ep;Megxaxp;Meakaqczp:Reczp:Sep;6ep;Megqaqp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jepxb;:FSb;:FSb;:FSb;:FSgkp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbgmp9oaxakp;Mearp;Keczp:Rep9qgxaqakp;Mearp;Keczp:ReaDakp;Mearp;Keamp9op9qgkpmbezHdiOAlvCXorQLgrp5baipblapEb:T:j83ibaiarp5eaipblapEe:T:j83iwaiaxakpmwDKYqk8AExm35Ps8E8Fgkp5baipblapEd:T:j83izaiakp5eaipblapEi:T:j83iKkawaiao;8qbbkk:Pddiue978Jjjjjbc;ab9Rhidnadcd4ae2glc98GgvTmbcbheabhdinadadpbbbgocwp:Recwp:Sep;6eaocep:SepxbbjZbbjZbbjZbbjZp:UepxbbjFbbjFbbjFbbjFp9op;Mepkbbadczfhdaeclfgeav6mbkkdnaval9pmbaialciGgecdtgdVcbc;abad9R;8kbaiabavcdtfgvad;8qbbdnaeTmbaiaipblbgocwp:Recwp:Sep;6eaocep:SepxbbjZbbjZbbjZbbjZp:UepxbbjFbbjFbbjFbbjFp9op;Mepklbkavaiad;8qbbkk9teiucbcbydj1jjbgeabcifc98GfgbBdj1jjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikkkebcjwklz9Tbb",e=new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,3,2,0,0,5,3,1,0,1,12,1,0,10,22,2,12,0,65,0,65,0,65,0,252,10,0,0,11,7,0,65,0,253,15,26,11]),r=new Uint8Array([32,0,65,2,1,106,34,33,3,128,11,4,13,64,6,253,10,7,15,116,127,5,8,12,40,16,19,54,20,9,27,255,113,17,42,67,24,23,146,148,18,14,22,45,70,69,56,114,101,21,25,63,75,136,108,28,118,29,73,115]);if(typeof WebAssembly!="object")return{supported:!1};var i=WebAssembly.validate(e)?t:n,a,o=WebAssembly.instantiate(s(i),{}).then(function(f){a=f.instance,a.exports.__wasm_call_ctors()});function s(f){for(var g=new Uint8Array(f.length),b=0;b<f.length;++b){var w=f.charCodeAt(b);g[b]=w>96?w-97:w>64?w-39:w+4}for(var E=0,b=0;b<f.length;++b)g[E++]=g[b]<60?r[g[b]]:(g[b]-60)*64+g[++b];return g.buffer.slice(0,E)}function u(f,g,b,w,E,x){var M=a.exports.sbrk,C=b+3&-4,I=M(C*w),P=M(E.length),S=new Uint8Array(a.exports.memory.buffer);S.set(E,P);var F=f(I,b,w,P,E.length);if(F==0&&x&&x(I,C,w),g.set(S.subarray(I,I+b*w)),M(I-M(0)),F!=0)throw new Error("Malformed buffer data: "+F)}var c={NONE:"",OCTAHEDRAL:"meshopt_decodeFilterOct",QUATERNION:"meshopt_decodeFilterQuat",EXPONENTIAL:"meshopt_decodeFilterExp"},l={ATTRIBUTES:"meshopt_decodeVertexBuffer",TRIANGLES:"meshopt_decodeIndexBuffer",INDICES:"meshopt_decodeIndexSequence"},h=[],p=0;function v(f){var g={object:new Worker(f),pending:0,requests:{}};return g.object.onmessage=function(b){var w=b.data;g.pending-=w.count,g.requests[w.id][w.action](w.value),delete g.requests[w.id]},g}function m(f){for(var g="var instance; var ready = WebAssembly.instantiate(new Uint8Array(["+new Uint8Array(s(i))+"]), {}).then(function(result) { instance = result.instance; instance.exports.__wasm_call_ctors(); });self.onmessage = workerProcess;"+u.toString()+y.toString(),b=new Blob([g],{type:"text/javascript"}),w=URL.createObjectURL(b),E=0;E<f;++E)h[E]=v(w);URL.revokeObjectURL(w)}function A(f,g,b,w,E){for(var x=h[0],M=1;M<h.length;++M)h[M].pending<x.pending&&(x=h[M]);return new Promise(function(C,I){var P=new Uint8Array(b),S=p++;x.pending+=f,x.requests[S]={resolve:C,reject:I},x.object.postMessage({id:S,count:f,size:g,source:P,mode:w,filter:E},[P.buffer])})}function y(f){o.then(function(){var g=f.data;try{var b=new Uint8Array(g.count*g.size);u(a.exports[g.mode],b,g.count,g.size,g.source,a.exports[g.filter]),self.postMessage({id:g.id,count:g.count,action:"resolve",value:b},[b.buffer])}catch(w){self.postMessage({id:g.id,count:g.count,action:"reject",value:w})}})}return{ready:o,supported:!0,useWorkers:function(f){m(f)},decodeVertexBuffer:function(f,g,b,w,E){u(a.exports.meshopt_decodeVertexBuffer,f,g,b,w,a.exports[c[E]])},decodeIndexBuffer:function(f,g,b,w){u(a.exports.meshopt_decodeIndexBuffer,f,g,b,w)},decodeIndexSequence:function(f,g,b,w){u(a.exports.meshopt_decodeIndexSequence,f,g,b,w)},decodeGltfBuffer:function(f,g,b,w,E,x){u(a.exports[l[E]],f,g,b,w,a.exports[c[x]])},decodeGltfBufferAsync:function(f,g,b,w,E){return h.length>0?A(f,g,b,l[w],c[E]):o.then(function(){var x=new Uint8Array(f*g);return u(a.exports[l[w]],x,f,g,b,a.exports[c[E]]),x})}}}(),Yi="EXT_meshopt_compression",Ad=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.loadBufferView=function(e,r){var i=r.json,a=i.bufferViews[e];if(a.extensions&&a.extensions[Yi]){var o=a.extensions[Yi],s=r.loadBuffer(o.buffer);if(!Xi.supported){if(i.extensionsRequired&&i.extensionsRequired.indexOf(Yi)>=0)throw new Error("THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files");return null}return Promise.all([s,Xi.ready]).then(function(u){var c=u[0],l=o.byteOffset||0,h=o.byteLength||0,p=o.count,v=o.byteStride,m=new ArrayBuffer(p*v),A=new Uint8Array(c,l,h);return Xi.decodeGltfBuffer(new Uint8Array(m),p,v,A,o.mode,o.filter),m})}else return null},t}(br),Jo="EXT_texture_webp",md=function(n){de(t,n);function t(){var e=n!==null&&n.apply(this,arguments)||this;return e.supportsWep=!1,e}return t.prototype.prepare=function(e){var r=this;return eu().then(function(i){r.supportsWep=i.webp})},t.prototype.loadTexture=function(e,r){var i=r.json,a=i.textures[e];if(!a.extensions||!a.extensions[Jo]||!this.supportsWep)return null;var o=a.extensions[Jo];return r.loadImage(o.source).then(function(s){var u=new d.Texture(s);u.needsUpdate=!0,u.flipY=!1,a.name&&(u.name=a.name);var c=r.json.samplers||{},l=c[a.sampler]||{};return u.magFilter=vi[l.magFilter]||d.LinearFilter,u.minFilter=vi[l.minFilter]||d.LinearMipmapLinearFilter,u.wrapS=Ai[l.wrapS]||d.RepeatWrapping,u.wrapT=Ai[l.wrapT]||d.RepeatWrapping,u})},t}(br),Ji="CESIUM_RTC",gd=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.emitResult=function(e,r){if(r.json.extensions[Ji]&&r.json.extensions[Ji].center){var i=r.json.extensions[Ji].center;e.CESIUM_RTC={center:new d.Vector3().fromArray(i)}}},t}(br);const yd=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,a=0,o="";return t[a].split(o).map(function(s){return s.charCodeAt(a)>i?s:String.fromCharCode((s.charCodeAt(a)+r)%i)}).join(o)}("{vs|z-sy|n-|}npv\bH{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-u|{Sy||V{qr\x07H0vs-qrsv{rq5b`RlP\\[`aN[alP\\Y\\_6--{vs|z-rp@-p|{n{P|y|H0r{qvs0vs-qrsv{rq5b`Rl]\\V[al[\\_ZNY6n\bv{t-rp@-[|znyH0r{qvs0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6--n\bv{t-sy|n-Sy||H0ryr--{vs|z-sy|n-sy||H0r{qvsn\bv{t-rpA-|yq]|vv|{Hn\bv{t-rp@-cvr]|vv|{Hn\bv{t-rp@-P|y|Hn\bv{t-sy|n-Y|tQr}uHn\bv{t-sy|n-]|v{`v rHp-Pyv}}r-\n--znA-znv\x07V{rrH--sy|n-sy||V{qr\x07H\fH0vs-[bZlPYV]]R_`-K-=--{vs|z-Pyv}}r-pyv}}rh[bZlPYV]]R_`jH0r{qvs|vq-znv{56-\n--sy|n-ory|{tv{tSY||-J-=;=H--0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6----ory|{tv{tSY||-J-Sy||H--0ryr----ory|{tv{tSY||-J-sy||H--0r{qvs--<<前置裁切计算--0vs-[bZlPYV]]R_`-K-=----o||y-pyv}}rqH----rpA-pyv}}r]|vv|{H----0}ntzn-{|yyly||}ln----s|-5-v{-v-J-=H-v-I-[bZlPYV]]R_`H-v-88-6-\n------pyv}}r]|vv|{-J-pyv}}rh-v-j;znv\x07V{rr-7-|yq]|vv|{H------pyv}}rq-J-5pyv}}rh-v-j;sy||V{qr\x07-I-=;=-\v\v-no5ory|{tv{tSY||-:-pyv}}rh-v-j;sy||V{qr\x076-I->;=6H------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{;\x07-K-:=;B-33-pyv}}r]|vv|{;\x07-I-=;BH------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{;\b-K-:=;B-33-pyv}}r]|vv|{;\b-I-=;BH------pyv}}rq-J-pyv}}rq-33-pyv}}r]|vv|{; -K-:=;B-33-pyv}}r]|vv|{; -I-=;BH------vs-5pyv}}rq6-\n--------qvpnqH------\f----\f----0}ntzn-{|yyly||}lr{q--0r{qvs--<<楼层选择计算--sy|n-sy||\\}npv\b-J->;=H--vs-5u|{Sy||V{qr\x07-KJ-=;=-33-no5ory|{tv{tSY||-:-u|{Sy||V{qr\x076-KJ->;=6-\n----sy||\\}npv\b-J-=;>H--\f--rp@-sv{nyP|y|-J-P|y|H--0vs-qrsv{rq5b`Rl]\\V[al[\\_ZNY6----0vs-qrsv{rq5b`Rl]\\V[alONPXlUVQQR[6------rp@-pnzrnQvrpv|{-J-{|znyv r5pnzrn]|vv|{-:-|yq]|vv|{;\x07\b 6H------vs-5q|5pnzrnQvrpv|{9-[|zny6-I-=;=6-\n--------qvpnqH------\f----0ryvs-qrsv{rq5b`Rl]\\V[alONPXlQN_X6------rp@-pnzrnQvrpv|{-J-{|znyv r5pnzrn]|vv|{-:-|yq]|vv|{;\x07\b 6H------vs-5q|5pnzrnQvrpv|{9-[|zny6-I-=;=6-\n--------sv{nyP|y|-J-sv{nyP|y|-7-=;EH------\f----0r{qvs--0r{qvs--0vs-qrsv{rq5b`Rl]\\V[al`UN]RlPV_PYR6----sy|n--J-?;=-7-tyl]|v{P||q;\x07-:->;=H----sy|n--J-?;=-7-tyl]|v{P||q;\b-:->;=H----sy|n-pp-J-7-8-7H----vs-5]|v{`v r-K-E;=-33-pp-K->;=6-\n------qvpnqH----\f--0r{qvs--0vs-qrsv{rq5b`RlP\\[`aN[alP\\Y\\_6----tylSntP|y|-J-rpA5p|{n{P|y|;9-p|{n{P|y|;t9-p|{n{P|y|;o9->;=6H--0ryr----tylSntP|y|-J-rpA5sv{nyP|y|9-z|qryNy}un-7-|}npv\b-7-sy||\\}npv\b6H--0r{qvs--0vs-qrsv{rq5b`RlRQY6----tylSntP|y|;n-J-Y|tQr}uH--0r{qvs--0vs-qrsv{rq5b`RlU^ldRVTUa6----sy|n-qvn{pr-J-?;=-7-yr{tu5tyl]|v{P||q;\x07\b-:-=;B6H----sy|n-rvtu-J-zn\x075=;=9->;=-:-qvn{pr6H----rvtu-J-}|5rvtu9->;B6H----tylSntP|y|;n-J-rvtuH----tylSntP|y|;\x07\b -J-tylSntP|y|;\x07\b -7-rvtuH--0r{qvs\f"),bd=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,a=0,o="";return t[a].split(o).map(function(s){return s.charCodeAt(a)>i?s:String.fromCharCode((s.charCodeAt(a)+r)%i)}).join(o)}("nvor-rp@-p|y|H0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6--nvor-sy|n-sy||H--n\bv{t-sy|n-Sy||H0r{qvs{vs|z-sy|n-prr{UrvtuH{vs|z-sy|n-}v\x07ry_nv|H{vs|z-sy|n-}|v{`pnyrH{vs|z-sy|n-}|v{Zv{]v\x07ryH{vs|z-sy|n-}|v{Zn\x07]v\x07ryH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-tr|zrvpR|H0vs-qrsv{rq5b`Rl]\\V[alP\\Y\\_lNYaVabQR6--{vs|z-nz}yr?Q-tnqvr{ar\x07rH0r{qvsn\bv{t-rpA-|yq]|vv|{Hn\bv{t-rp@-P|y|H0vs-qrsv{rq5b`Rl]\\V[al[\\_ZNY6--n\bv{t-rp@-[|znyH0r{qvs0vs-qrsv{rq5b`RlRQY6--n\bv{t-sy|n-Y|tQr}uH0r{qvsn\bv{t-sy|n-]|v{`v rHn\bv{t-rp@-cvr]|vv|{H0qrsv{r-]V-@;>A>BF?CB@BEFDF@rp@-_TOa|Yv{rn5-rp@-nyr-6-\n--r{-rp@5-zv\x075-}|5-nyr;to-7-=;FADECD?FEC-8-rp@5-=;=B?>@?D=>A-69-rp@5-?;A-6-69-nyr;to-7-=;=DD@FF@E=E9-rp@5-yraun{R\0ny5-nyr;to9-rp@5-=;=A=AB-6-6-6-66H\frp@-Yv{rna|_TO5-rp@-nyr-6-\nr{-rp@5-zv\x075-}|5-nyr;to9-rp@5-=;A>CCC-6-6-7->;=BB-:-rp@5-=;=BB-69-nyr;to-7->?;F?9-rp@5-yraun{R\0ny5-nyr;to9-rp@5-=;==@>@=E-6-6-6-66H\frp@-trP|y|O\bUrvtu5nz}yr?Q-tnqvr{ar\x07r9-rpA-|yq]|vv|{6-\n--rp@-p|y|-J-r\x07r?Q5tnqvr{ar\x07r9-rp?5|yq]|vv|{;\b-<->=;=9-=;B66;toH--r{-p|y|H\f|vq-znv{56-\n--rpA-n{s|zrq-J-rpA5}|vv|{9->;=6H--rpA-z]|vv|{-J-z|qrycvrZnv\x07-7-n{s|zrqH--|yq]|vv|{-J-z|qryZnv\x07-7-n{s|zrqH--0vs-qrsv{rq5b`RlcR_aRelSY\\\\_6----Sy||-J-sy||H--0r{qvs--cvr]|vv|{-J-:z]|vv|{;\x07\b H--tyl]|vv|{-J-}|wrpv|{Znv\x07-7-z]|vv|{H--<<传递nvor的p|y|到s里使用--<<动态调整}|v{`v r--sy|n-rny]|v{`v r-J-}|v{`pnyr-7-}v\x07ry_nv|H--0vs-qrsv{rq5b`Rl]\\V[al`VgRlTR\\ZRa_VP6----rny]|v{`v r-7J-tr|zrvpR|H----sy|n-urvtu-J->;=-<-}|wrpv|{Znv\x07h>jh>j-7-zv\x075>;=9-:z]|vv|{; 9-:}|wrpv|{Znv\x07h?jh@j6-7-?;=H----rny]|v{`v r-J-prr{Urvtu-7-rny]|v{`v r-<-urvtuH--0ryvs-qrsv{rq5b`Rl]\\V[al`VgRlNaaR[bNaV\\[6----sy|n-urvtu-J->;=-<-}|wrpv|{Znv\x07h>jh>j-7-zv\x075>;=9-:z]|vv|{; 9-:}|wrpv|{Znv\x07h?jh@j6-7-?;=H----rny]|v{`v r-J-prr{Urvtu-7-rny]|v{`v r-<-urvtuH--0r{qvs--]|v{`v r-J-pynz}5rny]|v{`v r9-}|v{Zv{]v\x07ry-7-}v\x07ry_nv|9-}|v{Zn\x07]v\x07ry-7-}v\x07ry_nv|6H--tyl]|v{`v r-J-]|v{`v rH--0vs-qrsv{rq5b`Rl]\\V[alP\\Y\\_lNYaVabQR6----P|y|-J-trP|y|O\bUrvtu5tnqvr{ar\x07r9-|yq]|vv|{6H--0ryr----P|y|-J-p|y|H--0r{qvs--0vs-qrsv{rq5b`Rl]\\V[al[\\_ZNY6----[|zny-J-{|znyv r5zn@5z|qryZnv\x076-7-{|zny6H--0r{qvs--0vs-qrsv{rq5b`RlRQY6----Y|tQr}u-J-y|t?5:z]|vv|{; 6H--0r{qvs--0vs-qrsv{rq5b`RlU^lQR]aU6----<<-sy|n-}|wSnp|-J-:=;B-7-prr{Urvtu-<-5n{5s|-<-?;=6-7-z]|vv|{; 6H----<<-sy|n-_nqv-J-rny]|v{`v r-<-}|wSnp|H----sy|n-|vtv{nyQr}u-J-tyl]|vv|{;H----sy|n-nqwrqQr}u-J-|vtv{nyQr}u-8-=;>H----sy|n-nqw-J-nqwrqQr}u-<-|vtv{nyQr}uH----z]|vv|{;\x07\b -J-z]|vv|{;\x07\b -7-nqwH----tyl]|vv|{-J-}|wrpv|{Znv\x07-7-z]|vv|{H0r{qvs\f");var wd=new d.Vector4,Ed=Object.assign({pointScale:new d.Uniform(1),pointMinPixel:new d.Uniform(1),pointMaxPixel:new d.Uniform(1),opacity:new d.Uniform(1),gradientTexture:new d.Uniform(null),modelAlpha:new d.Uniform(0),clippers:new d.Uniform([]),shownFloorIndex:new d.Uniform(-1),constantColor:new d.Uniform(null),geometricError:new d.Uniform(0),pixelRatio:new d.Uniform(1),screenHeight:new d.Uniform(512),floor:new d.Uniform(0)},d.UniformsUtils.clone(d.UniformsLib.common)),Su=function(n){de(t,n);function t(e){e===void 0&&(e={});var r,i,a,o,s,u,c,l,h,p,v,m,A,y,f,g,b,w,E,x,M=n.call(this,{vertexShader:bd,fragmentShader:yd,uniforms:d.UniformsUtils.clone(Ed),defines:{USE_CONSTANT_COLOR:!1,USE_EDL:!1,USE_HQ_WEIGHT:!1,USE_HQ_DEPTH:!1,NUM_CLIPPING_BOX:!1,USE_CLIPFLOOR:!1,USE_VERTEX_FLOOR:!1,USE_MAP:!0,USE_UV:!0,USE_LUMINANCE:!1,USE_PANO_OPACITY:!1,USE_BLACK_TRANSITION:!1,USE_PANO_VIDEO:!1,USE_POINT_NORMAL:!1,USE_POINT_SHAPE_CIRCLE:!1,USE_POINT_SIZE_ATTENUATION:!1,USE_POINT_SIZE_GEOMETRIC:!1,USE_POINT_BACK_HIDDEN:!1,USE_POINT_BACK_DARK:!1}})||this,C;return Object.defineProperties(M,{constantColor:{get:function(){return this.uniforms.constantColor.value},set:function(I){this.uniforms.constantColor.value=I;var P=this.defines.USE_CONSTANT_COLOR,S=I!==null;P!==S&&(this.defines.USE_CONSTANT_COLOR=S,this.needsUpdate=!0)}},opacity:{get:function(){return this.uniforms.opacity.value},set:function(I){this.uniforms.opacity.value=I}},modelAlpha:{get:function(){return this.uniforms.modelAlpha.value},set:function(I){this.uniforms.modelAlpha.value=I}},shownFloorIndex:{get:function(){return this.uniforms.shownFloorIndex.value},set:function(I){this.uniforms.shownFloorIndex.value=I}},clippers:{get:function(){return C},set:function(I){C!==I&&(C=I,this.uniforms.clippers.value=(C||[]).map(function(P){var S=typeof P.floorIndex=="number"?P.floorIndex:-1,F=new d.Matrix4().getInverse(P.clippingBoxMatrix);return{matrixInverse:F,floorIndex:S}}),this.needsUpdate=!0)}},pointColor:{get:function(){return this.defines.USE_POINT_COLOR_ALTITUDE===!0?"ALTITUDE":"RGB"},set:function(I){var P=I==="ALTITUDE";this.defines.USE_POINT_COLOR_ALTITUDE!==P&&(this.defines.USE_POINT_COLOR_ALTITUDE=P,this.needsUpdate=!0)}},pointSize:{get:function(){return this.defines.USE_POINT_SIZE_GEOMETRIC===!0?"GEOMETRIC":this.defines.USE_POINT_SIZE_ATTENUATION===!0?"ATTENUATION":"FIXED"},set:function(I){var P=I==="ATTENUATION",S=I==="GEOMETRIC";this.defines.USE_POINT_SIZE_GEOMETRIC!==S&&(this.defines.USE_POINT_SIZE_GEOMETRIC=S,this.needsUpdate=!0),this.defines.USE_POINT_SIZE_ATTENUATION!==P&&(this.defines.USE_POINT_SIZE_ATTENUATION=P,this.needsUpdate=!0)}},pointShape:{get:function(){return this.defines.USE_POINT_SHAPE_CIRCLE===!0?"CIRCLE":"SQUARE"},set:function(I){var P=I==="CIRCLE";this.defines.USE_POINT_SHAPE_CIRCLE!==P&&(this.defines.USE_POINT_SHAPE_CIRCLE=P,this.needsUpdate=!0)}},pointScale:{get:function(){return this.uniforms.pointScale.value},set:function(I){this.uniforms.pointScale.value=I}},pointBack:{get:function(){return this.defines.USE_POINT_BACK_HIDDEN===!0?"HIDDEN":this.defines.USE_POINT_BACK_DARK===!0?"DARK":"VISIBLE"},set:function(I){var P=I==="HIDDEN",S=I==="DARK";this.defines.USE_POINT_BACK_HIDDEN!==P&&(this.defines.USE_POINT_BACK_HIDDEN=P,this.needsUpdate=!0),this.defines.USE_POINT_BACK_DARK!==S&&(this.defines.USE_POINT_BACK_DARK=S,this.needsUpdate=!0)}},pointMinPixel:{get:function(){return this.uniforms.pointMinPixel.value},set:function(I){this.uniforms.pointMinPixel.value=I}},pointMaxPixel:{get:function(){return this.uniforms.pointMaxPixel.value},set:function(I){this.uniforms.pointMaxPixel.value=I}},useEDL:{get:function(){return this.defines.USE_EDL},set:function(I){I!==this.defines.USE_EDL&&(this.defines.USE_EDL=I,this.needsUpdate=!0)}},useHQWeight:{get:function(){return this.defines.USE_HQ_WEIGHT},set:function(I){I!==this.defines.USE_HQ_WEIGHT&&(this.defines.USE_HQ_WEIGHT=I,this.needsUpdate=!0)}},useHQDepth:{get:function(){return this.defines.USE_HQ_DEPTH},set:function(I){I!==this.defines.USE_HQ_DEPTH&&(this.defines.USE_HQ_DEPTH=I,this.needsUpdate=!0)}},gradientTexture:{get:function(){return this.uniforms.gradientTexture.value},set:function(I){this.uniforms.gradientTexture.value=I}},floor:{get:function(){return this.uniforms.floor.value},set:function(I){this.uniforms.floor.value=I}}}),M.pano0=(r=e.pano0)!==null&&r!==void 0?r:be.pano0,M.pano1=(i=e.pano1)!==null&&i!==void 0?i:be.pano1,M.modelAlpha=(a=e.modelAlpha)!==null&&a!==void 0?a:be.modelAlpha,M.progress=(o=e.progress)!==null&&o!==void 0?o:be.progress,M.useBlackTransition=(s=e.useBlackTransition)!==null&&s!==void 0?s:be.useBlackTransition,M.constantColor=(u=e.constantColor)!==null&&u!==void 0?u:be.constantColor,M.opacity=(c=e.opacity)!==null&&c!==void 0?c:be.opacity,M.shownFloorIndex=(l=e.shownFloorIndex)!==null&&l!==void 0?l:be.shownFloorIndex,M.clippers=(h=e.clippers)!==null&&h!==void 0?h:be.clippers,M.useEDL=(p=e.useEDL)!==null&&p!==void 0?p:be.useEDL,M.useHQWeight=(v=e.useHQWeight)!==null&&v!==void 0?v:be.useHQWeight,M.useHQDepth=(m=e.useHQDepth)!==null&&m!==void 0?m:be.useHQDepth,M.pointColor=(A=e.pointColor)!==null&&A!==void 0?A:be.pointColor,M.pointShape=(y=e.pointShape)!==null&&y!==void 0?y:be.pointShape,M.pointSize=(f=e.pointSize)!==null&&f!==void 0?f:be.pointSize,M.pointScale=(g=e.pointScale)!==null&&g!==void 0?g:be.pointScale,M.pointBack=(b=e.pointBack)!==null&&b!==void 0?b:be.pointBack,M.pointMinPixel=(w=e.pointMinPixel)!==null&&w!==void 0?w:be.pointMinPixel,M.pointMaxPixel=(E=e.pointMaxPixel)!==null&&E!==void 0?E:be.pointMaxPixel,M.gradientTexture=(x=e.gradientTexture)!==null&&x!==void 0?x:be.gradientTexture,M.floor=0,M.transparent=!1,M}return t.prototype.onBeforeCompile=function(e,r){var i,a,o=String((a=(i=this.clippers)===null||i===void 0?void 0:i.length)!==null&&a!==void 0?a:0);e.vertexShader=e.vertexShader.replace(/NUM_CLIPPERS/g,o),e.fragmentShader=e.fragmentShader.replace(/NUM_CLIPPERS/g,o)},t.prototype.update=function(e,r){var i=r instanceof hi?r.pixelRatio:e.getPixelRatio(),a=r instanceof hi?r.screenHeight:e.getViewport(wd).z;this.uniforms.pixelRatio.value=i,this.uniforms.screenHeight.value=a,this.transparent=this.shownFloorIndex>-1||this.opacity<1||this.modelAlpha<1,this.useEDL&&(this.transparent=!1),this.useHQDepth&&(this.depthTest=!0,this.depthWrite=!0),this.useHQWeight?(this.depthWrite=!1,this.blending=d.CustomBlending,this.blendSrc=d.SrcAlphaFactor,this.blendSrcAlpha=d.SrcAlphaFactor,this.blendDst=d.OneFactor,this.blendDstAlpha=d.OneFactor):(this.depthWrite=!0,this.transparent=this.shownFloorIndex>-1||this.opacity<1||this.modelAlpha<1,this.blendDst=d.OneMinusSrcAlphaFactor,this.blendEquation=d.AddEquation,this.blendSrcAlpha=null,this.blendDstAlpha=null,this.blendEquationAlpha=null,this.blending=d.NormalBlending)},t.prototype.syncModel=function(e){var r="".concat(e.id,":").concat(e.materialVersion);r!==this.syncModelVersion&&(Object.assign(this,e.getMaterial()),this.syncModelVersion=r)},t}(d.ShaderMaterial),xd=function(n){de(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.loadMesh=function(e,r){var i=this,a=r.json.meshes[e],o=a.primitives,s=Promise.all(o.map(function(l){return r.loadGeometry(l)})),u=Promise.all(o.map(function(l){return i.loadPBMMaterial(l,r)})),c=Promise.all([s,u]).then(function(l){for(var h=l[0],p=l[1],v=[],m=0;m<o.length;m++){var A=o[m],y=h[m],f=p[m];y.attributes.normal===void 0&&(f.flatShading=!0),y.attributes.tangent===void 0&&f.normalScale&&(f.normalScale.y*=-1);var g=A.mode||Re.TRIANGLES,b=void 0;if(g===Re.TRIANGLES||g===Re.TRIANGLE_STRIP||g===Re.TRIANGLE_FAN)g===Re.TRIANGLE_STRIP?y=r.toGeometryTrianglesDrawMode(y,d.TriangleStripDrawMode):g===Re.TRIANGLE_FAN&&(y=r.toGeometryTrianglesDrawMode(y,d.TriangleFanDrawMode)),y=y.clone(),y.clearGroups(),y.addGroup(0,y.index?y.index.count:y.attributes.position.count,0),y.attributes.normal||y.computeVertexNormals(),b=new _t(y,[f]);else if(g===Re.POINTS)b=new Lr(y,f);else throw new Error("glTF: Primitive mode unsupported: "+g);b.name=r.createUniqueName(a.name||"mesh_"+e),v.push(b)}if(v.length===1)return v[0];for(var w=new d.Group,E=0,x=v;E<x.length;E++){var b=x[E];w.add(b)}return w});return c},t.prototype.loadPBMMaterial=function(e,r){var i=e.mode,a=null;if(i===Re.TRIANGLES||i===Re.TRIANGLE_STRIP||i===Re.TRIANGLE_FAN)a=this.loadPBMMeshMaterial(e,r);else if(i===Re.POINTS)a=this.loadPBMPointCloudMaterial(e,r);else throw new Error("glTF: Primitive mode unsupported: "+i);return a},t.prototype.extendTexture=function(e,r,i){return e.minFilter=d.LinearFilter,e.magFilter=d.LinearFilter,e.generateMipmaps=!1,e},t.prototype.loadPBMPointCloudMaterial=function(e,r){var i=new Su;return Object.keys(e.attributes).filter(function(a){return Rt[a]==="normal"}).length>0&&(i.defines.USE_POINT_NORMAL=!0),Promise.resolve(i)},t.prototype.loadPBMMeshMaterial=function(e,r){var i=[],a=new Vn;if(a.uniforms.diffuse.value=new d.Color(1,1,1),a.uniforms.exposure.value=3.3,a.defines.USE_MAP=!1,Object.keys(e.attributes).filter(function(l){return Rt[l]==="color"}).length>0&&(a.vertexColors=!0),Object.keys(e.attributes).filter(function(l){return Rt[l]==="tangent"}).length===0&&(a.normalScale&&(a.normalScale.y*=-1),a.clearcoatNormalScale&&(a.clearcoatNormalScale.y*=-1)),e.material!==void 0){var o=r.json.materials[e.material];o.name&&(a.name=o.name);var s=o.pbrMetallicRoughness||{};if(Array.isArray(s.baseColorFactor)){var u=s.baseColorFactor;a.uniforms.diffuse.value.fromArray(u)}if(s.baseColorTexture!==void 0&&i.push(r.createMaterialTexture(s.baseColorTexture).then(function(l){a.uniforms.map.value=l,a.defines.USE_MAP=!0})),o.doubleSided===!0&&(a.side=d.DoubleSide),o.normalTexture!==void 0&&(i.push(r.createMaterialTexture(o.normalTexture).then(function(l){a.uniforms.normalMap.value=l})),a.uniforms.normalScale.value=new d.Vector2(1,1),o.normalTexture.scale!==void 0)){var c=o.normalTexture.scale;a.uniforms.normalScale.value.set(c,c)}}return Promise.all(i).then(function(){return a})},t}(br),rn={KHR_binary_glTF:ed,KHR_draco_mesh_compression:nd,KHR_texture_basisu:hd,KHR_texture_transform:pd,KHR_mesh_quantization:vd,EXT_meshopt_compression:Ad,EXT_texture_webp:md,CESIUM_RTC:gd,PBM_mesh:xd};function Ga(n,t){var e,r,i,a={};if(t.addonExtensions)for(var o=0,s=t.addonExtensions;o<s.length;o++){var u=s[o];a[u]=new rn[u]}var c;if(typeof n=="string")c=n;else{var l=rn.KHR_binary_glTF.getMagic(n);if(l===rn.KHR_binary_glTF.HEADER_MAGIC){var h=new rn.KHR_binary_glTF;try{h.loadGlbBinary(n)}catch(f){return Promise.reject(f)}a.KHR_binary_glTF=h,c=h.content}else c=Ea(new Uint8Array(n))}var p=JSON.parse(c);if(p.asset===void 0||Number(p.asset.version[0])<2)return Promise.reject(new Error("glTF: Unsupported asset. glTF versions >=2.0 are supported."));if(p.extensionsUsed)for(var v=p.extensionsRequired||[],m=0;m<p.extensionsUsed.length;m++){var A=p.extensionsUsed[m];a[A]||(rn[A]?a[A]=new rn[A]:v.indexOf(A)>=0&&console.warn('glTF: Unknown extension "'+A+'".'))}var y=new $c(p,a,{copyUV2:(e=t.copyUV2)!==null&&e!==void 0?e:!0,resourcePath:(r=t.resourcePath)!==null&&r!==void 0?r:"",search:(i=t.search)!==null&&i!==void 0?i:"",fetcher:t.fetcher});return y.parse()}var Md=new d.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]);function Tu(n,t){var e={uri:n,gltfUpAxis:t.upAxis};return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"}).then(function(r){return r.body})}).then(function(r){return Promise.resolve(0).then(function(i){return xu(e,r,i)}).then(function(i){return Iu(e,r,i)}).then(function(i){return Jc(e,r,i)})}).then(function(){var r;return Ga(e.gltfArrayBuffer,{copyUV2:!1,addonExtensions:["PBM_mesh"],resourcePath:n.slice(0,n.lastIndexOf("/")+1),search:(r=n.split("?")[1])!==null&&r!==void 0?r:"",fetcher:t.fetcher}).then(function(i){var a=new d.Matrix4;t.upAxis!=="Z"&&a.premultiply(Md);var o=new d.Matrix4().setPosition(e.rtcCenter);if(a.premultiply(o),i.CESIUM_RTC){var s=new d.Matrix4().setPosition(i.CESIUM_RTC.center);a.premultiply(s)}var u=i.scene;return u.applyMatrix4(a),{type:"b3dm",uri:e.uri,byteLength:e.byteLength,object:u,dispose:function(){return i.dispose()}}})})}function Cd(n,t,e){var r=new Mu(n.featureTableJson,n.featureTableBinary);return Promise.resolve().then(function(){var i=r.getExtension("3DTILES_draco_point_compression");if(i)return Bd(i,r);var a=[Id(r),Sd(r),Pd(r)];return Promise.all(a).then(function(o){var s=o[0],u=o[1],c=o[2];return{position:s,color:u,normal:c}})}).then(function(i){return n.attributes=i,e})}function or(n,t,e){return{type:n,array:t,size:e}}var Zi=65535;function Id(n){if(n.hasProperty("POSITION")){var t=n.getPropertyArray("POSITION",xe.FLOAT,3);return or(xe.FLOAT,t,3)}else if(n.hasProperty("POSITION_QUANTIZED")){var e=n.getPropertyArray("POSITION_QUANTIZED",xe.UNSIGNED_SHORT,3),r=n.getGlobalProperty("QUANTIZED_VOLUME_SCALE",xe.FLOAT,3),i=n.getGlobalProperty("QUANTIZED_VOLUME_OFFSET",xe.FLOAT,3);if(!r||!i)throw new Error("QUANTIZED_VOLUME_SCALE or QUANTIZED_VOLUME_OFFSET never found.");for(var a=new Float32Array(e.length),o=e.length/3,s=r[0]/Zi,u=r[1]/Zi,c=r[2]/Zi,l=i[0],h=i[1],p=i[2],v=0,m=void 0;v<o;v++)m=v*3,a[m]=e[m]*s+l,a[++m]=e[m]*u+h,a[++m]=e[m]*c+p;return or(xe.FLOAT,a,3)}return null}function Sd(n){if(n.hasProperty("RGB")){var t=n.getPropertyArray("RGB",xe.UNSIGNED_BYTE,3);return or(xe.UNSIGNED_BYTE,t,3)}else if(n.hasProperty("RGBA")){for(var t=n.getPropertyArray("RGBA",xe.UNSIGNED_BYTE,4),e=t.length,r=new Uint8Array(e*3),i=0,a=void 0,o=void 0;i<e;i++)a=i*3,o=i*4,r[a]=t[o],r[++a]=t[++o],r[++a]=t[++o];return or(xe.UNSIGNED_BYTE,t,4)}else if(n.hasProperty("RGB565")){for(var t=n.getPropertyArray("RGB565",xe.UNSIGNED_SHORT,1),e=t.length,r=new Uint8Array(e*3),i=0,s=void 0,u=void 0;i<e;i++)u=t[i],s=i*3,r[s]=(u>>11&31)<<3,r[++s]=(u>>5&63)<<2,r[++s]=(u&31)<<3;return or(xe.UNSIGNED_BYTE,r,3)}return null}var Td=255,Zo=2/Td;function Pd(n){if(n.hasProperty("NORMAL")){var t=n.getPropertyArray("NORMAL",xe.FLOAT,3);return or(xe.FLOAT,t,3)}else if(n.hasProperty("NORMAL_OCT16P")){for(var t=n.getPropertyArray("NORMAL_OCT16P",xe.UNSIGNED_BYTE,2),e=t.length/2,r=new Float32Array(e*3),i=0,a=void 0,o=void 0,s=void 0,u=void 0,c=void 0,l=void 0,h=void 0;i<e;i++)a=i*2,o=t[a]*Zo-1,s=t[++a]*Zo-1,c=o<0?-o:o,l=s<0?-s:s,u=1-(c+l),u<0&&(o=(1-l)*(o<0?-1:1),s=(1-c)*(s<0?-1:1)),h=Math.sqrt(o*o+s*s+u*u),a=i*3,r[a]=o/h,r[++a]=s/h,r[++a]=u/h;return or(xe.FLOAT,r,3)}return null}function Bd(n,t){return Mi(this,void 0,void 0,function(){var e,r,i,a,o,s;return Ci(this,function(u){if(e=n.properties||{},r=n.byteOffset,i=n.byteLength,!e||!Number.isFinite(r)||!i)throw new Error("Draco properties, byteOffset, and byteLength must be defined");return a=t.buffer.slice(r,r+i),o=n.properties,s={POSITION:"Float32Array",NORMAL:"Float32Array",RGB:"Uint8Array"},[2,mi.decodeGeometry(a.buffer,{attributeIDs:o,attributeTypes:s,useUniqueIDs:!0}).then(function(c){var l=c.getAttribute("POSITION"),h=c.getAttribute("RGB"),p=c.getAttribute("NORMAL");return{position:l?or(xe.FLOAT,l.array,l.itemSize):null,color:h?or(xe.UNSIGNED_BYTE,h.array,h.itemSize):null,normal:p?or(xe.FLOAT,p.array,p.itemSize):null}})]})})}function Pu(n,t){var e={uri:n};return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"}).then(function(r){return r.body})}).then(function(r){return Promise.resolve(0).then(function(i){return xu(e,r,i)}).then(function(i){return Iu(e,r,i)}).then(function(i){return Cd(e,r,i)})}).then(function(){var r;return Rd(e.attributes,{computeBoundingBox:(r=t.computeBoundingBox)!==null&&r!==void 0?r:!0})}).then(function(r){var i=new d.Matrix4,a=new d.Matrix4().setPosition(e.rtcCenter);return i.premultiply(a),r.object.applyMatrix4(i),{type:"pnts",uri:e.uri,byteLength:e.byteLength,object:r.object,dispose:function(){return r.dispose()}}})}function Rd(n,t){var e=new Set,r=new d.BufferGeometry;e.add(r);var i=new Su;e.add(i),n.position&&r.setAttribute("position",new d.BufferAttribute(n.position.array,n.position.size,!1)),n.color&&r.setAttribute("color",new d.BufferAttribute(n.color.array,n.color.size,!0)),n.normal&&(r.setAttribute("normal",new d.BufferAttribute(n.normal.array,n.normal.size,!1)),i.defines.USE_POINT_NORMAL=!0),t.computeBoundingBox&&r.computeBoundingBox();var a=new Lr(r,i);return a.matrix.compose(a.position,a.quaternion,a.scale),a.matrixAutoUpdate=!1,a.frustumCulled=!1,a.renderOrder=-1e3,Promise.resolve({object:a,dispose:function(){e.forEach(function(o){o.dispose()}),e.clear()}})}function Bu(){var n={};return n.OutWindow=function(){this._windowSize=0},n.OutWindow.prototype.create=function(t){(!this._buffer||this._windowSize!==t)&&(this._buffer=[]),this._windowSize=t,this._pos=0,this._streamPos=0},n.OutWindow.prototype.flush=function(){var t=this._pos-this._streamPos;if(t!==0){for(;t--;)this._stream.writeByte(this._buffer[this._streamPos++]);this._pos>=this._windowSize&&(this._pos=0),this._streamPos=this._pos}},n.OutWindow.prototype.releaseStream=function(){this.flush(),this._stream=null},n.OutWindow.prototype.setStream=function(t){this.releaseStream(),this._stream=t},n.OutWindow.prototype.init=function(t){t||(this._streamPos=0,this._pos=0)},n.OutWindow.prototype.copyBlock=function(t,e){var r=this._pos-t-1;for(r<0&&(r+=this._windowSize);e--;)r>=this._windowSize&&(r=0),this._buffer[this._pos++]=this._buffer[r++],this._pos>=this._windowSize&&this.flush()},n.OutWindow.prototype.putByte=function(t){this._buffer[this._pos++]=t,this._pos>=this._windowSize&&this.flush()},n.OutWindow.prototype.getByte=function(t){var e=this._pos-t-1;return e<0&&(e+=this._windowSize),this._buffer[e]},n.RangeDecoder=function(){},n.RangeDecoder.prototype.setStream=function(t){this._stream=t},n.RangeDecoder.prototype.releaseStream=function(){this._stream=null},n.RangeDecoder.prototype.init=function(){var t=5;for(this._code=0,this._range=-1;t--;)this._code=this._code<<8|this._stream.readByte()},n.RangeDecoder.prototype.decodeDirectBits=function(t){for(var e=0,r=t,i;r--;)this._range>>>=1,i=this._code-this._range>>>31,this._code-=this._range&i-1,e=e<<1|1-i,this._range&4278190080||(this._code=this._code<<8|this._stream.readByte(),this._range<<=8);return e},n.RangeDecoder.prototype.decodeBit=function(t,e){var r=t[e],i=(this._range>>>11)*r;return(this._code^2147483648)<(i^2147483648)?(this._range=i,t[e]+=2048-r>>>5,this._range&4278190080||(this._code=this._code<<8|this._stream.readByte(),this._range<<=8),0):(this._range-=i,this._code-=i,t[e]-=r>>>5,this._range&4278190080||(this._code=this._code<<8|this._stream.readByte(),this._range<<=8),1)},n.initBitModels=function(t,e){for(;e--;)t[e]=1024},n.BitTreeDecoder=function(t){this._models=[],this._numBitLevels=t},n.BitTreeDecoder.prototype.init=function(){n.initBitModels(this._models,1<<this._numBitLevels)},n.BitTreeDecoder.prototype.decode=function(t){for(var e=1,r=this._numBitLevels;r--;)e=e<<1|t.decodeBit(this._models,e);return e-(1<<this._numBitLevels)},n.BitTreeDecoder.prototype.reverseDecode=function(t){for(var e=1,r=0,i=0,a;i<this._numBitLevels;++i)a=t.decodeBit(this._models,e),e=e<<1|a,r|=a<<i;return r},n.reverseDecode2=function(t,e,r,i){for(var a=1,o=0,s=0,u;s<i;++s)u=r.decodeBit(t,e+a),a=a<<1|u,o|=u<<s;return o},n.LenDecoder=function(){this._choice=[],this._lowCoder=[],this._midCoder=[],this._highCoder=new n.BitTreeDecoder(8),this._numPosStates=0},n.LenDecoder.prototype.create=function(t){for(;this._numPosStates<t;++this._numPosStates)this._lowCoder[this._numPosStates]=new n.BitTreeDecoder(3),this._midCoder[this._numPosStates]=new n.BitTreeDecoder(3)},n.LenDecoder.prototype.init=function(){var t=this._numPosStates;for(n.initBitModels(this._choice,2);t--;)this._lowCoder[t].init(),this._midCoder[t].init();this._highCoder.init()},n.LenDecoder.prototype.decode=function(t,e){return t.decodeBit(this._choice,0)===0?this._lowCoder[e].decode(t):t.decodeBit(this._choice,1)===0?8+this._midCoder[e].decode(t):16+this._highCoder.decode(t)},n.Decoder2=function(){this._decoders=[]},n.Decoder2.prototype.init=function(){n.initBitModels(this._decoders,768)},n.Decoder2.prototype.decodeNormal=function(t){var e=1;do e=e<<1|t.decodeBit(this._decoders,e);while(e<256);return e&255},n.Decoder2.prototype.decodeWithMatchByte=function(t,e){var r=1,i,a;do if(i=e>>7&1,e<<=1,a=t.decodeBit(this._decoders,(1+i<<8)+r),r=r<<1|a,i!==a){for(;r<256;)r=r<<1|t.decodeBit(this._decoders,r);break}while(r<256);return r&255},n.LiteralDecoder=function(){},n.LiteralDecoder.prototype.create=function(t,e){var r;if(!(this._coders&&this._numPrevBits===e&&this._numPosBits===t))for(this._numPosBits=t,this._posMask=(1<<t)-1,this._numPrevBits=e,this._coders=[],r=1<<this._numPrevBits+this._numPosBits;r--;)this._coders[r]=new n.Decoder2},n.LiteralDecoder.prototype.init=function(){for(var t=1<<this._numPrevBits+this._numPosBits;t--;)this._coders[t].init()},n.LiteralDecoder.prototype.getDecoder=function(t,e){return this._coders[((t&this._posMask)<<this._numPrevBits)+((e&255)>>>8-this._numPrevBits)]},n.Decoder=function(){this._outWindow=new n.OutWindow,this._rangeDecoder=new n.RangeDecoder,this._isMatchDecoders=[],this._isRepDecoders=[],this._isRepG0Decoders=[],this._isRepG1Decoders=[],this._isRepG2Decoders=[],this._isRep0LongDecoders=[],this._posSlotDecoder=[],this._posDecoders=[],this._posAlignDecoder=new n.BitTreeDecoder(4),this._lenDecoder=new n.LenDecoder,this._repLenDecoder=new n.LenDecoder,this._literalDecoder=new n.LiteralDecoder,this._dictionarySize=-1,this._dictionarySizeCheck=-1,this._posSlotDecoder[0]=new n.BitTreeDecoder(6),this._posSlotDecoder[1]=new n.BitTreeDecoder(6),this._posSlotDecoder[2]=new n.BitTreeDecoder(6),this._posSlotDecoder[3]=new n.BitTreeDecoder(6)},n.Decoder.prototype.setDictionarySize=function(t){return t<0?!1:(this._dictionarySize!==t&&(this._dictionarySize=t,this._dictionarySizeCheck=Math.max(this._dictionarySize,1),this._outWindow.create(Math.max(this._dictionarySizeCheck,4096))),!0)},n.Decoder.prototype.setLcLpPb=function(t,e,r){var i=1<<r;return t>8||e>4||r>4?!1:(this._literalDecoder.create(e,t),this._lenDecoder.create(i),this._repLenDecoder.create(i),this._posStateMask=i-1,!0)},n.Decoder.prototype.init=function(){var t=4;for(this._outWindow.init(!1),n.initBitModels(this._isMatchDecoders,192),n.initBitModels(this._isRep0LongDecoders,192),n.initBitModels(this._isRepDecoders,12),n.initBitModels(this._isRepG0Decoders,12),n.initBitModels(this._isRepG1Decoders,12),n.initBitModels(this._isRepG2Decoders,12),n.initBitModels(this._posDecoders,114),this._literalDecoder.init();t--;)this._posSlotDecoder[t].init();this._lenDecoder.init(),this._repLenDecoder.init(),this._posAlignDecoder.init(),this._rangeDecoder.init()},n.Decoder.prototype.decode=function(t,e,r){var i=0,a=0,o=0,s=0,u=0,c=0,l=0,h,p,v,m,A,y;for(this._rangeDecoder.setStream(t),this._outWindow.setStream(e),this.init();r<0||c<r;)if(h=c&this._posStateMask,this._rangeDecoder.decodeBit(this._isMatchDecoders,(i<<4)+h)===0)p=this._literalDecoder.getDecoder(c++,l),i>=7?l=p.decodeWithMatchByte(this._rangeDecoder,this._outWindow.getByte(a)):l=p.decodeNormal(this._rangeDecoder),this._outWindow.putByte(l),i=i<4?0:i-(i<10?3:6);else{if(this._rangeDecoder.decodeBit(this._isRepDecoders,i)===1)v=0,this._rangeDecoder.decodeBit(this._isRepG0Decoders,i)===0?this._rangeDecoder.decodeBit(this._isRep0LongDecoders,(i<<4)+h)===0&&(i=i<7?9:11,v=1):(this._rangeDecoder.decodeBit(this._isRepG1Decoders,i)===0?m=o:(this._rangeDecoder.decodeBit(this._isRepG2Decoders,i)===0?m=s:(m=u,u=s),s=o),o=a,a=m),v===0&&(v=2+this._repLenDecoder.decode(this._rangeDecoder,h),i=i<7?8:11);else if(u=s,s=o,o=a,v=2+this._lenDecoder.decode(this._rangeDecoder,h),i=i<7?7:10,A=this._posSlotDecoder[v<=5?v-2:3].decode(this._rangeDecoder),A>=4){if(y=(A>>1)-1,a=(2|A&1)<<y,A<14)a+=n.reverseDecode2(this._posDecoders,a-A-1,this._rangeDecoder,y);else if(a+=this._rangeDecoder.decodeDirectBits(y-4)<<4,a+=this._posAlignDecoder.reverseDecode(this._rangeDecoder),a<0){if(a===-1)break;return!1}}else a=A;if(a>=c||a>=this._dictionarySizeCheck)return!1;this._outWindow.copyBlock(a,v),c+=v,l=this._outWindow.getByte(0)}return this._outWindow.flush(),this._outWindow.releaseStream(),this._rangeDecoder.releaseStream(),!0},n.Decoder.prototype.setDecoderProperties=function(t){var e,r,i,a,o;return t.size<5||(e=t.readByte(),r=e%9,e=~~(e/9),i=e%5,a=~~(e/5),!this.setLcLpPb(r,i,a))?!1:(o=t.readByte(),o|=t.readByte()<<8,o|=t.readByte()<<16,o+=t.readByte()*16777216,this.setDictionarySize(o))},n.decompress=function(t,e,r,i){var a=new n.Decoder;if(!a.setDecoderProperties(t))throw"Incorrect stream properties";if(!a.decode(e,r,i))throw"Error in data stream";return!0},n.decompressFile=function(t,e){var r=new n.Decoder,i;if(!r.setDecoderProperties(t))throw"Incorrect stream properties";if(i=t.readByte(),i|=t.readByte()<<8,i|=t.readByte()<<16,i+=t.readByte()*16777216,t.readByte(),t.readByte(),t.readByte(),t.readByte(),!r.decode(t,e,i))throw"Error in data stream";return!0},n}var Fd=Bu();function Od(){function n(e){for(var r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",i=new Uint8Array(256),a=0;a<r.length;a++)i[r.charCodeAt(a)]=a;var o=e.length*.75,s=e.length,u,c=0,l,h,p,v;e[e.length-1]==="="&&(o--,e[e.length-2]==="="&&o--);var m=new ArrayBuffer(o),A=new Uint8Array(m);for(u=0;u<s;u+=4)l=i[e.charCodeAt(u)],h=i[e.charCodeAt(u+1)],p=i[e.charCodeAt(u+2)],v=i[e.charCodeAt(u+3)],A[c++]=l<<2|h>>4,A[c++]=(h&15)<<4|p>>2,A[c++]=(p&3)<<6|v&63;return m}var t="AGFzbQEAAAABSg1gAABgAX8Bf2ACf38Bf2AEf39/fwBgA39/fwBgAX8AYAJ/fwBgA39/fwF/YAR/f39/AX9gAn9/AGABfwF/YAABf2AEf39/fwF/AhsCA2VudgVhYm9ydAADA2VudgZtZW1vcnkCAAEDJiUBAQkKAgoKCwsLCwsAAgoBAgQKAQYFCAoFBQQEBwgCBwwCAQAABAQBcAABBhoFfwFBAAt/AUEAC38BQQALfwFBAAt/AUEACwc9BgZtZW1vcnkCAAV0YWJsZQEABXJlc2V0AA0KbmV3VThBcnJheQAQCnVucGFja1NpemUAFAZkZWNvZGUAIwgBJAkHAQBBAAsBJQqAViVoAQN/IABBgICAgARLBEAACyMBIgEgAEEBIABBAUsbakEHakF4cSICPwAiA0EQdEsEQCADIAIgAWtB//8DakGAgHxxQRB2IgAgAyAAShtAAEEASARAIABAAEEASARAAAsLCyACJAEgAQsbAQF/QQFBICAAQQdqZ2t0EAEiASAANgIAIAELkQMBAX8gAUUEQA8LIABBADoAACAAIAFqQQFrQQA6AAAgAUECTQRADwsgAEEBakEAOgAAIABBAmpBADoAACAAIAFqIgJBAmtBADoAACACQQNrQQA6AAAgAUEGTQRADwsgAEEDakEAOgAAIAAgAWpBBGtBADoAACABQQhNBEAPC0EAIABrQQNxIgIgAGoiAEEANgIAIAEgAmtBfHEiASAAakEEa0EANgIAIAFBCE0EQA8LIABBBGpBADYCACAAQQhqQQA2AgAgACABaiICQQxrQQA2AgAgAkEIa0EANgIAIAFBGE0EQA8LIABBDGpBADYCACAAQRBqQQA2AgAgAEEUakEANgIAIABBGGpBADYCACAAIAFqIgJBHGtBADYCACACQRhrQQA2AgAgAkEUa0EANgIAIAJBEGtBADYCACAAQQRxQRhqIgIgAGohACABIAJrIQEDQCABQSBPBEAgAEIANwMAIABBCGpCADcDACAAQRBqQgA3AwAgAEEYakIANwMAIAFBIGshASAAQSBqIQAMAQsLC1EBA38gAEH+////AEsEQEEAQSBBLUEnEAAACyAAQQJ0IgMQAiECQQgQASIBQQA2AgAgAUEANgIEIAEgAjYCACABIAA2AgQgAkEIaiADEAMgAQtmAQF/IAFB/P///wFLBEBBAEHAAEEXQSIQAAALIAFBAXQiARACIgJBCGogARADIABFBEBBDBABIQALIABBADYCACAAQQA2AgQgAEEANgIIIAAgAjYCACAAQQA2AgQgACABNgIIIAALCgBBDBABIAAQBQsuAQF/QQgQASIBQQA2AgAgAUEANgIEIAEgADYCBCABQQEgASgCBHQQBjYCACABC6EBAQR/QRAQASIBQQA2AgAgAUEANgIEIAFBADYCCCABQQA2AgxBEBAEIQIDQCAAQRBIBEBBAxAHIQMgAigCACAAQQJ0aiADNgIIIABBAWohAAwBCwsgASACNgIEQRAQBCECQQAhAANAIABBEEgEQEEDEAchAyACKAIAIABBAnRqIAM2AgggAEEBaiEADAELCyABIAI2AgggAUEIEAc2AgwgAQs0AQF/QRQQASIAQQA2AgAgAEEAOgAEIABBADYCCCAAQQA2AgwgAEEANgIQIABBDTYCCCAAC0IBAX9BGRABIgBBADYCACAAQQA2AgQgAEEANgIIIABBADYCDCAAQQA2AhAgAEEANgIUIABBADoAGCAAQQA2AhAgAAu1AgEEf0HQABABIgBBADoAACAAQQA2AgQgAEEANgIIIABBADYCDCAAQQA2AhAgAEEAOgAUIABBADYCGCAAQQA2AhwgAEEANgIgIABBADYCJCAAQQA2AiggAEEANgIsIABBADYCMCAAQQA2AjQgAEEANgI4IABBADYCPCAAQQA2AkAgAEEANgJEIABBADYCSCAAQQA2AkxBBBAEIQIDQCABQQRIBEBBBhAHIQMgAigCACABQQJ0aiADNgIIIAFBAWohAQwBCwsgACACNgIkIABBBBAHNgIoIABB8wAQBjYCLCAAQcABEAY2AjAgAEEMEAY2AjQgAEEMEAY2AjggAEEMEAY2AjwgAEEMEAY2AkAgAEHAARAGNgJEIAAQCDYCSCAAEAg2AkwgABAJNgIEIAAQCjYCCCAACx8BAX9BCBABIgBBADYCACAAQQA2AgQgABALNgIAIAALCgAjACQBEAwkAwthAQF/IAFB+P///wNLBEBBAEHAAEEXQSIQAAALIAEQAiICQQhqIAEQAyAARQRAQQwQASEACyAAQQA2AgAgAEEANgIEIABBADYCCCAAIAI2AgAgAEEANgIEIAAgATYCCCAACwoAQQwQASAAEA4LBgAgABAPCyoAIAEgACgCCE8EQEEAQcAAQSdBPxAAAAsgACgCBCABIAAoAgBqai0ACAssACABIAAoAghPBEBBAEHAAEEyQT8QAAALIAAoAgQgASAAKAIAamogAjoACAtkAQJ/QQ0QDyECA0AgAUENSARAIAIgASAAIAEQEUH/AXEQEiABQQFqIQEMAQsLQQAhAEEAIQEDQCABQQhIBEAgAiABQQVqEBFB/wFxIAFBA3R0IAByIQAgAUEBaiEBDAELCyAACwYAIAAQEwsnACAAIAEQDzYCCCAAQQA2AgwgACABNgIUIABBADoAGCAAQQA2AgALJAAgACgCCCAAKAIYEBUgAEGABiAAKAIMIAAtABRqdBAGNgIgC5UBAQR/IAEhBSAAIgYoAgAhASAAKAIEIQcgACgCCEEBdiEEIAJBAEgEfyACIARqIgBBACAAQQBKGwUgAiIAIAQgACAESBsLIQIgA0EASAR/IAMgBGoiAEEAIABBAEobBSADIgAgBCAAIARIGwshAwNAIAIgA05FBEAgAkEBdCABaiAHaiAFOwEIIAJBAWohAgwBCwsgBgssAQF/AkACQAJAIwRBAWsOAwEBAgALAAtB/////wchAQsgAEGACEEAIAEQFwvBAQECfyAAQQIQBjYCACAAKAIAIgEoAgAgASgCBGpBgAg7AQggACgCACICKAIAIQEgAigCBCABQQJqakGACDsBCCAAKAIMKAIAQQEkBBAYGkEAIQIDQCACQRBIBEAgAiAAKAIEKAIAIgEoAgBBAnZJBH8gAkECdCABaigCCAUACygCAEEBJAQQGBogAiAAKAIIKAIAIgEoAgBBAnZJBH8gAkECdCABaigCCAUACygCAEEBJAQQGBogAkEBaiECDAELCwuHAgEFfyAAIQJBgAYgACgCDCAALQAUanQhAQNAIAMgAUgEQCACKAIgIgQoAgAhBSAEKAIEIANBAXQgBWpqQYAIOwEIIANBAWohAwwBCwsgAiEBQQAhAgNAIAJBBEkEQCACIAEoAiQoAgAiAygCAEECdkkEfyACQQJ0IANqKAIIBQALKAIAQQEkBBAYGiACQQFqIQIMAQsLIAEoAigoAgBBASQEEBgaIAEoAixBASQEEBgaIAAoAjBBASQEEBgaIAAoAjRBASQEEBgaIAAoAjhBASQEEBgaIAAoAjxBASQEEBgaIAAoAkBBASQEEBgaIAAoAkRBASQEEBgaIAAoAkgQGSAAKAJMEBkLyAwBA38DQCABQQNxIAIgAhsEQCAAIgRBAWohACABIgNBAWohASAEIAMtAAA6AAAgAkEBayECDAELCyAAQQNxRQRAA0AgAkEQTwRAIAAgASgCADYCACAAQQRqIAFBBGooAgA2AgAgAEEIaiABQQhqKAIANgIAIABBDGogAUEMaigCADYCACABQRBqIQEgAEEQaiEAIAJBEGshAgwBCwsgAkEIcQRAIAAgASgCADYCACAAQQRqIAFBBGooAgA2AgAgAUEIaiEBIABBCGohAAsgAkEEcQRAIAAgASgCADYCACABQQRqIQEgAEEEaiEACyACQQJxBEAgACABLwEAOwEAIAFBAmohASAAQQJqIQALIAJBAXEEQCAAIAEtAAA6AAALDwsgAkEgTwRAAkACQAJAIABBA3EiA0EBRwRAIANBAkYNASADQQNGDQIMAwsgASgCACEFIAAgASIDLQAAOgAAIABBAWoiASABIANBAWoiAS0AADoAAEEBaiIEQQFqIQAgAUEBaiIDQQFqIQEgBCADLQAAOgAAIAJBA2shAgNAIAJBEU8EQCAAIAFBAWooAgAiA0EIdCAFQRh2cjYCACAAQQRqIAFBBWooAgAiBUEIdCADQRh2cjYCACAAQQhqIAFBCWooAgAiA0EIdCAFQRh2cjYCACAAQQxqIAFBDWooAgAiBUEIdCADQRh2cjYCACABQRBqIQEgAEEQaiEAIAJBEGshAgwBCwsMAgsgASgCACEFIAAgAS0AADoAACAAQQFqIgRBAWohACABQQFqIgNBAWohASAEIAMtAAA6AAAgAkECayECA0AgAkESTwRAIAAgAUECaigCACIDQRB0IAVBEHZyNgIAIABBBGogAUEGaigCACIFQRB0IANBEHZyNgIAIABBCGogAUEKaigCACIDQRB0IAVBEHZyNgIAIABBDGogAUEOaigCACIFQRB0IANBEHZyNgIAIAFBEGohASAAQRBqIQAgAkEQayECDAELCwwBCyABKAIAIQUgACIEQQFqIQAgASIDQQFqIQEgBCADLQAAOgAAIAJBAWshAgNAIAJBE08EQCAAIAFBA2ooAgAiA0EYdCAFQQh2cjYCACAAQQRqIAFBB2ooAgAiBUEYdCADQQh2cjYCACAAQQhqIAFBC2ooAgAiA0EY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";return n(t)}function kd(n,t,e){try{var r={data:t,offset:0,readByte:function(){return this.data[this.offset++]}},i=r.data.length,a={data:[],offset:0,writeByte:function(u){var c=Math.floor(this.offset/i);this.data[c]||(this.data[c]=new Uint8Array(i)),this.data[c][this.offset%i]=u,this.offset++}};n.decompressFile(r,a);for(var o=new Uint8Array(a.offset),s=0;s<a.offset;s++)o[s]=a.data[Math.floor(s/i)][s%i];e(null,o)}catch(u){e(u)}}function Ld(n,t,e){var r=24;try{var i=new WebAssembly.Memory({initial:16}),a=new WebAssembly.Module(n),o=new WebAssembly.Instance(a,{env:{memory:i,abort:function(){e(new Error("webAssembly abort"))}}}),s=o.exports,u=s.newU8Array(t.length),c=new Uint8Array(i.buffer,u+r,t.length);c.set(t);var l=s.decode(u),h=new Uint32Array(i.buffer,l,4),p=h[0],v=h[2],m=h[3];p?e(null,new Uint8Array(i.buffer,m+r,v).slice(0,v)):e(new Error("lzma deocder error"))}catch(A){e(A)}}var Dd=`
|
|
884
884
|
var decodeLZMA = (function() {
|
|
885
885
|
var LZMA = (`.concat(Bu.toString(),`)();
|
|
886
886
|
return function(data, callback) {
|
|
@@ -1836,7 +1836,7 @@ void main() {
|
|
|
1836
1836
|
`,e},t.prototype.updateShaderSource=function(){var e=this.getDefines()+ep,r=this.getDefines()+tp;this.setValues({vertexShader:e,fragmentShader:r}),this.needsUpdate=!0},Pt([Yt("screenWidth"),Bt("design:type",Number)],t.prototype,"screenWidth",void 0),Pt([Yt("screenHeight"),Bt("design:type",Number)],t.prototype,"screenHeight",void 0),Pt([Yt("edlStrength"),Bt("design:type",Number)],t.prototype,"edlStrength",void 0),Pt([Yt("uNear"),Bt("design:type",Number)],t.prototype,"uNear",void 0),Pt([Yt("uFar"),Bt("design:type",Number)],t.prototype,"uFar",void 0),Pt([Yt("radius"),Bt("design:type",Number)],t.prototype,"radius",void 0),Pt([Yt("neighbours",!0),Bt("design:type",Float32Array)],t.prototype,"neighbours",void 0),Pt([Yt("depthMap"),Bt("design:type",d.Texture)],t.prototype,"depthMap",void 0),Pt([Yt("uEDLColor"),Bt("design:type",d.Texture)],t.prototype,"uEDLColor",void 0),Pt([Yt("uEDLDepth"),Bt("design:type",d.Texture)],t.prototype,"uEDLDepth",void 0),Pt([Yt("uProj"),Bt("design:type",Array)],t.prototype,"uProj",void 0),t}(d.RawShaderMaterial);function Qt(n,t){return{type:n,value:t}}function Yt(n,t){return t===void 0&&(t=!1),function(e,r){Object.defineProperty(e,r,{get:function(){return this.getUniform(n)},set:function(i){i!==this.getUniform(n)&&(this.setUniform(n,i),t&&this.updateShaderSource())}})}}var np=new d.OrthographicCamera(-1,1,1,-1,0,1),oo=new d.BufferGeometry;oo.setAttribute("position",new d.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3));oo.setAttribute("uv",new d.Float32BufferAttribute([0,2,0,0,2,0],2));var n0=new d.Mesh(oo),i0=new d.Scene;i0.add(n0);var ip=function(n){de(t,n);function t(e,r,i,a){var o=n.call(this,e,r,i,a)||this;return o.sharedV2=new d.Vector2,o.renderer=e,o.material=new rp,n0.material=o.material,o}return t.prototype.render=function(e){var r=this.camera,i=this.material.uniforms,a=this.renderer.getSize(this.sharedV2);i.screenWidth.value=a.x,i.screenHeight.value=a.y;var o=r.projectionMatrix,s=new Float32Array(16);s.set(o.elements);for(var u=new Float32Array(this.material.neighbourCount*2),c=0;c<this.material.neighbourCount;c++)u[2*c+0]=Math.cos(2*c*Math.PI/this.material.neighbourCount),u[2*c+1]=Math.sin(2*c*Math.PI/this.material.neighbourCount);i.neighbours.value=u,i.uNear.value=r.near,i.uFar.value=r.far,i.uEDLColor.value=e[0].texture,i.uProj.value=s,i.edlStrength.value=.25,i.radius.value=1,i.opacity.value=1,this.renderer.setRenderTarget(null),this.renderer.render(i0,np)},t.prototype.dispose=function(){this.copyPass.dispose()},t}(Bi);const ap=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,a=0,o="";return t[a].split(o).map(function(s){return s.charCodeAt(a)>i?s:String.fromCharCode((s.charCodeAt(a)+r)%i)}).join(o)}(`}rpvv|{-zrqvz}-sy|nH}rpvv|{-zrqvz}-v{H{vs|z-nz}yr?Q-drvtuZn}H{vs|z-nz}yr?Q-Qr}uZn}Hn\bv{t-rp?-bH|vq-znv{56-
|
|
1837
1837
|
sy|n-qr}u-J-r\x07r?Q5Qr}uZn}9-b6;Hvs5qr}u-KJ->;=6
|
|
1838
1838
|
qvpnqH\frpA-p|y|-J-r\x07r?Q5drvtuZn}9-b6H-p|y|-J-p|y|-<-p|y|;HtylSntP|y|-J-rpA5p|y|;\x07\b 9->;=6H-\f`),op=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,a=0,o="";return t[a].split(o).map(function(s){return s.charCodeAt(a)>i?s:String.fromCharCode((s.charCodeAt(a)+r)%i)}).join(o)}(`}rpvv|{-zrqvz}-sy|nH}rpvv|{-zrqvz}-v{Hnvor-rp@-}|vv|{Hnvor-rp?-H{vs|z-znA-}|wrpv|{Znv\x07H{vs|z-znA-z|qrycvrZnv\x07Hn\bv{t-rp?-bH|vq-znv{56-
|
|
1839
|
-
b-J-Htyl]|vv|{-J-}|wrpv|{Znv\x07-7-z|qrycvrZnv\x07-7-rpA5}|vv|{9>;=6H\f`);var sp=function(n){de(t,n);function t(e){var r=n.call(this,{vertexShader:op,fragmentShader:ap})||this;return r.uniforms={uDepthMap:Bs("t",null),uWeightMap:Bs("t",null)},r.depthTest=!0,r.depthWrite=!0,r.opacity=1,r}return t.prototype.getUniform=function(e){return this.uniforms===void 0?void 0:this.uniforms[e].value},t.prototype.setUniform=function(e,r){if(this.uniforms!==void 0){var i=this.uniforms[e];i.value=r}},Pt([Rs("uDepthMap"),Bt("design:type",Number)],t.prototype,"uDepthMap",void 0),Pt([Rs("uWeightMap"),Bt("design:type",Number)],t.prototype,"uWeightMap",void 0),t}(d.RawShaderMaterial);function Bs(n,t){return{type:n,value:t}}function Rs(n,t){return t===void 0&&(t=!1),function(e,r){Object.defineProperty(e,r,{get:function(){return this.getUniform(n)},set:function(i){i!==this.getUniform(n)&&(this.setUniform(n,i),t&&this.updateShaderSource())}})}}var up=new d.OrthographicCamera(-1,1,1,-1,0,1),so=new d.BufferGeometry;so.setAttribute("position",new d.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3));so.setAttribute("uv",new d.Float32BufferAttribute([0,2,0,0,2,0],2));var a0=new d.Mesh(so),o0=new d.Scene;o0.add(a0);var lp=function(n){de(t,n);function t(e,r,i,a){var o=n.call(this,e,r,i,a)||this;return o.sharedV2=new d.Vector2,o.renderer=e,o.material=new sp,o.scene=r,o.camera=i,a0.material=o.material,o}return t.prototype.render=function(e){var r=this.material.uniforms;this.models.setMaterial({useHQWeight:!0,useHQDepth:!1}),this.renderer.setRenderTarget(e[1]),this.models.update(this.renderer,this.camera,"Mapview"),this.renderer.autoClearDepth=!1,this.renderer.setClearAlpha(0),this.renderer.render(this.scene,this.camera),r.uWeightMap.value=e[1].texture,r.uDepthMap.value=e[0].depthTexture,this.renderer.setRenderTarget(null),this.renderer.autoClearDepth=!0,this.renderer.setClearAlpha(1),this.renderer.render(o0,up),this.models.setMaterial({useHQWeight:!1,useHQDepth:!0}),this.models.update(this.renderer,this.camera,"Mapview")},t.prototype.dispose=function(){this.copyPass.dispose()},t}(Bi),ua=.5,la=0,cp=function(n){de(t,n);function t(e){var r=this,i,a=t.parseArgs(e);return r=n.call(this,a)||this,r.mode="Mapview",r.defaultLongitude=a.defaultLongitude,r.defaultLatitude=a.defaultLatitude,r.defaultDistance=a.defaultDistance,r.maxLatitude=a.maxLatitude,r.minLatitude=a.minLatitude,r.locationMotion=new we({x:r.camera.pose.offset.x,y:r.camera.pose.offset.y,z:r.camera.pose.offset.z,distance:r.camera.pose.distance}),r.modelAlphaMotion=new we({modelAlpha:(i=r.models.getMaterial().modelAlpha)!==null&&i!==void 0?i:0}),r.perspToOrthoMotion=new we({perspToOrtho:r.camera.perspToOrtho.x}),r.intersectMeshCreator=a.intersectMeshCreator,r.intersectMesh=r.intersectMeshCreator(),r.intersectMesh.name="intersect",r.intersectMesh.visible=!1,r.currentTapId=null,r.helper.add(r.intersectMesh),r.edlTarget=new d.WebGLRenderTarget(1024,1024,{minFilter:d.NearestFilter,magFilter:d.NearestFilter,format:d.RGBAFormat,type:d.FloatType,depthTexture:new d.DepthTexture(1024,1024,d.UnsignedIntType)}),r.edlEffect=new ip(r.renderer,r.scene,r.camera,r.models),r.hqEffect=new lp(r.renderer,r.scene,r.camera,r.models),r}return t.parseArgs=function(e){var r,i,a,o,s,u;if(e instanceof t)return e;var c=n.parseArgs.call(this,e);return R(R({},c),{defaultLongitude:(r=e.defaultLongitude)!==null&&r!==void 0?r:Math.PI/4,defaultLatitude:(i=e.defaultLatitude)!==null&&i!==void 0?i:Math.PI/4,defaultDistance:(a=e.defaultDistance)!==null&&a!==void 0?a:150,maxLatitude:(o=e.maxLatitude)!==null&&o!==void 0?o:+Math.PI/2,minLatitude:(s=e.minLatitude)!==null&&s!==void 0?s:0,intersectMeshCreator:(u=e.intersectMeshCreator)!==null&&u!==void 0?u:function(){return new Si}})},t.distanceFromModel=function(e,r,i){var a=e.bounding,o=Math.pow(Math.pow(a.max.x-a.min.x+1,2)+Math.pow(a.max.y-a.min.y+1,2)+Math.pow(a.max.z-a.min.z+1,2),1/2),s=o/2/Math.tan(Math.PI*r/360);return i<1&&(s=s/i),isNaN(s)?o:s},t.initAnimationEndState=function(e){var r,i,a,o,s,u,c,l=this.parseArgs(e),h=l.works,p=l.models,v=e.initial,m=v.state,A=v.currentState,y=typeof m.panoIndex=="number"?{workCode:(a=(r=m.workCode)!==null&&r!==void 0?r:(i=l.works[0])===null||i===void 0?void 0:i.workCode)!==null&&a!==void 0?a:"",panoIndex:m.panoIndex}:{workCode:A.workCode,panoIndex:A.panoIndex},f=h.getResolvedObserver(y),g=(o=m.fov)!==null&&o!==void 0?o:60,b=le((s=m.latitude)!==null&&s!==void 0?s:Pa(A.mode)?A.latitude:l.defaultLatitude,l.minLatitude,l.maxLatitude),w=t.distanceFromModel(l.models,g,l.camera.aspect),E=new d.Vector3,x=(u=m.distance)!==null&&u!==void 0?u:Math.min(l.defaultDistance,w),M=(c=m.longitude)!==null&&c!==void 0?c:Pa(A.mode)?A.longitude:l.defaultLongitude;return m.offset?E.copy(m.offset):l.defaultDistance<w&&f?(E.copy(f.position),m.longitude===void 0&&(M=A.longitude)):E.copy(p.bounding.getCenter(E)),p.bounding.containsPoint(E)||p.bounding.getCenter(E),R(R({},y),{mode:"Mapview",longitude:M,latitude:b,fov:g,offset:E,distance:x})},t.prototype.destroy=function(){n.prototype.destroy.call(this),this.locationMotion.dispose(),delete this.panState,this.intersectMesh.dispose(),this.helper.remove(this.intersectMesh)},t.prototype.isReady=function(){return this.locationMotion.ended===!1?!1:n.prototype.isReady.call(this)},t.prototype.updateWork=function(e,r,i,a){this.userAction=a,this.works=e;var o=t.initAnimationEndState(R(R({},this),{initial:{currentState:R(R({},this.currentPano),this.camera.pose),duration:i,state:r,userAction:a}}));this.currentPano={workCode:o.workCode,panoIndex:o.panoIndex};var s={longitude:o.longitude,latitude:o.latitude,fov:o.fov},u={x:o.offset.x,y:o.offset.y,z:o.offset.z,distance:o.distance,orthoDistance:o.distance};return this.locationMotion.set(u,i).catch(Q),this.cameraMotion.set(s,i).catch(Q),!0},t.prototype.updateModel=function(e){n.prototype.updateModel.call(this,e)},t.prototype.updateCamera=function(e,r,i){var a=this;return this.initAnimationReady.then(function(){a.userAction=i,a.stopMomentumMovement();var o={},s={};return e.distance!==void 0&&(o.distance=e.distance),e.offset!==void 0&&(o.x=e.offset.x,o.y=e.offset.y,o.z=e.offset.z),e.longitude!==void 0&&(s.longitude=e.longitude),e.latitude!==void 0&&(s.latitude=e.latitude),e.fov!==void 0&&(s.fov=e.fov),a.locationMotion.set(o,r).catch(Q),a.cameraMotion.set(s,r).catch(Q)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var a=this;return this.initAnimationReady.then(function(){a.userAction=i,a.stopMomentumMovement();for(var o=[],s=[],u=0,c=e;u<c.length;u++){var l=c[u];o.push({key:l.key,progress:l.progress,value:{distance:l.value.distance,x:l.value.offset.x,y:l.value.offset.x,z:l.value.offset.x}}),s.push({key:l.key,progress:l.progress,value:{longitude:l.value.longitude,latitude:l.value.latitude,fov:l.value.fov}})}return a.locationMotion.setKeyframes(o,r).catch(Q),a.cameraMotion.setKeyframes(e,r)})},t.prototype.updateTime=function(e,r){if(!this.destroyed){var i={},a={};if(this.locationMotion.ended||(this.locationMotion.update(e),a.distance=this.locationMotion.value.distance,a.offset=new d.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z)),!this.cameraMotion.ended){this.cameraMotion.update(e),a.longitude=this.cameraMotion.value.longitude,a.latitude=this.cameraMotion.value.latitude,a.fov=this.cameraMotion.value.fov;var o=Math.PI/2-a.latitude<.02?1:0;this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho!==o&&this.perspToOrthoMotion.set({perspToOrtho:o},500).catch(Q)}this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),i.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(le(this.perspToOrthoMotion.value.perspToOrtho,0,1))),St(i)||this.models.setMaterial(i),St(a)||this.setCamera(a)}},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(ve())[1],r=this.locationMotion.getKeyFrameSegment(ve())[1];return R(R({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,distance:r.value.distance,offset:new d.Vector3(r.value.x,r.value.y,r.value.z)})},t.prototype.initAnimation=function(){var e=this;return this.destroyed?Promise.resolve():new Promise(function(r){var i=e.initial;i.state,i.currentState;var a=i.duration,o=i.userAction;e.userAction=o;var s=t.initAnimationEndState(e),u={longitude:s.longitude,latitude:s.latitude,fov:s.fov},c={x:s.offset.x,y:s.offset.y,z:s.offset.z,distance:s.distance},l={modelAlpha:1},h={perspToOrtho:0};e.emit("initAnimation.start",_("initAnimation.start",{state:s,userAction:e.userAction})),e.perspToOrthoMotion.set(h,a).catch(Q),e.modelAlphaMotion.set(l,a/3).catch(Q),e.cameraMotion.set(u,a).catch(Q),e.locationMotion.set(c,a).then(function(){e.emit("initAnimation.end",_("initAnimation.end",{state:s,userAction:e.userAction}))},function(p){var v=R(R(R({},e.currentPano),{mode:e.mode}),Ve(e.camera.pose));e.emit("initAnimation.end",_("initAnimation.end",{state:v,userAction:e.userAction}))}).then(function(){r()})})},t.prototype.getForwardObserverOrNot=function(e){var r=this.models.intersectRaycaster(e)[0];if(!r)return null;var i=this.works.resolvedObservers,a=Ot(i,function(u){return u.standingPosition.distanceTo(r.point)},!0),o=a[0],s=a[1];return o&&s<10?o:null},t.prototype.coordinatesForOffset=function(e){var r=this.renderer.getSize(new d.Vector2);return{longitude:-2*e.x/(r.x*this.scissor.width),latitude:2*e.y/(r.y*this.scissor.height)}},t.prototype.requestMomentumMovement=function(e,r,i,a){var o=this;if(this.inMomentumMovement!==null){for(var s=R({},i),u={longitude:0,latitude:0,x:0,y:0,z:0},c=0;c<a;c++)s.longitude*=.996,s.latitude*=.996*.998,s.x*=.99,s.y*=.99,s.z*=.99,u.longitude+=s.longitude,u.latitude+=s.latitude,u.x+=s.x,u.y+=s.y,u.z+=s.z;var l=Nr(this.cameraMotion.value.longitude+u.longitude),h=le(this.cameraMotion.value.latitude+u.latitude,this.minLatitude,this.maxLatitude),p=le(this.locationMotion.value.x+u.x,this.models.bounding.min.x,this.models.bounding.max.x),v=le(this.locationMotion.value.y+u.y,this.models.bounding.min.y,this.models.bounding.max.y),m=le(this.locationMotion.value.z+u.z,this.models.bounding.min.z,this.models.bounding.max.z),A=R(R({},this.currentPano),{mode:this.mode,longitude:l,latitude:h,offset:new d.Vector3(p,v,m),fov:this.cameraMotion.value.fov,distance:this.camera.pose.distance}),y=!(Math.abs(s.longitude)>1e-4||Math.abs(s.latitude)>1e-4||Math.abs(s.x)>1e-4||Math.abs(s.y)>1e-4||Math.abs(s.z)>1e-4),f=_("gesture.momentum",R(R({},e),{isFirst:r,isFinal:y,state:A}));if(this.inMomentumMovement.event=f,this.emit("gesture.momentum",f),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:l,latitude:h},0).catch(Q),this.locationMotion.set({x:A.offset.x,y:A.offset.y,z:A.offset.z},0).catch(Q),y?this.inMomentumMovement=null:it.shared.add(function(g,b){o.requestMomentumMovement(e,!1,s,b|0)},!0,1))}},t.prototype.fixFinalState=function(e){if(this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho!==1){var r=Rr(e,new d.Vector3),i=new d.Vector3().copy(e.offset).sub(r.clone().multiplyScalar(e.distance)),a=new d.Raycaster(i,r);a.params.Points={threshold:.1},a.near=ua;var o=this.models.intersectRaycaster(a)[0];if(!o&&a.ray.direction.y<-.3){var s=new d.Plane(new d.Vector3(0,1,0),0),u=a.ray.intersectPlane(s,new d.Vector3);if(u){var c=u.distanceTo(a.ray.origin);c<1e4&&c>=a.near&&(o={distance:c,floor:0,point:u,object:this.scene,face:null})}}o&&(e.distance=le(o.distance,la,1/0),e.offset.copy(i).add(r.clone().multiplyScalar(e.distance)))}},t.prototype.onPanGesture=function(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();var r=e.pointers.length,i=this.panState,a=0;e.pointerType==="mouse"&&(a=e.srcEvent.buttons),i&&a===0&&i.buttons!==0&&(a=i.buttons);var o=i==null?void 0:i.target;if(!o){var s=this.relativeClientPosition(e.center),u=new d.Raycaster;u.params.Points={threshold:.1},u.setFromCamera(s,this.camera),u.near=ua,o=new d.Vector3().copy(u.ray.direction).multiplyScalar(3).add(u.ray.origin);var c=this.models.intersectRaycaster(u)[0];if(!c&&u.ray.direction.y<-.3){var l=new d.Plane(new d.Vector3(0,1,0),0),h=u.ray.intersectPlane(l,new d.Vector3);if(h){var p=h.distanceTo(u.ray.origin);p<1e4&&p>=u.near&&(c={distance:p,floor:0,point:h,object:this.scene})}}if(c)o.copy(c.point);else{var v=new d.Vector3().copy(this.camera.pose.offset).sub(this.camera.position),l=new d.Plane().setFromNormalAndCoplanarPoint(v,this.camera.pose.offset);u.ray.intersectPlane(l,o)}}if(e.isFinal?delete this.panState:this.panState={target:o,buttons:a,pointerLength:r,x:e.center.x,y:e.center.y},!(typeof i>"u"||i.pointerLength!==r)){var m=r>1||a===2;if(m){var A={x:e.center.x-i.x,y:e.center.y-i.y},y=new d.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),f=Rr(this.cameraMotion.value).setLength(this.locationMotion.value.distance).add(y),g=new d.Vector3().copy(f).sub(i.target).length();g*=Math.tan(this.camera.pose.fov/2*Math.PI/180);var b=this.renderer.getSize(new d.Vector2),w=2*A.x*g/b.y,E=2*A.y*g/b.y,x=new d.Vector3;x.setFromMatrixColumn(this.camera.matrix,0),x.multiplyScalar(-w),y.add(x),this.camera.pose.latitude<Math.PI/12?x.setFromMatrixColumn(this.camera.matrix,1):(x.setFromMatrixColumn(this.camera.matrix,0),x.crossVectors(this.camera.up,x)),x.multiplyScalar(E),y.add(x),y.clamp(this.models.bounding.min,this.models.bounding.max);var M=R(R({},this.currentPano),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:y,distance:this.camera.pose.distance});if(e.state=M,this.emit("gesture.pan",e),e.defaultPrevented)return;if(this.locationMotion.set({x:M.offset.x,y:M.offset.y,z:M.offset.z},0).catch(Q),e.isFinal&&(this.fixFinalState(M),this.locationMotion.set({distance:M.distance,x:M.offset.x,y:M.offset.y,z:M.offset.z},0).catch(Q)),e.isFinal){var C=this.renderer.getSize(new d.Vector2),I=2*e.velocityX*g/C.y,P=2*e.velocityY*g/C.y,S=new d.Vector3,F=new d.Vector3;S.setFromMatrixColumn(this.camera.matrix,0),S.multiplyScalar(-I),F.add(S),this.camera.pose.latitude<Math.PI/4?S.setFromMatrixColumn(this.camera.matrix,1):(S.setFromMatrixColumn(this.camera.matrix,0),S.crossVectors(this.camera.up,S)),S.multiplyScalar(P),F.add(S),this.inMomentumMovement={uuid:vt()},this.requestMomentumMovement(e,!0,{longitude:0,latitude:0,x:F.x,y:F.y,z:F.z},0)}}else{var A={x:e.center.x-i.x,y:e.center.y-i.y},k=this.coordinatesForOffset(A),O=Nr(this.cameraMotion.value.longitude+k.longitude),L=le(this.cameraMotion.value.latitude+k.latitude,this.minLatitude,this.maxLatitude);this.camera.aspect<1&&Math.abs(e.overallVelocityX)>.2&&Math.atan2(Math.abs(e.overallVelocityY),Math.abs(e.overallVelocityX))<Math.PI/6.923&&(L=this.cameraMotion.value.latitude);var M=R(R({},this.currentPano),{mode:this.mode,longitude:O,latitude:L,fov:this.camera.pose.fov,offset:this.camera.pose.offset,distance:this.camera.pose.distance});if(e.isFinal&&this.fixFinalState(M),e.state=M,this.emit("gesture.pan",e),e.defaultPrevented)return;if(e.isFinal?this.locationMotion.set({distance:M.distance,x:M.offset.x,y:M.offset.y,z:M.offset.z},0).catch(Q):this.cameraMotion.set({longitude:M.longitude,latitude:M.latitude},0).catch(Q),e.isFinal){var N=e.velocityX,V=e.velocityY;this.inMomentumMovement={uuid:vt()},this.requestMomentumMovement(e,!0,R(R({},this.coordinatesForOffset({x:N,y:V})),{x:0,y:0,z:0}),0)}}}},t.prototype.onPinchGesture=function(e){var r;this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();var i=(r=this.pinchState)===null||r===void 0?void 0:r.distance;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,scale:1,distance:this.locationMotion.value.distance};return}if(e.isFinal){delete this.panState,delete this.pinchState;return}if(!(typeof i>"u")){this.models.bounding.getCenter(new d.Vector3);var a=t.distanceFromModel(this.models,this.cameraMotion.value.fov,this.camera.aspect)*1.3,o=le(i/e.scale,la,1/0),s=e.state.offset.clone().sub(Rr(e.state).setLength(o)),u=this.models.bounding.containsPoint(s),c;!u&&this.pinchState&&this.pinchState.scale>e.scale&&o>a?c=e.state.distance:(c=o,this.pinchState&&(this.pinchState.scale=e.scale)),e.state.distance=c,this.emit("gesture.pinch",e),!e.defaultPrevented&&(this.locationMotion.set({distance:e.state.distance},0).catch(Q),e.pointerType!=="mouse"&&(e.type="gesture.pan",this.onPanGesture(e)))}},t.prototype.onMouseMove=function(e){var r,i;if(this.intersectMesh.parent&&!this.panState&&!this.pinchState&&!this.mouseWheelState&&(this.emit("gesture.mousemove",e),!e.defaultPrevented)){var a=e.center.raycaster;if(a.near=ua,a.far=500,e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}var o=this.models.intersectRaycaster(a)[0],s=_("intersect.update",{raycaster:a,intersection:o??null,object:this.intersectMesh});if(this.emit("intersect.update",s),s.defaultPrevented){this.hideIntersectMesh();return}if(o){var u=(i=(r=o.face)===null||r===void 0?void 0:r.normal)!==null&&i!==void 0?i:new d.Vector3().copy(a.ray.direction).multiplyScalar(-1),c=u.clone().multiplyScalar(.05),l=o.point.clone().add(c);this.intersectMesh.position.copy(l);var h=l.clone().add(c);if(this.intersectMesh.lookAt(h),Math.abs(u.y)>.99){var p=this.camera.position.clone().sub(l);this.intersectMesh.rotation.z=-Math.atan2(p.z,p.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}},t.prototype.onMouseWheel=function(e){if(this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh(),e.isFinal){var r=e.state;if(this.fixFinalState(r),this.emit("gesture.mousewheel",e),e.defaultPrevented)return;var i={x:r.offset.x,y:r.offset.y,z:r.offset.z,distance:r.distance};this.locationMotion.set(i,0).catch(Q)}else{var a=e.center.delta/2*Math.max(Math.log(this.locationMotion.value.distance),1),o=t.distanceFromModel(this.models,this.cameraMotion.value.fov,this.camera.aspect)*1.3,s=le(this.locationMotion.value.distance-a,la,1/0),u=e.state.offset.clone().sub(Rr(e.state).setLength(s)),c=this.models.bounding.containsPoint(u),l=!c&&a<0&&s>o?e.state.distance:s;if(e.state.distance=s,this.emit("gesture.mousewheel",e),e.defaultPrevented)return;this.locationMotion.set({distance:l},0).catch(Q)}},t.prototype.onTapGesture=function(e){var r=this;this.userAction=e.userAction,this.stopMomentumMovement();var i=e.center.raycaster,a=this.getForwardObserverOrNot(i);if(!a)this.emit("gesture.tap",e);else{var o={longitude:this.camera.pose.longitude,latitude:0},s=R(R({},e.state),{mode:"Panorama",workCode:a.pano.workCode,panoIndex:a.pano.panoIndex,longitude:o.longitude,latitude:o.latitude,offset:a?a.position.clone():new d.Vector3,distance:0});if(e.state=s,this.emit("gesture.tap",e),!e.defaultPrevented&&(this.emit("pano.select",_("pano.select",{prevPano:this.currentPano,state:s,userAction:e.userAction,options:o,progress:0,error:null})),a&&a.active)){var u=this.currentTapId=vt();this.preloadPano(a.pano).then(function(c){r.currentTapId===u&&r.emit("pano.request",_("pano.request",{userAction:!0,prevPano:r.currentPano,progress:0,state:s,options:o,error:null}))})}}},t.prototype.hideIntersectMesh=function(){this.intersectMesh.visible=!1,this.needsRender=!0},t.prototype.postProcessing=function(e,r){var i;if(!this.destroyed){if(r==="edl")return this.edlEffect.render(e);if(r==="hq")return(i=this.hqEffect)===null||i===void 0?void 0:i.render(e)}},t}(eo);function Fs(n){return n==null}var dp={type:"move"},Os=function(){function n(){this._targetRay=null,this._grip=null,this._hand=null,this._axes=[0,0]}return n.prototype.getHandSpace=function(){return this._hand===null&&(this._hand=new d.Group,this._hand.matrixAutoUpdate=!1,this._hand.visible=!1,this._hand.joints={},this._hand.inputState={pinching:!1}),this._hand},n.prototype.getTargetRaySpace=function(){return this._targetRay===null&&(this._targetRay=new d.Group,this._targetRay.matrixAutoUpdate=!1,this._targetRay.visible=!1,this._targetRay.hasLinearVelocity=!1,this._targetRay.linearVelocity=new d.Vector3,this._targetRay.hasAngularVelocity=!1,this._targetRay.angularVelocity=new d.Vector3),this._targetRay},n.prototype.getGripSpace=function(){return this._grip===null&&(this._grip=new d.Group,this._grip.matrixAutoUpdate=!1,this._grip.visible=!1,this._grip.hasLinearVelocity=!1,this._grip.linearVelocity=new d.Vector3,this._grip.hasAngularVelocity=!1,this._grip.angularVelocity=new d.Vector3),this._grip},n.prototype.dispatchEvent=function(t){return this._targetRay!==null&&this._targetRay.dispatchEvent(t),this._grip!==null&&this._grip.dispatchEvent(t),this._hand!==null&&this._hand.dispatchEvent(t),this},n.prototype.disconnect=function(t){return this.dispatchEvent({type:"disconnected",data:t}),this._targetRay!==null&&(this._targetRay.visible=!1),this._grip!==null&&(this._grip.visible=!1),this._hand!==null&&(this._hand.visible=!1),this},n.prototype.getAxes=function(){return this._axes},n.prototype.update=function(t,e,r){var i=null,a=null,o=null,s=this._targetRay,u=this._grip,c=this._hand;if(t&&t.gamepad&&t.gamepad.axes&&(this._axes=[t.gamepad.axes[2],t.gamepad.axes[3]]),t&&e.session.visibilityState!=="visible-blurred")if(s!==null&&(i=e.getPose(t.targetRaySpace,r),i!==null&&(s.matrix.fromArray(i.transform.matrix),s.matrix.decompose(s.position,s.rotation,s.scale),i.linearVelocity?(s.hasLinearVelocity=!0,s.linearVelocity.copy(i.linearVelocity)):s.hasLinearVelocity=!1,i.angularVelocity?(s.hasAngularVelocity=!0,s.angularVelocity.copy(i.angularVelocity)):s.hasAngularVelocity=!1,this.dispatchEvent(dp))),c&&t.hand){o=!0;for(var l=0,h=t.hand.values();l<h.length;l++){var p=h[l],v=e.getJointPose(p,r);if(c.joints[p.jointName]===void 0){var m=new d.Group;m.matrixAutoUpdate=!1,m.visible=!1,c.joints[p.jointName]=m,c.add(m)}var A=c.joints[p.jointName];v!==null&&(A.matrix.fromArray(v.transform.matrix),A.matrix.decompose(A.position,A.rotation,A.scale),A.jointRadius=v.radius),A.visible=v!==null}var y=c.joints["index-finger-tip"],f=c.joints["thumb-tip"],g=y.position.distanceTo(f.position),b=.02,w=.005;c.inputState.pinching&&g>b+w?(c.inputState.pinching=!1,this.dispatchEvent({type:"pinchend",handedness:t.handedness,target:this})):!c.inputState.pinching&&g<=b-w&&(c.inputState.pinching=!0,this.dispatchEvent({type:"pinchstart",handedness:t.handedness,target:this}))}else u!==null&&t.gripSpace&&(a=e.getPose(t.gripSpace,r),a!==null&&(u.matrix.fromArray(a.transform.matrix),u.matrix.decompose(u.position,u.rotation,u.scale),a.linearVelocity?(u.hasLinearVelocity=!0,u.linearVelocity.copy(a.linearVelocity)):u.hasLinearVelocity=!1,a.angularVelocity?(u.hasAngularVelocity=!0,u.angularVelocity.copy(a.angularVelocity)):u.hasAngularVelocity=!1));return s!==null&&(s.visible=i!==null),u!==null&&(u.visible=a!==null),c!==null&&(c.visible=o!==null),this},n}(),fp=1,hp=function(){function n(t,e,r){var i,a,o,s,u;this.isPanorama=(i=r==null?void 0:r.isPanorama)!==null&&i!==void 0?i:!0,this.machineType=(a=r==null?void 0:r.machineType)!==null&&a!==void 0?a:"Pico",this.renderer=t,this.gl=e,this.enabled=!1,this.session=null,this.referenceSpaceType=(o=r==null?void 0:r.referenceSpaceType)!==null&&o!==void 0?o:"local-floor",this.referenceSpace=null,this.onSessionStartCallback=(s=r==null?void 0:r.onSessionStart)!==null&&s!==void 0?s:Q,this.onSessionEndCallback=(u=r==null?void 0:r.onSessionEnd)!==null&&u!==void 0?u:Q,this.controllers=[new Os,new Os],this.inputSourcesMap=new Map,this.cameraVR=new d.ArrayCamera,this.cameraL=new d.PerspectiveCamera,this.cameraR=new d.PerspectiveCamera,this.cameraL.viewport=new d.Vector4,this.cameraR.viewport=new d.Vector4,this.cameraL.layers.enable(1),this.cameraR.layers.enable(2),this.cameraVR.layers.enable(1),this.cameraVR.layers.enable(2),this.isPresenting=!1,this.currentDepthNear=null,this.currentDepthFar=null,this.cameraLPos=new d.Vector3,this.cameraRPos=new d.Vector3}return n.prototype.getController=function(t){var e=this.controllers[t];return e||console.warn("no controller find"),e.getTargetRaySpace()},n.prototype.getRightController=function(){if(!this.session)return null;var t=this.session.inputSources[0].handedness==="right"?0:1,e=this.controllers[t];return e||console.warn("no controller find"),e.getTargetRaySpace()},n.prototype.getLeftController=function(){if(!this.session)return null;var t=this.session.inputSources[0].handedness==="left"?0:1,e=this.controllers[t];return e||console.warn("no controller find"),e.getTargetRaySpace()},n.prototype.getControllerGrip=function(t){var e=this.controllers[t];return e||console.warn("no controller find"),e.getGripSpace()},n.prototype.getCameras=function(){return{cameraL:this.cameraL,cameraR:this.cameraR,cameraVR:this.cameraVR}},n.prototype.updateCamera=function(t,e){e===null?t.matrixWorld.copy(t.matrix):t.matrixWorld.multiplyMatrices(e.matrixWorld,t.matrix),t.matrixWorldInverse.getInverse(t.matrixWorld)},n.prototype.setProjectionFromUnion=function(t,e,r){this.cameraLPos.setFromMatrixPosition(e.matrixWorld),this.cameraRPos.setFromMatrixPosition(r.matrixWorld);var i=this.cameraLPos.distanceTo(this.cameraRPos),a=e.projectionMatrix.elements,o=r.projectionMatrix.elements,s=a[14]/(a[10]-1),u=a[14]/(a[10]+1),c=(a[9]+1)/a[5],l=(a[9]-1)/a[5],h=(a[8]-1)/a[0],p=(o[8]+1)/o[0],v=s*h,m=s*p,A=i/(-h+p),y=A*-h;e.matrixWorld.decompose(t.position,t.quaternion,t.scale),t.translateX(y),t.translateZ(A),t.matrixWorld.compose(t.position,t.quaternion,t.scale),t.matrixWorldInverse.getInverse(t.matrixWorld);var f=s+A,g=u+A,b=v-y,w=m+(i-y),E=c*u/g*f,x=l*u/g*f;t.projectionMatrix.makePerspective(b,w,E,x,f,g)},n.prototype.getCamera=function(t){this.cameraVR.near=this.cameraR.near=this.cameraL.near=t.near,this.cameraVR.far=this.cameraR.far=this.cameraL.far=t.far,this.session&&(this.currentDepthNear!==this.cameraVR.near||this.currentDepthFar!==this.cameraVR.far)&&(this.session.updateRenderState({depthNear:this.cameraVR.near,depthFar:this.cameraVR.far}),this.currentDepthNear=this.cameraVR.near,this.currentDepthFar=this.cameraVR.far);var e=t.parent,r=this.cameraVR.cameras;this.updateCamera(this.cameraVR,e);for(var i=0;i<r.length;i++)this.updateCamera(r[i],e);t.matrixWorld.copy(this.cameraVR.matrixWorld);for(var a=t.children,i=0,o=a.length;i<o;i++)a[i].updateMatrixWorld(!0);return r.length===2?this.setProjectionFromUnion(this.cameraVR,this.cameraL,this.cameraR):this.cameraVR.projectionMatrix.copy(this.cameraL.projectionMatrix),this.cameraVR},n.prototype.updateInputSources=function(t){if(!this.session){console.warn("session is lose!");return}for(var e=this.session.inputSources,r=0;r<this.controllers.length;r++)this.inputSourcesMap.set(e[r],this.controllers[r]);for(var r=0;r<t.removed.length;r++){var i=t.removed[r],a=this.inputSourcesMap.get(i);a&&(a.dispatchEvent({type:"disconnected",data:i}),this.inputSourcesMap.delete(i))}for(var r=0;r<t.added.length;r++){var i=t.added[r],a=this.inputSourcesMap.get(i);a&&a.dispatchEvent({type:"connected",data:i})}},n.prototype.onSessionEvent=function(t){var e=this.inputSourcesMap.get(t.inputSource);e&&e.dispatchEvent({type:t.type})},n.prototype.onSessionEnd=function(){this.inputSourcesMap.forEach(function(t,e){t.disconnect(e)}),this.inputSourcesMap.clear(),this.renderer.setFramebuffer(null),this.renderer.setRenderTarget(this.renderer.getRenderTarget()),this.isPresenting=!1,this.session=null,it.shared.setContext(null),this.onSessionEndCallback()},n.prototype.onRequestReferenceSpace=function(t){this.referenceSpace=t,this.isPresenting=!0,this.session&&this.onSessionStartCallback(this.session)},n.prototype.setSession=function(t){var e=this;if(this.session=t,this.session){this.session.addEventListener("select",function(i){e.onSessionEvent(i)}),this.session.addEventListener("selectstart",function(i){e.onSessionEvent(i)}),this.session.addEventListener("selectend",function(i){e.onSessionEvent(i)}),this.session.addEventListener("squeeze",function(i){e.onSessionEvent(i)}),this.session.addEventListener("squeezestart",function(i){e.onSessionEvent(i)}),this.session.addEventListener("squeezeend",function(i){e.onSessionEvent(i)}),this.session.addEventListener("end",function(i){e.onSessionEnd()});var r=this.gl.getContextAttributes();this.gl.makeXRCompatible().then(function(){var i={antialias:r==null?void 0:r.antialias,alpha:r==null?void 0:r.alpha,depth:r==null?void 0:r.depth,stencil:r==null?void 0:r.stencil,framebufferScaleFactor:fp};if(!e.session){console.error("session is lose while set session!");return}switch(e.machineType){case"Pico":e.session.updateRenderState({baseLayer:new XRWebGLLayer(e.session,e.gl,i)});break;case"Oculus":e.session.updateRenderState({layers:[new XRWebGLLayer(e.session,e.gl,i)]});break;default:e.machineType;break}e.session.requestReferenceSpace(e.referenceSpaceType).then(function(a){e.onRequestReferenceSpace(a)}),e.session.addEventListener("inputsourceschange",function(a){e.updateInputSources(a)})})}},n}(),uo=function(n){de(t,n);function t(){var e=n.call(this)||this;e.type="LineSegmentsGeometry";var r=[-1,2,0,1,2,0,-1,1,0,1,1,0,-1,0,0,1,0,0,-1,-1,0,1,-1,0],i=[-1,2,1,2,-1,1,1,1,-1,-1,1,-1,-1,-2,1,-2],a=[0,2,1,2,3,1,2,4,3,4,5,3,4,6,5,6,7,5];return e.setIndex(a),e.setAttribute("position",new d.Float32BufferAttribute(r,3)),e.setAttribute("uv",new d.Float32BufferAttribute(i,2)),e}return t.prototype.applyMatrix4=function(e){var r=this.attributes.instanceStart,i=this.attributes.instanceEnd;return r!==void 0&&(r.applyMatrix4(e),i.applyMatrix4(e),r.needsUpdate=!0),this.boundingBox!==null&&this.computeBoundingBox(),this.boundingSphere!==null&&this.computeBoundingSphere(),this},t.prototype.setPositions=function(e){var r;e instanceof Float32Array?r=e:Array.isArray(e)?r=new Float32Array(e):r=new Float32Array;var i=new d.InstancedInterleavedBuffer(r,6,1);return this.setAttribute("instanceStart",new d.InterleavedBufferAttribute(i,3,0)),this.setAttribute("instanceEnd",new d.InterleavedBufferAttribute(i,3,3)),this.computeBoundingBox(),this.computeBoundingSphere(),this},t.prototype.setColors=function(e){var r;e instanceof Float32Array?r=e:Array.isArray(e)?r=new Float32Array(e):r=new Float32Array;var i=new d.InstancedInterleavedBuffer(r,6,1);return this.setAttribute("instanceColorStart",new d.InterleavedBufferAttribute(i,3,0)),this.setAttribute("instanceColorEnd",new d.InterleavedBufferAttribute(i,3,3)),this},t.prototype.fromWireframeGeometry=function(e){return this.setPositions(e.attributes.position.array),this},t.prototype.fromEdgesGeometry=function(e){return this.setPositions(e.attributes.position.array),this},t.prototype.fromMesh=function(e){return this.fromWireframeGeometry(new d.WireframeGeometry(e.geometry)),this},t.prototype.fromLineSegments=function(e){var r=e.geometry;if(r instanceof d.Geometry){var i=new d.BufferGeometry().fromGeometry(r);this.setPositions(i.attributes.position.array)}else r instanceof d.BufferGeometry&&this.setPositions(r.attributes.position.array);return this},t.prototype.computeBoundingBox=function(){this.boundingBox===null&&(this.boundingBox=new d.Box3);var e=this.attributes.instanceStart,r=this.attributes.instanceEnd;if(e!==void 0&&r!==void 0){var i=new d.Box3;this.boundingBox.setFromBufferAttribute(e),i.setFromBufferAttribute(r),this.boundingBox.union(i)}},t.prototype.computeBoundingSphere=function(){this.boundingSphere===null&&(this.boundingSphere=new d.Sphere),this.boundingBox===null&&this.computeBoundingBox();var e=this.attributes.instanceStart,r=this.attributes.instanceEnd;if(e!==void 0&&r!==void 0){var i=this.boundingSphere.center;this.boundingBox.getCenter(i);for(var a=0,o=new d.Vector3,s=0,u=e.count;s<u;s++)o.fromBufferAttribute(e,s),a=Math.max(a,i.distanceToSquared(o)),o.fromBufferAttribute(r,s),a=Math.max(a,i.distanceToSquared(o));this.boundingSphere.radius=Math.sqrt(a),isNaN(this.boundingSphere.radius)&&console.error("THREE.LineSegmentsGeometry.computeBoundingSphere(): Computed radius is NaN. The instanced position data is likely to have NaN values.",this)}},t.prototype.toJSON=function(){},t}(d.InstancedBufferGeometry);Object.assign(uo.prototype,{isLineSegmentsGeometry:!0});var ca={uniforms:d.UniformsUtils.merge([d.UniformsLib.common,d.UniformsLib.fog,{linewidth:{value:1},resolution:{value:new d.Vector2(1,1)},dashScale:{value:1},dashSize:{value:1},gapSize:{value:1},opacity:{value:1}}]),vertexShader:`
|
|
1839
|
+
b-J-Htyl]|vv|{-J-}|wrpv|{Znv\x07-7-z|qrycvrZnv\x07-7-rpA5}|vv|{9>;=6H\f`);var sp=function(n){de(t,n);function t(e){var r=n.call(this,{vertexShader:op,fragmentShader:ap})||this;return r.uniforms={uDepthMap:Bs("t",null),uWeightMap:Bs("t",null)},r.depthTest=!0,r.depthWrite=!0,r.opacity=1,r}return t.prototype.getUniform=function(e){return this.uniforms===void 0?void 0:this.uniforms[e].value},t.prototype.setUniform=function(e,r){if(this.uniforms!==void 0){var i=this.uniforms[e];i.value=r}},Pt([Rs("uDepthMap"),Bt("design:type",Number)],t.prototype,"uDepthMap",void 0),Pt([Rs("uWeightMap"),Bt("design:type",Number)],t.prototype,"uWeightMap",void 0),t}(d.RawShaderMaterial);function Bs(n,t){return{type:n,value:t}}function Rs(n,t){return t===void 0&&(t=!1),function(e,r){Object.defineProperty(e,r,{get:function(){return this.getUniform(n)},set:function(i){i!==this.getUniform(n)&&(this.setUniform(n,i),t&&this.updateShaderSource())}})}}var up=new d.OrthographicCamera(-1,1,1,-1,0,1),so=new d.BufferGeometry;so.setAttribute("position",new d.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3));so.setAttribute("uv",new d.Float32BufferAttribute([0,2,0,0,2,0],2));var a0=new d.Mesh(so),o0=new d.Scene;o0.add(a0);var lp=function(n){de(t,n);function t(e,r,i,a){var o=n.call(this,e,r,i,a)||this;return o.sharedV2=new d.Vector2,o.renderer=e,o.material=new sp,o.scene=r,o.camera=i,a0.material=o.material,o}return t.prototype.render=function(e){var r=this.material.uniforms;this.models.setMaterial({useHQWeight:!0,useHQDepth:!1}),this.renderer.setRenderTarget(e[1]),this.models.update(this.renderer,this.camera,"Mapview"),this.renderer.autoClearDepth=!1,this.renderer.setClearAlpha(0),this.renderer.render(this.scene,this.camera),r.uWeightMap.value=e[1].texture,r.uDepthMap.value=e[0].depthTexture,this.renderer.setRenderTarget(null),this.renderer.autoClearDepth=!0,this.renderer.setClearAlpha(1),this.renderer.render(o0,up),this.models.setMaterial({useHQWeight:!1,useHQDepth:!0}),this.models.update(this.renderer,this.camera,"Mapview")},t.prototype.dispose=function(){this.copyPass.dispose()},t}(Bi),ua=.5,la=0,cp=function(n){de(t,n);function t(e){var r=this,i,a=t.parseArgs(e);return r=n.call(this,a)||this,r.mode="Mapview",r.defaultLongitude=a.defaultLongitude,r.defaultLatitude=a.defaultLatitude,r.defaultDistance=a.defaultDistance,r.maxLatitude=a.maxLatitude,r.minLatitude=a.minLatitude,r.locationMotion=new we({x:r.camera.pose.offset.x,y:r.camera.pose.offset.y,z:r.camera.pose.offset.z,distance:r.camera.pose.distance}),r.modelAlphaMotion=new we({modelAlpha:(i=r.models.getMaterial().modelAlpha)!==null&&i!==void 0?i:0}),r.perspToOrthoMotion=new we({perspToOrtho:r.camera.perspToOrtho.x}),r.intersectMeshCreator=a.intersectMeshCreator,r.intersectMesh=r.intersectMeshCreator(),r.intersectMesh.name="intersect",r.intersectMesh.visible=!1,r.currentTapId=null,r.helper.add(r.intersectMesh),r.edlTarget=new d.WebGLRenderTarget(1024,1024,{minFilter:d.NearestFilter,magFilter:d.NearestFilter,format:d.RGBAFormat,type:d.FloatType,depthTexture:new d.DepthTexture(1024,1024,d.UnsignedIntType)}),r.edlEffect=new ip(r.renderer,r.scene,r.camera,r.models),r.hqEffect=new lp(r.renderer,r.scene,r.camera,r.models),r}return t.parseArgs=function(e){var r,i,a,o,s,u;if(e instanceof t)return e;var c=n.parseArgs.call(this,e);return R(R({},c),{defaultLongitude:(r=e.defaultLongitude)!==null&&r!==void 0?r:Math.PI/4,defaultLatitude:(i=e.defaultLatitude)!==null&&i!==void 0?i:Math.PI/4,defaultDistance:(a=e.defaultDistance)!==null&&a!==void 0?a:150,maxLatitude:(o=e.maxLatitude)!==null&&o!==void 0?o:+Math.PI/2,minLatitude:(s=e.minLatitude)!==null&&s!==void 0?s:0,intersectMeshCreator:(u=e.intersectMeshCreator)!==null&&u!==void 0?u:function(){return new Si}})},t.distanceFromModel=function(e,r,i){var a=e.bounding,o=Math.pow(Math.pow(a.max.x-a.min.x+1,2)+Math.pow(a.max.y-a.min.y+1,2)+Math.pow(a.max.z-a.min.z+1,2),1/2),s=o/2/Math.tan(Math.PI*r/360);return i<1&&(s=s/i),isNaN(s)?o:s},t.initAnimationEndState=function(e){var r,i,a,o,s,u,c,l=this.parseArgs(e),h=l.works,p=l.models,v=e.initial,m=v.state,A=v.currentState,y=typeof m.panoIndex=="number"?{workCode:(a=(r=m.workCode)!==null&&r!==void 0?r:(i=l.works[0])===null||i===void 0?void 0:i.workCode)!==null&&a!==void 0?a:"",panoIndex:m.panoIndex}:{workCode:A.workCode,panoIndex:A.panoIndex},f=h.getResolvedObserver(y),g=(o=m.fov)!==null&&o!==void 0?o:60,b=le((s=m.latitude)!==null&&s!==void 0?s:Pa(A.mode)?A.latitude:l.defaultLatitude,l.minLatitude,l.maxLatitude),w=t.distanceFromModel(l.models,g,l.camera.aspect),E=new d.Vector3,x=(u=m.distance)!==null&&u!==void 0?u:Math.min(l.defaultDistance,w),M=(c=m.longitude)!==null&&c!==void 0?c:Pa(A.mode)?A.longitude:l.defaultLongitude;return m.offset?E.copy(m.offset):l.defaultDistance<w&&f?(E.copy(f.position),m.longitude===void 0&&(M=A.longitude)):E.copy(p.bounding.getCenter(E)),p.bounding.containsPoint(E)||p.bounding.getCenter(E),R(R({},y),{mode:"Mapview",longitude:M,latitude:b,fov:g,offset:E,distance:x})},t.prototype.destroy=function(){n.prototype.destroy.call(this),this.locationMotion.dispose(),delete this.panState,this.intersectMesh.dispose(),this.helper.remove(this.intersectMesh)},t.prototype.isReady=function(){return this.locationMotion.ended===!1?!1:n.prototype.isReady.call(this)},t.prototype.updateWork=function(e,r,i,a){this.userAction=a,this.works=e;var o=t.initAnimationEndState(R(R({},this),{initial:{currentState:R(R({},this.currentPano),this.camera.pose),duration:i,state:r,userAction:a}}));this.currentPano={workCode:o.workCode,panoIndex:o.panoIndex};var s={longitude:o.longitude,latitude:o.latitude,fov:o.fov},u={x:o.offset.x,y:o.offset.y,z:o.offset.z,distance:o.distance,orthoDistance:o.distance};return this.locationMotion.set(u,i).catch(Q),this.cameraMotion.set(s,i).catch(Q),!0},t.prototype.updateModel=function(e){n.prototype.updateModel.call(this,e)},t.prototype.updateCamera=function(e,r,i){var a=this;return this.initAnimationReady.then(function(){a.userAction=i,a.stopMomentumMovement();var o={},s={};return e.distance!==void 0&&(o.distance=e.distance),e.offset!==void 0&&(o.x=e.offset.x,o.y=e.offset.y,o.z=e.offset.z),e.longitude!==void 0&&(s.longitude=e.longitude),e.latitude!==void 0&&(s.latitude=e.latitude),e.fov!==void 0&&(s.fov=e.fov),a.locationMotion.set(o,r).catch(Q),a.cameraMotion.set(s,r).catch(Q)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var a=this;return this.initAnimationReady.then(function(){a.userAction=i,a.stopMomentumMovement();for(var o=[],s=[],u=0,c=e;u<c.length;u++){var l=c[u];o.push({key:l.key,progress:l.progress,value:{distance:l.value.distance,x:l.value.offset.x,y:l.value.offset.x,z:l.value.offset.x}}),s.push({key:l.key,progress:l.progress,value:{longitude:l.value.longitude,latitude:l.value.latitude,fov:l.value.fov}})}return a.locationMotion.setKeyframes(o,r).catch(Q),a.cameraMotion.setKeyframes(e,r)})},t.prototype.updateTime=function(e,r){if(!this.destroyed){var i={},a={};if(this.locationMotion.ended||(this.locationMotion.update(e),a.distance=this.locationMotion.value.distance,a.offset=new d.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z)),!this.cameraMotion.ended){this.cameraMotion.update(e),a.longitude=this.cameraMotion.value.longitude,a.latitude=this.cameraMotion.value.latitude,a.fov=this.cameraMotion.value.fov;var o=Math.PI/2-a.latitude<.02?1:0;this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho!==o&&this.perspToOrthoMotion.set({perspToOrtho:o},500).catch(Q)}this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),i.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(le(this.perspToOrthoMotion.value.perspToOrtho,0,1))),St(i)||this.models.setMaterial(i),St(a)||this.setCamera(a)}},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(ve())[1],r=this.locationMotion.getKeyFrameSegment(ve())[1];return R(R({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,distance:r.value.distance,offset:new d.Vector3(r.value.x,r.value.y,r.value.z)})},t.prototype.initAnimation=function(){var e=this;return this.destroyed?Promise.resolve():new Promise(function(r){var i=e.initial;i.state,i.currentState;var a=i.duration,o=i.userAction;e.userAction=o;var s=t.initAnimationEndState(e),u={longitude:s.longitude,latitude:s.latitude,fov:s.fov},c={x:s.offset.x,y:s.offset.y,z:s.offset.z,distance:s.distance},l={modelAlpha:1},h={perspToOrtho:0};e.emit("initAnimation.start",_("initAnimation.start",{state:s,userAction:e.userAction})),e.perspToOrthoMotion.set(h,a).catch(Q),e.modelAlphaMotion.set(l,a/3).catch(Q),e.cameraMotion.set(u,a).catch(Q),e.locationMotion.set(c,a).then(function(){e.emit("initAnimation.end",_("initAnimation.end",{state:s,userAction:e.userAction}))},function(p){var v=R(R(R({},e.currentPano),{mode:e.mode}),Ve(e.camera.pose));e.emit("initAnimation.end",_("initAnimation.end",{state:v,userAction:e.userAction}))}).then(function(){r()})})},t.prototype.getForwardObserverOrNot=function(e){var r=this.models.intersectRaycaster(e)[0];if(!r)return null;var i=this.works.resolvedObservers,a=Ot(i,function(u){return u.standingPosition.distanceTo(r.point)},!0),o=a[0],s=a[1];return o&&s<10?o:null},t.prototype.coordinatesForOffset=function(e){var r=this.renderer.getSize(new d.Vector2);return{longitude:-2*e.x/(r.x*this.scissor.width),latitude:2*e.y/(r.y*this.scissor.height)}},t.prototype.requestMomentumMovement=function(e,r,i,a){var o=this;if(this.inMomentumMovement!==null){for(var s=R({},i),u={longitude:0,latitude:0,x:0,y:0,z:0},c=0;c<a;c++)s.longitude*=.996,s.latitude*=.996*.998,s.x*=.99,s.y*=.99,s.z*=.99,u.longitude+=s.longitude,u.latitude+=s.latitude,u.x+=s.x,u.y+=s.y,u.z+=s.z;var l=Nr(this.cameraMotion.value.longitude+u.longitude),h=le(this.cameraMotion.value.latitude+u.latitude,this.minLatitude,this.maxLatitude),p=le(this.locationMotion.value.x+u.x,this.models.bounding.min.x,this.models.bounding.max.x),v=le(this.locationMotion.value.y+u.y,this.models.bounding.min.y,this.models.bounding.max.y),m=le(this.locationMotion.value.z+u.z,this.models.bounding.min.z,this.models.bounding.max.z),A=R(R({},this.currentPano),{mode:this.mode,longitude:l,latitude:h,offset:new d.Vector3(p,v,m),fov:this.cameraMotion.value.fov,distance:this.camera.pose.distance}),y=!(Math.abs(s.longitude)>1e-4||Math.abs(s.latitude)>1e-4||Math.abs(s.x)>1e-4||Math.abs(s.y)>1e-4||Math.abs(s.z)>1e-4),f=_("gesture.momentum",R(R({},e),{isFirst:r,isFinal:y,state:A}));if(this.inMomentumMovement.event=f,this.emit("gesture.momentum",f),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:l,latitude:h},0).catch(Q),this.locationMotion.set({x:A.offset.x,y:A.offset.y,z:A.offset.z},0).catch(Q),y?this.inMomentumMovement=null:it.shared.add(function(g,b){o.requestMomentumMovement(e,!1,s,b|0)},!0,1))}},t.prototype.fixFinalState=function(e){if(this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho!==1){var r=Rr(e,new d.Vector3),i=new d.Vector3().copy(e.offset).sub(r.clone().multiplyScalar(e.distance)),a=new d.Raycaster(i,r);a.params.Points={threshold:.1},a.near=ua;var o=this.models.intersectRaycaster(a)[0];if(!o&&a.ray.direction.y<-.3){var s=new d.Plane(new d.Vector3(0,1,0),0),u=a.ray.intersectPlane(s,new d.Vector3);if(u){var c=u.distanceTo(a.ray.origin);c<1e4&&c>=a.near&&(o={distance:c,floor:0,point:u,object:this.scene,face:null})}}o&&(e.distance=le(o.distance,la,1/0),e.offset.copy(i).add(r.clone().multiplyScalar(e.distance)))}},t.prototype.onPanGesture=function(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();var r=e.pointers.length,i=this.panState,a=0;e.pointerType==="mouse"&&(a=e.srcEvent.buttons),i&&a===0&&i.buttons!==0&&(a=i.buttons);var o=i==null?void 0:i.target;if(!o){var s=this.relativeClientPosition(e.center),u=new d.Raycaster;u.params.Points={threshold:.1},u.setFromCamera(s,this.camera),u.near=ua,o=new d.Vector3().copy(u.ray.direction).multiplyScalar(3).add(u.ray.origin);var c=this.models.intersectRaycaster(u)[0];if(!c&&u.ray.direction.y<-.3){var l=new d.Plane(new d.Vector3(0,1,0),0),h=u.ray.intersectPlane(l,new d.Vector3);if(h){var p=h.distanceTo(u.ray.origin);p<1e4&&p>=u.near&&(c={distance:p,floor:0,point:h,object:this.scene})}}if(c)o.copy(c.point);else{var v=new d.Vector3().copy(this.camera.pose.offset).sub(this.camera.position),l=new d.Plane().setFromNormalAndCoplanarPoint(v,this.camera.pose.offset);u.ray.intersectPlane(l,o)}}if(e.isFinal?delete this.panState:this.panState={target:o,buttons:a,pointerLength:r,x:e.center.x,y:e.center.y},!(typeof i>"u"||i.pointerLength!==r)){var m=r>1||a===2;if(m){var A={x:e.center.x-i.x,y:e.center.y-i.y},y=new d.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),f=Rr(this.cameraMotion.value).setLength(this.locationMotion.value.distance).add(y),g=new d.Vector3().copy(f).sub(i.target).length();g*=Math.tan(this.camera.pose.fov/2*Math.PI/180);var b=this.renderer.getSize(new d.Vector2),w=2*A.x*g/b.y,E=2*A.y*g/b.y,x=new d.Vector3;x.setFromMatrixColumn(this.camera.matrix,0),x.multiplyScalar(-w),y.add(x),this.camera.pose.latitude<Math.PI/12?x.setFromMatrixColumn(this.camera.matrix,1):(x.setFromMatrixColumn(this.camera.matrix,0),x.crossVectors(this.camera.up,x)),x.multiplyScalar(E),y.add(x),y.clamp(this.models.bounding.min,this.models.bounding.max);var M=R(R({},this.currentPano),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:y,distance:this.camera.pose.distance});if(e.state=M,this.emit("gesture.pan",e),e.defaultPrevented)return;if(this.locationMotion.set({x:M.offset.x,y:M.offset.y,z:M.offset.z},0).catch(Q),e.isFinal&&(this.fixFinalState(M),this.locationMotion.set({distance:M.distance,x:M.offset.x,y:M.offset.y,z:M.offset.z},0).catch(Q)),e.isFinal){var C=this.renderer.getSize(new d.Vector2),I=2*e.velocityX*g/C.y,P=2*e.velocityY*g/C.y,S=new d.Vector3,F=new d.Vector3;S.setFromMatrixColumn(this.camera.matrix,0),S.multiplyScalar(-I),F.add(S),this.camera.pose.latitude<Math.PI/4?S.setFromMatrixColumn(this.camera.matrix,1):(S.setFromMatrixColumn(this.camera.matrix,0),S.crossVectors(this.camera.up,S)),S.multiplyScalar(P),F.add(S),this.inMomentumMovement={uuid:vt()},this.requestMomentumMovement(e,!0,{longitude:0,latitude:0,x:F.x,y:F.y,z:F.z},0)}}else{var A={x:e.center.x-i.x,y:e.center.y-i.y},k=this.coordinatesForOffset(A),O=Nr(this.cameraMotion.value.longitude+k.longitude),L=le(this.cameraMotion.value.latitude+k.latitude,this.minLatitude,this.maxLatitude);this.camera.aspect<1&&Math.abs(e.overallVelocityX)>.2&&Math.atan2(Math.abs(e.overallVelocityY),Math.abs(e.overallVelocityX))<Math.PI/6.923&&(L=this.cameraMotion.value.latitude);var M=R(R({},this.currentPano),{mode:this.mode,longitude:O,latitude:L,fov:this.camera.pose.fov,offset:this.camera.pose.offset,distance:this.camera.pose.distance});if(e.isFinal&&this.fixFinalState(M),e.state=M,this.emit("gesture.pan",e),e.defaultPrevented)return;if(e.isFinal?this.locationMotion.set({distance:M.distance,x:M.offset.x,y:M.offset.y,z:M.offset.z},0).catch(Q):this.cameraMotion.set({longitude:M.longitude,latitude:M.latitude},0).catch(Q),e.isFinal){var N=e.velocityX,V=e.velocityY;this.inMomentumMovement={uuid:vt()},this.requestMomentumMovement(e,!0,R(R({},this.coordinatesForOffset({x:N,y:V})),{x:0,y:0,z:0}),0)}}}},t.prototype.onPinchGesture=function(e){var r;this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();var i=(r=this.pinchState)===null||r===void 0?void 0:r.distance;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,scale:1,distance:this.locationMotion.value.distance};return}if(e.isFinal){delete this.panState,delete this.pinchState;return}if(!(typeof i>"u")){var a=this.models.bounding.getCenter(new d.Vector3),o=t.distanceFromModel(this.models,this.cameraMotion.value.fov,this.camera.aspect),s=le(i/e.scale,la,1/0),u=e.state.offset.clone().sub(Rr(e.state).setLength(s)),c=this.models.bounding.containsPoint(u),l;!c&&this.pinchState&&this.pinchState.scale>e.scale&&a.distanceTo(u)>o?l=e.state.distance:(l=s,this.pinchState&&(this.pinchState.scale=e.scale)),e.state.distance=l,this.emit("gesture.pinch",e),!e.defaultPrevented&&(this.locationMotion.set({distance:e.state.distance},0).catch(Q),e.pointerType!=="mouse"&&(e.type="gesture.pan",this.onPanGesture(e)))}},t.prototype.onMouseMove=function(e){var r,i;if(this.intersectMesh.parent&&!this.panState&&!this.pinchState&&!this.mouseWheelState&&(this.emit("gesture.mousemove",e),!e.defaultPrevented)){var a=e.center.raycaster;if(a.near=ua,a.far=500,e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}var o=this.models.intersectRaycaster(a)[0],s=_("intersect.update",{raycaster:a,intersection:o??null,object:this.intersectMesh});if(this.emit("intersect.update",s),s.defaultPrevented){this.hideIntersectMesh();return}if(o){var u=(i=(r=o.face)===null||r===void 0?void 0:r.normal)!==null&&i!==void 0?i:new d.Vector3().copy(a.ray.direction).multiplyScalar(-1),c=u.clone().multiplyScalar(.05),l=o.point.clone().add(c);this.intersectMesh.position.copy(l);var h=l.clone().add(c);if(this.intersectMesh.lookAt(h),Math.abs(u.y)>.99){var p=this.camera.position.clone().sub(l);this.intersectMesh.rotation.z=-Math.atan2(p.z,p.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}},t.prototype.onMouseWheel=function(e){if(this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh(),e.isFinal){var r=e.state;if(this.fixFinalState(r),this.emit("gesture.mousewheel",e),e.defaultPrevented)return;var i={x:r.offset.x,y:r.offset.y,z:r.offset.z,distance:r.distance};this.locationMotion.set(i,0).catch(Q)}else{var a=e.center.delta/2*Math.max(Math.log(this.locationMotion.value.distance),1),o=this.models.bounding.getCenter(new d.Vector3),s=t.distanceFromModel(this.models,this.cameraMotion.value.fov,this.camera.aspect),u=le(this.locationMotion.value.distance-a,la,1/0),c=e.state.offset.clone().sub(Rr(e.state).setLength(u)),l=this.models.bounding.containsPoint(c),h=!l&&a<0&&o.distanceTo(c)>s?e.state.distance:u;if(e.state.distance=u,this.emit("gesture.mousewheel",e),e.defaultPrevented)return;this.locationMotion.set({distance:h},0).catch(Q)}},t.prototype.onTapGesture=function(e){var r=this;this.userAction=e.userAction,this.stopMomentumMovement();var i=e.center.raycaster,a=this.getForwardObserverOrNot(i);if(!a)this.emit("gesture.tap",e);else{var o={longitude:this.camera.pose.longitude,latitude:0},s=R(R({},e.state),{mode:"Panorama",workCode:a.pano.workCode,panoIndex:a.pano.panoIndex,longitude:o.longitude,latitude:o.latitude,offset:a?a.position.clone():new d.Vector3,distance:0});if(e.state=s,this.emit("gesture.tap",e),!e.defaultPrevented&&(this.emit("pano.select",_("pano.select",{prevPano:this.currentPano,state:s,userAction:e.userAction,options:o,progress:0,error:null})),a&&a.active)){var u=this.currentTapId=vt();this.preloadPano(a.pano).then(function(c){r.currentTapId===u&&r.emit("pano.request",_("pano.request",{userAction:!0,prevPano:r.currentPano,progress:0,state:s,options:o,error:null}))})}}},t.prototype.hideIntersectMesh=function(){this.intersectMesh.visible=!1,this.needsRender=!0},t.prototype.postProcessing=function(e,r){var i;if(!this.destroyed){if(r==="edl")return this.edlEffect.render(e);if(r==="hq")return(i=this.hqEffect)===null||i===void 0?void 0:i.render(e)}},t}(eo);function Fs(n){return n==null}var dp={type:"move"},Os=function(){function n(){this._targetRay=null,this._grip=null,this._hand=null,this._axes=[0,0]}return n.prototype.getHandSpace=function(){return this._hand===null&&(this._hand=new d.Group,this._hand.matrixAutoUpdate=!1,this._hand.visible=!1,this._hand.joints={},this._hand.inputState={pinching:!1}),this._hand},n.prototype.getTargetRaySpace=function(){return this._targetRay===null&&(this._targetRay=new d.Group,this._targetRay.matrixAutoUpdate=!1,this._targetRay.visible=!1,this._targetRay.hasLinearVelocity=!1,this._targetRay.linearVelocity=new d.Vector3,this._targetRay.hasAngularVelocity=!1,this._targetRay.angularVelocity=new d.Vector3),this._targetRay},n.prototype.getGripSpace=function(){return this._grip===null&&(this._grip=new d.Group,this._grip.matrixAutoUpdate=!1,this._grip.visible=!1,this._grip.hasLinearVelocity=!1,this._grip.linearVelocity=new d.Vector3,this._grip.hasAngularVelocity=!1,this._grip.angularVelocity=new d.Vector3),this._grip},n.prototype.dispatchEvent=function(t){return this._targetRay!==null&&this._targetRay.dispatchEvent(t),this._grip!==null&&this._grip.dispatchEvent(t),this._hand!==null&&this._hand.dispatchEvent(t),this},n.prototype.disconnect=function(t){return this.dispatchEvent({type:"disconnected",data:t}),this._targetRay!==null&&(this._targetRay.visible=!1),this._grip!==null&&(this._grip.visible=!1),this._hand!==null&&(this._hand.visible=!1),this},n.prototype.getAxes=function(){return this._axes},n.prototype.update=function(t,e,r){var i=null,a=null,o=null,s=this._targetRay,u=this._grip,c=this._hand;if(t&&t.gamepad&&t.gamepad.axes&&(this._axes=[t.gamepad.axes[2],t.gamepad.axes[3]]),t&&e.session.visibilityState!=="visible-blurred")if(s!==null&&(i=e.getPose(t.targetRaySpace,r),i!==null&&(s.matrix.fromArray(i.transform.matrix),s.matrix.decompose(s.position,s.rotation,s.scale),i.linearVelocity?(s.hasLinearVelocity=!0,s.linearVelocity.copy(i.linearVelocity)):s.hasLinearVelocity=!1,i.angularVelocity?(s.hasAngularVelocity=!0,s.angularVelocity.copy(i.angularVelocity)):s.hasAngularVelocity=!1,this.dispatchEvent(dp))),c&&t.hand){o=!0;for(var l=0,h=t.hand.values();l<h.length;l++){var p=h[l],v=e.getJointPose(p,r);if(c.joints[p.jointName]===void 0){var m=new d.Group;m.matrixAutoUpdate=!1,m.visible=!1,c.joints[p.jointName]=m,c.add(m)}var A=c.joints[p.jointName];v!==null&&(A.matrix.fromArray(v.transform.matrix),A.matrix.decompose(A.position,A.rotation,A.scale),A.jointRadius=v.radius),A.visible=v!==null}var y=c.joints["index-finger-tip"],f=c.joints["thumb-tip"],g=y.position.distanceTo(f.position),b=.02,w=.005;c.inputState.pinching&&g>b+w?(c.inputState.pinching=!1,this.dispatchEvent({type:"pinchend",handedness:t.handedness,target:this})):!c.inputState.pinching&&g<=b-w&&(c.inputState.pinching=!0,this.dispatchEvent({type:"pinchstart",handedness:t.handedness,target:this}))}else u!==null&&t.gripSpace&&(a=e.getPose(t.gripSpace,r),a!==null&&(u.matrix.fromArray(a.transform.matrix),u.matrix.decompose(u.position,u.rotation,u.scale),a.linearVelocity?(u.hasLinearVelocity=!0,u.linearVelocity.copy(a.linearVelocity)):u.hasLinearVelocity=!1,a.angularVelocity?(u.hasAngularVelocity=!0,u.angularVelocity.copy(a.angularVelocity)):u.hasAngularVelocity=!1));return s!==null&&(s.visible=i!==null),u!==null&&(u.visible=a!==null),c!==null&&(c.visible=o!==null),this},n}(),fp=1,hp=function(){function n(t,e,r){var i,a,o,s,u;this.isPanorama=(i=r==null?void 0:r.isPanorama)!==null&&i!==void 0?i:!0,this.machineType=(a=r==null?void 0:r.machineType)!==null&&a!==void 0?a:"Pico",this.renderer=t,this.gl=e,this.enabled=!1,this.session=null,this.referenceSpaceType=(o=r==null?void 0:r.referenceSpaceType)!==null&&o!==void 0?o:"local-floor",this.referenceSpace=null,this.onSessionStartCallback=(s=r==null?void 0:r.onSessionStart)!==null&&s!==void 0?s:Q,this.onSessionEndCallback=(u=r==null?void 0:r.onSessionEnd)!==null&&u!==void 0?u:Q,this.controllers=[new Os,new Os],this.inputSourcesMap=new Map,this.cameraVR=new d.ArrayCamera,this.cameraL=new d.PerspectiveCamera,this.cameraR=new d.PerspectiveCamera,this.cameraL.viewport=new d.Vector4,this.cameraR.viewport=new d.Vector4,this.cameraL.layers.enable(1),this.cameraR.layers.enable(2),this.cameraVR.layers.enable(1),this.cameraVR.layers.enable(2),this.isPresenting=!1,this.currentDepthNear=null,this.currentDepthFar=null,this.cameraLPos=new d.Vector3,this.cameraRPos=new d.Vector3}return n.prototype.getController=function(t){var e=this.controllers[t];return e||console.warn("no controller find"),e.getTargetRaySpace()},n.prototype.getRightController=function(){if(!this.session)return null;var t=this.session.inputSources[0].handedness==="right"?0:1,e=this.controllers[t];return e||console.warn("no controller find"),e.getTargetRaySpace()},n.prototype.getLeftController=function(){if(!this.session)return null;var t=this.session.inputSources[0].handedness==="left"?0:1,e=this.controllers[t];return e||console.warn("no controller find"),e.getTargetRaySpace()},n.prototype.getControllerGrip=function(t){var e=this.controllers[t];return e||console.warn("no controller find"),e.getGripSpace()},n.prototype.getCameras=function(){return{cameraL:this.cameraL,cameraR:this.cameraR,cameraVR:this.cameraVR}},n.prototype.updateCamera=function(t,e){e===null?t.matrixWorld.copy(t.matrix):t.matrixWorld.multiplyMatrices(e.matrixWorld,t.matrix),t.matrixWorldInverse.getInverse(t.matrixWorld)},n.prototype.setProjectionFromUnion=function(t,e,r){this.cameraLPos.setFromMatrixPosition(e.matrixWorld),this.cameraRPos.setFromMatrixPosition(r.matrixWorld);var i=this.cameraLPos.distanceTo(this.cameraRPos),a=e.projectionMatrix.elements,o=r.projectionMatrix.elements,s=a[14]/(a[10]-1),u=a[14]/(a[10]+1),c=(a[9]+1)/a[5],l=(a[9]-1)/a[5],h=(a[8]-1)/a[0],p=(o[8]+1)/o[0],v=s*h,m=s*p,A=i/(-h+p),y=A*-h;e.matrixWorld.decompose(t.position,t.quaternion,t.scale),t.translateX(y),t.translateZ(A),t.matrixWorld.compose(t.position,t.quaternion,t.scale),t.matrixWorldInverse.getInverse(t.matrixWorld);var f=s+A,g=u+A,b=v-y,w=m+(i-y),E=c*u/g*f,x=l*u/g*f;t.projectionMatrix.makePerspective(b,w,E,x,f,g)},n.prototype.getCamera=function(t){this.cameraVR.near=this.cameraR.near=this.cameraL.near=t.near,this.cameraVR.far=this.cameraR.far=this.cameraL.far=t.far,this.session&&(this.currentDepthNear!==this.cameraVR.near||this.currentDepthFar!==this.cameraVR.far)&&(this.session.updateRenderState({depthNear:this.cameraVR.near,depthFar:this.cameraVR.far}),this.currentDepthNear=this.cameraVR.near,this.currentDepthFar=this.cameraVR.far);var e=t.parent,r=this.cameraVR.cameras;this.updateCamera(this.cameraVR,e);for(var i=0;i<r.length;i++)this.updateCamera(r[i],e);t.matrixWorld.copy(this.cameraVR.matrixWorld);for(var a=t.children,i=0,o=a.length;i<o;i++)a[i].updateMatrixWorld(!0);return r.length===2?this.setProjectionFromUnion(this.cameraVR,this.cameraL,this.cameraR):this.cameraVR.projectionMatrix.copy(this.cameraL.projectionMatrix),this.cameraVR},n.prototype.updateInputSources=function(t){if(!this.session){console.warn("session is lose!");return}for(var e=this.session.inputSources,r=0;r<this.controllers.length;r++)this.inputSourcesMap.set(e[r],this.controllers[r]);for(var r=0;r<t.removed.length;r++){var i=t.removed[r],a=this.inputSourcesMap.get(i);a&&(a.dispatchEvent({type:"disconnected",data:i}),this.inputSourcesMap.delete(i))}for(var r=0;r<t.added.length;r++){var i=t.added[r],a=this.inputSourcesMap.get(i);a&&a.dispatchEvent({type:"connected",data:i})}},n.prototype.onSessionEvent=function(t){var e=this.inputSourcesMap.get(t.inputSource);e&&e.dispatchEvent({type:t.type})},n.prototype.onSessionEnd=function(){this.inputSourcesMap.forEach(function(t,e){t.disconnect(e)}),this.inputSourcesMap.clear(),this.renderer.setFramebuffer(null),this.renderer.setRenderTarget(this.renderer.getRenderTarget()),this.isPresenting=!1,this.session=null,it.shared.setContext(null),this.onSessionEndCallback()},n.prototype.onRequestReferenceSpace=function(t){this.referenceSpace=t,this.isPresenting=!0,this.session&&this.onSessionStartCallback(this.session)},n.prototype.setSession=function(t){var e=this;if(this.session=t,this.session){this.session.addEventListener("select",function(i){e.onSessionEvent(i)}),this.session.addEventListener("selectstart",function(i){e.onSessionEvent(i)}),this.session.addEventListener("selectend",function(i){e.onSessionEvent(i)}),this.session.addEventListener("squeeze",function(i){e.onSessionEvent(i)}),this.session.addEventListener("squeezestart",function(i){e.onSessionEvent(i)}),this.session.addEventListener("squeezeend",function(i){e.onSessionEvent(i)}),this.session.addEventListener("end",function(i){e.onSessionEnd()});var r=this.gl.getContextAttributes();this.gl.makeXRCompatible().then(function(){var i={antialias:r==null?void 0:r.antialias,alpha:r==null?void 0:r.alpha,depth:r==null?void 0:r.depth,stencil:r==null?void 0:r.stencil,framebufferScaleFactor:fp};if(!e.session){console.error("session is lose while set session!");return}switch(e.machineType){case"Pico":e.session.updateRenderState({baseLayer:new XRWebGLLayer(e.session,e.gl,i)});break;case"Oculus":e.session.updateRenderState({layers:[new XRWebGLLayer(e.session,e.gl,i)]});break;default:e.machineType;break}e.session.requestReferenceSpace(e.referenceSpaceType).then(function(a){e.onRequestReferenceSpace(a)}),e.session.addEventListener("inputsourceschange",function(a){e.updateInputSources(a)})})}},n}(),uo=function(n){de(t,n);function t(){var e=n.call(this)||this;e.type="LineSegmentsGeometry";var r=[-1,2,0,1,2,0,-1,1,0,1,1,0,-1,0,0,1,0,0,-1,-1,0,1,-1,0],i=[-1,2,1,2,-1,1,1,1,-1,-1,1,-1,-1,-2,1,-2],a=[0,2,1,2,3,1,2,4,3,4,5,3,4,6,5,6,7,5];return e.setIndex(a),e.setAttribute("position",new d.Float32BufferAttribute(r,3)),e.setAttribute("uv",new d.Float32BufferAttribute(i,2)),e}return t.prototype.applyMatrix4=function(e){var r=this.attributes.instanceStart,i=this.attributes.instanceEnd;return r!==void 0&&(r.applyMatrix4(e),i.applyMatrix4(e),r.needsUpdate=!0),this.boundingBox!==null&&this.computeBoundingBox(),this.boundingSphere!==null&&this.computeBoundingSphere(),this},t.prototype.setPositions=function(e){var r;e instanceof Float32Array?r=e:Array.isArray(e)?r=new Float32Array(e):r=new Float32Array;var i=new d.InstancedInterleavedBuffer(r,6,1);return this.setAttribute("instanceStart",new d.InterleavedBufferAttribute(i,3,0)),this.setAttribute("instanceEnd",new d.InterleavedBufferAttribute(i,3,3)),this.computeBoundingBox(),this.computeBoundingSphere(),this},t.prototype.setColors=function(e){var r;e instanceof Float32Array?r=e:Array.isArray(e)?r=new Float32Array(e):r=new Float32Array;var i=new d.InstancedInterleavedBuffer(r,6,1);return this.setAttribute("instanceColorStart",new d.InterleavedBufferAttribute(i,3,0)),this.setAttribute("instanceColorEnd",new d.InterleavedBufferAttribute(i,3,3)),this},t.prototype.fromWireframeGeometry=function(e){return this.setPositions(e.attributes.position.array),this},t.prototype.fromEdgesGeometry=function(e){return this.setPositions(e.attributes.position.array),this},t.prototype.fromMesh=function(e){return this.fromWireframeGeometry(new d.WireframeGeometry(e.geometry)),this},t.prototype.fromLineSegments=function(e){var r=e.geometry;if(r instanceof d.Geometry){var i=new d.BufferGeometry().fromGeometry(r);this.setPositions(i.attributes.position.array)}else r instanceof d.BufferGeometry&&this.setPositions(r.attributes.position.array);return this},t.prototype.computeBoundingBox=function(){this.boundingBox===null&&(this.boundingBox=new d.Box3);var e=this.attributes.instanceStart,r=this.attributes.instanceEnd;if(e!==void 0&&r!==void 0){var i=new d.Box3;this.boundingBox.setFromBufferAttribute(e),i.setFromBufferAttribute(r),this.boundingBox.union(i)}},t.prototype.computeBoundingSphere=function(){this.boundingSphere===null&&(this.boundingSphere=new d.Sphere),this.boundingBox===null&&this.computeBoundingBox();var e=this.attributes.instanceStart,r=this.attributes.instanceEnd;if(e!==void 0&&r!==void 0){var i=this.boundingSphere.center;this.boundingBox.getCenter(i);for(var a=0,o=new d.Vector3,s=0,u=e.count;s<u;s++)o.fromBufferAttribute(e,s),a=Math.max(a,i.distanceToSquared(o)),o.fromBufferAttribute(r,s),a=Math.max(a,i.distanceToSquared(o));this.boundingSphere.radius=Math.sqrt(a),isNaN(this.boundingSphere.radius)&&console.error("THREE.LineSegmentsGeometry.computeBoundingSphere(): Computed radius is NaN. The instanced position data is likely to have NaN values.",this)}},t.prototype.toJSON=function(){},t}(d.InstancedBufferGeometry);Object.assign(uo.prototype,{isLineSegmentsGeometry:!0});var ca={uniforms:d.UniformsUtils.merge([d.UniformsLib.common,d.UniformsLib.fog,{linewidth:{value:1},resolution:{value:new d.Vector2(1,1)},dashScale:{value:1},dashSize:{value:1},gapSize:{value:1},opacity:{value:1}}]),vertexShader:`
|
|
1840
1840
|
#include <common>
|
|
1841
1841
|
#include <color_pars_vertex>
|
|
1842
1842
|
#include <fog_pars_vertex>
|
|
@@ -2035,7 +2035,7 @@ void main() {
|
|
|
2035
2035
|
#include <premultiplied_alpha_fragment>
|
|
2036
2036
|
|
|
2037
2037
|
}
|
|
2038
|
-
`},lo=function(n){de(t,n);function t(e){var r=n.call(this,{uniforms:d.UniformsUtils.clone(ca.uniforms),vertexShader:ca.vertexShader,fragmentShader:ca.fragmentShader,clipping:!0})||this;return r.type="LineMaterial",r.dashed=!1,Object.defineProperties(r,{color:{enumerable:!0,get:function(){return this.uniforms.diffuse.value},set:function(i){this.uniforms.diffuse.value=i}},linewidth:{enumerable:!0,get:function(){return this.uniforms.linewidth.value},set:function(i){this.uniforms.linewidth.value=i}},dashScale:{enumerable:!0,get:function(){return this.uniforms.dashScale.value},set:function(i){this.uniforms.dashScale.value=i}},dashSize:{enumerable:!0,get:function(){return this.uniforms.dashSize.value},set:function(i){this.uniforms.dashSize.value=i}},gapSize:{enumerable:!0,get:function(){return this.uniforms.gapSize.value},set:function(i){this.uniforms.gapSize.value=i}},opacity:{enumerable:!0,get:function(){return this.uniforms.opacity.value},set:function(i){this.uniforms.opacity.value=i}},resolution:{enumerable:!0,get:function(){return this.uniforms.resolution.value},set:function(i){this.uniforms.resolution.value.copy(i)}}}),r.setValues(e),r}return t}(d.ShaderMaterial);Object.assign(lo.prototype,{isLineMaterial:!0});var s0=function(n){de(t,n);function t(e,r){var i=n.call(this)||this;return i.type="LineSegments2",i.geometry=e!==void 0?e:new uo,i.material=r!==void 0?r:new lo({color:Math.random()*16777215}),i}return t.prototype.computeLineDistances=function(){for(var e=this.geometry,r=e.attributes.instanceStart,i=e.attributes.instanceEnd,a=new Float32Array(2*r.count),o=new d.Vector3,s=new d.Vector3,u=0,c=0,l=r.count;u<l;u++,c+=2)o.fromBufferAttribute(r,u),s.fromBufferAttribute(i,u),a[c]=c===0?0:a[c-1],a[c+1]=a[c]+o.distanceTo(s);var h=new d.InstancedInterleavedBuffer(a,2,1);return e.setAttribute("instanceDistanceStart",new d.InterleavedBufferAttribute(h,1,0)),e.setAttribute("instanceDistanceEnd",new d.InterleavedBufferAttribute(h,1,1)),this},t.prototype.raycast=function(e,r){e.camera===null&&console.error('LineSegments2: "Raycaster.camera" needs to be set in order to raycast against LineSegments2.');var i=e.ray,a=e.camera,o=a.projectionMatrix,s=this.geometry,u=this.material,c=u.resolution,l=u.linewidth,h=s.attributes.instanceStart,p=s.attributes.instanceEnd,v=new d.Vector4,m=new d.Vector4,A=new d.Vector4,y=new d.Vector3,f=new d.Matrix4,g=new d.Line3,b=new d.Vector3;i.at(1,A),A.w=1,A.applyMatrix4(a.matrixWorldInverse),A.applyMatrix4(o),A.multiplyScalar(1/A.w),A.x*=c.x/2,A.y*=c.y/2,A.z=0,y.copy(A);var w=this.matrixWorld;f.multiplyMatrices(a.matrixWorldInverse,w);for(var E=0,x=h.count;E<x;E++){v.fromBufferAttribute(h,E),m.fromBufferAttribute(p,E),v.w=1,m.w=1,v.applyMatrix4(f),m.applyMatrix4(f),v.applyMatrix4(o),m.applyMatrix4(o),v.multiplyScalar(1/v.w),m.multiplyScalar(1/m.w);var M=v.z<-1&&m.z<-1,C=v.z>1&&m.z>1;if(!(M||C)){v.x*=c.x/2,v.y*=c.y/2,m.x*=c.x/2,m.y*=c.y/2,g.start.copy(v),g.start.z=0,g.end.copy(m),g.end.z=0;var I=g.closestPointToPointParameter(y,!0);g.at(I,b);var P=d.MathUtils.lerp(v.z,m.z,I),S=P>=-1&&P<=1,F=y.distanceTo(b)<l*.5;if(S&&F){g.start.fromBufferAttribute(h,E),g.end.fromBufferAttribute(p,E),g.start.applyMatrix4(w),g.end.applyMatrix4(w);var k=new d.Vector3,O=new d.Vector3;i.distanceSqToSegment(g.start,g.end,O,k),r.push({point:O,pointOnLine:k,distance:i.origin.distanceTo(O),object:this,faceIndex:E})}}}},t}(d.Mesh);Object.assign(s0.prototype,{isLineSegments2:!0});var u0=function(n){de(t,n);function t(e,r){var i=n.call(this,e,r)||this;return i.type="Line2",i}return t}(s0);Object.assign(u0.prototype,{isLine2:!0});var l0=function(n){de(t,n);function t(){var e=n.call(this)||this;return e.type="LineGeometry",e}return t.prototype.setPositions=function(e){for(var r=e.length-3,i=new Float32Array(2*r),a=0;a<r;a+=3)i[2*a]=e[a],i[2*a+1]=e[a+1],i[2*a+2]=e[a+2],i[2*a+3]=e[a+3],i[2*a+4]=e[a+4],i[2*a+5]=e[a+5];return n.prototype.setPositions.call(this,i),this},t.prototype.setColors=function(e){for(var r=e.length-3,i=new Float32Array(2*r),a=0;a<r;a+=3)i[2*a]=e[a],i[2*a+1]=e[a+1],i[2*a+2]=e[a+2],i[2*a+3]=e[a+3],i[2*a+4]=e[a+4],i[2*a+5]=e[a+5];return n.prototype.setColors.call(this,i),this},t.prototype.fromLine=function(e){var r=e.geometry;if(r instanceof d.Geometry){var i=new d.BufferGeometry().fromGeometry(r);this.setPositions(i.attributes.position.array)}else r instanceof d.BufferGeometry&&this.setPositions(r.attributes.position.array);return this},t.prototype.copy=function(){return this},t}(uo);Object.assign(l0.prototype,{isLineGeometry:!0});var pp="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9sHDgwCEMBJZu0AAAAdaVRYdENvbW1lbnQAAAAAAENyZWF0ZWQgd2l0aCBHSU1QZC5lBwAABM5JREFUWMO1V0tPG2cUPZ4Hxh6DazIOrjFNqJs0FIMqWFgWQkatsmvVbtggKlSVRVf5AWz4AWz4AUSKEChll19QJYSXkECuhFxsHjEhxCYm+DWGMZ5HF72DJq4bAzFXurI0M/I5997v3u9cC65vTJVn2lX/xHINQOYSBLTLEuIuCWw4Z3IGAEvf6ASmVHjNzHCXBG4A0AjACsAOwEbO0nsFQBnAGYASAIl+ZRMR7SolMEdsByD09fV5R0ZGgg8ePPjW5/N1iqLYpuu6RZblciKR2I9Go69evnwZnZ+fjwI4IS8AKBIRzeQfJWCANwKwh0KhtrGxsYehUOin1tbW+zzP23ietzY2NnIAoGmaLsuyUiqVyvl8XtrY2NiamZn589mzZxsAUgCOAeQAnFI2tI+VxIjaAeDzoaGh7xYWFuZOTk6OZVk+12uYqqq6JEnn0Wg0OT4+/geAXwGEAdwDIFJQXC1wO4DWR48e/RCPxxclSSroVzRFUbSDg4P848ePFwH8DuAhkWih83TRQWxFOXgAwvDwcOfo6OhvXV1d39tsNtuVBwTDWBwOh1UUxVsMw1hXVlbSdCgNV43uYSvrHg6H24aHh38eHBz85TrgF9FYLHA4HLzH43FvbW2d7u/vG+dANp8FpqIlbd3d3V8Fg8EfBUFw4BONZVmL3+9vHhkZCQL4AoAHgJPK8G+yzC0XDofdoVAo5PP5vkadTBAEtr+/39ff3x8gAp/RPOEqx2qjx+NpvXv3bk9DQ0NDvQgwDIOWlhZrMBj8kgi0UJdxRgYMArzL5XJ7vd57qLPZ7Xamp6fnNgBXtQxcjFuHw+Hyer3t9SYgCAITCAScAJoBNNEY/08GOFVVrfVMv7kMNDntFD1vjIAPrlRN0xjckOm6biFQ3jwNPwDMZrOnqVTqfb3Bi8Wivru7W/VCYkwPlKOjo0IikXh7EwQikYgE4Nw0CfXKDCipVCoTj8df3QABbW1tLUc6oUgkFPMkVACUNjc337148eKvw8PDbJ2jP1taWkoCyNDVXDSECmNSK4qiKNLq6urW8+fPI/UicHx8rD59+jSVy+WOAKSJhKENwFItLtoxk8mwsixzHR0dHe3t7c5PAU+n09rs7OzJkydPYqVSaQfANoDXALIk31S2smU1TWMPDg7K5XKZ7+3t9TudTut1U7+wsFCcmJiIpdPpbQBxADsAknQWymYCOukBHYCuKApisdhpMpnURFEU79y503TVyKenpzOTk5M7e3t7MQKPV0Zv1gNm+awB0MvlshqLxfLb29uyJElWURSbXC4XXyvqxcXFs6mpqeTc3Nzu3t7e3wQcA7BPZ8Cov1pNlJplmQtAG8MwHV6v95tAINA5MDBwPxAIuLu6upr8fr/VAN3c3JQjkcjZ+vp6fnl5+d2bN29SuVzuNYAEpf01CdRChUL+X1VskHACuA3Ay3Fcu9vt7nA6nZ7m5uYWQRCaNE3jVVW15PP580KhIGUymWw2m00DOAJwSP4WwPtq4LX2Ao6USxNlQyS/RcQcdLGwlNIz6vEMAaZpNzCk2Pll94LK/cDYimxERiBwG10sxjgvEZBE0UpE6vxj+0Ct5bTaXthgEhRmja8QWNkkPGsuIpfdjpkK+cZUWTC0KredVmtD/gdlSl6EG4AMvQAAAABJRU5ErkJggg==",ks=14467195,vp=8,Ap=2,mp=20,Ls=null,Oa=function(n){de(t,n);function t(e,r){e===void 0&&(e=new d.Vector3),r===void 0&&(r=new d.Vector3);var i=n.call(this)||this;i.type="FiveLine",i.needsRender=!0;var a=new l0,o=new lo({color:ks,linewidth:Ap,dashScale:mp,dashed:!1});i.line=new u0(a,o);var s=new d.BufferGeometry,u=new d.PointsMaterial({color:ks,size:vp,map:Ls||(Ls=new d.TextureLoader().load(pp)),sizeAttenuation:!1,transparent:!0});return i.points=new d.Points(s,u),i.points.renderOrder=11,i.points.frustumCulled=!1,i.setPoints(e,r),i.add(i.line,i.points),i}return Object.defineProperty(t,"version",{get:function(){return"6.0.0-alpha.65"},enumerable:!1,configurable:!0}),t.prototype.setPoints=function(e,r){var i=[].concat(e.toArray(),r.toArray());this.points.geometry.setAttribute("position",new d.BufferAttribute(new Float32Array(i),3)),this.line.geometry.setPositions(i),this.line.computeLineDistances(),this.needsRender=!0},t.prototype.getPoints=function(){var e=this.points.geometry.attributes.position.array;return[new d.Vector3(e[0],e[1],e[2]),new d.Vector3(e[3],e[4],e[5])]},t.prototype.setMaterial=function(e){var r=this.line.material;for(var i in e)if(e.hasOwnProperty(i)){var a=e[i];i==="dashed"?(r.dashed=a,a?r.defines.USE_DASH="":delete r.defines.USE_DASH,r.needsUpdate=!0):r[i]=e[i]}this.needsRender=!0},t.prototype.setResolution=function(e,r){var i=this.line.material.resolution;(i.x!==e||i.y!==r)&&(i.set(e,r),this.needsRender=!0)},t}(d.Object3D);Object.assign(Oa.prototype,{isFiveLine:!0});var _e={Handedness:Object.freeze({NONE:"none",LEFT:"left",RIGHT:"right"}),ComponentState:Object.freeze({DEFAULT:"default",TOUCHED:"touched",PRESSED:"pressed"}),ComponentProperty:Object.freeze({BUTTON:"button",X_AXIS:"xAxis",Y_AXIS:"yAxis",STATE:"state"}),ComponentType:Object.freeze({TRIGGER:"trigger",SQUEEZE:"squeeze",TOUCHPAD:"touchpad",THUMBSTICK:"thumbstick",BUTTON:"button"}),ButtonTouchThreshold:.05,AxisTouchThreshold:.1,VisualResponseProperty:Object.freeze({TRANSFORM:"transform",VISIBILITY:"visibility"})};function c0(n){return Mi(this,void 0,void 0,function(){var t;return Ci(this,function(e){switch(e.label){case 0:return[4,fetch(n)];case 1:if(t=e.sent(),t.ok)return[2,t.json()];throw new Error(t.statusText)}})})}function gp(n){return Mi(this,void 0,void 0,function(){var t,e;return Ci(this,function(r){switch(r.label){case 0:if(!n)throw new Error("No basePath supplied");return t="profilesList.json",[4,c0("".concat(n,"/").concat(t))];case 1:return e=r.sent(),[2,e]}})})}function yp(n,t,e,r){return e===void 0&&(e=null),r===void 0&&(r=!0),Mi(this,void 0,void 0,function(){var i,a,o,s,u,c;return Ci(this,function(l){switch(l.label){case 0:if(!n)throw new Error("No xrInputSource supplied");if(!t)throw new Error("No basePath supplied");return[4,gp(t)];case 1:if(i=l.sent(),n.profiles.some(function(h){var p=i[h];return p&&(a={profileId:h,profilePath:"".concat(t,"/").concat(p.path),deprecated:!!p.deprecated}),!!a}),!a){if(!e)throw new Error("No matching profile name found");if(o=i[e],!o)throw new Error('No matching profile name found and default profile "'.concat(e,'" missing.'));a={profileId:e,profilePath:"".concat(t,"/").concat(o.path),deprecated:!!o.deprecated}}return[4,c0(a.profilePath)];case 2:if(s=l.sent(),r){if(c=void 0,c=s.layouts[n.handedness],!c)throw new Error("No matching handedness, ".concat(n.handedness,", in profile ").concat(a.profileId));c.assetPath&&(u=a.profilePath.replace("profile.json",c.assetPath))}return[2,{profile:s,assetPath:u}]}})})}var bp={xAxis:0,yAxis:0,button:0,state:_e.ComponentState.DEFAULT};function wp(n,t){n===void 0&&(n=0),t===void 0&&(t=0);var e=n,r=t,i=Math.sqrt(n*n+t*t);if(i>1){var a=Math.atan2(t,n);e=Math.cos(a),r=Math.sin(a)}var o={normalizedXAxis:e*.5+.5,normalizedYAxis:r*.5+.5};return o}var Ep=function(){function n(t){this.componentProperty=t.componentProperty,this.states=t.states,this.valueNodeName=t.valueNodeName,this.valueNodeProperty=t.valueNodeProperty,this.valueNodeProperty===_e.VisualResponseProperty.TRANSFORM&&(this.minNodeName=t.minNodeName,this.maxNodeName=t.maxNodeName),this.value=0,this.updateFromComponent(bp)}return n.prototype.updateFromComponent=function(t){var e=t.xAxis,r=t.yAxis,i=t.button,a=t.state,o=wp(e,r),s=o.normalizedXAxis,u=o.normalizedYAxis;switch(this.componentProperty){case _e.ComponentProperty.X_AXIS:this.value=this.states.includes(a)?s:.5;break;case _e.ComponentProperty.Y_AXIS:this.value=this.states.includes(a)?u:.5;break;case _e.ComponentProperty.BUTTON:this.value=this.states.includes(a)?i:0;break;case _e.ComponentProperty.STATE:this.valueNodeProperty===_e.VisualResponseProperty.VISIBILITY?this.value=this.states.includes(a):this.value=this.states.includes(a)?1:0;break;default:throw new Error("Unexpected visualResponse componentProperty ".concat(this.componentProperty))}},n}(),xp=function(){function n(t,e){var r=this;if(!t||!e||!e.visualResponses||!e.gamepadIndices||Object.keys(e.gamepadIndices).length===0)throw new Error("Invalid arguments supplied");this.id=t,this.type=e.type,this.rootNodeName=e.rootNodeName,this.touchPointNodeName=e.touchPointNodeName,this.visualResponses={},Object.keys(e.visualResponses).forEach(function(i){var a=new Ep(e.visualResponses[i]);r.visualResponses[i]=a}),this.gamepadIndices=Object.assign({},e.gamepadIndices),this.values={state:_e.ComponentState.DEFAULT,button:this.gamepadIndices.button!==void 0?0:void 0,xAxis:this.gamepadIndices.xAxis!==void 0?0:void 0,yAxis:this.gamepadIndices.yAxis!==void 0?0:void 0}}return Object.defineProperty(n.prototype,"data",{get:function(){var t=R({id:this.id},this.values);return t},enumerable:!1,configurable:!0}),n.prototype.updateFromGamepad=function(t){var e=this;if(this.values.state=_e.ComponentState.DEFAULT,this.gamepadIndices.button!==void 0&&t.buttons.length>this.gamepadIndices.button){var r=t.buttons[this.gamepadIndices.button];this.values.button=r.value,this.values.button=this.values.button<0?0:this.values.button,this.values.button=this.values.button>1?1:this.values.button,r.pressed||this.values.button===1?this.values.state=_e.ComponentState.PRESSED:(r.touched||this.values.button>_e.ButtonTouchThreshold)&&(this.values.state=_e.ComponentState.TOUCHED)}this.gamepadIndices.xAxis!==void 0&&t.axes.length>this.gamepadIndices.xAxis&&(this.values.xAxis=t.axes[this.gamepadIndices.xAxis],this.values.xAxis=this.values.xAxis<-1?-1:this.values.xAxis,this.values.xAxis=this.values.xAxis>1?1:this.values.xAxis,this.values.state===_e.ComponentState.DEFAULT&&Math.abs(this.values.xAxis)>_e.AxisTouchThreshold&&(this.values.state=_e.ComponentState.TOUCHED)),this.gamepadIndices.yAxis!==void 0&&t.axes.length>this.gamepadIndices.yAxis&&(this.values.yAxis=t.axes[this.gamepadIndices.yAxis],this.values.yAxis=this.values.yAxis<-1?-1:this.values.yAxis,this.values.yAxis=this.values.yAxis>1?1:this.values.yAxis,this.values.state===_e.ComponentState.DEFAULT&&Math.abs(this.values.yAxis)>_e.AxisTouchThreshold&&(this.values.state=_e.ComponentState.TOUCHED)),Object.values(this.visualResponses).forEach(function(i){i.updateFromComponent(e.values)})},n}(),Mp=function(){function n(t,e,r){var i=this;if(!t)throw new Error("No xrInputSource supplied");if(!e)throw new Error("No profile supplied");this.xrInputSource=t,this.assetUrl=r,this.id=e.profileId,this.layoutDescription=e.layouts[t.handedness],this.components={},Object.keys(this.layoutDescription.components).forEach(function(a){var o=i.layoutDescription.components[a];i.components[a]=new xp(a,o)}),this.updateFromGamepad()}return Object.defineProperty(n.prototype,"gripSpace",{get:function(){return this.xrInputSource.gripSpace},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"targetRaySpace",{get:function(){return this.xrInputSource.targetRaySpace},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"data",{get:function(){var t=[];return Object.values(this.components).forEach(function(e){t.push(e.data)}),t},enumerable:!1,configurable:!0}),n.prototype.updateFromGamepad=function(){var t=this;Object.values(this.components).forEach(function(e){e.updateFromGamepad(t.xrInputSource.gamepad)})},n}(),Cp="https://cdn.jsdelivr.net/npm/@webxr-input-profiles/assets@1.0/dist/profiles",Ip="generic-trigger",Sp=function(n){de(t,n);function t(){var e=n.call(this)||this;return e.motionController=null,e.envMap=null,e}return t.prototype.setEnvironmentMap=function(e){var r=this;return this.envMap==e?this:(this.envMap=e,this.traverse(function(i){i instanceof d.Mesh&&i.isMesh&&(i.material.envMap=r.envMap,i.material.needsUpdate=!0)}),this)},t.prototype.updateMatrixWorld=function(e){n.prototype.updateMatrixWorld.call(this,e),this.motionController&&(this.motionController.updateFromGamepad(),Object.values(this.motionController.components).forEach(function(r){Object.values(r.visualResponses).forEach(function(i){var a=i.valueNode,o=i.minNode,s=i.maxNode,u=i.value,c=i.valueNodeProperty;a&&(c===_e.VisualResponseProperty.VISIBILITY?a.visible=u:c===_e.VisualResponseProperty.TRANSFORM&&(a.quaternion.copy(o.quaternion).slerp(s.quaternion,u),a.position.lerpVectors(o.position,s.position,u)))})}))},t}(Sn.Object3D);function Tp(n,t){Object.values(n.components).forEach(function(e){var r=e.type,i=e.touchPointNodeName,a=e.visualResponses;if(r===_e.ComponentType.TOUCHPAD)if(e.touchPointNode=t.getObjectByName(i),e.touchPointNode){var o=new Sn.SphereGeometry(.001),s=new Sn.MeshBasicMaterial({color:255}),u=new Sn.Mesh(o,s);e.touchPointNode.add(u)}else console.warn("Could not find touch dot, ".concat(e.touchPointNodeName,", in touchpad component ").concat(e.id));Object.values(a).forEach(function(c){var l=c.valueNodeName,h=c.minNodeName,p=c.maxNodeName,v=c.valueNodeProperty;if(v===_e.VisualResponseProperty.TRANSFORM){if(c.minNode=t.getObjectByName(h),c.maxNode=t.getObjectByName(p),!c.minNode){console.warn("Could not find ".concat(h," in the model"));return}if(!c.maxNode){console.warn("Could not find ".concat(p," in the model"));return}}c.valueNode=t.getObjectByName(l),c.valueNode||console.warn("Could not find ".concat(l," in the model"))})})}function Ds(n,t){Tp(n.motionController,t),n.envMap&&t.traverse(function(e){e instanceof d.Mesh&&e.isMesh&&(e.material.envMap=n.envMap,e.material.needsUpdate=!0)}),n.add(t)}var Pp=function(){function n(t){t===void 0&&(t=null),this.gltfLoader=t,this.path=Cp,this._assetCache={}}return n.prototype.createControllerModel=function(t){var e=this,r=new Sp,i=null;return t.addEventListener("connected",function(a){var o=a.data;o.targetRayMode!=="tracked-pointer"||!o.gamepad||yp(o,e.path,Ip).then(function(s){var u=s.profile,c=s.assetPath;r.motionController=new Mp(o,u,c);var l=e._assetCache[r.motionController.assetUrl];if(l)i=l.scene.clone(),Ds(r,i);else{if(!e.gltfLoader)throw new Error("GLTFLoader not set.");e.gltfLoader.load(r.motionController.assetUrl,function(h){e._assetCache[r.motionController.assetUrl]=h,i=h.scene.clone(),Ds(r,i)})}}).catch(function(s){console.warn(s)})}),t.addEventListener("disconnected",function(){r.motionController=null,r.remove(i),i=null}),r},n}();function Bp(n,t){if(!t)return n;var e=n.match(/\d+_[a-z].png/);return n.substring(0,e.index)+t+"/"+n.substring(e.index)}var Ns=300,Rp=new d.Matrix4().makeRotationAxis(new d.Vector3(0,1,0),Math.PI),Qs=new d.Vector3(-1,1,1),Fp=function(n){de(t,n);function t(e){var r,i=n.call(this,e)||this;i.xrManager=new hp(i.renderer,i.renderer.getContext(),{onSessionStart:function(c){i.emit("xr.session.start",_("xr.session.start",{session:c,machineType:i.xrManager.machineType}))},onSessionEnd:function(){i.emit("xr.session.end",_("xr.session.end",{session:null,machineType:i.xrManager.machineType}))}}),i.xrControllerRay={left:new d.Raycaster,right:new d.Raycaster},i.xrControllerRay.left.params.Points={threshold:.1},i.xrControllerRay.right.params.Points={threshold:.1},i.pointerLines={left:new Oa,right:new Oa},i.pointerLines.left.visible=!1,i.pointerLines.right.visible=!0,i.pointerLines.left.setMaterial({color:new d.Vector3(1,1,1)}),i.pointerLines.left.points.material.depthTest=!1,i.pointerLines.right.setMaterial({color:new d.Vector3(1,1,1)}),i.pointerLines.right.points.material.depthTest=!1,i.scene.add(i.pointerLines.left,i.pointerLines.right),i.panoResources={},i.panoResources[i.locationMotion.keyframes[0].key=i.locationMotion.keyframes[1].key=vt()]={panoId:Be(i.currentPano),leftPanoPicture:null,position:i.camera.pose.offset.clone(),effect:"fade"},i.parallaxCameraMatrixs=[],i.onlyUseRightController=(r=e.onlyUseRightController)!==null&&r!==void 0?r:!1;var a=it.shared.getContext();if(!a)return console.error("获取session失败,请退出重试"),i;i.on("xr.session.end",function(){i.scene.remove(i.pointerLines.left,i.pointerLines.right)}),i.xrManager.setSession(a),i.controllerWrappers=[new d.Group,new d.Group],i.scene.add(i.controllerWrappers[0],i.controllerWrappers[1]);var o=i.xrManager.getController(0);i.controllerWrappers[0].add(o);var s=i.xrManager.getController(1);i.controllerWrappers[1].add(s);var u=new Pp;return u.gltfLoader={load:function(c,l){ci.ajax(c,{responseType:"arraybuffer"}).then(function(h){var p;return Ga(h.body,{resourcePath:c.slice(0,c.lastIndexOf("/")+1),search:(p=c.split("?")[1])!==null&&p!==void 0?p:"",fetcher:ci})}).then(function(h){return l(h)})}},i.on("xr.session.start",function(){var c=i.xrManager.getControllerGrip(0);if(c.add(u.createControllerModel(c)),i.controllerWrappers[0].add(c),!i.onlyUseRightController){var l=i.xrManager.getControllerGrip(1);l.add(u.createControllerModel(l)),i.controllerWrappers[1].add(l)}}),i.xrControllerState={LeftAxesUp:{touchStartTime:0,touchStart:!1},LeftAxesDown:{touchStartTime:0,touchStart:!1},LeftAxesLeft:{touchStartTime:0,touchStart:!1},LeftAxesRight:{touchStartTime:0,touchStart:!1},LeftTrigger:{touchStartTime:0,touchStart:!1},LeftPinch:{touchStartTime:0,touchStart:!1},RightAxesUp:{touchStartTime:0,touchStart:!1},RightAxesDown:{touchStartTime:0,touchStart:!1},RightAxesLeft:{touchStartTime:0,touchStart:!1},RightAxesRight:{touchStartTime:0,touchStart:!1},RightTrigger:{touchStartTime:0,touchStart:!1},RightPinch:{touchStartTime:0,touchStart:!1},Y:{touchStartTime:0,touchStart:!1},X:{touchStartTime:0,touchStart:!1},A:{touchStartTime:0,touchStart:!1},B:{touchStartTime:0,touchStart:!1}},i}return t.parseArgs=function(e){if(e instanceof t)return e;var r=R(R({},e),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2});return n.parseArgs.call(this,r)},t.initAnimationEndState=function(e){var r=this.parseArgs(e),i=n.initAnimationEndState.call(this,r);return R(R({},i),{mode:"XRPanorama"})},t.prototype.moveToPano=function(e,r,i){var a=this,o,s,u,c;this.userAction=i,this.stopMomentumMovement();var l=this.works.getResolvedObserver(e);if(!l)throw new Error("Invalid PanoIndex");var h=this.imageOptions.size;if(typeof h>"u"&&l){var p=l.images.up.match(/\/cube_(\d+)\//);p&&(h=Number(p[1]))}typeof h>"u"&&(h=2048);var v=this.imageOptions.transform,m=function(P,S){return Bp(di(P,v,S))},A=R({key:"pano.".concat(l.panoId)},sr(this.imageOptions,["format","size","quality"])),y=l.images,f=(s=(o=l.images.tiles)===null||o===void 0?void 0:o.filter(function(P){return P.size>h}))!==null&&s!==void 0?s:null,g="pano:"+fn([y,A,v]);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===g)return;var b=this.pendingTextureTask.panoId;(u=this.panoMeshes[b])===null||u===void 0||u.setProgress(0),this.emit("pano.texture.abort",_("pano.texture.abort",{error:null,progress:0,meta:null,pano:l.pano})),this.pendingTextureTask.onError(new Error("texture aborted"))}var w=this.models.getMaterial()||{},E=w.pano0,x=w.pano1,M;if((E==null?void 0:E.map.name)===g?M=E:(x==null?void 0:x.map.name)===g&&(M=x),M){var C={panoId:l.panoId,effect:(c=r.effect)!==null&&c!==void 0?c:"fade",leftPanoPicture:{map:M.map,luminanceMap:M.luminanceMap,matrix:new d.Matrix4().compose(l.position,l.quaternion,Qs)},position:l.position.clone()};this.doMoveToPano(l.pano,C,r);return}var I="move-to-pano-"+l.panoId;this.pending.add(I),this.pendingTextureTask={panoId:l.panoId,hash:g,onLoad:function(P){var S;if(a.pending.delete(I),a.destroyed)P.body.dispose();else{P.body.name=g;var F={panoId:l.panoId,effect:(S=r.effect)!==null&&S!==void 0?S:"fade",leftPanoPicture:{map:P.body,luminanceMap:null,matrix:new d.Matrix4().compose(l.position,l.quaternion,Qs)},position:l.position.clone()};a.doMoveToPano(l.pano,F,r)}},onError:function(P){a.pending.delete(I);var S=R(R(R({},l.pano),{mode:a.mode}),Ve(a.camera.pose));a.emit("pano.error",_("pano.error",{error:P,userAction:a.userAction,options:r,prevPano:a.currentPano,progress:0,state:S})),a.emit("pano.cancel",_("pano.cancel",{error:null,userAction:a.userAction,options:r,prevPano:a.currentPano,progress:0,state:S})),r.moveCancelCallback&&r.moveCancelCallback()}},Promise.all([this.tileLevelForFov&&f&&f.length?this.textureLoader.loadTiledCubeTexture(y,f,{tileMaxLevel:this.TILED_CUBE_TEXTURE_LEVEL,imageURL:{transform:m,options:A},format:d.RGBAFormat,viaAjax:!0,fetcher:pt(l.work)},void 0,void 0,function(P){var S,F;a.emit("pano.texture.progress",_("pano.texture.progress",{error:null,progress:P,meta:null,pano:l.pano})),((S=a.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&((F=a.panoMeshes[l.panoId])===null||F===void 0||F.setProgress(P))},this.renderer):this.textureLoader.loadCubeTexture(y,{imageURL:{transform:m,options:A},format:d.RGBAFormat,fetcher:pt(l.work)},void 0,void 0,function(P){var S,F;((S=a.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&((F=a.panoMeshes[l.panoId])===null||F===void 0||F.setProgress(P)),a.emit("pano.texture.progress",_("pano.texture.progress",{error:null,progress:P,meta:null,pano:l.pano}))},this.renderer)]).then(function(P){var S,F,k=P[0];((S=a.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g?(a.pendingTextureTask.onLoad(k),(F=a.panoMeshes[l.panoId])===null||F===void 0||F.setProgress(0),delete a.pendingTextureTask,a.emit("pano.texture.success",_("pano.texture.success",{error:null,progress:1,meta:k.meta,pano:l.pano}))):k.body.dispose()}).catch(function(P){var S,F;((S=a.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&(a.pendingTextureTask.onError(P),(F=a.panoMeshes[l.panoId])===null||F===void 0||F.setProgress(0),delete a.pendingTextureTask,a.emit("pano.texture.error",_("pano.texture.error",{error:P,progress:0,meta:null,pano:l.pano})),a.emit("error",P))}),this.emit("pano.texture.load",_("pano.texture.load",{error:null,progress:0,meta:null,pano:l.pano}))},t.prototype.doMoveToPano=function(e,r,i){var a=this,o,s,u;i===void 0&&(i={});var c=ve(),l=vt();this.panoResources[l]=r;var h=1,p,v,m;if(this.locationMotion.ended){var A=this.locationMotion.getKeyFrameSegment(c);A[0];var y=A[1],f=this.locationMotion.value,g=this.panoResourceFromLocationMotionKeyframe(y).position,b=r.position;p=Math.max(g.distanceTo(b),h),v=[{key:y.key,progress:0,value:R(R({},f),{count:0})},{key:l,progress:1,value:{distance:0,count:1}}],m=0}else{var w=this.locationMotion.getKeyFrameSegment(c),E=w[0],y=w[1],f=this.locationMotion.value,x=this.panoResourceFromLocationMotionKeyframe(E).position,g=this.panoResourceFromLocationMotionKeyframe(y).position,b=r.position,M=y.value.count-f.count,C=Math.max(x.distanceTo(g),h)*M,I=Math.max(g.distanceTo(b),h);p=C+I,v=[{key:E.key,progress:0,value:R({},f)},{key:y.key,progress:C/p,value:y.value},{key:l,progress:1,value:{count:y.value.count+1,distance:0}}];var P=this.locationMotionKeyframesLength(this.locationMotion.keyframes),S=this.locationMotionKeyframesLength(v);m=this.locationMotion.getProgressVelocity(c)*P/S}var F=this.calculateMovingDuration(i.duration,p),k={longitude:i.longitude,latitude:i.latitude,fov:i.fov},O=R(R({},e),{mode:this.mode,longitude:(o=k.longitude)!==null&&o!==void 0?o:this.camera.pose.longitude,latitude:(s=k.latitude)!==null&&s!==void 0?s:this.camera.pose.latitude,fov:(u=k.fov)!==null&&u!==void 0?u:this.camera.pose.fov,offset:r.position.clone(),distance:0}),L=this.currentPano;this.emit("pano.moveTo",_("pano.moveTo",{options:i,prevPano:L,progress:0,state:O,userAction:this.userAction,error:null})),i.moveStartCallback&&i.moveStartCallback(O),this.videoTexture&&this.videoTexture.image instanceof HTMLVideoElement&&this.videoTexture.image.getAttribute("src")&&(this.videoTexture.image.pause(),this.videoTexture.image.removeAttribute("uuid"),this.videoTexture.image.removeAttribute("src"),this.videoTexture.image.oncanplay=Q,this.videoTexture.needsUpdate=!0),this.panoVideo.setMaterial(null),this.cameraMotion.set(k,F).catch(Q);var N=this.locationMotion.setKeyframes(v,F,m);N.then(function(){var V,j,z,U=R(R({},e),{mode:a.mode,longitude:a.camera.pose.longitude,latitude:a.camera.pose.latitude,fov:a.camera.pose.fov,offset:a.camera.pose.offset.clone(),distance:0});a.emit("pano.arrived",_("pano.arrived",{options:i,prevPano:L,progress:1,state:U,userAction:a.userAction,error:null})),i.moveEndCallback&&i.moveEndCallback(U);var X=a.works.getResolvedObserver(a.currentPano);if(X&&X.video&&a.videoTexture&&a.videoTexture.image instanceof HTMLVideoElement){var G=Rp.clone().multiply((z=(j=(V=a.models.getMaterial())===null||V===void 0?void 0:V.pano1)===null||j===void 0?void 0:j.matrix)!==null&&z!==void 0?z:new d.Matrix4).multiply(X.video.matrix),K={map:a.videoTexture,size:X.video.size,matrix:G,alpha:1},Y=vt(),H=a.videoTexture.image;H.setAttribute("uuid",Y),Ju().then(function(J){J&&X.video&&H.getAttribute("uuid")===Y&&(H.oncanplay=function(){H.oncanplay=Q,H.play()},H.ontimeupdate=function(){H.currentTime>.5&&(H.ontimeupdate=Q,a.panoVideo.setMaterial(K))},H.src=X.video.source)}).catch(function(){H.removeAttribute("uuid")})}},function(){a.emit("pano.cancel",_("pano.cancel",{options:i,prevPano:L,progress:0,state:O,userAction:a.userAction,error:null})),i.moveCancelCallback&&i.moveCancelCallback()})},t.prototype.checkSelectedPano=function(e){var r=this,i,a,o,s;this.stopMomentumMovement();var u=this.camera.getDirection(new d.Vector3).setY(0),c=null,l=this.works.getResolvedObserver(this.currentPano);if(!l)return null;var h=l.accessibleIds.filter(function(Y){var H=Ye(Y);if(Ft(H,r.currentPano))return!1;var J=r.works.getResolvedObserver(H);return!J||J.position.distanceTo(r.camera.position)>r.maxAccessibleDistance?!1:J.loadable||J.active}),p=this.models.intersectRaycaster(e)[0];if(p){var v=Ot(h,function(Y){var H=r.works.getResolvedObserver(Y);if(!H)return 1/0;var J=H.standingPosition.clone();return J.distanceTo(p.point)},!0),m=v[0],A=v[1];m&&A<this.panoTapTriggerRadius&&(c=(i=this.works.getResolvedObserver(m))!==null&&i!==void 0?i:null)}if(Fs(c)){var y=this.getForwardObserverOrNot(e);y&&(c=y)}for(var f=0,g=this.locationMotion.keyframes;f<g.length;f++){var b=g[f],w=this.panoResourceFromLocationMotionKeyframe(b);if(!(b.progress<this.locationMotion.progress)&&c&&w.panoId===c.panoId){c=null;break}}if(Fs(c))return this.locationMotion.ended===!0&&this.cameraBounce(),null;if(c&&!c.active){var E=c.panoId;this.panoMeshes[E]&&(this.panoMeshes[E].setDisabled(!1),this.panoMeshes[E].setLoading(!0))}var x={};if(c){x.effect="fade";for(var M=Math.PI/6,C=Math.PI/12,I=new d.Vector3(0,1,0),P=c.position.clone().setY(0).sub(l.position.clone().setY(0)).normalize(),S=P.clone().applyAxisAngle(I,M),F=P.clone().applyAxisAngle(I,-M),k=[],O=[],L=[],N=0,V=c.accessibleIds;N<V.length;N++){var m=V[N],j=Ye(m);if(!(Ft(j,this.currentPano)||Ft(j,c.pano))){var z=this.works.getResolvedObserver(m);if(z){var U=z.position.clone().sub(c.position).setY(0);P.angleTo(U)<M?L.push(U):S.angleTo(U)<M?k.push(U):F.angleTo(U)<M&&O.push(U)}}}var X=L.length>0?L:at(at([],k,!0),O,!0),G=X.slice().sort(function(Y,H){return Y.angleTo(P)-H.angleTo(P)})[0];G&&G.angleTo(u)>C&&(x.longitude=Math.atan2(-G.x,-G.z))}this.cameraMotion.value.latitude<-Math.PI/4&&(x.latitude=le(0,this.minLatitude,this.maxLatitude)),this.cameraMotion.value.fov<60&&(x.fov=this.defaultFov);var K={workCode:c.pano.workCode,panoIndex:c.pano.panoIndex,mode:this.mode,longitude:(a=x.longitude)!==null&&a!==void 0?a:this.camera.pose.longitude,latitude:(o=x.latitude)!==null&&o!==void 0?o:this.camera.pose.latitude,fov:(s=x.fov)!==null&&s!==void 0?s:this.camera.pose.fov,distance:0,offset:c?c.position.clone():new d.Vector3};return this.emit("pano.select",_("pano.select",{prevPano:this.currentPano,state:K,userAction:!0,options:x,progress:0,error:null})),c&&c.active?(this.emit("pano.request",_("pano.request",{userAction:!0,prevPano:this.currentPano,progress:0,state:K,options:x,error:null})),c.pano):null},t.prototype.destroy=function(){n.prototype.destroy.call(this)},t.prototype.isReady=function(){return!1},t.prototype.updateCamera=function(e,r,i){return Promise.resolve()},t.prototype.updateCameraWithKeyframes=function(e,r,i){return Promise.resolve()},t.prototype.updateTime=function(e,r){for(var i=this,a,o,s,u,c,l,h,p,v=[],m=2;m<arguments.length;m++)v[m-2]=arguments[m];this.userAction=!0;var A={},y={},f=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[0]),g=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[this.locationMotion.keyframes.length-1]),b=!1;if(this.cameraMotion.ended===!1&&(this.cameraMotion.update(e),y.longitude=this.cameraMotion.value.longitude,y.latitude=this.cameraMotion.value.latitude,y.fov=this.cameraMotion.value.fov),this.modelAlphaMotion.ended===!1&&(this.modelAlphaMotion.update(e),A.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(le(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);var w=this.locationMotion.getKeyFrameSegment(e),E=w[0],x=w[1],M=this.panoResourceFromLocationMotionKeyframe(E),C=this.panoResourceFromLocationMotionKeyframe(x),I=new d.Vector3().copy(M.position),P=new d.Vector3().copy(C.position),S=this.locationMotion.value.count-x.value.count+1;A.progress=S,C.leftPanoPicture&&(S<1?M.leftPanoPicture&&(A.pano0=M.leftPanoPicture):A.pano0=C.leftPanoPicture,A.pano1=C.leftPanoPicture),b=A.useBlackTransition=C.effect==="instant"||C.effect==="montage",(C.effect==="fade"||C.effect==="montage")&&(A.pano0&&M.leftPanoPicture&&(A.pano0={map:A.pano0.map,luminanceMap:A.pano0.luminanceMap,matrix:M.leftPanoPicture.matrix.clone().setPosition(C.position)}),I.copy(P)),y.distance=this.locationMotion.value.distance,y.offset=new d.Vector3(I.x+(P.x-I.x)*S,I.y+(P.y-I.y)*S,I.z+(P.z-I.z)*S);for(var F=[],k=[],O=0,L=this.locationMotion.keyframes;O<L.length;O++){var N=L[O],V=N.key,j=N.progress;V!==void 0&&(F.push(V),j>=this.locationMotion.progress&&k.push(V))}for(var z=0,U=Object.keys(this.panoResources);z<U.length;z++){var X=U[z];if(!(k.indexOf(X)>=0)){var G=this.panoResources[X];if(G.leftPanoPicture){var K=G.leftPanoPicture.map;if(K){if(K===((a=A.pano0)===null||a===void 0?void 0:a.map)||K===((o=A.pano1)===null||o===void 0?void 0:o.map))continue;K instanceof Qe&&K.cubeRenderTarget&&this.colorCubeRenderTargetPool.push(K.cubeRenderTarget),K.dispose(),G.leftPanoPicture=null}}F.indexOf(X)>=0||delete this.panoResources[X]}}this.currentPano=Ye(C.panoId),this.emit("pano.moving",_("pano.moving",{userAction:this.userAction,prevPano:Ye(f.panoId),state:R(R(R(R({},Ye(g.panoId)),{mode:this.mode}),Ve(this.camera.pose)),y),options:{},progress:this.locationMotion.progress,error:null}))}St(A)===!1&&(!((s=A.pano0)===null||s===void 0)&&s.map&&A.pano0.map instanceof Qe&&!A.pano0.map.cubeRenderTarget&&(A.pano0.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((u=A.pano1)===null||u===void 0)&&u.map&&A.pano1.map instanceof Qe&&!A.pano1.map.cubeRenderTarget&&(A.pano1.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),this.models.setMaterial(A)),St(y)===!1&&this.setCamera(y);var Y=this.works.getResolvedObserver(this.currentPano),H=v[1];if(!H){console.error("xrFrame丢失,请重试");return}if(!this.xrManager.session){console.error("session丢失,请重试");return}var J=this.xrManager.referenceSpace;if(J){var ne=this.xrManager.cameraVR,$=this.xrManager.cameraL,te=this.xrManager.cameraR,ae=[$,te],ce=H.getViewerPose(J),oe=new d.Vector3(0,0,0);if(ce){var fe;fe=this.xrManager.session.renderState.baseLayer;var Ie=ce.views;if(!fe){console.error("no layer found");return}this.renderer.setFramebuffer(fe.framebuffer);var Ae=!1;Ie.length!==ne.cameras.length&&(ne.cameras.length=0,Ae=!0),this.parallaxCameraMatrixs=[];var Fe=new d.Vector3,re=new d.Vector3;new d.Matrix4().fromArray(Ie[0].transform.matrix).decompose(Fe,new d.Quaternion,new d.Vector3),new d.Matrix4().fromArray(Ie[1].transform.matrix).decompose(re,new d.Quaternion,new d.Vector3),re.clone().sub(Fe).normalize();var he=new d.Vector3,W=new d.Quaternion,Oe=new d.Vector3;this.camera.matrix.decompose(he,W,Oe);for(var ke=0;ke<Ie.length;ke++){var Je=Ie[ke],Ze=fe.getViewport(Je),De=ae[ke];De.matrix.fromArray(Je.transform.matrix);var We=new d.Vector3,Le=new d.Quaternion,ye=new d.Vector3;De.matrix.decompose(We,Le,ye),oe.copy(he),De.position.copy(he),De.quaternion.copy(Le),De.scale.copy(ye),De.updateMatrix(),De.projectionMatrix.fromArray(Je.projectionMatrix),De.viewport.set(Ze.x,Ze.y,Ze.width,Ze.height),Ae===!0&&ne.cameras.push(De)}ce.views[0].transform.position,ce.views[1].transform.position;for(var me=this.xrManager.session.inputSources,ke=0;ke<this.xrManager.controllers.length;ke++){var lt=this.xrManager.controllers[ke],Se=me[ke];if(Se){lt.update(Se,H,J);var $e=this.xrManager.getController(ke),Ue=new d.Vector3(0,1.2,0),At=$e.position.clone().add(oe).sub(Ue);Se.handedness==="left"?this.xrControllerRay.left.set(At,new d.Vector3(0,0,-1).applyEuler($e.rotation)):Se.handedness==="right"&&this.xrControllerRay.right.set(At,new d.Vector3(0,0,-1).applyEuler($e.rotation)),this.controllerWrappers[ke].position.copy(new d.Vector3(0,0,0).add(oe).sub(Ue));var Ke=this.models.intersectRaycaster(this.xrControllerRay.right);if(Ke.length===0&&(Ke=this.xrControllerRay.right.intersectObject(this.boundingMesh,!0).map(function(ft){var Et;return R({floor:(Et=Y==null?void 0:Y.floorIndex)!==null&&Et!==void 0?Et:0},ft)})),Ke.length>=1&&Ke[0].face)if(Se.handedness==="right"){var Gt=this.xrControllerRay.right.intersectObject(this.xrCustomObjectsScene,!0),Kt=Ke[0].face.normal,ze=Kt.clone().multiplyScalar(.05),ot=Ke[0].point.clone().add(ze);this.intersectMesh.position.copy(ot);var $t=ot.clone().add(ze);if(this.intersectMesh.lookAt($t),Math.abs(Kt.y)>.99){var He=this.camera.position.clone().sub(ot);this.intersectMesh.rotation.z=-Math.atan2(He.z,He.x)}this.intersectMesh.visible=!0,this.needsRender=!0,Gt.length>0?(this.pointerLines.right.setPoints(At,Gt[0].point),this.pointerLines.right.points.visible=!0,this.intersectMesh.visible=!1):(this.pointerLines.right.points.visible=!1,this.pointerLines.right.setPoints(At,Ke[0].point));var ct=Ke[0],wt=_("intersect.update",{raycaster:(c=this.xrControllerRay.right)!==null&&c!==void 0?c:null,intersection:ct??null,object:this.intersectMesh});if(this.emit("intersect.update",wt),wt.defaultPrevented){this.hideIntersectMesh();return}}else this.pointerLines.left.setPoints(At,Ke[0].point)}}if(this.camera.pose.distance>.1||b){if(Y)for(var Tt=0,er=Object.keys(this.panoMeshes);Tt<er.length;Tt++){var mt=er[Tt],Te=this.panoMeshes[mt];Te.setOpacity(0),Te.setCurrent(!1),Te.updateTime&&Te.updateTime(e,r)}}else if(Y){var wr=Ot(Y.visibleIds,function(st){var ft=i.works.getResolvedObserver(st);return ft?Y.standingPosition.distanceTo(ft.standingPosition):1/0},!0),kt=wr[1];kt=le(kt,2.5,1/0);for(var ur=Y.visibleIds.concat(Be(this.currentPano)),Lt=this.getForwardObserverOrNot(),mn=this.camera.getDirection(new d.Vector3),Qr=0,Vr=Object.keys(this.panoMeshes);Qr<Vr.length;Qr++){var mt=Vr[Qr],Te=this.panoMeshes[mt],lr=this.works.getResolvedObserver(mt);if(ur.indexOf(mt)===-1)Te.setCurrent(!1),Te.setOpacity(0);else if(!lr)Te.setCurrent(!1),Te.setOpacity(0);else if(!lr.loadable&&!lr.active)Te.setCurrent(!1),Te.setOpacity(0);else{var cr=Te.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);Te.setCurrent(!Te.loading&&Te.progress===0&&Lt!==null&&Lt.panoId===mt),Te.setOpacity(cr<.01?0:le(kt/cr*1.2,.65,.98));var rt=this.camera.position.clone().setY(Te.position.y),Xe=new d.Vector3().copy(Te.position).sub(rt).normalize();if(mt===Be(this.currentPano)){var Dt=le((.5-rt.distanceTo(Te.position))/.5,0,1);Xe.multiplyScalar(1-Dt).add(mn.clone().multiplyScalar(Dt))}Xe.length()>0&&Te.quaternion.setFromEuler(new d.Euler(0,Math.atan2(Xe.x,Xe.z),0))}Te.updateTime&&Te.updateTime(e,r)}}var dr=function(){if(i.tileLevelForFov===!1)return 0;var st=new d.Vector2(4e3,4e3),ft=g.panoId,Et=i.works.getResolvedObserver(ft),xt=i.imageOptions.size;if(typeof xt>"u"&&Et){var zn=Et.images.up.match(/\/cube_(\d+)\//);zn&&(xt=Number(zn[1]))}typeof xt>"u"&&(xt=2048);var qr=0;xt>=1024&&(qr=1),xt>=2048&&(qr=2),xt>=4096&&(qr=3),xt>=8192&&(qr=4);var zr=i.tileLevelForFov($.fov,st);return zr>qr?zr:0}(),gn=function(){var st=new d.PerspectiveCamera;st.applyMatrix4(ne.matrix),st.position.set(0,0,0);var ft=i.works.getResolvedObserver(g.panoId),Et=ft??Y;Et&&st.quaternion.premultiply(Et.quaternion.clone().inverse()),st.updateProjectionMatrix(),st.updateMatrixWorld(!0);var xt=new d.Frustum().setFromProjectionMatrix(new d.Matrix4().multiplyMatrices(st.projectionMatrix,st.matrixWorldInverse));return xt}();g.panoId===Be(this.currentPano)&&((l=g.leftPanoPicture)===null||l===void 0?void 0:l.map)instanceof Qe&&(g.leftPanoPicture.map.update(gn,dr),g.leftPanoPicture.map.needsRender===!0&&(this.needsRender=!0));{var qn=this.tiling.object.visible;if(dr>this.TILED_CUBE_TEXTURE_LEVEL&&this.initAnimationed){var Ur=g.panoId,dt=this.works.getResolvedObserver(Ur);dt?Ti(this.camera.position,dt.position)&&this.locationMotion.ended?(this.tiling.object.visible=!0,this.tiling.panoId!==Ur&&this.tiling.cleanup(),this.tiling.panoId=Ur,this.tiling.setResource((p=(h=dt.images)===null||h===void 0?void 0:h.tiles)!==null&&p!==void 0?p:[],this.enableIOSEDR&&dt.images.luminance?dt.images.luminance:null),this.tiling.setFetcher(pt(dt.work)),this.tiling.setRotation(dt.quaternion),this.tiling.setPosition(dt.position),this.tiling.update(gn,dr,e)):this.tiling.object.visible=!1:this.tiling.object.visible=!1}else this.tiling.object.visible=!1;qn!==this.tiling.object.visible&&(this.tiling.object.needsRender=!0)}this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e),!(!me||me.length<1)&&this.updateControllerHelper(me,e,r)}}},t.prototype.render=function(){var e=this.xrManager.getCamera(this.camera);this.renderer.render(this.scene,e)},t.prototype.onPanGesture=function(){},t.prototype.onTapGesture=function(){},t.prototype.onPinchGesture=function(){},t.prototype.onMouseMove=function(){},t.prototype.onMouseOut=function(){},t.prototype.panoResourceFromLocationMotionKeyframe=function(e){return this.panoResources[e.key]},t.prototype.updateControllerHelper=function(e,r,i){var a=this.xrControllerRay.left,o=this.xrControllerRay.right;if(!(!e||e.length===0)){for(var s={buttons:{X:!1,Y:!1,LeftTrigger:!1,LeftPinch:!1,A:!1,B:!1,RightTrigger:!1,RightPinch:!1}},u=0;u<e.length;u++){var c=e[u].handedness,l=e[u].gamepad;switch(c){case"left":l.axes&&(this.emitEvent(l.axes[2]===-1,"LeftAxesLeft",r),this.emitEvent(l.axes[2]===1,"LeftAxesRight",r),this.emitEvent(l.axes[3]===-1,"LeftAxesUp",r),this.emitEvent(l.axes[3]===1,"LeftAxesDown",r)),l!=null&&l.buttons&&(this.emitEvent(l==null?void 0:l.buttons[4].pressed,"X",r),this.emitEvent(l.buttons[5].pressed,"Y",r),this.emitEvent(l==null?void 0:l.buttons[0].pressed,"LeftTrigger",r),this.emitEvent(l==null?void 0:l.buttons[1].pressed,"LeftPinch",r));var h={raycaster:a,axes:{up:l.axes&&l.axes[3]<0?Math.abs(l.axes[3]):0,down:l.axes&&l.axes[3]<0?0:Math.abs(l.axes[3]),left:l.axes&&l.axes[2]<0?Math.abs(l.axes[2]):0,right:l.axes&&l.axes[2]<0?0:Math.abs(l.axes[2])},deltaTime:i};s.buttons.X=l.buttons&&l.buttons[4]?l.buttons[4].pressed:!1,s.buttons.Y=l.buttons&&l.buttons[5]?l==null?void 0:l.buttons[5].pressed:!1,s.buttons.LeftTrigger=l.buttons&&l.buttons[0]?l==null?void 0:l.buttons[0].pressed:!1,s.buttons.LeftPinch=l.buttons&&l.buttons[1]?l==null?void 0:l.buttons[1].pressed:!1,s.left=h;break;case"right":l.axes&&(this.emitEvent(l.axes[2]===-1,"RightAxesLeft",r),this.emitEvent(l.axes[2]===1,"RightAxesRight",r),this.emitEvent(l.axes[3]===-1,"RightAxesUp",r),this.emitEvent(l.axes[3]===1,"RightAxesDown",r)),l.buttons&&(this.emitEvent(l==null?void 0:l.buttons[4].pressed,"A",r),this.emitEvent(l.buttons[5].pressed,"B",r),this.emitEvent(l==null?void 0:l.buttons[0].pressed,"RightTrigger",r),this.emitEvent(l==null?void 0:l.buttons[1].pressed,"RightPinch",r));var p={raycaster:o,axes:{up:l.axes&&l.axes[3]<0?Math.abs(l.axes[3]):0,down:l.axes&&l.axes[3]<0?0:Math.abs(l.axes[3]),left:l.axes&&l.axes[2]<0?Math.abs(l.axes[2]):0,right:l.axes&&l.axes[2]<0?0:Math.abs(l.axes[2])},deltaTime:i};s.right=p,s.buttons.A=l.buttons&&l.buttons[4]?l==null?void 0:l.buttons[4].pressed:!1,s.buttons.B=l.buttons&&l.buttons[5]?l==null?void 0:l.buttons[5].pressed:!1,s.buttons.RightTrigger=l.buttons&&l.buttons[0]?l==null?void 0:l.buttons[0].pressed:!1,s.buttons.RightPinch=l.buttons&&l.buttons[1]?l==null?void 0:l.buttons[1].pressed:!1;break}}this.emit("xr.controller.update",_("xr.controller.update",s))}},t.prototype.emitEvent=function(e,r,i){var a=this.xrControllerRay.left,o=this.xrControllerRay.right;if(e)if(this.xrControllerState[r].touchStart===!1)this.xrControllerState[r].touchStartTime=i,this.xrControllerState[r].touchStart=!0,this.emit("xr.gesture.buttonDown",_("xr.gesture.buttonDown",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!1,isFirst:!0,controllers:{raycaster:{leftRay:a,rightRay:o}}}));else{var s=i-this.xrControllerState[r].touchStartTime;s>Ns&&this.emit("xr.gesture.press",_("xr.gesture.tap",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!0,controllers:{raycaster:{leftRay:a,rightRay:o}}}))}else if(this.xrControllerState[r].touchStart===!0){this.emit("xr.gesture.buttonUp",_("xr.gesture.buttonUp",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:a,rightRay:o}}}));var s=i-this.xrControllerState[r].touchStartTime;if(s<=Ns){var u=this.emit("xr.gesture.tap",_("xr.gesture.tap",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:a,rightRay:o}}}));u||r==="RightTrigger"&&this.checkSelectedPano(this.xrControllerRay.right)}this.xrControllerState[r].touchStart=!1,this.xrControllerState[r].touchStartTime=0}},t}(ao),Vt={Floorplan:si,Topview:Hf,Panorama:ao,VRPanorama:Hh,Model:_h,DepthPanorama:$h,Mapview:cp,XRPanorama:Fp},d0=["gesture.pan","gesture.tap","gesture.press","gesture.pinch","gesture.mousewheel","gesture.mousemove","gesture.momentum","initAnimation.start","initAnimation.end","camera.update","intersect.update","pano.select","pano.moveTo","pano.moving","pano.arrived","pano.cancel","pano.error","pano.texture.load","pano.texture.progress","pano.texture.success","pano.texture.error","pano.texture.abort","xr.session.start","xr.session.end","xr.gesture.tap","xr.gesture.press","xr.gesture.buttonUp","xr.gesture.buttonDown","xr.controller.update"];function Op(n){n.on("initAnimation.start",function(t){n.emit("initAnimationWillStart",t.state.panoIndex,t.state,t.userAction)}),n.on("initAnimation.end",function(t){n.emit("initAnimationEnded",t.state.panoIndex,t.state,t.userAction)}),n.on("gesture.pan",function(t){var e=!1;e=n.emit("wantsGesture","pan",t.pointers,t.isFinal),e&&t.preventDefault(),e=n.emit("wantsPanGesture",t.state,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","pan",t.pointers,t.isFinal),n.emit("panGesture",t.state,t.isFinal))}),n.on("gesture.tap",function(t){var e=!1;e=n.emit("wantsGesture","tap",t.pointers,t.isFinal),e&&t.preventDefault(),e=n.emit("wantsTapGesture",t.center.raycaster,t.center.coords,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","tap",t.pointers,t.isFinal),n.emit("tapGesture",t.center.raycaster,t.center.coords,t.isFinal))}),n.on("gesture.press",function(t){var e=!1;e=n.emit("wantsGesture","press",t.pointers,t.isFinal),e&&t.preventDefault(),e=n.emit("wantsPressGesture",t.center.raycaster,t.center.coords,t.center.delta,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","press",t.pointers,t.isFinal),n.emit("pressGesture",t.center.raycaster,t.center.coords,t.center.delta,t.isFinal))}),n.on("gesture.pinch",function(t){var e=!1;e=n.emit("wantsGesture","pinch",t.pointers,t.isFinal),e&&t.preventDefault(),e=n.emit("wantsPinchGesture",t.scale,t.state.fov,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","pinch",t.pointers,t.isFinal),n.emit("pinchGesture",t.scale,t.state.fov,t.isFinal))}),n.on("gesture.mousewheel",function(t){var e=!1;e=n.emit("wantsGesture","mouseWheel",t.pointers,t.isFinal),e&&t.preventDefault(),e=n.emit("wantsMouseWheel",t.center.delta,t.state.fov,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","mouseWheel",t.pointers,t.isFinal),n.emit("mouseWheel",t.center.delta,t.state.fov,t.isFinal))}),n.on("gesture.mousemove",function(t){var e=!1;e=n.emit("wantsGesture","mouseMove",t.pointers,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","mouseMove",t.pointers,t.isFinal),e=n.emit("wantsChangeCameraFov",t.state.fov),e&&t.preventDefault())}),n.on("gesture.momentum",function(t){var e=!1;e=n.emit("wantsInteriaPan",t.state),e&&t.preventDefault(),t.defaultPrevented||n.emit("interiaPan",t.state,t.isFinal)}),n.on("camera.update",function(t){n.emit("cameraFovUpdate",t.state.fov,t.userAction),n.emit("cameraDirectionUpdate",t.state,t.userAction);var e=Rr(t.state);e.setLength(t.state.distance);var r=t.state.offset.clone().sub(e);n.emit("cameraPositionUpdate",r,t.userAction),n.emit("cameraUpdate",t.state,t.userAction)}),n.on("intersect.update",function(t){if(t.intersection){var e=!1;e=n.emit("wantsShowIntersectionOnModel",t.raycaster),e&&t.preventDefault(),t.defaultPrevented||n.emit("intersectionOnModelUpdate",t.intersection,t.object)}else n.emit("intersectionHidden")}),n.on("pano.request",function(t){var e=n.emit("wantsMoveToPano",t.state.panoIndex,t.options,t.userAction);e||(e=n.emit("wantsToMoveToPano",t.state.panoIndex,t.options,t.userAction)),e&&t.preventDefault(),t.defaultPrevented||n.emit("panoWillLoad",t.state.panoIndex)}),n.on("pano.select",function(t){n.emit("panoSelected",t.state.panoIndex)}),n.on("pano.moveTo",function(t){n.emit("panoLoaded",t.state.panoIndex),n.emit("moveToPano",t.state.panoIndex,t.userAction),n.emit("panoWillArrive",t.state.panoIndex,t.state,t.userAction)}),n.on("pano.moving",function(t){n.emit("movingToPano",t.state.panoIndex,t.prevPano.panoIndex,t.progress)}),n.on("pano.arrived",function(t){n.emit("panoArrived",t.state.panoIndex,t.state,t.userAction)}),n.on("pano.cancel",function(t){n.emit("moveToPanoCanceled",t.state.panoIndex)}),n.on("pano.error",function(t){n.emit("panoLoadError",t.error,t.state.panoIndex)}),n.on("pano.texture.load",function(t){n.emit("textureStartLoad",t.pano.panoIndex)}),n.on("pano.texture.success",function(t){n.emit("textureLoaded",t.pano.panoIndex,t.meta)}),n.on("pano.texture.error",function(t){n.emit("textureError",t.error,t.pano.panoIndex)}),n.on("pano.texture.abort",function(t){n.emit("textureAbort",t.pano.panoIndex)}),n.on("pano.texture.progress",function(t){n.emit("textureLoading",t.progress,t.pano.panoIndex)}),n.on("xr.session.start",function(t){n.emit("webXRSessionStart")}),n.on("xr.session.end",function(t){n.emit("webXRSessionEnd")}),n.on("xr.gesture.tap",function(t){n.emit("webXRControllerEvent","tap",t.buttons,{raycaster:t.controllers.raycaster})}),n.on("xr.gesture.press",function(t){n.emit("webXRControllerEvent","press",t.buttons,{raycaster:t.controllers.raycaster})}),n.on("xr.gesture.buttonUp",function(t){n.emit("webXRControllerEvent","buttonUp",t.buttons,{raycaster:t.controllers.raycaster})}),n.on("xr.gesture.buttonDown",function(t){n.emit("webXRControllerEvent","buttonDown",t.buttons,{raycaster:t.controllers.raycaster})}),n.on("xr.controller.update",function(t){n.emit("webXRControllerRayUpdate",{leftRay:t.left?t.left.raycaster:void 0,rightRay:t.right?t.right.raycaster:void 0}),t.left&&n.emit("webXRAxesUpdate","left",{raycaster:{leftRay:t.left?t.left.raycaster:void 0,rightRay:t.right?t.right.raycaster:void 0},axesState:{up:t.left.axes.up,down:t.left.axes.down,left:t.left.axes.left,right:t.left.axes.right},deltaTime:t.left.deltaTime}),t.right&&n.emit("webXRAxesUpdate","right",{raycaster:{leftRay:t.left?t.left.raycaster:void 0,rightRay:t.right?t.right.raycaster:void 0},axesState:{up:t.right.axes.up,down:t.right.axes.down,left:t.right.axes.left,right:t.right.axes.right},deltaTime:t.right.deltaTime})}),n.on("works.request",function(t){n.emit("willLoad",t.input,t.works[0],t.state)}),n.on("works.load",function(t){n.emit("load",t.input,t.works[0],t.state)}),n.on("works.ready",function(t){n.emit("loaded",t.input,t.works[0])}),n.on("state.change",function(t){n.emit("stateChange",t.state,t.userAction)}),n.on("currentState.change",function(t){n.emit("currentStateChange",t.state,t.userAction)}),n.on("state.set",function(t){n.emit("setState",t.state)}),n.on("state.synced",function(t){n.emit("stateSynced",t.state)}),n.on("model.request",function(t){n.emit("modelWillLoad",t.work.model)}),n.on("model.error",function(t){n.emit("modelLoadError",t.error,t.model)}),n.on("model.load",function(t){n.emit("modelLoaded",t.model)}),n.on("model.changeShownFloor",function(t){n.emit("modelShownFloorChange",t.model.shownFloor,t.model.floorLength)}),n.on("render",function(t){n.emit("renderFrame",t.needsRender)}),n.on("mode.change.request",function(t){n.emit("wantsChangeMode",t.mode,t.prevMode)}),n.on("mode.change",function(t){n.emit("modeChange",t.mode,t.prevMode,t.state.panoIndex,t.state,t.userAction)}),n.on("helpers.visible",function(t){n.emit("helpersVisibleChange",t.object.visible)}),n.on("network.resource",function(t){n.emit("network",t.source,t.requestType,t.requestState,t.detail)})}function kp(){var n=document.createElement("video");n.loop=!0,n.autoplay=!0,n.playsInline=!0,n.muted=!0,n.crossOrigin="";var t=function(){document.removeEventListener("touchstart",t,!1),document.removeEventListener("mousedown",t,!1),n.muted=!1};return document.addEventListener("touchstart",t,!1),document.addEventListener("mousedown",t,!1),n}function Lp(n){{var t=new d.DirectionalLight(16777215,.5);t.position.copy(new d.Vector3(1,1,1)),n.add(t)}{var t=new d.DirectionalLight(16777215,.3);n.add(t)}{var t=new d.AmbientLight(16777215,.3);n.add(t)}}function Dp(n){for(var t,e,r={},i=n.split(/(\;|\,)/),a=0,o=i;a<o.length;a++){var s=o[a],u=s.split("="),c=(t=u[0])===null||t===void 0?void 0:t.trim(),l=(e=u[1])===null||e===void 0?void 0:e.trim();c&&l&&(r[c]=l)}return r}function f0(){for(var n,t=document.getElementsByTagName("meta"),e=0;e<t.length;e++){var r=t[e];if(r.getAttribute("name")==="viewport"){var i=Dp((n=r.getAttribute("content"))!==null&&n!==void 0?n:""),a=Number(i["initial-scale"]);if(!isNaN(a))return a}}return 1}const Np="data:image/png;base64,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";var Vs=[351,63],Us=[20,20],Qp=new Float32Array([-.5,-.5,0,.5,-.5,0,-.5,.5,0,.5,.5,0]),Vp=new Float32Array([0,0,1,0,0,1,1,1]),Up=new Uint8Array([0,1,2,1,3,2]),Fi=new d.BufferGeometry;Fi.setAttribute("position",new d.BufferAttribute(Qp,3));Fi.setAttribute("uv",new d.BufferAttribute(Vp,2));Fi.setIndex(new d.BufferAttribute(Up,1));var ui=new d.MeshBasicMaterial({transparent:!0,depthTest:!1,depthWrite:!1,stencilWrite:!1,fog:!1}),h0=new d.Mesh(Fi,ui);h0.matrixAutoUpdate=!1;var co=new d.Scene;co.add(h0);co.matrixAutoUpdate=!1;var Un=new d.OrthographicCamera(-.5,.5,.5,-.5,.1,1);Un.position.set(0,0,.5);Un.lookAt(0,0,0);Un.updateMatrixWorld(!0);Un.matrixAutoUpdate=!1;var qp=new d.Vector4,zp=new d.Vector4;function qs(n){if(ui.map){var r=n.getViewport(qp),i=n.getScissor(zp),a=n.getScissorTest(),o=n.autoClear,s=i.x+Us[0]/3,u=i.y+Us[1]/3,c=Vs[0]/3,l=Vs[1]/3;n.setViewport(s,u,c,l),n.setScissor(s,u,c,l),n.setScissorTest(!0),n.autoClear=!1,n.render(co,Un),n.setViewport(r),n.setScissor(i),n.setScissorTest(a),n.autoClear=o}else{var t=new d.Texture,e=new Image;e.onload=function(){t.image=e,t.wrapS=d.ClampToEdgeWrapping,t.wrapT=d.ClampToEdgeWrapping,t.minFilter=d.LinearFilter,t.needsUpdate=!0,t.generateMipmaps=!1,ui.needsUpdate=!0,e.onload=Q},e.src=Np,ui.map=t}}var Hp=800,jp=function(n){return n.replace("//vrlab-public.ljcdn.com/","//vr-public.realsee-cdn.cn/").replace("//vrlab-image4.ljcdn.com/","//vr-image-4.realsee-cdn.cn/").replace("//vrlab-image3.ljcdn.com/","//vr-image-3.realsee-cdn.cn/").replace("//vrlab-image2.ljcdn.com/","//vr-image-2.realsee-cdn.cn/").replace("//vrlab-image1.ljcdn.com/","//vr-image-1.realsee-cdn.cn/")},_p=[{name:"Z",transformToUpAxisZ:function(){return new d.Matrix4}},{name:"Y",transformToUpAxisZ:function(){return new d.Matrix4().makeRotationAxis(new d.Vector3(1,0,0),+Math.PI/2)}},{name:"-Y",transformToUpAxisZ:function(){return new d.Matrix4().makeRotationAxis(new d.Vector3(1,0,0),-Math.PI/2)}},{name:"WGS84",transformToEarthCentered:function(){return new d.Matrix4}},{name:"GCJ02",transformToEarthCentered:function(){return new d.Matrix4}},{name:"BD09",transformToEarthCentered:function(){return new d.Matrix4}}],on=new d.Vector2,ri=new d.Frustum,ni=new d.Matrix4,zs=new WeakMap,Hs=new WeakMap,js=Gu([]),p0=function(n){de(t,n);function t(e){e===void 0&&(e={});var r,i,a,o,s,u,c,l,h,p,v=n.call(this)||this;v.ident=vt(),ka.instances[v.ident]=v,v.renderSwitch01=0,v.currentMode="Panorama",v.pano={workCode:"",panoIndex:0},v.needsRender=!1,v.onlyRenderIfNeeds=(r=e.onlyRenderIfNeeds)!==null&&r!==void 0?r:!0,v.imageOptions=R({},(i=e.imageOptions)!==null&&i!==void 0?i:{}),v.textureOptions=R({},(a=e.textureOptions)!==null&&a!==void 0?a:{}),v.poweredByRealsee=(o=e.poweredByRealsee)!==null&&o!==void 0?o:!0,v.extraElements=[],v.controllerInits={Panorama:Object.assign({},e.panorama),Model:Object.assign({},e.model),Floorplan:Object.assign({},e.floorplan),Topview:Object.assign({},e.topview),Mapview:Object.assign({},e.mapview),DepthPanorama:Object.assign({},e.depthPanorama),VRPanorama:Object.assign({},e.vrPanorama),XRPanorama:Object.assign({},e.xrPanorama)},v.coordinatesSystemTransformers=at([],(s=e.coordinatesSystemTransformers)!==null&&s!==void 0?s:[],!0);for(var m=function(F){var k=A.coordinatesSystemTransformers.find(function(O){return O.name===F.name});k||A.coordinatesSystemTransformers.push(R({},F))},A=this,y=0,f=_p;y<f.length;y++){var g=f[y];m(g)}if(v.fps={testCount:0,testTime:ve()},v.info=null,v.modeChangeDuration=(u=e.modeChangeDuration)!==null&&u!==void 0?u:Hp,v.enableWheel=(c=e.enableWheel)!==null&&c!==void 0?c:!0,typeof window<"u")if(e.renderer)e.renderer instanceof _r&&v.throwError(new Error("cannot render a internal renderer")),v.renderer=e.renderer;else try{v.renderer=new _r({preserveDrawingBuffer:e.preserveDrawingBuffer,backgroundColor:e.backgroundColor,backgroundAlpha:e.backgroundAlpha,antialias:e.antialias,webgl2:e==null?void 0:e.webgl2});var b=f0();v.renderer.setPixelRatio(b===1?window.devicePixelRatio:1),v.renderer.setSize(512,512)}catch(F){F instanceof Error&&v.throwError(F)}v.getPixelsRenderTarget=new d.WebGLRenderTarget(1,1,{encoding:(h=(l=v.renderer)===null||l===void 0?void 0:l.outputEncoding)!==null&&h!==void 0?h:d.sRGBEncoding}),v.scissor=Object.assign({left:0,bottom:0,width:1,height:1},e.scissor),v.camera=new hi(90),v.scene=new cu,v.xrCustomObjectsScene=new d.Scene,v.scene.add(v.xrCustomObjectsScene),v.scene.matrixAutoUpdate=!1,v.lastLoadWorkTask=Promise.resolve(),v.requestProxy=(p=e.requestProxy)!==null&&p!==void 0?p:jp,v.networkSubscribe=new Zs,v.networkSubscribe.on("network",function(F,k,O,L){var N;v.emit("network.resource",_("network.resource",{source:F,requestType:k,requestState:O,detail:L})),(N=v.analysis)===null||N===void 0||N.network(v.works,F,k,O,L)}),v.boundingMesh=kf(new d.Box3(new d.Vector3(-.5,-.5,-.5),new d.Vector3(.5,.5,.5))),v.boundingMesh.name="bounding",v.scene.add(v.boundingMesh),v.models=vs(),v.models.push(new Ba),v.lastModels=vs(),v.readyCallbacks=[],v.syncingState=!1,v.modelGroup=new d.Group,v.modelGroup.visible=!1,v.modelGroup.name="model",v.modelGroup.matrixAutoUpdate=!1,v.modelGroup.renderOrder=-4,v.scene.add(v.modelGroup),v.helperGroup=new d.Group,v.helperGroup.name="helper",v.helperGroup.matrixAutoUpdate=!1,v.scene.add(v.helperGroup),v.videoTexture=new d.VideoTexture(e.videoInstance||kp()),Lp(v.scene),v.copyEffect=new Bi(v.renderer,v.scene,v.camera,v.models),v.state={mode:v.currentMode,workCode:v.pano.workCode,panoIndex:v.pano.panoIndex,longitude:v.camera.pose.longitude,latitude:v.camera.pose.latitude,fov:v.camera.pose.fov,offset:v.camera.pose.offset.clone(),distance:v.camera.pose.distance},v.stateSynced=!1,v._enableIOSEDR=!1,v.destroyed=!1,v.paused=!0,typeof window<"u"&&(e.play!==!1&&v.play(),v.stopAnimationLoop=it.shared.add(function(F,k){for(var O=[],L=2;L<arguments.length;L++)O[L-2]=arguments[L];v.updateTime.apply(v,at([F,k],O,!1))},!1,0,10));var w=function(){typeof document<"u"&&document.fullscreenElement===null&&v.currentMode==="VRPanorama"&&v.controller.emit("vr.requestExit",_("vr.requestExit",{}))};if(typeof document<"u"&&document.addEventListener("fullscreenchange",w,!1),v.removeEventListeners=function(){typeof document<"u"&&document.removeEventListener("fullscreenchange",w,!1)},v.plugins={},e.plugins&&e.plugins.length)for(var E=0,x=e.plugins;E<x.length;E++){var M=x[E];if(typeof M=="function")M(v);else if(Array.isArray(M)){var C=M[0],I=M[1],P=M[2];if(typeof C=="function"){var S=C(v,P);typeof I=="string"&&(v.plugins[I]?v.throwError(new Error("plugin name ".concat(I," is exists."))):v.plugins[I]=S)}}}return v.gpuPickingRenderTarget=new d.WebGLRenderTarget(1,1),v.meshReplaceMaterialMap=new Map,v.meshOriginMaterialMap=new Map,Op(v),v}return Object.defineProperty(t,"version",{get:function(){return"6.0.0-alpha.65"},enumerable:!1,configurable:!0}),Object.defineProperty(t,"dracoPath",{get:function(){return mi.decoderPath},set:function(e){mi.setDecoderPath(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t,"ktx2Path",{get:function(){return Fn.transcoderPath},set:function(e){Fn.setTranscoderPath(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"panoIndex",{get:function(){return this.pano.panoIndex},enumerable:!1,configurable:!0}),t.prototype.getGPUPicking=function(e,r,i,a,o){var s=this;if(a===void 0&&(a=1),o===void 0&&(o=new d.Vector3(0,0,0)),!this.renderer)throw new Error("renderer is not initialized.");this.models.setMaterial({constantColor:o}),this.scene.traverse(function(h){if(!(!(h instanceof d.Mesh)||h instanceof _t)){var p=Object.keys(i).filter(function(m){return m===h.uuid})[0];if(p)if(s.meshOriginMaterialMap.set(p,h.material),s.meshReplaceMaterialMap.get(p))h.material=s.meshReplaceMaterialMap.get(p);else{var v=new d.ShaderMaterial({uniforms:{color:{value:i[p]}},vertexShader:`
|
|
2038
|
+
`},lo=function(n){de(t,n);function t(e){var r=n.call(this,{uniforms:d.UniformsUtils.clone(ca.uniforms),vertexShader:ca.vertexShader,fragmentShader:ca.fragmentShader,clipping:!0})||this;return r.type="LineMaterial",r.dashed=!1,Object.defineProperties(r,{color:{enumerable:!0,get:function(){return this.uniforms.diffuse.value},set:function(i){this.uniforms.diffuse.value=i}},linewidth:{enumerable:!0,get:function(){return this.uniforms.linewidth.value},set:function(i){this.uniforms.linewidth.value=i}},dashScale:{enumerable:!0,get:function(){return this.uniforms.dashScale.value},set:function(i){this.uniforms.dashScale.value=i}},dashSize:{enumerable:!0,get:function(){return this.uniforms.dashSize.value},set:function(i){this.uniforms.dashSize.value=i}},gapSize:{enumerable:!0,get:function(){return this.uniforms.gapSize.value},set:function(i){this.uniforms.gapSize.value=i}},opacity:{enumerable:!0,get:function(){return this.uniforms.opacity.value},set:function(i){this.uniforms.opacity.value=i}},resolution:{enumerable:!0,get:function(){return this.uniforms.resolution.value},set:function(i){this.uniforms.resolution.value.copy(i)}}}),r.setValues(e),r}return t}(d.ShaderMaterial);Object.assign(lo.prototype,{isLineMaterial:!0});var s0=function(n){de(t,n);function t(e,r){var i=n.call(this)||this;return i.type="LineSegments2",i.geometry=e!==void 0?e:new uo,i.material=r!==void 0?r:new lo({color:Math.random()*16777215}),i}return t.prototype.computeLineDistances=function(){for(var e=this.geometry,r=e.attributes.instanceStart,i=e.attributes.instanceEnd,a=new Float32Array(2*r.count),o=new d.Vector3,s=new d.Vector3,u=0,c=0,l=r.count;u<l;u++,c+=2)o.fromBufferAttribute(r,u),s.fromBufferAttribute(i,u),a[c]=c===0?0:a[c-1],a[c+1]=a[c]+o.distanceTo(s);var h=new d.InstancedInterleavedBuffer(a,2,1);return e.setAttribute("instanceDistanceStart",new d.InterleavedBufferAttribute(h,1,0)),e.setAttribute("instanceDistanceEnd",new d.InterleavedBufferAttribute(h,1,1)),this},t.prototype.raycast=function(e,r){e.camera===null&&console.error('LineSegments2: "Raycaster.camera" needs to be set in order to raycast against LineSegments2.');var i=e.ray,a=e.camera,o=a.projectionMatrix,s=this.geometry,u=this.material,c=u.resolution,l=u.linewidth,h=s.attributes.instanceStart,p=s.attributes.instanceEnd,v=new d.Vector4,m=new d.Vector4,A=new d.Vector4,y=new d.Vector3,f=new d.Matrix4,g=new d.Line3,b=new d.Vector3;i.at(1,A),A.w=1,A.applyMatrix4(a.matrixWorldInverse),A.applyMatrix4(o),A.multiplyScalar(1/A.w),A.x*=c.x/2,A.y*=c.y/2,A.z=0,y.copy(A);var w=this.matrixWorld;f.multiplyMatrices(a.matrixWorldInverse,w);for(var E=0,x=h.count;E<x;E++){v.fromBufferAttribute(h,E),m.fromBufferAttribute(p,E),v.w=1,m.w=1,v.applyMatrix4(f),m.applyMatrix4(f),v.applyMatrix4(o),m.applyMatrix4(o),v.multiplyScalar(1/v.w),m.multiplyScalar(1/m.w);var M=v.z<-1&&m.z<-1,C=v.z>1&&m.z>1;if(!(M||C)){v.x*=c.x/2,v.y*=c.y/2,m.x*=c.x/2,m.y*=c.y/2,g.start.copy(v),g.start.z=0,g.end.copy(m),g.end.z=0;var I=g.closestPointToPointParameter(y,!0);g.at(I,b);var P=d.MathUtils.lerp(v.z,m.z,I),S=P>=-1&&P<=1,F=y.distanceTo(b)<l*.5;if(S&&F){g.start.fromBufferAttribute(h,E),g.end.fromBufferAttribute(p,E),g.start.applyMatrix4(w),g.end.applyMatrix4(w);var k=new d.Vector3,O=new d.Vector3;i.distanceSqToSegment(g.start,g.end,O,k),r.push({point:O,pointOnLine:k,distance:i.origin.distanceTo(O),object:this,faceIndex:E})}}}},t}(d.Mesh);Object.assign(s0.prototype,{isLineSegments2:!0});var u0=function(n){de(t,n);function t(e,r){var i=n.call(this,e,r)||this;return i.type="Line2",i}return t}(s0);Object.assign(u0.prototype,{isLine2:!0});var l0=function(n){de(t,n);function t(){var e=n.call(this)||this;return e.type="LineGeometry",e}return t.prototype.setPositions=function(e){for(var r=e.length-3,i=new Float32Array(2*r),a=0;a<r;a+=3)i[2*a]=e[a],i[2*a+1]=e[a+1],i[2*a+2]=e[a+2],i[2*a+3]=e[a+3],i[2*a+4]=e[a+4],i[2*a+5]=e[a+5];return n.prototype.setPositions.call(this,i),this},t.prototype.setColors=function(e){for(var r=e.length-3,i=new Float32Array(2*r),a=0;a<r;a+=3)i[2*a]=e[a],i[2*a+1]=e[a+1],i[2*a+2]=e[a+2],i[2*a+3]=e[a+3],i[2*a+4]=e[a+4],i[2*a+5]=e[a+5];return n.prototype.setColors.call(this,i),this},t.prototype.fromLine=function(e){var r=e.geometry;if(r instanceof d.Geometry){var i=new d.BufferGeometry().fromGeometry(r);this.setPositions(i.attributes.position.array)}else r instanceof d.BufferGeometry&&this.setPositions(r.attributes.position.array);return this},t.prototype.copy=function(){return this},t}(uo);Object.assign(l0.prototype,{isLineGeometry:!0});var pp="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAAZiS0dEAAAAAAAA+UO7fwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB9sHDgwCEMBJZu0AAAAdaVRYdENvbW1lbnQAAAAAAENyZWF0ZWQgd2l0aCBHSU1QZC5lBwAABM5JREFUWMO1V0tPG2cUPZ4Hxh6DazIOrjFNqJs0FIMqWFgWQkatsmvVbtggKlSVRVf5AWz4AWz4AUSKEChll19QJYSXkECuhFxsHjEhxCYm+DWGMZ5HF72DJq4bAzFXurI0M/I5997v3u9cC65vTJVn2lX/xHINQOYSBLTLEuIuCWw4Z3IGAEvf6ASmVHjNzHCXBG4A0AjACsAOwEbO0nsFQBnAGYASAIl+ZRMR7SolMEdsByD09fV5R0ZGgg8ePPjW5/N1iqLYpuu6RZblciKR2I9Go69evnwZnZ+fjwI4IS8AKBIRzeQfJWCANwKwh0KhtrGxsYehUOin1tbW+zzP23ietzY2NnIAoGmaLsuyUiqVyvl8XtrY2NiamZn589mzZxsAUgCOAeQAnFI2tI+VxIjaAeDzoaGh7xYWFuZOTk6OZVk+12uYqqq6JEnn0Wg0OT4+/geAXwGEAdwDIFJQXC1wO4DWR48e/RCPxxclSSroVzRFUbSDg4P848ePFwH8DuAhkWih83TRQWxFOXgAwvDwcOfo6OhvXV1d39tsNtuVBwTDWBwOh1UUxVsMw1hXVlbSdCgNV43uYSvrHg6H24aHh38eHBz85TrgF9FYLHA4HLzH43FvbW2d7u/vG+dANp8FpqIlbd3d3V8Fg8EfBUFw4BONZVmL3+9vHhkZCQL4AoAHgJPK8G+yzC0XDofdoVAo5PP5vkadTBAEtr+/39ff3x8gAp/RPOEqx2qjx+NpvXv3bk9DQ0NDvQgwDIOWlhZrMBj8kgi0UJdxRgYMArzL5XJ7vd57qLPZ7Xamp6fnNgBXtQxcjFuHw+Hyer3t9SYgCAITCAScAJoBNNEY/08GOFVVrfVMv7kMNDntFD1vjIAPrlRN0xjckOm6biFQ3jwNPwDMZrOnqVTqfb3Bi8Wivru7W/VCYkwPlKOjo0IikXh7EwQikYgE4Nw0CfXKDCipVCoTj8df3QABbW1tLUc6oUgkFPMkVACUNjc337148eKvw8PDbJ2jP1taWkoCyNDVXDSECmNSK4qiKNLq6urW8+fPI/UicHx8rD59+jSVy+WOAKSJhKENwFItLtoxk8mwsixzHR0dHe3t7c5PAU+n09rs7OzJkydPYqVSaQfANoDXALIk31S2smU1TWMPDg7K5XKZ7+3t9TudTut1U7+wsFCcmJiIpdPpbQBxADsAknQWymYCOukBHYCuKApisdhpMpnURFEU79y503TVyKenpzOTk5M7e3t7MQKPV0Zv1gNm+awB0MvlshqLxfLb29uyJElWURSbXC4XXyvqxcXFs6mpqeTc3Nzu3t7e3wQcA7BPZ8Cov1pNlJplmQtAG8MwHV6v95tAINA5MDBwPxAIuLu6upr8fr/VAN3c3JQjkcjZ+vp6fnl5+d2bN29SuVzuNYAEpf01CdRChUL+X1VskHACuA3Ay3Fcu9vt7nA6nZ7m5uYWQRCaNE3jVVW15PP580KhIGUymWw2m00DOAJwSP4WwPtq4LX2Ao6USxNlQyS/RcQcdLGwlNIz6vEMAaZpNzCk2Pll94LK/cDYimxERiBwG10sxjgvEZBE0UpE6vxj+0Ct5bTaXthgEhRmja8QWNkkPGsuIpfdjpkK+cZUWTC0KredVmtD/gdlSl6EG4AMvQAAAABJRU5ErkJggg==",ks=14467195,vp=8,Ap=2,mp=20,Ls=null,Oa=function(n){de(t,n);function t(e,r){e===void 0&&(e=new d.Vector3),r===void 0&&(r=new d.Vector3);var i=n.call(this)||this;i.type="FiveLine",i.needsRender=!0;var a=new l0,o=new lo({color:ks,linewidth:Ap,dashScale:mp,dashed:!1});i.line=new u0(a,o);var s=new d.BufferGeometry,u=new d.PointsMaterial({color:ks,size:vp,map:Ls||(Ls=new d.TextureLoader().load(pp)),sizeAttenuation:!1,transparent:!0});return i.points=new d.Points(s,u),i.points.renderOrder=11,i.points.frustumCulled=!1,i.setPoints(e,r),i.add(i.line,i.points),i}return Object.defineProperty(t,"version",{get:function(){return"6.0.0-alpha.66"},enumerable:!1,configurable:!0}),t.prototype.setPoints=function(e,r){var i=[].concat(e.toArray(),r.toArray());this.points.geometry.setAttribute("position",new d.BufferAttribute(new Float32Array(i),3)),this.line.geometry.setPositions(i),this.line.computeLineDistances(),this.needsRender=!0},t.prototype.getPoints=function(){var e=this.points.geometry.attributes.position.array;return[new d.Vector3(e[0],e[1],e[2]),new d.Vector3(e[3],e[4],e[5])]},t.prototype.setMaterial=function(e){var r=this.line.material;for(var i in e)if(e.hasOwnProperty(i)){var a=e[i];i==="dashed"?(r.dashed=a,a?r.defines.USE_DASH="":delete r.defines.USE_DASH,r.needsUpdate=!0):r[i]=e[i]}this.needsRender=!0},t.prototype.setResolution=function(e,r){var i=this.line.material.resolution;(i.x!==e||i.y!==r)&&(i.set(e,r),this.needsRender=!0)},t}(d.Object3D);Object.assign(Oa.prototype,{isFiveLine:!0});var _e={Handedness:Object.freeze({NONE:"none",LEFT:"left",RIGHT:"right"}),ComponentState:Object.freeze({DEFAULT:"default",TOUCHED:"touched",PRESSED:"pressed"}),ComponentProperty:Object.freeze({BUTTON:"button",X_AXIS:"xAxis",Y_AXIS:"yAxis",STATE:"state"}),ComponentType:Object.freeze({TRIGGER:"trigger",SQUEEZE:"squeeze",TOUCHPAD:"touchpad",THUMBSTICK:"thumbstick",BUTTON:"button"}),ButtonTouchThreshold:.05,AxisTouchThreshold:.1,VisualResponseProperty:Object.freeze({TRANSFORM:"transform",VISIBILITY:"visibility"})};function c0(n){return Mi(this,void 0,void 0,function(){var t;return Ci(this,function(e){switch(e.label){case 0:return[4,fetch(n)];case 1:if(t=e.sent(),t.ok)return[2,t.json()];throw new Error(t.statusText)}})})}function gp(n){return Mi(this,void 0,void 0,function(){var t,e;return Ci(this,function(r){switch(r.label){case 0:if(!n)throw new Error("No basePath supplied");return t="profilesList.json",[4,c0("".concat(n,"/").concat(t))];case 1:return e=r.sent(),[2,e]}})})}function yp(n,t,e,r){return e===void 0&&(e=null),r===void 0&&(r=!0),Mi(this,void 0,void 0,function(){var i,a,o,s,u,c;return Ci(this,function(l){switch(l.label){case 0:if(!n)throw new Error("No xrInputSource supplied");if(!t)throw new Error("No basePath supplied");return[4,gp(t)];case 1:if(i=l.sent(),n.profiles.some(function(h){var p=i[h];return p&&(a={profileId:h,profilePath:"".concat(t,"/").concat(p.path),deprecated:!!p.deprecated}),!!a}),!a){if(!e)throw new Error("No matching profile name found");if(o=i[e],!o)throw new Error('No matching profile name found and default profile "'.concat(e,'" missing.'));a={profileId:e,profilePath:"".concat(t,"/").concat(o.path),deprecated:!!o.deprecated}}return[4,c0(a.profilePath)];case 2:if(s=l.sent(),r){if(c=void 0,c=s.layouts[n.handedness],!c)throw new Error("No matching handedness, ".concat(n.handedness,", in profile ").concat(a.profileId));c.assetPath&&(u=a.profilePath.replace("profile.json",c.assetPath))}return[2,{profile:s,assetPath:u}]}})})}var bp={xAxis:0,yAxis:0,button:0,state:_e.ComponentState.DEFAULT};function wp(n,t){n===void 0&&(n=0),t===void 0&&(t=0);var e=n,r=t,i=Math.sqrt(n*n+t*t);if(i>1){var a=Math.atan2(t,n);e=Math.cos(a),r=Math.sin(a)}var o={normalizedXAxis:e*.5+.5,normalizedYAxis:r*.5+.5};return o}var Ep=function(){function n(t){this.componentProperty=t.componentProperty,this.states=t.states,this.valueNodeName=t.valueNodeName,this.valueNodeProperty=t.valueNodeProperty,this.valueNodeProperty===_e.VisualResponseProperty.TRANSFORM&&(this.minNodeName=t.minNodeName,this.maxNodeName=t.maxNodeName),this.value=0,this.updateFromComponent(bp)}return n.prototype.updateFromComponent=function(t){var e=t.xAxis,r=t.yAxis,i=t.button,a=t.state,o=wp(e,r),s=o.normalizedXAxis,u=o.normalizedYAxis;switch(this.componentProperty){case _e.ComponentProperty.X_AXIS:this.value=this.states.includes(a)?s:.5;break;case _e.ComponentProperty.Y_AXIS:this.value=this.states.includes(a)?u:.5;break;case _e.ComponentProperty.BUTTON:this.value=this.states.includes(a)?i:0;break;case _e.ComponentProperty.STATE:this.valueNodeProperty===_e.VisualResponseProperty.VISIBILITY?this.value=this.states.includes(a):this.value=this.states.includes(a)?1:0;break;default:throw new Error("Unexpected visualResponse componentProperty ".concat(this.componentProperty))}},n}(),xp=function(){function n(t,e){var r=this;if(!t||!e||!e.visualResponses||!e.gamepadIndices||Object.keys(e.gamepadIndices).length===0)throw new Error("Invalid arguments supplied");this.id=t,this.type=e.type,this.rootNodeName=e.rootNodeName,this.touchPointNodeName=e.touchPointNodeName,this.visualResponses={},Object.keys(e.visualResponses).forEach(function(i){var a=new Ep(e.visualResponses[i]);r.visualResponses[i]=a}),this.gamepadIndices=Object.assign({},e.gamepadIndices),this.values={state:_e.ComponentState.DEFAULT,button:this.gamepadIndices.button!==void 0?0:void 0,xAxis:this.gamepadIndices.xAxis!==void 0?0:void 0,yAxis:this.gamepadIndices.yAxis!==void 0?0:void 0}}return Object.defineProperty(n.prototype,"data",{get:function(){var t=R({id:this.id},this.values);return t},enumerable:!1,configurable:!0}),n.prototype.updateFromGamepad=function(t){var e=this;if(this.values.state=_e.ComponentState.DEFAULT,this.gamepadIndices.button!==void 0&&t.buttons.length>this.gamepadIndices.button){var r=t.buttons[this.gamepadIndices.button];this.values.button=r.value,this.values.button=this.values.button<0?0:this.values.button,this.values.button=this.values.button>1?1:this.values.button,r.pressed||this.values.button===1?this.values.state=_e.ComponentState.PRESSED:(r.touched||this.values.button>_e.ButtonTouchThreshold)&&(this.values.state=_e.ComponentState.TOUCHED)}this.gamepadIndices.xAxis!==void 0&&t.axes.length>this.gamepadIndices.xAxis&&(this.values.xAxis=t.axes[this.gamepadIndices.xAxis],this.values.xAxis=this.values.xAxis<-1?-1:this.values.xAxis,this.values.xAxis=this.values.xAxis>1?1:this.values.xAxis,this.values.state===_e.ComponentState.DEFAULT&&Math.abs(this.values.xAxis)>_e.AxisTouchThreshold&&(this.values.state=_e.ComponentState.TOUCHED)),this.gamepadIndices.yAxis!==void 0&&t.axes.length>this.gamepadIndices.yAxis&&(this.values.yAxis=t.axes[this.gamepadIndices.yAxis],this.values.yAxis=this.values.yAxis<-1?-1:this.values.yAxis,this.values.yAxis=this.values.yAxis>1?1:this.values.yAxis,this.values.state===_e.ComponentState.DEFAULT&&Math.abs(this.values.yAxis)>_e.AxisTouchThreshold&&(this.values.state=_e.ComponentState.TOUCHED)),Object.values(this.visualResponses).forEach(function(i){i.updateFromComponent(e.values)})},n}(),Mp=function(){function n(t,e,r){var i=this;if(!t)throw new Error("No xrInputSource supplied");if(!e)throw new Error("No profile supplied");this.xrInputSource=t,this.assetUrl=r,this.id=e.profileId,this.layoutDescription=e.layouts[t.handedness],this.components={},Object.keys(this.layoutDescription.components).forEach(function(a){var o=i.layoutDescription.components[a];i.components[a]=new xp(a,o)}),this.updateFromGamepad()}return Object.defineProperty(n.prototype,"gripSpace",{get:function(){return this.xrInputSource.gripSpace},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"targetRaySpace",{get:function(){return this.xrInputSource.targetRaySpace},enumerable:!1,configurable:!0}),Object.defineProperty(n.prototype,"data",{get:function(){var t=[];return Object.values(this.components).forEach(function(e){t.push(e.data)}),t},enumerable:!1,configurable:!0}),n.prototype.updateFromGamepad=function(){var t=this;Object.values(this.components).forEach(function(e){e.updateFromGamepad(t.xrInputSource.gamepad)})},n}(),Cp="https://cdn.jsdelivr.net/npm/@webxr-input-profiles/assets@1.0/dist/profiles",Ip="generic-trigger",Sp=function(n){de(t,n);function t(){var e=n.call(this)||this;return e.motionController=null,e.envMap=null,e}return t.prototype.setEnvironmentMap=function(e){var r=this;return this.envMap==e?this:(this.envMap=e,this.traverse(function(i){i instanceof d.Mesh&&i.isMesh&&(i.material.envMap=r.envMap,i.material.needsUpdate=!0)}),this)},t.prototype.updateMatrixWorld=function(e){n.prototype.updateMatrixWorld.call(this,e),this.motionController&&(this.motionController.updateFromGamepad(),Object.values(this.motionController.components).forEach(function(r){Object.values(r.visualResponses).forEach(function(i){var a=i.valueNode,o=i.minNode,s=i.maxNode,u=i.value,c=i.valueNodeProperty;a&&(c===_e.VisualResponseProperty.VISIBILITY?a.visible=u:c===_e.VisualResponseProperty.TRANSFORM&&(a.quaternion.copy(o.quaternion).slerp(s.quaternion,u),a.position.lerpVectors(o.position,s.position,u)))})}))},t}(Sn.Object3D);function Tp(n,t){Object.values(n.components).forEach(function(e){var r=e.type,i=e.touchPointNodeName,a=e.visualResponses;if(r===_e.ComponentType.TOUCHPAD)if(e.touchPointNode=t.getObjectByName(i),e.touchPointNode){var o=new Sn.SphereGeometry(.001),s=new Sn.MeshBasicMaterial({color:255}),u=new Sn.Mesh(o,s);e.touchPointNode.add(u)}else console.warn("Could not find touch dot, ".concat(e.touchPointNodeName,", in touchpad component ").concat(e.id));Object.values(a).forEach(function(c){var l=c.valueNodeName,h=c.minNodeName,p=c.maxNodeName,v=c.valueNodeProperty;if(v===_e.VisualResponseProperty.TRANSFORM){if(c.minNode=t.getObjectByName(h),c.maxNode=t.getObjectByName(p),!c.minNode){console.warn("Could not find ".concat(h," in the model"));return}if(!c.maxNode){console.warn("Could not find ".concat(p," in the model"));return}}c.valueNode=t.getObjectByName(l),c.valueNode||console.warn("Could not find ".concat(l," in the model"))})})}function Ds(n,t){Tp(n.motionController,t),n.envMap&&t.traverse(function(e){e instanceof d.Mesh&&e.isMesh&&(e.material.envMap=n.envMap,e.material.needsUpdate=!0)}),n.add(t)}var Pp=function(){function n(t){t===void 0&&(t=null),this.gltfLoader=t,this.path=Cp,this._assetCache={}}return n.prototype.createControllerModel=function(t){var e=this,r=new Sp,i=null;return t.addEventListener("connected",function(a){var o=a.data;o.targetRayMode!=="tracked-pointer"||!o.gamepad||yp(o,e.path,Ip).then(function(s){var u=s.profile,c=s.assetPath;r.motionController=new Mp(o,u,c);var l=e._assetCache[r.motionController.assetUrl];if(l)i=l.scene.clone(),Ds(r,i);else{if(!e.gltfLoader)throw new Error("GLTFLoader not set.");e.gltfLoader.load(r.motionController.assetUrl,function(h){e._assetCache[r.motionController.assetUrl]=h,i=h.scene.clone(),Ds(r,i)})}}).catch(function(s){console.warn(s)})}),t.addEventListener("disconnected",function(){r.motionController=null,r.remove(i),i=null}),r},n}();function Bp(n,t){if(!t)return n;var e=n.match(/\d+_[a-z].png/);return n.substring(0,e.index)+t+"/"+n.substring(e.index)}var Ns=300,Rp=new d.Matrix4().makeRotationAxis(new d.Vector3(0,1,0),Math.PI),Qs=new d.Vector3(-1,1,1),Fp=function(n){de(t,n);function t(e){var r,i=n.call(this,e)||this;i.xrManager=new hp(i.renderer,i.renderer.getContext(),{onSessionStart:function(c){i.emit("xr.session.start",_("xr.session.start",{session:c,machineType:i.xrManager.machineType}))},onSessionEnd:function(){i.emit("xr.session.end",_("xr.session.end",{session:null,machineType:i.xrManager.machineType}))}}),i.xrControllerRay={left:new d.Raycaster,right:new d.Raycaster},i.xrControllerRay.left.params.Points={threshold:.1},i.xrControllerRay.right.params.Points={threshold:.1},i.pointerLines={left:new Oa,right:new Oa},i.pointerLines.left.visible=!1,i.pointerLines.right.visible=!0,i.pointerLines.left.setMaterial({color:new d.Vector3(1,1,1)}),i.pointerLines.left.points.material.depthTest=!1,i.pointerLines.right.setMaterial({color:new d.Vector3(1,1,1)}),i.pointerLines.right.points.material.depthTest=!1,i.scene.add(i.pointerLines.left,i.pointerLines.right),i.panoResources={},i.panoResources[i.locationMotion.keyframes[0].key=i.locationMotion.keyframes[1].key=vt()]={panoId:Be(i.currentPano),leftPanoPicture:null,position:i.camera.pose.offset.clone(),effect:"fade"},i.parallaxCameraMatrixs=[],i.onlyUseRightController=(r=e.onlyUseRightController)!==null&&r!==void 0?r:!1;var a=it.shared.getContext();if(!a)return console.error("获取session失败,请退出重试"),i;i.on("xr.session.end",function(){i.scene.remove(i.pointerLines.left,i.pointerLines.right)}),i.xrManager.setSession(a),i.controllerWrappers=[new d.Group,new d.Group],i.scene.add(i.controllerWrappers[0],i.controllerWrappers[1]);var o=i.xrManager.getController(0);i.controllerWrappers[0].add(o);var s=i.xrManager.getController(1);i.controllerWrappers[1].add(s);var u=new Pp;return u.gltfLoader={load:function(c,l){ci.ajax(c,{responseType:"arraybuffer"}).then(function(h){var p;return Ga(h.body,{resourcePath:c.slice(0,c.lastIndexOf("/")+1),search:(p=c.split("?")[1])!==null&&p!==void 0?p:"",fetcher:ci})}).then(function(h){return l(h)})}},i.on("xr.session.start",function(){var c=i.xrManager.getControllerGrip(0);if(c.add(u.createControllerModel(c)),i.controllerWrappers[0].add(c),!i.onlyUseRightController){var l=i.xrManager.getControllerGrip(1);l.add(u.createControllerModel(l)),i.controllerWrappers[1].add(l)}}),i.xrControllerState={LeftAxesUp:{touchStartTime:0,touchStart:!1},LeftAxesDown:{touchStartTime:0,touchStart:!1},LeftAxesLeft:{touchStartTime:0,touchStart:!1},LeftAxesRight:{touchStartTime:0,touchStart:!1},LeftTrigger:{touchStartTime:0,touchStart:!1},LeftPinch:{touchStartTime:0,touchStart:!1},RightAxesUp:{touchStartTime:0,touchStart:!1},RightAxesDown:{touchStartTime:0,touchStart:!1},RightAxesLeft:{touchStartTime:0,touchStart:!1},RightAxesRight:{touchStartTime:0,touchStart:!1},RightTrigger:{touchStartTime:0,touchStart:!1},RightPinch:{touchStartTime:0,touchStart:!1},Y:{touchStartTime:0,touchStart:!1},X:{touchStartTime:0,touchStart:!1},A:{touchStartTime:0,touchStart:!1},B:{touchStartTime:0,touchStart:!1}},i}return t.parseArgs=function(e){if(e instanceof t)return e;var r=R(R({},e),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2});return n.parseArgs.call(this,r)},t.initAnimationEndState=function(e){var r=this.parseArgs(e),i=n.initAnimationEndState.call(this,r);return R(R({},i),{mode:"XRPanorama"})},t.prototype.moveToPano=function(e,r,i){var a=this,o,s,u,c;this.userAction=i,this.stopMomentumMovement();var l=this.works.getResolvedObserver(e);if(!l)throw new Error("Invalid PanoIndex");var h=this.imageOptions.size;if(typeof h>"u"&&l){var p=l.images.up.match(/\/cube_(\d+)\//);p&&(h=Number(p[1]))}typeof h>"u"&&(h=2048);var v=this.imageOptions.transform,m=function(P,S){return Bp(di(P,v,S))},A=R({key:"pano.".concat(l.panoId)},sr(this.imageOptions,["format","size","quality"])),y=l.images,f=(s=(o=l.images.tiles)===null||o===void 0?void 0:o.filter(function(P){return P.size>h}))!==null&&s!==void 0?s:null,g="pano:"+fn([y,A,v]);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===g)return;var b=this.pendingTextureTask.panoId;(u=this.panoMeshes[b])===null||u===void 0||u.setProgress(0),this.emit("pano.texture.abort",_("pano.texture.abort",{error:null,progress:0,meta:null,pano:l.pano})),this.pendingTextureTask.onError(new Error("texture aborted"))}var w=this.models.getMaterial()||{},E=w.pano0,x=w.pano1,M;if((E==null?void 0:E.map.name)===g?M=E:(x==null?void 0:x.map.name)===g&&(M=x),M){var C={panoId:l.panoId,effect:(c=r.effect)!==null&&c!==void 0?c:"fade",leftPanoPicture:{map:M.map,luminanceMap:M.luminanceMap,matrix:new d.Matrix4().compose(l.position,l.quaternion,Qs)},position:l.position.clone()};this.doMoveToPano(l.pano,C,r);return}var I="move-to-pano-"+l.panoId;this.pending.add(I),this.pendingTextureTask={panoId:l.panoId,hash:g,onLoad:function(P){var S;if(a.pending.delete(I),a.destroyed)P.body.dispose();else{P.body.name=g;var F={panoId:l.panoId,effect:(S=r.effect)!==null&&S!==void 0?S:"fade",leftPanoPicture:{map:P.body,luminanceMap:null,matrix:new d.Matrix4().compose(l.position,l.quaternion,Qs)},position:l.position.clone()};a.doMoveToPano(l.pano,F,r)}},onError:function(P){a.pending.delete(I);var S=R(R(R({},l.pano),{mode:a.mode}),Ve(a.camera.pose));a.emit("pano.error",_("pano.error",{error:P,userAction:a.userAction,options:r,prevPano:a.currentPano,progress:0,state:S})),a.emit("pano.cancel",_("pano.cancel",{error:null,userAction:a.userAction,options:r,prevPano:a.currentPano,progress:0,state:S})),r.moveCancelCallback&&r.moveCancelCallback()}},Promise.all([this.tileLevelForFov&&f&&f.length?this.textureLoader.loadTiledCubeTexture(y,f,{tileMaxLevel:this.TILED_CUBE_TEXTURE_LEVEL,imageURL:{transform:m,options:A},format:d.RGBAFormat,viaAjax:!0,fetcher:pt(l.work)},void 0,void 0,function(P){var S,F;a.emit("pano.texture.progress",_("pano.texture.progress",{error:null,progress:P,meta:null,pano:l.pano})),((S=a.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&((F=a.panoMeshes[l.panoId])===null||F===void 0||F.setProgress(P))},this.renderer):this.textureLoader.loadCubeTexture(y,{imageURL:{transform:m,options:A},format:d.RGBAFormat,fetcher:pt(l.work)},void 0,void 0,function(P){var S,F;((S=a.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&((F=a.panoMeshes[l.panoId])===null||F===void 0||F.setProgress(P)),a.emit("pano.texture.progress",_("pano.texture.progress",{error:null,progress:P,meta:null,pano:l.pano}))},this.renderer)]).then(function(P){var S,F,k=P[0];((S=a.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g?(a.pendingTextureTask.onLoad(k),(F=a.panoMeshes[l.panoId])===null||F===void 0||F.setProgress(0),delete a.pendingTextureTask,a.emit("pano.texture.success",_("pano.texture.success",{error:null,progress:1,meta:k.meta,pano:l.pano}))):k.body.dispose()}).catch(function(P){var S,F;((S=a.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&(a.pendingTextureTask.onError(P),(F=a.panoMeshes[l.panoId])===null||F===void 0||F.setProgress(0),delete a.pendingTextureTask,a.emit("pano.texture.error",_("pano.texture.error",{error:P,progress:0,meta:null,pano:l.pano})),a.emit("error",P))}),this.emit("pano.texture.load",_("pano.texture.load",{error:null,progress:0,meta:null,pano:l.pano}))},t.prototype.doMoveToPano=function(e,r,i){var a=this,o,s,u;i===void 0&&(i={});var c=ve(),l=vt();this.panoResources[l]=r;var h=1,p,v,m;if(this.locationMotion.ended){var A=this.locationMotion.getKeyFrameSegment(c);A[0];var y=A[1],f=this.locationMotion.value,g=this.panoResourceFromLocationMotionKeyframe(y).position,b=r.position;p=Math.max(g.distanceTo(b),h),v=[{key:y.key,progress:0,value:R(R({},f),{count:0})},{key:l,progress:1,value:{distance:0,count:1}}],m=0}else{var w=this.locationMotion.getKeyFrameSegment(c),E=w[0],y=w[1],f=this.locationMotion.value,x=this.panoResourceFromLocationMotionKeyframe(E).position,g=this.panoResourceFromLocationMotionKeyframe(y).position,b=r.position,M=y.value.count-f.count,C=Math.max(x.distanceTo(g),h)*M,I=Math.max(g.distanceTo(b),h);p=C+I,v=[{key:E.key,progress:0,value:R({},f)},{key:y.key,progress:C/p,value:y.value},{key:l,progress:1,value:{count:y.value.count+1,distance:0}}];var P=this.locationMotionKeyframesLength(this.locationMotion.keyframes),S=this.locationMotionKeyframesLength(v);m=this.locationMotion.getProgressVelocity(c)*P/S}var F=this.calculateMovingDuration(i.duration,p),k={longitude:i.longitude,latitude:i.latitude,fov:i.fov},O=R(R({},e),{mode:this.mode,longitude:(o=k.longitude)!==null&&o!==void 0?o:this.camera.pose.longitude,latitude:(s=k.latitude)!==null&&s!==void 0?s:this.camera.pose.latitude,fov:(u=k.fov)!==null&&u!==void 0?u:this.camera.pose.fov,offset:r.position.clone(),distance:0}),L=this.currentPano;this.emit("pano.moveTo",_("pano.moveTo",{options:i,prevPano:L,progress:0,state:O,userAction:this.userAction,error:null})),i.moveStartCallback&&i.moveStartCallback(O),this.videoTexture&&this.videoTexture.image instanceof HTMLVideoElement&&this.videoTexture.image.getAttribute("src")&&(this.videoTexture.image.pause(),this.videoTexture.image.removeAttribute("uuid"),this.videoTexture.image.removeAttribute("src"),this.videoTexture.image.oncanplay=Q,this.videoTexture.needsUpdate=!0),this.panoVideo.setMaterial(null),this.cameraMotion.set(k,F).catch(Q);var N=this.locationMotion.setKeyframes(v,F,m);N.then(function(){var V,j,z,U=R(R({},e),{mode:a.mode,longitude:a.camera.pose.longitude,latitude:a.camera.pose.latitude,fov:a.camera.pose.fov,offset:a.camera.pose.offset.clone(),distance:0});a.emit("pano.arrived",_("pano.arrived",{options:i,prevPano:L,progress:1,state:U,userAction:a.userAction,error:null})),i.moveEndCallback&&i.moveEndCallback(U);var X=a.works.getResolvedObserver(a.currentPano);if(X&&X.video&&a.videoTexture&&a.videoTexture.image instanceof HTMLVideoElement){var G=Rp.clone().multiply((z=(j=(V=a.models.getMaterial())===null||V===void 0?void 0:V.pano1)===null||j===void 0?void 0:j.matrix)!==null&&z!==void 0?z:new d.Matrix4).multiply(X.video.matrix),K={map:a.videoTexture,size:X.video.size,matrix:G,alpha:1},Y=vt(),H=a.videoTexture.image;H.setAttribute("uuid",Y),Ju().then(function(J){J&&X.video&&H.getAttribute("uuid")===Y&&(H.oncanplay=function(){H.oncanplay=Q,H.play()},H.ontimeupdate=function(){H.currentTime>.5&&(H.ontimeupdate=Q,a.panoVideo.setMaterial(K))},H.src=X.video.source)}).catch(function(){H.removeAttribute("uuid")})}},function(){a.emit("pano.cancel",_("pano.cancel",{options:i,prevPano:L,progress:0,state:O,userAction:a.userAction,error:null})),i.moveCancelCallback&&i.moveCancelCallback()})},t.prototype.checkSelectedPano=function(e){var r=this,i,a,o,s;this.stopMomentumMovement();var u=this.camera.getDirection(new d.Vector3).setY(0),c=null,l=this.works.getResolvedObserver(this.currentPano);if(!l)return null;var h=l.accessibleIds.filter(function(Y){var H=Ye(Y);if(Ft(H,r.currentPano))return!1;var J=r.works.getResolvedObserver(H);return!J||J.position.distanceTo(r.camera.position)>r.maxAccessibleDistance?!1:J.loadable||J.active}),p=this.models.intersectRaycaster(e)[0];if(p){var v=Ot(h,function(Y){var H=r.works.getResolvedObserver(Y);if(!H)return 1/0;var J=H.standingPosition.clone();return J.distanceTo(p.point)},!0),m=v[0],A=v[1];m&&A<this.panoTapTriggerRadius&&(c=(i=this.works.getResolvedObserver(m))!==null&&i!==void 0?i:null)}if(Fs(c)){var y=this.getForwardObserverOrNot(e);y&&(c=y)}for(var f=0,g=this.locationMotion.keyframes;f<g.length;f++){var b=g[f],w=this.panoResourceFromLocationMotionKeyframe(b);if(!(b.progress<this.locationMotion.progress)&&c&&w.panoId===c.panoId){c=null;break}}if(Fs(c))return this.locationMotion.ended===!0&&this.cameraBounce(),null;if(c&&!c.active){var E=c.panoId;this.panoMeshes[E]&&(this.panoMeshes[E].setDisabled(!1),this.panoMeshes[E].setLoading(!0))}var x={};if(c){x.effect="fade";for(var M=Math.PI/6,C=Math.PI/12,I=new d.Vector3(0,1,0),P=c.position.clone().setY(0).sub(l.position.clone().setY(0)).normalize(),S=P.clone().applyAxisAngle(I,M),F=P.clone().applyAxisAngle(I,-M),k=[],O=[],L=[],N=0,V=c.accessibleIds;N<V.length;N++){var m=V[N],j=Ye(m);if(!(Ft(j,this.currentPano)||Ft(j,c.pano))){var z=this.works.getResolvedObserver(m);if(z){var U=z.position.clone().sub(c.position).setY(0);P.angleTo(U)<M?L.push(U):S.angleTo(U)<M?k.push(U):F.angleTo(U)<M&&O.push(U)}}}var X=L.length>0?L:at(at([],k,!0),O,!0),G=X.slice().sort(function(Y,H){return Y.angleTo(P)-H.angleTo(P)})[0];G&&G.angleTo(u)>C&&(x.longitude=Math.atan2(-G.x,-G.z))}this.cameraMotion.value.latitude<-Math.PI/4&&(x.latitude=le(0,this.minLatitude,this.maxLatitude)),this.cameraMotion.value.fov<60&&(x.fov=this.defaultFov);var K={workCode:c.pano.workCode,panoIndex:c.pano.panoIndex,mode:this.mode,longitude:(a=x.longitude)!==null&&a!==void 0?a:this.camera.pose.longitude,latitude:(o=x.latitude)!==null&&o!==void 0?o:this.camera.pose.latitude,fov:(s=x.fov)!==null&&s!==void 0?s:this.camera.pose.fov,distance:0,offset:c?c.position.clone():new d.Vector3};return this.emit("pano.select",_("pano.select",{prevPano:this.currentPano,state:K,userAction:!0,options:x,progress:0,error:null})),c&&c.active?(this.emit("pano.request",_("pano.request",{userAction:!0,prevPano:this.currentPano,progress:0,state:K,options:x,error:null})),c.pano):null},t.prototype.destroy=function(){n.prototype.destroy.call(this)},t.prototype.isReady=function(){return!1},t.prototype.updateCamera=function(e,r,i){return Promise.resolve()},t.prototype.updateCameraWithKeyframes=function(e,r,i){return Promise.resolve()},t.prototype.updateTime=function(e,r){for(var i=this,a,o,s,u,c,l,h,p,v=[],m=2;m<arguments.length;m++)v[m-2]=arguments[m];this.userAction=!0;var A={},y={},f=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[0]),g=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[this.locationMotion.keyframes.length-1]),b=!1;if(this.cameraMotion.ended===!1&&(this.cameraMotion.update(e),y.longitude=this.cameraMotion.value.longitude,y.latitude=this.cameraMotion.value.latitude,y.fov=this.cameraMotion.value.fov),this.modelAlphaMotion.ended===!1&&(this.modelAlphaMotion.update(e),A.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(le(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);var w=this.locationMotion.getKeyFrameSegment(e),E=w[0],x=w[1],M=this.panoResourceFromLocationMotionKeyframe(E),C=this.panoResourceFromLocationMotionKeyframe(x),I=new d.Vector3().copy(M.position),P=new d.Vector3().copy(C.position),S=this.locationMotion.value.count-x.value.count+1;A.progress=S,C.leftPanoPicture&&(S<1?M.leftPanoPicture&&(A.pano0=M.leftPanoPicture):A.pano0=C.leftPanoPicture,A.pano1=C.leftPanoPicture),b=A.useBlackTransition=C.effect==="instant"||C.effect==="montage",(C.effect==="fade"||C.effect==="montage")&&(A.pano0&&M.leftPanoPicture&&(A.pano0={map:A.pano0.map,luminanceMap:A.pano0.luminanceMap,matrix:M.leftPanoPicture.matrix.clone().setPosition(C.position)}),I.copy(P)),y.distance=this.locationMotion.value.distance,y.offset=new d.Vector3(I.x+(P.x-I.x)*S,I.y+(P.y-I.y)*S,I.z+(P.z-I.z)*S);for(var F=[],k=[],O=0,L=this.locationMotion.keyframes;O<L.length;O++){var N=L[O],V=N.key,j=N.progress;V!==void 0&&(F.push(V),j>=this.locationMotion.progress&&k.push(V))}for(var z=0,U=Object.keys(this.panoResources);z<U.length;z++){var X=U[z];if(!(k.indexOf(X)>=0)){var G=this.panoResources[X];if(G.leftPanoPicture){var K=G.leftPanoPicture.map;if(K){if(K===((a=A.pano0)===null||a===void 0?void 0:a.map)||K===((o=A.pano1)===null||o===void 0?void 0:o.map))continue;K instanceof Qe&&K.cubeRenderTarget&&this.colorCubeRenderTargetPool.push(K.cubeRenderTarget),K.dispose(),G.leftPanoPicture=null}}F.indexOf(X)>=0||delete this.panoResources[X]}}this.currentPano=Ye(C.panoId),this.emit("pano.moving",_("pano.moving",{userAction:this.userAction,prevPano:Ye(f.panoId),state:R(R(R(R({},Ye(g.panoId)),{mode:this.mode}),Ve(this.camera.pose)),y),options:{},progress:this.locationMotion.progress,error:null}))}St(A)===!1&&(!((s=A.pano0)===null||s===void 0)&&s.map&&A.pano0.map instanceof Qe&&!A.pano0.map.cubeRenderTarget&&(A.pano0.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((u=A.pano1)===null||u===void 0)&&u.map&&A.pano1.map instanceof Qe&&!A.pano1.map.cubeRenderTarget&&(A.pano1.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),this.models.setMaterial(A)),St(y)===!1&&this.setCamera(y);var Y=this.works.getResolvedObserver(this.currentPano),H=v[1];if(!H){console.error("xrFrame丢失,请重试");return}if(!this.xrManager.session){console.error("session丢失,请重试");return}var J=this.xrManager.referenceSpace;if(J){var ne=this.xrManager.cameraVR,$=this.xrManager.cameraL,te=this.xrManager.cameraR,ae=[$,te],ce=H.getViewerPose(J),oe=new d.Vector3(0,0,0);if(ce){var fe;fe=this.xrManager.session.renderState.baseLayer;var Ie=ce.views;if(!fe){console.error("no layer found");return}this.renderer.setFramebuffer(fe.framebuffer);var Ae=!1;Ie.length!==ne.cameras.length&&(ne.cameras.length=0,Ae=!0),this.parallaxCameraMatrixs=[];var Fe=new d.Vector3,re=new d.Vector3;new d.Matrix4().fromArray(Ie[0].transform.matrix).decompose(Fe,new d.Quaternion,new d.Vector3),new d.Matrix4().fromArray(Ie[1].transform.matrix).decompose(re,new d.Quaternion,new d.Vector3),re.clone().sub(Fe).normalize();var he=new d.Vector3,W=new d.Quaternion,Oe=new d.Vector3;this.camera.matrix.decompose(he,W,Oe);for(var ke=0;ke<Ie.length;ke++){var Je=Ie[ke],Ze=fe.getViewport(Je),De=ae[ke];De.matrix.fromArray(Je.transform.matrix);var We=new d.Vector3,Le=new d.Quaternion,ye=new d.Vector3;De.matrix.decompose(We,Le,ye),oe.copy(he),De.position.copy(he),De.quaternion.copy(Le),De.scale.copy(ye),De.updateMatrix(),De.projectionMatrix.fromArray(Je.projectionMatrix),De.viewport.set(Ze.x,Ze.y,Ze.width,Ze.height),Ae===!0&&ne.cameras.push(De)}ce.views[0].transform.position,ce.views[1].transform.position;for(var me=this.xrManager.session.inputSources,ke=0;ke<this.xrManager.controllers.length;ke++){var lt=this.xrManager.controllers[ke],Se=me[ke];if(Se){lt.update(Se,H,J);var $e=this.xrManager.getController(ke),Ue=new d.Vector3(0,1.2,0),At=$e.position.clone().add(oe).sub(Ue);Se.handedness==="left"?this.xrControllerRay.left.set(At,new d.Vector3(0,0,-1).applyEuler($e.rotation)):Se.handedness==="right"&&this.xrControllerRay.right.set(At,new d.Vector3(0,0,-1).applyEuler($e.rotation)),this.controllerWrappers[ke].position.copy(new d.Vector3(0,0,0).add(oe).sub(Ue));var Ke=this.models.intersectRaycaster(this.xrControllerRay.right);if(Ke.length===0&&(Ke=this.xrControllerRay.right.intersectObject(this.boundingMesh,!0).map(function(ft){var Et;return R({floor:(Et=Y==null?void 0:Y.floorIndex)!==null&&Et!==void 0?Et:0},ft)})),Ke.length>=1&&Ke[0].face)if(Se.handedness==="right"){var Gt=this.xrControllerRay.right.intersectObject(this.xrCustomObjectsScene,!0),Kt=Ke[0].face.normal,ze=Kt.clone().multiplyScalar(.05),ot=Ke[0].point.clone().add(ze);this.intersectMesh.position.copy(ot);var $t=ot.clone().add(ze);if(this.intersectMesh.lookAt($t),Math.abs(Kt.y)>.99){var He=this.camera.position.clone().sub(ot);this.intersectMesh.rotation.z=-Math.atan2(He.z,He.x)}this.intersectMesh.visible=!0,this.needsRender=!0,Gt.length>0?(this.pointerLines.right.setPoints(At,Gt[0].point),this.pointerLines.right.points.visible=!0,this.intersectMesh.visible=!1):(this.pointerLines.right.points.visible=!1,this.pointerLines.right.setPoints(At,Ke[0].point));var ct=Ke[0],wt=_("intersect.update",{raycaster:(c=this.xrControllerRay.right)!==null&&c!==void 0?c:null,intersection:ct??null,object:this.intersectMesh});if(this.emit("intersect.update",wt),wt.defaultPrevented){this.hideIntersectMesh();return}}else this.pointerLines.left.setPoints(At,Ke[0].point)}}if(this.camera.pose.distance>.1||b){if(Y)for(var Tt=0,er=Object.keys(this.panoMeshes);Tt<er.length;Tt++){var mt=er[Tt],Te=this.panoMeshes[mt];Te.setOpacity(0),Te.setCurrent(!1),Te.updateTime&&Te.updateTime(e,r)}}else if(Y){var wr=Ot(Y.visibleIds,function(st){var ft=i.works.getResolvedObserver(st);return ft?Y.standingPosition.distanceTo(ft.standingPosition):1/0},!0),kt=wr[1];kt=le(kt,2.5,1/0);for(var ur=Y.visibleIds.concat(Be(this.currentPano)),Lt=this.getForwardObserverOrNot(),mn=this.camera.getDirection(new d.Vector3),Qr=0,Vr=Object.keys(this.panoMeshes);Qr<Vr.length;Qr++){var mt=Vr[Qr],Te=this.panoMeshes[mt],lr=this.works.getResolvedObserver(mt);if(ur.indexOf(mt)===-1)Te.setCurrent(!1),Te.setOpacity(0);else if(!lr)Te.setCurrent(!1),Te.setOpacity(0);else if(!lr.loadable&&!lr.active)Te.setCurrent(!1),Te.setOpacity(0);else{var cr=Te.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);Te.setCurrent(!Te.loading&&Te.progress===0&&Lt!==null&&Lt.panoId===mt),Te.setOpacity(cr<.01?0:le(kt/cr*1.2,.65,.98));var rt=this.camera.position.clone().setY(Te.position.y),Xe=new d.Vector3().copy(Te.position).sub(rt).normalize();if(mt===Be(this.currentPano)){var Dt=le((.5-rt.distanceTo(Te.position))/.5,0,1);Xe.multiplyScalar(1-Dt).add(mn.clone().multiplyScalar(Dt))}Xe.length()>0&&Te.quaternion.setFromEuler(new d.Euler(0,Math.atan2(Xe.x,Xe.z),0))}Te.updateTime&&Te.updateTime(e,r)}}var dr=function(){if(i.tileLevelForFov===!1)return 0;var st=new d.Vector2(4e3,4e3),ft=g.panoId,Et=i.works.getResolvedObserver(ft),xt=i.imageOptions.size;if(typeof xt>"u"&&Et){var zn=Et.images.up.match(/\/cube_(\d+)\//);zn&&(xt=Number(zn[1]))}typeof xt>"u"&&(xt=2048);var qr=0;xt>=1024&&(qr=1),xt>=2048&&(qr=2),xt>=4096&&(qr=3),xt>=8192&&(qr=4);var zr=i.tileLevelForFov($.fov,st);return zr>qr?zr:0}(),gn=function(){var st=new d.PerspectiveCamera;st.applyMatrix4(ne.matrix),st.position.set(0,0,0);var ft=i.works.getResolvedObserver(g.panoId),Et=ft??Y;Et&&st.quaternion.premultiply(Et.quaternion.clone().inverse()),st.updateProjectionMatrix(),st.updateMatrixWorld(!0);var xt=new d.Frustum().setFromProjectionMatrix(new d.Matrix4().multiplyMatrices(st.projectionMatrix,st.matrixWorldInverse));return xt}();g.panoId===Be(this.currentPano)&&((l=g.leftPanoPicture)===null||l===void 0?void 0:l.map)instanceof Qe&&(g.leftPanoPicture.map.update(gn,dr),g.leftPanoPicture.map.needsRender===!0&&(this.needsRender=!0));{var qn=this.tiling.object.visible;if(dr>this.TILED_CUBE_TEXTURE_LEVEL&&this.initAnimationed){var Ur=g.panoId,dt=this.works.getResolvedObserver(Ur);dt?Ti(this.camera.position,dt.position)&&this.locationMotion.ended?(this.tiling.object.visible=!0,this.tiling.panoId!==Ur&&this.tiling.cleanup(),this.tiling.panoId=Ur,this.tiling.setResource((p=(h=dt.images)===null||h===void 0?void 0:h.tiles)!==null&&p!==void 0?p:[],this.enableIOSEDR&&dt.images.luminance?dt.images.luminance:null),this.tiling.setFetcher(pt(dt.work)),this.tiling.setRotation(dt.quaternion),this.tiling.setPosition(dt.position),this.tiling.update(gn,dr,e)):this.tiling.object.visible=!1:this.tiling.object.visible=!1}else this.tiling.object.visible=!1;qn!==this.tiling.object.visible&&(this.tiling.object.needsRender=!0)}this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e),!(!me||me.length<1)&&this.updateControllerHelper(me,e,r)}}},t.prototype.render=function(){var e=this.xrManager.getCamera(this.camera);this.renderer.render(this.scene,e)},t.prototype.onPanGesture=function(){},t.prototype.onTapGesture=function(){},t.prototype.onPinchGesture=function(){},t.prototype.onMouseMove=function(){},t.prototype.onMouseOut=function(){},t.prototype.panoResourceFromLocationMotionKeyframe=function(e){return this.panoResources[e.key]},t.prototype.updateControllerHelper=function(e,r,i){var a=this.xrControllerRay.left,o=this.xrControllerRay.right;if(!(!e||e.length===0)){for(var s={buttons:{X:!1,Y:!1,LeftTrigger:!1,LeftPinch:!1,A:!1,B:!1,RightTrigger:!1,RightPinch:!1}},u=0;u<e.length;u++){var c=e[u].handedness,l=e[u].gamepad;switch(c){case"left":l.axes&&(this.emitEvent(l.axes[2]===-1,"LeftAxesLeft",r),this.emitEvent(l.axes[2]===1,"LeftAxesRight",r),this.emitEvent(l.axes[3]===-1,"LeftAxesUp",r),this.emitEvent(l.axes[3]===1,"LeftAxesDown",r)),l!=null&&l.buttons&&(this.emitEvent(l==null?void 0:l.buttons[4].pressed,"X",r),this.emitEvent(l.buttons[5].pressed,"Y",r),this.emitEvent(l==null?void 0:l.buttons[0].pressed,"LeftTrigger",r),this.emitEvent(l==null?void 0:l.buttons[1].pressed,"LeftPinch",r));var h={raycaster:a,axes:{up:l.axes&&l.axes[3]<0?Math.abs(l.axes[3]):0,down:l.axes&&l.axes[3]<0?0:Math.abs(l.axes[3]),left:l.axes&&l.axes[2]<0?Math.abs(l.axes[2]):0,right:l.axes&&l.axes[2]<0?0:Math.abs(l.axes[2])},deltaTime:i};s.buttons.X=l.buttons&&l.buttons[4]?l.buttons[4].pressed:!1,s.buttons.Y=l.buttons&&l.buttons[5]?l==null?void 0:l.buttons[5].pressed:!1,s.buttons.LeftTrigger=l.buttons&&l.buttons[0]?l==null?void 0:l.buttons[0].pressed:!1,s.buttons.LeftPinch=l.buttons&&l.buttons[1]?l==null?void 0:l.buttons[1].pressed:!1,s.left=h;break;case"right":l.axes&&(this.emitEvent(l.axes[2]===-1,"RightAxesLeft",r),this.emitEvent(l.axes[2]===1,"RightAxesRight",r),this.emitEvent(l.axes[3]===-1,"RightAxesUp",r),this.emitEvent(l.axes[3]===1,"RightAxesDown",r)),l.buttons&&(this.emitEvent(l==null?void 0:l.buttons[4].pressed,"A",r),this.emitEvent(l.buttons[5].pressed,"B",r),this.emitEvent(l==null?void 0:l.buttons[0].pressed,"RightTrigger",r),this.emitEvent(l==null?void 0:l.buttons[1].pressed,"RightPinch",r));var p={raycaster:o,axes:{up:l.axes&&l.axes[3]<0?Math.abs(l.axes[3]):0,down:l.axes&&l.axes[3]<0?0:Math.abs(l.axes[3]),left:l.axes&&l.axes[2]<0?Math.abs(l.axes[2]):0,right:l.axes&&l.axes[2]<0?0:Math.abs(l.axes[2])},deltaTime:i};s.right=p,s.buttons.A=l.buttons&&l.buttons[4]?l==null?void 0:l.buttons[4].pressed:!1,s.buttons.B=l.buttons&&l.buttons[5]?l==null?void 0:l.buttons[5].pressed:!1,s.buttons.RightTrigger=l.buttons&&l.buttons[0]?l==null?void 0:l.buttons[0].pressed:!1,s.buttons.RightPinch=l.buttons&&l.buttons[1]?l==null?void 0:l.buttons[1].pressed:!1;break}}this.emit("xr.controller.update",_("xr.controller.update",s))}},t.prototype.emitEvent=function(e,r,i){var a=this.xrControllerRay.left,o=this.xrControllerRay.right;if(e)if(this.xrControllerState[r].touchStart===!1)this.xrControllerState[r].touchStartTime=i,this.xrControllerState[r].touchStart=!0,this.emit("xr.gesture.buttonDown",_("xr.gesture.buttonDown",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!1,isFirst:!0,controllers:{raycaster:{leftRay:a,rightRay:o}}}));else{var s=i-this.xrControllerState[r].touchStartTime;s>Ns&&this.emit("xr.gesture.press",_("xr.gesture.tap",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!0,controllers:{raycaster:{leftRay:a,rightRay:o}}}))}else if(this.xrControllerState[r].touchStart===!0){this.emit("xr.gesture.buttonUp",_("xr.gesture.buttonUp",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:a,rightRay:o}}}));var s=i-this.xrControllerState[r].touchStartTime;if(s<=Ns){var u=this.emit("xr.gesture.tap",_("xr.gesture.tap",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:a,rightRay:o}}}));u||r==="RightTrigger"&&this.checkSelectedPano(this.xrControllerRay.right)}this.xrControllerState[r].touchStart=!1,this.xrControllerState[r].touchStartTime=0}},t}(ao),Vt={Floorplan:si,Topview:Hf,Panorama:ao,VRPanorama:Hh,Model:_h,DepthPanorama:$h,Mapview:cp,XRPanorama:Fp},d0=["gesture.pan","gesture.tap","gesture.press","gesture.pinch","gesture.mousewheel","gesture.mousemove","gesture.momentum","initAnimation.start","initAnimation.end","camera.update","intersect.update","pano.select","pano.moveTo","pano.moving","pano.arrived","pano.cancel","pano.error","pano.texture.load","pano.texture.progress","pano.texture.success","pano.texture.error","pano.texture.abort","xr.session.start","xr.session.end","xr.gesture.tap","xr.gesture.press","xr.gesture.buttonUp","xr.gesture.buttonDown","xr.controller.update"];function Op(n){n.on("initAnimation.start",function(t){n.emit("initAnimationWillStart",t.state.panoIndex,t.state,t.userAction)}),n.on("initAnimation.end",function(t){n.emit("initAnimationEnded",t.state.panoIndex,t.state,t.userAction)}),n.on("gesture.pan",function(t){var e=!1;e=n.emit("wantsGesture","pan",t.pointers,t.isFinal),e&&t.preventDefault(),e=n.emit("wantsPanGesture",t.state,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","pan",t.pointers,t.isFinal),n.emit("panGesture",t.state,t.isFinal))}),n.on("gesture.tap",function(t){var e=!1;e=n.emit("wantsGesture","tap",t.pointers,t.isFinal),e&&t.preventDefault(),e=n.emit("wantsTapGesture",t.center.raycaster,t.center.coords,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","tap",t.pointers,t.isFinal),n.emit("tapGesture",t.center.raycaster,t.center.coords,t.isFinal))}),n.on("gesture.press",function(t){var e=!1;e=n.emit("wantsGesture","press",t.pointers,t.isFinal),e&&t.preventDefault(),e=n.emit("wantsPressGesture",t.center.raycaster,t.center.coords,t.center.delta,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","press",t.pointers,t.isFinal),n.emit("pressGesture",t.center.raycaster,t.center.coords,t.center.delta,t.isFinal))}),n.on("gesture.pinch",function(t){var e=!1;e=n.emit("wantsGesture","pinch",t.pointers,t.isFinal),e&&t.preventDefault(),e=n.emit("wantsPinchGesture",t.scale,t.state.fov,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","pinch",t.pointers,t.isFinal),n.emit("pinchGesture",t.scale,t.state.fov,t.isFinal))}),n.on("gesture.mousewheel",function(t){var e=!1;e=n.emit("wantsGesture","mouseWheel",t.pointers,t.isFinal),e&&t.preventDefault(),e=n.emit("wantsMouseWheel",t.center.delta,t.state.fov,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","mouseWheel",t.pointers,t.isFinal),n.emit("mouseWheel",t.center.delta,t.state.fov,t.isFinal))}),n.on("gesture.mousemove",function(t){var e=!1;e=n.emit("wantsGesture","mouseMove",t.pointers,t.isFinal),e&&t.preventDefault(),t.defaultPrevented||(n.emit("gesture","mouseMove",t.pointers,t.isFinal),e=n.emit("wantsChangeCameraFov",t.state.fov),e&&t.preventDefault())}),n.on("gesture.momentum",function(t){var e=!1;e=n.emit("wantsInteriaPan",t.state),e&&t.preventDefault(),t.defaultPrevented||n.emit("interiaPan",t.state,t.isFinal)}),n.on("camera.update",function(t){n.emit("cameraFovUpdate",t.state.fov,t.userAction),n.emit("cameraDirectionUpdate",t.state,t.userAction);var e=Rr(t.state);e.setLength(t.state.distance);var r=t.state.offset.clone().sub(e);n.emit("cameraPositionUpdate",r,t.userAction),n.emit("cameraUpdate",t.state,t.userAction)}),n.on("intersect.update",function(t){if(t.intersection){var e=!1;e=n.emit("wantsShowIntersectionOnModel",t.raycaster),e&&t.preventDefault(),t.defaultPrevented||n.emit("intersectionOnModelUpdate",t.intersection,t.object)}else n.emit("intersectionHidden")}),n.on("pano.request",function(t){var e=n.emit("wantsMoveToPano",t.state.panoIndex,t.options,t.userAction);e||(e=n.emit("wantsToMoveToPano",t.state.panoIndex,t.options,t.userAction)),e&&t.preventDefault(),t.defaultPrevented||n.emit("panoWillLoad",t.state.panoIndex)}),n.on("pano.select",function(t){n.emit("panoSelected",t.state.panoIndex)}),n.on("pano.moveTo",function(t){n.emit("panoLoaded",t.state.panoIndex),n.emit("moveToPano",t.state.panoIndex,t.userAction),n.emit("panoWillArrive",t.state.panoIndex,t.state,t.userAction)}),n.on("pano.moving",function(t){n.emit("movingToPano",t.state.panoIndex,t.prevPano.panoIndex,t.progress)}),n.on("pano.arrived",function(t){n.emit("panoArrived",t.state.panoIndex,t.state,t.userAction)}),n.on("pano.cancel",function(t){n.emit("moveToPanoCanceled",t.state.panoIndex)}),n.on("pano.error",function(t){n.emit("panoLoadError",t.error,t.state.panoIndex)}),n.on("pano.texture.load",function(t){n.emit("textureStartLoad",t.pano.panoIndex)}),n.on("pano.texture.success",function(t){n.emit("textureLoaded",t.pano.panoIndex,t.meta)}),n.on("pano.texture.error",function(t){n.emit("textureError",t.error,t.pano.panoIndex)}),n.on("pano.texture.abort",function(t){n.emit("textureAbort",t.pano.panoIndex)}),n.on("pano.texture.progress",function(t){n.emit("textureLoading",t.progress,t.pano.panoIndex)}),n.on("xr.session.start",function(t){n.emit("webXRSessionStart")}),n.on("xr.session.end",function(t){n.emit("webXRSessionEnd")}),n.on("xr.gesture.tap",function(t){n.emit("webXRControllerEvent","tap",t.buttons,{raycaster:t.controllers.raycaster})}),n.on("xr.gesture.press",function(t){n.emit("webXRControllerEvent","press",t.buttons,{raycaster:t.controllers.raycaster})}),n.on("xr.gesture.buttonUp",function(t){n.emit("webXRControllerEvent","buttonUp",t.buttons,{raycaster:t.controllers.raycaster})}),n.on("xr.gesture.buttonDown",function(t){n.emit("webXRControllerEvent","buttonDown",t.buttons,{raycaster:t.controllers.raycaster})}),n.on("xr.controller.update",function(t){n.emit("webXRControllerRayUpdate",{leftRay:t.left?t.left.raycaster:void 0,rightRay:t.right?t.right.raycaster:void 0}),t.left&&n.emit("webXRAxesUpdate","left",{raycaster:{leftRay:t.left?t.left.raycaster:void 0,rightRay:t.right?t.right.raycaster:void 0},axesState:{up:t.left.axes.up,down:t.left.axes.down,left:t.left.axes.left,right:t.left.axes.right},deltaTime:t.left.deltaTime}),t.right&&n.emit("webXRAxesUpdate","right",{raycaster:{leftRay:t.left?t.left.raycaster:void 0,rightRay:t.right?t.right.raycaster:void 0},axesState:{up:t.right.axes.up,down:t.right.axes.down,left:t.right.axes.left,right:t.right.axes.right},deltaTime:t.right.deltaTime})}),n.on("works.request",function(t){n.emit("willLoad",t.input,t.works[0],t.state)}),n.on("works.load",function(t){n.emit("load",t.input,t.works[0],t.state)}),n.on("works.ready",function(t){n.emit("loaded",t.input,t.works[0])}),n.on("state.change",function(t){n.emit("stateChange",t.state,t.userAction)}),n.on("currentState.change",function(t){n.emit("currentStateChange",t.state,t.userAction)}),n.on("state.set",function(t){n.emit("setState",t.state)}),n.on("state.synced",function(t){n.emit("stateSynced",t.state)}),n.on("model.request",function(t){n.emit("modelWillLoad",t.work.model)}),n.on("model.error",function(t){n.emit("modelLoadError",t.error,t.model)}),n.on("model.load",function(t){n.emit("modelLoaded",t.model)}),n.on("model.changeShownFloor",function(t){n.emit("modelShownFloorChange",t.model.shownFloor,t.model.floorLength)}),n.on("render",function(t){n.emit("renderFrame",t.needsRender)}),n.on("mode.change.request",function(t){n.emit("wantsChangeMode",t.mode,t.prevMode)}),n.on("mode.change",function(t){n.emit("modeChange",t.mode,t.prevMode,t.state.panoIndex,t.state,t.userAction)}),n.on("helpers.visible",function(t){n.emit("helpersVisibleChange",t.object.visible)}),n.on("network.resource",function(t){n.emit("network",t.source,t.requestType,t.requestState,t.detail)})}function kp(){var n=document.createElement("video");n.loop=!0,n.autoplay=!0,n.playsInline=!0,n.muted=!0,n.crossOrigin="";var t=function(){document.removeEventListener("touchstart",t,!1),document.removeEventListener("mousedown",t,!1),n.muted=!1};return document.addEventListener("touchstart",t,!1),document.addEventListener("mousedown",t,!1),n}function Lp(n){{var t=new d.DirectionalLight(16777215,.5);t.position.copy(new d.Vector3(1,1,1)),n.add(t)}{var t=new d.DirectionalLight(16777215,.3);n.add(t)}{var t=new d.AmbientLight(16777215,.3);n.add(t)}}function Dp(n){for(var t,e,r={},i=n.split(/(\;|\,)/),a=0,o=i;a<o.length;a++){var s=o[a],u=s.split("="),c=(t=u[0])===null||t===void 0?void 0:t.trim(),l=(e=u[1])===null||e===void 0?void 0:e.trim();c&&l&&(r[c]=l)}return r}function f0(){for(var n,t=document.getElementsByTagName("meta"),e=0;e<t.length;e++){var r=t[e];if(r.getAttribute("name")==="viewport"){var i=Dp((n=r.getAttribute("content"))!==null&&n!==void 0?n:""),a=Number(i["initial-scale"]);if(!isNaN(a))return a}}return 1}const Np="data:image/png;base64,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";var Vs=[351,63],Us=[20,20],Qp=new Float32Array([-.5,-.5,0,.5,-.5,0,-.5,.5,0,.5,.5,0]),Vp=new Float32Array([0,0,1,0,0,1,1,1]),Up=new Uint8Array([0,1,2,1,3,2]),Fi=new d.BufferGeometry;Fi.setAttribute("position",new d.BufferAttribute(Qp,3));Fi.setAttribute("uv",new d.BufferAttribute(Vp,2));Fi.setIndex(new d.BufferAttribute(Up,1));var ui=new d.MeshBasicMaterial({transparent:!0,depthTest:!1,depthWrite:!1,stencilWrite:!1,fog:!1}),h0=new d.Mesh(Fi,ui);h0.matrixAutoUpdate=!1;var co=new d.Scene;co.add(h0);co.matrixAutoUpdate=!1;var Un=new d.OrthographicCamera(-.5,.5,.5,-.5,.1,1);Un.position.set(0,0,.5);Un.lookAt(0,0,0);Un.updateMatrixWorld(!0);Un.matrixAutoUpdate=!1;var qp=new d.Vector4,zp=new d.Vector4;function qs(n){if(ui.map){var r=n.getViewport(qp),i=n.getScissor(zp),a=n.getScissorTest(),o=n.autoClear,s=i.x+Us[0]/3,u=i.y+Us[1]/3,c=Vs[0]/3,l=Vs[1]/3;n.setViewport(s,u,c,l),n.setScissor(s,u,c,l),n.setScissorTest(!0),n.autoClear=!1,n.render(co,Un),n.setViewport(r),n.setScissor(i),n.setScissorTest(a),n.autoClear=o}else{var t=new d.Texture,e=new Image;e.onload=function(){t.image=e,t.wrapS=d.ClampToEdgeWrapping,t.wrapT=d.ClampToEdgeWrapping,t.minFilter=d.LinearFilter,t.needsUpdate=!0,t.generateMipmaps=!1,ui.needsUpdate=!0,e.onload=Q},e.src=Np,ui.map=t}}var Hp=800,jp=function(n){return n.replace("//vrlab-public.ljcdn.com/","//vr-public.realsee-cdn.cn/").replace("//vrlab-image4.ljcdn.com/","//vr-image-4.realsee-cdn.cn/").replace("//vrlab-image3.ljcdn.com/","//vr-image-3.realsee-cdn.cn/").replace("//vrlab-image2.ljcdn.com/","//vr-image-2.realsee-cdn.cn/").replace("//vrlab-image1.ljcdn.com/","//vr-image-1.realsee-cdn.cn/")},_p=[{name:"Z",transformToUpAxisZ:function(){return new d.Matrix4}},{name:"Y",transformToUpAxisZ:function(){return new d.Matrix4().makeRotationAxis(new d.Vector3(1,0,0),+Math.PI/2)}},{name:"-Y",transformToUpAxisZ:function(){return new d.Matrix4().makeRotationAxis(new d.Vector3(1,0,0),-Math.PI/2)}},{name:"WGS84",transformToEarthCentered:function(){return new d.Matrix4}},{name:"GCJ02",transformToEarthCentered:function(){return new d.Matrix4}},{name:"BD09",transformToEarthCentered:function(){return new d.Matrix4}}],on=new d.Vector2,ri=new d.Frustum,ni=new d.Matrix4,zs=new WeakMap,Hs=new WeakMap,js=Gu([]),p0=function(n){de(t,n);function t(e){e===void 0&&(e={});var r,i,a,o,s,u,c,l,h,p,v=n.call(this)||this;v.ident=vt(),ka.instances[v.ident]=v,v.renderSwitch01=0,v.currentMode="Panorama",v.pano={workCode:"",panoIndex:0},v.needsRender=!1,v.onlyRenderIfNeeds=(r=e.onlyRenderIfNeeds)!==null&&r!==void 0?r:!0,v.imageOptions=R({},(i=e.imageOptions)!==null&&i!==void 0?i:{}),v.textureOptions=R({},(a=e.textureOptions)!==null&&a!==void 0?a:{}),v.poweredByRealsee=(o=e.poweredByRealsee)!==null&&o!==void 0?o:!0,v.extraElements=[],v.controllerInits={Panorama:Object.assign({},e.panorama),Model:Object.assign({},e.model),Floorplan:Object.assign({},e.floorplan),Topview:Object.assign({},e.topview),Mapview:Object.assign({},e.mapview),DepthPanorama:Object.assign({},e.depthPanorama),VRPanorama:Object.assign({},e.vrPanorama),XRPanorama:Object.assign({},e.xrPanorama)},v.coordinatesSystemTransformers=at([],(s=e.coordinatesSystemTransformers)!==null&&s!==void 0?s:[],!0);for(var m=function(F){var k=A.coordinatesSystemTransformers.find(function(O){return O.name===F.name});k||A.coordinatesSystemTransformers.push(R({},F))},A=this,y=0,f=_p;y<f.length;y++){var g=f[y];m(g)}if(v.fps={testCount:0,testTime:ve()},v.info=null,v.modeChangeDuration=(u=e.modeChangeDuration)!==null&&u!==void 0?u:Hp,v.enableWheel=(c=e.enableWheel)!==null&&c!==void 0?c:!0,typeof window<"u")if(e.renderer)e.renderer instanceof _r&&v.throwError(new Error("cannot render a internal renderer")),v.renderer=e.renderer;else try{v.renderer=new _r({preserveDrawingBuffer:e.preserveDrawingBuffer,backgroundColor:e.backgroundColor,backgroundAlpha:e.backgroundAlpha,antialias:e.antialias,webgl2:e==null?void 0:e.webgl2});var b=f0();v.renderer.setPixelRatio(b===1?window.devicePixelRatio:1),v.renderer.setSize(512,512)}catch(F){F instanceof Error&&v.throwError(F)}v.getPixelsRenderTarget=new d.WebGLRenderTarget(1,1,{encoding:(h=(l=v.renderer)===null||l===void 0?void 0:l.outputEncoding)!==null&&h!==void 0?h:d.sRGBEncoding}),v.scissor=Object.assign({left:0,bottom:0,width:1,height:1},e.scissor),v.camera=new hi(90),v.scene=new cu,v.xrCustomObjectsScene=new d.Scene,v.scene.add(v.xrCustomObjectsScene),v.scene.matrixAutoUpdate=!1,v.lastLoadWorkTask=Promise.resolve(),v.requestProxy=(p=e.requestProxy)!==null&&p!==void 0?p:jp,v.networkSubscribe=new Zs,v.networkSubscribe.on("network",function(F,k,O,L){var N;v.emit("network.resource",_("network.resource",{source:F,requestType:k,requestState:O,detail:L})),(N=v.analysis)===null||N===void 0||N.network(v.works,F,k,O,L)}),v.boundingMesh=kf(new d.Box3(new d.Vector3(-.5,-.5,-.5),new d.Vector3(.5,.5,.5))),v.boundingMesh.name="bounding",v.scene.add(v.boundingMesh),v.models=vs(),v.models.push(new Ba),v.lastModels=vs(),v.readyCallbacks=[],v.syncingState=!1,v.modelGroup=new d.Group,v.modelGroup.visible=!1,v.modelGroup.name="model",v.modelGroup.matrixAutoUpdate=!1,v.modelGroup.renderOrder=-4,v.scene.add(v.modelGroup),v.helperGroup=new d.Group,v.helperGroup.name="helper",v.helperGroup.matrixAutoUpdate=!1,v.scene.add(v.helperGroup),v.videoTexture=new d.VideoTexture(e.videoInstance||kp()),Lp(v.scene),v.copyEffect=new Bi(v.renderer,v.scene,v.camera,v.models),v.state={mode:v.currentMode,workCode:v.pano.workCode,panoIndex:v.pano.panoIndex,longitude:v.camera.pose.longitude,latitude:v.camera.pose.latitude,fov:v.camera.pose.fov,offset:v.camera.pose.offset.clone(),distance:v.camera.pose.distance},v.stateSynced=!1,v._enableIOSEDR=!1,v.destroyed=!1,v.paused=!0,typeof window<"u"&&(e.play!==!1&&v.play(),v.stopAnimationLoop=it.shared.add(function(F,k){for(var O=[],L=2;L<arguments.length;L++)O[L-2]=arguments[L];v.updateTime.apply(v,at([F,k],O,!1))},!1,0,10));var w=function(){typeof document<"u"&&document.fullscreenElement===null&&v.currentMode==="VRPanorama"&&v.controller.emit("vr.requestExit",_("vr.requestExit",{}))};if(typeof document<"u"&&document.addEventListener("fullscreenchange",w,!1),v.removeEventListeners=function(){typeof document<"u"&&document.removeEventListener("fullscreenchange",w,!1)},v.plugins={},e.plugins&&e.plugins.length)for(var E=0,x=e.plugins;E<x.length;E++){var M=x[E];if(typeof M=="function")M(v);else if(Array.isArray(M)){var C=M[0],I=M[1],P=M[2];if(typeof C=="function"){var S=C(v,P);typeof I=="string"&&(v.plugins[I]?v.throwError(new Error("plugin name ".concat(I," is exists."))):v.plugins[I]=S)}}}return v.gpuPickingRenderTarget=new d.WebGLRenderTarget(1,1),v.meshReplaceMaterialMap=new Map,v.meshOriginMaterialMap=new Map,Op(v),v}return Object.defineProperty(t,"version",{get:function(){return"6.0.0-alpha.66"},enumerable:!1,configurable:!0}),Object.defineProperty(t,"dracoPath",{get:function(){return mi.decoderPath},set:function(e){mi.setDecoderPath(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t,"ktx2Path",{get:function(){return Fn.transcoderPath},set:function(e){Fn.setTranscoderPath(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"panoIndex",{get:function(){return this.pano.panoIndex},enumerable:!1,configurable:!0}),t.prototype.getGPUPicking=function(e,r,i,a,o){var s=this;if(a===void 0&&(a=1),o===void 0&&(o=new d.Vector3(0,0,0)),!this.renderer)throw new Error("renderer is not initialized.");this.models.setMaterial({constantColor:o}),this.scene.traverse(function(h){if(!(!(h instanceof d.Mesh)||h instanceof _t)){var p=Object.keys(i).filter(function(m){return m===h.uuid})[0];if(p)if(s.meshOriginMaterialMap.set(p,h.material),s.meshReplaceMaterialMap.get(p))h.material=s.meshReplaceMaterialMap.get(p);else{var v=new d.ShaderMaterial({uniforms:{color:{value:i[p]}},vertexShader:`
|
|
2039
2039
|
void main() {
|
|
2040
2040
|
vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );
|
|
2041
2041
|
gl_Position = projectionMatrix * mvPosition;
|