@realsee/five 6.0.0-alpha.64 → 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 +66 -66
- package/five/index.mjs +1151 -1140
- package/gltf-loader/index.js +3 -3
- package/gltf-loader/index.mjs +3 -3
- package/line/index.js +3 -3
- package/line/index.mjs +3 -3
- package/package.json +1 -1
- package/react/index.js +2 -2
- package/react/index.mjs +2 -2
- package/sticker/index.js +3 -3
- package/sticker/index.mjs +3 -3
- package/umd/five-gltf-loader.js +3 -3
- package/umd/five-line.js +3 -3
- package/umd/five-react.js +2 -2
- package/umd/five-sticker.js +3 -3
- package/umd/five-vfx.js +2 -2
- package/umd/five-vue.js +2 -2
- package/umd/five.js +20 -20
- package/vfx/index.js +2 -2
- package/vfx/index.mjs +2 -2
- package/vue/index.js +2 -2
- package/vue/index.mjs +2 -2
package/umd/five.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* @license
|
|
3
3
|
* @realsee/five
|
|
4
|
-
* Generated: 12/
|
|
5
|
-
* Version: 6.0.0-alpha.
|
|
4
|
+
* Generated: 12/14/2023
|
|
5
|
+
* Version: 6.0.0-alpha.66
|
|
6
6
|
* Terms:
|
|
7
7
|
* Realsee SDK License Agreement
|
|
8
8
|
* Update: July 28, 2021
|
|
@@ -339,7 +339,7 @@
|
|
|
339
339
|
*
|
|
340
340
|
* https://code.google.com/p/crypto-js/wiki/License
|
|
341
341
|
* PART: ext/cryptojs
|
|
342
|
-
*/var KJUR={},CryptoJS=CryptoJS||function(n,t){var e={},r=e.lib={},i=r.Base=function(){function h(){}return{extend:function(v){h.prototype=this;var A=new h;return v&&A.mixIn(v),A.hasOwnProperty("init")||(A.init=function(){A.$super.init.apply(this,arguments)}),A.init.prototype=A,A.$super=this,A},create:function(){var v=this.extend();return v.init.apply(v,arguments),v},init:function(){},mixIn:function(v){for(var A in v)v.hasOwnProperty(A)&&(this[A]=v[A]);v.hasOwnProperty("toString")&&(this.toString=v.toString)},clone:function(){return this.init.prototype.extend(this)}}}(),o=r.WordArray=i.extend({init:function(h,v){h=this.words=h||[],v!=t?this.sigBytes=v:this.sigBytes=h.length*4},toString:function(h){return(h||u).stringify(this)},concat:function(h){var v=this.words,A=h.words,m=this.sigBytes,y=h.sigBytes;if(this.clamp(),m%4)for(var p=0;p<y;p++){var g=A[p>>>2]>>>24-p%4*8&255;v[m+p>>>2]|=g<<24-(m+p)%4*8}else for(var p=0;p<y;p+=4)v[m+p>>>2]=A[p>>>2];return this.sigBytes+=y,this},clamp:function(){var h=this.words,v=this.sigBytes;h[v>>>2]&=4294967295<<32-v%4*8,h.length=n.ceil(v/4)},clone:function(){var h=i.clone.call(this);return h.words=this.words.slice(0),h},random:function(h){for(var v=[],A=0;A<h;A+=4)v.push(n.random()*4294967296|0);return new o.init(v,h)}}),s=e.enc={},u=s.Hex={stringify:function(h){for(var v=h.words,A=h.sigBytes,m=[],y=0;y<A;y++){var p=v[y>>>2]>>>24-y%4*8&255;m.push((p>>>4).toString(16)),m.push((p&15).toString(16))}return m.join("")},parse:function(h){for(var v=h.length,A=[],m=0;m<v;m+=2)A[m>>>3]|=parseInt(h.substr(m,2),16)<<24-m%8*4;return new o.init(A,v/2)}},l=s.Latin1={stringify:function(h){for(var v=h.words,A=h.sigBytes,m=[],y=0;y<A;y++){var p=v[y>>>2]>>>24-y%4*8&255;m.push(String.fromCharCode(p))}return m.join("")},parse:function(h){for(var v=h.length,A=[],m=0;m<v;m++)A[m>>>2]|=(h.charCodeAt(m)&255)<<24-m%4*8;return new o.init(A,v)}},d=s.Utf8={stringify:function(h){try{return decodeURIComponent(escape(l.stringify(h)))}catch{throw new Error("Malformed UTF-8 data")}},parse:function(h){return l.parse(unescape(encodeURIComponent(h)))}},c=r.BufferedBlockAlgorithm=i.extend({reset:function(){this._data=new o.init,this._nDataBytes=0},_append:function(h){typeof h=="string"&&(h=d.parse(h)),this._data.concat(h),this._nDataBytes+=h.sigBytes},_process:function(h){var v=this._data,A=v.words,m=v.sigBytes,y=this.blockSize,p=y*4,g=m/p;h?g=n.ceil(g):g=n.max((g|0)-this._minBufferSize,0);var b=g*y,T=n.min(b*4,m);if(b){for(var _=0;_<b;_+=y)this._doProcessBlock(A,_);var w=A.splice(0,b);v.sigBytes-=T}return new o.init(w,T)},clone:function(){var h=i.clone.call(this);return h._data=this._data.clone(),h},_minBufferSize:0});r.Hasher=c.extend({cfg:i.extend(),init:function(h){this.cfg=this.cfg.extend(h),this.reset()},reset:function(){c.reset.call(this),this._doReset()},update:function(h){return this._append(h),this._process(),this},finalize:function(h){h&&this._append(h);var v=this._doFinalize();return v},blockSize:512/32,_createHelper:function(h){return function(v,A){return new h.init(A).finalize(v)}},_createHmacHelper:function(h){return function(v,A){return new f.HMAC.init(h,A).finalize(v)}}});var f=e.algo={};return e}(Math);(function(n){for(var t=CryptoJS,v=t.lib,e=v.WordArray,r=v.Hasher,v=t.algo,i=[],o=[],s=function(m){return 4294967296*(m-(m|0))|0},u=2,l=0;64>l;){var d;e:{d=u;for(var c=n.sqrt(d),f=2;f<=c;f++)if(!(d%f)){d=!1;break e}d=!0}d&&(8>l&&(i[l]=s(n.pow(u,.5))),o[l]=s(n.pow(u,1/3)),l++),u++}var h=[],v=v.SHA256=r.extend({_doReset:function(){this._hash=new e.init(i.slice(0))},_doProcessBlock:function(A,m){for(var y=this._hash.words,p=y[0],g=y[1],b=y[2],T=y[3],_=y[4],w=y[5],x=y[6],M=y[7],R=0;64>R;R++){if(16>R)h[R]=A[m+R]|0;else{var I=h[R-15],S=h[R-2];h[R]=((I<<25|I>>>7)^(I<<14|I>>>18)^I>>>3)+h[R-7]+((S<<15|S>>>17)^(S<<13|S>>>19)^S>>>10)+h[R-16]}I=M+((_<<26|_>>>6)^(_<<21|_>>>11)^(_<<7|_>>>25))+(_&w^~_&x)+o[R]+h[R],S=((p<<30|p>>>2)^(p<<19|p>>>13)^(p<<10|p>>>22))+(p&g^p&b^g&b),M=x,x=w,w=_,_=T+I|0,T=b,b=g,g=p,p=I+S|0}y[0]=y[0]+p|0,y[1]=y[1]+g|0,y[2]=y[2]+b|0,y[3]=y[3]+T|0,y[4]=y[4]+_|0,y[5]=y[5]+w|0,y[6]=y[6]+x|0,y[7]=y[7]+M|0},_doFinalize:function(){var A=this._data,m=A.words,y=8*this._nDataBytes,p=8*A.sigBytes;return m[p>>>5]|=128<<24-p%32,m[(p+64>>>9<<4)+14]=n.floor(y/4294967296),m[(p+64>>>9<<4)+15]=y,A.sigBytes=4*m.length,this._process(),this._hash},clone:function(){var A=r.clone.call(this);return A._hash=this._hash.clone(),A}});t.SHA256=r._createHelper(v),t.HmacSHA256=r._createHmacHelper(v)})(Math),CryptoJS.lib.Cipher||function(n){var v=CryptoJS,t=v.lib,e=t.Base,r=t.WordArray,i=t.BufferedBlockAlgorithm,o=v.enc.Base64,s=v.algo.EvpKDF,u=t.Cipher=i.extend({cfg:e.extend(),createEncryptor:function(m,y){return this.create(this._ENC_XFORM_MODE,m,y)},createDecryptor:function(m,y){return this.create(this._DEC_XFORM_MODE,m,y)},init:function(m,y,p){this.cfg=this.cfg.extend(p),this._xformMode=m,this._key=y,this.reset()},reset:function(){i.reset.call(this),this._doReset()},process:function(m){return this._append(m),this._process()},finalize:function(m){return m&&this._append(m),this._doFinalize()},keySize:4,ivSize:4,_ENC_XFORM_MODE:1,_DEC_XFORM_MODE:2,_createHelper:function(m){return{encrypt:function(y,p,g){return(typeof p=="string"?A:h).encrypt(m,y,p,g)},decrypt:function(y,p,g){return(typeof p=="string"?A:h).decrypt(m,y,p,g)}}}});t.StreamCipher=u.extend({_doFinalize:function(){return this._process(!0)},blockSize:1});var f=v.mode={},l=function(m,y,p){var g=this._iv;g?this._iv=n:g=this._prevBlock;for(var b=0;b<p;b++)m[y+b]^=g[b]},d=(t.BlockCipherMode=e.extend({createEncryptor:function(m,y){return this.Encryptor.create(m,y)},createDecryptor:function(m,y){return this.Decryptor.create(m,y)},init:function(m,y){this._cipher=m,this._iv=y}})).extend();d.Encryptor=d.extend({processBlock:function(m,y){var p=this._cipher,g=p.blockSize;l.call(this,m,y,g),p.encryptBlock(m,y),this._prevBlock=m.slice(y,y+g)}}),d.Decryptor=d.extend({processBlock:function(m,y){var p=this._cipher,g=p.blockSize,b=m.slice(y,y+g);p.decryptBlock(m,y),l.call(this,m,y,g),this._prevBlock=b}}),f=f.CBC=d,d=(v.pad={}).Pkcs7={pad:function(m,y){for(var p=4*y,p=p-m.sigBytes%p,g=p<<24|p<<16|p<<8|p,b=[],T=0;T<p;T+=4)b.push(g);p=r.create(b,p),m.concat(p)},unpad:function(m){m.sigBytes-=m.words[m.sigBytes-1>>>2]&255}},t.BlockCipher=u.extend({cfg:u.cfg.extend({mode:f,padding:d}),reset:function(){u.reset.call(this);var y=this.cfg,m=y.iv,y=y.mode;if(this._xformMode==this._ENC_XFORM_MODE)var p=y.createEncryptor;else p=y.createDecryptor,this._minBufferSize=1;this._mode=p.call(y,this,m&&m.words)},_doProcessBlock:function(m,y){this._mode.processBlock(m,y)},_doFinalize:function(){var m=this.cfg.padding;if(this._xformMode==this._ENC_XFORM_MODE){m.pad(this._data,this.blockSize);var y=this._process(!0)}else y=this._process(!0),m.unpad(y);return y},blockSize:4});var c=t.CipherParams=e.extend({init:function(m){this.mixIn(m)},toString:function(m){return(m||this.formatter).stringify(this)}}),f=(v.format={}).OpenSSL={stringify:function(m){var y=m.ciphertext;return m=m.salt,(m?r.create([1398893684,1701076831]).concat(m).concat(y):y).toString(o)},parse:function(m){m=o.parse(m);var y=m.words;if(y[0]==1398893684&&y[1]==1701076831){var p=r.create(y.slice(2,4));y.splice(0,4),m.sigBytes-=16}return c.create({ciphertext:m,salt:p})}},h=t.SerializableCipher=e.extend({cfg:e.extend({format:f}),encrypt:function(m,y,p,g){g=this.cfg.extend(g);var b=m.createEncryptor(p,g);return y=b.finalize(y),b=b.cfg,c.create({ciphertext:y,key:p,iv:b.iv,algorithm:m,mode:b.mode,padding:b.padding,blockSize:m.blockSize,formatter:g.format})},decrypt:function(m,y,p,g){return g=this.cfg.extend(g),y=this._parse(y,g.format),m.createDecryptor(p,g).finalize(y.ciphertext)},_parse:function(m,y){return typeof m=="string"?y.parse(m,this):m}}),v=(v.kdf={}).OpenSSL={execute:function(m,y,p,g){return g||(g=r.random(8)),m=s.create({keySize:y+p}).compute(m,g),p=r.create(m.words.slice(y),4*p),m.sigBytes=4*y,c.create({key:m,iv:p,salt:g})}},A=t.PasswordBasedCipher=h.extend({cfg:h.cfg.extend({kdf:v}),encrypt:function(m,y,p,g){return g=this.cfg.extend(g),p=g.kdf.execute(p,m.keySize,m.ivSize),g.iv=p.iv,m=h.encrypt.call(this,m,y,p.key,g),m.mixIn(p),m},decrypt:function(m,y,p,g){return g=this.cfg.extend(g),y=this._parse(y,g.format),p=g.kdf.execute(p,m.keySize,m.ivSize,y.salt),g.iv=p.iv,h.decrypt.call(this,m,y,p.key,g)}})}(),function(){for(var n=CryptoJS,t=n.lib.BlockCipher,w=n.algo,e=[],r=[],i=[],o=[],s=[],u=[],l=[],d=[],c=[],f=[],h=[],v=0;256>v;v++)h[v]=128>v?v<<1:v<<1^283;for(var A=0,m=0,v=0;256>v;v++){var y=m^m<<1^m<<2^m<<3^m<<4,y=y>>>8^y&255^99;e[A]=y,r[y]=A;var p=h[A],g=h[p],b=h[g],T=257*h[y]^16843008*y;i[A]=T<<24|T>>>8,o[A]=T<<16|T>>>16,s[A]=T<<8|T>>>24,u[A]=T,T=16843009*b^65537*g^257*p^16843008*A,l[y]=T<<24|T>>>8,d[y]=T<<16|T>>>16,c[y]=T<<8|T>>>24,f[y]=T,A?(A=p^h[h[h[b^p]]],m^=h[h[m]]):A=m=1}var _=[0,1,2,4,8,16,32,64,128,27,54],w=w.AES=t.extend({_doReset:function(){for(var R=this._key,x=R.words,M=R.sigBytes/4,R=4*((this._nRounds=M+6)+1),I=this._keySchedule=[],S=0;S<R;S++)if(S<M)I[S]=x[S];else{var B=I[S-1];S%M?6<M&&S%M==4&&(B=e[B>>>24]<<24|e[B>>>16&255]<<16|e[B>>>8&255]<<8|e[B&255]):(B=B<<8|B>>>24,B=e[B>>>24]<<24|e[B>>>16&255]<<16|e[B>>>8&255]<<8|e[B&255],B^=_[S/M|0]<<24),I[S]=I[S-M]^B}for(x=this._invKeySchedule=[],M=0;M<R;M++)S=R-M,B=M%4?I[S]:I[S-4],x[M]=4>M||4>=S?B:l[e[B>>>24]]^d[e[B>>>16&255]]^c[e[B>>>8&255]]^f[e[B&255]]},encryptBlock:function(x,M){this._doCryptBlock(x,M,this._keySchedule,i,o,s,u,e)},decryptBlock:function(x,M){var R=x[M+1];x[M+1]=x[M+3],x[M+3]=R,this._doCryptBlock(x,M,this._invKeySchedule,l,d,c,f,r),R=x[M+1],x[M+1]=x[M+3],x[M+3]=R},_doCryptBlock:function(x,M,R,I,S,B,F,O){for(var H=this._nRounds,z=x[M]^R[0],G=x[M+1]^R[1],W=x[M+2]^R[2],K=x[M+3]^R[3],k=4,N=1;N<H;N++)var q=I[z>>>24]^S[G>>>16&255]^B[W>>>8&255]^F[K&255]^R[k++],V=I[G>>>24]^S[W>>>16&255]^B[K>>>8&255]^F[z&255]^R[k++],D=I[W>>>24]^S[K>>>16&255]^B[z>>>8&255]^F[G&255]^R[k++],K=I[K>>>24]^S[z>>>16&255]^B[G>>>8&255]^F[W&255]^R[k++],z=q,G=V,W=D;q=(O[z>>>24]<<24|O[G>>>16&255]<<16|O[W>>>8&255]<<8|O[K&255])^R[k++],V=(O[G>>>24]<<24|O[W>>>16&255]<<16|O[K>>>8&255]<<8|O[z&255])^R[k++],D=(O[W>>>24]<<24|O[K>>>16&255]<<16|O[z>>>8&255]<<8|O[G&255])^R[k++],K=(O[K>>>24]<<24|O[z>>>16&255]<<16|O[G>>>8&255]<<8|O[W&255])^R[k++],x[M]=q,x[M+1]=V,x[M+2]=D,x[M+3]=K},keySize:8});n.AES=t._createHelper(w)}();/*! (c) Tom Wu | http://www-cs-students.stanford.edu/~tjw/jsbn/
|
|
342
|
+
*/var KJUR={},CryptoJS=CryptoJS||function(n,t){var e={},r=e.lib={},i=r.Base=function(){function h(){}return{extend:function(v){h.prototype=this;var A=new h;return v&&A.mixIn(v),A.hasOwnProperty("init")||(A.init=function(){A.$super.init.apply(this,arguments)}),A.init.prototype=A,A.$super=this,A},create:function(){var v=this.extend();return v.init.apply(v,arguments),v},init:function(){},mixIn:function(v){for(var A in v)v.hasOwnProperty(A)&&(this[A]=v[A]);v.hasOwnProperty("toString")&&(this.toString=v.toString)},clone:function(){return this.init.prototype.extend(this)}}}(),o=r.WordArray=i.extend({init:function(h,v){h=this.words=h||[],v!=t?this.sigBytes=v:this.sigBytes=h.length*4},toString:function(h){return(h||u).stringify(this)},concat:function(h){var v=this.words,A=h.words,m=this.sigBytes,y=h.sigBytes;if(this.clamp(),m%4)for(var p=0;p<y;p++){var g=A[p>>>2]>>>24-p%4*8&255;v[m+p>>>2]|=g<<24-(m+p)%4*8}else for(var p=0;p<y;p+=4)v[m+p>>>2]=A[p>>>2];return this.sigBytes+=y,this},clamp:function(){var h=this.words,v=this.sigBytes;h[v>>>2]&=4294967295<<32-v%4*8,h.length=n.ceil(v/4)},clone:function(){var h=i.clone.call(this);return h.words=this.words.slice(0),h},random:function(h){for(var v=[],A=0;A<h;A+=4)v.push(n.random()*4294967296|0);return new o.init(v,h)}}),s=e.enc={},u=s.Hex={stringify:function(h){for(var v=h.words,A=h.sigBytes,m=[],y=0;y<A;y++){var p=v[y>>>2]>>>24-y%4*8&255;m.push((p>>>4).toString(16)),m.push((p&15).toString(16))}return m.join("")},parse:function(h){for(var v=h.length,A=[],m=0;m<v;m+=2)A[m>>>3]|=parseInt(h.substr(m,2),16)<<24-m%8*4;return new o.init(A,v/2)}},l=s.Latin1={stringify:function(h){for(var v=h.words,A=h.sigBytes,m=[],y=0;y<A;y++){var p=v[y>>>2]>>>24-y%4*8&255;m.push(String.fromCharCode(p))}return m.join("")},parse:function(h){for(var v=h.length,A=[],m=0;m<v;m++)A[m>>>2]|=(h.charCodeAt(m)&255)<<24-m%4*8;return new o.init(A,v)}},d=s.Utf8={stringify:function(h){try{return decodeURIComponent(escape(l.stringify(h)))}catch{throw new Error("Malformed UTF-8 data")}},parse:function(h){return l.parse(unescape(encodeURIComponent(h)))}},c=r.BufferedBlockAlgorithm=i.extend({reset:function(){this._data=new o.init,this._nDataBytes=0},_append:function(h){typeof h=="string"&&(h=d.parse(h)),this._data.concat(h),this._nDataBytes+=h.sigBytes},_process:function(h){var v=this._data,A=v.words,m=v.sigBytes,y=this.blockSize,p=y*4,g=m/p;h?g=n.ceil(g):g=n.max((g|0)-this._minBufferSize,0);var b=g*y,T=n.min(b*4,m);if(b){for(var _=0;_<b;_+=y)this._doProcessBlock(A,_);var w=A.splice(0,b);v.sigBytes-=T}return new o.init(w,T)},clone:function(){var h=i.clone.call(this);return h._data=this._data.clone(),h},_minBufferSize:0});r.Hasher=c.extend({cfg:i.extend(),init:function(h){this.cfg=this.cfg.extend(h),this.reset()},reset:function(){c.reset.call(this),this._doReset()},update:function(h){return this._append(h),this._process(),this},finalize:function(h){h&&this._append(h);var v=this._doFinalize();return v},blockSize:512/32,_createHelper:function(h){return function(v,A){return new h.init(A).finalize(v)}},_createHmacHelper:function(h){return function(v,A){return new f.HMAC.init(h,A).finalize(v)}}});var f=e.algo={};return e}(Math);(function(n){for(var t=CryptoJS,v=t.lib,e=v.WordArray,r=v.Hasher,v=t.algo,i=[],o=[],s=function(m){return 4294967296*(m-(m|0))|0},u=2,l=0;64>l;){var d;e:{d=u;for(var c=n.sqrt(d),f=2;f<=c;f++)if(!(d%f)){d=!1;break e}d=!0}d&&(8>l&&(i[l]=s(n.pow(u,.5))),o[l]=s(n.pow(u,1/3)),l++),u++}var h=[],v=v.SHA256=r.extend({_doReset:function(){this._hash=new e.init(i.slice(0))},_doProcessBlock:function(A,m){for(var y=this._hash.words,p=y[0],g=y[1],b=y[2],T=y[3],_=y[4],w=y[5],x=y[6],M=y[7],R=0;64>R;R++){if(16>R)h[R]=A[m+R]|0;else{var I=h[R-15],S=h[R-2];h[R]=((I<<25|I>>>7)^(I<<14|I>>>18)^I>>>3)+h[R-7]+((S<<15|S>>>17)^(S<<13|S>>>19)^S>>>10)+h[R-16]}I=M+((_<<26|_>>>6)^(_<<21|_>>>11)^(_<<7|_>>>25))+(_&w^~_&x)+o[R]+h[R],S=((p<<30|p>>>2)^(p<<19|p>>>13)^(p<<10|p>>>22))+(p&g^p&b^g&b),M=x,x=w,w=_,_=T+I|0,T=b,b=g,g=p,p=I+S|0}y[0]=y[0]+p|0,y[1]=y[1]+g|0,y[2]=y[2]+b|0,y[3]=y[3]+T|0,y[4]=y[4]+_|0,y[5]=y[5]+w|0,y[6]=y[6]+x|0,y[7]=y[7]+M|0},_doFinalize:function(){var A=this._data,m=A.words,y=8*this._nDataBytes,p=8*A.sigBytes;return m[p>>>5]|=128<<24-p%32,m[(p+64>>>9<<4)+14]=n.floor(y/4294967296),m[(p+64>>>9<<4)+15]=y,A.sigBytes=4*m.length,this._process(),this._hash},clone:function(){var A=r.clone.call(this);return A._hash=this._hash.clone(),A}});t.SHA256=r._createHelper(v),t.HmacSHA256=r._createHmacHelper(v)})(Math),CryptoJS.lib.Cipher||function(n){var v=CryptoJS,t=v.lib,e=t.Base,r=t.WordArray,i=t.BufferedBlockAlgorithm,o=v.enc.Base64,s=v.algo.EvpKDF,u=t.Cipher=i.extend({cfg:e.extend(),createEncryptor:function(m,y){return this.create(this._ENC_XFORM_MODE,m,y)},createDecryptor:function(m,y){return this.create(this._DEC_XFORM_MODE,m,y)},init:function(m,y,p){this.cfg=this.cfg.extend(p),this._xformMode=m,this._key=y,this.reset()},reset:function(){i.reset.call(this),this._doReset()},process:function(m){return this._append(m),this._process()},finalize:function(m){return m&&this._append(m),this._doFinalize()},keySize:4,ivSize:4,_ENC_XFORM_MODE:1,_DEC_XFORM_MODE:2,_createHelper:function(m){return{encrypt:function(y,p,g){return(typeof p=="string"?A:h).encrypt(m,y,p,g)},decrypt:function(y,p,g){return(typeof p=="string"?A:h).decrypt(m,y,p,g)}}}});t.StreamCipher=u.extend({_doFinalize:function(){return this._process(!0)},blockSize:1});var f=v.mode={},l=function(m,y,p){var g=this._iv;g?this._iv=n:g=this._prevBlock;for(var b=0;b<p;b++)m[y+b]^=g[b]},d=(t.BlockCipherMode=e.extend({createEncryptor:function(m,y){return this.Encryptor.create(m,y)},createDecryptor:function(m,y){return this.Decryptor.create(m,y)},init:function(m,y){this._cipher=m,this._iv=y}})).extend();d.Encryptor=d.extend({processBlock:function(m,y){var p=this._cipher,g=p.blockSize;l.call(this,m,y,g),p.encryptBlock(m,y),this._prevBlock=m.slice(y,y+g)}}),d.Decryptor=d.extend({processBlock:function(m,y){var p=this._cipher,g=p.blockSize,b=m.slice(y,y+g);p.decryptBlock(m,y),l.call(this,m,y,g),this._prevBlock=b}}),f=f.CBC=d,d=(v.pad={}).Pkcs7={pad:function(m,y){for(var p=4*y,p=p-m.sigBytes%p,g=p<<24|p<<16|p<<8|p,b=[],T=0;T<p;T+=4)b.push(g);p=r.create(b,p),m.concat(p)},unpad:function(m){m.sigBytes-=m.words[m.sigBytes-1>>>2]&255}},t.BlockCipher=u.extend({cfg:u.cfg.extend({mode:f,padding:d}),reset:function(){u.reset.call(this);var y=this.cfg,m=y.iv,y=y.mode;if(this._xformMode==this._ENC_XFORM_MODE)var p=y.createEncryptor;else p=y.createDecryptor,this._minBufferSize=1;this._mode=p.call(y,this,m&&m.words)},_doProcessBlock:function(m,y){this._mode.processBlock(m,y)},_doFinalize:function(){var m=this.cfg.padding;if(this._xformMode==this._ENC_XFORM_MODE){m.pad(this._data,this.blockSize);var y=this._process(!0)}else y=this._process(!0),m.unpad(y);return y},blockSize:4});var c=t.CipherParams=e.extend({init:function(m){this.mixIn(m)},toString:function(m){return(m||this.formatter).stringify(this)}}),f=(v.format={}).OpenSSL={stringify:function(m){var y=m.ciphertext;return m=m.salt,(m?r.create([1398893684,1701076831]).concat(m).concat(y):y).toString(o)},parse:function(m){m=o.parse(m);var y=m.words;if(y[0]==1398893684&&y[1]==1701076831){var p=r.create(y.slice(2,4));y.splice(0,4),m.sigBytes-=16}return c.create({ciphertext:m,salt:p})}},h=t.SerializableCipher=e.extend({cfg:e.extend({format:f}),encrypt:function(m,y,p,g){g=this.cfg.extend(g);var b=m.createEncryptor(p,g);return y=b.finalize(y),b=b.cfg,c.create({ciphertext:y,key:p,iv:b.iv,algorithm:m,mode:b.mode,padding:b.padding,blockSize:m.blockSize,formatter:g.format})},decrypt:function(m,y,p,g){return g=this.cfg.extend(g),y=this._parse(y,g.format),m.createDecryptor(p,g).finalize(y.ciphertext)},_parse:function(m,y){return typeof m=="string"?y.parse(m,this):m}}),v=(v.kdf={}).OpenSSL={execute:function(m,y,p,g){return g||(g=r.random(8)),m=s.create({keySize:y+p}).compute(m,g),p=r.create(m.words.slice(y),4*p),m.sigBytes=4*y,c.create({key:m,iv:p,salt:g})}},A=t.PasswordBasedCipher=h.extend({cfg:h.cfg.extend({kdf:v}),encrypt:function(m,y,p,g){return g=this.cfg.extend(g),p=g.kdf.execute(p,m.keySize,m.ivSize),g.iv=p.iv,m=h.encrypt.call(this,m,y,p.key,g),m.mixIn(p),m},decrypt:function(m,y,p,g){return g=this.cfg.extend(g),y=this._parse(y,g.format),p=g.kdf.execute(p,m.keySize,m.ivSize,y.salt),g.iv=p.iv,h.decrypt.call(this,m,y,p.key,g)}})}(),function(){for(var n=CryptoJS,t=n.lib.BlockCipher,w=n.algo,e=[],r=[],i=[],o=[],s=[],u=[],l=[],d=[],c=[],f=[],h=[],v=0;256>v;v++)h[v]=128>v?v<<1:v<<1^283;for(var A=0,m=0,v=0;256>v;v++){var y=m^m<<1^m<<2^m<<3^m<<4,y=y>>>8^y&255^99;e[A]=y,r[y]=A;var p=h[A],g=h[p],b=h[g],T=257*h[y]^16843008*y;i[A]=T<<24|T>>>8,o[A]=T<<16|T>>>16,s[A]=T<<8|T>>>24,u[A]=T,T=16843009*b^65537*g^257*p^16843008*A,l[y]=T<<24|T>>>8,d[y]=T<<16|T>>>16,c[y]=T<<8|T>>>24,f[y]=T,A?(A=p^h[h[h[b^p]]],m^=h[h[m]]):A=m=1}var _=[0,1,2,4,8,16,32,64,128,27,54],w=w.AES=t.extend({_doReset:function(){for(var R=this._key,x=R.words,M=R.sigBytes/4,R=4*((this._nRounds=M+6)+1),I=this._keySchedule=[],S=0;S<R;S++)if(S<M)I[S]=x[S];else{var B=I[S-1];S%M?6<M&&S%M==4&&(B=e[B>>>24]<<24|e[B>>>16&255]<<16|e[B>>>8&255]<<8|e[B&255]):(B=B<<8|B>>>24,B=e[B>>>24]<<24|e[B>>>16&255]<<16|e[B>>>8&255]<<8|e[B&255],B^=_[S/M|0]<<24),I[S]=I[S-M]^B}for(x=this._invKeySchedule=[],M=0;M<R;M++)S=R-M,B=M%4?I[S]:I[S-4],x[M]=4>M||4>=S?B:l[e[B>>>24]]^d[e[B>>>16&255]]^c[e[B>>>8&255]]^f[e[B&255]]},encryptBlock:function(x,M){this._doCryptBlock(x,M,this._keySchedule,i,o,s,u,e)},decryptBlock:function(x,M){var R=x[M+1];x[M+1]=x[M+3],x[M+3]=R,this._doCryptBlock(x,M,this._invKeySchedule,l,d,c,f,r),R=x[M+1],x[M+1]=x[M+3],x[M+3]=R},_doCryptBlock:function(x,M,R,I,S,B,O,F){for(var H=this._nRounds,z=x[M]^R[0],G=x[M+1]^R[1],W=x[M+2]^R[2],K=x[M+3]^R[3],k=4,N=1;N<H;N++)var q=I[z>>>24]^S[G>>>16&255]^B[W>>>8&255]^O[K&255]^R[k++],V=I[G>>>24]^S[W>>>16&255]^B[K>>>8&255]^O[z&255]^R[k++],D=I[W>>>24]^S[K>>>16&255]^B[z>>>8&255]^O[G&255]^R[k++],K=I[K>>>24]^S[z>>>16&255]^B[G>>>8&255]^O[W&255]^R[k++],z=q,G=V,W=D;q=(F[z>>>24]<<24|F[G>>>16&255]<<16|F[W>>>8&255]<<8|F[K&255])^R[k++],V=(F[G>>>24]<<24|F[W>>>16&255]<<16|F[K>>>8&255]<<8|F[z&255])^R[k++],D=(F[W>>>24]<<24|F[K>>>16&255]<<16|F[z>>>8&255]<<8|F[G&255])^R[k++],K=(F[K>>>24]<<24|F[z>>>16&255]<<16|F[G>>>8&255]<<8|F[W&255])^R[k++],x[M]=q,x[M+1]=V,x[M+2]=D,x[M+3]=K},keySize:8});n.AES=t._createHelper(w)}();/*! (c) Tom Wu | http://www-cs-students.stanford.edu/~tjw/jsbn/
|
|
343
343
|
*/var dbits;function BigInteger(n,t,e){n!=null&&(typeof n=="number"?this.fromNumber(n,t,e):t==null&&typeof n!="string"?this.fromString(n,256):this.fromString(n,t))}function nbi(){return new BigInteger(null)}function am1(n,t,e,r,i,o){for(;--o>=0;){var s=t*this[n++]+e[r]+i;i=Math.floor(s/67108864),e[r++]=s&67108863}return i}function am2(n,t,e,r,i,o){for(var s=t&32767,u=t>>15;--o>=0;){var l=this[n]&32767,d=this[n++]>>15,c=u*l+d*s;l=s*l+((c&32767)<<15)+e[r]+(i&1073741823),i=(l>>>30)+(c>>>15)+u*d+(i>>>30),e[r++]=l&1073741823}return i}function am3(n,t,e,r,i,o){for(var s=t&16383,u=t>>14;--o>=0;){var l=this[n]&16383,d=this[n++]>>14,c=u*l+d*s;l=s*l+((c&16383)<<14)+e[r]+i,i=(l>>28)+(c>>14)+u*d,e[r++]=l&268435455}return i}typeof navigator<"u"&&navigator.appName=="Microsoft Internet Explorer"?(BigInteger.prototype.am=am2,dbits=30):typeof navigator<"u"&&navigator.appName!="Netscape"?(BigInteger.prototype.am=am1,dbits=26):(BigInteger.prototype.am=am3,dbits=28),BigInteger.prototype.DB=dbits,BigInteger.prototype.DM=(1<<dbits)-1,BigInteger.prototype.DV=1<<dbits;var BI_FP=52;BigInteger.prototype.FV=Math.pow(2,BI_FP),BigInteger.prototype.F1=BI_FP-dbits,BigInteger.prototype.F2=2*dbits-BI_FP;var BI_RM="0123456789abcdefghijklmnopqrstuvwxyz",BI_RC=new Array,rr,vv;for(rr=48,vv=0;vv<=9;++vv)BI_RC[rr++]=vv;for(rr=97,vv=10;vv<36;++vv)BI_RC[rr++]=vv;for(rr=65,vv=10;vv<36;++vv)BI_RC[rr++]=vv;function int2char(n){return BI_RM.charAt(n)}function intAt(n,t){var e=BI_RC[n.charCodeAt(t)];return e??-1}function bnpCopyTo(n){for(var t=this.t-1;t>=0;--t)n[t]=this[t];n.t=this.t,n.s=this.s}function bnpFromInt(n){this.t=1,this.s=n<0?-1:0,n>0?this[0]=n:n<-1?this[0]=n+this.DV:this.t=0}function nbv(n){var t=nbi();return t.fromInt(n),t}function bnpFromString(n,t){var e;if(t==16)e=4;else if(t==8)e=3;else if(t==256)e=8;else if(t==2)e=1;else if(t==32)e=5;else if(t==4)e=2;else{this.fromRadix(n,t);return}this.t=0,this.s=0;for(var r=n.length,i=!1,o=0;--r>=0;){var s=e==8?n[r]&255:intAt(n,r);if(s<0){n.charAt(r)=="-"&&(i=!0);continue}i=!1,o==0?this[this.t++]=s:o+e>this.DB?(this[this.t-1]|=(s&(1<<this.DB-o)-1)<<o,this[this.t++]=s>>this.DB-o):this[this.t-1]|=s<<o,o+=e,o>=this.DB&&(o-=this.DB)}e==8&&n[0]&128&&(this.s=-1,o>0&&(this[this.t-1]|=(1<<this.DB-o)-1<<o)),this.clamp(),i&&BigInteger.ZERO.subTo(this,this)}function bnpClamp(){for(var n=this.s&this.DM;this.t>0&&this[this.t-1]==n;)--this.t}function bnToString(n){if(this.s<0)return"-"+this.negate().toString(n);var t;if(n==16)t=4;else if(n==8)t=3;else if(n==2)t=1;else if(n==32)t=5;else if(n==4)t=2;else return this.toRadix(n);var e=(1<<t)-1,r,i=!1,o="",s=this.t,u=this.DB-s*this.DB%t;if(s-- >0)for(u<this.DB&&(r=this[s]>>u)>0&&(i=!0,o=int2char(r));s>=0;)u<t?(r=(this[s]&(1<<u)-1)<<t-u,r|=this[--s]>>(u+=this.DB-t)):(r=this[s]>>(u-=t)&e,u<=0&&(u+=this.DB,--s)),r>0&&(i=!0),i&&(o+=int2char(r));return i?o:"0"}function bnNegate(){var n=nbi();return BigInteger.ZERO.subTo(this,n),n}function bnAbs(){return this.s<0?this.negate():this}function bnCompareTo(n){var t=this.s-n.s;if(t!=0)return t;var e=this.t;if(t=e-n.t,t!=0)return this.s<0?-t:t;for(;--e>=0;)if((t=this[e]-n[e])!=0)return t;return 0}function nbits(n){var t=1,e;return(e=n>>>16)!=0&&(n=e,t+=16),(e=n>>8)!=0&&(n=e,t+=8),(e=n>>4)!=0&&(n=e,t+=4),(e=n>>2)!=0&&(n=e,t+=2),(e=n>>1)!=0&&(n=e,t+=1),t}function bnBitLength(){return this.t<=0?0:this.DB*(this.t-1)+nbits(this[this.t-1]^this.s&this.DM)}function bnpDLShiftTo(n,t){var e;for(e=this.t-1;e>=0;--e)t[e+n]=this[e];for(e=n-1;e>=0;--e)t[e]=0;t.t=this.t+n,t.s=this.s}function bnpDRShiftTo(n,t){for(var e=n;e<this.t;++e)t[e-n]=this[e];t.t=Math.max(this.t-n,0),t.s=this.s}function bnpLShiftTo(n,t){var e=n%this.DB,r=this.DB-e,i=(1<<r)-1,o=Math.floor(n/this.DB),s=this.s<<e&this.DM,u;for(u=this.t-1;u>=0;--u)t[u+o+1]=this[u]>>r|s,s=(this[u]&i)<<e;for(u=o-1;u>=0;--u)t[u]=0;t[o]=s,t.t=this.t+o+1,t.s=this.s,t.clamp()}function bnpRShiftTo(n,t){t.s=this.s;var e=Math.floor(n/this.DB);if(e>=this.t){t.t=0;return}var r=n%this.DB,i=this.DB-r,o=(1<<r)-1;t[0]=this[e]>>r;for(var s=e+1;s<this.t;++s)t[s-e-1]|=(this[s]&o)<<i,t[s-e]=this[s]>>r;r>0&&(t[this.t-e-1]|=(this.s&o)<<i),t.t=this.t-e,t.clamp()}function bnpSubTo(n,t){for(var e=0,r=0,i=Math.min(n.t,this.t);e<i;)r+=this[e]-n[e],t[e++]=r&this.DM,r>>=this.DB;if(n.t<this.t){for(r-=n.s;e<this.t;)r+=this[e],t[e++]=r&this.DM,r>>=this.DB;r+=this.s}else{for(r+=this.s;e<n.t;)r-=n[e],t[e++]=r&this.DM,r>>=this.DB;r-=n.s}t.s=r<0?-1:0,r<-1?t[e++]=this.DV+r:r>0&&(t[e++]=r),t.t=e,t.clamp()}function bnpMultiplyTo(n,t){var e=this.abs(),r=n.abs(),i=e.t;for(t.t=i+r.t;--i>=0;)t[i]=0;for(i=0;i<r.t;++i)t[i+e.t]=e.am(0,r[i],t,i,0,e.t);t.s=0,t.clamp(),this.s!=n.s&&BigInteger.ZERO.subTo(t,t)}function bnpSquareTo(n){for(var t=this.abs(),e=n.t=2*t.t;--e>=0;)n[e]=0;for(e=0;e<t.t-1;++e){var r=t.am(e,t[e],n,2*e,0,1);(n[e+t.t]+=t.am(e+1,2*t[e],n,2*e+1,r,t.t-e-1))>=t.DV&&(n[e+t.t]-=t.DV,n[e+t.t+1]=1)}n.t>0&&(n[n.t-1]+=t.am(e,t[e],n,2*e,0,1)),n.s=0,n.clamp()}function bnpDivRemTo(n,t,e){var r=n.abs();if(!(r.t<=0)){var i=this.abs();if(i.t<r.t){t!=null&&t.fromInt(0),e!=null&&this.copyTo(e);return}e==null&&(e=nbi());var o=nbi(),s=this.s,u=n.s,l=this.DB-nbits(r[r.t-1]);l>0?(r.lShiftTo(l,o),i.lShiftTo(l,e)):(r.copyTo(o),i.copyTo(e));var d=o.t,c=o[d-1];if(c!=0){var f=c*(1<<this.F1)+(d>1?o[d-2]>>this.F2:0),h=this.FV/f,v=(1<<this.F1)/f,A=1<<this.F2,m=e.t,y=m-d,p=t??nbi();for(o.dlShiftTo(y,p),e.compareTo(p)>=0&&(e[e.t++]=1,e.subTo(p,e)),BigInteger.ONE.dlShiftTo(d,p),p.subTo(o,o);o.t<d;)o[o.t++]=0;for(;--y>=0;){var g=e[--m]==c?this.DM:Math.floor(e[m]*h+(e[m-1]+A)*v);if((e[m]+=o.am(0,g,e,y,0,d))<g)for(o.dlShiftTo(y,p),e.subTo(p,e);e[m]<--g;)e.subTo(p,e)}t!=null&&(e.drShiftTo(d,t),s!=u&&BigInteger.ZERO.subTo(t,t)),e.t=d,e.clamp(),l>0&&e.rShiftTo(l,e),s<0&&BigInteger.ZERO.subTo(e,e)}}}function bnMod(n){var t=nbi();return this.abs().divRemTo(n,null,t),this.s<0&&t.compareTo(BigInteger.ZERO)>0&&n.subTo(t,t),t}function Classic(n){this.m=n}function cConvert(n){return n.s<0||n.compareTo(this.m)>=0?n.mod(this.m):n}function cRevert(n){return n}function cReduce(n){n.divRemTo(this.m,null,n)}function cMulTo(n,t,e){n.multiplyTo(t,e),this.reduce(e)}function cSqrTo(n,t){n.squareTo(t),this.reduce(t)}Classic.prototype.convert=cConvert,Classic.prototype.revert=cRevert,Classic.prototype.reduce=cReduce,Classic.prototype.mulTo=cMulTo,Classic.prototype.sqrTo=cSqrTo;function bnpInvDigit(){if(this.t<1)return 0;var n=this[0];if(!(n&1))return 0;var t=n&3;return t=t*(2-(n&15)*t)&15,t=t*(2-(n&255)*t)&255,t=t*(2-((n&65535)*t&65535))&65535,t=t*(2-n*t%this.DV)%this.DV,t>0?this.DV-t:-t}function Montgomery(n){this.m=n,this.mp=n.invDigit(),this.mpl=this.mp&32767,this.mph=this.mp>>15,this.um=(1<<n.DB-15)-1,this.mt2=2*n.t}function montConvert(n){var t=nbi();return n.abs().dlShiftTo(this.m.t,t),t.divRemTo(this.m,null,t),n.s<0&&t.compareTo(BigInteger.ZERO)>0&&this.m.subTo(t,t),t}function montRevert(n){var t=nbi();return n.copyTo(t),this.reduce(t),t}function montReduce(n){for(;n.t<=this.mt2;)n[n.t++]=0;for(var t=0;t<this.m.t;++t){var e=n[t]&32767,r=e*this.mpl+((e*this.mph+(n[t]>>15)*this.mpl&this.um)<<15)&n.DM;for(e=t+this.m.t,n[e]+=this.m.am(0,r,n,t,0,this.m.t);n[e]>=n.DV;)n[e]-=n.DV,n[++e]++}n.clamp(),n.drShiftTo(this.m.t,n),n.compareTo(this.m)>=0&&n.subTo(this.m,n)}function montSqrTo(n,t){n.squareTo(t),this.reduce(t)}function montMulTo(n,t,e){n.multiplyTo(t,e),this.reduce(e)}Montgomery.prototype.convert=montConvert,Montgomery.prototype.revert=montRevert,Montgomery.prototype.reduce=montReduce,Montgomery.prototype.mulTo=montMulTo,Montgomery.prototype.sqrTo=montSqrTo;function bnpIsEven(){return(this.t>0?this[0]&1:this.s)==0}function bnpExp(n,t){if(n>4294967295||n<1)return BigInteger.ONE;var e=nbi(),r=nbi(),i=t.convert(this),o=nbits(n)-1;for(i.copyTo(e);--o>=0;)if(t.sqrTo(e,r),(n&1<<o)>0)t.mulTo(r,i,e);else{var s=e;e=r,r=s}return t.revert(e)}function bnModPowInt(n,t){var e;return n<256||t.isEven()?e=new Classic(t):e=new Montgomery(t),this.exp(n,e)}BigInteger.prototype.copyTo=bnpCopyTo,BigInteger.prototype.fromInt=bnpFromInt,BigInteger.prototype.fromString=bnpFromString,BigInteger.prototype.clamp=bnpClamp,BigInteger.prototype.dlShiftTo=bnpDLShiftTo,BigInteger.prototype.drShiftTo=bnpDRShiftTo,BigInteger.prototype.lShiftTo=bnpLShiftTo,BigInteger.prototype.rShiftTo=bnpRShiftTo,BigInteger.prototype.subTo=bnpSubTo,BigInteger.prototype.multiplyTo=bnpMultiplyTo,BigInteger.prototype.squareTo=bnpSquareTo,BigInteger.prototype.divRemTo=bnpDivRemTo,BigInteger.prototype.invDigit=bnpInvDigit,BigInteger.prototype.isEven=bnpIsEven,BigInteger.prototype.exp=bnpExp,BigInteger.prototype.toString=bnToString,BigInteger.prototype.negate=bnNegate,BigInteger.prototype.abs=bnAbs,BigInteger.prototype.compareTo=bnCompareTo,BigInteger.prototype.bitLength=bnBitLength,BigInteger.prototype.mod=bnMod,BigInteger.prototype.modPowInt=bnModPowInt,BigInteger.ZERO=nbv(0),BigInteger.ONE=nbv(1);/*! (c) Tom Wu | http://www-cs-students.stanford.edu/~tjw/jsbn/ */function bnIntValue(){if(this.s<0){if(this.t==1)return this[0]-this.DV;if(this.t==0)return-1}else{if(this.t==1)return this[0];if(this.t==0)return 0}return(this[1]&(1<<32-this.DB)-1)<<this.DB|this[0]}function bnpChunkSize(n){return Math.floor(Math.LN2*this.DB/Math.log(n))}function bnSigNum(){return this.s<0?-1:this.t<=0||this.t==1&&this[0]<=0?0:1}function bnpToRadix(n){if(n==null&&(n=10),this.signum()==0||n<2||n>36)return"0";var t=this.chunkSize(n),e=Math.pow(n,t),r=nbv(e),i=nbi(),o=nbi(),s="";for(this.divRemTo(r,i,o);i.signum()>0;)s=(e+o.intValue()).toString(n).substr(1)+s,i.divRemTo(r,i,o);return o.intValue().toString(n)+s}BigInteger.prototype.chunkSize=bnpChunkSize,BigInteger.prototype.toRadix=bnpToRadix,BigInteger.prototype.intValue=bnIntValue,BigInteger.prototype.signum=bnSigNum;/*! (c) Tom Wu | http://www-cs-students.stanford.edu/~tjw/jsbn/ */var b64map="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",b64pad="=";function hex2b64(n){var t,e,r="";for(t=0;t+3<=n.length;t+=3)e=parseInt(n.substring(t,t+3),16),r+=b64map.charAt(e>>6)+b64map.charAt(e&63);for(t+1==n.length?(e=parseInt(n.substring(t,t+1),16),r+=b64map.charAt(e<<2)):t+2==n.length&&(e=parseInt(n.substring(t,t+2),16),r+=b64map.charAt(e>>2)+b64map.charAt((e&3)<<4));(r.length&3)>0;)r+=b64pad;return r}function b64tohex(n){var t="",e,r=0,i,o;for(e=0;e<n.length&&n.charAt(e)!=b64pad;++e)o=b64map.indexOf(n.charAt(e)),!(o<0)&&(r==0?(t+=int2char(o>>2),i=o&3,r=1):r==1?(t+=int2char(i<<2|o>>4),i=o&15,r=2):r==2?(t+=int2char(i),t+=int2char(o>>2),i=o&3,r=3):(t+=int2char(i<<2|o>>4),t+=int2char(o&15),r=0));return r==1&&(t+=int2char(i<<2)),t}/*! (c) Tom Wu | http://www-cs-students.stanford.edu/~tjw/jsbn/ */function parseBigInt(n,t){return new BigInteger(n,t)}function pkcs1pad2(n,t){if(t<n.length+11)throw"Message too long for RSA";for(var e=new Array,r=n.length-1;r>=0&&t>0;){var i=n.charCodeAt(r--);i<128?e[--t]=i:i>127&&i<2048?(e[--t]=i&63|128,e[--t]=i>>6|192):(e[--t]=i&63|128,e[--t]=i>>6&63|128,e[--t]=i>>12|224)}e[--t]=0;for(var o=new SecureRandom,s=new Array;t>2;){for(s[0]=0;s[0]==0;)o.nextBytes(s);e[--t]=s[0]}return e[--t]=2,e[--t]=0,new BigInteger(e)}function oaep_mgf1_arr(n,t,e){for(var r="",i=0;r.length<t;)r+=e(String.fromCharCode.apply(String,n.concat([(i&4278190080)>>24,(i&16711680)>>16,(i&65280)>>8,i&255]))),i+=1;return r}function oaep_pad(n,t,e,r){var i=KJUR.crypto.MessageDigest,o=KJUR.crypto.Util,s=null;if(e||(e="sha1"),typeof e=="string"&&(s=i.getCanonicalAlgName(e),r=i.getHashLength(s),e=function(m){return hextorstr(o.hashHex(rstrtohex(m),s))}),n.length+2*r+2>t)throw"Message too long for RSA";var u="",l;for(l=0;l<t-n.length-2*r-2;l+=1)u+="\0";var d=e("")+u+""+n,c=new Array(r);new SecureRandom().nextBytes(c);var f=oaep_mgf1_arr(c,d.length,e),h=[];for(l=0;l<d.length;l+=1)h[l]=d.charCodeAt(l)^f.charCodeAt(l);var v=oaep_mgf1_arr(h,c.length,e),A=[0];for(l=0;l<c.length;l+=1)A[l+1]=c[l]^v.charCodeAt(l);return new BigInteger(A.concat(h))}function RSAKey(){this.n=null,this.e=0,this.d=null,this.p=null,this.q=null,this.dmp1=null,this.dmq1=null,this.coeff=null}function RSASetPublic(n,t){if(this.isPublic=!0,this.isPrivate=!1,typeof n!="string")this.n=n,this.e=t;else if(n!=null&&t!=null&&n.length>0&&t.length>0)this.n=parseBigInt(n,16),this.e=parseInt(t,16);else throw"Invalid RSA public key"}function RSADoPublic(n){return n.modPowInt(this.e,this.n)}function RSAEncrypt(n){var t=pkcs1pad2(n,this.n.bitLength()+7>>3);if(t==null)return null;var e=this.doPublic(t);if(e==null)return null;var r=e.toString(16);return r.length&1?"0"+r:r}function RSAEncryptOAEP(n,t,e){var r=oaep_pad(n,this.n.bitLength()+7>>3,t,e);if(r==null)return null;var i=this.doPublic(r);if(i==null)return null;var o=i.toString(16);return o.length&1?"0"+o:o}RSAKey.prototype.doPublic=RSADoPublic,RSAKey.prototype.setPublic=RSASetPublic,RSAKey.prototype.encrypt=RSAEncrypt,RSAKey.prototype.encryptOAEP=RSAEncryptOAEP,RSAKey.prototype.type="RSA";/*! (c) Tom Wu | http://www-cs-students.stanford.edu/~tjw/jsbn/ */function pkcs1unpad2(n,t){for(var e=n.toByteArray(),r=0;r<e.length&&e[r]==0;)++r;if(e.length-r!=t-1||e[r]!=2)return null;for(++r;e[r]!=0;)if(++r>=e.length)return null;for(var i="";++r<e.length;){var o=e[r]&255;o<128?i+=String.fromCharCode(o):o>191&&o<224?(i+=String.fromCharCode((o&31)<<6|e[r+1]&63),++r):(i+=String.fromCharCode((o&15)<<12|(e[r+1]&63)<<6|e[r+2]&63),r+=2)}return i}function oaep_mgf1_str(n,t,e){for(var r="",i=0;r.length<t;)r+=e(n+String.fromCharCode.apply(String,[(i&4278190080)>>24,(i&16711680)>>16,(i&65280)>>8,i&255])),i+=1;return r}function oaep_unpad(n,t,e,r){var i=KJUR.crypto.MessageDigest,o=KJUR.crypto.Util,s=null;e||(e="sha1"),typeof e=="string"&&(s=i.getCanonicalAlgName(e),r=i.getHashLength(s),e=function(y){return hextorstr(o.hashHex(rstrtohex(y),s))}),n=n.toByteArray();var f;for(f=0;f<n.length;f+=1)n[f]&=255;for(;n.length<t;)n.unshift(0);if(n=String.fromCharCode.apply(String,n),n.length<2*r+2)throw"Cipher too short";var u=n.substr(1,r),l=n.substr(r+1),d=oaep_mgf1_str(l,r,e),c=[],f;for(f=0;f<u.length;f+=1)c[f]=u.charCodeAt(f)^d.charCodeAt(f);var h=oaep_mgf1_str(String.fromCharCode.apply(String,c),n.length-r,e),v=[];for(f=0;f<l.length;f+=1)v[f]=l.charCodeAt(f)^h.charCodeAt(f);if(v=String.fromCharCode.apply(String,v),v.substr(0,r)!==e(""))throw"Hash mismatch";v=v.substr(r);var A=v.indexOf(""),m=A!=-1?v.substr(0,A).lastIndexOf("\0"):-1;if(m+1!=A)throw"Malformed data";return v.substr(A+1)}function RSASetPrivate(n,t,e){if(this.isPrivate=!0,typeof n!="string")this.n=n,this.e=t,this.d=e;else if(n!=null&&t!=null&&n.length>0&&t.length>0)this.n=parseBigInt(n,16),this.e=parseInt(t,16),this.d=parseBigInt(e,16);else throw"Invalid RSA private key"}function RSASetPrivateEx(n,t,e,r,i,o,s,u){if(this.isPrivate=!0,this.isPublic=!1,n==null)throw"RSASetPrivateEx N == null";if(t==null)throw"RSASetPrivateEx E == null";if(n.length==0)throw"RSASetPrivateEx N.length == 0";if(t.length==0)throw"RSASetPrivateEx E.length == 0";if(n!=null&&t!=null&&n.length>0&&t.length>0)this.n=parseBigInt(n,16),this.e=parseInt(t,16),this.d=parseBigInt(e,16),this.p=parseBigInt(r,16),this.q=parseBigInt(i,16),this.dmp1=parseBigInt(o,16),this.dmq1=parseBigInt(s,16),this.coeff=parseBigInt(u,16);else throw"Invalid RSA private key in RSASetPrivateEx"}function RSADoPrivate(n){if(this.p==null||this.q==null)return n.modPow(this.d,this.n);for(var t=n.mod(this.p).modPow(this.dmp1,this.p),e=n.mod(this.q).modPow(this.dmq1,this.q);t.compareTo(e)<0;)t=t.add(this.p);return t.subtract(e).multiply(this.coeff).mod(this.p).multiply(this.q).add(e)}function RSADecrypt(n){if(n.length!=Math.ceil(this.n.bitLength()/4))throw new Error("wrong ctext length");var t=parseBigInt(n,16),e=this.doPrivate(t);return e==null?null:pkcs1unpad2(e,this.n.bitLength()+7>>3)}function RSADecryptOAEP(n,t,e){if(n.length!=Math.ceil(this.n.bitLength()/4))throw new Error("wrong ctext length");var r=parseBigInt(n,16),i=this.doPrivate(r);return i==null?null:oaep_unpad(i,this.n.bitLength()+7>>3,t,e)}RSAKey.prototype.doPrivate=RSADoPrivate,RSAKey.prototype.setPrivate=RSASetPrivate,RSAKey.prototype.setPrivateEx=RSASetPrivateEx,RSAKey.prototype.decrypt=RSADecrypt,RSAKey.prototype.decryptOAEP=RSADecryptOAEP,(typeof KJUR.lang>"u"||!KJUR.lang)&&(KJUR.lang={}),KJUR.lang.String=function(){};function b64utob64(n){return n.length%4==2?n=n+"==":n.length%4==3&&(n=n+"="),n=n.replace(/-/g,"+"),n=n.replace(/_/g,"/"),n}function b64utohex(n){return b64tohex(b64utob64(n))}function hextoutf8(n){return decodeURIComponent(hextouricmp(n))}function hextorstr(n){for(var t="",e=0;e<n.length-1;e+=2)t+=String.fromCharCode(parseInt(n.substr(e,2),16));return t}function rstrtohex(n){for(var t="",e=0;e<n.length;e++)t+=("0"+n.charCodeAt(e).toString(16)).slice(-2);return t}function hextob64(n){return hex2b64(n)}function hextob64nl(n){var t=hextob64(n),e=t.replace(/(.{64})/g,`$1\r
|
|
344
344
|
`);return e=e.replace(/\r\n$/,""),e}function b64nltohex(n){var t=n.replace(/[^0-9A-Za-z\/+=]*/g,""),e=b64tohex(t);return e}function hextopem(n,t){var e=hextob64nl(n);return"-----BEGIN "+t+`-----\r
|
|
345
345
|
`+e+`\r
|
|
@@ -359,7 +359,7 @@
|
|
|
359
359
|
`,R+=`\r
|
|
360
360
|
`,R+=M,R+=`\r
|
|
361
361
|
-----END `+A+` PRIVATE KEY-----\r
|
|
362
|
-
`,R},parseHexOfEncryptedPKCS8:function(A){var m=ASN1HEX,y=m.getChildIdx,p=m.getV,g={},b=y(A,0);if(b.length!=2)throw"malformed format: SEQUENCE(0).items != 2: "+b.length;g.ciphertext=p(A,b[1]);var T=y(A,b[0]);if(T.length!=2)throw"malformed format: SEQUENCE(0.0).items != 2: "+T.length;if(p(A,T[0])!="2a864886f70d01050d")throw"this only supports pkcs5PBES2";var _=y(A,T[1]);if(T.length!=2)throw"malformed format: SEQUENCE(0.0.1).items != 2: "+_.length;var w=y(A,_[1]);if(w.length!=2)throw"malformed format: SEQUENCE(0.0.1.1).items != 2: "+w.length;if(p(A,w[0])!="2a864886f70d0307")throw"this only supports TripleDES";g.encryptionSchemeAlg="TripleDES",g.encryptionSchemeIV=p(A,w[1]);var x=y(A,_[0]);if(x.length!=2)throw"malformed format: SEQUENCE(0.0.1.0).items != 2: "+x.length;if(p(A,x[0])!="2a864886f70d01050c")throw"this only supports pkcs5PBKDF2";var M=y(A,x[1]);if(M.length<2)throw"malformed format: SEQUENCE(0.0.1.0.1).items < 2: "+M.length;g.pbkdf2Salt=p(A,M[0]);var R=p(A,M[1]);try{g.pbkdf2Iter=parseInt(R,16)}catch{throw"malformed format pbkdf2Iter: "+R}return g},getPBKDF2KeyHexFromParam:function(A,m){var y=CryptoJS.enc.Hex.parse(A.pbkdf2Salt),p=A.pbkdf2Iter,g=CryptoJS.PBKDF2(m,y,{keySize:192/32,iterations:p}),b=CryptoJS.enc.Hex.stringify(g);return b},_getPlainPKCS8HexFromEncryptedPKCS8PEM:function(A,m){var y=pemtohex(A,"ENCRYPTED PRIVATE KEY"),p=this.parseHexOfEncryptedPKCS8(y),g=KEYUTIL.getPBKDF2KeyHexFromParam(p,m),b={};b.ciphertext=CryptoJS.enc.Hex.parse(p.ciphertext);var T=CryptoJS.enc.Hex.parse(g),_=CryptoJS.enc.Hex.parse(p.encryptionSchemeIV),w=CryptoJS.TripleDES.decrypt(b,T,{iv:_}),x=CryptoJS.enc.Hex.stringify(w);return x},getKeyFromEncryptedPKCS8PEM:function(A,m){var y=this._getPlainPKCS8HexFromEncryptedPKCS8PEM(A,m),p=this.getKeyFromPlainPrivatePKCS8Hex(y);return p},parsePlainPrivatePKCS8Hex:function(A){var m=ASN1HEX,y=m.getChildIdx,p=m.getV,g={};if(g.algparam=null,A.substr(0,2)!="30")throw new Error("malformed plain PKCS8 private key(code:001)");var b=y(A,0);if(b.length<3)throw new Error("malformed plain PKCS8 private key(code:002)");if(A.substr(b[1],2)!="30")throw new Error("malformed PKCS8 private key(code:003)");var T=y(A,b[1]);if(T.length!=2)throw new Error("malformed PKCS8 private key(code:004)");if(A.substr(T[0],2)!="06")throw new Error("malformed PKCS8 private key(code:005)");if(g.algoid=p(A,T[0]),A.substr(T[1],2)=="06"&&(g.algparam=p(A,T[1])),A.substr(b[2],2)!="04")throw new Error("malformed PKCS8 private key(code:006)");return g.keyidx=m.getVidx(A,b[2]),g},getKeyFromPlainPrivatePKCS8PEM:function(A){var m=pemtohex(A,"PRIVATE KEY"),y=this.getKeyFromPlainPrivatePKCS8Hex(m);return y},getKeyFromPlainPrivatePKCS8Hex:function(A){var m=this.parsePlainPrivatePKCS8Hex(A),y;if(m.algoid=="2a864886f70d010101")y=new RSAKey;else if(KJUR.crypto.DSA&&m.algoid=="2a8648ce380401")y=new KJUR.crypto.DSA;else if(KJUR.crypto.ECDSA&&m.algoid=="2a8648ce3d0201")y=new KJUR.crypto.ECDSA;else throw"unsupported private key algorithm";return y.readPKCS8PrvKeyHex(A),y},_getKeyFromPublicPKCS8Hex:function(A){var m,y=ASN1HEX.getVbyList(A,0,[0,0],"06");if(y==="2a864886f70d010101")m=new RSAKey;else if(KJUR.crypto.DSA&&y==="2a8648ce380401")m=new KJUR.crypto.DSA;else if(KJUR.crypto.ECDSA&&y==="2a8648ce3d0201")m=new KJUR.crypto.ECDSA;else throw"unsupported PKCS#8 public key hex";return m.readPKCS8PubKeyHex(A),m},parsePublicRawRSAKeyHex:function(A){var m=ASN1HEX,y=m.getChildIdx,p=m.getV,g={};if(A.substr(0,2)!="30")throw"malformed RSA key(code:001)";var b=y(A,0);if(b.length!=2)throw"malformed RSA key(code:002)";if(A.substr(b[0],2)!="02")throw"malformed RSA key(code:003)";if(g.n=p(A,b[0]),A.substr(b[1],2)!="02")throw"malformed RSA key(code:004)";return g.e=p(A,b[1]),g},parsePublicPKCS8Hex:function(A){var m=ASN1HEX,y=m.getChildIdx,p=m.getV,g={};g.algparam=null;var b=y(A,0);if(b.length!=2)throw"outer DERSequence shall have 2 elements: "+b.length;var T=b[0];if(A.substr(T,2)!="30")throw"malformed PKCS8 public key(code:001)";var _=y(A,T);if(_.length!=2)throw"malformed PKCS8 public key(code:002)";if(A.substr(_[0],2)!="06")throw"malformed PKCS8 public key(code:003)";if(g.algoid=p(A,_[0]),A.substr(_[1],2)=="06"?g.algparam=p(A,_[1]):A.substr(_[1],2)=="30"&&(g.algparam={},g.algparam.p=m.getVbyList(A,_[1],[0],"02"),g.algparam.q=m.getVbyList(A,_[1],[1],"02"),g.algparam.g=m.getVbyList(A,_[1],[2],"02")),A.substr(b[1],2)!="03")throw"malformed PKCS8 public key(code:004)";return g.key=p(A,b[1]).substr(2),g}}}();KEYUTIL.getKey=function(n,t,e){var r=ASN1HEX,i=r.getChildIdx;r.getV;var o=r.getVbyList,s=KJUR.crypto,u=s.ECDSA,l=s.DSA,d=RSAKey,c=pemtohex,f=KEYUTIL;if(typeof d<"u"&&n instanceof d||typeof u<"u"&&n instanceof u||typeof l<"u"&&n instanceof l)return n;if(n.curve!==void 0&&n.xy!==void 0&&n.d===void 0)return new u({pub:n.xy,curve:n.curve});if(n.curve!==void 0&&n.d!==void 0)return new u({prv:n.d,curve:n.curve});if(n.kty===void 0&&n.n!==void 0&&n.e!==void 0&&n.d===void 0){var h=new d;return h.setPublic(n.n,n.e),h}if(n.kty===void 0&&n.n!==void 0&&n.e!==void 0&&n.d!==void 0&&n.p!==void 0&&n.q!==void 0&&n.dp!==void 0&&n.dq!==void 0&&n.co!==void 0&&n.qi===void 0){var h=new d;return h.setPrivateEx(n.n,n.e,n.d,n.p,n.q,n.dp,n.dq,n.co),h}if(n.kty===void 0&&n.n!==void 0&&n.e!==void 0&&n.d!==void 0&&n.p===void 0){var h=new d;return h.setPrivate(n.n,n.e,n.d),h}if(n.p!==void 0&&n.q!==void 0&&n.g!==void 0&&n.y!==void 0&&n.x===void 0){var h=new l;return h.setPublic(n.p,n.q,n.g,n.y),h}if(n.p!==void 0&&n.q!==void 0&&n.g!==void 0&&n.y!==void 0&&n.x!==void 0){var h=new l;return h.setPrivate(n.p,n.q,n.g,n.y,n.x),h}if(n.kty==="RSA"&&n.n!==void 0&&n.e!==void 0&&n.d===void 0){var h=new d;return h.setPublic(b64utohex(n.n),b64utohex(n.e)),h}if(n.kty==="RSA"&&n.n!==void 0&&n.e!==void 0&&n.d!==void 0&&n.p!==void 0&&n.q!==void 0&&n.dp!==void 0&&n.dq!==void 0&&n.qi!==void 0){var h=new d;return h.setPrivateEx(b64utohex(n.n),b64utohex(n.e),b64utohex(n.d),b64utohex(n.p),b64utohex(n.q),b64utohex(n.dp),b64utohex(n.dq),b64utohex(n.qi)),h}if(n.kty==="RSA"&&n.n!==void 0&&n.e!==void 0&&n.d!==void 0){var h=new d;return h.setPrivate(b64utohex(n.n),b64utohex(n.e),b64utohex(n.d)),h}if(n.kty==="EC"&&n.crv!==void 0&&n.x!==void 0&&n.y!==void 0&&n.d===void 0){var v=new u({curve:n.crv}),A=v.ecparams.keylen/4,m=("0000000000"+b64utohex(n.x)).slice(-A),y=("0000000000"+b64utohex(n.y)).slice(-A),p="04"+m+y;return v.setPublicKeyHex(p),v}if(n.kty==="EC"&&n.crv!==void 0&&n.x!==void 0&&n.y!==void 0&&n.d!==void 0){var v=new u({curve:n.crv}),A=v.ecparams.keylen/4,m=("0000000000"+b64utohex(n.x)).slice(-A),y=("0000000000"+b64utohex(n.y)).slice(-A),p="04"+m+y,g=("0000000000"+b64utohex(n.d)).slice(-A);return v.setPublicKeyHex(p),v.setPrivateKeyHex(g),v}if(e==="pkcs5prv"){var b=n,r=ASN1HEX,T,h;if(T=i(b,0),T.length===9)h=new d,h.readPKCS5PrvKeyHex(b);else if(T.length===6)h=new l,h.readPKCS5PrvKeyHex(b);else if(T.length>2&&b.substr(T[1],2)==="04")h=new u,h.readPKCS5PrvKeyHex(b);else throw"unsupported PKCS#1/5 hexadecimal key";return h}if(e==="pkcs8prv"){var h=f.getKeyFromPlainPrivatePKCS8Hex(n);return h}if(e==="pkcs8pub")return f._getKeyFromPublicPKCS8Hex(n);if(e==="x509pub")return X509.getPublicKeyFromCertHex(n);if(n.indexOf("-END CERTIFICATE-",0)!=-1||n.indexOf("-END X509 CERTIFICATE-",0)!=-1||n.indexOf("-END TRUSTED CERTIFICATE-",0)!=-1)return X509.getPublicKeyFromCertPEM(n);if(n.indexOf("-END PUBLIC KEY-")!=-1){var _=pemtohex(n,"PUBLIC KEY");return f._getKeyFromPublicPKCS8Hex(_)}if(n.indexOf("-END RSA PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")==-1){var w=c(n,"RSA PRIVATE KEY");return f.getKey(w,null,"pkcs5prv")}if(n.indexOf("-END DSA PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")==-1){var x=c(n,"DSA PRIVATE KEY"),M=o(x,0,[1],"02"),R=o(x,0,[2],"02"),I=o(x,0,[3],"02"),S=o(x,0,[4],"02"),B=o(x,0,[5],"02"),h=new l;return h.setPrivate(new BigInteger(M,16),new BigInteger(R,16),new BigInteger(I,16),new BigInteger(S,16),new BigInteger(B,16)),h}if(n.indexOf("-END EC PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")==-1){var w=c(n,"EC PRIVATE KEY");return f.getKey(w,null,"pkcs5prv")}if(n.indexOf("-END PRIVATE KEY-")!=-1)return f.getKeyFromPlainPrivatePKCS8PEM(n);if(n.indexOf("-END RSA PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")!=-1){var F=f.getDecryptedKeyHex(n,t),O=new RSAKey;return O.readPKCS5PrvKeyHex(F),O}if(n.indexOf("-END EC PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")!=-1){var x=f.getDecryptedKeyHex(n,t),h=o(x,0,[1],"04"),H=o(x,0,[2,0],"06"),k=o(x,0,[3,0],"03").substr(2),N="";if(KJUR.crypto.OID.oidhex2name[H]!==void 0)N=KJUR.crypto.OID.oidhex2name[H];else throw"undefined OID(hex) in KJUR.crypto.OID: "+H;var v=new u({curve:N});return v.setPublicKeyHex(k),v.setPrivateKeyHex(h),v.isPublic=!1,v}if(n.indexOf("-END DSA PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")!=-1){var x=f.getDecryptedKeyHex(n,t),M=o(x,0,[1],"02"),R=o(x,0,[2],"02"),I=o(x,0,[3],"02"),S=o(x,0,[4],"02"),B=o(x,0,[5],"02"),h=new l;return h.setPrivate(new BigInteger(M,16),new BigInteger(R,16),new BigInteger(I,16),new BigInteger(S,16),new BigInteger(B,16)),h}if(n.indexOf("-END ENCRYPTED PRIVATE KEY-")!=-1)return f.getKeyFromEncryptedPKCS8PEM(n,t);throw new Error("not supported argument")},(typeof KJUR.asn1>"u"||!KJUR.asn1)&&(KJUR.asn1={}),KJUR.asn1.ASN1Util={},KJUR.asn1.ASN1Util.oidHexToInt=function(n){for(var i="",t=parseInt(n.substr(0,2),16),e=Math.floor(t/40),r=t%40,i=e+"."+r,o="",s=2;s<n.length;s+=2){var u=parseInt(n.substr(s,2),16),l=("00000000"+u.toString(2)).slice(-8);if(o=o+l.substr(1,7),l.substr(0,1)=="0"){var d=new BigInteger(o,2);i=i+"."+d.toString(10),o=""}}return i};var ASN1HEX=new function(){};ASN1HEX.getLblen=function(n,t){if(n.substr(t+2,1)!="8")return 1;var e=parseInt(n.substr(t+3,1));return e==0?-1:0<e&&e<10?e+1:-2},ASN1HEX.getL=function(n,t){var e=ASN1HEX.getLblen(n,t);return e<1?"":n.substr(t+2,e*2)},ASN1HEX.getVblen=function(n,t){var e,r;return e=ASN1HEX.getL(n,t),e==""?-1:(e.substr(0,1)==="8"?r=new BigInteger(e.substr(2),16):r=new BigInteger(e,16),r.intValue())},ASN1HEX.getVidx=function(n,t){var e=ASN1HEX.getLblen(n,t);return e<0?e:t+(e+1)*2},ASN1HEX.getV=function(n,t){var e=ASN1HEX.getVidx(n,t),r=ASN1HEX.getVblen(n,t);return n.substr(e,r*2)},ASN1HEX.getTLV=function(n,t){return n.substr(t,2)+ASN1HEX.getL(n,t)+ASN1HEX.getV(n,t)},ASN1HEX.getTLVblen=function(n,t){return 2+ASN1HEX.getLblen(n,t)*2+ASN1HEX.getVblen(n,t)*2},ASN1HEX.getNextSiblingIdx=function(n,t){var e=ASN1HEX.getVidx(n,t),r=ASN1HEX.getVblen(n,t);return e+r*2},ASN1HEX.getChildIdx=function(n,t){var e=ASN1HEX,r=[],i,o,s;i=e.getVidx(n,t),o=e.getVblen(n,t)*2,n.substr(t,2)=="03"&&(i+=2,o-=2),s=0;for(var u=i;s<=o;){var l=e.getTLVblen(n,u);if(s+=l,s<=o&&r.push(u),u+=l,s>=o)break}return r},ASN1HEX.getNthChildIdx=function(n,t,e){var r=ASN1HEX.getChildIdx(n,t);return r[e]},ASN1HEX.getIdxbyList=function(n,t,e,r){var i=ASN1HEX,o,s;return e.length==0?r!==void 0&&n.substr(t,2)!==r?-1:t:(o=e.shift(),s=i.getChildIdx(n,t),o>=s.length?-1:i.getIdxbyList(n,s[o],e,r))},ASN1HEX.getIdxbyListEx=function(n,t,e,r){var i=ASN1HEX,o,s;if(e.length==0)return r!==void 0&&n.substr(t,2)!==r?-1:t;o=e.shift(),s=i.getChildIdx(n,t);for(var u=0,l=0;l<s.length;l++){var d=n.substr(s[l],2);if(typeof o=="number"&&!i.isContextTag(d)&&u==o||typeof o=="string"&&i.isContextTag(d,o))return i.getIdxbyListEx(n,s[l],e,r);i.isContextTag(d)||u++}return-1},ASN1HEX.getTLVbyList=function(n,t,e,r){var i=ASN1HEX,o=i.getIdxbyList(n,t,e,r);return o==-1||o>=n.length?null:i.getTLV(n,o)},ASN1HEX.getTLVbyListEx=function(n,t,e,r){var i=ASN1HEX,o=i.getIdxbyListEx(n,t,e,r);return o==-1?null:i.getTLV(n,o)},ASN1HEX.getVbyList=function(n,t,e,r,i){var o=ASN1HEX,s,u;return s=o.getIdxbyList(n,t,e,r),s==-1||s>=n.length?null:(u=o.getV(n,s),i===!0&&(u=u.substr(2)),u)},ASN1HEX.getVbyListEx=function(n,t,e,r,i){var o=ASN1HEX,s,u;return s=o.getIdxbyListEx(n,t,e,r),s==-1?null:(u=o.getV(n,s),n.substr(s,2)=="03"&&i!==!1&&(u=u.substr(2)),u)},ASN1HEX.getInt=function(n,t,e){e==null&&(e=-1);try{var r=n.substr(t,2);if(r!="02"&&r!="03")return e;var i=ASN1HEX.getV(n,t);return r=="02"?parseInt(i,16):bitstrtoint(i)}catch{return e}},ASN1HEX.getOID=function(n,t,e){e==null&&(e=null);try{if(n.substr(t,2)!="06")return e;var r=ASN1HEX.getV(n,t);return hextooid(r)}catch{return e}},ASN1HEX.getOIDName=function(n,t,e){e==null&&(e=null);try{var r=ASN1HEX.getOID(n,t,e);if(r==e)return e;var i=KJUR.asn1.x509.OID.oid2name(r);return i==""?r:i}catch{return e}},ASN1HEX.getString=function(n,t,e){e==null&&(e=null);try{var r=ASN1HEX.getV(n,t);return hextorstr(r)}catch{return e}},ASN1HEX.hextooidstr=function(n){var t=function(f,h){return f.length>=h?f:new Array(h-f.length+1).join("0")+f},e=[],r=n.substr(0,2),i=parseInt(r,16);e[0]=new String(Math.floor(i/40)),e[1]=new String(i%40);for(var o=n.substr(2),s=[],u=0;u<o.length/2;u++)s.push(parseInt(o.substr(u*2,2),16));for(var l=[],d="",u=0;u<s.length;u++)s[u]&128?d=d+t((s[u]&127).toString(2),7):(d=d+t((s[u]&127).toString(2),7),l.push(new String(parseInt(d,2))),d="");var c=e.join(".");return l.length>0&&(c=c+"."+l.join(".")),c},ASN1HEX.isContextTag=function(n,t){n=n.toLowerCase();var e,r;try{e=parseInt(n,16)}catch{return-1}if(t===void 0)return(e&192)==128;try{var i=t.match(/^\[[0-9]+\]$/);return i==null||(r=parseInt(t.substr(1,t.length-1),10),r>31)?!1:(e&192)==128&&(e&31)==r}catch{return!1}},ASN1HEX.isASN1HEX=function(n){var t=ASN1HEX;if(n.length%2==1)return!1;var e=t.getVblen(n,0),r=n.substr(0,2),i=t.getL(n,0),o=n.length-r.length-i.length;return o==e*2},ASN1HEX.checkStrictDER=function(n,t,e,r,i){var o=ASN1HEX;if(e===void 0){if(typeof n!="string")throw new Error("not hex string");if(n=n.toLowerCase(),!KJUR.lang.String.isHex(n))throw new Error("not hex string");e=n.length,r=n.length/2,r<128?i=1:i=Math.ceil(r.toString(16))+1}var s=o.getL(n,t);if(s.length>i*2)throw new Error("L of TLV too long: idx="+t);var u=o.getVblen(n,t);if(u>r)throw new Error("value of L too long than hex: idx="+t);var l=o.getTLV(n,t),d=l.length-2-o.getL(n,t).length;if(d!==u*2)throw new Error("V string length and L's value not the same:"+d+"/"+u*2);if(t===0&&n.length!=l.length)throw new Error("total length and TLV length unmatch:"+n.length+"!="+l.length);var c=n.substr(t,2);if(c==="02"){var f=o.getVidx(n,t);if(n.substr(f,2)=="00"&&n.charCodeAt(f+2)<56)throw new Error("not least zeros for DER INTEGER")}if(parseInt(c,16)&32){for(var h=o.getVblen(n,t),v=0,A=o.getChildIdx(n,t),m=0;m<A.length;m++){var y=o.getTLV(n,A[m]);v+=y.length,o.checkStrictDER(n,A[m],e,r,i)}if(h*2!=v)throw new Error("sum of children's TLV length and L unmatch: "+h*2+"!="+v)}},ASN1HEX.oidname=function(n){var t=KJUR.asn1;KJUR.lang.String.isHex(n)&&(n=t.ASN1Util.oidHexToInt(n));var e=t.x509.OID.oid2name(n);return e===""&&(e=n),e},(typeof KJUR.asn1>"u"||!KJUR.asn1)&&(KJUR.asn1={}),(typeof KJUR.asn1.x509>"u"||!KJUR.asn1.x509)&&(KJUR.asn1.x509={}),KJUR.asn1.x509.AlgorithmIdentifier={},KJUR.asn1.x509.AlgorithmIdentifier.PSSNAME2ASN1TLV={SHAwithRSAandMGF1:"300d06092a864886f70d01010a3000",SHA256withRSAandMGF1:"303d06092a864886f70d01010a3030a00d300b0609608648016503040201a11a301806092a864886f70d010108300b0609608648016503040201a203020120",SHA384withRSAandMGF1:"303d06092a864886f70d01010a3030a00d300b0609608648016503040202a11a301806092a864886f70d010108300b0609608648016503040202a203020130",SHA512withRSAandMGF1:"303d06092a864886f70d01010a3030a00d300b0609608648016503040203a11a301806092a864886f70d010108300b0609608648016503040203a203020140"},KJUR.asn1.x509.OID=new function(n){this.atype2oidList={CN:"2.5.4.3",L:"2.5.4.7",ST:"2.5.4.8",O:"2.5.4.10",OU:"2.5.4.11",C:"2.5.4.6",STREET:"2.5.4.9",DC:"0.9.2342.19200300.100.1.25",UID:"0.9.2342.19200300.100.1.1",SN:"2.5.4.4",T:"2.5.4.12",DN:"2.5.4.49",E:"1.2.840.113549.1.9.1",description:"2.5.4.13",businessCategory:"2.5.4.15",postalCode:"2.5.4.17",serialNumber:"2.5.4.5",uniqueIdentifier:"2.5.4.45",organizationIdentifier:"2.5.4.97",jurisdictionOfIncorporationL:"1.3.6.1.4.1.311.60.2.1.1",jurisdictionOfIncorporationSP:"1.3.6.1.4.1.311.60.2.1.2",jurisdictionOfIncorporationC:"1.3.6.1.4.1.311.60.2.1.3"},this.name2oidList={sha1:"1.3.14.3.2.26",sha256:"2.16.840.1.101.3.4.2.1",sha384:"2.16.840.1.101.3.4.2.2",sha512:"2.16.840.1.101.3.4.2.3",sha224:"2.16.840.1.101.3.4.2.4",md5:"1.2.840.113549.2.5",md2:"1.3.14.7.2.2.1",ripemd160:"1.3.36.3.2.1",MD2withRSA:"1.2.840.113549.1.1.2",MD4withRSA:"1.2.840.113549.1.1.3",MD5withRSA:"1.2.840.113549.1.1.4",SHA1withRSA:"1.2.840.113549.1.1.5","pkcs1-MGF":"1.2.840.113549.1.1.8",rsaPSS:"1.2.840.113549.1.1.10",SHA224withRSA:"1.2.840.113549.1.1.14",SHA256withRSA:"1.2.840.113549.1.1.11",SHA384withRSA:"1.2.840.113549.1.1.12",SHA512withRSA:"1.2.840.113549.1.1.13",SHA1withECDSA:"1.2.840.10045.4.1",SHA224withECDSA:"1.2.840.10045.4.3.1",SHA256withECDSA:"1.2.840.10045.4.3.2",SHA384withECDSA:"1.2.840.10045.4.3.3",SHA512withECDSA:"1.2.840.10045.4.3.4",dsa:"1.2.840.10040.4.1",SHA1withDSA:"1.2.840.10040.4.3",SHA224withDSA:"2.16.840.1.101.3.4.3.1",SHA256withDSA:"2.16.840.1.101.3.4.3.2",rsaEncryption:"1.2.840.113549.1.1.1",commonName:"2.5.4.3",countryName:"2.5.4.6",localityName:"2.5.4.7",stateOrProvinceName:"2.5.4.8",streetAddress:"2.5.4.9",organizationName:"2.5.4.10",organizationalUnitName:"2.5.4.11",domainComponent:"0.9.2342.19200300.100.1.25",userId:"0.9.2342.19200300.100.1.1",surname:"2.5.4.4",givenName:"2.5.4.42",title:"2.5.4.12",distinguishedName:"2.5.4.49",emailAddress:"1.2.840.113549.1.9.1",description:"2.5.4.13",businessCategory:"2.5.4.15",postalCode:"2.5.4.17",uniqueIdentifier:"2.5.4.45",organizationIdentifier:"2.5.4.97",jurisdictionOfIncorporationL:"1.3.6.1.4.1.311.60.2.1.1",jurisdictionOfIncorporationSP:"1.3.6.1.4.1.311.60.2.1.2",jurisdictionOfIncorporationC:"1.3.6.1.4.1.311.60.2.1.3",subjectDirectoryAttributes:"2.5.29.9",subjectKeyIdentifier:"2.5.29.14",keyUsage:"2.5.29.15",subjectAltName:"2.5.29.17",issuerAltName:"2.5.29.18",basicConstraints:"2.5.29.19",cRLNumber:"2.5.29.20",cRLReason:"2.5.29.21",nameConstraints:"2.5.29.30",cRLDistributionPoints:"2.5.29.31",certificatePolicies:"2.5.29.32",anyPolicy:"2.5.29.32.0",authorityKeyIdentifier:"2.5.29.35",policyConstraints:"2.5.29.36",extKeyUsage:"2.5.29.37",authorityInfoAccess:"1.3.6.1.5.5.7.1.1",ocsp:"1.3.6.1.5.5.7.48.1",ocspBasic:"1.3.6.1.5.5.7.48.1.1",ocspNonce:"1.3.6.1.5.5.7.48.1.2",ocspNoCheck:"1.3.6.1.5.5.7.48.1.5",caIssuers:"1.3.6.1.5.5.7.48.2",anyExtendedKeyUsage:"2.5.29.37.0",serverAuth:"1.3.6.1.5.5.7.3.1",clientAuth:"1.3.6.1.5.5.7.3.2",codeSigning:"1.3.6.1.5.5.7.3.3",emailProtection:"1.3.6.1.5.5.7.3.4",timeStamping:"1.3.6.1.5.5.7.3.8",ocspSigning:"1.3.6.1.5.5.7.3.9",dateOfBirth:"1.3.6.1.5.5.7.9.1",placeOfBirth:"1.3.6.1.5.5.7.9.2",gender:"1.3.6.1.5.5.7.9.3",countryOfCitizenship:"1.3.6.1.5.5.7.9.4",countryOfResidence:"1.3.6.1.5.5.7.9.5",ecPublicKey:"1.2.840.10045.2.1","P-256":"1.2.840.10045.3.1.7",secp256r1:"1.2.840.10045.3.1.7",secp256k1:"1.3.132.0.10",secp384r1:"1.3.132.0.34",pkcs5PBES2:"1.2.840.113549.1.5.13",pkcs5PBKDF2:"1.2.840.113549.1.5.12","des-EDE3-CBC":"1.2.840.113549.3.7",data:"1.2.840.113549.1.7.1","signed-data":"1.2.840.113549.1.7.2","enveloped-data":"1.2.840.113549.1.7.3","digested-data":"1.2.840.113549.1.7.5","encrypted-data":"1.2.840.113549.1.7.6","authenticated-data":"1.2.840.113549.1.9.16.1.2",tstinfo:"1.2.840.113549.1.9.16.1.4",signingCertificate:"1.2.840.113549.1.9.16.2.12",timeStampToken:"1.2.840.113549.1.9.16.2.14",signaturePolicyIdentifier:"1.2.840.113549.1.9.16.2.15",etsArchiveTimeStamp:"1.2.840.113549.1.9.16.2.27",signingCertificateV2:"1.2.840.113549.1.9.16.2.47",etsArchiveTimeStampV2:"1.2.840.113549.1.9.16.2.48",extensionRequest:"1.2.840.113549.1.9.14",contentType:"1.2.840.113549.1.9.3",messageDigest:"1.2.840.113549.1.9.4",signingTime:"1.2.840.113549.1.9.5",counterSignature:"1.2.840.113549.1.9.6",archiveTimeStampV3:"0.4.0.1733.2.4",pdfRevocationInfoArchival:"1.2.840.113583.1.1.8",adobeTimeStamp:"1.2.840.113583.1.1.9.1"},this.objCache={},this.name2obj=function(t){if(typeof this.objCache[t]<"u")return this.objCache[t];if(typeof this.name2oidList[t]>"u")throw"Name of ObjectIdentifier not defined: "+t;var e=this.name2oidList[t],r=new KJUR.asn1.DERObjectIdentifier({oid:e});return this.objCache[t]=r,r},this.atype2obj=function(t){if(this.objCache[t]!==void 0)return this.objCache[t];var e;if(t.match(/^\d+\.\d+\.[0-9.]+$/))e=t;else if(this.atype2oidList[t]!==void 0)e=this.atype2oidList[t];else if(this.name2oidList[t]!==void 0)e=this.name2oidList[t];else throw"AttributeType name undefined: "+t;var r=new KJUR.asn1.DERObjectIdentifier({oid:e});return this.objCache[t]=r,r}},KJUR.asn1.x509.OID.oid2name=function(n){var t=KJUR.asn1.x509.OID.name2oidList;for(var e in t)if(t[e]==n)return e;return""},KJUR.asn1.x509.OID.oid2atype=function(n){var t=KJUR.asn1.x509.OID.atype2oidList;for(var e in t)if(t[e]==n)return e;return n},KJUR.asn1.x509.OID.name2oid=function(n){if(n.match(/^[0-9.]+$/))return n;var t=KJUR.asn1.x509.OID.name2oidList;return t[n]===void 0?"":t[n]},RSAKey.getPosArrayOfChildrenFromHex=function(n){return ASN1HEX.getChildIdx(n,0)},RSAKey.getHexValueArrayOfChildrenFromHex=function(n){var t=ASN1HEX,e=t.getV,h=RSAKey.getPosArrayOfChildrenFromHex(n),r=e(n,h[0]),i=e(n,h[1]),o=e(n,h[2]),s=e(n,h[3]),u=e(n,h[4]),l=e(n,h[5]),d=e(n,h[6]),c=e(n,h[7]),f=e(n,h[8]),h=new Array;return h.push(r,i,o,s,u,l,d,c,f),h},RSAKey.prototype.readPrivateKeyFromPEMString=function(n){var t=pemtohex(n),e=RSAKey.getHexValueArrayOfChildrenFromHex(t);this.setPrivateEx(e[1],e[2],e[3],e[4],e[5],e[6],e[7],e[8])},RSAKey.prototype.readPKCS5PrvKeyHex=function(n){var t=RSAKey.getHexValueArrayOfChildrenFromHex(n);this.setPrivateEx(t[1],t[2],t[3],t[4],t[5],t[6],t[7],t[8])},RSAKey.prototype.readPKCS8PrvKeyHex=function(n){var t,e,r,i,o,s,u,l,d=ASN1HEX,c=d.getVbyListEx;if(d.isASN1HEX(n)===!1)throw new Error("not ASN.1 hex string");try{t=c(n,0,[2,0,1],"02"),e=c(n,0,[2,0,2],"02"),r=c(n,0,[2,0,3],"02"),i=c(n,0,[2,0,4],"02"),o=c(n,0,[2,0,5],"02"),s=c(n,0,[2,0,6],"02"),u=c(n,0,[2,0,7],"02"),l=c(n,0,[2,0,8],"02")}catch{throw new Error("malformed PKCS#8 plain RSA private key")}this.setPrivateEx(t,e,r,i,o,s,u,l)},RSAKey.prototype.readPKCS5PubKeyHex=function(n){var t=ASN1HEX,e=t.getV;if(t.isASN1HEX(n)===!1)throw new Error("keyHex is not ASN.1 hex string");var r=t.getChildIdx(n,0);if(r.length!==2||n.substr(r[0],2)!=="02"||n.substr(r[1],2)!=="02")throw new Error("wrong hex for PKCS#5 public key");var i=e(n,r[0]),o=e(n,r[1]);this.setPublic(i,o)},RSAKey.prototype.readPKCS8PubKeyHex=function(n){var t=ASN1HEX;if(t.isASN1HEX(n)===!1)throw new Error("not ASN.1 hex string");if(t.getTLVbyListEx(n,0,[0,0])!=="06092a864886f70d010101")throw new Error("not PKCS8 RSA public key");var e=t.getTLVbyListEx(n,0,[1,0]);this.readPKCS5PubKeyHex(e)},RSAKey.prototype.readCertPubKeyHex=function(n,t){var e,r;e=new X509,e.readCertHex(n),r=e.getPublicKeyHex(),this.readPKCS8PubKeyHex(r)};function _rsasign_getAlgNameAndHashFromHexDisgestInfo(n){for(var t in KJUR.crypto.Util.DIGESTINFOHEAD){var e=KJUR.crypto.Util.DIGESTINFOHEAD[t],r=e.length;if(n.substring(0,r)==e){var i=[t,n.substring(r)];return i}}return[]}RSAKey.prototype.verify=function(n,t){if(t=t.toLowerCase(),t.match(/^[0-9a-f]+$/)==null)return!1;var e=parseBigInt(t,16),r=this.n.bitLength();if(e.bitLength()>r)return!1;var i=this.doPublic(e),o=i.toString(16);if(o.length+3!=r/4)return!1;var s=o.replace(/^1f+00/,""),u=_rsasign_getAlgNameAndHashFromHexDisgestInfo(s);if(u.length==0)return!1;var l=u[0],d=u[1],c=function(h){return KJUR.crypto.Util.hashString(h,l)},f=c(n);return d==f},RSAKey.prototype.verifyWithMessageHash=function(n,t){if(t.length!=Math.ceil(this.n.bitLength()/4))return!1;var e=parseBigInt(t,16);if(e.bitLength()>this.n.bitLength())return 0;var r=this.doPublic(e),i=r.toString(16).replace(/^1f+00/,""),o=_rsasign_getAlgNameAndHashFromHexDisgestInfo(i);if(o.length==0)return!1;o[0];var s=o[1];return s==n},RSAKey.prototype.verifyPSS=function(n,t,e,r){var i=function(s){return KJUR.crypto.Util.hashHex(s,e)},o=i(rstrtohex(n));return r===void 0&&(r=-1),this.verifyWithMessageHashPSS(o,t,e,r)},RSAKey.prototype.verifyWithMessageHashPSS=function(n,t,e,r){if(t.length!=Math.ceil(this.n.bitLength()/4))return!1;var i=new BigInteger(t,16),o=function(g){return KJUR.crypto.Util.hashHex(g,e)},s=hextorstr(n),u=s.length,l=this.n.bitLength()-1,d=Math.ceil(l/8),c;if(r===-1||r===void 0)r=u;else if(r===-2)r=d-u-2;else if(r<-2)throw new Error("invalid salt length");if(d<u+r+2)throw new Error("data too long");var f=this.doPublic(i).toByteArray();for(c=0;c<f.length;c+=1)f[c]&=255;for(;f.length<d;)f.unshift(0);if(f[d-1]!==188)throw new Error("encoded message does not end in 0xbc");f=String.fromCharCode.apply(String,f);var h=f.substr(0,d-u-1),v=f.substr(h.length,u),A=65280>>8*d-l&255;if(h.charCodeAt(0)&A)throw new Error("bits beyond keysize not zero");var m=pss_mgf1_str(v,h.length,o),y=[];for(c=0;c<h.length;c+=1)y[c]=h.charCodeAt(c)^m.charCodeAt(c);y[0]&=~A;var p=d-u-r-2;for(c=0;c<p;c+=1)if(y[c]!==0)throw new Error("leftmost octets not zero");if(y[p]!==1)throw new Error("0x01 marker not found");return v===hextorstr(o(rstrtohex("\0\0\0\0\0\0\0\0"+s+String.fromCharCode.apply(String,y.slice(-r)))))},RSAKey.SALT_LEN_HLEN=-1,RSAKey.SALT_LEN_MAX=-2,RSAKey.SALT_LEN_RECOVER=-2;function X509(n){var t=ASN1HEX,e=t.getChildIdx,r=t.getV,i=t.getTLV,o=t.getVbyList,s=t.getVbyListEx,u=t.getTLVbyList,l=t.getTLVbyListEx,d=t.getIdxbyList,c=t.getIdxbyListEx,f=t.getVidx,h=t.getInt,v=t.oidname,A=t.hextooidstr,m=pemtohex,y;try{y=KJUR.asn1.x509.AlgorithmIdentifier.PSSNAME2ASN1TLV}catch{}this.HEX2STAG={"0c":"utf8",13:"prn",16:"ia5","1a":"vis","1e":"bmp"},this.hex=null,this.version=0,this.foffset=0,this.aExtInfo=null,this.getVersion=function(){if(this.hex===null||this.version!==0)return this.version;var p=u(this.hex,0,[0,0]);if(p.substr(0,2)=="a0"){var g=u(p,0,[0]),b=h(g,0);if(b<0||2<b)throw new Error("malformed version field");return this.version=b+1,this.version}else return this.version=1,this.foffset=-1,1},this.getSerialNumberHex=function(){return s(this.hex,0,[0,0],"02")},this.getSignatureAlgorithmField=function(){var p=l(this.hex,0,[0,1]);return this.getAlgorithmIdentifierName(p)},this.getAlgorithmIdentifierName=function(p){for(var g in y)if(p===y[g])return g;return v(s(p,0,[0],"06"))},this.getIssuer=function(){return this.getX500Name(this.getIssuerHex())},this.getIssuerHex=function(){return u(this.hex,0,[0,3+this.foffset],"30")},this.getIssuerString=function(){var p=this.getIssuer();return p.str},this.getSubject=function(){return this.getX500Name(this.getSubjectHex())},this.getSubjectHex=function(){return u(this.hex,0,[0,5+this.foffset],"30")},this.getSubjectString=function(){var p=this.getSubject();return p.str},this.getNotBefore=function(){var p=o(this.hex,0,[0,4+this.foffset,0]);return p=p.replace(/(..)/g,"%$1"),p=decodeURIComponent(p),p},this.getNotAfter=function(){var p=o(this.hex,0,[0,4+this.foffset,1]);return p=p.replace(/(..)/g,"%$1"),p=decodeURIComponent(p),p},this.getPublicKeyHex=function(){return t.getTLVbyList(this.hex,0,[0,6+this.foffset],"30")},this.getPublicKeyIdx=function(){return d(this.hex,0,[0,6+this.foffset],"30")},this.getPublicKeyContentIdx=function(){var p=this.getPublicKeyIdx();return d(this.hex,p,[1,0],"30")},this.getPublicKey=function(){return KEYUTIL.getKey(this.getPublicKeyHex(),null,"pkcs8pub")},this.getSignatureAlgorithmName=function(){var p=u(this.hex,0,[1],"30");return this.getAlgorithmIdentifierName(p)},this.getSignatureValueHex=function(){return o(this.hex,0,[2],"03",!0)},this.verifySignature=function(p){var g=this.getSignatureAlgorithmField(),b=this.getSignatureValueHex(),T=u(this.hex,0,[0],"30"),_=new KJUR.crypto.Signature({alg:g});return _.init(p),_.updateHex(T),_.verify(b)},this.parseExt=function(p){var g,b,T;if(p===void 0){if(T=this.hex,this.version!==3)return-1;g=d(T,0,[0,7,0],"30"),b=e(T,g)}else{T=pemtohex(p);var _=d(T,0,[0,3,0,0],"06");if(r(T,_)!="2a864886f70d01090e"){this.aExtInfo=new Array;return}g=d(T,0,[0,3,0,1,0],"30"),b=e(T,g),this.hex=T}this.aExtInfo=new Array;for(var w=0;w<b.length;w++){var x={};x.critical=!1;var M=e(T,b[w]),R=0;M.length===3&&(x.critical=!0,R=1),x.oid=t.hextooidstr(o(T,b[w],[0],"06"));var I=d(T,b[w],[1+R]);x.vidx=f(T,I),this.aExtInfo.push(x)}},this.getExtInfo=function(p){var g=this.aExtInfo,b=p;if(p.match(/^[0-9.]+$/)||(b=KJUR.asn1.x509.OID.name2oid(p)),b!==""){for(var T=0;T<g.length;T++)if(g[T].oid===b)return g[T]}},this.getExtBasicConstraints=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("basicConstraints");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"basicConstraints"};if(g&&(T.critical=!0),p==="3000")return T;if(p==="30030101ff")return T.cA=!0,T;if(p.substr(0,12)==="30060101ff02"){var _=r(p,10),w=parseInt(_,16);return T.cA=!0,T.pathLen=w,T}throw new Error("hExtV parse error: "+p)},this.getExtKeyUsage=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("keyUsage");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"keyUsage"};return g&&(T.critical=!0),T.names=this.getExtKeyUsageString(p).split(","),T},this.getExtKeyUsageBin=function(p){if(p===void 0){var g=this.getExtInfo("keyUsage");if(g===void 0)return"";p=i(this.hex,g.vidx)}if(p.length!=8&&p.length!=10)throw new Error("malformed key usage value: "+p);var b="000000000000000"+parseInt(p.substr(6),16).toString(2);return p.length==8&&(b=b.slice(-8)),p.length==10&&(b=b.slice(-16)),b=b.replace(/0+$/,""),b==""&&(b="0"),b},this.getExtKeyUsageString=function(p){for(var g=this.getExtKeyUsageBin(p),b=new Array,T=0;T<g.length;T++)g.substr(T,1)=="1"&&b.push(X509.KEYUSAGE_NAME[T]);return b.join(",")},this.getExtSubjectKeyIdentifier=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("subjectKeyIdentifier");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"subjectKeyIdentifier"};g&&(T.critical=!0);var _=r(p,0);return T.kid={hex:_},T},this.getExtAuthorityKeyIdentifier=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("authorityKeyIdentifier");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"authorityKeyIdentifier"};g&&(T.critical=!0);for(var _=e(p,0),w=0;w<_.length;w++){var x=p.substr(_[w],2);if(x==="80"&&(T.kid={hex:r(p,_[w])}),x==="a1"){var M=i(p,_[w]),R=this.getGeneralNames(M);T.issuer=R[0].dn}x==="82"&&(T.sn={hex:r(p,_[w])})}return T},this.getExtExtKeyUsage=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("extKeyUsage");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"extKeyUsage",array:[]};g&&(T.critical=!0);for(var _=e(p,0),w=0;w<_.length;w++)T.array.push(v(r(p,_[w])));return T},this.getExtExtKeyUsageName=function(){var p=this.getExtInfo("extKeyUsage");if(p===void 0)return p;var g=new Array,b=i(this.hex,p.vidx);if(b==="")return g;for(var T=e(b,0),_=0;_<T.length;_++)g.push(v(r(b,T[_])));return g},this.getExtSubjectAltName=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("subjectAltName");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"subjectAltName",array:[]};return g&&(T.critical=!0),T.array=this.getGeneralNames(p),T},this.getExtIssuerAltName=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("issuerAltName");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"issuerAltName",array:[]};return g&&(T.critical=!0),T.array=this.getGeneralNames(p),T},this.getGeneralNames=function(p){for(var g=e(p,0),b=[],T=0;T<g.length;T++){var _=this.getGeneralName(i(p,g[T]));_!==void 0&&b.push(_)}return b},this.getGeneralName=function(p){var g=p.substr(0,2),b=r(p,0),T=hextorstr(b);if(g=="81")return{rfc822:T};if(g=="82")return{dns:T};if(g=="86")return{uri:T};if(g=="87")return{ip:hextoip(b)};if(g=="a4")return{dn:this.getX500Name(b)}},this.getExtSubjectAltName2=function(){var p,g,b,T=this.getExtInfo("subjectAltName");if(T===void 0)return T;for(var _=new Array,w=i(this.hex,T.vidx),x=e(w,0),M=0;M<x.length;M++)b=w.substr(x[M],2),p=r(w,x[M]),b==="81"&&(g=hextoutf8(p),_.push(["MAIL",g])),b==="82"&&(g=hextoutf8(p),_.push(["DNS",g])),b==="84"&&(g=X509.hex2dn(p,0),_.push(["DN",g])),b==="86"&&(g=hextoutf8(p),_.push(["URI",g])),b==="87"&&(g=hextoip(p),_.push(["IP",g]));return _},this.getExtCRLDistributionPoints=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("cRLDistributionPoints");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"cRLDistributionPoints",array:[]};g&&(T.critical=!0);for(var _=e(p,0),w=0;w<_.length;w++){var x=i(p,_[w]);T.array.push(this.getDistributionPoint(x))}return T},this.getDistributionPoint=function(p){for(var g={},b=e(p,0),T=0;T<b.length;T++){var _=p.substr(b[T],2),w=i(p,b[T]);_=="a0"&&(g.dpname=this.getDistributionPointName(w))}return g},this.getDistributionPointName=function(p){for(var g={},b=e(p,0),T=0;T<b.length;T++){var _=p.substr(b[T],2),w=i(p,b[T]);_=="a0"&&(g.full=this.getGeneralNames(w))}return g},this.getExtCRLDistributionPointsURI=function(){var p=this.getExtInfo("cRLDistributionPoints");if(p===void 0)return p;for(var g=new Array,b=e(this.hex,p.vidx),T=0;T<b.length;T++)try{var _=o(this.hex,b[T],[0,0,0],"86"),w=hextoutf8(_);g.push(w)}catch{}return g},this.getExtAIAInfo=function(){var p=this.getExtInfo("authorityInfoAccess");if(p===void 0)return p;for(var g={ocsp:[],caissuer:[]},b=e(this.hex,p.vidx),T=0;T<b.length;T++){var _=o(this.hex,b[T],[0],"06"),w=o(this.hex,b[T],[1],"86");_==="2b06010505073001"&&g.ocsp.push(hextoutf8(w)),_==="2b06010505073002"&&g.caissuer.push(hextoutf8(w))}return g},this.getExtAuthorityInfoAccess=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("authorityInfoAccess");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"authorityInfoAccess",array:[]};g&&(T.critical=!0);for(var _=e(p,0),w=0;w<_.length;w++){var x=s(p,_[w],[0],"06"),M=o(p,_[w],[1],"86"),R=hextoutf8(M);if(x=="2b06010505073001")T.array.push({ocsp:R});else if(x=="2b06010505073002")T.array.push({caissuer:R});else throw new Error("unknown method: "+x)}return T},this.getExtCertificatePolicies=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("certificatePolicies");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"certificatePolicies",array:[]};g&&(T.critical=!0);for(var _=e(p,0),w=0;w<_.length;w++){var x=i(p,_[w]),M=this.getPolicyInformation(x);T.array.push(M)}return T},this.getPolicyInformation=function(p){var g={},b=o(p,0,[0],"06");g.policyoid=v(b);var T=c(p,0,[1],"30");if(T!=-1){g.array=[];for(var _=e(p,T),w=0;w<_.length;w++){var x=i(p,_[w]),M=this.getPolicyQualifierInfo(x);g.array.push(M)}}return g},this.getPolicyQualifierInfo=function(p){var g={},b=o(p,0,[0],"06");if(b==="2b06010505070201"){var T=s(p,0,[1],"16");g.cps=hextorstr(T)}else if(b==="2b06010505070202"){var _=u(p,0,[1],"30");g.unotice=this.getUserNotice(_)}return g},this.getUserNotice=function(p){for(var g={},b=e(p,0),T=0;T<b.length;T++){var _=i(p,b[T]);_.substr(0,2)!="30"&&(g.exptext=this.getDisplayText(_))}return g},this.getDisplayText=function(p){var g={"0c":"utf8",16:"ia5","1a":"vis","1e":"bmp"},b={};return b.type=g[p.substr(0,2)],b.str=hextorstr(r(p,0)),b},this.getExtCRLNumber=function(p,g){var b={extname:"cRLNumber"};if(g&&(b.critical=!0),p.substr(0,2)=="02")return b.num={hex:r(p,0)},b;throw new Error("hExtV parse error: "+p)},this.getExtCRLReason=function(p,g){var b={extname:"cRLReason"};if(g&&(b.critical=!0),p.substr(0,2)=="0a")return b.code=parseInt(r(p,0),16),b;throw new Error("hExtV parse error: "+p)},this.getExtOcspNonce=function(p,g){var b={extname:"ocspNonce"};g&&(b.critical=!0);var T=r(p,0);return b.hex=T,b},this.getExtOcspNoCheck=function(p,g){var b={extname:"ocspNoCheck"};return g&&(b.critical=!0),b},this.getExtAdobeTimeStamp=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("adobeTimeStamp");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"adobeTimeStamp"};g&&(T.critical=!0);var _=e(p,0);if(_.length>1){var w=i(p,_[1]),x=this.getGeneralName(w);x.uri!=null&&(T.uri=x.uri)}if(_.length>2){var M=i(p,_[2]);M=="0101ff"&&(T.reqauth=!0),M=="010100"&&(T.reqauth=!1)}return T},this.getX500NameRule=function(p){for(var g=null,b=[],T=0;T<p.length;T++)for(var _=p[T],w=0;w<_.length;w++)b.push(_[w]);for(var T=0;T<b.length;T++){var x=b[T],M=x.ds,R=x.value,I=x.type;if(M!="prn"&&M!="utf8"&&M!="ia5")return"mixed";if(M=="ia5"){if(I!="CN")return"mixed";if(KJUR.lang.String.isMail(R))continue;return"mixed"}if(I=="C"){if(M=="prn")continue;return"mixed"}if(g==null)g=M;else if(g!==M)return"mixed"}return g??"prn"},this.getX500Name=function(p){var g=this.getX500NameArray(p),b=this.dnarraytostr(g);return{array:g,str:b}},this.getX500NameArray=function(p){for(var g=[],b=e(p,0),T=0;T<b.length;T++)g.push(this.getRDN(i(p,b[T])));return g},this.getRDN=function(p){for(var g=[],b=e(p,0),T=0;T<b.length;T++)g.push(this.getAttrTypeAndValue(i(p,b[T])));return g},this.getAttrTypeAndValue=function(p){var g={type:null,value:null,ds:null},b=e(p,0),T=o(p,b[0],[],"06"),_=o(p,b[1],[]),w=KJUR.asn1.ASN1Util.oidHexToInt(T);return g.type=KJUR.asn1.x509.OID.oid2atype(w),g.ds=this.HEX2STAG[p.substr(b[1],2)],g.ds!="bmp"?g.value=hextoutf8(_):g.value=ucs2hextoutf8(_),g},this.readCertPEM=function(p){this.readCertHex(m(p))},this.readCertHex=function(p){this.hex=p,this.getVersion();try{d(this.hex,0,[0,7],"a3"),this.parseExt()}catch{}},this.getParam=function(){var p={};return p.version=this.getVersion(),p.serial={hex:this.getSerialNumberHex()},p.sigalg=this.getSignatureAlgorithmField(),p.issuer=this.getIssuer(),p.notbefore=this.getNotBefore(),p.notafter=this.getNotAfter(),p.subject=this.getSubject(),p.sbjpubkey=hextopem(this.getPublicKeyHex(),"PUBLIC KEY"),this.aExtInfo.length>0&&(p.ext=this.getExtParamArray()),p.sighex=this.getSignatureValueHex(),p},this.getExtParamArray=function(p){if(p==null){var g=c(this.hex,0,[0,"[3]"]);g!=-1&&(p=l(this.hex,0,[0,"[3]",0],"30"))}for(var b=[],T=e(p,0),_=0;_<T.length;_++){var w=i(p,T[_]),x=this.getExtParam(w);x!=null&&b.push(x)}return b},this.getExtParam=function(p){var g=e(p,0),b=g.length;if(b!=2&&b!=3)throw new Error("wrong number elements in Extension: "+b+" "+p);var T=A(o(p,0,[0],"06")),_=!1;b==3&&u(p,0,[1])=="0101ff"&&(_=!0);var w=u(p,0,[b-1,0]),x=void 0;if(T=="2.5.29.14"?x=this.getExtSubjectKeyIdentifier(w,_):T=="2.5.29.15"?x=this.getExtKeyUsage(w,_):T=="2.5.29.17"?x=this.getExtSubjectAltName(w,_):T=="2.5.29.18"?x=this.getExtIssuerAltName(w,_):T=="2.5.29.19"?x=this.getExtBasicConstraints(w,_):T=="2.5.29.31"?x=this.getExtCRLDistributionPoints(w,_):T=="2.5.29.32"?x=this.getExtCertificatePolicies(w,_):T=="2.5.29.35"?x=this.getExtAuthorityKeyIdentifier(w,_):T=="2.5.29.37"?x=this.getExtExtKeyUsage(w,_):T=="1.3.6.1.5.5.7.1.1"?x=this.getExtAuthorityInfoAccess(w,_):T=="2.5.29.20"?x=this.getExtCRLNumber(w,_):T=="2.5.29.21"?x=this.getExtCRLReason(w,_):T=="1.3.6.1.5.5.7.48.1.2"?x=this.getExtOcspNonce(w,_):T=="1.3.6.1.5.5.7.48.1.5"?x=this.getExtOcspNoCheck(w,_):T=="1.2.840.113583.1.1.9.1"&&(x=this.getExtAdobeTimeStamp(w,_)),x!=null)return x;var M={extname:T,extn:w};return _&&(M.critical=!0),M},this.findExt=function(p,g){for(var b=0;b<p.length;b++)if(p[b].extname==g)return p[b];return null},this.dnarraytostr=function(p){function g(T){return T.map(function(_){return b(_).replace(/\+/,"\\+")}).join("+")}function b(T){return T.type+"="+T.value}return"/"+p.map(function(T){return g(T).replace(/\//,"\\/")}).join("/")},this.getInfo=function(){var p=function(q){var V=JSON.stringify(q.array).replace(/[\[\]\{\}\"]/g,"");return V},g=function(q){for(var V="",D=q.array,K=0;K<D.length;K++){var z=D[K];if(V+=" policy oid: "+z.policyoid+`
|
|
362
|
+
`,R},parseHexOfEncryptedPKCS8:function(A){var m=ASN1HEX,y=m.getChildIdx,p=m.getV,g={},b=y(A,0);if(b.length!=2)throw"malformed format: SEQUENCE(0).items != 2: "+b.length;g.ciphertext=p(A,b[1]);var T=y(A,b[0]);if(T.length!=2)throw"malformed format: SEQUENCE(0.0).items != 2: "+T.length;if(p(A,T[0])!="2a864886f70d01050d")throw"this only supports pkcs5PBES2";var _=y(A,T[1]);if(T.length!=2)throw"malformed format: SEQUENCE(0.0.1).items != 2: "+_.length;var w=y(A,_[1]);if(w.length!=2)throw"malformed format: SEQUENCE(0.0.1.1).items != 2: "+w.length;if(p(A,w[0])!="2a864886f70d0307")throw"this only supports TripleDES";g.encryptionSchemeAlg="TripleDES",g.encryptionSchemeIV=p(A,w[1]);var x=y(A,_[0]);if(x.length!=2)throw"malformed format: SEQUENCE(0.0.1.0).items != 2: "+x.length;if(p(A,x[0])!="2a864886f70d01050c")throw"this only supports pkcs5PBKDF2";var M=y(A,x[1]);if(M.length<2)throw"malformed format: SEQUENCE(0.0.1.0.1).items < 2: "+M.length;g.pbkdf2Salt=p(A,M[0]);var R=p(A,M[1]);try{g.pbkdf2Iter=parseInt(R,16)}catch{throw"malformed format pbkdf2Iter: "+R}return g},getPBKDF2KeyHexFromParam:function(A,m){var y=CryptoJS.enc.Hex.parse(A.pbkdf2Salt),p=A.pbkdf2Iter,g=CryptoJS.PBKDF2(m,y,{keySize:192/32,iterations:p}),b=CryptoJS.enc.Hex.stringify(g);return b},_getPlainPKCS8HexFromEncryptedPKCS8PEM:function(A,m){var y=pemtohex(A,"ENCRYPTED PRIVATE KEY"),p=this.parseHexOfEncryptedPKCS8(y),g=KEYUTIL.getPBKDF2KeyHexFromParam(p,m),b={};b.ciphertext=CryptoJS.enc.Hex.parse(p.ciphertext);var T=CryptoJS.enc.Hex.parse(g),_=CryptoJS.enc.Hex.parse(p.encryptionSchemeIV),w=CryptoJS.TripleDES.decrypt(b,T,{iv:_}),x=CryptoJS.enc.Hex.stringify(w);return x},getKeyFromEncryptedPKCS8PEM:function(A,m){var y=this._getPlainPKCS8HexFromEncryptedPKCS8PEM(A,m),p=this.getKeyFromPlainPrivatePKCS8Hex(y);return p},parsePlainPrivatePKCS8Hex:function(A){var m=ASN1HEX,y=m.getChildIdx,p=m.getV,g={};if(g.algparam=null,A.substr(0,2)!="30")throw new Error("malformed plain PKCS8 private key(code:001)");var b=y(A,0);if(b.length<3)throw new Error("malformed plain PKCS8 private key(code:002)");if(A.substr(b[1],2)!="30")throw new Error("malformed PKCS8 private key(code:003)");var T=y(A,b[1]);if(T.length!=2)throw new Error("malformed PKCS8 private key(code:004)");if(A.substr(T[0],2)!="06")throw new Error("malformed PKCS8 private key(code:005)");if(g.algoid=p(A,T[0]),A.substr(T[1],2)=="06"&&(g.algparam=p(A,T[1])),A.substr(b[2],2)!="04")throw new Error("malformed PKCS8 private key(code:006)");return g.keyidx=m.getVidx(A,b[2]),g},getKeyFromPlainPrivatePKCS8PEM:function(A){var m=pemtohex(A,"PRIVATE KEY"),y=this.getKeyFromPlainPrivatePKCS8Hex(m);return y},getKeyFromPlainPrivatePKCS8Hex:function(A){var m=this.parsePlainPrivatePKCS8Hex(A),y;if(m.algoid=="2a864886f70d010101")y=new RSAKey;else if(KJUR.crypto.DSA&&m.algoid=="2a8648ce380401")y=new KJUR.crypto.DSA;else if(KJUR.crypto.ECDSA&&m.algoid=="2a8648ce3d0201")y=new KJUR.crypto.ECDSA;else throw"unsupported private key algorithm";return y.readPKCS8PrvKeyHex(A),y},_getKeyFromPublicPKCS8Hex:function(A){var m,y=ASN1HEX.getVbyList(A,0,[0,0],"06");if(y==="2a864886f70d010101")m=new RSAKey;else if(KJUR.crypto.DSA&&y==="2a8648ce380401")m=new KJUR.crypto.DSA;else if(KJUR.crypto.ECDSA&&y==="2a8648ce3d0201")m=new KJUR.crypto.ECDSA;else throw"unsupported PKCS#8 public key hex";return m.readPKCS8PubKeyHex(A),m},parsePublicRawRSAKeyHex:function(A){var m=ASN1HEX,y=m.getChildIdx,p=m.getV,g={};if(A.substr(0,2)!="30")throw"malformed RSA key(code:001)";var b=y(A,0);if(b.length!=2)throw"malformed RSA key(code:002)";if(A.substr(b[0],2)!="02")throw"malformed RSA key(code:003)";if(g.n=p(A,b[0]),A.substr(b[1],2)!="02")throw"malformed RSA key(code:004)";return g.e=p(A,b[1]),g},parsePublicPKCS8Hex:function(A){var m=ASN1HEX,y=m.getChildIdx,p=m.getV,g={};g.algparam=null;var b=y(A,0);if(b.length!=2)throw"outer DERSequence shall have 2 elements: "+b.length;var T=b[0];if(A.substr(T,2)!="30")throw"malformed PKCS8 public key(code:001)";var _=y(A,T);if(_.length!=2)throw"malformed PKCS8 public key(code:002)";if(A.substr(_[0],2)!="06")throw"malformed PKCS8 public key(code:003)";if(g.algoid=p(A,_[0]),A.substr(_[1],2)=="06"?g.algparam=p(A,_[1]):A.substr(_[1],2)=="30"&&(g.algparam={},g.algparam.p=m.getVbyList(A,_[1],[0],"02"),g.algparam.q=m.getVbyList(A,_[1],[1],"02"),g.algparam.g=m.getVbyList(A,_[1],[2],"02")),A.substr(b[1],2)!="03")throw"malformed PKCS8 public key(code:004)";return g.key=p(A,b[1]).substr(2),g}}}();KEYUTIL.getKey=function(n,t,e){var r=ASN1HEX,i=r.getChildIdx;r.getV;var o=r.getVbyList,s=KJUR.crypto,u=s.ECDSA,l=s.DSA,d=RSAKey,c=pemtohex,f=KEYUTIL;if(typeof d<"u"&&n instanceof d||typeof u<"u"&&n instanceof u||typeof l<"u"&&n instanceof l)return n;if(n.curve!==void 0&&n.xy!==void 0&&n.d===void 0)return new u({pub:n.xy,curve:n.curve});if(n.curve!==void 0&&n.d!==void 0)return new u({prv:n.d,curve:n.curve});if(n.kty===void 0&&n.n!==void 0&&n.e!==void 0&&n.d===void 0){var h=new d;return h.setPublic(n.n,n.e),h}if(n.kty===void 0&&n.n!==void 0&&n.e!==void 0&&n.d!==void 0&&n.p!==void 0&&n.q!==void 0&&n.dp!==void 0&&n.dq!==void 0&&n.co!==void 0&&n.qi===void 0){var h=new d;return h.setPrivateEx(n.n,n.e,n.d,n.p,n.q,n.dp,n.dq,n.co),h}if(n.kty===void 0&&n.n!==void 0&&n.e!==void 0&&n.d!==void 0&&n.p===void 0){var h=new d;return h.setPrivate(n.n,n.e,n.d),h}if(n.p!==void 0&&n.q!==void 0&&n.g!==void 0&&n.y!==void 0&&n.x===void 0){var h=new l;return h.setPublic(n.p,n.q,n.g,n.y),h}if(n.p!==void 0&&n.q!==void 0&&n.g!==void 0&&n.y!==void 0&&n.x!==void 0){var h=new l;return h.setPrivate(n.p,n.q,n.g,n.y,n.x),h}if(n.kty==="RSA"&&n.n!==void 0&&n.e!==void 0&&n.d===void 0){var h=new d;return h.setPublic(b64utohex(n.n),b64utohex(n.e)),h}if(n.kty==="RSA"&&n.n!==void 0&&n.e!==void 0&&n.d!==void 0&&n.p!==void 0&&n.q!==void 0&&n.dp!==void 0&&n.dq!==void 0&&n.qi!==void 0){var h=new d;return h.setPrivateEx(b64utohex(n.n),b64utohex(n.e),b64utohex(n.d),b64utohex(n.p),b64utohex(n.q),b64utohex(n.dp),b64utohex(n.dq),b64utohex(n.qi)),h}if(n.kty==="RSA"&&n.n!==void 0&&n.e!==void 0&&n.d!==void 0){var h=new d;return h.setPrivate(b64utohex(n.n),b64utohex(n.e),b64utohex(n.d)),h}if(n.kty==="EC"&&n.crv!==void 0&&n.x!==void 0&&n.y!==void 0&&n.d===void 0){var v=new u({curve:n.crv}),A=v.ecparams.keylen/4,m=("0000000000"+b64utohex(n.x)).slice(-A),y=("0000000000"+b64utohex(n.y)).slice(-A),p="04"+m+y;return v.setPublicKeyHex(p),v}if(n.kty==="EC"&&n.crv!==void 0&&n.x!==void 0&&n.y!==void 0&&n.d!==void 0){var v=new u({curve:n.crv}),A=v.ecparams.keylen/4,m=("0000000000"+b64utohex(n.x)).slice(-A),y=("0000000000"+b64utohex(n.y)).slice(-A),p="04"+m+y,g=("0000000000"+b64utohex(n.d)).slice(-A);return v.setPublicKeyHex(p),v.setPrivateKeyHex(g),v}if(e==="pkcs5prv"){var b=n,r=ASN1HEX,T,h;if(T=i(b,0),T.length===9)h=new d,h.readPKCS5PrvKeyHex(b);else if(T.length===6)h=new l,h.readPKCS5PrvKeyHex(b);else if(T.length>2&&b.substr(T[1],2)==="04")h=new u,h.readPKCS5PrvKeyHex(b);else throw"unsupported PKCS#1/5 hexadecimal key";return h}if(e==="pkcs8prv"){var h=f.getKeyFromPlainPrivatePKCS8Hex(n);return h}if(e==="pkcs8pub")return f._getKeyFromPublicPKCS8Hex(n);if(e==="x509pub")return X509.getPublicKeyFromCertHex(n);if(n.indexOf("-END CERTIFICATE-",0)!=-1||n.indexOf("-END X509 CERTIFICATE-",0)!=-1||n.indexOf("-END TRUSTED CERTIFICATE-",0)!=-1)return X509.getPublicKeyFromCertPEM(n);if(n.indexOf("-END PUBLIC KEY-")!=-1){var _=pemtohex(n,"PUBLIC KEY");return f._getKeyFromPublicPKCS8Hex(_)}if(n.indexOf("-END RSA PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")==-1){var w=c(n,"RSA PRIVATE KEY");return f.getKey(w,null,"pkcs5prv")}if(n.indexOf("-END DSA PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")==-1){var x=c(n,"DSA PRIVATE KEY"),M=o(x,0,[1],"02"),R=o(x,0,[2],"02"),I=o(x,0,[3],"02"),S=o(x,0,[4],"02"),B=o(x,0,[5],"02"),h=new l;return h.setPrivate(new BigInteger(M,16),new BigInteger(R,16),new BigInteger(I,16),new BigInteger(S,16),new BigInteger(B,16)),h}if(n.indexOf("-END EC PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")==-1){var w=c(n,"EC PRIVATE KEY");return f.getKey(w,null,"pkcs5prv")}if(n.indexOf("-END PRIVATE KEY-")!=-1)return f.getKeyFromPlainPrivatePKCS8PEM(n);if(n.indexOf("-END RSA PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")!=-1){var O=f.getDecryptedKeyHex(n,t),F=new RSAKey;return F.readPKCS5PrvKeyHex(O),F}if(n.indexOf("-END EC PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")!=-1){var x=f.getDecryptedKeyHex(n,t),h=o(x,0,[1],"04"),H=o(x,0,[2,0],"06"),k=o(x,0,[3,0],"03").substr(2),N="";if(KJUR.crypto.OID.oidhex2name[H]!==void 0)N=KJUR.crypto.OID.oidhex2name[H];else throw"undefined OID(hex) in KJUR.crypto.OID: "+H;var v=new u({curve:N});return v.setPublicKeyHex(k),v.setPrivateKeyHex(h),v.isPublic=!1,v}if(n.indexOf("-END DSA PRIVATE KEY-")!=-1&&n.indexOf("4,ENCRYPTED")!=-1){var x=f.getDecryptedKeyHex(n,t),M=o(x,0,[1],"02"),R=o(x,0,[2],"02"),I=o(x,0,[3],"02"),S=o(x,0,[4],"02"),B=o(x,0,[5],"02"),h=new l;return h.setPrivate(new BigInteger(M,16),new BigInteger(R,16),new BigInteger(I,16),new BigInteger(S,16),new BigInteger(B,16)),h}if(n.indexOf("-END ENCRYPTED PRIVATE KEY-")!=-1)return f.getKeyFromEncryptedPKCS8PEM(n,t);throw new Error("not supported argument")},(typeof KJUR.asn1>"u"||!KJUR.asn1)&&(KJUR.asn1={}),KJUR.asn1.ASN1Util={},KJUR.asn1.ASN1Util.oidHexToInt=function(n){for(var i="",t=parseInt(n.substr(0,2),16),e=Math.floor(t/40),r=t%40,i=e+"."+r,o="",s=2;s<n.length;s+=2){var u=parseInt(n.substr(s,2),16),l=("00000000"+u.toString(2)).slice(-8);if(o=o+l.substr(1,7),l.substr(0,1)=="0"){var d=new BigInteger(o,2);i=i+"."+d.toString(10),o=""}}return i};var ASN1HEX=new function(){};ASN1HEX.getLblen=function(n,t){if(n.substr(t+2,1)!="8")return 1;var e=parseInt(n.substr(t+3,1));return e==0?-1:0<e&&e<10?e+1:-2},ASN1HEX.getL=function(n,t){var e=ASN1HEX.getLblen(n,t);return e<1?"":n.substr(t+2,e*2)},ASN1HEX.getVblen=function(n,t){var e,r;return e=ASN1HEX.getL(n,t),e==""?-1:(e.substr(0,1)==="8"?r=new BigInteger(e.substr(2),16):r=new BigInteger(e,16),r.intValue())},ASN1HEX.getVidx=function(n,t){var e=ASN1HEX.getLblen(n,t);return e<0?e:t+(e+1)*2},ASN1HEX.getV=function(n,t){var e=ASN1HEX.getVidx(n,t),r=ASN1HEX.getVblen(n,t);return n.substr(e,r*2)},ASN1HEX.getTLV=function(n,t){return n.substr(t,2)+ASN1HEX.getL(n,t)+ASN1HEX.getV(n,t)},ASN1HEX.getTLVblen=function(n,t){return 2+ASN1HEX.getLblen(n,t)*2+ASN1HEX.getVblen(n,t)*2},ASN1HEX.getNextSiblingIdx=function(n,t){var e=ASN1HEX.getVidx(n,t),r=ASN1HEX.getVblen(n,t);return e+r*2},ASN1HEX.getChildIdx=function(n,t){var e=ASN1HEX,r=[],i,o,s;i=e.getVidx(n,t),o=e.getVblen(n,t)*2,n.substr(t,2)=="03"&&(i+=2,o-=2),s=0;for(var u=i;s<=o;){var l=e.getTLVblen(n,u);if(s+=l,s<=o&&r.push(u),u+=l,s>=o)break}return r},ASN1HEX.getNthChildIdx=function(n,t,e){var r=ASN1HEX.getChildIdx(n,t);return r[e]},ASN1HEX.getIdxbyList=function(n,t,e,r){var i=ASN1HEX,o,s;return e.length==0?r!==void 0&&n.substr(t,2)!==r?-1:t:(o=e.shift(),s=i.getChildIdx(n,t),o>=s.length?-1:i.getIdxbyList(n,s[o],e,r))},ASN1HEX.getIdxbyListEx=function(n,t,e,r){var i=ASN1HEX,o,s;if(e.length==0)return r!==void 0&&n.substr(t,2)!==r?-1:t;o=e.shift(),s=i.getChildIdx(n,t);for(var u=0,l=0;l<s.length;l++){var d=n.substr(s[l],2);if(typeof o=="number"&&!i.isContextTag(d)&&u==o||typeof o=="string"&&i.isContextTag(d,o))return i.getIdxbyListEx(n,s[l],e,r);i.isContextTag(d)||u++}return-1},ASN1HEX.getTLVbyList=function(n,t,e,r){var i=ASN1HEX,o=i.getIdxbyList(n,t,e,r);return o==-1||o>=n.length?null:i.getTLV(n,o)},ASN1HEX.getTLVbyListEx=function(n,t,e,r){var i=ASN1HEX,o=i.getIdxbyListEx(n,t,e,r);return o==-1?null:i.getTLV(n,o)},ASN1HEX.getVbyList=function(n,t,e,r,i){var o=ASN1HEX,s,u;return s=o.getIdxbyList(n,t,e,r),s==-1||s>=n.length?null:(u=o.getV(n,s),i===!0&&(u=u.substr(2)),u)},ASN1HEX.getVbyListEx=function(n,t,e,r,i){var o=ASN1HEX,s,u;return s=o.getIdxbyListEx(n,t,e,r),s==-1?null:(u=o.getV(n,s),n.substr(s,2)=="03"&&i!==!1&&(u=u.substr(2)),u)},ASN1HEX.getInt=function(n,t,e){e==null&&(e=-1);try{var r=n.substr(t,2);if(r!="02"&&r!="03")return e;var i=ASN1HEX.getV(n,t);return r=="02"?parseInt(i,16):bitstrtoint(i)}catch{return e}},ASN1HEX.getOID=function(n,t,e){e==null&&(e=null);try{if(n.substr(t,2)!="06")return e;var r=ASN1HEX.getV(n,t);return hextooid(r)}catch{return e}},ASN1HEX.getOIDName=function(n,t,e){e==null&&(e=null);try{var r=ASN1HEX.getOID(n,t,e);if(r==e)return e;var i=KJUR.asn1.x509.OID.oid2name(r);return i==""?r:i}catch{return e}},ASN1HEX.getString=function(n,t,e){e==null&&(e=null);try{var r=ASN1HEX.getV(n,t);return hextorstr(r)}catch{return e}},ASN1HEX.hextooidstr=function(n){var t=function(f,h){return f.length>=h?f:new Array(h-f.length+1).join("0")+f},e=[],r=n.substr(0,2),i=parseInt(r,16);e[0]=new String(Math.floor(i/40)),e[1]=new String(i%40);for(var o=n.substr(2),s=[],u=0;u<o.length/2;u++)s.push(parseInt(o.substr(u*2,2),16));for(var l=[],d="",u=0;u<s.length;u++)s[u]&128?d=d+t((s[u]&127).toString(2),7):(d=d+t((s[u]&127).toString(2),7),l.push(new String(parseInt(d,2))),d="");var c=e.join(".");return l.length>0&&(c=c+"."+l.join(".")),c},ASN1HEX.isContextTag=function(n,t){n=n.toLowerCase();var e,r;try{e=parseInt(n,16)}catch{return-1}if(t===void 0)return(e&192)==128;try{var i=t.match(/^\[[0-9]+\]$/);return i==null||(r=parseInt(t.substr(1,t.length-1),10),r>31)?!1:(e&192)==128&&(e&31)==r}catch{return!1}},ASN1HEX.isASN1HEX=function(n){var t=ASN1HEX;if(n.length%2==1)return!1;var e=t.getVblen(n,0),r=n.substr(0,2),i=t.getL(n,0),o=n.length-r.length-i.length;return o==e*2},ASN1HEX.checkStrictDER=function(n,t,e,r,i){var o=ASN1HEX;if(e===void 0){if(typeof n!="string")throw new Error("not hex string");if(n=n.toLowerCase(),!KJUR.lang.String.isHex(n))throw new Error("not hex string");e=n.length,r=n.length/2,r<128?i=1:i=Math.ceil(r.toString(16))+1}var s=o.getL(n,t);if(s.length>i*2)throw new Error("L of TLV too long: idx="+t);var u=o.getVblen(n,t);if(u>r)throw new Error("value of L too long than hex: idx="+t);var l=o.getTLV(n,t),d=l.length-2-o.getL(n,t).length;if(d!==u*2)throw new Error("V string length and L's value not the same:"+d+"/"+u*2);if(t===0&&n.length!=l.length)throw new Error("total length and TLV length unmatch:"+n.length+"!="+l.length);var c=n.substr(t,2);if(c==="02"){var f=o.getVidx(n,t);if(n.substr(f,2)=="00"&&n.charCodeAt(f+2)<56)throw new Error("not least zeros for DER INTEGER")}if(parseInt(c,16)&32){for(var h=o.getVblen(n,t),v=0,A=o.getChildIdx(n,t),m=0;m<A.length;m++){var y=o.getTLV(n,A[m]);v+=y.length,o.checkStrictDER(n,A[m],e,r,i)}if(h*2!=v)throw new Error("sum of children's TLV length and L unmatch: "+h*2+"!="+v)}},ASN1HEX.oidname=function(n){var t=KJUR.asn1;KJUR.lang.String.isHex(n)&&(n=t.ASN1Util.oidHexToInt(n));var e=t.x509.OID.oid2name(n);return e===""&&(e=n),e},(typeof KJUR.asn1>"u"||!KJUR.asn1)&&(KJUR.asn1={}),(typeof KJUR.asn1.x509>"u"||!KJUR.asn1.x509)&&(KJUR.asn1.x509={}),KJUR.asn1.x509.AlgorithmIdentifier={},KJUR.asn1.x509.AlgorithmIdentifier.PSSNAME2ASN1TLV={SHAwithRSAandMGF1:"300d06092a864886f70d01010a3000",SHA256withRSAandMGF1:"303d06092a864886f70d01010a3030a00d300b0609608648016503040201a11a301806092a864886f70d010108300b0609608648016503040201a203020120",SHA384withRSAandMGF1:"303d06092a864886f70d01010a3030a00d300b0609608648016503040202a11a301806092a864886f70d010108300b0609608648016503040202a203020130",SHA512withRSAandMGF1:"303d06092a864886f70d01010a3030a00d300b0609608648016503040203a11a301806092a864886f70d010108300b0609608648016503040203a203020140"},KJUR.asn1.x509.OID=new function(n){this.atype2oidList={CN:"2.5.4.3",L:"2.5.4.7",ST:"2.5.4.8",O:"2.5.4.10",OU:"2.5.4.11",C:"2.5.4.6",STREET:"2.5.4.9",DC:"0.9.2342.19200300.100.1.25",UID:"0.9.2342.19200300.100.1.1",SN:"2.5.4.4",T:"2.5.4.12",DN:"2.5.4.49",E:"1.2.840.113549.1.9.1",description:"2.5.4.13",businessCategory:"2.5.4.15",postalCode:"2.5.4.17",serialNumber:"2.5.4.5",uniqueIdentifier:"2.5.4.45",organizationIdentifier:"2.5.4.97",jurisdictionOfIncorporationL:"1.3.6.1.4.1.311.60.2.1.1",jurisdictionOfIncorporationSP:"1.3.6.1.4.1.311.60.2.1.2",jurisdictionOfIncorporationC:"1.3.6.1.4.1.311.60.2.1.3"},this.name2oidList={sha1:"1.3.14.3.2.26",sha256:"2.16.840.1.101.3.4.2.1",sha384:"2.16.840.1.101.3.4.2.2",sha512:"2.16.840.1.101.3.4.2.3",sha224:"2.16.840.1.101.3.4.2.4",md5:"1.2.840.113549.2.5",md2:"1.3.14.7.2.2.1",ripemd160:"1.3.36.3.2.1",MD2withRSA:"1.2.840.113549.1.1.2",MD4withRSA:"1.2.840.113549.1.1.3",MD5withRSA:"1.2.840.113549.1.1.4",SHA1withRSA:"1.2.840.113549.1.1.5","pkcs1-MGF":"1.2.840.113549.1.1.8",rsaPSS:"1.2.840.113549.1.1.10",SHA224withRSA:"1.2.840.113549.1.1.14",SHA256withRSA:"1.2.840.113549.1.1.11",SHA384withRSA:"1.2.840.113549.1.1.12",SHA512withRSA:"1.2.840.113549.1.1.13",SHA1withECDSA:"1.2.840.10045.4.1",SHA224withECDSA:"1.2.840.10045.4.3.1",SHA256withECDSA:"1.2.840.10045.4.3.2",SHA384withECDSA:"1.2.840.10045.4.3.3",SHA512withECDSA:"1.2.840.10045.4.3.4",dsa:"1.2.840.10040.4.1",SHA1withDSA:"1.2.840.10040.4.3",SHA224withDSA:"2.16.840.1.101.3.4.3.1",SHA256withDSA:"2.16.840.1.101.3.4.3.2",rsaEncryption:"1.2.840.113549.1.1.1",commonName:"2.5.4.3",countryName:"2.5.4.6",localityName:"2.5.4.7",stateOrProvinceName:"2.5.4.8",streetAddress:"2.5.4.9",organizationName:"2.5.4.10",organizationalUnitName:"2.5.4.11",domainComponent:"0.9.2342.19200300.100.1.25",userId:"0.9.2342.19200300.100.1.1",surname:"2.5.4.4",givenName:"2.5.4.42",title:"2.5.4.12",distinguishedName:"2.5.4.49",emailAddress:"1.2.840.113549.1.9.1",description:"2.5.4.13",businessCategory:"2.5.4.15",postalCode:"2.5.4.17",uniqueIdentifier:"2.5.4.45",organizationIdentifier:"2.5.4.97",jurisdictionOfIncorporationL:"1.3.6.1.4.1.311.60.2.1.1",jurisdictionOfIncorporationSP:"1.3.6.1.4.1.311.60.2.1.2",jurisdictionOfIncorporationC:"1.3.6.1.4.1.311.60.2.1.3",subjectDirectoryAttributes:"2.5.29.9",subjectKeyIdentifier:"2.5.29.14",keyUsage:"2.5.29.15",subjectAltName:"2.5.29.17",issuerAltName:"2.5.29.18",basicConstraints:"2.5.29.19",cRLNumber:"2.5.29.20",cRLReason:"2.5.29.21",nameConstraints:"2.5.29.30",cRLDistributionPoints:"2.5.29.31",certificatePolicies:"2.5.29.32",anyPolicy:"2.5.29.32.0",authorityKeyIdentifier:"2.5.29.35",policyConstraints:"2.5.29.36",extKeyUsage:"2.5.29.37",authorityInfoAccess:"1.3.6.1.5.5.7.1.1",ocsp:"1.3.6.1.5.5.7.48.1",ocspBasic:"1.3.6.1.5.5.7.48.1.1",ocspNonce:"1.3.6.1.5.5.7.48.1.2",ocspNoCheck:"1.3.6.1.5.5.7.48.1.5",caIssuers:"1.3.6.1.5.5.7.48.2",anyExtendedKeyUsage:"2.5.29.37.0",serverAuth:"1.3.6.1.5.5.7.3.1",clientAuth:"1.3.6.1.5.5.7.3.2",codeSigning:"1.3.6.1.5.5.7.3.3",emailProtection:"1.3.6.1.5.5.7.3.4",timeStamping:"1.3.6.1.5.5.7.3.8",ocspSigning:"1.3.6.1.5.5.7.3.9",dateOfBirth:"1.3.6.1.5.5.7.9.1",placeOfBirth:"1.3.6.1.5.5.7.9.2",gender:"1.3.6.1.5.5.7.9.3",countryOfCitizenship:"1.3.6.1.5.5.7.9.4",countryOfResidence:"1.3.6.1.5.5.7.9.5",ecPublicKey:"1.2.840.10045.2.1","P-256":"1.2.840.10045.3.1.7",secp256r1:"1.2.840.10045.3.1.7",secp256k1:"1.3.132.0.10",secp384r1:"1.3.132.0.34",pkcs5PBES2:"1.2.840.113549.1.5.13",pkcs5PBKDF2:"1.2.840.113549.1.5.12","des-EDE3-CBC":"1.2.840.113549.3.7",data:"1.2.840.113549.1.7.1","signed-data":"1.2.840.113549.1.7.2","enveloped-data":"1.2.840.113549.1.7.3","digested-data":"1.2.840.113549.1.7.5","encrypted-data":"1.2.840.113549.1.7.6","authenticated-data":"1.2.840.113549.1.9.16.1.2",tstinfo:"1.2.840.113549.1.9.16.1.4",signingCertificate:"1.2.840.113549.1.9.16.2.12",timeStampToken:"1.2.840.113549.1.9.16.2.14",signaturePolicyIdentifier:"1.2.840.113549.1.9.16.2.15",etsArchiveTimeStamp:"1.2.840.113549.1.9.16.2.27",signingCertificateV2:"1.2.840.113549.1.9.16.2.47",etsArchiveTimeStampV2:"1.2.840.113549.1.9.16.2.48",extensionRequest:"1.2.840.113549.1.9.14",contentType:"1.2.840.113549.1.9.3",messageDigest:"1.2.840.113549.1.9.4",signingTime:"1.2.840.113549.1.9.5",counterSignature:"1.2.840.113549.1.9.6",archiveTimeStampV3:"0.4.0.1733.2.4",pdfRevocationInfoArchival:"1.2.840.113583.1.1.8",adobeTimeStamp:"1.2.840.113583.1.1.9.1"},this.objCache={},this.name2obj=function(t){if(typeof this.objCache[t]<"u")return this.objCache[t];if(typeof this.name2oidList[t]>"u")throw"Name of ObjectIdentifier not defined: "+t;var e=this.name2oidList[t],r=new KJUR.asn1.DERObjectIdentifier({oid:e});return this.objCache[t]=r,r},this.atype2obj=function(t){if(this.objCache[t]!==void 0)return this.objCache[t];var e;if(t.match(/^\d+\.\d+\.[0-9.]+$/))e=t;else if(this.atype2oidList[t]!==void 0)e=this.atype2oidList[t];else if(this.name2oidList[t]!==void 0)e=this.name2oidList[t];else throw"AttributeType name undefined: "+t;var r=new KJUR.asn1.DERObjectIdentifier({oid:e});return this.objCache[t]=r,r}},KJUR.asn1.x509.OID.oid2name=function(n){var t=KJUR.asn1.x509.OID.name2oidList;for(var e in t)if(t[e]==n)return e;return""},KJUR.asn1.x509.OID.oid2atype=function(n){var t=KJUR.asn1.x509.OID.atype2oidList;for(var e in t)if(t[e]==n)return e;return n},KJUR.asn1.x509.OID.name2oid=function(n){if(n.match(/^[0-9.]+$/))return n;var t=KJUR.asn1.x509.OID.name2oidList;return t[n]===void 0?"":t[n]},RSAKey.getPosArrayOfChildrenFromHex=function(n){return ASN1HEX.getChildIdx(n,0)},RSAKey.getHexValueArrayOfChildrenFromHex=function(n){var t=ASN1HEX,e=t.getV,h=RSAKey.getPosArrayOfChildrenFromHex(n),r=e(n,h[0]),i=e(n,h[1]),o=e(n,h[2]),s=e(n,h[3]),u=e(n,h[4]),l=e(n,h[5]),d=e(n,h[6]),c=e(n,h[7]),f=e(n,h[8]),h=new Array;return h.push(r,i,o,s,u,l,d,c,f),h},RSAKey.prototype.readPrivateKeyFromPEMString=function(n){var t=pemtohex(n),e=RSAKey.getHexValueArrayOfChildrenFromHex(t);this.setPrivateEx(e[1],e[2],e[3],e[4],e[5],e[6],e[7],e[8])},RSAKey.prototype.readPKCS5PrvKeyHex=function(n){var t=RSAKey.getHexValueArrayOfChildrenFromHex(n);this.setPrivateEx(t[1],t[2],t[3],t[4],t[5],t[6],t[7],t[8])},RSAKey.prototype.readPKCS8PrvKeyHex=function(n){var t,e,r,i,o,s,u,l,d=ASN1HEX,c=d.getVbyListEx;if(d.isASN1HEX(n)===!1)throw new Error("not ASN.1 hex string");try{t=c(n,0,[2,0,1],"02"),e=c(n,0,[2,0,2],"02"),r=c(n,0,[2,0,3],"02"),i=c(n,0,[2,0,4],"02"),o=c(n,0,[2,0,5],"02"),s=c(n,0,[2,0,6],"02"),u=c(n,0,[2,0,7],"02"),l=c(n,0,[2,0,8],"02")}catch{throw new Error("malformed PKCS#8 plain RSA private key")}this.setPrivateEx(t,e,r,i,o,s,u,l)},RSAKey.prototype.readPKCS5PubKeyHex=function(n){var t=ASN1HEX,e=t.getV;if(t.isASN1HEX(n)===!1)throw new Error("keyHex is not ASN.1 hex string");var r=t.getChildIdx(n,0);if(r.length!==2||n.substr(r[0],2)!=="02"||n.substr(r[1],2)!=="02")throw new Error("wrong hex for PKCS#5 public key");var i=e(n,r[0]),o=e(n,r[1]);this.setPublic(i,o)},RSAKey.prototype.readPKCS8PubKeyHex=function(n){var t=ASN1HEX;if(t.isASN1HEX(n)===!1)throw new Error("not ASN.1 hex string");if(t.getTLVbyListEx(n,0,[0,0])!=="06092a864886f70d010101")throw new Error("not PKCS8 RSA public key");var e=t.getTLVbyListEx(n,0,[1,0]);this.readPKCS5PubKeyHex(e)},RSAKey.prototype.readCertPubKeyHex=function(n,t){var e,r;e=new X509,e.readCertHex(n),r=e.getPublicKeyHex(),this.readPKCS8PubKeyHex(r)};function _rsasign_getAlgNameAndHashFromHexDisgestInfo(n){for(var t in KJUR.crypto.Util.DIGESTINFOHEAD){var e=KJUR.crypto.Util.DIGESTINFOHEAD[t],r=e.length;if(n.substring(0,r)==e){var i=[t,n.substring(r)];return i}}return[]}RSAKey.prototype.verify=function(n,t){if(t=t.toLowerCase(),t.match(/^[0-9a-f]+$/)==null)return!1;var e=parseBigInt(t,16),r=this.n.bitLength();if(e.bitLength()>r)return!1;var i=this.doPublic(e),o=i.toString(16);if(o.length+3!=r/4)return!1;var s=o.replace(/^1f+00/,""),u=_rsasign_getAlgNameAndHashFromHexDisgestInfo(s);if(u.length==0)return!1;var l=u[0],d=u[1],c=function(h){return KJUR.crypto.Util.hashString(h,l)},f=c(n);return d==f},RSAKey.prototype.verifyWithMessageHash=function(n,t){if(t.length!=Math.ceil(this.n.bitLength()/4))return!1;var e=parseBigInt(t,16);if(e.bitLength()>this.n.bitLength())return 0;var r=this.doPublic(e),i=r.toString(16).replace(/^1f+00/,""),o=_rsasign_getAlgNameAndHashFromHexDisgestInfo(i);if(o.length==0)return!1;o[0];var s=o[1];return s==n},RSAKey.prototype.verifyPSS=function(n,t,e,r){var i=function(s){return KJUR.crypto.Util.hashHex(s,e)},o=i(rstrtohex(n));return r===void 0&&(r=-1),this.verifyWithMessageHashPSS(o,t,e,r)},RSAKey.prototype.verifyWithMessageHashPSS=function(n,t,e,r){if(t.length!=Math.ceil(this.n.bitLength()/4))return!1;var i=new BigInteger(t,16),o=function(g){return KJUR.crypto.Util.hashHex(g,e)},s=hextorstr(n),u=s.length,l=this.n.bitLength()-1,d=Math.ceil(l/8),c;if(r===-1||r===void 0)r=u;else if(r===-2)r=d-u-2;else if(r<-2)throw new Error("invalid salt length");if(d<u+r+2)throw new Error("data too long");var f=this.doPublic(i).toByteArray();for(c=0;c<f.length;c+=1)f[c]&=255;for(;f.length<d;)f.unshift(0);if(f[d-1]!==188)throw new Error("encoded message does not end in 0xbc");f=String.fromCharCode.apply(String,f);var h=f.substr(0,d-u-1),v=f.substr(h.length,u),A=65280>>8*d-l&255;if(h.charCodeAt(0)&A)throw new Error("bits beyond keysize not zero");var m=pss_mgf1_str(v,h.length,o),y=[];for(c=0;c<h.length;c+=1)y[c]=h.charCodeAt(c)^m.charCodeAt(c);y[0]&=~A;var p=d-u-r-2;for(c=0;c<p;c+=1)if(y[c]!==0)throw new Error("leftmost octets not zero");if(y[p]!==1)throw new Error("0x01 marker not found");return v===hextorstr(o(rstrtohex("\0\0\0\0\0\0\0\0"+s+String.fromCharCode.apply(String,y.slice(-r)))))},RSAKey.SALT_LEN_HLEN=-1,RSAKey.SALT_LEN_MAX=-2,RSAKey.SALT_LEN_RECOVER=-2;function X509(n){var t=ASN1HEX,e=t.getChildIdx,r=t.getV,i=t.getTLV,o=t.getVbyList,s=t.getVbyListEx,u=t.getTLVbyList,l=t.getTLVbyListEx,d=t.getIdxbyList,c=t.getIdxbyListEx,f=t.getVidx,h=t.getInt,v=t.oidname,A=t.hextooidstr,m=pemtohex,y;try{y=KJUR.asn1.x509.AlgorithmIdentifier.PSSNAME2ASN1TLV}catch{}this.HEX2STAG={"0c":"utf8",13:"prn",16:"ia5","1a":"vis","1e":"bmp"},this.hex=null,this.version=0,this.foffset=0,this.aExtInfo=null,this.getVersion=function(){if(this.hex===null||this.version!==0)return this.version;var p=u(this.hex,0,[0,0]);if(p.substr(0,2)=="a0"){var g=u(p,0,[0]),b=h(g,0);if(b<0||2<b)throw new Error("malformed version field");return this.version=b+1,this.version}else return this.version=1,this.foffset=-1,1},this.getSerialNumberHex=function(){return s(this.hex,0,[0,0],"02")},this.getSignatureAlgorithmField=function(){var p=l(this.hex,0,[0,1]);return this.getAlgorithmIdentifierName(p)},this.getAlgorithmIdentifierName=function(p){for(var g in y)if(p===y[g])return g;return v(s(p,0,[0],"06"))},this.getIssuer=function(){return this.getX500Name(this.getIssuerHex())},this.getIssuerHex=function(){return u(this.hex,0,[0,3+this.foffset],"30")},this.getIssuerString=function(){var p=this.getIssuer();return p.str},this.getSubject=function(){return this.getX500Name(this.getSubjectHex())},this.getSubjectHex=function(){return u(this.hex,0,[0,5+this.foffset],"30")},this.getSubjectString=function(){var p=this.getSubject();return p.str},this.getNotBefore=function(){var p=o(this.hex,0,[0,4+this.foffset,0]);return p=p.replace(/(..)/g,"%$1"),p=decodeURIComponent(p),p},this.getNotAfter=function(){var p=o(this.hex,0,[0,4+this.foffset,1]);return p=p.replace(/(..)/g,"%$1"),p=decodeURIComponent(p),p},this.getPublicKeyHex=function(){return t.getTLVbyList(this.hex,0,[0,6+this.foffset],"30")},this.getPublicKeyIdx=function(){return d(this.hex,0,[0,6+this.foffset],"30")},this.getPublicKeyContentIdx=function(){var p=this.getPublicKeyIdx();return d(this.hex,p,[1,0],"30")},this.getPublicKey=function(){return KEYUTIL.getKey(this.getPublicKeyHex(),null,"pkcs8pub")},this.getSignatureAlgorithmName=function(){var p=u(this.hex,0,[1],"30");return this.getAlgorithmIdentifierName(p)},this.getSignatureValueHex=function(){return o(this.hex,0,[2],"03",!0)},this.verifySignature=function(p){var g=this.getSignatureAlgorithmField(),b=this.getSignatureValueHex(),T=u(this.hex,0,[0],"30"),_=new KJUR.crypto.Signature({alg:g});return _.init(p),_.updateHex(T),_.verify(b)},this.parseExt=function(p){var g,b,T;if(p===void 0){if(T=this.hex,this.version!==3)return-1;g=d(T,0,[0,7,0],"30"),b=e(T,g)}else{T=pemtohex(p);var _=d(T,0,[0,3,0,0],"06");if(r(T,_)!="2a864886f70d01090e"){this.aExtInfo=new Array;return}g=d(T,0,[0,3,0,1,0],"30"),b=e(T,g),this.hex=T}this.aExtInfo=new Array;for(var w=0;w<b.length;w++){var x={};x.critical=!1;var M=e(T,b[w]),R=0;M.length===3&&(x.critical=!0,R=1),x.oid=t.hextooidstr(o(T,b[w],[0],"06"));var I=d(T,b[w],[1+R]);x.vidx=f(T,I),this.aExtInfo.push(x)}},this.getExtInfo=function(p){var g=this.aExtInfo,b=p;if(p.match(/^[0-9.]+$/)||(b=KJUR.asn1.x509.OID.name2oid(p)),b!==""){for(var T=0;T<g.length;T++)if(g[T].oid===b)return g[T]}},this.getExtBasicConstraints=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("basicConstraints");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"basicConstraints"};if(g&&(T.critical=!0),p==="3000")return T;if(p==="30030101ff")return T.cA=!0,T;if(p.substr(0,12)==="30060101ff02"){var _=r(p,10),w=parseInt(_,16);return T.cA=!0,T.pathLen=w,T}throw new Error("hExtV parse error: "+p)},this.getExtKeyUsage=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("keyUsage");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"keyUsage"};return g&&(T.critical=!0),T.names=this.getExtKeyUsageString(p).split(","),T},this.getExtKeyUsageBin=function(p){if(p===void 0){var g=this.getExtInfo("keyUsage");if(g===void 0)return"";p=i(this.hex,g.vidx)}if(p.length!=8&&p.length!=10)throw new Error("malformed key usage value: "+p);var b="000000000000000"+parseInt(p.substr(6),16).toString(2);return p.length==8&&(b=b.slice(-8)),p.length==10&&(b=b.slice(-16)),b=b.replace(/0+$/,""),b==""&&(b="0"),b},this.getExtKeyUsageString=function(p){for(var g=this.getExtKeyUsageBin(p),b=new Array,T=0;T<g.length;T++)g.substr(T,1)=="1"&&b.push(X509.KEYUSAGE_NAME[T]);return b.join(",")},this.getExtSubjectKeyIdentifier=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("subjectKeyIdentifier");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"subjectKeyIdentifier"};g&&(T.critical=!0);var _=r(p,0);return T.kid={hex:_},T},this.getExtAuthorityKeyIdentifier=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("authorityKeyIdentifier");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"authorityKeyIdentifier"};g&&(T.critical=!0);for(var _=e(p,0),w=0;w<_.length;w++){var x=p.substr(_[w],2);if(x==="80"&&(T.kid={hex:r(p,_[w])}),x==="a1"){var M=i(p,_[w]),R=this.getGeneralNames(M);T.issuer=R[0].dn}x==="82"&&(T.sn={hex:r(p,_[w])})}return T},this.getExtExtKeyUsage=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("extKeyUsage");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"extKeyUsage",array:[]};g&&(T.critical=!0);for(var _=e(p,0),w=0;w<_.length;w++)T.array.push(v(r(p,_[w])));return T},this.getExtExtKeyUsageName=function(){var p=this.getExtInfo("extKeyUsage");if(p===void 0)return p;var g=new Array,b=i(this.hex,p.vidx);if(b==="")return g;for(var T=e(b,0),_=0;_<T.length;_++)g.push(v(r(b,T[_])));return g},this.getExtSubjectAltName=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("subjectAltName");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"subjectAltName",array:[]};return g&&(T.critical=!0),T.array=this.getGeneralNames(p),T},this.getExtIssuerAltName=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("issuerAltName");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"issuerAltName",array:[]};return g&&(T.critical=!0),T.array=this.getGeneralNames(p),T},this.getGeneralNames=function(p){for(var g=e(p,0),b=[],T=0;T<g.length;T++){var _=this.getGeneralName(i(p,g[T]));_!==void 0&&b.push(_)}return b},this.getGeneralName=function(p){var g=p.substr(0,2),b=r(p,0),T=hextorstr(b);if(g=="81")return{rfc822:T};if(g=="82")return{dns:T};if(g=="86")return{uri:T};if(g=="87")return{ip:hextoip(b)};if(g=="a4")return{dn:this.getX500Name(b)}},this.getExtSubjectAltName2=function(){var p,g,b,T=this.getExtInfo("subjectAltName");if(T===void 0)return T;for(var _=new Array,w=i(this.hex,T.vidx),x=e(w,0),M=0;M<x.length;M++)b=w.substr(x[M],2),p=r(w,x[M]),b==="81"&&(g=hextoutf8(p),_.push(["MAIL",g])),b==="82"&&(g=hextoutf8(p),_.push(["DNS",g])),b==="84"&&(g=X509.hex2dn(p,0),_.push(["DN",g])),b==="86"&&(g=hextoutf8(p),_.push(["URI",g])),b==="87"&&(g=hextoip(p),_.push(["IP",g]));return _},this.getExtCRLDistributionPoints=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("cRLDistributionPoints");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"cRLDistributionPoints",array:[]};g&&(T.critical=!0);for(var _=e(p,0),w=0;w<_.length;w++){var x=i(p,_[w]);T.array.push(this.getDistributionPoint(x))}return T},this.getDistributionPoint=function(p){for(var g={},b=e(p,0),T=0;T<b.length;T++){var _=p.substr(b[T],2),w=i(p,b[T]);_=="a0"&&(g.dpname=this.getDistributionPointName(w))}return g},this.getDistributionPointName=function(p){for(var g={},b=e(p,0),T=0;T<b.length;T++){var _=p.substr(b[T],2),w=i(p,b[T]);_=="a0"&&(g.full=this.getGeneralNames(w))}return g},this.getExtCRLDistributionPointsURI=function(){var p=this.getExtInfo("cRLDistributionPoints");if(p===void 0)return p;for(var g=new Array,b=e(this.hex,p.vidx),T=0;T<b.length;T++)try{var _=o(this.hex,b[T],[0,0,0],"86"),w=hextoutf8(_);g.push(w)}catch{}return g},this.getExtAIAInfo=function(){var p=this.getExtInfo("authorityInfoAccess");if(p===void 0)return p;for(var g={ocsp:[],caissuer:[]},b=e(this.hex,p.vidx),T=0;T<b.length;T++){var _=o(this.hex,b[T],[0],"06"),w=o(this.hex,b[T],[1],"86");_==="2b06010505073001"&&g.ocsp.push(hextoutf8(w)),_==="2b06010505073002"&&g.caissuer.push(hextoutf8(w))}return g},this.getExtAuthorityInfoAccess=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("authorityInfoAccess");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"authorityInfoAccess",array:[]};g&&(T.critical=!0);for(var _=e(p,0),w=0;w<_.length;w++){var x=s(p,_[w],[0],"06"),M=o(p,_[w],[1],"86"),R=hextoutf8(M);if(x=="2b06010505073001")T.array.push({ocsp:R});else if(x=="2b06010505073002")T.array.push({caissuer:R});else throw new Error("unknown method: "+x)}return T},this.getExtCertificatePolicies=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("certificatePolicies");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"certificatePolicies",array:[]};g&&(T.critical=!0);for(var _=e(p,0),w=0;w<_.length;w++){var x=i(p,_[w]),M=this.getPolicyInformation(x);T.array.push(M)}return T},this.getPolicyInformation=function(p){var g={},b=o(p,0,[0],"06");g.policyoid=v(b);var T=c(p,0,[1],"30");if(T!=-1){g.array=[];for(var _=e(p,T),w=0;w<_.length;w++){var x=i(p,_[w]),M=this.getPolicyQualifierInfo(x);g.array.push(M)}}return g},this.getPolicyQualifierInfo=function(p){var g={},b=o(p,0,[0],"06");if(b==="2b06010505070201"){var T=s(p,0,[1],"16");g.cps=hextorstr(T)}else if(b==="2b06010505070202"){var _=u(p,0,[1],"30");g.unotice=this.getUserNotice(_)}return g},this.getUserNotice=function(p){for(var g={},b=e(p,0),T=0;T<b.length;T++){var _=i(p,b[T]);_.substr(0,2)!="30"&&(g.exptext=this.getDisplayText(_))}return g},this.getDisplayText=function(p){var g={"0c":"utf8",16:"ia5","1a":"vis","1e":"bmp"},b={};return b.type=g[p.substr(0,2)],b.str=hextorstr(r(p,0)),b},this.getExtCRLNumber=function(p,g){var b={extname:"cRLNumber"};if(g&&(b.critical=!0),p.substr(0,2)=="02")return b.num={hex:r(p,0)},b;throw new Error("hExtV parse error: "+p)},this.getExtCRLReason=function(p,g){var b={extname:"cRLReason"};if(g&&(b.critical=!0),p.substr(0,2)=="0a")return b.code=parseInt(r(p,0),16),b;throw new Error("hExtV parse error: "+p)},this.getExtOcspNonce=function(p,g){var b={extname:"ocspNonce"};g&&(b.critical=!0);var T=r(p,0);return b.hex=T,b},this.getExtOcspNoCheck=function(p,g){var b={extname:"ocspNoCheck"};return g&&(b.critical=!0),b},this.getExtAdobeTimeStamp=function(p,g){if(p===void 0&&g===void 0){var b=this.getExtInfo("adobeTimeStamp");if(b===void 0)return;p=i(this.hex,b.vidx),g=b.critical}var T={extname:"adobeTimeStamp"};g&&(T.critical=!0);var _=e(p,0);if(_.length>1){var w=i(p,_[1]),x=this.getGeneralName(w);x.uri!=null&&(T.uri=x.uri)}if(_.length>2){var M=i(p,_[2]);M=="0101ff"&&(T.reqauth=!0),M=="010100"&&(T.reqauth=!1)}return T},this.getX500NameRule=function(p){for(var g=null,b=[],T=0;T<p.length;T++)for(var _=p[T],w=0;w<_.length;w++)b.push(_[w]);for(var T=0;T<b.length;T++){var x=b[T],M=x.ds,R=x.value,I=x.type;if(M!="prn"&&M!="utf8"&&M!="ia5")return"mixed";if(M=="ia5"){if(I!="CN")return"mixed";if(KJUR.lang.String.isMail(R))continue;return"mixed"}if(I=="C"){if(M=="prn")continue;return"mixed"}if(g==null)g=M;else if(g!==M)return"mixed"}return g??"prn"},this.getX500Name=function(p){var g=this.getX500NameArray(p),b=this.dnarraytostr(g);return{array:g,str:b}},this.getX500NameArray=function(p){for(var g=[],b=e(p,0),T=0;T<b.length;T++)g.push(this.getRDN(i(p,b[T])));return g},this.getRDN=function(p){for(var g=[],b=e(p,0),T=0;T<b.length;T++)g.push(this.getAttrTypeAndValue(i(p,b[T])));return g},this.getAttrTypeAndValue=function(p){var g={type:null,value:null,ds:null},b=e(p,0),T=o(p,b[0],[],"06"),_=o(p,b[1],[]),w=KJUR.asn1.ASN1Util.oidHexToInt(T);return g.type=KJUR.asn1.x509.OID.oid2atype(w),g.ds=this.HEX2STAG[p.substr(b[1],2)],g.ds!="bmp"?g.value=hextoutf8(_):g.value=ucs2hextoutf8(_),g},this.readCertPEM=function(p){this.readCertHex(m(p))},this.readCertHex=function(p){this.hex=p,this.getVersion();try{d(this.hex,0,[0,7],"a3"),this.parseExt()}catch{}},this.getParam=function(){var p={};return p.version=this.getVersion(),p.serial={hex:this.getSerialNumberHex()},p.sigalg=this.getSignatureAlgorithmField(),p.issuer=this.getIssuer(),p.notbefore=this.getNotBefore(),p.notafter=this.getNotAfter(),p.subject=this.getSubject(),p.sbjpubkey=hextopem(this.getPublicKeyHex(),"PUBLIC KEY"),this.aExtInfo.length>0&&(p.ext=this.getExtParamArray()),p.sighex=this.getSignatureValueHex(),p},this.getExtParamArray=function(p){if(p==null){var g=c(this.hex,0,[0,"[3]"]);g!=-1&&(p=l(this.hex,0,[0,"[3]",0],"30"))}for(var b=[],T=e(p,0),_=0;_<T.length;_++){var w=i(p,T[_]),x=this.getExtParam(w);x!=null&&b.push(x)}return b},this.getExtParam=function(p){var g=e(p,0),b=g.length;if(b!=2&&b!=3)throw new Error("wrong number elements in Extension: "+b+" "+p);var T=A(o(p,0,[0],"06")),_=!1;b==3&&u(p,0,[1])=="0101ff"&&(_=!0);var w=u(p,0,[b-1,0]),x=void 0;if(T=="2.5.29.14"?x=this.getExtSubjectKeyIdentifier(w,_):T=="2.5.29.15"?x=this.getExtKeyUsage(w,_):T=="2.5.29.17"?x=this.getExtSubjectAltName(w,_):T=="2.5.29.18"?x=this.getExtIssuerAltName(w,_):T=="2.5.29.19"?x=this.getExtBasicConstraints(w,_):T=="2.5.29.31"?x=this.getExtCRLDistributionPoints(w,_):T=="2.5.29.32"?x=this.getExtCertificatePolicies(w,_):T=="2.5.29.35"?x=this.getExtAuthorityKeyIdentifier(w,_):T=="2.5.29.37"?x=this.getExtExtKeyUsage(w,_):T=="1.3.6.1.5.5.7.1.1"?x=this.getExtAuthorityInfoAccess(w,_):T=="2.5.29.20"?x=this.getExtCRLNumber(w,_):T=="2.5.29.21"?x=this.getExtCRLReason(w,_):T=="1.3.6.1.5.5.7.48.1.2"?x=this.getExtOcspNonce(w,_):T=="1.3.6.1.5.5.7.48.1.5"?x=this.getExtOcspNoCheck(w,_):T=="1.2.840.113583.1.1.9.1"&&(x=this.getExtAdobeTimeStamp(w,_)),x!=null)return x;var M={extname:T,extn:w};return _&&(M.critical=!0),M},this.findExt=function(p,g){for(var b=0;b<p.length;b++)if(p[b].extname==g)return p[b];return null},this.dnarraytostr=function(p){function g(T){return T.map(function(_){return b(_).replace(/\+/,"\\+")}).join("+")}function b(T){return T.type+"="+T.value}return"/"+p.map(function(T){return g(T).replace(/\//,"\\/")}).join("/")},this.getInfo=function(){var p=function(q){var V=JSON.stringify(q.array).replace(/[\[\]\{\}\"]/g,"");return V},g=function(q){for(var V="",D=q.array,K=0;K<D.length;K++){var z=D[K];if(V+=" policy oid: "+z.policyoid+`
|
|
363
363
|
`,z.array!==void 0)for(var G=0;G<z.array.length;G++){var W=z.array[G];W.cps!==void 0&&(V+=" cps: "+W.cps+`
|
|
364
364
|
`)}}return V},b=function(q){for(var V="",D=q.array,K=0;K<D.length;K++){var z=D[K];try{z.dpname.full[0].uri!==void 0&&(V+=" "+z.dpname.full[0].uri+`
|
|
365
365
|
`)}catch{}try{z.dname.full[0].dn.hex!==void 0&&(V+=" "+X509.hex2dn(z.dpname.full[0].dn.hex)+`
|
|
@@ -382,13 +382,13 @@
|
|
|
382
382
|
`:(_+=" cA=true",B.pathLen!==void 0&&(_+=", pathLen="+B.pathLen),_+=`
|
|
383
383
|
`)}else if(I==="keyUsage")_+=" "+this.getExtKeyUsageString()+`
|
|
384
384
|
`;else if(I==="subjectKeyIdentifier")_+=" "+this.getExtSubjectKeyIdentifier().kid.hex+`
|
|
385
|
-
`;else if(I==="authorityKeyIdentifier"){var
|
|
386
|
-
`)}else if(I==="extKeyUsage"){var
|
|
385
|
+
`;else if(I==="authorityKeyIdentifier"){var O=this.getExtAuthorityKeyIdentifier();O.kid!==void 0&&(_+=" kid="+O.kid.hex+`
|
|
386
|
+
`)}else if(I==="extKeyUsage"){var F=this.getExtExtKeyUsage().array;_+=" "+F.join(", ")+`
|
|
387
387
|
`}else if(I==="subjectAltName"){var H=p(this.getExtSubjectAltName());_+=" "+H+`
|
|
388
388
|
`}else if(I==="cRLDistributionPoints"){var k=this.getExtCRLDistributionPoints();_+=b(k)}else if(I==="authorityInfoAccess"){var N=this.getExtAuthorityInfoAccess();_+=T(N)}else I==="certificatePolicies"&&(_+=g(this.getExtCertificatePolicies()))}}return _+="signature algorithm: "+this.getSignatureAlgorithmName()+`
|
|
389
389
|
`,_+="signature: "+this.getSignatureValueHex().substr(0,16)+`...
|
|
390
390
|
`,_},typeof n=="string"&&(n.indexOf("-----BEGIN")!=-1?this.readCertPEM(n):KJUR.lang.String.isHex(n)&&this.readCertHex(n))}X509.hex2dn=function(n,t){t===void 0&&(t=0);var e=new X509;ASN1HEX.getTLV(n,t);var r=e.getX500Name(n);return r.str},X509.hex2rdn=function(n,t){if(t===void 0&&(t=0),n.substr(t,2)!=="31")throw new Error("malformed RDN");for(var e=new Array,r=ASN1HEX.getChildIdx(n,t),i=0;i<r.length;i++)e.push(X509.hex2attrTypeValue(n,r[i]));return e=e.map(function(o){return o.replace("+","\\+")}),e.join("+")},X509.hex2attrTypeValue=function(n,t){var e=ASN1HEX,r=e.getV;if(t===void 0&&(t=0),n.substr(t,2)!=="30")throw new Error("malformed attribute type and value");var i=e.getChildIdx(n,t);i.length!==2||n.substr(i[0],2);var o=r(n,i[0]),s=KJUR.asn1.ASN1Util.oidHexToInt(o),u=KJUR.asn1.x509.OID.oid2atype(s),l=r(n,i[1]),d=hextorstr(l);return u+"="+d},X509.getPublicKeyFromCertHex=function(n){var t=new X509;return t.readCertHex(n),t.getPublicKey()},X509.getPublicKeyFromCertPEM=function(n){var t=new X509;return t.readCertPEM(n),t.getPublicKey()},X509.getPublicKeyInfoPropOfCertPEM=function(n){var t=ASN1HEX,e=t.getVbyList,r={},i,o;return r.algparam=null,i=new X509,i.readCertPEM(n),o=i.getPublicKeyHex(),r.keyhex=e(o,0,[1],"03").substr(2),r.algoid=e(o,0,[0,0],"06"),r.algoid==="2a8648ce3d0201"&&(r.algparam=e(o,0,[0,1],"06")),r},X509.KEYUSAGE_NAME=["digitalSignature","nonRepudiation","keyEncipherment","dataEncipherment","keyAgreement","keyCertSign","cRLSign","encipherOnly","decipherOnly"];function sha256(n){return CryptoJS.SHA256(n).toString()}var certificates=[function(){var n=new X509;return n.readCertPEM(function(){var t=113,e=126,r=0,i="";return arguments[r].split(i).map(function(o){return o.charCodeAt(r)>e?o:String.fromCharCode((o.charCodeAt(r)+t)%e)}).join(i)}(":::::ORTV[-PR_aVSVPNaR:::::ZVVS@ PPNErtNVONtVWNZR}@]nU\0ZaZN=TP`\0T`Vo@Q^ROPbNZVTSZ^P^fQc^^TRWQawR^ZNATN>bRPNU^zc}nzyg R^ZNATN>bROU^zc}nzyg R]ZN=TN>bRPtTn?bf?FZ_NQtfQc^^YQNq`gdSp?cyZ^P^fQc^^QQNWQ^aRvZPNTP`\0T`Vo@Q^RWN_fapzFqSFwfbOndSnzyuYz[oaNrS=\x07\\QN>Z N\\Q^B[QqnS=\b\\QN>Zwp\\Q^B[QqnZVTSZ^P^fQc^^TRWQawR^ZNATN>bRPNU^zc}nzyg R^ZNATN>bROU^zc}nzyg R]ZN=TN>bRPtTn?bf?FZ_NQtfQc^^YQNq`gdSp?cyZ^P^fQc^^QQNWQ^aRvZPNTP`\0T`Vo@Q^RWN_fapzFqSFwfbOndSnzyuYz[oaPPNvVQ^fWX|gVup[N^ROO^NQttV]NQPPNt|PttVONZU|C\b\\@@e^Xv{[vTtd8`nyO@\x07ebN[bqx=ng? S^w@|XAz|qUTwfzn]Bu<qs_ae\\y<}u`eRAoE`_\\s\0r|b{rp_o<oC@o=x\bw_cUUZPApQevD\\FxFo\x07FgE=<sq[p<coqyn>TEpP@aSC_YDU8\0|8TB?c>r\\=rp`pcwP}c\0PP_\\RS\\EPVSy8x`\0?R|NP P>}A^VP}Ex\bU\x07Za=syDw}>Ya\x078wPp[pRnn\brU^dE8U?a\bcW|<FEbbupn^`ZNr sof[wA}e{\\z}w[YDQ|dt=wC Nv\x07bR\x07Z@@U|ZAYpFsabCBB\\`wrqxsYW8uFyWdaWezeUeA_8VoVupvY[TD[OYdpO\bC[wX\\O]=[QRpV\0d`\x07N\0RXt^Z}vEpdC=\bY?\x07=V}?^W\bad|qN@Ww>@PycaqANE]asPcE^OB_VA?>wzeftac Z guf\bF]\x07DCP?znNYf uaYu[`\x07=b|v]Bp=RAS``\\PRDW]_`UXdUg=SuqwVFDeB D8{B>\\sPY\x07bEU FQXz\0@\x07`zsqgfD\0[WY\bPeZc} \0bx?Rfed\x07}BUe\x07|Uo\0y?\bsSXZOSBCgbFqf\0Bs?b?d<VE\\Zzns\\d@?dPvf\\{}_\0Sd[<q_YB\x07Y`Ffg=sY>{t<fu]x\x07rFNtZONNTwbQO\\ZO=TN>bqQt^dOOaAFXw= PCVxsv?{`a\bvS8YQ[aNsOt[cU`ZRTQNdtOaAFXw= PCVxsv?{`a\bvS8YQ[aNZOt[cU_ZROaNQN^U<ZN=TP`\0T`Vo@Q^ROPbNNAVPN^P\0{y\0Bs\\8\0R[z]w??qZP?NpgdenSuvv?>|f_?UpYPcQ\\gCb8zxtSvsOQNg>[\\\0\bx\b_o@8\0g`Z<PyUE`8yu}\\g{@`s`zUgErRtve{YdCvoO@>WFDtABNp\0feUWszpQaEYNAc]^xB[@]BDAN8\b}XA=E\x07nO}Pud8TA ?yPrVv{\\>E]o`BO^RE^X[W[rEU?x\bf>V OUwY=>X[\\E`tW[8}VwpF\x07BQcnrPF}yUtd8<Doe_\b[oOVU\x07ep@pYY\0cegY{r ?\bAbq?ff8}UaXoN_D]_X_8yozYFT`N{`\\{zvu?\bDWT}=_<\x07StX Nx\x07\0\b \0aT=c@ucnWfR[vf>RFxAFV}{N`dN^\\<eawBPxx}quT=|{T_R@Fp^Y<ZevRsWaZ]V CVrRVtAAc[ Qp|d|tqoQ=T|XX =u\\N8XNCx\\aU>wz X<e@Vc?dy\\|^FEq|=p`pBdF@bs^d<]vp\\^TZ P\bZ\b\\YNNSZ_\\w^|TsD8db _ Y\\o^Cw>Z\0x\\^aN]wWf\bA} C^d_{\x07ZC@\by]gY@E BFY?OsaqbDcVgQbZeFc ovtucxnq|<TnuyXRveYFOegCpAs{YTe|>bE<OXsSqCBWD_SVepfvCCUg]z ZvQ[\0s|U>pFz\b=OwT``fNJJ:::::R[Q-PR_aVSVPNaR:::::")),n}()];function getCertificateBySubjectHex(n,t){for(var e=0,r=t;e<r.length;e++){var i=r[e];if(i.getSubjectHex()===n)return i}}function verifyCertificate_(n,t){var e=n.getIssuerHex();if(e===n.getSubjectHex())return n.verifySignature(n.getPublicKey());var r=getCertificateBySubjectHex(e,t);return!r||n.verifySignature(r.getPublicKey())===!1?!1:verifyCertificate_(r,t)}function verifyCertificate(n){var t=n.getIssuerHex();return t===n.getSubjectHex()?!1:verifyCertificate_(n,certificates)}function addCertificate(n){var t=new X509;typeof n=="string"?t.readCertPEM(n):t.readCertHex(n.hex);var e=verifyCertificate(t);return certificates.push(t),e}function verifyMessage(n,t,e){var r=new X509;if(typeof e=="string"?r.readCertPEM(e):r.readCertHex(e.hex),verifyCertificate(r)===!1)return!1;var i=new RSAKey;return i.readCertPubKeyHex(r.hex,6),!!i.verify(n,b64tohex(t))}addCertificate(function(){var t=113,e=126,r=0,i="";return arguments[r].split(i).map(function(o){return o.charCodeAt(r)>e?o:String.fromCharCode((o.charCodeAt(r)+t)%e)}).join(i)}(":::::ORTV[-PR_aVSVPNaR:::::ZVVTU PPONrtNVONtVWNW=_SVw VE=ZN=TP`\0T`Vo@Q^ROPbNZVTSZ^P^fQc^^TRWQawR^ZNATN>bRPNU^zc}nzyg R^ZNATN>bROU^zc}nzyg R]ZN=TN>bRPtTn?bf?FZ_NQtfQc^^YQNq`gdSp?cyZ^P^fQc^^QQNWQ^aRvZPNTP`\0T`Vo@Q^RWN_fapzFqSFwfbOndSnzyuYz[oaNrS=\bZQNAZaN\\aZ [QSnS=\b[aNBZQZ\\aZ [QSnZVTaZ^P^fQc^^TRWQawR^ZNATN>bRPNU^zc}nzyg R^ZNATN>bROU^zc}nzyg RbZOVTN>bRPtYoTyuoz}}f`Bwo?=\x07RQN\\Ot[cONZO>Wyfd\x07 gdb\x07RaN]Ot[cONZZPRuupz_@feWyZ`bVfWX|gVup[N^xOSugnec|fdy\x07ndB{^T\x07}fdB\0ndRf?FZVVPVwN[Otx\0uxvTF=ON^RSNN\\PNtENZVVPPtXPNtRN?=?]q[VD|{\\oyo`oOu}F SA\x07e`tn[t u\b8^a]qx\bE_^\x07ZN?[QC\0yuOpybY8r\\RPAS=8rUq\0E8>xean^e\bf]Y`XO}{C[Ur^?\0x[SRXvVQ\\CFr}QnAPRQ\x07FO=Yw\0_TePCOFV@|\x07N>ROXcDrT<>bW<ssO?NOT{^s]uU\0gS\bBffsfE\0AfDyQEZR`]XBo|Qw}yYdwwTvOFcBndUz^\\{] b=^yQYSTQ`]\0?tR{WRUun\\\0bVe_E|VWWV|r Ao\0 F`fdzCnRtq\br \b8eBp=Z\\TRaadc}@Eub`\x07quuNqAdF\0aUay{}x>tgVz` _YBFwu_q?egt8v[o\x008 wTQcrA <z{DZoEE^rZTrpaZQzqpBY]^zt8[bQv}yEWw XDYQB\0QB\bx_^X]|uEDtPf[n[r_bpB[bE}?ung|bnU|NYOoedY_tvXySZfYP\x07\x07dWV]OE^\bOFwA}<uXoO}_NDz8aon\x07zWOfcv@?>snfqu@FeEx^\\\bVfuO`\\\0tSg]zDU}QrAT| OZV|OvpVD<sN@z`<_cSrNCW>?=Au?g_8v{|}}WF>Sr>QBxO d_D}eBb?Uq^b [y}x]}{?P|BQtecTB[pQBW>|p|nfv\0zU\x07xOO}WqwE=<PURZy@X8r\\]u=<pPNRNNn\\OtaO<ZOETPdPT`NTT8RVOQ^^`SuO`gdSp?cyVRg\bo?B=VR[OZO=TN>bqQt^dOO`Fy\x07WadZcAD peXybcW@}Qf\\QNsOt[cU`ZRTQNdtOaAFXw= PCVxsv?{`a\bvS8YQ[aN]Ot[cU_ZONsEROaNQN^U<ZNTN>bqQ^RNVOOwN[Otx\0uxvTF=ON^SNN\\PNtRNrx a[}tP_g8FbD\0^\0qt<f88ufuN]^}]gp\bqYudF88Fas_Ef` ?^x>X}esa{>\\r?eE]CC_cZ[vQs >gX[szONg=^pn=<e]nbSz\bZvac\b[w^nA_`vP|@8w[}nQobe=??oRYf{vpRxcC}yCd>8[NDx{Ne\\t8oou=guC\x07>>g\x07vb}ACd ``Ntq\0yC[Q{|ynpNQqSqzxF<_PFDw<]Bnnu>F<XgU_Zf\\\\A=gu\\codOwQ]oQ<f>gv_pwozwC}xX>C`c]suEdfW?cbeo\b`BbyR@eFTUwSud=t]sS\\onc XSq {\0\x07DvAVBbnTqEE[QzDyqF`bF}R=Q?VeDo<Vzb\0w}D}NZ\0t}^?OyFP\bVaVNrTNYqe?[NRYTSQby@yzWvT`wQo}y]c_WgxBYCy RNRg@\x07NZCaaq8?` ^`?ryD =obzw?E]Ou\x07]n@>bVzqAQT?@_zo@}CxWVTUsAYdNd?{APQr8{P]]AZ>aR\0[D<z?Tr@`u@X|YDwd_<p<>zWE>]\0=X`\b@uucp|^_Qb@uZouTX^o\0\\{PCq{ug\x078^f[YQAWad8FNqxFQE?ZOo }RnO\bsQc xyccn=nxvs>bDBf\b\bW\\TuTnvAO^U\0QXC>xx8FxRFf<tJ:::::R[Q-PR_aVSVPNaR:::::"));var extendStatics=function(n,t){return extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,r){e.__proto__=r}||function(e,r){for(var i in r)Object.prototype.hasOwnProperty.call(r,i)&&(e[i]=r[i])},extendStatics(n,t)};function __extends(n,t){if(typeof t!="function"&&t!==null)throw new TypeError("Class extends value "+String(t)+" is not a constructor or null");extendStatics(n,t);function e(){this.constructor=n}n.prototype=t===null?Object.create(t):(e.prototype=t.prototype,new e)}var __assign=function(){return __assign=Object.assign||function(t){for(var e,r=1,i=arguments.length;r<i;r++){e=arguments[r];for(var o in e)Object.prototype.hasOwnProperty.call(e,o)&&(t[o]=e[o])}return t},__assign.apply(this,arguments)};function __decorate(n,t,e,r){var i=arguments.length,o=i<3?t:r===null?r=Object.getOwnPropertyDescriptor(t,e):r,s;if(typeof Reflect=="object"&&typeof Reflect.decorate=="function")o=Reflect.decorate(n,t,e,r);else for(var u=n.length-1;u>=0;u--)(s=n[u])&&(o=(i<3?s(o):i>3?s(t,e,o):s(t,e))||o);return i>3&&o&&Object.defineProperty(t,e,o),o}function __metadata(n,t){if(typeof Reflect=="object"&&typeof Reflect.metadata=="function")return Reflect.metadata(n,t)}function __awaiter(n,t,e,r){function i(o){return o instanceof e?o:new e(function(s){s(o)})}return new(e||(e=Promise))(function(o,s){function u(c){try{d(r.next(c))}catch(f){s(f)}}function l(c){try{d(r.throw(c))}catch(f){s(f)}}function d(c){c.done?o(c.value):i(c.value).then(u,l)}d((r=r.apply(n,t||[])).next())})}function __generator(n,t){var e={label:0,sent:function(){if(o[0]&1)throw o[1];return o[1]},trys:[],ops:[]},r,i,o,s;return s={next:u(0),throw:u(1),return:u(2)},typeof Symbol=="function"&&(s[Symbol.iterator]=function(){return this}),s;function u(d){return function(c){return l([d,c])}}function l(d){if(r)throw new TypeError("Generator is already executing.");for(;s&&(s=0,d[0]&&(e=0)),e;)try{if(r=1,i&&(o=d[0]&2?i.return:d[0]?i.throw||((o=i.return)&&o.call(i),0):i.next)&&!(o=o.call(i,d[1])).done)return o;switch(i=0,o&&(d=[d[0]&2,o.value]),d[0]){case 0:case 1:o=d;break;case 4:return e.label++,{value:d[1],done:!1};case 5:e.label++,i=d[1],d=[0];continue;case 7:d=e.ops.pop(),e.trys.pop();continue;default:if(o=e.trys,!(o=o.length>0&&o[o.length-1])&&(d[0]===6||d[0]===2)){e=0;continue}if(d[0]===3&&(!o||d[1]>o[0]&&d[1]<o[3])){e.label=d[1];break}if(d[0]===6&&e.label<o[1]){e.label=o[1],o=d;break}if(o&&e.label<o[2]){e.label=o[2],e.ops.push(d);break}o[2]&&e.ops.pop(),e.trys.pop();continue}d=t.call(n,e)}catch(c){d=[6,c],i=0}finally{r=o=0}if(d[0]&5)throw d[1];return{value:d[0]?d[1]:void 0,done:!0}}}function __spreadArray(n,t,e){if(e||arguments.length===2)for(var r=0,i=t.length,o;r<i;r++)(o||!(r in t))&&(o||(o=Array.prototype.slice.call(t,0,r)),o[r]=t[r]);return n.concat(o||Array.prototype.slice.call(t))}typeof SuppressedError=="function"&&SuppressedError;function createSymbol(n){return typeof Symbol>"u"?"$Symbol<".concat(n,">$"):Symbol(n)}var EVENT_SYMBOL=createSymbol("$$FIVE_EVENT$$");function __generateEventIfNotExisted(n){return n[EVENT_SYMBOL]||(n[EVENT_SYMBOL]={}),n[EVENT_SYMBOL]}function __removeEventIfNotExisted(n){n[EVENT_SYMBOL]||delete n[EVENT_SYMBOL]}var Subscribe=function(){function n(){}return n.prototype.hasListener=function(t){var e=__generateEventIfNotExisted(this);return e&&e[t]&&e[t].callbacks.length>0},n.prototype.on=function(t,e,r){var i=this,o=__generateEventIfNotExisted(this);return o[t]||(o[t]={called:[!1],callbacks:[]}),o[t].callbacks.push([e,r||!1]),function(){return i.off(t,e)}},n.prototype.once=function(t,e){return this.on(t,e,!0)},n.prototype.off=function(t,e){if(t===void 0){__removeEventIfNotExisted(this);return}var r=__generateEventIfNotExisted(this);if(r[t]||(r[t]={called:[!1],callbacks:[]}),e===void 0){r[t].callbacks.length=0;return}for(var i=0;i<r[t].callbacks.length&&r[t].callbacks[i][0]!==e;i++);i<r[t].callbacks.length&&r[t].callbacks.splice(i,1)},n.prototype.emit=function(t){for(var e=[],r=1;r<arguments.length;r++)e[r-1]=arguments[r];var i=!1,o=__generateEventIfNotExisted(this);o[t]||(o[t]={called:[!1],callbacks:[]}),o[t].called=[!0,e];for(var s=o[t].callbacks.slice(),u=0,l=s;u<l.length;u++){var d=l[u],c=d[0],f=d[1],h=f===void 0?!1:f,v=c.apply(void 0,e);h&&this.off(t,c),v===!1&&(i=!0)}return i},n.prototype.waitUnitl=function(t){var e=this,r=__generateEventIfNotExisted(this);r[t]||(r[t]={called:[!1],callbacks:[]});var i=r[t].called,o=i[0],s=i[1];return o?Promise.resolve(s):new Promise(function(u){e.once(t,function(){for(var l=[],d=0;d<arguments.length;d++)l[d]=arguments[d];return u(l),!0})})},n}();function noop$1(){}var start=typeof performance<"u"&&typeof performance.timing<"u"?performance.timing.navigationStart:Date.now(),now=typeof performance<"u"?function(){return start+performance.now()}:function(){return Date.now()};function deepFreeze(n){Object.freeze(n);var t=typeof n=="function",e=Object.prototype.hasOwnProperty;return Object.getOwnPropertyNames(n).forEach(function(r){e.call(n,r)&&(!t||r!=="caller"&&r!=="callee"&&r!=="arguments")&&n[r]!==null&&(typeof n[r]=="object"||typeof n[r]=="function")&&!Object.isFrozen(n[r])&&deepFreeze(n[r])}),n}var domainRegex=/^([^.]+)(\.([^.]+))*$/;function match(n,t){if(n==="*")return!0;var e=n.split(".").reverse(),r=t.split(".").reverse();if(e.length<=1)return n===t;for(var i=0;i<e.length;i++)if(e[i]!==r[i])return!1;return!0}function isIPDomain(n){return/^(([1-9]?\d|1\d\d|2[0-4]\d|25[0-5])(\.(?!$)|$)){4}$/.test(n)}function matchDomain(n,t){return domainRegex.test(n)&&domainRegex.test(t)&&match(n,t)}var JSONP_REGEXPS=[/\.([0-9a-z]+)\.jsonp([\?\#].*)?$/i,/jsonp_([0-9a-z]+)([\?\#].*)?$/i],BUILDIN_ALLOW_HOST=deepFreeze(JSON.parse(function(){var t=113,e=126,r=0,i="";return arguments[r].split(i).map(function(o){return o.charCodeAt(r)>e?o:String.fromCharCode((o.charCodeAt(r)+t)%e)}).join(i)}("h/y|pnyu|/9/xr;p|z/9/yvn{wvn;p|z/9/rnyrr;p|z/9/rnyrr;p{/9/rnyrr;w}/9/uv;p|z/9/uv;p{/9/ywpq{;p|z/9/rnyrr:pq{;p|z/9/rnyrr:pq{;p{/9/rnyrr;nv/9/;p{/9/pq{;p{/9/pnyp{|qr;vr/j"))),NetworkProxyError=function(n){__extends(t,n);function t(e,r,i){return n.call(this,"[NETWORK]: request proxy error(type: ".concat(r,", reason: ").concat(i,"): ").concat(e))||this}return t}(Error),NetworkResponseError=function(n){__extends(t,n);function t(e,r,i){var o=n.call(this,"[NETWORK]: response error(type: ".concat(r,", status: ").concat(i,"): ").concat(e))||this;return o.httpStatus=i,o}return t}(Error);(function(n){__extends(t,n);function t(e,r){return n.call(this,"[NETWORK]: request abort(type: ".concat(r,"): ").concat(e))||this}return t})(Error);var NetworkTimeoutError=function(n){__extends(t,n);function t(e,r,i){return n.call(this,"[NETWORK]: request timeout(type: ".concat(r,", timeout: ").concat(i,"ms): ").concat(e))||this}return t}(Error),NetworkFirbiddenError=function(n){__extends(t,n);function t(e,r,i){return n.call(this,"[NETWORK]: request forbidden(type: ".concat(r,", reason: ").concat(i,"): ").concat(e))||this}return t}(Error);function parseHeaders(n){if(!n)return{};for(var t={},e=n.trim().split(`
|
|
391
|
-
`),r=0;r<e.length;r++){var i=e[r],o=i.indexOf(":"),s=i.slice(0,o).trim().toLowerCase(),u=i.slice(o+1).trim();u&&(t[s]?t[s]+=", "+u:t[s]=u)}return t}function matchJsonpFunctionName(n){for(var t=0,e=JSONP_REGEXPS;t<e.length;t++){var r=e[t],i=n.match(r);if(i)return"jsonp_"+i[1]}return null}function isJsonpSource(n){return matchJsonpFunctionName(n)!==null}function getProtocol(n){var t=n.match(/^([0-9a-z]+\:)\/\/(([^:/?#]*)(?::[0-9]+)?)/);return t?t[1]:location.protocol}function hostnameFromURL(n){if(/^blob\:/i.test(n))return"blob:";if(/^data\:/i.test(n))return"data:";var t=n.match(/^[0-9a-z]+\:\/\/(([^:/?#]*)(?::[0-9]+)?)/i);return t?t[2]:location.hostname}var NetworkSubscribe=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t}(Subscribe);function ajax(n,t,e,r,i){t===void 0&&(t={}),e===void 0&&(e=noop$1),r===void 0&&(r=noop$1),i===void 0&&(i=noop$1);var o=now(),s=n;return Promise.resolve().then(function(){return t.requestProxy?t.requestProxy(n):n}).then(function(u){return/^https\:/.test(location.href)&&/^http\:/.test(u)?(console.warn("The page at '".concat(location.href,"' was loaded over HTTPS, but requested an insecure element '").concat(u,"'. This request was automatically upgraded to HTTPS")),u.replace(/^http\:/,"https:")):u}).catch(function(u){var l,d=matchJsonpFunctionName(n),c=d?"Script":"XMLHttpRequest",f=new NetworkProxyError(s,c,u&&u.message?String(u.message):String(u));return(l=t.networkSubscribe)===null||l===void 0||l.emit("network",n,c,"proxy-error",f.message),Promise.reject(f)}).then(function(u){return new Promise(function(l,d){var c,f=t.allowHosts?BUILDIN_ALLOW_HOST.concat(t.allowHosts):BUILDIN_ALLOW_HOST.slice(),h=hostnameFromURL(u),v=matchJsonpFunctionName(u);if(location.hostname.length!==0&&!isIPDomain(location.hostname)&&BUILDIN_ALLOW_HOST.filter(function(F){return matchDomain(F,location.hostname)}).length===0&&!isIPDomain(h)&&f.filter(function(F){return matchDomain(F,h)}).length===0){var A=v?"Script":"XMLHttpRequest",m=new NetworkFirbiddenError(u,A,"request host(".concat(h,") is not allowed"));r(m),d(m),(c=t.networkSubscribe)===null||c===void 0||c.emit("network",u,A,"forbidden",m.message);return}if(v){var y=window,p=null,g=!1,b=document.createElement("script"),T=function(){var F;if(p=null,g!==!0){g=!0;var O=new NetworkTimeoutError(u,"Script",t.timeout||NaN);r(O),d(O),(F=t.networkSubscribe)===null||F===void 0||F.emit("network",u,"Script","timeout",O.message)}},_=function(F){var O,H,k=now(),N=k-o;if(delete y[v],b.parentNode&&b.parentNode.removeChild(b),p!==null&&(window.clearTimeout(p),p=null),g!==!0){if(F.indexOf("data:")!==0){var q=new NetworkResponseError(u,"Script",500);r(q),d(q),(O=t.networkSubscribe)===null||O===void 0||O.emit("network",u,"Script","error",q.message);return}var V=F.split(","),D=(V[0].match(/:(.*?);/)||[])[1],K=V[1];if(t.responseType==="arraybuffer"||t.responseType==="blob"){for(var z=atob(V[1]),G=z.length,W=new Uint8Array(G),Q=0;Q<G;Q++)W[Q]=z.charCodeAt(Q);t.responseType==="arraybuffer"?K=W.buffer:K=new Blob([W],{type:D})}var X={},ee={body:K,meta:{origin:s,source:u,requestTime:o,responseTime:k,costs:N,headers:X}};e(ee),l(ee),(H=t.networkSubscribe)===null||H===void 0||H.emit("network",u,"Script","ok",JSON.stringify(ee.meta)),g=!0}};y[v]=_,b.src=u,document.body.appendChild(b),typeof t.timeout=="number"&&(p=window.setTimeout(T,t.timeout))}else{var w=!1,x=new XMLHttpRequest,M=function(){x&&(x.removeEventListener("timeout",R,!1),x.removeEventListener("progress",I,!1),x.removeEventListener("load",S,!1),x.removeEventListener("error",B,!1)),x=null,M=noop$1},R=function(){var F;if(w!==!0){w=!0,M();var O=new NetworkTimeoutError(u,"XMLHttpRequest",t.timeout||NaN);r(O),d(O),(F=t.networkSubscribe)===null||F===void 0||F.emit("network",u,"XMLHttpRequest","timeout",O.message)}},I=function(F){w!==!0&&F.lengthComputable&&(F.total<=0||i(F.loaded/F.total))},S=function(F){var O;if(w!==!0){var H=this.status;if(H===0||H>=200&&H<400){w=!0,M();var k=now(),N=k-o,q=parseHeaders(this.getAllResponseHeaders()),V=F.total,D={body:this.response,meta:{origin:s,source:u,requestTime:o,responseTime:k,costs:N,headers:q,size:V}};e(D),l(D),(O=t.networkSubscribe)===null||O===void 0||O.emit("network",u,"XMLHttpRequest","ok",JSON.stringify(D.meta))}else B.call(this)}},B=function(){var F;if(w!==!0){w=!0,M();var O=new NetworkResponseError(u,"XMLHttpRequest",this.status);r(O),d(O),(F=t.networkSubscribe)===null||F===void 0||F.emit("network",u,"XMLHttpRequest","error",O.message)}};x.addEventListener("timeout",R,!1),x.addEventListener("progress",I,!1),x.addEventListener("load",S,!1),x.addEventListener("error",B,!1),t.responseType&&(x.responseType=t.responseType),typeof t.timeout=="number"&&(x.timeout=t.timeout),x.open("GET",u,!0),x.send(null)}})})}var preloadCache={};function preload(n,t){t===void 0&&(t={});var e=now(),r=n;return Promise.resolve().then(function(){return t.requestProxy?t.requestProxy(n):n}).then(function(i){return/^https\:/.test(location.href)&&/^http\:/.test(i)?(console.warn("The page at '".concat(location.href,"' was loaded over HTTPS, but requested an insecure element '").concat(i,"'. This request was automatically upgraded to HTTPS")),i.replace(/^http\:/,"https:")):i}).catch(function(i){var o,s=new NetworkProxyError(r,"Link",i&&i.message?String(i.message):String(i));return(o=t.networkSubscribe)===null||o===void 0||o.emit("network",n,"Link","proxy-error",s.message),Promise.reject(s)}).then(function(i){return i in preloadCache?preloadCache[i]:preloadCache[i]=new Promise(function(o,s){var u,l=t.allowHosts?BUILDIN_ALLOW_HOST.concat(t.allowHosts):BUILDIN_ALLOW_HOST.slice(),d=hostnameFromURL(i);if(location.hostname.length!==0&&!isIPDomain(location.hostname)&&BUILDIN_ALLOW_HOST.filter(function(A){return matchDomain(A,location.hostname)}).length===0&&!isIPDomain(d)&&l.filter(function(A){return matchDomain(A,d)}).length===0){var c=new NetworkFirbiddenError(i,"Link","request host(".concat(d,") is not allowed"));s(c),(u=t.networkSubscribe)===null||u===void 0||u.emit("network",i,"Link","forbidden",c.message);return}var f=document.createElement("link");f.href=i,f.rel=f.relList&&f.relList.supports("prefetch")?"prefetch":"preload",f.as="fetch",f.crossOrigin="";var h=document.head||document.getElementsByTagName("head")[0];h&&h.appendChild(f);var v=!1;f.onload=function(){var A;if(v!==!0){v=!0,o();var m=now(),y=m-e,p={},g={origin:r,source:i,requestTime:e,responseTime:m,costs:y,headers:p};(A=t.networkSubscribe)===null||A===void 0||A.emit("network",i,"Link","preload",JSON.stringify(g))}},f.onerror=function(A){var m;if(v!==!0){v=!0;var y=new NetworkResponseError(i,"Link",0);s(y),(m=t.networkSubscribe)===null||m===void 0||m.emit("network",i,"Link","error",y.message)}}})})}function loadImage(n,t,e,r,i,o){t===void 0&&(t={}),e===void 0&&(e=noop$1),r===void 0&&(r=noop$1),i===void 0&&(i=noop$1);var s=now(),u=n;return Promise.resolve().then(function(){return t.requestProxy?t.requestProxy(n):n}).then(function(l){return/^https\:/.test(location.href)&&/^http\:/.test(l)?(console.warn("The page at '".concat(location.href,"' was loaded over HTTPS, but requested an insecure element '").concat(l,"'. This request was automatically upgraded to HTTPS")),l.replace(/^http\:/,"https:")):l}).catch(function(l){var d,c=new NetworkProxyError(u,"Image",l&&l.message?String(l.message):String(l));return(d=t.networkSubscribe)===null||d===void 0||d.emit("network",n,"Image","proxy-error",c.message),Promise.reject(c)}).then(function(l){return new Promise(function(d,c){var f,h=t.allowHosts?BUILDIN_ALLOW_HOST.concat(t.allowHosts):BUILDIN_ALLOW_HOST.slice(),v=hostnameFromURL(l);if(location.hostname.length!==0&&!isIPDomain(location.hostname)&&BUILDIN_ALLOW_HOST.filter(function(T){return matchDomain(T,location.hostname)}).length===0&&!isIPDomain(v)&&h.filter(function(T){return matchDomain(T,v)}).length===0){var A=new NetworkFirbiddenError(l,"Image","request host(".concat(v,") is not allowed"));r(A),c(A),(f=t.networkSubscribe)===null||f===void 0||f.emit("network",l,"Image","forbidden",A.message);return}var m=o??new Image,y=!1,p=null,g=function(){var T;if(m.onload=noop$1,m.onerror=noop$1,p!==null&&(clearTimeout(p),p=null),y!==!0){var _=now(),w={headers:{},origin:u,source:l,requestTime:s,responseTime:_,costs:_-s};y=!0;var x={body:m,meta:w};i(1),e(x),d(x),(T=t.networkSubscribe)===null||T===void 0||T.emit("network",l,"Image","ok",JSON.stringify(x.meta))}},b=function(){var T;if(m.onload=noop$1,m.onerror=noop$1,p!==null&&(clearTimeout(p),p=null),y!==!0){y=!0;var _=new NetworkResponseError(l,"Image",0);r(_),c(_),(T=t.networkSubscribe)===null||T===void 0||T.emit("network",l,"Image","ok",_.message)}};typeof t.timeout=="number"&&(p=window.setTimeout(function(){var T;if(m.onload=noop$1,m.onerror=noop$1,p=null,y!==!0){y=!0;var _=new NetworkTimeoutError(l,"Image",t.timeout);r(_),c(_),(T=t.networkSubscribe)===null||T===void 0||T.emit("network",l,"Image","timeout",_.message)}},t.timeout)),m.onload=g,m.onerror=b,i(0),m.src=l})})}var Fetcher=function(){function n(t){t===void 0&&(t={}),this.options=deepFreeze(t)}return n.prototype.ajax=function(t,e,r,i,o){var s;e===void 0&&(e={}),r===void 0&&(r=noop$1),i===void 0&&(i=noop$1),o===void 0&&(o=noop$1);var u=this.options,l={responseType:e.responseType,timeout:(s=e.timeout)!==null&&s!==void 0?s:u.timeout,get allowHosts(){var d;return(d=e.allowHosts)!==null&&d!==void 0?d:u.allowHosts},get requestProxy(){var d;return(d=e.requestProxy)!==null&&d!==void 0?d:u.requestProxy},get networkSubscribe(){var d;return(d=e.networkSubscribe)!==null&&d!==void 0?d:u.networkSubscribe}};return ajax(t,l,r,i,o)},n.prototype.loadImage=function(t,e,r,i,o,s){var u;e===void 0&&(e={}),r===void 0&&(r=noop$1),i===void 0&&(i=noop$1),o===void 0&&(o=noop$1);var l=this.options,d={timeout:(u=e.timeout)!==null&&u!==void 0?u:l.timeout,get allowHosts(){var c;return(c=e.allowHosts)!==null&&c!==void 0?c:l.allowHosts},get requestProxy(){var c;return(c=e.requestProxy)!==null&&c!==void 0?c:l.requestProxy},get networkSubscribe(){var c;return(c=e.networkSubscribe)!==null&&c!==void 0?c:l.networkSubscribe}};return loadImage(t,d,r,i,o,s)},n.prototype.preload=function(t,e){var r;e===void 0&&(e={});var i=this.options,o={timeout:(r=e.timeout)!==null&&r!==void 0?r:i.timeout,get allowHosts(){var s;return(s=e.allowHosts)!==null&&s!==void 0?s:i.allowHosts},get requestProxy(){var s;return(s=e.requestProxy)!==null&&s!==void 0?s:i.requestProxy},get networkSubscribe(){var s;return(s=e.networkSubscribe)!==null&&s!==void 0?s:i.networkSubscribe}};return preload(t,o)},n}(),internalFetcher=new Fetcher,_requestAnimationFrame=function(){if(typeof window<"u"){var n=window;return n.requestAnimationFrame||n.mozRequestAnimationFrame||n.webkitRequestAnimationFrame||n.msRequestAnimationFrame||function(t){return setTimeout(t,16)}}else return function(t){return setTimeout(t,16)}}(),_cancelAnimationFrame=function(n){var t;if(typeof window<"u"){var e=window;t=e.cancelAnimationFrame||e.mozCancelAnimationFrame||e.webkitCancelAnimationFrame||e.msCancelAnimationFrame||function(r){return window.clearTimeout(r)}}else t=function(r){return window.clearTimeout(r)};t(n)},DEFAULT_ORDER=5,deviceFrameTime=16,AnimationFrameLoop=function(){function n(){this.frames=[],this.stoped=!1,this.time=now(),this.context=null,this.loop=this.loop.bind(this),this.loop()}return Object.defineProperty(n,"shared",{get:function(){return this.sharedInstance||(this.sharedInstance=new n),this.sharedInstance},enumerable:!1,configurable:!0}),n.getFrameTime=function(){return deviceFrameTime},n.prototype.loop=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];if(!this.stoped){var r=now(),i=r-this.time;this.time=r;var o=[];deviceFrameTime=i;for(var s=0,u=this.frames;s<u.length;s++){var l=u[s];if(l.delay>0){l.delay=l.delay-1;continue}try{l.callback.apply(l,__spreadArray([r,i],t,!1))}catch(d){console.error(d)}l.once&&o.push(l)}o.length>0&&(this.frames=this.frames.filter(function(d){return o.indexOf(d)===-1})),this.requestAnimationFrame(this.loop)}},n.prototype.setContext=function(t){this.cancelAnimationFrame(this.requestId),this.context=t,this.requestId=this.requestAnimationFrame(this.loop)},n.prototype.getContext=function(){return this.context},n.prototype.requestAnimationFrame=function(t){return this.context?this.context.requestAnimationFrame(t):_requestAnimationFrame(t)},n.prototype.cancelAnimationFrame=function(t){this.context?this.context.cancelAnimationFrame(t):_cancelAnimationFrame(this.loop),this.requestId=null},n.prototype.remove=function(t){var e=this.frames.indexOf(t);e>=0&&this.frames.splice(e,1)},n.prototype.add=function(t,e,r,i){var o=this;e===void 0&&(e=!1),r===void 0&&(r=0),i===void 0&&(i=DEFAULT_ORDER);var s={callback:t,once:e,delay:r,order:i};return this.frames.push(s),this.frames.sort(function(u,l){return u.order-l.order}),function(){return o.remove(s)}},n.prototype.disponse=function(){this.stoped=!0,this.frames.length=0},n}(),DEFAULT_IMAGE_URL_MAPPINGS={"vrlab-public.ljcdn.com":{type:"tencentCloud",pano:["vrlab-image1.ljcdn.com","vrlab-image2.ljcdn.com"],texture:["vrlab-image3.ljcdn.com"],tile:["vr-tile-1.realsee-cdn.cn","vr-tile-2.realsee-cdn.cn"],model:["vr-model-1.realsee-cdn.cn","vr-model-2.realsee-cdn.cn"],default:["vrlab-image4.ljcdn.com"]},"vr-public.realsee-cdn.cn":{type:"tencentCloud",pano:["vr-image-1.realsee-cdn.cn","vr-image-2.realsee-cdn.cn"],texture:["vr-image-3.realsee-cdn.cn"],tile:["vr-tile-1.realsee-cdn.cn","vr-tile-2.realsee-cdn.cn"],model:["vr-model-1.realsee-cdn.cn","vr-model-2.realsee-cdn.cn"],default:["vr-image-4.realsee-cdn.cn"]},"vr-public.rscdn.cn":{type:"tencentCloud",pano:["vr-image-1.rscdn.cn","vr-image-2.rscdn.cn"],texture:["vr-image-3.rscdn.cn"],tile:["vr-tile-1.rscdn.cn","vr-tile-2.rscdn.cn"],model:["vr-model-1.rscdn.cn","vr-model-2.rscdn.cn"],default:["vr-image-4.rscdn.cn"]},"mars-public.realsee-cdn.cn":{type:"aliyun",pano:["mars-image-1.realsee-cdn.cn","mars-image-2.realsee-cdn.cn"],texture:["mars-image-3.realsee-cdn.cn"],tile:["mars-tile-1.realsee-cdn.cn","mars-tile-2.realsee-cdn.cn"],model:["mars-model-1.realsee-cdn.cn","mars-model-2.realsee-cdn.cn"],default:["mars-image-4.realsee-cdn.cn"]},"global-public.realsee-cdn.com":{type:"tencentCloud",pano:["global-image-1.realsee-cdn.com","global-image-2.realsee-cdn.com"],texture:["global-image-3.realsee-cdn.com"],tile:["global-tile-1.realsee-cdn.com","global-tile-2.realsee-cdn.com"],model:["global-model-1.realsee-cdn.com","global-model-2.realsee-cdn.com"],default:["global-image-4.realsee-cdn.com"]},"earth-ga-public.realsee-cdn.cn":{type:"tencentCloud",pano:["earth-ga-image-1.realsee-cdn.cn","earth-ga-image-2.realsee-cdn.cn"],texture:["earth-ga-image-3.realsee-cdn.cn"],tile:["earth-ga-tile-1.realsee-cdn.cn","earth-ga-tile-2.realsee-cdn.cn"],model:["earth-ga-model-1.realsee-cdn.cn","earth-ga-model-2.realsee-cdn.cn"],default:["earth-ga-image-4.realsee-cdn.cn"]},"test-vr-public.realsee-cdn.com":{type:"tencentCloud",pano:["test-vr-image.realsee-cdn.com","test-vr-image.realsee-cdn.com"],texture:["test-vr-image.realsee-cdn.com"],tile:["test-vr-image.realsee-cdn.com","test-vr-image.realsee-cdn.com"],model:["test-vr-image.realsee-cdn.com","test-vr-image.realsee-cdn.com"],default:["test-vr-image.realsee-cdn.com"]},"test-vr-public.realsee-cdn.cn":{type:"tencentCloud",pano:["test-vr-image.realsee-cdn.cn","test-vr-image.realsee-cdn.cn"],texture:["test-vr-image.realsee-cdn.cn"],tile:["test-vr-image.realsee-cdn.cn","test-vr-image.realsee-cdn.cn"],model:["test-vr-image.realsee-cdn.cn","test-vr-image.realsee-cdn.cn"],default:["test-vr-image.realsee-cdn.cn"]}},URL_DOMAIN_REGEX=/^https?\:\/\/?([^\/]+)/;function getDomain(n){var t=n.match(URL_DOMAIN_REGEX);return t===null?null:t[1]}function replaceDomain(n,t){return n.replace(URL_DOMAIN_REGEX,function(e,r){return e.slice(0,e.length-r.length)+t})}function route(n,t,e){var r=t.split("."),i=r[0],o=r.slice(1);if(i==="texture")return replaceDomain(n,e.texture[0]);if(i==="pano"||i==="pano_luminance"){o[0];var s=o[1];switch(s){case"front":case"left":case"up":return replaceDomain(n,e.pano[0]);case"down":case"right":case"back":return replaceDomain(n,e.pano[1])}}else if(i==="pano_tile"||i==="pano_tile_luminance"){o[0],o[1];var u=o[2],l=o[3],d=o[4],c=Math.pow(2,Number(u))*Number(l)+Number(d);if(!isNaN(c))return replaceDomain(n,e.tile[c%2])}else if(i==="model"){var f=o[0],c=Number(f);if(!isNaN(c))return replaceDomain(n,e.model[c%2])}return replaceDomain(n,e.default[0])}var tencentCloudImageProcesser=function(n,t){var e,r=n.split("?")[0],i=r.split(".").pop();if(i==="jpeg"&&(i="jpg"),i!=="png"&&i!=="jpg")return n;var o="";if(t.format!==void 0&&t.format!==i&&(o+="/format/".concat(t.format)),t.cut!==void 0&&(o+="/cut/".concat(t.cut[2],"x").concat(t.cut[3],"x").concat(t.cut[0],"x").concat(t.cut[1])),t.quality!==void 0){var s=(e=t.format)!==null&&e!==void 0?e:i;s&&["jpg","webp","tpg","heif","avif"].indexOf(s)>=0&&(o+="/quality/".concat(t.quality))}if(t.size!==void 0){var u=n.match(/\/cube_(\d+)\//),l=u?Number(u[1]):NaN;l!==Number(t.size)&&(o+="/thumbnail/".concat(t.size,"x"))}return t.sharpen!==void 0&&(o+="/sharpen/".concat(t.sharpen)),o.length&&(o="?imageMogr2"+o),r+o},aliyunOOSImageProcesser=function(n,t){var e,r=n.split("?")[0],i=r.split(".").pop();if(i==="jpeg"&&(i="jpg"),i!=="png"&&i!=="jpg")return n;var o="",s=[],u=t.format,l=t.quality,d=t.size;if(u!==void 0&&u!==i&&s.push("format,".concat(u==="heif"?"heic":u)),t.cut!==void 0){var c=t.cut,f=c[0],h=c[1],v=c[2],A=c[3];s.push("crop,x_".concat(f,",y_").concat(h,",w_").concat(v,",h_").concat(A,",g_nw"))}if(l!==void 0&&l!==100){var m=(e=t.format)!==null&&e!==void 0?e:i;m&&["jpg","webp"].indexOf(m)>=0&&s.push("quality,Q_".concat(l))}return d&&d!==2048&&s.push("resize,w_".concat(d)),t.sharpen!==void 0&&s.push("sharpen,".concat(t.sharpen)),s.length&&(o="?x-oss-process=image/"+s.join("/")),r+o};function imageURL(n,t){var e=__assign(__assign({},DEFAULT_IMAGE_URL_MAPPINGS),t.mappings),r=getDomain(n);if(r===null)return n;var i=e[r];return i?(n=route(n,t.key,i),/\.basis(\?|$)/.test(n)&&(n=n.replace(/\.basis(\?|$)/,".jpg$1")),i.type==="tencentCloud"?tencentCloudImageProcesser(n,t):i.type==="aliyun"?aliyunOOSImageProcesser(n,t):n):n}function applyImageURLOptions(n,t,e){t===void 0&&(t=imageURL);var r=t(n,e);if(r===n&&e.cut)throw new Error("ImageURL: cut option not applied.");return r}var webp="data:image/webp;base64,UklGRiQAAABXRUJQVlA4IBgAAAAwAQCdASoCAAIAAUAmJaQAA3AA/vz0AAA=",avif="data:image/avif;base64,AAAAIGZ0eXBhdmlmAAAAAGF2aWZtaWYxbWlhZk1BMUIAAAGhbWV0YQAAAAAAAAAoaGRscgAAAAAAAAAAcGljdAAAAAAAAAAAAAAAAGxpYmF2aWYAAAAADnBpdG0AAAAAAAEAAAAsaWxvYwAAAABEAAACAAEAAAABAAAB3gAAABkAAgAAAAEAAAHJAAAAFQAAAEJpaW5mAAAAAAACAAAAGmluZmUCAAAAAAEAAGF2MDFDb2xvcgAAAAAaaW5mZQIAAAAAAgAAYXYwMUFscGhhAAAAABppcmVmAAAAAAAAAA5hdXhsAAIAAQABAAAA12lwcnAAAACxaXBjbwAAABRpc3BlAAAAAAAAAAIAAAACAAAAEHBpeGkAAAAAAwgICAAAAAxhdjFDgQAMAAAAABNjb2xybmNseAACAAIAAoAAAAAUaXNwZQAAAAAAAAACAAAAAgAAAA5waXhpAAAAAAEIAAAADGF2MUOBABwAAAAAOGF1eEMAAAAAdXJuOm1wZWc6bXBlZ0I6Y2ljcDpzeXN0ZW1zOmF1eGlsaWFyeTphbHBoYQAAAAAeaXBtYQAAAAAAAAACAAEEAQKDBAACBAUGhwgAAAA2bWRhdBIACgQYADLVMgsWQBhhIAQqrNj/+BIACgUYADLEoDIOFkADDDDCQAACDaqCCb4=",heif="data:image/heif;base64,AAAAGGZ0eXBoZWljAAAAAG1pZjFoZWljAAABL21ldGEAAAAAAAAAIWhkbHIAAAAAAAAAAHBpY3QAAAAAAAAAAAAAAAAAAAAADnBpdG0AAAAAAAEAAAAjaWluZgAAAAAAAQAAABVpbmZlAgAAAAABAABodmMxAAAAAK9pcHJwAAAAkmlwY28AAAB2aHZjQwEBYAAAAAAAAAAAAADwAPz9+PgAACcDoAABAB5AAQwG//8BYAAAAwAAAwAAAwAAAwAAAwAAreTLgSChAAEAI0IBBwFgAAADAAADAAADAAADAAADAAChInJJlreTLySZNdggogABAAdEAcA98DMkAAAAFGlzcGUAAAAAAAAAAgAAAAIAAAAVaXBtYQAAAAAAAAABAAECgQIAAAAiaWxvYwAAAABEQAABAAEAAAAAAU8AAQAAAAAAAAAOAAAAFm1kYXQAAAAKJgGvLvkQwuWM4A==";function checkImage(n){return new Promise(function(t){var e=new Image,r=setTimeout(function(){e.onload=e.onerror=function(){},clearTimeout(r),t(!1)},100);e.onload=e.onerror=function(){e.onload=e.onerror=function(){},clearTimeout(r),t(e.height===2)},e.src=n})}var imageSupportCache=null;function imageSupport(){return imageSupportCache||(imageSupportCache=Promise.all([checkImage(webp),checkImage(avif),checkImage(heif)]).then(function(n){return{webp:n[0],avif:n[1],heif:n[2]}}))}var PANO_ID_REG=/^(.*)\[(\d+)\]$/;function panoStringify(n){if(!isNaN(n.panoIndex)&&isFinite(n.panoIndex))return"".concat(n.workCode,"[").concat(n.panoIndex,"]");throw new Error("Invalid Pano")}function panoParse(n){var t=n.match(PANO_ID_REG);if(t){t[0];var e=t[1],r=t[2],i=Math.floor(Number(r));if(!isNaN(i)&&isFinite(i))return{workCode:e,panoIndex:i}}throw new Error("Invalid PanoId")}function panoEqual(n,t){return panoStringify(n)===panoStringify(t)}function isPanoId(n){return typeof n=="string"&&PANO_ID_REG.test(n)}var PBMGroup=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t}(THREE__namespace.Group),PBMMesh=function(n){__extends(t,n);function t(e,r){var i=n.call(this,e,r)||this;return i.onBeforeRender=onBeforeRender$1,i}return t}(THREE__namespace.Mesh);function onBeforeRender$1(n,t,e){for(var r=0,i=this.material;r<i.length;r++){var o=i[r];this.model&&o.syncModel(this.model),o.update(n,e)}}var gradientTexture=new THREE__namespace.TextureLoader().load("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAABCAYAAACouxZ2AAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAACAKADAAQAAAABAAAAAQAAAAB7UD0+AAACA0lEQVRIDXWUW3YjIQxEwdnV/GT/q8kO3FO3pAJst3PSAaR6Cbszf//9XeMxxpjXmI+pVXudp2s6PC4dqHff9e6D7/PZLy46xQvG+sZvrfK8xgXUeq85yINe9bdmtOK1+kun5vjgq58a+eZPna9jvmjiserqG/+Whathvo3L3WhV89L9sXI/m18z2uene9ap/ftsuT9WZxoHXzW56/fpj8l7+tTw7P011NdpqnY19sRsfuHMA9u8oZWfDz4+fra/dfG1V60ydZ7qba1g7UNAeK0JP7ydD7/OqH6wO2f7HTq+B/lbL9qsB3/N1/UzR81XfPzw4tp5OPvRneacteq8Xo0xR3vuv/kPz0KtX0Nhg0eHuaNXdWI3X/ld427h++vzyp99V6VPrzWFhbv4ayay4oFecm198MmUXN/mL+x7npq/uJXBGb/MTw4+t+SvbLoTZnUW5uHhz7nWcTxT73OwXV7cxT9wbBf/0LnDBgcnHmtPLYba32Hp808sMy1u88yhr58n70/v4xX92GSN19l/2UsqGmiH94Hpxjcs+DO/ccpIVNVp62PUWXu//ur1GQy1Cf+GZ13rtNYN1po3/NI79fGXibHkq4z25xvV2pW3szpneXsW8SsreTe/NIPrtXMnH7wPf+LEN6tqhUVHj3XKD/72p9eafCeYB3zuonnbv7yqP8d/o4K6gRb1wbYAAAAASUVORK5CYII=");gradientTexture.minFilter=THREE__namespace.NearestFilter,gradientTexture.magFilter=THREE__namespace.NearestFilter,gradientTexture.wrapS=THREE__namespace.RepeatWrapping,gradientTexture.wrapT=THREE__namespace.RepeatWrapping;var defaultPbmParameters={pano0:null,pano1:null,shownFloorIndex:-1,modelAlpha:1,opacity:1,progress:0,useBlackTransition:!1,clippers:null,constantColor:null,useEDL:!1,useHQWeight:!1,useHQDepth:!1,pointColor:"RGB",pointSize:"ATTENUATION",pointBack:"DARK",pointShape:"SQUARE",pointScale:.03,pointMaxPixel:40,pointMinPixel:.5,gradientTexture};function isEqualClipperParameters(n,t){var e=n??[],r=t??[];if(r.length!==e.length)return!1;for(var i=0;i<r.length;i++)if(!e[i].clippingBoxMatrix.equals(r[i].clippingBoxMatrix)||e[i].floorIndex!==r[i].floorIndex)return!1;return!0}function isEqualPBMPanoPicture(n,t){return n&&t?n.luminanceMap===t.luminanceMap&&n.map===t.map&&n.matrix.equals(t.matrix):!n&&!t}function updatePBMParameters(n,t){var e=!1;for(var r in t)switch(r){case"clippers":isEqualClipperParameters(n[r],t[r])||(n[r]=t[r],e=!0);break;case"pano0":case"pano1":isEqualPBMPanoPicture(n[r],t[r])||(n[r]=t[r],e=!0);break;default:n[r]!==t[r]&&(n[r]=t[r],e=!0);break}return e}var PBMPointCloud=function(n){__extends(t,n);function t(e,r){var i=n.call(this,e,r)||this;return i.onBeforeRender=onBeforeRender,i}return t}(THREE__namespace.Points);function onBeforeRender(n,t,e){this.model&&this.material.syncModel(this.model),this.material.update(n,e)}var scratchMaterialSet=new Set,PBMContainer=function(n){__extends(t,n);function t(){var e=n.call(this)||this;return e.needsRender=!0,e.pbmMaterialParametersVersion=0,e.materialParameters=__assign({},defaultPbmParameters),e}return t.prototype.getMaterial=function(){return __assign({},this.materialParameters)},t.prototype.setMaterial=function(e){var r=this;Object.assign(this.materialParameters,e),scratchMaterialSet.clear(),this.traverse(function(i){if(i instanceof PBMMesh)for(var o=0,s=i.material;o<s.length;o++){var u=s[o];scratchMaterialSet.has(u)||(Object.assign(u,r.materialParameters),scratchMaterialSet.add(u))}i instanceof PBMPointCloud&&(scratchMaterialSet.has(i.material)||(Object.assign(i.material,r.materialParameters),scratchMaterialSet.add(i.material)))}),scratchMaterialSet.clear(),this.needsRender=!0},t}(THREE__namespace.Group),FACE_ORDER$1=["right","left","up","down","front","back"];function getBox(n,t,e,r){var i=new THREE__namespace.Box3;switch(n){case"up":i.min.y=.5,i.max.y=.5,i.min.x=+t-.5,i.max.x=+t-.5+r,i.min.z=-e+.5-r,i.max.z=-e+.5;break;case"down":i.min.y=-.5,i.max.y=-.5,i.min.x=+t-.5,i.max.x=+t-.5+r,i.min.z=+e-.5,i.max.z=+e-.5+r;break;case"left":i.min.x=-.5,i.max.x=-.5,i.min.z=-t+.5-r,i.max.z=-t+.5,i.min.y=-e+.5-r,i.max.y=-e+.5;break;case"right":i.min.x=.5,i.max.x=.5,i.min.z=+t-.5,i.max.z=+t-.5+r,i.min.y=-e+.5-r,i.max.y=-e+.5;break;case"front":i.min.z=-.5,i.max.z=-.5,i.min.x=+t-.5,i.max.x=+t-.5+r,i.min.y=-e+.5-r,i.max.y=-e+.5;break;case"back":i.min.z=.5,i.max.z=.5,i.min.x=-t+.5-r,i.max.x=-t+.5,i.min.y=-e+.5-r,i.max.y=-e+.5;break}return i.applyMatrix4(new THREE__namespace.Matrix4().makeRotationY(Math.PI))}var createChildren=function(n,t){if(!(n.level>=t))for(var e=n.level+1,r=n.size/2,i=[new THREE__namespace.Vector2(n.position.x,n.position.y),new THREE__namespace.Vector2(n.position.x+r,n.position.y),new THREE__namespace.Vector2(n.position.x,n.position.y+r),new THREE__namespace.Vector2(n.position.x+r,n.position.y+r)],o=0,s=i;o<s.length;o++){var u=s[o],l={face:n.face,level:e,size:r,position:u,box:getBox(n.face,u.x,u.y,r),children:[]};n.children.push(l),createChildren(l,t)}};function createTileCubeNode(n,t){var e={level:0,face:n,position:new THREE__namespace.Vector2(0,0),size:1,box:getBox(n,0,0,1),children:[]};return createChildren(e,t),e}function createTileCubeTree(n){var t=FACE_ORDER$1.map(function(e){return createTileCubeNode(e,n)});return{children:t}}function traverseTileCubeNode(n,t){for(var e=0,r=n.children;e<r.length;e++){var i=r[e],o=t(i);o!==!1&&traverseTileCubeNode(i,t)}}var CUBE_GEOMETRY=new THREE__namespace.BoxBufferGeometry(1,1,1,1,1);CUBE_GEOMETRY.deleteAttribute("uv"),CUBE_GEOMETRY.deleteAttribute("normal"),CUBE_GEOMETRY.groups=[],CUBE_GEOMETRY.scale(-1,1,1);var CUBE_VERTEX_SHADER=`
|
|
391
|
+
`),r=0;r<e.length;r++){var i=e[r],o=i.indexOf(":"),s=i.slice(0,o).trim().toLowerCase(),u=i.slice(o+1).trim();u&&(t[s]?t[s]+=", "+u:t[s]=u)}return t}function matchJsonpFunctionName(n){for(var t=0,e=JSONP_REGEXPS;t<e.length;t++){var r=e[t],i=n.match(r);if(i)return"jsonp_"+i[1]}return null}function isJsonpSource(n){return matchJsonpFunctionName(n)!==null}function getProtocol(n){var t=n.match(/^([0-9a-z]+\:)\/\/(([^:/?#]*)(?::[0-9]+)?)/);return t?t[1]:location.protocol}function hostnameFromURL(n){if(/^blob\:/i.test(n))return"blob:";if(/^data\:/i.test(n))return"data:";var t=n.match(/^[0-9a-z]+\:\/\/(([^:/?#]*)(?::[0-9]+)?)/i);return t?t[2]:location.hostname}var NetworkSubscribe=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t}(Subscribe);function ajax(n,t,e,r,i){t===void 0&&(t={}),e===void 0&&(e=noop$1),r===void 0&&(r=noop$1),i===void 0&&(i=noop$1);var o=now(),s=n;return Promise.resolve().then(function(){return t.requestProxy?t.requestProxy(n):n}).then(function(u){return/^https\:/.test(location.href)&&/^http\:/.test(u)?(console.warn("The page at '".concat(location.href,"' was loaded over HTTPS, but requested an insecure element '").concat(u,"'. This request was automatically upgraded to HTTPS")),u.replace(/^http\:/,"https:")):u}).catch(function(u){var l,d=matchJsonpFunctionName(n),c=d?"Script":"XMLHttpRequest",f=new NetworkProxyError(s,c,u&&u.message?String(u.message):String(u));return(l=t.networkSubscribe)===null||l===void 0||l.emit("network",n,c,"proxy-error",f.message),Promise.reject(f)}).then(function(u){return new Promise(function(l,d){var c,f=t.allowHosts?BUILDIN_ALLOW_HOST.concat(t.allowHosts):BUILDIN_ALLOW_HOST.slice(),h=hostnameFromURL(u),v=matchJsonpFunctionName(u);if(location.hostname.length!==0&&!isIPDomain(location.hostname)&&BUILDIN_ALLOW_HOST.filter(function(O){return matchDomain(O,location.hostname)}).length===0&&!isIPDomain(h)&&f.filter(function(O){return matchDomain(O,h)}).length===0){var A=v?"Script":"XMLHttpRequest",m=new NetworkFirbiddenError(u,A,"request host(".concat(h,") is not allowed"));r(m),d(m),(c=t.networkSubscribe)===null||c===void 0||c.emit("network",u,A,"forbidden",m.message);return}if(v){var y=window,p=null,g=!1,b=document.createElement("script"),T=function(){var O;if(p=null,g!==!0){g=!0;var F=new NetworkTimeoutError(u,"Script",t.timeout||NaN);r(F),d(F),(O=t.networkSubscribe)===null||O===void 0||O.emit("network",u,"Script","timeout",F.message)}},_=function(O){var F,H,k=now(),N=k-o;if(delete y[v],b.parentNode&&b.parentNode.removeChild(b),p!==null&&(window.clearTimeout(p),p=null),g!==!0){if(O.indexOf("data:")!==0){var q=new NetworkResponseError(u,"Script",500);r(q),d(q),(F=t.networkSubscribe)===null||F===void 0||F.emit("network",u,"Script","error",q.message);return}var V=O.split(","),D=(V[0].match(/:(.*?);/)||[])[1],K=V[1];if(t.responseType==="arraybuffer"||t.responseType==="blob"){for(var z=atob(V[1]),G=z.length,W=new Uint8Array(G),Q=0;Q<G;Q++)W[Q]=z.charCodeAt(Q);t.responseType==="arraybuffer"?K=W.buffer:K=new Blob([W],{type:D})}var X={},ee={body:K,meta:{origin:s,source:u,requestTime:o,responseTime:k,costs:N,headers:X}};e(ee),l(ee),(H=t.networkSubscribe)===null||H===void 0||H.emit("network",u,"Script","ok",JSON.stringify(ee.meta)),g=!0}};y[v]=_,b.src=u,document.body.appendChild(b),typeof t.timeout=="number"&&(p=window.setTimeout(T,t.timeout))}else{var w=!1,x=new XMLHttpRequest,M=function(){x&&(x.removeEventListener("timeout",R,!1),x.removeEventListener("progress",I,!1),x.removeEventListener("load",S,!1),x.removeEventListener("error",B,!1)),x=null,M=noop$1},R=function(){var O;if(w!==!0){w=!0,M();var F=new NetworkTimeoutError(u,"XMLHttpRequest",t.timeout||NaN);r(F),d(F),(O=t.networkSubscribe)===null||O===void 0||O.emit("network",u,"XMLHttpRequest","timeout",F.message)}},I=function(O){w!==!0&&O.lengthComputable&&(O.total<=0||i(O.loaded/O.total))},S=function(O){var F;if(w!==!0){var H=this.status;if(H===0||H>=200&&H<400){w=!0,M();var k=now(),N=k-o,q=parseHeaders(this.getAllResponseHeaders()),V=O.total,D={body:this.response,meta:{origin:s,source:u,requestTime:o,responseTime:k,costs:N,headers:q,size:V}};e(D),l(D),(F=t.networkSubscribe)===null||F===void 0||F.emit("network",u,"XMLHttpRequest","ok",JSON.stringify(D.meta))}else B.call(this)}},B=function(){var O;if(w!==!0){w=!0,M();var F=new NetworkResponseError(u,"XMLHttpRequest",this.status);r(F),d(F),(O=t.networkSubscribe)===null||O===void 0||O.emit("network",u,"XMLHttpRequest","error",F.message)}};x.addEventListener("timeout",R,!1),x.addEventListener("progress",I,!1),x.addEventListener("load",S,!1),x.addEventListener("error",B,!1),t.responseType&&(x.responseType=t.responseType),typeof t.timeout=="number"&&(x.timeout=t.timeout),x.open("GET",u,!0),x.send(null)}})})}var preloadCache={};function preload(n,t){t===void 0&&(t={});var e=now(),r=n;return Promise.resolve().then(function(){return t.requestProxy?t.requestProxy(n):n}).then(function(i){return/^https\:/.test(location.href)&&/^http\:/.test(i)?(console.warn("The page at '".concat(location.href,"' was loaded over HTTPS, but requested an insecure element '").concat(i,"'. This request was automatically upgraded to HTTPS")),i.replace(/^http\:/,"https:")):i}).catch(function(i){var o,s=new NetworkProxyError(r,"Link",i&&i.message?String(i.message):String(i));return(o=t.networkSubscribe)===null||o===void 0||o.emit("network",n,"Link","proxy-error",s.message),Promise.reject(s)}).then(function(i){return i in preloadCache?preloadCache[i]:preloadCache[i]=new Promise(function(o,s){var u,l=t.allowHosts?BUILDIN_ALLOW_HOST.concat(t.allowHosts):BUILDIN_ALLOW_HOST.slice(),d=hostnameFromURL(i);if(location.hostname.length!==0&&!isIPDomain(location.hostname)&&BUILDIN_ALLOW_HOST.filter(function(A){return matchDomain(A,location.hostname)}).length===0&&!isIPDomain(d)&&l.filter(function(A){return matchDomain(A,d)}).length===0){var c=new NetworkFirbiddenError(i,"Link","request host(".concat(d,") is not allowed"));s(c),(u=t.networkSubscribe)===null||u===void 0||u.emit("network",i,"Link","forbidden",c.message);return}var f=document.createElement("link");f.href=i,f.rel=f.relList&&f.relList.supports("prefetch")?"prefetch":"preload",f.as="fetch",f.crossOrigin="";var h=document.head||document.getElementsByTagName("head")[0];h&&h.appendChild(f);var v=!1;f.onload=function(){var A;if(v!==!0){v=!0,o();var m=now(),y=m-e,p={},g={origin:r,source:i,requestTime:e,responseTime:m,costs:y,headers:p};(A=t.networkSubscribe)===null||A===void 0||A.emit("network",i,"Link","preload",JSON.stringify(g))}},f.onerror=function(A){var m;if(v!==!0){v=!0;var y=new NetworkResponseError(i,"Link",0);s(y),(m=t.networkSubscribe)===null||m===void 0||m.emit("network",i,"Link","error",y.message)}}})})}function loadImage(n,t,e,r,i,o){t===void 0&&(t={}),e===void 0&&(e=noop$1),r===void 0&&(r=noop$1),i===void 0&&(i=noop$1);var s=now(),u=n;return Promise.resolve().then(function(){return t.requestProxy?t.requestProxy(n):n}).then(function(l){return/^https\:/.test(location.href)&&/^http\:/.test(l)?(console.warn("The page at '".concat(location.href,"' was loaded over HTTPS, but requested an insecure element '").concat(l,"'. This request was automatically upgraded to HTTPS")),l.replace(/^http\:/,"https:")):l}).catch(function(l){var d,c=new NetworkProxyError(u,"Image",l&&l.message?String(l.message):String(l));return(d=t.networkSubscribe)===null||d===void 0||d.emit("network",n,"Image","proxy-error",c.message),Promise.reject(c)}).then(function(l){return new Promise(function(d,c){var f,h=t.allowHosts?BUILDIN_ALLOW_HOST.concat(t.allowHosts):BUILDIN_ALLOW_HOST.slice(),v=hostnameFromURL(l);if(location.hostname.length!==0&&!isIPDomain(location.hostname)&&BUILDIN_ALLOW_HOST.filter(function(T){return matchDomain(T,location.hostname)}).length===0&&!isIPDomain(v)&&h.filter(function(T){return matchDomain(T,v)}).length===0){var A=new NetworkFirbiddenError(l,"Image","request host(".concat(v,") is not allowed"));r(A),c(A),(f=t.networkSubscribe)===null||f===void 0||f.emit("network",l,"Image","forbidden",A.message);return}var m=o??new Image,y=!1,p=null,g=function(){var T;if(m.onload=noop$1,m.onerror=noop$1,p!==null&&(clearTimeout(p),p=null),y!==!0){var _=now(),w={headers:{},origin:u,source:l,requestTime:s,responseTime:_,costs:_-s};y=!0;var x={body:m,meta:w};i(1),e(x),d(x),(T=t.networkSubscribe)===null||T===void 0||T.emit("network",l,"Image","ok",JSON.stringify(x.meta))}},b=function(){var T;if(m.onload=noop$1,m.onerror=noop$1,p!==null&&(clearTimeout(p),p=null),y!==!0){y=!0;var _=new NetworkResponseError(l,"Image",0);r(_),c(_),(T=t.networkSubscribe)===null||T===void 0||T.emit("network",l,"Image","ok",_.message)}};typeof t.timeout=="number"&&(p=window.setTimeout(function(){var T;if(m.onload=noop$1,m.onerror=noop$1,p=null,y!==!0){y=!0;var _=new NetworkTimeoutError(l,"Image",t.timeout);r(_),c(_),(T=t.networkSubscribe)===null||T===void 0||T.emit("network",l,"Image","timeout",_.message)}},t.timeout)),m.onload=g,m.onerror=b,i(0),m.src=l})})}var Fetcher=function(){function n(t){t===void 0&&(t={}),this.options=deepFreeze(t)}return n.prototype.ajax=function(t,e,r,i,o){var s;e===void 0&&(e={}),r===void 0&&(r=noop$1),i===void 0&&(i=noop$1),o===void 0&&(o=noop$1);var u=this.options,l={responseType:e.responseType,timeout:(s=e.timeout)!==null&&s!==void 0?s:u.timeout,get allowHosts(){var d;return(d=e.allowHosts)!==null&&d!==void 0?d:u.allowHosts},get requestProxy(){var d;return(d=e.requestProxy)!==null&&d!==void 0?d:u.requestProxy},get networkSubscribe(){var d;return(d=e.networkSubscribe)!==null&&d!==void 0?d:u.networkSubscribe}};return ajax(t,l,r,i,o)},n.prototype.loadImage=function(t,e,r,i,o,s){var u;e===void 0&&(e={}),r===void 0&&(r=noop$1),i===void 0&&(i=noop$1),o===void 0&&(o=noop$1);var l=this.options,d={timeout:(u=e.timeout)!==null&&u!==void 0?u:l.timeout,get allowHosts(){var c;return(c=e.allowHosts)!==null&&c!==void 0?c:l.allowHosts},get requestProxy(){var c;return(c=e.requestProxy)!==null&&c!==void 0?c:l.requestProxy},get networkSubscribe(){var c;return(c=e.networkSubscribe)!==null&&c!==void 0?c:l.networkSubscribe}};return loadImage(t,d,r,i,o,s)},n.prototype.preload=function(t,e){var r;e===void 0&&(e={});var i=this.options,o={timeout:(r=e.timeout)!==null&&r!==void 0?r:i.timeout,get allowHosts(){var s;return(s=e.allowHosts)!==null&&s!==void 0?s:i.allowHosts},get requestProxy(){var s;return(s=e.requestProxy)!==null&&s!==void 0?s:i.requestProxy},get networkSubscribe(){var s;return(s=e.networkSubscribe)!==null&&s!==void 0?s:i.networkSubscribe}};return preload(t,o)},n}(),internalFetcher=new Fetcher,_requestAnimationFrame=function(){if(typeof window<"u"){var n=window;return n.requestAnimationFrame||n.mozRequestAnimationFrame||n.webkitRequestAnimationFrame||n.msRequestAnimationFrame||function(t){return setTimeout(t,16)}}else return function(t){return setTimeout(t,16)}}(),_cancelAnimationFrame=function(n){var t;if(typeof window<"u"){var e=window;t=e.cancelAnimationFrame||e.mozCancelAnimationFrame||e.webkitCancelAnimationFrame||e.msCancelAnimationFrame||function(r){return window.clearTimeout(r)}}else t=function(r){return window.clearTimeout(r)};t(n)},DEFAULT_ORDER=5,deviceFrameTime=16,AnimationFrameLoop=function(){function n(){this.frames=[],this.stoped=!1,this.time=now(),this.context=null,this.loop=this.loop.bind(this),this.loop()}return Object.defineProperty(n,"shared",{get:function(){return this.sharedInstance||(this.sharedInstance=new n),this.sharedInstance},enumerable:!1,configurable:!0}),n.getFrameTime=function(){return deviceFrameTime},n.prototype.loop=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];if(!this.stoped){var r=now(),i=r-this.time;this.time=r;var o=[];deviceFrameTime=i;for(var s=0,u=this.frames;s<u.length;s++){var l=u[s];if(l.delay>0){l.delay=l.delay-1;continue}try{l.callback.apply(l,__spreadArray([r,i],t,!1))}catch(d){console.error(d)}l.once&&o.push(l)}o.length>0&&(this.frames=this.frames.filter(function(d){return o.indexOf(d)===-1})),this.requestAnimationFrame(this.loop)}},n.prototype.setContext=function(t){this.cancelAnimationFrame(this.requestId),this.context=t,this.requestId=this.requestAnimationFrame(this.loop)},n.prototype.getContext=function(){return this.context},n.prototype.requestAnimationFrame=function(t){return this.context?this.context.requestAnimationFrame(t):_requestAnimationFrame(t)},n.prototype.cancelAnimationFrame=function(t){this.context?this.context.cancelAnimationFrame(t):_cancelAnimationFrame(this.loop),this.requestId=null},n.prototype.remove=function(t){var e=this.frames.indexOf(t);e>=0&&this.frames.splice(e,1)},n.prototype.add=function(t,e,r,i){var o=this;e===void 0&&(e=!1),r===void 0&&(r=0),i===void 0&&(i=DEFAULT_ORDER);var s={callback:t,once:e,delay:r,order:i};return this.frames.push(s),this.frames.sort(function(u,l){return u.order-l.order}),function(){return o.remove(s)}},n.prototype.disponse=function(){this.stoped=!0,this.frames.length=0},n}(),DEFAULT_IMAGE_URL_MAPPINGS={"vrlab-public.ljcdn.com":{type:"tencentCloud",pano:["vrlab-image1.ljcdn.com","vrlab-image2.ljcdn.com"],texture:["vrlab-image3.ljcdn.com"],tile:["vr-tile-1.realsee-cdn.cn","vr-tile-2.realsee-cdn.cn"],model:["vr-model-1.realsee-cdn.cn","vr-model-2.realsee-cdn.cn"],default:["vrlab-image4.ljcdn.com"]},"vr-public.realsee-cdn.cn":{type:"tencentCloud",pano:["vr-image-1.realsee-cdn.cn","vr-image-2.realsee-cdn.cn"],texture:["vr-image-3.realsee-cdn.cn"],tile:["vr-tile-1.realsee-cdn.cn","vr-tile-2.realsee-cdn.cn"],model:["vr-model-1.realsee-cdn.cn","vr-model-2.realsee-cdn.cn"],default:["vr-image-4.realsee-cdn.cn"]},"vr-public.rscdn.cn":{type:"tencentCloud",pano:["vr-image-1.rscdn.cn","vr-image-2.rscdn.cn"],texture:["vr-image-3.rscdn.cn"],tile:["vr-tile-1.rscdn.cn","vr-tile-2.rscdn.cn"],model:["vr-model-1.rscdn.cn","vr-model-2.rscdn.cn"],default:["vr-image-4.rscdn.cn"]},"mars-public.realsee-cdn.cn":{type:"aliyun",pano:["mars-image-1.realsee-cdn.cn","mars-image-2.realsee-cdn.cn"],texture:["mars-image-3.realsee-cdn.cn"],tile:["mars-tile-1.realsee-cdn.cn","mars-tile-2.realsee-cdn.cn"],model:["mars-model-1.realsee-cdn.cn","mars-model-2.realsee-cdn.cn"],default:["mars-image-4.realsee-cdn.cn"]},"global-public.realsee-cdn.com":{type:"tencentCloud",pano:["global-image-1.realsee-cdn.com","global-image-2.realsee-cdn.com"],texture:["global-image-3.realsee-cdn.com"],tile:["global-tile-1.realsee-cdn.com","global-tile-2.realsee-cdn.com"],model:["global-model-1.realsee-cdn.com","global-model-2.realsee-cdn.com"],default:["global-image-4.realsee-cdn.com"]},"earth-ga-public.realsee-cdn.cn":{type:"tencentCloud",pano:["earth-ga-image-1.realsee-cdn.cn","earth-ga-image-2.realsee-cdn.cn"],texture:["earth-ga-image-3.realsee-cdn.cn"],tile:["earth-ga-tile-1.realsee-cdn.cn","earth-ga-tile-2.realsee-cdn.cn"],model:["earth-ga-model-1.realsee-cdn.cn","earth-ga-model-2.realsee-cdn.cn"],default:["earth-ga-image-4.realsee-cdn.cn"]},"test-vr-public.realsee-cdn.com":{type:"tencentCloud",pano:["test-vr-image.realsee-cdn.com","test-vr-image.realsee-cdn.com"],texture:["test-vr-image.realsee-cdn.com"],tile:["test-vr-image.realsee-cdn.com","test-vr-image.realsee-cdn.com"],model:["test-vr-image.realsee-cdn.com","test-vr-image.realsee-cdn.com"],default:["test-vr-image.realsee-cdn.com"]},"test-vr-public.realsee-cdn.cn":{type:"tencentCloud",pano:["test-vr-image.realsee-cdn.cn","test-vr-image.realsee-cdn.cn"],texture:["test-vr-image.realsee-cdn.cn"],tile:["test-vr-image.realsee-cdn.cn","test-vr-image.realsee-cdn.cn"],model:["test-vr-image.realsee-cdn.cn","test-vr-image.realsee-cdn.cn"],default:["test-vr-image.realsee-cdn.cn"]}},URL_DOMAIN_REGEX=/^https?\:\/\/?([^\/]+)/;function getDomain(n){var t=n.match(URL_DOMAIN_REGEX);return t===null?null:t[1]}function replaceDomain(n,t){return n.replace(URL_DOMAIN_REGEX,function(e,r){return e.slice(0,e.length-r.length)+t})}function route(n,t,e){var r=t.split("."),i=r[0],o=r.slice(1);if(i==="texture")return replaceDomain(n,e.texture[0]);if(i==="pano"||i==="pano_luminance"){o[0];var s=o[1];switch(s){case"front":case"left":case"up":return replaceDomain(n,e.pano[0]);case"down":case"right":case"back":return replaceDomain(n,e.pano[1])}}else if(i==="pano_tile"||i==="pano_tile_luminance"){o[0],o[1];var u=o[2],l=o[3],d=o[4],c=Math.pow(2,Number(u))*Number(l)+Number(d);if(!isNaN(c))return replaceDomain(n,e.tile[c%2])}else if(i==="model"){var f=o[0],c=Number(f);if(!isNaN(c))return replaceDomain(n,e.model[c%2])}return replaceDomain(n,e.default[0])}var tencentCloudImageProcesser=function(n,t){var e,r=n.split("?")[0],i=r.split(".").pop();if(i==="jpeg"&&(i="jpg"),i!=="png"&&i!=="jpg")return n;var o="";if(t.format!==void 0&&t.format!==i&&(o+="/format/".concat(t.format)),t.cut!==void 0&&(o+="/cut/".concat(t.cut[2],"x").concat(t.cut[3],"x").concat(t.cut[0],"x").concat(t.cut[1])),t.quality!==void 0){var s=(e=t.format)!==null&&e!==void 0?e:i;s&&["jpg","webp","tpg","heif","avif"].indexOf(s)>=0&&(o+="/quality/".concat(t.quality))}if(t.size!==void 0){var u=n.match(/\/cube_(\d+)\//),l=u?Number(u[1]):NaN;l!==Number(t.size)&&(o+="/thumbnail/".concat(t.size,"x"))}return t.sharpen!==void 0&&(o+="/sharpen/".concat(t.sharpen)),o.length&&(o="?imageMogr2"+o),r+o},aliyunOOSImageProcesser=function(n,t){var e,r=n.split("?")[0],i=r.split(".").pop();if(i==="jpeg"&&(i="jpg"),i!=="png"&&i!=="jpg")return n;var o="",s=[],u=t.format,l=t.quality,d=t.size;if(u!==void 0&&u!==i&&s.push("format,".concat(u==="heif"?"heic":u)),t.cut!==void 0){var c=t.cut,f=c[0],h=c[1],v=c[2],A=c[3];s.push("crop,x_".concat(f,",y_").concat(h,",w_").concat(v,",h_").concat(A,",g_nw"))}if(l!==void 0&&l!==100){var m=(e=t.format)!==null&&e!==void 0?e:i;m&&["jpg","webp"].indexOf(m)>=0&&s.push("quality,Q_".concat(l))}return d&&d!==2048&&s.push("resize,w_".concat(d)),t.sharpen!==void 0&&s.push("sharpen,".concat(t.sharpen)),s.length&&(o="?x-oss-process=image/"+s.join("/")),r+o};function imageURL(n,t){var e=__assign(__assign({},DEFAULT_IMAGE_URL_MAPPINGS),t.mappings),r=getDomain(n);if(r===null)return n;var i=e[r];return i?(n=route(n,t.key,i),/\.basis(\?|$)/.test(n)&&(n=n.replace(/\.basis(\?|$)/,".jpg$1")),i.type==="tencentCloud"?tencentCloudImageProcesser(n,t):i.type==="aliyun"?aliyunOOSImageProcesser(n,t):n):n}function applyImageURLOptions(n,t,e){t===void 0&&(t=imageURL);var r=t(n,e);if(r===n&&e.cut)throw new Error("ImageURL: cut option not applied.");return r}var webp="data:image/webp;base64,UklGRiQAAABXRUJQVlA4IBgAAAAwAQCdASoCAAIAAUAmJaQAA3AA/vz0AAA=",avif="data:image/avif;base64,AAAAIGZ0eXBhdmlmAAAAAGF2aWZtaWYxbWlhZk1BMUIAAAGhbWV0YQAAAAAAAAAoaGRscgAAAAAAAAAAcGljdAAAAAAAAAAAAAAAAGxpYmF2aWYAAAAADnBpdG0AAAAAAAEAAAAsaWxvYwAAAABEAAACAAEAAAABAAAB3gAAABkAAgAAAAEAAAHJAAAAFQAAAEJpaW5mAAAAAAACAAAAGmluZmUCAAAAAAEAAGF2MDFDb2xvcgAAAAAaaW5mZQIAAAAAAgAAYXYwMUFscGhhAAAAABppcmVmAAAAAAAAAA5hdXhsAAIAAQABAAAA12lwcnAAAACxaXBjbwAAABRpc3BlAAAAAAAAAAIAAAACAAAAEHBpeGkAAAAAAwgICAAAAAxhdjFDgQAMAAAAABNjb2xybmNseAACAAIAAoAAAAAUaXNwZQAAAAAAAAACAAAAAgAAAA5waXhpAAAAAAEIAAAADGF2MUOBABwAAAAAOGF1eEMAAAAAdXJuOm1wZWc6bXBlZ0I6Y2ljcDpzeXN0ZW1zOmF1eGlsaWFyeTphbHBoYQAAAAAeaXBtYQAAAAAAAAACAAEEAQKDBAACBAUGhwgAAAA2bWRhdBIACgQYADLVMgsWQBhhIAQqrNj/+BIACgUYADLEoDIOFkADDDDCQAACDaqCCb4=",heif="data:image/heif;base64,AAAAGGZ0eXBoZWljAAAAAG1pZjFoZWljAAABL21ldGEAAAAAAAAAIWhkbHIAAAAAAAAAAHBpY3QAAAAAAAAAAAAAAAAAAAAADnBpdG0AAAAAAAEAAAAjaWluZgAAAAAAAQAAABVpbmZlAgAAAAABAABodmMxAAAAAK9pcHJwAAAAkmlwY28AAAB2aHZjQwEBYAAAAAAAAAAAAADwAPz9+PgAACcDoAABAB5AAQwG//8BYAAAAwAAAwAAAwAAAwAAAwAAreTLgSChAAEAI0IBBwFgAAADAAADAAADAAADAAADAAChInJJlreTLySZNdggogABAAdEAcA98DMkAAAAFGlzcGUAAAAAAAAAAgAAAAIAAAAVaXBtYQAAAAAAAAABAAECgQIAAAAiaWxvYwAAAABEQAABAAEAAAAAAU8AAQAAAAAAAAAOAAAAFm1kYXQAAAAKJgGvLvkQwuWM4A==";function checkImage(n){return new Promise(function(t){var e=new Image,r=setTimeout(function(){e.onload=e.onerror=function(){},clearTimeout(r),t(!1)},100);e.onload=e.onerror=function(){e.onload=e.onerror=function(){},clearTimeout(r),t(e.height===2)},e.src=n})}var imageSupportCache=null;function imageSupport(){return imageSupportCache||(imageSupportCache=Promise.all([checkImage(webp),checkImage(avif),checkImage(heif)]).then(function(n){return{webp:n[0],avif:n[1],heif:n[2]}}))}var PANO_ID_REG=/^(.*)\[(\d+)\]$/;function panoStringify(n){if(!isNaN(n.panoIndex)&&isFinite(n.panoIndex))return"".concat(n.workCode,"[").concat(n.panoIndex,"]");throw new Error("Invalid Pano")}function panoParse(n){var t=n.match(PANO_ID_REG);if(t){t[0];var e=t[1],r=t[2],i=Math.floor(Number(r));if(!isNaN(i)&&isFinite(i))return{workCode:e,panoIndex:i}}throw new Error("Invalid PanoId")}function panoEqual(n,t){return panoStringify(n)===panoStringify(t)}function isPanoId(n){return typeof n=="string"&&PANO_ID_REG.test(n)}var PBMGroup=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t}(THREE__namespace.Group),PBMMesh=function(n){__extends(t,n);function t(e,r){var i=n.call(this,e,r)||this;return i.onBeforeRender=onBeforeRender$1,i}return t}(THREE__namespace.Mesh);function onBeforeRender$1(n,t,e){for(var r=0,i=this.material;r<i.length;r++){var o=i[r];this.model&&o.syncModel(this.model),o.update(n,e)}}var gradientTexture=new THREE__namespace.TextureLoader().load("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAABCAYAAACouxZ2AAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAACAKADAAQAAAABAAAAAQAAAAB7UD0+AAACA0lEQVRIDXWUW3YjIQxEwdnV/GT/q8kO3FO3pAJst3PSAaR6Cbszf//9XeMxxpjXmI+pVXudp2s6PC4dqHff9e6D7/PZLy46xQvG+sZvrfK8xgXUeq85yINe9bdmtOK1+kun5vjgq58a+eZPna9jvmjiserqG/+Whathvo3L3WhV89L9sXI/m18z2uene9ap/ftsuT9WZxoHXzW56/fpj8l7+tTw7P011NdpqnY19sRsfuHMA9u8oZWfDz4+fra/dfG1V60ydZ7qba1g7UNAeK0JP7ydD7/OqH6wO2f7HTq+B/lbL9qsB3/N1/UzR81XfPzw4tp5OPvRneacteq8Xo0xR3vuv/kPz0KtX0Nhg0eHuaNXdWI3X/ld427h++vzyp99V6VPrzWFhbv4ayay4oFecm198MmUXN/mL+x7npq/uJXBGb/MTw4+t+SvbLoTZnUW5uHhz7nWcTxT73OwXV7cxT9wbBf/0LnDBgcnHmtPLYba32Hp808sMy1u88yhr58n70/v4xX92GSN19l/2UsqGmiH94Hpxjcs+DO/ccpIVNVp62PUWXu//ur1GQy1Cf+GZ13rtNYN1po3/NI79fGXibHkq4z25xvV2pW3szpneXsW8SsreTe/NIPrtXMnH7wPf+LEN6tqhUVHj3XKD/72p9eafCeYB3zuonnbv7yqP8d/o4K6gRb1wbYAAAAASUVORK5CYII=");gradientTexture.minFilter=THREE__namespace.NearestFilter,gradientTexture.magFilter=THREE__namespace.NearestFilter,gradientTexture.wrapS=THREE__namespace.RepeatWrapping,gradientTexture.wrapT=THREE__namespace.RepeatWrapping;var defaultPbmParameters={pano0:null,pano1:null,shownFloorIndex:-1,modelAlpha:1,opacity:1,progress:0,useBlackTransition:!1,clippers:null,constantColor:null,useEDL:!1,useHQWeight:!1,useHQDepth:!1,pointColor:"RGB",pointSize:"ATTENUATION",pointBack:"DARK",pointShape:"SQUARE",pointScale:.03,pointMaxPixel:40,pointMinPixel:.5,gradientTexture};function isEqualClipperParameters(n,t){var e=n??[],r=t??[];if(r.length!==e.length)return!1;for(var i=0;i<r.length;i++)if(!e[i].clippingBoxMatrix.equals(r[i].clippingBoxMatrix)||e[i].floorIndex!==r[i].floorIndex)return!1;return!0}function isEqualPBMPanoPicture(n,t){return n&&t?n.luminanceMap===t.luminanceMap&&n.map===t.map&&n.matrix.equals(t.matrix):!n&&!t}function updatePBMParameters(n,t){var e=!1;for(var r in t)switch(r){case"clippers":isEqualClipperParameters(n[r],t[r])||(n[r]=t[r],e=!0);break;case"pano0":case"pano1":isEqualPBMPanoPicture(n[r],t[r])||(n[r]=t[r],e=!0);break;default:n[r]!==t[r]&&(n[r]=t[r],e=!0);break}return e}var PBMPointCloud=function(n){__extends(t,n);function t(e,r){var i=n.call(this,e,r)||this;return i.onBeforeRender=onBeforeRender,i}return t}(THREE__namespace.Points);function onBeforeRender(n,t,e){this.model&&this.material.syncModel(this.model),this.material.update(n,e)}var scratchMaterialSet=new Set,PBMContainer=function(n){__extends(t,n);function t(){var e=n.call(this)||this;return e.needsRender=!0,e.pbmMaterialParametersVersion=0,e.materialParameters=__assign({},defaultPbmParameters),e}return t.prototype.getMaterial=function(){return __assign({},this.materialParameters)},t.prototype.setMaterial=function(e){var r=this;Object.assign(this.materialParameters,e),scratchMaterialSet.clear(),this.traverse(function(i){if(i instanceof PBMMesh)for(var o=0,s=i.material;o<s.length;o++){var u=s[o];scratchMaterialSet.has(u)||(Object.assign(u,r.materialParameters),scratchMaterialSet.add(u))}i instanceof PBMPointCloud&&(scratchMaterialSet.has(i.material)||(Object.assign(i.material,r.materialParameters),scratchMaterialSet.add(i.material)))}),scratchMaterialSet.clear(),this.needsRender=!0},t}(THREE__namespace.Group),FACE_ORDER$1=["right","left","up","down","front","back"];function getBox(n,t,e,r){var i=new THREE__namespace.Box3;switch(n){case"up":i.min.y=.5,i.max.y=.5,i.min.x=+t-.5,i.max.x=+t-.5+r,i.min.z=-e+.5-r,i.max.z=-e+.5;break;case"down":i.min.y=-.5,i.max.y=-.5,i.min.x=+t-.5,i.max.x=+t-.5+r,i.min.z=+e-.5,i.max.z=+e-.5+r;break;case"left":i.min.x=-.5,i.max.x=-.5,i.min.z=-t+.5-r,i.max.z=-t+.5,i.min.y=-e+.5-r,i.max.y=-e+.5;break;case"right":i.min.x=.5,i.max.x=.5,i.min.z=+t-.5,i.max.z=+t-.5+r,i.min.y=-e+.5-r,i.max.y=-e+.5;break;case"front":i.min.z=-.5,i.max.z=-.5,i.min.x=+t-.5,i.max.x=+t-.5+r,i.min.y=-e+.5-r,i.max.y=-e+.5;break;case"back":i.min.z=.5,i.max.z=.5,i.min.x=-t+.5-r,i.max.x=-t+.5,i.min.y=-e+.5-r,i.max.y=-e+.5;break}return i.applyMatrix4(new THREE__namespace.Matrix4().makeRotationY(Math.PI))}var createChildren=function(n,t){if(!(n.level>=t))for(var e=n.level+1,r=n.size/2,i=[new THREE__namespace.Vector2(n.position.x,n.position.y),new THREE__namespace.Vector2(n.position.x+r,n.position.y),new THREE__namespace.Vector2(n.position.x,n.position.y+r),new THREE__namespace.Vector2(n.position.x+r,n.position.y+r)],o=0,s=i;o<s.length;o++){var u=s[o],l={face:n.face,level:e,size:r,position:u,box:getBox(n.face,u.x,u.y,r),children:[]};n.children.push(l),createChildren(l,t)}};function createTileCubeNode(n,t){var e={level:0,face:n,position:new THREE__namespace.Vector2(0,0),size:1,box:getBox(n,0,0,1),children:[]};return createChildren(e,t),e}function createTileCubeTree(n){var t=FACE_ORDER$1.map(function(e){return createTileCubeNode(e,n)});return{children:t}}function traverseTileCubeNode(n,t){for(var e=0,r=n.children;e<r.length;e++){var i=r[e],o=t(i);o!==!1&&traverseTileCubeNode(i,t)}}var CUBE_GEOMETRY=new THREE__namespace.BoxBufferGeometry(1,1,1,1,1);CUBE_GEOMETRY.deleteAttribute("uv"),CUBE_GEOMETRY.deleteAttribute("normal"),CUBE_GEOMETRY.groups=[],CUBE_GEOMETRY.scale(-1,1,1);var CUBE_VERTEX_SHADER=`
|
|
392
392
|
varying vec3 worldPosition;
|
|
393
393
|
void main() {
|
|
394
394
|
vec4 transform = vec4(position, 1.0);
|
|
@@ -414,7 +414,7 @@ varying vec2 vUv;
|
|
|
414
414
|
void main() {
|
|
415
415
|
gl_FragColor = texture2D(map, vUv);
|
|
416
416
|
}
|
|
417
|
-
`,cacheMaterials=[];function getMaterial(){var n=cacheMaterials.pop();return n||new THREE__namespace.ShaderMaterial({uniforms:{map:{value:null},flipY:{value:0}},vertexShader:PLANE_VERTEX_SHADER,fragmentShader:PLANE_FRAGMENT_SHADER,depthTest:!1,depthWrite:!1,stencilWrite:!1,blending:THREE__namespace.NoBlending,lights:!1,toneMapped:!1,fog:!1})}function releaseMaterial(n){n.uniforms.map.value=null,cacheMaterials.push(n)}function renderTexturesToCubeRenderTarget(n,t,e){var r=new THREE__namespace.Scene;r.matrixAutoUpdate=!1;var i=new THREE__namespace.Group;i.scale.set(1,1,-1),r.add(i);for(var o=[],s=0,u=n;s<u.length;s++){var l=u[s],d=getMaterial();o.push(d),d.uniforms.map.value=l.texture,d.uniforms.flipY.value=l.flipY?1:0;var c=new THREE__namespace.Group,f=new THREE__namespace.Mesh(PLAME_GEOMETRY,d);f.position.set(l.position.x+l.size.x/2-.5,1-(l.position.y+l.size.y/2)-.5,-.5),f.scale.set(l.size.x,l.size.y,1),c.quaternion.copy(QUATERNION[l.face]),c.add(f),i.add(c)}var h=e.autoClear;e.autoClear=!1;var v=new THREE__namespace.CubeCamera(.1,2,t);v.matrixAutoUpdate=!1,v.update(e,r),e.autoClear=h;for(var A=0,m=o;A<m.length;A++){var d=m[A];releaseMaterial(d)}}var asyncImageTaskQueue=[],IMAGE_TASK_EACH_FRAME=6,imageTaskEachFrame=0;AnimationFrameLoop.shared.add(function(){if(imageTaskEachFrame=IMAGE_TASK_EACH_FRAME,asyncImageTaskQueue.length)for(var n=asyncImageTaskQueue.splice(0,imageTaskEachFrame),t=0,e=n;t<e.length;t++){var r=e[t];imageTaskEachFrame--,r()}});var hasImageBitmap=!!window.ImageBitmap,canUseNativeImageBitmap=function(){return!1}();function createImageBitmapLikeImage(){var n=Object.assign(document.createElementNS("http://www.w3.org/1999/xhtml","img"),{crossOrigin:"",close:function(){n.onerror=n.onload=n.close=noop$1,n.removeAttribute("src"),/^blob\:/.test(n.src)&&URL.revokeObjectURL(n.src)}});return n}function createImageBitmapLike(n){return new Promise(function(t,e){var r=createImageBitmapLikeImage();r.onload=function(){/^blob\:/.test(r.src)&&URL.revokeObjectURL(r.src),r.onload=r.onerror=noop$1,setTimeout(function(){t(r)},0)},r.onerror=function(){var i=r.src;r.onload=r.onerror=noop$1,r.close(),e(new Error("image load error: ".concat(i)))},r.src=URL.createObjectURL(n)})}function createImageBitmapLikeAsync(n){return new Promise(function(t){asyncImageTaskQueue.push(function(){t(createImageBitmapLike(n))})})}var canvasPool=[];function createCanvas(n,t){var e=canvasPool.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=noop$1,canvasPool.push(r)}});return r}function poolImageToTexture(n,t){if(t&&(n.width>t.width||n.height>t.height)){var e=createCanvas(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 THREE__namespace.Texture(e);i.needsUpdate=!0,i.flipY=!0;var o=i.dispose;return i.dispose=function(){e.close(),o.call(i),i.dispose=o},i}else{var s=new THREE__namespace.Texture(n);s.needsUpdate=!0,hasImageBitmap&&n instanceof ImageBitmap?s.flipY=!1:s.flipY=!0;var u=s.dispose;return s.dispose=function(){n.close(),u.call(s),s.dispose=u},s}}function poolImagesToCubeTexture(n){var t=new THREE__namespace.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 o=i[r];o.close()}e.call(t),t.dispose=e},t}var FACE_ORDER=["right","left","up","down","front","back"],MAX_TILE_RENDER_EACH_FRAME=4,TileCubeTextureTarget=function(){function n(t,e,r,i,o){this.tileTree=e,this.tileSources=r,this.options=i,this.renderer=o,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,o,s;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:THREE__namespace.RGBAFormat,t.texture.minFilter=(r=this.options.minFilter)!==null&&r!==void 0?r:THREE__namespace.LinearFilter,t.texture.magFilter=(i=this.options.magFilter)!==null&&i!==void 0?i:THREE__namespace.LinearFilter,t.texture.wrapS=(o=this.options.wrapS)!==null&&o!==void 0?o:THREE__namespace.ClampToEdgeWrapping,t.texture.wrapT=(s=this.options.wrapT)!==null&&s!==void 0?s:THREE__namespace.ClampToEdgeWrapping,this.baseCubeTexture&&(renderCubeTextureToCubeRenderTarget(this.baseCubeTexture,t,this.renderer),this.baseCubeTexture.dispose(),this.baseCubeTexture=null),this._cubeRenderTarget&&renderCubeTextureToCubeRenderTarget(this._cubeRenderTarget.texture,t,this.renderer),this._cubeRenderTarget=t},enumerable:!1,configurable:!0}),n.prototype.requestTile=function(t){var e=this,r,i,o,s,u,l,d=this.tileSources.filter(function(m){return m.level===t.level})[0];if(!d){this.loadedCubeNodes.add(t);return}var c=d.size,f=Math.pow(2,t.level)*t.position.y,h=Math.pow(2,t.level)*t.position.x,v="".concat(((o=(i=(r=this.options.imageURL)===null||r===void 0?void 0:r.options)===null||i===void 0?void 0:i.key)!==null&&o!==void 0?o:"pano.0").replace(/^pano/,"pano_tile"),".").concat(t.face,".").concat(t.level,".").concat(f,".").concat(h),A=__assign(__assign({},(u=(s=this.options.imageURL)===null||s===void 0?void 0:s.options)!==null&&u!==void 0?u:{key:"unknown"}),{key:v,size:c*t.size===this.options.tileImageSize?void 0:this.options.tileImageSize,quality:void 0,cut:[c*t.position.x,c*t.position.y,c*t.size,c*t.size]});this.loadingCubeNodes.add(t),this.options.textureLoader.loadTexture(d[t.face],{imageURL:{transform:(l=this.options.imageURL)===null||l===void 0?void 0:l.transform,options:__assign({},A)},format:THREE__namespace.RGBAFormat,viaAjax:canUseNativeImageBitmap,timeout:this.options.timeout,fetcher:this.options.fetcher}).then(function(m){if(e.disposed){m.body.dispose();return}e.textures.push({face:t.face,level:t.level,position:t.position,size:new THREE__namespace.Vector2(t.size,t.size),texture:m.body,flipY:!m.body.flipY}),e.loadedCubeNodes.add(t)}).catch(noop$1).then(function(){e.disposed||e.loadingCubeNodes.delete(t)})},n.prototype.update=function(t,e){var r=this;if(!this.disposed){var i=[];traverseTileCubeNode(this.tileTree,function(h){if(r.loadingCubeNodes.has(h)||h.level>e||!t.intersectsBox(h.box))return!1;if(!r.loadedCubeNodes.has(h))return i.push(h),!1});for(var o=0,s=i;o<s.length;o++){var u=s[o];this.requestTile(u)}if(this.cubeRenderTarget&&this.textures.length){var l=this.textures.splice(0,MAX_TILE_RENDER_EACH_FRAME);renderTexturesToCubeRenderTarget(l,this.cubeRenderTarget,this.renderer),this.needsRender=!0;for(var d=0,c=l;d<c.length;d++){var f=c[d];f.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}(),TextureLoader=function(){function n(){}return n.prototype.loadTexture=function(t,e,r,i,o,s){var u,l,d,c;r===void 0&&(r=noop$1),i===void 0&&(i=noop$1),o===void 0&&(o=noop$1);var f={};typeof e.flipY<"u"&&(f.flipY=e.flipY),typeof e.format<"u"&&(f.format=e.format),typeof e.minFilter<"u"&&(f.minFilter=e.minFilter),typeof e.magFilter<"u"&&(f.magFilter=e.magFilter);var h=(l=(u=e.imageURL)===null||u===void 0?void 0:u.options)!==null&&l!==void 0?l:{key:"unknown"};t=applyImageURLOptions(t,(d=e.imageURL)===null||d===void 0?void 0:d.transform,h);var v=getProtocol(t),A=(c=e.viaAjax)!==null&&c!==void 0?c:!1,m=isJsonpSource(t),y=/^https?:/.test(v);if(m?A=!0:y||(A=!1),A){var p=null,g="blob";return e.fetcher.ajax(t,{timeout:e.timeout,responseType:g},void 0,void 0,o).then(function(_){return createImageBitmapLikeAsync(_.body)}).then(function(_){return poolImageToTexture(_,e.maxSize)}).then(function(_){return Object.assign(_,f),_}).then(function(_){var w={meta:p,body:_};return r(w),w}).catch(function(_){return i(_),Promise.reject(_)})}else{var b=null,T;return Promise.resolve().then(function(){return createImageBitmapLikeImage()}).then(function(_){return T=_,e.fetcher.loadImage(t,{timeout:e.timeout},void 0,void 0,o,_)}).then(function(_){return b=_.meta,poolImageToTexture(_.body,e.maxSize)}).then(function(_){return Object.assign(_,f),_}).then(function(_){var w={meta:b,body:_};return r(w),w}).catch(function(_){return T&&T.close(),i(_),Promise.reject(_)})}},n.prototype.loadCubeTexture=function(t,e,r,i,o,s){var u,l,d,c;r===void 0&&(r=noop$1),i===void 0&&(i=noop$1),o===void 0&&(o=noop$1),typeof e.format<"u"&&e.format,typeof e.minFilter<"u"&&e.minFilter,typeof e.magFilter<"u"&&e.magFilter;for(var f=[t[FACE_ORDER[0]],t[FACE_ORDER[1]],t[FACE_ORDER[2]],t[FACE_ORDER[3]],t[FACE_ORDER[4]],t[FACE_ORDER[5]]],h=[],v=[0,0,0,0,0,0],A=[],m=function(p){var g=(l=(u=e.imageURL)===null||u===void 0?void 0:u.options)!==null&&l!==void 0?l:{key:"unknown"},b=applyImageURLOptions(f[p],(d=e.imageURL)===null||d===void 0?void 0:d.transform,__assign(__assign({},g),{key:g.key+"."+FACE_ORDER[p]})),T=getProtocol(b),_=function(B){v[p]=B,o(v.reduce(function(F,O){return F+O},0)/6)},w=(c=e.viaAjax)!==null&&c!==void 0?c:!1,x=/^https?:$/.test(T),M=isJsonpSource(b);if(M?w=!0:x||(w=!1),w){var R="blob",I=e.fetcher.ajax(b,{timeout:e.timeout,responseType:R},void 0,void 0,_).then(function(B){return A[p]=B.meta,createImageBitmapLikeAsync(B.body)});h.push(I)}else{var S,I=Promise.resolve().then(function(){return createImageBitmapLikeImage()}).then(function(F){return S=F,e.fetcher.loadImage(b,{timeout:e.timeout},void 0,void 0,_,F)}).then(function(F){return A[p]=F.meta,F.body}).catch(function(F){return S&&S.close(),Promise.reject(F)});h.push(I)}},y=0;y<6;y++)m(y);return Promise.all(h).then(function(p){return poolImagesToCubeTexture(p)}).then(function(p){return Object.assign(p,__assign({encoding:THREE__namespace.sRGBEncoding},e)),p}).then(function(p){var g={body:p,meta:A};return r(g),g}).catch(function(p){for(var g=0,b=h;g<b.length;g++){var T=b[g];T.then(function(_){return _.close()}).catch(noop$1)}return i(p),Promise.reject(p)})},n.prototype.loadTiledCubeTexture=function(t,e,r,i,o,s,u){var l=this;return i===void 0&&(i=noop$1),o===void 0&&(o=noop$1),s===void 0&&(s=noop$1),new Promise(function(d,c){var f,h;l.loadCubeTexture(t,{imageURL:{transform:(f=r.imageURL)===null||f===void 0?void 0:f.transform,options:(h=r.imageURL)===null||h===void 0?void 0:h.options},format:THREE__namespace.RGBAFormat,viaAjax:r.viaAjax,timeout:r.timeout,fetcher:r.fetcher},function(v){var A,m,y=v.meta,p=v.body,g=(A=r.tileImageSize)!==null&&A!==void 0?A:512,b=(m=r.tileMaxLevel)!==null&&m!==void 0?m:2,T=Math.max(1024*b,512),_=createTileCubeTree(b),w=new TileCubeTextureTarget(p,_,e,{textureSize:T,tileImageSize:g,textureLoader:l,imageURL:r.imageURL,timeout:r.timeout,fetcher:r.fetcher},u),x={meta:y,body:w};i(x),d(x)},function(v){o(v),c(v)},s,u).catch(noop$1)})},n}();const vertexShader$6=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}("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"),fragmentShader$6=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}("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 EMPTY_CUBE_TEXTURE=new THREE__namespace.WebGLCubeRenderTarget(1).texture;EMPTY_CUBE_TEXTURE.name="EMPTY_TEXTURE";var shaderUniforms$2=Object.assign({modelAlpha:new THREE__namespace.Uniform(0),progress:new THREE__namespace.Uniform(0),pano0_map:new THREE__namespace.Uniform(EMPTY_CUBE_TEXTURE),pano0_luminanceMap:new THREE__namespace.Uniform(null),pano0_matrix:new THREE__namespace.Uniform(new THREE__namespace.Matrix4),pano1_map:new THREE__namespace.Uniform(EMPTY_CUBE_TEXTURE),pano1_luminanceMap:new THREE__namespace.Uniform(null),pano1_matrix:new THREE__namespace.Uniform(new THREE__namespace.Matrix4),clippers:new THREE__namespace.Uniform([]),shownFloorIndex:new THREE__namespace.Uniform(-1),constantColor:new THREE__namespace.Uniform(null),floor:new THREE__namespace.Uniform(0)},{exposure:new THREE__namespace.Uniform(1),emissive:new THREE__namespace.Uniform(new THREE__namespace.Color(0)),emissiveMap:new THREE__namespace.Uniform(null),specular:new THREE__namespace.Uniform(new THREE__namespace.Color(1118481)),specularMap:new THREE__namespace.Uniform(null),normalMap:new THREE__namespace.Uniform(null),bumpMap:new THREE__namespace.Uniform(null),shininess:new THREE__namespace.Uniform(30)},THREE__namespace.UniformsUtils.clone(THREE__namespace.UniformsLib.common),THREE__namespace.UniformsUtils.clone(THREE__namespace.UniformsLib.lights)),PBMMeshMaterial=function(n){__extends(t,n);function t(e){e===void 0&&(e={});var r,i,o,s,u,l,d,c,f,h,v,A,m,y,p,g,b,T,_,w,x=n.call(this,{vertexShader:vertexShader$6,fragmentShader:fragmentShader$6,uniforms:THREE__namespace.UniformsUtils.clone(shaderUniforms$2),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,M,R=null,I=null;return Object.defineProperties(x,{pano0:{get:function(){return R},set:function(S){if(R!==S){R=S,S===null?(this.uniforms.pano0_map.value=EMPTY_CUBE_TEXTURE,this.uniforms.pano0_luminanceMap.value=null,this.uniforms.pano0_matrix.value.identity()):(this.uniforms.pano0_map.value=S.map instanceof TileCubeTextureTarget?S.map.texture:S.map,this.uniforms.pano0_luminanceMap.value=S.luminanceMap instanceof TileCubeTextureTarget?S.luminanceMap.texture:S.luminanceMap,this.uniforms.pano0_matrix.value.copy(S.matrix));var B=this.uniforms.pano0_luminanceMap.value!==null&&this.uniforms.pano1_luminanceMap.value!==null,F=this.defines.USE_LUMINANCE;F!==B&&(this.defines.USE_LUMINANCE=B,this.needsUpdate=!0)}}},pano1:{get:function(){return I},set:function(S){if(I!==S){I=S,S===null?(this.uniforms.pano1_map.value=EMPTY_CUBE_TEXTURE,this.uniforms.pano1_luminanceMap.value=null,this.uniforms.pano1_matrix.value.identity()):(this.uniforms.pano1_map.value=S.map instanceof TileCubeTextureTarget?S.map.texture:S.map,this.uniforms.pano1_luminanceMap.value=S.luminanceMap instanceof TileCubeTextureTarget?S.luminanceMap.texture:S.luminanceMap,this.uniforms.pano1_matrix.value.copy(S.matrix));var B=this.uniforms.pano0_luminanceMap.value!==null&&this.uniforms.pano1_luminanceMap.value!==null,F=this.defines.USE_LUMINANCE;F!==B&&(this.defines.USE_LUMINANCE=B,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 B=this.defines.USE_BLACK_TRANSITION;B!==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 B=this.defines.USE_CONSTANT_COLOR,F=S!==null;B!==F&&(this.defines.USE_CONSTANT_COLOR=F,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 M},set:function(S){M!==S&&(M=S,this.uniforms.clippers.value=(M||[]).map(function(B){var F=typeof B.floorIndex=="number"?B.floorIndex:-1,O=new THREE__namespace.Matrix4().getInverse(B.clippingBoxMatrix);return{matrixInverse:O,floorIndex:F}}),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}}}),x.pano0=(r=e.pano0)!==null&&r!==void 0?r:defaultPbmParameters.pano0,x.pano1=(i=e.pano1)!==null&&i!==void 0?i:defaultPbmParameters.pano1,x.modelAlpha=(o=e.modelAlpha)!==null&&o!==void 0?o:defaultPbmParameters.modelAlpha,x.progress=(s=e.progress)!==null&&s!==void 0?s:defaultPbmParameters.progress,x.useBlackTransition=(u=e.useBlackTransition)!==null&&u!==void 0?u:defaultPbmParameters.useBlackTransition,x.constantColor=(l=e.constantColor)!==null&&l!==void 0?l:defaultPbmParameters.constantColor,x.opacity=(d=e.opacity)!==null&&d!==void 0?d:defaultPbmParameters.opacity,x.shownFloorIndex=(c=e.shownFloorIndex)!==null&&c!==void 0?c:defaultPbmParameters.shownFloorIndex,x.clippers=(f=e.clippers)!==null&&f!==void 0?f:defaultPbmParameters.clippers,x.useEDL=(h=e.useEDL)!==null&&h!==void 0?h:defaultPbmParameters.useEDL,x.useHQWeight=(v=e.useHQWeight)!==null&&v!==void 0?v:defaultPbmParameters.useHQWeight,x.useHQDepth=(A=e.useHQDepth)!==null&&A!==void 0?A:defaultPbmParameters.useHQDepth,x.pointSize=(m=e.pointSize)!==null&&m!==void 0?m:defaultPbmParameters.pointSize,x.pointColor=(y=e.pointColor)!==null&&y!==void 0?y:defaultPbmParameters.pointColor,x.pointShape=(p=e.pointShape)!==null&&p!==void 0?p:defaultPbmParameters.pointShape,x.pointScale=(g=e.pointScale)!==null&&g!==void 0?g:defaultPbmParameters.pointScale,x.pointBack=(b=e.pointBack)!==null&&b!==void 0?b:defaultPbmParameters.pointBack,x.pointMinPixel=(T=e.pointMinPixel)!==null&&T!==void 0?T:defaultPbmParameters.pointMinPixel,x.pointMaxPixel=(_=e.pointMaxPixel)!==null&&_!==void 0?_:defaultPbmParameters.pointMaxPixel,x.gradientTexture=(w=e.gradientTexture)!==null&&w!==void 0?w:defaultPbmParameters.gradientTexture,x.floor=0,x}return t.prototype.onBeforeCompile=function(e,r){var i,o,s=String((o=(i=this.clippers)===null||i===void 0?void 0:i.length)!==null&&o!==void 0?o:0);e.vertexShader=e.vertexShader.replace(/NUM_CLIPPERS/g,s),e.fragmentShader=e.fragmentShader.replace(/NUM_CLIPPERS/g,s)},t.prototype.update=function(e,r){this.transparent=this.shownFloorIndex>-1||this.opacity<1,this.blending=this.transparent?THREE__namespace.NormalBlending:THREE__namespace.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}(THREE__namespace.ShaderMaterial),InternalWebGLRenderer=function(n){__extends(t,n);function t(e){var r=e.preserveDrawingBuffer,i=r===void 0?!0:r,o=e.backgroundColor,s=o===void 0?1579548:o,u=e.backgroundAlpha,l=u===void 0?1:u,d=e.pixelRatio,c=d===void 0?1:d,f=e.antialias,h=f===void 0?!1:f,v=e.webgl2,A=v===void 0?!1:v,m=this,y=l<1;if(A){var p=document.createElement("canvas"),g=p.getContext("webgl2");g?m=n.call(this,{antialias:h,preserveDrawingBuffer:i,alpha:y,canvas:p,context:g})||this:(console.error("error occurred when getting webgl2 canvas context, mybe webgl2 not support, fallback to webgl."),m=n.call(this,{antialias:h,preserveDrawingBuffer:i,alpha:y})||this)}else m=n.call(this,{antialias:h,preserveDrawingBuffer:i,alpha:y})||this;return m.setPixelRatio(c),m.setClearColor(s,l),m.outputEncoding=THREE__namespace.sRGBEncoding,m.autoClear=!0,m}return t}(THREE__namespace.WebGLRenderer),Scene=function(n){__extends(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}(THREE__namespace.Scene);function coordinatesToVector(n,t){var e=Math.abs(Math.cos(n.latitude)),r=-Math.sin(n.longitude)*e,i=-Math.sin(n.latitude),o=-Math.cos(n.longitude)*e;return t?t.set(r,i,o):new THREE__namespace.Vector3(r,i,o)}var DEFAULT_ASPECT=1,DEFAULT_NEAR=.1,DEFAULT_FAR=1e3,TAU$2=Math.PI*2,PI_2=Math.PI/2;function formatRad$1(n){return n>0&&n<=TAU$2?n:(n%TAU$2+TAU$2)%TAU$2}function matrixLerp(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 Camera=function(n){__extends(t,n);function t(e,r,i,o,s,u,l){r===void 0&&(r=DEFAULT_ASPECT),i===void 0&&(i=DEFAULT_NEAR),o===void 0&&(o=DEFAULT_FAR),s===void 0&&(s=new THREE__namespace.Vector2),u===void 0&&(u=512),l===void 0&&(l=1);var d=n.call(this)||this;d.fov=e,d.aspect=r,d.near=i,d.far=o,d.perspToOrtho=s,d.screenHeight=u,d.pixelRatio=l,d.needsRender=!0,d.pose={longitude:0,latitude:0,fov:e,distance:0,offset:new THREE__namespace.Vector3},d.computePose(),d.perspectiveCamera=new THREE__namespace.PerspectiveCamera(d.fov,d.aspect,.001,d.far);var c=Math.max(d.orthoDistance,.01)*Math.tan(.5*d.fov/180*Math.PI),f=-.5*d.aspect*2*c;return d.orthographicCamera=new THREE__namespace.OrthographicCamera(f,-f,c,-c,.001,d.far),d.computeProjectionMatrix(),d.lastValues={position:d.position.clone(),quaternion:d.quaternion.clone(),scale:d.scale.clone(),fov:d.fov,aspect:d.aspect,near:d.near,far:d.far,perspToOrtho:d.perspToOrtho.clone()},d.type=d.perspToOrtho.x<1?"PerspectiveCamera":"OrthographicCamera",d}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 coordinatesToVector(this.pose,e)},t.prototype.computePose=function(e){e===void 0&&(e=0);var r=this.getDirection(new THREE__namespace.Vector3);this.pose.longitude=formatRad$1(-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 THREE__namespace.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,o,s,u,l=formatRad$1((r=e.longitude)!==null&&r!==void 0?r:this.pose.longitude),d=Math.max(-PI_2+1e-4,Math.min(PI_2-1e-4,(i=e.latitude)!==null&&i!==void 0?i:this.pose.latitude)),c=(o=e.fov)!==null&&o!==void 0?o:this.pose.fov,f=(s=e.distance)!==null&&s!==void 0?s:this.pose.distance,h=(u=e.offset)!==null&&u!==void 0?u:this.pose.offset,v=coordinatesToVector({longitude:l,latitude:d}).normalize();return this.position.set(0,0,0),this.lookAt(v),this.position.add(h).sub(v.clone().setLength(f)),this.fov!==c&&(this.fov=c,this.updateProjectionMatrix()),this.updateMatrixWorld(),this.pose.longitude=l,this.pose.latitude=d,this.pose.fov=c,this.pose.distance=f,this.pose.offset.copy(h),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(){matrixLerp(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,o,s,u){this.perspectiveCamera.setViewOffset(e,r,i,o,s,u),this.orthographicCamera.setViewOffset(e,r,i,o,s,u),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 o=Math.max(this.orthoDistance,.01)*Math.tan(.5*this.fov/180*Math.PI),s=-.5*this.aspect*2*o;this.orthographicCamera.left=s,this.orthographicCamera.right=-s,this.orthographicCamera.top=o,this.orthographicCamera.bottom=-o,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(now(),0),this},t}(THREE__namespace.Camera),VolumePlaneIntersect;(function(n){n[n.Outside=-1]="Outside",n[n.Intersecting=0]="Intersecting",n[n.Inside=1]="Inside"})(VolumePlaneIntersect||(VolumePlaneIntersect={}));var EPSILON$2=1e-6,scratchVector=new THREE__namespace.Vector3,scratchMatrix4$3=new THREE__namespace.Matrix4,scratchXAxis=new THREE__namespace.Vector3,scratchYAxis=new THREE__namespace.Vector3,scratchZAxis=new THREE__namespace.Vector3,scratchSize=new THREE__namespace.Vector3,scratchBox3=new THREE__namespace.Box3,scratchSphere$1=new THREE__namespace.Sphere,scratchMatrix4Inverse$1=new THREE__namespace.Matrix4,scratchRay$1=new THREE__namespace.Ray,scratchObject3D=new THREE__namespace.Object3D,scratchFrustum=new THREE__namespace.Frustum;function quaternionFromMatrix3(n,t){var e=n.elements;return t.setFromRotationMatrix(scratchMatrix4$3.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 CullingVolume=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 scratchMatrix4$3.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse),scratchFrustum.setFromProjectionMatrix(scratchMatrix4$3),this.setFromFrustum(scratchFrustum),this},n.prototype.computeVisibility=function(t){for(var e=VolumePlaneIntersect.Inside,r=0,i=this.planes;r<i.length;r++){var o=i[r],s=t.intersectPlane(o);switch(s){case VolumePlaneIntersect.Outside:return VolumePlaneIntersect.Outside;case VolumePlaneIntersect.Intersecting:e=VolumePlaneIntersect.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),o=0;o<i;++o){var s=1<<o;if(e&s){var u=this.planes[o],l=t.intersectPlane(u);if(l===VolumePlaneIntersect.Outside)return n.MASK_OUTSIDE;l===VolumePlaneIntersect.Intersecting&&(r|=s)}}return r},n}(),BoxBoundingVolume=function(){function n(){this.type="box",this.center=new THREE__namespace.Vector3,this.halfSize=new THREE__namespace.Vector3,this.rotation=new THREE__namespace.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],o=e[5],s=e[6],u=e[7],l=e[8],d=e[9],c=e[10],f=e[11],h=Math.sqrt(r*r+i*i+o*o),v=Math.sqrt(s*s+u*u+l*l),A=Math.sqrt(d*d+c*c+f*f);this.halfSize.set(h,v,A);var m=this.halfSize.toArray().reduce(function(y,p){return y+p},0);return(isNaN(m)||m<=0)&&this.halfSize.setScalar(EPSILON$2),this.rotation.fromArray([r/h,i/h,o/h,s/v,u/v,l/v,d/A,c/A,f/A]),isNaN(this.rotation.toArray().reduce(function(y,p){return y+p},0))&&this.rotation.identity(),this},n.prototype.toJson=function(){return this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),{box:__spreadArray(__spreadArray(__spreadArray(__spreadArray([],this.center.toArray(),!0),scratchXAxis.multiplyScalar(this.halfSize.x).toArray(),!0),scratchYAxis.multiplyScalar(this.halfSize.y).toArray(),!0),scratchZAxis.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 scratchObject3D.position.copy(this.center),quaternionFromMatrix3(this.rotation,scratchObject3D.quaternion),scratchObject3D.scale.copy(this.halfSize),scratchObject3D.matrix.compose(scratchObject3D.position,scratchObject3D.quaternion,scratchObject3D.scale),scratchObject3D.matrix.premultiply(t),scratchObject3D.matrix.decompose(scratchObject3D.position,scratchObject3D.quaternion,scratchObject3D.scale),this.center.copy(scratchObject3D.position),this.rotation.setFromMatrix4(scratchMatrix4$3.makeRotationFromQuaternion(scratchObject3D.quaternion)),this.halfSize.copy(scratchObject3D.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,o=t.z-this.center.z,s=0,u;return u=r*e[0]+i*e[1]+o*e[2],u<0&&(u=-u),u-=this.halfSize.x,u>0&&(s+=u*u),u=r*e[3]+i*e[4]+o*e[5],u<0&&(u=-u),u-=this.halfSize.y,u>0&&(s+=u*u),u=r*e[6]+i*e[7]+o*e[8],u<0&&(u=-u),u-=this.halfSize.z,u>0&&(s+=u*u),s},n.prototype.distanceTo=function(t){return Math.sqrt(this.distanceSquaredTo(t))},n.prototype.getBoundingBox=function(t){return t.makeEmpty(),this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchXAxis.setLength(this.halfSize.x),scratchYAxis.setLength(this.halfSize.y),scratchZAxis.setLength(this.halfSize.z),t.expandByPoint(scratchVector.copy(this.center).add(scratchXAxis)),t.expandByPoint(scratchVector.copy(this.center).sub(scratchXAxis)),t.expandByPoint(scratchVector.copy(this.center).add(scratchYAxis)),t.expandByPoint(scratchVector.copy(this.center).sub(scratchYAxis)),t.expandByPoint(scratchVector.copy(this.center).add(scratchZAxis)),t.expandByPoint(scratchVector.copy(this.center).sub(scratchZAxis)),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);scratchVector.set(this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,0),scratchVector.set(-this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,3),scratchVector.set(-this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,6),scratchVector.set(this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,9),scratchVector.set(this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,12),scratchVector.set(-this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,15),scratchVector.set(-this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,18),scratchVector.set(this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,21);var r=new THREE__namespace.BufferGeometry;return r.setIndex(new THREE__namespace.BufferAttribute(t,1)),r.setAttribute("position",new THREE__namespace.BufferAttribute(e,3)),r.computeBoundingBox(),r.computeBoundingSphere(),r},n.prototype.intersectPlane=function(t){var e=this.center,r=t.normal,i=this.rotation.elements,o=this.halfSize,s=r.x,u=r.y,l=r.z,d=Math.abs(s*i[0]*o.x+u*i[1]*o.x+l*i[2]*o.x)+Math.abs(s*i[3]*o.y+u*i[4]*o.y+l*i[5]*o.y)+Math.abs(s*i[6]*o.z+u*i[7]*o.z+l*i[8]*o.z),c=r.dot(e)+t.constant;return c<=-d?VolumePlaneIntersect.Outside:c>=d?VolumePlaneIntersect.Inside:VolumePlaneIntersect.Intersecting},n.prototype.intersectRay=function(t,e){scratchSize.copy(this.halfSize).multiplyScalar(2),scratchBox3.setFromCenterAndSize(scratchVector.set(0,0,0),scratchSize),this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchMatrix4$3.makeBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchMatrix4$3.setPosition(this.center),scratchMatrix4Inverse$1.getInverse(scratchMatrix4$3),scratchRay$1.copy(t).applyMatrix4(scratchMatrix4Inverse$1);var r=scratchRay$1.intersectBox(scratchBox3,scratchVector);return r?e!==void 0?r.applyMatrix4(scratchMatrix4$3).distanceTo(t.origin)<e:!0:!1},n}(),SphereBoundingVolume=function(){function n(){this.type="sphere",this.center=new THREE__namespace.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],EPSILON$2),this},n.prototype.toJson=function(){return{sphere:__spreadArray(__spreadArray([],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,scratchSize.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 o=new THREE__namespace.BufferGeometry;return o.setAttribute("position",new THREE__namespace.BufferAttribute(e,3)),o.computeBoundingBox(),o.computeBoundingSphere(),o},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,o=i.dot(e)+t.constant;return o<-r?VolumePlaneIntersect.Outside:o<r?VolumePlaneIntersect.Intersecting:VolumePlaneIntersect.Inside},n.prototype.intersectRay=function(t,e){scratchSphere$1.set(this.center,this.radius);var r=t.intersectSphere(scratchSphere$1,scratchVector);return r?e!==void 0?t.origin.distanceTo(r)<e:!0:!1},n}(),RegionBoundingVolume=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 makeBoundingVolume(n){if("box"in n)return new BoxBoundingVolume().fromJson(n);if("sphere"in n)return new SphereBoundingVolume().fromJson(n);if("region"in n)return new RegionBoundingVolume().fromJson(n);throw new Error("BoundingVolume ".concat(JSON.stringify(n)," never suppored."))}var debugMaterials=[2621517,3801199,4915345,5963950,7274706,8782079,9575167,10434047,11623423,12482559,13274879,13870335,14464511,15125247,15852031,16446719].map(function(n){return new THREE__namespace.LineBasicMaterial({color:n,depthWrite:!1,transparent:!0})}),debugBoxGeometry=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);scratchVector.set(1,1,1).toArray(t,0),scratchVector.set(-1,1,1).toArray(t,3),scratchVector.set(-1,-1,1).toArray(t,6),scratchVector.set(1,-1,1).toArray(t,9),scratchVector.set(1,1,-1).toArray(t,12),scratchVector.set(-1,1,-1).toArray(t,15),scratchVector.set(-1,-1,-1).toArray(t,18),scratchVector.set(1,-1,-1).toArray(t,21);var e=new THREE__namespace.BufferGeometry;return e.setIndex(new THREE__namespace.BufferAttribute(n,1)),e.setAttribute("position",new THREE__namespace.BufferAttribute(t,3)),e.computeBoundingBox(),e.computeBoundingSphere(),e}(),debugSphereGeometry=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 THREE__namespace.BufferGeometry;return i.setAttribute("position",new THREE__namespace.BufferAttribute(t,3)),i.computeBoundingBox(),i.computeBoundingSphere(),i}();function createDebugBoundingMesh(n,t){if(n instanceof BoxBoundingVolume){var e=new THREE__namespace.LineSegments(debugBoxGeometry,debugMaterials[Math.min(t,debugMaterials.length-1)]);return e.position.copy(n.center),quaternionFromMatrix3(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 SphereBoundingVolume){var e=new THREE__namespace.LineSegments(debugSphereGeometry,debugMaterials[Math.min(t,debugMaterials.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 Tile=function(){function n(t,e,r,i){var o=this,s,u,l;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=(s=e.refine)!==null&&s!==void 0?s:this.parent?this.parent.refine:"REPLACE",this.transform=new THREE__namespace.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=(l=(u=this.parent)===null||u===void 0?void 0:u.geometricError)!==null&&l!==void 0?l: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=makeBoundingVolume(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=makeBoundingVolume(e.boundingVolume).applyMatrix4(this.transform)),e.viewerRequestVolume&&(this.viewerRequestVolume=makeBoundingVolume(e.viewerRequestVolume).applyMatrix4(this.transform)),this.extras=e.extras||{},e.children?this.children=e.children.map(function(d,c){return new n("".concat(o.id,".").concat(c),d,r,o)}):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:CullingVolume.MASK_INDETERMINATE;this.state.visibilityPlaneMask=t.cullingVolume.computeVisibilityWithPlaneMask(r,i),this.state.visible=this.state.visibilityPlaneMask!==CullingVolume.MASK_OUTSIDE}else this.state.distanceToCamera=0,this.state.visibilityPlaneMask=CullingVolume.MASK_INDETERMINATE,this.state.visible=!0;if(this.viewerRequestVolume){var o=e?this.viewerRequestVolume.clone().applyMatrix4(e):this.viewerRequestVolume;this.state.inRequestVolume=o.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(o){return i.done(),r.loadState=o?"READY":"UNLOADED",o}).catch(function(o){return r.loadState="FAILED",i.done(),Promise.reject(o)}):(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(),o=this.parent?this.parent.geometricError:this.tileset.geometricError,s=i*(r?o:this.geometricError);if(s===0)return 0;var u=Math.max(e,.001),l=s*t.height/(u*t.sseDenominator);return l},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,o=this.tileset.root?this.tileset.root.state.screenSpaceError:0,s=Math.max(o-i,0);return s},n}(),RequestScheduler=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(){}},o=new Promise(function(s){return i.resolve=s});return this.requestQueue.push(i),this.requestMap.set(t,o),this.issueNewRequests(),o},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,o=!1,s=function(){o||(o=!0,e.requestMap.delete(r),e.activeRequests--,e.issueNewRequests())};this.activeRequests++,i({done:s})},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,o){return i.priority-o.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}(),CacheNode=function(){function n(t,e,r){this.item=t,this.previous=e,this.next=r}return n}(),CacheNodeList=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 CacheNode(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}(),TilesetCache=function(){function n(){this.cacheNodeMap=new Map,this.list=new CacheNodeList,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}(),ManagedArray=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}(),TilesetTraverser=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 ManagedArray,this._emptyTraversalStack=new ManagedArray,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,o=r;i<o.length;i++){var s=o[i];this._traversalStack.reset(),this._emptyTraversalStack.reset(),this._canSelectTile=s.camera.visible,this.updateTile(t,s),this.executeTraversal(t,s)}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(),o=!1;if(this.canTraverse(i,e,!1,!1)){var s=i.hasRenderContent?i.state.selectionDepth+1:i.state.selectionDepth;this.updateChildTiles(i,e,s),o=this.updateAndPushChildren(i,e,r)}var u=i.parent,l=!u||u.state.shouldRefine,d=!o;i.hasRenderContent?i.refine==="ADD"?(this.loadTile(i,e.frameNumber),this.selectTile(i,e)):i.refine==="REPLACE"&&(this.loadTile(i,e.frameNumber),d&&this.selectTile(i,e)):(this.emptyTiles.set(i.id,i),this.loadTile(i,e.frameNumber),d&&this.selectTile(i,e)),this.touchTile(i,e),i.state.shouldRefine=o&&l}},n.prototype.updateChildTiles=function(t,e,r){for(var i=t.children,o=0,s=i;o<s.length;o++){var u=s[o];u.state.selectionDepth=r,this.updateTile(u,e)}return!0},n.prototype.updateAndPushChildren=function(t,e,r){for(var i=t.children,o=t.refine==="REPLACE"&&t.hasRenderContent&&!this.skipLevelOfDetail,s=!1,u=!0,l=0,d=i;l<d.length;l++){var c=d[l];if(c.state.visible&&c.state.inRequestVolume?(r.find(c)&&r.delete(c),r.push(c),s=!0):(o||this.loadSiblings)&&(this.loadTile(c,e.frameNumber),this.touchTile(c,e)),o){var f=void 0;c.state.inRequestVolume?c.hasRenderContent?f=c.contentAvailable:f=this.executeEmptyTraversal(c,e):f=!1,u=u&&f}}return s||(u=!1),u},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 o=i.pop();this.updateTile(o,e),o.state.visible||this.loadTile(o,e.frameNumber),this.touchTile(o,e);var s=!o.hasRenderContent&&this.canTraverse(o,e,!1,!0);if(s)for(var u=o.children,l=0,d=u;l<d.length;l++){var c=d[l];i.find(c)&&i.delete(c),i.push(c)}else o.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}(),identityMatrix4=new THREE__namespace.Matrix4,Tileset=function(){function n(t,e,r){var i,o;this.id=t,this.transform=new THREE__namespace.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=(o=e.properties)!==null&&o!==void 0?o:{},this.options=r,this.traverser=new TilesetTraverser,this.cache=new TilesetCache,this.requestScheduler=new RequestScheduler,this.frameNumber=0,this.pendingCount=0,this.tiles=new Map,this.memoryUsageInBytes=0,this.root=new Tile("".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,o=r.children.length;i<o;i++)e.push(r.children[i]);this.cache.unloadTile(r,function(s){return t.unloadTile(s)})}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(identityMatrix4),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=TilesetTraverser.DEFAULT_MAX_SCREEN_SPACE_ERROR,n.DEFAULT_MAX_REQUESTS=RequestScheduler.DEFAULT_MAX_REQUESTS,n}(),BVHNode=function(){function n(t,e,r,i){this.extents=t,this.startIndex=e,this.endIndex=r,this.deepth=i}return n}();function intersectNodeBox(n,t,e,r){r===void 0&&(r=0);var i=e.extents[0]-r,o=e.extents[1]-r,s=e.extents[2]-r,u=e.extents[3]+r,l=e.extents[4]+r,d=e.extents[5]+r,c={min:0,max:0};t.x>=0?(c.min=(i-n.x)*t.x,c.max=(u-n.x)*t.x):(c.min=(u-n.x)*t.x,c.max=(i-n.x)*t.x);var f={min:0,max:0};if(t.y>=0?(f.min=(o-n.y)*t.y,f.max=(l-n.y)*t.y):(f.min=(l-n.y)*t.y,f.max=(o-n.y)*t.y),c.min>f.max||f.min>c.max)return!1;f.min>c.min&&(c.min=f.min),f.max<c.max&&(c.max=f.max);var h={min:0,max:0};return t.z>=0?(h.min=(s-n.z)*t.z,h.max=(d-n.z)*t.z):(h.min=(d-n.z)*t.z,h.max=(s-n.z)*t.z),!(c.min>h.max||h.min>c.max||(h.min>c.min&&(c.min=h.min),h.max<c.max&&(c.max=h.max),c.max<0))}var BVHVector3=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,o=t.z,s=e.x,u=e.y,l=e.z;return this.x=i*l-o*u,this.y=o*s-r*l,this.z=r*u-i*s,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}(),BVHIntersect=function(){function n(t,e,r){this.triangle=t,this.intersectionPoint=e,this.index=r}return n}(),EPSILON$1=1e-6,BVHMesh=function(){function n(t,e){if(this.positionArray=t,e)this.indicesArray=e;else{for(var r=t.length/3,i=new Uint32Array(r),o=0;o<r;o++)i[o]=o;this.indicesArray=i}}return n.prototype.createTree=function(t,e,r){var i=this.positionArray,o=this.indicesArray,s=o.length/3,u=new Uint32Array(s),l=new Float32Array(s*6),d=[],c=0;if(r)for(var f=0,h=0,v=0,A=void 0,m=void 0,y=void 0,p=void 0,g=void 0,b=void 0,T=void 0;f<s;f+=1,h+=3,v+=6)u[f]=f,A=p=i[o[h]*3],T=i[o[h+1]*3],T<A&&(A=T),T>p&&(p=T),T=i[o[h+2]*3],T<A&&(A=T),T>p&&(p=T),m=g=i[o[h]*3+1],T=i[o[h+1]*3+1],T<m&&(m=T),T>g&&(g=T),T=i[o[h+2]*3+1],T<m&&(m=T),T>g&&(g=T),y=b=i[o[h]*3+2],T=i[o[h+1]*3+2],T<y&&(y=T),T>b&&(b=T),T=i[o[h+2]*3+2],T<y&&(y=T),T>b&&(b=T),l[v]=A,l[v+1]=m,l[v+2]=y,l[v+3]=p,l[v+4]=g,l[v+5]=b;else{for(var _=1/0,w=1/0,x=1/0,M=-1/0,R=-1/0,I=-1/0,f=0,h=0,v=0,A=void 0,m=void 0,y=void 0,p=void 0,g=void 0,b=void 0,T=void 0;f<s;f+=1,h+=3,v+=6)u[f]=f,A=p=i[o[h]*3],T=i[o[h+1]*3],T<A&&(A=T),T>p&&(p=T),T=i[o[h+2]*3],T<A&&(A=T),T>p&&(p=T),m=g=i[o[h]*3+1],T=i[o[h+1]*3+1],T<m&&(m=T),T>g&&(g=T),T=i[o[h+2]*3+1],T<m&&(m=T),T>g&&(g=T),y=b=i[o[h]*3+2],T=i[o[h+1]*3+2],T<y&&(y=T),T>b&&(b=T),T=i[o[h+2]*3+2],T<y&&(y=T),T>b&&(b=T),l[v]=A,l[v+1]=m,l[v+2]=y,l[v+3]=p,l[v+4]=g,l[v+5]=b,A<_&&(_=A),p>M&&(M=p),m<w&&(w=m),g>R&&(R=g),y<x&&(x=y),b>I&&(I=b);r=[_,w,x,M,R,I]}var S=new BVHNode(r,0,s,0);d[c++]=S;function B(F){for(var O=F.startIndex,H=F.endIndex,k=F.extents,N=[k[3]-k[0],k[4]-k[1],k[5]-k[2]],q=[0,1,2].sort(function(J,Z){return N[Z]-N[J]}),V=0;V<3;V++){for(var D=q[V],K=k[D]+k[D+3],z=O,G=H-1,W=-1,Q=void 0;z<=G;)W===-1?(Q=u[z],l[Q*6+D]+l[Q*6+D+3]<K?z++:W=Q):(Q=u[G],l[Q*6+D]+l[Q*6+D+3]>=K||(u[z]=Q,u[G]=W,W=-1,z++),G--);if(z>O&&z<H){var X=new BVHNode(calcExtents(u,l,O,z,EPSILON$1),O,z,F.deepth+1);X.deepth<e&&X.endIndex-X.startIndex>t&&(d[c++]=X);var ee=new BVHNode(calcExtents(u,l,z,H,EPSILON$1),z,H,F.deepth+1);ee.deepth<e&&ee.endIndex-ee.startIndex>t&&(d[c++]=ee),F.node0=X,F.node1=ee,F.startIndex=0,F.endIndex=0;break}}}for(;c;)B(d[--c]);return this.offsetArray=u,this.rootNode=S,d.length=0,this},n.prototype.trianglesInSphere=function(t,e){for(var r=this.positionArray,i=this.indicesArray,o=this.offsetArray,s=this.rootNode,u=[s],l=[],d;d=u.pop();){var c=clamp$1(t.x,d.extents[0],d.extents[3])-t.x,f=clamp$1(t.y,d.extents[1],d.extents[4])-t.y,h=clamp$1(t.z,d.extents[2],d.extents[5])-t.z;if(c*c+f*f+h*h<=e*e){d.node0&&u.push(d.node0),d.node1&&u.push(d.node1);for(var v=d.startIndex;v<d.endIndex;v++)l.push(o[v])}}for(var A=l.length,m=new Float32Array(A*9),v=0;v<A;v++){var y=l[v];m[v*9]=r[i[y]*3],m[v*9+1]=r[i[y]*3+1],m[v*9+2]=r[i[y]*3+2],m[v*9+3]=r[i[y+1]*3],m[v*9+4]=r[i[y+1]*3+1],m[v*9+5]=r[i[y+1]*3+2],m[v*9+6]=r[i[y+2]*3],m[v*9+7]=r[i[y+2]*3+1],m[v*9+8]=r[i[y+2]*3+2]}return m},n.prototype.intersectRay=function(t,e,r){for(var i=this.positionArray,o=this.indicesArray,s=this.offsetArray,u=this.rootNode,l=new BVHVector3(1/e.x,1/e.y,1/e.z),d=[u],c;c=d.pop();)if(intersectNodeBox(t,l,c)){for(var f=c.startIndex,h=c.endIndex,v=void 0,A=void 0,m=void 0,y=t.x,p=t.y,g=t.z,b=e.x,T=e.y,_=e.z,w=void 0,x=void 0,M=void 0,R=void 0,I=void 0,S=void 0,B=void 0,F=void 0,O=void 0,H=void 0,k=void 0,N=void 0,q=void 0,V=void 0,D=void 0,K=void 0,z=void 0,G=void 0,W=void 0,Q=void 0,X=void 0,ee=void 0,J=void 0,Z=void 0,te=void 0,ae=void 0,re=void 0;f<h;f++){if(v=s[f],A=v*3,m=o[A]*3,w=i[m],x=i[++m],M=i[++m],m=o[A+1]*3,R=i[m],I=i[++m],S=i[++m],m=o[A+2]*3,B=i[m],F=i[++m],O=i[++m],H=R-w,k=I-x,N=S-M,q=B-w,V=F-x,D=O-M,K=k*D-N*V,z=N*q-H*D,G=H*V-k*q,J=b*K+T*z+_*G,J>0)ee=1;else if(J<0)ee=-1,J=-J;else continue;W=y-w,Q=p-x,X=g-M,Z=ee*(b*(Q*D-X*V)+T*(X*q-W*D)+_*(W*V-Q*q)),!(Z<0)&&(te=ee*(b*(k*X-N*Q)+T*(N*W-H*X)+_*(H*Q-k*W)),!(te<0)&&(Z+te>J||(ae=-ee*(W*K+Q*z+X*G),!(ae<0)&&(re=ae/J,r.push(new BVHIntersect([w,x,M,R,I,S,B,F,O],[y+b*re,p+T*re,g+_*re],v))))))}c.node0&&d.push(c.node0),c.node1&&d.push(c.node1)}return r},n}();function clamp$1(n,t,e){return n<t?t:n>e?e:n}function calcExtents(n,t,e,r,i){if(e>=r)return[0,0,0,0,0,0];for(var o=1/0,s=1/0,u=1/0,l=-1/0,d=-1/0,c=-1/0,f=e,h=void 0,v=void 0;f<r;f++)h=n[f]*6,v=t[h],v<o&&(o=v),v=t[h+1],v<s&&(s=v),v=t[h+2],v<u&&(u=v),v=t[h+3],v>l&&(l=v),v=t[h+4],v>d&&(d=v),v=t[h+5],v>c&&(c=v);return[o-i,s-i,u-i,l+i,d+i,c+i]}var EPSILON=1e-6,BVHPoints=function(){function n(t,e){if(this.positionArray=t,e)this.indicesArray=e;else{for(var r=t.length/3,i=new Uint32Array(r),o=0;o<r;o++)i[o]=o;this.indicesArray=i}}return n.prototype.createTree=function(t,e,r){var i=this.positionArray,o=this.indicesArray,s=o.length,u=new Uint32Array(s),l=[],d=0;if(r)for(var c=0;c<s;c+=1)u[c]=c;else{for(var f=o[0]*3,h=i[f],v=i[f+1],A=i[f+2],m=h,y=v,p=A,c=0,g=0,b=void 0,T=void 0,_=void 0;c<s;c+=1,g+=3)u[c]=c,f=o[g]*3,b=i[f],T=i[f+1],_=i[f+2],b<h?h=b:b>m&&(m=b),T<v?v=T:T>y&&(y=T),_<A?A=_:_>p&&(p=_);r=[h,v,A,m,y,p]}var w=new BVHNode(r,0,s,0);l[d++]=w;function x(M){for(var R=M.startIndex,I=M.endIndex,S=M.extents,B=[S[3]-S[0],S[4]-S[1],S[5]-S[2]],F=[0,1,2].sort(function(G,W){return B[W]-B[G]})[0],O=(S[F]+S[F+3])/2,H=R,k=I-1,N=-1,q;H<=k;)N===-1?(q=u[H],i[o[q]*3+F]<O?H++:N=q):(q=u[k],i[o[q]*3+F]>=O||(u[H]=q,u[k]=N,N=-1,H++),k--);if(H>R){var V=S.slice();V[F+3]=O+EPSILON;var D=new BVHNode(V,R,H,M.deepth+1);D.deepth<e&&D.endIndex-D.startIndex>t&&(l[d++]=D),M.node0=D}if(I>H){var K=S.slice();K[F]=O-EPSILON;var z=new BVHNode(K,H,I,M.deepth+1);z.deepth<e&&z.endIndex-z.startIndex>t&&(l[d++]=z),M.node1=z}M.startIndex=0,M.endIndex=0}for(;d;)x(l[--d]);return this.offsetArray=u,this.rootNode=w,l.length=0,this},n.prototype.intersectRay=function(t,e,r,i){for(var o=this.positionArray,s=this.indicesArray,u=this.offsetArray,l=this.rootNode,d=r*r,c=new BVHVector3(1/e.x,1/e.y,1/e.z),f=[l],h;h=f.pop();)if(intersectNodeBox(t,c,h,r)){for(var v=h.startIndex,A=h.endIndex,m=void 0,y=void 0,p=void 0,g=void 0,b=void 0,T=void 0,_=void 0,w=void 0,x=void 0,M=void 0,R=void 0,I=void 0,S=void 0;v<A;v++)m=u[v],y=s[m]*3,p=o[y],g=o[++y],b=o[++y],T=t.x,_=t.y,w=t.z,x=e.x,M=e.y,R=e.z,I=x*(p-T)+M*(g-_)+R*(b-w),I>0&&(T+=x*I,_+=M*I,w+=R*I),x=p-T,M=g-_,R=b-w,I=x*x+M*M+R*R,I<=d&&i.push(new BVHIntersect([p,g,b,p,g,b,p,g,b],[T,_,w],m));h.node0&&f.push(h.node0),h.node1&&f.push(h.node1)}return i},n}(),bvhMeshMap=new Map,bvhPointsMap=new Map,scratchRay=new THREE__namespace.Ray,scratchNormalMatrix=new THREE__namespace.Matrix3,scratchInverseMatrix=new THREE__namespace.Matrix4,scratchIntersectionFaceA$1=new THREE__namespace.Vector3,scratchIntersectionFaceB$1=new THREE__namespace.Vector3,scratchIntersectionFaceC$1=new THREE__namespace.Vector3,scratchIntersectionTriangle=new THREE__namespace.Triangle;function raycastMesh(n,t,e,r){var i,o=n.matrixWorld;scratchInverseMatrix.getInverse(o),scratchRay.copy(e.ray).applyMatrix4(scratchInverseMatrix);for(var s=t.intersectRay(scratchRay.origin,scratchRay.direction,[]),u=n.geometry,l=n.material,d=u.groups,c=u.index,f=0,h=s.length;f<h;f++){var v=s[f],A=v.triangle,m=v.index,y=v.intersectionPoint,p=new THREE__namespace.Vector3(y[0],y[1],y[2]).applyMatrix4(o),g=e.ray.origin.distanceTo(p);if(!(g<e.near||g>e.far)){var b=void 0;if(Array.isArray(l)){if(d)for(var T=m*3,_=0,w=d;_<w.length;_++){var x=w[_];if(T>=x.start&&T-x.start<x.count){b=l[(i=x.materialIndex)!==null&&i!==void 0?i:0];break}}}else b=l;if(b){var M=scratchIntersectionTriangle.set(scratchIntersectionFaceA$1.set(A[0],A[1],A[2]).applyMatrix4(o),scratchIntersectionFaceB$1.set(A[3],A[4],A[5]).applyMatrix4(o),scratchIntersectionFaceC$1.set(A[6],A[7],A[8]).applyMatrix4(o)).getNormal(new THREE__namespace.Vector3),R=m*3,I=new THREE__namespace.Face3(c?c.array[R]:R,c?c.array[R+1]:R+1,c?c.array[R+2]:R+2,M),S=e.ray.direction.dot(M);b.side===THREE__namespace.FrontSide&&S>=0||b.side===THREE__namespace.BackSide&&S<=0||r.push({distance:g,object:n,face:I,point:p,distanceToRay:0,faceIndex:m})}}}}function raycastPoints(n,t,e,r){var i,o,s=n.matrixWorld;scratchNormalMatrix.getNormalMatrix(s),scratchInverseMatrix.getInverse(s);var u=((o=(i=e.params.Points)===null||i===void 0?void 0:i.threshold)!==null&&o!==void 0?o:1)*scratchInverseMatrix.getMaxScaleOnAxis();scratchRay.copy(e.ray).applyMatrix4(scratchInverseMatrix);for(var l=t.intersectRay(scratchRay.origin,scratchRay.direction,u,[]),d=n.geometry,c=d.index,f=d.getAttribute("normal"),h=0,v=l.length;h<v;h++){var A=l[h],m=A.triangle,y=A.index,p=A.intersectionPoint,g=new THREE__namespace.Vector3(p[0],p[1],p[2]).applyMatrix4(s),b=e.ray.origin.distanceTo(g);if(!(b<e.near||b>e.far)){var T=scratchIntersectionFaceA$1.set(m[0],m[1],m[2]).applyMatrix4(s),_=c?c.array[y]:y,w=void 0;f instanceof THREE__namespace.BufferAttribute&&(w=new THREE__namespace.Vector3().fromBufferAttribute(f,_).applyNormalMatrix(scratchNormalMatrix));var x=new THREE__namespace.Face3(_,_,_,w);r.push({distance:b,object:n,face:x,point:g,distanceToRay:g.distanceTo(T),index:y})}}}function generateBvhTreeForMesh(n,t,e){var r;if(t===void 0&&(t=100),e===void 0&&(e=10),n.geometry instanceof THREE__namespace.BufferGeometry){var i=n.geometry.getAttribute("position");if(i instanceof THREE__namespace.BufferAttribute){var o=n.raycast,s=function(h,v){var A=bvhMeshMap.get(this);A?raycastMesh(this,A,h,v):o.call(this,h,v)};n.raycast=s;var u=i.array,l=(r=n.geometry.getIndex())===null||r===void 0?void 0:r.array,d=n.geometry.boundingBox,c=d?[d.min.x,d.min.y,d.min.z,d.max.x,d.max.y,d.max.z]:void 0,f=new BVHMesh(u,l);return f.createTree(t,e,c),bvhMeshMap.set(n,f),function(){bvhMeshMap.delete(n),n.raycast===s&&(n.raycast=o)}}}return function(){}}function generateBvhTreeForPoints(n,t,e){var r;if(t===void 0&&(t=100),e===void 0&&(e=10),n.geometry instanceof THREE__namespace.BufferGeometry){var i=n.geometry.getAttribute("position");if(i instanceof THREE__namespace.BufferAttribute){var o=n.raycast,s=function(h,v){var A=bvhPointsMap.get(this);A?raycastPoints(this,A,h,v):o.call(this,h,v)};n.raycast=s;var u=i.array,l=(r=n.geometry.getIndex())===null||r===void 0?void 0:r.array,d=n.geometry.boundingBox,c=d?[d.min.x,d.min.y,d.min.z,d.max.x,d.max.y,d.max.z]:void 0,f=new BVHPoints(u,l);return f.createTree(t,e,c),bvhPointsMap.set(n,f),function(){bvhPointsMap.delete(n),n.raycast===s&&(n.raycast=o)}}}return function(){}}function generateBvhTree(n,t,e){t===void 0&&(t=100),e===void 0&&(e=10);var r=[];return n.traverse(function(i){if(i instanceof THREE__namespace.Mesh){var o=generateBvhTreeForMesh(i,t,e);r.push(o)}else if(i instanceof THREE__namespace.Points){var o=generateBvhTreeForPoints(i,t,e);r.push(o)}}),function(){for(var i=0,o=r;i<o.length;i++){var s=o[i];s()}}}var scratchIntersectionFaceA=new THREE__namespace.Vector3,scratchIntersectionFaceB=new THREE__namespace.Vector3,scratchIntersectionFaceC=new THREE__namespace.Vector3,TileNode=function(n){__extends(t,n);function t(e,r){var i=n.call(this)||this;i.renderOrder=-4;var o=generateBvhTree(e,200,10);return i.disposers=[r,o],i.add(e),i}return t.prototype.intersectRaycaster=function(e,r,i){var o=this;r===void 0&&(r=!0),i===void 0&&(i=[]);for(var s=this.children.slice(),u;u=s.pop();)if(u.visible){u.raycast(e,i);for(var l=0,d=u.children.length;l<d;l++)s.push(u.children[l])}return i.forEach(function(c){var f,h,v=0;if((c.object instanceof PBMMesh||c.object instanceof PBMPointCloud)&&c.face){var A=Array.isArray(c.object.material)?c.object.material[c.face.materialIndex]:c.object.material;if(A)if(A.defines.USE_VERTEX_FLOOR){var m=(f=c.object.geometry.attributes.position)===null||f===void 0?void 0:f.array,y=(h=c.object.geometry.attributes.floor)===null||h===void 0?void 0:h.array;if(m&&y){var p=scratchIntersectionFaceA.set(m[c.face.a*3],m[c.face.a*3+1],m[c.face.a*3+2]).applyMatrix4(o.matrixWorld),g=scratchIntersectionFaceB.set(m[c.face.b*3],m[c.face.b*3+1],m[c.face.b*3+2]).applyMatrix4(o.matrixWorld),b=scratchIntersectionFaceC.set(m[c.face.c*3],m[c.face.c*3+1],m[c.face.c*3+2]).applyMatrix4(o.matrixWorld),T=c.point.distanceTo(p),_=c.point.distanceTo(g),w=c.point.distanceTo(b);v=Math.round((T*y[c.face.a]+_*y[c.face.b]+w*y[c.face.c])/(T+_+w))}}else v=A.floor}c.floor=v}),r&&i.sort(function(c,f){return c.distance-f.distance}),i},t.prototype.dispose=function(){for(var e=0,r=this.disposers;e<r.length;e++){var i=r[e];i()}},t}(THREE__namespace.Group);function pathJoin(){for(var n=[],t=0;t<arguments.length;t++)n[t]=arguments[t];var e=[];n=n.map(function(u){return(u??"").trim()}).filter(function(u){return u.length>0&&!/^\/+$/.test(u)});for(var r=0;r<n.length;r++){var i=r===0,o=r===n.length-1,s=n[r];i||(s=s.replace(/^\.\//,"").replace(/^\/+/,"")),o||(s=s.replace(/\/+$/,"")),e.push(s)}return e.join("/")}function isAbsoluteURL(n){return n.indexOf("//")===0||/^[0-9a-z]+\:/i.test(n)}function normalizeTileHeader(n,t){if(n.content&&n.content.uri&&(isAbsoluteURL(n.content.uri)||(n.content.uri=pathJoin(t,n.content.uri))),n.children)for(var e=0,r=n.children;e<r.length;e++){var i=r[e];normalizeTileHeader(i,t)}return n}function normalizeTilesetHeader(n,t){return n.asset.overview={imageFile:"overview.png",worldFile:"overview.pgw",imageWidth:1024,imageHeight:1024},n.asset.overview&&(isAbsoluteURL(n.asset.overview.imageFile)||(n.asset.overview.imageFile=pathJoin(t,n.asset.overview.imageFile)),isAbsoluteURL(n.asset.overview.worldFile)||(n.asset.overview.worldFile=pathJoin(t,n.asset.overview.worldFile))),normalizeTileHeader(n.root,t),n}function appendSearch(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 SIZEOF_UINT32$1=4;function parseHeader(n,t,e){var r=new DataView(t);if(n.magic=r.getUint32(e,!0),e+=SIZEOF_UINT32$1,n.version=r.getUint32(e,!0),e+=SIZEOF_UINT32$1,n.byteLength=r.getUint32(e,!0),e+=SIZEOF_UINT32$1,n.version!==1)throw new Error("3D Tile Version ".concat(n.version," not supported"));return e}var _a$2,GL_TYPE;(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"})(GL_TYPE||(GL_TYPE={}));var GL_TYPE_TO_ARRAY_TYPE=(_a$2={},_a$2[GL_TYPE.DOUBLE]=Float64Array,_a$2[GL_TYPE.FLOAT]=Float32Array,_a$2[GL_TYPE.UNSIGNED_SHORT]=Uint16Array,_a$2[GL_TYPE.UNSIGNED_INT]=Uint32Array,_a$2[GL_TYPE.UNSIGNED_BYTE]=Uint8Array,_a$2[GL_TYPE.BYTE]=Int8Array,_a$2[GL_TYPE.SHORT]=Int16Array,_a$2[GL_TYPE.INT]=Int32Array,_a$2),NAME_TO_GL_TYPE={DOUBLE:GL_TYPE.DOUBLE,FLOAT:GL_TYPE.FLOAT,UNSIGNED_SHORT:GL_TYPE.UNSIGNED_SHORT,UNSIGNED_INT:GL_TYPE.UNSIGNED_INT,UNSIGNED_BYTE:GL_TYPE.UNSIGNED_BYTE,BYTE:GL_TYPE.BYTE,SHORT:GL_TYPE.SHORT,INT:GL_TYPE.INT};function getArrayType(n){var t=GL_TYPE_TO_ARRAY_TYPE[n];if(!t)throw new Error("Failed to convert GL type");return t}function getByteSize(n){var t=getArrayType(n);return t.BYTES_PER_ELEMENT}function createTypedArray(n,t,e,r){e===void 0&&(e=0);var i=getArrayType(n);if(e%getByteSize(n)!==0){var o=r?t.slice(e,e+r*getByteSize(n)):t.slice(e);return new i(o)}else return new i(t,e,r??(t.byteLength-e)/getByteSize(n))}function glTypeFromName(n){var t=NAME_TO_GL_TYPE[n];if(!t)throw new Error("Failed to convert GL type");return t}var FeatureTable=function(){function n(t,e){this.featuresLength=0,this.cachedTypedArrays={},this.json=t,this.buffer=e;var r=this.getGlobalProperty("POINTS_LENGTH",GL_TYPE.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 o=getArrayType(e);return new o([i])}else if(Array.isArray(i)){var o=getArrayType(e);return new o(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=glTypeFromName(i.componentType)),this.getTypedArrayFromBinary(t,e,r,this.featuresLength,i.byteOffset)):this.getTypedArrayFromArray(t,e,i)},n.prototype.getProperty=function(t,e,r,i,o){var s=this.json[t];if(!s)return null;var u=this.getPropertyArray(t,e,r);if(r===1)return o[0]=u[i],o;for(var l=0;l<r;++l)o[l]=u[r*i+l];return o},n.prototype.getTypedArrayFromBinary=function(t,e,r,i,o){var s=this.cachedTypedArrays,u=s[t];return u||(u=createTypedArray(e,this.buffer.buffer,this.buffer.byteOffset+o,i*r),s[t]=u),u},n.prototype.getTypedArrayFromArray=function(t,e,r){var i=this.cachedTypedArrays,o=i[t];return o||(o=createTypedArray(e,r),i[t]=o),o},n}(),SIZEOF_UINT32=4,DEPRECATION_WARNING="b3dm tile in legacy format.";function getStringFromArrayBuffer(n,t,e){var r=new TextDecoder("utf8"),i=new Uint8Array(n,t,e),o=r.decode(i);return o}function parseTable(n,t,e){return e=parseTablesHeader(n,t,e),e=parseFeatureTable(n,t,e),e=parseBatchTable(n,t,e),e}function parseTablesHeader(n,t,e){var r=new DataView(t),i=0;n.header=n.header||{};var o=r.getUint32(e,!0);e+=SIZEOF_UINT32;var s=r.getUint32(e,!0);e+=SIZEOF_UINT32;var u=r.getUint32(e,!0);e+=SIZEOF_UINT32;var l=r.getUint32(e,!0);return e+=SIZEOF_UINT32,u>=570425344?(e-=SIZEOF_UINT32*2,i=o,u=s,l=0,o=0,s=0,console.warn(DEPRECATION_WARNING)):l>=570425344&&(e-=SIZEOF_UINT32,i=u,u=o,l=s,o=0,s=0,console.warn(DEPRECATION_WARNING)),n.header.featureTableJsonByteLength=o,n.header.featureTableBinaryByteLength=s,n.header.batchTableJsonByteLength=u,n.header.batchTableBinaryByteLength=l,n.header.batchLength=i,e}function parseFeatureTable(n,t,e){var r=n.header||{},i=r.featureTableJsonByteLength,o=r.featureTableBinaryByteLength,s=r.batchLength;if(n.featureTableJson={BATCH_LENGTH:s||0},i&&i>0){var u=getStringFromArrayBuffer(t,e,i);n.featureTableJson=JSON.parse(u)}e+=i||0,n.featureTableBinary=new Uint8Array(t,e,o),e+=o||0,n.rtcCenter=new THREE__namespace.Vector3;var l=new FeatureTable(n.featureTableJson,n.featureTableBinary);if(Array.isArray(l.json.RTC_CENTER))n.rtcCenter.fromArray(l.json.RTC_CENTER);else{var d=l.getGlobalProperty("RTC_CENTER",GL_TYPE.FLOAT,3);d&&n.rtcCenter.fromArray(d)}return e}function parseBatchTable(n,t,e){var r=n.header||{},i=r.batchTableJsonByteLength,o=r.batchTableBinaryByteLength;if(i&&i>0){var s=getStringFromArrayBuffer(t,e,i);n.batchTableJson=JSON.parse(s),e+=i,o&&o>0&&(n.batchTableBinary=new Uint8Array(t,e,o),n.batchTableBinary=new Uint8Array(n.batchTableBinary),e+=o)}return e}function sliceArrayBuffer(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 parseGlTFArrayBuffer(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=sliceArrayBuffer(t,e,r),n.byteLength}function decodeText(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 WEBGL_CONSTANTS={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},WEBGL_COMPONENT_TYPES={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array},WEBGL_FILTERS={9728:THREE__namespace.NearestFilter,9729:THREE__namespace.LinearFilter,9984:THREE__namespace.NearestMipmapNearestFilter,9985:THREE__namespace.LinearMipmapNearestFilter,9986:THREE__namespace.NearestMipmapLinearFilter,9987:THREE__namespace.LinearMipmapLinearFilter},WEBGL_WRAPPINGS={33071:THREE__namespace.ClampToEdgeWrapping,33648:THREE__namespace.MirroredRepeatWrapping,10497:THREE__namespace.RepeatWrapping},WEBGL_TYPE_SIZES={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},ATTRIBUTES={POSITION:"position",NORMAL:"normal",TANGENT:"tangent",TEXCOORD_0:"uv",TEXCOORD_1:"uv2",COLOR_0:"color",WEIGHTS_0:"skinWeight",JOINTS_0:"skinIndex"},PATH_PROPERTIES={scale:"scale",translation:"position",rotation:"quaternion",weights:"morphTargetInfluences"},INTERPOLATION={CUBICSPLINE:void 0,LINEAR:THREE__namespace.InterpolateLinear,STEP:THREE__namespace.InterpolateDiscrete},ALPHA_MODES={OPAQUE:"OPAQUE",MASK:"MASK",BLEND:"BLEND"};function values(n){var t=[];for(var e in n)t.push(n[e]);return t}var Parser=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,o=e.length;i<o;i++)for(var s=e[i].joints,u=0,l=s.length;u<l;u++)t[s[u]].isBone=!0;for(var d=0,c=t.length;d<c;d++){var f=t[d];f.mesh!==void 0&&f.skin!==void 0&&(r[f.mesh].isSkinnedMesh=!0)}},n.prototype.parse=function(){var t=this,e=this.json,r=this.extensions;this.dispose(),this.markDefs();for(var i=0,o=values(r);i<o.length;i++){var s=o[i];s.markDefs(this)}return Promise.all(values(r).map(function(u){return u.prepare(t)})).then(function(){var u,l,d;return Promise.all([Promise.all(((u=e.scenes)!==null&&u!==void 0?u:[]).map(function(c,f){return t.loadScene(f)})),Promise.all(((l=e.animations)!==null&&l!==void 0?l:[]).map(function(c,f){return t.loadAnimation(f)})),Promise.all(((d=e.cameras)!==null&&d!==void 0?d:[]).map(function(c,f){return t.loadCamera(f)}))])}).then(function(u){var l=u[0],d=u[1],c=u[2],f={json:t.json,scene:l[e.scene||0],scenes:l,animations:d,cameras:c,dispose:function(){return t.dispose()}};return Promise.all(values(r).map(function(h){return h.emitResult(f,t)})).then(function(){return f})})},n.prototype.loadCamera=function(t){var e="camera:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,o=0,s=values(this.extensions);o<s.length;o++){var u=s[o];if(i=u.loadCamera(t,this),i)break}if(!i){var l=void 0,d=this.json.cameras[t],c=d[d.type];c?d.type==="perspective"?l=new THREE__namespace.PerspectiveCamera(THREE__namespace.MathUtils.radToDeg(c.yfov),c.aspectRatio||1,c.znear||1,c.zfar||2e6):d.type==="orthographic"?l=new THREE__namespace.OrthographicCamera(-c.xmag,c.xmag,c.ymag,-c.ymag,c.znear,c.zfar):(console.warn("glTF: Invalid camera type ".concat(d.type,".")),l=new THREE__namespace.Camera):(console.warn("glTF: Missing camera parameters."),l=new THREE__namespace.Camera),d.name&&(l.name=this.createUniqueName(d.name)),i=Promise.resolve(l)}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,o=this.json.skins[t],s={joints:o.joints};return o.inverseBindMatrices===void 0?i=Promise.resolve(s):i=this.loadAccessor(o.inverseBindMatrices).then(function(u){return u&&(s.inverseBindMatrices=u),s}),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,o=0,s=values(this.extensions);o<s.length;o++){var u=s[o];if(i=u.loadAnimation(t,this),i)break}if(!i){for(var l=this.json,d=l.animations[t],c=[],f=[],h=[],v=[],A=[],m=0,y=d.channels.length;m<y;m++){var p=d.channels[m],g=d.samplers[p.sampler],b=p.target,T=b.node!==void 0?b.node:b.id,_=d.parameters!==void 0?d.parameters[g.input]:g.input,w=d.parameters!==void 0?d.parameters[g.output]:g.output;c.push(this.loadNode(T)),f.push(this.loadAccessor(_)),h.push(this.loadAccessor(w)),v.push(g),A.push(b)}i=Promise.all([Promise.all(c),Promise.all(f),Promise.all(h),Promise.all(v),Promise.all(A)]).then(function(x){for(var M=x[0],R=x[1],I=x[2],S=x[3],B=x[4],F=[],O=function(q,V){var D=M[q],K=R[q],z=I[q],G=S[q],W=B[q];if(D===void 0)return"continue";D.updateMatrix(),D.matrixAutoUpdate=!0;var Q=void 0;switch(PATH_PROPERTIES[W.path]){case PATH_PROPERTIES.weights:Q=THREE__namespace.NumberKeyframeTrack;break;case PATH_PROPERTIES.rotation:Q=THREE__namespace.QuaternionKeyframeTrack;break;case PATH_PROPERTIES.position:case PATH_PROPERTIES.scale:default:Q=THREE__namespace.VectorKeyframeTrack;break}var X=D.name?D.name:D.uuid,ee=G.interpolation!==void 0?INTERPOLATION[G.interpolation]:THREE__namespace.InterpolateLinear,J=[];PATH_PROPERTIES[W.path]===PATH_PROPERTIES.weights?D.traverse(function(se){se.morphTargetInfluences&&J.push(se.name?se.name:se.uuid)}):J.push(X);var Z=z.array;if(z.normalized){for(var te=getNormalizedComponentScale(Z.constructor),ae=new Float32Array(Z.length),re=0,ie=Z.length;re<ie;re++)ae[re]=Z[re]*te;Z=ae}for(var re=0,ie=J.length;re<ie;re++){var de=new Q(J[re]+"."+PATH_PROPERTIES[W.path],K.array,Z,ee);F.push(de)}},H=0,k=M.length;H<k;H++)O(H);var N=d.name?d.name:"animation_"+t;return new THREE__namespace.AnimationClip(N,void 0,F)})}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 o=null,s=0,u=values(this.extensions);s<u.length;s++){var l=u[s];if(o=l.loadBuffer(t,this),o)break}if(!o){var d=this.json.buffers[t];o=this.options.fetcher.ajax(this.resolveResouce(d.uri),{responseType:"arraybuffer"}).then(function(c){return c.body})}return this.cache.set(r,o),o},n.prototype.loadBufferView=function(t){var e="bufferView:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,o=0,s=values(this.extensions);o<s.length;o++){var u=s[o];if(i=u.loadBufferView(t,this),i)break}if(!i){var l=this.json.bufferViews[t];i=this.loadBuffer(l.buffer).then(function(d){var c=l.byteLength||0,f=l.byteOffset||0;return d.slice(f,f+c)})}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 o=null;if(!o){var s=this.json.accessors[t];if(s.bufferView===void 0&&s.sparse===void 0)o=Promise.resolve(null);else{var u=[];s.bufferView!==void 0?u.push(this.loadBufferView(s.bufferView)):u.push(Promise.resolve(null)),s.sparse!==void 0&&(u.push(this.loadBufferView(s.sparse.indices.bufferView)),u.push(this.loadBufferView(s.sparse.values.bufferView))),o=Promise.all(u).then(function(l){var d=l[0],c=WEBGL_TYPE_SIZES[s.type],f=WEBGL_COMPONENT_TYPES[s.componentType],h=f.BYTES_PER_ELEMENT,v=h*c,A=s.byteOffset||0,m=s.bufferView!==void 0?e.json.bufferViews[s.bufferView].byteStride:void 0,y=s.normalized===!0,p,g;if(m&&m!==v){var b=Math.floor(A/m),T="InterleavedBuffer:"+s.bufferView+":"+s.componentType+":"+b+":"+s.count,_=e.cache.get(T);_||(p=new f(d,b*m,s.count*m/h),_=new THREE__namespace.InterleavedBuffer(p,m/h),e.cache.set(T,_)),g=new THREE__namespace.InterleavedBufferAttribute(_,c,A%m/h,y)}else d===null?p=new f(s.count*c):p=new f(d,A,s.count*c),g=new THREE__namespace.BufferAttribute(p,c,y);if(s.sparse!==void 0){var w=WEBGL_TYPE_SIZES.SCALAR,x=WEBGL_COMPONENT_TYPES[s.sparse.indices.componentType],M=s.sparse.indices.byteOffset||0,R=s.sparse.values.byteOffset||0,I=new x(l[1],M,s.sparse.count*w),S=new f(l[2],R,s.sparse.count*c);d!==null&&(g=new THREE__namespace.BufferAttribute(g.array.slice(),g.itemSize,g.normalized));for(var B=0,F=I.length;B<F;B++){var O=I[B];if(g.setX(O,S[B*c]),c>=2&&g.setY(O,S[B*c+1]),c>=3&&g.setZ(O,S[B*c+2]),c>=4&&g.setW(O,S[B*c+3]),c>=5)throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.")}}return g})}}return this.cache.set(r,o),o},n.prototype.createPrimitiveKey=function(t){for(var e=0,r=values(this.extensions);e<r.length;e++){var i=r[e],o=i.createPrimitiveKey(t,this);if(o)return o}for(var s="",u=Object.keys(t.attributes).sort(),l=0,d=u.length;l<d;l++)s+=u[l]+":"+t.attributes[u[l]]+";";return t.indices+":"+s+":"+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 o=null,s=0,u=values(this.extensions);s<u.length;s++){var l=u[s];if(o=l.loadGeometry(t,this),o)break}return o||(o=this.addGeometryPrimitiveAttributes(new THREE__namespace.BufferGeometry,t)),o=o.then(function(d){return e.disposeSet.add(d),d}),this.cache.set(r,o),o},n.prototype.loadImage=function(t){var e="image:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,o=0,s=values(this.extensions);o<s.length;o++){var u=s[o];if(i=u.loadImage(t,this),i)break}if(!i){var l=this.json.images[t];if(l.bufferView)i=this.loadBufferView(l.bufferView).then(function(c){var f=new Blob([c],{type:l.mimeType});return createImageBitmapLike(f)});else if(l.uri){var d=this.resolveResouce(l.uri);i=this.options.fetcher.loadImage(d,{},void 0,void 0,void 0,createImageBitmapLikeImage()).then(function(c){return c.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 THREE__namespace.MeshStandardMaterial;if(i.color=new THREE__namespace.Color(1,1,1),i.opacity=1,Object.keys(t.attributes).filter(function(c){return ATTRIBUTES[c]==="color"}).length>0&&(i.vertexColors=!0),Object.keys(t.attributes).filter(function(c){return ATTRIBUTES[c]==="normal"}).length===0&&(i.flatShading=!0),Object.keys(t.attributes).filter(function(c){return ATTRIBUTES[c]==="tangent"}).length===0&&(i.normalScale&&(i.normalScale.y*=-1),i.clearcoatNormalScale&&(i.clearcoatNormalScale.y*=-1)),t.material!==void 0){var o=this.json.materials[t.material];o.name&&(i.name=o.name);var s=o.pbrMetallicRoughness||{};if(Array.isArray(s.baseColorFactor)){var u=s.baseColorFactor;i.color.fromArray(u),i.opacity=u[3]}s.baseColorTexture!==void 0&&r.push(this.createMaterialTexture(s.baseColorTexture).then(function(c){c.encoding=THREE__namespace.sRGBEncoding,i.map=c,e.disposeSet.add(c)})),i.metalness=s.metallicFactor!==void 0?s.metallicFactor:1,i.roughness=s.roughnessFactor!==void 0?s.roughnessFactor:1,s.metallicRoughnessTexture!==void 0&&r.push(this.createMaterialTexture(s.metallicRoughnessTexture).then(function(c){c.encoding=THREE__namespace.sRGBEncoding,i.metalnessMap=c,i.roughnessMap=c,e.disposeSet.add(c)})),o.doubleSided===!0&&(i.side=THREE__namespace.DoubleSide);var l=o.alphaMode||ALPHA_MODES.OPAQUE;if(l===ALPHA_MODES.BLEND?(i.transparent=!0,i.depthWrite=!1):(i.transparent=!1,l===ALPHA_MODES.MASK&&(i.alphaTest=o.alphaCutoff!==void 0?o.alphaCutoff:.5)),o.normalTexture!==void 0&&(r.push(this.createMaterialTexture(o.normalTexture).then(function(c){i.normalMap=c,e.disposeSet.add(c)})),i.normalScale=new THREE__namespace.Vector2(1,1),o.normalTexture.scale!==void 0)){var d=o.normalTexture.scale;i.normalScale.set(d,d)}o.occlusionTexture!==void 0&&(r.push(this.createMaterialTexture(o.occlusionTexture).then(function(c){i.aoMap=c,e.disposeSet.add(c)})),o.occlusionTexture.strength!==void 0&&(i.aoMapIntensity=o.occlusionTexture.strength)),o.emissiveFactor!==void 0&&(i.emissive=new THREE__namespace.Color().fromArray(o.emissiveFactor)),o.emissiveTexture!==void 0&&r.push(this.createMaterialTexture(o.emissiveTexture).then(function(c){i.emissiveMap=c,e.disposeSet.add(c)}))}return this.disposeSet.add(i),Promise.all(r).then(function(){return i})},n.prototype.loadMaterialAsLineBasicMaterial=function(t){var e=[],r=new THREE__namespace.LineBasicMaterial;if(r.color=new THREE__namespace.Color(1,1,1),r.opacity=1,Object.keys(t.attributes).filter(function(l){return ATTRIBUTES[l]==="color"}).length>0&&(r.vertexColors=!0),Object.keys(t.attributes).filter(function(l){return ATTRIBUTES[l]==="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 o=i.pbrMetallicRoughness||{};if(Array.isArray(o.baseColorFactor)){var s=o.baseColorFactor;r.color.fromArray(s),r.opacity=s[3]}i.doubleSided===!0&&(r.side=THREE__namespace.DoubleSide);var u=i.alphaMode||ALPHA_MODES.OPAQUE;u===ALPHA_MODES.BLEND?(r.transparent=!0,r.depthWrite=!1):(r.transparent=!1,u===ALPHA_MODES.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 THREE__namespace.PointsMaterial;if(i.color=new THREE__namespace.Color(1,1,1),i.opacity=1,i.sizeAttenuation=!1,Object.keys(t.attributes).filter(function(d){return ATTRIBUTES[d]==="color"}).length>0&&(i.vertexColors=!0),Object.keys(t.attributes).filter(function(d){return ATTRIBUTES[d]==="tangent"}).length===0&&(i.normalScale&&(i.normalScale.y*=-1),i.clearcoatNormalScale&&(i.clearcoatNormalScale.y*=-1)),t.material!==void 0){var o=this.json.materials[t.material];o.name&&(i.name=o.name);var s=o.pbrMetallicRoughness||{};if(Array.isArray(s.baseColorFactor)){var u=s.baseColorFactor;i.color.fromArray(u),i.opacity=u[3]}s.baseColorTexture!==void 0&&r.push(this.createMaterialTexture(s.baseColorTexture).then(function(d){d.encoding=THREE__namespace.sRGBEncoding,i.map=d,e.disposeSet.add(d)})),o.doubleSided===!0&&(i.side=THREE__namespace.DoubleSide);var l=o.alphaMode||ALPHA_MODES.OPAQUE;l===ALPHA_MODES.BLEND?(i.transparent=!0,i.depthWrite=!1):(i.transparent=!1,l===ALPHA_MODES.MASK&&(i.alphaTest=o.alphaCutoff!==void 0?o.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:WEBGL_CONSTANTS.TRIANGLES,o="material:"+this.createPrimitiveKey(t),s=this.cache.get(o);if(s)return s;for(var u=null,l=0,d=values(this.extensions);l<d.length;l++){var c=d[l];if(u=c.loadMaterial(t,this),u)break}if(i===WEBGL_CONSTANTS.TRIANGLES||i===WEBGL_CONSTANTS.TRIANGLE_STRIP||i===WEBGL_CONSTANTS.TRIANGLE_FAN)u=this.loadMaterialAsMeshStandardMaterial(t);else if(i===WEBGL_CONSTANTS.LINES||i===WEBGL_CONSTANTS.LINE_STRIP||i===WEBGL_CONSTANTS.LINE_LOOP)u=this.loadMaterialAsLineBasicMaterial(t);else if(i===WEBGL_CONSTANTS.POINTS)u=this.loadMaterialAsPointsMaterial(t);else throw new Error("glTF: Primitive mode unsupported: "+i);return u=u.then(function(f){return e.disposeSet.add(f),f}),this.cache.set(o,u),u},n.prototype.loadTexture=function(t){var e=this,r="texture:"+t,i=this.cache.get(r);if(i)return i;for(var o=null,s=0,u=values(this.extensions);s<u.length;s++){var l=u[s];if(o=l.loadTexture(t,this),o)break}if(!o){var d=this.json.textures[t];o=this.loadImage(d.source).then(function(c){var f=new THREE__namespace.Texture(c);f.needsUpdate=!0,f.flipY=!1,d.name&&(f.name=d.name);var h=e.json.samplers||{},v=h[d.sampler]||{};f.magFilter=WEBGL_FILTERS[v.magFilter]||THREE__namespace.LinearFilter,f.minFilter=WEBGL_FILTERS[v.minFilter]||THREE__namespace.LinearMipmapLinearFilter,f.wrapS=WEBGL_WRAPPINGS[v.wrapS]||THREE__namespace.RepeatWrapping,f.wrapT=WEBGL_WRAPPINGS[v.wrapT]||THREE__namespace.RepeatWrapping;var A=f.dispose;return f.dispose=function(){return f.dispose=A,c.close(),A.call(this)},f})}return o=o.then(function(c){return e.disposeSet.add(c),c}),this.cache.set(r,o),o},n.prototype.loadMesh=function(t){for(var e=this,r=null,i=0,o=values(this.extensions);i<o.length;i++){var s=o[i];if(r=s.loadMesh(t,this),r)break}if(!r){var u=this.json.meshes[t],l=u.primitives,d=Promise.all(l.map(function(f){return e.loadGeometry(f)})),c=Promise.all(l.map(function(f){return e.loadMaterial(f)}));r=Promise.all([d,c]).then(function(f){for(var h=f[0],v=f[1],A=[],m=0;m<l.length;m++){var y=l[m],p=h[m],g=v[m],b=y.mode||WEBGL_CONSTANTS.TRIANGLES,T=void 0;if(b===WEBGL_CONSTANTS.TRIANGLES||b===WEBGL_CONSTANTS.TRIANGLE_STRIP||b===WEBGL_CONSTANTS.TRIANGLE_FAN)if(b===WEBGL_CONSTANTS.TRIANGLE_STRIP?p=e.toGeometryTrianglesDrawMode(p,THREE__namespace.TriangleStripDrawMode):b===WEBGL_CONSTANTS.TRIANGLE_FAN&&(p=e.toGeometryTrianglesDrawMode(p,THREE__namespace.TriangleFanDrawMode)),u.isSkinnedMesh){var _=new THREE__namespace.SkinnedMesh(p,g);p.attributes.skinWeight.normalized||_.normalizeSkinWeights(),T=_}else T=new THREE__namespace.Mesh(p,g);else if(b===WEBGL_CONSTANTS.POINTS)T=new THREE__namespace.Points(p,g);else if(b===WEBGL_CONSTANTS.LINES)T=new THREE__namespace.LineSegments(p,g);else if(b===WEBGL_CONSTANTS.LINE_STRIP)T=new THREE__namespace.Line(p,g);else if(b===WEBGL_CONSTANTS.LINE_LOOP)T=new THREE__namespace.LineLoop(p,g);else throw new Error("glTF: Primitive mode unsupported: "+b);if(Object.keys(p.morphAttributes).length>0){if(u.weights!==void 0)for(var w=0,x=u.weights.length;w<x;w++)T.morphTargetInfluences[w]=u.weights[w];if(u.extras&&Array.isArray(u.extras.targetNames)){var M=u.extras.targetNames;if(T.morphTargetInfluences.length===M.length){T.morphTargetDictionary={};for(var w=0,x=M.length;w<x;w++)T.morphTargetDictionary[M[w]]=w}else console.warn("glTF: Invalid extras.targetNames length. Ignoring names.")}}T.name=e.createUniqueName(u.name||"mesh_"+t),A.push(T)}if(A.length===1)return A[0];for(var R=new THREE__namespace.Group,I=0,S=A;I<S.length;I++){var T=S[I];R.add(T)}return R})}return r},n.prototype.loadNodeAttachments=function(t){for(var e=[],r=0,i=values(this.extensions);r<i.length;r++){var o=i[r],s=o.loadNodeAttachments(t,this);s&&e.push(s)}return e},n.prototype.loadNode=function(t){var e="node:"+t,r=this.cache.get(e);if(r)return r;var i=this.json,o=i.nodes[t],s=o.name?this.createUniqueName(o.name):"",u=[];o.mesh!==void 0&&u.push(this.loadMesh(o.mesh).then(function(h){if(o.weights!==void 0){var v=o.weights;h.traverse(function(A){if(A instanceof THREE__namespace.Mesh||A instanceof THREE__namespace.Line||A instanceof THREE__namespace.Points)for(var m=0,y=v.length;m<y;m++)A.morphTargetInfluences[m]=v[m]})}return h})),o.camera!==void 0&&u.push(this.loadCamera(o.camera));for(var l=this.loadNodeAttachments(t),d=0,c=l;d<c.length;d++){var f=c[d];u.push(f)}return Promise.all(u).then(function(h){var v;if(o.isBone===!0?v=new THREE__namespace.Bone:h.length>1?v=new THREE__namespace.Group:h.length===1?v=h[0]:v=new THREE__namespace.Object3D,v!==h[0])for(var A=0,m=h.length;A<m;A++)v.add(h[A]);if(o.name&&(v.name=s),o.matrix!==void 0){var y=new THREE__namespace.Matrix4;y.fromArray(o.matrix),v.applyMatrix4(y)}else o.translation!==void 0&&v.position.fromArray(o.translation),o.rotation!==void 0&&v.quaternion.fromArray(o.rotation),o.scale!==void 0&&v.scale.fromArray(o.scale);return v})},n.prototype.loadScene=function(t){var e=this.json,r=e.scenes[t],i=new THREE__namespace.Group;r.name&&(i.name=this.createUniqueName(r.name));for(var o=r.nodes||[],s=[],u=0,l=o.length;u<l;u++)s.push(this.buildNodeHierarchy(o[u],i));return Promise.all(s).then(function(){return i})},n.prototype.createMaterialTexture=function(t){var e=this;return this.loadTexture(t.index).then(function(r){for(var i=0,o=values(e.extensions);i<o.length;i++){var s=o[i],u=s.extendTexture(r,t,e);u&&(r=u)}return r})},n.prototype.addGeometryPrimitiveAttributes=function(t,e){var r=this,i=e.attributes,o=[],s=function(_){var w=ATTRIBUTES[_]||_.toLowerCase();if(w in t.attributes)return"continue";o.push(u.loadAccessor(i[_]).then(function(x){x&&t.setAttribute(w,x)}))},u=this;for(var l in i)s(l);e.indices!==void 0&&!t.index&&o.push(this.loadAccessor(e.indices).then(function(_){_&&t.setIndex(_)}));var d=new THREE__namespace.Box3;if(i.POSITION!==void 0){var c=this.json.accessors[i.POSITION],f=c.min,h=c.max;if(f!==void 0&&h!==void 0){if(d.set(new THREE__namespace.Vector3(f[0],f[1],f[2]),new THREE__namespace.Vector3(h[0],h[1],h[2])),c.normalized){var v=getNormalizedComponentScale(WEBGL_COMPONENT_TYPES[c.componentType]);d.min.multiplyScalar(v),d.max.multiplyScalar(v)}}else console.warn("glTF: Missing min/max properties for accessor POSITION.")}var A=e.targets;if(A!==void 0){for(var m=new THREE__namespace.Vector3,y=new THREE__namespace.Vector3,p=0,g=A.length;p<g;p++){var b=A[p];if(b.POSITION!==void 0){var c=this.json.accessors[b.POSITION],f=c.min,h=c.max;if(f!==void 0&&h!==void 0){if(y.setX(Math.max(Math.abs(f[0]),Math.abs(h[0]))),y.setY(Math.max(Math.abs(f[1]),Math.abs(h[1]))),y.setZ(Math.max(Math.abs(f[2]),Math.abs(h[2]))),c.normalized){var v=getNormalizedComponentScale(WEBGL_COMPONENT_TYPES[c.componentType]);y.multiplyScalar(v)}m.max(y)}else console.warn("glTF: Missing min/max properties for accessor POSITION.")}}d.expandByVector(m)}t.boundingBox=d;var T=new THREE__namespace.Sphere;return d.getCenter(T.center),T.radius=d.min.distanceTo(d.max)/2,t.boundingSphere=T,Promise.all(o).then(function(){if(t.attributes.uv&&!t.attributes.uv2&&r.options.copyUV2&&t.setAttribute("uv2",t.attributes.uv),e.targets){for(var _=!1,w=!1,x=0,M=e.targets.length;x<M;x++){var R=e.targets[x];if(R.POSITION!==void 0&&(_=!0),R.NORMAL!==void 0&&(w=!0),_&&w)break}if(!_&&!w)return t;var I=[];t.morphTargetsRelative=!0;for(var S=function(B,F){var O=e.targets[B];_?I.push(r.loadAccessor(O.POSITION).then(function(H){H&&(t.morphAttributes.position[B]=H)})):t.morphAttributes.position[B]=t.attributes.position,w?I.push(r.loadAccessor(O.NORMAL).then(function(H){H&&(t.morphAttributes.normal[B]=H)})):t.morphAttributes.normal[B]=t.attributes.normal},x=0,M=e.targets.length;x<M;x++)S(x,M);return Promise.all(I).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(o){if(i.skin===void 0)return o;var s;return r.loadSkin(i.skin).then(function(u){s=u;for(var l=[],d=0,c=s.joints.length;d<c;d++)l.push(r.loadNode(s.joints[d]));return Promise.all(l)}).then(function(u){return o.traverse(function(l){if(l instanceof THREE__namespace.SkinnedMesh){for(var d=[],c=[],f=0,h=u.length;f<h;f++){var v=u[f];if(v instanceof THREE__namespace.Bone){d.push(v);var A=new THREE__namespace.Matrix4;s.inverseBindMatrices!==void 0&&A.fromArray(s.inverseBindMatrices.array,f*16),c.push(A)}else console.warn('glTF: Joint "%s" could not be found.',s.joints[f])}l.bind(new THREE__namespace.Skeleton(d,c),l.matrixWorld)}}),o})}).then(function(o){e.add(o);var s=[];if(i.children)for(var u=i.children,l=0,d=u.length;l<d;l++){var c=u[l];s.push(r.buildNodeHierarchy(c,o))}return Promise.all(s).then(function(){return o})})},n.prototype.createUniqueName=function(t){for(var e=THREE__namespace.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 pathJoin(this.options.resourcePath,appendSearch(t,this.options.search))},n.prototype.toGeometryTrianglesDrawMode=function(t,e){var r=t.getIndex();if(r===null){var i=[],o=t.getAttribute("position");if(o!==void 0){for(var s=0;s<o.count;s++)i.push(s);t.setIndex(i),r=t.getIndex()}}if(r===null)return console.error("glTF: Undefined position attribute. Processing not possible."),t;var u=r.count-2,l=[];if(e===THREE__namespace.TriangleFanDrawMode)for(var s=1;s<=u;s++)l.push(r.getX(0)),l.push(r.getX(s)),l.push(r.getX(s+1));else for(var s=0;s<u;s++)s%2===0?(l.push(r.getX(s)),l.push(r.getX(s+1)),l.push(r.getX(s+2))):(l.push(r.getX(s+2)),l.push(r.getX(s+1)),l.push(r.getX(s)));l.length/3!==u&&console.error("glTF: Unable to generate correct amount of triangles.");var d=t.clone();return d.setIndex(l),d},n}();function getNormalizedComponentScale(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 BaseExtension=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}(),KHR_binary_glTF=function(n){__extends(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 decodeText(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),o=0,s=null,u=null;o<i.byteLength;){var l=i.getUint32(o,!0);o+=4;var d=i.getUint32(o,!0);if(o+=4,d===t.CHUNK_TYPES.JSON){var c=new Uint8Array(e,t.HEADER_LENGTH+o,l);s=decodeText(c)}else if(d===t.CHUNK_TYPES.BIN){var f=t.HEADER_LENGTH+o;u=e.slice(f,f+l)}o+=l}if(s===null)throw new Error("glTF:KHR_binary_glTF: JSON content not found.");this.content=s,this.body=u},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}(BaseExtension),defaultDecoderPath="https://vr-public.realsee-cdn.cn/release/static/image/release/five/resource/draco/1.5.6/",defaultAttributeIDs={position:"POSITION",normal:"NORMAL",color:"COLOR",uv:"TEX_COORD"},defaultAttributeTypes={position:"Float32Array",normal:"Float32Array",color:"Float32Array",uv:"Float32Array"},Draco=function(){function n(){this.decoderPath=defaultDecoderPath,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 o={attributeIDs:r||defaultAttributeIDs,attributeTypes:i||defaultAttributeTypes,useUniqueIDs:!!r};this.decodeGeometry(t,o).then(e)},n.prototype.decodeGeometry=function(t,e){var r=this;e===void 0&&(e={attributeIDs:defaultAttributeIDs,attributeTypes:defaultAttributeTypes,useUniqueIDs:!1});for(var i in e.attributeTypes){var o=e.attributeTypes[i];o.BYTES_PER_ELEMENT!==void 0&&(e.attributeTypes[i]=o.name)}var s,u=this.workerNextTaskID++,l=t.byteLength,d=this._getWorker(u,l).then(function(c){return s=c,new Promise(function(f,h){s._callbacks[u]={resolve:f,reject:h},s.postMessage({type:"decode",id:u,taskConfig:e,buffer:t},[t])})}).then(function(c){return r._createGeometry(c.geometry)});return d.catch(function(){return!0}).then(function(){s&&u&&r._releaseTask(s,u)}),d},n.prototype._createGeometry=function(t){var e=new THREE__namespace.BufferGeometry;t.index&&e.setIndex(new THREE__namespace.BufferAttribute(t.index.array,1));for(var r=0;r<t.attributes.length;r++){var i=t.attributes[r],o=i.name,s=i.array,u=i.itemSize;e.setAttribute(o,new THREE__namespace.BufferAttribute(s,u))}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=ajax(this.decoderPath+"draco_decoder.js",{responseType:"text"}).then(function(o){return o.body});this.decoderPending=r.then(function(o){var s=["/* draco decoder */",o,"","/* worker */",DRACOWorker].join(`
|
|
417
|
+
`,cacheMaterials=[];function getMaterial(){var n=cacheMaterials.pop();return n||new THREE__namespace.ShaderMaterial({uniforms:{map:{value:null},flipY:{value:0}},vertexShader:PLANE_VERTEX_SHADER,fragmentShader:PLANE_FRAGMENT_SHADER,depthTest:!1,depthWrite:!1,stencilWrite:!1,blending:THREE__namespace.NoBlending,lights:!1,toneMapped:!1,fog:!1})}function releaseMaterial(n){n.uniforms.map.value=null,cacheMaterials.push(n)}function renderTexturesToCubeRenderTarget(n,t,e){var r=new THREE__namespace.Scene;r.matrixAutoUpdate=!1;var i=new THREE__namespace.Group;i.scale.set(1,1,-1),r.add(i);for(var o=[],s=0,u=n;s<u.length;s++){var l=u[s],d=getMaterial();o.push(d),d.uniforms.map.value=l.texture,d.uniforms.flipY.value=l.flipY?1:0;var c=new THREE__namespace.Group,f=new THREE__namespace.Mesh(PLAME_GEOMETRY,d);f.position.set(l.position.x+l.size.x/2-.5,1-(l.position.y+l.size.y/2)-.5,-.5),f.scale.set(l.size.x,l.size.y,1),c.quaternion.copy(QUATERNION[l.face]),c.add(f),i.add(c)}var h=e.autoClear;e.autoClear=!1;var v=new THREE__namespace.CubeCamera(.1,2,t);v.matrixAutoUpdate=!1,v.update(e,r),e.autoClear=h;for(var A=0,m=o;A<m.length;A++){var d=m[A];releaseMaterial(d)}}var asyncImageTaskQueue=[],IMAGE_TASK_EACH_FRAME=6,imageTaskEachFrame=0;AnimationFrameLoop.shared.add(function(){if(imageTaskEachFrame=IMAGE_TASK_EACH_FRAME,asyncImageTaskQueue.length)for(var n=asyncImageTaskQueue.splice(0,imageTaskEachFrame),t=0,e=n;t<e.length;t++){var r=e[t];imageTaskEachFrame--,r()}});var canUseNativeImageBitmap=function(){return!1}();function createImageBitmapLikeImage(){var n=Object.assign(document.createElementNS("http://www.w3.org/1999/xhtml","img"),{crossOrigin:"",close:function(){n.onerror=n.onload=n.close=noop$1;var t=n.src;n.removeAttribute("src"),/^blob\:/.test(t)&&URL.revokeObjectURL(t)}});return n}function createImageBitmapLike(n){return new Promise(function(t,e){var r=createImageBitmapLikeImage();r.onload=function(){/^blob\:/.test(r.src)&&URL.revokeObjectURL(r.src),r.onload=r.onerror=noop$1,setTimeout(function(){t(r)},0)},r.onerror=function(){var i=r.src;r.onload=r.onerror=noop$1,r.close(),e(new Error("image load error: ".concat(i)))},r.src=URL.createObjectURL(n)})}function createImageBitmapLikeAsync(n){return new Promise(function(t){asyncImageTaskQueue.push(function(){t(createImageBitmapLike(n))})})}var canvasPool=[];function createCanvas(n,t){var e=canvasPool.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=noop$1,canvasPool.push(r)}});return r}function poolImageToTexture(n,t){if(t&&(n.width>t.width||n.height>t.height)){var e=createCanvas(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 THREE__namespace.Texture(e);i.needsUpdate=!0,i.flipY=!0;var o=i.dispose;return i.dispose=function(){e.close(),o.call(i),i.dispose=o},i}else{var s=new THREE__namespace.Texture(n);s.needsUpdate=!0,typeof ImageBitmap<"u"&&n instanceof ImageBitmap?s.flipY=!1:s.flipY=!0;var u=s.dispose;return s.dispose=function(){n.close(),u.call(s),s.dispose=u},s}}function poolImagesToCubeTexture(n){var t=new THREE__namespace.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 o=i[r];o.close()}e.call(t),t.dispose=e},t}var FACE_ORDER=["right","left","up","down","front","back"],MAX_TILE_RENDER_EACH_FRAME=4,TileCubeTextureTarget=function(){function n(t,e,r,i,o){this.tileTree=e,this.tileSources=r,this.options=i,this.renderer=o,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,o,s;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:THREE__namespace.RGBAFormat,t.texture.minFilter=(r=this.options.minFilter)!==null&&r!==void 0?r:THREE__namespace.LinearFilter,t.texture.magFilter=(i=this.options.magFilter)!==null&&i!==void 0?i:THREE__namespace.LinearFilter,t.texture.wrapS=(o=this.options.wrapS)!==null&&o!==void 0?o:THREE__namespace.ClampToEdgeWrapping,t.texture.wrapT=(s=this.options.wrapT)!==null&&s!==void 0?s:THREE__namespace.ClampToEdgeWrapping,this.baseCubeTexture&&(renderCubeTextureToCubeRenderTarget(this.baseCubeTexture,t,this.renderer),this.baseCubeTexture.dispose(),this.baseCubeTexture=null),this._cubeRenderTarget&&renderCubeTextureToCubeRenderTarget(this._cubeRenderTarget.texture,t,this.renderer),this._cubeRenderTarget=t},enumerable:!1,configurable:!0}),n.prototype.requestTile=function(t){var e=this,r,i,o,s,u,l,d=this.tileSources.filter(function(m){return m.level===t.level})[0];if(!d){this.loadedCubeNodes.add(t);return}var c=d.size,f=Math.pow(2,t.level)*t.position.y,h=Math.pow(2,t.level)*t.position.x,v="".concat(((o=(i=(r=this.options.imageURL)===null||r===void 0?void 0:r.options)===null||i===void 0?void 0:i.key)!==null&&o!==void 0?o:"pano.0").replace(/^pano/,"pano_tile"),".").concat(t.face,".").concat(t.level,".").concat(f,".").concat(h),A=__assign(__assign({},(u=(s=this.options.imageURL)===null||s===void 0?void 0:s.options)!==null&&u!==void 0?u:{key:"unknown"}),{key:v,size:c*t.size===this.options.tileImageSize?void 0:this.options.tileImageSize,quality:void 0,cut:[c*t.position.x,c*t.position.y,c*t.size,c*t.size]});this.loadingCubeNodes.add(t),this.options.textureLoader.loadTexture(d[t.face],{imageURL:{transform:(l=this.options.imageURL)===null||l===void 0?void 0:l.transform,options:__assign({},A)},format:THREE__namespace.RGBAFormat,viaAjax:canUseNativeImageBitmap,timeout:this.options.timeout,fetcher:this.options.fetcher}).then(function(m){if(e.disposed){m.body.dispose();return}e.textures.push({face:t.face,level:t.level,position:t.position,size:new THREE__namespace.Vector2(t.size,t.size),texture:m.body,flipY:!m.body.flipY}),e.loadedCubeNodes.add(t)}).catch(noop$1).then(function(){e.disposed||e.loadingCubeNodes.delete(t)})},n.prototype.update=function(t,e){var r=this;if(!this.disposed){var i=[];traverseTileCubeNode(this.tileTree,function(h){if(r.loadingCubeNodes.has(h)||h.level>e||!t.intersectsBox(h.box))return!1;if(!r.loadedCubeNodes.has(h))return i.push(h),!1});for(var o=0,s=i;o<s.length;o++){var u=s[o];this.requestTile(u)}if(this.cubeRenderTarget&&this.textures.length){var l=this.textures.splice(0,MAX_TILE_RENDER_EACH_FRAME);renderTexturesToCubeRenderTarget(l,this.cubeRenderTarget,this.renderer),this.needsRender=!0;for(var d=0,c=l;d<c.length;d++){var f=c[d];f.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}(),TextureLoader=function(){function n(){}return n.prototype.loadTexture=function(t,e,r,i,o,s){var u,l,d,c;r===void 0&&(r=noop$1),i===void 0&&(i=noop$1),o===void 0&&(o=noop$1);var f={};typeof e.flipY<"u"&&(f.flipY=e.flipY),typeof e.format<"u"&&(f.format=e.format),typeof e.minFilter<"u"&&(f.minFilter=e.minFilter),typeof e.magFilter<"u"&&(f.magFilter=e.magFilter);var h=(l=(u=e.imageURL)===null||u===void 0?void 0:u.options)!==null&&l!==void 0?l:{key:"unknown"};t=applyImageURLOptions(t,(d=e.imageURL)===null||d===void 0?void 0:d.transform,h);var v=getProtocol(t),A=(c=e.viaAjax)!==null&&c!==void 0?c:!1,m=isJsonpSource(t),y=/^https?:/.test(v);if(m?A=!0:y||(A=!1),A){var p=null,g="blob";return e.fetcher.ajax(t,{timeout:e.timeout,responseType:g},void 0,void 0,o).then(function(_){return createImageBitmapLikeAsync(_.body)}).then(function(_){return poolImageToTexture(_,e.maxSize)}).then(function(_){return Object.assign(_,f),_}).then(function(_){var w={meta:p,body:_};return r(w),w}).catch(function(_){return i(_),Promise.reject(_)})}else{var b=null,T;return Promise.resolve().then(function(){return createImageBitmapLikeImage()}).then(function(_){return T=_,e.fetcher.loadImage(t,{timeout:e.timeout},void 0,void 0,o,_)}).then(function(_){return b=_.meta,poolImageToTexture(_.body,e.maxSize)}).then(function(_){return Object.assign(_,f),_}).then(function(_){var w={meta:b,body:_};return r(w),w}).catch(function(_){return T&&T.close(),i(_),Promise.reject(_)})}},n.prototype.loadCubeTexture=function(t,e,r,i,o,s){var u,l,d,c;r===void 0&&(r=noop$1),i===void 0&&(i=noop$1),o===void 0&&(o=noop$1),typeof e.format<"u"&&e.format,typeof e.minFilter<"u"&&e.minFilter,typeof e.magFilter<"u"&&e.magFilter;for(var f=[t[FACE_ORDER[0]],t[FACE_ORDER[1]],t[FACE_ORDER[2]],t[FACE_ORDER[3]],t[FACE_ORDER[4]],t[FACE_ORDER[5]]],h=[],v=[0,0,0,0,0,0],A=[],m=function(p){var g=(l=(u=e.imageURL)===null||u===void 0?void 0:u.options)!==null&&l!==void 0?l:{key:"unknown"},b=applyImageURLOptions(f[p],(d=e.imageURL)===null||d===void 0?void 0:d.transform,__assign(__assign({},g),{key:g.key+"."+FACE_ORDER[p]})),T=getProtocol(b),_=function(B){v[p]=B,o(v.reduce(function(O,F){return O+F},0)/6)},w=(c=e.viaAjax)!==null&&c!==void 0?c:!1,x=/^https?:$/.test(T),M=isJsonpSource(b);if(M?w=!0:x||(w=!1),w){var R="blob",I=e.fetcher.ajax(b,{timeout:e.timeout,responseType:R},void 0,void 0,_).then(function(B){return A[p]=B.meta,createImageBitmapLikeAsync(B.body)});h.push(I)}else{var S,I=Promise.resolve().then(function(){return createImageBitmapLikeImage()}).then(function(O){return S=O,e.fetcher.loadImage(b,{timeout:e.timeout},void 0,void 0,_,O)}).then(function(O){return A[p]=O.meta,O.body}).catch(function(O){return S&&S.close(),Promise.reject(O)});h.push(I)}},y=0;y<6;y++)m(y);return Promise.all(h).then(function(p){return poolImagesToCubeTexture(p)}).then(function(p){return Object.assign(p,__assign({encoding:THREE__namespace.sRGBEncoding},e)),p}).then(function(p){var g={body:p,meta:A};return r(g),g}).catch(function(p){for(var g=0,b=h;g<b.length;g++){var T=b[g];T.then(function(_){return _.close()}).catch(noop$1)}return i(p),Promise.reject(p)})},n.prototype.loadTiledCubeTexture=function(t,e,r,i,o,s,u){var l=this;return i===void 0&&(i=noop$1),o===void 0&&(o=noop$1),s===void 0&&(s=noop$1),new Promise(function(d,c){var f,h;l.loadCubeTexture(t,{imageURL:{transform:(f=r.imageURL)===null||f===void 0?void 0:f.transform,options:(h=r.imageURL)===null||h===void 0?void 0:h.options},format:THREE__namespace.RGBAFormat,viaAjax:r.viaAjax,timeout:r.timeout,fetcher:r.fetcher},function(v){var A,m,y=v.meta,p=v.body,g=(A=r.tileImageSize)!==null&&A!==void 0?A:512,b=(m=r.tileMaxLevel)!==null&&m!==void 0?m:2,T=Math.max(1024*b,512),_=createTileCubeTree(b),w=new TileCubeTextureTarget(p,_,e,{textureSize:T,tileImageSize:g,textureLoader:l,imageURL:r.imageURL,timeout:r.timeout,fetcher:r.fetcher},u),x={meta:y,body:w};i(x),d(x)},function(v){o(v),c(v)},s,u).catch(noop$1)})},n}();const vertexShader$6=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}("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"),fragmentShader$6=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}("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 EMPTY_CUBE_TEXTURE=new THREE__namespace.WebGLCubeRenderTarget(1).texture;EMPTY_CUBE_TEXTURE.name="EMPTY_TEXTURE";var shaderUniforms$2=Object.assign({modelAlpha:new THREE__namespace.Uniform(0),progress:new THREE__namespace.Uniform(0),pano0_map:new THREE__namespace.Uniform(EMPTY_CUBE_TEXTURE),pano0_luminanceMap:new THREE__namespace.Uniform(null),pano0_matrix:new THREE__namespace.Uniform(new THREE__namespace.Matrix4),pano1_map:new THREE__namespace.Uniform(EMPTY_CUBE_TEXTURE),pano1_luminanceMap:new THREE__namespace.Uniform(null),pano1_matrix:new THREE__namespace.Uniform(new THREE__namespace.Matrix4),clippers:new THREE__namespace.Uniform([]),shownFloorIndex:new THREE__namespace.Uniform(-1),constantColor:new THREE__namespace.Uniform(null),floor:new THREE__namespace.Uniform(0)},{exposure:new THREE__namespace.Uniform(1),emissive:new THREE__namespace.Uniform(new THREE__namespace.Color(0)),emissiveMap:new THREE__namespace.Uniform(null),specular:new THREE__namespace.Uniform(new THREE__namespace.Color(1118481)),specularMap:new THREE__namespace.Uniform(null),normalMap:new THREE__namespace.Uniform(null),bumpMap:new THREE__namespace.Uniform(null),shininess:new THREE__namespace.Uniform(30)},THREE__namespace.UniformsUtils.clone(THREE__namespace.UniformsLib.common),THREE__namespace.UniformsUtils.clone(THREE__namespace.UniformsLib.lights)),PBMMeshMaterial=function(n){__extends(t,n);function t(e){e===void 0&&(e={});var r,i,o,s,u,l,d,c,f,h,v,A,m,y,p,g,b,T,_,w,x=n.call(this,{vertexShader:vertexShader$6,fragmentShader:fragmentShader$6,uniforms:THREE__namespace.UniformsUtils.clone(shaderUniforms$2),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,M,R=null,I=null;return Object.defineProperties(x,{pano0:{get:function(){return R},set:function(S){if(R!==S){R=S,S===null?(this.uniforms.pano0_map.value=EMPTY_CUBE_TEXTURE,this.uniforms.pano0_luminanceMap.value=null,this.uniforms.pano0_matrix.value.identity()):(this.uniforms.pano0_map.value=S.map instanceof TileCubeTextureTarget?S.map.texture:S.map,this.uniforms.pano0_luminanceMap.value=S.luminanceMap instanceof TileCubeTextureTarget?S.luminanceMap.texture:S.luminanceMap,this.uniforms.pano0_matrix.value.copy(S.matrix));var B=this.uniforms.pano0_luminanceMap.value!==null&&this.uniforms.pano1_luminanceMap.value!==null,O=this.defines.USE_LUMINANCE;O!==B&&(this.defines.USE_LUMINANCE=B,this.needsUpdate=!0)}}},pano1:{get:function(){return I},set:function(S){if(I!==S){I=S,S===null?(this.uniforms.pano1_map.value=EMPTY_CUBE_TEXTURE,this.uniforms.pano1_luminanceMap.value=null,this.uniforms.pano1_matrix.value.identity()):(this.uniforms.pano1_map.value=S.map instanceof TileCubeTextureTarget?S.map.texture:S.map,this.uniforms.pano1_luminanceMap.value=S.luminanceMap instanceof TileCubeTextureTarget?S.luminanceMap.texture:S.luminanceMap,this.uniforms.pano1_matrix.value.copy(S.matrix));var B=this.uniforms.pano0_luminanceMap.value!==null&&this.uniforms.pano1_luminanceMap.value!==null,O=this.defines.USE_LUMINANCE;O!==B&&(this.defines.USE_LUMINANCE=B,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 B=this.defines.USE_BLACK_TRANSITION;B!==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 B=this.defines.USE_CONSTANT_COLOR,O=S!==null;B!==O&&(this.defines.USE_CONSTANT_COLOR=O,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 M},set:function(S){M!==S&&(M=S,this.uniforms.clippers.value=(M||[]).map(function(B){var O=typeof B.floorIndex=="number"?B.floorIndex:-1,F=new THREE__namespace.Matrix4().getInverse(B.clippingBoxMatrix);return{matrixInverse:F,floorIndex:O}}),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}}}),x.pano0=(r=e.pano0)!==null&&r!==void 0?r:defaultPbmParameters.pano0,x.pano1=(i=e.pano1)!==null&&i!==void 0?i:defaultPbmParameters.pano1,x.modelAlpha=(o=e.modelAlpha)!==null&&o!==void 0?o:defaultPbmParameters.modelAlpha,x.progress=(s=e.progress)!==null&&s!==void 0?s:defaultPbmParameters.progress,x.useBlackTransition=(u=e.useBlackTransition)!==null&&u!==void 0?u:defaultPbmParameters.useBlackTransition,x.constantColor=(l=e.constantColor)!==null&&l!==void 0?l:defaultPbmParameters.constantColor,x.opacity=(d=e.opacity)!==null&&d!==void 0?d:defaultPbmParameters.opacity,x.shownFloorIndex=(c=e.shownFloorIndex)!==null&&c!==void 0?c:defaultPbmParameters.shownFloorIndex,x.clippers=(f=e.clippers)!==null&&f!==void 0?f:defaultPbmParameters.clippers,x.useEDL=(h=e.useEDL)!==null&&h!==void 0?h:defaultPbmParameters.useEDL,x.useHQWeight=(v=e.useHQWeight)!==null&&v!==void 0?v:defaultPbmParameters.useHQWeight,x.useHQDepth=(A=e.useHQDepth)!==null&&A!==void 0?A:defaultPbmParameters.useHQDepth,x.pointSize=(m=e.pointSize)!==null&&m!==void 0?m:defaultPbmParameters.pointSize,x.pointColor=(y=e.pointColor)!==null&&y!==void 0?y:defaultPbmParameters.pointColor,x.pointShape=(p=e.pointShape)!==null&&p!==void 0?p:defaultPbmParameters.pointShape,x.pointScale=(g=e.pointScale)!==null&&g!==void 0?g:defaultPbmParameters.pointScale,x.pointBack=(b=e.pointBack)!==null&&b!==void 0?b:defaultPbmParameters.pointBack,x.pointMinPixel=(T=e.pointMinPixel)!==null&&T!==void 0?T:defaultPbmParameters.pointMinPixel,x.pointMaxPixel=(_=e.pointMaxPixel)!==null&&_!==void 0?_:defaultPbmParameters.pointMaxPixel,x.gradientTexture=(w=e.gradientTexture)!==null&&w!==void 0?w:defaultPbmParameters.gradientTexture,x.floor=0,x}return t.prototype.onBeforeCompile=function(e,r){var i,o,s=String((o=(i=this.clippers)===null||i===void 0?void 0:i.length)!==null&&o!==void 0?o:0);e.vertexShader=e.vertexShader.replace(/NUM_CLIPPERS/g,s),e.fragmentShader=e.fragmentShader.replace(/NUM_CLIPPERS/g,s)},t.prototype.update=function(e,r){this.transparent=this.shownFloorIndex>-1||this.opacity<1,this.blending=this.transparent?THREE__namespace.NormalBlending:THREE__namespace.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}(THREE__namespace.ShaderMaterial),InternalWebGLRenderer=function(n){__extends(t,n);function t(e){var r=e.preserveDrawingBuffer,i=r===void 0?!1:r,o=e.backgroundColor,s=o===void 0?1579548:o,u=e.backgroundAlpha,l=u===void 0?1:u,d=e.pixelRatio,c=d===void 0?1:d,f=e.antialias,h=f===void 0?!1:f,v=e.webgl2,A=v===void 0?!1:v,m=this,y=l<1;if(A){var p=document.createElement("canvas"),g=p.getContext("webgl2",{antialias:h,alpha:y,preserveDrawingBuffer:i,powerPreference:"high-performance",desynchronized:!0});g?m=n.call(this,{canvas:p,context:g})||this:(console.error("error occurred when getting webgl2 canvas context, mybe webgl2 not support, fallback to webgl."),m=n.call(this,{antialias:h,alpha:y,preserveDrawingBuffer:i,powerPreference:"high-performance"})||this)}else m=n.call(this,{antialias:h,alpha:y,preserveDrawingBuffer:i,powerPreference:"high-performance"})||this;return m.setPixelRatio(c),m.setClearColor(s,l),m.outputEncoding=THREE__namespace.sRGBEncoding,m.autoClear=!0,m}return t}(THREE__namespace.WebGLRenderer),Scene=function(n){__extends(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}(THREE__namespace.Scene);function coordinatesToVector(n,t){var e=Math.abs(Math.cos(n.latitude)),r=-Math.sin(n.longitude)*e,i=-Math.sin(n.latitude),o=-Math.cos(n.longitude)*e;return t?t.set(r,i,o):new THREE__namespace.Vector3(r,i,o)}var DEFAULT_ASPECT=1,DEFAULT_NEAR=.1,DEFAULT_FAR=2e3,TAU$2=Math.PI*2,PI_2=Math.PI/2;function formatRad$1(n){return n>0&&n<=TAU$2?n:(n%TAU$2+TAU$2)%TAU$2}function matrixLerp(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 Camera=function(n){__extends(t,n);function t(e,r,i,o,s,u,l){r===void 0&&(r=DEFAULT_ASPECT),i===void 0&&(i=DEFAULT_NEAR),o===void 0&&(o=DEFAULT_FAR),s===void 0&&(s=new THREE__namespace.Vector2),u===void 0&&(u=512),l===void 0&&(l=1);var d=n.call(this)||this;d.fov=e,d.aspect=r,d.near=i,d.far=o,d.perspToOrtho=s,d.screenHeight=u,d.pixelRatio=l,d.needsRender=!0,d.pose={longitude:0,latitude:0,fov:e,distance:0,offset:new THREE__namespace.Vector3},d.computePose(),d.perspectiveCamera=new THREE__namespace.PerspectiveCamera(d.fov,d.aspect,.001,d.far);var c=Math.max(d.orthoDistance,.01)*Math.tan(.5*d.fov/180*Math.PI),f=-.5*d.aspect*2*c;return d.orthographicCamera=new THREE__namespace.OrthographicCamera(f,-f,c,-c,.001,d.far),d.computeProjectionMatrix(),d.lastValues={position:d.position.clone(),quaternion:d.quaternion.clone(),scale:d.scale.clone(),fov:d.fov,aspect:d.aspect,near:d.near,far:d.far,perspToOrtho:d.perspToOrtho.clone()},d.type=d.perspToOrtho.x<1?"PerspectiveCamera":"OrthographicCamera",d}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 coordinatesToVector(this.pose,e)},t.prototype.computePose=function(e){e===void 0&&(e=0);var r=this.getDirection(new THREE__namespace.Vector3);this.pose.longitude=formatRad$1(-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 THREE__namespace.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,o,s,u,l=formatRad$1((r=e.longitude)!==null&&r!==void 0?r:this.pose.longitude),d=Math.max(-PI_2+1e-4,Math.min(PI_2-1e-4,(i=e.latitude)!==null&&i!==void 0?i:this.pose.latitude)),c=(o=e.fov)!==null&&o!==void 0?o:this.pose.fov,f=(s=e.distance)!==null&&s!==void 0?s:this.pose.distance,h=(u=e.offset)!==null&&u!==void 0?u:this.pose.offset,v=coordinatesToVector({longitude:l,latitude:d}).normalize();return this.position.set(0,0,0),this.lookAt(v),this.position.add(h).sub(v.clone().setLength(f)),this.fov!==c&&(this.fov=c,this.updateProjectionMatrix()),this.updateMatrixWorld(),this.pose.longitude=l,this.pose.latitude=d,this.pose.fov=c,this.pose.distance=f,this.pose.offset.copy(h),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(){matrixLerp(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,o,s,u){this.perspectiveCamera.setViewOffset(e,r,i,o,s,u),this.orthographicCamera.setViewOffset(e,r,i,o,s,u),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 o=Math.max(this.orthoDistance,.01)*Math.tan(.5*this.fov/180*Math.PI),s=-.5*this.aspect*2*o;this.orthographicCamera.left=s,this.orthographicCamera.right=-s,this.orthographicCamera.top=o,this.orthographicCamera.bottom=-o,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(now(),0),this},t}(THREE__namespace.Camera),VolumePlaneIntersect;(function(n){n[n.Outside=-1]="Outside",n[n.Intersecting=0]="Intersecting",n[n.Inside=1]="Inside"})(VolumePlaneIntersect||(VolumePlaneIntersect={}));var EPSILON$2=1e-6,scratchVector=new THREE__namespace.Vector3,scratchMatrix4$3=new THREE__namespace.Matrix4,scratchXAxis=new THREE__namespace.Vector3,scratchYAxis=new THREE__namespace.Vector3,scratchZAxis=new THREE__namespace.Vector3,scratchSize=new THREE__namespace.Vector3,scratchBox3=new THREE__namespace.Box3,scratchSphere$1=new THREE__namespace.Sphere,scratchMatrix4Inverse$1=new THREE__namespace.Matrix4,scratchRay$1=new THREE__namespace.Ray,scratchObject3D=new THREE__namespace.Object3D,scratchFrustum=new THREE__namespace.Frustum;function quaternionFromMatrix3(n,t){var e=n.elements;return t.setFromRotationMatrix(scratchMatrix4$3.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 CullingVolume=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 scratchMatrix4$3.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse),scratchFrustum.setFromProjectionMatrix(scratchMatrix4$3),this.setFromFrustum(scratchFrustum),this},n.prototype.computeVisibility=function(t){for(var e=VolumePlaneIntersect.Inside,r=0,i=this.planes;r<i.length;r++){var o=i[r],s=t.intersectPlane(o);switch(s){case VolumePlaneIntersect.Outside:return VolumePlaneIntersect.Outside;case VolumePlaneIntersect.Intersecting:e=VolumePlaneIntersect.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),o=0;o<i;++o){var s=1<<o;if(e&s){var u=this.planes[o],l=t.intersectPlane(u);if(l===VolumePlaneIntersect.Outside)return n.MASK_OUTSIDE;l===VolumePlaneIntersect.Intersecting&&(r|=s)}}return r},n}(),BoxBoundingVolume=function(){function n(){this.type="box",this.center=new THREE__namespace.Vector3,this.halfSize=new THREE__namespace.Vector3,this.rotation=new THREE__namespace.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],o=e[5],s=e[6],u=e[7],l=e[8],d=e[9],c=e[10],f=e[11],h=Math.sqrt(r*r+i*i+o*o),v=Math.sqrt(s*s+u*u+l*l),A=Math.sqrt(d*d+c*c+f*f);this.halfSize.set(h,v,A);var m=this.halfSize.toArray().reduce(function(y,p){return y+p},0);return(isNaN(m)||m<=0)&&this.halfSize.setScalar(EPSILON$2),this.rotation.fromArray([r/h,i/h,o/h,s/v,u/v,l/v,d/A,c/A,f/A]),isNaN(this.rotation.toArray().reduce(function(y,p){return y+p},0))&&this.rotation.identity(),this},n.prototype.toJson=function(){return this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),{box:__spreadArray(__spreadArray(__spreadArray(__spreadArray([],this.center.toArray(),!0),scratchXAxis.multiplyScalar(this.halfSize.x).toArray(),!0),scratchYAxis.multiplyScalar(this.halfSize.y).toArray(),!0),scratchZAxis.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 scratchObject3D.position.copy(this.center),quaternionFromMatrix3(this.rotation,scratchObject3D.quaternion),scratchObject3D.scale.copy(this.halfSize),scratchObject3D.matrix.compose(scratchObject3D.position,scratchObject3D.quaternion,scratchObject3D.scale),scratchObject3D.matrix.premultiply(t),scratchObject3D.matrix.decompose(scratchObject3D.position,scratchObject3D.quaternion,scratchObject3D.scale),this.center.copy(scratchObject3D.position),this.rotation.setFromMatrix4(scratchMatrix4$3.makeRotationFromQuaternion(scratchObject3D.quaternion)),this.halfSize.copy(scratchObject3D.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,o=t.z-this.center.z,s=0,u;return u=r*e[0]+i*e[1]+o*e[2],u<0&&(u=-u),u-=this.halfSize.x,u>0&&(s+=u*u),u=r*e[3]+i*e[4]+o*e[5],u<0&&(u=-u),u-=this.halfSize.y,u>0&&(s+=u*u),u=r*e[6]+i*e[7]+o*e[8],u<0&&(u=-u),u-=this.halfSize.z,u>0&&(s+=u*u),s},n.prototype.distanceTo=function(t){return Math.sqrt(this.distanceSquaredTo(t))},n.prototype.getBoundingBox=function(t){return t.makeEmpty(),this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchXAxis.setLength(this.halfSize.x),scratchYAxis.setLength(this.halfSize.y),scratchZAxis.setLength(this.halfSize.z),t.expandByPoint(scratchVector.copy(this.center).add(scratchXAxis)),t.expandByPoint(scratchVector.copy(this.center).sub(scratchXAxis)),t.expandByPoint(scratchVector.copy(this.center).add(scratchYAxis)),t.expandByPoint(scratchVector.copy(this.center).sub(scratchYAxis)),t.expandByPoint(scratchVector.copy(this.center).add(scratchZAxis)),t.expandByPoint(scratchVector.copy(this.center).sub(scratchZAxis)),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);scratchVector.set(this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,0),scratchVector.set(-this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,3),scratchVector.set(-this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,6),scratchVector.set(this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,9),scratchVector.set(this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,12),scratchVector.set(-this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,15),scratchVector.set(-this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,18),scratchVector.set(this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(e,21);var r=new THREE__namespace.BufferGeometry;return r.setIndex(new THREE__namespace.BufferAttribute(t,1)),r.setAttribute("position",new THREE__namespace.BufferAttribute(e,3)),r.computeBoundingBox(),r.computeBoundingSphere(),r},n.prototype.intersectPlane=function(t){var e=this.center,r=t.normal,i=this.rotation.elements,o=this.halfSize,s=r.x,u=r.y,l=r.z,d=Math.abs(s*i[0]*o.x+u*i[1]*o.x+l*i[2]*o.x)+Math.abs(s*i[3]*o.y+u*i[4]*o.y+l*i[5]*o.y)+Math.abs(s*i[6]*o.z+u*i[7]*o.z+l*i[8]*o.z),c=r.dot(e)+t.constant;return c<=-d?VolumePlaneIntersect.Outside:c>=d?VolumePlaneIntersect.Inside:VolumePlaneIntersect.Intersecting},n.prototype.intersectRay=function(t,e){scratchSize.copy(this.halfSize).multiplyScalar(2),scratchBox3.setFromCenterAndSize(scratchVector.set(0,0,0),scratchSize),this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchMatrix4$3.makeBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchMatrix4$3.setPosition(this.center),scratchMatrix4Inverse$1.getInverse(scratchMatrix4$3),scratchRay$1.copy(t).applyMatrix4(scratchMatrix4Inverse$1);var r=scratchRay$1.intersectBox(scratchBox3,scratchVector);return r?e!==void 0?r.applyMatrix4(scratchMatrix4$3).distanceTo(t.origin)<e:!0:!1},n}(),SphereBoundingVolume=function(){function n(){this.type="sphere",this.center=new THREE__namespace.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],EPSILON$2),this},n.prototype.toJson=function(){return{sphere:__spreadArray(__spreadArray([],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,scratchSize.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 o=new THREE__namespace.BufferGeometry;return o.setAttribute("position",new THREE__namespace.BufferAttribute(e,3)),o.computeBoundingBox(),o.computeBoundingSphere(),o},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,o=i.dot(e)+t.constant;return o<-r?VolumePlaneIntersect.Outside:o<r?VolumePlaneIntersect.Intersecting:VolumePlaneIntersect.Inside},n.prototype.intersectRay=function(t,e){scratchSphere$1.set(this.center,this.radius);var r=t.intersectSphere(scratchSphere$1,scratchVector);return r?e!==void 0?t.origin.distanceTo(r)<e:!0:!1},n}(),RegionBoundingVolume=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 makeBoundingVolume(n){if("box"in n)return new BoxBoundingVolume().fromJson(n);if("sphere"in n)return new SphereBoundingVolume().fromJson(n);if("region"in n)return new RegionBoundingVolume().fromJson(n);throw new Error("BoundingVolume ".concat(JSON.stringify(n)," never suppored."))}var debugMaterials=[2621517,3801199,4915345,5963950,7274706,8782079,9575167,10434047,11623423,12482559,13274879,13870335,14464511,15125247,15852031,16446719].map(function(n){return new THREE__namespace.LineBasicMaterial({color:n,depthWrite:!1,transparent:!0})}),debugBoxGeometry=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);scratchVector.set(1,1,1).toArray(t,0),scratchVector.set(-1,1,1).toArray(t,3),scratchVector.set(-1,-1,1).toArray(t,6),scratchVector.set(1,-1,1).toArray(t,9),scratchVector.set(1,1,-1).toArray(t,12),scratchVector.set(-1,1,-1).toArray(t,15),scratchVector.set(-1,-1,-1).toArray(t,18),scratchVector.set(1,-1,-1).toArray(t,21);var e=new THREE__namespace.BufferGeometry;return e.setIndex(new THREE__namespace.BufferAttribute(n,1)),e.setAttribute("position",new THREE__namespace.BufferAttribute(t,3)),e.computeBoundingBox(),e.computeBoundingSphere(),e}(),debugSphereGeometry=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 THREE__namespace.BufferGeometry;return i.setAttribute("position",new THREE__namespace.BufferAttribute(t,3)),i.computeBoundingBox(),i.computeBoundingSphere(),i}();function createDebugBoundingMesh(n,t){if(n instanceof BoxBoundingVolume){var e=new THREE__namespace.LineSegments(debugBoxGeometry,debugMaterials[Math.min(t,debugMaterials.length-1)]);return e.position.copy(n.center),quaternionFromMatrix3(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 SphereBoundingVolume){var e=new THREE__namespace.LineSegments(debugSphereGeometry,debugMaterials[Math.min(t,debugMaterials.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 Tile=function(){function n(t,e,r,i){var o=this,s,u,l;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=(s=e.refine)!==null&&s!==void 0?s:this.parent?this.parent.refine:"REPLACE",this.transform=new THREE__namespace.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=(l=(u=this.parent)===null||u===void 0?void 0:u.geometricError)!==null&&l!==void 0?l: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=makeBoundingVolume(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=makeBoundingVolume(e.boundingVolume).applyMatrix4(this.transform)),e.viewerRequestVolume&&(this.viewerRequestVolume=makeBoundingVolume(e.viewerRequestVolume).applyMatrix4(this.transform)),this.extras=e.extras||{},e.children?this.children=e.children.map(function(d,c){return new n("".concat(o.id,".").concat(c),d,r,o)}):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:CullingVolume.MASK_INDETERMINATE;this.state.visibilityPlaneMask=t.cullingVolume.computeVisibilityWithPlaneMask(r,i),this.state.visible=this.state.visibilityPlaneMask!==CullingVolume.MASK_OUTSIDE}else this.state.distanceToCamera=0,this.state.visibilityPlaneMask=CullingVolume.MASK_INDETERMINATE,this.state.visible=!0;if(this.viewerRequestVolume){var o=e?this.viewerRequestVolume.clone().applyMatrix4(e):this.viewerRequestVolume;this.state.inRequestVolume=o.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(o){return i.done(),r.loadState=o?"READY":"UNLOADED",o}).catch(function(o){return r.loadState="FAILED",i.done(),Promise.reject(o)}):(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(),o=this.parent?this.parent.geometricError:this.tileset.geometricError,s=i*(r?o:this.geometricError);if(s===0)return 0;var u=Math.max(e,.001),l=s*t.height/(u*t.sseDenominator);return l},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,o=this.tileset.root?this.tileset.root.state.screenSpaceError:0,s=Math.max(o-i,0);return s},n}(),RequestScheduler=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(){}},o=new Promise(function(s){return i.resolve=s});return this.requestQueue.push(i),this.requestMap.set(t,o),this.issueNewRequests(),o},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,o=!1,s=function(){o||(o=!0,e.requestMap.delete(r),e.activeRequests--,e.issueNewRequests())};this.activeRequests++,i({done:s})},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,o){return i.priority-o.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}(),CacheNode=function(){function n(t,e,r){this.item=t,this.previous=e,this.next=r}return n}(),CacheNodeList=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 CacheNode(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}(),TilesetCache=function(){function n(){this.cacheNodeMap=new Map,this.list=new CacheNodeList,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}(),ManagedArray=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}(),TilesetTraverser=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 ManagedArray,this._emptyTraversalStack=new ManagedArray,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,o=r;i<o.length;i++){var s=o[i];this._traversalStack.reset(),this._emptyTraversalStack.reset(),this._canSelectTile=s.camera.visible,this.updateTile(t,s),this.executeTraversal(t,s)}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(),o=!1;if(this.canTraverse(i,e,!1,!1)){var s=i.hasRenderContent?i.state.selectionDepth+1:i.state.selectionDepth;this.updateChildTiles(i,e,s),o=this.updateAndPushChildren(i,e,r)}var u=i.parent,l=!u||u.state.shouldRefine,d=!o;i.hasRenderContent?i.refine==="ADD"?(this.loadTile(i,e.frameNumber),this.selectTile(i,e)):i.refine==="REPLACE"&&(this.loadTile(i,e.frameNumber),d&&this.selectTile(i,e)):(this.emptyTiles.set(i.id,i),this.loadTile(i,e.frameNumber),d&&this.selectTile(i,e)),this.touchTile(i,e),i.state.shouldRefine=o&&l}},n.prototype.updateChildTiles=function(t,e,r){for(var i=t.children,o=0,s=i;o<s.length;o++){var u=s[o];u.state.selectionDepth=r,this.updateTile(u,e)}return!0},n.prototype.updateAndPushChildren=function(t,e,r){for(var i=t.children,o=t.refine==="REPLACE"&&t.hasRenderContent&&!this.skipLevelOfDetail,s=!1,u=!0,l=0,d=i;l<d.length;l++){var c=d[l];if(c.state.visible&&c.state.inRequestVolume?(r.find(c)&&r.delete(c),r.push(c),s=!0):(o||this.loadSiblings)&&(this.loadTile(c,e.frameNumber),this.touchTile(c,e)),o){var f=void 0;c.state.inRequestVolume?c.hasRenderContent?f=c.contentAvailable:f=this.executeEmptyTraversal(c,e):f=!1,u=u&&f}}return s||(u=!1),u},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 o=i.pop();this.updateTile(o,e),o.state.visible||this.loadTile(o,e.frameNumber),this.touchTile(o,e);var s=!o.hasRenderContent&&this.canTraverse(o,e,!1,!0);if(s)for(var u=o.children,l=0,d=u;l<d.length;l++){var c=d[l];i.find(c)&&i.delete(c),i.push(c)}else o.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}(),identityMatrix4=new THREE__namespace.Matrix4,Tileset=function(){function n(t,e,r){var i,o;this.id=t,this.transform=new THREE__namespace.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=(o=e.properties)!==null&&o!==void 0?o:{},this.options=r,this.traverser=new TilesetTraverser,this.cache=new TilesetCache,this.requestScheduler=new RequestScheduler,this.frameNumber=0,this.pendingCount=0,this.tiles=new Map,this.memoryUsageInBytes=0,this.root=new Tile("".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,o=r.children.length;i<o;i++)e.push(r.children[i]);this.cache.unloadTile(r,function(s){return t.unloadTile(s)})}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(identityMatrix4),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=TilesetTraverser.DEFAULT_MAX_SCREEN_SPACE_ERROR,n.DEFAULT_MAX_REQUESTS=RequestScheduler.DEFAULT_MAX_REQUESTS,n}(),BVHNode=function(){function n(t,e,r,i){this.extents=t,this.startIndex=e,this.endIndex=r,this.deepth=i}return n}();function intersectNodeBox(n,t,e,r){r===void 0&&(r=0);var i=e.extents[0]-r,o=e.extents[1]-r,s=e.extents[2]-r,u=e.extents[3]+r,l=e.extents[4]+r,d=e.extents[5]+r,c={min:0,max:0};t.x>=0?(c.min=(i-n.x)*t.x,c.max=(u-n.x)*t.x):(c.min=(u-n.x)*t.x,c.max=(i-n.x)*t.x);var f={min:0,max:0};if(t.y>=0?(f.min=(o-n.y)*t.y,f.max=(l-n.y)*t.y):(f.min=(l-n.y)*t.y,f.max=(o-n.y)*t.y),c.min>f.max||f.min>c.max)return!1;f.min>c.min&&(c.min=f.min),f.max<c.max&&(c.max=f.max);var h={min:0,max:0};return t.z>=0?(h.min=(s-n.z)*t.z,h.max=(d-n.z)*t.z):(h.min=(d-n.z)*t.z,h.max=(s-n.z)*t.z),!(c.min>h.max||h.min>c.max||(h.min>c.min&&(c.min=h.min),h.max<c.max&&(c.max=h.max),c.max<0))}var BVHVector3=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,o=t.z,s=e.x,u=e.y,l=e.z;return this.x=i*l-o*u,this.y=o*s-r*l,this.z=r*u-i*s,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}(),BVHIntersect=function(){function n(t,e,r){this.triangle=t,this.intersectionPoint=e,this.index=r}return n}(),EPSILON$1=1e-6,BVHMesh=function(){function n(t,e){if(this.positionArray=t,e)this.indicesArray=e;else{for(var r=t.length/3,i=new Uint32Array(r),o=0;o<r;o++)i[o]=o;this.indicesArray=i}}return n.prototype.createTree=function(t,e,r){var i=this.positionArray,o=this.indicesArray,s=o.length/3,u=new Uint32Array(s),l=new Float32Array(s*6),d=[],c=0;if(r)for(var f=0,h=0,v=0,A=void 0,m=void 0,y=void 0,p=void 0,g=void 0,b=void 0,T=void 0;f<s;f+=1,h+=3,v+=6)u[f]=f,A=p=i[o[h]*3],T=i[o[h+1]*3],T<A&&(A=T),T>p&&(p=T),T=i[o[h+2]*3],T<A&&(A=T),T>p&&(p=T),m=g=i[o[h]*3+1],T=i[o[h+1]*3+1],T<m&&(m=T),T>g&&(g=T),T=i[o[h+2]*3+1],T<m&&(m=T),T>g&&(g=T),y=b=i[o[h]*3+2],T=i[o[h+1]*3+2],T<y&&(y=T),T>b&&(b=T),T=i[o[h+2]*3+2],T<y&&(y=T),T>b&&(b=T),l[v]=A,l[v+1]=m,l[v+2]=y,l[v+3]=p,l[v+4]=g,l[v+5]=b;else{for(var _=1/0,w=1/0,x=1/0,M=-1/0,R=-1/0,I=-1/0,f=0,h=0,v=0,A=void 0,m=void 0,y=void 0,p=void 0,g=void 0,b=void 0,T=void 0;f<s;f+=1,h+=3,v+=6)u[f]=f,A=p=i[o[h]*3],T=i[o[h+1]*3],T<A&&(A=T),T>p&&(p=T),T=i[o[h+2]*3],T<A&&(A=T),T>p&&(p=T),m=g=i[o[h]*3+1],T=i[o[h+1]*3+1],T<m&&(m=T),T>g&&(g=T),T=i[o[h+2]*3+1],T<m&&(m=T),T>g&&(g=T),y=b=i[o[h]*3+2],T=i[o[h+1]*3+2],T<y&&(y=T),T>b&&(b=T),T=i[o[h+2]*3+2],T<y&&(y=T),T>b&&(b=T),l[v]=A,l[v+1]=m,l[v+2]=y,l[v+3]=p,l[v+4]=g,l[v+5]=b,A<_&&(_=A),p>M&&(M=p),m<w&&(w=m),g>R&&(R=g),y<x&&(x=y),b>I&&(I=b);r=[_,w,x,M,R,I]}var S=new BVHNode(r,0,s,0);d[c++]=S;function B(O){for(var F=O.startIndex,H=O.endIndex,k=O.extents,N=[k[3]-k[0],k[4]-k[1],k[5]-k[2]],q=[0,1,2].sort(function(J,Z){return N[Z]-N[J]}),V=0;V<3;V++){for(var D=q[V],K=k[D]+k[D+3],z=F,G=H-1,W=-1,Q=void 0;z<=G;)W===-1?(Q=u[z],l[Q*6+D]+l[Q*6+D+3]<K?z++:W=Q):(Q=u[G],l[Q*6+D]+l[Q*6+D+3]>=K||(u[z]=Q,u[G]=W,W=-1,z++),G--);if(z>F&&z<H){var X=new BVHNode(calcExtents(u,l,F,z,EPSILON$1),F,z,O.deepth+1);X.deepth<e&&X.endIndex-X.startIndex>t&&(d[c++]=X);var ee=new BVHNode(calcExtents(u,l,z,H,EPSILON$1),z,H,O.deepth+1);ee.deepth<e&&ee.endIndex-ee.startIndex>t&&(d[c++]=ee),O.node0=X,O.node1=ee,O.startIndex=0,O.endIndex=0;break}}}for(;c;)B(d[--c]);return this.offsetArray=u,this.rootNode=S,d.length=0,this},n.prototype.trianglesInSphere=function(t,e){for(var r=this.positionArray,i=this.indicesArray,o=this.offsetArray,s=this.rootNode,u=[s],l=[],d;d=u.pop();){var c=clamp$1(t.x,d.extents[0],d.extents[3])-t.x,f=clamp$1(t.y,d.extents[1],d.extents[4])-t.y,h=clamp$1(t.z,d.extents[2],d.extents[5])-t.z;if(c*c+f*f+h*h<=e*e){d.node0&&u.push(d.node0),d.node1&&u.push(d.node1);for(var v=d.startIndex;v<d.endIndex;v++)l.push(o[v])}}for(var A=l.length,m=new Float32Array(A*9),v=0;v<A;v++){var y=l[v];m[v*9]=r[i[y]*3],m[v*9+1]=r[i[y]*3+1],m[v*9+2]=r[i[y]*3+2],m[v*9+3]=r[i[y+1]*3],m[v*9+4]=r[i[y+1]*3+1],m[v*9+5]=r[i[y+1]*3+2],m[v*9+6]=r[i[y+2]*3],m[v*9+7]=r[i[y+2]*3+1],m[v*9+8]=r[i[y+2]*3+2]}return m},n.prototype.intersectRay=function(t,e,r){for(var i=this.positionArray,o=this.indicesArray,s=this.offsetArray,u=this.rootNode,l=new BVHVector3(1/e.x,1/e.y,1/e.z),d=[u],c;c=d.pop();)if(intersectNodeBox(t,l,c)){for(var f=c.startIndex,h=c.endIndex,v=void 0,A=void 0,m=void 0,y=t.x,p=t.y,g=t.z,b=e.x,T=e.y,_=e.z,w=void 0,x=void 0,M=void 0,R=void 0,I=void 0,S=void 0,B=void 0,O=void 0,F=void 0,H=void 0,k=void 0,N=void 0,q=void 0,V=void 0,D=void 0,K=void 0,z=void 0,G=void 0,W=void 0,Q=void 0,X=void 0,ee=void 0,J=void 0,Z=void 0,te=void 0,ae=void 0,re=void 0;f<h;f++){if(v=s[f],A=v*3,m=o[A]*3,w=i[m],x=i[++m],M=i[++m],m=o[A+1]*3,R=i[m],I=i[++m],S=i[++m],m=o[A+2]*3,B=i[m],O=i[++m],F=i[++m],H=R-w,k=I-x,N=S-M,q=B-w,V=O-x,D=F-M,K=k*D-N*V,z=N*q-H*D,G=H*V-k*q,J=b*K+T*z+_*G,J>0)ee=1;else if(J<0)ee=-1,J=-J;else continue;W=y-w,Q=p-x,X=g-M,Z=ee*(b*(Q*D-X*V)+T*(X*q-W*D)+_*(W*V-Q*q)),!(Z<0)&&(te=ee*(b*(k*X-N*Q)+T*(N*W-H*X)+_*(H*Q-k*W)),!(te<0)&&(Z+te>J||(ae=-ee*(W*K+Q*z+X*G),!(ae<0)&&(re=ae/J,r.push(new BVHIntersect([w,x,M,R,I,S,B,O,F],[y+b*re,p+T*re,g+_*re],v))))))}c.node0&&d.push(c.node0),c.node1&&d.push(c.node1)}return r},n}();function clamp$1(n,t,e){return n<t?t:n>e?e:n}function calcExtents(n,t,e,r,i){if(e>=r)return[0,0,0,0,0,0];for(var o=1/0,s=1/0,u=1/0,l=-1/0,d=-1/0,c=-1/0,f=e,h=void 0,v=void 0;f<r;f++)h=n[f]*6,v=t[h],v<o&&(o=v),v=t[h+1],v<s&&(s=v),v=t[h+2],v<u&&(u=v),v=t[h+3],v>l&&(l=v),v=t[h+4],v>d&&(d=v),v=t[h+5],v>c&&(c=v);return[o-i,s-i,u-i,l+i,d+i,c+i]}var EPSILON=1e-6,BVHPoints=function(){function n(t,e){if(this.positionArray=t,e)this.indicesArray=e;else{for(var r=t.length/3,i=new Uint32Array(r),o=0;o<r;o++)i[o]=o;this.indicesArray=i}}return n.prototype.createTree=function(t,e,r){var i=this.positionArray,o=this.indicesArray,s=o.length,u=new Uint32Array(s),l=[],d=0;if(r)for(var c=0;c<s;c+=1)u[c]=c;else{for(var f=o[0]*3,h=i[f],v=i[f+1],A=i[f+2],m=h,y=v,p=A,c=0,g=0,b=void 0,T=void 0,_=void 0;c<s;c+=1,g+=3)u[c]=c,f=o[g]*3,b=i[f],T=i[f+1],_=i[f+2],b<h?h=b:b>m&&(m=b),T<v?v=T:T>y&&(y=T),_<A?A=_:_>p&&(p=_);r=[h,v,A,m,y,p]}var w=new BVHNode(r,0,s,0);l[d++]=w;function x(M){for(var R=M.startIndex,I=M.endIndex,S=M.extents,B=[S[3]-S[0],S[4]-S[1],S[5]-S[2]],O=[0,1,2].sort(function(G,W){return B[W]-B[G]})[0],F=(S[O]+S[O+3])/2,H=R,k=I-1,N=-1,q;H<=k;)N===-1?(q=u[H],i[o[q]*3+O]<F?H++:N=q):(q=u[k],i[o[q]*3+O]>=F||(u[H]=q,u[k]=N,N=-1,H++),k--);if(H>R){var V=S.slice();V[O+3]=F+EPSILON;var D=new BVHNode(V,R,H,M.deepth+1);D.deepth<e&&D.endIndex-D.startIndex>t&&(l[d++]=D),M.node0=D}if(I>H){var K=S.slice();K[O]=F-EPSILON;var z=new BVHNode(K,H,I,M.deepth+1);z.deepth<e&&z.endIndex-z.startIndex>t&&(l[d++]=z),M.node1=z}M.startIndex=0,M.endIndex=0}for(;d;)x(l[--d]);return this.offsetArray=u,this.rootNode=w,l.length=0,this},n.prototype.intersectRay=function(t,e,r,i){for(var o=this.positionArray,s=this.indicesArray,u=this.offsetArray,l=this.rootNode,d=r*r,c=new BVHVector3(1/e.x,1/e.y,1/e.z),f=[l],h;h=f.pop();)if(intersectNodeBox(t,c,h,r)){for(var v=h.startIndex,A=h.endIndex,m=void 0,y=void 0,p=void 0,g=void 0,b=void 0,T=void 0,_=void 0,w=void 0,x=void 0,M=void 0,R=void 0,I=void 0,S=void 0;v<A;v++)m=u[v],y=s[m]*3,p=o[y],g=o[++y],b=o[++y],T=t.x,_=t.y,w=t.z,x=e.x,M=e.y,R=e.z,I=x*(p-T)+M*(g-_)+R*(b-w),I>0&&(T+=x*I,_+=M*I,w+=R*I),x=p-T,M=g-_,R=b-w,I=x*x+M*M+R*R,I<=d&&i.push(new BVHIntersect([p,g,b,p,g,b,p,g,b],[T,_,w],m));h.node0&&f.push(h.node0),h.node1&&f.push(h.node1)}return i},n}(),bvhMeshMap=new Map,bvhPointsMap=new Map,scratchRay=new THREE__namespace.Ray,scratchNormalMatrix=new THREE__namespace.Matrix3,scratchInverseMatrix=new THREE__namespace.Matrix4,scratchIntersectionFaceA$1=new THREE__namespace.Vector3,scratchIntersectionFaceB$1=new THREE__namespace.Vector3,scratchIntersectionFaceC$1=new THREE__namespace.Vector3,scratchIntersectionTriangle=new THREE__namespace.Triangle;function raycastMesh(n,t,e,r){var i,o=n.matrixWorld;scratchInverseMatrix.getInverse(o),scratchRay.copy(e.ray).applyMatrix4(scratchInverseMatrix);for(var s=t.intersectRay(scratchRay.origin,scratchRay.direction,[]),u=n.geometry,l=n.material,d=u.groups,c=u.index,f=0,h=s.length;f<h;f++){var v=s[f],A=v.triangle,m=v.index,y=v.intersectionPoint,p=new THREE__namespace.Vector3(y[0],y[1],y[2]).applyMatrix4(o),g=e.ray.origin.distanceTo(p);if(!(g<e.near||g>e.far)){var b=void 0;if(Array.isArray(l)){if(d)for(var T=m*3,_=0,w=d;_<w.length;_++){var x=w[_];if(T>=x.start&&T-x.start<x.count){b=l[(i=x.materialIndex)!==null&&i!==void 0?i:0];break}}}else b=l;if(b){var M=scratchIntersectionTriangle.set(scratchIntersectionFaceA$1.set(A[0],A[1],A[2]).applyMatrix4(o),scratchIntersectionFaceB$1.set(A[3],A[4],A[5]).applyMatrix4(o),scratchIntersectionFaceC$1.set(A[6],A[7],A[8]).applyMatrix4(o)).getNormal(new THREE__namespace.Vector3),R=m*3,I=new THREE__namespace.Face3(c?c.array[R]:R,c?c.array[R+1]:R+1,c?c.array[R+2]:R+2,M),S=e.ray.direction.dot(M);b.side===THREE__namespace.FrontSide&&S>=0||b.side===THREE__namespace.BackSide&&S<=0||r.push({distance:g,object:n,face:I,point:p,distanceToRay:0,faceIndex:m})}}}}function raycastPoints(n,t,e,r){var i,o,s=n.matrixWorld;scratchNormalMatrix.getNormalMatrix(s),scratchInverseMatrix.getInverse(s);var u=((o=(i=e.params.Points)===null||i===void 0?void 0:i.threshold)!==null&&o!==void 0?o:1)*scratchInverseMatrix.getMaxScaleOnAxis();scratchRay.copy(e.ray).applyMatrix4(scratchInverseMatrix);for(var l=t.intersectRay(scratchRay.origin,scratchRay.direction,u,[]),d=n.geometry,c=d.index,f=d.getAttribute("normal"),h=0,v=l.length;h<v;h++){var A=l[h],m=A.triangle,y=A.index,p=A.intersectionPoint,g=new THREE__namespace.Vector3(p[0],p[1],p[2]).applyMatrix4(s),b=e.ray.origin.distanceTo(g);if(!(b<e.near||b>e.far)){var T=scratchIntersectionFaceA$1.set(m[0],m[1],m[2]).applyMatrix4(s),_=c?c.array[y]:y,w=void 0;f instanceof THREE__namespace.BufferAttribute&&(w=new THREE__namespace.Vector3().fromBufferAttribute(f,_).applyNormalMatrix(scratchNormalMatrix));var x=new THREE__namespace.Face3(_,_,_,w);r.push({distance:b,object:n,face:x,point:g,distanceToRay:g.distanceTo(T),index:y})}}}function generateBvhTreeForMesh(n,t,e){var r;if(t===void 0&&(t=100),e===void 0&&(e=10),n.geometry instanceof THREE__namespace.BufferGeometry){var i=n.geometry.getAttribute("position");if(i instanceof THREE__namespace.BufferAttribute){var o=n.raycast,s=function(h,v){var A=bvhMeshMap.get(this);A?raycastMesh(this,A,h,v):o.call(this,h,v)};n.raycast=s;var u=i.array,l=(r=n.geometry.getIndex())===null||r===void 0?void 0:r.array,d=n.geometry.boundingBox,c=d?[d.min.x,d.min.y,d.min.z,d.max.x,d.max.y,d.max.z]:void 0,f=new BVHMesh(u,l);return f.createTree(t,e,c),bvhMeshMap.set(n,f),function(){bvhMeshMap.delete(n),n.raycast===s&&(n.raycast=o)}}}return function(){}}function generateBvhTreeForPoints(n,t,e){var r;if(t===void 0&&(t=100),e===void 0&&(e=10),n.geometry instanceof THREE__namespace.BufferGeometry){var i=n.geometry.getAttribute("position");if(i instanceof THREE__namespace.BufferAttribute){var o=n.raycast,s=function(h,v){var A=bvhPointsMap.get(this);A?raycastPoints(this,A,h,v):o.call(this,h,v)};n.raycast=s;var u=i.array,l=(r=n.geometry.getIndex())===null||r===void 0?void 0:r.array,d=n.geometry.boundingBox,c=d?[d.min.x,d.min.y,d.min.z,d.max.x,d.max.y,d.max.z]:void 0,f=new BVHPoints(u,l);return f.createTree(t,e,c),bvhPointsMap.set(n,f),function(){bvhPointsMap.delete(n),n.raycast===s&&(n.raycast=o)}}}return function(){}}function generateBvhTree(n,t,e){t===void 0&&(t=100),e===void 0&&(e=10);var r=[];return n.traverse(function(i){if(i instanceof THREE__namespace.Mesh){var o=generateBvhTreeForMesh(i,t,e);r.push(o)}else if(i instanceof THREE__namespace.Points){var o=generateBvhTreeForPoints(i,t,e);r.push(o)}}),function(){for(var i=0,o=r;i<o.length;i++){var s=o[i];s()}}}var scratchIntersectionFaceA=new THREE__namespace.Vector3,scratchIntersectionFaceB=new THREE__namespace.Vector3,scratchIntersectionFaceC=new THREE__namespace.Vector3,TileNode=function(n){__extends(t,n);function t(e,r){var i=n.call(this)||this;i.renderOrder=-4;var o=generateBvhTree(e,200,10);return i.disposers=[r,o],i.add(e),i}return t.prototype.intersectRaycaster=function(e,r,i){var o=this;r===void 0&&(r=!0),i===void 0&&(i=[]);for(var s=this.children.slice(),u;u=s.pop();)if(u.visible){u.raycast(e,i);for(var l=0,d=u.children.length;l<d;l++)s.push(u.children[l])}return i.forEach(function(c){var f,h,v=0;if((c.object instanceof PBMMesh||c.object instanceof PBMPointCloud)&&c.face){var A=Array.isArray(c.object.material)?c.object.material[c.face.materialIndex]:c.object.material;if(A)if(A.defines.USE_VERTEX_FLOOR){var m=(f=c.object.geometry.attributes.position)===null||f===void 0?void 0:f.array,y=(h=c.object.geometry.attributes.floor)===null||h===void 0?void 0:h.array;if(m&&y){var p=scratchIntersectionFaceA.set(m[c.face.a*3],m[c.face.a*3+1],m[c.face.a*3+2]).applyMatrix4(o.matrixWorld),g=scratchIntersectionFaceB.set(m[c.face.b*3],m[c.face.b*3+1],m[c.face.b*3+2]).applyMatrix4(o.matrixWorld),b=scratchIntersectionFaceC.set(m[c.face.c*3],m[c.face.c*3+1],m[c.face.c*3+2]).applyMatrix4(o.matrixWorld),T=c.point.distanceTo(p),_=c.point.distanceTo(g),w=c.point.distanceTo(b);v=Math.round((T*y[c.face.a]+_*y[c.face.b]+w*y[c.face.c])/(T+_+w))}}else v=A.floor}c.floor=v}),r&&i.sort(function(c,f){return c.distance-f.distance}),i},t.prototype.dispose=function(){for(var e=0,r=this.disposers;e<r.length;e++){var i=r[e];i()}},t}(THREE__namespace.Group);function pathJoin(){for(var n=[],t=0;t<arguments.length;t++)n[t]=arguments[t];var e=[];n=n.map(function(u){return(u??"").trim()}).filter(function(u){return u.length>0&&!/^\/+$/.test(u)});for(var r=0;r<n.length;r++){var i=r===0,o=r===n.length-1,s=n[r];i||(s=s.replace(/^\.\//,"").replace(/^\/+/,"")),o||(s=s.replace(/\/+$/,"")),e.push(s)}return e.join("/")}function isAbsoluteURL(n){return n.indexOf("//")===0||/^[0-9a-z]+\:/i.test(n)}function normalizeTileHeader(n,t){if(n.content&&n.content.uri&&(isAbsoluteURL(n.content.uri)||(n.content.uri=pathJoin(t,n.content.uri))),n.children)for(var e=0,r=n.children;e<r.length;e++){var i=r[e];normalizeTileHeader(i,t)}return n}function normalizeTilesetHeader(n,t){return n.asset.overview&&(isAbsoluteURL(n.asset.overview.imageFile)||(n.asset.overview.imageFile=pathJoin(t,n.asset.overview.imageFile)),isAbsoluteURL(n.asset.overview.worldFile)||(n.asset.overview.worldFile=pathJoin(t,n.asset.overview.worldFile))),normalizeTileHeader(n.root,t),n}function appendSearch(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 SIZEOF_UINT32$1=4;function parseHeader(n,t,e){var r=new DataView(t);if(n.magic=r.getUint32(e,!0),e+=SIZEOF_UINT32$1,n.version=r.getUint32(e,!0),e+=SIZEOF_UINT32$1,n.byteLength=r.getUint32(e,!0),e+=SIZEOF_UINT32$1,n.version!==1)throw new Error("3D Tile Version ".concat(n.version," not supported"));return e}var _a$2,GL_TYPE;(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"})(GL_TYPE||(GL_TYPE={}));var GL_TYPE_TO_ARRAY_TYPE=(_a$2={},_a$2[GL_TYPE.DOUBLE]=Float64Array,_a$2[GL_TYPE.FLOAT]=Float32Array,_a$2[GL_TYPE.UNSIGNED_SHORT]=Uint16Array,_a$2[GL_TYPE.UNSIGNED_INT]=Uint32Array,_a$2[GL_TYPE.UNSIGNED_BYTE]=Uint8Array,_a$2[GL_TYPE.BYTE]=Int8Array,_a$2[GL_TYPE.SHORT]=Int16Array,_a$2[GL_TYPE.INT]=Int32Array,_a$2),NAME_TO_GL_TYPE={DOUBLE:GL_TYPE.DOUBLE,FLOAT:GL_TYPE.FLOAT,UNSIGNED_SHORT:GL_TYPE.UNSIGNED_SHORT,UNSIGNED_INT:GL_TYPE.UNSIGNED_INT,UNSIGNED_BYTE:GL_TYPE.UNSIGNED_BYTE,BYTE:GL_TYPE.BYTE,SHORT:GL_TYPE.SHORT,INT:GL_TYPE.INT};function getArrayType(n){var t=GL_TYPE_TO_ARRAY_TYPE[n];if(!t)throw new Error("Failed to convert GL type");return t}function getByteSize(n){var t=getArrayType(n);return t.BYTES_PER_ELEMENT}function createTypedArray(n,t,e,r){e===void 0&&(e=0);var i=getArrayType(n);if(e%getByteSize(n)!==0){var o=r?t.slice(e,e+r*getByteSize(n)):t.slice(e);return new i(o)}else return new i(t,e,r??(t.byteLength-e)/getByteSize(n))}function glTypeFromName(n){var t=NAME_TO_GL_TYPE[n];if(!t)throw new Error("Failed to convert GL type");return t}var FeatureTable=function(){function n(t,e){this.featuresLength=0,this.cachedTypedArrays={},this.json=t,this.buffer=e;var r=this.getGlobalProperty("POINTS_LENGTH",GL_TYPE.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 o=getArrayType(e);return new o([i])}else if(Array.isArray(i)){var o=getArrayType(e);return new o(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=glTypeFromName(i.componentType)),this.getTypedArrayFromBinary(t,e,r,this.featuresLength,i.byteOffset)):this.getTypedArrayFromArray(t,e,i)},n.prototype.getProperty=function(t,e,r,i,o){var s=this.json[t];if(!s)return null;var u=this.getPropertyArray(t,e,r);if(r===1)return o[0]=u[i],o;for(var l=0;l<r;++l)o[l]=u[r*i+l];return o},n.prototype.getTypedArrayFromBinary=function(t,e,r,i,o){var s=this.cachedTypedArrays,u=s[t];return u||(u=createTypedArray(e,this.buffer.buffer,this.buffer.byteOffset+o,i*r),s[t]=u),u},n.prototype.getTypedArrayFromArray=function(t,e,r){var i=this.cachedTypedArrays,o=i[t];return o||(o=createTypedArray(e,r),i[t]=o),o},n}(),SIZEOF_UINT32=4,DEPRECATION_WARNING="b3dm tile in legacy format.";function getStringFromArrayBuffer(n,t,e){var r=new TextDecoder("utf8"),i=new Uint8Array(n,t,e),o=r.decode(i);return o}function parseTable(n,t,e){return e=parseTablesHeader(n,t,e),e=parseFeatureTable(n,t,e),e=parseBatchTable(n,t,e),e}function parseTablesHeader(n,t,e){var r=new DataView(t),i=0;n.header=n.header||{};var o=r.getUint32(e,!0);e+=SIZEOF_UINT32;var s=r.getUint32(e,!0);e+=SIZEOF_UINT32;var u=r.getUint32(e,!0);e+=SIZEOF_UINT32;var l=r.getUint32(e,!0);return e+=SIZEOF_UINT32,u>=570425344?(e-=SIZEOF_UINT32*2,i=o,u=s,l=0,o=0,s=0,console.warn(DEPRECATION_WARNING)):l>=570425344&&(e-=SIZEOF_UINT32,i=u,u=o,l=s,o=0,s=0,console.warn(DEPRECATION_WARNING)),n.header.featureTableJsonByteLength=o,n.header.featureTableBinaryByteLength=s,n.header.batchTableJsonByteLength=u,n.header.batchTableBinaryByteLength=l,n.header.batchLength=i,e}function parseFeatureTable(n,t,e){var r=n.header||{},i=r.featureTableJsonByteLength,o=r.featureTableBinaryByteLength,s=r.batchLength;if(n.featureTableJson={BATCH_LENGTH:s||0},i&&i>0){var u=getStringFromArrayBuffer(t,e,i);n.featureTableJson=JSON.parse(u)}e+=i||0,n.featureTableBinary=new Uint8Array(t,e,o),e+=o||0,n.rtcCenter=new THREE__namespace.Vector3;var l=new FeatureTable(n.featureTableJson,n.featureTableBinary);if(Array.isArray(l.json.RTC_CENTER))n.rtcCenter.fromArray(l.json.RTC_CENTER);else{var d=l.getGlobalProperty("RTC_CENTER",GL_TYPE.FLOAT,3);d&&n.rtcCenter.fromArray(d)}return e}function parseBatchTable(n,t,e){var r=n.header||{},i=r.batchTableJsonByteLength,o=r.batchTableBinaryByteLength;if(i&&i>0){var s=getStringFromArrayBuffer(t,e,i);n.batchTableJson=JSON.parse(s),e+=i,o&&o>0&&(n.batchTableBinary=new Uint8Array(t,e,o),n.batchTableBinary=new Uint8Array(n.batchTableBinary),e+=o)}return e}function sliceArrayBuffer(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 parseGlTFArrayBuffer(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=sliceArrayBuffer(t,e,r),n.byteLength}function decodeText(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 WEBGL_CONSTANTS={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},WEBGL_COMPONENT_TYPES={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array},WEBGL_FILTERS={9728:THREE__namespace.NearestFilter,9729:THREE__namespace.LinearFilter,9984:THREE__namespace.NearestMipmapNearestFilter,9985:THREE__namespace.LinearMipmapNearestFilter,9986:THREE__namespace.NearestMipmapLinearFilter,9987:THREE__namespace.LinearMipmapLinearFilter},WEBGL_WRAPPINGS={33071:THREE__namespace.ClampToEdgeWrapping,33648:THREE__namespace.MirroredRepeatWrapping,10497:THREE__namespace.RepeatWrapping},WEBGL_TYPE_SIZES={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},ATTRIBUTES={POSITION:"position",NORMAL:"normal",TANGENT:"tangent",TEXCOORD_0:"uv",TEXCOORD_1:"uv2",COLOR_0:"color",WEIGHTS_0:"skinWeight",JOINTS_0:"skinIndex"},PATH_PROPERTIES={scale:"scale",translation:"position",rotation:"quaternion",weights:"morphTargetInfluences"},INTERPOLATION={CUBICSPLINE:void 0,LINEAR:THREE__namespace.InterpolateLinear,STEP:THREE__namespace.InterpolateDiscrete},ALPHA_MODES={OPAQUE:"OPAQUE",MASK:"MASK",BLEND:"BLEND"};function values(n){var t=[];for(var e in n)t.push(n[e]);return t}var Parser=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,o=e.length;i<o;i++)for(var s=e[i].joints,u=0,l=s.length;u<l;u++)t[s[u]].isBone=!0;for(var d=0,c=t.length;d<c;d++){var f=t[d];f.mesh!==void 0&&f.skin!==void 0&&(r[f.mesh].isSkinnedMesh=!0)}},n.prototype.parse=function(){var t=this,e=this.json,r=this.extensions;this.dispose(),this.markDefs();for(var i=0,o=values(r);i<o.length;i++){var s=o[i];s.markDefs(this)}return Promise.all(values(r).map(function(u){return u.prepare(t)})).then(function(){var u,l,d;return Promise.all([Promise.all(((u=e.scenes)!==null&&u!==void 0?u:[]).map(function(c,f){return t.loadScene(f)})),Promise.all(((l=e.animations)!==null&&l!==void 0?l:[]).map(function(c,f){return t.loadAnimation(f)})),Promise.all(((d=e.cameras)!==null&&d!==void 0?d:[]).map(function(c,f){return t.loadCamera(f)}))])}).then(function(u){var l=u[0],d=u[1],c=u[2],f={json:t.json,scene:l[e.scene||0],scenes:l,animations:d,cameras:c,dispose:function(){return t.dispose()}};return Promise.all(values(r).map(function(h){return h.emitResult(f,t)})).then(function(){return f})})},n.prototype.loadCamera=function(t){var e="camera:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,o=0,s=values(this.extensions);o<s.length;o++){var u=s[o];if(i=u.loadCamera(t,this),i)break}if(!i){var l=void 0,d=this.json.cameras[t],c=d[d.type];c?d.type==="perspective"?l=new THREE__namespace.PerspectiveCamera(THREE__namespace.MathUtils.radToDeg(c.yfov),c.aspectRatio||1,c.znear||1,c.zfar||2e6):d.type==="orthographic"?l=new THREE__namespace.OrthographicCamera(-c.xmag,c.xmag,c.ymag,-c.ymag,c.znear,c.zfar):(console.warn("glTF: Invalid camera type ".concat(d.type,".")),l=new THREE__namespace.Camera):(console.warn("glTF: Missing camera parameters."),l=new THREE__namespace.Camera),d.name&&(l.name=this.createUniqueName(d.name)),i=Promise.resolve(l)}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,o=this.json.skins[t],s={joints:o.joints};return o.inverseBindMatrices===void 0?i=Promise.resolve(s):i=this.loadAccessor(o.inverseBindMatrices).then(function(u){return u&&(s.inverseBindMatrices=u),s}),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,o=0,s=values(this.extensions);o<s.length;o++){var u=s[o];if(i=u.loadAnimation(t,this),i)break}if(!i){for(var l=this.json,d=l.animations[t],c=[],f=[],h=[],v=[],A=[],m=0,y=d.channels.length;m<y;m++){var p=d.channels[m],g=d.samplers[p.sampler],b=p.target,T=b.node!==void 0?b.node:b.id,_=d.parameters!==void 0?d.parameters[g.input]:g.input,w=d.parameters!==void 0?d.parameters[g.output]:g.output;c.push(this.loadNode(T)),f.push(this.loadAccessor(_)),h.push(this.loadAccessor(w)),v.push(g),A.push(b)}i=Promise.all([Promise.all(c),Promise.all(f),Promise.all(h),Promise.all(v),Promise.all(A)]).then(function(x){for(var M=x[0],R=x[1],I=x[2],S=x[3],B=x[4],O=[],F=function(q,V){var D=M[q],K=R[q],z=I[q],G=S[q],W=B[q];if(D===void 0)return"continue";D.updateMatrix(),D.matrixAutoUpdate=!0;var Q=void 0;switch(PATH_PROPERTIES[W.path]){case PATH_PROPERTIES.weights:Q=THREE__namespace.NumberKeyframeTrack;break;case PATH_PROPERTIES.rotation:Q=THREE__namespace.QuaternionKeyframeTrack;break;case PATH_PROPERTIES.position:case PATH_PROPERTIES.scale:default:Q=THREE__namespace.VectorKeyframeTrack;break}var X=D.name?D.name:D.uuid,ee=G.interpolation!==void 0?INTERPOLATION[G.interpolation]:THREE__namespace.InterpolateLinear,J=[];PATH_PROPERTIES[W.path]===PATH_PROPERTIES.weights?D.traverse(function(se){se.morphTargetInfluences&&J.push(se.name?se.name:se.uuid)}):J.push(X);var Z=z.array;if(z.normalized){for(var te=getNormalizedComponentScale(Z.constructor),ae=new Float32Array(Z.length),re=0,ie=Z.length;re<ie;re++)ae[re]=Z[re]*te;Z=ae}for(var re=0,ie=J.length;re<ie;re++){var de=new Q(J[re]+"."+PATH_PROPERTIES[W.path],K.array,Z,ee);O.push(de)}},H=0,k=M.length;H<k;H++)F(H);var N=d.name?d.name:"animation_"+t;return new THREE__namespace.AnimationClip(N,void 0,O)})}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 o=null,s=0,u=values(this.extensions);s<u.length;s++){var l=u[s];if(o=l.loadBuffer(t,this),o)break}if(!o){var d=this.json.buffers[t];o=this.options.fetcher.ajax(this.resolveResouce(d.uri),{responseType:"arraybuffer"}).then(function(c){return c.body})}return this.cache.set(r,o),o},n.prototype.loadBufferView=function(t){var e="bufferView:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,o=0,s=values(this.extensions);o<s.length;o++){var u=s[o];if(i=u.loadBufferView(t,this),i)break}if(!i){var l=this.json.bufferViews[t];i=this.loadBuffer(l.buffer).then(function(d){var c=l.byteLength||0,f=l.byteOffset||0;return d.slice(f,f+c)})}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 o=null;if(!o){var s=this.json.accessors[t];if(s.bufferView===void 0&&s.sparse===void 0)o=Promise.resolve(null);else{var u=[];s.bufferView!==void 0?u.push(this.loadBufferView(s.bufferView)):u.push(Promise.resolve(null)),s.sparse!==void 0&&(u.push(this.loadBufferView(s.sparse.indices.bufferView)),u.push(this.loadBufferView(s.sparse.values.bufferView))),o=Promise.all(u).then(function(l){var d=l[0],c=WEBGL_TYPE_SIZES[s.type],f=WEBGL_COMPONENT_TYPES[s.componentType],h=f.BYTES_PER_ELEMENT,v=h*c,A=s.byteOffset||0,m=s.bufferView!==void 0?e.json.bufferViews[s.bufferView].byteStride:void 0,y=s.normalized===!0,p,g;if(m&&m!==v){var b=Math.floor(A/m),T="InterleavedBuffer:"+s.bufferView+":"+s.componentType+":"+b+":"+s.count,_=e.cache.get(T);_||(p=new f(d,b*m,s.count*m/h),_=new THREE__namespace.InterleavedBuffer(p,m/h),e.cache.set(T,_)),g=new THREE__namespace.InterleavedBufferAttribute(_,c,A%m/h,y)}else d===null?p=new f(s.count*c):p=new f(d,A,s.count*c),g=new THREE__namespace.BufferAttribute(p,c,y);if(s.sparse!==void 0){var w=WEBGL_TYPE_SIZES.SCALAR,x=WEBGL_COMPONENT_TYPES[s.sparse.indices.componentType],M=s.sparse.indices.byteOffset||0,R=s.sparse.values.byteOffset||0,I=new x(l[1],M,s.sparse.count*w),S=new f(l[2],R,s.sparse.count*c);d!==null&&(g=new THREE__namespace.BufferAttribute(g.array.slice(),g.itemSize,g.normalized));for(var B=0,O=I.length;B<O;B++){var F=I[B];if(g.setX(F,S[B*c]),c>=2&&g.setY(F,S[B*c+1]),c>=3&&g.setZ(F,S[B*c+2]),c>=4&&g.setW(F,S[B*c+3]),c>=5)throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.")}}return g})}}return this.cache.set(r,o),o},n.prototype.createPrimitiveKey=function(t){for(var e=0,r=values(this.extensions);e<r.length;e++){var i=r[e],o=i.createPrimitiveKey(t,this);if(o)return o}for(var s="",u=Object.keys(t.attributes).sort(),l=0,d=u.length;l<d;l++)s+=u[l]+":"+t.attributes[u[l]]+";";return t.indices+":"+s+":"+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 o=null,s=0,u=values(this.extensions);s<u.length;s++){var l=u[s];if(o=l.loadGeometry(t,this),o)break}return o||(o=this.addGeometryPrimitiveAttributes(new THREE__namespace.BufferGeometry,t)),o=o.then(function(d){return e.disposeSet.add(d),d}),this.cache.set(r,o),o},n.prototype.loadImage=function(t){var e="image:"+t,r=this.cache.get(e);if(r)return r;for(var i=null,o=0,s=values(this.extensions);o<s.length;o++){var u=s[o];if(i=u.loadImage(t,this),i)break}if(!i){var l=this.json.images[t];if(l.bufferView)i=this.loadBufferView(l.bufferView).then(function(c){var f=new Blob([c],{type:l.mimeType});return createImageBitmapLike(f)});else if(l.uri){var d=this.resolveResouce(l.uri);i=this.options.fetcher.loadImage(d,{},void 0,void 0,void 0,createImageBitmapLikeImage()).then(function(c){return c.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 THREE__namespace.MeshStandardMaterial;if(i.color=new THREE__namespace.Color(1,1,1),i.opacity=1,Object.keys(t.attributes).filter(function(c){return ATTRIBUTES[c]==="color"}).length>0&&(i.vertexColors=!0),Object.keys(t.attributes).filter(function(c){return ATTRIBUTES[c]==="normal"}).length===0&&(i.flatShading=!0),Object.keys(t.attributes).filter(function(c){return ATTRIBUTES[c]==="tangent"}).length===0&&(i.normalScale&&(i.normalScale.y*=-1),i.clearcoatNormalScale&&(i.clearcoatNormalScale.y*=-1)),t.material!==void 0){var o=this.json.materials[t.material];o.name&&(i.name=o.name);var s=o.pbrMetallicRoughness||{};if(Array.isArray(s.baseColorFactor)){var u=s.baseColorFactor;i.color.fromArray(u),i.opacity=u[3]}s.baseColorTexture!==void 0&&r.push(this.createMaterialTexture(s.baseColorTexture).then(function(c){c.encoding=THREE__namespace.sRGBEncoding,i.map=c,e.disposeSet.add(c)})),i.metalness=s.metallicFactor!==void 0?s.metallicFactor:1,i.roughness=s.roughnessFactor!==void 0?s.roughnessFactor:1,s.metallicRoughnessTexture!==void 0&&r.push(this.createMaterialTexture(s.metallicRoughnessTexture).then(function(c){c.encoding=THREE__namespace.sRGBEncoding,i.metalnessMap=c,i.roughnessMap=c,e.disposeSet.add(c)})),o.doubleSided===!0&&(i.side=THREE__namespace.DoubleSide);var l=o.alphaMode||ALPHA_MODES.OPAQUE;if(l===ALPHA_MODES.BLEND?(i.transparent=!0,i.depthWrite=!1):(i.transparent=!1,l===ALPHA_MODES.MASK&&(i.alphaTest=o.alphaCutoff!==void 0?o.alphaCutoff:.5)),o.normalTexture!==void 0&&(r.push(this.createMaterialTexture(o.normalTexture).then(function(c){i.normalMap=c,e.disposeSet.add(c)})),i.normalScale=new THREE__namespace.Vector2(1,1),o.normalTexture.scale!==void 0)){var d=o.normalTexture.scale;i.normalScale.set(d,d)}o.occlusionTexture!==void 0&&(r.push(this.createMaterialTexture(o.occlusionTexture).then(function(c){i.aoMap=c,e.disposeSet.add(c)})),o.occlusionTexture.strength!==void 0&&(i.aoMapIntensity=o.occlusionTexture.strength)),o.emissiveFactor!==void 0&&(i.emissive=new THREE__namespace.Color().fromArray(o.emissiveFactor)),o.emissiveTexture!==void 0&&r.push(this.createMaterialTexture(o.emissiveTexture).then(function(c){i.emissiveMap=c,e.disposeSet.add(c)}))}return this.disposeSet.add(i),Promise.all(r).then(function(){return i})},n.prototype.loadMaterialAsLineBasicMaterial=function(t){var e=[],r=new THREE__namespace.LineBasicMaterial;if(r.color=new THREE__namespace.Color(1,1,1),r.opacity=1,Object.keys(t.attributes).filter(function(l){return ATTRIBUTES[l]==="color"}).length>0&&(r.vertexColors=!0),Object.keys(t.attributes).filter(function(l){return ATTRIBUTES[l]==="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 o=i.pbrMetallicRoughness||{};if(Array.isArray(o.baseColorFactor)){var s=o.baseColorFactor;r.color.fromArray(s),r.opacity=s[3]}i.doubleSided===!0&&(r.side=THREE__namespace.DoubleSide);var u=i.alphaMode||ALPHA_MODES.OPAQUE;u===ALPHA_MODES.BLEND?(r.transparent=!0,r.depthWrite=!1):(r.transparent=!1,u===ALPHA_MODES.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 THREE__namespace.PointsMaterial;if(i.color=new THREE__namespace.Color(1,1,1),i.opacity=1,i.sizeAttenuation=!1,Object.keys(t.attributes).filter(function(d){return ATTRIBUTES[d]==="color"}).length>0&&(i.vertexColors=!0),Object.keys(t.attributes).filter(function(d){return ATTRIBUTES[d]==="tangent"}).length===0&&(i.normalScale&&(i.normalScale.y*=-1),i.clearcoatNormalScale&&(i.clearcoatNormalScale.y*=-1)),t.material!==void 0){var o=this.json.materials[t.material];o.name&&(i.name=o.name);var s=o.pbrMetallicRoughness||{};if(Array.isArray(s.baseColorFactor)){var u=s.baseColorFactor;i.color.fromArray(u),i.opacity=u[3]}s.baseColorTexture!==void 0&&r.push(this.createMaterialTexture(s.baseColorTexture).then(function(d){d.encoding=THREE__namespace.sRGBEncoding,i.map=d,e.disposeSet.add(d)})),o.doubleSided===!0&&(i.side=THREE__namespace.DoubleSide);var l=o.alphaMode||ALPHA_MODES.OPAQUE;l===ALPHA_MODES.BLEND?(i.transparent=!0,i.depthWrite=!1):(i.transparent=!1,l===ALPHA_MODES.MASK&&(i.alphaTest=o.alphaCutoff!==void 0?o.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:WEBGL_CONSTANTS.TRIANGLES,o="material:"+this.createPrimitiveKey(t),s=this.cache.get(o);if(s)return s;for(var u=null,l=0,d=values(this.extensions);l<d.length;l++){var c=d[l];if(u=c.loadMaterial(t,this),u)break}if(i===WEBGL_CONSTANTS.TRIANGLES||i===WEBGL_CONSTANTS.TRIANGLE_STRIP||i===WEBGL_CONSTANTS.TRIANGLE_FAN)u=this.loadMaterialAsMeshStandardMaterial(t);else if(i===WEBGL_CONSTANTS.LINES||i===WEBGL_CONSTANTS.LINE_STRIP||i===WEBGL_CONSTANTS.LINE_LOOP)u=this.loadMaterialAsLineBasicMaterial(t);else if(i===WEBGL_CONSTANTS.POINTS)u=this.loadMaterialAsPointsMaterial(t);else throw new Error("glTF: Primitive mode unsupported: "+i);return u=u.then(function(f){return e.disposeSet.add(f),f}),this.cache.set(o,u),u},n.prototype.loadTexture=function(t){var e=this,r="texture:"+t,i=this.cache.get(r);if(i)return i;for(var o=null,s=0,u=values(this.extensions);s<u.length;s++){var l=u[s];if(o=l.loadTexture(t,this),o)break}if(!o){var d=this.json.textures[t];o=this.loadImage(d.source).then(function(c){var f=new THREE__namespace.Texture(c);f.needsUpdate=!0,f.flipY=!1,d.name&&(f.name=d.name);var h=e.json.samplers||{},v=h[d.sampler]||{};f.magFilter=WEBGL_FILTERS[v.magFilter]||THREE__namespace.LinearFilter,f.minFilter=WEBGL_FILTERS[v.minFilter]||THREE__namespace.LinearMipmapLinearFilter,f.wrapS=WEBGL_WRAPPINGS[v.wrapS]||THREE__namespace.RepeatWrapping,f.wrapT=WEBGL_WRAPPINGS[v.wrapT]||THREE__namespace.RepeatWrapping;var A=f.dispose;return f.dispose=function(){return f.dispose=A,c.close(),A.call(this)},f})}return o=o.then(function(c){return e.disposeSet.add(c),c}),this.cache.set(r,o),o},n.prototype.loadMesh=function(t){for(var e=this,r=null,i=0,o=values(this.extensions);i<o.length;i++){var s=o[i];if(r=s.loadMesh(t,this),r)break}if(!r){var u=this.json.meshes[t],l=u.primitives,d=Promise.all(l.map(function(f){return e.loadGeometry(f)})),c=Promise.all(l.map(function(f){return e.loadMaterial(f)}));r=Promise.all([d,c]).then(function(f){for(var h=f[0],v=f[1],A=[],m=0;m<l.length;m++){var y=l[m],p=h[m],g=v[m],b=y.mode||WEBGL_CONSTANTS.TRIANGLES,T=void 0;if(b===WEBGL_CONSTANTS.TRIANGLES||b===WEBGL_CONSTANTS.TRIANGLE_STRIP||b===WEBGL_CONSTANTS.TRIANGLE_FAN)if(b===WEBGL_CONSTANTS.TRIANGLE_STRIP?p=e.toGeometryTrianglesDrawMode(p,THREE__namespace.TriangleStripDrawMode):b===WEBGL_CONSTANTS.TRIANGLE_FAN&&(p=e.toGeometryTrianglesDrawMode(p,THREE__namespace.TriangleFanDrawMode)),u.isSkinnedMesh){var _=new THREE__namespace.SkinnedMesh(p,g);p.attributes.skinWeight.normalized||_.normalizeSkinWeights(),T=_}else T=new THREE__namespace.Mesh(p,g);else if(b===WEBGL_CONSTANTS.POINTS)T=new THREE__namespace.Points(p,g);else if(b===WEBGL_CONSTANTS.LINES)T=new THREE__namespace.LineSegments(p,g);else if(b===WEBGL_CONSTANTS.LINE_STRIP)T=new THREE__namespace.Line(p,g);else if(b===WEBGL_CONSTANTS.LINE_LOOP)T=new THREE__namespace.LineLoop(p,g);else throw new Error("glTF: Primitive mode unsupported: "+b);if(Object.keys(p.morphAttributes).length>0){if(u.weights!==void 0)for(var w=0,x=u.weights.length;w<x;w++)T.morphTargetInfluences[w]=u.weights[w];if(u.extras&&Array.isArray(u.extras.targetNames)){var M=u.extras.targetNames;if(T.morphTargetInfluences.length===M.length){T.morphTargetDictionary={};for(var w=0,x=M.length;w<x;w++)T.morphTargetDictionary[M[w]]=w}else console.warn("glTF: Invalid extras.targetNames length. Ignoring names.")}}T.name=e.createUniqueName(u.name||"mesh_"+t),A.push(T)}if(A.length===1)return A[0];for(var R=new THREE__namespace.Group,I=0,S=A;I<S.length;I++){var T=S[I];R.add(T)}return R})}return r},n.prototype.loadNodeAttachments=function(t){for(var e=[],r=0,i=values(this.extensions);r<i.length;r++){var o=i[r],s=o.loadNodeAttachments(t,this);s&&e.push(s)}return e},n.prototype.loadNode=function(t){var e="node:"+t,r=this.cache.get(e);if(r)return r;var i=this.json,o=i.nodes[t],s=o.name?this.createUniqueName(o.name):"",u=[];o.mesh!==void 0&&u.push(this.loadMesh(o.mesh).then(function(h){if(o.weights!==void 0){var v=o.weights;h.traverse(function(A){if(A instanceof THREE__namespace.Mesh||A instanceof THREE__namespace.Line||A instanceof THREE__namespace.Points)for(var m=0,y=v.length;m<y;m++)A.morphTargetInfluences[m]=v[m]})}return h})),o.camera!==void 0&&u.push(this.loadCamera(o.camera));for(var l=this.loadNodeAttachments(t),d=0,c=l;d<c.length;d++){var f=c[d];u.push(f)}return Promise.all(u).then(function(h){var v;if(o.isBone===!0?v=new THREE__namespace.Bone:h.length>1?v=new THREE__namespace.Group:h.length===1?v=h[0]:v=new THREE__namespace.Object3D,v!==h[0])for(var A=0,m=h.length;A<m;A++)v.add(h[A]);if(o.name&&(v.name=s),o.matrix!==void 0){var y=new THREE__namespace.Matrix4;y.fromArray(o.matrix),v.applyMatrix4(y)}else o.translation!==void 0&&v.position.fromArray(o.translation),o.rotation!==void 0&&v.quaternion.fromArray(o.rotation),o.scale!==void 0&&v.scale.fromArray(o.scale);return v})},n.prototype.loadScene=function(t){var e=this.json,r=e.scenes[t],i=new THREE__namespace.Group;r.name&&(i.name=this.createUniqueName(r.name));for(var o=r.nodes||[],s=[],u=0,l=o.length;u<l;u++)s.push(this.buildNodeHierarchy(o[u],i));return Promise.all(s).then(function(){return i})},n.prototype.createMaterialTexture=function(t){var e=this;return this.loadTexture(t.index).then(function(r){for(var i=0,o=values(e.extensions);i<o.length;i++){var s=o[i],u=s.extendTexture(r,t,e);u&&(r=u)}return r})},n.prototype.addGeometryPrimitiveAttributes=function(t,e){var r=this,i=e.attributes,o=[],s=function(_){var w=ATTRIBUTES[_]||_.toLowerCase();if(w in t.attributes)return"continue";o.push(u.loadAccessor(i[_]).then(function(x){x&&t.setAttribute(w,x)}))},u=this;for(var l in i)s(l);e.indices!==void 0&&!t.index&&o.push(this.loadAccessor(e.indices).then(function(_){_&&t.setIndex(_)}));var d=new THREE__namespace.Box3;if(i.POSITION!==void 0){var c=this.json.accessors[i.POSITION],f=c.min,h=c.max;if(f!==void 0&&h!==void 0){if(d.set(new THREE__namespace.Vector3(f[0],f[1],f[2]),new THREE__namespace.Vector3(h[0],h[1],h[2])),c.normalized){var v=getNormalizedComponentScale(WEBGL_COMPONENT_TYPES[c.componentType]);d.min.multiplyScalar(v),d.max.multiplyScalar(v)}}else console.warn("glTF: Missing min/max properties for accessor POSITION.")}var A=e.targets;if(A!==void 0){for(var m=new THREE__namespace.Vector3,y=new THREE__namespace.Vector3,p=0,g=A.length;p<g;p++){var b=A[p];if(b.POSITION!==void 0){var c=this.json.accessors[b.POSITION],f=c.min,h=c.max;if(f!==void 0&&h!==void 0){if(y.setX(Math.max(Math.abs(f[0]),Math.abs(h[0]))),y.setY(Math.max(Math.abs(f[1]),Math.abs(h[1]))),y.setZ(Math.max(Math.abs(f[2]),Math.abs(h[2]))),c.normalized){var v=getNormalizedComponentScale(WEBGL_COMPONENT_TYPES[c.componentType]);y.multiplyScalar(v)}m.max(y)}else console.warn("glTF: Missing min/max properties for accessor POSITION.")}}d.expandByVector(m)}t.boundingBox=d;var T=new THREE__namespace.Sphere;return d.getCenter(T.center),T.radius=d.min.distanceTo(d.max)/2,t.boundingSphere=T,Promise.all(o).then(function(){if(t.attributes.uv&&!t.attributes.uv2&&r.options.copyUV2&&t.setAttribute("uv2",t.attributes.uv),e.targets){for(var _=!1,w=!1,x=0,M=e.targets.length;x<M;x++){var R=e.targets[x];if(R.POSITION!==void 0&&(_=!0),R.NORMAL!==void 0&&(w=!0),_&&w)break}if(!_&&!w)return t;var I=[];t.morphTargetsRelative=!0;for(var S=function(B,O){var F=e.targets[B];_?I.push(r.loadAccessor(F.POSITION).then(function(H){H&&(t.morphAttributes.position[B]=H)})):t.morphAttributes.position[B]=t.attributes.position,w?I.push(r.loadAccessor(F.NORMAL).then(function(H){H&&(t.morphAttributes.normal[B]=H)})):t.morphAttributes.normal[B]=t.attributes.normal},x=0,M=e.targets.length;x<M;x++)S(x,M);return Promise.all(I).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(o){if(i.skin===void 0)return o;var s;return r.loadSkin(i.skin).then(function(u){s=u;for(var l=[],d=0,c=s.joints.length;d<c;d++)l.push(r.loadNode(s.joints[d]));return Promise.all(l)}).then(function(u){return o.traverse(function(l){if(l instanceof THREE__namespace.SkinnedMesh){for(var d=[],c=[],f=0,h=u.length;f<h;f++){var v=u[f];if(v instanceof THREE__namespace.Bone){d.push(v);var A=new THREE__namespace.Matrix4;s.inverseBindMatrices!==void 0&&A.fromArray(s.inverseBindMatrices.array,f*16),c.push(A)}else console.warn('glTF: Joint "%s" could not be found.',s.joints[f])}l.bind(new THREE__namespace.Skeleton(d,c),l.matrixWorld)}}),o})}).then(function(o){e.add(o);var s=[];if(i.children)for(var u=i.children,l=0,d=u.length;l<d;l++){var c=u[l];s.push(r.buildNodeHierarchy(c,o))}return Promise.all(s).then(function(){return o})})},n.prototype.createUniqueName=function(t){for(var e=THREE__namespace.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 pathJoin(this.options.resourcePath,appendSearch(t,this.options.search))},n.prototype.toGeometryTrianglesDrawMode=function(t,e){var r=t.getIndex();if(r===null){var i=[],o=t.getAttribute("position");if(o!==void 0){for(var s=0;s<o.count;s++)i.push(s);t.setIndex(i),r=t.getIndex()}}if(r===null)return console.error("glTF: Undefined position attribute. Processing not possible."),t;var u=r.count-2,l=[];if(e===THREE__namespace.TriangleFanDrawMode)for(var s=1;s<=u;s++)l.push(r.getX(0)),l.push(r.getX(s)),l.push(r.getX(s+1));else for(var s=0;s<u;s++)s%2===0?(l.push(r.getX(s)),l.push(r.getX(s+1)),l.push(r.getX(s+2))):(l.push(r.getX(s+2)),l.push(r.getX(s+1)),l.push(r.getX(s)));l.length/3!==u&&console.error("glTF: Unable to generate correct amount of triangles.");var d=t.clone();return d.setIndex(l),d},n}();function getNormalizedComponentScale(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 BaseExtension=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}(),KHR_binary_glTF=function(n){__extends(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 decodeText(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),o=0,s=null,u=null;o<i.byteLength;){var l=i.getUint32(o,!0);o+=4;var d=i.getUint32(o,!0);if(o+=4,d===t.CHUNK_TYPES.JSON){var c=new Uint8Array(e,t.HEADER_LENGTH+o,l);s=decodeText(c)}else if(d===t.CHUNK_TYPES.BIN){var f=t.HEADER_LENGTH+o;u=e.slice(f,f+l)}o+=l}if(s===null)throw new Error("glTF:KHR_binary_glTF: JSON content not found.");this.content=s,this.body=u},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}(BaseExtension),defaultDecoderPath="https://vr-public.realsee-cdn.cn/release/static/image/release/five/resource/draco/1.5.6/",defaultAttributeIDs={position:"POSITION",normal:"NORMAL",color:"COLOR",uv:"TEX_COORD"},defaultAttributeTypes={position:"Float32Array",normal:"Float32Array",color:"Float32Array",uv:"Float32Array"},Draco=function(){function n(){this.decoderPath=defaultDecoderPath,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 o={attributeIDs:r||defaultAttributeIDs,attributeTypes:i||defaultAttributeTypes,useUniqueIDs:!!r};this.decodeGeometry(t,o).then(e)},n.prototype.decodeGeometry=function(t,e){var r=this;e===void 0&&(e={attributeIDs:defaultAttributeIDs,attributeTypes:defaultAttributeTypes,useUniqueIDs:!1});for(var i in e.attributeTypes){var o=e.attributeTypes[i];o.BYTES_PER_ELEMENT!==void 0&&(e.attributeTypes[i]=o.name)}var s,u=this.workerNextTaskID++,l=t.byteLength,d=this._getWorker(u,l).then(function(c){return s=c,new Promise(function(f,h){s._callbacks[u]={resolve:f,reject:h},s.postMessage({type:"decode",id:u,taskConfig:e,buffer:t},[t])})}).then(function(c){return r._createGeometry(c.geometry)});return d.catch(function(){return!0}).then(function(){s&&u&&r._releaseTask(s,u)}),d},n.prototype._createGeometry=function(t){var e=new THREE__namespace.BufferGeometry;t.index&&e.setIndex(new THREE__namespace.BufferAttribute(t.index.array,1));for(var r=0;r<t.attributes.length;r++){var i=t.attributes[r],o=i.name,s=i.array,u=i.itemSize;e.setAttribute(o,new THREE__namespace.BufferAttribute(s,u))}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=ajax(this.decoderPath+"draco_decoder.js",{responseType:"text"}).then(function(o){return o.body});this.decoderPending=r.then(function(o){var s=["/* draco decoder */",o,"","/* worker */",DRACOWorker].join(`
|
|
418
418
|
`);t.workerSourceURL=URL.createObjectURL(new Blob([s]))})}else{var r=ajax(this.decoderPath+"draco_wasm_wrapper.js",{responseType:"text"}).then(function(s){return s.body}),i=ajax(this.decoderPath+"draco_decoder.wasm",{responseType:"arraybuffer"}).then(function(s){return s.body});this.decoderPending=Promise.all([r,i]).then(function(s){var u=s[0],l=s[1];t.decoderConfig.wasmBinary=l;var d=["/* draco decoder */",u,"","/* worker */",DRACOWorker].join(`
|
|
419
419
|
`);t.workerSourceURL=URL.createObjectURL(new Blob([d]))})}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(s){var u=s.data;switch(u.type){case"decode":i._callbacks[u.id].resolve(u);break;case"error":i._callbacks[u.id].reject(u);break;default:console.error('DRACO: Unexpected message, "'+u.type+'"')}},r.workerPool.push(i)}else r.workerPool.sort(function(s,u){return s._taskLoad>u._taskLoad?-1:1});var o=r.workerPool[r.workerPool.length-1];return o._taskCosts[t]=e,o._taskLoad+=e,o})},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}(),draco=new Draco,DRACOWorker=`
|
|
420
420
|
let decoderConfig;
|
|
@@ -880,7 +880,7 @@ void main() {
|
|
|
880
880
|
return ( value & ( value - 1 ) ) === 0 && value !== 0;
|
|
881
881
|
|
|
882
882
|
}
|
|
883
|
-
`,EXTENSION_NAME$4="KHR_texture_basisu",KHR_texture_basisu=function(n){__extends(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[EXTENSION_NAME$4])return null;var o=i.extensions[EXTENSION_NAME$4],s=r.json.images[o.source],u=null;if(s.bufferView)u=r.loadBufferView(s.bufferView).then(function(l){return ktx2.parse(l)});else if(s.uri)u=r.options.fetcher.ajax(r.resolveResouce(s.uri),{responseType:"arraybuffer"}).then(function(l){return ktx2.parse(l.body)});else throw new Error("glTF: Invalid image defs.");return u},t}(BaseExtension),EXTENSION_NAME$3="KHR_texture_transform",KHR_texture_transform=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.extendTexture=function(e,r,i){var o=r.extensions!==void 0?r.extensions[EXTENSION_NAME$3]:void 0;return o?(o.texCoord!==void 0&&console.warn('glTF: Custom UV sets in "'+EXTENSION_NAME$3+'" extension not yet supported.'),o.offset===void 0&&o.rotation===void 0&&o.scale===void 0||(e=e.clone(),e.needsUpdate=!0,o.offset!==void 0&&e.offset.fromArray(o.offset),o.rotation!==void 0&&(e.rotation=o.rotation),o.scale!==void 0&&e.repeat.fromArray(o.scale)),e):null},t}(BaseExtension),KHR_mesh_quantization=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t}(BaseExtension),meshoptDecoder=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,o,s=WebAssembly.instantiate(u(i),{}).then(function(p){o=p.instance,o.exports.__wasm_call_ctors()});function u(p){for(var g=new Uint8Array(p.length),b=0;b<p.length;++b){var T=p.charCodeAt(b);g[b]=T>96?T-97:T>64?T-39:T+4}for(var _=0,b=0;b<p.length;++b)g[_++]=g[b]<60?r[g[b]]:(g[b]-60)*64+g[++b];return g.buffer.slice(0,_)}function l(p,g,b,T,_,w){var x=o.exports.sbrk,M=b+3&-4,R=x(M*T),I=x(_.length),S=new Uint8Array(o.exports.memory.buffer);S.set(_,I);var B=p(R,b,T,I,_.length);if(B==0&&w&&w(R,M,T),g.set(S.subarray(R,R+b*T)),x(R-x(0)),B!=0)throw new Error("Malformed buffer data: "+B)}var d={NONE:"",OCTAHEDRAL:"meshopt_decodeFilterOct",QUATERNION:"meshopt_decodeFilterQuat",EXPONENTIAL:"meshopt_decodeFilterExp"},c={ATTRIBUTES:"meshopt_decodeVertexBuffer",TRIANGLES:"meshopt_decodeIndexBuffer",INDICES:"meshopt_decodeIndexSequence"},f=[],h=0;function v(p){var g={object:new Worker(p),pending:0,requests:{}};return g.object.onmessage=function(b){var T=b.data;g.pending-=T.count,g.requests[T.id][T.action](T.value),delete g.requests[T.id]},g}function A(p){for(var g="var instance; var ready = WebAssembly.instantiate(new Uint8Array(["+new Uint8Array(u(i))+"]), {}).then(function(result) { instance = result.instance; instance.exports.__wasm_call_ctors(); });self.onmessage = workerProcess;"+l.toString()+y.toString(),b=new Blob([g],{type:"text/javascript"}),T=URL.createObjectURL(b),_=0;_<p;++_)f[_]=v(T);URL.revokeObjectURL(T)}function m(p,g,b,T,_){for(var w=f[0],x=1;x<f.length;++x)f[x].pending<w.pending&&(w=f[x]);return new Promise(function(M,R){var I=new Uint8Array(b),S=h++;w.pending+=p,w.requests[S]={resolve:M,reject:R},w.object.postMessage({id:S,count:p,size:g,source:I,mode:T,filter:_},[I.buffer])})}function y(p){s.then(function(){var g=p.data;try{var b=new Uint8Array(g.count*g.size);l(o.exports[g.mode],b,g.count,g.size,g.source,o.exports[g.filter]),self.postMessage({id:g.id,count:g.count,action:"resolve",value:b},[b.buffer])}catch(T){self.postMessage({id:g.id,count:g.count,action:"reject",value:T})}})}return{ready:s,supported:!0,useWorkers:function(p){A(p)},decodeVertexBuffer:function(p,g,b,T,_){l(o.exports.meshopt_decodeVertexBuffer,p,g,b,T,o.exports[d[_]])},decodeIndexBuffer:function(p,g,b,T){l(o.exports.meshopt_decodeIndexBuffer,p,g,b,T)},decodeIndexSequence:function(p,g,b,T){l(o.exports.meshopt_decodeIndexSequence,p,g,b,T)},decodeGltfBuffer:function(p,g,b,T,_,w){l(o.exports[c[_]],p,g,b,T,o.exports[d[w]])},decodeGltfBufferAsync:function(p,g,b,T,_){return f.length>0?m(p,g,b,c[T],d[_]):s.then(function(){var w=new Uint8Array(p*g);return l(o.exports[c[T]],w,p,g,b,o.exports[d[_]]),w})}}}(),EXTENSION_NAME$2="EXT_meshopt_compression",EXT_meshopt_compression=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.loadBufferView=function(e,r){var i=r.json,o=i.bufferViews[e];if(o.extensions&&o.extensions[EXTENSION_NAME$2]){var s=o.extensions[EXTENSION_NAME$2],u=r.loadBuffer(s.buffer);if(!meshoptDecoder.supported){if(i.extensionsRequired&&i.extensionsRequired.indexOf(EXTENSION_NAME$2)>=0)throw new Error("THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files");return null}return Promise.all([u,meshoptDecoder.ready]).then(function(l){var d=l[0],c=s.byteOffset||0,f=s.byteLength||0,h=s.count,v=s.byteStride,A=new ArrayBuffer(h*v),m=new Uint8Array(d,c,f);return meshoptDecoder.decodeGltfBuffer(new Uint8Array(A),h,v,m,s.mode,s.filter),A})}else return null},t}(BaseExtension),EXTENSION_NAME$1="EXT_texture_webp",EXT_texture_webp=function(n){__extends(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 imageSupport().then(function(i){r.supportsWep=i.webp})},t.prototype.loadTexture=function(e,r){var i=r.json,o=i.textures[e];if(!o.extensions||!o.extensions[EXTENSION_NAME$1]||!this.supportsWep)return null;var s=o.extensions[EXTENSION_NAME$1];return r.loadImage(s.source).then(function(u){var l=new THREE__namespace.Texture(u);l.needsUpdate=!0,l.flipY=!1,o.name&&(l.name=o.name);var d=r.json.samplers||{},c=d[o.sampler]||{};return l.magFilter=WEBGL_FILTERS[c.magFilter]||THREE__namespace.LinearFilter,l.minFilter=WEBGL_FILTERS[c.minFilter]||THREE__namespace.LinearMipmapLinearFilter,l.wrapS=WEBGL_WRAPPINGS[c.wrapS]||THREE__namespace.RepeatWrapping,l.wrapT=WEBGL_WRAPPINGS[c.wrapT]||THREE__namespace.RepeatWrapping,l})},t}(BaseExtension),EXTENSION_NAME="CESIUM_RTC",CESIUM_RTC=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.emitResult=function(e,r){if(r.json.extensions[EXTENSION_NAME]&&r.json.extensions[EXTENSION_NAME].center){var i=r.json.extensions[EXTENSION_NAME].center;e.CESIUM_RTC={center:new THREE__namespace.Vector3().fromArray(i)}}},t}(BaseExtension);const pointcloudFragmentShader=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}("{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"),pointcloudVertexShader=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}("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 scratchVector4=new THREE__namespace.Vector4,shaderUniforms$1=Object.assign({pointScale:new THREE__namespace.Uniform(1),pointMinPixel:new THREE__namespace.Uniform(1),pointMaxPixel:new THREE__namespace.Uniform(1),opacity:new THREE__namespace.Uniform(1),gradientTexture:new THREE__namespace.Uniform(null),modelAlpha:new THREE__namespace.Uniform(0),clippers:new THREE__namespace.Uniform([]),shownFloorIndex:new THREE__namespace.Uniform(-1),constantColor:new THREE__namespace.Uniform(null),geometricError:new THREE__namespace.Uniform(0),pixelRatio:new THREE__namespace.Uniform(1),screenHeight:new THREE__namespace.Uniform(512),floor:new THREE__namespace.Uniform(0)},THREE__namespace.UniformsUtils.clone(THREE__namespace.UniformsLib.common)),PBMPointCloudMaterial=function(n){__extends(t,n);function t(e){e===void 0&&(e={});var r,i,o,s,u,l,d,c,f,h,v,A,m,y,p,g,b,T,_,w,x=n.call(this,{vertexShader:pointcloudVertexShader,fragmentShader:pointcloudFragmentShader,uniforms:THREE__namespace.UniformsUtils.clone(shaderUniforms$1),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,M;return Object.defineProperties(x,{constantColor:{get:function(){return this.uniforms.constantColor.value},set:function(R){this.uniforms.constantColor.value=R;var I=this.defines.USE_CONSTANT_COLOR,S=R!==null;I!==S&&(this.defines.USE_CONSTANT_COLOR=S,this.needsUpdate=!0)}},opacity:{get:function(){return this.uniforms.opacity.value},set:function(R){this.uniforms.opacity.value=R}},modelAlpha:{get:function(){return this.uniforms.modelAlpha.value},set:function(R){this.uniforms.modelAlpha.value=R}},shownFloorIndex:{get:function(){return this.uniforms.shownFloorIndex.value},set:function(R){this.uniforms.shownFloorIndex.value=R}},clippers:{get:function(){return M},set:function(R){M!==R&&(M=R,this.uniforms.clippers.value=(M||[]).map(function(I){var S=typeof I.floorIndex=="number"?I.floorIndex:-1,B=new THREE__namespace.Matrix4().getInverse(I.clippingBoxMatrix);return{matrixInverse:B,floorIndex:S}}),this.needsUpdate=!0)}},pointColor:{get:function(){return this.defines.USE_POINT_COLOR_ALTITUDE===!0?"ALTITUDE":"RGB"},set:function(R){var I=R==="ALTITUDE";this.defines.USE_POINT_COLOR_ALTITUDE!==I&&(this.defines.USE_POINT_COLOR_ALTITUDE=I,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(R){var I=R==="ATTENUATION",S=R==="GEOMETRIC";this.defines.USE_POINT_SIZE_GEOMETRIC!==S&&(this.defines.USE_POINT_SIZE_GEOMETRIC=S,this.needsUpdate=!0),this.defines.USE_POINT_SIZE_ATTENUATION!==I&&(this.defines.USE_POINT_SIZE_ATTENUATION=I,this.needsUpdate=!0)}},pointShape:{get:function(){return this.defines.USE_POINT_SHAPE_CIRCLE===!0?"CIRCLE":"SQUARE"},set:function(R){var I=R==="CIRCLE";this.defines.USE_POINT_SHAPE_CIRCLE!==I&&(this.defines.USE_POINT_SHAPE_CIRCLE=I,this.needsUpdate=!0)}},pointScale:{get:function(){return this.uniforms.pointScale.value},set:function(R){this.uniforms.pointScale.value=R}},pointBack:{get:function(){return this.defines.USE_POINT_BACK_HIDDEN===!0?"HIDDEN":this.defines.USE_POINT_BACK_DARK===!0?"DARK":"VISIBLE"},set:function(R){var I=R==="HIDDEN",S=R==="DARK";this.defines.USE_POINT_BACK_HIDDEN!==I&&(this.defines.USE_POINT_BACK_HIDDEN=I,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(R){this.uniforms.pointMinPixel.value=R}},pointMaxPixel:{get:function(){return this.uniforms.pointMaxPixel.value},set:function(R){this.uniforms.pointMaxPixel.value=R}},useEDL:{get:function(){return this.defines.USE_EDL},set:function(R){R!==this.defines.USE_EDL&&(this.defines.USE_EDL=R,this.needsUpdate=!0)}},useHQWeight:{get:function(){return this.defines.USE_HQ_WEIGHT},set:function(R){R!==this.defines.USE_HQ_WEIGHT&&(this.defines.USE_HQ_WEIGHT=R,this.needsUpdate=!0)}},useHQDepth:{get:function(){return this.defines.USE_HQ_DEPTH},set:function(R){R!==this.defines.USE_HQ_DEPTH&&(this.defines.USE_HQ_DEPTH=R,this.needsUpdate=!0)}},gradientTexture:{get:function(){return this.uniforms.gradientTexture.value},set:function(R){this.uniforms.gradientTexture.value=R}},floor:{get:function(){return this.uniforms.floor.value},set:function(R){this.uniforms.floor.value=R}}}),x.pano0=(r=e.pano0)!==null&&r!==void 0?r:defaultPbmParameters.pano0,x.pano1=(i=e.pano1)!==null&&i!==void 0?i:defaultPbmParameters.pano1,x.modelAlpha=(o=e.modelAlpha)!==null&&o!==void 0?o:defaultPbmParameters.modelAlpha,x.progress=(s=e.progress)!==null&&s!==void 0?s:defaultPbmParameters.progress,x.useBlackTransition=(u=e.useBlackTransition)!==null&&u!==void 0?u:defaultPbmParameters.useBlackTransition,x.constantColor=(l=e.constantColor)!==null&&l!==void 0?l:defaultPbmParameters.constantColor,x.opacity=(d=e.opacity)!==null&&d!==void 0?d:defaultPbmParameters.opacity,x.shownFloorIndex=(c=e.shownFloorIndex)!==null&&c!==void 0?c:defaultPbmParameters.shownFloorIndex,x.clippers=(f=e.clippers)!==null&&f!==void 0?f:defaultPbmParameters.clippers,x.useEDL=(h=e.useEDL)!==null&&h!==void 0?h:defaultPbmParameters.useEDL,x.useHQWeight=(v=e.useHQWeight)!==null&&v!==void 0?v:defaultPbmParameters.useHQWeight,x.useHQDepth=(A=e.useHQDepth)!==null&&A!==void 0?A:defaultPbmParameters.useHQDepth,x.pointColor=(m=e.pointColor)!==null&&m!==void 0?m:defaultPbmParameters.pointColor,x.pointShape=(y=e.pointShape)!==null&&y!==void 0?y:defaultPbmParameters.pointShape,x.pointSize=(p=e.pointSize)!==null&&p!==void 0?p:defaultPbmParameters.pointSize,x.pointScale=(g=e.pointScale)!==null&&g!==void 0?g:defaultPbmParameters.pointScale,x.pointBack=(b=e.pointBack)!==null&&b!==void 0?b:defaultPbmParameters.pointBack,x.pointMinPixel=(T=e.pointMinPixel)!==null&&T!==void 0?T:defaultPbmParameters.pointMinPixel,x.pointMaxPixel=(_=e.pointMaxPixel)!==null&&_!==void 0?_:defaultPbmParameters.pointMaxPixel,x.gradientTexture=(w=e.gradientTexture)!==null&&w!==void 0?w:defaultPbmParameters.gradientTexture,x.floor=0,x.transparent=!1,x}return t.prototype.onBeforeCompile=function(e,r){var i,o,s=String((o=(i=this.clippers)===null||i===void 0?void 0:i.length)!==null&&o!==void 0?o:0);e.vertexShader=e.vertexShader.replace(/NUM_CLIPPERS/g,s),e.fragmentShader=e.fragmentShader.replace(/NUM_CLIPPERS/g,s)},t.prototype.update=function(e,r){var i=r instanceof Camera?r.pixelRatio:e.getPixelRatio(),o=r instanceof Camera?r.screenHeight:e.getViewport(scratchVector4).z;this.uniforms.pixelRatio.value=i,this.uniforms.screenHeight.value=o,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=THREE__namespace.CustomBlending,this.blendSrc=THREE__namespace.SrcAlphaFactor,this.blendSrcAlpha=THREE__namespace.SrcAlphaFactor,this.blendDst=THREE__namespace.OneFactor,this.blendDstAlpha=THREE__namespace.OneFactor):(this.depthWrite=!0,this.transparent=this.shownFloorIndex>-1||this.opacity<1||this.modelAlpha<1,this.blendDst=THREE__namespace.OneMinusSrcAlphaFactor,this.blendEquation=THREE__namespace.AddEquation,this.blendSrcAlpha=null,this.blendDstAlpha=null,this.blendEquationAlpha=null,this.blending=THREE__namespace.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}(THREE__namespace.ShaderMaterial),sharedMaterial$1=new PBMPointCloudMaterial;sharedMaterial$1.dispose=function(){};var sharedMaterialWithNormal=new PBMPointCloudMaterial;sharedMaterialWithNormal.defines.USE_POINT_NORMAL=!0,sharedMaterialWithNormal.dispose=function(){};var PBM_mesh=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.loadMesh=function(e,r){var i=this,o=r.json.meshes[e],s=o.primitives,u=Promise.all(s.map(function(c){return r.loadGeometry(c)})),l=Promise.all(s.map(function(c){return i.loadPBMMaterial(c,r)})),d=Promise.all([u,l]).then(function(c){for(var f=c[0],h=c[1],v=[],A=0;A<s.length;A++){var m=s[A],y=f[A],p=h[A];y.attributes.normal===void 0&&(p.flatShading=!0),y.attributes.tangent===void 0&&p.normalScale&&(p.normalScale.y*=-1);var g=m.mode||WEBGL_CONSTANTS.TRIANGLES,b=void 0;if(g===WEBGL_CONSTANTS.TRIANGLES||g===WEBGL_CONSTANTS.TRIANGLE_STRIP||g===WEBGL_CONSTANTS.TRIANGLE_FAN)g===WEBGL_CONSTANTS.TRIANGLE_STRIP?y=r.toGeometryTrianglesDrawMode(y,THREE__namespace.TriangleStripDrawMode):g===WEBGL_CONSTANTS.TRIANGLE_FAN&&(y=r.toGeometryTrianglesDrawMode(y,THREE__namespace.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 PBMMesh(y,[p]);else if(g===WEBGL_CONSTANTS.POINTS)b=new PBMPointCloud(y,p);else throw new Error("glTF: Primitive mode unsupported: "+g);b.name=r.createUniqueName(o.name||"mesh_"+e),v.push(b)}if(v.length===1)return v[0];for(var T=new THREE__namespace.Group,_=0,w=v;_<w.length;_++){var b=w[_];T.add(b)}return T});return d},t.prototype.loadPBMMaterial=function(e,r){var i=e.mode,o=null;if(i===WEBGL_CONSTANTS.TRIANGLES||i===WEBGL_CONSTANTS.TRIANGLE_STRIP||i===WEBGL_CONSTANTS.TRIANGLE_FAN)o=this.loadPBMMeshMaterial(e,r);else if(i===WEBGL_CONSTANTS.POINTS)o=this.loadPBMPointCloudMaterial(e,r);else throw new Error("glTF: Primitive mode unsupported: "+i);return o},t.prototype.loadPBMPointCloudMaterial=function(e,r){return Object.keys(e.attributes).filter(function(i){return ATTRIBUTES[i]==="normal"}).length>0?Promise.resolve(sharedMaterialWithNormal):Promise.resolve(sharedMaterial$1)},t.prototype.loadPBMMeshMaterial=function(e,r){var i=[],o=new PBMMeshMaterial;if(o.uniforms.diffuse.value=new THREE__namespace.Color(1,1,1),o.uniforms.exposure.value=3.3,o.defines.USE_MAP=!1,Object.keys(e.attributes).filter(function(c){return ATTRIBUTES[c]==="color"}).length>0&&(o.vertexColors=!0),Object.keys(e.attributes).filter(function(c){return ATTRIBUTES[c]==="tangent"}).length===0&&(o.normalScale&&(o.normalScale.y*=-1),o.clearcoatNormalScale&&(o.clearcoatNormalScale.y*=-1)),e.material!==void 0){var s=r.json.materials[e.material];s.name&&(o.name=s.name);var u=s.pbrMetallicRoughness||{};if(Array.isArray(u.baseColorFactor)){var l=u.baseColorFactor;o.uniforms.diffuse.value.fromArray(l)}if(u.baseColorTexture!==void 0&&i.push(r.createMaterialTexture(u.baseColorTexture).then(function(c){o.uniforms.map.value=c,o.defines.USE_MAP=!0})),s.doubleSided===!0&&(o.side=THREE__namespace.DoubleSide),s.normalTexture!==void 0&&(i.push(r.createMaterialTexture(s.normalTexture).then(function(c){o.uniforms.normalMap.value=c})),o.uniforms.normalScale.value=new THREE__namespace.Vector2(1,1),s.normalTexture.scale!==void 0)){var d=s.normalTexture.scale;o.uniforms.normalScale.value.set(d,d)}}return Promise.all(i).then(function(){return o})},t}(BaseExtension),EXTENSIONS={KHR_binary_glTF,KHR_draco_mesh_compression,KHR_texture_basisu,KHR_texture_transform,KHR_mesh_quantization,EXT_meshopt_compression,EXT_texture_webp,CESIUM_RTC,PBM_mesh};function parseGltf(n,t){var e,r,i,o={};if(t.addonExtensions)for(var s=0,u=t.addonExtensions;s<u.length;s++){var l=u[s];o[l]=new EXTENSIONS[l]}var d;if(typeof n=="string")d=n;else{var c=EXTENSIONS.KHR_binary_glTF.getMagic(n);if(c===EXTENSIONS.KHR_binary_glTF.HEADER_MAGIC){var f=new EXTENSIONS.KHR_binary_glTF;try{f.loadGlbBinary(n)}catch(p){return Promise.reject(p)}o.KHR_binary_glTF=f,d=f.content}else d=decodeText(new Uint8Array(n))}var h=JSON.parse(d);if(h.asset===void 0||Number(h.asset.version[0])<2)return Promise.reject(new Error("glTF: Unsupported asset. glTF versions >=2.0 are supported."));if(h.extensionsUsed)for(var v=h.extensionsRequired||[],A=0;A<h.extensionsUsed.length;A++){var m=h.extensionsUsed[A];o[m]||(EXTENSIONS[m]?o[m]=new EXTENSIONS[m]:v.indexOf(m)>=0&&console.warn('glTF: Unknown extension "'+m+'".'))}var y=new Parser(h,o,{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 ROTATE_X_MATRIX$1=new THREE__namespace.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]);function loadB3dm(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 parseHeader(e,r,i)}).then(function(i){return parseTable(e,r,i)}).then(function(i){return parseGlTFArrayBuffer(e,r,i)})}).then(function(){var r;return parseGltf(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 o=new THREE__namespace.Matrix4;t.upAxis!=="Z"&&o.premultiply(ROTATE_X_MATRIX$1);var s=new THREE__namespace.Matrix4().setPosition(e.rtcCenter);if(o.premultiply(s),i.CESIUM_RTC){var u=new THREE__namespace.Matrix4().setPosition(i.CESIUM_RTC.center);o.premultiply(u)}var l=i.scene;return l.applyMatrix4(o),{type:"b3dm",uri:e.uri,byteLength:e.byteLength,object:l,dispose:function(){return i.dispose()}}})})}function parsePointCloud(n,t,e){var r=new FeatureTable(n.featureTableJson,n.featureTableBinary);return Promise.resolve().then(function(){var i=r.getExtension("3DTILES_draco_point_compression");if(i)return parseDraco(i,r);var o=[parsePosition(r),parseColor(r),parseNormal(r)];return Promise.all(o).then(function(s){var u=s[0],l=s[1],d=s[2];return{position:u,color:l,normal:d}})}).then(function(i){return n.attributes=i,e})}function createAttribute(n,t,e){return{type:n,array:t,size:e}}var POSITION_QUANTIZED_RANGE=65535;function parsePosition(n){if(n.hasProperty("POSITION")){var t=n.getPropertyArray("POSITION",GL_TYPE.FLOAT,3);return createAttribute(GL_TYPE.FLOAT,t,3)}else if(n.hasProperty("POSITION_QUANTIZED")){var e=n.getPropertyArray("POSITION_QUANTIZED",GL_TYPE.UNSIGNED_SHORT,3),r=n.getGlobalProperty("QUANTIZED_VOLUME_SCALE",GL_TYPE.FLOAT,3),i=n.getGlobalProperty("QUANTIZED_VOLUME_OFFSET",GL_TYPE.FLOAT,3);if(!r||!i)throw new Error("QUANTIZED_VOLUME_SCALE or QUANTIZED_VOLUME_OFFSET never found.");for(var o=new Float32Array(e.length),s=e.length/3,u=r[0]/POSITION_QUANTIZED_RANGE,l=r[1]/POSITION_QUANTIZED_RANGE,d=r[2]/POSITION_QUANTIZED_RANGE,c=i[0],f=i[1],h=i[2],v=0,A=void 0;v<s;v++)A=v*3,o[A]=e[A]*u+c,o[++A]=e[A]*l+f,o[++A]=e[A]*d+h;return createAttribute(GL_TYPE.FLOAT,o,3)}return null}function parseColor(n){if(n.hasProperty("RGB")){var t=n.getPropertyArray("RGB",GL_TYPE.UNSIGNED_BYTE,3);return createAttribute(GL_TYPE.UNSIGNED_BYTE,t,3)}else if(n.hasProperty("RGBA")){for(var t=n.getPropertyArray("RGBA",GL_TYPE.UNSIGNED_BYTE,4),e=t.length,r=new Uint8Array(e*3),i=0,o=void 0,s=void 0;i<e;i++)o=i*3,s=i*4,r[o]=t[s],r[++o]=t[++s],r[++o]=t[++s];return createAttribute(GL_TYPE.UNSIGNED_BYTE,t,4)}else if(n.hasProperty("RGB565")){for(var t=n.getPropertyArray("RGB565",GL_TYPE.UNSIGNED_SHORT,1),e=t.length,r=new Uint8Array(e*3),i=0,u=void 0,l=void 0;i<e;i++)l=t[i],u=i*3,r[u]=(l>>11&31)<<3,r[++u]=(l>>5&63)<<2,r[++u]=(l&31)<<3;return createAttribute(GL_TYPE.UNSIGNED_BYTE,r,3)}return null}var NORMAL_OCT16P_RANGE_MAX=255,NORMAL_OCT16P_DELTA=2/NORMAL_OCT16P_RANGE_MAX;function parseNormal(n){if(n.hasProperty("NORMAL")){var t=n.getPropertyArray("NORMAL",GL_TYPE.FLOAT,3);return createAttribute(GL_TYPE.FLOAT,t,3)}else if(n.hasProperty("NORMAL_OCT16P")){for(var t=n.getPropertyArray("NORMAL_OCT16P",GL_TYPE.UNSIGNED_BYTE,2),e=t.length/2,r=new Float32Array(e*3),i=0,o=void 0,s=void 0,u=void 0,l=void 0,d=void 0,c=void 0,f=void 0;i<e;i++)o=i*2,s=t[o]*NORMAL_OCT16P_DELTA-1,u=t[++o]*NORMAL_OCT16P_DELTA-1,d=s<0?-s:s,c=u<0?-u:u,l=1-(d+c),l<0&&(s=(1-c)*(s<0?-1:1),u=(1-d)*(u<0?-1:1)),f=Math.sqrt(s*s+u*u+l*l),o=i*3,r[o]=s/f,r[++o]=u/f,r[++o]=l/f;return createAttribute(GL_TYPE.FLOAT,r,3)}return null}function parseDraco(n,t){return __awaiter(this,void 0,void 0,function(){var e,r,i,o,s,u;return __generator(this,function(l){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 o=t.buffer.slice(r,r+i),s=n.properties,u={POSITION:"Float32Array",NORMAL:"Float32Array",RGB:"Uint8Array"},[2,draco.decodeGeometry(o.buffer,{attributeIDs:s,attributeTypes:u,useUniqueIDs:!0}).then(function(d){var c=d.getAttribute("POSITION"),f=d.getAttribute("RGB"),h=d.getAttribute("NORMAL");return{position:c?createAttribute(GL_TYPE.FLOAT,c.array,c.itemSize):null,color:f?createAttribute(GL_TYPE.UNSIGNED_BYTE,f.array,f.itemSize):null,normal:h?createAttribute(GL_TYPE.FLOAT,h.array,h.itemSize):null}})]})})}function loadPnts(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 parseHeader(e,r,i)}).then(function(i){return parseTable(e,r,i)}).then(function(i){return parsePointCloud(e,r,i)})}).then(function(){var r;return createPoints(e.attributes,{computeBoundingBox:(r=t.computeBoundingBox)!==null&&r!==void 0?r:!0})}).then(function(r){var i=new THREE__namespace.Matrix4,o=new THREE__namespace.Matrix4().setPosition(e.rtcCenter);return i.premultiply(o),r.object.applyMatrix4(i),{type:"pnts",uri:e.uri,byteLength:e.byteLength,object:r.object,dispose:function(){return r.dispose()}}})}function createPoints(n,t){var e=new Set,r=new THREE__namespace.BufferGeometry;e.add(r);var i=new PBMPointCloudMaterial;e.add(i),n.position&&r.setAttribute("position",new THREE__namespace.BufferAttribute(n.position.array,n.position.size,!1)),n.color&&r.setAttribute("color",new THREE__namespace.BufferAttribute(n.color.array,n.color.size,!0)),n.normal&&(r.setAttribute("normal",new THREE__namespace.BufferAttribute(n.normal.array,n.normal.size,!1)),i.defines.USE_POINT_NORMAL=!0),t.computeBoundingBox&&r.computeBoundingBox();var o=new PBMPointCloud(r,i);return o.matrix.compose(o.position,o.quaternion,o.scale),o.matrixAutoUpdate=!1,o.frustumCulled=!1,o.renderOrder=-1e3,Promise.resolve({object:o,dispose:function(){e.forEach(function(s){s.dispose()}),e.clear()}})}function createLZMA(){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,o;i<this._numBitLevels;++i)o=t.decodeBit(this._models,e),e=e<<1|o,r|=o<<i;return r},n.reverseDecode2=function(t,e,r,i){for(var o=1,s=0,u=0,l;u<i;++u)l=r.decodeBit(t,e+o),o=o<<1|l,s|=l<<u;return s},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,o;do if(i=e>>7&1,e<<=1,o=t.decodeBit(this._decoders,(1+i<<8)+r),r=r<<1|o,i!==o){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,o=0,s=0,u=0,l=0,d=0,c=0,f,h,v,A,m,y;for(this._rangeDecoder.setStream(t),this._outWindow.setStream(e),this.init();r<0||d<r;)if(f=d&this._posStateMask,this._rangeDecoder.decodeBit(this._isMatchDecoders,(i<<4)+f)===0)h=this._literalDecoder.getDecoder(d++,c),i>=7?c=h.decodeWithMatchByte(this._rangeDecoder,this._outWindow.getByte(o)):c=h.decodeNormal(this._rangeDecoder),this._outWindow.putByte(c),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)+f)===0&&(i=i<7?9:11,v=1):(this._rangeDecoder.decodeBit(this._isRepG1Decoders,i)===0?A=s:(this._rangeDecoder.decodeBit(this._isRepG2Decoders,i)===0?A=u:(A=l,l=u),u=s),s=o,o=A),v===0&&(v=2+this._repLenDecoder.decode(this._rangeDecoder,f),i=i<7?8:11);else if(l=u,u=s,s=o,v=2+this._lenDecoder.decode(this._rangeDecoder,f),i=i<7?7:10,m=this._posSlotDecoder[v<=5?v-2:3].decode(this._rangeDecoder),m>=4){if(y=(m>>1)-1,o=(2|m&1)<<y,m<14)o+=n.reverseDecode2(this._posDecoders,o-m-1,this._rangeDecoder,y);else if(o+=this._rangeDecoder.decodeDirectBits(y-4)<<4,o+=this._posAlignDecoder.reverseDecode(this._rangeDecoder),o<0){if(o===-1)break;return!1}}else o=m;if(o>=d||o>=this._dictionarySizeCheck)return!1;this._outWindow.copyBlock(o,v),d+=v,c=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,o,s;return t.size<5||(e=t.readByte(),r=e%9,e=~~(e/9),i=e%5,o=~~(e/5),!this.setLcLpPb(r,i,o))?!1:(s=t.readByte(),s|=t.readByte()<<8,s|=t.readByte()<<16,s+=t.readByte()*16777216,this.setDictionarySize(s))},n.decompress=function(t,e,r,i){var o=new n.Decoder;if(!o.setDecoderProperties(t))throw"Incorrect stream properties";if(!o.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 LZMA=createLZMA();function createWASM(){function n(e){for(var r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",i=new Uint8Array(256),o=0;o<r.length;o++)i[r.charCodeAt(o)]=o;var s=e.length*.75,u=e.length,l,d=0,c,f,h,v;e[e.length-1]==="="&&(s--,e[e.length-2]==="="&&s--);var A=new ArrayBuffer(s),m=new Uint8Array(A);for(l=0;l<u;l+=4)c=i[e.charCodeAt(l)],f=i[e.charCodeAt(l+1)],h=i[e.charCodeAt(l+2)],v=i[e.charCodeAt(l+3)],m[d++]=c<<2|f>>4,m[d++]=(f&15)<<4|h>>2,m[d++]=(h&3)<<6|v&63;return A}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 decodeLZMA(n,t,e){try{var r={data:t,offset:0,readByte:function(){return this.data[this.offset++]}},i=r.data.length,o={data:[],offset:0,writeByte:function(l){var d=Math.floor(this.offset/i);this.data[d]||(this.data[d]=new Uint8Array(i)),this.data[d][this.offset%i]=l,this.offset++}};n.decompressFile(r,o);for(var s=new Uint8Array(o.offset),u=0;u<o.offset;u++)s[u]=o.data[Math.floor(u/i)][u%i];e(null,s)}catch(l){e(l)}}function decodeLZMAWithWASM(n,t,e){var r=24;try{var i=new WebAssembly.Memory({initial:16}),o=new WebAssembly.Module(n),s=new WebAssembly.Instance(o,{env:{memory:i,abort:function(){e(new Error("webAssembly abort"))}}}),u=s.exports,l=u.newU8Array(t.length),d=new Uint8Array(i.buffer,l+r,t.length);d.set(t);var c=u.decode(l),f=new Uint32Array(i.buffer,c,4),h=f[0],v=f[2],A=f[3];h?e(null,new Uint8Array(i.buffer,A+r,v).slice(0,v)):e(new Error("lzma deocder error"))}catch(m){e(m)}}var lzmaWorkerSource=`
|
|
883
|
+
`,EXTENSION_NAME$4="KHR_texture_basisu",KHR_texture_basisu=function(n){__extends(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[EXTENSION_NAME$4])return null;var o=i.extensions[EXTENSION_NAME$4],s=r.json.images[o.source],u=null;if(s.bufferView)u=r.loadBufferView(s.bufferView).then(function(l){return ktx2.parse(l)});else if(s.uri)u=r.options.fetcher.ajax(r.resolveResouce(s.uri),{responseType:"arraybuffer"}).then(function(l){return ktx2.parse(l.body)});else throw new Error("glTF: Invalid image defs.");return u},t}(BaseExtension),EXTENSION_NAME$3="KHR_texture_transform",KHR_texture_transform=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.extendTexture=function(e,r,i){var o=r.extensions!==void 0?r.extensions[EXTENSION_NAME$3]:void 0;return o?(o.texCoord!==void 0&&console.warn('glTF: Custom UV sets in "'+EXTENSION_NAME$3+'" extension not yet supported.'),o.offset===void 0&&o.rotation===void 0&&o.scale===void 0||(e=e.clone(),e.needsUpdate=!0,o.offset!==void 0&&e.offset.fromArray(o.offset),o.rotation!==void 0&&(e.rotation=o.rotation),o.scale!==void 0&&e.repeat.fromArray(o.scale)),e):null},t}(BaseExtension),KHR_mesh_quantization=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t}(BaseExtension),meshoptDecoder=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,o,s=WebAssembly.instantiate(u(i),{}).then(function(p){o=p.instance,o.exports.__wasm_call_ctors()});function u(p){for(var g=new Uint8Array(p.length),b=0;b<p.length;++b){var T=p.charCodeAt(b);g[b]=T>96?T-97:T>64?T-39:T+4}for(var _=0,b=0;b<p.length;++b)g[_++]=g[b]<60?r[g[b]]:(g[b]-60)*64+g[++b];return g.buffer.slice(0,_)}function l(p,g,b,T,_,w){var x=o.exports.sbrk,M=b+3&-4,R=x(M*T),I=x(_.length),S=new Uint8Array(o.exports.memory.buffer);S.set(_,I);var B=p(R,b,T,I,_.length);if(B==0&&w&&w(R,M,T),g.set(S.subarray(R,R+b*T)),x(R-x(0)),B!=0)throw new Error("Malformed buffer data: "+B)}var d={NONE:"",OCTAHEDRAL:"meshopt_decodeFilterOct",QUATERNION:"meshopt_decodeFilterQuat",EXPONENTIAL:"meshopt_decodeFilterExp"},c={ATTRIBUTES:"meshopt_decodeVertexBuffer",TRIANGLES:"meshopt_decodeIndexBuffer",INDICES:"meshopt_decodeIndexSequence"},f=[],h=0;function v(p){var g={object:new Worker(p),pending:0,requests:{}};return g.object.onmessage=function(b){var T=b.data;g.pending-=T.count,g.requests[T.id][T.action](T.value),delete g.requests[T.id]},g}function A(p){for(var g="var instance; var ready = WebAssembly.instantiate(new Uint8Array(["+new Uint8Array(u(i))+"]), {}).then(function(result) { instance = result.instance; instance.exports.__wasm_call_ctors(); });self.onmessage = workerProcess;"+l.toString()+y.toString(),b=new Blob([g],{type:"text/javascript"}),T=URL.createObjectURL(b),_=0;_<p;++_)f[_]=v(T);URL.revokeObjectURL(T)}function m(p,g,b,T,_){for(var w=f[0],x=1;x<f.length;++x)f[x].pending<w.pending&&(w=f[x]);return new Promise(function(M,R){var I=new Uint8Array(b),S=h++;w.pending+=p,w.requests[S]={resolve:M,reject:R},w.object.postMessage({id:S,count:p,size:g,source:I,mode:T,filter:_},[I.buffer])})}function y(p){s.then(function(){var g=p.data;try{var b=new Uint8Array(g.count*g.size);l(o.exports[g.mode],b,g.count,g.size,g.source,o.exports[g.filter]),self.postMessage({id:g.id,count:g.count,action:"resolve",value:b},[b.buffer])}catch(T){self.postMessage({id:g.id,count:g.count,action:"reject",value:T})}})}return{ready:s,supported:!0,useWorkers:function(p){A(p)},decodeVertexBuffer:function(p,g,b,T,_){l(o.exports.meshopt_decodeVertexBuffer,p,g,b,T,o.exports[d[_]])},decodeIndexBuffer:function(p,g,b,T){l(o.exports.meshopt_decodeIndexBuffer,p,g,b,T)},decodeIndexSequence:function(p,g,b,T){l(o.exports.meshopt_decodeIndexSequence,p,g,b,T)},decodeGltfBuffer:function(p,g,b,T,_,w){l(o.exports[c[_]],p,g,b,T,o.exports[d[w]])},decodeGltfBufferAsync:function(p,g,b,T,_){return f.length>0?m(p,g,b,c[T],d[_]):s.then(function(){var w=new Uint8Array(p*g);return l(o.exports[c[T]],w,p,g,b,o.exports[d[_]]),w})}}}(),EXTENSION_NAME$2="EXT_meshopt_compression",EXT_meshopt_compression=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.loadBufferView=function(e,r){var i=r.json,o=i.bufferViews[e];if(o.extensions&&o.extensions[EXTENSION_NAME$2]){var s=o.extensions[EXTENSION_NAME$2],u=r.loadBuffer(s.buffer);if(!meshoptDecoder.supported){if(i.extensionsRequired&&i.extensionsRequired.indexOf(EXTENSION_NAME$2)>=0)throw new Error("THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files");return null}return Promise.all([u,meshoptDecoder.ready]).then(function(l){var d=l[0],c=s.byteOffset||0,f=s.byteLength||0,h=s.count,v=s.byteStride,A=new ArrayBuffer(h*v),m=new Uint8Array(d,c,f);return meshoptDecoder.decodeGltfBuffer(new Uint8Array(A),h,v,m,s.mode,s.filter),A})}else return null},t}(BaseExtension),EXTENSION_NAME$1="EXT_texture_webp",EXT_texture_webp=function(n){__extends(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 imageSupport().then(function(i){r.supportsWep=i.webp})},t.prototype.loadTexture=function(e,r){var i=r.json,o=i.textures[e];if(!o.extensions||!o.extensions[EXTENSION_NAME$1]||!this.supportsWep)return null;var s=o.extensions[EXTENSION_NAME$1];return r.loadImage(s.source).then(function(u){var l=new THREE__namespace.Texture(u);l.needsUpdate=!0,l.flipY=!1,o.name&&(l.name=o.name);var d=r.json.samplers||{},c=d[o.sampler]||{};return l.magFilter=WEBGL_FILTERS[c.magFilter]||THREE__namespace.LinearFilter,l.minFilter=WEBGL_FILTERS[c.minFilter]||THREE__namespace.LinearMipmapLinearFilter,l.wrapS=WEBGL_WRAPPINGS[c.wrapS]||THREE__namespace.RepeatWrapping,l.wrapT=WEBGL_WRAPPINGS[c.wrapT]||THREE__namespace.RepeatWrapping,l})},t}(BaseExtension),EXTENSION_NAME="CESIUM_RTC",CESIUM_RTC=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.emitResult=function(e,r){if(r.json.extensions[EXTENSION_NAME]&&r.json.extensions[EXTENSION_NAME].center){var i=r.json.extensions[EXTENSION_NAME].center;e.CESIUM_RTC={center:new THREE__namespace.Vector3().fromArray(i)}}},t}(BaseExtension);const pointcloudFragmentShader=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}("{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"),pointcloudVertexShader=function(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}("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 scratchVector4=new THREE__namespace.Vector4,shaderUniforms$1=Object.assign({pointScale:new THREE__namespace.Uniform(1),pointMinPixel:new THREE__namespace.Uniform(1),pointMaxPixel:new THREE__namespace.Uniform(1),opacity:new THREE__namespace.Uniform(1),gradientTexture:new THREE__namespace.Uniform(null),modelAlpha:new THREE__namespace.Uniform(0),clippers:new THREE__namespace.Uniform([]),shownFloorIndex:new THREE__namespace.Uniform(-1),constantColor:new THREE__namespace.Uniform(null),geometricError:new THREE__namespace.Uniform(0),pixelRatio:new THREE__namespace.Uniform(1),screenHeight:new THREE__namespace.Uniform(512),floor:new THREE__namespace.Uniform(0)},THREE__namespace.UniformsUtils.clone(THREE__namespace.UniformsLib.common)),PBMPointCloudMaterial=function(n){__extends(t,n);function t(e){e===void 0&&(e={});var r,i,o,s,u,l,d,c,f,h,v,A,m,y,p,g,b,T,_,w,x=n.call(this,{vertexShader:pointcloudVertexShader,fragmentShader:pointcloudFragmentShader,uniforms:THREE__namespace.UniformsUtils.clone(shaderUniforms$1),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,M;return Object.defineProperties(x,{constantColor:{get:function(){return this.uniforms.constantColor.value},set:function(R){this.uniforms.constantColor.value=R;var I=this.defines.USE_CONSTANT_COLOR,S=R!==null;I!==S&&(this.defines.USE_CONSTANT_COLOR=S,this.needsUpdate=!0)}},opacity:{get:function(){return this.uniforms.opacity.value},set:function(R){this.uniforms.opacity.value=R}},modelAlpha:{get:function(){return this.uniforms.modelAlpha.value},set:function(R){this.uniforms.modelAlpha.value=R}},shownFloorIndex:{get:function(){return this.uniforms.shownFloorIndex.value},set:function(R){this.uniforms.shownFloorIndex.value=R}},clippers:{get:function(){return M},set:function(R){M!==R&&(M=R,this.uniforms.clippers.value=(M||[]).map(function(I){var S=typeof I.floorIndex=="number"?I.floorIndex:-1,B=new THREE__namespace.Matrix4().getInverse(I.clippingBoxMatrix);return{matrixInverse:B,floorIndex:S}}),this.needsUpdate=!0)}},pointColor:{get:function(){return this.defines.USE_POINT_COLOR_ALTITUDE===!0?"ALTITUDE":"RGB"},set:function(R){var I=R==="ALTITUDE";this.defines.USE_POINT_COLOR_ALTITUDE!==I&&(this.defines.USE_POINT_COLOR_ALTITUDE=I,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(R){var I=R==="ATTENUATION",S=R==="GEOMETRIC";this.defines.USE_POINT_SIZE_GEOMETRIC!==S&&(this.defines.USE_POINT_SIZE_GEOMETRIC=S,this.needsUpdate=!0),this.defines.USE_POINT_SIZE_ATTENUATION!==I&&(this.defines.USE_POINT_SIZE_ATTENUATION=I,this.needsUpdate=!0)}},pointShape:{get:function(){return this.defines.USE_POINT_SHAPE_CIRCLE===!0?"CIRCLE":"SQUARE"},set:function(R){var I=R==="CIRCLE";this.defines.USE_POINT_SHAPE_CIRCLE!==I&&(this.defines.USE_POINT_SHAPE_CIRCLE=I,this.needsUpdate=!0)}},pointScale:{get:function(){return this.uniforms.pointScale.value},set:function(R){this.uniforms.pointScale.value=R}},pointBack:{get:function(){return this.defines.USE_POINT_BACK_HIDDEN===!0?"HIDDEN":this.defines.USE_POINT_BACK_DARK===!0?"DARK":"VISIBLE"},set:function(R){var I=R==="HIDDEN",S=R==="DARK";this.defines.USE_POINT_BACK_HIDDEN!==I&&(this.defines.USE_POINT_BACK_HIDDEN=I,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(R){this.uniforms.pointMinPixel.value=R}},pointMaxPixel:{get:function(){return this.uniforms.pointMaxPixel.value},set:function(R){this.uniforms.pointMaxPixel.value=R}},useEDL:{get:function(){return this.defines.USE_EDL},set:function(R){R!==this.defines.USE_EDL&&(this.defines.USE_EDL=R,this.needsUpdate=!0)}},useHQWeight:{get:function(){return this.defines.USE_HQ_WEIGHT},set:function(R){R!==this.defines.USE_HQ_WEIGHT&&(this.defines.USE_HQ_WEIGHT=R,this.needsUpdate=!0)}},useHQDepth:{get:function(){return this.defines.USE_HQ_DEPTH},set:function(R){R!==this.defines.USE_HQ_DEPTH&&(this.defines.USE_HQ_DEPTH=R,this.needsUpdate=!0)}},gradientTexture:{get:function(){return this.uniforms.gradientTexture.value},set:function(R){this.uniforms.gradientTexture.value=R}},floor:{get:function(){return this.uniforms.floor.value},set:function(R){this.uniforms.floor.value=R}}}),x.pano0=(r=e.pano0)!==null&&r!==void 0?r:defaultPbmParameters.pano0,x.pano1=(i=e.pano1)!==null&&i!==void 0?i:defaultPbmParameters.pano1,x.modelAlpha=(o=e.modelAlpha)!==null&&o!==void 0?o:defaultPbmParameters.modelAlpha,x.progress=(s=e.progress)!==null&&s!==void 0?s:defaultPbmParameters.progress,x.useBlackTransition=(u=e.useBlackTransition)!==null&&u!==void 0?u:defaultPbmParameters.useBlackTransition,x.constantColor=(l=e.constantColor)!==null&&l!==void 0?l:defaultPbmParameters.constantColor,x.opacity=(d=e.opacity)!==null&&d!==void 0?d:defaultPbmParameters.opacity,x.shownFloorIndex=(c=e.shownFloorIndex)!==null&&c!==void 0?c:defaultPbmParameters.shownFloorIndex,x.clippers=(f=e.clippers)!==null&&f!==void 0?f:defaultPbmParameters.clippers,x.useEDL=(h=e.useEDL)!==null&&h!==void 0?h:defaultPbmParameters.useEDL,x.useHQWeight=(v=e.useHQWeight)!==null&&v!==void 0?v:defaultPbmParameters.useHQWeight,x.useHQDepth=(A=e.useHQDepth)!==null&&A!==void 0?A:defaultPbmParameters.useHQDepth,x.pointColor=(m=e.pointColor)!==null&&m!==void 0?m:defaultPbmParameters.pointColor,x.pointShape=(y=e.pointShape)!==null&&y!==void 0?y:defaultPbmParameters.pointShape,x.pointSize=(p=e.pointSize)!==null&&p!==void 0?p:defaultPbmParameters.pointSize,x.pointScale=(g=e.pointScale)!==null&&g!==void 0?g:defaultPbmParameters.pointScale,x.pointBack=(b=e.pointBack)!==null&&b!==void 0?b:defaultPbmParameters.pointBack,x.pointMinPixel=(T=e.pointMinPixel)!==null&&T!==void 0?T:defaultPbmParameters.pointMinPixel,x.pointMaxPixel=(_=e.pointMaxPixel)!==null&&_!==void 0?_:defaultPbmParameters.pointMaxPixel,x.gradientTexture=(w=e.gradientTexture)!==null&&w!==void 0?w:defaultPbmParameters.gradientTexture,x.floor=0,x.transparent=!1,x}return t.prototype.onBeforeCompile=function(e,r){var i,o,s=String((o=(i=this.clippers)===null||i===void 0?void 0:i.length)!==null&&o!==void 0?o:0);e.vertexShader=e.vertexShader.replace(/NUM_CLIPPERS/g,s),e.fragmentShader=e.fragmentShader.replace(/NUM_CLIPPERS/g,s)},t.prototype.update=function(e,r){var i=r instanceof Camera?r.pixelRatio:e.getPixelRatio(),o=r instanceof Camera?r.screenHeight:e.getViewport(scratchVector4).z;this.uniforms.pixelRatio.value=i,this.uniforms.screenHeight.value=o,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=THREE__namespace.CustomBlending,this.blendSrc=THREE__namespace.SrcAlphaFactor,this.blendSrcAlpha=THREE__namespace.SrcAlphaFactor,this.blendDst=THREE__namespace.OneFactor,this.blendDstAlpha=THREE__namespace.OneFactor):(this.depthWrite=!0,this.transparent=this.shownFloorIndex>-1||this.opacity<1||this.modelAlpha<1,this.blendDst=THREE__namespace.OneMinusSrcAlphaFactor,this.blendEquation=THREE__namespace.AddEquation,this.blendSrcAlpha=null,this.blendDstAlpha=null,this.blendEquationAlpha=null,this.blending=THREE__namespace.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}(THREE__namespace.ShaderMaterial),PBM_mesh=function(n){__extends(t,n);function t(){return n!==null&&n.apply(this,arguments)||this}return t.prototype.loadMesh=function(e,r){var i=this,o=r.json.meshes[e],s=o.primitives,u=Promise.all(s.map(function(c){return r.loadGeometry(c)})),l=Promise.all(s.map(function(c){return i.loadPBMMaterial(c,r)})),d=Promise.all([u,l]).then(function(c){for(var f=c[0],h=c[1],v=[],A=0;A<s.length;A++){var m=s[A],y=f[A],p=h[A];y.attributes.normal===void 0&&(p.flatShading=!0),y.attributes.tangent===void 0&&p.normalScale&&(p.normalScale.y*=-1);var g=m.mode||WEBGL_CONSTANTS.TRIANGLES,b=void 0;if(g===WEBGL_CONSTANTS.TRIANGLES||g===WEBGL_CONSTANTS.TRIANGLE_STRIP||g===WEBGL_CONSTANTS.TRIANGLE_FAN)g===WEBGL_CONSTANTS.TRIANGLE_STRIP?y=r.toGeometryTrianglesDrawMode(y,THREE__namespace.TriangleStripDrawMode):g===WEBGL_CONSTANTS.TRIANGLE_FAN&&(y=r.toGeometryTrianglesDrawMode(y,THREE__namespace.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 PBMMesh(y,[p]);else if(g===WEBGL_CONSTANTS.POINTS)b=new PBMPointCloud(y,p);else throw new Error("glTF: Primitive mode unsupported: "+g);b.name=r.createUniqueName(o.name||"mesh_"+e),v.push(b)}if(v.length===1)return v[0];for(var T=new THREE__namespace.Group,_=0,w=v;_<w.length;_++){var b=w[_];T.add(b)}return T});return d},t.prototype.loadPBMMaterial=function(e,r){var i=e.mode,o=null;if(i===WEBGL_CONSTANTS.TRIANGLES||i===WEBGL_CONSTANTS.TRIANGLE_STRIP||i===WEBGL_CONSTANTS.TRIANGLE_FAN)o=this.loadPBMMeshMaterial(e,r);else if(i===WEBGL_CONSTANTS.POINTS)o=this.loadPBMPointCloudMaterial(e,r);else throw new Error("glTF: Primitive mode unsupported: "+i);return o},t.prototype.extendTexture=function(e,r,i){return e.minFilter=THREE__namespace.LinearFilter,e.magFilter=THREE__namespace.LinearFilter,e.generateMipmaps=!1,e},t.prototype.loadPBMPointCloudMaterial=function(e,r){var i=new PBMPointCloudMaterial;return Object.keys(e.attributes).filter(function(o){return ATTRIBUTES[o]==="normal"}).length>0&&(i.defines.USE_POINT_NORMAL=!0),Promise.resolve(i)},t.prototype.loadPBMMeshMaterial=function(e,r){var i=[],o=new PBMMeshMaterial;if(o.uniforms.diffuse.value=new THREE__namespace.Color(1,1,1),o.uniforms.exposure.value=3.3,o.defines.USE_MAP=!1,Object.keys(e.attributes).filter(function(c){return ATTRIBUTES[c]==="color"}).length>0&&(o.vertexColors=!0),Object.keys(e.attributes).filter(function(c){return ATTRIBUTES[c]==="tangent"}).length===0&&(o.normalScale&&(o.normalScale.y*=-1),o.clearcoatNormalScale&&(o.clearcoatNormalScale.y*=-1)),e.material!==void 0){var s=r.json.materials[e.material];s.name&&(o.name=s.name);var u=s.pbrMetallicRoughness||{};if(Array.isArray(u.baseColorFactor)){var l=u.baseColorFactor;o.uniforms.diffuse.value.fromArray(l)}if(u.baseColorTexture!==void 0&&i.push(r.createMaterialTexture(u.baseColorTexture).then(function(c){o.uniforms.map.value=c,o.defines.USE_MAP=!0})),s.doubleSided===!0&&(o.side=THREE__namespace.DoubleSide),s.normalTexture!==void 0&&(i.push(r.createMaterialTexture(s.normalTexture).then(function(c){o.uniforms.normalMap.value=c})),o.uniforms.normalScale.value=new THREE__namespace.Vector2(1,1),s.normalTexture.scale!==void 0)){var d=s.normalTexture.scale;o.uniforms.normalScale.value.set(d,d)}}return Promise.all(i).then(function(){return o})},t}(BaseExtension),EXTENSIONS={KHR_binary_glTF,KHR_draco_mesh_compression,KHR_texture_basisu,KHR_texture_transform,KHR_mesh_quantization,EXT_meshopt_compression,EXT_texture_webp,CESIUM_RTC,PBM_mesh};function parseGltf(n,t){var e,r,i,o={};if(t.addonExtensions)for(var s=0,u=t.addonExtensions;s<u.length;s++){var l=u[s];o[l]=new EXTENSIONS[l]}var d;if(typeof n=="string")d=n;else{var c=EXTENSIONS.KHR_binary_glTF.getMagic(n);if(c===EXTENSIONS.KHR_binary_glTF.HEADER_MAGIC){var f=new EXTENSIONS.KHR_binary_glTF;try{f.loadGlbBinary(n)}catch(p){return Promise.reject(p)}o.KHR_binary_glTF=f,d=f.content}else d=decodeText(new Uint8Array(n))}var h=JSON.parse(d);if(h.asset===void 0||Number(h.asset.version[0])<2)return Promise.reject(new Error("glTF: Unsupported asset. glTF versions >=2.0 are supported."));if(h.extensionsUsed)for(var v=h.extensionsRequired||[],A=0;A<h.extensionsUsed.length;A++){var m=h.extensionsUsed[A];o[m]||(EXTENSIONS[m]?o[m]=new EXTENSIONS[m]:v.indexOf(m)>=0&&console.warn('glTF: Unknown extension "'+m+'".'))}var y=new Parser(h,o,{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 ROTATE_X_MATRIX$1=new THREE__namespace.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]);function loadB3dm(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 parseHeader(e,r,i)}).then(function(i){return parseTable(e,r,i)}).then(function(i){return parseGlTFArrayBuffer(e,r,i)})}).then(function(){var r;return parseGltf(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 o=new THREE__namespace.Matrix4;t.upAxis!=="Z"&&o.premultiply(ROTATE_X_MATRIX$1);var s=new THREE__namespace.Matrix4().setPosition(e.rtcCenter);if(o.premultiply(s),i.CESIUM_RTC){var u=new THREE__namespace.Matrix4().setPosition(i.CESIUM_RTC.center);o.premultiply(u)}var l=i.scene;return l.applyMatrix4(o),{type:"b3dm",uri:e.uri,byteLength:e.byteLength,object:l,dispose:function(){return i.dispose()}}})})}function parsePointCloud(n,t,e){var r=new FeatureTable(n.featureTableJson,n.featureTableBinary);return Promise.resolve().then(function(){var i=r.getExtension("3DTILES_draco_point_compression");if(i)return parseDraco(i,r);var o=[parsePosition(r),parseColor(r),parseNormal(r)];return Promise.all(o).then(function(s){var u=s[0],l=s[1],d=s[2];return{position:u,color:l,normal:d}})}).then(function(i){return n.attributes=i,e})}function createAttribute(n,t,e){return{type:n,array:t,size:e}}var POSITION_QUANTIZED_RANGE=65535;function parsePosition(n){if(n.hasProperty("POSITION")){var t=n.getPropertyArray("POSITION",GL_TYPE.FLOAT,3);return createAttribute(GL_TYPE.FLOAT,t,3)}else if(n.hasProperty("POSITION_QUANTIZED")){var e=n.getPropertyArray("POSITION_QUANTIZED",GL_TYPE.UNSIGNED_SHORT,3),r=n.getGlobalProperty("QUANTIZED_VOLUME_SCALE",GL_TYPE.FLOAT,3),i=n.getGlobalProperty("QUANTIZED_VOLUME_OFFSET",GL_TYPE.FLOAT,3);if(!r||!i)throw new Error("QUANTIZED_VOLUME_SCALE or QUANTIZED_VOLUME_OFFSET never found.");for(var o=new Float32Array(e.length),s=e.length/3,u=r[0]/POSITION_QUANTIZED_RANGE,l=r[1]/POSITION_QUANTIZED_RANGE,d=r[2]/POSITION_QUANTIZED_RANGE,c=i[0],f=i[1],h=i[2],v=0,A=void 0;v<s;v++)A=v*3,o[A]=e[A]*u+c,o[++A]=e[A]*l+f,o[++A]=e[A]*d+h;return createAttribute(GL_TYPE.FLOAT,o,3)}return null}function parseColor(n){if(n.hasProperty("RGB")){var t=n.getPropertyArray("RGB",GL_TYPE.UNSIGNED_BYTE,3);return createAttribute(GL_TYPE.UNSIGNED_BYTE,t,3)}else if(n.hasProperty("RGBA")){for(var t=n.getPropertyArray("RGBA",GL_TYPE.UNSIGNED_BYTE,4),e=t.length,r=new Uint8Array(e*3),i=0,o=void 0,s=void 0;i<e;i++)o=i*3,s=i*4,r[o]=t[s],r[++o]=t[++s],r[++o]=t[++s];return createAttribute(GL_TYPE.UNSIGNED_BYTE,t,4)}else if(n.hasProperty("RGB565")){for(var t=n.getPropertyArray("RGB565",GL_TYPE.UNSIGNED_SHORT,1),e=t.length,r=new Uint8Array(e*3),i=0,u=void 0,l=void 0;i<e;i++)l=t[i],u=i*3,r[u]=(l>>11&31)<<3,r[++u]=(l>>5&63)<<2,r[++u]=(l&31)<<3;return createAttribute(GL_TYPE.UNSIGNED_BYTE,r,3)}return null}var NORMAL_OCT16P_RANGE_MAX=255,NORMAL_OCT16P_DELTA=2/NORMAL_OCT16P_RANGE_MAX;function parseNormal(n){if(n.hasProperty("NORMAL")){var t=n.getPropertyArray("NORMAL",GL_TYPE.FLOAT,3);return createAttribute(GL_TYPE.FLOAT,t,3)}else if(n.hasProperty("NORMAL_OCT16P")){for(var t=n.getPropertyArray("NORMAL_OCT16P",GL_TYPE.UNSIGNED_BYTE,2),e=t.length/2,r=new Float32Array(e*3),i=0,o=void 0,s=void 0,u=void 0,l=void 0,d=void 0,c=void 0,f=void 0;i<e;i++)o=i*2,s=t[o]*NORMAL_OCT16P_DELTA-1,u=t[++o]*NORMAL_OCT16P_DELTA-1,d=s<0?-s:s,c=u<0?-u:u,l=1-(d+c),l<0&&(s=(1-c)*(s<0?-1:1),u=(1-d)*(u<0?-1:1)),f=Math.sqrt(s*s+u*u+l*l),o=i*3,r[o]=s/f,r[++o]=u/f,r[++o]=l/f;return createAttribute(GL_TYPE.FLOAT,r,3)}return null}function parseDraco(n,t){return __awaiter(this,void 0,void 0,function(){var e,r,i,o,s,u;return __generator(this,function(l){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 o=t.buffer.slice(r,r+i),s=n.properties,u={POSITION:"Float32Array",NORMAL:"Float32Array",RGB:"Uint8Array"},[2,draco.decodeGeometry(o.buffer,{attributeIDs:s,attributeTypes:u,useUniqueIDs:!0}).then(function(d){var c=d.getAttribute("POSITION"),f=d.getAttribute("RGB"),h=d.getAttribute("NORMAL");return{position:c?createAttribute(GL_TYPE.FLOAT,c.array,c.itemSize):null,color:f?createAttribute(GL_TYPE.UNSIGNED_BYTE,f.array,f.itemSize):null,normal:h?createAttribute(GL_TYPE.FLOAT,h.array,h.itemSize):null}})]})})}function loadPnts(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 parseHeader(e,r,i)}).then(function(i){return parseTable(e,r,i)}).then(function(i){return parsePointCloud(e,r,i)})}).then(function(){var r;return createPoints(e.attributes,{computeBoundingBox:(r=t.computeBoundingBox)!==null&&r!==void 0?r:!0})}).then(function(r){var i=new THREE__namespace.Matrix4,o=new THREE__namespace.Matrix4().setPosition(e.rtcCenter);return i.premultiply(o),r.object.applyMatrix4(i),{type:"pnts",uri:e.uri,byteLength:e.byteLength,object:r.object,dispose:function(){return r.dispose()}}})}function createPoints(n,t){var e=new Set,r=new THREE__namespace.BufferGeometry;e.add(r);var i=new PBMPointCloudMaterial;e.add(i),n.position&&r.setAttribute("position",new THREE__namespace.BufferAttribute(n.position.array,n.position.size,!1)),n.color&&r.setAttribute("color",new THREE__namespace.BufferAttribute(n.color.array,n.color.size,!0)),n.normal&&(r.setAttribute("normal",new THREE__namespace.BufferAttribute(n.normal.array,n.normal.size,!1)),i.defines.USE_POINT_NORMAL=!0),t.computeBoundingBox&&r.computeBoundingBox();var o=new PBMPointCloud(r,i);return o.matrix.compose(o.position,o.quaternion,o.scale),o.matrixAutoUpdate=!1,o.frustumCulled=!1,o.renderOrder=-1e3,Promise.resolve({object:o,dispose:function(){e.forEach(function(s){s.dispose()}),e.clear()}})}function createLZMA(){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,o;i<this._numBitLevels;++i)o=t.decodeBit(this._models,e),e=e<<1|o,r|=o<<i;return r},n.reverseDecode2=function(t,e,r,i){for(var o=1,s=0,u=0,l;u<i;++u)l=r.decodeBit(t,e+o),o=o<<1|l,s|=l<<u;return s},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,o;do if(i=e>>7&1,e<<=1,o=t.decodeBit(this._decoders,(1+i<<8)+r),r=r<<1|o,i!==o){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,o=0,s=0,u=0,l=0,d=0,c=0,f,h,v,A,m,y;for(this._rangeDecoder.setStream(t),this._outWindow.setStream(e),this.init();r<0||d<r;)if(f=d&this._posStateMask,this._rangeDecoder.decodeBit(this._isMatchDecoders,(i<<4)+f)===0)h=this._literalDecoder.getDecoder(d++,c),i>=7?c=h.decodeWithMatchByte(this._rangeDecoder,this._outWindow.getByte(o)):c=h.decodeNormal(this._rangeDecoder),this._outWindow.putByte(c),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)+f)===0&&(i=i<7?9:11,v=1):(this._rangeDecoder.decodeBit(this._isRepG1Decoders,i)===0?A=s:(this._rangeDecoder.decodeBit(this._isRepG2Decoders,i)===0?A=u:(A=l,l=u),u=s),s=o,o=A),v===0&&(v=2+this._repLenDecoder.decode(this._rangeDecoder,f),i=i<7?8:11);else if(l=u,u=s,s=o,v=2+this._lenDecoder.decode(this._rangeDecoder,f),i=i<7?7:10,m=this._posSlotDecoder[v<=5?v-2:3].decode(this._rangeDecoder),m>=4){if(y=(m>>1)-1,o=(2|m&1)<<y,m<14)o+=n.reverseDecode2(this._posDecoders,o-m-1,this._rangeDecoder,y);else if(o+=this._rangeDecoder.decodeDirectBits(y-4)<<4,o+=this._posAlignDecoder.reverseDecode(this._rangeDecoder),o<0){if(o===-1)break;return!1}}else o=m;if(o>=d||o>=this._dictionarySizeCheck)return!1;this._outWindow.copyBlock(o,v),d+=v,c=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,o,s;return t.size<5||(e=t.readByte(),r=e%9,e=~~(e/9),i=e%5,o=~~(e/5),!this.setLcLpPb(r,i,o))?!1:(s=t.readByte(),s|=t.readByte()<<8,s|=t.readByte()<<16,s+=t.readByte()*16777216,this.setDictionarySize(s))},n.decompress=function(t,e,r,i){var o=new n.Decoder;if(!o.setDecoderProperties(t))throw"Incorrect stream properties";if(!o.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 LZMA=createLZMA();function createWASM(){function n(e){for(var r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",i=new Uint8Array(256),o=0;o<r.length;o++)i[r.charCodeAt(o)]=o;var s=e.length*.75,u=e.length,l,d=0,c,f,h,v;e[e.length-1]==="="&&(s--,e[e.length-2]==="="&&s--);var A=new ArrayBuffer(s),m=new Uint8Array(A);for(l=0;l<u;l+=4)c=i[e.charCodeAt(l)],f=i[e.charCodeAt(l+1)],h=i[e.charCodeAt(l+2)],v=i[e.charCodeAt(l+3)],m[d++]=c<<2|f>>4,m[d++]=(f&15)<<4|h>>2,m[d++]=(h&3)<<6|v&63;return A}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 decodeLZMA(n,t,e){try{var r={data:t,offset:0,readByte:function(){return this.data[this.offset++]}},i=r.data.length,o={data:[],offset:0,writeByte:function(l){var d=Math.floor(this.offset/i);this.data[d]||(this.data[d]=new Uint8Array(i)),this.data[d][this.offset%i]=l,this.offset++}};n.decompressFile(r,o);for(var s=new Uint8Array(o.offset),u=0;u<o.offset;u++)s[u]=o.data[Math.floor(u/i)][u%i];e(null,s)}catch(l){e(l)}}function decodeLZMAWithWASM(n,t,e){var r=24;try{var i=new WebAssembly.Memory({initial:16}),o=new WebAssembly.Module(n),s=new WebAssembly.Instance(o,{env:{memory:i,abort:function(){e(new Error("webAssembly abort"))}}}),u=s.exports,l=u.newU8Array(t.length),d=new Uint8Array(i.buffer,l+r,t.length);d.set(t);var c=u.decode(l),f=new Uint32Array(i.buffer,c,4),h=f[0],v=f[2],A=f[3];h?e(null,new Uint8Array(i.buffer,A+r,v).slice(0,v)):e(new Error("lzma deocder error"))}catch(m){e(m)}}var lzmaWorkerSource=`
|
|
884
884
|
var decodeLZMA = (function() {
|
|
885
885
|
var LZMA = (`.concat(createLZMA.toString(),`)();
|
|
886
886
|
return function(data, callback) {
|
|
@@ -943,11 +943,11 @@ self.onmessage = function(event) {
|
|
|
943
943
|
void main() {
|
|
944
944
|
gl_FragColor = textureCube(map, vec3(0, 0, 0));
|
|
945
945
|
}
|
|
946
|
-
`,depthTest:!1,depthWrite:!1,stencilWrite:!1,blending:THREE__namespace.NoBlending,lights:!1,toneMapped:!1}),task=Promise.resolve();function initTexture(n,t){if(!t)return Promise.resolve(n);var e=t.getRenderTarget();t.setRenderTarget(renderTarget),n instanceof THREE__namespace.CubeTexture?(mesh$4.material=cubeTextureMaterial,cubeTextureMaterial.uniforms.map.value=n,t.render(scene$2,camera$2),cubeTextureMaterial.uniforms.map.value=null):(mesh$4.material=textureMaterial,textureMaterial.uniforms.map.value=n,t.render(scene$2,camera$2),cubeTextureMaterial.uniforms.map.value=null),t.setRenderTarget(e);var r=task.then(function(){return new Promise(function(i){AnimationFrameLoop.shared.add(function(){i(n)},!0)})});return task=r.catch(function(){}),r}var commonjsGlobal=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{},indexMinimal={},minimal$1={},aspromise=asPromise;function asPromise(n,t){for(var e=new Array(arguments.length-1),r=0,i=2,o=!0;i<arguments.length;)e[r++]=arguments[i++];return new Promise(function(u,l){e[r]=function(c){if(o)if(o=!1,c)l(c);else{for(var f=new Array(arguments.length-1),h=0;h<f.length;)f[h++]=arguments[h];u.apply(null,f)}};try{n.apply(t||null,e)}catch(d){o&&(o=!1,l(d))}})}var base64$1={};(function(n){var t=n;t.length=function(u){var l=u.length;if(!l)return 0;for(var d=0;--l%4>1&&u.charAt(l)==="=";)++d;return Math.ceil(u.length*3)/4-d};for(var e=new Array(64),r=new Array(123),i=0;i<64;)r[e[i]=i<26?i+65:i<52?i+71:i<62?i-4:i-59|43]=i++;t.encode=function(u,l,d){for(var c=null,f=[],h=0,v=0,A;l<d;){var m=u[l++];switch(v){case 0:f[h++]=e[m>>2],A=(m&3)<<4,v=1;break;case 1:f[h++]=e[A|m>>4],A=(m&15)<<2,v=2;break;case 2:f[h++]=e[A|m>>6],f[h++]=e[m&63],v=0;break}h>8191&&((c||(c=[])).push(String.fromCharCode.apply(String,f)),h=0)}return v&&(f[h++]=e[A],f[h++]=61,v===1&&(f[h++]=61)),c?(h&&c.push(String.fromCharCode.apply(String,f.slice(0,h))),c.join("")):String.fromCharCode.apply(String,f.slice(0,h))};var o="invalid encoding";t.decode=function(u,l,d){for(var c=d,f=0,h,v=0;v<u.length;){var A=u.charCodeAt(v++);if(A===61&&f>1)break;if((A=r[A])===void 0)throw Error(o);switch(f){case 0:h=A,f=1;break;case 1:l[d++]=h<<2|(A&48)>>4,h=A,f=2;break;case 2:l[d++]=(h&15)<<4|(A&60)>>2,h=A,f=3;break;case 3:l[d++]=(h&3)<<6|A,f=0;break}}if(f===1)throw Error(o);return d-c},t.test=function(u){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(u)}})(base64$1);var eventemitter=EventEmitter;function EventEmitter(){this._listeners={}}EventEmitter.prototype.on=function(t,e,r){return(this._listeners[t]||(this._listeners[t]=[])).push({fn:e,ctx:r||this}),this},EventEmitter.prototype.off=function(t,e){if(t===void 0)this._listeners={};else if(e===void 0)this._listeners[t]=[];else for(var r=this._listeners[t],i=0;i<r.length;)r[i].fn===e?r.splice(i,1):++i;return this},EventEmitter.prototype.emit=function(t){var e=this._listeners[t];if(e){for(var r=[],i=1;i<arguments.length;)r.push(arguments[i++]);for(i=0;i<e.length;)e[i].fn.apply(e[i++].ctx,r)}return this};var float=factory(factory);function factory(n){return typeof Float32Array<"u"?function(){var t=new Float32Array([-0]),e=new Uint8Array(t.buffer),r=e[3]===128;function i(l,d,c){t[0]=l,d[c]=e[0],d[c+1]=e[1],d[c+2]=e[2],d[c+3]=e[3]}function o(l,d,c){t[0]=l,d[c]=e[3],d[c+1]=e[2],d[c+2]=e[1],d[c+3]=e[0]}n.writeFloatLE=r?i:o,n.writeFloatBE=r?o:i;function s(l,d){return e[0]=l[d],e[1]=l[d+1],e[2]=l[d+2],e[3]=l[d+3],t[0]}function u(l,d){return e[3]=l[d],e[2]=l[d+1],e[1]=l[d+2],e[0]=l[d+3],t[0]}n.readFloatLE=r?s:u,n.readFloatBE=r?u:s}():function(){function t(r,i,o,s){var u=i<0?1:0;if(u&&(i=-i),i===0)r(1/i>0?0:2147483648,o,s);else if(isNaN(i))r(2143289344,o,s);else if(i>34028234663852886e22)r((u<<31|2139095040)>>>0,o,s);else if(i<11754943508222875e-54)r((u<<31|Math.round(i/1401298464324817e-60))>>>0,o,s);else{var l=Math.floor(Math.log(i)/Math.LN2),d=Math.round(i*Math.pow(2,-l)*8388608)&8388607;r((u<<31|l+127<<23|d)>>>0,o,s)}}n.writeFloatLE=t.bind(null,writeUintLE),n.writeFloatBE=t.bind(null,writeUintBE);function e(r,i,o){var s=r(i,o),u=(s>>31)*2+1,l=s>>>23&255,d=s&8388607;return l===255?d?NaN:u*(1/0):l===0?u*1401298464324817e-60*d:u*Math.pow(2,l-150)*(d+8388608)}n.readFloatLE=e.bind(null,readUintLE),n.readFloatBE=e.bind(null,readUintBE)}(),typeof Float64Array<"u"?function(){var t=new Float64Array([-0]),e=new Uint8Array(t.buffer),r=e[7]===128;function i(l,d,c){t[0]=l,d[c]=e[0],d[c+1]=e[1],d[c+2]=e[2],d[c+3]=e[3],d[c+4]=e[4],d[c+5]=e[5],d[c+6]=e[6],d[c+7]=e[7]}function o(l,d,c){t[0]=l,d[c]=e[7],d[c+1]=e[6],d[c+2]=e[5],d[c+3]=e[4],d[c+4]=e[3],d[c+5]=e[2],d[c+6]=e[1],d[c+7]=e[0]}n.writeDoubleLE=r?i:o,n.writeDoubleBE=r?o:i;function s(l,d){return e[0]=l[d],e[1]=l[d+1],e[2]=l[d+2],e[3]=l[d+3],e[4]=l[d+4],e[5]=l[d+5],e[6]=l[d+6],e[7]=l[d+7],t[0]}function u(l,d){return e[7]=l[d],e[6]=l[d+1],e[5]=l[d+2],e[4]=l[d+3],e[3]=l[d+4],e[2]=l[d+5],e[1]=l[d+6],e[0]=l[d+7],t[0]}n.readDoubleLE=r?s:u,n.readDoubleBE=r?u:s}():function(){function t(r,i,o,s,u,l){var d=s<0?1:0;if(d&&(s=-s),s===0)r(0,u,l+i),r(1/s>0?0:2147483648,u,l+o);else if(isNaN(s))r(0,u,l+i),r(2146959360,u,l+o);else if(s>17976931348623157e292)r(0,u,l+i),r((d<<31|2146435072)>>>0,u,l+o);else{var c;if(s<22250738585072014e-324)c=s/5e-324,r(c>>>0,u,l+i),r((d<<31|c/4294967296)>>>0,u,l+o);else{var f=Math.floor(Math.log(s)/Math.LN2);f===1024&&(f=1023),c=s*Math.pow(2,-f),r(c*4503599627370496>>>0,u,l+i),r((d<<31|f+1023<<20|c*1048576&1048575)>>>0,u,l+o)}}}n.writeDoubleLE=t.bind(null,writeUintLE,0,4),n.writeDoubleBE=t.bind(null,writeUintBE,4,0);function e(r,i,o,s,u){var l=r(s,u+i),d=r(s,u+o),c=(d>>31)*2+1,f=d>>>20&2047,h=4294967296*(d&1048575)+l;return f===2047?h?NaN:c*(1/0):f===0?c*5e-324*h:c*Math.pow(2,f-1075)*(h+4503599627370496)}n.readDoubleLE=e.bind(null,readUintLE,0,4),n.readDoubleBE=e.bind(null,readUintBE,4,0)}(),n}function writeUintLE(n,t,e){t[e]=n&255,t[e+1]=n>>>8&255,t[e+2]=n>>>16&255,t[e+3]=n>>>24}function writeUintBE(n,t,e){t[e]=n>>>24,t[e+1]=n>>>16&255,t[e+2]=n>>>8&255,t[e+3]=n&255}function readUintLE(n,t){return(n[t]|n[t+1]<<8|n[t+2]<<16|n[t+3]<<24)>>>0}function readUintBE(n,t){return(n[t]<<24|n[t+1]<<16|n[t+2]<<8|n[t+3])>>>0}var inquire_1=inquire;function inquire(moduleName){try{var mod=eval("quire".replace(/^/,"re"))(moduleName);if(mod&&(mod.length||Object.keys(mod).length))return mod}catch(n){}return null}var utf8$2={};(function(n){var t=n;t.length=function(r){for(var i=0,o=0,s=0;s<r.length;++s)o=r.charCodeAt(s),o<128?i+=1:o<2048?i+=2:(o&64512)===55296&&(r.charCodeAt(s+1)&64512)===56320?(++s,i+=4):i+=3;return i},t.read=function(r,i,o){var s=o-i;if(s<1)return"";for(var u=null,l=[],d=0,c;i<o;)c=r[i++],c<128?l[d++]=c:c>191&&c<224?l[d++]=(c&31)<<6|r[i++]&63:c>239&&c<365?(c=((c&7)<<18|(r[i++]&63)<<12|(r[i++]&63)<<6|r[i++]&63)-65536,l[d++]=55296+(c>>10),l[d++]=56320+(c&1023)):l[d++]=(c&15)<<12|(r[i++]&63)<<6|r[i++]&63,d>8191&&((u||(u=[])).push(String.fromCharCode.apply(String,l)),d=0);return u?(d&&u.push(String.fromCharCode.apply(String,l.slice(0,d))),u.join("")):String.fromCharCode.apply(String,l.slice(0,d))},t.write=function(r,i,o){for(var s=o,u,l,d=0;d<r.length;++d)u=r.charCodeAt(d),u<128?i[o++]=u:u<2048?(i[o++]=u>>6|192,i[o++]=u&63|128):(u&64512)===55296&&((l=r.charCodeAt(d+1))&64512)===56320?(u=65536+((u&1023)<<10)+(l&1023),++d,i[o++]=u>>18|240,i[o++]=u>>12&63|128,i[o++]=u>>6&63|128,i[o++]=u&63|128):(i[o++]=u>>12|224,i[o++]=u>>6&63|128,i[o++]=u&63|128);return o-s}})(utf8$2);var pool_1=pool;function pool(n,t,e){var r=e||8192,i=r>>>1,o=null,s=r;return function(l){if(l<1||l>i)return n(l);s+l>r&&(o=n(r),s=0);var d=t.call(o,s,s+=l);return s&7&&(s=(s|7)+1),d}}var longbits,hasRequiredLongbits;function requireLongbits(){if(hasRequiredLongbits)return longbits;hasRequiredLongbits=1,longbits=t;var n=requireMinimal();function t(o,s){this.lo=o>>>0,this.hi=s>>>0}var e=t.zero=new t(0,0);e.toNumber=function(){return 0},e.zzEncode=e.zzDecode=function(){return this},e.length=function(){return 1};var r=t.zeroHash="\0\0\0\0\0\0\0\0";t.fromNumber=function(s){if(s===0)return e;var u=s<0;u&&(s=-s);var l=s>>>0,d=(s-l)/4294967296>>>0;return u&&(d=~d>>>0,l=~l>>>0,++l>4294967295&&(l=0,++d>4294967295&&(d=0))),new t(l,d)},t.from=function(s){if(typeof s=="number")return t.fromNumber(s);if(n.isString(s))if(n.Long)s=n.Long.fromString(s);else return t.fromNumber(parseInt(s,10));return s.low||s.high?new t(s.low>>>0,s.high>>>0):e},t.prototype.toNumber=function(s){if(!s&&this.hi>>>31){var u=~this.lo+1>>>0,l=~this.hi>>>0;return u||(l=l+1>>>0),-(u+l*4294967296)}return this.lo+this.hi*4294967296},t.prototype.toLong=function(s){return n.Long?new n.Long(this.lo|0,this.hi|0,!!s):{low:this.lo|0,high:this.hi|0,unsigned:!!s}};var i=String.prototype.charCodeAt;return t.fromHash=function(s){return s===r?e:new t((i.call(s,0)|i.call(s,1)<<8|i.call(s,2)<<16|i.call(s,3)<<24)>>>0,(i.call(s,4)|i.call(s,5)<<8|i.call(s,6)<<16|i.call(s,7)<<24)>>>0)},t.prototype.toHash=function(){return String.fromCharCode(this.lo&255,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,this.hi&255,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},t.prototype.zzEncode=function(){var s=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^s)>>>0,this.lo=(this.lo<<1^s)>>>0,this},t.prototype.zzDecode=function(){var s=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^s)>>>0,this.hi=(this.hi>>>1^s)>>>0,this},t.prototype.length=function(){var s=this.lo,u=(this.lo>>>28|this.hi<<4)>>>0,l=this.hi>>>24;return l===0?u===0?s<16384?s<128?1:2:s<2097152?3:4:u<16384?u<128?5:6:u<2097152?7:8:l<128?9:10},longbits}var hasRequiredMinimal;function requireMinimal(){return hasRequiredMinimal||(hasRequiredMinimal=1,function(n){var t=n;t.asPromise=aspromise,t.base64=base64$1,t.EventEmitter=eventemitter,t.float=float,t.inquire=inquire_1,t.utf8=utf8$2,t.pool=pool_1,t.LongBits=requireLongbits(),t.isNode=!!(typeof commonjsGlobal<"u"&&commonjsGlobal&&commonjsGlobal.process&&commonjsGlobal.process.versions&&commonjsGlobal.process.versions.node),t.global=t.isNode&&commonjsGlobal||typeof window<"u"&&window||typeof self<"u"&&self||commonjsGlobal,t.emptyArray=Object.freeze?Object.freeze([]):[],t.emptyObject=Object.freeze?Object.freeze({}):{},t.isInteger=Number.isInteger||function(o){return typeof o=="number"&&isFinite(o)&&Math.floor(o)===o},t.isString=function(o){return typeof o=="string"||o instanceof String},t.isObject=function(o){return o&&typeof o=="object"},t.isset=t.isSet=function(o,s){var u=o[s];return u!=null&&o.hasOwnProperty(s)?typeof u!="object"||(Array.isArray(u)?u.length:Object.keys(u).length)>0:!1},t.Buffer=function(){try{var i=t.inquire("buffer").Buffer;return i.prototype.utf8Write?i:null}catch{return null}}(),t._Buffer_from=null,t._Buffer_allocUnsafe=null,t.newBuffer=function(o){return typeof o=="number"?t.Buffer?t._Buffer_allocUnsafe(o):new t.Array(o):t.Buffer?t._Buffer_from(o):typeof Uint8Array>"u"?o:new Uint8Array(o)},t.Array=typeof Uint8Array<"u"?Uint8Array:Array,t.Long=t.global.dcodeIO&&t.global.dcodeIO.Long||t.global.Long||t.inquire("long"),t.key2Re=/^true|false|0|1$/,t.key32Re=/^-?(?:0|[1-9][0-9]*)$/,t.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,t.longToHash=function(o){return o?t.LongBits.from(o).toHash():t.LongBits.zeroHash},t.longFromHash=function(o,s){var u=t.LongBits.fromHash(o);return t.Long?t.Long.fromBits(u.lo,u.hi,s):u.toNumber(!!s)};function e(i,o,s){for(var u=Object.keys(o),l=0;l<u.length;++l)(i[u[l]]===void 0||!s)&&(i[u[l]]=o[u[l]]);return i}t.merge=e,t.lcFirst=function(o){return o.charAt(0).toLowerCase()+o.substring(1)};function r(i){function o(s,u){if(!(this instanceof o))return new o(s,u);Object.defineProperty(this,"message",{get:function(){return s}}),Error.captureStackTrace?Error.captureStackTrace(this,o):Object.defineProperty(this,"stack",{value:new Error().stack||""}),u&&e(this,u)}return o.prototype=Object.create(Error.prototype,{constructor:{value:o,writable:!0,enumerable:!1,configurable:!0},name:{get:function(){return i},set:void 0,enumerable:!1,configurable:!0},toString:{value:function(){return this.name+": "+this.message},writable:!0,enumerable:!1,configurable:!0}}),o}t.newError=r,t.ProtocolError=r("ProtocolError"),t.oneOfGetter=function(o){for(var s={},u=0;u<o.length;++u)s[o[u]]=1;return function(){for(var l=Object.keys(this),d=l.length-1;d>-1;--d)if(s[l[d]]===1&&this[l[d]]!==void 0&&this[l[d]]!==null)return l[d]}},t.oneOfSetter=function(o){return function(s){for(var u=0;u<o.length;++u)o[u]!==s&&delete this[o[u]]}},t.toJSONOptions={longs:String,enums:String,bytes:String,json:!0},t._configure=function(){var i=t.Buffer;if(!i){t._Buffer_from=t._Buffer_allocUnsafe=null;return}t._Buffer_from=i.from!==Uint8Array.from&&i.from||function(s,u){return new i(s,u)},t._Buffer_allocUnsafe=i.allocUnsafe||function(s){return new i(s)}}}(minimal$1)),minimal$1}var writer=Writer$1,util$4=requireMinimal(),BufferWriter$1,LongBits$1=util$4.LongBits,base64=util$4.base64,utf8$1=util$4.utf8;function Op(n,t,e){this.fn=n,this.len=t,this.next=void 0,this.val=e}function noop(){}function State(n){this.head=n.head,this.tail=n.tail,this.len=n.len,this.next=n.states}function Writer$1(){this.len=0,this.head=new Op(noop,0,0),this.tail=this.head,this.states=null}var create$1=function n(){return util$4.Buffer?function(){return(Writer$1.create=function(){return new BufferWriter$1})()}:function(){return new Writer$1}};Writer$1.create=create$1(),Writer$1.alloc=function n(t){return new util$4.Array(t)},util$4.Array!==Array&&(Writer$1.alloc=util$4.pool(Writer$1.alloc,util$4.Array.prototype.subarray)),Writer$1.prototype._push=function n(t,e,r){return this.tail=this.tail.next=new Op(t,e,r),this.len+=e,this};function writeByte(n,t,e){t[e]=n&255}function writeVarint32(n,t,e){for(;n>127;)t[e++]=n&127|128,n>>>=7;t[e]=n}function VarintOp(n,t){this.len=n,this.next=void 0,this.val=t}VarintOp.prototype=Object.create(Op.prototype),VarintOp.prototype.fn=writeVarint32,Writer$1.prototype.uint32=function n(t){return this.len+=(this.tail=this.tail.next=new VarintOp((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this},Writer$1.prototype.int32=function n(t){return t<0?this._push(writeVarint64,10,LongBits$1.fromNumber(t)):this.uint32(t)},Writer$1.prototype.sint32=function n(t){return this.uint32((t<<1^t>>31)>>>0)};function writeVarint64(n,t,e){for(;n.hi;)t[e++]=n.lo&127|128,n.lo=(n.lo>>>7|n.hi<<25)>>>0,n.hi>>>=7;for(;n.lo>127;)t[e++]=n.lo&127|128,n.lo=n.lo>>>7;t[e++]=n.lo}Writer$1.prototype.uint64=function n(t){var e=LongBits$1.from(t);return this._push(writeVarint64,e.length(),e)},Writer$1.prototype.int64=Writer$1.prototype.uint64,Writer$1.prototype.sint64=function n(t){var e=LongBits$1.from(t).zzEncode();return this._push(writeVarint64,e.length(),e)},Writer$1.prototype.bool=function n(t){return this._push(writeByte,1,t?1:0)};function writeFixed32(n,t,e){t[e]=n&255,t[e+1]=n>>>8&255,t[e+2]=n>>>16&255,t[e+3]=n>>>24}Writer$1.prototype.fixed32=function n(t){return this._push(writeFixed32,4,t>>>0)},Writer$1.prototype.sfixed32=Writer$1.prototype.fixed32,Writer$1.prototype.fixed64=function n(t){var e=LongBits$1.from(t);return this._push(writeFixed32,4,e.lo)._push(writeFixed32,4,e.hi)},Writer$1.prototype.sfixed64=Writer$1.prototype.fixed64,Writer$1.prototype.float=function n(t){return this._push(util$4.float.writeFloatLE,4,t)},Writer$1.prototype.double=function n(t){return this._push(util$4.float.writeDoubleLE,8,t)};var writeBytes=util$4.Array.prototype.set?function n(t,e,r){e.set(t,r)}:function n(t,e,r){for(var i=0;i<t.length;++i)e[r+i]=t[i]};Writer$1.prototype.bytes=function n(t){var e=t.length>>>0;if(!e)return this._push(writeByte,1,0);if(util$4.isString(t)){var r=Writer$1.alloc(e=base64.length(t));base64.decode(t,r,0),t=r}return this.uint32(e)._push(writeBytes,e,t)},Writer$1.prototype.string=function n(t){var e=utf8$1.length(t);return e?this.uint32(e)._push(utf8$1.write,e,t):this._push(writeByte,1,0)},Writer$1.prototype.fork=function n(){return this.states=new State(this),this.head=this.tail=new Op(noop,0,0),this.len=0,this},Writer$1.prototype.reset=function n(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Op(noop,0,0),this.len=0),this},Writer$1.prototype.ldelim=function n(){var t=this.head,e=this.tail,r=this.len;return this.reset().uint32(r),r&&(this.tail.next=t.next,this.tail=e,this.len+=r),this},Writer$1.prototype.finish=function n(){for(var t=this.head.next,e=this.constructor.alloc(this.len),r=0;t;)t.fn(t.val,e,r),r+=t.len,t=t.next;return e},Writer$1._configure=function(n){BufferWriter$1=n,Writer$1.create=create$1(),BufferWriter$1._configure()};var writer_buffer=BufferWriter,Writer=writer;(BufferWriter.prototype=Object.create(Writer.prototype)).constructor=BufferWriter;var util$3=requireMinimal();function BufferWriter(){Writer.call(this)}BufferWriter._configure=function(){BufferWriter.alloc=util$3._Buffer_allocUnsafe,BufferWriter.writeBytesBuffer=util$3.Buffer&&util$3.Buffer.prototype instanceof Uint8Array&&util$3.Buffer.prototype.set.name==="set"?function(t,e,r){e.set(t,r)}:function(t,e,r){if(t.copy)t.copy(e,r,0,t.length);else for(var i=0;i<t.length;)e[r++]=t[i++]}},BufferWriter.prototype.bytes=function n(t){util$3.isString(t)&&(t=util$3._Buffer_from(t,"base64"));var e=t.length>>>0;return this.uint32(e),e&&this._push(BufferWriter.writeBytesBuffer,e,t),this};function writeStringBuffer(n,t,e){n.length<40?util$3.utf8.write(n,t,e):t.utf8Write?t.utf8Write(n,e):t.write(n,e)}BufferWriter.prototype.string=function n(t){var e=util$3.Buffer.byteLength(t);return this.uint32(e),e&&this._push(writeStringBuffer,e,t),this},BufferWriter._configure();var reader=Reader$1,util$2=requireMinimal(),BufferReader$1,LongBits=util$2.LongBits,utf8=util$2.utf8;function indexOutOfRange(n,t){return RangeError("index out of range: "+n.pos+" + "+(t||1)+" > "+n.len)}function Reader$1(n){this.buf=n,this.pos=0,this.len=n.length}var create_array=typeof Uint8Array<"u"?function n(t){if(t instanceof Uint8Array||Array.isArray(t))return new Reader$1(t);throw Error("illegal buffer")}:function n(t){if(Array.isArray(t))return new Reader$1(t);throw Error("illegal buffer")},create=function n(){return util$2.Buffer?function(e){return(Reader$1.create=function(i){return util$2.Buffer.isBuffer(i)?new BufferReader$1(i):create_array(i)})(e)}:create_array};Reader$1.create=create(),Reader$1.prototype._slice=util$2.Array.prototype.subarray||util$2.Array.prototype.slice,Reader$1.prototype.uint32=function n(){var t=4294967295;return function(){if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,indexOutOfRange(this,10);return t}}(),Reader$1.prototype.int32=function n(){return this.uint32()|0},Reader$1.prototype.sint32=function n(){var t=this.uint32();return t>>>1^-(t&1)|0};function readLongVarint(){var n=new LongBits(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(n.lo=(n.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return n;if(n.lo=(n.lo|(this.buf[this.pos]&127)<<28)>>>0,n.hi=(n.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return n;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(n.lo=(n.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return n}return n.lo=(n.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,n}if(this.len-this.pos>4){for(;t<5;++t)if(n.hi=(n.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return n}else for(;t<5;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(n.hi=(n.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return n}throw Error("invalid varint encoding")}Reader$1.prototype.bool=function n(){return this.uint32()!==0};function readFixed32_end(n,t){return(n[t-4]|n[t-3]<<8|n[t-2]<<16|n[t-1]<<24)>>>0}Reader$1.prototype.fixed32=function n(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return readFixed32_end(this.buf,this.pos+=4)},Reader$1.prototype.sfixed32=function n(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return readFixed32_end(this.buf,this.pos+=4)|0};function readFixed64(){if(this.pos+8>this.len)throw indexOutOfRange(this,8);return new LongBits(readFixed32_end(this.buf,this.pos+=4),readFixed32_end(this.buf,this.pos+=4))}Reader$1.prototype.float=function n(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);var t=util$2.float.readFloatLE(this.buf,this.pos);return this.pos+=4,t},Reader$1.prototype.double=function n(){if(this.pos+8>this.len)throw indexOutOfRange(this,4);var t=util$2.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,t},Reader$1.prototype.bytes=function n(){var t=this.uint32(),e=this.pos,r=this.pos+t;if(r>this.len)throw indexOutOfRange(this,t);if(this.pos+=t,Array.isArray(this.buf))return this.buf.slice(e,r);if(e===r){var i=util$2.Buffer;return i?i.alloc(0):new this.buf.constructor(0)}return this._slice.call(this.buf,e,r)},Reader$1.prototype.string=function n(){var t=this.bytes();return utf8.read(t,0,t.length)},Reader$1.prototype.skip=function n(t){if(typeof t=="number"){if(this.pos+t>this.len)throw indexOutOfRange(this,t);this.pos+=t}else do if(this.pos>=this.len)throw indexOutOfRange(this);while(this.buf[this.pos++]&128);return this},Reader$1.prototype.skipType=function(n){switch(n){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(n=this.uint32()&7)!==4;)this.skipType(n);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+n+" at offset "+this.pos)}return this},Reader$1._configure=function(n){BufferReader$1=n,Reader$1.create=create(),BufferReader$1._configure();var t=util$2.Long?"toLong":"toNumber";util$2.merge(Reader$1.prototype,{int64:function(){return readLongVarint.call(this)[t](!1)},uint64:function(){return readLongVarint.call(this)[t](!0)},sint64:function(){return readLongVarint.call(this).zzDecode()[t](!1)},fixed64:function(){return readFixed64.call(this)[t](!0)},sfixed64:function(){return readFixed64.call(this)[t](!1)}})};var reader_buffer=BufferReader,Reader=reader;(BufferReader.prototype=Object.create(Reader.prototype)).constructor=BufferReader;var util$1=requireMinimal();function BufferReader(n){Reader.call(this,n)}BufferReader._configure=function(){util$1.Buffer&&(BufferReader.prototype._slice=util$1.Buffer.prototype.slice)},BufferReader.prototype.string=function n(){var t=this.uint32();return this.buf.utf8Slice?this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+t,this.len)):this.buf.toString("utf-8",this.pos,this.pos=Math.min(this.pos+t,this.len))},BufferReader._configure();var rpc={},service=Service,util=requireMinimal();(Service.prototype=Object.create(util.EventEmitter.prototype)).constructor=Service;function Service(n,t,e){if(typeof n!="function")throw TypeError("rpcImpl must be a function");util.EventEmitter.call(this),this.rpcImpl=n,this.requestDelimited=!!t,this.responseDelimited=!!e}Service.prototype.rpcCall=function n(t,e,r,i,o){if(!i)throw TypeError("request must be specified");var s=this;if(!o)return util.asPromise(n,s,t,e,r,i);if(!s.rpcImpl){setTimeout(function(){o(Error("already ended"))},0);return}try{return s.rpcImpl(t,e[s.requestDelimited?"encodeDelimited":"encode"](i).finish(),function(l,d){if(l)return s.emit("error",l,t),o(l);if(d===null){s.end(!0);return}if(!(d instanceof r))try{d=r[s.responseDelimited?"decodeDelimited":"decode"](d)}catch(c){return s.emit("error",c,t),o(c)}return s.emit("data",d,t),o(null,d)})}catch(u){s.emit("error",u,t),setTimeout(function(){o(u)},0);return}},Service.prototype.end=function n(t){return this.rpcImpl&&(t||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this},function(n){var t=n;t.Service=service}(rpc);var roots={};(function(n){var t=n;t.build="minimal",t.Writer=writer,t.BufferWriter=writer_buffer,t.Reader=reader,t.BufferReader=reader_buffer,t.util=requireMinimal(),t.rpc=rpc,t.roots=roots,t.configure=e;function e(){t.util._configure(),t.Writer._configure(t.BufferWriter),t.Reader._configure(t.BufferReader)}e()})(indexMinimal);var minimal=indexMinimal;const $Reader$1=minimal.Reader,$util$1=minimal.util,$root$1=minimal.roots["@REALSEE/FIVE:five/loaders/model/proto/pbm.proto"]||(minimal.roots["@REALSEE/FIVE:five/loaders/model/proto/pbm.proto"]={}),Model$2=$root$1.Model=(()=>{function n(t){if(this.chunks=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.chunks=$util$1.emptyArray,n.prototype.createAt=$util$1.Long?$util$1.Long.fromBits(0,0,!0):0,n.prototype.description="",n.decode=function(e,r){e instanceof $Reader$1||(e=$Reader$1.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root$1.Model;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.chunks&&o.chunks.length||(o.chunks=[]),o.chunks.push($root$1.Chunk.decode(e,e.uint32()));break}case 2:{o.createAt=e.uint64();break}case 3:{o.description=e.string();break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Model"},n})();$root$1.Chunk=(()=>{function n(t){if(t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.vertices=null,n.prototype.faces=null,n.prototype.name="",n.prototype.texture="",n.decode=function(e,r){e instanceof $Reader$1||(e=$Reader$1.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root$1.Chunk;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.vertices=$root$1.Vertices.decode(e,e.uint32());break}case 2:{o.faces=$root$1.Faces.decode(e,e.uint32());break}case 3:{o.name=e.string();break}case 4:{o.texture=e.string();break}default:e.skipType(s&7);break}}if(!o.hasOwnProperty("vertices"))throw $util$1.ProtocolError("missing required 'vertices'",{instance:o});if(!o.hasOwnProperty("faces"))throw $util$1.ProtocolError("missing required 'faces'",{instance:o});if(!o.hasOwnProperty("name"))throw $util$1.ProtocolError("missing required 'name'",{instance:o});return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Chunk"},n})(),$root$1.Vertices=(()=>{function n(t){if(this.xyz=[],this.uvs=[],this.marks=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.xyz=$util$1.emptyArray,n.prototype.uvs=$util$1.emptyArray,n.prototype.marks=$util$1.emptyArray,n.decode=function(e,r){e instanceof $Reader$1||(e=$Reader$1.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root$1.Vertices;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.xyz&&o.xyz.length||(o.xyz=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.xyz.push(e.float())}else o.xyz.push(e.float());break}case 2:{if(o.uvs&&o.uvs.length||(o.uvs=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.uvs.push(e.float())}else o.uvs.push(e.float());break}case 3:{if(o.marks&&o.marks.length||(o.marks=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.marks.push(e.int32())}else o.marks.push(e.int32());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Vertices"},n})(),$root$1.Faces=(()=>{function n(t){if(this.indices=[],this.normals=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.indices=$util$1.emptyArray,n.prototype.normals=$util$1.emptyArray,n.decode=function(e,r){e instanceof $Reader$1||(e=$Reader$1.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root$1.Faces;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.indices&&o.indices.length||(o.indices=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.indices.push(e.uint32())}else o.indices.push(e.uint32());break}case 2:{if(o.normals&&o.normals.length||(o.normals=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.normals.push(e.float())}else o.normals.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Faces"},n})(),$root$1.VertexMark=(()=>{const n={},t=Object.create(n);return t[n[0]="VERTEX_MARK_UNSPECIFIED"]=0,t[n[1]="VERTEX_MARK_ROOF"]=1,t})();function loadPbm(n,t){var e,r,i,o={byteLength:0},s=autoRestImageOptionsByTextureLength((e=t.textureOptions)!==null&&e!==void 0?e:{},(i=(r=t.textureArray)===null||r===void 0?void 0:r.length)!==null&&i!==void 0?i:0),u={};if(t.textureArray)for(var l=0,d=t.textureArray;l<d.length;l++){var c=d[l];u[c]=loadTexture$1(c,s,t.fetcher)}return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"})}).then(function(f){return o.byteLength=f.body.byteLength,delay(function(){var h=new Uint8Array(f.body);return Model$2.decode(h)})}).then(function(f){return delay(function(){var h,v;return parse$2(f,(h=t.textureBaseUri)!==null&&h!==void 0?h:function(){var A=n.lastIndexOf("/");if(A>=0){var m=n.slice(0,A)+"/";return/\/model\/$/.test(m)&&(m=m.replace(/\/model\/$/,"/materials/")),m}return""}(),((v=t.textureArray)!==null&&v!==void 0?v:[]).slice(),s,u,t.fetcher)})}).then(function(f){var h=new THREE__namespace.Group;h.renderOrder=-4,h.matrixAutoUpdate=!1,h.matrix.compose(h.position,h.quaternion,h.scale),h.name=n;for(var v=0,A=f.objects;v<A.length;v++){var m=A[v];h.add(m)}return f.texturePromise.then(function(){return{type:"pbm",uri:n,byteLength:o.byteLength,object:h,dispose:function(){return f.dispose()}}})})}var MODEL_FLIP_MATRIX=new THREE__namespace.Matrix4().set(1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1),E=MODEL_FLIP_MATRIX.elements;function parseFloorName(n){var t=n.match(/(group|floor)-?(\d+)/);return t?parseInt(t[2],10):0}function parseChunkName(n){var t=n.match(/(chunk)-?(\d+)/);return t?parseInt(t[2],10):0}function parseSubName(n){var t=n.match(/(sub)-?(\d+)/);return t?parseInt(t[2],10):0}function chunkOrder(n){var t=parseFloorName(n.name),e=parseChunkName(n.name),r=parseSubName(n.name);return t*1e6+e*1e3+r}function parsePBMModel(n){for(var t,e,r,i=typeof n.createAt=="number"?n.createAt:0,o=(t=n.description)!==null&&t!==void 0?t:"",s=[],u=!0,l=!0,d=0,c=n.chunks;d<c.length;d++){var f=c[d];if(!f.vertices.marks||f.vertices.marks.length===0){l=!1;break}}for(var h=0,v=n.chunks;h<v.length;h++){var f=v[h];if(!f.faces.normals||f.faces.normals.length===0){u=!1;break}}for(var A=n.chunks.sort(function(De,qe){return chunkOrder(De)-chunkOrder(qe)}),m=[],y=0,p=A;y<p.length;y++){var f=p[y],g=parseFloorName(f.name);m[g]||(m[g]=[]),m[g].push(f)}for(var b=0;b<m.length;b++){var T=m[b];if(T)if(u){for(var _=0,w=0;w<T.length;w++){var f=T[w];_+=f.faces.indices.length}for(var x=new Float32Array(_*3),M=new Float32Array(_),R=new Float32Array(_*2),I=new Float32Array(_*3),S=[],B=[1/0,1/0,1/0,-1/0,-1/0,-1/0],F=0,O=0;O<T.length;O++){for(var H=[1/0,1/0,1/0,-1/0,-1/0,-1/0],f=T[O],k=f.vertices.xyz,N=f.vertices.uvs,q=f.faces.indices,V=f.faces.normals,D=f.vertices.marks,K=q.length,w=0;w<K;w++){var z=q[w],G=k[z*3],W=k[z*3+1],Q=k[z*3+2],X=1/(E[3]*G+E[7]*W+E[11]*Q+E[15]),ee=(E[0]*G+E[4]*W+E[8]*Q+E[12])*X,J=(E[1]*G+E[5]*W+E[9]*Q+E[13])*X,Z=(E[2]*G+E[6]*W+E[10]*Q+E[14])*X;x[F*3+w*3]=ee,x[F*3+w*3+1]=J,x[F*3+w*3+2]=Z,M[F+w]=l?D[z]:0,R[F*2+w*2]=N[z*2],R[F*2+w*2+1]=N[z*2+1];var te=Math.floor(w/3)*3,ae=V[te],re=V[te+1],ie=V[te+2],de=1/(E[3]*ae+E[7]*re+E[11]*ie+E[15]),se=(E[0]*ae+E[4]*re+E[8]*ie+E[12])*de,pe=(E[1]*ae+E[5]*re+E[9]*ie+E[13])*de,$=(E[2]*ae+E[6]*re+E[10]*ie+E[14])*de;I[F*3+w*3]=se,I[F*3+w*3+1]=pe,I[F*3+w*3+2]=$,ee<H[0]&&(H[0]=ee),J<H[1]&&(H[1]=J),Z<H[2]&&(H[2]=Z),ee>H[3]&&(H[3]=ee),J>H[4]&&(H[4]=J),Z>H[5]&&(H[5]=Z)}H[0]<B[0]&&(B[0]=H[0]),H[1]<B[1]&&(B[1]=H[1]),H[2]<B[2]&&(B[2]=H[2]),H[3]>B[3]&&(B[3]=H[3]),H[4]>B[4]&&(B[4]=H[4]),H[5]>B[5]&&(B[5]=H[5]),S.push({materialIndex:O,name:f.name,chunkName:parseChunkName(f.name),start:F,count:f.faces.indices.length,texture:(e=f.texture)!==null&&e!==void 0?e:void 0}),F+=K}var oe={createAt:i,description:o,vertices:x,uvs:R,normals:I,indices:null,floorIndex:b,groups:S,extents:B,vertexMarks:M};s.push(oe)}else{for(var _=0,j=0,w=0;w<T.length;w++){var f=T[w];j+=f.vertices.xyz.length/3,_+=f.faces.indices.length}for(var x=new Float32Array(j*3),R=new Float32Array(j*2),I=new Float32Array(j*3),ve=new Float32Array(j),me=new Uint32Array(_),M=new Float32Array(_),S=[],B=[1/0,1/0,1/0,-1/0,-1/0,-1/0],Me=0,F=0,O=0;O<T.length;O++){for(var H=[1/0,1/0,1/0,-1/0,-1/0,-1/0],f=T[O],k=f.vertices.xyz,D=f.vertices.marks,N=f.vertices.uvs,q=f.faces.indices,Re=k.length/3,K=q.length,w=0;w<Re;w++){var G=k[w*3],W=k[w*3+1],Q=k[w*3+2],X=1/(E[3]*G+E[7]*W+E[11]*Q+E[15]),ee=(E[0]*G+E[4]*W+E[8]*Q+E[12])*X,J=(E[1]*G+E[5]*W+E[9]*Q+E[13])*X,Z=(E[2]*G+E[6]*W+E[10]*Q+E[14])*X;x[F*3+w*3]=ee,x[F*3+w*3+1]=J,x[F*3+w*3+2]=Z,M[F+w]=l?D[w]:0,R[F*2+w*2]=N[w*2],R[F*2+w*2+1]=N[w*2+1],ve[F+w]=b,ee<H[0]&&(H[0]=ee),J<H[1]&&(H[1]=J),Z<H[2]&&(H[2]=Z),ee>H[3]&&(H[3]=ee),J>H[4]&&(H[4]=J),Z>H[5]&&(H[5]=Z)}H[0]<B[0]&&(B[0]=H[0]),H[1]<B[1]&&(B[1]=H[1]),H[2]<B[2]&&(B[2]=H[2]),H[3]>B[3]&&(B[3]=H[3]),H[4]>B[4]&&(B[4]=H[4]),H[5]>B[5]&&(B[5]=H[5]);for(var w=0;w<K;w++)me[Me+w]=F+q[w];S.push({materialIndex:O,name:f.name,chunkName:parseChunkName(f.name),start:Me,count:f.faces.indices.length,texture:(r=f.texture)!==null&&r!==void 0?r:void 0}),F+=Re,Me+=K}for(var w=0;w<_;w+=3){var ge=void 0,we=void 0,Ae=void 0,le=void 0,ue=void 0,Oe=void 0,fe=void 0,Se=void 0,ye=void 0,ke=void 0,_e=void 0,We=void 0,Xe=void 0,Ee=void 0,Pe=void 0,Je=void 0,be=void 0,Fe=void 0,ae=void 0,re=void 0,ie=void 0;ge=me[w]*3,we=me[w+1]*3,Ae=me[w+2]*3,le=x[ge],ue=x[ge+1],Oe=x[ge+2],fe=x[we],Se=x[we+1],ye=x[we+2],ke=x[Ae],_e=x[Ae+1],We=x[Ae+2],Xe=ke-fe,Ee=_e-Se,Pe=We-ye,Je=le-fe,be=ue-Se,Fe=Oe-ye,ae=Ee*Fe-Pe*be,re=Pe*Je-Xe*Fe,ie=Xe*be-Ee*Je,I[ge]+=ae,I[ge+1]+=re,I[ge+2]+=ie,I[we]+=ae,I[we+1]+=re,I[we+2]+=ie,I[Ae]+=ae,I[Ae+1]+=re,I[Ae+2]+=ie}var oe={createAt:i,description:o,vertices:x,uvs:R,normals:I,indices:me,floorIndex:b,groups:S,extents:B,vertexMarks:M};s.push(oe)}}return s}function loadTexture$1(n,t,e,r){var i=__assign({key:"texture.pbm"},pick(t,["format","quality","size","sharpen","mappings"])),o=new TextureLoader,s=o.loadTexture(n,{imageURL:{transform:t.transform,options:i},wrapS:THREE__namespace.ClampToEdgeWrapping,wrapT:THREE__namespace.ClampToEdgeWrapping,minFilter:THREE__namespace.LinearFilter,maxSize:typeof i.size=="number"?new THREE__namespace.Vector2(i.size,i.size):void 0,fetcher:e}).then(function(u){var l=u.body;return l.needsUpdate=!0,initTexture(l,r)});return Object.assign(s,{url:n,textureOptions:t})}function parse$2(n,t,e,r,i,o,s){i===void 0&&(i={});for(var u=parsePBMModel(n),l=0,d="",c=[],f={},h=new Set,v=0,A=u;v<A.length;v++){var m=A[v],y=m.createAt,p=m.description,g=m.vertices,b=m.vertexMarks,T=m.uvs,_=m.normals,w=m.indices,x=m.floorIndex,M=m.groups,R=m.extents,I=new THREE__namespace.Box3;I.min.x=R[0],I.min.y=R[1],I.min.z=R[2],I.max.x=R[3],I.max.y=R[4],I.max.z=R[5];var S=new THREE__namespace.BufferGeometry;S.setAttribute("position",new THREE__namespace.BufferAttribute(g,3)),S.setAttribute("uv",new THREE__namespace.BufferAttribute(T,2)),S.setAttribute("normal",new THREE__namespace.BufferAttribute(_,3)),S.setAttribute("isRoofMark",new THREE__namespace.BufferAttribute(b,1)),w&&S.setIndex(new THREE__namespace.BufferAttribute(w,1)),S.boundingBox=I,S.boundingSphere=I.getBoundingSphere(new THREE__namespace.Sphere);for(var B=0,F=M;B<F.length;B++){var O=F[B];S.addGroup(O.start,O.count,O.materialIndex)}h.add(S);for(var H=[],k=0,N=M;k<N.length;k++){var O=N[k],q=e[O.chunkName]||(O.texture?pathJoin(t||"",O.texture):void 0),V=new PBMMeshMaterial;V.defines.USE_VERTEX_FLOOR=!1,V.floor=x,H.push(V),q?f[q]?f[q].push(V):f[q]=[V]:(V.defines.USE_MAP=!1,V.uniforms.diffuse.value=new THREE__namespace.Color(16777215)),h.add(V)}var D=new PBMMesh(S,H);D.name="model_floor_"+x,D.userData.createAt=y,D.userData.description=p,D.matrix.compose(D.position,D.quaternion,D.scale),D.matrixAutoUpdate=!1,D.frustumCulled=!1,D.renderOrder=-1e3+x,l=y,d=p,c.push(D)}var K="",z=function(W){W=autoRestImageOptionsByTextureLength(W,e.length);var Q=[],X=jsonHash(W);if(K===X)return Promise.resolve();K=X;for(var ee=function(ae){var re=null;ae in i&&(jsonHash(i[ae].textureOptions)===jsonHash(W)?re=i[ae]:i[ae].then(function(ie){return ie.dispose()})),re||(re=loadTexture$1(ae,W,o,s)),Q.push(re.then(function(ie){if(K!==X){ie.dispose();return}for(var de=0,se=f[ae];de<se.length;de++){var pe=se[de];pe.uniforms.map.value&&(h.delete(pe.uniforms.map.value),pe.uniforms.map.value.dispose()),pe.uniforms.map.value=ie,h.add(ie),pe.uniforms.exposure.value=3.3}}).catch(function(){if(K===X)for(var ie=0,de=f[ae];ie<de.length;ie++){var se=de[ie];se.uniforms.map.value&&(h.delete(se.uniforms.map.value),se.uniforms.map.value.dispose()),se.uniforms.map.value=null,se.defines.USE_MAP=!1,se.uniforms.diffuse.value=new THREE__namespace.Color(16777215)}}))},J=0,Z=Object.keys(f);J<Z.length;J++){var te=Z[J];ee(te)}for(var te in i)delete i[te];return Promise.all(Q).then(function(){})},G=z(r);return{createAt:l,description:d,objects:c,texturePromise:G,updateTexture:z,dispose:function(){h.forEach(function(W){W.dispose()}),h.clear()}}}function autoRestImageOptionsByTextureLength(n,t){return n=Object.assign({},n),n.autoResize!==!1&&(t>96?n.size=Math.min(n.size||1/0,100):t>48?n.size=Math.min(n.size||1/0,200):t>24?n.size=Math.min(n.size||1/0,400):t>22?n.size=Math.min(n.size||1/0,800):t>5&&(n.size=Math.min(n.size||1/0,1024))),n}function loadAt3d(n,t){var e,r,i,o={byteLength:0},s=autoRestImageOptionsByTextureLength((e=t.textureOptions)!==null&&e!==void 0?e:{},(i=(r=t.textureArray)===null||r===void 0?void 0:r.length)!==null&&i!==void 0?i:0),u={};if(t.textureArray)for(var l=0,d=t.textureArray;l<d.length;l++){var c=d[l];u[c]=loadTexture$1(c,s,t.fetcher)}return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"})}).then(function(f){return lzma(f.body)}).then(function(f){return delay(function(){for(var h,v={chunks:[],createAt:void 0,description:void 0},A=0,m=f;A<m.length;A++){var y=m[A],p=Model$2.decode(y);p.chunks.length&&((h=v.chunks).push.apply(h,p.chunks),v.createAt=p.createAt,v.description=p.description)}return v})}).then(function(f){return delay(function(){var h,v,A;return parse$2(f,(h=t.textureBaseUri)!==null&&h!==void 0?h:function(){var m=n.lastIndexOf("/");if(m>=0){var y=n.slice(0,m)+"/";return/\/model\/$/.test(y)&&(y=y.replace(/\/model\/$/,"/materials/")),y}return""}(),((v=t.textureArray)!==null&&v!==void 0?v:[]).slice(),(A=t.textureOptions)!==null&&A!==void 0?A:{},u,t.fetcher)})}).then(function(f){var h=new THREE__namespace.Group;h.renderOrder=-4,h.name=n;for(var v=0,A=f.objects;v<A.length;v++){var m=A[v];h.add(m)}return f.texturePromise.then(function(){return{type:"at3d",uri:n,byteLength:o.byteLength,object:h,dispose:function(){return f.dispose()}}})})}const $Reader=minimal.Reader,$util=minimal.util,$root=minimal.roots["@REALSEE/FIVE:five/loaders/model/proto/dome.proto"]||(minimal.roots["@REALSEE/FIVE:five/loaders/model/proto/dome.proto"]={}),Model$1=$root.Model=(()=>{function n(t){if(this.meshes=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.meshes=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Model;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.meshes&&o.meshes.length||(o.meshes=[]),o.meshes.push($root.Mesh.decode(e,e.uint32()));break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Model"},n})();$root.Mesh=(()=>{function n(t){if(this.chunks=[],this.matrix=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.name="",n.prototype.chunks=$util.emptyArray,n.prototype.matrix=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Mesh;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.name=e.string();break}case 2:{o.chunks&&o.chunks.length||(o.chunks=[]),o.chunks.push($root.Chunk.decode(e,e.uint32()));break}case 3:{o.matrix&&o.matrix.length||(o.matrix=[]),o.matrix.push($root.Matrix.decode(e,e.uint32()));break}default:e.skipType(s&7);break}}if(!o.hasOwnProperty("name"))throw $util.ProtocolError("missing required 'name'",{instance:o});return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Mesh"},n})(),$root.Matrix=(()=>{function n(t){if(this.elements=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.elements=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Matrix;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.elements&&o.elements.length||(o.elements=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.elements.push(e.float())}else o.elements.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Matrix"},n})(),$root.Chunk=(()=>{function n(t){if(this.material=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.geometry=null,n.prototype.material=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Chunk;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 2:{o.geometry=$root.Geometry.decode(e,e.uint32());break}case 3:{o.material&&o.material.length||(o.material=[]),o.material.push($root.Material.decode(e,e.uint32()));break}default:e.skipType(s&7);break}}if(!o.hasOwnProperty("geometry"))throw $util.ProtocolError("missing required 'geometry'",{instance:o});return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Chunk"},n})(),$root.Geometry=(()=>{function n(t){if(this.groups=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.position=null,n.prototype.uv=null,n.prototype.uv2=null,n.prototype.normal=null,n.prototype.groups=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Geometry;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.position=$root.Position.decode(e,e.uint32());break}case 2:{o.uv=$root.UV.decode(e,e.uint32());break}case 3:{o.uv2=$root.UV.decode(e,e.uint32());break}case 4:{o.normal=$root.Normal.decode(e,e.uint32());break}case 5:{o.groups&&o.groups.length||(o.groups=[]),o.groups.push($root.Group.decode(e,e.uint32()));break}default:e.skipType(s&7);break}}if(!o.hasOwnProperty("position"))throw $util.ProtocolError("missing required 'position'",{instance:o});if(!o.hasOwnProperty("normal"))throw $util.ProtocolError("missing required 'normal'",{instance:o});return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Geometry"},n})(),$root.Position=(()=>{function n(t){if(this.array=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.array=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Position;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.array&&o.array.length||(o.array=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.array.push(e.float())}else o.array.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Position"},n})(),$root.UV=(()=>{function n(t){if(this.array=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.array=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.UV;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.array&&o.array.length||(o.array=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.array.push(e.float())}else o.array.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/UV"},n})(),$root.Normal=(()=>{function n(t){if(this.array=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.array=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Normal;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.array&&o.array.length||(o.array=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.array.push(e.float())}else o.array.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Normal"},n})(),$root.Group=(()=>{function n(t){if(t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.start=0,n.prototype.count=0,n.prototype.materialIndex=0,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Group;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.start=e.uint32();break}case 2:{o.count=e.uint32();break}case 3:{o.materialIndex=e.uint32();break}default:e.skipType(s&7);break}}if(!o.hasOwnProperty("start"))throw $util.ProtocolError("missing required 'start'",{instance:o});if(!o.hasOwnProperty("count"))throw $util.ProtocolError("missing required 'count'",{instance:o});if(!o.hasOwnProperty("materialIndex"))throw $util.ProtocolError("missing required 'materialIndex'",{instance:o});return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Group"},n})(),$root.Material=(()=>{function n(t){if(t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.kd=null,n.prototype.ks=null,n.prototype.ke=null,n.prototype.mapkd="",n.prototype.mapks="",n.prototype.mapke="",n.prototype.norm="",n.prototype.mapbump="",n.prototype.bump="",n.prototype.mapd="",n.prototype.ns=0,n.prototype.d=0,n.prototype.tr=0,n.prototype.mapkdrepeat="",n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Material;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.kd=$root.Color.decode(e,e.uint32());break}case 2:{o.ks=$root.Color.decode(e,e.uint32());break}case 3:{o.ke=$root.Color.decode(e,e.uint32());break}case 4:{o.mapkd=e.string();break}case 5:{o.mapks=e.string();break}case 6:{o.mapke=e.string();break}case 7:{o.norm=e.string();break}case 8:{o.mapbump=e.string();break}case 9:{o.bump=e.string();break}case 10:{o.mapd=e.string();break}case 11:{o.ns=e.float();break}case 12:{o.d=e.float();break}case 13:{o.tr=e.float();break}case 14:{o.mapkdrepeat=e.string();break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Material"},n})(),$root.Color=(()=>{function n(t){if(this.rgb=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.rgb=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Color;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.rgb&&o.rgb.length||(o.rgb=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.rgb.push(e.float())}else o.rgb.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Color"},n})();function loadDome(n,t){var e={byteLength:0};return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"})}).then(function(r){return e.byteLength=r.body.byteLength,parse$1(new Uint8Array(r.body),t.textureBaseUri||"",t.textureOptions,t.fetcher)}).then(function(r){var i=new THREE__namespace.Group;i.renderOrder=-4,i.matrixAutoUpdate=!1,i.matrix.compose(i.position,i.quaternion,i.scale),i.name=n;for(var o=0,s=r.objects;o<s.length;o++){var u=s[o];i.add(u)}return r.texturePromise.then(function(){return{type:"dome",uri:n,byteLength:e.byteLength,object:i,dispose:function(){return r.dispose()}}})})}function flipBufferGeometryNormals(n){for(var t=[0,0,0],e=0;e<n.attributes.normal.array.length/9;e++)t[0]=n.attributes.normal.array[e*9],t[1]=n.attributes.normal.array[e*9+1],t[2]=n.attributes.normal.array[e*9+2],n.attributes.normal.array[e*9]=n.attributes.normal.array[e*9+6],n.attributes.normal.array[e*9+1]=n.attributes.normal.array[e*9+7],n.attributes.normal.array[e*9+2]=n.attributes.normal.array[e*9+8],n.attributes.normal.array[e*9+6]=t[0],n.attributes.normal.array[e*9+7]=t[1],n.attributes.normal.array[e*9+8]=t[2];for(var e=0;e<n.attributes.position.array.length/9;e++)t[0]=n.attributes.position.array[e*9],t[1]=n.attributes.position.array[e*9+1],t[2]=n.attributes.position.array[e*9+2],n.attributes.position.array[e*9]=n.attributes.position.array[e*9+6],n.attributes.position.array[e*9+1]=n.attributes.position.array[e*9+7],n.attributes.position.array[e*9+2]=n.attributes.position.array[e*9+8],n.attributes.position.array[e*9+6]=t[0],n.attributes.position.array[e*9+7]=t[1],n.attributes.position.array[e*9+8]=t[2];for(var e=0;e<n.attributes.uv.array.length/6;e++)t[0]=n.attributes.uv.array[e*6],t[1]=n.attributes.uv.array[e*6+1],n.attributes.uv.array[e*6]=n.attributes.uv.array[e*6+4],n.attributes.uv.array[e*6+1]=n.attributes.uv.array[e*6+5],n.attributes.uv.array[e*6+4]=t[0],n.attributes.uv.array[e*6+5]=t[1];n.attributes.normal.needsUpdate=!0,n.attributes.position.needsUpdate=!0,n.attributes.uv.needsUpdate=!0}function parseGeometry(n){var t=n.position,e=n.normal,r=n.uv,i=n.uv2,o=n.groups,s=new THREE__namespace.BufferGeometry;s.setAttribute("position",new THREE__namespace.BufferAttribute(new Float32Array(t.array),3)),e&&s.setAttribute("normal",new THREE__namespace.BufferAttribute(new Float32Array(e.array),3)),r&&s.setAttribute("uv",new THREE__namespace.BufferAttribute(new Float32Array(r.array),2)),i&&s.setAttribute("uv2",new THREE__namespace.BufferAttribute(new Float32Array(i.array),2));for(var u=0,l=o;u<l.length;u++){var d=l[u];s.addGroup(d.start,d.count,d.materialIndex)}return s}function loadTexture(n,t,e,r,i,o,s){if(s.hasOwnProperty(n))return s[n];n=n.split("?")[0],isAbsoluteURL(n)||(n=pathJoin(t,n)),n=n.replace(/\/\/vrlab-image\d*.ljcdn.com\//,"//vrlab-public.ljcdn.com/"),n.indexOf("//")===0&&(n="https:"+n);var u=__assign({key:"texture.dome",size:64},pick(e,["quality","format","sharpen","mappings"])),l=s[n]=i.loadTexture(n,{imageURL:{transform:e.transform,options:u},wrapS:THREE__namespace.RepeatWrapping,wrapT:THREE__namespace.RepeatWrapping,fetcher:o}).then(function(d){var c=d.body;return r&&c.repeat.copy(r),c.needsUpdate=!0,c.updateMatrix(),c});return l}function parseMaterial(n,t,e,r,i,o,s){var u=[],l=new PBMMeshMaterial;s.add(l);var d=l.uniforms;d.exposure.value=4.3;var c=l.defines;if(c.USE_MAP=!1,c.USE_UV=!1,n.kd&&(d.diffuse.value=new THREE__namespace.Color().fromArray(n.kd.rgb)),n.mapkd){var f=null;if(n.mapkdrepeat){var h=n.mapkdrepeat.split(/\s+/).map(function(y){return Number(y)}),v=h[0],A=h[1];f=new THREE__namespace.Vector2(v,A)}u.push(loadTexture(n.mapkd,t,e,f,r,i,o).then(function(y){c.USE_MAP=!0,c.USE_UV=!0,d.map.value=y,s.add(y),d.uvTransform.value=y.matrix,l.needsUpdate=!0}).catch(noop$1))}if(n.ks&&(d.specular.value=new THREE__namespace.Color().fromArray(n.ks.rgb)),n.mapks&&u.push(loadTexture(n.mapks,t,e,null,r,i,o).then(function(y){d.specularMap.value=y,s.add(y)}).catch(noop$1)),n.ke&&(d.emissive.value=new THREE__namespace.Color().fromArray(n.ke.rgb)),n.mapke&&u.push(loadTexture(n.mapke,t,e,null,r,i,o).then(function(y){d.emissiveMap.value=y,s.add(y)}).catch(noop$1)),n.norm&&u.push(loadTexture(n.norm,t,e,null,r,i,o).then(function(y){d.normalMap.value=y,s.add(y)}).catch(noop$1)),n.mapbump&&u.push(loadTexture(n.mapbump,t,e,null,r,i,o).then(function(y){d.bumpMap.value=y,s.add(y)}).catch(noop$1)),n.bump&&u.push(loadTexture(n.bump,t,e,null,r,i,o).then(function(y){d.bumpMap.value=y,s.add(y)}).catch(noop$1)),typeof n.ns=="number"&&(d.shininess.value=n.ns),typeof n.d=="number"){var m=n.d;m>0&&m<1&&(l.opacity=m)}return l.floor=0,l.defines.USE_VERTEX_FLOOR=!1,{material:l,textureReady:Promise.all(u).then(noop$1)}}function fromProtoBuf(n){return Model$1.decode(n).meshes}function parse$1(n,t,e,r){for(var i=[],o=[],s=new Set,u=fromProtoBuf(n),l=new TextureLoader,d=new THREE__namespace.Matrix4,c=new THREE__namespace.Vector3,f=new THREE__namespace.Quaternion,h=new THREE__namespace.Vector3,v={},A=0,m=u;A<m.length;A++){var y=m[A],p=y.name,g=y.chunks,b=y.matrix;if(!(p==="Ceiling"||p==="CeilingDrop"))for(var T=0,_=b;T<_.length;T++){var w=_[T];d.elements=w.elements;var x=new THREE__namespace.Group;x.renderOrder=-4;for(var M=0;M<g.length;M++){var R=parseGeometry(g[M].geometry);R.applyMatrix4(d),d.decompose(c,f,h),h.x*h.y*h.z<0&&R.attributes.normal&&R.attributes.position&&R.attributes.uv&&flipBufferGeometryNormals(R),s.add(R);for(var I=[],S=0,B=g[M].material;S<B.length;S++){var F=B[S],O=parseMaterial(F,t||"",e,l,r,v,s),H=O.material,k=O.textureReady;o.push(k),I.push(H)}var N=new PBMMesh(R,I);N.name="chunk_"+M,N.matrix.compose(N.position,N.quaternion,N.scale),N.matrixAutoUpdate=!1,N.frustumCulled=!1,N.renderOrder=-1e3,x.add(N)}x.name=p,i.push(x)}}var q=Promise.all(o).catch(noop$1),V=function(D){return Promise.resolve()};return{createAt:0,description:"",objects:i,texturePromise:q,updateTexture:V,dispose:function(){s.forEach(function(D){D.dispose()}),s.clear()}}}function loadDomez(n,t){var e={byteLength:0};return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"})}).then(function(r){return e.byteLength=r.body.byteLength,lzma(r.body)}).then(function(r){var i=r.reduce(function(u,l){return u+l.length},0),o=new Uint8Array(i),s=0;return r.forEach(function(u){o.set(u,s),s+=u.length}),o}).then(function(r){return parse$1(r,t.textureBaseUri||"",t.textureOptions,t.fetcher)}).then(function(r){var i=new THREE__namespace.Group;i.renderOrder=-4,i.name=n;for(var o=0,s=r.objects;o<s.length;o++){var u=s[o];i.add(u)}return r.texturePromise.then(function(){return{type:"domez",uri:n,byteLength:e.byteLength,object:i,dispose:function(){return r.dispose()}}})})}var ROTATE_X_MATRIX=new THREE__namespace.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]);function loadGlb(n,t){var e=0;return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"}).then(function(r){return e=r.body.byteLength,r.body})}).then(function(r){var i;return parseGltf(r,{copyUV2:!1,addonExtensions:["PBM_mesh"],resourcePath:n.slice(0,n.lastIndexOf("/")+1),search:(i=n.split("?")[1])!==null&&i!==void 0?i:"",fetcher:t.fetcher})}).then(function(r){var i=new THREE__namespace.Matrix4;if(t.upAxis!=="Z"&&i.premultiply(ROTATE_X_MATRIX),r.CESIUM_RTC){var o=new THREE__namespace.Matrix4().setPosition(r.CESIUM_RTC.center);i.premultiply(o)}var s=r.scene;return s.applyMatrix4(i),{type:"glb",uri:n,byteLength:e,object:s,dispose:function(){return r.dispose()}}})}var scratchVector3$2=new THREE__namespace.Vector3,scratchMatrix4$2=new THREE__namespace.Matrix4,refineTimeInterval=30;function attachFloor(n,t){var e=t.tileset.properties.floorInfo;n.traverse(function(r){if("floor"in t.extras)r instanceof PBMMesh?(r.material.forEach(function(g){g.floor=t.extras.floor}),r.renderOrder=-1e3+t.extras.floor):r instanceof PBMPointCloud&&(r.material.floor=t.extras.floor,r.renderOrder=-1e3+t.extras.floor);else if((r instanceof PBMMesh||r instanceof PBMPointCloud)&&e){var i=r.geometry.index,o=r.geometry.getAttribute("position"),s=0,u=new Float32Array(o.count);if(e)if(i){for(var l=0,d=i.count,c=0;c<d;c++){var y=i.array[c];scratchVector3$2.set(o.array[y*3+0],o.array[y*3+1],o.array[y*3+2]),scratchVector3$2.applyMatrix4(r.matrixWorld);var f=scratchVector3$2.y;u[y]=0;for(var h=0;h<e.length;h++){var p=e[h],A=p.ground,m=p.height;if(f<A+m){u[y]=h;break}}l+=u[y]}s=l/d}else{for(var l=0,d=o.count,c=0;c<d;c++){scratchVector3$2.set(o.array[c*3+0],o.array[c*3+1],o.array[c*3+2]),scratchVector3$2.applyMatrix4(r.matrixWorld);var f=scratchVector3$2.y;u[c]=0;for(var h=0;h<e.length;h++){var v=e[h],A=v.ground,m=v.height;if(f<A+m){u[c]=h;break}}l+=u[c]}s=l/d}r.renderOrder=-1e3+s,r.geometry.setAttribute("floor",new THREE__namespace.BufferAttribute(u,1)),Array.isArray(r.material)?r.material.forEach(function(g){g.defines.USE_VERTEX_FLOOR=!0,g.needsUpdate=!0}):(r.material.defines.USE_VERTEX_FLOOR=!0,r.material.needsUpdate=!0)}})}var Tile3DModel=function(n){__extends(t,n);function t(e,r,i,o){var s,u,l,d,c=n.call(this)||this;c.model=e,c.objType=r,c.search=(s=o.search)!==null&&s!==void 0?s:"",c.unloadTileQueue=[],c.boundingBox=new THREE__namespace.Box3,c.minLevelOfDetail=t.DEFAULT_MIN_LEVEL_OF_DETAIL,c.maxLevelOfDetail=t.DEFAULT_MAX_LEVEL_OF_DETAIL,c.needsRefined=!0,c.refined=!1,c.refineProgress=[0,0],c.loaded=!1,c.disposed=!1,c.needsRender=!0,c.matrixAutoUpdate=!1,c.renderOrder=-4,c.lastRefineTime=-1,c.nodes=new Map,c.nodeGroup=new THREE__namespace.Group,c.nodeGroup.matrixAutoUpdate=!1,c.nodeGroup.renderOrder=-4,c.add(c.nodeGroup),c.debugBoundings=new Map,c.debugBoundingGroup=new THREE__namespace.Group,c.debugBoundingGroup.visible=!1,c.debugBoundingGroup.matrixAutoUpdate=!1,c.debugBoundingGroup.renderOrder=-4,c.add(c.debugBoundingGroup),c.cacheCameras=[];var f=normalizeTilesetHeader(i,(u=o.resourcePath)!==null&&u!==void 0?u:"");return c.tileset=new Tileset((d=(l=c.model.work)===null||l===void 0?void 0:l.workCode)!==null&&d!==void 0?d:"",f,{contentLoader:function(h){return c.loadContent(h,{fetcher:o.fetcher})},onTileLoad:function(){},onTileUnload:function(h){c.unloadTileQueue.push(h)},onTileError:function(h,v){o.onError&&o.onError(Object.assign(v,{error:v})),console.error("Tile error",h.id,v)}}),c.tileset.root.boundingVolume&&c.tileset.root.boundingVolume.getBoundingBox(c.boundingBox),c}return Object.defineProperty(t.prototype,"debug",{get:function(){return this.debugBoundingGroup.visible},set:function(e){this.debugBoundingGroup.visible!==e&&(this.debugBoundingGroup.visible=e,this.needsRender=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"maxMemoryUsage",{get:function(){return this.tileset.maxMemoryUsage},set:function(e){this.tileset.maxMemoryUsage=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"maxRequests",{get:function(){return this.tileset.maxRequests},set:function(e){this.tileset.maxRequests=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"maxScreenSpaceError",{get:function(){return this.tileset.maxScreenSpaceError},set:function(e){this.tileset.maxScreenSpaceError=e},enumerable:!1,configurable:!0}),t.prototype.loadContent=function(e,r){var i=this;if(!e.content)return Promise.resolve(!1);var o=e.content,s=appendSearch(o.uri,this.search);if(e.type==="TILESET"){var u=imageURL(s,{key:"model.".concat(e.siblingIndex)});return r.fetcher.ajax(u,{responseType:"text"}).then(function(l){return l.body}).then(function(l){var d=u.slice(0,u.lastIndexOf("/")+1);return normalizeTilesetHeader(JSON.parse(l),d)}).then(function(l){return e.geometricError=l.geometricError,e.children.length===0&&(e.children=[new Tile("".concat(e.id,".0"),l.root,e.tileset,e)]),!0})}return e.type==="SCENEGRAPH"?Promise.resolve().then(function(){var l,d,c,f,h,v,A,m,y,p,g="",b=s.split("#"),T=b[0],_=b[1],w=(_||T).split("?")[0].match(/\.([0-9a-zA-Z]+)$/);if(w&&(g=w[1]),g==="b3dm"){var x=imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadB3dm(x,{upAxis:e.tileset.asset.gltfUpAxis,fetcher:r.fetcher}).then(function(M){return M.object.applyMatrix4(e.transform),M.object.updateWorldMatrix(!1,!0),M.object.matrixAutoUpdate=!1,attachFloor(M.object,e),M})}if(g==="pnts"){var x=imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadPnts(x,{fetcher:r.fetcher,computeBoundingBox:!1}).then(function(R){if(R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,e.boundingVolume){var I=e.boundingVolume;R.object.traverse(function(S){if(S instanceof PBMPointCloud){scratchMatrix4$2.getInverse(S.matrixWorld);var B=new THREE__namespace.Box3;I.getBoundingBox(B),B.applyMatrix4(scratchMatrix4$2),S.geometry.boundingBox=B}})}return R})}if(g==="glb"){var x=imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadGlb(x,{upAxis:e.tileset.asset.gltfUpAxis,fetcher:r.fetcher}).then(function(R){return R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,attachFloor(R.object,e),R})}if(g==="at3d"){var x=e.extras.at3d?s:imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadAt3d(x,{textureBaseUri:(l=e.extras.at3d)===null||l===void 0?void 0:l.textureBaseUri,textureArray:(d=e.extras.at3d)===null||d===void 0?void 0:d.textureArray,textureOptions:(c=e.extras.at3d)===null||c===void 0?void 0:c.textureOptions,fetcher:r.fetcher}).then(function(R){return R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,R})}if(g==="pbm"){var x=e.extras.pbm?s:imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadPbm(x,{textureBaseUri:(f=e.extras.pbm)===null||f===void 0?void 0:f.textureBaseUri,textureArray:(h=e.extras.pbm)===null||h===void 0?void 0:h.textureArray,textureOptions:(v=e.extras.pbm)===null||v===void 0?void 0:v.textureOptions,fetcher:r.fetcher}).then(function(R){return R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,R})}if(g==="dome"){var x=e.extras.dome?s:imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadDome(x,{textureBaseUri:(A=e.extras.dome)===null||A===void 0?void 0:A.textureBaseUri,textureOptions:(m=e.extras.dome)===null||m===void 0?void 0:m.textureOptions,fetcher:r.fetcher}).then(function(R){return R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,R})}if(g==="domez"){var x=e.extras.domez?s:imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadDomez(x,{textureBaseUri:(y=e.extras.domez)===null||y===void 0?void 0:y.textureBaseUri,textureOptions:(p=e.extras.domez)===null||p===void 0?void 0:p.textureOptions,fetcher:r.fetcher}).then(function(R){return R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,R})}}).then(function(l){if(!l)return!1;var d={type:l.type,uri:l.uri,byteLength:l.byteLength,object:new TileNode(l.object,l.dispose)};if(i.disposed)return d.object.dispose(),o.data=void 0,o.byteLength=0,!1;if(d.object.traverse(function(v){(v instanceof PBMPointCloud||v instanceof PBMMesh)&&(v.model=i.model)}),l.type==="pnts"){var c=l.object,f=c.material;f.uniforms.geometricError.value=e.geometricError}if(o.data=d,o.byteLength=d.byteLength,d.object.traverse(function(v){v.renderOrder>-4&&(v.renderOrder=-4)}),d.object.visible=!1,i.boundingBox.expandByObject(d.object),i.nodes.set(e.id,d.object),i.nodeGroup.add(d.object),e.boundingVolume){var h=createDebugBoundingMesh(e.boundingVolume,e.state.selectionDepth);h.matrixWorldNeedsUpdate=!0,h.matrixAutoUpdate=!1,h.frustumCulled=!1,h.visible=!0,i.debugBoundings.set(e.id,h),i.debugBoundingGroup.add(h)}return!0}):Promise.resolve(!1)},t.prototype.intersectRaycaster=function(e,r,i){r===void 0&&(r=!0),i===void 0&&(i=[]);for(var o=[this.tileset.root],s=this.tileset.transform,u;u=o.pop();){var l=void 0;if(u.boundingVolume){var d=u.boundingVolume.clone().applyMatrix4(s);l=d.intersectRay(e.ray,e.far)}else l=!0;if(l){for(var c=0,f=u.children.length;c<f;c++)o.push(u.children[c]);u.selected&&u.content&&u.content.data&&u.content.data.object.intersectRaycaster(e,!1,i)}}return r&&i.sort(function(h,v){return h.distance-v.distance}),i},t.prototype.update=function(e,r){var i=this;this.tileset.transform.equals(this.matrixWorld)||this.tileset.transform.copy(this.matrixWorld);var o=now();if(this.needsRefined&&o-this.lastRefineTime>refineTimeInterval){this.lastRefineTime=o,this.tileset.cache.reset(),this.tileset.frameNumber++;var s={camera:{position:new THREE__namespace.Vector3().copy(r.position),direction:r.getDirection(new THREE__namespace.Vector3),up:new THREE__namespace.Vector3().copy(r.up),visible:r.visible},minLevelOfDetail:this.visible?this.minLevelOfDetail:-1,maxLevelOfDetail:this.visible?this.maxLevelOfDetail:-1,height:r.screenHeight,pixelRatio:r.pixelRatio,frameNumber:this.tileset.frameNumber,sseDenominator:2*Math.tan(.5*r.fov/180*Math.PI),cullingVolume:new CullingVolume().setFromCamera(r)},u=this.cacheCameras.map(function(h){return __assign(__assign({},s),{camera:{position:new THREE__namespace.Vector3().copy(h.position),direction:h.getWorldDirection(new THREE__namespace.Vector3),up:new THREE__namespace.Vector3().copy(h.up),visible:h.visible},cullingVolume:new CullingVolume().setFromCamera(h)})});this.tileset.traverse(s,u),this.refined=!0,this.refineProgress[0]=0,this.refineProgress[1]=0,this.tileset.needsRefinedTiles.forEach(function(h){if(i.refineProgress[1]++,h.content&&h.state.visible){var v=h.content.loadState;if(v==="UNLOADED"||v==="LOADING"){i.refined=!1;return}}i.refineProgress[0]++}),this.loaded===!1&&(this.loaded=!0,this.tileset.needsRefinedTiles.forEach(function(h){if(i.loaded!==!1&&h.content&&h.state.visible&&h.state.selectionDepth===0){var v=h.content.loadState;(v==="UNLOADED"||v==="LOADING")&&(i.loaded=!1)}}))}var l;this.tileset.tiles.forEach(function(h){var v=h.selected,A=h.id;l=i.nodes.get(A),l&&l.visible!==v&&(l.visible=v,i.needsRender=!0),l=i.debugBoundings.get(A),l&&l.visible!==v&&(l.visible=v,i.needsRender=!0)});for(var d;d=this.unloadTileQueue.pop();){var c=d.id,f=d.content;f&&f.data&&(f.data.object.dispose(),f.data=void 0,f.byteLength=0),l=this.nodes.get(c),l&&(this.nodeGroup.remove(l),this.nodes.delete(c),this.needsRender=!0),l=this.debugBoundings.get(c),l&&(this.debugBoundingGroup.remove(l),this.debugBoundings.delete(c),this.needsRender=!0)}},t.prototype.dispose=function(){var e=this;this.disposed=!0,this.tileset.reset();for(var r,i;r=this.unloadTileQueue.pop();){var o=r.id,s=r.content;s&&s.data&&(s.data.object.dispose(),s.data=void 0,s.byteLength=0),i=this.nodes.get(o),i&&(this.nodeGroup.remove(i),this.nodes.delete(o),this.needsRender=!0),i=this.debugBoundings.get(o),i&&(this.debugBoundingGroup.remove(i),this.debugBoundings.delete(o),this.needsRender=!0)}this.nodes.forEach(function(u,l,d){e.nodeGroup.remove(u),u.dispose(),d.delete(l)})},t.DEFAULT_MIN_LEVEL_OF_DETAIL=-1,t.DEFAULT_MAX_LEVEL_OF_DETAIL=20,t.DEFAULT_MAX_MEMORY_USAGE=16,t.DEFAULT_MAX_SCREEN_SPACE_ERROR=Tileset.DEFAULT_MAX_SCREEN_SPACE_ERROR,t.DEFAULT_MAX_REQUESTS=Tileset.DEFAULT_MAX_REQUESTS,t}(THREE__namespace.Object3D);function clamp(n,t,e){return n<t?t:n>e?e:n}function headingToLongitude(n){return-((n-.25)*360+90)/180*Math.PI}function equal(n,t){if(n===t)return!0;if(n&&t&&typeof n=="object"&&typeof t=="object"){if(n.constructor!==t.constructor)return!1;var e,r,i;if(Array.isArray(n)){if(e=n.length,e!=t.length)return!1;for(r=e;r--!==0;)if(!equal(n[r],t[r]))return!1;return!0}if(n.constructor===RegExp)return n.source===t.source&&n.flags===t.flags;if(n.valueOf!==Object.prototype.valueOf)return n.valueOf()===t.valueOf();if(n.toString!==Object.prototype.toString)return n.toString()===t.toString();if(i=Object.keys(n),e=i.length,e!==Object.keys(t).length)return!1;for(r=e;r--!==0;)if(!Object.prototype.hasOwnProperty.call(t,i[r]))return!1;for(r=e;r--!==0;){var o=i[r];if(!equal(n[o],t[o]))return!1}return!0}return n!==n&&t!==t}function isNumber(n){return typeof n=="number"}function isPowerOfTwo(n){return(n&n-1)===0&&n!==0}var error_invalid_input=function(){return new Error("Invalid input.")},error_invalid_certificate=function(){return new Error("Invalid certificate.")},error_invalid_signature=function(){return new Error("Invalid signature.")},error_date_expired=function(n){return new Error("date(".concat(n.toString(),") expired."))},error_host_not_allowed=function(n){return new Error("host(".concat(JSON.stringify(n),") is not allowed."))};function ObjectOmit(n,t){for(var e={},r=0,i=Object.keys(n);r<i.length;r++){var o=i[r];t.indexOf(o)===-1&&(e[o]=n[o])}return e}function jsonStableNoneNumberStrinfiy_(n,t){t===void 0&&(t=!1);var e=typeof n;if(e==="string")return JSON.stringify(n);if(n===!0)return"true";if(n===!1)return"false";if(n===null)return"null";if(n instanceof Array){for(var r="[",i=n.length-1,o=0;o<i;o++)r+=jsonStableNoneNumberStrinfiy_(n[o],!1)+",";return i>-1&&(r+=jsonStableNoneNumberStrinfiy_(n[o],!1)),r+"]"}if(n instanceof Object){if(typeof n.toJSON=="function")return jsonStableNoneNumberStrinfiy_(n.toJSON(),t);for(var s=Object.keys(n).sort(),u=s.length,r="",o=0;o<u;){var l=s[o],d=jsonStableNoneNumberStrinfiy_(n[l],!0);d!==void 0&&(o&&r!==""&&(r+=","),r+=JSON.stringify(l)+":"+d),o++}return"{"+r+"}"}switch(e){case"function":case"undefined":return t?void 0:null;case"number":return 0;default:return isFinite(n)?n:null}}function jsonStableNoneNumberStrinfiy(n){return String(jsonStableNoneNumberStrinfiy_(n,!1))}function verify(n){var t,e,r;if(Array.isArray(n)){var i=void 0,o,s;if(n.length<=0)return error_invalid_input();for(var u=function(_){var w=verify(n[_]);if(w instanceof Error)return{value:w};if(!i)i=w.issuer;else if(i!==w.issuer)return{value:error_invalid_certificate()};o?w.expire.getTime()<o.getTime()&&(o=w.expire):o=w.expire,s?s=s.filter(function(x){return w.allowHosts.indexOf(x)!==-1}):s=w.allowHosts},l=0;l<n.length;l++){var d=u(l);if(typeof d=="object")return d.value}return deepFreeze({issuer:i,expire:o,allowHosts:s})}var c=JSON.parse(n),f=typeof location<"u"?location.hostname:"",h=Date.now();if(typeof c!="object")return error_invalid_input();var v=new Date(typeof c.expire_at=="string"&&/^\d+$/.test(c.expire_at)?Number(c.expire_at):c.expire_at),A=Array.isArray(c.allow_hosts)?c.allow_hosts:[];if(f.length===0||isIPDomain(f)||BUILDIN_ALLOW_HOST.filter(function(_){return matchDomain(_,f)}).length>0){var m=String((t=c.certificate)!==null&&t!==void 0?t:"");if(m){var y=new X509;return y.readCertPEM(m),deepFreeze({issuer:y.getSubjectString(),expire:v,allowHosts:A})}return deepFreeze({issuer:"none",expire:v,allowHosts:A})}var p=String((e=c.certificate)!==null&&e!==void 0?e:"");if(!p)return error_invalid_certificate();var g=new X509;g.readCertPEM(p);var b=String((r=c._signature)!==null&&r!==void 0?r:"");if(!b)return error_invalid_signature();var T=jsonStableNoneNumberStrinfiy(ObjectOmit(c,["_signature"]));return verifyMessage(T,b,g)===!1?error_invalid_signature():h<v.getTime()?A.filter(function(_){return matchDomain(_,f)}).length===0?error_host_not_allowed(f):deepFreeze({issuer:g.getSubjectString(),expire:v,allowHosts:A}):error_date_expired(v)}var scratchMatrix4$1=new THREE__namespace.Matrix4,workRawMapping=new WeakMap,Work=function(){function n(t,e){this.name="",this.workCode="",this.expire=new Date,this.allowHosts=[],this.initial={work:this},this.observers=[],this.issuer="none",this.raw={works:[""],options:""},this.options={transform:new THREE__namespace.Matrix4};var r=parse(t,e,this);if(r instanceof Error)throw new Error("[PARSE FAILED]: "+r.message+`
|
|
946
|
+
`,depthTest:!1,depthWrite:!1,stencilWrite:!1,blending:THREE__namespace.NoBlending,lights:!1,toneMapped:!1}),task=Promise.resolve();function initTexture(n,t){if(!t)return Promise.resolve(n);var e=t.getRenderTarget();t.setRenderTarget(renderTarget),n instanceof THREE__namespace.CubeTexture?(mesh$4.material=cubeTextureMaterial,cubeTextureMaterial.uniforms.map.value=n,t.render(scene$2,camera$2),cubeTextureMaterial.uniforms.map.value=null):(mesh$4.material=textureMaterial,textureMaterial.uniforms.map.value=n,t.render(scene$2,camera$2),cubeTextureMaterial.uniforms.map.value=null),t.setRenderTarget(e);var r=task.then(function(){return new Promise(function(i){AnimationFrameLoop.shared.add(function(){i(n)},!0)})});return task=r.catch(function(){}),r}var commonjsGlobal=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{},indexMinimal={},minimal$1={},aspromise=asPromise;function asPromise(n,t){for(var e=new Array(arguments.length-1),r=0,i=2,o=!0;i<arguments.length;)e[r++]=arguments[i++];return new Promise(function(u,l){e[r]=function(c){if(o)if(o=!1,c)l(c);else{for(var f=new Array(arguments.length-1),h=0;h<f.length;)f[h++]=arguments[h];u.apply(null,f)}};try{n.apply(t||null,e)}catch(d){o&&(o=!1,l(d))}})}var base64$1={};(function(n){var t=n;t.length=function(u){var l=u.length;if(!l)return 0;for(var d=0;--l%4>1&&u.charAt(l)==="=";)++d;return Math.ceil(u.length*3)/4-d};for(var e=new Array(64),r=new Array(123),i=0;i<64;)r[e[i]=i<26?i+65:i<52?i+71:i<62?i-4:i-59|43]=i++;t.encode=function(u,l,d){for(var c=null,f=[],h=0,v=0,A;l<d;){var m=u[l++];switch(v){case 0:f[h++]=e[m>>2],A=(m&3)<<4,v=1;break;case 1:f[h++]=e[A|m>>4],A=(m&15)<<2,v=2;break;case 2:f[h++]=e[A|m>>6],f[h++]=e[m&63],v=0;break}h>8191&&((c||(c=[])).push(String.fromCharCode.apply(String,f)),h=0)}return v&&(f[h++]=e[A],f[h++]=61,v===1&&(f[h++]=61)),c?(h&&c.push(String.fromCharCode.apply(String,f.slice(0,h))),c.join("")):String.fromCharCode.apply(String,f.slice(0,h))};var o="invalid encoding";t.decode=function(u,l,d){for(var c=d,f=0,h,v=0;v<u.length;){var A=u.charCodeAt(v++);if(A===61&&f>1)break;if((A=r[A])===void 0)throw Error(o);switch(f){case 0:h=A,f=1;break;case 1:l[d++]=h<<2|(A&48)>>4,h=A,f=2;break;case 2:l[d++]=(h&15)<<4|(A&60)>>2,h=A,f=3;break;case 3:l[d++]=(h&3)<<6|A,f=0;break}}if(f===1)throw Error(o);return d-c},t.test=function(u){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(u)}})(base64$1);var eventemitter=EventEmitter;function EventEmitter(){this._listeners={}}EventEmitter.prototype.on=function(t,e,r){return(this._listeners[t]||(this._listeners[t]=[])).push({fn:e,ctx:r||this}),this},EventEmitter.prototype.off=function(t,e){if(t===void 0)this._listeners={};else if(e===void 0)this._listeners[t]=[];else for(var r=this._listeners[t],i=0;i<r.length;)r[i].fn===e?r.splice(i,1):++i;return this},EventEmitter.prototype.emit=function(t){var e=this._listeners[t];if(e){for(var r=[],i=1;i<arguments.length;)r.push(arguments[i++]);for(i=0;i<e.length;)e[i].fn.apply(e[i++].ctx,r)}return this};var float=factory(factory);function factory(n){return typeof Float32Array<"u"?function(){var t=new Float32Array([-0]),e=new Uint8Array(t.buffer),r=e[3]===128;function i(l,d,c){t[0]=l,d[c]=e[0],d[c+1]=e[1],d[c+2]=e[2],d[c+3]=e[3]}function o(l,d,c){t[0]=l,d[c]=e[3],d[c+1]=e[2],d[c+2]=e[1],d[c+3]=e[0]}n.writeFloatLE=r?i:o,n.writeFloatBE=r?o:i;function s(l,d){return e[0]=l[d],e[1]=l[d+1],e[2]=l[d+2],e[3]=l[d+3],t[0]}function u(l,d){return e[3]=l[d],e[2]=l[d+1],e[1]=l[d+2],e[0]=l[d+3],t[0]}n.readFloatLE=r?s:u,n.readFloatBE=r?u:s}():function(){function t(r,i,o,s){var u=i<0?1:0;if(u&&(i=-i),i===0)r(1/i>0?0:2147483648,o,s);else if(isNaN(i))r(2143289344,o,s);else if(i>34028234663852886e22)r((u<<31|2139095040)>>>0,o,s);else if(i<11754943508222875e-54)r((u<<31|Math.round(i/1401298464324817e-60))>>>0,o,s);else{var l=Math.floor(Math.log(i)/Math.LN2),d=Math.round(i*Math.pow(2,-l)*8388608)&8388607;r((u<<31|l+127<<23|d)>>>0,o,s)}}n.writeFloatLE=t.bind(null,writeUintLE),n.writeFloatBE=t.bind(null,writeUintBE);function e(r,i,o){var s=r(i,o),u=(s>>31)*2+1,l=s>>>23&255,d=s&8388607;return l===255?d?NaN:u*(1/0):l===0?u*1401298464324817e-60*d:u*Math.pow(2,l-150)*(d+8388608)}n.readFloatLE=e.bind(null,readUintLE),n.readFloatBE=e.bind(null,readUintBE)}(),typeof Float64Array<"u"?function(){var t=new Float64Array([-0]),e=new Uint8Array(t.buffer),r=e[7]===128;function i(l,d,c){t[0]=l,d[c]=e[0],d[c+1]=e[1],d[c+2]=e[2],d[c+3]=e[3],d[c+4]=e[4],d[c+5]=e[5],d[c+6]=e[6],d[c+7]=e[7]}function o(l,d,c){t[0]=l,d[c]=e[7],d[c+1]=e[6],d[c+2]=e[5],d[c+3]=e[4],d[c+4]=e[3],d[c+5]=e[2],d[c+6]=e[1],d[c+7]=e[0]}n.writeDoubleLE=r?i:o,n.writeDoubleBE=r?o:i;function s(l,d){return e[0]=l[d],e[1]=l[d+1],e[2]=l[d+2],e[3]=l[d+3],e[4]=l[d+4],e[5]=l[d+5],e[6]=l[d+6],e[7]=l[d+7],t[0]}function u(l,d){return e[7]=l[d],e[6]=l[d+1],e[5]=l[d+2],e[4]=l[d+3],e[3]=l[d+4],e[2]=l[d+5],e[1]=l[d+6],e[0]=l[d+7],t[0]}n.readDoubleLE=r?s:u,n.readDoubleBE=r?u:s}():function(){function t(r,i,o,s,u,l){var d=s<0?1:0;if(d&&(s=-s),s===0)r(0,u,l+i),r(1/s>0?0:2147483648,u,l+o);else if(isNaN(s))r(0,u,l+i),r(2146959360,u,l+o);else if(s>17976931348623157e292)r(0,u,l+i),r((d<<31|2146435072)>>>0,u,l+o);else{var c;if(s<22250738585072014e-324)c=s/5e-324,r(c>>>0,u,l+i),r((d<<31|c/4294967296)>>>0,u,l+o);else{var f=Math.floor(Math.log(s)/Math.LN2);f===1024&&(f=1023),c=s*Math.pow(2,-f),r(c*4503599627370496>>>0,u,l+i),r((d<<31|f+1023<<20|c*1048576&1048575)>>>0,u,l+o)}}}n.writeDoubleLE=t.bind(null,writeUintLE,0,4),n.writeDoubleBE=t.bind(null,writeUintBE,4,0);function e(r,i,o,s,u){var l=r(s,u+i),d=r(s,u+o),c=(d>>31)*2+1,f=d>>>20&2047,h=4294967296*(d&1048575)+l;return f===2047?h?NaN:c*(1/0):f===0?c*5e-324*h:c*Math.pow(2,f-1075)*(h+4503599627370496)}n.readDoubleLE=e.bind(null,readUintLE,0,4),n.readDoubleBE=e.bind(null,readUintBE,4,0)}(),n}function writeUintLE(n,t,e){t[e]=n&255,t[e+1]=n>>>8&255,t[e+2]=n>>>16&255,t[e+3]=n>>>24}function writeUintBE(n,t,e){t[e]=n>>>24,t[e+1]=n>>>16&255,t[e+2]=n>>>8&255,t[e+3]=n&255}function readUintLE(n,t){return(n[t]|n[t+1]<<8|n[t+2]<<16|n[t+3]<<24)>>>0}function readUintBE(n,t){return(n[t]<<24|n[t+1]<<16|n[t+2]<<8|n[t+3])>>>0}var inquire_1=inquire;function inquire(moduleName){try{var mod=eval("quire".replace(/^/,"re"))(moduleName);if(mod&&(mod.length||Object.keys(mod).length))return mod}catch(n){}return null}var utf8$2={};(function(n){var t=n;t.length=function(r){for(var i=0,o=0,s=0;s<r.length;++s)o=r.charCodeAt(s),o<128?i+=1:o<2048?i+=2:(o&64512)===55296&&(r.charCodeAt(s+1)&64512)===56320?(++s,i+=4):i+=3;return i},t.read=function(r,i,o){var s=o-i;if(s<1)return"";for(var u=null,l=[],d=0,c;i<o;)c=r[i++],c<128?l[d++]=c:c>191&&c<224?l[d++]=(c&31)<<6|r[i++]&63:c>239&&c<365?(c=((c&7)<<18|(r[i++]&63)<<12|(r[i++]&63)<<6|r[i++]&63)-65536,l[d++]=55296+(c>>10),l[d++]=56320+(c&1023)):l[d++]=(c&15)<<12|(r[i++]&63)<<6|r[i++]&63,d>8191&&((u||(u=[])).push(String.fromCharCode.apply(String,l)),d=0);return u?(d&&u.push(String.fromCharCode.apply(String,l.slice(0,d))),u.join("")):String.fromCharCode.apply(String,l.slice(0,d))},t.write=function(r,i,o){for(var s=o,u,l,d=0;d<r.length;++d)u=r.charCodeAt(d),u<128?i[o++]=u:u<2048?(i[o++]=u>>6|192,i[o++]=u&63|128):(u&64512)===55296&&((l=r.charCodeAt(d+1))&64512)===56320?(u=65536+((u&1023)<<10)+(l&1023),++d,i[o++]=u>>18|240,i[o++]=u>>12&63|128,i[o++]=u>>6&63|128,i[o++]=u&63|128):(i[o++]=u>>12|224,i[o++]=u>>6&63|128,i[o++]=u&63|128);return o-s}})(utf8$2);var pool_1=pool;function pool(n,t,e){var r=e||8192,i=r>>>1,o=null,s=r;return function(l){if(l<1||l>i)return n(l);s+l>r&&(o=n(r),s=0);var d=t.call(o,s,s+=l);return s&7&&(s=(s|7)+1),d}}var longbits,hasRequiredLongbits;function requireLongbits(){if(hasRequiredLongbits)return longbits;hasRequiredLongbits=1,longbits=t;var n=requireMinimal();function t(o,s){this.lo=o>>>0,this.hi=s>>>0}var e=t.zero=new t(0,0);e.toNumber=function(){return 0},e.zzEncode=e.zzDecode=function(){return this},e.length=function(){return 1};var r=t.zeroHash="\0\0\0\0\0\0\0\0";t.fromNumber=function(s){if(s===0)return e;var u=s<0;u&&(s=-s);var l=s>>>0,d=(s-l)/4294967296>>>0;return u&&(d=~d>>>0,l=~l>>>0,++l>4294967295&&(l=0,++d>4294967295&&(d=0))),new t(l,d)},t.from=function(s){if(typeof s=="number")return t.fromNumber(s);if(n.isString(s))if(n.Long)s=n.Long.fromString(s);else return t.fromNumber(parseInt(s,10));return s.low||s.high?new t(s.low>>>0,s.high>>>0):e},t.prototype.toNumber=function(s){if(!s&&this.hi>>>31){var u=~this.lo+1>>>0,l=~this.hi>>>0;return u||(l=l+1>>>0),-(u+l*4294967296)}return this.lo+this.hi*4294967296},t.prototype.toLong=function(s){return n.Long?new n.Long(this.lo|0,this.hi|0,!!s):{low:this.lo|0,high:this.hi|0,unsigned:!!s}};var i=String.prototype.charCodeAt;return t.fromHash=function(s){return s===r?e:new t((i.call(s,0)|i.call(s,1)<<8|i.call(s,2)<<16|i.call(s,3)<<24)>>>0,(i.call(s,4)|i.call(s,5)<<8|i.call(s,6)<<16|i.call(s,7)<<24)>>>0)},t.prototype.toHash=function(){return String.fromCharCode(this.lo&255,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,this.hi&255,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},t.prototype.zzEncode=function(){var s=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^s)>>>0,this.lo=(this.lo<<1^s)>>>0,this},t.prototype.zzDecode=function(){var s=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^s)>>>0,this.hi=(this.hi>>>1^s)>>>0,this},t.prototype.length=function(){var s=this.lo,u=(this.lo>>>28|this.hi<<4)>>>0,l=this.hi>>>24;return l===0?u===0?s<16384?s<128?1:2:s<2097152?3:4:u<16384?u<128?5:6:u<2097152?7:8:l<128?9:10},longbits}var hasRequiredMinimal;function requireMinimal(){return hasRequiredMinimal||(hasRequiredMinimal=1,function(n){var t=n;t.asPromise=aspromise,t.base64=base64$1,t.EventEmitter=eventemitter,t.float=float,t.inquire=inquire_1,t.utf8=utf8$2,t.pool=pool_1,t.LongBits=requireLongbits(),t.isNode=!!(typeof commonjsGlobal<"u"&&commonjsGlobal&&commonjsGlobal.process&&commonjsGlobal.process.versions&&commonjsGlobal.process.versions.node),t.global=t.isNode&&commonjsGlobal||typeof window<"u"&&window||typeof self<"u"&&self||commonjsGlobal,t.emptyArray=Object.freeze?Object.freeze([]):[],t.emptyObject=Object.freeze?Object.freeze({}):{},t.isInteger=Number.isInteger||function(o){return typeof o=="number"&&isFinite(o)&&Math.floor(o)===o},t.isString=function(o){return typeof o=="string"||o instanceof String},t.isObject=function(o){return o&&typeof o=="object"},t.isset=t.isSet=function(o,s){var u=o[s];return u!=null&&o.hasOwnProperty(s)?typeof u!="object"||(Array.isArray(u)?u.length:Object.keys(u).length)>0:!1},t.Buffer=function(){try{var i=t.inquire("buffer").Buffer;return i.prototype.utf8Write?i:null}catch{return null}}(),t._Buffer_from=null,t._Buffer_allocUnsafe=null,t.newBuffer=function(o){return typeof o=="number"?t.Buffer?t._Buffer_allocUnsafe(o):new t.Array(o):t.Buffer?t._Buffer_from(o):typeof Uint8Array>"u"?o:new Uint8Array(o)},t.Array=typeof Uint8Array<"u"?Uint8Array:Array,t.Long=t.global.dcodeIO&&t.global.dcodeIO.Long||t.global.Long||t.inquire("long"),t.key2Re=/^true|false|0|1$/,t.key32Re=/^-?(?:0|[1-9][0-9]*)$/,t.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,t.longToHash=function(o){return o?t.LongBits.from(o).toHash():t.LongBits.zeroHash},t.longFromHash=function(o,s){var u=t.LongBits.fromHash(o);return t.Long?t.Long.fromBits(u.lo,u.hi,s):u.toNumber(!!s)};function e(i,o,s){for(var u=Object.keys(o),l=0;l<u.length;++l)(i[u[l]]===void 0||!s)&&(i[u[l]]=o[u[l]]);return i}t.merge=e,t.lcFirst=function(o){return o.charAt(0).toLowerCase()+o.substring(1)};function r(i){function o(s,u){if(!(this instanceof o))return new o(s,u);Object.defineProperty(this,"message",{get:function(){return s}}),Error.captureStackTrace?Error.captureStackTrace(this,o):Object.defineProperty(this,"stack",{value:new Error().stack||""}),u&&e(this,u)}return o.prototype=Object.create(Error.prototype,{constructor:{value:o,writable:!0,enumerable:!1,configurable:!0},name:{get:function(){return i},set:void 0,enumerable:!1,configurable:!0},toString:{value:function(){return this.name+": "+this.message},writable:!0,enumerable:!1,configurable:!0}}),o}t.newError=r,t.ProtocolError=r("ProtocolError"),t.oneOfGetter=function(o){for(var s={},u=0;u<o.length;++u)s[o[u]]=1;return function(){for(var l=Object.keys(this),d=l.length-1;d>-1;--d)if(s[l[d]]===1&&this[l[d]]!==void 0&&this[l[d]]!==null)return l[d]}},t.oneOfSetter=function(o){return function(s){for(var u=0;u<o.length;++u)o[u]!==s&&delete this[o[u]]}},t.toJSONOptions={longs:String,enums:String,bytes:String,json:!0},t._configure=function(){var i=t.Buffer;if(!i){t._Buffer_from=t._Buffer_allocUnsafe=null;return}t._Buffer_from=i.from!==Uint8Array.from&&i.from||function(s,u){return new i(s,u)},t._Buffer_allocUnsafe=i.allocUnsafe||function(s){return new i(s)}}}(minimal$1)),minimal$1}var writer=Writer$1,util$4=requireMinimal(),BufferWriter$1,LongBits$1=util$4.LongBits,base64=util$4.base64,utf8$1=util$4.utf8;function Op(n,t,e){this.fn=n,this.len=t,this.next=void 0,this.val=e}function noop(){}function State(n){this.head=n.head,this.tail=n.tail,this.len=n.len,this.next=n.states}function Writer$1(){this.len=0,this.head=new Op(noop,0,0),this.tail=this.head,this.states=null}var create$1=function n(){return util$4.Buffer?function(){return(Writer$1.create=function(){return new BufferWriter$1})()}:function(){return new Writer$1}};Writer$1.create=create$1(),Writer$1.alloc=function n(t){return new util$4.Array(t)},util$4.Array!==Array&&(Writer$1.alloc=util$4.pool(Writer$1.alloc,util$4.Array.prototype.subarray)),Writer$1.prototype._push=function n(t,e,r){return this.tail=this.tail.next=new Op(t,e,r),this.len+=e,this};function writeByte(n,t,e){t[e]=n&255}function writeVarint32(n,t,e){for(;n>127;)t[e++]=n&127|128,n>>>=7;t[e]=n}function VarintOp(n,t){this.len=n,this.next=void 0,this.val=t}VarintOp.prototype=Object.create(Op.prototype),VarintOp.prototype.fn=writeVarint32,Writer$1.prototype.uint32=function n(t){return this.len+=(this.tail=this.tail.next=new VarintOp((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this},Writer$1.prototype.int32=function n(t){return t<0?this._push(writeVarint64,10,LongBits$1.fromNumber(t)):this.uint32(t)},Writer$1.prototype.sint32=function n(t){return this.uint32((t<<1^t>>31)>>>0)};function writeVarint64(n,t,e){for(;n.hi;)t[e++]=n.lo&127|128,n.lo=(n.lo>>>7|n.hi<<25)>>>0,n.hi>>>=7;for(;n.lo>127;)t[e++]=n.lo&127|128,n.lo=n.lo>>>7;t[e++]=n.lo}Writer$1.prototype.uint64=function n(t){var e=LongBits$1.from(t);return this._push(writeVarint64,e.length(),e)},Writer$1.prototype.int64=Writer$1.prototype.uint64,Writer$1.prototype.sint64=function n(t){var e=LongBits$1.from(t).zzEncode();return this._push(writeVarint64,e.length(),e)},Writer$1.prototype.bool=function n(t){return this._push(writeByte,1,t?1:0)};function writeFixed32(n,t,e){t[e]=n&255,t[e+1]=n>>>8&255,t[e+2]=n>>>16&255,t[e+3]=n>>>24}Writer$1.prototype.fixed32=function n(t){return this._push(writeFixed32,4,t>>>0)},Writer$1.prototype.sfixed32=Writer$1.prototype.fixed32,Writer$1.prototype.fixed64=function n(t){var e=LongBits$1.from(t);return this._push(writeFixed32,4,e.lo)._push(writeFixed32,4,e.hi)},Writer$1.prototype.sfixed64=Writer$1.prototype.fixed64,Writer$1.prototype.float=function n(t){return this._push(util$4.float.writeFloatLE,4,t)},Writer$1.prototype.double=function n(t){return this._push(util$4.float.writeDoubleLE,8,t)};var writeBytes=util$4.Array.prototype.set?function n(t,e,r){e.set(t,r)}:function n(t,e,r){for(var i=0;i<t.length;++i)e[r+i]=t[i]};Writer$1.prototype.bytes=function n(t){var e=t.length>>>0;if(!e)return this._push(writeByte,1,0);if(util$4.isString(t)){var r=Writer$1.alloc(e=base64.length(t));base64.decode(t,r,0),t=r}return this.uint32(e)._push(writeBytes,e,t)},Writer$1.prototype.string=function n(t){var e=utf8$1.length(t);return e?this.uint32(e)._push(utf8$1.write,e,t):this._push(writeByte,1,0)},Writer$1.prototype.fork=function n(){return this.states=new State(this),this.head=this.tail=new Op(noop,0,0),this.len=0,this},Writer$1.prototype.reset=function n(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Op(noop,0,0),this.len=0),this},Writer$1.prototype.ldelim=function n(){var t=this.head,e=this.tail,r=this.len;return this.reset().uint32(r),r&&(this.tail.next=t.next,this.tail=e,this.len+=r),this},Writer$1.prototype.finish=function n(){for(var t=this.head.next,e=this.constructor.alloc(this.len),r=0;t;)t.fn(t.val,e,r),r+=t.len,t=t.next;return e},Writer$1._configure=function(n){BufferWriter$1=n,Writer$1.create=create$1(),BufferWriter$1._configure()};var writer_buffer=BufferWriter,Writer=writer;(BufferWriter.prototype=Object.create(Writer.prototype)).constructor=BufferWriter;var util$3=requireMinimal();function BufferWriter(){Writer.call(this)}BufferWriter._configure=function(){BufferWriter.alloc=util$3._Buffer_allocUnsafe,BufferWriter.writeBytesBuffer=util$3.Buffer&&util$3.Buffer.prototype instanceof Uint8Array&&util$3.Buffer.prototype.set.name==="set"?function(t,e,r){e.set(t,r)}:function(t,e,r){if(t.copy)t.copy(e,r,0,t.length);else for(var i=0;i<t.length;)e[r++]=t[i++]}},BufferWriter.prototype.bytes=function n(t){util$3.isString(t)&&(t=util$3._Buffer_from(t,"base64"));var e=t.length>>>0;return this.uint32(e),e&&this._push(BufferWriter.writeBytesBuffer,e,t),this};function writeStringBuffer(n,t,e){n.length<40?util$3.utf8.write(n,t,e):t.utf8Write?t.utf8Write(n,e):t.write(n,e)}BufferWriter.prototype.string=function n(t){var e=util$3.Buffer.byteLength(t);return this.uint32(e),e&&this._push(writeStringBuffer,e,t),this},BufferWriter._configure();var reader=Reader$1,util$2=requireMinimal(),BufferReader$1,LongBits=util$2.LongBits,utf8=util$2.utf8;function indexOutOfRange(n,t){return RangeError("index out of range: "+n.pos+" + "+(t||1)+" > "+n.len)}function Reader$1(n){this.buf=n,this.pos=0,this.len=n.length}var create_array=typeof Uint8Array<"u"?function n(t){if(t instanceof Uint8Array||Array.isArray(t))return new Reader$1(t);throw Error("illegal buffer")}:function n(t){if(Array.isArray(t))return new Reader$1(t);throw Error("illegal buffer")},create=function n(){return util$2.Buffer?function(e){return(Reader$1.create=function(i){return util$2.Buffer.isBuffer(i)?new BufferReader$1(i):create_array(i)})(e)}:create_array};Reader$1.create=create(),Reader$1.prototype._slice=util$2.Array.prototype.subarray||util$2.Array.prototype.slice,Reader$1.prototype.uint32=function n(){var t=4294967295;return function(){if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,indexOutOfRange(this,10);return t}}(),Reader$1.prototype.int32=function n(){return this.uint32()|0},Reader$1.prototype.sint32=function n(){var t=this.uint32();return t>>>1^-(t&1)|0};function readLongVarint(){var n=new LongBits(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(n.lo=(n.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return n;if(n.lo=(n.lo|(this.buf[this.pos]&127)<<28)>>>0,n.hi=(n.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return n;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(n.lo=(n.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return n}return n.lo=(n.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,n}if(this.len-this.pos>4){for(;t<5;++t)if(n.hi=(n.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return n}else for(;t<5;++t){if(this.pos>=this.len)throw indexOutOfRange(this);if(n.hi=(n.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return n}throw Error("invalid varint encoding")}Reader$1.prototype.bool=function n(){return this.uint32()!==0};function readFixed32_end(n,t){return(n[t-4]|n[t-3]<<8|n[t-2]<<16|n[t-1]<<24)>>>0}Reader$1.prototype.fixed32=function n(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return readFixed32_end(this.buf,this.pos+=4)},Reader$1.prototype.sfixed32=function n(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);return readFixed32_end(this.buf,this.pos+=4)|0};function readFixed64(){if(this.pos+8>this.len)throw indexOutOfRange(this,8);return new LongBits(readFixed32_end(this.buf,this.pos+=4),readFixed32_end(this.buf,this.pos+=4))}Reader$1.prototype.float=function n(){if(this.pos+4>this.len)throw indexOutOfRange(this,4);var t=util$2.float.readFloatLE(this.buf,this.pos);return this.pos+=4,t},Reader$1.prototype.double=function n(){if(this.pos+8>this.len)throw indexOutOfRange(this,4);var t=util$2.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,t},Reader$1.prototype.bytes=function n(){var t=this.uint32(),e=this.pos,r=this.pos+t;if(r>this.len)throw indexOutOfRange(this,t);if(this.pos+=t,Array.isArray(this.buf))return this.buf.slice(e,r);if(e===r){var i=util$2.Buffer;return i?i.alloc(0):new this.buf.constructor(0)}return this._slice.call(this.buf,e,r)},Reader$1.prototype.string=function n(){var t=this.bytes();return utf8.read(t,0,t.length)},Reader$1.prototype.skip=function n(t){if(typeof t=="number"){if(this.pos+t>this.len)throw indexOutOfRange(this,t);this.pos+=t}else do if(this.pos>=this.len)throw indexOutOfRange(this);while(this.buf[this.pos++]&128);return this},Reader$1.prototype.skipType=function(n){switch(n){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(n=this.uint32()&7)!==4;)this.skipType(n);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+n+" at offset "+this.pos)}return this},Reader$1._configure=function(n){BufferReader$1=n,Reader$1.create=create(),BufferReader$1._configure();var t=util$2.Long?"toLong":"toNumber";util$2.merge(Reader$1.prototype,{int64:function(){return readLongVarint.call(this)[t](!1)},uint64:function(){return readLongVarint.call(this)[t](!0)},sint64:function(){return readLongVarint.call(this).zzDecode()[t](!1)},fixed64:function(){return readFixed64.call(this)[t](!0)},sfixed64:function(){return readFixed64.call(this)[t](!1)}})};var reader_buffer=BufferReader,Reader=reader;(BufferReader.prototype=Object.create(Reader.prototype)).constructor=BufferReader;var util$1=requireMinimal();function BufferReader(n){Reader.call(this,n)}BufferReader._configure=function(){util$1.Buffer&&(BufferReader.prototype._slice=util$1.Buffer.prototype.slice)},BufferReader.prototype.string=function n(){var t=this.uint32();return this.buf.utf8Slice?this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+t,this.len)):this.buf.toString("utf-8",this.pos,this.pos=Math.min(this.pos+t,this.len))},BufferReader._configure();var rpc={},service=Service,util=requireMinimal();(Service.prototype=Object.create(util.EventEmitter.prototype)).constructor=Service;function Service(n,t,e){if(typeof n!="function")throw TypeError("rpcImpl must be a function");util.EventEmitter.call(this),this.rpcImpl=n,this.requestDelimited=!!t,this.responseDelimited=!!e}Service.prototype.rpcCall=function n(t,e,r,i,o){if(!i)throw TypeError("request must be specified");var s=this;if(!o)return util.asPromise(n,s,t,e,r,i);if(!s.rpcImpl){setTimeout(function(){o(Error("already ended"))},0);return}try{return s.rpcImpl(t,e[s.requestDelimited?"encodeDelimited":"encode"](i).finish(),function(l,d){if(l)return s.emit("error",l,t),o(l);if(d===null){s.end(!0);return}if(!(d instanceof r))try{d=r[s.responseDelimited?"decodeDelimited":"decode"](d)}catch(c){return s.emit("error",c,t),o(c)}return s.emit("data",d,t),o(null,d)})}catch(u){s.emit("error",u,t),setTimeout(function(){o(u)},0);return}},Service.prototype.end=function n(t){return this.rpcImpl&&(t||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this},function(n){var t=n;t.Service=service}(rpc);var roots={};(function(n){var t=n;t.build="minimal",t.Writer=writer,t.BufferWriter=writer_buffer,t.Reader=reader,t.BufferReader=reader_buffer,t.util=requireMinimal(),t.rpc=rpc,t.roots=roots,t.configure=e;function e(){t.util._configure(),t.Writer._configure(t.BufferWriter),t.Reader._configure(t.BufferReader)}e()})(indexMinimal);var minimal=indexMinimal;const $Reader$1=minimal.Reader,$util$1=minimal.util,$root$1=minimal.roots["@REALSEE/FIVE:five/loaders/model/proto/pbm.proto"]||(minimal.roots["@REALSEE/FIVE:five/loaders/model/proto/pbm.proto"]={}),Model$2=$root$1.Model=(()=>{function n(t){if(this.chunks=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.chunks=$util$1.emptyArray,n.prototype.createAt=$util$1.Long?$util$1.Long.fromBits(0,0,!0):0,n.prototype.description="",n.decode=function(e,r){e instanceof $Reader$1||(e=$Reader$1.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root$1.Model;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.chunks&&o.chunks.length||(o.chunks=[]),o.chunks.push($root$1.Chunk.decode(e,e.uint32()));break}case 2:{o.createAt=e.uint64();break}case 3:{o.description=e.string();break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Model"},n})();$root$1.Chunk=(()=>{function n(t){if(t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.vertices=null,n.prototype.faces=null,n.prototype.name="",n.prototype.texture="",n.decode=function(e,r){e instanceof $Reader$1||(e=$Reader$1.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root$1.Chunk;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.vertices=$root$1.Vertices.decode(e,e.uint32());break}case 2:{o.faces=$root$1.Faces.decode(e,e.uint32());break}case 3:{o.name=e.string();break}case 4:{o.texture=e.string();break}default:e.skipType(s&7);break}}if(!o.hasOwnProperty("vertices"))throw $util$1.ProtocolError("missing required 'vertices'",{instance:o});if(!o.hasOwnProperty("faces"))throw $util$1.ProtocolError("missing required 'faces'",{instance:o});if(!o.hasOwnProperty("name"))throw $util$1.ProtocolError("missing required 'name'",{instance:o});return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Chunk"},n})(),$root$1.Vertices=(()=>{function n(t){if(this.xyz=[],this.uvs=[],this.marks=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.xyz=$util$1.emptyArray,n.prototype.uvs=$util$1.emptyArray,n.prototype.marks=$util$1.emptyArray,n.decode=function(e,r){e instanceof $Reader$1||(e=$Reader$1.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root$1.Vertices;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.xyz&&o.xyz.length||(o.xyz=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.xyz.push(e.float())}else o.xyz.push(e.float());break}case 2:{if(o.uvs&&o.uvs.length||(o.uvs=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.uvs.push(e.float())}else o.uvs.push(e.float());break}case 3:{if(o.marks&&o.marks.length||(o.marks=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.marks.push(e.int32())}else o.marks.push(e.int32());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Vertices"},n})(),$root$1.Faces=(()=>{function n(t){if(this.indices=[],this.normals=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.indices=$util$1.emptyArray,n.prototype.normals=$util$1.emptyArray,n.decode=function(e,r){e instanceof $Reader$1||(e=$Reader$1.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root$1.Faces;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.indices&&o.indices.length||(o.indices=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.indices.push(e.uint32())}else o.indices.push(e.uint32());break}case 2:{if(o.normals&&o.normals.length||(o.normals=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.normals.push(e.float())}else o.normals.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Faces"},n})(),$root$1.VertexMark=(()=>{const n={},t=Object.create(n);return t[n[0]="VERTEX_MARK_UNSPECIFIED"]=0,t[n[1]="VERTEX_MARK_ROOF"]=1,t})();function loadPbm(n,t){var e,r,i,o={byteLength:0},s=autoRestImageOptionsByTextureLength((e=t.textureOptions)!==null&&e!==void 0?e:{},(i=(r=t.textureArray)===null||r===void 0?void 0:r.length)!==null&&i!==void 0?i:0),u={};if(t.textureArray)for(var l=0,d=t.textureArray;l<d.length;l++){var c=d[l];u[c]=loadTexture$1(c,s,t.fetcher)}return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"})}).then(function(f){return o.byteLength=f.body.byteLength,delay(function(){var h=new Uint8Array(f.body);return Model$2.decode(h)})}).then(function(f){return delay(function(){var h,v;return parse$2(f,(h=t.textureBaseUri)!==null&&h!==void 0?h:function(){var A=n.lastIndexOf("/");if(A>=0){var m=n.slice(0,A)+"/";return/\/model\/$/.test(m)&&(m=m.replace(/\/model\/$/,"/materials/")),m}return""}(),((v=t.textureArray)!==null&&v!==void 0?v:[]).slice(),s,u,t.fetcher)})}).then(function(f){var h=new THREE__namespace.Group;h.renderOrder=-4,h.matrixAutoUpdate=!1,h.matrix.compose(h.position,h.quaternion,h.scale),h.name=n;for(var v=0,A=f.objects;v<A.length;v++){var m=A[v];h.add(m)}return f.texturePromise.then(function(){return{type:"pbm",uri:n,byteLength:o.byteLength,object:h,dispose:function(){return f.dispose()}}})})}var MODEL_FLIP_MATRIX=new THREE__namespace.Matrix4().set(1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1),E=MODEL_FLIP_MATRIX.elements;function parseFloorName(n){var t=n.match(/(group|floor)-?(\d+)/);return t?parseInt(t[2],10):0}function parseChunkName(n){var t=n.match(/(chunk)-?(\d+)/);return t?parseInt(t[2],10):0}function parseSubName(n){var t=n.match(/(sub)-?(\d+)/);return t?parseInt(t[2],10):0}function chunkOrder(n){var t=parseFloorName(n.name),e=parseChunkName(n.name),r=parseSubName(n.name);return t*1e6+e*1e3+r}function parsePBMModel(n){for(var t,e,r,i=typeof n.createAt=="number"?n.createAt:0,o=(t=n.description)!==null&&t!==void 0?t:"",s=[],u=!0,l=!0,d=0,c=n.chunks;d<c.length;d++){var f=c[d];if(!f.vertices.marks||f.vertices.marks.length===0){l=!1;break}}for(var h=0,v=n.chunks;h<v.length;h++){var f=v[h];if(!f.faces.normals||f.faces.normals.length===0){u=!1;break}}for(var A=n.chunks.sort(function(De,qe){return chunkOrder(De)-chunkOrder(qe)}),m=[],y=0,p=A;y<p.length;y++){var f=p[y],g=parseFloorName(f.name);m[g]||(m[g]=[]),m[g].push(f)}for(var b=0;b<m.length;b++){var T=m[b];if(T)if(u){for(var _=0,w=0;w<T.length;w++){var f=T[w];_+=f.faces.indices.length}for(var x=new Float32Array(_*3),M=new Float32Array(_),R=new Float32Array(_*2),I=new Float32Array(_*3),S=[],B=[1/0,1/0,1/0,-1/0,-1/0,-1/0],O=0,F=0;F<T.length;F++){for(var H=[1/0,1/0,1/0,-1/0,-1/0,-1/0],f=T[F],k=f.vertices.xyz,N=f.vertices.uvs,q=f.faces.indices,V=f.faces.normals,D=f.vertices.marks,K=q.length,w=0;w<K;w++){var z=q[w],G=k[z*3],W=k[z*3+1],Q=k[z*3+2],X=1/(E[3]*G+E[7]*W+E[11]*Q+E[15]),ee=(E[0]*G+E[4]*W+E[8]*Q+E[12])*X,J=(E[1]*G+E[5]*W+E[9]*Q+E[13])*X,Z=(E[2]*G+E[6]*W+E[10]*Q+E[14])*X;x[O*3+w*3]=ee,x[O*3+w*3+1]=J,x[O*3+w*3+2]=Z,M[O+w]=l?D[z]:0,R[O*2+w*2]=N[z*2],R[O*2+w*2+1]=N[z*2+1];var te=Math.floor(w/3)*3,ae=V[te],re=V[te+1],ie=V[te+2],de=1/(E[3]*ae+E[7]*re+E[11]*ie+E[15]),se=(E[0]*ae+E[4]*re+E[8]*ie+E[12])*de,pe=(E[1]*ae+E[5]*re+E[9]*ie+E[13])*de,$=(E[2]*ae+E[6]*re+E[10]*ie+E[14])*de;I[O*3+w*3]=se,I[O*3+w*3+1]=pe,I[O*3+w*3+2]=$,ee<H[0]&&(H[0]=ee),J<H[1]&&(H[1]=J),Z<H[2]&&(H[2]=Z),ee>H[3]&&(H[3]=ee),J>H[4]&&(H[4]=J),Z>H[5]&&(H[5]=Z)}H[0]<B[0]&&(B[0]=H[0]),H[1]<B[1]&&(B[1]=H[1]),H[2]<B[2]&&(B[2]=H[2]),H[3]>B[3]&&(B[3]=H[3]),H[4]>B[4]&&(B[4]=H[4]),H[5]>B[5]&&(B[5]=H[5]),S.push({materialIndex:F,name:f.name,chunkName:parseChunkName(f.name),start:O,count:f.faces.indices.length,texture:(e=f.texture)!==null&&e!==void 0?e:void 0}),O+=K}var oe={createAt:i,description:o,vertices:x,uvs:R,normals:I,indices:null,floorIndex:b,groups:S,extents:B,vertexMarks:M};s.push(oe)}else{for(var _=0,j=0,w=0;w<T.length;w++){var f=T[w];j+=f.vertices.xyz.length/3,_+=f.faces.indices.length}for(var x=new Float32Array(j*3),R=new Float32Array(j*2),I=new Float32Array(j*3),ve=new Float32Array(j),me=new Uint32Array(_),M=new Float32Array(_),S=[],B=[1/0,1/0,1/0,-1/0,-1/0,-1/0],Me=0,O=0,F=0;F<T.length;F++){for(var H=[1/0,1/0,1/0,-1/0,-1/0,-1/0],f=T[F],k=f.vertices.xyz,D=f.vertices.marks,N=f.vertices.uvs,q=f.faces.indices,Re=k.length/3,K=q.length,w=0;w<Re;w++){var G=k[w*3],W=k[w*3+1],Q=k[w*3+2],X=1/(E[3]*G+E[7]*W+E[11]*Q+E[15]),ee=(E[0]*G+E[4]*W+E[8]*Q+E[12])*X,J=(E[1]*G+E[5]*W+E[9]*Q+E[13])*X,Z=(E[2]*G+E[6]*W+E[10]*Q+E[14])*X;x[O*3+w*3]=ee,x[O*3+w*3+1]=J,x[O*3+w*3+2]=Z,M[O+w]=l?D[w]:0,R[O*2+w*2]=N[w*2],R[O*2+w*2+1]=N[w*2+1],ve[O+w]=b,ee<H[0]&&(H[0]=ee),J<H[1]&&(H[1]=J),Z<H[2]&&(H[2]=Z),ee>H[3]&&(H[3]=ee),J>H[4]&&(H[4]=J),Z>H[5]&&(H[5]=Z)}H[0]<B[0]&&(B[0]=H[0]),H[1]<B[1]&&(B[1]=H[1]),H[2]<B[2]&&(B[2]=H[2]),H[3]>B[3]&&(B[3]=H[3]),H[4]>B[4]&&(B[4]=H[4]),H[5]>B[5]&&(B[5]=H[5]);for(var w=0;w<K;w++)me[Me+w]=O+q[w];S.push({materialIndex:F,name:f.name,chunkName:parseChunkName(f.name),start:Me,count:f.faces.indices.length,texture:(r=f.texture)!==null&&r!==void 0?r:void 0}),O+=Re,Me+=K}for(var w=0;w<_;w+=3){var ge=void 0,we=void 0,Ae=void 0,le=void 0,ue=void 0,Fe=void 0,fe=void 0,Se=void 0,ye=void 0,ke=void 0,_e=void 0,We=void 0,Xe=void 0,Ee=void 0,Pe=void 0,Je=void 0,be=void 0,Oe=void 0,ae=void 0,re=void 0,ie=void 0;ge=me[w]*3,we=me[w+1]*3,Ae=me[w+2]*3,le=x[ge],ue=x[ge+1],Fe=x[ge+2],fe=x[we],Se=x[we+1],ye=x[we+2],ke=x[Ae],_e=x[Ae+1],We=x[Ae+2],Xe=ke-fe,Ee=_e-Se,Pe=We-ye,Je=le-fe,be=ue-Se,Oe=Fe-ye,ae=Ee*Oe-Pe*be,re=Pe*Je-Xe*Oe,ie=Xe*be-Ee*Je,I[ge]+=ae,I[ge+1]+=re,I[ge+2]+=ie,I[we]+=ae,I[we+1]+=re,I[we+2]+=ie,I[Ae]+=ae,I[Ae+1]+=re,I[Ae+2]+=ie}var oe={createAt:i,description:o,vertices:x,uvs:R,normals:I,indices:me,floorIndex:b,groups:S,extents:B,vertexMarks:M};s.push(oe)}}return s}function loadTexture$1(n,t,e,r){var i=__assign({key:"texture.pbm"},pick(t,["format","quality","size","sharpen","mappings"])),o=new TextureLoader,s=o.loadTexture(n,{imageURL:{transform:t.transform,options:i},wrapS:THREE__namespace.ClampToEdgeWrapping,wrapT:THREE__namespace.ClampToEdgeWrapping,minFilter:THREE__namespace.LinearFilter,maxSize:typeof i.size=="number"?new THREE__namespace.Vector2(i.size,i.size):void 0,fetcher:e}).then(function(u){var l=u.body;return l.needsUpdate=!0,initTexture(l,r)});return Object.assign(s,{url:n,textureOptions:t})}function parse$2(n,t,e,r,i,o,s){i===void 0&&(i={});for(var u=parsePBMModel(n),l=0,d="",c=[],f={},h=new Set,v=0,A=u;v<A.length;v++){var m=A[v],y=m.createAt,p=m.description,g=m.vertices,b=m.vertexMarks,T=m.uvs,_=m.normals,w=m.indices,x=m.floorIndex,M=m.groups,R=m.extents,I=new THREE__namespace.Box3;I.min.x=R[0],I.min.y=R[1],I.min.z=R[2],I.max.x=R[3],I.max.y=R[4],I.max.z=R[5];var S=new THREE__namespace.BufferGeometry;S.setAttribute("position",new THREE__namespace.BufferAttribute(g,3)),S.setAttribute("uv",new THREE__namespace.BufferAttribute(T,2)),S.setAttribute("normal",new THREE__namespace.BufferAttribute(_,3)),S.setAttribute("isRoofMark",new THREE__namespace.BufferAttribute(b,1)),w&&S.setIndex(new THREE__namespace.BufferAttribute(w,1)),S.boundingBox=I,S.boundingSphere=I.getBoundingSphere(new THREE__namespace.Sphere);for(var B=0,O=M;B<O.length;B++){var F=O[B];S.addGroup(F.start,F.count,F.materialIndex)}h.add(S);for(var H=[],k=0,N=M;k<N.length;k++){var F=N[k],q=e[F.chunkName]||(F.texture?pathJoin(t||"",F.texture):void 0),V=new PBMMeshMaterial;V.defines.USE_VERTEX_FLOOR=!1,V.floor=x,H.push(V),q?f[q]?f[q].push(V):f[q]=[V]:(V.defines.USE_MAP=!1,V.uniforms.diffuse.value=new THREE__namespace.Color(16777215)),h.add(V)}var D=new PBMMesh(S,H);D.name="model_floor_"+x,D.userData.createAt=y,D.userData.description=p,D.matrix.compose(D.position,D.quaternion,D.scale),D.matrixAutoUpdate=!1,D.frustumCulled=!1,D.renderOrder=-1e3+x,l=y,d=p,c.push(D)}var K="",z=function(W){W=autoRestImageOptionsByTextureLength(W,e.length);var Q=[],X=jsonHash(W);if(K===X)return Promise.resolve();K=X;for(var ee=function(ae){var re=null;ae in i&&(jsonHash(i[ae].textureOptions)===jsonHash(W)?re=i[ae]:i[ae].then(function(ie){return ie.dispose()})),re||(re=loadTexture$1(ae,W,o,s)),Q.push(re.then(function(ie){if(K!==X){ie.dispose();return}for(var de=0,se=f[ae];de<se.length;de++){var pe=se[de];pe.uniforms.map.value&&(h.delete(pe.uniforms.map.value),pe.uniforms.map.value.dispose()),pe.uniforms.map.value=ie,h.add(ie),pe.uniforms.exposure.value=3.3}}).catch(function(){if(K===X)for(var ie=0,de=f[ae];ie<de.length;ie++){var se=de[ie];se.uniforms.map.value&&(h.delete(se.uniforms.map.value),se.uniforms.map.value.dispose()),se.uniforms.map.value=null,se.defines.USE_MAP=!1,se.uniforms.diffuse.value=new THREE__namespace.Color(16777215)}}))},J=0,Z=Object.keys(f);J<Z.length;J++){var te=Z[J];ee(te)}for(var te in i)delete i[te];return Promise.all(Q).then(function(){})},G=z(r);return{createAt:l,description:d,objects:c,texturePromise:G,updateTexture:z,dispose:function(){h.forEach(function(W){W.dispose()}),h.clear()}}}function autoRestImageOptionsByTextureLength(n,t){return n=Object.assign({},n),n.autoResize!==!1&&(t>96?n.size=Math.min(n.size||1/0,100):t>48?n.size=Math.min(n.size||1/0,200):t>24?n.size=Math.min(n.size||1/0,400):t>22?n.size=Math.min(n.size||1/0,800):t>5&&(n.size=Math.min(n.size||1/0,1024))),n}function loadAt3d(n,t){var e,r,i,o={byteLength:0},s=autoRestImageOptionsByTextureLength((e=t.textureOptions)!==null&&e!==void 0?e:{},(i=(r=t.textureArray)===null||r===void 0?void 0:r.length)!==null&&i!==void 0?i:0),u={};if(t.textureArray)for(var l=0,d=t.textureArray;l<d.length;l++){var c=d[l];u[c]=loadTexture$1(c,s,t.fetcher)}return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"})}).then(function(f){return lzma(f.body)}).then(function(f){return delay(function(){for(var h,v={chunks:[],createAt:void 0,description:void 0},A=0,m=f;A<m.length;A++){var y=m[A],p=Model$2.decode(y);p.chunks.length&&((h=v.chunks).push.apply(h,p.chunks),v.createAt=p.createAt,v.description=p.description)}return v})}).then(function(f){return delay(function(){var h,v,A;return parse$2(f,(h=t.textureBaseUri)!==null&&h!==void 0?h:function(){var m=n.lastIndexOf("/");if(m>=0){var y=n.slice(0,m)+"/";return/\/model\/$/.test(y)&&(y=y.replace(/\/model\/$/,"/materials/")),y}return""}(),((v=t.textureArray)!==null&&v!==void 0?v:[]).slice(),(A=t.textureOptions)!==null&&A!==void 0?A:{},u,t.fetcher)})}).then(function(f){var h=new THREE__namespace.Group;h.renderOrder=-4,h.name=n;for(var v=0,A=f.objects;v<A.length;v++){var m=A[v];h.add(m)}return f.texturePromise.then(function(){return{type:"at3d",uri:n,byteLength:o.byteLength,object:h,dispose:function(){return f.dispose()}}})})}const $Reader=minimal.Reader,$util=minimal.util,$root=minimal.roots["@REALSEE/FIVE:five/loaders/model/proto/dome.proto"]||(minimal.roots["@REALSEE/FIVE:five/loaders/model/proto/dome.proto"]={}),Model$1=$root.Model=(()=>{function n(t){if(this.meshes=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.meshes=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Model;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.meshes&&o.meshes.length||(o.meshes=[]),o.meshes.push($root.Mesh.decode(e,e.uint32()));break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Model"},n})();$root.Mesh=(()=>{function n(t){if(this.chunks=[],this.matrix=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.name="",n.prototype.chunks=$util.emptyArray,n.prototype.matrix=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Mesh;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.name=e.string();break}case 2:{o.chunks&&o.chunks.length||(o.chunks=[]),o.chunks.push($root.Chunk.decode(e,e.uint32()));break}case 3:{o.matrix&&o.matrix.length||(o.matrix=[]),o.matrix.push($root.Matrix.decode(e,e.uint32()));break}default:e.skipType(s&7);break}}if(!o.hasOwnProperty("name"))throw $util.ProtocolError("missing required 'name'",{instance:o});return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Mesh"},n})(),$root.Matrix=(()=>{function n(t){if(this.elements=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.elements=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Matrix;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.elements&&o.elements.length||(o.elements=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.elements.push(e.float())}else o.elements.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Matrix"},n})(),$root.Chunk=(()=>{function n(t){if(this.material=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.geometry=null,n.prototype.material=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Chunk;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 2:{o.geometry=$root.Geometry.decode(e,e.uint32());break}case 3:{o.material&&o.material.length||(o.material=[]),o.material.push($root.Material.decode(e,e.uint32()));break}default:e.skipType(s&7);break}}if(!o.hasOwnProperty("geometry"))throw $util.ProtocolError("missing required 'geometry'",{instance:o});return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Chunk"},n})(),$root.Geometry=(()=>{function n(t){if(this.groups=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.position=null,n.prototype.uv=null,n.prototype.uv2=null,n.prototype.normal=null,n.prototype.groups=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Geometry;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.position=$root.Position.decode(e,e.uint32());break}case 2:{o.uv=$root.UV.decode(e,e.uint32());break}case 3:{o.uv2=$root.UV.decode(e,e.uint32());break}case 4:{o.normal=$root.Normal.decode(e,e.uint32());break}case 5:{o.groups&&o.groups.length||(o.groups=[]),o.groups.push($root.Group.decode(e,e.uint32()));break}default:e.skipType(s&7);break}}if(!o.hasOwnProperty("position"))throw $util.ProtocolError("missing required 'position'",{instance:o});if(!o.hasOwnProperty("normal"))throw $util.ProtocolError("missing required 'normal'",{instance:o});return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Geometry"},n})(),$root.Position=(()=>{function n(t){if(this.array=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.array=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Position;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.array&&o.array.length||(o.array=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.array.push(e.float())}else o.array.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Position"},n})(),$root.UV=(()=>{function n(t){if(this.array=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.array=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.UV;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.array&&o.array.length||(o.array=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.array.push(e.float())}else o.array.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/UV"},n})(),$root.Normal=(()=>{function n(t){if(this.array=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.array=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Normal;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.array&&o.array.length||(o.array=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.array.push(e.float())}else o.array.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Normal"},n})(),$root.Group=(()=>{function n(t){if(t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.start=0,n.prototype.count=0,n.prototype.materialIndex=0,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Group;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.start=e.uint32();break}case 2:{o.count=e.uint32();break}case 3:{o.materialIndex=e.uint32();break}default:e.skipType(s&7);break}}if(!o.hasOwnProperty("start"))throw $util.ProtocolError("missing required 'start'",{instance:o});if(!o.hasOwnProperty("count"))throw $util.ProtocolError("missing required 'count'",{instance:o});if(!o.hasOwnProperty("materialIndex"))throw $util.ProtocolError("missing required 'materialIndex'",{instance:o});return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Group"},n})(),$root.Material=(()=>{function n(t){if(t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.kd=null,n.prototype.ks=null,n.prototype.ke=null,n.prototype.mapkd="",n.prototype.mapks="",n.prototype.mapke="",n.prototype.norm="",n.prototype.mapbump="",n.prototype.bump="",n.prototype.mapd="",n.prototype.ns=0,n.prototype.d=0,n.prototype.tr=0,n.prototype.mapkdrepeat="",n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Material;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{o.kd=$root.Color.decode(e,e.uint32());break}case 2:{o.ks=$root.Color.decode(e,e.uint32());break}case 3:{o.ke=$root.Color.decode(e,e.uint32());break}case 4:{o.mapkd=e.string();break}case 5:{o.mapks=e.string();break}case 6:{o.mapke=e.string();break}case 7:{o.norm=e.string();break}case 8:{o.mapbump=e.string();break}case 9:{o.bump=e.string();break}case 10:{o.mapd=e.string();break}case 11:{o.ns=e.float();break}case 12:{o.d=e.float();break}case 13:{o.tr=e.float();break}case 14:{o.mapkdrepeat=e.string();break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Material"},n})(),$root.Color=(()=>{function n(t){if(this.rgb=[],t)for(let e=Object.keys(t),r=0;r<e.length;++r)t[e[r]]!=null&&(this[e[r]]=t[e[r]])}return n.prototype.rgb=$util.emptyArray,n.decode=function(e,r){e instanceof $Reader||(e=$Reader.create(e));let i=r===void 0?e.len:e.pos+r,o=new $root.Color;for(;e.pos<i;){let s=e.uint32();switch(s>>>3){case 1:{if(o.rgb&&o.rgb.length||(o.rgb=[]),(s&7)===2){let u=e.uint32()+e.pos;for(;e.pos<u;)o.rgb.push(e.float())}else o.rgb.push(e.float());break}default:e.skipType(s&7);break}}return o},n.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/Color"},n})();function loadDome(n,t){var e={byteLength:0};return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"})}).then(function(r){return e.byteLength=r.body.byteLength,parse$1(new Uint8Array(r.body),t.textureBaseUri||"",t.textureOptions,t.fetcher)}).then(function(r){var i=new THREE__namespace.Group;i.renderOrder=-4,i.matrixAutoUpdate=!1,i.matrix.compose(i.position,i.quaternion,i.scale),i.name=n;for(var o=0,s=r.objects;o<s.length;o++){var u=s[o];i.add(u)}return r.texturePromise.then(function(){return{type:"dome",uri:n,byteLength:e.byteLength,object:i,dispose:function(){return r.dispose()}}})})}function flipBufferGeometryNormals(n){for(var t=[0,0,0],e=0;e<n.attributes.normal.array.length/9;e++)t[0]=n.attributes.normal.array[e*9],t[1]=n.attributes.normal.array[e*9+1],t[2]=n.attributes.normal.array[e*9+2],n.attributes.normal.array[e*9]=n.attributes.normal.array[e*9+6],n.attributes.normal.array[e*9+1]=n.attributes.normal.array[e*9+7],n.attributes.normal.array[e*9+2]=n.attributes.normal.array[e*9+8],n.attributes.normal.array[e*9+6]=t[0],n.attributes.normal.array[e*9+7]=t[1],n.attributes.normal.array[e*9+8]=t[2];for(var e=0;e<n.attributes.position.array.length/9;e++)t[0]=n.attributes.position.array[e*9],t[1]=n.attributes.position.array[e*9+1],t[2]=n.attributes.position.array[e*9+2],n.attributes.position.array[e*9]=n.attributes.position.array[e*9+6],n.attributes.position.array[e*9+1]=n.attributes.position.array[e*9+7],n.attributes.position.array[e*9+2]=n.attributes.position.array[e*9+8],n.attributes.position.array[e*9+6]=t[0],n.attributes.position.array[e*9+7]=t[1],n.attributes.position.array[e*9+8]=t[2];for(var e=0;e<n.attributes.uv.array.length/6;e++)t[0]=n.attributes.uv.array[e*6],t[1]=n.attributes.uv.array[e*6+1],n.attributes.uv.array[e*6]=n.attributes.uv.array[e*6+4],n.attributes.uv.array[e*6+1]=n.attributes.uv.array[e*6+5],n.attributes.uv.array[e*6+4]=t[0],n.attributes.uv.array[e*6+5]=t[1];n.attributes.normal.needsUpdate=!0,n.attributes.position.needsUpdate=!0,n.attributes.uv.needsUpdate=!0}function parseGeometry(n){var t=n.position,e=n.normal,r=n.uv,i=n.uv2,o=n.groups,s=new THREE__namespace.BufferGeometry;s.setAttribute("position",new THREE__namespace.BufferAttribute(new Float32Array(t.array),3)),e&&s.setAttribute("normal",new THREE__namespace.BufferAttribute(new Float32Array(e.array),3)),r&&s.setAttribute("uv",new THREE__namespace.BufferAttribute(new Float32Array(r.array),2)),i&&s.setAttribute("uv2",new THREE__namespace.BufferAttribute(new Float32Array(i.array),2));for(var u=0,l=o;u<l.length;u++){var d=l[u];s.addGroup(d.start,d.count,d.materialIndex)}return s}function loadTexture(n,t,e,r,i,o,s){if(s.hasOwnProperty(n))return s[n];n=n.split("?")[0],isAbsoluteURL(n)||(n=pathJoin(t,n)),n=n.replace(/\/\/vrlab-image\d*.ljcdn.com\//,"//vrlab-public.ljcdn.com/"),n.indexOf("//")===0&&(n="https:"+n);var u=__assign({key:"texture.dome",size:64},pick(e,["quality","format","sharpen","mappings"])),l=s[n]=i.loadTexture(n,{imageURL:{transform:e.transform,options:u},wrapS:THREE__namespace.RepeatWrapping,wrapT:THREE__namespace.RepeatWrapping,fetcher:o}).then(function(d){var c=d.body;return r&&c.repeat.copy(r),c.needsUpdate=!0,c.updateMatrix(),c});return l}function parseMaterial(n,t,e,r,i,o,s){var u=[],l=new PBMMeshMaterial;s.add(l);var d=l.uniforms;d.exposure.value=4.3;var c=l.defines;if(c.USE_MAP=!1,c.USE_UV=!1,n.kd&&(d.diffuse.value=new THREE__namespace.Color().fromArray(n.kd.rgb)),n.mapkd){var f=null;if(n.mapkdrepeat){var h=n.mapkdrepeat.split(/\s+/).map(function(y){return Number(y)}),v=h[0],A=h[1];f=new THREE__namespace.Vector2(v,A)}u.push(loadTexture(n.mapkd,t,e,f,r,i,o).then(function(y){c.USE_MAP=!0,c.USE_UV=!0,d.map.value=y,s.add(y),d.uvTransform.value=y.matrix,l.needsUpdate=!0}).catch(noop$1))}if(n.ks&&(d.specular.value=new THREE__namespace.Color().fromArray(n.ks.rgb)),n.mapks&&u.push(loadTexture(n.mapks,t,e,null,r,i,o).then(function(y){d.specularMap.value=y,s.add(y)}).catch(noop$1)),n.ke&&(d.emissive.value=new THREE__namespace.Color().fromArray(n.ke.rgb)),n.mapke&&u.push(loadTexture(n.mapke,t,e,null,r,i,o).then(function(y){d.emissiveMap.value=y,s.add(y)}).catch(noop$1)),n.norm&&u.push(loadTexture(n.norm,t,e,null,r,i,o).then(function(y){d.normalMap.value=y,s.add(y)}).catch(noop$1)),n.mapbump&&u.push(loadTexture(n.mapbump,t,e,null,r,i,o).then(function(y){d.bumpMap.value=y,s.add(y)}).catch(noop$1)),n.bump&&u.push(loadTexture(n.bump,t,e,null,r,i,o).then(function(y){d.bumpMap.value=y,s.add(y)}).catch(noop$1)),typeof n.ns=="number"&&(d.shininess.value=n.ns),typeof n.d=="number"){var m=n.d;m>0&&m<1&&(l.opacity=m)}return l.floor=0,l.defines.USE_VERTEX_FLOOR=!1,{material:l,textureReady:Promise.all(u).then(noop$1)}}function fromProtoBuf(n){return Model$1.decode(n).meshes}function parse$1(n,t,e,r){for(var i=[],o=[],s=new Set,u=fromProtoBuf(n),l=new TextureLoader,d=new THREE__namespace.Matrix4,c=new THREE__namespace.Vector3,f=new THREE__namespace.Quaternion,h=new THREE__namespace.Vector3,v={},A=0,m=u;A<m.length;A++){var y=m[A],p=y.name,g=y.chunks,b=y.matrix;if(!(p==="Ceiling"||p==="CeilingDrop"))for(var T=0,_=b;T<_.length;T++){var w=_[T];d.elements=w.elements;var x=new THREE__namespace.Group;x.renderOrder=-4;for(var M=0;M<g.length;M++){var R=parseGeometry(g[M].geometry);R.applyMatrix4(d),d.decompose(c,f,h),h.x*h.y*h.z<0&&R.attributes.normal&&R.attributes.position&&R.attributes.uv&&flipBufferGeometryNormals(R),s.add(R);for(var I=[],S=0,B=g[M].material;S<B.length;S++){var O=B[S],F=parseMaterial(O,t||"",e,l,r,v,s),H=F.material,k=F.textureReady;o.push(k),I.push(H)}var N=new PBMMesh(R,I);N.name="chunk_"+M,N.matrix.compose(N.position,N.quaternion,N.scale),N.matrixAutoUpdate=!1,N.frustumCulled=!1,N.renderOrder=-1e3,x.add(N)}x.name=p,i.push(x)}}var q=Promise.all(o).catch(noop$1),V=function(D){return Promise.resolve()};return{createAt:0,description:"",objects:i,texturePromise:q,updateTexture:V,dispose:function(){s.forEach(function(D){D.dispose()}),s.clear()}}}function loadDomez(n,t){var e={byteLength:0};return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"})}).then(function(r){return e.byteLength=r.body.byteLength,lzma(r.body)}).then(function(r){var i=r.reduce(function(u,l){return u+l.length},0),o=new Uint8Array(i),s=0;return r.forEach(function(u){o.set(u,s),s+=u.length}),o}).then(function(r){return parse$1(r,t.textureBaseUri||"",t.textureOptions,t.fetcher)}).then(function(r){var i=new THREE__namespace.Group;i.renderOrder=-4,i.name=n;for(var o=0,s=r.objects;o<s.length;o++){var u=s[o];i.add(u)}return r.texturePromise.then(function(){return{type:"domez",uri:n,byteLength:e.byteLength,object:i,dispose:function(){return r.dispose()}}})})}var ROTATE_X_MATRIX=new THREE__namespace.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]);function loadGlb(n,t){var e=0;return Promise.resolve().then(function(){return t.fetcher.ajax(n,{responseType:"arraybuffer"}).then(function(r){return e=r.body.byteLength,r.body})}).then(function(r){var i;return parseGltf(r,{copyUV2:!1,addonExtensions:["PBM_mesh"],resourcePath:n.slice(0,n.lastIndexOf("/")+1),search:(i=n.split("?")[1])!==null&&i!==void 0?i:"",fetcher:t.fetcher})}).then(function(r){var i=new THREE__namespace.Matrix4;if(t.upAxis!=="Z"&&i.premultiply(ROTATE_X_MATRIX),r.CESIUM_RTC){var o=new THREE__namespace.Matrix4().setPosition(r.CESIUM_RTC.center);i.premultiply(o)}var s=r.scene;return s.applyMatrix4(i),{type:"glb",uri:n,byteLength:e,object:s,dispose:function(){return r.dispose()}}})}var scratchVector3$2=new THREE__namespace.Vector3,scratchMatrix4$2=new THREE__namespace.Matrix4,refineTimeInterval=30;function attachFloor(n,t){var e=t.tileset.properties.floorInfo;n.traverse(function(r){if("floor"in t.extras)r instanceof PBMMesh?(r.material.forEach(function(g){g.floor=t.extras.floor}),r.renderOrder=-1e3+t.extras.floor):r instanceof PBMPointCloud&&(r.material.floor=t.extras.floor,r.renderOrder=-1e3+t.extras.floor);else if((r instanceof PBMMesh||r instanceof PBMPointCloud)&&e){var i=r.geometry.index,o=r.geometry.getAttribute("position"),s=0,u=new Float32Array(o.count);if(e)if(i){for(var l=0,d=i.count,c=0;c<d;c++){var y=i.array[c];scratchVector3$2.set(o.array[y*3+0],o.array[y*3+1],o.array[y*3+2]),scratchVector3$2.applyMatrix4(r.matrixWorld);var f=scratchVector3$2.y;u[y]=0;for(var h=0;h<e.length;h++){var p=e[h],A=p.ground,m=p.height;if(f<A+m){u[y]=h;break}}l+=u[y]}s=l/d}else{for(var l=0,d=o.count,c=0;c<d;c++){scratchVector3$2.set(o.array[c*3+0],o.array[c*3+1],o.array[c*3+2]),scratchVector3$2.applyMatrix4(r.matrixWorld);var f=scratchVector3$2.y;u[c]=0;for(var h=0;h<e.length;h++){var v=e[h],A=v.ground,m=v.height;if(f<A+m){u[c]=h;break}}l+=u[c]}s=l/d}r.renderOrder=-1e3+s,r.geometry.setAttribute("floor",new THREE__namespace.BufferAttribute(u,1)),Array.isArray(r.material)?r.material.forEach(function(g){g.defines.USE_VERTEX_FLOOR=!0,g.needsUpdate=!0}):(r.material.defines.USE_VERTEX_FLOOR=!0,r.material.needsUpdate=!0)}})}var Tile3DModel=function(n){__extends(t,n);function t(e,r,i,o){var s,u,l,d,c=n.call(this)||this;c.model=e,c.objType=r,c.search=(s=o.search)!==null&&s!==void 0?s:"",c.unloadTileQueue=[],c.boundingBox=new THREE__namespace.Box3,c.minLevelOfDetail=t.DEFAULT_MIN_LEVEL_OF_DETAIL,c.maxLevelOfDetail=t.DEFAULT_MAX_LEVEL_OF_DETAIL,c.needsRefined=!0,c.refined=!1,c.refineProgress=[0,0],c.loaded=!1,c.disposed=!1,c.needsRender=!0,c.matrixAutoUpdate=!1,c.renderOrder=-4,c.lastRefineTime=-1,c.nodes=new Map,c.nodeGroup=new THREE__namespace.Group,c.nodeGroup.matrixAutoUpdate=!1,c.nodeGroup.renderOrder=-4,c.add(c.nodeGroup),c.debugBoundings=new Map,c.debugBoundingGroup=new THREE__namespace.Group,c.debugBoundingGroup.visible=!1,c.debugBoundingGroup.matrixAutoUpdate=!1,c.debugBoundingGroup.renderOrder=-4,c.add(c.debugBoundingGroup),c.cacheCameras=[];var f=normalizeTilesetHeader(i,(u=o.resourcePath)!==null&&u!==void 0?u:"");return c.tileset=new Tileset((d=(l=c.model.work)===null||l===void 0?void 0:l.workCode)!==null&&d!==void 0?d:"",f,{contentLoader:function(h){return c.loadContent(h,{fetcher:o.fetcher})},onTileLoad:function(){},onTileUnload:function(h){c.unloadTileQueue.push(h)},onTileError:function(h,v){o.onError&&o.onError(Object.assign(v,{error:v})),console.error("Tile error",h.id,v)}}),c.tileset.root.boundingVolume&&c.tileset.root.boundingVolume.getBoundingBox(c.boundingBox),c}return Object.defineProperty(t.prototype,"debug",{get:function(){return this.debugBoundingGroup.visible},set:function(e){this.debugBoundingGroup.visible!==e&&(this.debugBoundingGroup.visible=e,this.needsRender=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"maxMemoryUsage",{get:function(){return this.tileset.maxMemoryUsage},set:function(e){this.tileset.maxMemoryUsage=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"maxRequests",{get:function(){return this.tileset.maxRequests},set:function(e){this.tileset.maxRequests=e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"maxScreenSpaceError",{get:function(){return this.tileset.maxScreenSpaceError},set:function(e){this.tileset.maxScreenSpaceError=e},enumerable:!1,configurable:!0}),t.prototype.loadContent=function(e,r){var i=this;if(!e.content)return Promise.resolve(!1);var o=e.content,s=appendSearch(o.uri,this.search);if(e.type==="TILESET"){var u=imageURL(s,{key:"model.".concat(e.siblingIndex)});return r.fetcher.ajax(u,{responseType:"text"}).then(function(l){return l.body}).then(function(l){var d=u.slice(0,u.lastIndexOf("/")+1);return normalizeTilesetHeader(JSON.parse(l),d)}).then(function(l){return e.geometricError=l.geometricError,e.children.length===0&&(e.children=[new Tile("".concat(e.id,".0"),l.root,e.tileset,e)]),!0})}return e.type==="SCENEGRAPH"?Promise.resolve().then(function(){var l,d,c,f,h,v,A,m,y,p,g="",b=s.split("#"),T=b[0],_=b[1],w=(_||T).split("?")[0].match(/\.([0-9a-zA-Z]+)$/);if(w&&(g=w[1]),g==="b3dm"){var x=imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadB3dm(x,{upAxis:e.tileset.asset.gltfUpAxis,fetcher:r.fetcher}).then(function(M){return M.object.applyMatrix4(e.transform),M.object.updateWorldMatrix(!1,!0),M.object.matrixAutoUpdate=!1,attachFloor(M.object,e),M})}if(g==="pnts"){var x=imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadPnts(x,{fetcher:r.fetcher,computeBoundingBox:!1}).then(function(R){if(R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,e.boundingVolume){var I=e.boundingVolume;R.object.traverse(function(S){if(S instanceof PBMPointCloud){scratchMatrix4$2.getInverse(S.matrixWorld);var B=new THREE__namespace.Box3;I.getBoundingBox(B),B.applyMatrix4(scratchMatrix4$2),S.geometry.boundingBox=B}})}return R})}if(g==="glb"){var x=imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadGlb(x,{upAxis:e.tileset.asset.gltfUpAxis,fetcher:r.fetcher}).then(function(R){return R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,attachFloor(R.object,e),R})}if(g==="at3d"){var x=e.extras.at3d?s:imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadAt3d(x,{textureBaseUri:(l=e.extras.at3d)===null||l===void 0?void 0:l.textureBaseUri,textureArray:(d=e.extras.at3d)===null||d===void 0?void 0:d.textureArray,textureOptions:(c=e.extras.at3d)===null||c===void 0?void 0:c.textureOptions,fetcher:r.fetcher}).then(function(R){return R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,R})}if(g==="pbm"){var x=e.extras.pbm?s:imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadPbm(x,{textureBaseUri:(f=e.extras.pbm)===null||f===void 0?void 0:f.textureBaseUri,textureArray:(h=e.extras.pbm)===null||h===void 0?void 0:h.textureArray,textureOptions:(v=e.extras.pbm)===null||v===void 0?void 0:v.textureOptions,fetcher:r.fetcher}).then(function(R){return R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,R})}if(g==="dome"){var x=e.extras.dome?s:imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadDome(x,{textureBaseUri:(A=e.extras.dome)===null||A===void 0?void 0:A.textureBaseUri,textureOptions:(m=e.extras.dome)===null||m===void 0?void 0:m.textureOptions,fetcher:r.fetcher}).then(function(R){return R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,R})}if(g==="domez"){var x=e.extras.domez?s:imageURL(s,{key:"model.".concat(e.siblingIndex)});return loadDomez(x,{textureBaseUri:(y=e.extras.domez)===null||y===void 0?void 0:y.textureBaseUri,textureOptions:(p=e.extras.domez)===null||p===void 0?void 0:p.textureOptions,fetcher:r.fetcher}).then(function(R){return R.object.applyMatrix4(e.transform),R.object.updateWorldMatrix(!1,!0),R.object.matrixAutoUpdate=!1,R})}}).then(function(l){if(!l)return!1;var d={type:l.type,uri:l.uri,byteLength:l.byteLength,object:new TileNode(l.object,l.dispose)};if(i.disposed)return d.object.dispose(),o.data=void 0,o.byteLength=0,!1;if(d.object.traverse(function(v){(v instanceof PBMPointCloud||v instanceof PBMMesh)&&(v.model=i.model)}),l.type==="pnts"){var c=l.object,f=c.material;f.uniforms.geometricError.value=e.geometricError}if(o.data=d,o.byteLength=d.byteLength,d.object.traverse(function(v){v.renderOrder>-4&&(v.renderOrder=-4)}),d.object.visible=!1,i.boundingBox.expandByObject(d.object),i.nodes.set(e.id,d.object),i.nodeGroup.add(d.object),e.boundingVolume){var h=createDebugBoundingMesh(e.boundingVolume,e.state.selectionDepth);h.matrixWorldNeedsUpdate=!0,h.matrixAutoUpdate=!1,h.frustumCulled=!1,h.visible=!0,i.debugBoundings.set(e.id,h),i.debugBoundingGroup.add(h)}return!0}):Promise.resolve(!1)},t.prototype.intersectRaycaster=function(e,r,i){r===void 0&&(r=!0),i===void 0&&(i=[]);for(var o=[this.tileset.root],s=this.tileset.transform,u;u=o.pop();){var l=void 0;if(u.boundingVolume){var d=u.boundingVolume.clone().applyMatrix4(s);l=d.intersectRay(e.ray,e.far)}else l=!0;if(l){for(var c=0,f=u.children.length;c<f;c++)o.push(u.children[c]);u.selected&&u.content&&u.content.data&&u.content.data.object.intersectRaycaster(e,!1,i)}}return r&&i.sort(function(h,v){return h.distance-v.distance}),i},t.prototype.update=function(e,r){var i=this;this.tileset.transform.equals(this.matrixWorld)||this.tileset.transform.copy(this.matrixWorld);var o=now();if(this.needsRefined&&o-this.lastRefineTime>refineTimeInterval){this.lastRefineTime=o,this.tileset.cache.reset(),this.tileset.frameNumber++;var s={camera:{position:new THREE__namespace.Vector3().copy(r.position),direction:r.getDirection(new THREE__namespace.Vector3),up:new THREE__namespace.Vector3().copy(r.up),visible:r.visible},minLevelOfDetail:this.visible?this.minLevelOfDetail:-1,maxLevelOfDetail:this.visible?this.maxLevelOfDetail:-1,height:r.screenHeight,pixelRatio:r.pixelRatio,frameNumber:this.tileset.frameNumber,sseDenominator:2*Math.tan(.5*r.fov/180*Math.PI),cullingVolume:new CullingVolume().setFromCamera(r)},u=this.cacheCameras.map(function(h){return __assign(__assign({},s),{camera:{position:new THREE__namespace.Vector3().copy(h.position),direction:h.getWorldDirection(new THREE__namespace.Vector3),up:new THREE__namespace.Vector3().copy(h.up),visible:h.visible},cullingVolume:new CullingVolume().setFromCamera(h)})});this.tileset.traverse(s,u),this.refined=!0,this.refineProgress[0]=0,this.refineProgress[1]=0,this.tileset.needsRefinedTiles.forEach(function(h){if(i.refineProgress[1]++,h.content&&h.state.visible){var v=h.content.loadState;if(v==="UNLOADED"||v==="LOADING"){i.refined=!1;return}}i.refineProgress[0]++}),this.loaded===!1&&(this.loaded=!0,this.tileset.needsRefinedTiles.forEach(function(h){if(i.loaded!==!1&&h.content&&h.state.visible&&h.state.selectionDepth===0){var v=h.content.loadState;(v==="UNLOADED"||v==="LOADING")&&(i.loaded=!1)}}))}var l;this.tileset.tiles.forEach(function(h){var v=h.selected,A=h.id;l=i.nodes.get(A),l&&l.visible!==v&&(l.visible=v,i.needsRender=!0),l=i.debugBoundings.get(A),l&&l.visible!==v&&(l.visible=v,i.needsRender=!0)});for(var d;d=this.unloadTileQueue.pop();){var c=d.id,f=d.content;f&&f.data&&(f.data.object.dispose(),f.data=void 0,f.byteLength=0),l=this.nodes.get(c),l&&(this.nodeGroup.remove(l),this.nodes.delete(c),this.needsRender=!0),l=this.debugBoundings.get(c),l&&(this.debugBoundingGroup.remove(l),this.debugBoundings.delete(c),this.needsRender=!0)}},t.prototype.dispose=function(){var e=this;this.disposed=!0,this.tileset.reset();for(var r,i;r=this.unloadTileQueue.pop();){var o=r.id,s=r.content;s&&s.data&&(s.data.object.dispose(),s.data=void 0,s.byteLength=0),i=this.nodes.get(o),i&&(this.nodeGroup.remove(i),this.nodes.delete(o),this.needsRender=!0),i=this.debugBoundings.get(o),i&&(this.debugBoundingGroup.remove(i),this.debugBoundings.delete(o),this.needsRender=!0)}this.nodes.forEach(function(u,l,d){e.nodeGroup.remove(u),u.dispose(),d.delete(l)})},t.DEFAULT_MIN_LEVEL_OF_DETAIL=-1,t.DEFAULT_MAX_LEVEL_OF_DETAIL=20,t.DEFAULT_MAX_MEMORY_USAGE=16,t.DEFAULT_MAX_SCREEN_SPACE_ERROR=Tileset.DEFAULT_MAX_SCREEN_SPACE_ERROR,t.DEFAULT_MAX_REQUESTS=Tileset.DEFAULT_MAX_REQUESTS,t}(THREE__namespace.Object3D);function clamp(n,t,e){return n<t?t:n>e?e:n}function headingToLongitude(n){return-((n-.25)*360+90)/180*Math.PI}function equal(n,t){if(n===t)return!0;if(n&&t&&typeof n=="object"&&typeof t=="object"){if(n.constructor!==t.constructor)return!1;var e,r,i;if(Array.isArray(n)){if(e=n.length,e!=t.length)return!1;for(r=e;r--!==0;)if(!equal(n[r],t[r]))return!1;return!0}if(n.constructor===RegExp)return n.source===t.source&&n.flags===t.flags;if(n.valueOf!==Object.prototype.valueOf)return n.valueOf()===t.valueOf();if(n.toString!==Object.prototype.toString)return n.toString()===t.toString();if(i=Object.keys(n),e=i.length,e!==Object.keys(t).length)return!1;for(r=e;r--!==0;)if(!Object.prototype.hasOwnProperty.call(t,i[r]))return!1;for(r=e;r--!==0;){var o=i[r];if(!equal(n[o],t[o]))return!1}return!0}return n!==n&&t!==t}function isNumber(n){return typeof n=="number"}function isPowerOfTwo(n){return(n&n-1)===0&&n!==0}var error_invalid_input=function(){return new Error("Invalid input.")},error_invalid_certificate=function(){return new Error("Invalid certificate.")},error_invalid_signature=function(){return new Error("Invalid signature.")},error_date_expired=function(n){return new Error("date(".concat(n.toString(),") expired."))},error_host_not_allowed=function(n){return new Error("host(".concat(JSON.stringify(n),") is not allowed."))};function ObjectOmit(n,t){for(var e={},r=0,i=Object.keys(n);r<i.length;r++){var o=i[r];t.indexOf(o)===-1&&(e[o]=n[o])}return e}function jsonStableNoneNumberStrinfiy_(n,t){t===void 0&&(t=!1);var e=typeof n;if(e==="string")return JSON.stringify(n);if(n===!0)return"true";if(n===!1)return"false";if(n===null)return"null";if(n instanceof Array){for(var r="[",i=n.length-1,o=0;o<i;o++)r+=jsonStableNoneNumberStrinfiy_(n[o],!1)+",";return i>-1&&(r+=jsonStableNoneNumberStrinfiy_(n[o],!1)),r+"]"}if(n instanceof Object){if(typeof n.toJSON=="function")return jsonStableNoneNumberStrinfiy_(n.toJSON(),t);for(var s=Object.keys(n).sort(),u=s.length,r="",o=0;o<u;){var l=s[o],d=jsonStableNoneNumberStrinfiy_(n[l],!0);d!==void 0&&(o&&r!==""&&(r+=","),r+=JSON.stringify(l)+":"+d),o++}return"{"+r+"}"}switch(e){case"function":case"undefined":return t?void 0:null;case"number":return 0;default:return isFinite(n)?n:null}}function jsonStableNoneNumberStrinfiy(n){return String(jsonStableNoneNumberStrinfiy_(n,!1))}function verify(n){var t,e,r;if(Array.isArray(n)){var i=void 0,o,s;if(n.length<=0)return error_invalid_input();for(var u=function(_){var w=verify(n[_]);if(w instanceof Error)return{value:w};if(!i)i=w.issuer;else if(i!==w.issuer)return{value:error_invalid_certificate()};o?w.expire.getTime()<o.getTime()&&(o=w.expire):o=w.expire,s?s=s.filter(function(x){return w.allowHosts.indexOf(x)!==-1}):s=w.allowHosts},l=0;l<n.length;l++){var d=u(l);if(typeof d=="object")return d.value}return deepFreeze({issuer:i,expire:o,allowHosts:s})}var c=JSON.parse(n),f=typeof location<"u"?location.hostname:"",h=Date.now();if(typeof c!="object")return error_invalid_input();var v=new Date(typeof c.expire_at=="string"&&/^\d+$/.test(c.expire_at)?Number(c.expire_at):c.expire_at),A=Array.isArray(c.allow_hosts)?c.allow_hosts:[];if(f.length===0||isIPDomain(f)||BUILDIN_ALLOW_HOST.filter(function(_){return matchDomain(_,f)}).length>0){var m=String((t=c.certificate)!==null&&t!==void 0?t:"");if(m){var y=new X509;return y.readCertPEM(m),deepFreeze({issuer:y.getSubjectString(),expire:v,allowHosts:A})}return deepFreeze({issuer:"none",expire:v,allowHosts:A})}var p=String((e=c.certificate)!==null&&e!==void 0?e:"");if(!p)return error_invalid_certificate();var g=new X509;g.readCertPEM(p);var b=String((r=c._signature)!==null&&r!==void 0?r:"");if(!b)return error_invalid_signature();var T=jsonStableNoneNumberStrinfiy(ObjectOmit(c,["_signature"]));return verifyMessage(T,b,g)===!1?error_invalid_signature():h<v.getTime()?A.filter(function(_){return matchDomain(_,f)}).length===0?error_host_not_allowed(f):deepFreeze({issuer:g.getSubjectString(),expire:v,allowHosts:A}):error_date_expired(v)}var scratchMatrix4$1=new THREE__namespace.Matrix4,workRawMapping=new WeakMap,Work=function(){function n(t,e){this.name="",this.workCode="",this.expire=new Date,this.allowHosts=[],this.initial={work:this},this.observers=[],this.issuer="none",this.raw={works:[""],options:""},this.options={transform:new THREE__namespace.Matrix4};var r=parse(t,e,this);if(r instanceof Error)throw new Error("[PARSE FAILED]: "+r.message+`
|
|
947
947
|
Error work input:
|
|
948
|
-
`+JSON.stringify(t))}return n.prototype.toJSON=function(){return this.raw},n.parse=parseWork,n}();function getType(n){return n==null?"null":Array.isArray(n)?"array":typeof n=="object"?"dict":"value"}function deepMerge(n,t){var e=getType(n),r=getType(t);if(r==="null")return n;if(r==="value")return t;if(r!==e)return JSON.parse(JSON.stringify(t));if(r==="array")for(var i=0;i<t.length;i++)n[i]=deepMerge(n[i],t[i]);else if(r==="dict")for(var o in t)n[o]=deepMerge(n[o],t[o]);return n}function startWithString(n,t){return n.indexOf(t)===0}function urlWithParseOptions(n,t,e,r){var i,o=t;if(r.jsonp===!0){o=t.replace(/([\?\#].*)?$/i,"");var s=sha256("".concat(o)).slice(0,7);o="".concat(o,".").concat(s,".jsonp")}if(r.shortPath===!0){var u=o.replace(n,"").split("."),l=(i=u.shift())!==null&&i!==void 0?i:"",d=u.join(".");o=pathJoin(n,sha256(l))+(d?"."+d:"")}var c=o.replace(n,"");return r.baseURL&&(o=pathJoin(r.baseURL,c)),o}function panoURL(n,t,e,r,i){var o=e;return isAbsoluteURL(e)||(t&&(t=pathJoin(t,String(r))),o=pathJoin(t,o)),isAbsoluteURL(o)||(o=pathJoin(n,o)),startWithString(o,n)||console.warn("".concat(o," is not start with base_url(").concat(n,").")),urlWithParseOptions(n,o,"panorama",i)}function fileURL(n,t,e){var r=t;return isAbsoluteURL(r)||(r=pathJoin(n,t)),startWithString(r,n)||console.warn("".concat(r," is not start with base_url(").concat(n,").")),urlWithParseOptions(n,r,"model",e)}function textureURL$1(n,t,e,r){var i=t;return isAbsoluteURL(i)||(i=pathJoin(e,i)),isAbsoluteURL(i)||(i=pathJoin(n,i)),startWithString(i,n)||console.warn("".concat(i," is not start with base_url(").concat(n,").")),urlWithParseOptions(n,i,"texture",r)}function parse(n,t,e){for(var r,i,o,s,u,l,d,c,f,h,v,A,m,y,p,g,b,T,_=JSON.stringify(t),w=[],x=0,M=[].concat(n);x<M.length;x++){var R=M[x];R instanceof Work?w.push.apply(w,R.raw.works):typeof R=="string"?w.push(R):w.push(JSON.stringify(R))}var I=verify(w);if(I instanceof Error)return I;t=JSON.parse(_);var S={transform:new THREE__namespace.Matrix4};typeof t.debug<"u"&&(S.debug=t.debug),t.transform&&(Array.isArray(t.transform)?S.transform.fromArray(t.transform):S.transform.copy(t.transform)),t.viewerRequestVolume&&("clone"in t.viewerRequestVolume?S.viewerRequestVolume=t.viewerRequestVolume.clone():S.viewerRequestVolume=makeBoundingVolume(t.viewerRequestVolume)),typeof t.modelMinLevelOfDetail<"u"&&t.modelMinLevelOfDetail>=0&&(S.modelMinLevelOfDetail=t.modelMinLevelOfDetail),typeof t.modelMaxLevelOfDetail<"u"&&t.modelMaxLevelOfDetail>=0&&(S.modelMaxLevelOfDetail=t.modelMaxLevelOfDetail),typeof t.modelMaxRequests<"u"&&t.modelMaxRequests>=0&&(S.modelMaxRequests=t.modelMaxRequests),typeof t.modelMaxMemoryUsage<"u"&&t.modelMaxMemoryUsage>=0&&(S.modelMaxMemoryUsage=t.modelMaxMemoryUsage),typeof t.modelMaxScreenSpaceError<"u"&&t.modelMaxScreenSpaceError>=0&&(S.modelMaxScreenSpaceError=t.modelMaxScreenSpaceError),Object.defineProperty(e,"options",{configurable:!1,get:function(){return S}}),n=w.map(function($){return JSON.parse($)}).reduce(function($,oe){return deepMerge($,oe)}),Object.defineProperty(e,"raw",{configurable:!1,get:function(){return{works:w,options:_}}});{var B;if(t.workCode&&(typeof t.workCode=="string"?B=t.workCode:typeof t.workCode=="function"&&(B=t.workCode(n))),typeof B>"u"&&(B=String(n.resource_code||n.basic_code||n.vr_code||n.code||n.project_id||n.work_code||n.workCode)),typeof B>"u")return new Error("WorkCode never matched.");Object.defineProperty(e,"workCode",{configurable:!1,get:function(){return B}})}{var F=String(n.name);Object.defineProperty(e,"name",{configurable:!1,get:function(){return F}})}if(I instanceof Error)return I;Object.defineProperty(e,"issuer",{configurable:!1,get:function(){return I.issuer}}),Object.defineProperty(e,"expire",{configurable:!1,get:function(){return I.expire}}),Object.defineProperty(e,"allowHosts",{configurable:!1,get:function(){return I.allowHosts}});var O=(r=n.base_url)!==null&&r!==void 0?r:"";if(O&&O[O.length-1]!=="/"&&(O+="/"),I instanceof Error)return I;if(n.model){var H={work:e,layers:[]},k;n.model.file?k=fileURL(O,n.model.file,t):n.model.file_url&&(k=fileURL(O,n.model.file_url,t)),Object.defineProperty(H,"file",{configurable:!1,get:function(){return k}});var N;n.model.textureBase?N=textureURL$1(O,"",n.model.textureBase,t):n.model.material_base_url?N=textureURL$1(O,"",n.model.material_base_url,t):H.file&&(N=H.file.split("/").slice(0,-1).join("/").replace("/model/","/materials/")),Object.defineProperty(H,"textureBase",{configurable:!1,get:function(){return N}});var q;Array.isArray(n.model.textures)?(q=n.model.textures.map(function($){var oe,j;return textureURL$1(O,$,(j=(oe=n.model.textureBase)!==null&&oe!==void 0?oe:n.model.material_base_url)!==null&&j!==void 0?j:"",t)}),Object.freeze(q)):Array.isArray(n.model.material_textures)&&(q=n.model.material_textures.map(function($){var oe,j;return textureURL$1(O,$,(j=(oe=n.model.textureBase)!==null&&oe!==void 0?oe:n.model.material_base_url)!==null&&j!==void 0?j:"",t)}),Object.freeze(q)),Object.defineProperty(H,"textures",{configurable:!1,get:function(){return q}});var V=[];if(Array.isArray(n.model.tiles))for(var D=0,K=n.model.tiles;D<K.length;D++){var z=K[D];z&&(z.tileset||z.tileset_url)&&V.push(Object.freeze({type:(i=z.type)!==null&&i!==void 0?i:"mesh",name:(o=z.name)!==null&&o!==void 0?o:"",upAxis:(u=(s=z.upAxis)!==null&&s!==void 0?s:z.up_axis)!==null&&u!==void 0?u:"-Y",tileset:z.tileset||z.tileset_url}))}else n.model.tiles&&(n.model.tiles.tileset||n.model.tiles.tileset_url)&&V.push(Object.freeze({type:(l=n.model.tiles.type)!==null&&l!==void 0?l:"mesh",name:(d=n.model.tiles.name)!==null&&d!==void 0?d:"lod",upAxis:(f=(c=n.model.tiles.upAxis)!==null&&c!==void 0?c:n.model.tiles.up_axis)!==null&&f!==void 0?f:"-Y",tileset:n.model.tiles.tileset||n.model.tiles.tileset_url}));if(Array.isArray(n.model.layers))for(var G=0,W=n.model.layers;G<W.length;G++){var Q=W[G];Q&&(Q.tileset||Q.tileset_url)&&V.push(Object.freeze({type:(h=Q.type)!==null&&h!==void 0?h:"mesh",name:(v=Q.name)!==null&&v!==void 0?v:"",upAxis:(A=Q.upAxis)!==null&&A!==void 0?A:Q.up_axis,tileset:Q.tileset||Q.tileset_url}))}Object.freeze(V),Object.defineProperty(H,"layers",{configurable:!1,get:function(){return V}}),Object.defineProperty(e,"model",{configurable:!1,get:function(){if(H.file||H.layers.length)return H}})}if(I instanceof Error)return I;{var X=[];if(n.observers&&Array.isArray(n.observers)){var ee=[];n.panorama&&(Array.isArray(n.panorama)?ee=n.panorama:Array.isArray(n.panorama.list)?ee=n.panorama.list:Array.isArray(n.panorama.info)&&(ee=n.panorama.info));for(var J=function($){var oe={},j=n.observers[$];if(!j)return"break";var ve=ee[$];if(!ve)return"break";j=Object.assign({},j,ve,{active:j.active!==!1&&ve.active!==!1}),Object.defineProperty(oe,"work",{configurable:!1,get:function(){return e}}),Object.defineProperty(oe,"index",{configurable:!1,get:function(){return $}}),Object.defineProperty(oe,"panoIndex",{configurable:!1,get:function(){return $}});var me=panoStringify({workCode:e.workCode,panoIndex:$});Object.defineProperty(oe,"panoId",{configurable:!1,get:function(){return me}});var Me=Object.freeze({workCode:e.workCode,panoIndex:$});Object.defineProperty(oe,"pano",{configurable:!1,get:function(){return Me}});var Re=j.active!==!1;Object.defineProperty(oe,"active",{configurable:!1,get:function(){return Re}});var ge=j.loadable===!0;Object.defineProperty(oe,"loadable",{configurable:!1,get:function(){return ge}});var we=j.derived_id;Object.defineProperty(oe,"derivedId",{configurable:!1,get:function(){return we}});var Ae=j.derived_id_str;Object.defineProperty(oe,"derivedIdStr",{configurable:!1,get:function(){return Ae}});var le=(T=(g=(y=(m=n.panorama)===null||m===void 0?void 0:m.pano_high_cube_base_url)!==null&&y!==void 0?y:(p=n.panorama)===null||p===void 0?void 0:p.pano_cube_base_url)!==null&&g!==void 0?g:(b=n.panorama)===null||b===void 0?void 0:b.base_url)!==null&&T!==void 0?T:"",ue={up:panoURL(O,le,j.images?j.images.up:j.up,$,t),down:panoURL(O,le,j.images?j.images.down:j.down,$,t),right:panoURL(O,le,j.images?j.images.right:j.right,$,t),left:panoURL(O,le,j.images?j.images.left:j.left,$,t),front:panoURL(O,le,j.images?j.images.front:j.front,$,t),back:panoURL(O,le,j.images?j.images.back:j.back,$,t)},Oe=j.images?j.images.depth:j.depth;Oe&&(ue.depth=panoURL(O,le,Oe,$,t));var fe=j.images?j.images.luminance:j.luminance;fe&&(ue.luminance=Object.freeze({up:panoURL(O,le,fe.up,$,t),down:panoURL(O,le,fe.down,$,t),right:panoURL(O,le,fe.right,$,t),left:panoURL(O,le,fe.left,$,t),front:panoURL(O,le,fe.front,$,t),back:panoURL(O,le,fe.back,$,t)}));var Se=j.images?j.images.tiles:j.tiles;if(Se){for(var ye=[],ke=function(xe){var je=xe.match(/\/cube_(\d+)\//);if(je){var at=Number(je[1]);if(isPowerOfTwo(at))return at}return!1},_e=function(xe,je){return xe.replace(/\/cube_(\d+)\//,function(){return"/cube_".concat(je,"/")})},We=0,Xe=Se;We<Xe.length;We++){var Ee=Xe[We];if(typeof Ee=="number"){var Pe=Ee,Je=ke(ue.front);if(Je===!1)continue;var be=Math.max(Je,Math.pow(2,Pe)*512);if(be>2048){var Fe=_e(ue.up,be),De=_e(ue.down,be),qe=_e(ue.right,be),Ze=_e(ue.left,be),Ne=_e(ue.front,be),he=_e(ue.back,be);ye.push(Object.freeze({level:Pe,size:be,up:Fe,down:De,right:qe,left:Ze,front:Ne,back:he}))}else{var Fe=ue.up,De=ue.down,qe=ue.right,Ze=ue.left,Ne=ue.front,he=ue.back;ye.push(Object.freeze({level:Pe,size:be,up:Fe,down:De,right:qe,left:Ze,front:Ne,back:he}))}}else{var Pe=Ee.level;if(typeof Pe!="number")continue;var be=Ee.size;if(typeof be!="number")continue;var Fe=panoURL(O,le,Ee.up,$,t),De=panoURL(O,le,Ee.down,$,t),qe=panoURL(O,le,Ee.right,$,t),Ze=panoURL(O,le,Ee.left,$,t),Ne=panoURL(O,le,Ee.front,$,t),he=panoURL(O,le,Ee.back,$,t);ye.push(Object.freeze({level:Pe,size:be,up:Fe,down:De,right:qe,left:Ze,front:Ne,back:he}))}}ye.sort(function(xe,je){return xe.level-je.level}),Object.freeze(ye),Object.defineProperty(ue,"tiles",{configurable:!1,get:function(){return ye}})}Object.freeze(ue),Object.defineProperty(oe,"images",{configurable:!1,get:function(){return ue}});var st=new THREE__namespace.Vector3;if(j.position instanceof THREE__namespace.Vector3)st.copy(j.position);else if(Array.isArray(j.position))st.fromArray(j.position);else return"break";Object.freeze(st),Object.defineProperty(oe,"position",{configurable:!1,get:function(){return st}});var ze=new THREE__namespace.Vector3;if(j.standingPosition instanceof THREE__namespace.Vector3)ze.copy(j.standingPosition);else if(Array.isArray(j.standingPosition))ze.fromArray(j.standingPosition);else if(j.standing_position instanceof THREE__namespace.Vector3)ze.copy(j.standing_position);else if(Array.isArray(j.standing_position))ze.fromArray(j.standing_position);else return"break";Object.freeze(ze),Object.defineProperty(oe,"standingPosition",{configurable:!1,get:function(){return ze}});var tt=new THREE__namespace.Quaternion;if(j.quaternion instanceof THREE__namespace.Quaternion)tt.copy(j.quaternion);else if(Array.isArray(j.quaternion))tt.fromArray(j.quaternion);else if(j.quaternion){var Ge=j.quaternion,mt=Ge.x,lt=Ge.y,ct=Ge.z,rt=Ge.w;tt.set(mt,lt,ct,rt)}else return"break";Object.freeze(tt),Object.defineProperty(oe,"quaternion",{configurable:!1,get:function(){return tt}});var nt=0;isNumber(j.floorIndex)?nt=j.floorIndex:isNumber(j.floor_index)?nt=j.floor_index:isNumber(j.floor)&&(nt=j.floor),Object.defineProperty(oe,"floorIndex",{configurable:!1,get:function(){return nt}});var Ie;j.video&&(Ie={},typeof j.video.source=="string"&&(Ie.source=j.video.source),j.video.matrix instanceof THREE__namespace.Matrix4?Ie.matrix=j.video.matrix.clone():Array.isArray(j.video.matrix)&&(Ie.matrix=new THREE__namespace.Matrix4().fromArray(j.video.matrix)),j.video.size instanceof THREE__namespace.Vector2?Ie.size=j.video.size.clone():Array.isArray(j.video.size)&&(Ie.size=new THREE__namespace.Vector2().fromArray(j.video.size)),Ie.source&&Ie.matrix&&Ie.size&&(oe.video=Ie)),Object.freeze(Ie),Object.defineProperty(oe,"video",{configurable:!1,get:function(){return Ie}}),Array.isArray(j.accessibleNodes)?(oe.accessibleNodes=j.accessibleNodes.slice(),oe.accessibleIds=j.accessibleNodes.map(function(xe){return panoStringify({workCode:e.workCode,panoIndex:xe})})):Array.isArray(j.accessible_nodes)&&(oe.accessibleNodes=j.accessible_nodes.slice(),oe.accessibleIds=j.accessible_nodes.map(function(xe){return panoStringify({workCode:e.workCode,panoIndex:xe})})),Array.isArray(j.visibleNodes)?(oe.visibleNodes=j.visibleNodes.slice(),oe.visibleIds=j.visibleNodes.map(function(xe){return panoStringify({workCode:e.workCode,panoIndex:xe})})):Array.isArray(j.visible_nodes)&&(oe.visibleNodes=j.visible_nodes.slice(),oe.visibleIds=j.visible_nodes.map(function(xe){return panoStringify({workCode:e.workCode,panoIndex:xe})})),X[$]=oe},Z=0;Z<n.observers.length;Z++){var te=J(Z);if(te==="break")break}}for(var ae=function($){if($.accessibleIds){var ve=$.accessibleIds.filter(function(le){return!!X.find(function(ue){return ue.panoId===le})});Object.freeze(ve),Object.defineProperty($,"accessibleIds",{configurable:!1,get:function(){return ve}})}else{for(var oe=[],j=0;j<X.length;j++)X[j]!==$&&(Math.abs(X[j].position.y-$.position.y)>3||X[j].position.distanceTo($.position)>10||oe.push(X[j].panoId));Object.freeze(oe),Object.defineProperty($,"accessibleIds",{configurable:!1,get:function(){return oe}})}if($.accessibleNodes){var Me=$.accessibleNodes.filter(function(le){return!!X.find(function(ue){return ue.panoIndex===le})});Object.freeze(Me),Object.defineProperty($,"accessibleNodes",{configurable:!1,get:function(){return Me}})}else{for(var me=[],j=0;j<X.length;j++)X[j]!==$&&(Math.abs(X[j].position.y-$.position.y)>3||X[j].position.distanceTo($.position)>10||me.push(X[j].panoIndex));Object.freeze(me),Object.defineProperty($,"accessibleNodes",{configurable:!1,get:function(){return me}})}if($.visibleIds){var ge=$.visibleIds.filter(function(le){return!!X.find(function(ue){return ue.panoId===le})});Object.freeze(ge),Object.defineProperty($,"visibleIds",{configurable:!1,get:function(){return ge}})}else{var Re=$.accessibleIds.slice();Object.freeze(Re),Object.defineProperty($,"visibleIds",{configurable:!1,get:function(){return Re}})}if($.visibleNodes){var Ae=$.visibleNodes.filter(function(le){return!!X.find(function(ue){return ue.panoIndex===le})});Object.freeze(Ae),Object.defineProperty($,"visibleNodes",{configurable:!1,get:function(){return Ae}})}else{var we=$.accessibleNodes.slice();Object.freeze(we),Object.defineProperty($,"visibleNodes",{configurable:!1,get:function(){return we}})}},re=0,ie=X;re<ie.length;re++){var de=ie[re];ae(de)}Object.freeze(X),Object.defineProperty(e,"observers",{configurable:!1,get:function(){return X}})}if(I instanceof Error)return I;if(n.initial){if((n.initial.mode==="Panorama"&&e.observers.length===0||n.initial.mode==="Floorplan"||n.initial.mode==="Topview"||n.initial.mode==="Model"||n.initial.mode==="Mapview"||n.initial.mode==="DepthPanorama")&&(e.initial.mode=n.initial.mode),isNumber(n.initial.latitude)&&(e.initial.latitude=n.initial.latitude),isNumber(n.initial.longitude)?e.initial.longitude=n.initial.longitude:isNumber(n.initial.heading)&&(e.initial.longitude=headingToLongitude(n.initial.heading)),isNumber(n.initial.fov)&&(e.initial.fov=n.initial.fov),e.observers.length>0){var se=void 0;isNumber(n.initial.panoIndex)?se=n.initial.panoIndex:isNumber(n.initial.pano_index)?se=n.initial.pano_index:isNumber(n.initial.pano)&&(se=n.initial.pano),typeof se=="number"&&(se=clamp(se,0,e.observers.length-1),e.initial.panoIndex=se)}if(isNumber(n.initial.distance)&&(e.initial.distance=n.initial.distance),Array.isArray(n.initial.offset)){var pe=[0,0,0].map(function($,oe){var j=Number(n.initial.offset[oe]);return isNaN(j)||!isFinite(j)?0:j});e.initial.offset=new THREE__namespace.Vector3().fromArray(pe)}!e.initial.mode&&typeof e.initial.panoIndex=="number"&&(e.initial.mode="Panorama")}return I instanceof Error?I:(workRawMapping.set(e,{works:w,options:_}),e)}function parseWork(n,t){typeof n=="string"&&n.trim()[0]==="{"&&(n=JSON.parse(n));var e=workRawMapping.get(n);if(e){if(t&&!equal(JSON.parse(e.options),t))throw new Error("[PARSE FAILED]: work is parsed with different options.");return n}else try{return new Work(n,t??{})}catch(r){throw new Error("[PARSE FAILED]: "+r.message+`
|
|
948
|
+
`+JSON.stringify(t))}return n.prototype.toJSON=function(){return this.raw},n.parse=parseWork,n}();function getType(n){return n==null?"null":Array.isArray(n)?"array":typeof n=="object"?"dict":"value"}function deepMerge(n,t){var e=getType(n),r=getType(t);if(r==="null")return n;if(r==="value")return t;if(r!==e)return JSON.parse(JSON.stringify(t));if(r==="array")for(var i=0;i<t.length;i++)n[i]=deepMerge(n[i],t[i]);else if(r==="dict")for(var o in t)n[o]=deepMerge(n[o],t[o]);return n}function startWithString(n,t){return n.indexOf(t)===0}function urlWithParseOptions(n,t,e,r){var i,o=t;if(r.jsonp===!0){o=t.replace(/([\?\#].*)?$/i,"");var s=sha256("".concat(o)).slice(0,7);o="".concat(o,".").concat(s,".jsonp")}if(r.shortPath===!0){var u=o.replace(n,"").split("."),l=(i=u.shift())!==null&&i!==void 0?i:"",d=u.join(".");o=pathJoin(n,sha256(l))+(d?"."+d:"")}var c=o.replace(n,"");return r.baseURL&&(o=pathJoin(r.baseURL,c)),o}function panoURL(n,t,e,r,i){var o=e;return isAbsoluteURL(e)||(t&&(t=pathJoin(t,String(r))),o=pathJoin(t,o)),isAbsoluteURL(o)||(o=pathJoin(n,o)),startWithString(o,n)||console.warn("".concat(o," is not start with base_url(").concat(n,").")),urlWithParseOptions(n,o,"panorama",i)}function fileURL(n,t,e){var r=t;return isAbsoluteURL(r)||(r=pathJoin(n,t)),startWithString(r,n)||console.warn("".concat(r," is not start with base_url(").concat(n,").")),urlWithParseOptions(n,r,"model",e)}function textureURL$1(n,t,e,r){var i=t;return isAbsoluteURL(i)||(i=pathJoin(e,i)),isAbsoluteURL(i)||(i=pathJoin(n,i)),startWithString(i,n)||console.warn("".concat(i," is not start with base_url(").concat(n,").")),urlWithParseOptions(n,i,"texture",r)}function parse(n,t,e){for(var r,i,o,s,u,l,d,c,f,h,v,A,m,y,p,g,b,T,_=JSON.stringify(t),w=[],x=0,M=[].concat(n);x<M.length;x++){var R=M[x];R instanceof Work?w.push.apply(w,R.raw.works):typeof R=="string"?w.push(R):w.push(JSON.stringify(R))}var I=verify(w);if(I instanceof Error)return I;t=JSON.parse(_);var S={transform:new THREE__namespace.Matrix4};typeof t.debug<"u"&&(S.debug=t.debug),t.transform&&(Array.isArray(t.transform)?S.transform.fromArray(t.transform):S.transform.copy(t.transform)),t.viewerRequestVolume&&("clone"in t.viewerRequestVolume?S.viewerRequestVolume=t.viewerRequestVolume.clone():S.viewerRequestVolume=makeBoundingVolume(t.viewerRequestVolume)),typeof t.modelMinLevelOfDetail<"u"&&t.modelMinLevelOfDetail>=0&&(S.modelMinLevelOfDetail=t.modelMinLevelOfDetail),typeof t.modelMaxLevelOfDetail<"u"&&t.modelMaxLevelOfDetail>=0&&(S.modelMaxLevelOfDetail=t.modelMaxLevelOfDetail),typeof t.modelMaxRequests<"u"&&t.modelMaxRequests>=0&&(S.modelMaxRequests=t.modelMaxRequests),typeof t.modelMaxMemoryUsage<"u"&&t.modelMaxMemoryUsage>=0&&(S.modelMaxMemoryUsage=t.modelMaxMemoryUsage),typeof t.modelMaxScreenSpaceError<"u"&&t.modelMaxScreenSpaceError>=0&&(S.modelMaxScreenSpaceError=t.modelMaxScreenSpaceError),Object.defineProperty(e,"options",{configurable:!1,get:function(){return S}}),n=w.map(function($){return JSON.parse($)}).reduce(function($,oe){return deepMerge($,oe)}),Object.defineProperty(e,"raw",{configurable:!1,get:function(){return{works:w,options:_}}});{var B;if(t.workCode&&(typeof t.workCode=="string"?B=t.workCode:typeof t.workCode=="function"&&(B=t.workCode(n))),typeof B>"u"&&(B=String(n.resource_code||n.basic_code||n.vr_code||n.code||n.project_id||n.work_code||n.workCode)),typeof B>"u")return new Error("WorkCode never matched.");Object.defineProperty(e,"workCode",{configurable:!1,get:function(){return B}})}{var O=String(n.name);Object.defineProperty(e,"name",{configurable:!1,get:function(){return O}})}if(I instanceof Error)return I;Object.defineProperty(e,"issuer",{configurable:!1,get:function(){return I.issuer}}),Object.defineProperty(e,"expire",{configurable:!1,get:function(){return I.expire}}),Object.defineProperty(e,"allowHosts",{configurable:!1,get:function(){return I.allowHosts}});var F=(r=n.base_url)!==null&&r!==void 0?r:"";if(F&&F[F.length-1]!=="/"&&(F+="/"),I instanceof Error)return I;if(n.model){var H={work:e,layers:[]},k;n.model.file?k=fileURL(F,n.model.file,t):n.model.file_url&&(k=fileURL(F,n.model.file_url,t)),Object.defineProperty(H,"file",{configurable:!1,get:function(){return k}});var N;n.model.textureBase?N=textureURL$1(F,"",n.model.textureBase,t):n.model.material_base_url?N=textureURL$1(F,"",n.model.material_base_url,t):H.file&&(N=H.file.split("/").slice(0,-1).join("/").replace("/model/","/materials/")),Object.defineProperty(H,"textureBase",{configurable:!1,get:function(){return N}});var q;Array.isArray(n.model.textures)?(q=n.model.textures.map(function($){var oe,j;return textureURL$1(F,$,(j=(oe=n.model.textureBase)!==null&&oe!==void 0?oe:n.model.material_base_url)!==null&&j!==void 0?j:"",t)}),Object.freeze(q)):Array.isArray(n.model.material_textures)&&(q=n.model.material_textures.map(function($){var oe,j;return textureURL$1(F,$,(j=(oe=n.model.textureBase)!==null&&oe!==void 0?oe:n.model.material_base_url)!==null&&j!==void 0?j:"",t)}),Object.freeze(q)),Object.defineProperty(H,"textures",{configurable:!1,get:function(){return q}});var V=[];if(Array.isArray(n.model.tiles))for(var D=0,K=n.model.tiles;D<K.length;D++){var z=K[D];z&&(z.tileset||z.tileset_url)&&V.push(Object.freeze({type:(i=z.type)!==null&&i!==void 0?i:"mesh",name:(o=z.name)!==null&&o!==void 0?o:"",upAxis:(u=(s=z.upAxis)!==null&&s!==void 0?s:z.up_axis)!==null&&u!==void 0?u:"-Y",tileset:z.tileset||z.tileset_url}))}else n.model.tiles&&(n.model.tiles.tileset||n.model.tiles.tileset_url)&&V.push(Object.freeze({type:(l=n.model.tiles.type)!==null&&l!==void 0?l:"mesh",name:(d=n.model.tiles.name)!==null&&d!==void 0?d:"lod",upAxis:(f=(c=n.model.tiles.upAxis)!==null&&c!==void 0?c:n.model.tiles.up_axis)!==null&&f!==void 0?f:"-Y",tileset:n.model.tiles.tileset||n.model.tiles.tileset_url}));if(Array.isArray(n.model.layers))for(var G=0,W=n.model.layers;G<W.length;G++){var Q=W[G];Q&&(Q.tileset||Q.tileset_url)&&V.push(Object.freeze({type:(h=Q.type)!==null&&h!==void 0?h:"mesh",name:(v=Q.name)!==null&&v!==void 0?v:"",upAxis:(A=Q.upAxis)!==null&&A!==void 0?A:Q.up_axis,tileset:Q.tileset||Q.tileset_url}))}Object.freeze(V),Object.defineProperty(H,"layers",{configurable:!1,get:function(){return V}}),Object.defineProperty(e,"model",{configurable:!1,get:function(){if(H.file||H.layers.length)return H}})}if(I instanceof Error)return I;{var X=[];if(n.observers&&Array.isArray(n.observers)){var ee=[];n.panorama&&(Array.isArray(n.panorama)?ee=n.panorama:Array.isArray(n.panorama.list)?ee=n.panorama.list:Array.isArray(n.panorama.info)&&(ee=n.panorama.info));for(var J=function($){var oe={},j=n.observers[$];if(!j)return"break";var ve=ee[$];if(!ve)return"break";j=Object.assign({},j,ve,{active:j.active!==!1&&ve.active!==!1}),Object.defineProperty(oe,"work",{configurable:!1,get:function(){return e}}),Object.defineProperty(oe,"index",{configurable:!1,get:function(){return $}}),Object.defineProperty(oe,"panoIndex",{configurable:!1,get:function(){return $}});var me=panoStringify({workCode:e.workCode,panoIndex:$});Object.defineProperty(oe,"panoId",{configurable:!1,get:function(){return me}});var Me=Object.freeze({workCode:e.workCode,panoIndex:$});Object.defineProperty(oe,"pano",{configurable:!1,get:function(){return Me}});var Re=j.active!==!1;Object.defineProperty(oe,"active",{configurable:!1,get:function(){return Re}});var ge=j.loadable===!0;Object.defineProperty(oe,"loadable",{configurable:!1,get:function(){return ge}});var we=j.derived_id;Object.defineProperty(oe,"derivedId",{configurable:!1,get:function(){return we}});var Ae=j.derived_id_str;Object.defineProperty(oe,"derivedIdStr",{configurable:!1,get:function(){return Ae}});var le=(T=(g=(y=(m=n.panorama)===null||m===void 0?void 0:m.pano_high_cube_base_url)!==null&&y!==void 0?y:(p=n.panorama)===null||p===void 0?void 0:p.pano_cube_base_url)!==null&&g!==void 0?g:(b=n.panorama)===null||b===void 0?void 0:b.base_url)!==null&&T!==void 0?T:"",ue={up:panoURL(F,le,j.images?j.images.up:j.up,$,t),down:panoURL(F,le,j.images?j.images.down:j.down,$,t),right:panoURL(F,le,j.images?j.images.right:j.right,$,t),left:panoURL(F,le,j.images?j.images.left:j.left,$,t),front:panoURL(F,le,j.images?j.images.front:j.front,$,t),back:panoURL(F,le,j.images?j.images.back:j.back,$,t)},Fe=j.images?j.images.depth:j.depth;Fe&&(ue.depth=panoURL(F,le,Fe,$,t));var fe=j.images?j.images.luminance:j.luminance;fe&&(ue.luminance=Object.freeze({up:panoURL(F,le,fe.up,$,t),down:panoURL(F,le,fe.down,$,t),right:panoURL(F,le,fe.right,$,t),left:panoURL(F,le,fe.left,$,t),front:panoURL(F,le,fe.front,$,t),back:panoURL(F,le,fe.back,$,t)}));var Se=j.images?j.images.tiles:j.tiles;if(Se){for(var ye=[],ke=function(xe){var je=xe.match(/\/cube_(\d+)\//);if(je){var at=Number(je[1]);if(isPowerOfTwo(at))return at}return!1},_e=function(xe,je){return xe.replace(/\/cube_(\d+)\//,function(){return"/cube_".concat(je,"/")})},We=0,Xe=Se;We<Xe.length;We++){var Ee=Xe[We];if(typeof Ee=="number"){var Pe=Ee,Je=ke(ue.front);if(Je===!1)continue;var be=Math.max(Je,Math.pow(2,Pe)*512);if(be>2048){var Oe=_e(ue.up,be),De=_e(ue.down,be),qe=_e(ue.right,be),Ze=_e(ue.left,be),Ne=_e(ue.front,be),he=_e(ue.back,be);ye.push(Object.freeze({level:Pe,size:be,up:Oe,down:De,right:qe,left:Ze,front:Ne,back:he}))}else{var Oe=ue.up,De=ue.down,qe=ue.right,Ze=ue.left,Ne=ue.front,he=ue.back;ye.push(Object.freeze({level:Pe,size:be,up:Oe,down:De,right:qe,left:Ze,front:Ne,back:he}))}}else{var Pe=Ee.level;if(typeof Pe!="number")continue;var be=Ee.size;if(typeof be!="number")continue;var Oe=panoURL(F,le,Ee.up,$,t),De=panoURL(F,le,Ee.down,$,t),qe=panoURL(F,le,Ee.right,$,t),Ze=panoURL(F,le,Ee.left,$,t),Ne=panoURL(F,le,Ee.front,$,t),he=panoURL(F,le,Ee.back,$,t);ye.push(Object.freeze({level:Pe,size:be,up:Oe,down:De,right:qe,left:Ze,front:Ne,back:he}))}}ye.sort(function(xe,je){return xe.level-je.level}),Object.freeze(ye),Object.defineProperty(ue,"tiles",{configurable:!1,get:function(){return ye}})}Object.freeze(ue),Object.defineProperty(oe,"images",{configurable:!1,get:function(){return ue}});var st=new THREE__namespace.Vector3;if(j.position instanceof THREE__namespace.Vector3)st.copy(j.position);else if(Array.isArray(j.position))st.fromArray(j.position);else return"break";Object.freeze(st),Object.defineProperty(oe,"position",{configurable:!1,get:function(){return st}});var ze=new THREE__namespace.Vector3;if(j.standingPosition instanceof THREE__namespace.Vector3)ze.copy(j.standingPosition);else if(Array.isArray(j.standingPosition))ze.fromArray(j.standingPosition);else if(j.standing_position instanceof THREE__namespace.Vector3)ze.copy(j.standing_position);else if(Array.isArray(j.standing_position))ze.fromArray(j.standing_position);else return"break";Object.freeze(ze),Object.defineProperty(oe,"standingPosition",{configurable:!1,get:function(){return ze}});var tt=new THREE__namespace.Quaternion;if(j.quaternion instanceof THREE__namespace.Quaternion)tt.copy(j.quaternion);else if(Array.isArray(j.quaternion))tt.fromArray(j.quaternion);else if(j.quaternion){var Ge=j.quaternion,mt=Ge.x,lt=Ge.y,ct=Ge.z,rt=Ge.w;tt.set(mt,lt,ct,rt)}else return"break";Object.freeze(tt),Object.defineProperty(oe,"quaternion",{configurable:!1,get:function(){return tt}});var nt=0;isNumber(j.floorIndex)?nt=j.floorIndex:isNumber(j.floor_index)?nt=j.floor_index:isNumber(j.floor)&&(nt=j.floor),Object.defineProperty(oe,"floorIndex",{configurable:!1,get:function(){return nt}});var Ie;j.video&&(Ie={},typeof j.video.source=="string"&&(Ie.source=j.video.source),j.video.matrix instanceof THREE__namespace.Matrix4?Ie.matrix=j.video.matrix.clone():Array.isArray(j.video.matrix)&&(Ie.matrix=new THREE__namespace.Matrix4().fromArray(j.video.matrix)),j.video.size instanceof THREE__namespace.Vector2?Ie.size=j.video.size.clone():Array.isArray(j.video.size)&&(Ie.size=new THREE__namespace.Vector2().fromArray(j.video.size)),Ie.source&&Ie.matrix&&Ie.size&&(oe.video=Ie)),Object.freeze(Ie),Object.defineProperty(oe,"video",{configurable:!1,get:function(){return Ie}}),Array.isArray(j.accessibleNodes)?(oe.accessibleNodes=j.accessibleNodes.slice(),oe.accessibleIds=j.accessibleNodes.map(function(xe){return panoStringify({workCode:e.workCode,panoIndex:xe})})):Array.isArray(j.accessible_nodes)&&(oe.accessibleNodes=j.accessible_nodes.slice(),oe.accessibleIds=j.accessible_nodes.map(function(xe){return panoStringify({workCode:e.workCode,panoIndex:xe})})),Array.isArray(j.visibleNodes)?(oe.visibleNodes=j.visibleNodes.slice(),oe.visibleIds=j.visibleNodes.map(function(xe){return panoStringify({workCode:e.workCode,panoIndex:xe})})):Array.isArray(j.visible_nodes)&&(oe.visibleNodes=j.visible_nodes.slice(),oe.visibleIds=j.visible_nodes.map(function(xe){return panoStringify({workCode:e.workCode,panoIndex:xe})})),X[$]=oe},Z=0;Z<n.observers.length;Z++){var te=J(Z);if(te==="break")break}}for(var ae=function($){if($.accessibleIds){var ve=$.accessibleIds.filter(function(le){return!!X.find(function(ue){return ue.panoId===le})});Object.freeze(ve),Object.defineProperty($,"accessibleIds",{configurable:!1,get:function(){return ve}})}else{for(var oe=[],j=0;j<X.length;j++)X[j]!==$&&(Math.abs(X[j].position.y-$.position.y)>3||X[j].position.distanceTo($.position)>10||oe.push(X[j].panoId));Object.freeze(oe),Object.defineProperty($,"accessibleIds",{configurable:!1,get:function(){return oe}})}if($.accessibleNodes){var Me=$.accessibleNodes.filter(function(le){return!!X.find(function(ue){return ue.panoIndex===le})});Object.freeze(Me),Object.defineProperty($,"accessibleNodes",{configurable:!1,get:function(){return Me}})}else{for(var me=[],j=0;j<X.length;j++)X[j]!==$&&(Math.abs(X[j].position.y-$.position.y)>3||X[j].position.distanceTo($.position)>10||me.push(X[j].panoIndex));Object.freeze(me),Object.defineProperty($,"accessibleNodes",{configurable:!1,get:function(){return me}})}if($.visibleIds){var ge=$.visibleIds.filter(function(le){return!!X.find(function(ue){return ue.panoId===le})});Object.freeze(ge),Object.defineProperty($,"visibleIds",{configurable:!1,get:function(){return ge}})}else{var Re=$.accessibleIds.slice();Object.freeze(Re),Object.defineProperty($,"visibleIds",{configurable:!1,get:function(){return Re}})}if($.visibleNodes){var Ae=$.visibleNodes.filter(function(le){return!!X.find(function(ue){return ue.panoIndex===le})});Object.freeze(Ae),Object.defineProperty($,"visibleNodes",{configurable:!1,get:function(){return Ae}})}else{var we=$.accessibleNodes.slice();Object.freeze(we),Object.defineProperty($,"visibleNodes",{configurable:!1,get:function(){return we}})}},re=0,ie=X;re<ie.length;re++){var de=ie[re];ae(de)}Object.freeze(X),Object.defineProperty(e,"observers",{configurable:!1,get:function(){return X}})}if(I instanceof Error)return I;if(n.initial){if((n.initial.mode==="Panorama"&&e.observers.length===0||n.initial.mode==="Floorplan"||n.initial.mode==="Topview"||n.initial.mode==="Model"||n.initial.mode==="Mapview"||n.initial.mode==="DepthPanorama")&&(e.initial.mode=n.initial.mode),isNumber(n.initial.latitude)&&(e.initial.latitude=n.initial.latitude),isNumber(n.initial.longitude)?e.initial.longitude=n.initial.longitude:isNumber(n.initial.heading)&&(e.initial.longitude=headingToLongitude(n.initial.heading)),isNumber(n.initial.fov)&&(e.initial.fov=n.initial.fov),e.observers.length>0){var se=void 0;isNumber(n.initial.panoIndex)?se=n.initial.panoIndex:isNumber(n.initial.pano_index)?se=n.initial.pano_index:isNumber(n.initial.pano)&&(se=n.initial.pano),typeof se=="number"&&(se=clamp(se,0,e.observers.length-1),e.initial.panoIndex=se)}if(isNumber(n.initial.distance)&&(e.initial.distance=n.initial.distance),Array.isArray(n.initial.offset)){var pe=[0,0,0].map(function($,oe){var j=Number(n.initial.offset[oe]);return isNaN(j)||!isFinite(j)?0:j});e.initial.offset=new THREE__namespace.Vector3().fromArray(pe)}!e.initial.mode&&typeof e.initial.panoIndex=="number"&&(e.initial.mode="Panorama")}return I instanceof Error?I:(workRawMapping.set(e,{works:w,options:_}),e)}function parseWork(n,t){typeof n=="string"&&n.trim()[0]==="{"&&(n=JSON.parse(n));var e=workRawMapping.get(n);if(e){if(t&&!equal(JSON.parse(e.options),t))throw new Error("[PARSE FAILED]: work is parsed with different options.");return n}else try{return new Work(n,t??{})}catch(r){throw new Error("[PARSE FAILED]: "+r.message+`
|
|
949
949
|
Error work input:
|
|
950
|
-
`+JSON.stringify(n))}}function createWorks(n){for(var t={},e=[],r={},i=0,o=n;i<o.length;i++){var s=o[i],u=t[s.workCode];u||(u=t[s.workCode]=new THREE__namespace.Matrix4().copy(s.options.transform));for(var l=0,d=s.observers;l<d.length;l++){var c=d[l],f={isResolved:!0,active:c.active,accessibleIds:c.accessibleIds,visibleIds:c.visibleIds,accessibleNodes:c.accessibleNodes,visibleNodes:c.visibleNodes,floorIndex:c.floorIndex,images:c.images,index:c.index,panoIndex:c.panoIndex,loadable:c.loadable,panoId:c.panoId,pano:c.pano,work:c.work,derivedId:c.derivedId,video:c.video,position:new THREE__namespace.Vector3().copy(c.position).applyMatrix4(u),standingPosition:new THREE__namespace.Vector3().copy(c.standingPosition).applyMatrix4(u),quaternion:new THREE__namespace.Quaternion().setFromRotationMatrix(scratchMatrix4$1.makeRotationFromQuaternion(c.quaternion).premultiply(u))};Object.freeze(f),e.push(f),r[f.panoId]=f}}Object.freeze(e);for(var h=n.slice(),v={},A=0,m=h;A<m.length;A++){var s=m[A];v[s.workCode]=s}return Object.freeze(Object.assign(h,{get initial(){return h.length>0?h[0].initial:{work:{}}},get resolvedObservers(){return e},getWork:function(y){return v[y]},getResolvedObserver:function(y){var p,g;return isPanoId(y)?r[y]:typeof y=="number"?r[panoStringify({workCode:(g=(p=n[0])===null||p===void 0?void 0:p.workCode)!==null&&g!==void 0?g:"",panoIndex:y})]:r[panoStringify(y)]},update:function(){for(var y={},p=0,g=h;p<g.length;p++){var b=g[p],T=b.options.transform,_=t[b.workCode];_?_.equals(T)||(_.copy(T),y[b.workCode]=!0):(t[b.workCode]=new THREE__namespace.Matrix4().copy(T),y[b.workCode]=!0)}for(var w=0,x=e;w<x.length;w++){var M=x[w];if(y[M.work.workCode]===!0){var R=M.work.observers[M.index],I=M.work.options.transform;M.position.copy(R.position).applyMatrix4(I),M.standingPosition.copy(R.standingPosition).applyMatrix4(I),M.quaternion.setFromRotationMatrix(scratchMatrix4$1.makeRotationFromQuaternion(R.quaternion).premultiply(I))}}}}))}var fetcherMap=new Map;function getFetcher(n){var t=fetcherMap.get(n);if(t)return t;throw new Error("fetcher never registered.")}function registerFetcher(n,t){return fetcherMap.set(n,t)}var scratchVector3$1=new THREE__namespace.Vector3,scratchMatrix3=new THREE__namespace.Matrix3,a=6378137,invF=298.257223563;function coordinatesFromPoint(n){for(var t=a-a/invF,e=(a*a-t*t)/(a*a),r=Math.sqrt(n.x*n.x+n.y*n.y),i=1e-12,o=1e3,s=0,u=Math.atan2(n.z,r),l=0;s++<o;){var d=Math.sin(u),c=a/Math.sqrt(1-e*d*d);l=r/Math.cos(u)-c;var f=Math.atan2(n.z/(c*(1-e)+l),r/(c+l)),h=Math.abs(f-u);if(h<i)break;u=f}return{longitude:Math.atan2(n.y,n.x),latitude:u,altitude:l}}function pointFromCoordinates(n){var t=a-a/invF,e=(a*a-t*t)/(a*a),r=Math.sin(n.latitude),i=Math.cos(n.latitude),o=Math.sin(n.longitude),s=Math.cos(n.longitude),u=a/Math.sqrt(1-e*r*r),l=(u+n.altitude)*i*s,d=(u+n.altitude)*i*o,c=(t*t/(a*a)*u+n.altitude)*r;return new THREE__namespace.Vector3(l,d,c)}function getWorldToLocalMatrix(n,t){var e=coordinatesFromPoint(n),r=e.longitude,i=e.latitude,o=e.altitude,s=Math.sin(i),u=Math.sin(r),l=Math.cos(i),d=Math.cos(r),c=t.fromArray([-u,-s*d,l*d,0,+d,-s*u,l*u,0,0,l,s,0,0,0,0,1]),f=scratchMatrix3.setFromMatrix4(c),h=scratchVector3$1.copy(n).applyMatrix3(f).multiplyScalar(-1);c.setPosition(h);var v=new THREE__namespace.Matrix4().fromArray([1,0,0,0,0,1,0,0,0,0,1,0,0,0,o,1]);return c.premultiply(v),c}var BufferGeometryUtils={computeTangents:function(n){var t=n.index,e=n.attributes;if(t===null||e.position===void 0||e.normal===void 0||e.uv===void 0){console.warn("THREE.BufferGeometry: Missing required attributes (index, position, normal or uv) in BufferGeometry.computeTangents()");return}var r=t.array,i=e.position.array,o=e.normal.array,s=e.uv.array,u=i.length/3;e.tangent===void 0&&n.setAttribute("tangent",new THREE__namespace.BufferAttribute(new Float32Array(4*u),4));for(var l=e.tangent.array,d=[],c=[],f=0;f<u;f++)d[f]=new THREE__namespace.Vector3,c[f]=new THREE__namespace.Vector3;var h=new THREE__namespace.Vector3,v=new THREE__namespace.Vector3,A=new THREE__namespace.Vector3,m=new THREE__namespace.Vector2,y=new THREE__namespace.Vector2,p=new THREE__namespace.Vector2,g=new THREE__namespace.Vector3,b=new THREE__namespace.Vector3;function T(D,K,z){h.fromArray(i,D*3),v.fromArray(i,K*3),A.fromArray(i,z*3),m.fromArray(s,D*2),y.fromArray(s,K*2),p.fromArray(s,z*2);var G=v.x-h.x,W=A.x-h.x,Q=v.y-h.y,X=A.y-h.y,ee=v.z-h.z,J=A.z-h.z,Z=y.x-m.x,te=p.x-m.x,ae=y.y-m.y,re=p.y-m.y,ie=1/(Z*re-te*ae);g.set((re*G-ae*W)*ie,(re*Q-ae*X)*ie,(re*ee-ae*J)*ie),b.set((Z*W-te*G)*ie,(Z*X-te*Q)*ie,(Z*J-te*ee)*ie),d[D].add(g),d[K].add(g),d[z].add(g),c[D].add(b),c[K].add(b),c[z].add(b)}var _=n.groups;_.length===0&&(_=[{start:0,count:r.length}]);for(var f=0,w=_.length;f<w;++f)for(var x=_[f],M=x.start,R=x.count,I=M,S=M+R;I<S;I+=3)T(r[I+0],r[I+1],r[I+2]);var B=new THREE__namespace.Vector3,F=new THREE__namespace.Vector3,O=new THREE__namespace.Vector3,H=new THREE__namespace.Vector3,k,N,q;function V(D){O.fromArray(o,D*3),H.copy(O),N=d[D],B.copy(N),B.sub(O.multiplyScalar(O.dot(N))).normalize(),F.crossVectors(H,N),q=F.dot(c[D]),k=q<0?-1:1,l[D*4]=B.x,l[D*4+1]=B.y,l[D*4+2]=B.z,l[D*4+3]=k}for(var f=0,w=_.length;f<w;++f)for(var x=_[f],M=x.start,R=x.count,I=M,S=M+R;I<S;I+=3)V(r[I+0]),V(r[I+1]),V(r[I+2])},mergeBufferGeometries:function(n,t){for(var e=n[0].index!==null,r=new Set(Object.keys(n[0].attributes)),i=new Set(Object.keys(n[0].morphAttributes)),o={},s={},u=new THREE__namespace.BufferGeometry,l=0,d=0;d<n.length;++d){var c=n[d];if(e!==(c.index!==null))return null;for(var f in c.attributes){if(!r.has(f))return null;o[f]===void 0&&(o[f]=[]),o[f].push(c.attributes[f])}for(var f in c.morphAttributes){if(!i.has(f))return null;s[f]===void 0&&(s[f]=[]),s[f].push(c.morphAttributes[f])}if(u.userData.mergedUserData=u.userData.mergedUserData||[],u.userData.mergedUserData.push(c.userData),t){var h;if(e)h=c.index.count;else if(c.attributes.position!==void 0)h=c.attributes.position.count;else return null;u.addGroup(l,h,d),l+=h}}if(e){for(var v=0,A=[],d=0;d<n.length;++d){for(var m=n[d].index,y=0;y<m.count;++y)A.push(m.getX(y)+v);v+=n[d].attributes.position.count}u.setIndex(A)}for(var f in o){var p=this.mergeBufferAttributes(o[f]);if(!p)return null;u.setAttribute(f,p)}for(var f in s){var g=s[f][0].length;if(g===0)break;u.morphAttributes=u.morphAttributes||{},u.morphAttributes[f]=[];for(var d=0;d<g;++d){for(var b=[],y=0;y<s[f].length;++y)b.push(s[f][y][d]);var T=this.mergeBufferAttributes(b);if(!T)return null;u.morphAttributes[f].push(T)}}return u},mergeBufferAttributes:function(n){for(var t,e,r,i=0,o=0;o<n.length;++o){var s=n[o];if(s.isInterleavedBufferAttribute||(t===void 0&&(t=s.array.constructor),t!==s.array.constructor)||(e===void 0&&(e=s.itemSize),e!==s.itemSize)||(r===void 0&&(r=s.normalized),r!==s.normalized))return null;i+=s.array.length}for(var u=new t(i),l=0,o=0;o<n.length;++o)u.set(n[o].array,l),l+=n[o].array.length;return new THREE__namespace.BufferAttribute(u,e,r)},interleaveAttributes:function(n){for(var t,e=0,r=0,i=0,o=n.length;i<o;++i){var s=n[i];if(t===void 0&&(t=s.array.constructor),t!==s.array.constructor)return console.warn("AttributeBuffers of different types cannot be interleaved"),null;e+=s.array.length,r+=s.itemSize}for(var u=new THREE__namespace.InterleavedBuffer(new t(e),r),l=0,d=[],c=["getX","getY","getZ","getW"],f=["setX","setY","setZ","setW"],h=0,o=n.length;h<o;h++){var s=n[h],v=s.itemSize,A=s.count,m=new THREE__namespace.InterleavedBufferAttribute(u,v,l,s.normalized);d.push(m),l+=v;for(var y=0;y<A;y++)for(var p=0;p<v;p++)m[f[p]](y,s[c[p]](y))}return d},estimateBytesUsed:function(n){var t=0;for(var e in n.attributes){var r=n.getAttribute(e);t+=r.count*r.itemSize*r.array.BYTES_PER_ELEMENT}var i=n.getIndex();return t+=i?i.count*i.itemSize*i.array.BYTES_PER_ELEMENT:0,t},mergeVertices:function(n,t){t===void 0&&(t=1e-4),t=Math.max(t,Number.EPSILON);for(var e={},r=n.getIndex(),i=n.getAttribute("position"),o=r?r.count:i.count,s=0,u=Object.keys(n.attributes),l={},d={},c=[],f=["getX","getY","getZ","getW"],h=0,v=u.length;h<v;h++){var A=u[h];l[A]=[];var m=n.morphAttributes[A];m&&(d[A]=new Array(m.length).fill().map(function(){return[]}))}for(var y=Math.log10(1/t),p=Math.pow(10,y),h=0;h<o;h++){for(var g=r?r.getX(h):h,b="",T=0,v=u.length;T<v;T++)for(var A=u[T],_=n.getAttribute(A),w=_.itemSize,x=0;x<w;x++)b+="".concat(~~(_[f[x]](g)*p),",");if(b in e)c.push(e[b]);else{for(var T=0,v=u.length;T<v;T++)for(var A=u[T],_=n.getAttribute(A),m=n.morphAttributes[A],w=_.itemSize,M=l[A],R=d[A],x=0;x<w;x++){var I=f[x];if(M.push(_[I](g)),m)for(var S=0,B=m.length;S<B;S++)R[S].push(m[S][I](g))}e[b]=s,c.push(s),s++}}for(var F=n.clone(),h=0,v=u.length;h<v;h++){var A=u[h],O=n.getAttribute(A),H=new O.array.constructor(l[A]),_=new THREE__namespace.BufferAttribute(H,O.itemSize,O.normalized);if(F.setAttribute(A,_),A in d)for(var T=0;T<d[A].length;T++){var k=n.morphAttributes[A][T],H=new k.array.constructor(d[A][T]),N=new THREE__namespace.BufferAttribute(H,k.itemSize,k.normalized);F.morphAttributes[A][T]=N}}return F.setIndex(c),F}};function isThirdPersonMode(n){switch(n){case"Floorplan":return!0;case"Mapview":return!0;default:return!1}}function isFristPersonMode(n){switch(n){case"Panorama":return!0;case"VRPanorama":return!0;case"XRPanorama":return!0;case"Model":return!0;case"DepthPanorama":return!0;default:return!1}}var scratchVector3=new THREE__namespace.Vector3,scratchSphere=new THREE__namespace.Sphere,scratchMatrix4=new THREE__namespace.Matrix4,scratchMatrix4Inverse=new THREE__namespace.Matrix4,scratchBoundingBox=new THREE__namespace.Box3,ROTATE_X_90_MATRIX=new THREE__namespace.Matrix4().fromArray([1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1]),DEFAULT_BOUNDING=new THREE__namespace.Box3(new THREE__namespace.Vector3(-.5,-.5,-.5),new THREE__namespace.Vector3(.5,.5,.5));function getExt(n){var t=/([0-9a-z\.\_\-]+)([\?\#].*)?$/i.exec(n);if(t){var e=String(t[1]).trim().split(".").slice(1).reverse()[0];if(e)return e}return""}var Model=function(n){__extends(t,n);function t(e){e===void 0&&(e={});var r,i,o,s,u=n.call(this)||this;return u.name="",u.coordinatesSystemTransformers=(r=e.coordinatesSystemTransformers)!==null&&r!==void 0?r:[],u.onError=(i=e.onError)!==null&&i!==void 0?i:noop$1,u.onShownFloorChange=(o=e.onShownFloorChange)!==null&&o!==void 0?o:noop$1,u.onLoad=(s=e.onLoad)!==null&&s!==void 0?s:noop$1,u.work=null,u.viewLayers=[],u.bounding=new THREE__namespace.Box3(new THREE__namespace.Vector3,new THREE__namespace.Vector3),u.floorLength=0,u.textureOptions={},u.refined=!1,u.refineProgress=[0,0],u.loaded=!1,u.matrixAutoUpdate=!1,u.renderOrder=-4,u.needsRender=!0,u.autoRefine=!0,u.materialVersion=0,u.materialParameters=__assign({},defaultPbmParameters),u.cacheCameras=[],u.disposed=!1,u}return Object.defineProperty(t.prototype,"empty",{get:function(){return this.viewLayers.length===0},enumerable:!1,configurable:!0}),t.prototype.getMaterial=function(){return __assign({},this.materialParameters)},t.prototype.setMaterial=function(e){var r=this.materialParameters.shownFloorIndex,i=updatePBMParameters(this.materialParameters,e);if(i){var o=this.materialParameters.shownFloorIndex;r!==o&&this.onShownFloorChange(o),this.materialVersion++,this.needsRender=!0}},Object.defineProperty(t.prototype,"shownFloorIndex",{get:function(){return this.materialParameters.shownFloorIndex},set:function(e){this.setMaterial({shownFloorIndex:e})},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"shownFloor",{get:function(){return this.shownFloorIndex===-1?null:this.shownFloorIndex},set:function(e){this.shownFloorIndex=e===null?-1:e},enumerable:!1,configurable:!0}),t.prototype.show=function(e){this.shownFloor=e??null},Object.defineProperty(t.prototype,"clippers",{get:function(){return this.materialParameters.clippers},set:function(e){this.setMaterial({clippers:e})},enumerable:!1,configurable:!0}),t.prototype.getEdgesBySphere=function(e,r){r===void 0&&(r=30/180*Math.PI);for(var i=Math.cos(r),o=[],s=0,u=this.children;s<u.length;s++){var l=u[s];if(l instanceof Tile3DModel){var d=l.tileset.selectedTiles;d.forEach(function(c){var f,h,v;if(!(c.boundingVolume&&c.boundingVolume.distanceTo(e.center)>e.radius)){var A=(h=(f=c.content)===null||f===void 0?void 0:f.data)===null||h===void 0?void 0:h.object;if(A&&A.visible){var m=[];if(A.traverseVisible(function(G){if(G instanceof THREE__namespace.Mesh){var W=bvhMeshMap.get(G);if(W){scratchMatrix4.copy(G.matrixWorld),scratchMatrix4Inverse.getInverse(scratchMatrix4),scratchSphere.copy(e).applyMatrix4(scratchMatrix4Inverse);var Q=W.trianglesInSphere(scratchSphere.center,scratchSphere.radius),X=new THREE__namespace.BufferGeometry;X.setAttribute("position",new THREE__namespace.BufferAttribute(Q,3)),X.applyMatrix4(G.matrixWorld),X=BufferGeometryUtils.mergeVertices(X,.01),m.push(X)}}}),m.length===0)return;for(var y=["a","b","c"],p=BufferGeometryUtils.mergeBufferGeometries(m,!1),g=p.getAttribute("position").array,b=((v=p.getIndex())===null||v===void 0?void 0:v.array)||[],T=[],_=[],w=0,x=g.length;w<x;w+=3){var M=new THREE__namespace.Vector3(g[w],g[w+1],g[w+2]);T.push(M)}for(var w=0,x=b.length;w<x;w+=3){var R=b[w],I=b[w+1],S=b[w+2],B=new THREE__namespace.Vector3().crossVectors(T[I].clone().sub(T[R]),T[S].clone().sub(T[R])).normalize();_.push({a:R,b:I,c:S,normal:B})}for(var F={},w=0,x=_.length;w<x;w++)for(var O=_[w],H=0;H<3;H++){var k=O[y[H]],N=O[y[(H+1)%3]],q=[Math.min(k,N),Math.max(k,N)],V=q[0]+"-"+q[1];F[V]===void 0?F[V]={index1:q[0],index2:q[1],face1:w}:F[V].face2=w}for(var V in F){var D=F[V];if(D.face2===void 0||_[D.face1].normal.dot(_[D.face2].normal)<=i){var K=T[D.index1],z=T[D.index2];o.push(new THREE__namespace.Line3(K,z))}}T.length=0,_.length=0}}})}}return o},t.prototype.intersectRaycaster=function(e,r,i){r===void 0&&(r=null),i===void 0&&(i=!0);for(var o=[],s=0,u=this.children.length;s<u;s++){var l=this.children[s];l.visible&&l instanceof Tile3DModel&&l.intersectRaycaster(e,!1,o)}return r!=null&&(o=o.filter(function(d){return d.floor===r})),i&&o.sort(function(d,c){return d.distance-c.distance}),o},t.prototype.load=function(e,r){var i,o=this,s,u;if(r===void 0&&(r={}),this.work=e,this.name=this.work.workCode,!e.model)return Promise.resolve();for(var l=e.model,d=e.options,c=0,f=0,h=e.observers;f<h.length;f++){var v=h[f];c=Math.max(c,v.floorIndex)}this.floorLength=c+1;for(var A=!1,m=[],y=function(F){var O=F.tileset,H=F.upAxis,k=F.name,N=F.type;N==="mesh"&&(A=!0);var q=O.split("#"),V=q[0],D=q[1],K=(s=(D||V).split("?")[1])!==null&&s!==void 0?s:"",z=getFetcher(e).ajax(imageURL(O,{key:"model.0"}),{responseType:"text"}).then(function(G){var W=JSON.parse(G.body),Q=W.root;"lodVersion"in W&&(H="-Y","floorInfo"in W&&(W.properties=W.properties||{},W.properties.floorInfo=W.floorInfo.map(function(Z){return{ground:-Z.ground,height:Z.height}}),delete W.floorInfo),W.asset.tilesetVersion=String(W.lodVersion),delete W.lodVersion);var X=Q.boundingVolume?makeBoundingVolume(Q.boundingVolume):void 0;X&&Q.transform&&X.applyMatrix4(scratchMatrix4.fromArray(Q.transform));var ee=o.coordinatesSystemTransformers.find(function(Z){return Z.name===H});if(!ee)return Promise.reject(new Error("CoordinatesSystemTransformers: ".concat(H," not found.")));var J=new THREE__namespace.Vector3;return X&&X.getCenter(J),"transformToEarthCentered"in ee?Promise.resolve().then(function(){return ee.transformToEarthCentered(J)}).then(function(Z){var te,ae=new THREE__namespace.Matrix4,re="";if(X){X.getCenter(scratchVector3),scratchVector3.applyMatrix4(Z),ae.premultiply(Z).premultiply(getWorldToLocalMatrix(scratchVector3,scratchMatrix4)).premultiply(ROTATE_X_90_MATRIX);var ie=coordinatesFromPoint(scratchVector3),de=ie.longitude,se=ie.latitude;re=[se,de].map(function(pe){return(pe/Math.PI*180).toFixed(6)}).join(",")}return W.root={refine:(te=Q.refine)!==null&&te!==void 0?te:"REPLACE",geometricError:W.geometricError,transform:ae.toArray(),boundingVolume:X?X.toJson():void 0,viewerRequestVolume:d.viewerRequestVolume?d.viewerRequestVolume.toJson():void 0,children:[Q]},{tilesetHeader:W,coordinates:re,worldToLocalTransform:ae}}):Promise.resolve().then(function(){return ee.transformToUpAxisZ(J)}).then(function(Z){var te,ae=new THREE__namespace.Matrix4;ae.premultiply(Z).premultiply(ROTATE_X_90_MATRIX);var re="";return W.root={refine:(te=Q.refine)!==null&&te!==void 0?te:"REPLACE",geometricError:W.geometricError,transform:ae.toArray(),boundingVolume:X?X.toJson():void 0,viewerRequestVolume:d.viewerRequestVolume?d.viewerRequestVolume.toJson():void 0,children:[Q]},{tilesetHeader:W,coordinates:re,worldToLocalTransform:ae}})}).then(function(G){var W=G.tilesetHeader,Q=G.coordinates,X=G.worldToLocalTransform,ee=O?O.slice(0,O.lastIndexOf("/")+1):"",J=new Tile3DModel(o,N,W,{resourcePath:ee,search:K,fetcher:getFetcher(e)});J.name=O,J.matrix.copy(d.transform),J.matrix.decompose(J.position,J.quaternion,J.scale),J.matrixWorldNeedsUpdate=!0;var Z=function(ae){var re=pointFromCoordinates(ae);return re.applyMatrix4(X).applyMatrix4(J.matrix)},te=function(ae){var re=new THREE__namespace.Matrix4().premultiply(X).premultiply(J.matrix),ie=new THREE__namespace.Matrix4().getInverse(re);return coordinatesFromPoint(ae.clone().applyMatrix4(ie))};return{name:k,type:N,upAxis:H,coordinates:Q,scene:J,error:null,coordinatesToWorldPoint:Z,worldPointToCoordinates:te}});m.push(z.catch(function(G){o.onError(G);var W=function(X){throw new Error("coordinatesToWorldPoint require World Coordinates upAxis.")},Q=function(X){throw new Error("worldPointToCoordinates require World Coordinates upAxis.")};return{name:k,type:N,scene:null,error:G,upAxis:H,coordinates:"",coordinatesToWorldPoint:W,worldPointToCoordinates:Q}}))},p=0,g=l.layers;p<g.length;p++){var b=g[p];y(b)}if(!A&&l.file){var T=l.file,_=l.textureBase,w=l.textures,x={asset:{gltfUpAxis:"Z",version:"0.0"},geometricError:0,root:{content:{uri:T},refine:"REPLACE",geometricError:0,viewerRequestVolume:d.viewerRequestVolume?d.viewerRequestVolume.toJson():void 0,extras:(i={},i[getExt(T)||"at3d"]={textureBaseUri:_,textureArray:w,textureOptions:(u=r.textureOptions)!==null&&u!==void 0?u:{}},i)}},M=T.slice(0,T.lastIndexOf("/")+1),R=new Tile3DModel(this,"mesh",x,{resourcePath:M,fetcher:getFetcher(e)});R.name=T,R.matrix.copy(d.transform),R.matrix.decompose(R.position,R.quaternion,R.scale),R.matrixWorldNeedsUpdate=!0;var I=function(F){throw new Error("coordinatesToWorldPoint require WGS84 upAxis.")},S=function(F){throw new Error("worldPointToCoordinates require WGS84 upAxis.")},B=Promise.resolve({scene:R,error:null,coordinates:"",name:"fallback",type:"mesh",upAxis:"Y",coordinatesToWorldPoint:I,worldPointToCoordinates:S});m.push(B)}return Promise.all(m).then(function(F){for(var O=[],H=[],k=[],N=0,q=F;N<q.length;N++){var V=q[N];if(o.viewLayers.push(V),V.scene){if(o.disposed){V.scene.dispose();continue}switch(o.add(V.scene),V.scene.visible=!1,V.type){case"lod":O.push(V.scene);break;case"point_cloud":H.push(V.scene);break;default:k.push(V.scene);break}}}O.length?O[0].visible=!0:H.length?H[0].visible=!0:k.length&&(k[0].visible=!0)})},t.prototype.update=function(e,r,i){var o,s,u,l,d,c;if(this.children.length){var f=this.loaded;this.refined=this.work!==null,this.refineProgress[0]=0,this.refineProgress[1]=0,this.loaded=this.work!==null,this.bounding.makeEmpty();for(var h=0,v=this.children;h<v.length;h++){var A=v[h];A instanceof Tile3DModel&&(this.work&&(A.minLevelOfDetail=(o=this.work.options.modelMinLevelOfDetail)!==null&&o!==void 0?o:Tile3DModel.DEFAULT_MIN_LEVEL_OF_DETAIL,A.maxLevelOfDetail=this.materialParameters.modelAlpha===0||!A.loaded?0:(s=this.work.options.modelMaxLevelOfDetail)!==null&&s!==void 0?s:Tile3DModel.DEFAULT_MAX_LEVEL_OF_DETAIL,A.maxScreenSpaceError=(u=this.work.options.modelMaxScreenSpaceError)!==null&&u!==void 0?u:Tile3DModel.DEFAULT_MAX_SCREEN_SPACE_ERROR,A.maxRequests=(l=this.work.options.modelMaxRequests)!==null&&l!==void 0?l:Tile3DModel.DEFAULT_MAX_REQUESTS,A.maxMemoryUsage=(d=this.work.options.modelMaxMemoryUsage)!==null&&d!==void 0?d:Tile3DModel.DEFAULT_MAX_MEMORY_USAGE,A.debug=(c=this.work.options.debug)!==null&&c!==void 0?c:!1,A.cacheCameras=this.cacheCameras,this.autoRefine===!1?A.needsRefined=!1:isFristPersonMode(i)?A.needsRefined=this.materialParameters.modelAlpha===0||this.materialParameters.modelAlpha===1:A.needsRefined=!0,this.work.options.transform.equals(A.matrix)||(A.matrix.copy(this.work.options.transform),A.matrix.decompose(A.position,A.quaternion,A.scale),A.matrixWorldNeedsUpdate=!0)),A.update(e,r),A.boundingBox.isEmpty()||(scratchBoundingBox.copy(A.boundingBox).applyMatrix4(A.matrix),this.bounding.union(scratchBoundingBox)),A.needsRender===!0&&(A.needsRender=!1,this.needsRender=!0),A.refined===!1&&(this.refined=!1),this.refineProgress[0]+=A.refineProgress[0],this.refineProgress[1]+=A.refineProgress[1],A.loaded===!1&&(this.loaded=!1))}this.bounding.isEmpty()&&this.bounding.copy(DEFAULT_BOUNDING),f===!1&&this.loaded===!0&&this.onLoad()}else this.work&&!this.work.model?(this.refined=!0,this.refineProgress[0]=0,this.refineProgress[1]=0,this.loaded=!0):(this.refined=!1,this.refineProgress[0]=0,this.refineProgress[1]=0,this.loaded=!1),this.bounding.set(new THREE__namespace.Vector3,new THREE__namespace.Vector3)},t.prototype.dispose=function(){this.disposed=!0;for(var e;e=this.children[0];)e instanceof Tile3DModel&&e.dispose(),this.remove(e)},t}(THREE__namespace.Object3D);function createModels(){var n=new THREE__namespace.Box3,t=omit(defaultPbmParameters,["clippers","shownFloorIndex"]),e=Object.assign([],{bounding:n,needsRender:!1,refined:!1,refineProgress:[0,0],loaded:!1,materialVersion:0,cacheCameras:[],autoUpdate:!0,intersectRaycaster:function(r,i,o){o===void 0&&(o=!0);var s;if(e.length===1)s=e[0].intersectRaycaster(r,i,o);else if(e.length===0)s=[];else{s=[];for(var u=0,l=e;u<l.length;u++){var d=l[u];if(d.visible){var c=d.intersectRaycaster(r,i,!1);c.length&&s.push.apply(s,c)}}o&&s.sort(function(f,h){return f.distance-h.distance})}return s},setMaterial:function(r){var i=updatePBMParameters(t,r);i&&(e.materialVersion++,e.needsRender=!0)},getMaterial:function(){return __assign({},t)},update:function(r,i,o){if(e.autoUpdate!==!1){e.refined=e.length>0,e.loaded=e.length>0,e.refineProgress[0]=0,e.refineProgress[1]=0,n.makeEmpty();for(var s=0,u=e.cacheCameras;s<u.length;s++){var l=u[s];l.updateMatrixWorld(!0),l.updateProjectionMatrix()}for(var d=0,c=e;d<c.length;d++){var f=c[d];f.setMaterial(t),f.cacheCameras=e.cacheCameras,f.update(r,i,o),f.needsRender===!0&&(e.needsRender=!0,f.needsRender=!1),f.refined===!1&&(e.refined=!1),e.refineProgress[0]+=f.refineProgress[0],e.refineProgress[1]+=f.refineProgress[1],f.loaded===!1&&(e.loaded=!1),n.union(f.bounding)}n.isEmpty()&&n.copy(DEFAULT_BOUNDING)}}});return e}function mixNumber(n,t,e){return n+(t-n)*e}function value(n,t,e,r){var i=(t*e+2*n)/Math.pow(e,3),o=-(2*t*e+3*n)/Math.pow(e,2),s=t,u=n;return i*Math.pow(r,3)+o*Math.pow(r,2)+s*r+u}function velocity(n,t,e,r){var i=(t*e+2*n)/Math.pow(e,3),o=-(2*t*e+3*n)/Math.pow(e,2),s=t;return 3*i*Math.pow(r,2)+2*o*r+s}function mixCircle(n,t,e,r){var i=r[1]-r[0];return n=circleValue(n,r),t=circleValue(t,r),t-n>i/2?mixNumber(n+i,t,e):n-t>i/2?mixNumber(n-i,t,e):mixNumber(n,t,e)}function circleValue(n,t){var e=t[1]-t[0];return n<t[0]?circleValue(n+e,t):n>=t[1]?circleValue(n-e,t):n}function mixValue(n,t,e,r){return r?mixCircle(n,t,e,r):mixNumber(n,t,e)}var Motion=function(){function n(t){this.config={},this.progress=1,this.ended=!0,this.value={},this.startTime=now(),this.startVelocity=0,this.duration=0,this.keyframes=[];for(var e in t){var r=t[e];typeof r=="number"?(this.value[e]=r,this.config[e]={circle:!1}):(this.value[e]=r.value,this.config[e]={circle:r.circle})}this.keyframes=[{progress:0,value:__assign({},this.value)},{progress:1,value:__assign({},this.value)}]}return n.prototype.getProgress=function(t){var e=t-this.startTime;return e<0?0:e>=this.duration?1:1-value(1,this.startVelocity,this.duration,e)},n.prototype.getValue=function(t){for(var e=1;e<this.keyframes.length;e++)if(this.keyframes[e].progress>t){var r=this.keyframes[e-1],i=this.keyframes[e],o={};for(var s in this.config){var u=(t-r.progress)/(i.progress-r.progress);o[s]=mixValue(r.value[s],i.value[s],u,this.config[s].circle)}return o}return __assign({},this.keyframes[this.keyframes.length-1].value)},n.prototype.getProgressVelocity=function(t){var e=t-this.startTime;return e>=this.duration?0:velocity(1,this.startVelocity,this.duration,e)},n.prototype.update=function(t){return this.ended?!0:(this.progress=Math.min(1,Math.max(0,this.progress,this.getProgress(t))),this.value=this.getValue(this.progress),this.ended=this.progress>=1,this.ended&&this.callbacks&&(this.callbacks[0](),this.callbacks=void 0),this.ended)},n.prototype.getKeyFrameSegment=function(t){for(var e=this.getProgress(t),r=1;r<this.keyframes.length;r++)if(this.keyframes[r].progress>e)return[this.keyframes[r-1],this.keyframes[r]];return[this.keyframes[this.keyframes.length-2],this.keyframes[this.keyframes.length-1]]},n.prototype.getTargetKeyframe=function(){return this.keyframes[this.keyframes.length-1]},n.prototype.set=function(t,e,r,i){var o;r===void 0&&(r=0),isNaN(e)&&(e=0),isNaN(r)&&(r=0),i=i??now();var s=this.getProgress(i),u=this.getValue(s),l={};for(var d in this.config)l[d]=(o=t[d])!==null&&o!==void 0?o:u[d];var c=[{progress:0,value:u},{progress:1,value:l}];return this.setKeyframes(c,e,r,i)},n.prototype.setKeyframes=function(t,e,r,i){var o=this;if(r===void 0&&(r=0),t.length<2)throw new Error("keyframes invalid.");return isNaN(e)&&(e=0),isNaN(r)&&(r=0),this.callbacks&&(this.callbacks[1](new Error("motion aborted.")),this.callbacks=void 0),new Promise(function(s,u){i=i??now(),o.progress=0,o.ended=!1,o.startTime=i,o.startVelocity=r,o.keyframes=t,o.duration=e,e===0?(o.progress=1,o.value=__assign({},t[t.length-1].value)):o.value=__assign({},t[0].value),o.callbacks=[s,u]})},n.prototype.dispose=function(){this.callbacks&&(this.callbacks[1](new Error("motion dispose.")),this.callbacks=void 0)},n}(),easeOut$2=function(n){return n*(2-n)},sharedGeometry2$2=function(){var n=new Float32Array([-.18,0,-.18,.18,0,-.18,-.18,0,.18,.18,0,.18]),t=new Float32Array([1,0,0,0,1,1,0,1]),e=new Uint8Array([0,2,1,2,3,1]),r=new THREE__namespace.BufferGeometry;return r.setAttribute("position",new THREE__namespace.BufferAttribute(n,3)),r.setAttribute("uv",new THREE__namespace.BufferAttribute(t,2)),r.setIndex(new THREE__namespace.BufferAttribute(e,1)),r}(),vertexShader$5=`
|
|
950
|
+
`+JSON.stringify(n))}}function createWorks(n){for(var t={},e=[],r={},i=0,o=n;i<o.length;i++){var s=o[i],u=t[s.workCode];u||(u=t[s.workCode]=new THREE__namespace.Matrix4().copy(s.options.transform));for(var l=0,d=s.observers;l<d.length;l++){var c=d[l],f={isResolved:!0,active:c.active,accessibleIds:c.accessibleIds,visibleIds:c.visibleIds,accessibleNodes:c.accessibleNodes,visibleNodes:c.visibleNodes,floorIndex:c.floorIndex,images:c.images,index:c.index,panoIndex:c.panoIndex,loadable:c.loadable,panoId:c.panoId,pano:c.pano,work:c.work,derivedId:c.derivedId,video:c.video,position:new THREE__namespace.Vector3().copy(c.position).applyMatrix4(u),standingPosition:new THREE__namespace.Vector3().copy(c.standingPosition).applyMatrix4(u),quaternion:new THREE__namespace.Quaternion().setFromRotationMatrix(scratchMatrix4$1.makeRotationFromQuaternion(c.quaternion).premultiply(u))};Object.freeze(f),e.push(f),r[f.panoId]=f}}Object.freeze(e);for(var h=n.slice(),v={},A=0,m=h;A<m.length;A++){var s=m[A];v[s.workCode]=s}return Object.freeze(Object.assign(h,{get initial(){return h.length>0?h[0].initial:{work:{}}},get resolvedObservers(){return e},getWork:function(y){return v[y]},getResolvedObserver:function(y){var p,g;return isPanoId(y)?r[y]:typeof y=="number"?r[panoStringify({workCode:(g=(p=n[0])===null||p===void 0?void 0:p.workCode)!==null&&g!==void 0?g:"",panoIndex:y})]:r[panoStringify(y)]},update:function(){for(var y={},p=0,g=h;p<g.length;p++){var b=g[p],T=b.options.transform,_=t[b.workCode];_?_.equals(T)||(_.copy(T),y[b.workCode]=!0):(t[b.workCode]=new THREE__namespace.Matrix4().copy(T),y[b.workCode]=!0)}for(var w=0,x=e;w<x.length;w++){var M=x[w];if(y[M.work.workCode]===!0){var R=M.work.observers[M.index],I=M.work.options.transform;M.position.copy(R.position).applyMatrix4(I),M.standingPosition.copy(R.standingPosition).applyMatrix4(I),M.quaternion.setFromRotationMatrix(scratchMatrix4$1.makeRotationFromQuaternion(R.quaternion).premultiply(I))}}}}))}var fetcherMap=new Map;function getFetcher(n){var t=fetcherMap.get(n);if(t)return t;throw new Error("fetcher never registered.")}function registerFetcher(n,t){return fetcherMap.set(n,t)}var scratchVector3$1=new THREE__namespace.Vector3,scratchMatrix3=new THREE__namespace.Matrix3,a=6378137,invF=298.257223563;function coordinatesFromPoint(n){for(var t=a-a/invF,e=(a*a-t*t)/(a*a),r=Math.sqrt(n.x*n.x+n.y*n.y),i=1e-12,o=1e3,s=0,u=Math.atan2(n.z,r),l=0;s++<o;){var d=Math.sin(u),c=a/Math.sqrt(1-e*d*d);l=r/Math.cos(u)-c;var f=Math.atan2(n.z/(c*(1-e)+l),r/(c+l)),h=Math.abs(f-u);if(h<i)break;u=f}return{longitude:Math.atan2(n.y,n.x),latitude:u,altitude:l}}function pointFromCoordinates(n){var t=a-a/invF,e=(a*a-t*t)/(a*a),r=Math.sin(n.latitude),i=Math.cos(n.latitude),o=Math.sin(n.longitude),s=Math.cos(n.longitude),u=a/Math.sqrt(1-e*r*r),l=(u+n.altitude)*i*s,d=(u+n.altitude)*i*o,c=(t*t/(a*a)*u+n.altitude)*r;return new THREE__namespace.Vector3(l,d,c)}function getWorldToLocalMatrix(n,t){var e=coordinatesFromPoint(n),r=e.longitude,i=e.latitude,o=e.altitude,s=Math.sin(i),u=Math.sin(r),l=Math.cos(i),d=Math.cos(r),c=t.fromArray([-u,-s*d,l*d,0,+d,-s*u,l*u,0,0,l,s,0,0,0,0,1]),f=scratchMatrix3.setFromMatrix4(c),h=scratchVector3$1.copy(n).applyMatrix3(f).multiplyScalar(-1);c.setPosition(h);var v=new THREE__namespace.Matrix4().fromArray([1,0,0,0,0,1,0,0,0,0,1,0,0,0,o,1]);return c.premultiply(v),c}var BufferGeometryUtils={computeTangents:function(n){var t=n.index,e=n.attributes;if(t===null||e.position===void 0||e.normal===void 0||e.uv===void 0){console.warn("THREE.BufferGeometry: Missing required attributes (index, position, normal or uv) in BufferGeometry.computeTangents()");return}var r=t.array,i=e.position.array,o=e.normal.array,s=e.uv.array,u=i.length/3;e.tangent===void 0&&n.setAttribute("tangent",new THREE__namespace.BufferAttribute(new Float32Array(4*u),4));for(var l=e.tangent.array,d=[],c=[],f=0;f<u;f++)d[f]=new THREE__namespace.Vector3,c[f]=new THREE__namespace.Vector3;var h=new THREE__namespace.Vector3,v=new THREE__namespace.Vector3,A=new THREE__namespace.Vector3,m=new THREE__namespace.Vector2,y=new THREE__namespace.Vector2,p=new THREE__namespace.Vector2,g=new THREE__namespace.Vector3,b=new THREE__namespace.Vector3;function T(D,K,z){h.fromArray(i,D*3),v.fromArray(i,K*3),A.fromArray(i,z*3),m.fromArray(s,D*2),y.fromArray(s,K*2),p.fromArray(s,z*2);var G=v.x-h.x,W=A.x-h.x,Q=v.y-h.y,X=A.y-h.y,ee=v.z-h.z,J=A.z-h.z,Z=y.x-m.x,te=p.x-m.x,ae=y.y-m.y,re=p.y-m.y,ie=1/(Z*re-te*ae);g.set((re*G-ae*W)*ie,(re*Q-ae*X)*ie,(re*ee-ae*J)*ie),b.set((Z*W-te*G)*ie,(Z*X-te*Q)*ie,(Z*J-te*ee)*ie),d[D].add(g),d[K].add(g),d[z].add(g),c[D].add(b),c[K].add(b),c[z].add(b)}var _=n.groups;_.length===0&&(_=[{start:0,count:r.length}]);for(var f=0,w=_.length;f<w;++f)for(var x=_[f],M=x.start,R=x.count,I=M,S=M+R;I<S;I+=3)T(r[I+0],r[I+1],r[I+2]);var B=new THREE__namespace.Vector3,O=new THREE__namespace.Vector3,F=new THREE__namespace.Vector3,H=new THREE__namespace.Vector3,k,N,q;function V(D){F.fromArray(o,D*3),H.copy(F),N=d[D],B.copy(N),B.sub(F.multiplyScalar(F.dot(N))).normalize(),O.crossVectors(H,N),q=O.dot(c[D]),k=q<0?-1:1,l[D*4]=B.x,l[D*4+1]=B.y,l[D*4+2]=B.z,l[D*4+3]=k}for(var f=0,w=_.length;f<w;++f)for(var x=_[f],M=x.start,R=x.count,I=M,S=M+R;I<S;I+=3)V(r[I+0]),V(r[I+1]),V(r[I+2])},mergeBufferGeometries:function(n,t){for(var e=n[0].index!==null,r=new Set(Object.keys(n[0].attributes)),i=new Set(Object.keys(n[0].morphAttributes)),o={},s={},u=new THREE__namespace.BufferGeometry,l=0,d=0;d<n.length;++d){var c=n[d];if(e!==(c.index!==null))return null;for(var f in c.attributes){if(!r.has(f))return null;o[f]===void 0&&(o[f]=[]),o[f].push(c.attributes[f])}for(var f in c.morphAttributes){if(!i.has(f))return null;s[f]===void 0&&(s[f]=[]),s[f].push(c.morphAttributes[f])}if(u.userData.mergedUserData=u.userData.mergedUserData||[],u.userData.mergedUserData.push(c.userData),t){var h;if(e)h=c.index.count;else if(c.attributes.position!==void 0)h=c.attributes.position.count;else return null;u.addGroup(l,h,d),l+=h}}if(e){for(var v=0,A=[],d=0;d<n.length;++d){for(var m=n[d].index,y=0;y<m.count;++y)A.push(m.getX(y)+v);v+=n[d].attributes.position.count}u.setIndex(A)}for(var f in o){var p=this.mergeBufferAttributes(o[f]);if(!p)return null;u.setAttribute(f,p)}for(var f in s){var g=s[f][0].length;if(g===0)break;u.morphAttributes=u.morphAttributes||{},u.morphAttributes[f]=[];for(var d=0;d<g;++d){for(var b=[],y=0;y<s[f].length;++y)b.push(s[f][y][d]);var T=this.mergeBufferAttributes(b);if(!T)return null;u.morphAttributes[f].push(T)}}return u},mergeBufferAttributes:function(n){for(var t,e,r,i=0,o=0;o<n.length;++o){var s=n[o];if(s.isInterleavedBufferAttribute||(t===void 0&&(t=s.array.constructor),t!==s.array.constructor)||(e===void 0&&(e=s.itemSize),e!==s.itemSize)||(r===void 0&&(r=s.normalized),r!==s.normalized))return null;i+=s.array.length}for(var u=new t(i),l=0,o=0;o<n.length;++o)u.set(n[o].array,l),l+=n[o].array.length;return new THREE__namespace.BufferAttribute(u,e,r)},interleaveAttributes:function(n){for(var t,e=0,r=0,i=0,o=n.length;i<o;++i){var s=n[i];if(t===void 0&&(t=s.array.constructor),t!==s.array.constructor)return console.warn("AttributeBuffers of different types cannot be interleaved"),null;e+=s.array.length,r+=s.itemSize}for(var u=new THREE__namespace.InterleavedBuffer(new t(e),r),l=0,d=[],c=["getX","getY","getZ","getW"],f=["setX","setY","setZ","setW"],h=0,o=n.length;h<o;h++){var s=n[h],v=s.itemSize,A=s.count,m=new THREE__namespace.InterleavedBufferAttribute(u,v,l,s.normalized);d.push(m),l+=v;for(var y=0;y<A;y++)for(var p=0;p<v;p++)m[f[p]](y,s[c[p]](y))}return d},estimateBytesUsed:function(n){var t=0;for(var e in n.attributes){var r=n.getAttribute(e);t+=r.count*r.itemSize*r.array.BYTES_PER_ELEMENT}var i=n.getIndex();return t+=i?i.count*i.itemSize*i.array.BYTES_PER_ELEMENT:0,t},mergeVertices:function(n,t){t===void 0&&(t=1e-4),t=Math.max(t,Number.EPSILON);for(var e={},r=n.getIndex(),i=n.getAttribute("position"),o=r?r.count:i.count,s=0,u=Object.keys(n.attributes),l={},d={},c=[],f=["getX","getY","getZ","getW"],h=0,v=u.length;h<v;h++){var A=u[h];l[A]=[];var m=n.morphAttributes[A];m&&(d[A]=new Array(m.length).fill().map(function(){return[]}))}for(var y=Math.log10(1/t),p=Math.pow(10,y),h=0;h<o;h++){for(var g=r?r.getX(h):h,b="",T=0,v=u.length;T<v;T++)for(var A=u[T],_=n.getAttribute(A),w=_.itemSize,x=0;x<w;x++)b+="".concat(~~(_[f[x]](g)*p),",");if(b in e)c.push(e[b]);else{for(var T=0,v=u.length;T<v;T++)for(var A=u[T],_=n.getAttribute(A),m=n.morphAttributes[A],w=_.itemSize,M=l[A],R=d[A],x=0;x<w;x++){var I=f[x];if(M.push(_[I](g)),m)for(var S=0,B=m.length;S<B;S++)R[S].push(m[S][I](g))}e[b]=s,c.push(s),s++}}for(var O=n.clone(),h=0,v=u.length;h<v;h++){var A=u[h],F=n.getAttribute(A),H=new F.array.constructor(l[A]),_=new THREE__namespace.BufferAttribute(H,F.itemSize,F.normalized);if(O.setAttribute(A,_),A in d)for(var T=0;T<d[A].length;T++){var k=n.morphAttributes[A][T],H=new k.array.constructor(d[A][T]),N=new THREE__namespace.BufferAttribute(H,k.itemSize,k.normalized);O.morphAttributes[A][T]=N}}return O.setIndex(c),O}};function isThirdPersonMode(n){switch(n){case"Floorplan":return!0;case"Mapview":return!0;default:return!1}}function isFristPersonMode(n){switch(n){case"Panorama":return!0;case"VRPanorama":return!0;case"XRPanorama":return!0;case"Model":return!0;case"DepthPanorama":return!0;default:return!1}}var scratchVector3=new THREE__namespace.Vector3,scratchSphere=new THREE__namespace.Sphere,scratchMatrix4=new THREE__namespace.Matrix4,scratchMatrix4Inverse=new THREE__namespace.Matrix4,scratchBoundingBox=new THREE__namespace.Box3,ROTATE_X_90_MATRIX=new THREE__namespace.Matrix4().fromArray([1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1]),DEFAULT_BOUNDING=new THREE__namespace.Box3(new THREE__namespace.Vector3(-.5,-.5,-.5),new THREE__namespace.Vector3(.5,.5,.5));function getExt(n){var t=/([0-9a-z\.\_\-]+)([\?\#].*)?$/i.exec(n);if(t){var e=String(t[1]).trim().split(".").slice(1).reverse()[0];if(e)return e}return""}var Model=function(n){__extends(t,n);function t(e){e===void 0&&(e={});var r,i,o,s,u=n.call(this)||this;return u.name="",u.coordinatesSystemTransformers=(r=e.coordinatesSystemTransformers)!==null&&r!==void 0?r:[],u.onError=(i=e.onError)!==null&&i!==void 0?i:noop$1,u.onShownFloorChange=(o=e.onShownFloorChange)!==null&&o!==void 0?o:noop$1,u.onLoad=(s=e.onLoad)!==null&&s!==void 0?s:noop$1,u.work=null,u.viewLayers=[],u.bounding=new THREE__namespace.Box3(new THREE__namespace.Vector3,new THREE__namespace.Vector3),u.floorLength=0,u.textureOptions={},u.refined=!1,u.refineProgress=[0,0],u.loaded=!1,u.matrixAutoUpdate=!1,u.renderOrder=-4,u.needsRender=!0,u.autoRefine=!0,u.materialVersion=0,u.materialParameters=__assign({},defaultPbmParameters),u.cacheCameras=[],u.disposed=!1,u}return Object.defineProperty(t.prototype,"empty",{get:function(){return this.viewLayers.length===0},enumerable:!1,configurable:!0}),t.prototype.getMaterial=function(){return __assign({},this.materialParameters)},t.prototype.setMaterial=function(e){var r=this.materialParameters.shownFloorIndex,i=updatePBMParameters(this.materialParameters,e);if(i){var o=this.materialParameters.shownFloorIndex;r!==o&&this.onShownFloorChange(o),this.materialVersion++,this.needsRender=!0}},Object.defineProperty(t.prototype,"shownFloorIndex",{get:function(){return this.materialParameters.shownFloorIndex},set:function(e){this.setMaterial({shownFloorIndex:e})},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"shownFloor",{get:function(){return this.shownFloorIndex===-1?null:this.shownFloorIndex},set:function(e){this.shownFloorIndex=e===null?-1:e},enumerable:!1,configurable:!0}),t.prototype.show=function(e){this.shownFloor=e??null},Object.defineProperty(t.prototype,"clippers",{get:function(){return this.materialParameters.clippers},set:function(e){this.setMaterial({clippers:e})},enumerable:!1,configurable:!0}),t.prototype.getEdgesBySphere=function(e,r){r===void 0&&(r=30/180*Math.PI);for(var i=Math.cos(r),o=[],s=0,u=this.children;s<u.length;s++){var l=u[s];if(l instanceof Tile3DModel){var d=l.tileset.selectedTiles;d.forEach(function(c){var f,h,v;if(!(c.boundingVolume&&c.boundingVolume.distanceTo(e.center)>e.radius)){var A=(h=(f=c.content)===null||f===void 0?void 0:f.data)===null||h===void 0?void 0:h.object;if(A&&A.visible){var m=[];if(A.traverseVisible(function(G){if(G instanceof THREE__namespace.Mesh){var W=bvhMeshMap.get(G);if(W){scratchMatrix4.copy(G.matrixWorld),scratchMatrix4Inverse.getInverse(scratchMatrix4),scratchSphere.copy(e).applyMatrix4(scratchMatrix4Inverse);var Q=W.trianglesInSphere(scratchSphere.center,scratchSphere.radius),X=new THREE__namespace.BufferGeometry;X.setAttribute("position",new THREE__namespace.BufferAttribute(Q,3)),X.applyMatrix4(G.matrixWorld),X=BufferGeometryUtils.mergeVertices(X,.01),m.push(X)}}}),m.length===0)return;for(var y=["a","b","c"],p=BufferGeometryUtils.mergeBufferGeometries(m,!1),g=p.getAttribute("position").array,b=((v=p.getIndex())===null||v===void 0?void 0:v.array)||[],T=[],_=[],w=0,x=g.length;w<x;w+=3){var M=new THREE__namespace.Vector3(g[w],g[w+1],g[w+2]);T.push(M)}for(var w=0,x=b.length;w<x;w+=3){var R=b[w],I=b[w+1],S=b[w+2],B=new THREE__namespace.Vector3().crossVectors(T[I].clone().sub(T[R]),T[S].clone().sub(T[R])).normalize();_.push({a:R,b:I,c:S,normal:B})}for(var O={},w=0,x=_.length;w<x;w++)for(var F=_[w],H=0;H<3;H++){var k=F[y[H]],N=F[y[(H+1)%3]],q=[Math.min(k,N),Math.max(k,N)],V=q[0]+"-"+q[1];O[V]===void 0?O[V]={index1:q[0],index2:q[1],face1:w}:O[V].face2=w}for(var V in O){var D=O[V];if(D.face2===void 0||_[D.face1].normal.dot(_[D.face2].normal)<=i){var K=T[D.index1],z=T[D.index2];o.push(new THREE__namespace.Line3(K,z))}}T.length=0,_.length=0}}})}}return o},t.prototype.intersectRaycaster=function(e,r,i){r===void 0&&(r=null),i===void 0&&(i=!0);for(var o=[],s=0,u=this.children.length;s<u;s++){var l=this.children[s];l.visible&&l instanceof Tile3DModel&&l.intersectRaycaster(e,!1,o)}return r!=null&&(o=o.filter(function(d){return d.floor===r})),i&&o.sort(function(d,c){return d.distance-c.distance}),o},t.prototype.load=function(e,r){var i,o=this,s,u;if(r===void 0&&(r={}),this.work=e,this.name=this.work.workCode,!e.model)return Promise.resolve();for(var l=e.model,d=e.options,c=0,f=0,h=e.observers;f<h.length;f++){var v=h[f];c=Math.max(c,v.floorIndex)}this.floorLength=c+1;for(var A=!1,m=[],y=function(O){var F=O.tileset,H=O.upAxis,k=O.name,N=O.type;N==="mesh"&&(A=!0);var q=F.split("#"),V=q[0],D=q[1],K=(s=(D||V).split("?")[1])!==null&&s!==void 0?s:"",z=getFetcher(e).ajax(imageURL(F,{key:"model.0"}),{responseType:"text"}).then(function(G){var W=JSON.parse(G.body),Q=W.root;"lodVersion"in W&&(H="-Y","floorInfo"in W&&(W.properties=W.properties||{},W.properties.floorInfo=W.floorInfo.map(function(Z){return{ground:-Z.ground,height:Z.height}}),delete W.floorInfo),W.asset.tilesetVersion=String(W.lodVersion),delete W.lodVersion);var X=Q.boundingVolume?makeBoundingVolume(Q.boundingVolume):void 0;X&&Q.transform&&X.applyMatrix4(scratchMatrix4.fromArray(Q.transform));var ee=o.coordinatesSystemTransformers.find(function(Z){return Z.name===H});if(!ee)return Promise.reject(new Error("CoordinatesSystemTransformers: ".concat(H," not found.")));var J=new THREE__namespace.Vector3;return X&&X.getCenter(J),"transformToEarthCentered"in ee?Promise.resolve().then(function(){return ee.transformToEarthCentered(J)}).then(function(Z){var te,ae=new THREE__namespace.Matrix4,re="";if(X){X.getCenter(scratchVector3),scratchVector3.applyMatrix4(Z),ae.premultiply(Z).premultiply(getWorldToLocalMatrix(scratchVector3,scratchMatrix4)).premultiply(ROTATE_X_90_MATRIX);var ie=coordinatesFromPoint(scratchVector3),de=ie.longitude,se=ie.latitude;re=[se,de].map(function(pe){return(pe/Math.PI*180).toFixed(6)}).join(",")}return W.root={refine:(te=Q.refine)!==null&&te!==void 0?te:"REPLACE",geometricError:W.geometricError,transform:ae.toArray(),boundingVolume:X?X.toJson():void 0,viewerRequestVolume:d.viewerRequestVolume?d.viewerRequestVolume.toJson():void 0,children:[Q]},{tilesetHeader:W,coordinates:re,worldToLocalTransform:ae}}):Promise.resolve().then(function(){return ee.transformToUpAxisZ(J)}).then(function(Z){var te,ae=new THREE__namespace.Matrix4;ae.premultiply(Z).premultiply(ROTATE_X_90_MATRIX);var re="";return W.root={refine:(te=Q.refine)!==null&&te!==void 0?te:"REPLACE",geometricError:W.geometricError,transform:ae.toArray(),boundingVolume:X?X.toJson():void 0,viewerRequestVolume:d.viewerRequestVolume?d.viewerRequestVolume.toJson():void 0,children:[Q]},{tilesetHeader:W,coordinates:re,worldToLocalTransform:ae}})}).then(function(G){var W=G.tilesetHeader,Q=G.coordinates,X=G.worldToLocalTransform,ee=F?F.slice(0,F.lastIndexOf("/")+1):"",J=new Tile3DModel(o,N,W,{resourcePath:ee,search:K,fetcher:getFetcher(e)});J.name=F,J.matrix.copy(d.transform),J.matrix.decompose(J.position,J.quaternion,J.scale),J.matrixWorldNeedsUpdate=!0;var Z=function(ae){var re=pointFromCoordinates(ae);return re.applyMatrix4(X).applyMatrix4(J.matrix)},te=function(ae){var re=new THREE__namespace.Matrix4().premultiply(X).premultiply(J.matrix),ie=new THREE__namespace.Matrix4().getInverse(re);return coordinatesFromPoint(ae.clone().applyMatrix4(ie))};return{name:k,type:N,upAxis:H,coordinates:Q,scene:J,error:null,coordinatesToWorldPoint:Z,worldPointToCoordinates:te}});m.push(z.catch(function(G){o.onError(G);var W=function(X){throw new Error("coordinatesToWorldPoint require World Coordinates upAxis.")},Q=function(X){throw new Error("worldPointToCoordinates require World Coordinates upAxis.")};return{name:k,type:N,scene:null,error:G,upAxis:H,coordinates:"",coordinatesToWorldPoint:W,worldPointToCoordinates:Q}}))},p=0,g=l.layers;p<g.length;p++){var b=g[p];y(b)}if(!A&&l.file){var T=l.file,_=l.textureBase,w=l.textures,x={asset:{gltfUpAxis:"Z",version:"0.0"},geometricError:0,root:{content:{uri:T},refine:"REPLACE",geometricError:0,viewerRequestVolume:d.viewerRequestVolume?d.viewerRequestVolume.toJson():void 0,extras:(i={},i[getExt(T)||"at3d"]={textureBaseUri:_,textureArray:w,textureOptions:(u=r.textureOptions)!==null&&u!==void 0?u:{}},i)}},M=T.slice(0,T.lastIndexOf("/")+1),R=new Tile3DModel(this,"mesh",x,{resourcePath:M,fetcher:getFetcher(e)});R.name=T,R.matrix.copy(d.transform),R.matrix.decompose(R.position,R.quaternion,R.scale),R.matrixWorldNeedsUpdate=!0;var I=function(O){throw new Error("coordinatesToWorldPoint require WGS84 upAxis.")},S=function(O){throw new Error("worldPointToCoordinates require WGS84 upAxis.")},B=Promise.resolve({scene:R,error:null,coordinates:"",name:"fallback",type:"mesh",upAxis:"Y",coordinatesToWorldPoint:I,worldPointToCoordinates:S});m.push(B)}return Promise.all(m).then(function(O){for(var F=[],H=[],k=[],N=0,q=O;N<q.length;N++){var V=q[N];if(o.viewLayers.push(V),V.scene){if(o.disposed){V.scene.dispose();continue}switch(o.add(V.scene),V.scene.visible=!1,V.type){case"lod":F.push(V.scene);break;case"point_cloud":H.push(V.scene);break;default:k.push(V.scene);break}}}F.length?F[0].visible=!0:H.length?H[0].visible=!0:k.length&&(k[0].visible=!0)})},t.prototype.update=function(e,r,i){var o,s,u,l,d,c;if(this.children.length){var f=this.loaded;this.refined=this.work!==null,this.refineProgress[0]=0,this.refineProgress[1]=0,this.loaded=this.work!==null,this.bounding.makeEmpty();for(var h=0,v=this.children;h<v.length;h++){var A=v[h];A instanceof Tile3DModel&&(this.work&&(A.minLevelOfDetail=(o=this.work.options.modelMinLevelOfDetail)!==null&&o!==void 0?o:Tile3DModel.DEFAULT_MIN_LEVEL_OF_DETAIL,A.maxLevelOfDetail=this.materialParameters.modelAlpha===0||!A.loaded?0:(s=this.work.options.modelMaxLevelOfDetail)!==null&&s!==void 0?s:Tile3DModel.DEFAULT_MAX_LEVEL_OF_DETAIL,A.maxScreenSpaceError=(u=this.work.options.modelMaxScreenSpaceError)!==null&&u!==void 0?u:Tile3DModel.DEFAULT_MAX_SCREEN_SPACE_ERROR,A.maxRequests=(l=this.work.options.modelMaxRequests)!==null&&l!==void 0?l:Tile3DModel.DEFAULT_MAX_REQUESTS,A.maxMemoryUsage=(d=this.work.options.modelMaxMemoryUsage)!==null&&d!==void 0?d:Tile3DModel.DEFAULT_MAX_MEMORY_USAGE,A.debug=(c=this.work.options.debug)!==null&&c!==void 0?c:!1,A.cacheCameras=this.cacheCameras,this.autoRefine===!1?A.needsRefined=!1:isFristPersonMode(i)?A.needsRefined=this.materialParameters.modelAlpha===0||this.materialParameters.modelAlpha===1:A.needsRefined=!0,this.work.options.transform.equals(A.matrix)||(A.matrix.copy(this.work.options.transform),A.matrix.decompose(A.position,A.quaternion,A.scale),A.matrixWorldNeedsUpdate=!0)),A.update(e,r),A.boundingBox.isEmpty()||(scratchBoundingBox.copy(A.boundingBox).applyMatrix4(A.matrix),this.bounding.union(scratchBoundingBox)),A.needsRender===!0&&(A.needsRender=!1,this.needsRender=!0),A.refined===!1&&(this.refined=!1),this.refineProgress[0]+=A.refineProgress[0],this.refineProgress[1]+=A.refineProgress[1],A.loaded===!1&&(this.loaded=!1))}this.bounding.isEmpty()&&this.bounding.copy(DEFAULT_BOUNDING),f===!1&&this.loaded===!0&&this.onLoad()}else this.work&&!this.work.model?(this.refined=!0,this.refineProgress[0]=0,this.refineProgress[1]=0,this.loaded=!0):(this.refined=!1,this.refineProgress[0]=0,this.refineProgress[1]=0,this.loaded=!1),this.bounding.set(new THREE__namespace.Vector3,new THREE__namespace.Vector3)},t.prototype.dispose=function(){this.disposed=!0;for(var e;e=this.children[0];)e instanceof Tile3DModel&&e.dispose(),this.remove(e)},t}(THREE__namespace.Object3D);function createModels(){var n=new THREE__namespace.Box3,t=omit(defaultPbmParameters,["clippers","shownFloorIndex"]),e=Object.assign([],{bounding:n,needsRender:!1,refined:!1,refineProgress:[0,0],loaded:!1,materialVersion:0,cacheCameras:[],autoUpdate:!0,intersectRaycaster:function(r,i,o){o===void 0&&(o=!0);var s;if(e.length===1)s=e[0].intersectRaycaster(r,i,o);else if(e.length===0)s=[];else{s=[];for(var u=0,l=e;u<l.length;u++){var d=l[u];if(d.visible){var c=d.intersectRaycaster(r,i,!1);c.length&&s.push.apply(s,c)}}o&&s.sort(function(f,h){return f.distance-h.distance})}return s},setMaterial:function(r){var i=updatePBMParameters(t,r);i&&(e.materialVersion++,e.needsRender=!0)},getMaterial:function(){return __assign({},t)},update:function(r,i,o){if(e.autoUpdate!==!1){e.refined=e.length>0,e.loaded=e.length>0,e.refineProgress[0]=0,e.refineProgress[1]=0,n.makeEmpty();for(var s=0,u=e.cacheCameras;s<u.length;s++){var l=u[s];l.updateMatrixWorld(!0),l.updateProjectionMatrix()}for(var d=0,c=e;d<c.length;d++){var f=c[d];f.setMaterial(t),f.cacheCameras=e.cacheCameras,f.update(r,i,o),f.needsRender===!0&&(e.needsRender=!0,f.needsRender=!1),f.refined===!1&&(e.refined=!1),e.refineProgress[0]+=f.refineProgress[0],e.refineProgress[1]+=f.refineProgress[1],f.loaded===!1&&(e.loaded=!1),n.union(f.bounding)}n.isEmpty()&&n.copy(DEFAULT_BOUNDING)}}});return e}function mixNumber(n,t,e){return n+(t-n)*e}function value(n,t,e,r){var i=(t*e+2*n)/Math.pow(e,3),o=-(2*t*e+3*n)/Math.pow(e,2),s=t,u=n;return i*Math.pow(r,3)+o*Math.pow(r,2)+s*r+u}function velocity(n,t,e,r){var i=(t*e+2*n)/Math.pow(e,3),o=-(2*t*e+3*n)/Math.pow(e,2),s=t;return 3*i*Math.pow(r,2)+2*o*r+s}function mixCircle(n,t,e,r){var i=r[1]-r[0];return n=circleValue(n,r),t=circleValue(t,r),t-n>i/2?mixNumber(n+i,t,e):n-t>i/2?mixNumber(n-i,t,e):mixNumber(n,t,e)}function circleValue(n,t){var e=t[1]-t[0];return n<t[0]?circleValue(n+e,t):n>=t[1]?circleValue(n-e,t):n}function mixValue(n,t,e,r){return r?mixCircle(n,t,e,r):mixNumber(n,t,e)}var Motion=function(){function n(t){this.config={},this.progress=1,this.ended=!0,this.value={},this.startTime=now(),this.startVelocity=0,this.duration=0,this.keyframes=[];for(var e in t){var r=t[e];typeof r=="number"?(this.value[e]=r,this.config[e]={circle:!1}):(this.value[e]=r.value,this.config[e]={circle:r.circle})}this.keyframes=[{progress:0,value:__assign({},this.value)},{progress:1,value:__assign({},this.value)}]}return n.prototype.getProgress=function(t){var e=t-this.startTime;return e<0?0:e>=this.duration?1:1-value(1,this.startVelocity,this.duration,e)},n.prototype.getValue=function(t){for(var e=1;e<this.keyframes.length;e++)if(this.keyframes[e].progress>t){var r=this.keyframes[e-1],i=this.keyframes[e],o={};for(var s in this.config){var u=(t-r.progress)/(i.progress-r.progress);o[s]=mixValue(r.value[s],i.value[s],u,this.config[s].circle)}return o}return __assign({},this.keyframes[this.keyframes.length-1].value)},n.prototype.getProgressVelocity=function(t){var e=t-this.startTime;return e>=this.duration?0:velocity(1,this.startVelocity,this.duration,e)},n.prototype.update=function(t){return this.ended?!0:(this.progress=Math.min(1,Math.max(0,this.progress,this.getProgress(t))),this.value=this.getValue(this.progress),this.ended=this.progress>=1,this.ended&&this.callbacks&&(this.callbacks[0](),this.callbacks=void 0),this.ended)},n.prototype.getKeyFrameSegment=function(t){for(var e=this.getProgress(t),r=1;r<this.keyframes.length;r++)if(this.keyframes[r].progress>e)return[this.keyframes[r-1],this.keyframes[r]];return[this.keyframes[this.keyframes.length-2],this.keyframes[this.keyframes.length-1]]},n.prototype.getTargetKeyframe=function(){return this.keyframes[this.keyframes.length-1]},n.prototype.set=function(t,e,r,i){var o;r===void 0&&(r=0),isNaN(e)&&(e=0),isNaN(r)&&(r=0),i=i??now();var s=this.getProgress(i),u=this.getValue(s),l={};for(var d in this.config)l[d]=(o=t[d])!==null&&o!==void 0?o:u[d];var c=[{progress:0,value:u},{progress:1,value:l}];return this.setKeyframes(c,e,r,i)},n.prototype.setKeyframes=function(t,e,r,i){var o=this;if(r===void 0&&(r=0),t.length<2)throw new Error("keyframes invalid.");return isNaN(e)&&(e=0),isNaN(r)&&(r=0),this.callbacks&&(this.callbacks[1](new Error("motion aborted.")),this.callbacks=void 0),new Promise(function(s,u){i=i??now(),o.progress=0,o.ended=!1,o.startTime=i,o.startVelocity=r,o.keyframes=t,o.duration=e,e===0?(o.progress=1,o.value=__assign({},t[t.length-1].value)):o.value=__assign({},t[0].value),o.callbacks=[s,u]})},n.prototype.dispose=function(){this.callbacks&&(this.callbacks[1](new Error("motion dispose.")),this.callbacks=void 0)},n}(),easeOut$2=function(n){return n*(2-n)},sharedGeometry2$2=function(){var n=new Float32Array([-.18,0,-.18,.18,0,-.18,-.18,0,.18,.18,0,.18]),t=new Float32Array([1,0,0,0,1,1,0,1]),e=new Uint8Array([0,2,1,2,3,1]),r=new THREE__namespace.BufferGeometry;return r.setAttribute("position",new THREE__namespace.BufferAttribute(n,3)),r.setAttribute("uv",new THREE__namespace.BufferAttribute(t,2)),r.setIndex(new THREE__namespace.BufferAttribute(e,1)),r}(),vertexShader$5=`
|
|
951
951
|
varying vec2 vUv;
|
|
952
952
|
void main() {
|
|
953
953
|
vUv = uv;
|
|
@@ -1325,7 +1325,7 @@ void main() {
|
|
|
1325
1325
|
* Copyright (c) 2016 Jorik Tangelder;
|
|
1326
1326
|
* Licensed under the MIT license */var Hammer=function(n,t,e,r){var i=["","webkit","Moz","MS","ms","o"],o=t.createElement?t.createElement("div"):r,s="function",u=Math.round,l=Math.abs,d=Date.now;function c(C,P,L){return setTimeout(g(C,L),P)}function f(C,P,L){return Array.isArray(C)?(h(C,L[P],L),!0):!1}function h(C,P,L){var U;if(C)if(C.forEach)C.forEach(P,L);else if(C.length!==r)for(U=0;U<C.length;)P.call(L,C[U],U,C),U++;else for(U in C)C.hasOwnProperty(U)&&P.call(L,C[U],U,C)}function v(C,P,L){var U="DEPRECATED METHOD: "+P+`
|
|
1327
1327
|
`+L+` AT
|
|
1328
|
-
`;return function(){var Y=new Error("get-stack-trace"),ne=Y&&Y.stack?Y.stack.replace(/^[^\(]+?[\n$]/gm,"").replace(/^\s+at\s+/gm,"").replace(/^Object.<anonymous>\s*\(/gm,"{anonymous}()@"):"Unknown Stack Trace",ce=n.console&&(n.console.warn||n.console.log);return ce&&ce.call(n.console,U,ne),C.apply(this,arguments)}}var A;typeof Object.assign!="function"?A=function(P){if(P===r||P===null)throw new TypeError("Cannot convert undefined or null to object");for(var L=Object(P),U=1;U<arguments.length;U++){var Y=arguments[U];if(Y!==r&&Y!==null)for(var ne in Y)Y.hasOwnProperty(ne)&&(L[ne]=Y[ne])}return L}:A=Object.assign;var m=v(function(P,L,U){for(var Y=Object.keys(L),ne=0;ne<Y.length;)(!U||U&&P[Y[ne]]===r)&&(P[Y[ne]]=L[Y[ne]]),ne++;return P},"extend","Use `assign`."),y=v(function(P,L){return m(P,L,!0)},"merge","Use `assign`.");function p(C,P,L){var U=P.prototype,Y;Y=C.prototype=Object.create(U),Y.constructor=C,Y._super=U,L&&A(Y,L)}function g(C,P){return function(){return C.apply(P,arguments)}}function b(C,P){return typeof C==s?C.apply(P&&P[0]||r,P):C}function T(C,P){return C===r?P:C}function _(C,P,L){h(R(P),function(U){C.addEventListener(U,L,!1)})}function w(C,P,L){h(R(P),function(U){C.removeEventListener(U,L,!1)})}function x(C,P){for(;C;){if(C==P)return!0;C=C.parentNode}return!1}function M(C,P){return C.indexOf(P)>-1}function R(C){return C.trim().split(/\s+/g)}function I(C,P,L){if(C.indexOf&&!L)return C.indexOf(P);for(var U=0;U<C.length;){if(L&&C[U][L]==P||!L&&C[U]===P)return U;U++}return-1}function S(C){return Array.prototype.slice.call(C,0)}function B(C,P,L){for(var U=[],Y=[],ne=0;ne<C.length;){var ce=P?C[ne][P]:C[ne];I(Y,ce)<0&&U.push(C[ne]),Y[ne]=ce,ne++}return L&&(P?U=U.sort(function(Qe,Te){return Qe[P]>Te[P]}):U=U.sort()),U}function F(C,P){for(var L,U,Y=P[0].toUpperCase()+P.slice(1),ne=0;ne<i.length;){if(L=i[ne],U=L?L+Y:P,U in C)return U;ne++}return r}var O=1;function H(){return O++}function k(C){var P=C.ownerDocument||C;return P.defaultView||P.parentWindow||n}var N=/mobile|tablet|ip(ad|hone|od)|android/i,q="ontouchstart"in n,V=F(n,"PointerEvent")!==r,D=q&&N.test(navigator.userAgent),K="touch",z="pen",G="mouse",W="kinect",Q=25,X=1,ee=2,J=4,Z=8,te=1,ae=2,re=4,ie=8,de=16,se=ae|re,pe=ie|de,$=se|pe,oe=["x","y"],j=["clientX","clientY"];function ve(C,P){var L=this;this.manager=C,this.callback=P,this.element=C.element,this.target=C.options.inputTarget,this.domHandler=function(U){b(C.options.enable,[C])&&L.handler(U)},this.init()}ve.prototype={handler:function(){},init:function(){this.evEl&&_(this.element,this.evEl,this.domHandler),this.evTarget&&_(this.target,this.evTarget,this.domHandler),this.evWin&&_(k(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&w(this.element,this.evEl,this.domHandler),this.evTarget&&w(this.target,this.evTarget,this.domHandler),this.evWin&&w(k(this.element),this.evWin,this.domHandler)}};function me(C){var P,L=C.options.inputClass;return L?P=L:V?P=De:D?P=Ge:q?P=rt:P=Ee,new P(C,Me)}function Me(C,P,L){var U=L.pointers.length,Y=L.changedPointers.length,ne=P&X&&U-Y===0,ce=P&(J|Z)&&U-Y===0;L.isFirst=!!ne,L.isFinal=!!ce,ne&&(C.session={}),L.eventType=P,Re(C,L),C.emit("hammer.input",L),C.recognize(L),C.session.prevInput=L}function Re(C,P){var L=C.session,U=P.pointers,Y=U.length;L.firstInput||(L.firstInput=Ae(P)),Y>1&&!L.firstMultiple?L.firstMultiple=Ae(P):Y===1&&(L.firstMultiple=!1);var ne=L.firstInput,ce=L.firstMultiple,Ce=ce?ce.center:ne.center,Qe=P.center=le(U);P.timeStamp=d(),P.deltaTime=P.timeStamp-ne.timeStamp,P.angle=Se(Ce,Qe),P.distance=fe(Ce,Qe),ge(L,P),P.offsetDirection=Oe(P.deltaX,P.deltaY);var Te=ue(P.deltaTime,P.deltaX,P.deltaY);P.overallVelocityX=Te.x,P.overallVelocityY=Te.y,P.overallVelocity=l(Te.x)>l(Te.y)?Te.x:Te.y,P.scale=ce?ke(ce.pointers,U):1,P.rotation=ce?ye(ce.pointers,U):0,P.maxPointers=L.prevInput?P.pointers.length>L.prevInput.maxPointers?P.pointers.length:L.prevInput.maxPointers:P.pointers.length,we(L,P);var et=C.element;x(P.srcEvent.target,et)&&(et=P.srcEvent.target),P.target=et}function ge(C,P){var L=P.center,U=C.offsetDelta||{},Y=C.prevDelta||{},ne=C.prevInput||{};(P.eventType===X||ne.eventType===J)&&(Y=C.prevDelta={x:ne.deltaX||0,y:ne.deltaY||0},U=C.offsetDelta={x:L.x,y:L.y}),P.deltaX=Y.x+(L.x-U.x),P.deltaY=Y.y+(L.y-U.y)}function we(C,P){var L=C.lastInterval||P,U=P.timeStamp-L.timeStamp,Y,ne,ce,Ce;if(P.eventType!=Z&&(U>Q||L.velocity===r)){var Qe=P.deltaX-L.deltaX,Te=P.deltaY-L.deltaY,et=ue(U,Qe,Te);ne=et.x,ce=et.y,Y=l(et.x)>l(et.y)?et.x:et.y,Ce=Oe(Qe,Te),C.lastInterval=P}else Y=L.velocity,ne=L.velocityX,ce=L.velocityY,Ce=L.direction;P.velocity=Y,P.velocityX=ne,P.velocityY=ce,P.direction=Ce}function Ae(C){for(var P=[],L=0;L<C.pointers.length;)P[L]={clientX:u(C.pointers[L].clientX),clientY:u(C.pointers[L].clientY)},L++;return{timeStamp:d(),pointers:P,center:le(P),deltaX:C.deltaX,deltaY:C.deltaY}}function le(C){var P=C.length;if(P===1)return{x:u(C[0].clientX),y:u(C[0].clientY)};for(var L=0,U=0,Y=0;Y<P;)L+=C[Y].clientX,U+=C[Y].clientY,Y++;return{x:u(L/P),y:u(U/P)}}function ue(C,P,L){return{x:P/C||0,y:L/C||0}}function Oe(C,P){return C===P?te:l(C)>=l(P)?C<0?ae:re:P<0?ie:de}function fe(C,P,L){L||(L=oe);var U=P[L[0]]-C[L[0]],Y=P[L[1]]-C[L[1]];return Math.sqrt(U*U+Y*Y)}function Se(C,P,L){L||(L=oe);var U=P[L[0]]-C[L[0]],Y=P[L[1]]-C[L[1]];return Math.atan2(Y,U)*180/Math.PI}function ye(C,P){return Se(P[1],P[0],j)+Se(C[1],C[0],j)}function ke(C,P){return fe(P[0],P[1],j)/fe(C[0],C[1],j)}var _e={mousedown:X,mousemove:ee,mouseup:J},We="mousedown",Xe="mousemove mouseup";function Ee(){this.evEl=We,this.evWin=Xe,this.pressed=!1,ve.apply(this,arguments)}p(Ee,ve,{handler:function(P){var L=_e[P.type];L&X&&(P.button===0||P.button===2)&&(this.pressed=!0),L&ee&&P.which!==1&&(L=J),this.pressed&&(L&J&&(this.pressed=!1),this.callback(this.manager,L,{pointers:[P],changedPointers:[P],pointerType:G,srcEvent:P}))}});var Pe={pointerdown:X,pointermove:ee,pointerup:J,pointercancel:Z,pointerout:Z},Je={2:K,3:z,4:G,5:W},be="pointerdown",Fe="pointermove pointerup pointercancel";n.MSPointerEvent&&!n.PointerEvent&&(be="MSPointerDown",Fe="MSPointerMove MSPointerUp MSPointerCancel");function De(){this.evEl=be,this.evWin=Fe,ve.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}p(De,ve,{handler:function(P){var L=this.store,U=!1,Y=!1,ne=P.type.toLowerCase().replace("ms",""),ce=Pe[ne],Ce=Je[P.pointerType]||P.pointerType,Qe=Ce==K,Te=I(L,P.pointerId,"pointerId");ce&X&&(P.button===0||P.button===2||Qe)?Te<0&&(L.push(P),Te=L.length-1):ce&(J|Z)?U=!0:!Qe&&P.buttons===0&&(U=!0,Y=!0,ce=Pe.pointerup),!(Te<0)&&(Y||(L[Te]=P),this.callback(this.manager,ce,{pointers:L,changedPointers:[P],pointerType:Ce,srcEvent:L[Te]}),U&&L.splice(Te,1))}});var qe={touchstart:X,touchmove:ee,touchend:J,touchcancel:Z},Ze="touchstart",Ne="touchstart touchmove touchend touchcancel";function he(){this.evTarget=Ze,this.evWin=Ne,this.started=!1,ve.apply(this,arguments)}p(he,ve,{handler:function(P){var L=qe[P.type];if(L===X&&(this.started=!0),!!this.started){var U=st.call(this,P,L);L&(J|Z)&&U[0].length-U[1].length===0&&(this.started=!1),this.callback(this.manager,L,{pointers:U[0],changedPointers:U[1],pointerType:K,srcEvent:P})}}});function st(C,P){var L=S(C.touches),U=S(C.changedTouches);return P&(J|Z)&&(L=B(L.concat(U),"identifier",!0)),[L,U]}var ze={touchstart:X,touchmove:ee,touchend:J,touchcancel:Z},tt="touchstart touchmove touchend touchcancel";function Ge(){this.evTarget=tt,this.targetIds={},ve.apply(this,arguments)}p(Ge,ve,{handler:function(P){var L=ze[P.type],U=mt.call(this,P,L);U&&this.callback(this.manager,L,{pointers:U[0],changedPointers:U[1],pointerType:K,srcEvent:P})}});function mt(C,P){var L=S(C.touches),U=this.targetIds;if(P&(X|ee)&&L.length===1)return U[L[0].identifier]=!0,[L,L];var Y,ne,ce=S(C.changedTouches),Ce=[],Qe=this.target;if(ne=L.filter(function(Te){return x(Te.target,Qe)}),P===X)for(Y=0;Y<ne.length;)U[ne[Y].identifier]=!0,Y++;for(Y=0;Y<ce.length;)U[ce[Y].identifier]&&Ce.push(ce[Y]),P&(J|Z)&&delete U[ce[Y].identifier],Y++;if(Ce.length)return[B(ne.concat(Ce),"identifier",!0),Ce]}var lt=2500,ct=25;function rt(){ve.apply(this,arguments);var C=g(this.handler,this);this.touch=new Ge(this.manager,C),this.mouse=new Ee(this.manager,C),this.primaryTouch=null,this.lastTouches=[]}p(rt,ve,{handler:function(P,L,U){var Y=U.pointerType==K,ne=U.pointerType==G;if(!(ne&&U.sourceCapabilities&&U.sourceCapabilities.firesTouchEvents)){if(Y)nt.call(this,L,U);else if(ne&&xe.call(this,U))return;this.callback(P,L,U)}},destroy:function(){this.touch.destroy(),this.mouse.destroy()}});function nt(C,P){C&X?(this.primaryTouch=P.changedPointers[0].identifier,Ie.call(this,P)):C&(J|Z)&&Ie.call(this,P)}function Ie(C){var P=C.changedPointers[0];if(P.identifier===this.primaryTouch){var L={x:P.clientX,y:P.clientY};this.lastTouches.push(L);var U=this.lastTouches,Y=function(){var ne=U.indexOf(L);ne>-1&&U.splice(ne,1)};setTimeout(Y,lt)}}function xe(C){for(var P=C.srcEvent.clientX,L=C.srcEvent.clientY,U=0;U<this.lastTouches.length;U++){var Y=this.lastTouches[U],ne=Math.abs(P-Y.x),ce=Math.abs(L-Y.y);if(ne<=ct&&ce<=ct)return!0}return!1}var je=o?F(o.style,"touchAction"):r,at=je!==r,At="compute",yt="auto",dt="manipulation",He="none",Be="pan-x",Le="pan-y",Ue=ft();function Ve(C,P){this.manager=C,this.set(P)}Ve.prototype={set:function(C){C==At&&(C=this.compute()),at&&this.manager.element.style&&Ue[C]&&(this.manager.element.style[je]=C),this.actions=C.toLowerCase().trim()},update:function(){this.set(this.manager.options.touchAction)},compute:function(){var C=[];return h(this.manager.recognizers,function(P){b(P.options.enable,[P])&&(C=C.concat(P.getTouchAction()))}),Et(C.join(" "))},preventDefaults:function(C){var P=C.srcEvent,L=C.offsetDirection;if(this.manager.session.prevented){P.preventDefault();return}var U=this.actions,Y=M(U,He)&&!Ue[He],ne=M(U,Le)&&!Ue[Le],ce=M(U,Be)&&!Ue[Be];if(Y){var Ce=C.pointers.length===1,Qe=C.distance<2,Te=C.deltaTime<250;if(Ce&&Qe&&Te)return}if(!(ce&&ne)&&(Y||ne&&L&se||ce&&L&pe))return this.preventSrc(P)},preventSrc:function(C){this.manager.session.prevented=!0,C.preventDefault()}};function Et(C){if(M(C,He))return He;var P=M(C,Be),L=M(C,Le);return P&&L?He:P||L?P?Be:Le:M(C,dt)?dt:yt}function ft(){if(!at)return!1;var C={},P=n.CSS&&n.CSS.supports;return["auto","manipulation","pan-y","pan-x","pan-x pan-y","none"].forEach(function(L){C[L]=P?n.CSS.supports("touch-action",L):!0}),C}var ht=1,Ke=2,pt=4,ut=8,it=ut,gt=16,$e=32;function ot(C){this.options=A({},this.defaults,C||{}),this.id=H(),this.manager=null,this.options.enable=T(this.options.enable,!0),this.state=ht,this.simultaneous={},this.requireFail=[]}ot.prototype={defaults:{},set:function(C){return A(this.options,C),this.manager&&this.manager.touchAction.update(),this},recognizeWith:function(C){if(f(C,"recognizeWith",this))return this;var P=this.simultaneous;return C=bt(C,this),P[C.id]||(P[C.id]=C,C.recognizeWith(this)),this},dropRecognizeWith:function(C){return f(C,"dropRecognizeWith",this)?this:(C=bt(C,this),delete this.simultaneous[C.id],this)},requireFailure:function(C){if(f(C,"requireFailure",this))return this;var P=this.requireFail;return C=bt(C,this),I(P,C)===-1&&(P.push(C),C.requireFailure(this)),this},dropRequireFailure:function(C){if(f(C,"dropRequireFailure",this))return this;C=bt(C,this);var P=I(this.requireFail,C);return P>-1&&this.requireFail.splice(P,1),this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(C){return!!this.simultaneous[C.id]},emit:function(C){var P=this,L=this.state;function U(Y){P.manager.emit(Y,C)}L<ut&&U(P.options.event+Ct(L)),U(P.options.event),C.additionalEvent&&U(C.additionalEvent),L>=ut&&U(P.options.event+Ct(L))},tryEmit:function(C){if(this.canEmit())return this.emit(C);this.state=$e},canEmit:function(){for(var C=0;C<this.requireFail.length;){if(!(this.requireFail[C].state&($e|ht)))return!1;C++}return!0},recognize:function(C){var P=A({},C);if(!b(this.options.enable,[this,P])){this.reset(),this.state=$e;return}this.state&(it|gt|$e)&&(this.state=ht),this.state=this.process(P),this.state&(Ke|pt|ut|gt)&&this.tryEmit(P)},process:function(C){},getTouchAction:function(){},reset:function(){}};function Ct(C){return C>?"cancel":C&ut?"end":C&pt?"move":C&Ke?"start":""}function It(C){return C==de?"down":C==ie?"up":C==ae?"left":C==re?"right":""}function bt(C,P){var L=P.manager;return L?L.get(C):C}function Ye(){ot.apply(this,arguments)}p(Ye,ot,{defaults:{pointers:1},attrTest:function(C){var P=this.options.pointers;return P===0||C.pointers.length===P},process:function(C){var P=this.state,L=C.eventType,U=P&(Ke|pt),Y=this.attrTest(C);return U&&(L&Z||!Y)?P|gt:U||Y?L&J?P|ut:P&Ke?P|pt:Ke:$e}});function Tt(){Ye.apply(this,arguments),this.pX=null,this.pY=null}p(Tt,Ye,{defaults:{event:"pan",threshold:10,pointers:1,direction:$},getTouchAction:function(){var C=this.options.direction,P=[];return C&se&&P.push(Le),C&pe&&P.push(Be),P},directionTest:function(C){var P=this.options,L=!0,U=C.distance,Y=C.direction,ne=C.deltaX,ce=C.deltaY;return Y&P.direction||(P.direction&se?(Y=ne===0?te:ne<0?ae:re,L=ne!=this.pX,U=Math.abs(C.deltaX)):(Y=ce===0?te:ce<0?ie:de,L=ce!=this.pY,U=Math.abs(C.deltaY))),C.direction=Y,L&&U>P.threshold&&Y&P.direction},attrTest:function(C){return Ye.prototype.attrTest.call(this,C)&&(this.state&Ke||!(this.state&Ke)&&this.directionTest(C))},emit:function(C){this.pX=C.deltaX,this.pY=C.deltaY;var P=It(C.direction);P&&(C.additionalEvent=this.options.event+P),this._super.emit.call(this,C)}});function wt(){Ye.apply(this,arguments)}p(wt,Ye,{defaults:{event:"pinch",threshold:0,pointers:2},getTouchAction:function(){return[He]},attrTest:function(C){return this._super.attrTest.call(this,C)&&(Math.abs(C.scale-1)>this.options.threshold||this.state&Ke)},emit:function(C){if(C.scale!==1){var P=C.scale<1?"in":"out";C.additionalEvent=this.options.event+P}this._super.emit.call(this,C)}});function xt(){ot.apply(this,arguments),this._timer=null,this._input=null}p(xt,ot,{defaults:{event:"press",pointers:1,time:251,threshold:9},getTouchAction:function(){return[yt]},process:function(C){var P=this.options,L=C.pointers.length===P.pointers,U=C.distance<P.threshold,Y=C.deltaTime>P.time;if(this._input=C,!U||!L||C.eventType&(J|Z)&&!Y)this.reset();else if(C.eventType&X)this.reset(),this._timer=c(function(){this.state=it,this.tryEmit()},P.time,this);else if(C.eventType&J)return it;return $e},reset:function(){clearTimeout(this._timer)},emit:function(C){this.state===it&&(C&&C.eventType&J?this.manager.emit(this.options.event+"up",C):(this._input.timeStamp=d(),this.manager.emit(this.options.event,this._input)))}});function Mt(){Ye.apply(this,arguments)}p(Mt,Ye,{defaults:{event:"rotate",threshold:0,pointers:2},getTouchAction:function(){return[He]},attrTest:function(C){return this._super.attrTest.call(this,C)&&(Math.abs(C.rotation)>this.options.threshold||this.state&Ke)}});function Rt(){Ye.apply(this,arguments)}p(Rt,Ye,{defaults:{event:"swipe",threshold:10,velocity:.3,direction:se|pe,pointers:1},getTouchAction:function(){return Tt.prototype.getTouchAction.call(this)},attrTest:function(C){var P=this.options.direction,L;return P&(se|pe)?L=C.overallVelocity:P&se?L=C.overallVelocityX:P&pe&&(L=C.overallVelocityY),this._super.attrTest.call(this,C)&&P&C.offsetDirection&&C.distance>this.options.threshold&&C.maxPointers==this.options.pointers&&l(L)>this.options.velocity&&C.eventType&J},emit:function(C){var P=It(C.offsetDirection);P&&this.manager.emit(this.options.event+P,C),this.manager.emit(this.options.event,C)}});function _t(){ot.apply(this,arguments),this.pTime=!1,this.pCenter=!1,this._timer=null,this._input=null,this.count=0}p(_t,ot,{defaults:{event:"tap",pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[dt]},process:function(C){var P=this.options,L=C.pointers.length===P.pointers,U=C.distance<P.threshold,Y=C.deltaTime<P.time;if(this.reset(),C.eventType&X&&this.count===0)return this.failTimeout();if(U&&Y&&L){if(C.eventType!=J)return this.failTimeout();var ne=this.pTime?C.timeStamp-this.pTime<P.interval:!0,ce=!this.pCenter||fe(this.pCenter,C.center)<P.posThreshold;this.pTime=C.timeStamp,this.pCenter=C.center,!ce||!ne?this.count=1:this.count+=1,this._input=C;var Ce=this.count%P.taps;if(Ce===0)return this.hasRequireFailures()?(this._timer=c(function(){this.state=it,this.tryEmit()},P.interval,this),Ke):it}return $e},failTimeout:function(){return this._timer=c(function(){this.state=$e},this.options.interval,this),$e},reset:function(){clearTimeout(this._timer)},emit:function(){this.state==it&&(this._input.tapCount=this.count,this.manager.emit(this.options.event,this._input))}});function vt(C,P){return P=P||{},P.recognizers=T(P.recognizers,vt.defaults.preset),new St(C,P)}vt.VERSION="2.0.7",vt.defaults={domEvents:!1,touchAction:At,enable:!0,inputTarget:null,inputClass:null,preset:[[Mt,{enable:!1}],[wt,{enable:!1},["rotate"]],[Rt,{direction:se}],[Tt,{direction:se},["swipe"]],[_t],[_t,{event:"doubletap",taps:2},["tap"]],[xt]],cssProps:{userSelect:"none",touchSelect:"none",touchCallout:"none",contentZooming:"none",userDrag:"none",tapHighlightColor:"rgba(0,0,0,0)"}};var Ot=1,Pt=2;function St(C,P){this.options=A({},vt.defaults,P||{}),this.options.inputTarget=this.options.inputTarget||C,this.handlers={},this.session={},this.recognizers=[],this.oldCssProps={},this.element=C,this.input=me(this),this.touchAction=new Ve(this,this.options.touchAction),Bt(this,!0),h(this.options.recognizers,function(L){var U=this.add(new L[0](L[1]));L[2]&&U.recognizeWith(L[2]),L[3]&&U.requireFailure(L[3])},this)}St.prototype={set:function(C){return A(this.options,C),C.touchAction&&this.touchAction.update(),C.inputTarget&&(this.input.destroy(),this.input.target=C.inputTarget,this.input.init()),this},stop:function(C){this.session.stopped=C?Pt:Ot},recognize:function(C){var P=this.session;if(!P.stopped){this.touchAction.preventDefaults(C);var L,U=this.recognizers,Y=P.curRecognizer;(!Y||Y&&Y.state&it)&&(Y=P.curRecognizer=null);for(var ne=0;ne<U.length;)L=U[ne],P.stopped!==Pt&&(!Y||L==Y||L.canRecognizeWith(Y))?L.recognize(C):L.reset(),!Y&&L.state&(Ke|pt|ut)&&(Y=P.curRecognizer=L),ne++}},get:function(C){if(C instanceof ot)return C;for(var P=this.recognizers,L=0;L<P.length;L++)if(P[L].options.event==C)return P[L];return null},add:function(C){if(f(C,"add",this))return this;var P=this.get(C.options.event);return P&&this.remove(P),this.recognizers.push(C),C.manager=this,this.touchAction.update(),C},remove:function(C){if(f(C,"remove",this))return this;if(C=this.get(C),C){var P=this.recognizers,L=I(P,C);L!==-1&&(P.splice(L,1),this.touchAction.update())}return this},on:function(C,P){if(C!==r&&P!==r){var L=this.handlers;return h(R(C),function(U){L[U]=L[U]||[],L[U].push(P)}),this}},off:function(C,P){if(C!==r){var L=this.handlers;return h(R(C),function(U){P?L[U]&&L[U].splice(I(L[U],P),1):delete L[U]}),this}},emit:function(C,P){this.options.domEvents&&Ft(C,P);var L=this.handlers[C]&&this.handlers[C].slice();if(!(!L||!L.length)){P.type=C,P.preventDefault=function(){P.srcEvent.preventDefault()};for(var U=0;U<L.length;)L[U](P),U++}},destroy:function(){this.element&&Bt(this,!1),this.handlers={},this.session={},this.input.destroy(),this.element=null}};function Bt(C,P){var L=C.element;if(L.style){var U;h(C.options.cssProps,function(Y,ne){U=F(L.style,ne),P?(C.oldCssProps[U]=L.style[U],L.style[U]=Y):L.style[U]=C.oldCssProps[U]||""}),P||(C.oldCssProps={})}}function Ft(C,P){var L=t.createEvent("Event");L.initEvent(C,!0,!0),L.gesture=P,P.target.dispatchEvent(L)}return A(vt,{INPUT_START:X,INPUT_MOVE:ee,INPUT_END:J,INPUT_CANCEL:Z,STATE_POSSIBLE:ht,STATE_BEGAN:Ke,STATE_CHANGED:pt,STATE_ENDED:ut,STATE_RECOGNIZED:it,STATE_CANCELLED:gt,STATE_FAILED:$e,DIRECTION_NONE:te,DIRECTION_LEFT:ae,DIRECTION_RIGHT:re,DIRECTION_UP:ie,DIRECTION_DOWN:de,DIRECTION_HORIZONTAL:se,DIRECTION_VERTICAL:pe,DIRECTION_ALL:$,Manager:St,Input:ve,TouchAction:Ve,TouchInput:Ge,MouseInput:Ee,PointerEventInput:De,TouchMouseInput:rt,SingleTouchInput:he,Recognizer:ot,AttrRecognizer:Ye,Tap:_t,Pan:Tt,Swipe:Rt,Pinch:wt,Rotate:Mt,Press:xt,on:_,off:w,each:h,merge:y,extend:m,assign:A,inherit:p,bindFn:g,prefixed:F}),vt}(typeof window<"u"?window:{},typeof document<"u"?document:{});function calculateThreeMouse(n,t,e){var r=t.getBoundingClientRect(),i=r.top,o=r.left,s=r.width,u=r.height;return e&&(o=o+s*e.left,i=i+u*(1-e.bottom-e.height),s=s*e.width,u=u*e.height),new THREE__namespace.Vector2((n.x-o)/s*2-1,-(n.y-i)/u*2+1)}var BaseController=function(n){__extends(t,n);function t(e){var r,i,o,s,u,l,d=n.call(this)||this,c=t.parseArgs(e);return d.mode="",d.pending=new Set,d.userAction=c.initial.userAction,d.destroyed=!1,d.ident=c.ident,d.scene=c.scene,d.xrCustomObjectsScene=c.xrCustomObjectsScene,d.helper=c.helper,d.boundingMesh=c.boundingMesh,d.camera=c.camera,d.renderer=c.renderer,d.scissor=c.scissor,d.element=c.element,d.models=c.models,d.enableWheel=c.enableWheel,d.enableIOSEDR=(r=c.enableIOSEDR)!==null&&r!==void 0?r:!1,d.enableEDL=(i=c.enableEDL)!==null&&i!==void 0?i:!0,d.enableHQ=(o=c.enableHQ)!==null&&o!==void 0?o:!0,d.works=c.works,d.imageOptions=c.imageOptions,d.videoTexture=c.videoTexture,d.extraElements=c.extraElements,d.initial=c.initial,d.currentPano=typeof d.initial.state.panoIndex=="number"?{workCode:(l=(s=d.initial.state.workCode)!==null&&s!==void 0?s:(u=c.works[0])===null||u===void 0?void 0:u.workCode)!==null&&l!==void 0?l:"",panoIndex:d.initial.state.panoIndex}:{workCode:d.initial.currentState.workCode,panoIndex:d.initial.currentState.panoIndex},d.needsRender=!0,d.cameraMotion=new Motion({longitude:{value:d.camera.pose.longitude,circle:[0,Math.PI*2]},latitude:d.camera.pose.latitude,fov:d.camera.pose.fov}),d.inMomentumMovement=null,d.eventUnbinds=[c.element].concat(c.extraElements||[]).map(function(f){return d.bindEvents(f)}),d.pending.add("init-animation"),d.initAnimationReady=new Promise(function(f){AnimationFrameLoop.shared.add(function(){d.initAnimation().then(function(){d.pending.delete("init-animation"),f()})},!0)}),d}return t.parseArgs=function(e){return e instanceof t?e:__assign({},e)},t.initAnimationEndState=function(e){var r,i,o,s,u,l,d,c,f=this.parseArgs(e),h=f.initial,v=h.state,A=h.currentState,m=typeof v.panoIndex=="number"?{workCode:(o=(r=v.workCode)!==null&&r!==void 0?r:(i=f.works[0])===null||i===void 0?void 0:i.workCode)!==null&&o!==void 0?o:"",panoIndex:v.panoIndex}:{workCode:A.workCode,panoIndex:A.panoIndex};return __assign(__assign({},m),{mode:"",longitude:(s=v.longitude)!==null&&s!==void 0?s:A.longitude,latitude:(u=v.latitude)!==null&&u!==void 0?u:A.latitude,fov:(l=v.fov)!==null&&l!==void 0?l:A.fov,offset:(d=v.offset)!==null&&d!==void 0?d:A.offset,distance:(c=v.distance)!==null&&c!==void 0?c:A.distance})},t.prototype.destroy=function(){var e;this.stopMomentumMovement(),this.destroyed=!0,this.off(),this.cameraMotion.dispose();for(var r=0,i=this.eventUnbinds;r<i.length;r++){var o=i[r];o()}this.copyEffect&&(this.copyEffect.dispose(),delete this.copyEffect),delete this.panState,(e=this.pressState)===null||e===void 0||e.stop(),delete this.pressState},t.prototype.isReady=function(){return this.inMomentumMovement===null&&this.pending.size===0&&this.cameraMotion.ended===!0},t.prototype.bindExtraElement=function(e){for(var r=0,i=this.eventUnbinds;r<i.length;r++){var o=i[r];if(o.element===e)return}this.eventUnbinds.push(this.bindEvents(e))},t.prototype.unbindExtraElement=function(e){for(var r=[],i=0,o=this.eventUnbinds;i<o.length;i++){var s=o[i];s.element===e?s():r.push(s)}this.eventUnbinds=r},t.prototype.updateRenderSize=function(){this.needsRender=!0},t.prototype.updateModel=function(e){this.needsRender=!0},t.prototype.updateWork=function(e,r,i,o){return this.works=e,this.userAction=o,!1},t.prototype.updateTime=function(e,r){if(!this.destroyed){var i={};this.cameraMotion.ended&&(this.cameraMotion.update(e),i.longitude=this.cameraMotion.value.longitude,i.latitude=this.cameraMotion.value.latitude,i.fov=this.cameraMotion.value.fov),isEmptyObject(i)&&this.setCamera(i)}},t.prototype.render=function(){this.renderer.render(this.scene,this.camera)},t.prototype.postProcessing=function(e,r){this.destroyed},t.prototype.updateCamera=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();var s={};return e.longitude!==void 0&&(s.longitude=e.longitude),e.latitude!==void 0&&(s.latitude=e.latitude),e.fov!==void 0&&(s.fov=e.fov),o.cameraMotion.set(s,r).catch(noop$1)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();for(var s=[],u=0,l=e;u<l.length;u++){var d=l[u];s.push({key:d.key,progress:d.progress,value:{longitude:d.value.longitude,latitude:d.value.latitude,fov:d.value.fov}})}return o.cameraMotion.setKeyframes(s,r)})},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1];return __assign(__assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance})},t.prototype.initAnimation=function(){var e=this.initial;e.state,e.currentState,e.duration;var r=e.userAction,i=t.initAnimationEndState(this);return this.userAction=r,this.emit("initAnimation.start",createEvent("initAnimation.start",{state:i,userAction:this.userAction})),this.emit("initAnimation.end",createEvent("initAnimation.end",{state:i,userAction:this.userAction})),Promise.resolve()},t.prototype.setCamera=function(e){var r,i,o,s,u;e===void 0&&(e={});var l=(r=e.longitude)!==null&&r!==void 0?r:this.camera.pose.longitude,d=(i=e.latitude)!==null&&i!==void 0?i:this.camera.pose.latitude,c=(o=e.fov)!==null&&o!==void 0?o:this.camera.pose.fov,f=(s=e.distance)!==null&&s!==void 0?s:this.camera.pose.distance,h=(u=e.offset)!==null&&u!==void 0?u:this.camera.pose.offset,v=notSimilarValue(l,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(d,this.camera.pose.latitude),A=notSimilarValue(c,this.camera.pose.fov),m=notSimilarValue(f,this.camera.pose.distance),y=notSimilarVector3(h,this.camera.pose.offset);(A||v||y||m)&&(this.camera.setFromPose({longitude:l,latitude:d,fov:c,distance:f,offset:h}),this.emit("camera.update",createEvent("camera.update",{userAction:this.userAction,state:__assign(__assign({},this.currentPano),{mode:this.mode,longitude:l,latitude:d,fov:c,offset:h,distance:f})})),this.needsRender=!0)},t.prototype.stopMomentumMovement=function(){if(this.inMomentumMovement&&this.inMomentumMovement.event&&!this.inMomentumMovement.event.defaultPrevented&&!this.inMomentumMovement.event.isFinal){var e=createEvent("gesture.momentum",__assign(__assign({},this.inMomentumMovement.event),{isFirst:!1,isFinal:!0}));this.emit("gesture.momentum",e)}this.inMomentumMovement=null},t.prototype.onPanGesture=function(e){this.stopMomentumMovement(),this.emit("gesture.pan",e)},t.prototype.onTapGesture=function(e){this.stopMomentumMovement(),this.emit("gesture.tap",e)},t.prototype.onPressGesture=function(e){this.stopMomentumMovement(),this.emit("gesture.press",e)},t.prototype.onPinchGesture=function(e){this.stopMomentumMovement(),this.emit("gesture.pinch",e)},t.prototype.onMouseWheel=function(e){this.stopMomentumMovement(),this.emit("gesture.mousewheel",e)},t.prototype.onMouseMove=function(e){this.stopMomentumMovement(),this.emit("gesture.mousemove",e)},t.prototype.relativeClientPosition=function(e){return calculateThreeMouse(e,this.element,this.scissor)},t.prototype.bindEvents=function(e){var r=this,i=function(M){var R=calculateThreeMouse(M,r.element,r.scissor);return!(Math.abs(R.x)>1||Math.abs(R.y)>1)},o=new Hammer.Manager(e),s=function(M){var R=M.session;return R.firstInput||null};o.add(new Hammer.Pan({threshold:10,pointers:0})),o.add(new Hammer.Tap({interval:410})),o.add(new Hammer.Pinch({threshold:0,pointers:2})),o.on("panstart pan",function(M){var R=s(o);if(!(R&&!i(R.center))){var I=createEvent("gesture.pan",{target:M.target,pointerType:M.pointerType,srcEvent:M.srcEvent,pointers:M.pointers.map(function(S){var B=r.relativeClientPosition(S),F=new THREE__namespace.Raycaster;return F.params.Points={threshold:.1},F.setFromCamera(B,r.camera),{x:S.x,y:S.y,delta:0,buttons:0,coords:B,raycaster:F}}),isFirst:M.isFirst,isFinal:M.isFinal,scale:M.scale,center:function(S){var B=r.relativeClientPosition(S),F=new THREE__namespace.Raycaster;return F.params.Points={threshold:.1},F.setFromCamera(B,r.camera),{x:S.x,y:S.y,delta:0,buttons:0,coords:B,raycaster:F}}(M.center),velocityX:M.velocityX,velocityY:M.velocityY,overallVelocityX:M.overallVelocityX,overallVelocityY:M.overallVelocityY,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.onPanGesture(I),y()}}),o.on("tap",function(M){if(!(M.pointerType==="mouse"&&M.srcEvent.button!==0)){var R=s(o);if(!(R&&!i(R.center))){var I=createEvent("gesture.tap",{target:M.target,pointerType:M.pointerType,srcEvent:M.srcEvent,pointers:M.pointers.map(function(S){var B=r.relativeClientPosition(S),F=new THREE__namespace.Raycaster;return F.params.Points={threshold:.1},F.setFromCamera(B,r.camera),{x:S.x,y:S.y,delta:0,buttons:0,coords:B,raycaster:F}}),isFirst:!0,isFinal:!0,scale:M.scale,center:function(S){var B=r.relativeClientPosition(S),F=new THREE__namespace.Raycaster;return F.params.Points={threshold:.1},F.setFromCamera(B,r.camera),{x:S.x,y:S.y,delta:0,buttons:0,coords:B,raycaster:F}}(M.center),velocityX:M.velocityX,velocityY:M.velocityY,overallVelocityX:M.overallVelocityX,overallVelocityY:M.overallVelocityY,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.onTapGesture(I),y()}}}),o.on("pinchstart pinch pinchend",function(M){var R=s(o);if(!(R&&!i(R.center))){var I=createEvent("gesture.pinch",{target:M.target,pointerType:M.pointerType,srcEvent:M.srcEvent,pointers:M.pointers.map(function(S){var B,F=r.relativeClientPosition(S),O=new THREE__namespace.Raycaster;return O.params.Points={threshold:.1},O.setFromCamera(F,r.camera),{x:S.x,y:S.y,delta:(B=S.delta)!==null&&B!==void 0?B:0,buttons:0,coords:F,raycaster:O}}),isFirst:M.type==="pinchstart",isFinal:M.type==="pinchend",scale:M.scale,center:function(S){var B=r.relativeClientPosition(S),F=new THREE__namespace.Raycaster;return F.params.Points={threshold:.1},F.setFromCamera(B,r.camera),{x:S.x,y:S.y,delta:0,buttons:0,coords:B,raycaster:F}}(M.center),velocityX:M.velocityX,velocityY:M.velocityY,overallVelocityX:M.overallVelocityX,overallVelocityY:M.overallVelocityY,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.onPinchGesture(I),y()}});var u=null,l=null,d=function(M,R,I){var S={x:I.clientX,y:I.clientY},B=r.relativeClientPosition(S),F=new THREE__namespace.Raycaster;F.params.Points={threshold:.1},F.setFromCamera(B,r.camera);var O=__assign(__assign({},S),{coords:B,raycaster:F,buttons:I.buttons,delta:0}),H=M==="pinchend"?R:R-I.deltaY/280,k=createEvent("gesture.pinch",{target:I.target,pointerType:"mouse",srcEvent:I,pointers:[__assign({},O)],isFirst:M==="pinchstart",isFinal:M==="pinchend",scale:clamp(H,.1,10),center:__assign({},O),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});return k},c=function(M){var R,I={x:M.clientX,y:M.clientY};if(i(I)){if(M.preventDefault(),M.ctrlKey){var S=(R=u==null?void 0:u.prevEvent.scale)!==null&&R!==void 0?R:1,B=d(u?"pinch":"pinchstart",S,M);u===null?u={firstEvent:B,prevEvent:B}:u.prevEvent=B,r.onPinchGesture(B),l!==null&&window.clearTimeout(l),l=window.setTimeout(function(){var V;l=null;var D=(V=u==null?void 0:u.prevEvent.scale)!==null&&V!==void 0?V:1,K=d("pinchend",D,M);u=null,r.onPinchGesture(K)},200)}else{var F=(Math.abs(M.deltaY)>Math.abs(M.deltaX)?M.deltaY:M.deltaX)/-60,O=r.mouseWheelState!==void 0,H={x:M.clientX,y:M.clientY},k=r.relativeClientPosition(H),N=new THREE__namespace.Raycaster;N.params.Points={threshold:.1},N.setFromCamera(k,r.camera);var q=__assign(__assign({},H),{coords:k,raycaster:N,buttons:M.buttons,delta:F}),B=createEvent("gesture.mousewheel",{target:M.target,pointerType:"mouse",srcEvent:M,pointers:[__assign({},q)],isFirst:O,isFinal:!1,scale:0,center:__assign({},q),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.onMouseWheel(B),r.mouseWheelState&&clearTimeout(r.mouseWheelState.timer),r.mouseWheelState={timer:setTimeout(function(){delete r.mouseWheelState;var D=createEvent("gesture.mousewheel",{target:M.target,pointerType:"mouse",srcEvent:M,pointers:[__assign(__assign({},q),{delta:0})],isFirst:!1,isFinal:!0,scale:0,center:__assign(__assign({},q),{delta:0}),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.onMouseWheel(D)},100)}}y()}},f=function(M){if(!isMobile()){if(!i({x:M.clientX,y:M.clientY})){h();return}var R=!1;r.mouseMoveState||(R=!0);var I={x:M.clientX,y:M.clientY},S=r.relativeClientPosition(I),B=new THREE__namespace.Raycaster;B.params.Points={threshold:.1},B.setFromCamera(S,r.camera);var F=__assign(__assign({},I),{coords:S,raycaster:B,buttons:M.buttons,delta:0}),O=createEvent("gesture.mousemove",{target:M.target,pointerType:"mouse",srcEvent:M,pointers:[__assign({},F)],isFirst:R,isFinal:!1,scale:0,center:__assign({},F),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.mouseMoveState||(r.mouseMoveState={timeStamp:now(),event:O}),r.onMouseMove(O),r.pressState&&Math.abs(M.clientX-r.pressState.event.center.y)>10&&Math.abs(M.clientY-r.pressState.event.center.y)>10&&y()}},h=function(){if(r.mouseMoveState){var M=createEvent(r.mouseMoveState.event.type,__assign(__assign({},r.mouseMoveState.event),{isFinal:!0}));r.onMouseMove(M)}y()},v=function(M){if(!i(M.center)){y();return}var R=!1;r.pressState||(R=!0,r.pressState={event:M,timeStamp:now(),stop:noop$1});var I=now()-r.pressState.timeStamp,S=createEvent(r.pressState.event.type,__assign(__assign({},r.pressState.event),{isFirst:R,isFinal:!1,center:__assign(__assign({},r.pressState.event.center),{delta:I}),pointers:r.pressState.event.pointers.map(function(B){return __assign(__assign({},B),{delta:I})})}));r.onPressGesture(S),r.pressState&&(r.pressState.stop=AnimationFrameLoop.shared.add(function(B){v(M)},!0,1))},A=function(M){if(y(),!(M.touches.length>1||M.changedTouches.length<=0)){var R={x:M.changedTouches[0].clientX,y:M.changedTouches[0].clientY},I=r.relativeClientPosition(R),S=new THREE__namespace.Raycaster;S.params.Points={threshold:.1},S.setFromCamera(I,r.camera);var B=__assign(__assign({},R),{coords:I,raycaster:S,buttons:0,delta:0}),F=createEvent("gesture.press",{target:M.target,pointerType:"touch",srcEvent:M,pointers:[__assign({},B)],isFirst:!1,isFinal:!1,scale:0,center:B,velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});v(F)}},m=function(M){y();var R={x:M.clientX,y:M.clientY},I=r.relativeClientPosition(R),S=new THREE__namespace.Raycaster;S.params.Points={threshold:.1},S.setFromCamera(I,r.camera);var B=__assign(__assign({},R),{coords:I,raycaster:S,buttons:M.buttons,delta:0}),F=createEvent("gesture.press",{target:M.target,pointerType:"mouse",srcEvent:M,pointers:[__assign({},B)],isFirst:!1,isFinal:!1,scale:0,center:B,velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});v(F)},y=function(){var M;if(r.pressState){var R=now()-r.pressState.timeStamp,I=createEvent(r.pressState.event.type,__assign(__assign({},r.pressState.event),{center:__assign(__assign({},r.pressState.event.center),{delta:R}),isFirst:!1,isFinal:!0,pointers:r.pressState.event.pointers.map(function(S){return __assign(__assign({},S),{delta:R})})}));r.onPressGesture(I),(M=r.pressState)===null||M===void 0||M.stop(),delete r.pressState}},p=null,g=function(M){var R,I=!1,S=!1;switch(M.type){case"gesturestart":I=!0;break;case"gestureend":S=!0;break}var B={x:M.clientX,y:M.clientY},F=r.relativeClientPosition(B),O=new THREE__namespace.Raycaster;O.params.Points={threshold:.1},O.setFromCamera(F,r.camera);var H=__assign(__assign({},B),{coords:F,raycaster:O,buttons:0,delta:0}),k=createEvent("gesture.pinch",{target:M.target,pointerType:"mouse",srcEvent:M,pointers:[__assign({},H)],isFirst:I,isFinal:S,scale:(R=M.scale)!==null&&R!==void 0?R:1,center:__assign({},H),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});return k},b=function(M){if(M.preventDefault(),!isMobile()){var R=g(M);p={firstEvent:R};var I=p.firstEvent;I&&!i(I.center)||r.onPinchGesture(R)}},T=function(M){if(M.preventDefault(),!isMobile()&&p){var R=g(M),I=p.firstEvent;I&&!i(I.center)||r.onPinchGesture(R)}},_=function(M){if(M.preventDefault(),!isMobile()&&p){var R=g(M),I=p.firstEvent;p=null,!(I&&!i(I.center))&&r.onPinchGesture(R)}},w=function(M){if(M&&typeof M.preventDefault=="function"&&M.currentTarget===e&&M.preventDefault(),typeof getSelection=="function"){var R=getSelection();R&&R.focusNode&&(R.removeAllRanges&&R.removeAllRanges(),R.empty&&R.empty())}};this.enableWheel&&e.addEventListener("wheel",c,{passive:!1}),e.addEventListener("mousemove",f,!1),e.addEventListener("mouseout",h,!1),e.addEventListener("touchstart",A,{passive:!0}),e.addEventListener("touchend",y,!1),e.addEventListener("touchcancel",y,!1),e.addEventListener("mousedown",m,!1),e.addEventListener("mouseup",y,!1),e.addEventListener("gesturestart",b,{passive:!1}),e.addEventListener("gesturechange",T,{passive:!1}),e.addEventListener("gestureend",_,{passive:!1}),e.addEventListener("touchstart",w,{passive:!1}),e.addEventListener("contextmenu",w,!1);var x=function(){o.destroy(),e.removeEventListener("wheel",c,!1),e.removeEventListener("mousemove",f,!1),e.removeEventListener("mouseout",h,!1),e.removeEventListener("touchstart",A,!1),e.removeEventListener("touchend",y,!1),e.removeEventListener("touchcancel",y,!1),e.removeEventListener("mousedown",m,!1),e.removeEventListener("mouseup",y,!1),e.removeEventListener("gesturestart",b,!1),e.removeEventListener("gesturechange",T,!1),e.removeEventListener("gestureend",_,!1),e.removeEventListener("touchstart",w,!1),e.removeEventListener("contextmenu",w,!1)};return Object.assign(x,{element:e})},t.prototype.preloadPano=function(e,r){var i=this;r===void 0&&(r=noop$1);var o=this.works.getResolvedObserver(e);if(!o)return Promise.resolve();var s=["right","left","up","down","front","back"];return Promise.all(s.map(function(u){var l=__assign({key:"pano.".concat(panoStringify(e),".").concat(u)},pick(i.imageOptions,["size","format","quality","mappings"])),d=o.images[u],c=applyImageURLOptions(d,i.imageOptions.transform,l);return getFetcher(o.work).preload(c)})).then(function(){return r(e),e})},t}(Subscribe),FloorplanController=function(n){__extends(t,n);function t(e){var r=this,i,o=t.parseArgs(e);return r=n.call(this,o)||this,r.mode="Floorplan",r.defaultLongitude=o.defaultLongitude,r.defaultLatitude=o.defaultLatitude,r.defaultFov=o.defaultFov,r.maxFov=o.maxFov,r.minFov=o.minFov,r.maxLatitude=o.maxLatitude,r.minLatitude=o.minLatitude,r.locationMotion=new Motion({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 Motion({modelAlpha:(i=r.models.getMaterial().modelAlpha)!==null&&i!==void 0?i:0}),r.perspToOrthoMotion=new Motion({perspToOrtho:r.camera.perspToOrtho.x}),r.currentTapId=null,r.intersectMeshCreator=o.intersectMeshCreator,r.intersectMesh=r.intersectMeshCreator(),r.intersectMesh.name="intersect",r.intersectMesh.visible=!1,r.helper.add(r.intersectMesh),r}return t.distanceFromModel=function(e,r,i){var o=e.bounding,s=Math.pow(Math.pow(o.max.x-o.min.x+1,2)+Math.pow(o.max.y-o.min.y+1,2)+Math.pow(o.max.z-o.min.z+1,2),1/2),u=s/2/Math.tan(Math.PI*r/360);return i<1&&(u=u/i),isNaN(u)?s:u},t.parseArgs=function(e){var r,i,o,s,u,l,d,c;if(e instanceof t)return e;var f=n.parseArgs.call(this,e);return __assign(__assign({},f),{defaultLongitude:(r=e.defaultLongitude)!==null&&r!==void 0?r:Math.PI/4,defaultLatitude:(i=e.defaultLatitude)!==null&&i!==void 0?i:Math.PI/4,defaultFov:(o=e.defaultFov)!==null&&o!==void 0?o:80,maxFov:(s=e.maxFov)!==null&&s!==void 0?s:120,minFov:(u=e.minFov)!==null&&u!==void 0?u:20,maxLatitude:(l=e.maxLatitude)!==null&&l!==void 0?l:+Math.PI/2,minLatitude:(d=e.minLatitude)!==null&&d!==void 0?d:-Math.PI/2,intersectMeshCreator:(c=e.intersectMeshCreator)!==null&&c!==void 0?c:function(){return new IntersectMesh}})},t.initAnimationEndState=function(e){var r,i,o,s,u,l,d=this.parseArgs(e),c=e.initial,f=c.state,h=c.currentState,v=typeof f.panoIndex=="number"?{workCode:(o=(r=f.workCode)!==null&&r!==void 0?r:(i=d.works[0])===null||i===void 0?void 0:i.workCode)!==null&&o!==void 0?o:"",panoIndex:f.panoIndex}:{workCode:h.workCode,panoIndex:h.panoIndex},A=__assign(__assign({},v),{mode:"Floorplan",longitude:(s=f.longitude)!==null&&s!==void 0?s:isThirdPersonMode(h.mode)?h.longitude:d.defaultLongitude,latitude:clamp((u=f.latitude)!==null&&u!==void 0?u:h.mode==="Floorplan"?h.latitude:d.defaultLatitude,d.minLatitude,d.maxLatitude),fov:(l=f.fov)!==null&&l!==void 0?l:d.defaultFov,offset:e.models.bounding.getCenter(new THREE__namespace.Vector3),distance:t.distanceFromModel(d.models,d.defaultFov,d.camera.aspect)});return A},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,o){return this.works=e,this.updateCamera(r,i??0,o),!0},t.prototype.updateModel=function(e){n.prototype.updateModel.call(this,e);var r=e.bounding.getCenter(new THREE__namespace.Vector3),i=t.distanceFromModel(e,this.defaultFov,this.camera.aspect);this.locationMotion.set({x:r.x,y:r.y,z:r.z,distance:i},0).catch(noop$1)},t.prototype.updateCamera=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();var s={},u={};return e.distance!==void 0&&(s.distance=e.distance),e.offset!==void 0&&(s.x=e.offset.x,s.y=e.offset.y,s.z=e.offset.z),e.longitude!==void 0&&(u.longitude=e.longitude),e.latitude!==void 0&&(u.latitude=e.latitude),e.fov!==void 0&&(u.fov=e.fov),o.locationMotion.set(s,r).catch(noop$1),o.cameraMotion.set(u,r).catch(noop$1)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();for(var s=[],u=[],l=0,d=e;l<d.length;l++){var c=d[l];s.push({key:c.key,progress:c.progress,value:{distance:c.value.distance,x:c.value.offset.x,y:c.value.offset.x,z:c.value.offset.x}}),u.push({key:c.key,progress:c.progress,value:{longitude:c.value.longitude,latitude:c.value.latitude,fov:c.value.fov}})}return o.locationMotion.setKeyframes(s,r).catch(noop$1),o.cameraMotion.setKeyframes(e,r)})},t.prototype.updateTime=function(e,r){if(!this.destroyed){var i={},o={};this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),i.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended||(this.locationMotion.update(e),o.distance=this.locationMotion.value.distance,o.offset=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z)),this.cameraMotion.ended||(this.cameraMotion.update(e),o.longitude=this.cameraMotion.value.longitude,o.latitude=this.cameraMotion.value.latitude,o.fov=this.cameraMotion.value.fov),isEmptyObject(i)||this.models.setMaterial(i),isEmptyObject(o)||this.setCamera(o)}},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1],r=this.locationMotion.getKeyFrameSegment(now())[1];return __assign(__assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:new THREE__namespace.Vector3(r.value.x,r.value.y,r.value.z),distance:r.value.distance})},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 o=i.duration,s=i.userAction;e.userAction=s;var u=t.initAnimationEndState(e),l=pick(u,["longitude","latitude","fov"]),d={x:u.offset.x,y:u.offset.y,z:u.offset.z,distance:u.distance},c={modelAlpha:1},f={perspToOrtho:0};e.emit("initAnimation.start",createEvent("initAnimation.start",{state:u,userAction:e.userAction})),e.modelAlphaMotion.set(c,o/3).catch(noop$1),e.perspToOrthoMotion.set(f,o).catch(noop$1),e.cameraMotion.set(l,o).catch(noop$1),e.locationMotion.set(d,o).then(function(){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:u,userAction:e.userAction}))},function(h){var v=__assign(__assign(__assign({},e.currentPano),{mode:e.mode}),clonePose(e.camera.pose));e.emit("initAnimation.end",createEvent("initAnimation.end",{state:v,userAction:e.userAction}))}).then(function(){r()})})},t.prototype.updateRenderSize=function(){this.locationMotion.set({distance:t.distanceFromModel(this.models,this.defaultFov,this.camera.aspect)},0).catch(noop$1)},t.prototype.getForwardObserverOrNot=function(e){var r=this.models.intersectRaycaster(e)[0];if(!r)return null;var i=this.works.resolvedObservers,o=arrayMin(i,function(l){return l.standingPosition.distanceTo(r.point)},!0),s=o[0],u=o[1];return s&&u<10?s:null},t.prototype.coordinatesForOffset=function(e){var r=this.renderer.getSize(new THREE__namespace.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,o){var s=this;if(this.inMomentumMovement!==null){for(var u=__assign({},i),l={longitude:0,latitude:0},d=0;d<o;d++)u.longitude*=.996,u.latitude*=.996*.998,l.longitude+=u.longitude,l.latitude+=u.latitude;var c=formatRad(this.cameraMotion.value.longitude+l.longitude),f=clamp(this.cameraMotion.value.latitude+l.latitude,this.minLatitude,this.maxLatitude),h=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:c,latitude:f,fov:this.cameraMotion.value.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance}),v=!(u.longitude>1e-4||u.longitude<-1e-4||u.latitude>1e-4||u.latitude<-1e-4),A=createEvent("gesture.momentum",__assign(__assign({},e),{isFirst:r,isFinal:v,state:h}));if(this.inMomentumMovement.event=A,this.emit("gesture.momentum",A),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:c,latitude:f},0).catch(noop$1),v?this.inMomentumMovement=null:AnimationFrameLoop.shared.add(function(m,y){s.requestMomentumMovement(e,!1,u,y|0)},!0,1))}},t.prototype.onPanGesture=function(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();var r=this.panState,i=e.pointers.length;if(e.isFinal?delete this.panState:this.panState={pointerLength:i,x:e.center.x,y:e.center.y},!(typeof r>"u"||r.pointerLength!==i)){var o={x:e.center.x-r.x,y:e.center.y-r.y},s=this.relativeClientPosition(e.center),u=this.camera.pose.latitude<Math.PI/6||s.y<0?1:-1;o.x*=u;var l=this.coordinatesForOffset(o),d=formatRad(this.cameraMotion.value.longitude+l.longitude),c=clamp(this.cameraMotion.value.latitude+l.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&&(c=this.cameraMotion.value.latitude);var f=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:d,latitude:c,fov:this.camera.pose.fov,offset:this.camera.pose.offset,distance:this.camera.pose.distance});if(e.state=f,this.emit("gesture.pan",e),!e.defaultPrevented&&(this.cameraMotion.set({longitude:f.longitude,latitude:f.latitude},0).catch(noop$1),e.isFinal)){var h=e.velocityX*u,v=e.velocityY;this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,this.coordinatesForOffset({x:h,y:v}),0)}}},t.prototype.onPinchGesture=function(e){var r;this.userAction=e.userAction,this.stopMomentumMovement();var i=(r=this.pinchState)===null||r===void 0?void 0:r.fov;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&(delete this.panState,delete this.pinchState),!(typeof i>"u")){var o=clamp(i/e.scale,this.minFov,this.maxFov);e.state.fov=o,this.emit("gesture.pinch",e),!e.defaultPrevented&&(this.cameraMotion.set({fov:o},0).catch(noop$1),this.onPanGesture(e))}},t.prototype.onMouseMove=function(e){var r,i;if(this.intersectMesh.parent&&!this.panState){if(this.emit("gesture.mousemove",e),e.defaultPrevented){this.hideIntersectMesh();return}var o=e.center.raycaster;if(e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}var s=this.models.intersectRaycaster(o)[0],u=createEvent("intersect.update",{raycaster:o,intersection:s??null,object:this.intersectMesh});if(this.emit("intersect.update",u),u.defaultPrevented){this.hideIntersectMesh();return}if(s){var l=(i=(r=s.face)===null||r===void 0?void 0:r.normal)!==null&&i!==void 0?i:new THREE__namespace.Vector3().copy(o.ray.direction).multiplyScalar(-1),d=l.clone().multiplyScalar(.05),c=s.point.clone().add(d);this.intersectMesh.position.copy(c);var f=c.clone().add(d);if(this.intersectMesh.lookAt(f),Math.abs(l.y)>.99){var h=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(h.z,h.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}},t.prototype.onMouseWheel=function(e){this.userAction=e.userAction,this.stopMomentumMovement();var r=this,i=r.minFov,o=r.maxFov,s=clamp(this.camera.fov-e.center.delta,i,o);e.state.fov=s,this.emit("gesture.mousewheel",e),!e.defaultPrevented&&this.cameraMotion.set({fov:s},0).catch(noop$1)},t.prototype.onTapGesture=function(e){var r=this;this.userAction=!0,this.stopMomentumMovement();var i=e.center.raycaster,o=this.getForwardObserverOrNot(i);if(!o)this.emit("gesture.tap",e);else{var s={longitude:this.camera.pose.longitude,latitude:0},u=__assign(__assign({},e.state),{mode:"Panorama",workCode:o.pano.workCode,panoIndex:o.pano.panoIndex,longitude:s.longitude,latitude:s.latitude,offset:o?o.position.clone():new THREE__namespace.Vector3,distance:0});if(e.state=u,this.emit("gesture.tap",e),!e.defaultPrevented&&(this.emit("pano.select",createEvent("pano.select",{prevPano:this.currentPano,state:u,userAction:e.userAction,options:s,progress:0,error:null})),o&&o.active)){var l=this.currentTapId=createUuid();this.preloadPano(o.pano).then(function(d){r.currentTapId===l&&r.emit("pano.request",createEvent("pano.request",{userAction:!0,prevPano:r.currentPano,progress:0,state:u,options:s,error:null}))})}}},t.prototype.hideIntersectMesh=function(){this.intersectMesh.visible=!1,this.needsRender=!0},t}(BaseController),ViewDirection={Top:{longitude:0,latitude:Math.PI/2},FrontSide:{longitude:0,latitude:0},LeftSide:{longitude:Math.PI/2,latitude:0},BackSide:{longitude:Math.PI,latitude:0},RightSide:{longitude:Math.PI*1.5,latitude:0}};function panLeft(n,t){var e=new THREE__namespace.Vector3().copy(t);return e.multiplyScalar(-n),e}function panUp(n,t){var e=new THREE__namespace.Vector3().copy(t);return e.multiplyScalar(n),e}var TopviewController=function(n){__extends(t,n);function t(e){var r=this,i=t.parseArgs(e);return r=n.call(this,i)||this,r.mode="Topview",r}return t.parseArgs=function(e){if(e instanceof t)return e;var r=__assign(__assign({},e.initial),{state:__assign(__assign({},e.initial.state),{longitude:0,latitude:Math.PI/2})}),i=__assign(__assign({},e),{initial:r,maxLatitude:Math.PI/2,minLatitude:Math.PI/2,defaultLongitude:0,defaultLatitude:Math.PI/2});return n.parseArgs.call(this,i)},t.initAnimationEndState=function(e){var r=this.parseArgs(e),i=n.initAnimationEndState.call(this,r);return __assign(__assign({},i),{mode:"Topview"})},t.prototype.updateModel=function(e){this.needsRender=!0;var r=this.models.bounding.getCenter(new THREE__namespace.Vector3);this.locationMotion.set({x:r.x,y:r.y,z:r.z,distance:FloorplanController.distanceFromModel(this.models,this.defaultFov,this.camera.aspect)},0).catch(noop$1)},t.prototype.updateCamera=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();var s={},u={};return e.distance!==void 0&&(s.distance=e.distance),e.offset!==void 0&&(s.x=e.offset.x,s.y=e.offset.y,s.z=e.offset.z),e.longitude!==void 0&&(u.longitude=e.longitude),e.latitude!==void 0&&(u.latitude=e.latitude),e.fov!==void 0&&(u.fov=e.fov),o.locationMotion.set(s,r).catch(noop$1),o.cameraMotion.set(u,r).catch(noop$1)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();for(var s=[],u=[],l=0,d=e;l<d.length;l++){var c=d[l];s.push({key:c.key,progress:c.progress,value:{distance:c.value.distance,x:c.value.offset.x,y:c.value.offset.x,z:c.value.offset.x}}),u.push({key:c.key,progress:c.progress,value:{longitude:c.value.longitude,latitude:c.value.latitude,fov:c.value.fov}})}return o.locationMotion.setKeyframes(s,r).catch(noop$1),o.cameraMotion.setKeyframes(e,r)})},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 o=i.duration,s=i.userAction;e.userAction=s;var u=t.initAnimationEndState(e),l={longitude:u.longitude,latitude:u.latitude,fov:u.fov},d={x:u.offset.x,y:u.offset.y,z:u.offset.z,distance:u.distance},c={modelAlpha:1},f={perspToOrtho:1};e.emit("initAnimation.start",createEvent("initAnimation.start",{state:u,userAction:e.userAction})),e.modelAlphaMotion.set(c,o/3).catch(noop$1),e.perspToOrthoMotion.set(f,o).catch(noop$1),e.cameraMotion.set(l,o).catch(noop$1),e.locationMotion.set(d,o).then(function(){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:u,userAction:e.userAction}))},function(h){var v=__assign(__assign(__assign({},e.currentPano),{mode:e.mode}),clonePose(e.camera.pose));e.emit("initAnimation.end",createEvent("initAnimation.end",{state:v,userAction:e.userAction}))}).then(function(){r()})})},t.prototype.getZoomOffsetFromFov=function(e,r,i){var o=this.camera.getDirection(new THREE__namespace.Vector3),s=Math.tan(i/2*Math.PI/180),u=Math.tan(r.fov/2*Math.PI/180),l=(u-s)/u,d=new THREE__namespace.Raycaster;d.params.Points={threshold:.1},d.setFromCamera(e,r);var c=d.ray.direction,f=c.angleTo(o),h=FloorplanController.distanceFromModel(this.models,this.defaultFov,this.camera.aspect),v=h*Math.tan(f),A=c.clone().setLength(h*Math.cos(f)).projectOnPlane(o),m=A.length(),y=l/m*A.x*v,p=l/m*A.z*v,g=l/m*A.y*v;return new THREE__namespace.Vector3(y,g,p)},t.prototype.requestMomentumMovement=function(){this.inMomentumMovement=null},t.prototype.onPanGesture=function(e){this.userAction=e.userAction,this.stopMomentumMovement();var r=this.panState,i=e.pointers.length;if(e.isFinal?delete this.panState:this.panState={pointerLength:i,x:e.center.x,y:e.center.y},!(typeof r>"u"||r.pointerLength!==i)){var o={x:e.center.x-r.x,y:e.center.y-r.y},s=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),u=this.models.bounding,l={left:new THREE__namespace.Vector3,up:new THREE__namespace.Vector3,cameraDirection:"y"};this.cameraMotion.value.longitude===ViewDirection.Top.longitude&&this.cameraMotion.value.latitude===ViewDirection.Top.latitude?(l.left.set(1,0,0),l.up.set(0,0,-1),l.cameraDirection="y"):this.cameraMotion.value.longitude===ViewDirection.FrontSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.FrontSide.latitude?(l.left.set(1,0,0),l.up.set(0,1,0),l.cameraDirection="z"):this.cameraMotion.value.longitude===ViewDirection.BackSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.BackSide.latitude?(l.left.set(1,0,0),l.up.set(0,-1,0),l.cameraDirection="z"):this.cameraMotion.value.longitude===ViewDirection.RightSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.RightSide.latitude?(l.left.set(0,0,-1),l.up.set(0,-1,0),l.cameraDirection="x"):this.cameraMotion.value.longitude===ViewDirection.LeftSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.LeftSide.latitude&&(l.left.set(0,0,-1),l.up.set(0,1,0),l.cameraDirection="x");var d=(this.camera.position[l.cameraDirection]-u.min[l.cameraDirection])*Math.tan(this.camera.fov/2*Math.PI/180),c=this.renderer.getSize(new THREE__namespace.Vector2);s.add(panLeft(2*o.x*d/c.y,l.left)),s.add(panUp(2*o.y*d/c.y,l.up)),s.clamp(this.models.bounding.min,this.models.bounding.max);var f=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:0,latitude:Math.PI/2,fov:this.cameraMotion.value.fov,offset:s,distance:this.locationMotion.value.distance});e.state=f,this.emit("gesture.pan",e),!e.defaultPrevented&&this.locationMotion.set({x:s.x,y:s.y,z:s.z},0).catch(noop$1)}},t.prototype.onPinchGesture=function(e){var r;this.userAction=e.userAction,this.stopMomentumMovement();var i=(r=this.pinchState)===null||r===void 0?void 0:r.fov;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&delete this.pinchState,!(typeof i>"u")){var o=clamp(i/e.scale,this.minFov,this.maxFov),s=this.relativeClientPosition({x:e.center.x,y:e.center.y}),u=this.getZoomOffsetFromFov(s,this.camera,o);this.cameraMotion.value.longitude===ViewDirection.Top.longitude&&this.cameraMotion.value.latitude===ViewDirection.Top.latitude?u.y=0:this.cameraMotion.value.longitude===ViewDirection.FrontSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.FrontSide.latitude||this.cameraMotion.value.longitude===ViewDirection.BackSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.BackSide.latitude?u.z=0:(this.cameraMotion.value.longitude===ViewDirection.RightSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.RightSide.latitude||this.cameraMotion.value.longitude===ViewDirection.LeftSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.LeftSide.latitude)&&(u.x=0);var l=this.camera.pose.offset.clone().add(u);e.state.offset.copy(l),e.state.fov=o,this.emit("gesture.pinch",e),!e.defaultPrevented&&(this.locationMotion.set({x:l.x,y:l.y,z:l.z},0).catch(noop$1),this.cameraMotion.set({fov:o},0).catch(noop$1),e.type="gesture.pan",this.onPanGesture(e))}},t.prototype.onMouseWheel=function(e){this.userAction=e.userAction,this.stopMomentumMovement();var r=clamp(this.cameraMotion.value.fov-e.center.delta,this.minFov,this.maxFov),i=e.center.coords,o=this.getZoomOffsetFromFov(i,this.camera,r);this.cameraMotion.value.longitude===ViewDirection.Top.longitude&&this.cameraMotion.value.latitude===ViewDirection.Top.latitude?o.y=0:this.cameraMotion.value.longitude===ViewDirection.FrontSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.FrontSide.latitude||this.cameraMotion.value.longitude===ViewDirection.BackSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.BackSide.latitude?o.z=0:(this.cameraMotion.value.longitude===ViewDirection.RightSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.RightSide.latitude||this.cameraMotion.value.longitude===ViewDirection.LeftSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.LeftSide.latitude)&&(o.x=0);var s=this.camera.pose.offset.clone().add(o);e.state.offset.copy(s),e.state.fov=r,this.emit("gesture.mousewheel",e),!e.defaultPrevented&&(this.locationMotion.set({x:s.x,y:s.y,z:s.z},0).catch(noop$1),this.cameraMotion.set({fov:r},0).catch(noop$1))},t}(FloorplanController),PanoramaLikeController=function(n){__extends(t,n);function t(e){var r=this,i=t.parseArgs(e);return r=n.call(this,i)||this,r.mode="PanoramaLike",r.defaultLatitude=i.defaultLatitude,r.defaultFov=i.defaultFov,r.maxFov=i.maxFov,r.minFov=i.minFov,r.maxLatitude=i.maxLatitude,r.minLatitude=i.minLatitude,r.moveSpeed=i.moveSpeed,r.intersectMeshCreator=i.intersectMeshCreator,r.intersectMesh=r.intersectMeshCreator(),r.intersectMesh.name="intersect",r.intersectMesh.visible=!1,r.helper.add(r.intersectMesh),r}return t.parseArgs=function(e){var r,i,o,s,u,l,d,c;if(e instanceof t)return e;var f=n.parseArgs.call(this,e);return __assign(__assign({},f),{defaultLatitude:(r=e.defaultLatitude)!==null&&r!==void 0?r:0,defaultFov:(i=e.defaultFov)!==null&&i!==void 0?i:90,maxFov:(o=e.maxFov)!==null&&o!==void 0?o:120,minFov:(s=e.minFov)!==null&&s!==void 0?s:40,maxLatitude:(u=e.maxLatitude)!==null&&u!==void 0?u:+Math.PI/2,minLatitude:(l=e.minLatitude)!==null&&l!==void 0?l:-Math.PI/2,moveSpeed:(d=e.moveSpeed)!==null&&d!==void 0?d:3.4,intersectMeshCreator:(c=e.intersectMeshCreator)!==null&&c!==void 0?c:function(){return new IntersectMesh}})},t.initAnimationEndState=function(e){var r,i,o,s,u,l,d=this.parseArgs(e),c=d.works,f=e.initial,h=f.state,v=f.currentState,A=typeof h.panoIndex=="number"?{workCode:(o=(r=h.workCode)!==null&&r!==void 0?r:(i=d.works[0])===null||i===void 0?void 0:i.workCode)!==null&&o!==void 0?o:"",panoIndex:h.panoIndex}:{workCode:v.workCode,panoIndex:v.panoIndex},m=c.getResolvedObserver(A),y=(s=h.longitude)!==null&&s!==void 0?s:v.longitude,p=clamp((u=h.latitude)!==null&&u!==void 0?u:isFristPersonMode(v.mode)?v.latitude:d.defaultLatitude,d.minLatitude,d.maxLatitude),g=clamp((l=h.fov)!==null&&l!==void 0?l:isFristPersonMode(v.mode)?v.fov:d.defaultFov,d.minFov,d.maxFov),b=m?m.position.clone():new THREE__namespace.Vector3;return{workCode:A.workCode,panoIndex:A.panoIndex,mode:"PanoramaLike",longitude:y,latitude:p,fov:g,offset:b,distance:0}},t.prototype.destroy=function(){n.prototype.destroy.call(this),this.intersectMesh&&(this.helper.remove(this.intersectMesh),this.intersectMesh.dispose()),delete this.panState},t.prototype.isReady=function(){return this.panState||this.pinchState?!1:n.prototype.isReady.call(this)},t.prototype.calculateMovingDuration=function(e,r){switch(typeof e){case"function":return e(r,this.moveSpeed);case"number":return e;case"string":return Number(e);default:return clamp(r,2,5)/this.moveSpeed*1e3}},t.prototype.hideIntersectMesh=function(){this.intersectMesh.visible=!1,this.needsRender=!0},t.prototype.coordinatesForOffset=function(e){var r=this.cameraMotion.value.fov,i=this.camera.aspect,o=this.renderer.getSize(new THREE__namespace.Vector2);return{longitude:2*e.x/(o.x*this.scissor.width)*r/95*i,latitude:-2*e.y/(o.y*this.scissor.height)*r/95}},t.prototype.cameraBounce=function(){var e=this.cameraMotion.value,r=e.longitude,i=e.latitude,o=e.fov,s=[{progress:0,value:{longitude:r,latitude:i,fov:o}},{progress:.5,value:{longitude:r,latitude:i,fov:o*.98}},{progress:1,value:{longitude:r,latitude:i,fov:o}}];this.cameraMotion.setKeyframes(s,500).catch(noop$1)},t.prototype.requestMomentumMovement=function(e,r,i,o){var s=this;if(this.inMomentumMovement!==null){for(var u=__assign({},i),l={longitude:0,latitude:0},d=0;d<o;d++)u.longitude*=.996,u.latitude*=.996*.99,l.longitude+=u.longitude,l.latitude+=u.latitude;var c=formatRad(this.cameraMotion.value.longitude+l.longitude),f=clamp(this.cameraMotion.value.latitude+l.latitude,this.minLatitude,this.maxLatitude),h=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:c,latitude:f,fov:this.cameraMotion.value.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance}),v=!(u.longitude>1e-4||u.longitude<-1e-4||u.latitude>1e-4||u.latitude<-1e-4),A=createEvent("gesture.momentum",__assign(__assign({},e),{isFirst:r,isFinal:v,state:h}));if(this.inMomentumMovement.event=A,this.emit("gesture.momentum",A),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:c,latitude:f},0).catch(noop$1),v?this.inMomentumMovement=null:AnimationFrameLoop.shared.add(function(m,y){s.requestMomentumMovement(e,!1,u,y|0)},!0,1))}},t.prototype.onPanGesture=function(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();var r=this.panState,i=e.pointers.length;if(e.isFinal?delete this.panState:this.panState={pointerLength:i,x:e.center.x,y:e.center.y},!(typeof r>"u"||r.pointerLength!==i)){var o={x:e.center.x-r.x,y:e.center.y-r.y},s=this.coordinatesForOffset(o),u=formatRad(this.cameraMotion.value.longitude+s.longitude),l=clamp(this.cameraMotion.value.latitude+s.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 d=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:u,latitude:l,fov:this.cameraMotion.value.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance});if(e.state=d,this.emit("gesture.pan",e),!e.defaultPrevented){var c={longitude:d.longitude,latitude:d.latitude,fov:d.fov};if(this.cameraMotion.set(c,0).catch(noop$1),e.isFinal){var f=e.velocityX,h=e.velocityY*.6;Math.abs(h)>.5&&Math.abs(f)<.5&&(f=0),this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,this.coordinatesForOffset({x:f,y:h}),0)}}}},t.prototype.onPinchGesture=function(e){var r;this.userAction=e.userAction,this.stopMomentumMovement();var i=(r=this.pinchState)===null||r===void 0?void 0:r.fov,o=e.scale;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&delete this.pinchState,!(typeof i>"u")){var s=clamp(i/o,this.minFov,this.maxFov);e.state.fov=s,this.emit("gesture.pinch",e),!e.defaultPrevented&&(this.cameraMotion.set({fov:s},0).catch(noop$1),e.type="gesture.pan",this.onPanGesture(e))}},t.prototype.onMouseWheel=function(e){this.userAction=e.userAction,this.stopMomentumMovement();var r=clamp(this.cameraMotion.value.fov-e.center.delta,this.minFov,this.maxFov);e.state.fov=r,this.emit("gesture.mousewheel",e),!e.defaultPrevented&&this.cameraMotion.set({fov:r},0).catch(noop$1)},t.prototype.onMouseMove=function(e){var r,i;if(this.intersectMesh.parent&&!this.panState&&(this.emit("gesture.mousemove",e),!e.defaultPrevented)){var o=e.center.raycaster;if(e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}var s=this.models.intersectRaycaster(o)[0],u=createEvent("intersect.update",{raycaster:o,intersection:s??null,object:this.intersectMesh});if(this.emit("intersect.update",u),u.defaultPrevented){this.hideIntersectMesh();return}if(s){var l=(i=(r=s.face)===null||r===void 0?void 0:r.normal)!==null&&i!==void 0?i:new THREE__namespace.Vector3().copy(o.ray.direction).multiplyScalar(-1),d=l.clone().multiplyScalar(.05),c=s.point.clone().add(d);this.intersectMesh.position.copy(c);var f=c.clone().add(d);if(this.intersectMesh.lookAt(f),Math.abs(l.y)>.99){var h=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(h.z,h.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}},t}(BaseController),blankVideo="data:video/mp4;base64,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",result;function canplayVideo(){return result||(result=new Promise(function(n){var t,e=document.createElement("video");e.muted=!0,e.src=blankVideo,e.addEventListener("timeupdate",function r(){e.removeEventListener("timeupdate",r,!1),clearTimeout(t);var i=document.createElement("canvas");i.width=i.height=1;var o=i.getContext("2d");if(!o){n(!1);return}o.drawImage(e,0,0,1,1);var s=o.getImageData(0,0,1,1).data;s[3]>10?n(!0):n(!1)},!1),e.addEventListener("canplay",function r(){e.removeEventListener("canplay",r,!1),e.play()},!1),t=window.setTimeout(function(){return n(!1)},1e3)}))}var camera$1=new THREE__namespace.OrthographicCamera(-1,1,1,-1,0,1),geometry$4=new THREE__namespace.BufferGeometry;geometry$4.setAttribute("position",new THREE__namespace.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3)),geometry$4.setAttribute("uv",new THREE__namespace.Float32BufferAttribute([0,2,0,0,2,0],2));var mesh$3=new THREE__namespace.Mesh(geometry$4),scene$1=new THREE__namespace.Scene;scene$1.add(mesh$3);var DEFAULT_VERTEX_SHADER=`
|
|
1328
|
+
`;return function(){var Y=new Error("get-stack-trace"),ne=Y&&Y.stack?Y.stack.replace(/^[^\(]+?[\n$]/gm,"").replace(/^\s+at\s+/gm,"").replace(/^Object.<anonymous>\s*\(/gm,"{anonymous}()@"):"Unknown Stack Trace",ce=n.console&&(n.console.warn||n.console.log);return ce&&ce.call(n.console,U,ne),C.apply(this,arguments)}}var A;typeof Object.assign!="function"?A=function(P){if(P===r||P===null)throw new TypeError("Cannot convert undefined or null to object");for(var L=Object(P),U=1;U<arguments.length;U++){var Y=arguments[U];if(Y!==r&&Y!==null)for(var ne in Y)Y.hasOwnProperty(ne)&&(L[ne]=Y[ne])}return L}:A=Object.assign;var m=v(function(P,L,U){for(var Y=Object.keys(L),ne=0;ne<Y.length;)(!U||U&&P[Y[ne]]===r)&&(P[Y[ne]]=L[Y[ne]]),ne++;return P},"extend","Use `assign`."),y=v(function(P,L){return m(P,L,!0)},"merge","Use `assign`.");function p(C,P,L){var U=P.prototype,Y;Y=C.prototype=Object.create(U),Y.constructor=C,Y._super=U,L&&A(Y,L)}function g(C,P){return function(){return C.apply(P,arguments)}}function b(C,P){return typeof C==s?C.apply(P&&P[0]||r,P):C}function T(C,P){return C===r?P:C}function _(C,P,L){h(R(P),function(U){C.addEventListener(U,L,!1)})}function w(C,P,L){h(R(P),function(U){C.removeEventListener(U,L,!1)})}function x(C,P){for(;C;){if(C==P)return!0;C=C.parentNode}return!1}function M(C,P){return C.indexOf(P)>-1}function R(C){return C.trim().split(/\s+/g)}function I(C,P,L){if(C.indexOf&&!L)return C.indexOf(P);for(var U=0;U<C.length;){if(L&&C[U][L]==P||!L&&C[U]===P)return U;U++}return-1}function S(C){return Array.prototype.slice.call(C,0)}function B(C,P,L){for(var U=[],Y=[],ne=0;ne<C.length;){var ce=P?C[ne][P]:C[ne];I(Y,ce)<0&&U.push(C[ne]),Y[ne]=ce,ne++}return L&&(P?U=U.sort(function(Qe,Te){return Qe[P]>Te[P]}):U=U.sort()),U}function O(C,P){for(var L,U,Y=P[0].toUpperCase()+P.slice(1),ne=0;ne<i.length;){if(L=i[ne],U=L?L+Y:P,U in C)return U;ne++}return r}var F=1;function H(){return F++}function k(C){var P=C.ownerDocument||C;return P.defaultView||P.parentWindow||n}var N=/mobile|tablet|ip(ad|hone|od)|android/i,q="ontouchstart"in n,V=O(n,"PointerEvent")!==r,D=q&&N.test(navigator.userAgent),K="touch",z="pen",G="mouse",W="kinect",Q=25,X=1,ee=2,J=4,Z=8,te=1,ae=2,re=4,ie=8,de=16,se=ae|re,pe=ie|de,$=se|pe,oe=["x","y"],j=["clientX","clientY"];function ve(C,P){var L=this;this.manager=C,this.callback=P,this.element=C.element,this.target=C.options.inputTarget,this.domHandler=function(U){b(C.options.enable,[C])&&L.handler(U)},this.init()}ve.prototype={handler:function(){},init:function(){this.evEl&&_(this.element,this.evEl,this.domHandler),this.evTarget&&_(this.target,this.evTarget,this.domHandler),this.evWin&&_(k(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&w(this.element,this.evEl,this.domHandler),this.evTarget&&w(this.target,this.evTarget,this.domHandler),this.evWin&&w(k(this.element),this.evWin,this.domHandler)}};function me(C){var P,L=C.options.inputClass;return L?P=L:V?P=De:D?P=Ge:q?P=rt:P=Ee,new P(C,Me)}function Me(C,P,L){var U=L.pointers.length,Y=L.changedPointers.length,ne=P&X&&U-Y===0,ce=P&(J|Z)&&U-Y===0;L.isFirst=!!ne,L.isFinal=!!ce,ne&&(C.session={}),L.eventType=P,Re(C,L),C.emit("hammer.input",L),C.recognize(L),C.session.prevInput=L}function Re(C,P){var L=C.session,U=P.pointers,Y=U.length;L.firstInput||(L.firstInput=Ae(P)),Y>1&&!L.firstMultiple?L.firstMultiple=Ae(P):Y===1&&(L.firstMultiple=!1);var ne=L.firstInput,ce=L.firstMultiple,Ce=ce?ce.center:ne.center,Qe=P.center=le(U);P.timeStamp=d(),P.deltaTime=P.timeStamp-ne.timeStamp,P.angle=Se(Ce,Qe),P.distance=fe(Ce,Qe),ge(L,P),P.offsetDirection=Fe(P.deltaX,P.deltaY);var Te=ue(P.deltaTime,P.deltaX,P.deltaY);P.overallVelocityX=Te.x,P.overallVelocityY=Te.y,P.overallVelocity=l(Te.x)>l(Te.y)?Te.x:Te.y,P.scale=ce?ke(ce.pointers,U):1,P.rotation=ce?ye(ce.pointers,U):0,P.maxPointers=L.prevInput?P.pointers.length>L.prevInput.maxPointers?P.pointers.length:L.prevInput.maxPointers:P.pointers.length,we(L,P);var et=C.element;x(P.srcEvent.target,et)&&(et=P.srcEvent.target),P.target=et}function ge(C,P){var L=P.center,U=C.offsetDelta||{},Y=C.prevDelta||{},ne=C.prevInput||{};(P.eventType===X||ne.eventType===J)&&(Y=C.prevDelta={x:ne.deltaX||0,y:ne.deltaY||0},U=C.offsetDelta={x:L.x,y:L.y}),P.deltaX=Y.x+(L.x-U.x),P.deltaY=Y.y+(L.y-U.y)}function we(C,P){var L=C.lastInterval||P,U=P.timeStamp-L.timeStamp,Y,ne,ce,Ce;if(P.eventType!=Z&&(U>Q||L.velocity===r)){var Qe=P.deltaX-L.deltaX,Te=P.deltaY-L.deltaY,et=ue(U,Qe,Te);ne=et.x,ce=et.y,Y=l(et.x)>l(et.y)?et.x:et.y,Ce=Fe(Qe,Te),C.lastInterval=P}else Y=L.velocity,ne=L.velocityX,ce=L.velocityY,Ce=L.direction;P.velocity=Y,P.velocityX=ne,P.velocityY=ce,P.direction=Ce}function Ae(C){for(var P=[],L=0;L<C.pointers.length;)P[L]={clientX:u(C.pointers[L].clientX),clientY:u(C.pointers[L].clientY)},L++;return{timeStamp:d(),pointers:P,center:le(P),deltaX:C.deltaX,deltaY:C.deltaY}}function le(C){var P=C.length;if(P===1)return{x:u(C[0].clientX),y:u(C[0].clientY)};for(var L=0,U=0,Y=0;Y<P;)L+=C[Y].clientX,U+=C[Y].clientY,Y++;return{x:u(L/P),y:u(U/P)}}function ue(C,P,L){return{x:P/C||0,y:L/C||0}}function Fe(C,P){return C===P?te:l(C)>=l(P)?C<0?ae:re:P<0?ie:de}function fe(C,P,L){L||(L=oe);var U=P[L[0]]-C[L[0]],Y=P[L[1]]-C[L[1]];return Math.sqrt(U*U+Y*Y)}function Se(C,P,L){L||(L=oe);var U=P[L[0]]-C[L[0]],Y=P[L[1]]-C[L[1]];return Math.atan2(Y,U)*180/Math.PI}function ye(C,P){return Se(P[1],P[0],j)+Se(C[1],C[0],j)}function ke(C,P){return fe(P[0],P[1],j)/fe(C[0],C[1],j)}var _e={mousedown:X,mousemove:ee,mouseup:J},We="mousedown",Xe="mousemove mouseup";function Ee(){this.evEl=We,this.evWin=Xe,this.pressed=!1,ve.apply(this,arguments)}p(Ee,ve,{handler:function(P){var L=_e[P.type];L&X&&(P.button===0||P.button===2)&&(this.pressed=!0),L&ee&&P.which!==1&&(L=J),this.pressed&&(L&J&&(this.pressed=!1),this.callback(this.manager,L,{pointers:[P],changedPointers:[P],pointerType:G,srcEvent:P}))}});var Pe={pointerdown:X,pointermove:ee,pointerup:J,pointercancel:Z,pointerout:Z},Je={2:K,3:z,4:G,5:W},be="pointerdown",Oe="pointermove pointerup pointercancel";n.MSPointerEvent&&!n.PointerEvent&&(be="MSPointerDown",Oe="MSPointerMove MSPointerUp MSPointerCancel");function De(){this.evEl=be,this.evWin=Oe,ve.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}p(De,ve,{handler:function(P){var L=this.store,U=!1,Y=!1,ne=P.type.toLowerCase().replace("ms",""),ce=Pe[ne],Ce=Je[P.pointerType]||P.pointerType,Qe=Ce==K,Te=I(L,P.pointerId,"pointerId");ce&X&&(P.button===0||P.button===2||Qe)?Te<0&&(L.push(P),Te=L.length-1):ce&(J|Z)?U=!0:!Qe&&P.buttons===0&&(U=!0,Y=!0,ce=Pe.pointerup),!(Te<0)&&(Y||(L[Te]=P),this.callback(this.manager,ce,{pointers:L,changedPointers:[P],pointerType:Ce,srcEvent:L[Te]}),U&&L.splice(Te,1))}});var qe={touchstart:X,touchmove:ee,touchend:J,touchcancel:Z},Ze="touchstart",Ne="touchstart touchmove touchend touchcancel";function he(){this.evTarget=Ze,this.evWin=Ne,this.started=!1,ve.apply(this,arguments)}p(he,ve,{handler:function(P){var L=qe[P.type];if(L===X&&(this.started=!0),!!this.started){var U=st.call(this,P,L);L&(J|Z)&&U[0].length-U[1].length===0&&(this.started=!1),this.callback(this.manager,L,{pointers:U[0],changedPointers:U[1],pointerType:K,srcEvent:P})}}});function st(C,P){var L=S(C.touches),U=S(C.changedTouches);return P&(J|Z)&&(L=B(L.concat(U),"identifier",!0)),[L,U]}var ze={touchstart:X,touchmove:ee,touchend:J,touchcancel:Z},tt="touchstart touchmove touchend touchcancel";function Ge(){this.evTarget=tt,this.targetIds={},ve.apply(this,arguments)}p(Ge,ve,{handler:function(P){var L=ze[P.type],U=mt.call(this,P,L);U&&this.callback(this.manager,L,{pointers:U[0],changedPointers:U[1],pointerType:K,srcEvent:P})}});function mt(C,P){var L=S(C.touches),U=this.targetIds;if(P&(X|ee)&&L.length===1)return U[L[0].identifier]=!0,[L,L];var Y,ne,ce=S(C.changedTouches),Ce=[],Qe=this.target;if(ne=L.filter(function(Te){return x(Te.target,Qe)}),P===X)for(Y=0;Y<ne.length;)U[ne[Y].identifier]=!0,Y++;for(Y=0;Y<ce.length;)U[ce[Y].identifier]&&Ce.push(ce[Y]),P&(J|Z)&&delete U[ce[Y].identifier],Y++;if(Ce.length)return[B(ne.concat(Ce),"identifier",!0),Ce]}var lt=2500,ct=25;function rt(){ve.apply(this,arguments);var C=g(this.handler,this);this.touch=new Ge(this.manager,C),this.mouse=new Ee(this.manager,C),this.primaryTouch=null,this.lastTouches=[]}p(rt,ve,{handler:function(P,L,U){var Y=U.pointerType==K,ne=U.pointerType==G;if(!(ne&&U.sourceCapabilities&&U.sourceCapabilities.firesTouchEvents)){if(Y)nt.call(this,L,U);else if(ne&&xe.call(this,U))return;this.callback(P,L,U)}},destroy:function(){this.touch.destroy(),this.mouse.destroy()}});function nt(C,P){C&X?(this.primaryTouch=P.changedPointers[0].identifier,Ie.call(this,P)):C&(J|Z)&&Ie.call(this,P)}function Ie(C){var P=C.changedPointers[0];if(P.identifier===this.primaryTouch){var L={x:P.clientX,y:P.clientY};this.lastTouches.push(L);var U=this.lastTouches,Y=function(){var ne=U.indexOf(L);ne>-1&&U.splice(ne,1)};setTimeout(Y,lt)}}function xe(C){for(var P=C.srcEvent.clientX,L=C.srcEvent.clientY,U=0;U<this.lastTouches.length;U++){var Y=this.lastTouches[U],ne=Math.abs(P-Y.x),ce=Math.abs(L-Y.y);if(ne<=ct&&ce<=ct)return!0}return!1}var je=o?O(o.style,"touchAction"):r,at=je!==r,At="compute",yt="auto",dt="manipulation",He="none",Be="pan-x",Le="pan-y",Ue=ft();function Ve(C,P){this.manager=C,this.set(P)}Ve.prototype={set:function(C){C==At&&(C=this.compute()),at&&this.manager.element.style&&Ue[C]&&(this.manager.element.style[je]=C),this.actions=C.toLowerCase().trim()},update:function(){this.set(this.manager.options.touchAction)},compute:function(){var C=[];return h(this.manager.recognizers,function(P){b(P.options.enable,[P])&&(C=C.concat(P.getTouchAction()))}),Et(C.join(" "))},preventDefaults:function(C){var P=C.srcEvent,L=C.offsetDirection;if(this.manager.session.prevented){P.preventDefault();return}var U=this.actions,Y=M(U,He)&&!Ue[He],ne=M(U,Le)&&!Ue[Le],ce=M(U,Be)&&!Ue[Be];if(Y){var Ce=C.pointers.length===1,Qe=C.distance<2,Te=C.deltaTime<250;if(Ce&&Qe&&Te)return}if(!(ce&&ne)&&(Y||ne&&L&se||ce&&L&pe))return this.preventSrc(P)},preventSrc:function(C){this.manager.session.prevented=!0,C.preventDefault()}};function Et(C){if(M(C,He))return He;var P=M(C,Be),L=M(C,Le);return P&&L?He:P||L?P?Be:Le:M(C,dt)?dt:yt}function ft(){if(!at)return!1;var C={},P=n.CSS&&n.CSS.supports;return["auto","manipulation","pan-y","pan-x","pan-x pan-y","none"].forEach(function(L){C[L]=P?n.CSS.supports("touch-action",L):!0}),C}var ht=1,Ke=2,pt=4,ut=8,it=ut,gt=16,$e=32;function ot(C){this.options=A({},this.defaults,C||{}),this.id=H(),this.manager=null,this.options.enable=T(this.options.enable,!0),this.state=ht,this.simultaneous={},this.requireFail=[]}ot.prototype={defaults:{},set:function(C){return A(this.options,C),this.manager&&this.manager.touchAction.update(),this},recognizeWith:function(C){if(f(C,"recognizeWith",this))return this;var P=this.simultaneous;return C=bt(C,this),P[C.id]||(P[C.id]=C,C.recognizeWith(this)),this},dropRecognizeWith:function(C){return f(C,"dropRecognizeWith",this)?this:(C=bt(C,this),delete this.simultaneous[C.id],this)},requireFailure:function(C){if(f(C,"requireFailure",this))return this;var P=this.requireFail;return C=bt(C,this),I(P,C)===-1&&(P.push(C),C.requireFailure(this)),this},dropRequireFailure:function(C){if(f(C,"dropRequireFailure",this))return this;C=bt(C,this);var P=I(this.requireFail,C);return P>-1&&this.requireFail.splice(P,1),this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(C){return!!this.simultaneous[C.id]},emit:function(C){var P=this,L=this.state;function U(Y){P.manager.emit(Y,C)}L<ut&&U(P.options.event+Ct(L)),U(P.options.event),C.additionalEvent&&U(C.additionalEvent),L>=ut&&U(P.options.event+Ct(L))},tryEmit:function(C){if(this.canEmit())return this.emit(C);this.state=$e},canEmit:function(){for(var C=0;C<this.requireFail.length;){if(!(this.requireFail[C].state&($e|ht)))return!1;C++}return!0},recognize:function(C){var P=A({},C);if(!b(this.options.enable,[this,P])){this.reset(),this.state=$e;return}this.state&(it|gt|$e)&&(this.state=ht),this.state=this.process(P),this.state&(Ke|pt|ut|gt)&&this.tryEmit(P)},process:function(C){},getTouchAction:function(){},reset:function(){}};function Ct(C){return C>?"cancel":C&ut?"end":C&pt?"move":C&Ke?"start":""}function It(C){return C==de?"down":C==ie?"up":C==ae?"left":C==re?"right":""}function bt(C,P){var L=P.manager;return L?L.get(C):C}function Ye(){ot.apply(this,arguments)}p(Ye,ot,{defaults:{pointers:1},attrTest:function(C){var P=this.options.pointers;return P===0||C.pointers.length===P},process:function(C){var P=this.state,L=C.eventType,U=P&(Ke|pt),Y=this.attrTest(C);return U&&(L&Z||!Y)?P|gt:U||Y?L&J?P|ut:P&Ke?P|pt:Ke:$e}});function Tt(){Ye.apply(this,arguments),this.pX=null,this.pY=null}p(Tt,Ye,{defaults:{event:"pan",threshold:10,pointers:1,direction:$},getTouchAction:function(){var C=this.options.direction,P=[];return C&se&&P.push(Le),C&pe&&P.push(Be),P},directionTest:function(C){var P=this.options,L=!0,U=C.distance,Y=C.direction,ne=C.deltaX,ce=C.deltaY;return Y&P.direction||(P.direction&se?(Y=ne===0?te:ne<0?ae:re,L=ne!=this.pX,U=Math.abs(C.deltaX)):(Y=ce===0?te:ce<0?ie:de,L=ce!=this.pY,U=Math.abs(C.deltaY))),C.direction=Y,L&&U>P.threshold&&Y&P.direction},attrTest:function(C){return Ye.prototype.attrTest.call(this,C)&&(this.state&Ke||!(this.state&Ke)&&this.directionTest(C))},emit:function(C){this.pX=C.deltaX,this.pY=C.deltaY;var P=It(C.direction);P&&(C.additionalEvent=this.options.event+P),this._super.emit.call(this,C)}});function wt(){Ye.apply(this,arguments)}p(wt,Ye,{defaults:{event:"pinch",threshold:0,pointers:2},getTouchAction:function(){return[He]},attrTest:function(C){return this._super.attrTest.call(this,C)&&(Math.abs(C.scale-1)>this.options.threshold||this.state&Ke)},emit:function(C){if(C.scale!==1){var P=C.scale<1?"in":"out";C.additionalEvent=this.options.event+P}this._super.emit.call(this,C)}});function xt(){ot.apply(this,arguments),this._timer=null,this._input=null}p(xt,ot,{defaults:{event:"press",pointers:1,time:251,threshold:9},getTouchAction:function(){return[yt]},process:function(C){var P=this.options,L=C.pointers.length===P.pointers,U=C.distance<P.threshold,Y=C.deltaTime>P.time;if(this._input=C,!U||!L||C.eventType&(J|Z)&&!Y)this.reset();else if(C.eventType&X)this.reset(),this._timer=c(function(){this.state=it,this.tryEmit()},P.time,this);else if(C.eventType&J)return it;return $e},reset:function(){clearTimeout(this._timer)},emit:function(C){this.state===it&&(C&&C.eventType&J?this.manager.emit(this.options.event+"up",C):(this._input.timeStamp=d(),this.manager.emit(this.options.event,this._input)))}});function Mt(){Ye.apply(this,arguments)}p(Mt,Ye,{defaults:{event:"rotate",threshold:0,pointers:2},getTouchAction:function(){return[He]},attrTest:function(C){return this._super.attrTest.call(this,C)&&(Math.abs(C.rotation)>this.options.threshold||this.state&Ke)}});function Rt(){Ye.apply(this,arguments)}p(Rt,Ye,{defaults:{event:"swipe",threshold:10,velocity:.3,direction:se|pe,pointers:1},getTouchAction:function(){return Tt.prototype.getTouchAction.call(this)},attrTest:function(C){var P=this.options.direction,L;return P&(se|pe)?L=C.overallVelocity:P&se?L=C.overallVelocityX:P&pe&&(L=C.overallVelocityY),this._super.attrTest.call(this,C)&&P&C.offsetDirection&&C.distance>this.options.threshold&&C.maxPointers==this.options.pointers&&l(L)>this.options.velocity&&C.eventType&J},emit:function(C){var P=It(C.offsetDirection);P&&this.manager.emit(this.options.event+P,C),this.manager.emit(this.options.event,C)}});function _t(){ot.apply(this,arguments),this.pTime=!1,this.pCenter=!1,this._timer=null,this._input=null,this.count=0}p(_t,ot,{defaults:{event:"tap",pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[dt]},process:function(C){var P=this.options,L=C.pointers.length===P.pointers,U=C.distance<P.threshold,Y=C.deltaTime<P.time;if(this.reset(),C.eventType&X&&this.count===0)return this.failTimeout();if(U&&Y&&L){if(C.eventType!=J)return this.failTimeout();var ne=this.pTime?C.timeStamp-this.pTime<P.interval:!0,ce=!this.pCenter||fe(this.pCenter,C.center)<P.posThreshold;this.pTime=C.timeStamp,this.pCenter=C.center,!ce||!ne?this.count=1:this.count+=1,this._input=C;var Ce=this.count%P.taps;if(Ce===0)return this.hasRequireFailures()?(this._timer=c(function(){this.state=it,this.tryEmit()},P.interval,this),Ke):it}return $e},failTimeout:function(){return this._timer=c(function(){this.state=$e},this.options.interval,this),$e},reset:function(){clearTimeout(this._timer)},emit:function(){this.state==it&&(this._input.tapCount=this.count,this.manager.emit(this.options.event,this._input))}});function vt(C,P){return P=P||{},P.recognizers=T(P.recognizers,vt.defaults.preset),new St(C,P)}vt.VERSION="2.0.7",vt.defaults={domEvents:!1,touchAction:At,enable:!0,inputTarget:null,inputClass:null,preset:[[Mt,{enable:!1}],[wt,{enable:!1},["rotate"]],[Rt,{direction:se}],[Tt,{direction:se},["swipe"]],[_t],[_t,{event:"doubletap",taps:2},["tap"]],[xt]],cssProps:{userSelect:"none",touchSelect:"none",touchCallout:"none",contentZooming:"none",userDrag:"none",tapHighlightColor:"rgba(0,0,0,0)"}};var Ft=1,Pt=2;function St(C,P){this.options=A({},vt.defaults,P||{}),this.options.inputTarget=this.options.inputTarget||C,this.handlers={},this.session={},this.recognizers=[],this.oldCssProps={},this.element=C,this.input=me(this),this.touchAction=new Ve(this,this.options.touchAction),Bt(this,!0),h(this.options.recognizers,function(L){var U=this.add(new L[0](L[1]));L[2]&&U.recognizeWith(L[2]),L[3]&&U.requireFailure(L[3])},this)}St.prototype={set:function(C){return A(this.options,C),C.touchAction&&this.touchAction.update(),C.inputTarget&&(this.input.destroy(),this.input.target=C.inputTarget,this.input.init()),this},stop:function(C){this.session.stopped=C?Pt:Ft},recognize:function(C){var P=this.session;if(!P.stopped){this.touchAction.preventDefaults(C);var L,U=this.recognizers,Y=P.curRecognizer;(!Y||Y&&Y.state&it)&&(Y=P.curRecognizer=null);for(var ne=0;ne<U.length;)L=U[ne],P.stopped!==Pt&&(!Y||L==Y||L.canRecognizeWith(Y))?L.recognize(C):L.reset(),!Y&&L.state&(Ke|pt|ut)&&(Y=P.curRecognizer=L),ne++}},get:function(C){if(C instanceof ot)return C;for(var P=this.recognizers,L=0;L<P.length;L++)if(P[L].options.event==C)return P[L];return null},add:function(C){if(f(C,"add",this))return this;var P=this.get(C.options.event);return P&&this.remove(P),this.recognizers.push(C),C.manager=this,this.touchAction.update(),C},remove:function(C){if(f(C,"remove",this))return this;if(C=this.get(C),C){var P=this.recognizers,L=I(P,C);L!==-1&&(P.splice(L,1),this.touchAction.update())}return this},on:function(C,P){if(C!==r&&P!==r){var L=this.handlers;return h(R(C),function(U){L[U]=L[U]||[],L[U].push(P)}),this}},off:function(C,P){if(C!==r){var L=this.handlers;return h(R(C),function(U){P?L[U]&&L[U].splice(I(L[U],P),1):delete L[U]}),this}},emit:function(C,P){this.options.domEvents&&Ot(C,P);var L=this.handlers[C]&&this.handlers[C].slice();if(!(!L||!L.length)){P.type=C,P.preventDefault=function(){P.srcEvent.preventDefault()};for(var U=0;U<L.length;)L[U](P),U++}},destroy:function(){this.element&&Bt(this,!1),this.handlers={},this.session={},this.input.destroy(),this.element=null}};function Bt(C,P){var L=C.element;if(L.style){var U;h(C.options.cssProps,function(Y,ne){U=O(L.style,ne),P?(C.oldCssProps[U]=L.style[U],L.style[U]=Y):L.style[U]=C.oldCssProps[U]||""}),P||(C.oldCssProps={})}}function Ot(C,P){var L=t.createEvent("Event");L.initEvent(C,!0,!0),L.gesture=P,P.target.dispatchEvent(L)}return A(vt,{INPUT_START:X,INPUT_MOVE:ee,INPUT_END:J,INPUT_CANCEL:Z,STATE_POSSIBLE:ht,STATE_BEGAN:Ke,STATE_CHANGED:pt,STATE_ENDED:ut,STATE_RECOGNIZED:it,STATE_CANCELLED:gt,STATE_FAILED:$e,DIRECTION_NONE:te,DIRECTION_LEFT:ae,DIRECTION_RIGHT:re,DIRECTION_UP:ie,DIRECTION_DOWN:de,DIRECTION_HORIZONTAL:se,DIRECTION_VERTICAL:pe,DIRECTION_ALL:$,Manager:St,Input:ve,TouchAction:Ve,TouchInput:Ge,MouseInput:Ee,PointerEventInput:De,TouchMouseInput:rt,SingleTouchInput:he,Recognizer:ot,AttrRecognizer:Ye,Tap:_t,Pan:Tt,Swipe:Rt,Pinch:wt,Rotate:Mt,Press:xt,on:_,off:w,each:h,merge:y,extend:m,assign:A,inherit:p,bindFn:g,prefixed:O}),vt}(typeof window<"u"?window:{},typeof document<"u"?document:{});function calculateThreeMouse(n,t,e){var r=t.getBoundingClientRect(),i=r.top,o=r.left,s=r.width,u=r.height;return e&&(o=o+s*e.left,i=i+u*(1-e.bottom-e.height),s=s*e.width,u=u*e.height),new THREE__namespace.Vector2((n.x-o)/s*2-1,-(n.y-i)/u*2+1)}var BaseController=function(n){__extends(t,n);function t(e){var r,i,o,s,u,l,d=n.call(this)||this,c=t.parseArgs(e);return d.mode="",d.pending=new Set,d.userAction=c.initial.userAction,d.destroyed=!1,d.ident=c.ident,d.scene=c.scene,d.xrCustomObjectsScene=c.xrCustomObjectsScene,d.helper=c.helper,d.boundingMesh=c.boundingMesh,d.camera=c.camera,d.renderer=c.renderer,d.scissor=c.scissor,d.element=c.element,d.models=c.models,d.enableWheel=c.enableWheel,d.enableIOSEDR=(r=c.enableIOSEDR)!==null&&r!==void 0?r:!1,d.enableEDL=(i=c.enableEDL)!==null&&i!==void 0?i:!0,d.enableHQ=(o=c.enableHQ)!==null&&o!==void 0?o:!0,d.works=c.works,d.imageOptions=c.imageOptions,d.videoTexture=c.videoTexture,d.extraElements=c.extraElements,d.initial=c.initial,d.currentPano=typeof d.initial.state.panoIndex=="number"?{workCode:(l=(s=d.initial.state.workCode)!==null&&s!==void 0?s:(u=c.works[0])===null||u===void 0?void 0:u.workCode)!==null&&l!==void 0?l:"",panoIndex:d.initial.state.panoIndex}:{workCode:d.initial.currentState.workCode,panoIndex:d.initial.currentState.panoIndex},d.needsRender=!0,d.cameraMotion=new Motion({longitude:{value:d.camera.pose.longitude,circle:[0,Math.PI*2]},latitude:d.camera.pose.latitude,fov:d.camera.pose.fov}),d.inMomentumMovement=null,d.eventUnbinds=[c.element].concat(c.extraElements||[]).map(function(f){return d.bindEvents(f)}),d.pending.add("init-animation"),d.initAnimationReady=new Promise(function(f){AnimationFrameLoop.shared.add(function(){d.initAnimation().then(function(){d.pending.delete("init-animation"),f()})},!0)}),d}return t.parseArgs=function(e){return e instanceof t?e:__assign({},e)},t.initAnimationEndState=function(e){var r,i,o,s,u,l,d,c,f=this.parseArgs(e),h=f.initial,v=h.state,A=h.currentState,m=typeof v.panoIndex=="number"?{workCode:(o=(r=v.workCode)!==null&&r!==void 0?r:(i=f.works[0])===null||i===void 0?void 0:i.workCode)!==null&&o!==void 0?o:"",panoIndex:v.panoIndex}:{workCode:A.workCode,panoIndex:A.panoIndex};return __assign(__assign({},m),{mode:"",longitude:(s=v.longitude)!==null&&s!==void 0?s:A.longitude,latitude:(u=v.latitude)!==null&&u!==void 0?u:A.latitude,fov:(l=v.fov)!==null&&l!==void 0?l:A.fov,offset:(d=v.offset)!==null&&d!==void 0?d:A.offset,distance:(c=v.distance)!==null&&c!==void 0?c:A.distance})},t.prototype.destroy=function(){var e;this.stopMomentumMovement(),this.destroyed=!0,this.off(),this.cameraMotion.dispose();for(var r=0,i=this.eventUnbinds;r<i.length;r++){var o=i[r];o()}this.copyEffect&&(this.copyEffect.dispose(),delete this.copyEffect),delete this.panState,(e=this.pressState)===null||e===void 0||e.stop(),delete this.pressState},t.prototype.isReady=function(){return this.inMomentumMovement===null&&this.pending.size===0&&this.cameraMotion.ended===!0},t.prototype.bindExtraElement=function(e){for(var r=0,i=this.eventUnbinds;r<i.length;r++){var o=i[r];if(o.element===e)return}this.eventUnbinds.push(this.bindEvents(e))},t.prototype.unbindExtraElement=function(e){for(var r=[],i=0,o=this.eventUnbinds;i<o.length;i++){var s=o[i];s.element===e?s():r.push(s)}this.eventUnbinds=r},t.prototype.updateRenderSize=function(){this.needsRender=!0},t.prototype.updateModel=function(e){this.needsRender=!0},t.prototype.updateWork=function(e,r,i,o){return this.works=e,this.userAction=o,!1},t.prototype.updateTime=function(e,r){if(!this.destroyed){var i={};this.cameraMotion.ended&&(this.cameraMotion.update(e),i.longitude=this.cameraMotion.value.longitude,i.latitude=this.cameraMotion.value.latitude,i.fov=this.cameraMotion.value.fov),isEmptyObject(i)&&this.setCamera(i)}},t.prototype.render=function(){this.renderer.render(this.scene,this.camera)},t.prototype.postProcessing=function(e,r){this.destroyed},t.prototype.updateCamera=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();var s={};return e.longitude!==void 0&&(s.longitude=e.longitude),e.latitude!==void 0&&(s.latitude=e.latitude),e.fov!==void 0&&(s.fov=e.fov),o.cameraMotion.set(s,r).catch(noop$1)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();for(var s=[],u=0,l=e;u<l.length;u++){var d=l[u];s.push({key:d.key,progress:d.progress,value:{longitude:d.value.longitude,latitude:d.value.latitude,fov:d.value.fov}})}return o.cameraMotion.setKeyframes(s,r)})},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1];return __assign(__assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance})},t.prototype.initAnimation=function(){var e=this.initial;e.state,e.currentState,e.duration;var r=e.userAction,i=t.initAnimationEndState(this);return this.userAction=r,this.emit("initAnimation.start",createEvent("initAnimation.start",{state:i,userAction:this.userAction})),this.emit("initAnimation.end",createEvent("initAnimation.end",{state:i,userAction:this.userAction})),Promise.resolve()},t.prototype.setCamera=function(e){var r,i,o,s,u;e===void 0&&(e={});var l=(r=e.longitude)!==null&&r!==void 0?r:this.camera.pose.longitude,d=(i=e.latitude)!==null&&i!==void 0?i:this.camera.pose.latitude,c=(o=e.fov)!==null&&o!==void 0?o:this.camera.pose.fov,f=(s=e.distance)!==null&&s!==void 0?s:this.camera.pose.distance,h=(u=e.offset)!==null&&u!==void 0?u:this.camera.pose.offset,v=notSimilarValue(l,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(d,this.camera.pose.latitude),A=notSimilarValue(c,this.camera.pose.fov),m=notSimilarValue(f,this.camera.pose.distance),y=notSimilarVector3(h,this.camera.pose.offset);(A||v||y||m)&&(this.camera.setFromPose({longitude:l,latitude:d,fov:c,distance:f,offset:h}),this.emit("camera.update",createEvent("camera.update",{userAction:this.userAction,state:__assign(__assign({},this.currentPano),{mode:this.mode,longitude:l,latitude:d,fov:c,offset:h,distance:f})})),this.needsRender=!0)},t.prototype.stopMomentumMovement=function(){if(this.inMomentumMovement&&this.inMomentumMovement.event&&!this.inMomentumMovement.event.defaultPrevented&&!this.inMomentumMovement.event.isFinal){var e=createEvent("gesture.momentum",__assign(__assign({},this.inMomentumMovement.event),{isFirst:!1,isFinal:!0}));this.emit("gesture.momentum",e)}this.inMomentumMovement=null},t.prototype.onPanGesture=function(e){this.stopMomentumMovement(),this.emit("gesture.pan",e)},t.prototype.onTapGesture=function(e){this.stopMomentumMovement(),this.emit("gesture.tap",e)},t.prototype.onPressGesture=function(e){this.stopMomentumMovement(),this.emit("gesture.press",e)},t.prototype.onPinchGesture=function(e){this.stopMomentumMovement(),this.emit("gesture.pinch",e)},t.prototype.onMouseWheel=function(e){this.stopMomentumMovement(),this.emit("gesture.mousewheel",e)},t.prototype.onMouseMove=function(e){this.stopMomentumMovement(),this.emit("gesture.mousemove",e)},t.prototype.relativeClientPosition=function(e){return calculateThreeMouse(e,this.element,this.scissor)},t.prototype.bindEvents=function(e){var r=this,i=function(M){var R=calculateThreeMouse(M,r.element,r.scissor);return!(Math.abs(R.x)>1||Math.abs(R.y)>1)},o=new Hammer.Manager(e),s=function(M){var R=M.session;return R.firstInput||null};o.add(new Hammer.Pan({threshold:10,pointers:0})),o.add(new Hammer.Tap({interval:410})),o.add(new Hammer.Pinch({threshold:0,pointers:2})),o.on("panstart pan",function(M){var R=s(o);if(!(R&&!i(R.center))){var I=createEvent("gesture.pan",{target:M.target,pointerType:M.pointerType,srcEvent:M.srcEvent,pointers:M.pointers.map(function(S){var B=r.relativeClientPosition(S),O=new THREE__namespace.Raycaster;return O.params.Points={threshold:.1},O.setFromCamera(B,r.camera),{x:S.x,y:S.y,delta:0,buttons:0,coords:B,raycaster:O}}),isFirst:M.isFirst,isFinal:M.isFinal,scale:M.scale,center:function(S){var B=r.relativeClientPosition(S),O=new THREE__namespace.Raycaster;return O.params.Points={threshold:.1},O.setFromCamera(B,r.camera),{x:S.x,y:S.y,delta:0,buttons:0,coords:B,raycaster:O}}(M.center),velocityX:M.velocityX,velocityY:M.velocityY,overallVelocityX:M.overallVelocityX,overallVelocityY:M.overallVelocityY,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.onPanGesture(I),y()}}),o.on("tap",function(M){if(!(M.pointerType==="mouse"&&M.srcEvent.button!==0)){var R=s(o);if(!(R&&!i(R.center))){var I=createEvent("gesture.tap",{target:M.target,pointerType:M.pointerType,srcEvent:M.srcEvent,pointers:M.pointers.map(function(S){var B=r.relativeClientPosition(S),O=new THREE__namespace.Raycaster;return O.params.Points={threshold:.1},O.setFromCamera(B,r.camera),{x:S.x,y:S.y,delta:0,buttons:0,coords:B,raycaster:O}}),isFirst:!0,isFinal:!0,scale:M.scale,center:function(S){var B=r.relativeClientPosition(S),O=new THREE__namespace.Raycaster;return O.params.Points={threshold:.1},O.setFromCamera(B,r.camera),{x:S.x,y:S.y,delta:0,buttons:0,coords:B,raycaster:O}}(M.center),velocityX:M.velocityX,velocityY:M.velocityY,overallVelocityX:M.overallVelocityX,overallVelocityY:M.overallVelocityY,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.onTapGesture(I),y()}}}),o.on("pinchstart pinch pinchend",function(M){var R=s(o);if(!(R&&!i(R.center))){var I=createEvent("gesture.pinch",{target:M.target,pointerType:M.pointerType,srcEvent:M.srcEvent,pointers:M.pointers.map(function(S){var B,O=r.relativeClientPosition(S),F=new THREE__namespace.Raycaster;return F.params.Points={threshold:.1},F.setFromCamera(O,r.camera),{x:S.x,y:S.y,delta:(B=S.delta)!==null&&B!==void 0?B:0,buttons:0,coords:O,raycaster:F}}),isFirst:M.type==="pinchstart",isFinal:M.type==="pinchend",scale:M.scale,center:function(S){var B=r.relativeClientPosition(S),O=new THREE__namespace.Raycaster;return O.params.Points={threshold:.1},O.setFromCamera(B,r.camera),{x:S.x,y:S.y,delta:0,buttons:0,coords:B,raycaster:O}}(M.center),velocityX:M.velocityX,velocityY:M.velocityY,overallVelocityX:M.overallVelocityX,overallVelocityY:M.overallVelocityY,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.onPinchGesture(I),y()}});var u=null,l=null,d=function(M,R,I){var S={x:I.clientX,y:I.clientY},B=r.relativeClientPosition(S),O=new THREE__namespace.Raycaster;O.params.Points={threshold:.1},O.setFromCamera(B,r.camera);var F=__assign(__assign({},S),{coords:B,raycaster:O,buttons:I.buttons,delta:0}),H=M==="pinchend"?R:R-I.deltaY/280,k=createEvent("gesture.pinch",{target:I.target,pointerType:"mouse",srcEvent:I,pointers:[__assign({},F)],isFirst:M==="pinchstart",isFinal:M==="pinchend",scale:clamp(H,.1,10),center:__assign({},F),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});return k},c=function(M){var R,I={x:M.clientX,y:M.clientY};if(i(I)){if(M.preventDefault(),M.ctrlKey){var S=(R=u==null?void 0:u.prevEvent.scale)!==null&&R!==void 0?R:1,B=d(u?"pinch":"pinchstart",S,M);u===null?u={firstEvent:B,prevEvent:B}:u.prevEvent=B,r.onPinchGesture(B),l!==null&&window.clearTimeout(l),l=window.setTimeout(function(){var V;l=null;var D=(V=u==null?void 0:u.prevEvent.scale)!==null&&V!==void 0?V:1,K=d("pinchend",D,M);u=null,r.onPinchGesture(K)},200)}else{var O=(Math.abs(M.deltaY)>Math.abs(M.deltaX)?M.deltaY:M.deltaX)/-60,F=r.mouseWheelState!==void 0,H={x:M.clientX,y:M.clientY},k=r.relativeClientPosition(H),N=new THREE__namespace.Raycaster;N.params.Points={threshold:.1},N.setFromCamera(k,r.camera);var q=__assign(__assign({},H),{coords:k,raycaster:N,buttons:M.buttons,delta:O}),B=createEvent("gesture.mousewheel",{target:M.target,pointerType:"mouse",srcEvent:M,pointers:[__assign({},q)],isFirst:F,isFinal:!1,scale:0,center:__assign({},q),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.onMouseWheel(B),r.mouseWheelState&&clearTimeout(r.mouseWheelState.timer),r.mouseWheelState={timer:setTimeout(function(){delete r.mouseWheelState;var D=createEvent("gesture.mousewheel",{target:M.target,pointerType:"mouse",srcEvent:M,pointers:[__assign(__assign({},q),{delta:0})],isFirst:!1,isFinal:!0,scale:0,center:__assign(__assign({},q),{delta:0}),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.onMouseWheel(D)},100)}}y()}},f=function(M){if(!isMobile()){if(!i({x:M.clientX,y:M.clientY})){h();return}var R=!1;r.mouseMoveState||(R=!0);var I={x:M.clientX,y:M.clientY},S=r.relativeClientPosition(I),B=new THREE__namespace.Raycaster;B.params.Points={threshold:.1},B.setFromCamera(S,r.camera);var O=__assign(__assign({},I),{coords:S,raycaster:B,buttons:M.buttons,delta:0}),F=createEvent("gesture.mousemove",{target:M.target,pointerType:"mouse",srcEvent:M,pointers:[__assign({},O)],isFirst:R,isFinal:!1,scale:0,center:__assign({},O),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});r.mouseMoveState||(r.mouseMoveState={timeStamp:now(),event:F}),r.onMouseMove(F),r.pressState&&Math.abs(M.clientX-r.pressState.event.center.y)>10&&Math.abs(M.clientY-r.pressState.event.center.y)>10&&y()}},h=function(){if(r.mouseMoveState){var M=createEvent(r.mouseMoveState.event.type,__assign(__assign({},r.mouseMoveState.event),{isFinal:!0}));r.onMouseMove(M)}y()},v=function(M){if(!i(M.center)){y();return}var R=!1;r.pressState||(R=!0,r.pressState={event:M,timeStamp:now(),stop:noop$1});var I=now()-r.pressState.timeStamp,S=createEvent(r.pressState.event.type,__assign(__assign({},r.pressState.event),{isFirst:R,isFinal:!1,center:__assign(__assign({},r.pressState.event.center),{delta:I}),pointers:r.pressState.event.pointers.map(function(B){return __assign(__assign({},B),{delta:I})})}));r.onPressGesture(S),r.pressState&&(r.pressState.stop=AnimationFrameLoop.shared.add(function(B){v(M)},!0,1))},A=function(M){if(y(),!(M.touches.length>1||M.changedTouches.length<=0)){var R={x:M.changedTouches[0].clientX,y:M.changedTouches[0].clientY},I=r.relativeClientPosition(R),S=new THREE__namespace.Raycaster;S.params.Points={threshold:.1},S.setFromCamera(I,r.camera);var B=__assign(__assign({},R),{coords:I,raycaster:S,buttons:0,delta:0}),O=createEvent("gesture.press",{target:M.target,pointerType:"touch",srcEvent:M,pointers:[__assign({},B)],isFirst:!1,isFinal:!1,scale:0,center:B,velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});v(O)}},m=function(M){y();var R={x:M.clientX,y:M.clientY},I=r.relativeClientPosition(R),S=new THREE__namespace.Raycaster;S.params.Points={threshold:.1},S.setFromCamera(I,r.camera);var B=__assign(__assign({},R),{coords:I,raycaster:S,buttons:M.buttons,delta:0}),O=createEvent("gesture.press",{target:M.target,pointerType:"mouse",srcEvent:M,pointers:[__assign({},B)],isFirst:!1,isFinal:!1,scale:0,center:B,velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});v(O)},y=function(){var M;if(r.pressState){var R=now()-r.pressState.timeStamp,I=createEvent(r.pressState.event.type,__assign(__assign({},r.pressState.event),{center:__assign(__assign({},r.pressState.event.center),{delta:R}),isFirst:!1,isFinal:!0,pointers:r.pressState.event.pointers.map(function(S){return __assign(__assign({},S),{delta:R})})}));r.onPressGesture(I),(M=r.pressState)===null||M===void 0||M.stop(),delete r.pressState}},p=null,g=function(M){var R,I=!1,S=!1;switch(M.type){case"gesturestart":I=!0;break;case"gestureend":S=!0;break}var B={x:M.clientX,y:M.clientY},O=r.relativeClientPosition(B),F=new THREE__namespace.Raycaster;F.params.Points={threshold:.1},F.setFromCamera(O,r.camera);var H=__assign(__assign({},B),{coords:O,raycaster:F,buttons:0,delta:0}),k=createEvent("gesture.pinch",{target:M.target,pointerType:"mouse",srcEvent:M,pointers:[__assign({},H)],isFirst:I,isFinal:S,scale:(R=M.scale)!==null&&R!==void 0?R:1,center:__assign({},H),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:__assign(__assign({mode:r.mode},r.currentPano),clonePose(r.camera.pose))});return k},b=function(M){if(M.preventDefault(),!isMobile()){var R=g(M);p={firstEvent:R};var I=p.firstEvent;I&&!i(I.center)||r.onPinchGesture(R)}},T=function(M){if(M.preventDefault(),!isMobile()&&p){var R=g(M),I=p.firstEvent;I&&!i(I.center)||r.onPinchGesture(R)}},_=function(M){if(M.preventDefault(),!isMobile()&&p){var R=g(M),I=p.firstEvent;p=null,!(I&&!i(I.center))&&r.onPinchGesture(R)}},w=function(M){if(M&&typeof M.preventDefault=="function"&&M.currentTarget===e&&M.preventDefault(),typeof getSelection=="function"){var R=getSelection();R&&R.focusNode&&(R.removeAllRanges&&R.removeAllRanges(),R.empty&&R.empty())}};this.enableWheel&&e.addEventListener("wheel",c,{passive:!1}),e.addEventListener("mousemove",f,!1),e.addEventListener("mouseout",h,!1),e.addEventListener("touchstart",A,{passive:!0}),e.addEventListener("touchend",y,!1),e.addEventListener("touchcancel",y,!1),e.addEventListener("mousedown",m,!1),e.addEventListener("mouseup",y,!1),e.addEventListener("gesturestart",b,{passive:!1}),e.addEventListener("gesturechange",T,{passive:!1}),e.addEventListener("gestureend",_,{passive:!1}),e.addEventListener("touchstart",w,{passive:!1}),e.addEventListener("contextmenu",w,!1);var x=function(){o.destroy(),e.removeEventListener("wheel",c,!1),e.removeEventListener("mousemove",f,!1),e.removeEventListener("mouseout",h,!1),e.removeEventListener("touchstart",A,!1),e.removeEventListener("touchend",y,!1),e.removeEventListener("touchcancel",y,!1),e.removeEventListener("mousedown",m,!1),e.removeEventListener("mouseup",y,!1),e.removeEventListener("gesturestart",b,!1),e.removeEventListener("gesturechange",T,!1),e.removeEventListener("gestureend",_,!1),e.removeEventListener("touchstart",w,!1),e.removeEventListener("contextmenu",w,!1)};return Object.assign(x,{element:e})},t.prototype.preloadPano=function(e,r){var i=this;r===void 0&&(r=noop$1);var o=this.works.getResolvedObserver(e);if(!o)return Promise.resolve();var s=["right","left","up","down","front","back"];return Promise.all(s.map(function(u){var l=__assign({key:"pano.".concat(panoStringify(e),".").concat(u)},pick(i.imageOptions,["size","format","quality","mappings"])),d=o.images[u],c=applyImageURLOptions(d,i.imageOptions.transform,l);return getFetcher(o.work).preload(c)})).then(function(){return r(e),e})},t}(Subscribe),FloorplanController=function(n){__extends(t,n);function t(e){var r=this,i,o=t.parseArgs(e);return r=n.call(this,o)||this,r.mode="Floorplan",r.defaultLongitude=o.defaultLongitude,r.defaultLatitude=o.defaultLatitude,r.defaultFov=o.defaultFov,r.maxFov=o.maxFov,r.minFov=o.minFov,r.maxLatitude=o.maxLatitude,r.minLatitude=o.minLatitude,r.locationMotion=new Motion({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 Motion({modelAlpha:(i=r.models.getMaterial().modelAlpha)!==null&&i!==void 0?i:0}),r.perspToOrthoMotion=new Motion({perspToOrtho:r.camera.perspToOrtho.x}),r.currentTapId=null,r.intersectMeshCreator=o.intersectMeshCreator,r.intersectMesh=r.intersectMeshCreator(),r.intersectMesh.name="intersect",r.intersectMesh.visible=!1,r.helper.add(r.intersectMesh),r}return t.distanceFromModel=function(e,r,i){var o=e.bounding,s=Math.pow(Math.pow(o.max.x-o.min.x+1,2)+Math.pow(o.max.y-o.min.y+1,2)+Math.pow(o.max.z-o.min.z+1,2),1/2),u=s/2/Math.tan(Math.PI*r/360);return i<1&&(u=u/i),isNaN(u)?s:u},t.parseArgs=function(e){var r,i,o,s,u,l,d,c;if(e instanceof t)return e;var f=n.parseArgs.call(this,e);return __assign(__assign({},f),{defaultLongitude:(r=e.defaultLongitude)!==null&&r!==void 0?r:Math.PI/4,defaultLatitude:(i=e.defaultLatitude)!==null&&i!==void 0?i:Math.PI/4,defaultFov:(o=e.defaultFov)!==null&&o!==void 0?o:80,maxFov:(s=e.maxFov)!==null&&s!==void 0?s:120,minFov:(u=e.minFov)!==null&&u!==void 0?u:20,maxLatitude:(l=e.maxLatitude)!==null&&l!==void 0?l:+Math.PI/2,minLatitude:(d=e.minLatitude)!==null&&d!==void 0?d:-Math.PI/2,intersectMeshCreator:(c=e.intersectMeshCreator)!==null&&c!==void 0?c:function(){return new IntersectMesh}})},t.initAnimationEndState=function(e){var r,i,o,s,u,l,d=this.parseArgs(e),c=e.initial,f=c.state,h=c.currentState,v=typeof f.panoIndex=="number"?{workCode:(o=(r=f.workCode)!==null&&r!==void 0?r:(i=d.works[0])===null||i===void 0?void 0:i.workCode)!==null&&o!==void 0?o:"",panoIndex:f.panoIndex}:{workCode:h.workCode,panoIndex:h.panoIndex},A=__assign(__assign({},v),{mode:"Floorplan",longitude:(s=f.longitude)!==null&&s!==void 0?s:isThirdPersonMode(h.mode)?h.longitude:d.defaultLongitude,latitude:clamp((u=f.latitude)!==null&&u!==void 0?u:h.mode==="Floorplan"?h.latitude:d.defaultLatitude,d.minLatitude,d.maxLatitude),fov:(l=f.fov)!==null&&l!==void 0?l:d.defaultFov,offset:e.models.bounding.getCenter(new THREE__namespace.Vector3),distance:t.distanceFromModel(d.models,d.defaultFov,d.camera.aspect)});return A},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,o){return this.works=e,this.updateCamera(r,i??0,o),!0},t.prototype.updateModel=function(e){n.prototype.updateModel.call(this,e);var r=e.bounding.getCenter(new THREE__namespace.Vector3),i=t.distanceFromModel(e,this.defaultFov,this.camera.aspect);this.locationMotion.set({x:r.x,y:r.y,z:r.z,distance:i},0).catch(noop$1)},t.prototype.updateCamera=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();var s={},u={};return e.distance!==void 0&&(s.distance=e.distance),e.offset!==void 0&&(s.x=e.offset.x,s.y=e.offset.y,s.z=e.offset.z),e.longitude!==void 0&&(u.longitude=e.longitude),e.latitude!==void 0&&(u.latitude=e.latitude),e.fov!==void 0&&(u.fov=e.fov),o.locationMotion.set(s,r).catch(noop$1),o.cameraMotion.set(u,r).catch(noop$1)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();for(var s=[],u=[],l=0,d=e;l<d.length;l++){var c=d[l];s.push({key:c.key,progress:c.progress,value:{distance:c.value.distance,x:c.value.offset.x,y:c.value.offset.x,z:c.value.offset.x}}),u.push({key:c.key,progress:c.progress,value:{longitude:c.value.longitude,latitude:c.value.latitude,fov:c.value.fov}})}return o.locationMotion.setKeyframes(s,r).catch(noop$1),o.cameraMotion.setKeyframes(e,r)})},t.prototype.updateTime=function(e,r){if(!this.destroyed){var i={},o={};this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),i.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended||(this.locationMotion.update(e),o.distance=this.locationMotion.value.distance,o.offset=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z)),this.cameraMotion.ended||(this.cameraMotion.update(e),o.longitude=this.cameraMotion.value.longitude,o.latitude=this.cameraMotion.value.latitude,o.fov=this.cameraMotion.value.fov),isEmptyObject(i)||this.models.setMaterial(i),isEmptyObject(o)||this.setCamera(o)}},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1],r=this.locationMotion.getKeyFrameSegment(now())[1];return __assign(__assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:new THREE__namespace.Vector3(r.value.x,r.value.y,r.value.z),distance:r.value.distance})},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 o=i.duration,s=i.userAction;e.userAction=s;var u=t.initAnimationEndState(e),l=pick(u,["longitude","latitude","fov"]),d={x:u.offset.x,y:u.offset.y,z:u.offset.z,distance:u.distance},c={modelAlpha:1},f={perspToOrtho:0};e.emit("initAnimation.start",createEvent("initAnimation.start",{state:u,userAction:e.userAction})),e.modelAlphaMotion.set(c,o/3).catch(noop$1),e.perspToOrthoMotion.set(f,o).catch(noop$1),e.cameraMotion.set(l,o).catch(noop$1),e.locationMotion.set(d,o).then(function(){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:u,userAction:e.userAction}))},function(h){var v=__assign(__assign(__assign({},e.currentPano),{mode:e.mode}),clonePose(e.camera.pose));e.emit("initAnimation.end",createEvent("initAnimation.end",{state:v,userAction:e.userAction}))}).then(function(){r()})})},t.prototype.updateRenderSize=function(){this.locationMotion.set({distance:t.distanceFromModel(this.models,this.defaultFov,this.camera.aspect)},0).catch(noop$1)},t.prototype.getForwardObserverOrNot=function(e){var r=this.models.intersectRaycaster(e)[0];if(!r)return null;var i=this.works.resolvedObservers,o=arrayMin(i,function(l){return l.standingPosition.distanceTo(r.point)},!0),s=o[0],u=o[1];return s&&u<10?s:null},t.prototype.coordinatesForOffset=function(e){var r=this.renderer.getSize(new THREE__namespace.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,o){var s=this;if(this.inMomentumMovement!==null){for(var u=__assign({},i),l={longitude:0,latitude:0},d=0;d<o;d++)u.longitude*=.996,u.latitude*=.996*.998,l.longitude+=u.longitude,l.latitude+=u.latitude;var c=formatRad(this.cameraMotion.value.longitude+l.longitude),f=clamp(this.cameraMotion.value.latitude+l.latitude,this.minLatitude,this.maxLatitude),h=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:c,latitude:f,fov:this.cameraMotion.value.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance}),v=!(u.longitude>1e-4||u.longitude<-1e-4||u.latitude>1e-4||u.latitude<-1e-4),A=createEvent("gesture.momentum",__assign(__assign({},e),{isFirst:r,isFinal:v,state:h}));if(this.inMomentumMovement.event=A,this.emit("gesture.momentum",A),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:c,latitude:f},0).catch(noop$1),v?this.inMomentumMovement=null:AnimationFrameLoop.shared.add(function(m,y){s.requestMomentumMovement(e,!1,u,y|0)},!0,1))}},t.prototype.onPanGesture=function(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();var r=this.panState,i=e.pointers.length;if(e.isFinal?delete this.panState:this.panState={pointerLength:i,x:e.center.x,y:e.center.y},!(typeof r>"u"||r.pointerLength!==i)){var o={x:e.center.x-r.x,y:e.center.y-r.y},s=this.relativeClientPosition(e.center),u=this.camera.pose.latitude<Math.PI/6||s.y<0?1:-1;o.x*=u;var l=this.coordinatesForOffset(o),d=formatRad(this.cameraMotion.value.longitude+l.longitude),c=clamp(this.cameraMotion.value.latitude+l.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&&(c=this.cameraMotion.value.latitude);var f=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:d,latitude:c,fov:this.camera.pose.fov,offset:this.camera.pose.offset,distance:this.camera.pose.distance});if(e.state=f,this.emit("gesture.pan",e),!e.defaultPrevented&&(this.cameraMotion.set({longitude:f.longitude,latitude:f.latitude},0).catch(noop$1),e.isFinal)){var h=e.velocityX*u,v=e.velocityY;this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,this.coordinatesForOffset({x:h,y:v}),0)}}},t.prototype.onPinchGesture=function(e){var r;this.userAction=e.userAction,this.stopMomentumMovement();var i=(r=this.pinchState)===null||r===void 0?void 0:r.fov;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&(delete this.panState,delete this.pinchState),!(typeof i>"u")){var o=clamp(i/e.scale,this.minFov,this.maxFov);e.state.fov=o,this.emit("gesture.pinch",e),!e.defaultPrevented&&(this.cameraMotion.set({fov:o},0).catch(noop$1),this.onPanGesture(e))}},t.prototype.onMouseMove=function(e){var r,i;if(this.intersectMesh.parent&&!this.panState){if(this.emit("gesture.mousemove",e),e.defaultPrevented){this.hideIntersectMesh();return}var o=e.center.raycaster;if(e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}var s=this.models.intersectRaycaster(o)[0],u=createEvent("intersect.update",{raycaster:o,intersection:s??null,object:this.intersectMesh});if(this.emit("intersect.update",u),u.defaultPrevented){this.hideIntersectMesh();return}if(s){var l=(i=(r=s.face)===null||r===void 0?void 0:r.normal)!==null&&i!==void 0?i:new THREE__namespace.Vector3().copy(o.ray.direction).multiplyScalar(-1),d=l.clone().multiplyScalar(.05),c=s.point.clone().add(d);this.intersectMesh.position.copy(c);var f=c.clone().add(d);if(this.intersectMesh.lookAt(f),Math.abs(l.y)>.99){var h=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(h.z,h.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}},t.prototype.onMouseWheel=function(e){this.userAction=e.userAction,this.stopMomentumMovement();var r=this,i=r.minFov,o=r.maxFov,s=clamp(this.camera.fov-e.center.delta,i,o);e.state.fov=s,this.emit("gesture.mousewheel",e),!e.defaultPrevented&&this.cameraMotion.set({fov:s},0).catch(noop$1)},t.prototype.onTapGesture=function(e){var r=this;this.userAction=!0,this.stopMomentumMovement();var i=e.center.raycaster,o=this.getForwardObserverOrNot(i);if(!o)this.emit("gesture.tap",e);else{var s={longitude:this.camera.pose.longitude,latitude:0},u=__assign(__assign({},e.state),{mode:"Panorama",workCode:o.pano.workCode,panoIndex:o.pano.panoIndex,longitude:s.longitude,latitude:s.latitude,offset:o?o.position.clone():new THREE__namespace.Vector3,distance:0});if(e.state=u,this.emit("gesture.tap",e),!e.defaultPrevented&&(this.emit("pano.select",createEvent("pano.select",{prevPano:this.currentPano,state:u,userAction:e.userAction,options:s,progress:0,error:null})),o&&o.active)){var l=this.currentTapId=createUuid();this.preloadPano(o.pano).then(function(d){r.currentTapId===l&&r.emit("pano.request",createEvent("pano.request",{userAction:!0,prevPano:r.currentPano,progress:0,state:u,options:s,error:null}))})}}},t.prototype.hideIntersectMesh=function(){this.intersectMesh.visible=!1,this.needsRender=!0},t}(BaseController),ViewDirection={Top:{longitude:0,latitude:Math.PI/2},FrontSide:{longitude:0,latitude:0},LeftSide:{longitude:Math.PI/2,latitude:0},BackSide:{longitude:Math.PI,latitude:0},RightSide:{longitude:Math.PI*1.5,latitude:0}};function panLeft(n,t){var e=new THREE__namespace.Vector3().copy(t);return e.multiplyScalar(-n),e}function panUp(n,t){var e=new THREE__namespace.Vector3().copy(t);return e.multiplyScalar(n),e}var TopviewController=function(n){__extends(t,n);function t(e){var r=this,i=t.parseArgs(e);return r=n.call(this,i)||this,r.mode="Topview",r}return t.parseArgs=function(e){if(e instanceof t)return e;var r=__assign(__assign({},e.initial),{state:__assign(__assign({},e.initial.state),{longitude:0,latitude:Math.PI/2})}),i=__assign(__assign({},e),{initial:r,maxLatitude:Math.PI/2,minLatitude:Math.PI/2,defaultLongitude:0,defaultLatitude:Math.PI/2});return n.parseArgs.call(this,i)},t.initAnimationEndState=function(e){var r=this.parseArgs(e),i=n.initAnimationEndState.call(this,r);return __assign(__assign({},i),{mode:"Topview"})},t.prototype.updateModel=function(e){this.needsRender=!0;var r=this.models.bounding.getCenter(new THREE__namespace.Vector3);this.locationMotion.set({x:r.x,y:r.y,z:r.z,distance:FloorplanController.distanceFromModel(this.models,this.defaultFov,this.camera.aspect)},0).catch(noop$1)},t.prototype.updateCamera=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();var s={},u={};return e.distance!==void 0&&(s.distance=e.distance),e.offset!==void 0&&(s.x=e.offset.x,s.y=e.offset.y,s.z=e.offset.z),e.longitude!==void 0&&(u.longitude=e.longitude),e.latitude!==void 0&&(u.latitude=e.latitude),e.fov!==void 0&&(u.fov=e.fov),o.locationMotion.set(s,r).catch(noop$1),o.cameraMotion.set(u,r).catch(noop$1)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();for(var s=[],u=[],l=0,d=e;l<d.length;l++){var c=d[l];s.push({key:c.key,progress:c.progress,value:{distance:c.value.distance,x:c.value.offset.x,y:c.value.offset.x,z:c.value.offset.x}}),u.push({key:c.key,progress:c.progress,value:{longitude:c.value.longitude,latitude:c.value.latitude,fov:c.value.fov}})}return o.locationMotion.setKeyframes(s,r).catch(noop$1),o.cameraMotion.setKeyframes(e,r)})},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 o=i.duration,s=i.userAction;e.userAction=s;var u=t.initAnimationEndState(e),l={longitude:u.longitude,latitude:u.latitude,fov:u.fov},d={x:u.offset.x,y:u.offset.y,z:u.offset.z,distance:u.distance},c={modelAlpha:1},f={perspToOrtho:1};e.emit("initAnimation.start",createEvent("initAnimation.start",{state:u,userAction:e.userAction})),e.modelAlphaMotion.set(c,o/3).catch(noop$1),e.perspToOrthoMotion.set(f,o).catch(noop$1),e.cameraMotion.set(l,o).catch(noop$1),e.locationMotion.set(d,o).then(function(){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:u,userAction:e.userAction}))},function(h){var v=__assign(__assign(__assign({},e.currentPano),{mode:e.mode}),clonePose(e.camera.pose));e.emit("initAnimation.end",createEvent("initAnimation.end",{state:v,userAction:e.userAction}))}).then(function(){r()})})},t.prototype.getZoomOffsetFromFov=function(e,r,i){var o=this.camera.getDirection(new THREE__namespace.Vector3),s=Math.tan(i/2*Math.PI/180),u=Math.tan(r.fov/2*Math.PI/180),l=(u-s)/u,d=new THREE__namespace.Raycaster;d.params.Points={threshold:.1},d.setFromCamera(e,r);var c=d.ray.direction,f=c.angleTo(o),h=FloorplanController.distanceFromModel(this.models,this.defaultFov,this.camera.aspect),v=h*Math.tan(f),A=c.clone().setLength(h*Math.cos(f)).projectOnPlane(o),m=A.length(),y=l/m*A.x*v,p=l/m*A.z*v,g=l/m*A.y*v;return new THREE__namespace.Vector3(y,g,p)},t.prototype.requestMomentumMovement=function(){this.inMomentumMovement=null},t.prototype.onPanGesture=function(e){this.userAction=e.userAction,this.stopMomentumMovement();var r=this.panState,i=e.pointers.length;if(e.isFinal?delete this.panState:this.panState={pointerLength:i,x:e.center.x,y:e.center.y},!(typeof r>"u"||r.pointerLength!==i)){var o={x:e.center.x-r.x,y:e.center.y-r.y},s=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),u=this.models.bounding,l={left:new THREE__namespace.Vector3,up:new THREE__namespace.Vector3,cameraDirection:"y"};this.cameraMotion.value.longitude===ViewDirection.Top.longitude&&this.cameraMotion.value.latitude===ViewDirection.Top.latitude?(l.left.set(1,0,0),l.up.set(0,0,-1),l.cameraDirection="y"):this.cameraMotion.value.longitude===ViewDirection.FrontSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.FrontSide.latitude?(l.left.set(1,0,0),l.up.set(0,1,0),l.cameraDirection="z"):this.cameraMotion.value.longitude===ViewDirection.BackSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.BackSide.latitude?(l.left.set(1,0,0),l.up.set(0,-1,0),l.cameraDirection="z"):this.cameraMotion.value.longitude===ViewDirection.RightSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.RightSide.latitude?(l.left.set(0,0,-1),l.up.set(0,-1,0),l.cameraDirection="x"):this.cameraMotion.value.longitude===ViewDirection.LeftSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.LeftSide.latitude&&(l.left.set(0,0,-1),l.up.set(0,1,0),l.cameraDirection="x");var d=(this.camera.position[l.cameraDirection]-u.min[l.cameraDirection])*Math.tan(this.camera.fov/2*Math.PI/180),c=this.renderer.getSize(new THREE__namespace.Vector2);s.add(panLeft(2*o.x*d/c.y,l.left)),s.add(panUp(2*o.y*d/c.y,l.up)),s.clamp(this.models.bounding.min,this.models.bounding.max);var f=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:0,latitude:Math.PI/2,fov:this.cameraMotion.value.fov,offset:s,distance:this.locationMotion.value.distance});e.state=f,this.emit("gesture.pan",e),!e.defaultPrevented&&this.locationMotion.set({x:s.x,y:s.y,z:s.z},0).catch(noop$1)}},t.prototype.onPinchGesture=function(e){var r;this.userAction=e.userAction,this.stopMomentumMovement();var i=(r=this.pinchState)===null||r===void 0?void 0:r.fov;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&delete this.pinchState,!(typeof i>"u")){var o=clamp(i/e.scale,this.minFov,this.maxFov),s=this.relativeClientPosition({x:e.center.x,y:e.center.y}),u=this.getZoomOffsetFromFov(s,this.camera,o);this.cameraMotion.value.longitude===ViewDirection.Top.longitude&&this.cameraMotion.value.latitude===ViewDirection.Top.latitude?u.y=0:this.cameraMotion.value.longitude===ViewDirection.FrontSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.FrontSide.latitude||this.cameraMotion.value.longitude===ViewDirection.BackSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.BackSide.latitude?u.z=0:(this.cameraMotion.value.longitude===ViewDirection.RightSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.RightSide.latitude||this.cameraMotion.value.longitude===ViewDirection.LeftSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.LeftSide.latitude)&&(u.x=0);var l=this.camera.pose.offset.clone().add(u);e.state.offset.copy(l),e.state.fov=o,this.emit("gesture.pinch",e),!e.defaultPrevented&&(this.locationMotion.set({x:l.x,y:l.y,z:l.z},0).catch(noop$1),this.cameraMotion.set({fov:o},0).catch(noop$1),e.type="gesture.pan",this.onPanGesture(e))}},t.prototype.onMouseWheel=function(e){this.userAction=e.userAction,this.stopMomentumMovement();var r=clamp(this.cameraMotion.value.fov-e.center.delta,this.minFov,this.maxFov),i=e.center.coords,o=this.getZoomOffsetFromFov(i,this.camera,r);this.cameraMotion.value.longitude===ViewDirection.Top.longitude&&this.cameraMotion.value.latitude===ViewDirection.Top.latitude?o.y=0:this.cameraMotion.value.longitude===ViewDirection.FrontSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.FrontSide.latitude||this.cameraMotion.value.longitude===ViewDirection.BackSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.BackSide.latitude?o.z=0:(this.cameraMotion.value.longitude===ViewDirection.RightSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.RightSide.latitude||this.cameraMotion.value.longitude===ViewDirection.LeftSide.longitude&&this.cameraMotion.value.latitude===ViewDirection.LeftSide.latitude)&&(o.x=0);var s=this.camera.pose.offset.clone().add(o);e.state.offset.copy(s),e.state.fov=r,this.emit("gesture.mousewheel",e),!e.defaultPrevented&&(this.locationMotion.set({x:s.x,y:s.y,z:s.z},0).catch(noop$1),this.cameraMotion.set({fov:r},0).catch(noop$1))},t}(FloorplanController),PanoramaLikeController=function(n){__extends(t,n);function t(e){var r=this,i=t.parseArgs(e);return r=n.call(this,i)||this,r.mode="PanoramaLike",r.defaultLatitude=i.defaultLatitude,r.defaultFov=i.defaultFov,r.maxFov=i.maxFov,r.minFov=i.minFov,r.maxLatitude=i.maxLatitude,r.minLatitude=i.minLatitude,r.moveSpeed=i.moveSpeed,r.intersectMeshCreator=i.intersectMeshCreator,r.intersectMesh=r.intersectMeshCreator(),r.intersectMesh.name="intersect",r.intersectMesh.visible=!1,r.helper.add(r.intersectMesh),r}return t.parseArgs=function(e){var r,i,o,s,u,l,d,c;if(e instanceof t)return e;var f=n.parseArgs.call(this,e);return __assign(__assign({},f),{defaultLatitude:(r=e.defaultLatitude)!==null&&r!==void 0?r:0,defaultFov:(i=e.defaultFov)!==null&&i!==void 0?i:90,maxFov:(o=e.maxFov)!==null&&o!==void 0?o:120,minFov:(s=e.minFov)!==null&&s!==void 0?s:40,maxLatitude:(u=e.maxLatitude)!==null&&u!==void 0?u:+Math.PI/2,minLatitude:(l=e.minLatitude)!==null&&l!==void 0?l:-Math.PI/2,moveSpeed:(d=e.moveSpeed)!==null&&d!==void 0?d:3.4,intersectMeshCreator:(c=e.intersectMeshCreator)!==null&&c!==void 0?c:function(){return new IntersectMesh}})},t.initAnimationEndState=function(e){var r,i,o,s,u,l,d=this.parseArgs(e),c=d.works,f=e.initial,h=f.state,v=f.currentState,A=typeof h.panoIndex=="number"?{workCode:(o=(r=h.workCode)!==null&&r!==void 0?r:(i=d.works[0])===null||i===void 0?void 0:i.workCode)!==null&&o!==void 0?o:"",panoIndex:h.panoIndex}:{workCode:v.workCode,panoIndex:v.panoIndex},m=c.getResolvedObserver(A),y=(s=h.longitude)!==null&&s!==void 0?s:v.longitude,p=clamp((u=h.latitude)!==null&&u!==void 0?u:isFristPersonMode(v.mode)?v.latitude:d.defaultLatitude,d.minLatitude,d.maxLatitude),g=clamp((l=h.fov)!==null&&l!==void 0?l:isFristPersonMode(v.mode)?v.fov:d.defaultFov,d.minFov,d.maxFov),b=m?m.position.clone():new THREE__namespace.Vector3;return{workCode:A.workCode,panoIndex:A.panoIndex,mode:"PanoramaLike",longitude:y,latitude:p,fov:g,offset:b,distance:0}},t.prototype.destroy=function(){n.prototype.destroy.call(this),this.intersectMesh&&(this.helper.remove(this.intersectMesh),this.intersectMesh.dispose()),delete this.panState},t.prototype.isReady=function(){return this.panState||this.pinchState?!1:n.prototype.isReady.call(this)},t.prototype.calculateMovingDuration=function(e,r){switch(typeof e){case"function":return e(r,this.moveSpeed);case"number":return e;case"string":return Number(e);default:return clamp(r,2,5)/this.moveSpeed*1e3}},t.prototype.hideIntersectMesh=function(){this.intersectMesh.visible=!1,this.needsRender=!0},t.prototype.coordinatesForOffset=function(e){var r=this.cameraMotion.value.fov,i=this.camera.aspect,o=this.renderer.getSize(new THREE__namespace.Vector2);return{longitude:2*e.x/(o.x*this.scissor.width)*r/95*i,latitude:-2*e.y/(o.y*this.scissor.height)*r/95}},t.prototype.cameraBounce=function(){var e=this.cameraMotion.value,r=e.longitude,i=e.latitude,o=e.fov,s=[{progress:0,value:{longitude:r,latitude:i,fov:o}},{progress:.5,value:{longitude:r,latitude:i,fov:o*.98}},{progress:1,value:{longitude:r,latitude:i,fov:o}}];this.cameraMotion.setKeyframes(s,500).catch(noop$1)},t.prototype.requestMomentumMovement=function(e,r,i,o){var s=this;if(this.inMomentumMovement!==null){for(var u=__assign({},i),l={longitude:0,latitude:0},d=0;d<o;d++)u.longitude*=.996,u.latitude*=.996*.99,l.longitude+=u.longitude,l.latitude+=u.latitude;var c=formatRad(this.cameraMotion.value.longitude+l.longitude),f=clamp(this.cameraMotion.value.latitude+l.latitude,this.minLatitude,this.maxLatitude),h=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:c,latitude:f,fov:this.cameraMotion.value.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance}),v=!(u.longitude>1e-4||u.longitude<-1e-4||u.latitude>1e-4||u.latitude<-1e-4),A=createEvent("gesture.momentum",__assign(__assign({},e),{isFirst:r,isFinal:v,state:h}));if(this.inMomentumMovement.event=A,this.emit("gesture.momentum",A),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:c,latitude:f},0).catch(noop$1),v?this.inMomentumMovement=null:AnimationFrameLoop.shared.add(function(m,y){s.requestMomentumMovement(e,!1,u,y|0)},!0,1))}},t.prototype.onPanGesture=function(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();var r=this.panState,i=e.pointers.length;if(e.isFinal?delete this.panState:this.panState={pointerLength:i,x:e.center.x,y:e.center.y},!(typeof r>"u"||r.pointerLength!==i)){var o={x:e.center.x-r.x,y:e.center.y-r.y},s=this.coordinatesForOffset(o),u=formatRad(this.cameraMotion.value.longitude+s.longitude),l=clamp(this.cameraMotion.value.latitude+s.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 d=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:u,latitude:l,fov:this.cameraMotion.value.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance});if(e.state=d,this.emit("gesture.pan",e),!e.defaultPrevented){var c={longitude:d.longitude,latitude:d.latitude,fov:d.fov};if(this.cameraMotion.set(c,0).catch(noop$1),e.isFinal){var f=e.velocityX,h=e.velocityY*.6;Math.abs(h)>.5&&Math.abs(f)<.5&&(f=0),this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,this.coordinatesForOffset({x:f,y:h}),0)}}}},t.prototype.onPinchGesture=function(e){var r;this.userAction=e.userAction,this.stopMomentumMovement();var i=(r=this.pinchState)===null||r===void 0?void 0:r.fov,o=e.scale;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&delete this.pinchState,!(typeof i>"u")){var s=clamp(i/o,this.minFov,this.maxFov);e.state.fov=s,this.emit("gesture.pinch",e),!e.defaultPrevented&&(this.cameraMotion.set({fov:s},0).catch(noop$1),e.type="gesture.pan",this.onPanGesture(e))}},t.prototype.onMouseWheel=function(e){this.userAction=e.userAction,this.stopMomentumMovement();var r=clamp(this.cameraMotion.value.fov-e.center.delta,this.minFov,this.maxFov);e.state.fov=r,this.emit("gesture.mousewheel",e),!e.defaultPrevented&&this.cameraMotion.set({fov:r},0).catch(noop$1)},t.prototype.onMouseMove=function(e){var r,i;if(this.intersectMesh.parent&&!this.panState&&(this.emit("gesture.mousemove",e),!e.defaultPrevented)){var o=e.center.raycaster;if(e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}var s=this.models.intersectRaycaster(o)[0],u=createEvent("intersect.update",{raycaster:o,intersection:s??null,object:this.intersectMesh});if(this.emit("intersect.update",u),u.defaultPrevented){this.hideIntersectMesh();return}if(s){var l=(i=(r=s.face)===null||r===void 0?void 0:r.normal)!==null&&i!==void 0?i:new THREE__namespace.Vector3().copy(o.ray.direction).multiplyScalar(-1),d=l.clone().multiplyScalar(.05),c=s.point.clone().add(d);this.intersectMesh.position.copy(c);var f=c.clone().add(d);if(this.intersectMesh.lookAt(f),Math.abs(l.y)>.99){var h=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(h.z,h.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}},t}(BaseController),blankVideo="data:video/mp4;base64,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",result;function canplayVideo(){return result||(result=new Promise(function(n){var t,e=document.createElement("video");e.muted=!0,e.src=blankVideo,e.addEventListener("timeupdate",function r(){e.removeEventListener("timeupdate",r,!1),clearTimeout(t);var i=document.createElement("canvas");i.width=i.height=1;var o=i.getContext("2d");if(!o){n(!1);return}o.drawImage(e,0,0,1,1);var s=o.getImageData(0,0,1,1).data;s[3]>10?n(!0):n(!1)},!1),e.addEventListener("canplay",function r(){e.removeEventListener("canplay",r,!1),e.play()},!1),t=window.setTimeout(function(){return n(!1)},1e3)}))}var camera$1=new THREE__namespace.OrthographicCamera(-1,1,1,-1,0,1),geometry$4=new THREE__namespace.BufferGeometry;geometry$4.setAttribute("position",new THREE__namespace.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3)),geometry$4.setAttribute("uv",new THREE__namespace.Float32BufferAttribute([0,2,0,0,2,0],2));var mesh$3=new THREE__namespace.Mesh(geometry$4),scene$1=new THREE__namespace.Scene;scene$1.add(mesh$3);var DEFAULT_VERTEX_SHADER=`
|
|
1329
1329
|
varying vec2 vUv;
|
|
1330
1330
|
void main() {
|
|
1331
1331
|
vUv = uv;
|
|
@@ -1429,7 +1429,7 @@ void main() {
|
|
|
1429
1429
|
gl_FragColor.a = 1.0 - texture2D(luminanceMap, vUv).r;
|
|
1430
1430
|
#endif
|
|
1431
1431
|
}
|
|
1432
|
-
`,TileMaterial=function(n){__extends(t,n);function t(){var e=n.call(this,{uniforms:{map:{value:null},luminanceMap:{value:null},flipY:{value:0}},vertexShader:TILE_MATERIAL_VERTEX_SHADER,fragmentShader:TILE_MATERIAL_FRAGMENT_SHADER})||this;return e.depthTest=!1,e.depthWrite=!1,e.blending=THREE__namespace.NoBlending,e.map=e.uniforms.map.value,e.luminanceMap=e.uniforms.luminanceMap.value,e.flipY=e.uniforms.flipY.value,Object.defineProperties(e,{map:{get:function(){return this.uniforms.map.value},set:function(r){this.uniforms.map.value=r}},luminanceMap:{get:function(){return this.uniforms.luminanceMap.value},set:function(r){this.uniforms.luminanceMap.value=r,this.defines.USE_LUMINANCE=r!==null,this.needsUpdate=!0}},flipY:{get:function(){return this.uniforms.flipY.value===1},set:function(r){this.uniforms.flipY.value=r?1:0}}}),e}return t}(THREE__namespace.ShaderMaterial),TileMesh=function(n){__extends(t,n);function t(e,r){var i=n.call(this,geometry$3,new TileMaterial)||this;return e.box.getCenter(i.position),i.quaternion.multiplyQuaternions(new THREE__namespace.Quaternion().setFromAxisAngle(new THREE__namespace.Vector3(0,1,0),-Math.PI),TILE_QUATERNION[e.face]),i.scale.setScalar(e.size),i.node=e,i.name="tiling:tile",i.material.visible=!1,i.activeTime=-1,i.disposed=!1,i.needsRender=!1,i.frustumCulled=!1,r.then(function(o){var s=o[0],u=o[1];i.disposed?(s.dispose(),u==null||u.dispose()):(i.material.map=s,i.material.luminanceMap=u,i.material.flipY=!s.flipY,i.material.needsUpdate=!0,i.material.visible=!0,i.needsRender=!0)}).catch(noop$1),i}return t.prototype.updateTime=function(e){},t.prototype.dispose=function(){var e;this.disposed=!0,this.material.map&&(this.material.map.dispose(),(e=this.material.luminanceMap)===null||e===void 0||e.dispose()),this.material.dispose()},t}(THREE__namespace.Mesh),TilingObject3D=function(n){__extends(t,n);function t(){var e=n.call(this)||this;return e.needsRender=!1,e.name="tiling",e}return t}(THREE__namespace.Group),Tiling=function(){function n(t,e,r){this.disposed=!1,this.textureLoader=new TextureLoader,this.minLevel=e,this.level=0,this.panoId="[0]",this.pedding=0,this.tileTree=createTileCubeTree(this.minLevel),this.tileMeshes=new Map,this.resource=[],this.luminance=null,this.imageOptions=r,this.fetcher=t,this.object=new TilingObject3D,this.object.renderOrder=-3}return n.prototype.setFetcher=function(t){this.fetcher=t},n.prototype.cleanup=function(){var t=this;this.tileMeshes.forEach(function(e){e.dispose(),t.object.remove(e),t.object.needsRender=!0}),this.tileMeshes.clear()},n.prototype.setRotation=function(t){this.disposed||this.object.quaternion.equals(t)||(this.object.quaternion.copy(t),this.object.needsRender=!0)},n.prototype.setPosition=function(t){this.disposed||this.object.position.equals(t)||(this.object.position.copy(t),this.object.needsRender=!0)},n.prototype.setResource=function(t,e){var r,i;if(!this.disposed&&!(this.resource===t&&this.luminance===e)){this.cleanup(),this.resource=t;var o=(i=(r=t.slice().sort(function(s,u){return u.level-s.level})[0])===null||r===void 0?void 0:r.level)!==null&&i!==void 0?i:0;this.tileTree=createTileCubeTree(o),this.luminance=e,this.object.needsRender=!0}},n.prototype.update=function(t,e,r){var i=this;if(!this.disposed){this.level=e;var o=t.planes[5].normal,s=[];e>=this.minLevel&&traverseTileCubeNode(this.tileTree,function(b){if(!(b.level<i.minLevel)){if(b.level>e||!t.intersectsBox(b.box))return!1;s.push(b)}});var u=new THREE__namespace.Vector3;s.sort(function(b,T){return b.level!==T.level?b.level-T.level:b.box.getCenter(u).angleTo(o)-T.box.getCenter(u).angleTo(o)});for(var l=new Set,d=function(b){var T=c.resource.filter(function(V){return V.level===b.level})[0];if(!T)return"continue";if(l.add(b),c.tileMeshes.has(b))return c.tileMeshes.get(b).activeTime=r,"continue";var _=T.size,w=c.imageOptions.transform,x=Math.pow(2,b.level)*b.position.y,M=Math.pow(2,b.level)*b.position.x,R="".concat(c.panoId,".").concat(b.face,".").concat(b.level,".").concat(x,".").concat(M),I=__assign(__assign({key:"pano_tile.".concat(R)},pick(c.imageOptions,["format","size","quality","sharpen","mappings"])),{size:_*b.size===TILE_IMAGE_SIZE?void 0:TILE_IMAGE_SIZE,cut:[_*b.position.x,_*b.position.y,_*b.size,_*b.size]}),S=c.textureLoader.loadTexture(T[b.face],{imageURL:{transform:w,options:I},viaAjax:canUseNativeImageBitmap,fetcher:c.fetcher}).then(function(V){return V.body}),B=null;if(c.luminance){var
|
|
1432
|
+
`,TileMaterial=function(n){__extends(t,n);function t(){var e=n.call(this,{uniforms:{map:{value:null},luminanceMap:{value:null},flipY:{value:0}},vertexShader:TILE_MATERIAL_VERTEX_SHADER,fragmentShader:TILE_MATERIAL_FRAGMENT_SHADER})||this;return e.depthTest=!1,e.depthWrite=!1,e.blending=THREE__namespace.NoBlending,e.map=e.uniforms.map.value,e.luminanceMap=e.uniforms.luminanceMap.value,e.flipY=e.uniforms.flipY.value,Object.defineProperties(e,{map:{get:function(){return this.uniforms.map.value},set:function(r){this.uniforms.map.value=r}},luminanceMap:{get:function(){return this.uniforms.luminanceMap.value},set:function(r){this.uniforms.luminanceMap.value=r,this.defines.USE_LUMINANCE=r!==null,this.needsUpdate=!0}},flipY:{get:function(){return this.uniforms.flipY.value===1},set:function(r){this.uniforms.flipY.value=r?1:0}}}),e}return t}(THREE__namespace.ShaderMaterial),TileMesh=function(n){__extends(t,n);function t(e,r){var i=n.call(this,geometry$3,new TileMaterial)||this;return e.box.getCenter(i.position),i.quaternion.multiplyQuaternions(new THREE__namespace.Quaternion().setFromAxisAngle(new THREE__namespace.Vector3(0,1,0),-Math.PI),TILE_QUATERNION[e.face]),i.scale.setScalar(e.size),i.node=e,i.name="tiling:tile",i.material.visible=!1,i.activeTime=-1,i.disposed=!1,i.needsRender=!1,i.frustumCulled=!1,r.then(function(o){var s=o[0],u=o[1];i.disposed?(s.dispose(),u==null||u.dispose()):(i.material.map=s,i.material.luminanceMap=u,i.material.flipY=!s.flipY,i.material.needsUpdate=!0,i.material.visible=!0,i.needsRender=!0)}).catch(noop$1),i}return t.prototype.updateTime=function(e){},t.prototype.dispose=function(){var e;this.disposed=!0,this.material.map&&(this.material.map.dispose(),(e=this.material.luminanceMap)===null||e===void 0||e.dispose()),this.material.dispose()},t}(THREE__namespace.Mesh),TilingObject3D=function(n){__extends(t,n);function t(){var e=n.call(this)||this;return e.needsRender=!1,e.name="tiling",e}return t}(THREE__namespace.Group),Tiling=function(){function n(t,e,r){this.disposed=!1,this.textureLoader=new TextureLoader,this.minLevel=e,this.level=0,this.panoId="[0]",this.pedding=0,this.tileTree=createTileCubeTree(this.minLevel),this.tileMeshes=new Map,this.resource=[],this.luminance=null,this.imageOptions=r,this.fetcher=t,this.object=new TilingObject3D,this.object.renderOrder=-3}return n.prototype.setFetcher=function(t){this.fetcher=t},n.prototype.cleanup=function(){var t=this;this.tileMeshes.forEach(function(e){e.dispose(),t.object.remove(e),t.object.needsRender=!0}),this.tileMeshes.clear()},n.prototype.setRotation=function(t){this.disposed||this.object.quaternion.equals(t)||(this.object.quaternion.copy(t),this.object.needsRender=!0)},n.prototype.setPosition=function(t){this.disposed||this.object.position.equals(t)||(this.object.position.copy(t),this.object.needsRender=!0)},n.prototype.setResource=function(t,e){var r,i;if(!this.disposed&&!(this.resource===t&&this.luminance===e)){this.cleanup(),this.resource=t;var o=(i=(r=t.slice().sort(function(s,u){return u.level-s.level})[0])===null||r===void 0?void 0:r.level)!==null&&i!==void 0?i:0;this.tileTree=createTileCubeTree(o),this.luminance=e,this.object.needsRender=!0}},n.prototype.update=function(t,e,r){var i=this;if(!this.disposed){this.level=e;var o=t.planes[5].normal,s=[];e>=this.minLevel&&traverseTileCubeNode(this.tileTree,function(b){if(!(b.level<i.minLevel)){if(b.level>e||!t.intersectsBox(b.box))return!1;s.push(b)}});var u=new THREE__namespace.Vector3;s.sort(function(b,T){return b.level!==T.level?b.level-T.level:b.box.getCenter(u).angleTo(o)-T.box.getCenter(u).angleTo(o)});for(var l=new Set,d=function(b){var T=c.resource.filter(function(V){return V.level===b.level})[0];if(!T)return"continue";if(l.add(b),c.tileMeshes.has(b))return c.tileMeshes.get(b).activeTime=r,"continue";var _=T.size,w=c.imageOptions.transform,x=Math.pow(2,b.level)*b.position.y,M=Math.pow(2,b.level)*b.position.x,R="".concat(c.panoId,".").concat(b.face,".").concat(b.level,".").concat(x,".").concat(M),I=__assign(__assign({key:"pano_tile.".concat(R)},pick(c.imageOptions,["format","size","quality","sharpen","mappings"])),{size:_*b.size===TILE_IMAGE_SIZE?void 0:TILE_IMAGE_SIZE,cut:[_*b.position.x,_*b.position.y,_*b.size,_*b.size]}),S=c.textureLoader.loadTexture(T[b.face],{imageURL:{transform:w,options:I},viaAjax:canUseNativeImageBitmap,fetcher:c.fetcher}).then(function(V){return V.body}),B=null;if(c.luminance){var O=c.luminance[b.face],F=O.match(/\/cube_(\d+)\//),H=F?Number(F[1]):!1;if(H!==!1){var k=__assign(__assign({},I),{size:H*b.size===TILE_IMAGE_SIZE/2?void 0:TILE_IMAGE_SIZE/2,cut:[H*b.position.x,H*b.position.y,H*b.size,H*b.size],key:"pano_tile_luminance.".concat(R)});B=c.textureLoader.loadTexture(O,{imageURL:{transform:c.imageOptions.transform,options:k},viaAjax:canUseNativeImageBitmap,fetcher:c.fetcher}).then(function(V){return V.body}).catch(function(){return null})}}c.pedding++;var N=Promise.all([S,B]).then(function(V){return i.pedding--,V},function(V){return i.pedding--,Promise.reject(V)}),q=new TileMesh(b,N);q.name="tiling:tile-".concat(R),q.activeTime=r,q.renderOrder=b.level,c.tileMeshes.set(b,q),c.object.needsRender=!0,c.object.add(q)},c=this,f=0,h=s;f<h.length;f++){var v=h[f];d(v)}var A=[];this.tileMeshes.forEach(function(b,T){l.has(T)||A.push(T),b.visible=T.level<=e});for(var m=A.sort(function(b,T){var _,w,x,M;return((w=(_=i.tileMeshes.get(T))===null||_===void 0?void 0:_.activeTime)!==null&&w!==void 0?w:0)-((M=(x=i.tileMeshes.get(b))===null||x===void 0?void 0:x.activeTime)!==null&&M!==void 0?M:0)}).slice(Math.max(0,MAX_TILE_COUNT-l.size)),y=0,p=m;y<p.length;y++){var v=p[y],g=this.tileMeshes.get(v);g&&(g.dispose(),this.object.remove(g),this.object.needsRender=!0),this.tileMeshes.delete(v)}}},n.prototype.dispose=function(){this.cleanup(),this.resource=[],this.disposed=!0},n}(),vertices$1=new Float32Array([-1,1,1,-1,1,-1,-1,-1,1,-1,-1,-1,1,1,-1,1,1,1,1,-1,-1,1,-1,1,1,1,-1,-1,1,-1,1,1,1,-1,1,1,1,-1,1,-1,-1,1,1,-1,-1,-1,-1,-1,1,1,1,-1,1,1,1,-1,1,-1,-1,1,-1,1,-1,1,1,-1,-1,-1,-1,1,-1,-1]),index$1=new Uint8Array([0,2,1,2,3,1,4,6,5,6,7,5,8,10,9,10,11,9,12,14,13,14,15,13,16,18,17,18,19,17,20,22,21,22,23,21]),sharedGeometry$2=new THREE__namespace.BufferGeometry;sharedGeometry$2.setAttribute("position",new THREE__namespace.BufferAttribute(vertices$1,3)),sharedGeometry$2.setIndex(new THREE__namespace.BufferAttribute(index$1,1));var PANO_VIDEO_MATERIAL_VERTEX_SHADER=`
|
|
1433
1433
|
#if defined(USE_PANO_VIDEO)
|
|
1434
1434
|
varying vec3 worldPosition;
|
|
1435
1435
|
#endif
|
|
@@ -1464,7 +1464,7 @@ void main() {
|
|
|
1464
1464
|
gl_FragColor = vec4(videoColor.rgb, match * blendAlpha * alpha);
|
|
1465
1465
|
#endif
|
|
1466
1466
|
}
|
|
1467
|
-
`,PanoVideo=function(){function n(){this.material=new THREE__namespace.ShaderMaterial({vertexShader:PANO_VIDEO_MATERIAL_VERTEX_SHADER,fragmentShader:PANO_VIDEO_TILE_MATERIAL_FRAGMENT_SHADER,uniforms:{size:new THREE__namespace.Uniform(null),matrix:new THREE__namespace.Uniform(null),alpha:new THREE__namespace.Uniform(null),map:new THREE__namespace.Uniform(null)},depthTest:!1,depthWrite:!1,defines:{USE_PANO_VIDEO:!1},blending:THREE__namespace.CustomBlending,blendSrc:THREE__namespace.SrcAlphaFactor,blendDst:THREE__namespace.OneMinusSrcAlphaFactor,blendSrcAlpha:THREE__namespace.OneFactor,blendDstAlpha:THREE__namespace.OneMinusSrcAlphaFactor}),this.object=new THREE__namespace.Mesh(sharedGeometry$2,this.material),this.object.visible=!1,this.object.renderOrder=-1,this.object.frustumCulled=!1,this.object.name="pano-video",this.alphaMotion=new Motion({alpha:0})}return n.prototype.setMaterial=function(t){t?(this.material.uniforms.size.value=t.size,this.material.uniforms.matrix.value=t.matrix,this.material.uniforms.map.value=t.map,this.alphaMotion.set({alpha:t.alpha},500).catch(noop$1),this.material.uniforms.alpha.value=t.alpha):(this.material.uniforms.size.value=null,this.material.uniforms.matrix.value=null,this.material.uniforms.map.value=null,this.alphaMotion.set({alpha:0},0).catch(noop$1));var e=t!==null,r=this.material.defines.USE_PANO_VIDEO;e!==r&&(this.material.defines.USE_PANO_VIDEO=e,this.material.needsUpdate=!0,this.object.visible=t!==null)},n.prototype.updateTime=function(t){this.alphaMotion.ended||(this.alphaMotion.update(t),this.material.uniforms.alpha.value=this.alphaMotion.value.alpha)},n.prototype.dispose=function(){this.material.dispose()},n}(),ROTATE_Y_PI_MATRIX$1=new THREE__namespace.Matrix4().makeRotationAxis(new THREE__namespace.Vector3(0,1,0),Math.PI),PANO_TEXTURE_SCALE$2=new THREE__namespace.Vector3(-1,1,1),CubeRenderTargetPool=function(){function n(t){t===void 0&&(t=0),this.width=t,this.pool=[]}return Object.defineProperty(n.prototype,"size",{get:function(){return this.pool.length},enumerable:!1,configurable:!0}),n.prototype.create=function(){return new THREE__namespace.WebGLCubeRenderTarget(this.width,{stencilBuffer:!1,depthBuffer:!1})},n.prototype.pop=function(){var t=this.pool.pop();return t||this.create()},n.prototype.push=function(t){this.pool.indexOf(t)===-1&&this.pool.push(t)},n.prototype.clear=function(){for(var t=0,e=this.pool;t<e.length;t++){var r=e[t];r.dispose()}this.pool.length=0},n}(),PanoramaController=function(n){__extends(t,n);function t(e){var r=this,i,o,s,u,l=t.parseArgs(e);r=n.call(this,l)||this,r.TILED_CUBE_TEXTURE_LEVEL=2,r.mode="Panorama",r.tileLevel=0,r.initAnimationed=!1,r.maxAccessibleDistance=l.maxAccessibleDistance,r.panoTapTriggerRadius=l.panoTapTriggerRadius,r.panoCircleMeshCreator=l.panoCircleMeshCreator,r.tileLevelForFov=l.tileLevelForFov,r.luminanceAdaptiveEffectEnable=l.luminanceAdaptiveEffectEnable,r.colorCubeRenderTargetPool=new CubeRenderTargetPool,r.luminanceCubeRenderTargetPool=new CubeRenderTargetPool;var d=r.models.getMaterial()||{},c=d.pano0,f=d.pano1;c&&(f==null?void 0:f.map)!==c.map&&(r.models.setMaterial({pano0:f}),c.map.dispose(),c.map instanceof TileCubeTextureTarget&&c.map.cubeRenderTarget&&r.colorCubeRenderTargetPool.push(c.map.cubeRenderTarget),c.luminanceMap&&(c.luminanceMap.dispose(),c.luminanceMap instanceof TileCubeTextureTarget&&c.luminanceMap.cubeRenderTarget&&r.luminanceCubeRenderTargetPool.push(c.luminanceMap.cubeRenderTarget)));for(var h=r.colorCubeRenderTargetPool.size;h<2;h++){var v=Math.max(1024*r.TILED_CUBE_TEXTURE_LEVEL,512),A=r.colorCubeRenderTargetPool.create();A.setSize(v,v),renderCubeTextureToCubeRenderTarget(null,A,r.renderer),r.colorCubeRenderTargetPool.push(A)}r.panoMeshes={},r.updatePanoMeshes(),r.locationMotion=new Motion({count:0,distance:r.camera.pose.distance}),r.modelAlphaMotion=new Motion({modelAlpha:(o=(i=r.models.getMaterial())===null||i===void 0?void 0:i.modelAlpha)!==null&&o!==void 0?o:0}),r.perspToOrthoMotion=new Motion({perspToOrtho:r.camera.perspToOrtho.x}),r.panoResources={},r.panoResources[r.locationMotion.keyframes[0].key=r.locationMotion.keyframes[1].key=createUuid()]={panoId:panoStringify(r.currentPano),panoPicture:(u=(s=r.models.getMaterial())===null||s===void 0?void 0:s.pano1)!==null&&u!==void 0?u:null,position:r.camera.pose.offset.clone(),effect:"fly"};var m=r.works.getResolvedObserver(r.currentPano);return r.textureLoader=new TextureLoader,r.tiling=new Tiling(m?getFetcher(m.work):internalFetcher,r.TILED_CUBE_TEXTURE_LEVEL+1,r.imageOptions),r.scene.add(r.tiling.object),r.panoVideo=new PanoVideo,r.scene.add(r.panoVideo.object),r}return t.parseArgs=function(e){var r,i,o,s,u;if(e instanceof t)return e;var l=n.parseArgs.call(this,e);return __assign(__assign({},l),{maxAccessibleDistance:(r=e.maxAccessibleDistance)!==null&&r!==void 0?r:5,panoTapTriggerRadius:(i=e.panoTapTriggerRadius)!==null&&i!==void 0?i:.5,panoCircleMeshCreator:(o=e.panoCircleMeshCreator)!==null&&o!==void 0?o:function(d){return new PanoCircleMesh},tileLevelForFov:(s=e.tileLevelForFov)!==null&&s!==void 0?s:function(d,c){var f=function(y){return y/Math.PI*180},h=function(y){return y/180*Math.PI},v=c.height/2/Math.tan(h(d/2)),A=c.width>c.height?d:f(Math.atan(Math.tan(h(d/2))*(c.width/c.height))*2),m=v*(Math.tan(h(A/2))-Math.tan(h(A/2-1)));return m>60?4:m>30?3:m>18?2:m>12?1:0},luminanceAdaptiveEffectEnable:(u=e.luminanceAdaptiveEffectEnable)!==null&&u!==void 0?u:!0})},t.initAnimationEndState=function(e){var r=this.parseArgs(e),i=n.initAnimationEndState.call(this,r);return __assign(__assign({},i),{mode:"Panorama"})},t.prototype.destroy=function(){var e,r;if(n.prototype.destroy.call(this),this.scene.remove(this.tiling.object),this.tiling.dispose(),this.locationMotion.dispose(),this.colorCubeRenderTargetPool.clear(),this.luminanceCubeRenderTargetPool.clear(),delete this.pendingTextureTask,this.panoMeshes)for(var i=Object.keys(this.panoMeshes),o=0,s=i;o<s.length;o++){var u=s[o],l=this.panoMeshes[u];this.helper.remove(l),l.dispose(),delete this.panoMeshes[u]}var d=this.videoTexture.image;d.pause(),d.oncanplay=function(){},d.ontimeupdate=function(){},this.scene.remove(this.panoVideo.object),this.panoVideo.setMaterial(null),this.panoVideo.dispose();for(var c=(e=this.models.getMaterial())!==null&&e!==void 0?e:{},f=c.pano0,h=c.pano1,v=0,A=Object.keys(this.panoResources);v<A.length;v++){var m=A[v],y=this.panoResources[m];if(y.panoPicture){var p=y.panoPicture.map;p&&p!==(f==null?void 0:f.map)&&p!==(h==null?void 0:h.map)&&(p.dispose(),(r=y.panoPicture.luminanceMap)===null||r===void 0||r.dispose(),y.panoPicture=null)}delete this.panoResources[m]}this.luminanceAdaptiveEffect&&(this.luminanceAdaptiveEffect.dispose(),delete this.luminanceAdaptiveEffect)},t.prototype.isReady=function(){return this.locationMotion.ended!==!0?!1:n.prototype.isReady.call(this)},t.prototype.isTileReady=function(){var e,r,i,o=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[this.locationMotion.keyframes.length-1]),s=((e=o.panoPicture)===null||e===void 0?void 0:e.map)instanceof TileCubeTextureTarget&&(i=(r=o.panoPicture)===null||r===void 0?void 0:r.map.tilePending)!==null&&i!==void 0?i:0,u=this.tiling.pedding;return this.initAnimationed&&s<=0&&u<=0},t.prototype.updateWork=function(e,r,i,o){var s=this;this.userAction=o,this.works=e;var u=t.initAnimationEndState(__assign(__assign({},this),{initial:{currentState:__assign(__assign({},this.currentPano),this.camera.pose),duration:i,state:r,userAction:o}})),l={workCode:u.workCode,panoIndex:u.panoIndex},d=this.works.getWork(l.workCode);return this.tiling.setFetcher(d?getFetcher(d):internalFetcher),this.tiling.cleanup(),this.initAnimationed=!1,this.hideIntersectMesh(),this.updatePanoMeshes(),this.moveToPano(l,{effect:"fade",duration:i,longitude:r.longitude,latitude:r.latitude,fov:r.fov,moveEndCallback:function(){s.initAnimationed=!0},moveCancelCallback:function(){s.initAnimationed=!0}},o),!0},t.prototype.updateModel=function(e){this.models=e,this.updatePanoMeshes()},t.prototype.updateTime=function(e,r){var i=this,o,s,u,l,d,c,f,h,v,A;if(!this.destroyed){var m={},y={},p=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),m.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);var T=this.locationMotion.getKeyFrameSegment(e),_=T[0],w=T[1],x=this.panoResourceFromLocationMotionKeyframe(_),M=this.panoResourceFromLocationMotionKeyframe(w),R=new THREE__namespace.Vector3().copy(x.position),I=new THREE__namespace.Vector3().copy(M.position),S=this.locationMotion.value.count-w.value.count+1;m.progress=S,M.panoPicture&&(S<1?x.panoPicture&&(m.pano0=x.panoPicture):m.pano0=M.panoPicture,m.pano1=M.panoPicture),b=m.useBlackTransition=M.effect==="instant"||M.effect==="montage",(M.effect==="fade"||M.effect==="montage")&&(m.pano0&&x.panoPicture&&(m.pano0={map:m.pano0.map,luminanceMap:m.pano0.luminanceMap,matrix:x.panoPicture.matrix.clone().setPosition(M.position)}),R.copy(I)),y.distance=this.locationMotion.value.distance,y.offset=new THREE__namespace.Vector3(R.x+(I.x-R.x)*S,R.y+(I.y-R.y)*S,R.z+(I.z-R.z)*S);for(var B=[],F=[],O=0,H=this.locationMotion.keyframes;O<H.length;O++){var k=H[O],N=k.key,q=k.progress;N!==void 0&&(B.push(N),q>=this.locationMotion.progress&&F.push(N))}for(var V=0,D=Object.keys(this.panoResources);V<D.length;V++){var K=D[V];if(!(F.indexOf(K)>=0)){var z=this.panoResources[K];if(z.panoPicture){var G=z.panoPicture.map,W=z.panoPicture.luminanceMap;if(G){if(G===((o=m.pano0)===null||o===void 0?void 0:o.map)||G===((s=m.pano1)===null||s===void 0?void 0:s.map))continue;G instanceof TileCubeTextureTarget&&G.cubeRenderTarget&&this.colorCubeRenderTargetPool.push(G.cubeRenderTarget),G.dispose(),W&&(W instanceof TileCubeTextureTarget&&W.cubeRenderTarget&&this.luminanceCubeRenderTargetPool.push(W.cubeRenderTarget),W.dispose()),z.panoPicture=null}}B.indexOf(K)>=0||delete this.panoResources[K]}}this.currentPano=panoParse(M.panoId),this.emit("pano.moving",createEvent("pano.moving",{userAction:this.userAction,prevPano:panoParse(p.panoId),state:__assign(__assign(__assign(__assign({},panoParse(g.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),y),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(m)===!1&&(!((u=m.pano0)===null||u===void 0)&&u.map&&m.pano0.map instanceof TileCubeTextureTarget&&!m.pano0.map.cubeRenderTarget&&(m.pano0.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((l=m.pano0)===null||l===void 0)&&l.luminanceMap&&m.pano0.luminanceMap instanceof TileCubeTextureTarget&&!m.pano0.luminanceMap.cubeRenderTarget&&(m.pano0.luminanceMap.cubeRenderTarget=this.luminanceCubeRenderTargetPool.pop()),!((d=m.pano1)===null||d===void 0)&&d.map&&m.pano1.map instanceof TileCubeTextureTarget&&!m.pano1.map.cubeRenderTarget&&(m.pano1.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((c=m.pano1)===null||c===void 0)&&c.luminanceMap&&m.pano1.luminanceMap instanceof TileCubeTextureTarget&&!m.pano1.luminanceMap.cubeRenderTarget&&(m.pano1.luminanceMap.cubeRenderTarget=this.luminanceCubeRenderTargetPool.pop()),this.models.setMaterial(m)),isEmptyObject(y)===!1&&this.setCamera(y);var Q=this.works.getResolvedObserver(this.currentPano),X=this.locationMotion.ended?this.getForwardObserverOrNot():null;if(this.camera.pose.distance>.1||b){if(Q)for(var ee=0,J=Object.keys(this.panoMeshes);ee<J.length;ee++){var Z=J[ee],te=this.panoMeshes[Z];te.setOpacity(0),te.setCurrent(!1),te.updateTime&&te.updateTime(e,r)}}else if(Q){var ae=arrayMin(Q.visibleIds,function(le){var ue=i.works.getResolvedObserver(le);return ue?Q.standingPosition.distanceTo(ue.standingPosition):1/0},!0),re=ae[1];re=clamp(re,2.5,1/0);for(var ie=Q.visibleIds.concat(panoStringify(this.currentPano)),de=this.camera.getDirection(new THREE__namespace.Vector3),se=0,pe=Object.keys(this.panoMeshes);se<pe.length;se++){var Z=pe[se],te=this.panoMeshes[Z],$=this.works.getResolvedObserver(Z);if(ie.indexOf(Z)===-1)te.setCurrent(!1),te.setOpacity(0);else if(!$)te.setCurrent(!1),te.setOpacity(0);else if(!$.loadable&&!$.active)te.setCurrent(!1),te.setOpacity(0);else{var oe=te.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);te.setCurrent(!te.loading&&te.progress===0&&X!==null&&X.panoId===Z),te.setOpacity(oe<.01?0:clamp(re/oe*1.2,.4,.85));var j=this.camera.position.clone().setY(te.position.y),ve=new THREE__namespace.Vector3().copy(te.position).sub(j).normalize();if(Z===panoStringify(this.currentPano)){var me=clamp((.5-j.distanceTo(te.position))/.5,0,1);ve.multiplyScalar(1-me).add(de.clone().multiplyScalar(me))}ve.length()>0&&te.quaternion.setFromEuler(new THREE__namespace.Euler(0,Math.atan2(ve.x,ve.z),0))}te.updateTime&&te.updateTime(e,r)}}var Me=this.tileLevel=function(){if(i.tileLevelForFov===!1)return 0;var le=i.renderer.getDrawingBufferSize(new THREE__namespace.Vector2);le.width*=i.scissor.width,le.height*=i.scissor.height;var ue=g.panoId,Oe=i.works.getResolvedObserver(ue),fe=i.imageOptions.size;if(typeof fe>"u"&&Oe){var Se=Oe.images.up.match(/\/cube_(\d+)\//);Se&&(fe=Number(Se[1]))}typeof fe>"u"&&(fe=2048);var ye=0;fe>=1024&&(ye=1),fe>=2048&&(ye=2),fe>=4096&&(ye=3),fe>=8192&&(ye=4);var ke=i.tileLevelForFov(i.camera.fov,le);return ke>ye?ke:0}(),Re=function(){var le=i.camera.quaternion.clone(),ue=i.works.getResolvedObserver(g.panoId),Oe=ue??Q;Oe&&le.premultiply(Oe.quaternion.clone().inverse());var fe=new THREE__namespace.Matrix4().makeRotationFromQuaternion(le),Se=new THREE__namespace.Matrix4().getInverse(fe),ye=new THREE__namespace.Frustum().setFromProjectionMatrix(new THREE__namespace.Matrix4().multiplyMatrices(i.camera.projectionMatrix,Se));return ye}();g.panoId===panoStringify(this.currentPano)&&(((f=g.panoPicture)===null||f===void 0?void 0:f.map)instanceof TileCubeTextureTarget&&(g.panoPicture.map.update(Re,Me),g.panoPicture.map.needsRender===!0&&(g.panoPicture.map.needsRender=!1,this.needsRender=!0)),((h=g.panoPicture)===null||h===void 0?void 0:h.luminanceMap)instanceof TileCubeTextureTarget&&(g.panoPicture.luminanceMap.update(Re,Me),g.panoPicture.luminanceMap.needsRender===!0&&(g.panoPicture.luminanceMap.needsRender=!1,this.needsRender=!0)));{var ge=this.tiling.object.visible;if(this.initAnimationed){var we=g.panoId,Ae=this.works.getResolvedObserver(we);Ae?isSimilarVector3(this.camera.position,Ae.position)&&this.locationMotion.ended?(this.tiling.object.visible=!0,this.tiling.panoId!==we&&this.tiling.cleanup(),this.tiling.panoId=we,this.tiling.setResource((A=(v=Ae.images)===null||v===void 0?void 0:v.tiles)!==null&&A!==void 0?A:[],this.enableIOSEDR&&Ae.images.luminance?Ae.images.luminance:null),this.tiling.setFetcher(getFetcher(Ae.work)),this.tiling.setRotation(Ae.quaternion),this.tiling.setPosition(Ae.position),Me>this.TILED_CUBE_TEXTURE_LEVEL?this.tiling.update(Re,Me,e):this.tiling.update(Re,0,e)):this.tiling.object.visible=!1:this.tiling.object.visible=!1}else this.tiling.object.visible=!1;ge!==this.tiling.object.visible&&(this.tiling.object.needsRender=!0)}this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e)}},t.prototype.render=function(){var e=this.works.getResolvedObserver(this.currentPano);e&&e.video&&(this.needsRender=!0),n.prototype.render.call(this)},t.prototype.postProcessing=function(e,r){if(!this.destroyed&&r==="luminance")return this.luminanceAdaptiveEffect||(this.luminanceAdaptiveEffect=new LuminanceAdaptiveEffect(this.renderer,this.scene,this.camera,this.models),this.luminanceAdaptiveEffect.enable=this.luminanceAdaptiveEffectEnable),this.luminanceAdaptiveEffect.render(e)},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1],r=this.locationMotion.getKeyFrameSegment(now())[1],i=this.panoResourceFromLocationMotionKeyframe(r),o=this.works.getResolvedObserver(i.panoId);return{workCode:o?o.work.workCode:this.currentPano.workCode,panoIndex:o?o.panoIndex:this.currentPano.panoIndex,mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:o?o.position.clone():this.camera.position.clone(),distance:this.locationMotion.value.distance}},t.prototype.moveToPano=function(e,r,i){var o=this,s,u,l,d;this.userAction=i,this.stopMomentumMovement();var c=this.works.getResolvedObserver(e);if(!c)throw new Error("Invalid PanoId ".concat(JSON.stringify(e)));var f=this.imageOptions.size;if(typeof f>"u"&&c){var h=c.images.up.match(/\/cube_(\d+)\//);h&&(f=Number(h[1]))}typeof f>"u"&&(f=2048);var v=this.imageOptions.transform,A=__assign({key:"pano.".concat(c.panoId)},pick(this.imageOptions,["format","size","quality","sharpen","mappings"])),m=c.images,y=(u=(s=c.images.tiles)===null||s===void 0?void 0:s.filter(function(O){return O.size>f}))!==null&&u!==void 0?u:null,p=v,g={key:"pano_luminance.".concat(c.panoId),size:A.size?A.size/2:1024},b=this.enableIOSEDR&&c.images.luminance?c.images.luminance:null,T=function(){if(!c.images.tiles||!b)return null;var O=b.up.match(/\/cube_(\d+)\//),H=O?Number(O[1]):!1;return H===!1?null:y==null?void 0:y.map(function(k){return{level:k.level,size:H,back:b.back,front:b.front,left:b.left,right:b.right,up:b.up,down:b.down}})}(),_="pano:"+jsonHash([m,A,v]);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===_)return;var w=this.pendingTextureTask.panoId;(l=this.panoMeshes[w])===null||l===void 0||l.setProgress(0),this.emit("pano.texture.abort",createEvent("pano.texture.abort",{error:null,progress:0,meta:null,pano:c.pano})),this.pendingTextureTask.onError(new Error("texture aborted"))}var x="move-to-pano-"+c.panoId;this.pending.add(x);var M=this.models.getMaterial()||{},R=M.pano0,I=M.pano1,S;if(R&&R.map.name===_&&R.luminanceMap!==null===this.enableIOSEDR?S=R:(I==null?void 0:I.map.name)===_&&I.luminanceMap!==null===this.enableIOSEDR&&(S=I),S){var B={panoId:c.panoId,effect:(d=r.effect)!==null&&d!==void 0?d:"fly",panoPicture:{map:S.map,luminanceMap:S.luminanceMap,matrix:new THREE__namespace.Matrix4().compose(c.position,c.quaternion,PANO_TEXTURE_SCALE$2)},position:c.position.clone()};AnimationFrameLoop.shared.add(function(){o.pending.delete(x),o.doMoveToPano(c.pano,B,r)},!0,1);return}this.pendingTextureTask={panoId:c.panoId,hash:_,onLoad:function(O,H){var k,N;if(o.pending.delete(x),o.destroyed)O.body.dispose();else{O.body.name=_;var q={panoId:c.panoId,effect:(k=r.effect)!==null&&k!==void 0?k:"fly",panoPicture:{map:O.body,luminanceMap:(N=H==null?void 0:H.body)!==null&&N!==void 0?N:null,matrix:new THREE__namespace.Matrix4().compose(c.position,c.quaternion,PANO_TEXTURE_SCALE$2)},position:c.position.clone()};o.doMoveToPano(c.pano,q,r)}},onError:function(O){o.pending.delete(x);var H=__assign(__assign(__assign({},c.pano),{mode:o.mode}),clonePose(o.camera.pose));o.emit("pano.error",createEvent("pano.error",{error:O,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:H})),o.emit("pano.cancel",createEvent("pano.cancel",{error:O,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:H})),o.emit("error",O),r.moveCancelCallback&&r.moveCancelCallback()}};var F=this.panoMeshes[c.panoId];F&&F.tap&&F.tap(),Promise.all([this.tileLevelForFov&&y&&y.length?this.textureLoader.loadTiledCubeTexture(m,y,{tileMaxLevel:this.TILED_CUBE_TEXTURE_LEVEL,imageURL:{transform:v,options:A},format:THREE__namespace.RGBAFormat,viaAjax:!0,fetcher:getFetcher(c.work)},void 0,void 0,function(O){var H,k;o.emit("pano.texture.progress",createEvent("pano.texture.progress",{error:null,progress:O,meta:null,pano:c.pano})),((H=o.pendingTextureTask)===null||H===void 0?void 0:H.hash)===_&&((k=o.panoMeshes[c.panoId])===null||k===void 0||k.setProgress(O))},this.renderer):this.textureLoader.loadCubeTexture(m,{imageURL:{transform:v,options:A},format:THREE__namespace.RGBAFormat,viaAjax:!0,fetcher:getFetcher(c.work)},void 0,void 0,function(O){var H,k;o.emit("pano.texture.progress",createEvent("pano.texture.progress",{error:null,progress:O,meta:null,pano:c.pano})),((H=o.pendingTextureTask)===null||H===void 0?void 0:H.hash)===_&&((k=o.panoMeshes[c.panoId])===null||k===void 0||k.setProgress(O))},this.renderer),b?this.tileLevelForFov&&T&&T.length?this.textureLoader.loadTiledCubeTexture(b,T,{tileImageSize:256,tileMaxLevel:this.TILED_CUBE_TEXTURE_LEVEL,imageURL:{transform:p,options:g},fetcher:getFetcher(c.work)},void 0,void 0,void 0,this.renderer).catch(function(){return null}):this.textureLoader.loadCubeTexture(b,{imageURL:{transform:p,options:g},fetcher:getFetcher(c.work)},void 0,void 0,void 0,this.renderer).catch(function(){return null}):Promise.resolve(null)]).then(function(O){var H,k,N=O[0],q=O[1];((H=o.pendingTextureTask)===null||H===void 0?void 0:H.hash)===_?(o.pendingTextureTask.onLoad(N,q),(k=o.panoMeshes[c.panoId])===null||k===void 0||k.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.success",createEvent("pano.texture.success",{error:null,progress:1,meta:N.meta,pano:c.pano}))):(N.body.dispose(),q==null||q.body.dispose())}).catch(function(O){var H,k;((H=o.pendingTextureTask)===null||H===void 0?void 0:H.hash)===_&&(o.pendingTextureTask.onError(O),(k=o.panoMeshes[c.panoId])===null||k===void 0||k.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.error",createEvent("pano.texture.error",{error:O,progress:0,meta:null,pano:c.pano})),o.emit("error",O))}),this.emit("pano.texture.load",createEvent("pano.texture.load",{error:null,progress:0,meta:null,pano:c.pano}))},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 o=i.duration,s=i.userAction;e.userAction=s;var u=t.initAnimationEndState(e),l={workCode:u.workCode,panoIndex:u.panoIndex},d={modelAlpha:0},c={perspToOrtho:0},f=!1;e.moveToPano(l,{longitude:u.longitude,latitude:u.latitude,fov:u.fov,duration:o,moveStartCallback:function(h){f=!0,e.perspToOrthoMotion.set(c,o).catch(noop$1),e.modelAlphaMotion.setKeyframes([{progress:0,value:__assign({},e.modelAlphaMotion.value)},{progress:.6,value:__assign({},e.modelAlphaMotion.value)},{progress:1,value:d}],o).catch(noop$1),e.emit("initAnimation.start",createEvent("initAnimation.start",{state:h,userAction:e.userAction}))},moveEndCallback:function(h){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:h,userAction:e.userAction})),e.initAnimationed=!0,r()},moveCancelCallback:function(){var h=__assign(__assign(__assign({},l),{mode:e.mode}),clonePose(e.camera.pose));f===!1&&e.emit("initAnimation.start",createEvent("initAnimation.start",{state:h,userAction:e.userAction})),e.emit("initAnimation.end",createEvent("initAnimation.end",{state:h,userAction:e.userAction})),e.initAnimationed=!0,r()}},s)})},t.prototype.panoResourceFromLocationMotionKeyframe=function(e){return this.panoResources[e.key]},t.prototype.locationMotionKeyframesLength=function(e){for(var r=0,i=1;i<e.length;i++){var o=this.panoResourceFromLocationMotionKeyframe(e[i-1]).position,s=this.panoResourceFromLocationMotionKeyframe(e[i]).position,u=o.distanceTo(s)*(e[i].value.count-e[i-1].value.count);r+=u}return r},t.prototype.updatePanoMeshes=function(){for(var e=this,r={},i=Object.keys(this.panoMeshes),o=0,s=i;o<s.length;o++){var u=s[o],l=this.panoMeshes[u];r[u]=l,delete this.panoMeshes[u]}for(var d=1,c={},f=function(w){var x=arrayMin(w.accessibleIds,function(R){var I=e.works.getResolvedObserver(R);if(!I)return 1/0;var S=I.standingPosition.distanceTo(w.standingPosition);return clamp(S,1,1/0)},!0),M=x[1];c[w.panoId]===void 0&&(c[w.panoId]=M)},h=0,v=this.works.resolvedObservers;h<v.length;h++){var A=v[h];f(A)}var m=Object.keys(c).map(function(w){return c[w]});if(m.length){var y=m.reduce(function(w,x){return w+x},0)/m.length;d=clamp(y*.6,1,3)}for(var p=0,g=this.works.resolvedObservers;p<g.length;p++){var A=g[p],l=void 0;r[A.panoId]?(l=r[A.panoId],l.loading===!0&&A.loadable===!1&&l.setLoading(!1),delete r[A.panoId]):(l=this.panoCircleMeshCreator(A.pano),l.name="PanoCircleMesh_"+A.panoId,this.helper.add(l)),l.scale.set(d,1,d),l.position.copy(A.standingPosition),this.panoMeshes[A.panoId]=l}for(var b=0,T=Object.keys(r);b<T.length;b++){var _=T[b];this.helper.remove(r[_]),r[_].dispose(),delete r[_]}},t.prototype.doMoveToPano=function(e,r,i){var o=this,s,u,l,d;i===void 0&&(i={});var c=now(),f=createUuid();this.tiling.cleanup(),this.panoResources[f]=r;var h=1,v,A,m;if(this.locationMotion.ended){var y=this.locationMotion.getKeyFrameSegment(c);y[0];var p=y[1],g=this.locationMotion.value,b=((s=this.panoResourceFromLocationMotionKeyframe(p))!==null&&s!==void 0?s:this.camera).position,T=r.position;v=Math.max(b.distanceTo(T),h),A=[{key:p.key,progress:0,value:__assign(__assign({},g),{count:0})},{key:f,progress:1,value:{distance:0,count:1}}],m=0}else{var _=this.locationMotion.getKeyFrameSegment(c),w=_[0],p=_[1],g=this.locationMotion.value,x=this.panoResourceFromLocationMotionKeyframe(w).position,b=this.panoResourceFromLocationMotionKeyframe(p).position,T=r.position,M=p.value.count-g.count,R=Math.max(x.distanceTo(b),h)*M,I=Math.max(b.distanceTo(T),h);v=R+I,A=[{key:w.key,progress:0,value:__assign({},g)},{key:p.key,progress:R/v,value:p.value},{key:f,progress:1,value:{count:p.value.count+1,distance:0}}];var S=this.locationMotionKeyframesLength(this.locationMotion.keyframes),B=this.locationMotionKeyframesLength(A);S===0||S===0?m=0:m=this.locationMotion.getProgressVelocity(c)*S/B}var F=this.calculateMovingDuration(i.duration,i.effect==="fade"||i.effect==="montage"?0:v),O={longitude:i.longitude,latitude:i.latitude,fov:i.fov},H=__assign(__assign({},e),{mode:this.mode,longitude:(u=O.longitude)!==null&&u!==void 0?u:this.camera.pose.longitude,latitude:(l=O.latitude)!==null&&l!==void 0?l:this.camera.pose.latitude,fov:(d=O.fov)!==null&&d!==void 0?d:this.camera.pose.fov,offset:r.position.clone(),distance:this.camera.pose.distance}),k=this.currentPano;this.emit("pano.moveTo",createEvent("pano.moveTo",{options:i,prevPano:k,progress:0,state:H,userAction:this.userAction,error:null})),i.moveStartCallback&&i.moveStartCallback(H),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=noop$1,this.videoTexture.needsUpdate=!0),this.panoVideo.setMaterial(null),this.cameraMotion.set(O,F).catch(noop$1);var N=this.locationMotion.setKeyframes(A,F,m);N.then(function(){var q,V,D=__assign(__assign({},e),{mode:o.mode,longitude:o.camera.pose.longitude,latitude:o.camera.pose.latitude,fov:o.camera.pose.fov,offset:o.camera.pose.offset.clone(),distance:o.camera.pose.distance});o.emit("pano.arrived",createEvent("pano.arrived",{options:i,prevPano:k,progress:1,state:D,userAction:o.userAction,error:null})),i.moveEndCallback&&i.moveEndCallback(D);var K=o.works.getResolvedObserver(e);if(K&&K.video&&o.videoTexture&&o.videoTexture.image instanceof HTMLVideoElement){var z=ROTATE_Y_PI_MATRIX$1.clone().multiply((V=(q=o.models.getMaterial().pano1)===null||q===void 0?void 0:q.matrix)!==null&&V!==void 0?V:new THREE__namespace.Matrix4).multiply(K.video.matrix),G={map:o.videoTexture,size:K.video.size,matrix:z,alpha:1},W=createUuid(),Q=o.videoTexture.image;Q.setAttribute("uuid",W),canplayVideo().then(function(X){X&&K.video&&Q.getAttribute("uuid")===W&&(Q.oncanplay=function(){Q.oncanplay=noop$1,Q.play()},Q.ontimeupdate=function(){Q.currentTime>.5&&(Q.ontimeupdate=noop$1,o.panoVideo.setMaterial(G))},Q.src=K.video.source)}).catch(function(){Q.removeAttribute("uuid")})}},function(){o.emit("pano.cancel",createEvent("pano.cancel",{options:i,prevPano:k,progress:0,state:H,userAction:o.userAction,error:null})),i.moveCancelCallback&&i.moveCancelCallback()})},t.prototype.getForwardObserverOrNot=function(e){var r=this,i=this.works.getResolvedObserver(this.currentPano);if(!i)return null;var o=e??new THREE__namespace.Raycaster(this.camera.position.clone(),this.camera.getDirection(new THREE__namespace.Vector3));o.params.Points={threshold:.1};var s=i.standingPosition.clone();if(i.position.distanceTo(o.ray.origin)>1){var u=this.models.intersectRaycaster(new THREE__namespace.Raycaster(o.ray.origin,new THREE__namespace.Vector3(0,-1,0)))[0];u&&u.distance<=2?s.copy(u.point):s.copy(o.ray.origin).add(new THREE__namespace.Vector3(0,-1.5,0))}var l=this.models.intersectRaycaster(o)[0],d=l?l.point:o.ray.origin.clone().add(o.ray.direction.clone().normalize().multiplyScalar(3)),c=d.clone().sub(s).normalize();if(c.length()===0)return null;for(var f=i.accessibleIds.filter(function(_){if(_===panoStringify(r.currentPano))return!1;var w=r.works.getResolvedObserver(_);if(!w)return!1;var x=w.standingPosition.clone().project(r.camera);return Math.abs(x.z)>1||Math.abs(x.x)>1||Math.abs(x.y)>1?!1:w.loadable||w.active}),h=f.slice().sort(function(_,w){var x=r.works.getResolvedObserver(_).standingPosition.clone().distanceTo(s),M=r.works.getResolvedObserver(w).standingPosition.clone().distanceTo(s);return x-M}),v=0,A=[Math.PI/8,Math.PI/6,Math.PI/4,Math.PI/3];v<A.length;v++)for(var m=A[v],y=0,p=h;y<p.length;y++){var g=p[y],b=this.works.getResolvedObserver(g);if(b){var T=b.standingPosition.clone().sub(s);if(T&&T.length()!==0&&c.angleTo(T)<m)return b}}return null},t.prototype.onTapGesture=function(e){var r=this,i;if(this.userAction=e.userAction,this.stopMomentumMovement(),!!this.initAnimationed){if(!this.locationMotion.ended){var o=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[this.locationMotion.keyframes.length-1]);if(o.panoId!==panoStringify(this.currentPano))return}var s=e.center.raycaster,u=this.camera.getDirection(new THREE__namespace.Vector3).setY(0),l=null,d=this.works.getResolvedObserver(this.currentPano);if(d){var c=d.accessibleIds.filter(function(V){if(V===panoStringify(r.currentPano))return!1;var D=r.works.getResolvedObserver(V);return!D||D.position.distanceTo(r.camera.position)>r.maxAccessibleDistance?!1:D.loadable||D.active}),f=this.models.intersectRaycaster(s)[0];if(f){var h=arrayMin(c,function(V){var D=r.works.getResolvedObserver(V);if(!D)return 1/0;var K=D.standingPosition.clone();return K.distanceTo(f.point)},!0),v=h[0],A=h[1];v&&A<this.panoTapTriggerRadius&&(l=(i=this.works.getResolvedObserver(v))!==null&&i!==void 0?i:null)}l||(l=this.getForwardObserverOrNot(s));for(var m=0,y=this.locationMotion.keyframes;m<y.length;m++){var p=y[m],g=this.panoResourceFromLocationMotionKeyframe(p);if(!(p.progress<this.locationMotion.progress)&&l&&g.panoId===l.panoId){l=null;break}}if(!l)this.emit("gesture.tap",e),e.defaultPrevented||this.locationMotion.ended===!0&&this.cameraBounce();else{for(var b={},T=Math.PI/6,_=Math.PI/12,w=l.position.clone().setY(0).sub(d.position.clone().setY(0)).normalize(),x=[],M=[],R=[],I=0,S=l.accessibleIds;I<S.length;I++){var v=S[I],B=panoParse(v);if(!(panoEqual(B,this.currentPano)||panoEqual(B,l.pano))){var F=this.works.getResolvedObserver(v);if(F){var O=F.position.clone().sub(l.position).setY(0);w.angleTo(O)<T&&R.push(O)}}}var H=R.length>0?R:__spreadArray(__spreadArray([],x,!0),M,!0),k=H.slice().sort(function(V,D){return V.angleTo(w)-D.angleTo(w)})[0];k&&k.angleTo(u)>_&&(b.longitude=Math.atan2(-k.x,-k.z)),this.cameraMotion.value.latitude<-Math.PI/4&&(b.latitude=clamp(0,this.minLatitude,this.maxLatitude));var N=__assign({},e.state);if(N.workCode=l.pano.workCode,N.panoIndex=l.pano.panoIndex,b.longitude!==void 0&&(N.longitude=b.longitude),b.latitude!==void 0&&(N.latitude=b.latitude),b.fov!==void 0&&(N.fov=b.fov),N.distance=0,N.offset=l.position.clone(),e.state=N,this.emit("gesture.tap",e),!e.defaultPrevented){if(this.emit("pano.select",createEvent("pano.select",{prevPano:this.currentPano,state:N,userAction:e.userAction,options:b,progress:0,error:null})),l&&!l.active){var q=l.panoId;this.panoMeshes[q]&&(this.panoMeshes[q].setDisabled(!1),this.panoMeshes[q].setLoading(!0))}l&&l.active&&this.emit("pano.request",createEvent("pano.request",{userAction:e.userAction,prevPano:this.currentPano,progress:0,state:N,options:b,error:null}))}}}}},t}(PanoramaLikeController),DEG_TO_RAD=Math.PI/180,RAD_TO_DEG=180/Math.PI,MIN_TIMESTEP=.001,MAX_TIMESTEP=1,isIOS=function(){var n=typeof navigator<"u"&&/iPad|iPhone|iPod/.test(navigator.platform);return function(){return n}}(),isSafari=function(){var n=typeof navigator<"u"&&/^((?!chrome|android).)*safari/i.test(navigator.userAgent);return function(){return n}}(),isFirefoxAndroid=function(){var n=typeof navigator<"u"&&navigator.userAgent.indexOf("Firefox")!==-1&&navigator.userAgent.indexOf("Android")!==-1;return function(){return n}}(),getChromeVersion=function(){var n=typeof navigator<"u"?navigator.userAgent.match(/.*Chrome\/([0-9]+)/):null,t=n?parseInt(n[1],10):null;return function(){return t}}(),isChromeWithoutDeviceMotion=function(){var n=!1;if(getChromeVersion()===65){var t=typeof navigator<"u"?navigator.userAgent.match(/.*Chrome\/([0-9\.]*)/):null;if(t){var e=t[1].split(".");e[0],e[1];var r=e[2],i=e[3];n=parseInt(r,10)===3325&&parseInt(i,10)<148}}return function(){return n}}(),isSafariWithoutDeviceMotion=function(){var n=isIOS()&&isSafari()&&typeof navigator<"u"&&navigator.userAgent.indexOf("13_4")!==-1;return function(){return n}}(),isR7=function(){var n=typeof navigator<"u"&&navigator.userAgent.indexOf("R7 Build")!==-1;return function(){return n}}();function isLandscapeMode(){var n=typeof window<"u"&&(window.orientation==90||window.orientation==-90);return isR7()?!n:n}function isTimestampDeltaValid(n){return!(isNaN(n)||n<=MIN_TIMESTEP||n>MAX_TIMESTEP)}function getQuaternionAngle(n){if(n.w>1)return 0;var t=2*Math.acos(n.w);return t}var warnOnce=function(){var n={};return function(t,e){n[t]===void 0&&(console.warn("cardboard: "+e),n[t]=!0)}}();function getOriginFromUrl(n){var t,e=n.indexOf("://");e!==-1?t=e+3:t=0;var r=n.indexOf("/",t);return r===-1&&(r=n.length),n.substring(0,r)}function isInsideCrossOriginIFrame(){if(typeof window>"u"||typeof document>"u")return!1;var n=window.self!==window.top,t=getOriginFromUrl(document.referrer),e=getOriginFromUrl(window.location.href);return n&&t!==e}var updateEyeViewMatrices=function(){function n(r,i,o){var s=i?i[0]:0,u=i?i[1]:0,l=i?i[2]:0,d=i?i[3]:1,c=s+s,f=u+u,h=l+l,v=s*c,A=s*f,m=s*h,y=u*f,p=u*h,g=l*h,b=d*c,T=d*f,_=d*h;return r[0]=1-(y+g),r[1]=A+_,r[2]=m-T,r[3]=0,r[4]=A-_,r[5]=1-(v+g),r[6]=p+b,r[7]=0,r[8]=m+T,r[9]=p-b,r[10]=1-(v+y),r[11]=0,r[12]=o?o[0]:0,r[13]=o?o[1]:0,r[14]=o?o[2]:0,r[15]=1,r}function t(r,i,o){var s=o[0],u=o[1],l=o[2],d,c,f,h,v,A,m,y,p,g,b,T;return i===r?(r[12]=i[0]*s+i[4]*u+i[8]*l+i[12],r[13]=i[1]*s+i[5]*u+i[9]*l+i[13],r[14]=i[2]*s+i[6]*u+i[10]*l+i[14],r[15]=i[3]*s+i[7]*u+i[11]*l+i[15]):(d=i[0],c=i[1],f=i[2],h=i[3],v=i[4],A=i[5],m=i[6],y=i[7],p=i[8],g=i[9],b=i[10],T=i[11],r[0]=d,r[1]=c,r[2]=f,r[3]=h,r[4]=v,r[5]=A,r[6]=m,r[7]=y,r[8]=p,r[9]=g,r[10]=b,r[11]=T,r[12]=d*s+v*u+p*l+i[12],r[13]=c*s+A*u+g*l+i[13],r[14]=f*s+m*u+b*l+i[14],r[15]=h*s+y*u+T*l+i[15]),r}function e(r,i){var o=i[0],s=i[1],u=i[2],l=i[3],d=i[4],c=i[5],f=i[6],h=i[7],v=i[8],A=i[9],m=i[10],y=i[11],p=i[12],g=i[13],b=i[14],T=i[15],_=o*c-s*d,w=o*f-u*d,x=o*h-l*d,M=s*f-u*c,R=s*h-l*c,I=u*h-l*f,S=v*g-A*p,B=v*b-m*p,F=v*T-y*p,O=A*b-m*g,H=A*T-y*g,k=m*T-y*b,N=_*k-w*H+x*O+M*F-R*B+I*S;return N?(N=1/N,r[0]=(c*k-f*H+h*O)*N,r[1]=(u*H-s*k-l*O)*N,r[2]=(g*I-b*R+T*M)*N,r[3]=(m*R-A*I-y*M)*N,r[4]=(f*F-d*k-h*B)*N,r[5]=(o*k-u*F+l*B)*N,r[6]=(b*x-p*I-T*w)*N,r[7]=(v*I-m*x+y*w)*N,r[8]=(d*H-c*F+h*S)*N,r[9]=(s*F-o*H-l*S)*N,r[10]=(p*R-g*x+T*_)*N,r[11]=(A*x-v*R-y*_)*N,r[12]=(c*B-d*O-f*S)*N,r[13]=(o*O-s*B+u*S)*N,r[14]=(g*w-p*M-b*_)*N,r[15]=(v*M-A*w+m*_)*N,r):null}return function(r,i,o){n(r,i),o&&t(r,r,o),e(r,r)}}(),SensorSample=function(){function n(t,e){t===void 0&&(t=new THREE__namespace.Vector3),e===void 0&&(e=0),this.sample=t,this.timestampS=e}return n.prototype.set=function(t,e){this.sample=t,this.timestampS=e},n.prototype.copy=function(t){this.set(t.sample,t.timestampS)},n}(),ComplementaryFilter=function(){function n(t,e){this.kFilter=t,this.isDebug=e,this.currentAccelMeasurement=new SensorSample,this.currentGyroMeasurement=new SensorSample,this.previousGyroMeasurement=new SensorSample,isIOS()?this.filterQ=new THREE__namespace.Quaternion(-1,0,0,1):this.filterQ=new THREE__namespace.Quaternion(1,0,0,1),this.previousFilterQ=new THREE__namespace.Quaternion,this.previousFilterQ.copy(this.filterQ),this.accelQ=new THREE__namespace.Quaternion,this.isOrientationInitialized=!1,this.estimatedGravity=new THREE__namespace.Vector3,this.measuredGravity=new THREE__namespace.Vector3,this.gyroIntegralQ=new THREE__namespace.Quaternion}return n.prototype.addAccelMeasurement=function(t,e){this.currentAccelMeasurement.set(t,e)},n.prototype.addGyroMeasurement=function(t,e){this.currentGyroMeasurement.set(t,e);var r=e-this.previousGyroMeasurement.timestampS;isTimestampDeltaValid(r)&&this.run_(),this.previousGyroMeasurement.copy(this.currentGyroMeasurement)},n.prototype.getOrientation=function(){return this.filterQ},n.prototype.run_=function(){if(!this.isOrientationInitialized){this.accelQ=this.accelToQuaternion_(this.currentAccelMeasurement.sample),this.previousFilterQ.copy(this.accelQ),this.isOrientationInitialized=!0;return}var t=this.currentGyroMeasurement.timestampS-this.previousGyroMeasurement.timestampS,e=this.gyroToQuaternionDelta_(this.currentGyroMeasurement.sample,t);this.gyroIntegralQ.multiply(e),this.filterQ.copy(this.previousFilterQ),this.filterQ.multiply(e);var r=new THREE__namespace.Quaternion;r.copy(this.filterQ),r.inverse(),this.estimatedGravity.set(0,0,-1),this.estimatedGravity.applyQuaternion(r),this.estimatedGravity.normalize(),this.measuredGravity.copy(this.currentAccelMeasurement.sample),this.measuredGravity.normalize();var i=new THREE__namespace.Quaternion;i.setFromUnitVectors(this.estimatedGravity,this.measuredGravity),i.inverse(),this.isDebug&&console.log("Delta: %d deg, G_est: (%s, %s, %s), G_meas: (%s, %s, %s)",RAD_TO_DEG*getQuaternionAngle(i),this.estimatedGravity.x.toFixed(1),this.estimatedGravity.y.toFixed(1),this.estimatedGravity.z.toFixed(1),this.measuredGravity.x.toFixed(1),this.measuredGravity.y.toFixed(1),this.measuredGravity.z.toFixed(1));var o=new THREE__namespace.Quaternion;o.copy(this.filterQ),o.multiply(i),this.filterQ.slerp(o,1-this.kFilter),this.previousFilterQ.copy(this.filterQ)},n.prototype.accelToQuaternion_=function(t){var e=new THREE__namespace.Vector3;e.copy(t),e.normalize();var r=new THREE__namespace.Quaternion;return r.setFromUnitVectors(new THREE__namespace.Vector3(0,0,-1),e),r.inverse(),r},n.prototype.gyroToQuaternionDelta_=function(t,e){var r=new THREE__namespace.Quaternion,i=new THREE__namespace.Vector3;return i.copy(t),i.normalize(),r.setFromAxisAngle(i,t.length()*e),r},n}(),PosePredictor=function(){function n(t,e){this.predictionTimeS=t,this.isDebug=e,this.previousQ=new THREE__namespace.Quaternion,this.previousTimestampS=null,this.deltaQ=new THREE__namespace.Quaternion,this.outQ=new THREE__namespace.Quaternion}return n.prototype.getPrediction=function(t,e,r){if(!this.previousTimestampS)return this.previousQ.copy(t),this.previousTimestampS=r,t;var i=new THREE__namespace.Vector3;i.copy(e),i.normalize();var o=e.length();if(o<DEG_TO_RAD*20)return this.isDebug&&console.log("Moving slowly, at %s deg/s: no prediction",(RAD_TO_DEG*o).toFixed(1)),this.outQ.copy(t),this.previousQ.copy(t),this.outQ;var s=o*this.predictionTimeS;return this.deltaQ.setFromAxisAngle(i,s),this.outQ.copy(this.previousQ),this.outQ.multiply(this.deltaQ),this.previousQ.copy(t),this.previousTimestampS=r,this.outQ},n}(),Distortion=function(){function n(t){this.coefficients=t}return n.prototype.distortInverse=function(t){for(var e=0,r=1,i=t-this.distort(e);Math.abs(r-e)>1e-4;){var o=t-this.distort(r),s=r-o*((r-e)/(o-i));e=r,r=s,i=o}return r},n.prototype.distort=function(t){for(var e=t*t,r=0,i=0;i<this.coefficients.length;i++)r=e*(r+this.coefficients[i]);return(r+1)*t},n}(),Pose=function(){function n(){this.angularAcceleration=null,this.angularVelocity=null,this.linearAcceleration=null,this.linearVelocity=null,this.orientation=null,this.position=null}return n}(),FieldOfView=function(){function n(){this.leftDegrees=0,this.rightDegrees=0,this.upDegrees=0,this.downDegrees=0}return n}(),Sensor=function(){function n(t,e,r,i){this.viewer={id:"CardboardV1",label:"Cardboard I/O 2014",fov:40,interLensDistance:.06,baselineLensDistance:.035,screenLensDistance:.042,distortionCoefficients:[.441,.156],inverseCoefficients:[-.4410035,.42756155,-.4804439,.5460139,-.58821183,.5733938,-.48303202,.33299083,-.17573841,.0651772,-.01488963,.001559834]},this.device={widthMeters:.11,heightMeters:.062,bevelMeters:.004},this.depthNear=.01,this.depthFar=1e4,this.yawOnly=r,this.accelerometer=new THREE__namespace.Vector3,this.gyroscope=new THREE__namespace.Vector3,this.filter=new ComplementaryFilter(t,i),this.posePredictor=new PosePredictor(e,i),this.isFirefoxAndroid=isFirefoxAndroid(),this.isIOS=isIOS();var o=getChromeVersion();this.isDeviceMotionInRadians=!this.isIOS&&o!==null&&o<66,this.isWithoutDeviceMotion=isChromeWithoutDeviceMotion()||isSafariWithoutDeviceMotion(),this.filterToWorldQ=new THREE__namespace.Quaternion,isIOS()?this.filterToWorldQ.setFromAxisAngle(new THREE__namespace.Vector3(1,0,0),Math.PI/2):this.filterToWorldQ.setFromAxisAngle(new THREE__namespace.Vector3(1,0,0),-Math.PI/2),this.inverseWorldToScreenQ=new THREE__namespace.Quaternion,this.worldToScreenQ=new THREE__namespace.Quaternion,this.originalPoseAdjustQ=new THREE__namespace.Quaternion;var s=typeof window<"u"?-window.orientation*Math.PI/180:0;this.originalPoseAdjustQ.setFromAxisAngle(new THREE__namespace.Vector3(0,0,1),s),this.setScreenTransform_(),isLandscapeMode()&&this.filterToWorldQ.multiply(this.inverseWorldToScreenQ),this.resetQ=new THREE__namespace.Quaternion,this.orientationOut_=new Float32Array(4),this.previousTimestampS=Date.now()}return n.prototype.getPosition=function(){return null},n.prototype.getOrientation=function(){var t;if(this.isWithoutDeviceMotion&&this._deviceOrientationQ){this.deviceOrientationFixQ=this.deviceOrientationFixQ||function(){var o=new THREE__namespace.Quaternion().setFromAxisAngle(new THREE__namespace.Vector3(0,0,-1),0),s=new THREE__namespace.Quaternion;return typeof window<"u"&&window.orientation===-90?s.setFromAxisAngle(new THREE__namespace.Vector3(0,1,0),Math.PI/-2):s.setFromAxisAngle(new THREE__namespace.Vector3(0,1,0),Math.PI/2),o.multiply(s)}(),this.deviceOrientationFilterToWorldQ=this.deviceOrientationFilterToWorldQ||function(){var o=new THREE__namespace.Quaternion;return o.setFromAxisAngle(new THREE__namespace.Vector3(1,0,0),-Math.PI/2),o}(),t=this._deviceOrientationQ;var e=new THREE__namespace.Quaternion;return e.copy(t),e.multiply(this.deviceOrientationFilterToWorldQ),e.multiply(this.resetQ),e.multiply(this.worldToScreenQ),e.multiplyQuaternions(this.deviceOrientationFixQ,e),this.yawOnly&&(e.x=0,e.z=0,e.normalize()),this.orientationOut_[0]=e.x,this.orientationOut_[1]=e.y,this.orientationOut_[2]=e.z,this.orientationOut_[3]=e.w,this.orientationOut_}else{var r=this.filter.getOrientation();t=this.posePredictor.getPrediction(r,this.gyroscope,this.previousTimestampS)}var i=new THREE__namespace.Quaternion;return i.copy(this.filterToWorldQ),i.multiply(this.resetQ),i.multiply(t),i.multiply(this.worldToScreenQ),this.yawOnly&&(i.x=0,i.z=0,i.normalize()),this.orientationOut_[0]=i.x,this.orientationOut_[1]=i.y,this.orientationOut_[2]=i.z,this.orientationOut_[3]=i.w,this.orientationOut_},n.prototype.getPose=function(){var t=new Pose;return t.orientation=this.getOrientation(),t},n.prototype.resetPose=function(){this.resetQ.copy(this.filter.getOrientation()),this.resetQ.x=0,this.resetQ.y=0,this.resetQ.z*=-1,this.resetQ.normalize(),isLandscapeMode()&&this.resetQ.multiply(this.inverseWorldToScreenQ),this.resetQ.multiply(this.originalPoseAdjustQ)},n.prototype.getFrameData=function(t){var e=this.getOrientation(),r=this.getEyeOffset(),i=this.getEyeProjectionMatrix();return t.pose.angularAcceleration=null,t.pose.angularVelocity=null,t.pose.linearAcceleration=null,t.pose.linearVelocity=null,t.pose.orientation=e,t.pose.position=null,t.timestamp=this.previousTimestampS,t.leftProjectionMatrix.set(i.left),t.rightProjectionMatrix.set(i.right),updateEyeViewMatrices(t.leftViewMatrix,e,r.left),updateEyeViewMatrices(t.rightViewMatrix,e,r.right),t},n.prototype.start=function(){if(typeof window>"u")return function(){};var t=this.onDeviceMotion_.bind(this),e=this.onOrientationChange_.bind(this),r=this.onMessage_.bind(this),i=this.onDeviceOrientation_.bind(this);return isIOS()&&isInsideCrossOriginIFrame()&&window.addEventListener("message",r),window.addEventListener("orientationchange",e),this.isWithoutDeviceMotion?window.addEventListener("deviceorientation",i):window.addEventListener("devicemotion",t),function(){window.removeEventListener("devicemotion",t),window.removeEventListener("deviceorientation",e),window.removeEventListener("orientationchange",e),window.removeEventListener("message",r)}},n.prototype.getEyeOffset=function(){return{left:[-this.viewer.interLensDistance*.5,0,0],right:[this.viewer.interLensDistance*.5,0,0]}},n.prototype.getEyeProjectionMatrix=function(){var t=this.getEyeFieldOfView(),e=this.depthNear,r=this.depthFar,i={left:[],right:[]};{var o=t.left.upDegrees*DEG_TO_RAD,s=t.left.downDegrees*DEG_TO_RAD,u=t.left.leftDegrees*DEG_TO_RAD,l=t.left.rightDegrees*DEG_TO_RAD,d=2/(u+l),c=2/(o+s);i.left[0]=d,i.left[1]=0,i.left[2]=0,i.left[3]=0,i.left[4]=0,i.left[5]=c,i.left[6]=0,i.left[7]=0,i.left[8]=-((u-l)*d*.5),i.left[9]=(o-s)*c*.5,i.left[10]=r/(e-r),i.left[11]=-1,i.left[12]=0,i.left[13]=0,i.left[14]=r*e/(e-r),i.left[15]=0}{var o=t.right.upDegrees*DEG_TO_RAD,s=t.right.downDegrees*DEG_TO_RAD,u=t.right.leftDegrees*DEG_TO_RAD,l=t.right.rightDegrees*DEG_TO_RAD,d=2/(u+l),c=2/(o+s);i.right[0]=d,i.right[1]=0,i.right[2]=0,i.right[3]=0,i.right[4]=0,i.right[5]=c,i.right[6]=0,i.right[7]=0,i.right[8]=-((u-l)*d*.5),i.right[9]=(o-s)*c*.5,i.right[10]=r/(e-r),i.right[11]=-1,i.right[12]=0,i.right[13]=0,i.right[14]=r*e/(e-r),i.right[15]=0}return i},n.prototype.getEyeFieldOfView=function(){var t=this.viewer,e=this.device,r=new Distortion(t.distortionCoefficients),i=t.screenLensDistance,o=(e.widthMeters-t.interLensDistance)/2,s=t.interLensDistance/2,u=t.baselineLensDistance-e.bevelMeters,l=e.heightMeters-u,d=RAD_TO_DEG*Math.atan(r.distort(o/i)),c=RAD_TO_DEG*Math.atan(r.distort(s/i)),f=RAD_TO_DEG*Math.atan(r.distort(u/i)),h=RAD_TO_DEG*Math.atan(r.distort(l/i)),v=new FieldOfView,A=new FieldOfView;return v.leftDegrees=Math.min(d,t.fov),v.rightDegrees=Math.min(c,t.fov),v.downDegrees=Math.min(f,t.fov),v.upDegrees=Math.min(h,t.fov),A.leftDegrees=v.rightDegrees,A.rightDegrees=v.leftDegrees,A.upDegrees=v.upDegrees,A.downDegrees=v.downDegrees,{left:v,right:A}},n.prototype.onDeviceOrientation_=function(t){this._deviceOrientationQ=this._deviceOrientationQ||new THREE__namespace.Quaternion;var e=t.alpha,r=t.beta,i=t.gamma;e=(e||0)*Math.PI/180,r=(r||0)*Math.PI/180,i=(i||0)*Math.PI/180,this._deviceOrientationQ.setFromEuler(new THREE__namespace.Euler(e,r,-i,"YXZ"))},n.prototype.onDeviceMotion_=function(t){this.updateDeviceMotion_(t)},n.prototype.updateDeviceMotion_=function(t){var e=t.accelerationIncludingGravity,r=t.rotationRate,i=t.timeStamp/1e3,o=i-this.previousTimestampS;if(o<0){warnOnce("fusion-pose-sensor:invalid:non-monotonic","Invalid timestamps detected: non-monotonic timestamp from devicemotion"),this.previousTimestampS=i;return}else if(o<=MIN_TIMESTEP||o>MAX_TIMESTEP){warnOnce("fusion-pose-sensor:invalid:outside-threshold","Invalid timestamps detected: Timestamp from devicemotion outside expected range."),this.previousTimestampS=i;return}e&&(this.accelerometer.set(-e.x,-e.y,-e.z),r&&(isR7()?this.gyroscope.set(-r.beta,r.alpha,r.gamma):this.gyroscope.set(r.alpha,r.beta,r.gamma),this.isDeviceMotionInRadians||this.gyroscope.multiplyScalar(Math.PI/180),this.filter.addGyroMeasurement(this.gyroscope,i)),this.filter.addAccelMeasurement(this.accelerometer,i)),this.previousTimestampS=i},n.prototype.onOrientationChange_=function(){this.setScreenTransform_()},n.prototype.onMessage_=function(t){var e=t.data;if(!(!e||!e.type)){var r=e.type.toLowerCase();r==="devicemotion"&&this.updateDeviceMotion_(e.deviceMotionEvent)}},n.prototype.setScreenTransform_=function(){this.worldToScreenQ.set(0,0,0,1);var t=typeof window<"u"?window.orientation:0;switch(t){case 0:break;case 90:this.worldToScreenQ.setFromAxisAngle(new THREE__namespace.Vector3(0,0,1),-Math.PI/2);break;case-90:this.worldToScreenQ.setFromAxisAngle(new THREE__namespace.Vector3(0,0,1),Math.PI/2);break}this.inverseWorldToScreenQ.copy(this.worldToScreenQ),this.inverseWorldToScreenQ.inverse()},n}(),defaultLeftBounds=[0,0,.5,1],defaultRightBounds=[.5,0,.5,1],Cardboard=function(){function n(t){var e=this;this.renderer=t,this.sensor=new Sensor(.98,.04,!1,!1),this.scale=1,this.cameraL=new THREE__namespace.PerspectiveCamera,this.cameraR=new THREE__namespace.PerspectiveCamera;var r=this.sensor.start();this.dispose=function(){var i=e.renderer.getSize(new THREE__namespace.Vector2);e.renderer.setScissor(0,0,i.width,i.height),e.renderer.setViewport(0,0,i.width,i.height),e.renderer.setScissorTest(!1),r()}}return n.prototype.render=function(t,e){var r=this.renderer.getSize(new THREE__namespace.Vector2);if(r.width>r.height){var i=t.autoUpdate;i&&(t.updateMatrixWorld(),t.autoUpdate=!1);var o={x:Math.round(r.width*defaultLeftBounds[0]),y:Math.round(r.height*defaultLeftBounds[1]),width:Math.round(r.width*defaultLeftBounds[2]),height:Math.round(r.height*defaultLeftBounds[3])},s={x:Math.round(r.width*defaultRightBounds[0]),y:Math.round(r.height*defaultRightBounds[1]),width:Math.round(r.width*defaultRightBounds[2]),height:Math.round(r.height*defaultRightBounds[3])};this.renderer.setScissorTest(!0),this.renderer.autoClear&&this.renderer.clear(),e.parent===null&&e.updateMatrixWorld(),e.matrixWorld.decompose(this.cameraL.position,this.cameraL.quaternion,this.cameraL.scale),e.matrixWorld.decompose(this.cameraR.position,this.cameraR.quaternion,this.cameraR.scale);var u=this.sensor.getEyeOffset();this.cameraL.translateOnAxis(new THREE__namespace.Vector3().fromArray(u.left),this.scale),this.cameraR.translateOnAxis(new THREE__namespace.Vector3().fromArray(u.right),this.scale);var l=this.sensor.getEyeProjectionMatrix();this.cameraL.projectionMatrix.elements=l.left.slice(),this.cameraR.projectionMatrix.elements=l.right.slice(),this.renderer.setViewport(o.x,o.y,o.width,o.height),this.renderer.setScissor(o.x,o.y,o.width,o.height),this.renderer.render(t,this.cameraL),this.renderer.setViewport(s.x,s.y,s.width,s.height),this.renderer.setScissor(s.x,s.y,s.width,s.height),this.renderer.render(t,this.cameraR),this.renderer.setViewport(0,0,r.width,r.height),this.renderer.setScissor(0,0,r.width,r.height),this.renderer.setScissorTest(!1),i&&(t.autoUpdate=!0)}else this.renderer.render(t,e)},n.prototype.dispose=function(){},n}();const cardboard="data:image/png;base64,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",phone="data:image/png;base64,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";var _a,LOCALE={zh:{TITLE:"眼镜模式",HIT:"请将手机横屏放入 VR 眼镜中"},en:{TITLE:"GLASSES MODE",HIT:"Please put the mobile phone horizontally into the VR glasses."},ja:{TITLE:"メガネモード",HIT:"携帯電話をVRメガネに水平に入れてください。"}},TEXT=typeof navigator<"u"&&(_a=LOCALE[navigator.language.split("-")[0]])!==null&&_a!==void 0?_a:LOCALE.zh,CONTENTS=`
|
|
1467
|
+
`,PanoVideo=function(){function n(){this.material=new THREE__namespace.ShaderMaterial({vertexShader:PANO_VIDEO_MATERIAL_VERTEX_SHADER,fragmentShader:PANO_VIDEO_TILE_MATERIAL_FRAGMENT_SHADER,uniforms:{size:new THREE__namespace.Uniform(null),matrix:new THREE__namespace.Uniform(null),alpha:new THREE__namespace.Uniform(null),map:new THREE__namespace.Uniform(null)},depthTest:!1,depthWrite:!1,defines:{USE_PANO_VIDEO:!1},blending:THREE__namespace.CustomBlending,blendSrc:THREE__namespace.SrcAlphaFactor,blendDst:THREE__namespace.OneMinusSrcAlphaFactor,blendSrcAlpha:THREE__namespace.OneFactor,blendDstAlpha:THREE__namespace.OneMinusSrcAlphaFactor}),this.object=new THREE__namespace.Mesh(sharedGeometry$2,this.material),this.object.visible=!1,this.object.renderOrder=-1,this.object.frustumCulled=!1,this.object.name="pano-video",this.alphaMotion=new Motion({alpha:0})}return n.prototype.setMaterial=function(t){t?(this.material.uniforms.size.value=t.size,this.material.uniforms.matrix.value=t.matrix,this.material.uniforms.map.value=t.map,this.alphaMotion.set({alpha:t.alpha},500).catch(noop$1),this.material.uniforms.alpha.value=t.alpha):(this.material.uniforms.size.value=null,this.material.uniforms.matrix.value=null,this.material.uniforms.map.value=null,this.alphaMotion.set({alpha:0},0).catch(noop$1));var e=t!==null,r=this.material.defines.USE_PANO_VIDEO;e!==r&&(this.material.defines.USE_PANO_VIDEO=e,this.material.needsUpdate=!0,this.object.visible=t!==null)},n.prototype.updateTime=function(t){this.alphaMotion.ended||(this.alphaMotion.update(t),this.material.uniforms.alpha.value=this.alphaMotion.value.alpha)},n.prototype.dispose=function(){this.material.dispose()},n}(),ROTATE_Y_PI_MATRIX$1=new THREE__namespace.Matrix4().makeRotationAxis(new THREE__namespace.Vector3(0,1,0),Math.PI),PANO_TEXTURE_SCALE$2=new THREE__namespace.Vector3(-1,1,1),CubeRenderTargetPool=function(){function n(t){t===void 0&&(t=0),this.width=t,this.pool=[]}return Object.defineProperty(n.prototype,"size",{get:function(){return this.pool.length},enumerable:!1,configurable:!0}),n.prototype.create=function(){return new THREE__namespace.WebGLCubeRenderTarget(this.width,{stencilBuffer:!1,depthBuffer:!1})},n.prototype.pop=function(){var t=this.pool.pop();return t||this.create()},n.prototype.push=function(t){this.pool.indexOf(t)===-1&&this.pool.push(t)},n.prototype.clear=function(){for(var t=0,e=this.pool;t<e.length;t++){var r=e[t];r.dispose()}this.pool.length=0},n}(),PanoramaController=function(n){__extends(t,n);function t(e){var r=this,i,o,s,u,l=t.parseArgs(e);r=n.call(this,l)||this,r.TILED_CUBE_TEXTURE_LEVEL=2,r.mode="Panorama",r.tileLevel=0,r.initAnimationed=!1,r.maxAccessibleDistance=l.maxAccessibleDistance,r.panoTapTriggerRadius=l.panoTapTriggerRadius,r.panoCircleMeshCreator=l.panoCircleMeshCreator,r.tileLevelForFov=l.tileLevelForFov,r.luminanceAdaptiveEffectEnable=l.luminanceAdaptiveEffectEnable,r.colorCubeRenderTargetPool=new CubeRenderTargetPool,r.luminanceCubeRenderTargetPool=new CubeRenderTargetPool;var d=r.models.getMaterial()||{},c=d.pano0,f=d.pano1;c&&(f==null?void 0:f.map)!==c.map&&(r.models.setMaterial({pano0:f}),c.map.dispose(),c.map instanceof TileCubeTextureTarget&&c.map.cubeRenderTarget&&r.colorCubeRenderTargetPool.push(c.map.cubeRenderTarget),c.luminanceMap&&(c.luminanceMap.dispose(),c.luminanceMap instanceof TileCubeTextureTarget&&c.luminanceMap.cubeRenderTarget&&r.luminanceCubeRenderTargetPool.push(c.luminanceMap.cubeRenderTarget)));for(var h=r.colorCubeRenderTargetPool.size;h<2;h++){var v=Math.max(1024*r.TILED_CUBE_TEXTURE_LEVEL,512),A=r.colorCubeRenderTargetPool.create();A.setSize(v,v),renderCubeTextureToCubeRenderTarget(null,A,r.renderer),r.colorCubeRenderTargetPool.push(A)}r.panoMeshes={},r.updatePanoMeshes(),r.locationMotion=new Motion({count:0,distance:r.camera.pose.distance}),r.modelAlphaMotion=new Motion({modelAlpha:(o=(i=r.models.getMaterial())===null||i===void 0?void 0:i.modelAlpha)!==null&&o!==void 0?o:0}),r.perspToOrthoMotion=new Motion({perspToOrtho:r.camera.perspToOrtho.x}),r.panoResources={},r.panoResources[r.locationMotion.keyframes[0].key=r.locationMotion.keyframes[1].key=createUuid()]={panoId:panoStringify(r.currentPano),panoPicture:(u=(s=r.models.getMaterial())===null||s===void 0?void 0:s.pano1)!==null&&u!==void 0?u:null,position:r.camera.pose.offset.clone(),effect:"fly"};var m=r.works.getResolvedObserver(r.currentPano);return r.textureLoader=new TextureLoader,r.tiling=new Tiling(m?getFetcher(m.work):internalFetcher,r.TILED_CUBE_TEXTURE_LEVEL+1,r.imageOptions),r.scene.add(r.tiling.object),r.panoVideo=new PanoVideo,r.scene.add(r.panoVideo.object),r}return t.parseArgs=function(e){var r,i,o,s,u;if(e instanceof t)return e;var l=n.parseArgs.call(this,e);return __assign(__assign({},l),{maxAccessibleDistance:(r=e.maxAccessibleDistance)!==null&&r!==void 0?r:5,panoTapTriggerRadius:(i=e.panoTapTriggerRadius)!==null&&i!==void 0?i:.5,panoCircleMeshCreator:(o=e.panoCircleMeshCreator)!==null&&o!==void 0?o:function(d){return new PanoCircleMesh},tileLevelForFov:(s=e.tileLevelForFov)!==null&&s!==void 0?s:function(d,c){var f=function(y){return y/Math.PI*180},h=function(y){return y/180*Math.PI},v=c.height/2/Math.tan(h(d/2)),A=c.width>c.height?d:f(Math.atan(Math.tan(h(d/2))*(c.width/c.height))*2),m=v*(Math.tan(h(A/2))-Math.tan(h(A/2-1)));return m>60?4:m>30?3:m>18?2:m>12?1:0},luminanceAdaptiveEffectEnable:(u=e.luminanceAdaptiveEffectEnable)!==null&&u!==void 0?u:!0})},t.initAnimationEndState=function(e){var r=this.parseArgs(e),i=n.initAnimationEndState.call(this,r);return __assign(__assign({},i),{mode:"Panorama"})},t.prototype.destroy=function(){var e,r;if(n.prototype.destroy.call(this),this.scene.remove(this.tiling.object),this.tiling.dispose(),this.locationMotion.dispose(),this.colorCubeRenderTargetPool.clear(),this.luminanceCubeRenderTargetPool.clear(),delete this.pendingTextureTask,this.panoMeshes)for(var i=Object.keys(this.panoMeshes),o=0,s=i;o<s.length;o++){var u=s[o],l=this.panoMeshes[u];this.helper.remove(l),l.dispose(),delete this.panoMeshes[u]}var d=this.videoTexture.image;d.pause(),d.oncanplay=function(){},d.ontimeupdate=function(){},this.scene.remove(this.panoVideo.object),this.panoVideo.setMaterial(null),this.panoVideo.dispose();for(var c=(e=this.models.getMaterial())!==null&&e!==void 0?e:{},f=c.pano0,h=c.pano1,v=0,A=Object.keys(this.panoResources);v<A.length;v++){var m=A[v],y=this.panoResources[m];if(y.panoPicture){var p=y.panoPicture.map;p&&p!==(f==null?void 0:f.map)&&p!==(h==null?void 0:h.map)&&(p.dispose(),(r=y.panoPicture.luminanceMap)===null||r===void 0||r.dispose(),y.panoPicture=null)}delete this.panoResources[m]}this.luminanceAdaptiveEffect&&(this.luminanceAdaptiveEffect.dispose(),delete this.luminanceAdaptiveEffect)},t.prototype.isReady=function(){return this.locationMotion.ended!==!0?!1:n.prototype.isReady.call(this)},t.prototype.isTileReady=function(){var e,r,i,o=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[this.locationMotion.keyframes.length-1]),s=((e=o.panoPicture)===null||e===void 0?void 0:e.map)instanceof TileCubeTextureTarget&&(i=(r=o.panoPicture)===null||r===void 0?void 0:r.map.tilePending)!==null&&i!==void 0?i:0,u=this.tiling.pedding;return this.initAnimationed&&s<=0&&u<=0},t.prototype.updateWork=function(e,r,i,o){var s=this;this.userAction=o,this.works=e;var u=t.initAnimationEndState(__assign(__assign({},this),{initial:{currentState:__assign(__assign({},this.currentPano),this.camera.pose),duration:i,state:r,userAction:o}})),l={workCode:u.workCode,panoIndex:u.panoIndex},d=this.works.getWork(l.workCode);return this.tiling.setFetcher(d?getFetcher(d):internalFetcher),this.tiling.cleanup(),this.initAnimationed=!1,this.hideIntersectMesh(),this.updatePanoMeshes(),this.moveToPano(l,{effect:"fade",duration:i,longitude:r.longitude,latitude:r.latitude,fov:r.fov,moveEndCallback:function(){s.initAnimationed=!0},moveCancelCallback:function(){s.initAnimationed=!0}},o),!0},t.prototype.updateModel=function(e){this.models=e,this.updatePanoMeshes()},t.prototype.updateTime=function(e,r){var i=this,o,s,u,l,d,c,f,h,v,A;if(!this.destroyed){var m={},y={},p=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),m.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);var T=this.locationMotion.getKeyFrameSegment(e),_=T[0],w=T[1],x=this.panoResourceFromLocationMotionKeyframe(_),M=this.panoResourceFromLocationMotionKeyframe(w),R=new THREE__namespace.Vector3().copy(x.position),I=new THREE__namespace.Vector3().copy(M.position),S=this.locationMotion.value.count-w.value.count+1;m.progress=S,M.panoPicture&&(S<1?x.panoPicture&&(m.pano0=x.panoPicture):m.pano0=M.panoPicture,m.pano1=M.panoPicture),b=m.useBlackTransition=M.effect==="instant"||M.effect==="montage",(M.effect==="fade"||M.effect==="montage")&&(m.pano0&&x.panoPicture&&(m.pano0={map:m.pano0.map,luminanceMap:m.pano0.luminanceMap,matrix:x.panoPicture.matrix.clone().setPosition(M.position)}),R.copy(I)),y.distance=this.locationMotion.value.distance,y.offset=new THREE__namespace.Vector3(R.x+(I.x-R.x)*S,R.y+(I.y-R.y)*S,R.z+(I.z-R.z)*S);for(var B=[],O=[],F=0,H=this.locationMotion.keyframes;F<H.length;F++){var k=H[F],N=k.key,q=k.progress;N!==void 0&&(B.push(N),q>=this.locationMotion.progress&&O.push(N))}for(var V=0,D=Object.keys(this.panoResources);V<D.length;V++){var K=D[V];if(!(O.indexOf(K)>=0)){var z=this.panoResources[K];if(z.panoPicture){var G=z.panoPicture.map,W=z.panoPicture.luminanceMap;if(G){if(G===((o=m.pano0)===null||o===void 0?void 0:o.map)||G===((s=m.pano1)===null||s===void 0?void 0:s.map))continue;G instanceof TileCubeTextureTarget&&G.cubeRenderTarget&&this.colorCubeRenderTargetPool.push(G.cubeRenderTarget),G.dispose(),W&&(W instanceof TileCubeTextureTarget&&W.cubeRenderTarget&&this.luminanceCubeRenderTargetPool.push(W.cubeRenderTarget),W.dispose()),z.panoPicture=null}}B.indexOf(K)>=0||delete this.panoResources[K]}}this.currentPano=panoParse(M.panoId),this.emit("pano.moving",createEvent("pano.moving",{userAction:this.userAction,prevPano:panoParse(p.panoId),state:__assign(__assign(__assign(__assign({},panoParse(g.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),y),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(m)===!1&&(!((u=m.pano0)===null||u===void 0)&&u.map&&m.pano0.map instanceof TileCubeTextureTarget&&!m.pano0.map.cubeRenderTarget&&(m.pano0.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((l=m.pano0)===null||l===void 0)&&l.luminanceMap&&m.pano0.luminanceMap instanceof TileCubeTextureTarget&&!m.pano0.luminanceMap.cubeRenderTarget&&(m.pano0.luminanceMap.cubeRenderTarget=this.luminanceCubeRenderTargetPool.pop()),!((d=m.pano1)===null||d===void 0)&&d.map&&m.pano1.map instanceof TileCubeTextureTarget&&!m.pano1.map.cubeRenderTarget&&(m.pano1.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((c=m.pano1)===null||c===void 0)&&c.luminanceMap&&m.pano1.luminanceMap instanceof TileCubeTextureTarget&&!m.pano1.luminanceMap.cubeRenderTarget&&(m.pano1.luminanceMap.cubeRenderTarget=this.luminanceCubeRenderTargetPool.pop()),this.models.setMaterial(m)),isEmptyObject(y)===!1&&this.setCamera(y);var Q=this.works.getResolvedObserver(this.currentPano),X=this.locationMotion.ended?this.getForwardObserverOrNot():null;if(this.camera.pose.distance>.1||b){if(Q)for(var ee=0,J=Object.keys(this.panoMeshes);ee<J.length;ee++){var Z=J[ee],te=this.panoMeshes[Z];te.setOpacity(0),te.setCurrent(!1),te.updateTime&&te.updateTime(e,r)}}else if(Q){var ae=arrayMin(Q.visibleIds,function(le){var ue=i.works.getResolvedObserver(le);return ue?Q.standingPosition.distanceTo(ue.standingPosition):1/0},!0),re=ae[1];re=clamp(re,2.5,1/0);for(var ie=Q.visibleIds.concat(panoStringify(this.currentPano)),de=this.camera.getDirection(new THREE__namespace.Vector3),se=0,pe=Object.keys(this.panoMeshes);se<pe.length;se++){var Z=pe[se],te=this.panoMeshes[Z],$=this.works.getResolvedObserver(Z);if(ie.indexOf(Z)===-1)te.setCurrent(!1),te.setOpacity(0);else if(!$)te.setCurrent(!1),te.setOpacity(0);else if(!$.loadable&&!$.active)te.setCurrent(!1),te.setOpacity(0);else{var oe=te.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);te.setCurrent(!te.loading&&te.progress===0&&X!==null&&X.panoId===Z),te.setOpacity(oe<.01?0:clamp(re/oe*1.2,.4,.85));var j=this.camera.position.clone().setY(te.position.y),ve=new THREE__namespace.Vector3().copy(te.position).sub(j).normalize();if(Z===panoStringify(this.currentPano)){var me=clamp((.5-j.distanceTo(te.position))/.5,0,1);ve.multiplyScalar(1-me).add(de.clone().multiplyScalar(me))}ve.length()>0&&te.quaternion.setFromEuler(new THREE__namespace.Euler(0,Math.atan2(ve.x,ve.z),0))}te.updateTime&&te.updateTime(e,r)}}var Me=this.tileLevel=function(){if(i.tileLevelForFov===!1)return 0;var le=i.renderer.getDrawingBufferSize(new THREE__namespace.Vector2);le.width*=i.scissor.width,le.height*=i.scissor.height;var ue=g.panoId,Fe=i.works.getResolvedObserver(ue),fe=i.imageOptions.size;if(typeof fe>"u"&&Fe){var Se=Fe.images.up.match(/\/cube_(\d+)\//);Se&&(fe=Number(Se[1]))}typeof fe>"u"&&(fe=2048);var ye=0;fe>=1024&&(ye=1),fe>=2048&&(ye=2),fe>=4096&&(ye=3),fe>=8192&&(ye=4);var ke=i.tileLevelForFov(i.camera.fov,le);return ke>ye?ke:0}(),Re=function(){var le=i.camera.quaternion.clone(),ue=i.works.getResolvedObserver(g.panoId),Fe=ue??Q;Fe&&le.premultiply(Fe.quaternion.clone().inverse());var fe=new THREE__namespace.Matrix4().makeRotationFromQuaternion(le),Se=new THREE__namespace.Matrix4().getInverse(fe),ye=new THREE__namespace.Frustum().setFromProjectionMatrix(new THREE__namespace.Matrix4().multiplyMatrices(i.camera.projectionMatrix,Se));return ye}();g.panoId===panoStringify(this.currentPano)&&(((f=g.panoPicture)===null||f===void 0?void 0:f.map)instanceof TileCubeTextureTarget&&(g.panoPicture.map.update(Re,Me),g.panoPicture.map.needsRender===!0&&(g.panoPicture.map.needsRender=!1,this.needsRender=!0)),((h=g.panoPicture)===null||h===void 0?void 0:h.luminanceMap)instanceof TileCubeTextureTarget&&(g.panoPicture.luminanceMap.update(Re,Me),g.panoPicture.luminanceMap.needsRender===!0&&(g.panoPicture.luminanceMap.needsRender=!1,this.needsRender=!0)));{var ge=this.tiling.object.visible;if(this.initAnimationed){var we=g.panoId,Ae=this.works.getResolvedObserver(we);Ae?isSimilarVector3(this.camera.position,Ae.position)&&this.locationMotion.ended?(this.tiling.object.visible=!0,this.tiling.panoId!==we&&this.tiling.cleanup(),this.tiling.panoId=we,this.tiling.setResource((A=(v=Ae.images)===null||v===void 0?void 0:v.tiles)!==null&&A!==void 0?A:[],this.enableIOSEDR&&Ae.images.luminance?Ae.images.luminance:null),this.tiling.setFetcher(getFetcher(Ae.work)),this.tiling.setRotation(Ae.quaternion),this.tiling.setPosition(Ae.position),Me>this.TILED_CUBE_TEXTURE_LEVEL?this.tiling.update(Re,Me,e):this.tiling.update(Re,0,e)):this.tiling.object.visible=!1:this.tiling.object.visible=!1}else this.tiling.object.visible=!1;ge!==this.tiling.object.visible&&(this.tiling.object.needsRender=!0)}this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e)}},t.prototype.render=function(){var e=this.works.getResolvedObserver(this.currentPano);e&&e.video&&(this.needsRender=!0),n.prototype.render.call(this)},t.prototype.postProcessing=function(e,r){if(!this.destroyed&&r==="luminance")return this.luminanceAdaptiveEffect||(this.luminanceAdaptiveEffect=new LuminanceAdaptiveEffect(this.renderer,this.scene,this.camera,this.models),this.luminanceAdaptiveEffect.enable=this.luminanceAdaptiveEffectEnable),this.luminanceAdaptiveEffect.render(e)},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1],r=this.locationMotion.getKeyFrameSegment(now())[1],i=this.panoResourceFromLocationMotionKeyframe(r),o=this.works.getResolvedObserver(i.panoId);return{workCode:o?o.work.workCode:this.currentPano.workCode,panoIndex:o?o.panoIndex:this.currentPano.panoIndex,mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:o?o.position.clone():this.camera.position.clone(),distance:this.locationMotion.value.distance}},t.prototype.moveToPano=function(e,r,i){var o=this,s,u,l,d;this.userAction=i,this.stopMomentumMovement();var c=this.works.getResolvedObserver(e);if(!c)throw new Error("Invalid PanoId ".concat(JSON.stringify(e)));var f=this.imageOptions.size;if(typeof f>"u"&&c){var h=c.images.up.match(/\/cube_(\d+)\//);h&&(f=Number(h[1]))}typeof f>"u"&&(f=2048);var v=this.imageOptions.transform,A=__assign({key:"pano.".concat(c.panoId)},pick(this.imageOptions,["format","size","quality","sharpen","mappings"])),m=c.images,y=(u=(s=c.images.tiles)===null||s===void 0?void 0:s.filter(function(F){return F.size>f}))!==null&&u!==void 0?u:null,p=v,g={key:"pano_luminance.".concat(c.panoId),size:A.size?A.size/2:1024},b=this.enableIOSEDR&&c.images.luminance?c.images.luminance:null,T=function(){if(!c.images.tiles||!b)return null;var F=b.up.match(/\/cube_(\d+)\//),H=F?Number(F[1]):!1;return H===!1?null:y==null?void 0:y.map(function(k){return{level:k.level,size:H,back:b.back,front:b.front,left:b.left,right:b.right,up:b.up,down:b.down}})}(),_="pano:"+jsonHash([m,A,v]);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===_)return;var w=this.pendingTextureTask.panoId;(l=this.panoMeshes[w])===null||l===void 0||l.setProgress(0),this.emit("pano.texture.abort",createEvent("pano.texture.abort",{error:null,progress:0,meta:null,pano:c.pano})),this.pendingTextureTask.onError(new Error("texture aborted"))}var x="move-to-pano-"+c.panoId;this.pending.add(x);var M=this.models.getMaterial()||{},R=M.pano0,I=M.pano1,S;if(R&&R.map.name===_&&R.luminanceMap!==null===this.enableIOSEDR?S=R:(I==null?void 0:I.map.name)===_&&I.luminanceMap!==null===this.enableIOSEDR&&(S=I),S){var B={panoId:c.panoId,effect:(d=r.effect)!==null&&d!==void 0?d:"fly",panoPicture:{map:S.map,luminanceMap:S.luminanceMap,matrix:new THREE__namespace.Matrix4().compose(c.position,c.quaternion,PANO_TEXTURE_SCALE$2)},position:c.position.clone()};AnimationFrameLoop.shared.add(function(){o.pending.delete(x),o.doMoveToPano(c.pano,B,r)},!0,1);return}this.pendingTextureTask={panoId:c.panoId,hash:_,onLoad:function(F,H){var k,N;if(o.pending.delete(x),o.destroyed)F.body.dispose();else{F.body.name=_;var q={panoId:c.panoId,effect:(k=r.effect)!==null&&k!==void 0?k:"fly",panoPicture:{map:F.body,luminanceMap:(N=H==null?void 0:H.body)!==null&&N!==void 0?N:null,matrix:new THREE__namespace.Matrix4().compose(c.position,c.quaternion,PANO_TEXTURE_SCALE$2)},position:c.position.clone()};o.doMoveToPano(c.pano,q,r)}},onError:function(F){o.pending.delete(x);var H=__assign(__assign(__assign({},c.pano),{mode:o.mode}),clonePose(o.camera.pose));o.emit("pano.error",createEvent("pano.error",{error:F,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:H})),o.emit("pano.cancel",createEvent("pano.cancel",{error:F,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:H})),o.emit("error",F),r.moveCancelCallback&&r.moveCancelCallback()}};var O=this.panoMeshes[c.panoId];O&&O.tap&&O.tap(),Promise.all([this.tileLevelForFov&&y&&y.length?this.textureLoader.loadTiledCubeTexture(m,y,{tileMaxLevel:this.TILED_CUBE_TEXTURE_LEVEL,imageURL:{transform:v,options:A},format:THREE__namespace.RGBAFormat,viaAjax:!0,fetcher:getFetcher(c.work)},void 0,void 0,function(F){var H,k;o.emit("pano.texture.progress",createEvent("pano.texture.progress",{error:null,progress:F,meta:null,pano:c.pano})),((H=o.pendingTextureTask)===null||H===void 0?void 0:H.hash)===_&&((k=o.panoMeshes[c.panoId])===null||k===void 0||k.setProgress(F))},this.renderer):this.textureLoader.loadCubeTexture(m,{imageURL:{transform:v,options:A},format:THREE__namespace.RGBAFormat,viaAjax:!0,fetcher:getFetcher(c.work)},void 0,void 0,function(F){var H,k;o.emit("pano.texture.progress",createEvent("pano.texture.progress",{error:null,progress:F,meta:null,pano:c.pano})),((H=o.pendingTextureTask)===null||H===void 0?void 0:H.hash)===_&&((k=o.panoMeshes[c.panoId])===null||k===void 0||k.setProgress(F))},this.renderer),b?this.tileLevelForFov&&T&&T.length?this.textureLoader.loadTiledCubeTexture(b,T,{tileImageSize:256,tileMaxLevel:this.TILED_CUBE_TEXTURE_LEVEL,imageURL:{transform:p,options:g},fetcher:getFetcher(c.work)},void 0,void 0,void 0,this.renderer).catch(function(){return null}):this.textureLoader.loadCubeTexture(b,{imageURL:{transform:p,options:g},fetcher:getFetcher(c.work)},void 0,void 0,void 0,this.renderer).catch(function(){return null}):Promise.resolve(null)]).then(function(F){var H,k,N=F[0],q=F[1];((H=o.pendingTextureTask)===null||H===void 0?void 0:H.hash)===_?(o.pendingTextureTask.onLoad(N,q),(k=o.panoMeshes[c.panoId])===null||k===void 0||k.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.success",createEvent("pano.texture.success",{error:null,progress:1,meta:N.meta,pano:c.pano}))):(N.body.dispose(),q==null||q.body.dispose())}).catch(function(F){var H,k;((H=o.pendingTextureTask)===null||H===void 0?void 0:H.hash)===_&&(o.pendingTextureTask.onError(F),(k=o.panoMeshes[c.panoId])===null||k===void 0||k.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.error",createEvent("pano.texture.error",{error:F,progress:0,meta:null,pano:c.pano})),o.emit("error",F))}),this.emit("pano.texture.load",createEvent("pano.texture.load",{error:null,progress:0,meta:null,pano:c.pano}))},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 o=i.duration,s=i.userAction;e.userAction=s;var u=t.initAnimationEndState(e),l={workCode:u.workCode,panoIndex:u.panoIndex},d={modelAlpha:0},c={perspToOrtho:0},f=!1;e.moveToPano(l,{longitude:u.longitude,latitude:u.latitude,fov:u.fov,duration:o,moveStartCallback:function(h){f=!0,e.perspToOrthoMotion.set(c,o).catch(noop$1),e.modelAlphaMotion.setKeyframes([{progress:0,value:__assign({},e.modelAlphaMotion.value)},{progress:.6,value:__assign({},e.modelAlphaMotion.value)},{progress:1,value:d}],o).catch(noop$1),e.emit("initAnimation.start",createEvent("initAnimation.start",{state:h,userAction:e.userAction}))},moveEndCallback:function(h){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:h,userAction:e.userAction})),e.initAnimationed=!0,r()},moveCancelCallback:function(){var h=__assign(__assign(__assign({},l),{mode:e.mode}),clonePose(e.camera.pose));f===!1&&e.emit("initAnimation.start",createEvent("initAnimation.start",{state:h,userAction:e.userAction})),e.emit("initAnimation.end",createEvent("initAnimation.end",{state:h,userAction:e.userAction})),e.initAnimationed=!0,r()}},s)})},t.prototype.panoResourceFromLocationMotionKeyframe=function(e){return this.panoResources[e.key]},t.prototype.locationMotionKeyframesLength=function(e){for(var r=0,i=1;i<e.length;i++){var o=this.panoResourceFromLocationMotionKeyframe(e[i-1]).position,s=this.panoResourceFromLocationMotionKeyframe(e[i]).position,u=o.distanceTo(s)*(e[i].value.count-e[i-1].value.count);r+=u}return r},t.prototype.updatePanoMeshes=function(){for(var e=this,r={},i=Object.keys(this.panoMeshes),o=0,s=i;o<s.length;o++){var u=s[o],l=this.panoMeshes[u];r[u]=l,delete this.panoMeshes[u]}for(var d=1,c={},f=function(w){var x=arrayMin(w.accessibleIds,function(R){var I=e.works.getResolvedObserver(R);if(!I)return 1/0;var S=I.standingPosition.distanceTo(w.standingPosition);return clamp(S,1,1/0)},!0),M=x[1];c[w.panoId]===void 0&&(c[w.panoId]=M)},h=0,v=this.works.resolvedObservers;h<v.length;h++){var A=v[h];f(A)}var m=Object.keys(c).map(function(w){return c[w]});if(m.length){var y=m.reduce(function(w,x){return w+x},0)/m.length;d=clamp(y*.6,1,3)}for(var p=0,g=this.works.resolvedObservers;p<g.length;p++){var A=g[p],l=void 0;r[A.panoId]?(l=r[A.panoId],l.loading===!0&&A.loadable===!1&&l.setLoading(!1),delete r[A.panoId]):(l=this.panoCircleMeshCreator(A.pano),l.name="PanoCircleMesh_"+A.panoId,this.helper.add(l)),l.scale.set(d,1,d),l.position.copy(A.standingPosition),this.panoMeshes[A.panoId]=l}for(var b=0,T=Object.keys(r);b<T.length;b++){var _=T[b];this.helper.remove(r[_]),r[_].dispose(),delete r[_]}},t.prototype.doMoveToPano=function(e,r,i){var o=this,s,u,l,d;i===void 0&&(i={});var c=now(),f=createUuid();this.tiling.cleanup(),this.panoResources[f]=r;var h=1,v,A,m;if(this.locationMotion.ended){var y=this.locationMotion.getKeyFrameSegment(c);y[0];var p=y[1],g=this.locationMotion.value,b=((s=this.panoResourceFromLocationMotionKeyframe(p))!==null&&s!==void 0?s:this.camera).position,T=r.position;v=Math.max(b.distanceTo(T),h),A=[{key:p.key,progress:0,value:__assign(__assign({},g),{count:0})},{key:f,progress:1,value:{distance:0,count:1}}],m=0}else{var _=this.locationMotion.getKeyFrameSegment(c),w=_[0],p=_[1],g=this.locationMotion.value,x=this.panoResourceFromLocationMotionKeyframe(w).position,b=this.panoResourceFromLocationMotionKeyframe(p).position,T=r.position,M=p.value.count-g.count,R=Math.max(x.distanceTo(b),h)*M,I=Math.max(b.distanceTo(T),h);v=R+I,A=[{key:w.key,progress:0,value:__assign({},g)},{key:p.key,progress:R/v,value:p.value},{key:f,progress:1,value:{count:p.value.count+1,distance:0}}];var S=this.locationMotionKeyframesLength(this.locationMotion.keyframes),B=this.locationMotionKeyframesLength(A);S===0||S===0?m=0:m=this.locationMotion.getProgressVelocity(c)*S/B}var O=this.calculateMovingDuration(i.duration,i.effect==="fade"||i.effect==="montage"?0:v),F={longitude:i.longitude,latitude:i.latitude,fov:i.fov},H=__assign(__assign({},e),{mode:this.mode,longitude:(u=F.longitude)!==null&&u!==void 0?u:this.camera.pose.longitude,latitude:(l=F.latitude)!==null&&l!==void 0?l:this.camera.pose.latitude,fov:(d=F.fov)!==null&&d!==void 0?d:this.camera.pose.fov,offset:r.position.clone(),distance:this.camera.pose.distance}),k=this.currentPano;this.emit("pano.moveTo",createEvent("pano.moveTo",{options:i,prevPano:k,progress:0,state:H,userAction:this.userAction,error:null})),i.moveStartCallback&&i.moveStartCallback(H),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=noop$1,this.videoTexture.needsUpdate=!0),this.panoVideo.setMaterial(null),this.cameraMotion.set(F,O).catch(noop$1);var N=this.locationMotion.setKeyframes(A,O,m);N.then(function(){var q,V,D=__assign(__assign({},e),{mode:o.mode,longitude:o.camera.pose.longitude,latitude:o.camera.pose.latitude,fov:o.camera.pose.fov,offset:o.camera.pose.offset.clone(),distance:o.camera.pose.distance});o.emit("pano.arrived",createEvent("pano.arrived",{options:i,prevPano:k,progress:1,state:D,userAction:o.userAction,error:null})),i.moveEndCallback&&i.moveEndCallback(D);var K=o.works.getResolvedObserver(e);if(K&&K.video&&o.videoTexture&&o.videoTexture.image instanceof HTMLVideoElement){var z=ROTATE_Y_PI_MATRIX$1.clone().multiply((V=(q=o.models.getMaterial().pano1)===null||q===void 0?void 0:q.matrix)!==null&&V!==void 0?V:new THREE__namespace.Matrix4).multiply(K.video.matrix),G={map:o.videoTexture,size:K.video.size,matrix:z,alpha:1},W=createUuid(),Q=o.videoTexture.image;Q.setAttribute("uuid",W),canplayVideo().then(function(X){X&&K.video&&Q.getAttribute("uuid")===W&&(Q.oncanplay=function(){Q.oncanplay=noop$1,Q.play()},Q.ontimeupdate=function(){Q.currentTime>.5&&(Q.ontimeupdate=noop$1,o.panoVideo.setMaterial(G))},Q.src=K.video.source)}).catch(function(){Q.removeAttribute("uuid")})}},function(){o.emit("pano.cancel",createEvent("pano.cancel",{options:i,prevPano:k,progress:0,state:H,userAction:o.userAction,error:null})),i.moveCancelCallback&&i.moveCancelCallback()})},t.prototype.getForwardObserverOrNot=function(e){var r=this,i=this.works.getResolvedObserver(this.currentPano);if(!i)return null;var o=e??new THREE__namespace.Raycaster(this.camera.position.clone(),this.camera.getDirection(new THREE__namespace.Vector3));o.params.Points={threshold:.1};var s=i.standingPosition.clone();if(i.position.distanceTo(o.ray.origin)>1){var u=this.models.intersectRaycaster(new THREE__namespace.Raycaster(o.ray.origin,new THREE__namespace.Vector3(0,-1,0)))[0];u&&u.distance<=2?s.copy(u.point):s.copy(o.ray.origin).add(new THREE__namespace.Vector3(0,-1.5,0))}var l=this.models.intersectRaycaster(o)[0],d=l?l.point:o.ray.origin.clone().add(o.ray.direction.clone().normalize().multiplyScalar(3)),c=d.clone().sub(s).normalize();if(c.length()===0)return null;for(var f=i.accessibleIds.filter(function(_){if(_===panoStringify(r.currentPano))return!1;var w=r.works.getResolvedObserver(_);if(!w)return!1;var x=w.standingPosition.clone().project(r.camera);return Math.abs(x.z)>1||Math.abs(x.x)>1||Math.abs(x.y)>1?!1:w.loadable||w.active}),h=f.slice().sort(function(_,w){var x=r.works.getResolvedObserver(_).standingPosition.clone().distanceTo(s),M=r.works.getResolvedObserver(w).standingPosition.clone().distanceTo(s);return x-M}),v=0,A=[Math.PI/8,Math.PI/6,Math.PI/4,Math.PI/3];v<A.length;v++)for(var m=A[v],y=0,p=h;y<p.length;y++){var g=p[y],b=this.works.getResolvedObserver(g);if(b){var T=b.standingPosition.clone().sub(s);if(T&&T.length()!==0&&c.angleTo(T)<m)return b}}return null},t.prototype.onTapGesture=function(e){var r=this,i;if(this.userAction=e.userAction,this.stopMomentumMovement(),!!this.initAnimationed){if(!this.locationMotion.ended){var o=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[this.locationMotion.keyframes.length-1]);if(o.panoId!==panoStringify(this.currentPano))return}var s=e.center.raycaster,u=this.camera.getDirection(new THREE__namespace.Vector3).setY(0),l=null,d=this.works.getResolvedObserver(this.currentPano);if(d){var c=d.accessibleIds.filter(function(V){if(V===panoStringify(r.currentPano))return!1;var D=r.works.getResolvedObserver(V);return!D||D.position.distanceTo(r.camera.position)>r.maxAccessibleDistance?!1:D.loadable||D.active}),f=this.models.intersectRaycaster(s)[0];if(f){var h=arrayMin(c,function(V){var D=r.works.getResolvedObserver(V);if(!D)return 1/0;var K=D.standingPosition.clone();return K.distanceTo(f.point)},!0),v=h[0],A=h[1];v&&A<this.panoTapTriggerRadius&&(l=(i=this.works.getResolvedObserver(v))!==null&&i!==void 0?i:null)}l||(l=this.getForwardObserverOrNot(s));for(var m=0,y=this.locationMotion.keyframes;m<y.length;m++){var p=y[m],g=this.panoResourceFromLocationMotionKeyframe(p);if(!(p.progress<this.locationMotion.progress)&&l&&g.panoId===l.panoId){l=null;break}}if(!l)this.emit("gesture.tap",e),e.defaultPrevented||this.locationMotion.ended===!0&&this.cameraBounce();else{for(var b={},T=Math.PI/6,_=Math.PI/12,w=l.position.clone().setY(0).sub(d.position.clone().setY(0)).normalize(),x=[],M=[],R=[],I=0,S=l.accessibleIds;I<S.length;I++){var v=S[I],B=panoParse(v);if(!(panoEqual(B,this.currentPano)||panoEqual(B,l.pano))){var O=this.works.getResolvedObserver(v);if(O){var F=O.position.clone().sub(l.position).setY(0);w.angleTo(F)<T&&R.push(F)}}}var H=R.length>0?R:__spreadArray(__spreadArray([],x,!0),M,!0),k=H.slice().sort(function(V,D){return V.angleTo(w)-D.angleTo(w)})[0];k&&k.angleTo(u)>_&&(b.longitude=Math.atan2(-k.x,-k.z)),this.cameraMotion.value.latitude<-Math.PI/4&&(b.latitude=clamp(0,this.minLatitude,this.maxLatitude));var N=__assign({},e.state);if(N.workCode=l.pano.workCode,N.panoIndex=l.pano.panoIndex,b.longitude!==void 0&&(N.longitude=b.longitude),b.latitude!==void 0&&(N.latitude=b.latitude),b.fov!==void 0&&(N.fov=b.fov),N.distance=0,N.offset=l.position.clone(),e.state=N,this.emit("gesture.tap",e),!e.defaultPrevented){if(this.emit("pano.select",createEvent("pano.select",{prevPano:this.currentPano,state:N,userAction:e.userAction,options:b,progress:0,error:null})),l&&!l.active){var q=l.panoId;this.panoMeshes[q]&&(this.panoMeshes[q].setDisabled(!1),this.panoMeshes[q].setLoading(!0))}l&&l.active&&this.emit("pano.request",createEvent("pano.request",{userAction:e.userAction,prevPano:this.currentPano,progress:0,state:N,options:b,error:null}))}}}}},t}(PanoramaLikeController),DEG_TO_RAD=Math.PI/180,RAD_TO_DEG=180/Math.PI,MIN_TIMESTEP=.001,MAX_TIMESTEP=1,isIOS=function(){var n=typeof navigator<"u"&&/iPad|iPhone|iPod/.test(navigator.platform);return function(){return n}}(),isSafari=function(){var n=typeof navigator<"u"&&/^((?!chrome|android).)*safari/i.test(navigator.userAgent);return function(){return n}}(),isFirefoxAndroid=function(){var n=typeof navigator<"u"&&navigator.userAgent.indexOf("Firefox")!==-1&&navigator.userAgent.indexOf("Android")!==-1;return function(){return n}}(),getChromeVersion=function(){var n=typeof navigator<"u"?navigator.userAgent.match(/.*Chrome\/([0-9]+)/):null,t=n?parseInt(n[1],10):null;return function(){return t}}(),isChromeWithoutDeviceMotion=function(){var n=!1;if(getChromeVersion()===65){var t=typeof navigator<"u"?navigator.userAgent.match(/.*Chrome\/([0-9\.]*)/):null;if(t){var e=t[1].split(".");e[0],e[1];var r=e[2],i=e[3];n=parseInt(r,10)===3325&&parseInt(i,10)<148}}return function(){return n}}(),isSafariWithoutDeviceMotion=function(){var n=isIOS()&&isSafari()&&typeof navigator<"u"&&navigator.userAgent.indexOf("13_4")!==-1;return function(){return n}}(),isR7=function(){var n=typeof navigator<"u"&&navigator.userAgent.indexOf("R7 Build")!==-1;return function(){return n}}();function isLandscapeMode(){var n=typeof window<"u"&&(window.orientation==90||window.orientation==-90);return isR7()?!n:n}function isTimestampDeltaValid(n){return!(isNaN(n)||n<=MIN_TIMESTEP||n>MAX_TIMESTEP)}function getQuaternionAngle(n){if(n.w>1)return 0;var t=2*Math.acos(n.w);return t}var warnOnce=function(){var n={};return function(t,e){n[t]===void 0&&(console.warn("cardboard: "+e),n[t]=!0)}}();function getOriginFromUrl(n){var t,e=n.indexOf("://");e!==-1?t=e+3:t=0;var r=n.indexOf("/",t);return r===-1&&(r=n.length),n.substring(0,r)}function isInsideCrossOriginIFrame(){if(typeof window>"u"||typeof document>"u")return!1;var n=window.self!==window.top,t=getOriginFromUrl(document.referrer),e=getOriginFromUrl(window.location.href);return n&&t!==e}var updateEyeViewMatrices=function(){function n(r,i,o){var s=i?i[0]:0,u=i?i[1]:0,l=i?i[2]:0,d=i?i[3]:1,c=s+s,f=u+u,h=l+l,v=s*c,A=s*f,m=s*h,y=u*f,p=u*h,g=l*h,b=d*c,T=d*f,_=d*h;return r[0]=1-(y+g),r[1]=A+_,r[2]=m-T,r[3]=0,r[4]=A-_,r[5]=1-(v+g),r[6]=p+b,r[7]=0,r[8]=m+T,r[9]=p-b,r[10]=1-(v+y),r[11]=0,r[12]=o?o[0]:0,r[13]=o?o[1]:0,r[14]=o?o[2]:0,r[15]=1,r}function t(r,i,o){var s=o[0],u=o[1],l=o[2],d,c,f,h,v,A,m,y,p,g,b,T;return i===r?(r[12]=i[0]*s+i[4]*u+i[8]*l+i[12],r[13]=i[1]*s+i[5]*u+i[9]*l+i[13],r[14]=i[2]*s+i[6]*u+i[10]*l+i[14],r[15]=i[3]*s+i[7]*u+i[11]*l+i[15]):(d=i[0],c=i[1],f=i[2],h=i[3],v=i[4],A=i[5],m=i[6],y=i[7],p=i[8],g=i[9],b=i[10],T=i[11],r[0]=d,r[1]=c,r[2]=f,r[3]=h,r[4]=v,r[5]=A,r[6]=m,r[7]=y,r[8]=p,r[9]=g,r[10]=b,r[11]=T,r[12]=d*s+v*u+p*l+i[12],r[13]=c*s+A*u+g*l+i[13],r[14]=f*s+m*u+b*l+i[14],r[15]=h*s+y*u+T*l+i[15]),r}function e(r,i){var o=i[0],s=i[1],u=i[2],l=i[3],d=i[4],c=i[5],f=i[6],h=i[7],v=i[8],A=i[9],m=i[10],y=i[11],p=i[12],g=i[13],b=i[14],T=i[15],_=o*c-s*d,w=o*f-u*d,x=o*h-l*d,M=s*f-u*c,R=s*h-l*c,I=u*h-l*f,S=v*g-A*p,B=v*b-m*p,O=v*T-y*p,F=A*b-m*g,H=A*T-y*g,k=m*T-y*b,N=_*k-w*H+x*F+M*O-R*B+I*S;return N?(N=1/N,r[0]=(c*k-f*H+h*F)*N,r[1]=(u*H-s*k-l*F)*N,r[2]=(g*I-b*R+T*M)*N,r[3]=(m*R-A*I-y*M)*N,r[4]=(f*O-d*k-h*B)*N,r[5]=(o*k-u*O+l*B)*N,r[6]=(b*x-p*I-T*w)*N,r[7]=(v*I-m*x+y*w)*N,r[8]=(d*H-c*O+h*S)*N,r[9]=(s*O-o*H-l*S)*N,r[10]=(p*R-g*x+T*_)*N,r[11]=(A*x-v*R-y*_)*N,r[12]=(c*B-d*F-f*S)*N,r[13]=(o*F-s*B+u*S)*N,r[14]=(g*w-p*M-b*_)*N,r[15]=(v*M-A*w+m*_)*N,r):null}return function(r,i,o){n(r,i),o&&t(r,r,o),e(r,r)}}(),SensorSample=function(){function n(t,e){t===void 0&&(t=new THREE__namespace.Vector3),e===void 0&&(e=0),this.sample=t,this.timestampS=e}return n.prototype.set=function(t,e){this.sample=t,this.timestampS=e},n.prototype.copy=function(t){this.set(t.sample,t.timestampS)},n}(),ComplementaryFilter=function(){function n(t,e){this.kFilter=t,this.isDebug=e,this.currentAccelMeasurement=new SensorSample,this.currentGyroMeasurement=new SensorSample,this.previousGyroMeasurement=new SensorSample,isIOS()?this.filterQ=new THREE__namespace.Quaternion(-1,0,0,1):this.filterQ=new THREE__namespace.Quaternion(1,0,0,1),this.previousFilterQ=new THREE__namespace.Quaternion,this.previousFilterQ.copy(this.filterQ),this.accelQ=new THREE__namespace.Quaternion,this.isOrientationInitialized=!1,this.estimatedGravity=new THREE__namespace.Vector3,this.measuredGravity=new THREE__namespace.Vector3,this.gyroIntegralQ=new THREE__namespace.Quaternion}return n.prototype.addAccelMeasurement=function(t,e){this.currentAccelMeasurement.set(t,e)},n.prototype.addGyroMeasurement=function(t,e){this.currentGyroMeasurement.set(t,e);var r=e-this.previousGyroMeasurement.timestampS;isTimestampDeltaValid(r)&&this.run_(),this.previousGyroMeasurement.copy(this.currentGyroMeasurement)},n.prototype.getOrientation=function(){return this.filterQ},n.prototype.run_=function(){if(!this.isOrientationInitialized){this.accelQ=this.accelToQuaternion_(this.currentAccelMeasurement.sample),this.previousFilterQ.copy(this.accelQ),this.isOrientationInitialized=!0;return}var t=this.currentGyroMeasurement.timestampS-this.previousGyroMeasurement.timestampS,e=this.gyroToQuaternionDelta_(this.currentGyroMeasurement.sample,t);this.gyroIntegralQ.multiply(e),this.filterQ.copy(this.previousFilterQ),this.filterQ.multiply(e);var r=new THREE__namespace.Quaternion;r.copy(this.filterQ),r.inverse(),this.estimatedGravity.set(0,0,-1),this.estimatedGravity.applyQuaternion(r),this.estimatedGravity.normalize(),this.measuredGravity.copy(this.currentAccelMeasurement.sample),this.measuredGravity.normalize();var i=new THREE__namespace.Quaternion;i.setFromUnitVectors(this.estimatedGravity,this.measuredGravity),i.inverse(),this.isDebug&&console.log("Delta: %d deg, G_est: (%s, %s, %s), G_meas: (%s, %s, %s)",RAD_TO_DEG*getQuaternionAngle(i),this.estimatedGravity.x.toFixed(1),this.estimatedGravity.y.toFixed(1),this.estimatedGravity.z.toFixed(1),this.measuredGravity.x.toFixed(1),this.measuredGravity.y.toFixed(1),this.measuredGravity.z.toFixed(1));var o=new THREE__namespace.Quaternion;o.copy(this.filterQ),o.multiply(i),this.filterQ.slerp(o,1-this.kFilter),this.previousFilterQ.copy(this.filterQ)},n.prototype.accelToQuaternion_=function(t){var e=new THREE__namespace.Vector3;e.copy(t),e.normalize();var r=new THREE__namespace.Quaternion;return r.setFromUnitVectors(new THREE__namespace.Vector3(0,0,-1),e),r.inverse(),r},n.prototype.gyroToQuaternionDelta_=function(t,e){var r=new THREE__namespace.Quaternion,i=new THREE__namespace.Vector3;return i.copy(t),i.normalize(),r.setFromAxisAngle(i,t.length()*e),r},n}(),PosePredictor=function(){function n(t,e){this.predictionTimeS=t,this.isDebug=e,this.previousQ=new THREE__namespace.Quaternion,this.previousTimestampS=null,this.deltaQ=new THREE__namespace.Quaternion,this.outQ=new THREE__namespace.Quaternion}return n.prototype.getPrediction=function(t,e,r){if(!this.previousTimestampS)return this.previousQ.copy(t),this.previousTimestampS=r,t;var i=new THREE__namespace.Vector3;i.copy(e),i.normalize();var o=e.length();if(o<DEG_TO_RAD*20)return this.isDebug&&console.log("Moving slowly, at %s deg/s: no prediction",(RAD_TO_DEG*o).toFixed(1)),this.outQ.copy(t),this.previousQ.copy(t),this.outQ;var s=o*this.predictionTimeS;return this.deltaQ.setFromAxisAngle(i,s),this.outQ.copy(this.previousQ),this.outQ.multiply(this.deltaQ),this.previousQ.copy(t),this.previousTimestampS=r,this.outQ},n}(),Distortion=function(){function n(t){this.coefficients=t}return n.prototype.distortInverse=function(t){for(var e=0,r=1,i=t-this.distort(e);Math.abs(r-e)>1e-4;){var o=t-this.distort(r),s=r-o*((r-e)/(o-i));e=r,r=s,i=o}return r},n.prototype.distort=function(t){for(var e=t*t,r=0,i=0;i<this.coefficients.length;i++)r=e*(r+this.coefficients[i]);return(r+1)*t},n}(),Pose=function(){function n(){this.angularAcceleration=null,this.angularVelocity=null,this.linearAcceleration=null,this.linearVelocity=null,this.orientation=null,this.position=null}return n}(),FieldOfView=function(){function n(){this.leftDegrees=0,this.rightDegrees=0,this.upDegrees=0,this.downDegrees=0}return n}(),Sensor=function(){function n(t,e,r,i){this.viewer={id:"CardboardV1",label:"Cardboard I/O 2014",fov:40,interLensDistance:.06,baselineLensDistance:.035,screenLensDistance:.042,distortionCoefficients:[.441,.156],inverseCoefficients:[-.4410035,.42756155,-.4804439,.5460139,-.58821183,.5733938,-.48303202,.33299083,-.17573841,.0651772,-.01488963,.001559834]},this.device={widthMeters:.11,heightMeters:.062,bevelMeters:.004},this.depthNear=.01,this.depthFar=1e4,this.yawOnly=r,this.accelerometer=new THREE__namespace.Vector3,this.gyroscope=new THREE__namespace.Vector3,this.filter=new ComplementaryFilter(t,i),this.posePredictor=new PosePredictor(e,i),this.isFirefoxAndroid=isFirefoxAndroid(),this.isIOS=isIOS();var o=getChromeVersion();this.isDeviceMotionInRadians=!this.isIOS&&o!==null&&o<66,this.isWithoutDeviceMotion=isChromeWithoutDeviceMotion()||isSafariWithoutDeviceMotion(),this.filterToWorldQ=new THREE__namespace.Quaternion,isIOS()?this.filterToWorldQ.setFromAxisAngle(new THREE__namespace.Vector3(1,0,0),Math.PI/2):this.filterToWorldQ.setFromAxisAngle(new THREE__namespace.Vector3(1,0,0),-Math.PI/2),this.inverseWorldToScreenQ=new THREE__namespace.Quaternion,this.worldToScreenQ=new THREE__namespace.Quaternion,this.originalPoseAdjustQ=new THREE__namespace.Quaternion;var s=typeof window<"u"?-window.orientation*Math.PI/180:0;this.originalPoseAdjustQ.setFromAxisAngle(new THREE__namespace.Vector3(0,0,1),s),this.setScreenTransform_(),isLandscapeMode()&&this.filterToWorldQ.multiply(this.inverseWorldToScreenQ),this.resetQ=new THREE__namespace.Quaternion,this.orientationOut_=new Float32Array(4),this.previousTimestampS=Date.now()}return n.prototype.getPosition=function(){return null},n.prototype.getOrientation=function(){var t;if(this.isWithoutDeviceMotion&&this._deviceOrientationQ){this.deviceOrientationFixQ=this.deviceOrientationFixQ||function(){var o=new THREE__namespace.Quaternion().setFromAxisAngle(new THREE__namespace.Vector3(0,0,-1),0),s=new THREE__namespace.Quaternion;return typeof window<"u"&&window.orientation===-90?s.setFromAxisAngle(new THREE__namespace.Vector3(0,1,0),Math.PI/-2):s.setFromAxisAngle(new THREE__namespace.Vector3(0,1,0),Math.PI/2),o.multiply(s)}(),this.deviceOrientationFilterToWorldQ=this.deviceOrientationFilterToWorldQ||function(){var o=new THREE__namespace.Quaternion;return o.setFromAxisAngle(new THREE__namespace.Vector3(1,0,0),-Math.PI/2),o}(),t=this._deviceOrientationQ;var e=new THREE__namespace.Quaternion;return e.copy(t),e.multiply(this.deviceOrientationFilterToWorldQ),e.multiply(this.resetQ),e.multiply(this.worldToScreenQ),e.multiplyQuaternions(this.deviceOrientationFixQ,e),this.yawOnly&&(e.x=0,e.z=0,e.normalize()),this.orientationOut_[0]=e.x,this.orientationOut_[1]=e.y,this.orientationOut_[2]=e.z,this.orientationOut_[3]=e.w,this.orientationOut_}else{var r=this.filter.getOrientation();t=this.posePredictor.getPrediction(r,this.gyroscope,this.previousTimestampS)}var i=new THREE__namespace.Quaternion;return i.copy(this.filterToWorldQ),i.multiply(this.resetQ),i.multiply(t),i.multiply(this.worldToScreenQ),this.yawOnly&&(i.x=0,i.z=0,i.normalize()),this.orientationOut_[0]=i.x,this.orientationOut_[1]=i.y,this.orientationOut_[2]=i.z,this.orientationOut_[3]=i.w,this.orientationOut_},n.prototype.getPose=function(){var t=new Pose;return t.orientation=this.getOrientation(),t},n.prototype.resetPose=function(){this.resetQ.copy(this.filter.getOrientation()),this.resetQ.x=0,this.resetQ.y=0,this.resetQ.z*=-1,this.resetQ.normalize(),isLandscapeMode()&&this.resetQ.multiply(this.inverseWorldToScreenQ),this.resetQ.multiply(this.originalPoseAdjustQ)},n.prototype.getFrameData=function(t){var e=this.getOrientation(),r=this.getEyeOffset(),i=this.getEyeProjectionMatrix();return t.pose.angularAcceleration=null,t.pose.angularVelocity=null,t.pose.linearAcceleration=null,t.pose.linearVelocity=null,t.pose.orientation=e,t.pose.position=null,t.timestamp=this.previousTimestampS,t.leftProjectionMatrix.set(i.left),t.rightProjectionMatrix.set(i.right),updateEyeViewMatrices(t.leftViewMatrix,e,r.left),updateEyeViewMatrices(t.rightViewMatrix,e,r.right),t},n.prototype.start=function(){if(typeof window>"u")return function(){};var t=this.onDeviceMotion_.bind(this),e=this.onOrientationChange_.bind(this),r=this.onMessage_.bind(this),i=this.onDeviceOrientation_.bind(this);return isIOS()&&isInsideCrossOriginIFrame()&&window.addEventListener("message",r),window.addEventListener("orientationchange",e),this.isWithoutDeviceMotion?window.addEventListener("deviceorientation",i):window.addEventListener("devicemotion",t),function(){window.removeEventListener("devicemotion",t),window.removeEventListener("deviceorientation",e),window.removeEventListener("orientationchange",e),window.removeEventListener("message",r)}},n.prototype.getEyeOffset=function(){return{left:[-this.viewer.interLensDistance*.5,0,0],right:[this.viewer.interLensDistance*.5,0,0]}},n.prototype.getEyeProjectionMatrix=function(){var t=this.getEyeFieldOfView(),e=this.depthNear,r=this.depthFar,i={left:[],right:[]};{var o=t.left.upDegrees*DEG_TO_RAD,s=t.left.downDegrees*DEG_TO_RAD,u=t.left.leftDegrees*DEG_TO_RAD,l=t.left.rightDegrees*DEG_TO_RAD,d=2/(u+l),c=2/(o+s);i.left[0]=d,i.left[1]=0,i.left[2]=0,i.left[3]=0,i.left[4]=0,i.left[5]=c,i.left[6]=0,i.left[7]=0,i.left[8]=-((u-l)*d*.5),i.left[9]=(o-s)*c*.5,i.left[10]=r/(e-r),i.left[11]=-1,i.left[12]=0,i.left[13]=0,i.left[14]=r*e/(e-r),i.left[15]=0}{var o=t.right.upDegrees*DEG_TO_RAD,s=t.right.downDegrees*DEG_TO_RAD,u=t.right.leftDegrees*DEG_TO_RAD,l=t.right.rightDegrees*DEG_TO_RAD,d=2/(u+l),c=2/(o+s);i.right[0]=d,i.right[1]=0,i.right[2]=0,i.right[3]=0,i.right[4]=0,i.right[5]=c,i.right[6]=0,i.right[7]=0,i.right[8]=-((u-l)*d*.5),i.right[9]=(o-s)*c*.5,i.right[10]=r/(e-r),i.right[11]=-1,i.right[12]=0,i.right[13]=0,i.right[14]=r*e/(e-r),i.right[15]=0}return i},n.prototype.getEyeFieldOfView=function(){var t=this.viewer,e=this.device,r=new Distortion(t.distortionCoefficients),i=t.screenLensDistance,o=(e.widthMeters-t.interLensDistance)/2,s=t.interLensDistance/2,u=t.baselineLensDistance-e.bevelMeters,l=e.heightMeters-u,d=RAD_TO_DEG*Math.atan(r.distort(o/i)),c=RAD_TO_DEG*Math.atan(r.distort(s/i)),f=RAD_TO_DEG*Math.atan(r.distort(u/i)),h=RAD_TO_DEG*Math.atan(r.distort(l/i)),v=new FieldOfView,A=new FieldOfView;return v.leftDegrees=Math.min(d,t.fov),v.rightDegrees=Math.min(c,t.fov),v.downDegrees=Math.min(f,t.fov),v.upDegrees=Math.min(h,t.fov),A.leftDegrees=v.rightDegrees,A.rightDegrees=v.leftDegrees,A.upDegrees=v.upDegrees,A.downDegrees=v.downDegrees,{left:v,right:A}},n.prototype.onDeviceOrientation_=function(t){this._deviceOrientationQ=this._deviceOrientationQ||new THREE__namespace.Quaternion;var e=t.alpha,r=t.beta,i=t.gamma;e=(e||0)*Math.PI/180,r=(r||0)*Math.PI/180,i=(i||0)*Math.PI/180,this._deviceOrientationQ.setFromEuler(new THREE__namespace.Euler(e,r,-i,"YXZ"))},n.prototype.onDeviceMotion_=function(t){this.updateDeviceMotion_(t)},n.prototype.updateDeviceMotion_=function(t){var e=t.accelerationIncludingGravity,r=t.rotationRate,i=t.timeStamp/1e3,o=i-this.previousTimestampS;if(o<0){warnOnce("fusion-pose-sensor:invalid:non-monotonic","Invalid timestamps detected: non-monotonic timestamp from devicemotion"),this.previousTimestampS=i;return}else if(o<=MIN_TIMESTEP||o>MAX_TIMESTEP){warnOnce("fusion-pose-sensor:invalid:outside-threshold","Invalid timestamps detected: Timestamp from devicemotion outside expected range."),this.previousTimestampS=i;return}e&&(this.accelerometer.set(-e.x,-e.y,-e.z),r&&(isR7()?this.gyroscope.set(-r.beta,r.alpha,r.gamma):this.gyroscope.set(r.alpha,r.beta,r.gamma),this.isDeviceMotionInRadians||this.gyroscope.multiplyScalar(Math.PI/180),this.filter.addGyroMeasurement(this.gyroscope,i)),this.filter.addAccelMeasurement(this.accelerometer,i)),this.previousTimestampS=i},n.prototype.onOrientationChange_=function(){this.setScreenTransform_()},n.prototype.onMessage_=function(t){var e=t.data;if(!(!e||!e.type)){var r=e.type.toLowerCase();r==="devicemotion"&&this.updateDeviceMotion_(e.deviceMotionEvent)}},n.prototype.setScreenTransform_=function(){this.worldToScreenQ.set(0,0,0,1);var t=typeof window<"u"?window.orientation:0;switch(t){case 0:break;case 90:this.worldToScreenQ.setFromAxisAngle(new THREE__namespace.Vector3(0,0,1),-Math.PI/2);break;case-90:this.worldToScreenQ.setFromAxisAngle(new THREE__namespace.Vector3(0,0,1),Math.PI/2);break}this.inverseWorldToScreenQ.copy(this.worldToScreenQ),this.inverseWorldToScreenQ.inverse()},n}(),defaultLeftBounds=[0,0,.5,1],defaultRightBounds=[.5,0,.5,1],Cardboard=function(){function n(t){var e=this;this.renderer=t,this.sensor=new Sensor(.98,.04,!1,!1),this.scale=1,this.cameraL=new THREE__namespace.PerspectiveCamera,this.cameraR=new THREE__namespace.PerspectiveCamera;var r=this.sensor.start();this.dispose=function(){var i=e.renderer.getSize(new THREE__namespace.Vector2);e.renderer.setScissor(0,0,i.width,i.height),e.renderer.setViewport(0,0,i.width,i.height),e.renderer.setScissorTest(!1),r()}}return n.prototype.render=function(t,e){var r=this.renderer.getSize(new THREE__namespace.Vector2);if(r.width>r.height){var i=t.autoUpdate;i&&(t.updateMatrixWorld(),t.autoUpdate=!1);var o={x:Math.round(r.width*defaultLeftBounds[0]),y:Math.round(r.height*defaultLeftBounds[1]),width:Math.round(r.width*defaultLeftBounds[2]),height:Math.round(r.height*defaultLeftBounds[3])},s={x:Math.round(r.width*defaultRightBounds[0]),y:Math.round(r.height*defaultRightBounds[1]),width:Math.round(r.width*defaultRightBounds[2]),height:Math.round(r.height*defaultRightBounds[3])};this.renderer.setScissorTest(!0),this.renderer.autoClear&&this.renderer.clear(),e.parent===null&&e.updateMatrixWorld(),e.matrixWorld.decompose(this.cameraL.position,this.cameraL.quaternion,this.cameraL.scale),e.matrixWorld.decompose(this.cameraR.position,this.cameraR.quaternion,this.cameraR.scale);var u=this.sensor.getEyeOffset();this.cameraL.translateOnAxis(new THREE__namespace.Vector3().fromArray(u.left),this.scale),this.cameraR.translateOnAxis(new THREE__namespace.Vector3().fromArray(u.right),this.scale);var l=this.sensor.getEyeProjectionMatrix();this.cameraL.projectionMatrix.elements=l.left.slice(),this.cameraR.projectionMatrix.elements=l.right.slice(),this.renderer.setViewport(o.x,o.y,o.width,o.height),this.renderer.setScissor(o.x,o.y,o.width,o.height),this.renderer.render(t,this.cameraL),this.renderer.setViewport(s.x,s.y,s.width,s.height),this.renderer.setScissor(s.x,s.y,s.width,s.height),this.renderer.render(t,this.cameraR),this.renderer.setViewport(0,0,r.width,r.height),this.renderer.setScissor(0,0,r.width,r.height),this.renderer.setScissorTest(!1),i&&(t.autoUpdate=!0)}else this.renderer.render(t,e)},n.prototype.dispose=function(){},n}();const cardboard="data:image/png;base64,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",phone="data:image/png;base64,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";var _a,LOCALE={zh:{TITLE:"眼镜模式",HIT:"请将手机横屏放入 VR 眼镜中"},en:{TITLE:"GLASSES MODE",HIT:"Please put the mobile phone horizontally into the VR glasses."},ja:{TITLE:"メガネモード",HIT:"携帯電話をVRメガネに水平に入れてください。"}},TEXT=typeof navigator<"u"&&(_a=LOCALE[navigator.language.split("-")[0]])!==null&&_a!==void 0?_a:LOCALE.zh,CONTENTS=`
|
|
1468
1468
|
<style>
|
|
1469
1469
|
.$id {
|
|
1470
1470
|
all: initial;
|
|
@@ -1815,7 +1815,7 @@ void main() {
|
|
|
1815
1815
|
|
|
1816
1816
|
gl_FragColor = vec4(gl_FragColor.rgb, gl_FragColor.a * opacity * outside * inside);
|
|
1817
1817
|
}
|
|
1818
|
-
`,PanoSphereMesh=function(n){__extends(t,n);function t(){var e=n.call(this)||this;e.progress=0,e.opacity=0,e.loading=!1,e.current=!1,e.disabled=!1,e.currentMotion=new Motion({ringScale:1.1,ringOpacity:0,circleFade:0,circleOpacity:.85,circleScale:1}),e.opacityMotion=new Motion({opacity:0}),e.loadingMotion=new Motion({opacity:0}),e.disableMotion=new Motion({opacity:0});var r={blending:THREE__namespace.CustomBlending,blendSrc:THREE__namespace.SrcAlphaFactor,blendDst:THREE__namespace.OneMinusSrcAlphaFactor,blendSrcAlpha:THREE__namespace.OneFactor,blendDstAlpha:THREE__namespace.OneMinusSrcAlphaFactor,depthWrite:!1,transparent:!0};return e.hitTestMesh=new THREE__namespace.Mesh(sharedGeometry$1,new THREE__namespace.MeshBasicMaterial(__assign(__assign({},r),{color:0,opacity:0}))),e.hitTestMesh.scale.set(1.5,1.5,1.5),e.ringMesh=new THREE__namespace.Mesh(sharedGeometry$1,new THREE__namespace.ShaderMaterial(__assign(__assign({},r),{vertexShader:ringVertexShader,fragmentShader:ringFragmentShader,uniforms:{opacity:{value:0}}}))),e.panoMesh=new THREE__namespace.Mesh(sharedGeometry$1,new THREE__namespace.ShaderMaterial(__assign(__assign({},r),{vertexShader:vertexShader$1,fragmentShader:fragmentShader$1,uniforms:{circleScale:{value:1.1},circleFade:{value:0},circleOpacity:{value:.5},loadingAngle:{value:0},loadingOpacity:{value:0},opacity:{value:0},disable:{value:0}}}))),e.add(e.hitTestMesh),e.add(e.ringMesh),e.add(e.panoMesh),e.renderOrder=1e4,e.needsRender=!0,e}return t.prototype.setProgress=function(e){this.progress=e,this.setLoading(e>0)},t.prototype.setOpacity=function(e){this.opacity!==e&&(this.opacity=e=clamp(e,0,1),this.opacityMotion.set({opacity:e},30).catch(noop$1))},t.prototype.setCurrent=function(e){if(this.current!==e){if(e){var r=[{progress:0,value:{ringScale:2,ringOpacity:0,circleFade:0,circleOpacity:.85,circleScale:1}},{progress:.05,value:{ringScale:1,ringOpacity:1,circleFade:0,circleOpacity:.85,circleScale:1}},{progress:.15,value:{ringScale:1.2,ringOpacity:1,circleFade:0,circleOpacity:.85,circleScale:1}},{progress:.25,value:{ringScale:1.1,ringOpacity:1,circleFade:0,circleOpacity:.85,circleScale:1}},{progress:.8,value:{ringScale:1.1,ringOpacity:1,circleFade:1,circleOpacity:.85,circleScale:1}},{progress:.9,value:{ringScale:1.1,ringOpacity:1,circleFade:1,circleOpacity:.65,circleScale:.8}},{progress:.92,value:{ringScale:1.1,ringOpacity:1,circleFade:1,circleOpacity:.65,circleScale:.8}},{progress:1,value:{ringScale:1.1,ringOpacity:1,circleFade:1,circleOpacity:.85,circleScale:1.1}}];this.currentMotion.setKeyframes(r,1500).catch(noop$1)}else{var r=[{progress:0,value:__assign({},this.currentMotion.value)},{progress:1,value:{ringScale:1.1,ringOpacity:0,circleFade:0,circleOpacity:.85,circleScale:1}}];this.currentMotion.setKeyframes(r,200).catch(noop$1)}this.current=e}},t.prototype.setLoading=function(e){this.loading!==e&&(e?this.loadingMotion.setKeyframes([{progress:0,value:{opacity:0}},{progress:.3,value:{opacity:0}},{progress:1,value:{opacity:.8}}],500).catch(noop$1):this.loadingMotion.set({opacity:0},0).catch(noop$1),this.loading=e,this.disabled===!0&&this.setDisabled(!1),this.needsRender=!0)},t.prototype.setDisabled=function(e){this.disabled!==e&&(this.disabled=e,this.loading===!0&&this.setLoading(!1),this.disableMotion.set({opacity:e?1:0},300).catch(noop$1),this.needsRender=!0)},t.prototype.tap=function(){return Promise.resolve()},t.prototype.updateTime=function(e,r){this.opacityMotion.update(e),this.currentMotion.update(e),this.loadingMotion.update(e);var i=this.opacityMotion.value.opacity;this.visible=i!==0;var o=this.currentMotion.value,s=o.ringScale,u=o.ringOpacity,l=o.circleFade,d=o.circleOpacity,c=o.circleScale;this.ringMesh.scale.set(s,1,s),this.ringMesh.material.uniforms.opacity.value=u*i,this.panoMesh.material.uniforms.opacity.value=i,this.panoMesh.material.uniforms.circleOpacity.value=d,this.panoMesh.material.uniforms.circleScale.value=c,this.panoMesh.material.uniforms.circleFade.value=l,this.panoMesh.material.uniforms.loadingOpacity.value=this.loadingMotion.value.opacity,this.panoMesh.material.uniforms.disable.value=this.disableMotion.value.opacity,this.panoMesh.material.uniforms.loadingAngle.value=e/120%(Math.PI*2),this.needsRender=!0},t.prototype.dispose=function(){this.hitTestMesh.material.dispose(),this.ringMesh.material.dispose(),this.panoMesh.material.dispose()},t}(THREE__namespace.Object3D),ACTIVE_TO_CURRENT_DELAY=1500,VRPanoramaController=function(n){__extends(t,n);function t(e){var r=this,i=t.parseArgs(e);r=n.call(this,i)||this,r.mode="VRPanorama",r.cardboard=new Cardboard(r.renderer);var o=createHelper();r.helperElement=o;var s=new Hammer(o);return r.element.parentNode&&(r.element.parentNode.insertBefore(o,r.element),r.setHelperElementSize(),s.on("tap",function(){return r.emit("vr.requestExit",createEvent("vr.requestExit",{}))})),r.destroyHelper=function(){s.destroy(),o.parentNode&&o.parentNode.removeChild(o),delete r.helperElement},r}return t.parseArgs=function(e){if(e instanceof t)return e;var r=__assign(__assign({},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 __assign(__assign({},i),{mode:"VRPanorama"})},t.prototype.destroy=function(){n.prototype.destroy.call(this),this.cardboard.dispose(),this.destroyHelper();for(var e=Object.keys(this.panoMeshes),r=0,i=e;r<i.length;r++){var o=i[r],s=this.panoMeshes[o];this.helper.remove(s),s.dispose(),delete this.panoMeshes[o]}},t.prototype.isReady=function(){return!1},t.prototype.updateRenderSize=function(){this.needsRender=!0,this.setHelperElementSize()},t.prototype.updateCamera=function(e,r,i){return Promise.resolve()},t.prototype.updateCameraWithKeyframes=function(e,r,i){return Promise.resolve()},t.prototype.updatePanoMeshesVisible=function(){for(var e=this.works.getResolvedObserver(this.currentPano),r=(e?e.visibleIds:[]).concat(panoStringify(this.currentPano)),i=0,o=this.works.resolvedObservers;i<o.length;i++){var s=o[i],u=this.panoMeshes[s.panoId];u&&(r.indexOf(s.panoId)>=0?u.parent!==this.helper&&this.helper.add(u):u.parent===this.helper&&(this.helper.remove(u),u.setOpacity(0)))}},t.prototype.updatePanoMeshes=function(){for(var e=Object.keys(this.panoMeshes),r=0,i=e;r<i.length;r++){var o=i[r],s=this.panoMeshes[o];this.helper.remove(s),s.dispose(),delete this.panoMeshes[o]}for(var u=0,l=this.works.resolvedObservers;u<l.length;u++){var d=l[u],c=d.panoId,f=new PanoSphereMesh;f.name="panoSphere_".concat(c),f.position.copy(d.position),f.needsRender=!0,this.panoMeshes[c]=f}this.updatePanoMeshesVisible()},t.prototype.updateTime=function(e,r){var i,o,s,u,l,d;if(!this.destroyed){var c=this.currentPano;this.userAction=!0,this.needsRender=!0;var f={},h={};if(this.modelAlphaMotion.ended===!1&&(this.modelAlphaMotion.update(e),f.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);var v=this.locationMotion.getKeyFrameSegment(e),A=v[0],m=v[1],y=this.panoResourceFromLocationMotionKeyframe(A),p=this.panoResourceFromLocationMotionKeyframe(m),g=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[0]),b=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[this.locationMotion.keyframes.length-1]),T=y.position,_=p.position,w=this.locationMotion.value.count-m.value.count+1;f.useBlackTransition=p.effect==="instant",p.panoPicture&&(w<1?y.panoPicture&&(f.pano0=y.panoPicture):f.pano0=p.panoPicture,f.pano1=p.panoPicture),p.effect==="fade"&&(f.pano0&&y.panoPicture&&(f.pano0={map:f.pano0.map,luminanceMap:f.pano0.luminanceMap,matrix:y.panoPicture.matrix.clone().setPosition(p.position)}),T.copy(_)),f.progress=w,h.distance=this.locationMotion.value.distance,h.offset=new THREE__namespace.Vector3(T.x+(_.x-T.x)*w,T.y+(_.y-T.y)*w,T.z+(_.z-T.z)*w);for(var x=[],M=[],R=0,I=this.locationMotion.keyframes;R<I.length;R++){var S=I[R],B=S.key,F=S.progress;B!==void 0&&(x.push(B),F>=this.locationMotion.progress&&M.push(B))}for(var O=0,H=Object.keys(this.panoResources);O<H.length;O++){var k=H[O];if(!(M.indexOf(k)>=0)){var N=this.panoResources[k];if(N.panoPicture){var q=N.panoPicture.map;if(q){if(q===((i=f.pano0)===null||i===void 0?void 0:i.map)||q===((o=f.pano1)===null||o===void 0?void 0:o.map))continue;q.dispose(),N.panoPicture=null}}x.indexOf(k)>=0||delete this.panoResources[k]}}this.currentPano=panoParse(p.panoId),this.emit("pano.moving",createEvent("pano.moving",{userAction:this.userAction,prevPano:panoParse(g.panoId),state:__assign(__assign(__assign(__assign({},panoParse(b.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),h),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(f)===!1&&(!((s=f.pano0)===null||s===void 0)&&s.map&&f.pano0.map instanceof TileCubeTextureTarget&&!f.pano0.map.cubeRenderTarget&&(f.pano0.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((u=f.pano0)===null||u===void 0)&&u.luminanceMap&&f.pano0.luminanceMap instanceof TileCubeTextureTarget&&!f.pano0.luminanceMap.cubeRenderTarget&&(f.pano0.luminanceMap.cubeRenderTarget=this.luminanceCubeRenderTargetPool.pop()),!((l=f.pano1)===null||l===void 0)&&l.map&&f.pano1.map instanceof TileCubeTextureTarget&&!f.pano1.map.cubeRenderTarget&&(f.pano1.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((d=f.pano1)===null||d===void 0)&&d.luminanceMap&&f.pano1.luminanceMap instanceof TileCubeTextureTarget&&!f.pano1.luminanceMap.cubeRenderTarget&&(f.pano1.luminanceMap.cubeRenderTarget=this.luminanceCubeRenderTargetPool.pop()),this.models.setMaterial(f)),h.offset&&this.camera.position.copy(h.offset),panoEqual(this.currentPano,c)&&this.updatePanoMeshesVisible();var V=this.camera.pose.longitude,D=this.camera.pose.latitude;this.camera.quaternion.fromArray(this.cardboard.sensor.getOrientation()),this.camera.updateMatrixWorld(),this.camera.computePose();var K=this.works.getResolvedObserver(this.currentPano);if(K)for(var z=K.visibleIds.concat(panoStringify(this.currentPano)),G=0,W=z;G<W.length;G++){var Q=W[G],X=panoParse(Q),ee=this.works.getResolvedObserver(X);if(ee){var J=this.panoMeshes[Q];if(!ee.loadable&&!ee.active){J.setOpacity(0);continue}var Z=J.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);Z<.05?J.setOpacity(0):J.setOpacity(clamp(1.5/Z,0,1)),panoEqual(this.currentPano,X)&&J.setOpacity(0),J.lookAt(this.camera.position)}}for(var te=this.intersect(e),ae=0,re=this.works.resolvedObservers;ae<re.length;ae++){var ee=re[ae],J=this.panoMeshes[ee.panoId];J&&(J.setCurrent(J===te),J.updateTime&&J.updateTime(e,r))}(V!==this.camera.pose.longitude||D!==this.camera.pose.latitude)&&(this.cameraMotion.set(pick(this.camera.pose,["longitude","latitude"]),0).catch(noop$1),this.emit("camera.update",createEvent("camera.update",{userAction:!0,state:__assign(__assign(__assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose))})))}},t.prototype.render=function(){this.cardboard.render(this.scene,this.camera)},t.prototype.setCamera=function(e){},t.prototype.destroyHelper=function(){},t.prototype.setHelperElementSize=function(){if(this.helperElement){var e=new THREE__namespace.Vector2(this.element.offsetWidth,this.element.offsetHeight),r=e.x*this.scissor.left,i=e.y*(1-this.scissor.bottom-this.scissor.height),o=e.x*this.scissor.width,s=e.y*this.scissor.height;this.helperElement.style.marginLeft=r+"px",this.helperElement.style.marginTop=i+"px",this.helperElement.style.width=o+"px",this.helperElement.style.height=s+"px"}},t.prototype.intersect=function(e){var r,i;if(this.locationMotion.ended===!1){this.intersectMesh.visible=!1,delete this.activePanoMesh,delete this.activeTime;return}if(this.activePanoMesh&&this.activeTime&&e-this.activeTime>ACTIVE_TO_CURRENT_DELAY){for(var o=this.activePanoMesh,s=Object.keys(this.panoMeshes),u=null,l=0,d=s;l<d.length;l++){var c=d[l];if(this.panoMeshes[c]===o){u=c;break}}return u!==null&&this.moveToPano(panoParse(u),{},!0),delete this.activePanoMesh,delete this.activeTime,o}var f=this.camera.getDirection(new THREE__namespace.Vector3),h=new THREE__namespace.Raycaster(this.camera.position,f);h.params.Points={threshold:.1};for(var v=void 0,A=[],m=this.works.getResolvedObserver(this.currentPano),y=m?m.visibleIds:[],p=0,g=y;p<g.length;p++){var u=g[p],b=this.panoMeshes[u],T=h.intersectObject((r=b.hitTestMesh)!==null&&r!==void 0?r:b,!0)[0];T&&A.push({panoMesh:b,intersection:__assign({floor:(i=m==null?void 0:m.floorIndex)!==null&&i!==void 0?i:0},T)})}var _=A.sort(function(S,B){return S.intersection.distance-B.intersection.distance})[0];_?(v=_.intersection,this.activePanoMesh!==_.panoMesh&&(this.activePanoMesh=_.panoMesh,this.activeTime=e),this.intersectMesh.position.copy(_.panoMesh.position),this.intersectMesh.lookAt(this.camera.position),this.intersectMesh.visible=!1):(this.activePanoMesh=void 0,this.activeTime=void 0),v||(v=this.models.intersectRaycaster(h)[0]);var w=createEvent("intersect.update",{raycaster:h,intersection:v??null,object:this.intersectMesh});if(this.emit("intersect.update",w),w.defaultPrevented){this.hideIntersectMesh();return}if(v&&v.face){var x=v.face.normal,M=new THREE__namespace.Quaternion;M.setFromUnitVectors(new THREE__namespace.Vector3(0,0,1),x),this.intersectMesh.quaternion.copy(M);var R=x.clone().multiplyScalar(.05),I=v.point.clone().add(R);this.intersectMesh.position.copy(I),this.intersectMesh.visible=!0}else this.intersectMesh.visible=!1;return _==null?void 0:_.panoMesh},t.prototype.onPanGesture=function(){},t.prototype.onTapGesture=function(){},t.prototype.onPinchGesture=function(){},t.prototype.onMouseMove=function(){},t.prototype.onMouseOut=function(){},t}(PanoramaController),HUMAN_EYE_POSITION=new THREE__namespace.Vector3(0,1.6,0),ModelController=function(n){__extends(t,n);function t(e){var r=this,i,o=t.parseArgs(e);return r=n.call(this,o)||this,r.mode="Model",r.locationMotion=new Motion({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 Motion({modelAlpha:(i=r.models.getMaterial().modelAlpha)!==null&&i!==void 0?i:0}),r.perspToOrthoMotion=new Motion({perspToOrtho:r.camera.perspToOrtho.x}),r}return t.parseArgs=function(e){return e instanceof t?e:n.parseArgs.call(this,e)},t.initAnimationEndState=function(e){var r,i,o,s,u,l,d=this.parseArgs(e),c=d.works,f=e.initial,h=f.state,v=f.currentState,A=typeof h.panoIndex=="number"?{workCode:(o=(r=h.workCode)!==null&&r!==void 0?r:(i=d.works[0])===null||i===void 0?void 0:i.workCode)!==null&&o!==void 0?o:"",panoIndex:h.panoIndex}:{workCode:v.workCode,panoIndex:v.panoIndex},m=c.getResolvedObserver(A),y=(s=h.longitude)!==null&&s!==void 0?s:v.longitude,p=clamp((u=h.latitude)!==null&&u!==void 0?u:!m||isFristPersonMode(v.mode)?v.latitude:d.defaultLatitude,d.minLatitude,d.maxLatitude),g=clamp((l=h.fov)!==null&&l!==void 0?l:!m||isFristPersonMode(v.mode)?v.fov:d.defaultFov,d.minFov,d.maxFov),b=new THREE__namespace.Vector3;if(d.initial.state.offset)b.copy(d.initial.state.offset);else if(m)b.copy(m.position);else{var T=coordinatesToVector(v).setLength(v.distance);b.copy(d.initial.currentState.offset).sub(T)}return{workCode:A.workCode,panoIndex:A.panoIndex,mode:"Model",longitude:y,latitude:p,fov:g,offset:b,distance:0}},t.prototype.destroy=function(){n.prototype.destroy.call(this),this.locationMotion.dispose()},t.prototype.isReady=function(){return this.locationMotion.ended!==!1},t.prototype.updateWork=function(e,r,i,o){this.works=e;var s=t.initAnimationEndState(__assign(__assign({},this),{initial:{currentState:__assign(__assign({},this.currentPano),this.camera.pose),duration:i,state:r,userAction:o}}));this.hideIntersectMesh();var u={duration:0,longitude:s.longitude,latitude:s.latitude,fov:s.fov};return this.moveToPosition(s.offset,u,o),!0},t.prototype.updateCamera=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();var s={},u={};return s.distance=0,e.offset!==void 0&&(s.x=e.offset.x,s.y=e.offset.y,s.z=e.offset.z),e.longitude!==void 0&&(u.longitude=e.longitude),e.latitude!==void 0&&(u.latitude=e.latitude),e.fov!==void 0&&(u.fov=e.fov),o.locationMotion.set(s,r).catch(noop$1),o.cameraMotion.set(u,r).catch(noop$1)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();for(var s=[],u=[],l=0,d=e;l<d.length;l++){var c=d[l];s.push({key:c.key,progress:c.progress,value:{distance:0,x:c.value.offset.x,y:c.value.offset.x,z:c.value.offset.x}}),u.push({key:c.key,progress:c.progress,value:{longitude:c.value.longitude,latitude:c.value.latitude,fov:c.value.fov}})}return o.locationMotion.setKeyframes(s,r).catch(noop$1),o.cameraMotion.setKeyframes(e,r)})},t.prototype.updateTime=function(e,r){if(!this.destroyed){var i={},o={};if(this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),i.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),!this.locationMotion.ended){this.locationMotion.update(e),o.distance=this.locationMotion.value.distance,o.offset=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z);var s=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),u=this.works.resolvedObservers,l=arrayMin(u,function(d){return d.position.distanceTo(s)});this.currentPano=l?{workCode:l.work.workCode,panoIndex:l.panoIndex}:{workCode:"",panoIndex:0}}this.cameraMotion.ended||(this.cameraMotion.update(e),o.longitude=this.cameraMotion.value.longitude,o.latitude=this.cameraMotion.value.latitude,o.fov=this.cameraMotion.value.fov),isEmptyObject(i)||this.models.setMaterial(i),isEmptyObject(o)||this.setCamera(o)}},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 o=i.duration,s=i.userAction;e.userAction=s;var u=t.initAnimationEndState(e),l={modelAlpha:1},d={perspToOrtho:0},c={longitude:u.longitude,latitude:u.latitude,fov:u.fov,duration:o,moveStartCallback:function(f){e.perspToOrthoMotion.set(d,o).catch(noop$1),e.modelAlphaMotion.set(l,o).catch(noop$1),e.emit("initAnimation.start",createEvent("initAnimation.start",{state:f,userAction:e.userAction}))},moveEndCallback:function(f){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:f,userAction:e.userAction})),r()},moveCancelCallback:function(){var f=e.currentPano,h=__assign(__assign({},f),{mode:e.mode,longitude:e.camera.pose.longitude,latitude:e.camera.pose.latitude,fov:e.camera.pose.fov,offset:e.camera.pose.offset.clone(),distance:e.camera.pose.distance});e.emit("initAnimation.end",createEvent("initAnimation.end",{state:h,userAction:e.userAction})),r()}};e.moveToPosition(u.offset,c,s)})},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1],r=this.locationMotion.getKeyFrameSegment(now())[1];return __assign(__assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:new THREE__namespace.Vector3(r.value.x,r.value.y,r.value.z),distance:r.value.distance})},t.prototype.moveToPano=function(e,r,i){r===void 0&&(r={});var o=this.works.getResolvedObserver(e);o&&this.moveToPosition(o.position,r,i)},t.prototype.moveToPosition=function(e,r,i){var o=this,s,u,l;r===void 0&&(r={}),this.userAction=i,this.stopMomentumMovement();for(var d=now(),c=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),f=c.distanceTo(e),h=this.locationMotion.getProgressVelocity(d),v=0,A=1;A<this.locationMotion.keyframes.length;A++){var m=this.locationMotion.keyframes[A-1].value,y=m.x,p=m.y,g=m.z,b=this.locationMotion.keyframes[A].value,T=b.x,_=b.y,w=b.z;v+=Math.sqrt(Math.pow(T-y,2)+Math.pow(_-p,2)+Math.pow(w-g,2))}var x=f===0?0:h*v/f,M=this.calculateMovingDuration(r.duration,f),R={x:e.x,y:e.y,z:e.z,distance:0},I={longitude:r.longitude,latitude:r.latitude,fov:r.fov},S=this.works.resolvedObservers,B=arrayMin(S,function(k){return k.position.distanceTo(c)}),F=B?{workCode:B.work.workCode,panoIndex:B.panoIndex}:{workCode:"",panoIndex:0},O=__assign(__assign({},F),{mode:this.mode,longitude:(s=I.longitude)!==null&&s!==void 0?s:this.camera.pose.longitude,latitude:(u=I.latitude)!==null&&u!==void 0?u:this.camera.pose.latitude,fov:(l=I.fov)!==null&&l!==void 0?l:this.camera.pose.fov,offset:e.clone(),distance:0}),H=this.currentPano;this.emit("pano.moveTo",createEvent("pano.moveTo",{options:r,prevPano:H,progress:0,state:O,userAction:this.userAction,error:null})),r.moveStartCallback&&r.moveStartCallback(O),this.cameraMotion.set(I,M).catch(noop$1),this.locationMotion.set(R,M,x).then(function(){var k=__assign(__assign(__assign({},F),{mode:o.mode}),clonePose(o.camera.pose));o.emit("pano.arrived",createEvent("pano.arrived",{options:r,prevPano:H,progress:0,state:k,userAction:o.userAction,error:null})),r.moveEndCallback&&r.moveEndCallback(k)},function(){r.moveCancelCallback&&r.moveCancelCallback(),o.emit("pano.cancel",createEvent("pano.cancel",{options:r,prevPano:H,progress:0,state:O,userAction:o.userAction,error:null}))})},t.prototype.onTapGesture=function(e){var r=e.center.raycaster;this.stopMomentumMovement();var i=this.models.intersectRaycaster(r)[0];if(i&&i.face){var o=i.face.normal,s=i.point;if(new THREE__namespace.Vector3(0,1,0).angleTo(o)>Math.PI/3){var u=o.clone().setLength(.3).add(s);r.set(u,new THREE__namespace.Vector3(0,-1,0)),i=this.models.intersectRaycaster(r)[0]}}if(i){var l=new THREE__namespace.Vector3().copy(i.point).add(HUMAN_EYE_POSITION),d=this.works.resolvedObservers,c=arrayMin(d,function(v){return v.position.distanceTo(l)},!0),f=c[0],h=c[1];f&&h<5&&(l.y=f.position.y),e.state.offset.copy(l),e.state.distance=0,this.emit("gesture.tap",e),e.defaultPrevented||this.moveToPosition(l,{},!0)}else this.emit("gesture.tap",e),e.defaultPrevented||this.cameraBounce()},t}(PanoramaLikeController);const vertexShader=function n(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}(`{vs|z-rp@-}n{|]|vv|{H{vs|z-znA-}n{|Znv\x07H{vs|z-nz}yr?Q-}n{|Qv}ynprzr{Zn}H<<{vs|z-sy|n-pnyrHn\bv{t-rp@-}n{|d|yq]|vv|{H<<-n\bv{t-sy|n-vU|yrHp|{-sy|n-]V-J-@;>A>BF?CHp|{-sy|n-aNb-J-C;?E@>EB?Hp|{-sy|n-pnyr-J->@;>Hrp?-|P||q5rp@-rp|6-
|
|
1818
|
+
`,PanoSphereMesh=function(n){__extends(t,n);function t(){var e=n.call(this)||this;e.progress=0,e.opacity=0,e.loading=!1,e.current=!1,e.disabled=!1,e.currentMotion=new Motion({ringScale:1.1,ringOpacity:0,circleFade:0,circleOpacity:.85,circleScale:1}),e.opacityMotion=new Motion({opacity:0}),e.loadingMotion=new Motion({opacity:0}),e.disableMotion=new Motion({opacity:0});var r={blending:THREE__namespace.CustomBlending,blendSrc:THREE__namespace.SrcAlphaFactor,blendDst:THREE__namespace.OneMinusSrcAlphaFactor,blendSrcAlpha:THREE__namespace.OneFactor,blendDstAlpha:THREE__namespace.OneMinusSrcAlphaFactor,depthWrite:!1,transparent:!0};return e.hitTestMesh=new THREE__namespace.Mesh(sharedGeometry$1,new THREE__namespace.MeshBasicMaterial(__assign(__assign({},r),{color:0,opacity:0}))),e.hitTestMesh.scale.set(1.5,1.5,1.5),e.ringMesh=new THREE__namespace.Mesh(sharedGeometry$1,new THREE__namespace.ShaderMaterial(__assign(__assign({},r),{vertexShader:ringVertexShader,fragmentShader:ringFragmentShader,uniforms:{opacity:{value:0}}}))),e.panoMesh=new THREE__namespace.Mesh(sharedGeometry$1,new THREE__namespace.ShaderMaterial(__assign(__assign({},r),{vertexShader:vertexShader$1,fragmentShader:fragmentShader$1,uniforms:{circleScale:{value:1.1},circleFade:{value:0},circleOpacity:{value:.5},loadingAngle:{value:0},loadingOpacity:{value:0},opacity:{value:0},disable:{value:0}}}))),e.add(e.hitTestMesh),e.add(e.ringMesh),e.add(e.panoMesh),e.renderOrder=1e4,e.needsRender=!0,e}return t.prototype.setProgress=function(e){this.progress=e,this.setLoading(e>0)},t.prototype.setOpacity=function(e){this.opacity!==e&&(this.opacity=e=clamp(e,0,1),this.opacityMotion.set({opacity:e},30).catch(noop$1))},t.prototype.setCurrent=function(e){if(this.current!==e){if(e){var r=[{progress:0,value:{ringScale:2,ringOpacity:0,circleFade:0,circleOpacity:.85,circleScale:1}},{progress:.05,value:{ringScale:1,ringOpacity:1,circleFade:0,circleOpacity:.85,circleScale:1}},{progress:.15,value:{ringScale:1.2,ringOpacity:1,circleFade:0,circleOpacity:.85,circleScale:1}},{progress:.25,value:{ringScale:1.1,ringOpacity:1,circleFade:0,circleOpacity:.85,circleScale:1}},{progress:.8,value:{ringScale:1.1,ringOpacity:1,circleFade:1,circleOpacity:.85,circleScale:1}},{progress:.9,value:{ringScale:1.1,ringOpacity:1,circleFade:1,circleOpacity:.65,circleScale:.8}},{progress:.92,value:{ringScale:1.1,ringOpacity:1,circleFade:1,circleOpacity:.65,circleScale:.8}},{progress:1,value:{ringScale:1.1,ringOpacity:1,circleFade:1,circleOpacity:.85,circleScale:1.1}}];this.currentMotion.setKeyframes(r,1500).catch(noop$1)}else{var r=[{progress:0,value:__assign({},this.currentMotion.value)},{progress:1,value:{ringScale:1.1,ringOpacity:0,circleFade:0,circleOpacity:.85,circleScale:1}}];this.currentMotion.setKeyframes(r,200).catch(noop$1)}this.current=e}},t.prototype.setLoading=function(e){this.loading!==e&&(e?this.loadingMotion.setKeyframes([{progress:0,value:{opacity:0}},{progress:.3,value:{opacity:0}},{progress:1,value:{opacity:.8}}],500).catch(noop$1):this.loadingMotion.set({opacity:0},0).catch(noop$1),this.loading=e,this.disabled===!0&&this.setDisabled(!1),this.needsRender=!0)},t.prototype.setDisabled=function(e){this.disabled!==e&&(this.disabled=e,this.loading===!0&&this.setLoading(!1),this.disableMotion.set({opacity:e?1:0},300).catch(noop$1),this.needsRender=!0)},t.prototype.tap=function(){return Promise.resolve()},t.prototype.updateTime=function(e,r){this.opacityMotion.update(e),this.currentMotion.update(e),this.loadingMotion.update(e);var i=this.opacityMotion.value.opacity;this.visible=i!==0;var o=this.currentMotion.value,s=o.ringScale,u=o.ringOpacity,l=o.circleFade,d=o.circleOpacity,c=o.circleScale;this.ringMesh.scale.set(s,1,s),this.ringMesh.material.uniforms.opacity.value=u*i,this.panoMesh.material.uniforms.opacity.value=i,this.panoMesh.material.uniforms.circleOpacity.value=d,this.panoMesh.material.uniforms.circleScale.value=c,this.panoMesh.material.uniforms.circleFade.value=l,this.panoMesh.material.uniforms.loadingOpacity.value=this.loadingMotion.value.opacity,this.panoMesh.material.uniforms.disable.value=this.disableMotion.value.opacity,this.panoMesh.material.uniforms.loadingAngle.value=e/120%(Math.PI*2),this.needsRender=!0},t.prototype.dispose=function(){this.hitTestMesh.material.dispose(),this.ringMesh.material.dispose(),this.panoMesh.material.dispose()},t}(THREE__namespace.Object3D),ACTIVE_TO_CURRENT_DELAY=1500,VRPanoramaController=function(n){__extends(t,n);function t(e){var r=this,i=t.parseArgs(e);r=n.call(this,i)||this,r.mode="VRPanorama",r.cardboard=new Cardboard(r.renderer);var o=createHelper();r.helperElement=o;var s=new Hammer(o);return r.element.parentNode&&(r.element.parentNode.insertBefore(o,r.element),r.setHelperElementSize(),s.on("tap",function(){return r.emit("vr.requestExit",createEvent("vr.requestExit",{}))})),r.destroyHelper=function(){s.destroy(),o.parentNode&&o.parentNode.removeChild(o),delete r.helperElement},r}return t.parseArgs=function(e){if(e instanceof t)return e;var r=__assign(__assign({},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 __assign(__assign({},i),{mode:"VRPanorama"})},t.prototype.destroy=function(){n.prototype.destroy.call(this),this.cardboard.dispose(),this.destroyHelper();for(var e=Object.keys(this.panoMeshes),r=0,i=e;r<i.length;r++){var o=i[r],s=this.panoMeshes[o];this.helper.remove(s),s.dispose(),delete this.panoMeshes[o]}},t.prototype.isReady=function(){return!1},t.prototype.updateRenderSize=function(){this.needsRender=!0,this.setHelperElementSize()},t.prototype.updateCamera=function(e,r,i){return Promise.resolve()},t.prototype.updateCameraWithKeyframes=function(e,r,i){return Promise.resolve()},t.prototype.updatePanoMeshesVisible=function(){for(var e=this.works.getResolvedObserver(this.currentPano),r=(e?e.visibleIds:[]).concat(panoStringify(this.currentPano)),i=0,o=this.works.resolvedObservers;i<o.length;i++){var s=o[i],u=this.panoMeshes[s.panoId];u&&(r.indexOf(s.panoId)>=0?u.parent!==this.helper&&this.helper.add(u):u.parent===this.helper&&(this.helper.remove(u),u.setOpacity(0)))}},t.prototype.updatePanoMeshes=function(){for(var e=Object.keys(this.panoMeshes),r=0,i=e;r<i.length;r++){var o=i[r],s=this.panoMeshes[o];this.helper.remove(s),s.dispose(),delete this.panoMeshes[o]}for(var u=0,l=this.works.resolvedObservers;u<l.length;u++){var d=l[u],c=d.panoId,f=new PanoSphereMesh;f.name="panoSphere_".concat(c),f.position.copy(d.position),f.needsRender=!0,this.panoMeshes[c]=f}this.updatePanoMeshesVisible()},t.prototype.updateTime=function(e,r){var i,o,s,u,l,d;if(!this.destroyed){var c=this.currentPano;this.userAction=!0,this.needsRender=!0;var f={},h={};if(this.modelAlphaMotion.ended===!1&&(this.modelAlphaMotion.update(e),f.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);var v=this.locationMotion.getKeyFrameSegment(e),A=v[0],m=v[1],y=this.panoResourceFromLocationMotionKeyframe(A),p=this.panoResourceFromLocationMotionKeyframe(m),g=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[0]),b=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[this.locationMotion.keyframes.length-1]),T=y.position,_=p.position,w=this.locationMotion.value.count-m.value.count+1;f.useBlackTransition=p.effect==="instant",p.panoPicture&&(w<1?y.panoPicture&&(f.pano0=y.panoPicture):f.pano0=p.panoPicture,f.pano1=p.panoPicture),p.effect==="fade"&&(f.pano0&&y.panoPicture&&(f.pano0={map:f.pano0.map,luminanceMap:f.pano0.luminanceMap,matrix:y.panoPicture.matrix.clone().setPosition(p.position)}),T.copy(_)),f.progress=w,h.distance=this.locationMotion.value.distance,h.offset=new THREE__namespace.Vector3(T.x+(_.x-T.x)*w,T.y+(_.y-T.y)*w,T.z+(_.z-T.z)*w);for(var x=[],M=[],R=0,I=this.locationMotion.keyframes;R<I.length;R++){var S=I[R],B=S.key,O=S.progress;B!==void 0&&(x.push(B),O>=this.locationMotion.progress&&M.push(B))}for(var F=0,H=Object.keys(this.panoResources);F<H.length;F++){var k=H[F];if(!(M.indexOf(k)>=0)){var N=this.panoResources[k];if(N.panoPicture){var q=N.panoPicture.map;if(q){if(q===((i=f.pano0)===null||i===void 0?void 0:i.map)||q===((o=f.pano1)===null||o===void 0?void 0:o.map))continue;q.dispose(),N.panoPicture=null}}x.indexOf(k)>=0||delete this.panoResources[k]}}this.currentPano=panoParse(p.panoId),this.emit("pano.moving",createEvent("pano.moving",{userAction:this.userAction,prevPano:panoParse(g.panoId),state:__assign(__assign(__assign(__assign({},panoParse(b.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),h),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(f)===!1&&(!((s=f.pano0)===null||s===void 0)&&s.map&&f.pano0.map instanceof TileCubeTextureTarget&&!f.pano0.map.cubeRenderTarget&&(f.pano0.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((u=f.pano0)===null||u===void 0)&&u.luminanceMap&&f.pano0.luminanceMap instanceof TileCubeTextureTarget&&!f.pano0.luminanceMap.cubeRenderTarget&&(f.pano0.luminanceMap.cubeRenderTarget=this.luminanceCubeRenderTargetPool.pop()),!((l=f.pano1)===null||l===void 0)&&l.map&&f.pano1.map instanceof TileCubeTextureTarget&&!f.pano1.map.cubeRenderTarget&&(f.pano1.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((d=f.pano1)===null||d===void 0)&&d.luminanceMap&&f.pano1.luminanceMap instanceof TileCubeTextureTarget&&!f.pano1.luminanceMap.cubeRenderTarget&&(f.pano1.luminanceMap.cubeRenderTarget=this.luminanceCubeRenderTargetPool.pop()),this.models.setMaterial(f)),h.offset&&this.camera.position.copy(h.offset),panoEqual(this.currentPano,c)&&this.updatePanoMeshesVisible();var V=this.camera.pose.longitude,D=this.camera.pose.latitude;this.camera.quaternion.fromArray(this.cardboard.sensor.getOrientation()),this.camera.updateMatrixWorld(),this.camera.computePose();var K=this.works.getResolvedObserver(this.currentPano);if(K)for(var z=K.visibleIds.concat(panoStringify(this.currentPano)),G=0,W=z;G<W.length;G++){var Q=W[G],X=panoParse(Q),ee=this.works.getResolvedObserver(X);if(ee){var J=this.panoMeshes[Q];if(!ee.loadable&&!ee.active){J.setOpacity(0);continue}var Z=J.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);Z<.05?J.setOpacity(0):J.setOpacity(clamp(1.5/Z,0,1)),panoEqual(this.currentPano,X)&&J.setOpacity(0),J.lookAt(this.camera.position)}}for(var te=this.intersect(e),ae=0,re=this.works.resolvedObservers;ae<re.length;ae++){var ee=re[ae],J=this.panoMeshes[ee.panoId];J&&(J.setCurrent(J===te),J.updateTime&&J.updateTime(e,r))}(V!==this.camera.pose.longitude||D!==this.camera.pose.latitude)&&(this.cameraMotion.set(pick(this.camera.pose,["longitude","latitude"]),0).catch(noop$1),this.emit("camera.update",createEvent("camera.update",{userAction:!0,state:__assign(__assign(__assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose))})))}},t.prototype.render=function(){this.cardboard.render(this.scene,this.camera)},t.prototype.setCamera=function(e){},t.prototype.destroyHelper=function(){},t.prototype.setHelperElementSize=function(){if(this.helperElement){var e=new THREE__namespace.Vector2(this.element.offsetWidth,this.element.offsetHeight),r=e.x*this.scissor.left,i=e.y*(1-this.scissor.bottom-this.scissor.height),o=e.x*this.scissor.width,s=e.y*this.scissor.height;this.helperElement.style.marginLeft=r+"px",this.helperElement.style.marginTop=i+"px",this.helperElement.style.width=o+"px",this.helperElement.style.height=s+"px"}},t.prototype.intersect=function(e){var r,i;if(this.locationMotion.ended===!1){this.intersectMesh.visible=!1,delete this.activePanoMesh,delete this.activeTime;return}if(this.activePanoMesh&&this.activeTime&&e-this.activeTime>ACTIVE_TO_CURRENT_DELAY){for(var o=this.activePanoMesh,s=Object.keys(this.panoMeshes),u=null,l=0,d=s;l<d.length;l++){var c=d[l];if(this.panoMeshes[c]===o){u=c;break}}return u!==null&&this.moveToPano(panoParse(u),{},!0),delete this.activePanoMesh,delete this.activeTime,o}var f=this.camera.getDirection(new THREE__namespace.Vector3),h=new THREE__namespace.Raycaster(this.camera.position,f);h.params.Points={threshold:.1};for(var v=void 0,A=[],m=this.works.getResolvedObserver(this.currentPano),y=m?m.visibleIds:[],p=0,g=y;p<g.length;p++){var u=g[p],b=this.panoMeshes[u],T=h.intersectObject((r=b.hitTestMesh)!==null&&r!==void 0?r:b,!0)[0];T&&A.push({panoMesh:b,intersection:__assign({floor:(i=m==null?void 0:m.floorIndex)!==null&&i!==void 0?i:0},T)})}var _=A.sort(function(S,B){return S.intersection.distance-B.intersection.distance})[0];_?(v=_.intersection,this.activePanoMesh!==_.panoMesh&&(this.activePanoMesh=_.panoMesh,this.activeTime=e),this.intersectMesh.position.copy(_.panoMesh.position),this.intersectMesh.lookAt(this.camera.position),this.intersectMesh.visible=!1):(this.activePanoMesh=void 0,this.activeTime=void 0),v||(v=this.models.intersectRaycaster(h)[0]);var w=createEvent("intersect.update",{raycaster:h,intersection:v??null,object:this.intersectMesh});if(this.emit("intersect.update",w),w.defaultPrevented){this.hideIntersectMesh();return}if(v&&v.face){var x=v.face.normal,M=new THREE__namespace.Quaternion;M.setFromUnitVectors(new THREE__namespace.Vector3(0,0,1),x),this.intersectMesh.quaternion.copy(M);var R=x.clone().multiplyScalar(.05),I=v.point.clone().add(R);this.intersectMesh.position.copy(I),this.intersectMesh.visible=!0}else this.intersectMesh.visible=!1;return _==null?void 0:_.panoMesh},t.prototype.onPanGesture=function(){},t.prototype.onTapGesture=function(){},t.prototype.onPinchGesture=function(){},t.prototype.onMouseMove=function(){},t.prototype.onMouseOut=function(){},t}(PanoramaController),HUMAN_EYE_POSITION=new THREE__namespace.Vector3(0,1.6,0),ModelController=function(n){__extends(t,n);function t(e){var r=this,i,o=t.parseArgs(e);return r=n.call(this,o)||this,r.mode="Model",r.locationMotion=new Motion({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 Motion({modelAlpha:(i=r.models.getMaterial().modelAlpha)!==null&&i!==void 0?i:0}),r.perspToOrthoMotion=new Motion({perspToOrtho:r.camera.perspToOrtho.x}),r}return t.parseArgs=function(e){return e instanceof t?e:n.parseArgs.call(this,e)},t.initAnimationEndState=function(e){var r,i,o,s,u,l,d=this.parseArgs(e),c=d.works,f=e.initial,h=f.state,v=f.currentState,A=typeof h.panoIndex=="number"?{workCode:(o=(r=h.workCode)!==null&&r!==void 0?r:(i=d.works[0])===null||i===void 0?void 0:i.workCode)!==null&&o!==void 0?o:"",panoIndex:h.panoIndex}:{workCode:v.workCode,panoIndex:v.panoIndex},m=c.getResolvedObserver(A),y=(s=h.longitude)!==null&&s!==void 0?s:v.longitude,p=clamp((u=h.latitude)!==null&&u!==void 0?u:!m||isFristPersonMode(v.mode)?v.latitude:d.defaultLatitude,d.minLatitude,d.maxLatitude),g=clamp((l=h.fov)!==null&&l!==void 0?l:!m||isFristPersonMode(v.mode)?v.fov:d.defaultFov,d.minFov,d.maxFov),b=new THREE__namespace.Vector3;if(d.initial.state.offset)b.copy(d.initial.state.offset);else if(m)b.copy(m.position);else{var T=coordinatesToVector(v).setLength(v.distance);b.copy(d.initial.currentState.offset).sub(T)}return{workCode:A.workCode,panoIndex:A.panoIndex,mode:"Model",longitude:y,latitude:p,fov:g,offset:b,distance:0}},t.prototype.destroy=function(){n.prototype.destroy.call(this),this.locationMotion.dispose()},t.prototype.isReady=function(){return this.locationMotion.ended!==!1},t.prototype.updateWork=function(e,r,i,o){this.works=e;var s=t.initAnimationEndState(__assign(__assign({},this),{initial:{currentState:__assign(__assign({},this.currentPano),this.camera.pose),duration:i,state:r,userAction:o}}));this.hideIntersectMesh();var u={duration:0,longitude:s.longitude,latitude:s.latitude,fov:s.fov};return this.moveToPosition(s.offset,u,o),!0},t.prototype.updateCamera=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();var s={},u={};return s.distance=0,e.offset!==void 0&&(s.x=e.offset.x,s.y=e.offset.y,s.z=e.offset.z),e.longitude!==void 0&&(u.longitude=e.longitude),e.latitude!==void 0&&(u.latitude=e.latitude),e.fov!==void 0&&(u.fov=e.fov),o.locationMotion.set(s,r).catch(noop$1),o.cameraMotion.set(u,r).catch(noop$1)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();for(var s=[],u=[],l=0,d=e;l<d.length;l++){var c=d[l];s.push({key:c.key,progress:c.progress,value:{distance:0,x:c.value.offset.x,y:c.value.offset.x,z:c.value.offset.x}}),u.push({key:c.key,progress:c.progress,value:{longitude:c.value.longitude,latitude:c.value.latitude,fov:c.value.fov}})}return o.locationMotion.setKeyframes(s,r).catch(noop$1),o.cameraMotion.setKeyframes(e,r)})},t.prototype.updateTime=function(e,r){if(!this.destroyed){var i={},o={};if(this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),i.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),!this.locationMotion.ended){this.locationMotion.update(e),o.distance=this.locationMotion.value.distance,o.offset=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z);var s=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),u=this.works.resolvedObservers,l=arrayMin(u,function(d){return d.position.distanceTo(s)});this.currentPano=l?{workCode:l.work.workCode,panoIndex:l.panoIndex}:{workCode:"",panoIndex:0}}this.cameraMotion.ended||(this.cameraMotion.update(e),o.longitude=this.cameraMotion.value.longitude,o.latitude=this.cameraMotion.value.latitude,o.fov=this.cameraMotion.value.fov),isEmptyObject(i)||this.models.setMaterial(i),isEmptyObject(o)||this.setCamera(o)}},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 o=i.duration,s=i.userAction;e.userAction=s;var u=t.initAnimationEndState(e),l={modelAlpha:1},d={perspToOrtho:0},c={longitude:u.longitude,latitude:u.latitude,fov:u.fov,duration:o,moveStartCallback:function(f){e.perspToOrthoMotion.set(d,o).catch(noop$1),e.modelAlphaMotion.set(l,o).catch(noop$1),e.emit("initAnimation.start",createEvent("initAnimation.start",{state:f,userAction:e.userAction}))},moveEndCallback:function(f){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:f,userAction:e.userAction})),r()},moveCancelCallback:function(){var f=e.currentPano,h=__assign(__assign({},f),{mode:e.mode,longitude:e.camera.pose.longitude,latitude:e.camera.pose.latitude,fov:e.camera.pose.fov,offset:e.camera.pose.offset.clone(),distance:e.camera.pose.distance});e.emit("initAnimation.end",createEvent("initAnimation.end",{state:h,userAction:e.userAction})),r()}};e.moveToPosition(u.offset,c,s)})},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1],r=this.locationMotion.getKeyFrameSegment(now())[1];return __assign(__assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:new THREE__namespace.Vector3(r.value.x,r.value.y,r.value.z),distance:r.value.distance})},t.prototype.moveToPano=function(e,r,i){r===void 0&&(r={});var o=this.works.getResolvedObserver(e);o&&this.moveToPosition(o.position,r,i)},t.prototype.moveToPosition=function(e,r,i){var o=this,s,u,l;r===void 0&&(r={}),this.userAction=i,this.stopMomentumMovement();for(var d=now(),c=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),f=c.distanceTo(e),h=this.locationMotion.getProgressVelocity(d),v=0,A=1;A<this.locationMotion.keyframes.length;A++){var m=this.locationMotion.keyframes[A-1].value,y=m.x,p=m.y,g=m.z,b=this.locationMotion.keyframes[A].value,T=b.x,_=b.y,w=b.z;v+=Math.sqrt(Math.pow(T-y,2)+Math.pow(_-p,2)+Math.pow(w-g,2))}var x=f===0?0:h*v/f,M=this.calculateMovingDuration(r.duration,f),R={x:e.x,y:e.y,z:e.z,distance:0},I={longitude:r.longitude,latitude:r.latitude,fov:r.fov},S=this.works.resolvedObservers,B=arrayMin(S,function(k){return k.position.distanceTo(c)}),O=B?{workCode:B.work.workCode,panoIndex:B.panoIndex}:{workCode:"",panoIndex:0},F=__assign(__assign({},O),{mode:this.mode,longitude:(s=I.longitude)!==null&&s!==void 0?s:this.camera.pose.longitude,latitude:(u=I.latitude)!==null&&u!==void 0?u:this.camera.pose.latitude,fov:(l=I.fov)!==null&&l!==void 0?l:this.camera.pose.fov,offset:e.clone(),distance:0}),H=this.currentPano;this.emit("pano.moveTo",createEvent("pano.moveTo",{options:r,prevPano:H,progress:0,state:F,userAction:this.userAction,error:null})),r.moveStartCallback&&r.moveStartCallback(F),this.cameraMotion.set(I,M).catch(noop$1),this.locationMotion.set(R,M,x).then(function(){var k=__assign(__assign(__assign({},O),{mode:o.mode}),clonePose(o.camera.pose));o.emit("pano.arrived",createEvent("pano.arrived",{options:r,prevPano:H,progress:0,state:k,userAction:o.userAction,error:null})),r.moveEndCallback&&r.moveEndCallback(k)},function(){r.moveCancelCallback&&r.moveCancelCallback(),o.emit("pano.cancel",createEvent("pano.cancel",{options:r,prevPano:H,progress:0,state:F,userAction:o.userAction,error:null}))})},t.prototype.onTapGesture=function(e){var r=e.center.raycaster;this.stopMomentumMovement();var i=this.models.intersectRaycaster(r)[0];if(i&&i.face){var o=i.face.normal,s=i.point;if(new THREE__namespace.Vector3(0,1,0).angleTo(o)>Math.PI/3){var u=o.clone().setLength(.3).add(s);r.set(u,new THREE__namespace.Vector3(0,-1,0)),i=this.models.intersectRaycaster(r)[0]}}if(i){var l=new THREE__namespace.Vector3().copy(i.point).add(HUMAN_EYE_POSITION),d=this.works.resolvedObservers,c=arrayMin(d,function(v){return v.position.distanceTo(l)},!0),f=c[0],h=c[1];f&&h<5&&(l.y=f.position.y),e.state.offset.copy(l),e.state.distance=0,this.emit("gesture.tap",e),e.defaultPrevented||this.moveToPosition(l,{},!0)}else this.emit("gesture.tap",e),e.defaultPrevented||this.cameraBounce()},t}(PanoramaLikeController);const vertexShader=function n(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}(`{vs|z-rp@-}n{|]|vv|{H{vs|z-znA-}n{|Znv\x07H{vs|z-nz}yr?Q-}n{|Qv}ynprzr{Zn}H<<{vs|z-sy|n-pnyrHn\bv{t-rp@-}n{|d|yq]|vv|{H<<-n\bv{t-sy|n-vU|yrHp|{-sy|n-]V-J-@;>A>BF?CHp|{-sy|n-aNb-J-C;?E@>EB?Hp|{-sy|n-pnyr-J->@;>Hrp?-|P||q5rp@-rp|6-
|
|
1819
1819
|
--sy|n--J-yr{tu5rp|6H--sy|n-urn-J-np|5:rp|;\b-<-6H--sy|n-}uv-J-nn{5rp|;\x079-rp|; 6H--r{-rp?5=;B-8-}uv-<-aNb9-urn-<-]V6H\f|vq-znv{56-
|
|
1820
1820
|
--rpA-|yq]|vv|{-J-z|qryZnv\x07-7-rpA5}|vv|{9->;=6H--}n{|d|yq]|vv|{-J-5rpA5|yq]|vv|{;\x07\b 9->;=6-7-}n{|Znv\x076;\x07\b H--rp?-p||q-J-|P||q5}n{|d|yq]|vv|{6H--sy|n-qvn{pr-J-pnyrH--vs-5p||q;\b-I-=;>B6-
|
|
1821
1821
|
----rp?-n{s|zrqP||q-J-rp?5p||q;\x079-=;=6H----rpA-}n{|Qv}ynprzr{-J-r\x07r?Q5}n{|Qv}ynprzr{Zn}9-n{s|zrqP||q6H----qvn{pr-J-pnyr-7-}n{|Qv}ynprzr{;\x07H----qvn{pr-J-qvn{pr-7-p|5]V-7-5=;>B-:-p||q;\b66H----qvn{pr-J-pnyrH--\f-ryr-vs-5p||q;\b-KJ-=;>B-33-p||q;\b-IJ-=;EB6-
|
|
@@ -1823,7 +1823,7 @@ void main() {
|
|
|
1823
1823
|
------qvn{pr-J-pnyrH----\fryr
|
|
1824
1824
|
------qvn{pr-J-pnyr-7-}n{|Qv}ynprzr{;\x07H----\f--\f-ryr-
|
|
1825
1825
|
----rp?-n{s|zrqP||q-J-rp?5p||q;\x079->;=6H----rpA-}n{|Qv}ynprzr{-J-r\x07r?Q5}n{|Qv}ynprzr{Zn}9-n{s|zrqP||q6H----qvn{pr-J-pnyr-7-}n{|Qv}ynprzr{;\x07H----qvn{pr-J-qvn{pr-7-p|5]V-7-5p||q;\b-:-=;EB66H----qvn{pr-J-pnyrH--\f--rpA-ry]|vv|{-J-rpA5}|vv|{-8-}n{|]|vv|{-8-{|znyv r5|yq]|vv|{;\x07\b 6-7-qvn{pr9->;=6H--tyl]|vv|{-J-}|wrpv|{Znv\x07-7-z|qrycvrZnv\x07-7-ry]|vv|{H\f`),fragmentShader=function n(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}(`{vs|z-sy|n-|}npv\bH{vs|z-nz}yrPor-}n{|Zn}H{vs|z-nz}yr?Q-}n{|Qv}ynprzr{Zn}Hn\bv{t-rp@-}n{|d|yq]|vv|{H|vq-znv{56-
|
|
1826
|
-
--rpA-}n{|P|y|-J-r\x07rPor5}n{|Zn}9-}n{|d|yq]|vv|{;\x07\b 6H--tylSntP|y|-J-rpA5}n{|P|y|;to9-|}npv\b6H\f`);var shaderUniforms=Object.assign({opacity:new THREE__namespace.Uniform(1),scale:new THREE__namespace.Uniform(13.1),panoMap:new THREE__namespace.Uniform(null),panoDisplacementMap:new THREE__namespace.Uniform(null),panoPosition:new THREE__namespace.Uniform(new THREE__namespace.Vector3),panoMatrix:new THREE__namespace.Uniform(new THREE__namespace.Matrix4)},{emissive:new THREE__namespace.Uniform(new THREE__namespace.Color(0)),emissiveMap:new THREE__namespace.Uniform(null),specular:new THREE__namespace.Uniform(new THREE__namespace.Color(1118481)),specularMap:new THREE__namespace.Uniform(null),normalMap:new THREE__namespace.Uniform(null),bumpMap:new THREE__namespace.Uniform(null),shininess:new THREE__namespace.Uniform(30)},THREE__namespace.UniformsLib.common,THREE__namespace.UniformsLib.lights),sharedGeometry=new THREE__namespace.SphereBufferGeometry(.01,128,128);function toPanoModel(n,t,e,r){var i=new THREE__namespace.ShaderMaterial({side:THREE__namespace.BackSide,vertexShader,fragmentShader,transparent:!0,uniforms:THREE__namespace.UniformsUtils.clone(shaderUniforms)}),o=t;o.needsUpdate=!0,o.minFilter=THREE__namespace.LinearFilter,o.magFilter=THREE__namespace.LinearFilter,n.needsUpdate=!0,n.minFilter=THREE__namespace.LinearFilter,n.magFilter=THREE__namespace.LinearFilter,i.uniforms.opacity.value=0,i.uniforms.panoMap.value=o,i.uniforms.panoDisplacementMap.value=n,i.uniforms.panoPosition.value=e,i.uniforms.panoMatrix.value=r;var s=Object.assign(new THREE__namespace.Mesh(sharedGeometry,i),{frustumCulled:!1,dispose:function(){this.material instanceof THREE__namespace.ShaderMaterial&&(this.material.uniforms.panoDisplacementMap.value.dispose(),this.material.uniforms.panoDisplacementMap.value=null,this.material.dispose())}});return s}var DepthTextureLoader=function(){function n(){this.textureLoader=new TextureLoader}return n.prototype.load=function(t,e,r,i,o,s,u){var l=[0,0],d=function(f,h){l[h]=f,s(l[0]*.8+l[1]*.2)},c=[this.textureLoader.loadTexture(t,{imageURL:r.imageURL,viaAjax:!0,timeout:r.timeout,fetcher:r.fetcher},void 0,void 0,function(f){return d(f,1)},u),this.textureLoader.loadCubeTexture(e,{imageURL:r.imageURL,viaAjax:!0,timeout:r.timeout,fetcher:r.fetcher},void 0,void 0,function(f){return d(f,0)},u)];return Promise.all(c).then(function(f){var h=f[0],v=f[1],A=toPanoModel(h.body,v.body,r.position,r.matrix),m=__spreadArray([h.meta],v.meta,!0),y={body:A,meta:m};return i(y),y}).catch(function(f){for(var h=0,v=c;h<v.length;h++){var A=v[h];A.then(function(m){return m.body.dispose()}).catch(noop$1)}return o(f),Promise.reject(f)})},n}(),PANO_TEXTURE_SCALE$1=new THREE__namespace.Vector3(-1,1,1),DepthPanoramaController=function(n){__extends(t,n);function t(e){var r=this,i,o,s,u=t.parseArgs(e);r=n.call(this,u)||this;var l=u.initial;return l.state,l.currentState,r.maxAccessibleDistance=u.maxAccessibleDistance,r.panoTapTriggerRadius=u.panoTapTriggerRadius,r.panoCircleMeshCreator=u.panoCircleMeshCreator,r.panoModelGroup=new THREE__namespace.Group,r.panoModelGroup.name="panoModels",r.scene.add(r.panoModelGroup),r.panoMeshes={},r.updatePanoMeshes(),r.helper.remove(r.intersectMesh),r.locationMotion=new Motion({count:0,distance:r.camera.pose.distance}),r.modelAlphaMotion=new Motion({modelAlpha:(i=r.models.getMaterial().modelAlpha)!==null&&i!==void 0?i:0}),r.perspToOrthoMotion=new Motion({perspToOrtho:r.camera.perspToOrtho.x}),r.panoResources={},r.panoResources[r.locationMotion.keyframes[0].key=r.locationMotion.keyframes[1].key=createUuid()]={panoId:panoStringify(r.currentPano),matrix:(s=(o=r.models.getMaterial().pano1)===null||o===void 0?void 0:o.matrix)!==null&&s!==void 0?s:new THREE__namespace.Matrix4,position:r.camera.pose.offset.clone(),effect:"fly"},r.depthTextureLoader=new DepthTextureLoader,r}return t.parseArgs=function(e){var r,i,o;if(e instanceof t)return e;var s=n.parseArgs.call(this,e);return __assign(__assign({},s),{maxAccessibleDistance:(r=e.maxAccessibleDistance)!==null&&r!==void 0?r:5,panoTapTriggerRadius:(i=e.panoTapTriggerRadius)!==null&&i!==void 0?i:1,panoCircleMeshCreator:(o=e.panoCircleMeshCreator)!==null&&o!==void 0?o:function(u){return new PanoCircleMesh}})},t.initAnimationEndState=function(e){var r=this.parseArgs(e),i=n.initAnimationEndState.call(this,r);return __assign(__assign({},i),{mode:"DepthPanorama"})},t.prototype.destroy=function(){var e;if(n.prototype.destroy.call(this),this.locationMotion.dispose(),delete this.pendingTextureTask,this.panoModelGroup){for(var r=0,i=this.panoModelGroup.children;r<i.length;r++){var o=i[r];typeof o.dispose=="function"&&o.dispose()}this.scene.remove(this.panoModelGroup)}if(this.panoMeshes)for(var s=Object.keys(this.panoMeshes),u=0,l=s;u<l.length;u++){var d=l[u],c=this.panoMeshes[d];this.helper.remove(c),c.dispose(),delete this.panoMeshes[d]}for(var f=(e=this.models.getMaterial())!==null&&e!==void 0?e:{},h=f.pano0,v=f.pano1,A=0,m=Object.keys(this.panoResources);A<m.length;A++){var y=m[A],p=this.panoResources[y];p.panoModel&&p.panoModel.material.uniforms.panoMap.value!==(h==null?void 0:h.map)&&p.panoModel.material.uniforms.panoMap.value!==(v==null?void 0:v.map)&&(this.panoModelGroup.remove(p.panoModel),p.panoModel.material.uniforms.panoMap.value.dispose(),p.panoModel.dispose(),delete p.panoModel),delete this.panoResources[y]}},t.prototype.isReady=function(){return this.locationMotion.ended!==!1?!1:n.prototype.isReady.call(this)},t.prototype.updateWork=function(e,r,i,o){this.userAction=o,this.works=e;var s=t.initAnimationEndState(__assign(__assign({},this),{initial:{currentState:__assign(__assign({},this.currentPano),this.camera.pose),duration:i,state:r,userAction:o}})),u={workCode:s.workCode,panoIndex:s.panoIndex};return this.hideIntersectMesh(),this.updatePanoMeshes(),this.moveToPano(u,{effect:"fade",duration:i,longitude:r.longitude,latitude:r.latitude,fov:r.fov},o),!0},t.prototype.updateTime=function(e,r){var i=this,o,s;if(!this.destroyed){var u={},l={},d=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[0]),c=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[this.locationMotion.keyframes.length-1]),f=!1;if(this.cameraMotion.ended===!1&&(this.cameraMotion.update(e),l.longitude=this.cameraMotion.value.longitude,l.latitude=this.cameraMotion.value.latitude,l.fov=this.cameraMotion.value.fov),this.modelAlphaMotion.ended===!1&&(this.modelAlphaMotion.update(e),u.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);var h=this.locationMotion.getKeyFrameSegment(e),v=h[0],A=h[1],m=this.panoResourceFromLocationMotionKeyframe(v),y=this.panoResourceFromLocationMotionKeyframe(A),p=new THREE__namespace.Vector3().copy(m.position),g=new THREE__namespace.Vector3().copy(y.position),b=this.locationMotion.value.count-A.value.count+1;u.progress=b;for(var T=0,_=this.panoModelGroup.children;T<_.length;T++){var w=_[T];w.visible=w===m.panoModel||w===y.panoModel}m.panoModel&&(m.panoModel.material.uniforms.opacity.value=1-b,m.panoModel.material.depthTest=b!==0),y.panoModel&&(y.panoModel.material.uniforms.opacity.value=b,y.panoModel.material.depthTest=b!==1),y.panoModel&&(b<1?m.panoModel&&(u.pano0={map:m.panoModel.material.uniforms.panoMap.value,luminanceMap:null,matrix:m.matrix}):u.pano0={map:y.panoModel.material.uniforms.panoMap.value,luminanceMap:null,matrix:y.matrix},u.pano1={map:y.panoModel.material.uniforms.panoMap.value,luminanceMap:null,matrix:y.matrix}),f=u.useBlackTransition=y.effect==="instant"||y.effect==="montage",(y.effect==="fade"||y.effect==="montage")&&(u.pano0&&(u.pano0={map:u.pano0.map,luminanceMap:null,matrix:m.matrix.clone().setPosition(y.position)}),p.copy(g)),l.distance=this.locationMotion.value.distance,l.offset=new THREE__namespace.Vector3(p.x+(g.x-p.x)*b,p.y+(g.y-p.y)*b,p.z+(g.z-p.z)*b);for(var x=[],M=[],R=0,I=this.locationMotion.keyframes;R<I.length;R++){var S=I[R],B=S.key,F=S.progress;B!==void 0&&(x.push(B),F>=this.locationMotion.progress&&M.push(B))}for(var O=0,H=Object.keys(this.panoResources);O<H.length;O++){var k=H[O];if(!(M.indexOf(k)>=0)){var N=this.panoResources[k];if(N.panoModel){if(N.panoModel.material.uniforms.panoMap.value===((o=u.pano0)===null||o===void 0?void 0:o.map)||N.panoModel.material.uniforms.panoMap.value===((s=u.pano1)===null||s===void 0?void 0:s.map))continue;this.panoModelGroup.remove(N.panoModel),N.panoModel.material.uniforms.panoMap.value.dispose(),N.panoModel.dispose(),delete N.panoModel}x.indexOf(k)>=0||delete this.panoResources[k]}}this.currentPano=panoParse(y.panoId),this.emit("pano.moving",createEvent("pano.moving",{userAction:this.userAction,prevPano:panoParse(d.panoId),state:__assign(__assign(__assign(__assign({},panoParse(c.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),l),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(u)===!1&&this.models.setMaterial(u),isEmptyObject(l)===!1&&this.setCamera(l);var q=this.works.getResolvedObserver(this.currentPano),V=this.locationMotion.ended?this.getForwardObserverOrNot():null;if(this.camera.pose.distance>.1||f){if(q)for(var D=0,K=Object.keys(this.panoMeshes);D<K.length;D++){var z=K[D],G=this.panoMeshes[z];G.setOpacity(0),G.setCurrent(!1),G.updateTime&&G.updateTime(e,r)}}else if(q){var W=arrayMin(q.visibleIds,function(se){var pe=i.works.getResolvedObserver(se);return pe?q.standingPosition.distanceTo(pe.standingPosition):1/0},!0),Q=W[1];Q=clamp(Q,2.5,1/0);for(var X=q.visibleIds.concat(panoStringify(this.currentPano)),ee=this.camera.getDirection(new THREE__namespace.Vector3),J=0,Z=Object.keys(this.panoMeshes);J<Z.length;J++){var z=Z[J],G=this.panoMeshes[z],te=this.works.getResolvedObserver(z);if(X.indexOf(z)===-1)G.setCurrent(!1),G.setOpacity(0);else if(!te)G.setCurrent(!1),G.setOpacity(0);else if(!te.loadable&&!te.active)G.setCurrent(!1),G.setOpacity(0);else{var ae=G.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);G.setCurrent(!G.loading&&G.progress===0&&V!==null&&V.panoId===z),G.setOpacity(ae<.01?0:clamp(Q/ae*1.2,.4,.85));var re=this.camera.position.clone().setY(G.position.y),ie=new THREE__namespace.Vector3().copy(G.position).sub(re).normalize();if(z===panoStringify(this.currentPano)){var de=clamp((.5-re.distanceTo(G.position))/.5,0,1);ie.multiplyScalar(1-de).add(ee.clone().multiplyScalar(de))}ie.length()>0&&G.quaternion.setFromEuler(new THREE__namespace.Euler(0,Math.atan2(ie.x,ie.z),0))}G.updateTime&&G.updateTime(e,r)}}}},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1],r=this.locationMotion.getKeyFrameSegment(now())[1],i=this.panoResourceFromLocationMotionKeyframe(r),o=this.works.getResolvedObserver(i.panoId);return{mode:this.mode,workCode:o?o.work.workCode:this.currentPano.workCode,panoIndex:o?o.pano.panoIndex:this.currentPano.panoIndex,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:o?o.position.clone():this.camera.position.clone(),distance:0}},t.prototype.moveToPano=function(e,r,i){var o=this,s;r===void 0&&(r={});var u=this.works.getResolvedObserver(e);if(!u)throw new Error("panoId ".concat(JSON.stringify(e)," is not found."));this.userAction=i;var l=u.images.depth,d=__assign({key:"pano.".concat(u.panoId)},pick(this.imageOptions,["format","size","quality","sharpen","mappings"])),c=this.imageOptions.transform,f=u.images,h=u.position,v=u.quaternion,A=new THREE__namespace.Matrix4().compose(h,v,new THREE__namespace.Vector3(-1,1,1)),m="pano:"+jsonHash(f);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===m)return;var y=this.pendingTextureTask.panoId,p=panoParse(y);(s=this.panoMeshes[y])===null||s===void 0||s.setProgress(0),this.emit("pano.texture.abort",createEvent("pano.texture.abort",{error:null,progress:0,meta:null,pano:p})),this.pendingTextureTask.onError(new Error("pano ".concat(JSON.stringify(p)," texture aborted")))}var g="move-to-pano-"+u.panoId;this.pending.add(g),this.pendingTextureTask={panoId:u.panoId,hash:m,onLoad:function(T){o.pending.delete(g),o.destroyed?T.body.dispose():(T.body.name=m,o.doMoveToPano(u.pano,T.body,r))},onError:function(T){o.pending.delete(g);var _=__assign(__assign(__assign({},u.pano),{mode:o.mode}),clonePose(o.camera.pose));o.emit("pano.error",createEvent("pano.error",{error:T,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:_})),o.emit("pano.cancel",createEvent("pano.cancel",{error:null,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:_})),r.moveCancelCallback&&r.moveCancelCallback()}};var b=this.panoMeshes[u.panoId];b&&b.tap&&b.tap(),this.depthTextureLoader.load(l,f,{imageURL:{transform:c,options:d},position:h,matrix:A,fetcher:getFetcher(u.work)},function(T){var _,w;((_=o.pendingTextureTask)===null||_===void 0?void 0:_.hash)===m?(o.pendingTextureTask.onLoad(T),(w=o.panoMeshes[u.panoId])===null||w===void 0||w.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.success",createEvent("pano.texture.success",{error:null,progress:1,meta:T.meta,pano:u.pano}))):T.body.dispose()},function(T){var _,w;((_=o.pendingTextureTask)===null||_===void 0?void 0:_.hash)===m&&(o.pendingTextureTask.onError(T),(w=o.panoMeshes[u.panoId])===null||w===void 0||w.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.error",createEvent("pano.texture.error",{error:T,progress:0,meta:null,pano:u.pano})),o.emit("error",T))},function(T){var _,w;o.emit("pano.texture.progress",createEvent("pano.texture.progress",{error:null,progress:T,meta:null,pano:u.pano})),((_=o.pendingTextureTask)===null||_===void 0?void 0:_.hash)===m&&((w=o.panoMeshes[u.panoId])===null||w===void 0||w.setProgress(T))},this.renderer),this.emit("pano.texture.load",createEvent("pano.texture.load",{error:null,progress:0,meta:null,pano:u.pano}))},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 o=i.duration,s=i.userAction,u=t.initAnimationEndState(e),l={workCode:u.workCode,panoIndex:u.panoIndex},d=!1;e.userAction=s;var c={modelAlpha:0},f={perspToOrtho:0};e.moveToPano(l,{longitude:u.longitude,latitude:u.latitude,fov:u.fov,duration:o,moveStartCallback:function(h){d=!0,e.perspToOrthoMotion.set(f,o).catch(noop$1),e.modelAlphaMotion.set(c,o).catch(noop$1),e.emit("initAnimation.start",createEvent("initAnimation.start",{state:h,userAction:s}))},moveEndCallback:function(h){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:h,userAction:e.userAction})),r()},moveCancelCallback:function(){var h=__assign(__assign(__assign({},l),{mode:e.mode}),clonePose(e.camera.pose));d===!1&&e.emit("initAnimation.start",createEvent("initAnimation.start",{state:h,userAction:e.userAction})),e.emit("initAnimation.end",createEvent("initAnimation.end",{state:h,userAction:e.userAction})),r()}},s)})},t.prototype.panoResourceFromLocationMotionKeyframe=function(e){return this.panoResources[e.key]},t.prototype.locationMotionKeyframesLength=function(e){for(var r=0,i=1;i<e.length;i++){var o=this.panoResourceFromLocationMotionKeyframe(e[i-1]).position,s=this.panoResourceFromLocationMotionKeyframe(e[i]).position,u=o.distanceTo(s)*(e[i].value.count-e[i-1].value.count);r+=u}return r},t.prototype.updatePanoMeshes=function(){for(var e=this,r={},i=Object.keys(this.panoMeshes),o=0,s=i;o<s.length;o++){var u=s[o],l=this.panoMeshes[u];r[u]=l,delete this.panoMeshes[u]}for(var d=1,c={},f=function(w){var x=arrayMin(w.accessibleIds,function(R){var I=e.works.getResolvedObserver(R);if(!I)return 1/0;var S=I.standingPosition.distanceTo(w.standingPosition);return clamp(S,1,1/0)},!0),M=x[1];c[w.panoId]===void 0&&(c[w.panoId]=M)},h=0,v=this.works.resolvedObservers;h<v.length;h++){var A=v[h];f(A)}var m=Object.keys(c).map(function(w){return c[w]});if(m.length){var y=m.reduce(function(w,x){return w+x},0)/m.length;d=clamp(y*.6,1,3)}for(var p=0,g=this.works.resolvedObservers;p<g.length;p++){var A=g[p],l=void 0;r[A.panoId]?(l=r[A.panoId],l.loading===!0&&A.loadable===!1&&l.setLoading(!1),delete r[A.panoId]):(l=this.panoCircleMeshCreator(A.pano),l.name="PanoCircleMesh_"+A.panoId,this.helper.remove(l)),l.scale.set(d,1,d),l.position.copy(A.standingPosition),this.panoMeshes[A.panoId]=l}for(var b=0,T=Object.keys(r);b<T.length;b++){var _=T[b];this.helper.remove(r[_]),r[_].dispose(),delete r[_]}},t.prototype.doMoveToPano=function(e,r,i){var o=this,s,u,l,d;i===void 0&&(i={});var c=now(),f=createUuid(),h=this.works.getResolvedObserver(e);if(!h)throw new Error("panoId ".concat(JSON.stringify(e)," never found"));var v=this.panoResources[f]={panoId:h.panoId,effect:(s=i.effect)!==null&&s!==void 0?s:"fly",panoModel:r,matrix:new THREE__namespace.Matrix4().compose(h.position,h.quaternion,PANO_TEXTURE_SCALE$1),position:h.position.clone()};r.visible=!1,r.renderOrder=-1,this.panoModelGroup.add(r);var A=1,m,y,p;if(this.locationMotion.ended){var g=this.locationMotion.getKeyFrameSegment(c);g[0];var b=g[1],T=this.locationMotion.value,_=this.panoResourceFromLocationMotionKeyframe(b).position,w=v.position;m=Math.max(_.distanceTo(w),A),y=[{key:b.key,progress:0,value:__assign(__assign({},T),{count:0})},{key:f,progress:1,value:{distance:0,count:1}}],p=0}else{var x=this.locationMotion.getKeyFrameSegment(c),M=x[0],b=x[1],T=this.locationMotion.value,R=this.panoResourceFromLocationMotionKeyframe(M).position,_=this.panoResourceFromLocationMotionKeyframe(b).position,w=v.position,I=b.value.count-T.count,S=Math.max(R.distanceTo(_),A)*I,B=Math.max(_.distanceTo(w),A);m=S+B,y=[{key:M.key,progress:0,value:__assign({},T)},{key:b.key,progress:S/m,value:b.value},{key:f,progress:1,value:{count:b.value.count+1,distance:0}}];var F=this.locationMotionKeyframesLength(this.locationMotion.keyframes),O=this.locationMotionKeyframesLength(y);F===0||F===0?p=0:p=this.locationMotion.getProgressVelocity(c)*F/O}var H=this.calculateMovingDuration(i.duration,i.effect==="fade"||i.effect==="montage"?0:m),k={longitude:i.longitude,latitude:i.latitude,fov:i.fov},N=__assign(__assign({},e),{mode:this.mode,longitude:(u=k.longitude)!==null&&u!==void 0?u:this.camera.pose.longitude,latitude:(l=k.latitude)!==null&&l!==void 0?l:this.camera.pose.latitude,fov:(d=k.fov)!==null&&d!==void 0?d:this.camera.pose.fov,offset:h.position.clone(),distance:this.camera.pose.distance}),q=this.currentPano;this.emit("pano.moveTo",createEvent("pano.moveTo",{options:i,prevPano:q,progress:0,state:N,userAction:this.userAction,error:null})),i.moveStartCallback&&i.moveStartCallback(N),this.cameraMotion.set(k,H).catch(noop$1);var V=this.locationMotion.setKeyframes(y,H,p);V.then(function(){var D=__assign(__assign({},e),{mode:o.mode,longitude:o.camera.pose.longitude,latitude:o.camera.pose.latitude,fov:o.camera.pose.fov,offset:o.camera.pose.offset.clone(),distance:o.camera.pose.distance});o.emit("pano.arrived",createEvent("pano.arrived",{options:i,prevPano:q,progress:1,state:D,userAction:o.userAction,error:null})),i.moveEndCallback&&i.moveEndCallback(D)},function(){o.emit("pano.cancel",createEvent("pano.cancel",{options:i,prevPano:q,progress:0,state:N,userAction:o.userAction,error:null})),i.moveCancelCallback&&i.moveCancelCallback()})},t.prototype.getForwardObserverOrNot=function(e){var r=this,i=this.camera.getDirection(new THREE__namespace.Vector3),o=this.camera.position.clone(),s=this.works.getResolvedObserver(this.currentPano);if(!s)return null;var u=s.accessibleIds.filter(function(g){if(g===panoStringify(r.currentPano))return!1;var b=r.works.getResolvedObserver(g);if(!b)return!1;var T=b.standingPosition.clone().sub(o);return T.length()===0||T.angleTo(new THREE__namespace.Vector3(0,-1,0))<Math.PI/12?!1:b.loadable||b.active}),l=(e?e.ray.direction.clone():i.clone()).setY(0);if(l.length()===0)return null;for(var d=u.slice().sort(function(g,b){var T=r.works.getResolvedObserver(g).position.clone().setY(o.y),_=r.works.getResolvedObserver(b).position.clone().setY(o.y);return T.distanceTo(o)-_.distanceTo(o)}),c=0,f=[Math.PI/8,Math.PI/6,Math.PI/4,Math.PI/3];c<f.length;c++)for(var h=f[c],v=0,A=d;v<A.length;v++){var m=A[v],y=this.works.getResolvedObserver(m);if(y){var p=y.position.clone().setY(o.y).sub(o);if(p&&p.length()!==0&&l.angleTo(p)<h)return y}}return null},t.prototype.onTapGesture=function(e){var r=this,i;this.userAction=e.userAction,this.stopMomentumMovement();var o=e.center.raycaster,s=this.camera.getDirection(new THREE__namespace.Vector3).setY(0),u=null,l=this.works.getResolvedObserver(this.currentPano);if(l){var d=l.accessibleIds.filter(function(K){if(K===panoStringify(r.currentPano))return!1;var z=r.works.getResolvedObserver(K);return!z||z.position.distanceTo(r.camera.position)>r.maxAccessibleDistance?!1:z.loadable||z.active}),c=o.intersectObject(this.boundingMesh,!0)[0];if(c){var f=arrayMin(d,function(K){var z=r.works.getResolvedObserver(K).standingPosition.clone(),G=z.clone().sub(r.camera.position).setY(0).angleTo(s);return G>Math.PI/2?1/0:z.distanceTo(c.point)},!0),h=f[0],v=f[1];h&&v<this.panoTapTriggerRadius&&(u=(i=this.works.getResolvedObserver(h))!==null&&i!==void 0?i:null)}u||(u=this.getForwardObserverOrNot(o));for(var A=0,m=this.locationMotion.keyframes;A<m.length;A++){var y=m[A],p=this.panoResourceFromLocationMotionKeyframe(y);if(!(y.progress<this.locationMotion.progress)&&u&&p.panoId===u.panoId){u=null;break}}if(!u)this.emit("gesture.tap",e),e.defaultPrevented||this.locationMotion.ended===!0&&this.cameraBounce();else{for(var g={},b=Math.PI/6,T=Math.PI/12,_=new THREE__namespace.Vector3(0,1,0),w=u.position.clone().setY(0).sub(l.position.clone().setY(0)).normalize(),x=w.clone().applyAxisAngle(_,b),M=w.clone().applyAxisAngle(_,-b),R=[],I=[],S=[],B=0,F=u.accessibleIds;B<F.length;B++){var h=F[B],O=panoParse(h);if(!(panoEqual(O,this.currentPano)||panoEqual(O,u.pano))){var H=this.works.getResolvedObserver(h);if(H){var k=H.position.clone().sub(u.position).setY(0);w.angleTo(k)<b?S.push(k):x.angleTo(k)<b?R.push(k):M.angleTo(k)<b&&I.push(k)}}}var N=S.length>0?S:__spreadArray(__spreadArray([],R,!0),I,!0),q=N.slice().sort(function(K,z){return K.angleTo(w)-z.angleTo(w)})[0];q&&q.angleTo(s)>T&&(g.longitude=Math.atan2(-q.x,-q.z)),this.cameraMotion.value.latitude<-Math.PI/4&&(g.latitude=clamp(0,this.minLatitude,this.maxLatitude));var V=__assign({},e.state);if(V.workCode=u.pano.workCode,V.panoIndex=u.pano.panoIndex,g.longitude!==void 0&&(V.longitude=g.longitude),g.latitude!==void 0&&(V.latitude=g.latitude),g.fov!==void 0&&(V.fov=g.fov),V.distance=0,V.offset=u?u.position.clone():new THREE__namespace.Vector3,e.state=V,this.emit("gesture.tap",e),!e.defaultPrevented){if(this.emit("pano.select",createEvent("pano.select",{prevPano:this.currentPano,state:V,userAction:e.userAction,options:g,progress:0,error:null})),u&&!u.active){var D=u.panoId;this.panoMeshes[D]&&(this.panoMeshes[D].setDisabled(!1),this.panoMeshes[D].setLoading(!0))}u&&u.active&&this.emit("pano.request",createEvent("pano.request",{userAction:!0,prevPano:this.currentPano,progress:0,state:V,options:g,error:null}))}}}},t}(PanoramaLikeController);const edlVertexShader=function n(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}(`}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-
|
|
1826
|
+
--rpA-}n{|P|y|-J-r\x07rPor5}n{|Zn}9-}n{|d|yq]|vv|{;\x07\b 6H--tylSntP|y|-J-rpA5}n{|P|y|;to9-|}npv\b6H\f`);var shaderUniforms=Object.assign({opacity:new THREE__namespace.Uniform(1),scale:new THREE__namespace.Uniform(13.1),panoMap:new THREE__namespace.Uniform(null),panoDisplacementMap:new THREE__namespace.Uniform(null),panoPosition:new THREE__namespace.Uniform(new THREE__namespace.Vector3),panoMatrix:new THREE__namespace.Uniform(new THREE__namespace.Matrix4)},{emissive:new THREE__namespace.Uniform(new THREE__namespace.Color(0)),emissiveMap:new THREE__namespace.Uniform(null),specular:new THREE__namespace.Uniform(new THREE__namespace.Color(1118481)),specularMap:new THREE__namespace.Uniform(null),normalMap:new THREE__namespace.Uniform(null),bumpMap:new THREE__namespace.Uniform(null),shininess:new THREE__namespace.Uniform(30)},THREE__namespace.UniformsLib.common,THREE__namespace.UniformsLib.lights),sharedGeometry=new THREE__namespace.SphereBufferGeometry(.01,128,128);function toPanoModel(n,t,e,r){var i=new THREE__namespace.ShaderMaterial({side:THREE__namespace.BackSide,vertexShader,fragmentShader,transparent:!0,uniforms:THREE__namespace.UniformsUtils.clone(shaderUniforms)}),o=t;o.needsUpdate=!0,o.minFilter=THREE__namespace.LinearFilter,o.magFilter=THREE__namespace.LinearFilter,n.needsUpdate=!0,n.minFilter=THREE__namespace.LinearFilter,n.magFilter=THREE__namespace.LinearFilter,i.uniforms.opacity.value=0,i.uniforms.panoMap.value=o,i.uniforms.panoDisplacementMap.value=n,i.uniforms.panoPosition.value=e,i.uniforms.panoMatrix.value=r;var s=Object.assign(new THREE__namespace.Mesh(sharedGeometry,i),{frustumCulled:!1,dispose:function(){this.material instanceof THREE__namespace.ShaderMaterial&&(this.material.uniforms.panoDisplacementMap.value.dispose(),this.material.uniforms.panoDisplacementMap.value=null,this.material.dispose())}});return s}var DepthTextureLoader=function(){function n(){this.textureLoader=new TextureLoader}return n.prototype.load=function(t,e,r,i,o,s,u){var l=[0,0],d=function(f,h){l[h]=f,s(l[0]*.8+l[1]*.2)},c=[this.textureLoader.loadTexture(t,{imageURL:r.imageURL,viaAjax:!0,timeout:r.timeout,fetcher:r.fetcher},void 0,void 0,function(f){return d(f,1)},u),this.textureLoader.loadCubeTexture(e,{imageURL:r.imageURL,viaAjax:!0,timeout:r.timeout,fetcher:r.fetcher},void 0,void 0,function(f){return d(f,0)},u)];return Promise.all(c).then(function(f){var h=f[0],v=f[1],A=toPanoModel(h.body,v.body,r.position,r.matrix),m=__spreadArray([h.meta],v.meta,!0),y={body:A,meta:m};return i(y),y}).catch(function(f){for(var h=0,v=c;h<v.length;h++){var A=v[h];A.then(function(m){return m.body.dispose()}).catch(noop$1)}return o(f),Promise.reject(f)})},n}(),PANO_TEXTURE_SCALE$1=new THREE__namespace.Vector3(-1,1,1),DepthPanoramaController=function(n){__extends(t,n);function t(e){var r=this,i,o,s,u=t.parseArgs(e);r=n.call(this,u)||this;var l=u.initial;return l.state,l.currentState,r.maxAccessibleDistance=u.maxAccessibleDistance,r.panoTapTriggerRadius=u.panoTapTriggerRadius,r.panoCircleMeshCreator=u.panoCircleMeshCreator,r.panoModelGroup=new THREE__namespace.Group,r.panoModelGroup.name="panoModels",r.scene.add(r.panoModelGroup),r.panoMeshes={},r.updatePanoMeshes(),r.helper.remove(r.intersectMesh),r.locationMotion=new Motion({count:0,distance:r.camera.pose.distance}),r.modelAlphaMotion=new Motion({modelAlpha:(i=r.models.getMaterial().modelAlpha)!==null&&i!==void 0?i:0}),r.perspToOrthoMotion=new Motion({perspToOrtho:r.camera.perspToOrtho.x}),r.panoResources={},r.panoResources[r.locationMotion.keyframes[0].key=r.locationMotion.keyframes[1].key=createUuid()]={panoId:panoStringify(r.currentPano),matrix:(s=(o=r.models.getMaterial().pano1)===null||o===void 0?void 0:o.matrix)!==null&&s!==void 0?s:new THREE__namespace.Matrix4,position:r.camera.pose.offset.clone(),effect:"fly"},r.depthTextureLoader=new DepthTextureLoader,r}return t.parseArgs=function(e){var r,i,o;if(e instanceof t)return e;var s=n.parseArgs.call(this,e);return __assign(__assign({},s),{maxAccessibleDistance:(r=e.maxAccessibleDistance)!==null&&r!==void 0?r:5,panoTapTriggerRadius:(i=e.panoTapTriggerRadius)!==null&&i!==void 0?i:1,panoCircleMeshCreator:(o=e.panoCircleMeshCreator)!==null&&o!==void 0?o:function(u){return new PanoCircleMesh}})},t.initAnimationEndState=function(e){var r=this.parseArgs(e),i=n.initAnimationEndState.call(this,r);return __assign(__assign({},i),{mode:"DepthPanorama"})},t.prototype.destroy=function(){var e;if(n.prototype.destroy.call(this),this.locationMotion.dispose(),delete this.pendingTextureTask,this.panoModelGroup){for(var r=0,i=this.panoModelGroup.children;r<i.length;r++){var o=i[r];typeof o.dispose=="function"&&o.dispose()}this.scene.remove(this.panoModelGroup)}if(this.panoMeshes)for(var s=Object.keys(this.panoMeshes),u=0,l=s;u<l.length;u++){var d=l[u],c=this.panoMeshes[d];this.helper.remove(c),c.dispose(),delete this.panoMeshes[d]}for(var f=(e=this.models.getMaterial())!==null&&e!==void 0?e:{},h=f.pano0,v=f.pano1,A=0,m=Object.keys(this.panoResources);A<m.length;A++){var y=m[A],p=this.panoResources[y];p.panoModel&&p.panoModel.material.uniforms.panoMap.value!==(h==null?void 0:h.map)&&p.panoModel.material.uniforms.panoMap.value!==(v==null?void 0:v.map)&&(this.panoModelGroup.remove(p.panoModel),p.panoModel.material.uniforms.panoMap.value.dispose(),p.panoModel.dispose(),delete p.panoModel),delete this.panoResources[y]}},t.prototype.isReady=function(){return this.locationMotion.ended!==!1?!1:n.prototype.isReady.call(this)},t.prototype.updateWork=function(e,r,i,o){this.userAction=o,this.works=e;var s=t.initAnimationEndState(__assign(__assign({},this),{initial:{currentState:__assign(__assign({},this.currentPano),this.camera.pose),duration:i,state:r,userAction:o}})),u={workCode:s.workCode,panoIndex:s.panoIndex};return this.hideIntersectMesh(),this.updatePanoMeshes(),this.moveToPano(u,{effect:"fade",duration:i,longitude:r.longitude,latitude:r.latitude,fov:r.fov},o),!0},t.prototype.updateTime=function(e,r){var i=this,o,s;if(!this.destroyed){var u={},l={},d=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[0]),c=this.panoResourceFromLocationMotionKeyframe(this.locationMotion.keyframes[this.locationMotion.keyframes.length-1]),f=!1;if(this.cameraMotion.ended===!1&&(this.cameraMotion.update(e),l.longitude=this.cameraMotion.value.longitude,l.latitude=this.cameraMotion.value.latitude,l.fov=this.cameraMotion.value.fov),this.modelAlphaMotion.ended===!1&&(this.modelAlphaMotion.update(e),u.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);var h=this.locationMotion.getKeyFrameSegment(e),v=h[0],A=h[1],m=this.panoResourceFromLocationMotionKeyframe(v),y=this.panoResourceFromLocationMotionKeyframe(A),p=new THREE__namespace.Vector3().copy(m.position),g=new THREE__namespace.Vector3().copy(y.position),b=this.locationMotion.value.count-A.value.count+1;u.progress=b;for(var T=0,_=this.panoModelGroup.children;T<_.length;T++){var w=_[T];w.visible=w===m.panoModel||w===y.panoModel}m.panoModel&&(m.panoModel.material.uniforms.opacity.value=1-b,m.panoModel.material.depthTest=b!==0),y.panoModel&&(y.panoModel.material.uniforms.opacity.value=b,y.panoModel.material.depthTest=b!==1),y.panoModel&&(b<1?m.panoModel&&(u.pano0={map:m.panoModel.material.uniforms.panoMap.value,luminanceMap:null,matrix:m.matrix}):u.pano0={map:y.panoModel.material.uniforms.panoMap.value,luminanceMap:null,matrix:y.matrix},u.pano1={map:y.panoModel.material.uniforms.panoMap.value,luminanceMap:null,matrix:y.matrix}),f=u.useBlackTransition=y.effect==="instant"||y.effect==="montage",(y.effect==="fade"||y.effect==="montage")&&(u.pano0&&(u.pano0={map:u.pano0.map,luminanceMap:null,matrix:m.matrix.clone().setPosition(y.position)}),p.copy(g)),l.distance=this.locationMotion.value.distance,l.offset=new THREE__namespace.Vector3(p.x+(g.x-p.x)*b,p.y+(g.y-p.y)*b,p.z+(g.z-p.z)*b);for(var x=[],M=[],R=0,I=this.locationMotion.keyframes;R<I.length;R++){var S=I[R],B=S.key,O=S.progress;B!==void 0&&(x.push(B),O>=this.locationMotion.progress&&M.push(B))}for(var F=0,H=Object.keys(this.panoResources);F<H.length;F++){var k=H[F];if(!(M.indexOf(k)>=0)){var N=this.panoResources[k];if(N.panoModel){if(N.panoModel.material.uniforms.panoMap.value===((o=u.pano0)===null||o===void 0?void 0:o.map)||N.panoModel.material.uniforms.panoMap.value===((s=u.pano1)===null||s===void 0?void 0:s.map))continue;this.panoModelGroup.remove(N.panoModel),N.panoModel.material.uniforms.panoMap.value.dispose(),N.panoModel.dispose(),delete N.panoModel}x.indexOf(k)>=0||delete this.panoResources[k]}}this.currentPano=panoParse(y.panoId),this.emit("pano.moving",createEvent("pano.moving",{userAction:this.userAction,prevPano:panoParse(d.panoId),state:__assign(__assign(__assign(__assign({},panoParse(c.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),l),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(u)===!1&&this.models.setMaterial(u),isEmptyObject(l)===!1&&this.setCamera(l);var q=this.works.getResolvedObserver(this.currentPano),V=this.locationMotion.ended?this.getForwardObserverOrNot():null;if(this.camera.pose.distance>.1||f){if(q)for(var D=0,K=Object.keys(this.panoMeshes);D<K.length;D++){var z=K[D],G=this.panoMeshes[z];G.setOpacity(0),G.setCurrent(!1),G.updateTime&&G.updateTime(e,r)}}else if(q){var W=arrayMin(q.visibleIds,function(se){var pe=i.works.getResolvedObserver(se);return pe?q.standingPosition.distanceTo(pe.standingPosition):1/0},!0),Q=W[1];Q=clamp(Q,2.5,1/0);for(var X=q.visibleIds.concat(panoStringify(this.currentPano)),ee=this.camera.getDirection(new THREE__namespace.Vector3),J=0,Z=Object.keys(this.panoMeshes);J<Z.length;J++){var z=Z[J],G=this.panoMeshes[z],te=this.works.getResolvedObserver(z);if(X.indexOf(z)===-1)G.setCurrent(!1),G.setOpacity(0);else if(!te)G.setCurrent(!1),G.setOpacity(0);else if(!te.loadable&&!te.active)G.setCurrent(!1),G.setOpacity(0);else{var ae=G.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);G.setCurrent(!G.loading&&G.progress===0&&V!==null&&V.panoId===z),G.setOpacity(ae<.01?0:clamp(Q/ae*1.2,.4,.85));var re=this.camera.position.clone().setY(G.position.y),ie=new THREE__namespace.Vector3().copy(G.position).sub(re).normalize();if(z===panoStringify(this.currentPano)){var de=clamp((.5-re.distanceTo(G.position))/.5,0,1);ie.multiplyScalar(1-de).add(ee.clone().multiplyScalar(de))}ie.length()>0&&G.quaternion.setFromEuler(new THREE__namespace.Euler(0,Math.atan2(ie.x,ie.z),0))}G.updateTime&&G.updateTime(e,r)}}}},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1],r=this.locationMotion.getKeyFrameSegment(now())[1],i=this.panoResourceFromLocationMotionKeyframe(r),o=this.works.getResolvedObserver(i.panoId);return{mode:this.mode,workCode:o?o.work.workCode:this.currentPano.workCode,panoIndex:o?o.pano.panoIndex:this.currentPano.panoIndex,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:o?o.position.clone():this.camera.position.clone(),distance:0}},t.prototype.moveToPano=function(e,r,i){var o=this,s;r===void 0&&(r={});var u=this.works.getResolvedObserver(e);if(!u)throw new Error("panoId ".concat(JSON.stringify(e)," is not found."));this.userAction=i;var l=u.images.depth,d=__assign({key:"pano.".concat(u.panoId)},pick(this.imageOptions,["format","size","quality","sharpen","mappings"])),c=this.imageOptions.transform,f=u.images,h=u.position,v=u.quaternion,A=new THREE__namespace.Matrix4().compose(h,v,new THREE__namespace.Vector3(-1,1,1)),m="pano:"+jsonHash(f);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===m)return;var y=this.pendingTextureTask.panoId,p=panoParse(y);(s=this.panoMeshes[y])===null||s===void 0||s.setProgress(0),this.emit("pano.texture.abort",createEvent("pano.texture.abort",{error:null,progress:0,meta:null,pano:p})),this.pendingTextureTask.onError(new Error("pano ".concat(JSON.stringify(p)," texture aborted")))}var g="move-to-pano-"+u.panoId;this.pending.add(g),this.pendingTextureTask={panoId:u.panoId,hash:m,onLoad:function(T){o.pending.delete(g),o.destroyed?T.body.dispose():(T.body.name=m,o.doMoveToPano(u.pano,T.body,r))},onError:function(T){o.pending.delete(g);var _=__assign(__assign(__assign({},u.pano),{mode:o.mode}),clonePose(o.camera.pose));o.emit("pano.error",createEvent("pano.error",{error:T,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:_})),o.emit("pano.cancel",createEvent("pano.cancel",{error:null,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:_})),r.moveCancelCallback&&r.moveCancelCallback()}};var b=this.panoMeshes[u.panoId];b&&b.tap&&b.tap(),this.depthTextureLoader.load(l,f,{imageURL:{transform:c,options:d},position:h,matrix:A,fetcher:getFetcher(u.work)},function(T){var _,w;((_=o.pendingTextureTask)===null||_===void 0?void 0:_.hash)===m?(o.pendingTextureTask.onLoad(T),(w=o.panoMeshes[u.panoId])===null||w===void 0||w.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.success",createEvent("pano.texture.success",{error:null,progress:1,meta:T.meta,pano:u.pano}))):T.body.dispose()},function(T){var _,w;((_=o.pendingTextureTask)===null||_===void 0?void 0:_.hash)===m&&(o.pendingTextureTask.onError(T),(w=o.panoMeshes[u.panoId])===null||w===void 0||w.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.error",createEvent("pano.texture.error",{error:T,progress:0,meta:null,pano:u.pano})),o.emit("error",T))},function(T){var _,w;o.emit("pano.texture.progress",createEvent("pano.texture.progress",{error:null,progress:T,meta:null,pano:u.pano})),((_=o.pendingTextureTask)===null||_===void 0?void 0:_.hash)===m&&((w=o.panoMeshes[u.panoId])===null||w===void 0||w.setProgress(T))},this.renderer),this.emit("pano.texture.load",createEvent("pano.texture.load",{error:null,progress:0,meta:null,pano:u.pano}))},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 o=i.duration,s=i.userAction,u=t.initAnimationEndState(e),l={workCode:u.workCode,panoIndex:u.panoIndex},d=!1;e.userAction=s;var c={modelAlpha:0},f={perspToOrtho:0};e.moveToPano(l,{longitude:u.longitude,latitude:u.latitude,fov:u.fov,duration:o,moveStartCallback:function(h){d=!0,e.perspToOrthoMotion.set(f,o).catch(noop$1),e.modelAlphaMotion.set(c,o).catch(noop$1),e.emit("initAnimation.start",createEvent("initAnimation.start",{state:h,userAction:s}))},moveEndCallback:function(h){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:h,userAction:e.userAction})),r()},moveCancelCallback:function(){var h=__assign(__assign(__assign({},l),{mode:e.mode}),clonePose(e.camera.pose));d===!1&&e.emit("initAnimation.start",createEvent("initAnimation.start",{state:h,userAction:e.userAction})),e.emit("initAnimation.end",createEvent("initAnimation.end",{state:h,userAction:e.userAction})),r()}},s)})},t.prototype.panoResourceFromLocationMotionKeyframe=function(e){return this.panoResources[e.key]},t.prototype.locationMotionKeyframesLength=function(e){for(var r=0,i=1;i<e.length;i++){var o=this.panoResourceFromLocationMotionKeyframe(e[i-1]).position,s=this.panoResourceFromLocationMotionKeyframe(e[i]).position,u=o.distanceTo(s)*(e[i].value.count-e[i-1].value.count);r+=u}return r},t.prototype.updatePanoMeshes=function(){for(var e=this,r={},i=Object.keys(this.panoMeshes),o=0,s=i;o<s.length;o++){var u=s[o],l=this.panoMeshes[u];r[u]=l,delete this.panoMeshes[u]}for(var d=1,c={},f=function(w){var x=arrayMin(w.accessibleIds,function(R){var I=e.works.getResolvedObserver(R);if(!I)return 1/0;var S=I.standingPosition.distanceTo(w.standingPosition);return clamp(S,1,1/0)},!0),M=x[1];c[w.panoId]===void 0&&(c[w.panoId]=M)},h=0,v=this.works.resolvedObservers;h<v.length;h++){var A=v[h];f(A)}var m=Object.keys(c).map(function(w){return c[w]});if(m.length){var y=m.reduce(function(w,x){return w+x},0)/m.length;d=clamp(y*.6,1,3)}for(var p=0,g=this.works.resolvedObservers;p<g.length;p++){var A=g[p],l=void 0;r[A.panoId]?(l=r[A.panoId],l.loading===!0&&A.loadable===!1&&l.setLoading(!1),delete r[A.panoId]):(l=this.panoCircleMeshCreator(A.pano),l.name="PanoCircleMesh_"+A.panoId,this.helper.remove(l)),l.scale.set(d,1,d),l.position.copy(A.standingPosition),this.panoMeshes[A.panoId]=l}for(var b=0,T=Object.keys(r);b<T.length;b++){var _=T[b];this.helper.remove(r[_]),r[_].dispose(),delete r[_]}},t.prototype.doMoveToPano=function(e,r,i){var o=this,s,u,l,d;i===void 0&&(i={});var c=now(),f=createUuid(),h=this.works.getResolvedObserver(e);if(!h)throw new Error("panoId ".concat(JSON.stringify(e)," never found"));var v=this.panoResources[f]={panoId:h.panoId,effect:(s=i.effect)!==null&&s!==void 0?s:"fly",panoModel:r,matrix:new THREE__namespace.Matrix4().compose(h.position,h.quaternion,PANO_TEXTURE_SCALE$1),position:h.position.clone()};r.visible=!1,r.renderOrder=-1,this.panoModelGroup.add(r);var A=1,m,y,p;if(this.locationMotion.ended){var g=this.locationMotion.getKeyFrameSegment(c);g[0];var b=g[1],T=this.locationMotion.value,_=this.panoResourceFromLocationMotionKeyframe(b).position,w=v.position;m=Math.max(_.distanceTo(w),A),y=[{key:b.key,progress:0,value:__assign(__assign({},T),{count:0})},{key:f,progress:1,value:{distance:0,count:1}}],p=0}else{var x=this.locationMotion.getKeyFrameSegment(c),M=x[0],b=x[1],T=this.locationMotion.value,R=this.panoResourceFromLocationMotionKeyframe(M).position,_=this.panoResourceFromLocationMotionKeyframe(b).position,w=v.position,I=b.value.count-T.count,S=Math.max(R.distanceTo(_),A)*I,B=Math.max(_.distanceTo(w),A);m=S+B,y=[{key:M.key,progress:0,value:__assign({},T)},{key:b.key,progress:S/m,value:b.value},{key:f,progress:1,value:{count:b.value.count+1,distance:0}}];var O=this.locationMotionKeyframesLength(this.locationMotion.keyframes),F=this.locationMotionKeyframesLength(y);O===0||O===0?p=0:p=this.locationMotion.getProgressVelocity(c)*O/F}var H=this.calculateMovingDuration(i.duration,i.effect==="fade"||i.effect==="montage"?0:m),k={longitude:i.longitude,latitude:i.latitude,fov:i.fov},N=__assign(__assign({},e),{mode:this.mode,longitude:(u=k.longitude)!==null&&u!==void 0?u:this.camera.pose.longitude,latitude:(l=k.latitude)!==null&&l!==void 0?l:this.camera.pose.latitude,fov:(d=k.fov)!==null&&d!==void 0?d:this.camera.pose.fov,offset:h.position.clone(),distance:this.camera.pose.distance}),q=this.currentPano;this.emit("pano.moveTo",createEvent("pano.moveTo",{options:i,prevPano:q,progress:0,state:N,userAction:this.userAction,error:null})),i.moveStartCallback&&i.moveStartCallback(N),this.cameraMotion.set(k,H).catch(noop$1);var V=this.locationMotion.setKeyframes(y,H,p);V.then(function(){var D=__assign(__assign({},e),{mode:o.mode,longitude:o.camera.pose.longitude,latitude:o.camera.pose.latitude,fov:o.camera.pose.fov,offset:o.camera.pose.offset.clone(),distance:o.camera.pose.distance});o.emit("pano.arrived",createEvent("pano.arrived",{options:i,prevPano:q,progress:1,state:D,userAction:o.userAction,error:null})),i.moveEndCallback&&i.moveEndCallback(D)},function(){o.emit("pano.cancel",createEvent("pano.cancel",{options:i,prevPano:q,progress:0,state:N,userAction:o.userAction,error:null})),i.moveCancelCallback&&i.moveCancelCallback()})},t.prototype.getForwardObserverOrNot=function(e){var r=this,i=this.camera.getDirection(new THREE__namespace.Vector3),o=this.camera.position.clone(),s=this.works.getResolvedObserver(this.currentPano);if(!s)return null;var u=s.accessibleIds.filter(function(g){if(g===panoStringify(r.currentPano))return!1;var b=r.works.getResolvedObserver(g);if(!b)return!1;var T=b.standingPosition.clone().sub(o);return T.length()===0||T.angleTo(new THREE__namespace.Vector3(0,-1,0))<Math.PI/12?!1:b.loadable||b.active}),l=(e?e.ray.direction.clone():i.clone()).setY(0);if(l.length()===0)return null;for(var d=u.slice().sort(function(g,b){var T=r.works.getResolvedObserver(g).position.clone().setY(o.y),_=r.works.getResolvedObserver(b).position.clone().setY(o.y);return T.distanceTo(o)-_.distanceTo(o)}),c=0,f=[Math.PI/8,Math.PI/6,Math.PI/4,Math.PI/3];c<f.length;c++)for(var h=f[c],v=0,A=d;v<A.length;v++){var m=A[v],y=this.works.getResolvedObserver(m);if(y){var p=y.position.clone().setY(o.y).sub(o);if(p&&p.length()!==0&&l.angleTo(p)<h)return y}}return null},t.prototype.onTapGesture=function(e){var r=this,i;this.userAction=e.userAction,this.stopMomentumMovement();var o=e.center.raycaster,s=this.camera.getDirection(new THREE__namespace.Vector3).setY(0),u=null,l=this.works.getResolvedObserver(this.currentPano);if(l){var d=l.accessibleIds.filter(function(K){if(K===panoStringify(r.currentPano))return!1;var z=r.works.getResolvedObserver(K);return!z||z.position.distanceTo(r.camera.position)>r.maxAccessibleDistance?!1:z.loadable||z.active}),c=o.intersectObject(this.boundingMesh,!0)[0];if(c){var f=arrayMin(d,function(K){var z=r.works.getResolvedObserver(K).standingPosition.clone(),G=z.clone().sub(r.camera.position).setY(0).angleTo(s);return G>Math.PI/2?1/0:z.distanceTo(c.point)},!0),h=f[0],v=f[1];h&&v<this.panoTapTriggerRadius&&(u=(i=this.works.getResolvedObserver(h))!==null&&i!==void 0?i:null)}u||(u=this.getForwardObserverOrNot(o));for(var A=0,m=this.locationMotion.keyframes;A<m.length;A++){var y=m[A],p=this.panoResourceFromLocationMotionKeyframe(y);if(!(y.progress<this.locationMotion.progress)&&u&&p.panoId===u.panoId){u=null;break}}if(!u)this.emit("gesture.tap",e),e.defaultPrevented||this.locationMotion.ended===!0&&this.cameraBounce();else{for(var g={},b=Math.PI/6,T=Math.PI/12,_=new THREE__namespace.Vector3(0,1,0),w=u.position.clone().setY(0).sub(l.position.clone().setY(0)).normalize(),x=w.clone().applyAxisAngle(_,b),M=w.clone().applyAxisAngle(_,-b),R=[],I=[],S=[],B=0,O=u.accessibleIds;B<O.length;B++){var h=O[B],F=panoParse(h);if(!(panoEqual(F,this.currentPano)||panoEqual(F,u.pano))){var H=this.works.getResolvedObserver(h);if(H){var k=H.position.clone().sub(u.position).setY(0);w.angleTo(k)<b?S.push(k):x.angleTo(k)<b?R.push(k):M.angleTo(k)<b&&I.push(k)}}}var N=S.length>0?S:__spreadArray(__spreadArray([],R,!0),I,!0),q=N.slice().sort(function(K,z){return K.angleTo(w)-z.angleTo(w)})[0];q&&q.angleTo(s)>T&&(g.longitude=Math.atan2(-q.x,-q.z)),this.cameraMotion.value.latitude<-Math.PI/4&&(g.latitude=clamp(0,this.minLatitude,this.maxLatitude));var V=__assign({},e.state);if(V.workCode=u.pano.workCode,V.panoIndex=u.pano.panoIndex,g.longitude!==void 0&&(V.longitude=g.longitude),g.latitude!==void 0&&(V.latitude=g.latitude),g.fov!==void 0&&(V.fov=g.fov),V.distance=0,V.offset=u?u.position.clone():new THREE__namespace.Vector3,e.state=V,this.emit("gesture.tap",e),!e.defaultPrevented){if(this.emit("pano.select",createEvent("pano.select",{prevPano:this.currentPano,state:V,userAction:e.userAction,options:g,progress:0,error:null})),u&&!u.active){var D=u.panoId;this.panoMeshes[D]&&(this.panoMeshes[D].setDisabled(!1),this.panoMeshes[D].setLoading(!0))}u&&u.active&&this.emit("pano.request",createEvent("pano.request",{userAction:!0,prevPano:this.currentPano,progress:0,state:V,options:g,error:null}))}}}},t}(PanoramaLikeController);const edlVertexShader=function n(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}(`}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-
|
|
1827
1827
|
b-J-HrpA-z]|vv|{-J-z|qrycvrZnv\x07-7-rpA5}|vv|{9>;=6Htyl]|vv|{-J-}|wrpv|{Znv\x07-7-z]|vv|{H\f`),edlFragmentShader=function n(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}(`0r\x07r{v|{-TYlRealsntlqr}u-G-r{noyr<<<<-nqn}rq-s|z-ur-RQY-unqr-p|qr-s|z-Puvvn{-O|pur{\b-v{-py|q-p|z}nrG<<-u}G<<tvuo;p|z<py|qp|z}nr<{x<rr<znr<}ytv{<\0RQY<unqr<RQY<<}rpvv|{-zrqvz}-sy|nH}rpvv|{-zrqvz}-v{H{vs|z-sy|n-prr{dvquH{vs|z-sy|n-prr{UrvtuH{vs|z-rp?-{rvtuo|h[RVTUO\\b_lP\\b[ajH{vs|z-sy|n-rqy\`r{tuH{vs|z-sy|n-nqvH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-[rnH{vs|z-sy|n-SnH{vs|z-znA-]|wH{vs|z-nz}yr?Q-RQYP|y|Hn\bv{t-rp?-bHsy|n-r}|{r5sy|n-qr}u6
|
|
1828
1828
|
--rp?-_nqv-J-nqv-<-rp?5prr{dvqu9-prr{Urvtu6H--sy|n-z-J-=;=H--s|5v{-v-J-=H-v-I-[RVTUO\\b_lP\\b[aH-v886
|
|
1829
1829
|
----rp?-[rvtuo|-J-b-8-_nqv-7-{rvtuo|hvjH----sy|n-{rvtuo|Qr}u-J-r\x07r?Q5RQYP|y|9-[rvtuo|6;nH----{rvtuo|Qr}u-J-5{rvtuo|Qr}u-JJ->;=6-L-=;=-G-{rvtuo|Qr}uH----vs5{rvtuo|Qr}u-.J-=;=6
|
|
@@ -1836,7 +1836,7 @@ void main() {
|
|
|
1836
1836
|
`,e},t.prototype.updateShaderSource=function(){var e=this.getDefines()+edlVertexShader,r=this.getDefines()+edlFragmentShader;this.setValues({vertexShader:e,fragmentShader:r}),this.needsUpdate=!0},__decorate([uniform$1("screenWidth"),__metadata("design:type",Number)],t.prototype,"screenWidth",void 0),__decorate([uniform$1("screenHeight"),__metadata("design:type",Number)],t.prototype,"screenHeight",void 0),__decorate([uniform$1("edlStrength"),__metadata("design:type",Number)],t.prototype,"edlStrength",void 0),__decorate([uniform$1("uNear"),__metadata("design:type",Number)],t.prototype,"uNear",void 0),__decorate([uniform$1("uFar"),__metadata("design:type",Number)],t.prototype,"uFar",void 0),__decorate([uniform$1("radius"),__metadata("design:type",Number)],t.prototype,"radius",void 0),__decorate([uniform$1("neighbours",!0),__metadata("design:type",Float32Array)],t.prototype,"neighbours",void 0),__decorate([uniform$1("depthMap"),__metadata("design:type",THREE__namespace.Texture)],t.prototype,"depthMap",void 0),__decorate([uniform$1("uEDLColor"),__metadata("design:type",THREE__namespace.Texture)],t.prototype,"uEDLColor",void 0),__decorate([uniform$1("uEDLDepth"),__metadata("design:type",THREE__namespace.Texture)],t.prototype,"uEDLDepth",void 0),__decorate([uniform$1("uProj"),__metadata("design:type",Array)],t.prototype,"uProj",void 0),t}(THREE__namespace.RawShaderMaterial);function makeUniform$1(n,t){return{type:n,value:t}}function uniform$1(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 passCamera$1=new THREE__namespace.OrthographicCamera(-1,1,1,-1,0,1),geometry$2=new THREE__namespace.BufferGeometry;geometry$2.setAttribute("position",new THREE__namespace.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3)),geometry$2.setAttribute("uv",new THREE__namespace.Float32BufferAttribute([0,2,0,0,2,0],2));var mesh$2=new THREE__namespace.Mesh(geometry$2),edlEffectScene=new THREE__namespace.Scene;edlEffectScene.add(mesh$2);var EDLEffect=function(n){__extends(t,n);function t(e,r,i,o){var s=n.call(this,e,r,i,o)||this;return s.sharedV2=new THREE__namespace.Vector2,s.renderer=e,s.material=new EDLMaterial,mesh$2.material=s.material,s}return t.prototype.render=function(e){var r=this.camera,i=this.material.uniforms,o=this.renderer.getSize(this.sharedV2);i.screenWidth.value=o.x,i.screenHeight.value=o.y;var s=r.projectionMatrix,u=new Float32Array(16);u.set(s.elements);for(var l=new Float32Array(this.material.neighbourCount*2),d=0;d<this.material.neighbourCount;d++)l[2*d+0]=Math.cos(2*d*Math.PI/this.material.neighbourCount),l[2*d+1]=Math.sin(2*d*Math.PI/this.material.neighbourCount);i.neighbours.value=l,i.uNear.value=r.near,i.uFar.value=r.far,i.uEDLColor.value=e[0].texture,i.uProj.value=u,i.edlStrength.value=.25,i.radius.value=1,i.opacity.value=1,this.renderer.setRenderTarget(null),this.renderer.render(edlEffectScene,passCamera$1)},t.prototype.dispose=function(){this.copyPass.dispose()},t}(Effect);const fragment=function n(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}(`}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`),vertex=function n(){for(var t=[],e=0;e<arguments.length;e++)t[e]=arguments[e];var r=113,i=126,o=0,s="";return t[o].split(s).map(function(u){return u.charCodeAt(o)>i?u:String.fromCharCode((u.charCodeAt(o)+r)%i)}).join(s)}(`}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 HQMaterial=function(n){__extends(t,n);function t(e){var r=n.call(this,{vertexShader:vertex,fragmentShader:fragment})||this;return r.uniforms={uDepthMap:makeUniform("t",null),uWeightMap:makeUniform("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}},__decorate([uniform("uDepthMap"),__metadata("design:type",Number)],t.prototype,"uDepthMap",void 0),__decorate([uniform("uWeightMap"),__metadata("design:type",Number)],t.prototype,"uWeightMap",void 0),t}(THREE__namespace.RawShaderMaterial);function makeUniform(n,t){return{type:n,value:t}}function uniform(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 passCamera=new THREE__namespace.OrthographicCamera(-1,1,1,-1,0,1),geometry$1=new THREE__namespace.BufferGeometry;geometry$1.setAttribute("position",new THREE__namespace.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3)),geometry$1.setAttribute("uv",new THREE__namespace.Float32BufferAttribute([0,2,0,0,2,0],2));var mesh$1=new THREE__namespace.Mesh(geometry$1),hqScene=new THREE__namespace.Scene;hqScene.add(mesh$1);var HQEffect=function(n){__extends(t,n);function t(e,r,i,o){var s=n.call(this,e,r,i,o)||this;return s.sharedV2=new THREE__namespace.Vector2,s.renderer=e,s.material=new HQMaterial,s.scene=r,s.camera=i,mesh$1.material=s.material,s}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(hqScene,passCamera),this.models.setMaterial({useHQWeight:!1,useHQDepth:!0}),this.models.update(this.renderer,this.camera,"Mapview")},t.prototype.dispose=function(){this.copyPass.dispose()},t}(Effect),RAYCASTER_NEAR=.5,minDistance=0,MapviewController=function(n){__extends(t,n);function t(e){var r=this,i,o=t.parseArgs(e);return r=n.call(this,o)||this,r.mode="Mapview",r.defaultLongitude=o.defaultLongitude,r.defaultLatitude=o.defaultLatitude,r.defaultDistance=o.defaultDistance,r.maxLatitude=o.maxLatitude,r.minLatitude=o.minLatitude,r.locationMotion=new Motion({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 Motion({modelAlpha:(i=r.models.getMaterial().modelAlpha)!==null&&i!==void 0?i:0}),r.perspToOrthoMotion=new Motion({perspToOrtho:r.camera.perspToOrtho.x}),r.intersectMeshCreator=o.intersectMeshCreator,r.intersectMesh=r.intersectMeshCreator(),r.intersectMesh.name="intersect",r.intersectMesh.visible=!1,r.currentTapId=null,r.helper.add(r.intersectMesh),r.edlTarget=new THREE__namespace.WebGLRenderTarget(1024,1024,{minFilter:THREE__namespace.NearestFilter,magFilter:THREE__namespace.NearestFilter,format:THREE__namespace.RGBAFormat,type:THREE__namespace.FloatType,depthTexture:new THREE__namespace.DepthTexture(1024,1024,THREE__namespace.UnsignedIntType)}),r.edlEffect=new EDLEffect(r.renderer,r.scene,r.camera,r.models),r.hqEffect=new HQEffect(r.renderer,r.scene,r.camera,r.models),r}return t.parseArgs=function(e){var r,i,o,s,u,l;if(e instanceof t)return e;var d=n.parseArgs.call(this,e);return __assign(__assign({},d),{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:(o=e.defaultDistance)!==null&&o!==void 0?o:150,maxLatitude:(s=e.maxLatitude)!==null&&s!==void 0?s:+Math.PI/2,minLatitude:(u=e.minLatitude)!==null&&u!==void 0?u:0,intersectMeshCreator:(l=e.intersectMeshCreator)!==null&&l!==void 0?l:function(){return new IntersectMesh}})},t.distanceFromModel=function(e,r,i){var o=e.bounding,s=Math.pow(Math.pow(o.max.x-o.min.x+1,2)+Math.pow(o.max.y-o.min.y+1,2)+Math.pow(o.max.z-o.min.z+1,2),1/2),u=s/2/Math.tan(Math.PI*r/360);return i<1&&(u=u/i),isNaN(u)?s:u},t.initAnimationEndState=function(e){var r,i,o,s,u,l,d,c=this.parseArgs(e),f=c.works,h=c.models,v=e.initial,A=v.state,m=v.currentState,y=typeof A.panoIndex=="number"?{workCode:(o=(r=A.workCode)!==null&&r!==void 0?r:(i=c.works[0])===null||i===void 0?void 0:i.workCode)!==null&&o!==void 0?o:"",panoIndex:A.panoIndex}:{workCode:m.workCode,panoIndex:m.panoIndex},p=f.getResolvedObserver(y),g=(s=A.fov)!==null&&s!==void 0?s:60,b=clamp((u=A.latitude)!==null&&u!==void 0?u:isThirdPersonMode(m.mode)?m.latitude:c.defaultLatitude,c.minLatitude,c.maxLatitude),T=t.distanceFromModel(c.models,g,c.camera.aspect),_=new THREE__namespace.Vector3,w=(l=A.distance)!==null&&l!==void 0?l:Math.min(c.defaultDistance,T),x=(d=A.longitude)!==null&&d!==void 0?d:isThirdPersonMode(m.mode)?m.longitude:c.defaultLongitude;return A.offset?_.copy(A.offset):c.defaultDistance<T&&p?(_.copy(p.position),A.longitude===void 0&&(x=m.longitude)):_.copy(h.bounding.getCenter(_)),h.bounding.containsPoint(_)||h.bounding.getCenter(_),__assign(__assign({},y),{mode:"Mapview",longitude:x,latitude:b,fov:g,offset:_,distance:w})},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,o){this.userAction=o,this.works=e;var s=t.initAnimationEndState(__assign(__assign({},this),{initial:{currentState:__assign(__assign({},this.currentPano),this.camera.pose),duration:i,state:r,userAction:o}}));this.currentPano={workCode:s.workCode,panoIndex:s.panoIndex};var u={longitude:s.longitude,latitude:s.latitude,fov:s.fov},l={x:s.offset.x,y:s.offset.y,z:s.offset.z,distance:s.distance,orthoDistance:s.distance};return this.locationMotion.set(l,i).catch(noop$1),this.cameraMotion.set(u,i).catch(noop$1),!0},t.prototype.updateModel=function(e){n.prototype.updateModel.call(this,e)},t.prototype.updateCamera=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();var s={},u={};return e.distance!==void 0&&(s.distance=e.distance),e.offset!==void 0&&(s.x=e.offset.x,s.y=e.offset.y,s.z=e.offset.z),e.longitude!==void 0&&(u.longitude=e.longitude),e.latitude!==void 0&&(u.latitude=e.latitude),e.fov!==void 0&&(u.fov=e.fov),o.locationMotion.set(s,r).catch(noop$1),o.cameraMotion.set(u,r).catch(noop$1)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();for(var s=[],u=[],l=0,d=e;l<d.length;l++){var c=d[l];s.push({key:c.key,progress:c.progress,value:{distance:c.value.distance,x:c.value.offset.x,y:c.value.offset.x,z:c.value.offset.x}}),u.push({key:c.key,progress:c.progress,value:{longitude:c.value.longitude,latitude:c.value.latitude,fov:c.value.fov}})}return o.locationMotion.setKeyframes(s,r).catch(noop$1),o.cameraMotion.setKeyframes(e,r)})},t.prototype.updateTime=function(e,r){if(!this.destroyed){var i={},o={};if(this.locationMotion.ended||(this.locationMotion.update(e),o.distance=this.locationMotion.value.distance,o.offset=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z)),!this.cameraMotion.ended){this.cameraMotion.update(e),o.longitude=this.cameraMotion.value.longitude,o.latitude=this.cameraMotion.value.latitude,o.fov=this.cameraMotion.value.fov;var s=Math.PI/2-o.latitude<.02?1:0;this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho!==s&&this.perspToOrthoMotion.set({perspToOrtho:s},500).catch(noop$1)}this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),i.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),isEmptyObject(i)||this.models.setMaterial(i),isEmptyObject(o)||this.setCamera(o)}},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1],r=this.locationMotion.getKeyFrameSegment(now())[1];return __assign(__assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,distance:r.value.distance,offset:new THREE__namespace.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 o=i.duration,s=i.userAction;e.userAction=s;var u=t.initAnimationEndState(e),l={longitude:u.longitude,latitude:u.latitude,fov:u.fov},d={x:u.offset.x,y:u.offset.y,z:u.offset.z,distance:u.distance},c={modelAlpha:1},f={perspToOrtho:0};e.emit("initAnimation.start",createEvent("initAnimation.start",{state:u,userAction:e.userAction})),e.perspToOrthoMotion.set(f,o).catch(noop$1),e.modelAlphaMotion.set(c,o/3).catch(noop$1),e.cameraMotion.set(l,o).catch(noop$1),e.locationMotion.set(d,o).then(function(){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:u,userAction:e.userAction}))},function(h){var v=__assign(__assign(__assign({},e.currentPano),{mode:e.mode}),clonePose(e.camera.pose));e.emit("initAnimation.end",createEvent("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,o=arrayMin(i,function(l){return l.standingPosition.distanceTo(r.point)},!0),s=o[0],u=o[1];return s&&u<10?s:null},t.prototype.coordinatesForOffset=function(e){var r=this.renderer.getSize(new THREE__namespace.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,o){var s=this;if(this.inMomentumMovement!==null){for(var u=__assign({},i),l={longitude:0,latitude:0,x:0,y:0,z:0},d=0;d<o;d++)u.longitude*=.996,u.latitude*=.996*.998,u.x*=.99,u.y*=.99,u.z*=.99,l.longitude+=u.longitude,l.latitude+=u.latitude,l.x+=u.x,l.y+=u.y,l.z+=u.z;var c=formatRad(this.cameraMotion.value.longitude+l.longitude),f=clamp(this.cameraMotion.value.latitude+l.latitude,this.minLatitude,this.maxLatitude),h=clamp(this.locationMotion.value.x+l.x,this.models.bounding.min.x,this.models.bounding.max.x),v=clamp(this.locationMotion.value.y+l.y,this.models.bounding.min.y,this.models.bounding.max.y),A=clamp(this.locationMotion.value.z+l.z,this.models.bounding.min.z,this.models.bounding.max.z),m=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:c,latitude:f,offset:new THREE__namespace.Vector3(h,v,A),fov:this.cameraMotion.value.fov,distance:this.camera.pose.distance}),y=!(Math.abs(u.longitude)>1e-4||Math.abs(u.latitude)>1e-4||Math.abs(u.x)>1e-4||Math.abs(u.y)>1e-4||Math.abs(u.z)>1e-4),p=createEvent("gesture.momentum",__assign(__assign({},e),{isFirst:r,isFinal:y,state:m}));if(this.inMomentumMovement.event=p,this.emit("gesture.momentum",p),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:c,latitude:f},0).catch(noop$1),this.locationMotion.set({x:m.offset.x,y:m.offset.y,z:m.offset.z},0).catch(noop$1),y?this.inMomentumMovement=null:AnimationFrameLoop.shared.add(function(g,b){s.requestMomentumMovement(e,!1,u,b|0)},!0,1))}},t.prototype.fixFinalState=function(e){if(this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho!==1){var r=coordinatesToVector(e,new THREE__namespace.Vector3),i=new THREE__namespace.Vector3().copy(e.offset).sub(r.clone().multiplyScalar(e.distance)),o=new THREE__namespace.Raycaster(i,r);o.params.Points={threshold:.1},o.near=RAYCASTER_NEAR;var s=this.models.intersectRaycaster(o)[0];if(!s&&o.ray.direction.y<-.3){var u=new THREE__namespace.Plane(new THREE__namespace.Vector3(0,1,0),0),l=o.ray.intersectPlane(u,new THREE__namespace.Vector3);if(l){var d=l.distanceTo(o.ray.origin);d<1e4&&d>=o.near&&(s={distance:d,floor:0,point:l,object:this.scene,face:null})}}s&&(e.distance=clamp(s.distance,minDistance,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,o=0;e.pointerType==="mouse"&&(o=e.srcEvent.buttons),i&&o===0&&i.buttons!==0&&(o=i.buttons);var s=i==null?void 0:i.target;if(!s){var u=this.relativeClientPosition(e.center),l=new THREE__namespace.Raycaster;l.params.Points={threshold:.1},l.setFromCamera(u,this.camera),l.near=RAYCASTER_NEAR,s=new THREE__namespace.Vector3().copy(l.ray.direction).multiplyScalar(3).add(l.ray.origin);var d=this.models.intersectRaycaster(l)[0];if(!d&&l.ray.direction.y<-.3){var c=new THREE__namespace.Plane(new THREE__namespace.Vector3(0,1,0),0),f=l.ray.intersectPlane(c,new THREE__namespace.Vector3);if(f){var h=f.distanceTo(l.ray.origin);h<1e4&&h>=l.near&&(d={distance:h,floor:0,point:f,object:this.scene})}}if(d)s.copy(d.point);else{var v=new THREE__namespace.Vector3().copy(this.camera.pose.offset).sub(this.camera.position),c=new THREE__namespace.Plane().setFromNormalAndCoplanarPoint(v,this.camera.pose.offset);l.ray.intersectPlane(c,s)}}if(e.isFinal?delete this.panState:this.panState={target:s,buttons:o,pointerLength:r,x:e.center.x,y:e.center.y},!(typeof i>"u"||i.pointerLength!==r)){var A=r>1||o===2;if(A){var m={x:e.center.x-i.x,y:e.center.y-i.y},y=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),p=coordinatesToVector(this.cameraMotion.value).setLength(this.locationMotion.value.distance).add(y),g=new THREE__namespace.Vector3().copy(p).sub(i.target).length();g*=Math.tan(this.camera.pose.fov/2*Math.PI/180);var b=this.renderer.getSize(new THREE__namespace.Vector2),T=2*m.x*g/b.y,_=2*m.y*g/b.y,w=new THREE__namespace.Vector3;w.setFromMatrixColumn(this.camera.matrix,0),w.multiplyScalar(-T),y.add(w),this.camera.pose.latitude<Math.PI/12?w.setFromMatrixColumn(this.camera.matrix,1):(w.setFromMatrixColumn(this.camera.matrix,0),w.crossVectors(this.camera.up,w)),w.multiplyScalar(_),y.add(w),y.clamp(this.models.bounding.min,this.models.bounding.max);var x=__assign(__assign({},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=x,this.emit("gesture.pan",e),e.defaultPrevented)return;if(this.locationMotion.set({x:x.offset.x,y:x.offset.y,z:x.offset.z},0).catch(noop$1),e.isFinal&&(this.fixFinalState(x),this.locationMotion.set({distance:x.distance,x:x.offset.x,y:x.offset.y,z:x.offset.z},0).catch(noop$1)),e.isFinal){var M=this.renderer.getSize(new THREE__namespace.Vector2),R=2*e.velocityX*g/M.y,I=2*e.velocityY*g/M.y,S=new THREE__namespace.Vector3,B=new THREE__namespace.Vector3;S.setFromMatrixColumn(this.camera.matrix,0),S.multiplyScalar(-R),B.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(I),B.add(S),this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,{longitude:0,latitude:0,x:B.x,y:B.y,z:B.z},0)}}else{var m={x:e.center.x-i.x,y:e.center.y-i.y},F=this.coordinatesForOffset(m),O=formatRad(this.cameraMotion.value.longitude+F.longitude),H=clamp(this.cameraMotion.value.latitude+F.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&&(H=this.cameraMotion.value.latitude);var x=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:O,latitude:H,fov:this.camera.pose.fov,offset:this.camera.pose.offset,distance:this.camera.pose.distance});if(e.isFinal&&this.fixFinalState(x),e.state=x,this.emit("gesture.pan",e),e.defaultPrevented)return;if(e.isFinal?this.locationMotion.set({distance:x.distance,x:x.offset.x,y:x.offset.y,z:x.offset.z},0).catch(noop$1):this.cameraMotion.set({longitude:x.longitude,latitude:x.latitude},0).catch(noop$1),e.isFinal){var k=e.velocityX,N=e.velocityY;this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,__assign(__assign({},this.coordinatesForOffset({x:k,y:N})),{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 THREE__namespace.Vector3);var o=t.distanceFromModel(this.models,this.cameraMotion.value.fov,this.camera.aspect)*1.3,s=clamp(i/e.scale,minDistance,1/0),u=e.state.offset.clone().sub(coordinatesToVector(e.state).setLength(s)),l=this.models.bounding.containsPoint(u),d;!l&&this.pinchState&&this.pinchState.scale>e.scale&&s>o?d=e.state.distance:(d=s,this.pinchState&&(this.pinchState.scale=e.scale)),e.state.distance=d,this.emit("gesture.pinch",e),!e.defaultPrevented&&(this.locationMotion.set({distance:e.state.distance},0).catch(noop$1),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 o=e.center.raycaster;if(o.near=RAYCASTER_NEAR,o.far=500,e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}var s=this.models.intersectRaycaster(o)[0],u=createEvent("intersect.update",{raycaster:o,intersection:s??null,object:this.intersectMesh});if(this.emit("intersect.update",u),u.defaultPrevented){this.hideIntersectMesh();return}if(s){var l=(i=(r=s.face)===null||r===void 0?void 0:r.normal)!==null&&i!==void 0?i:new THREE__namespace.Vector3().copy(o.ray.direction).multiplyScalar(-1),d=l.clone().multiplyScalar(.05),c=s.point.clone().add(d);this.intersectMesh.position.copy(c);var f=c.clone().add(d);if(this.intersectMesh.lookAt(f),Math.abs(l.y)>.99){var h=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(h.z,h.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(noop$1)}else{var o=e.center.delta/2*Math.max(Math.log(this.locationMotion.value.distance),1),s=t.distanceFromModel(this.models,this.cameraMotion.value.fov,this.camera.aspect)*1.3,u=clamp(this.locationMotion.value.distance-o,minDistance,1/0),l=e.state.offset.clone().sub(coordinatesToVector(e.state).setLength(u)),d=this.models.bounding.containsPoint(l),c=!d&&o<0&&u>s?e.state.distance:u;if(e.state.distance=u,this.emit("gesture.mousewheel",e),e.defaultPrevented)return;this.locationMotion.set({distance:c},0).catch(noop$1)}},t.prototype.onTapGesture=function(e){var r=this;this.userAction=e.userAction,this.stopMomentumMovement();var i=e.center.raycaster,o=this.getForwardObserverOrNot(i);if(!o)this.emit("gesture.tap",e);else{var s={longitude:this.camera.pose.longitude,latitude:0},u=__assign(__assign({},e.state),{mode:"Panorama",workCode:o.pano.workCode,panoIndex:o.pano.panoIndex,longitude:s.longitude,latitude:s.latitude,offset:o?o.position.clone():new THREE__namespace.Vector3,distance:0});if(e.state=u,this.emit("gesture.tap",e),!e.defaultPrevented&&(this.emit("pano.select",createEvent("pano.select",{prevPano:this.currentPano,state:u,userAction:e.userAction,options:s,progress:0,error:null})),o&&o.active)){var l=this.currentTapId=createUuid();this.preloadPano(o.pano).then(function(d){r.currentTapId===l&&r.emit("pano.request",createEvent("pano.request",{userAction:!0,prevPano:r.currentPano,progress:0,state:u,options:s,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}(BaseController);function isNil(n){return n==null}var _moveEvent={type:"move"},XRController=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 THREE__namespace.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 THREE__namespace.Group,this._targetRay.matrixAutoUpdate=!1,this._targetRay.visible=!1,this._targetRay.hasLinearVelocity=!1,this._targetRay.linearVelocity=new THREE__namespace.Vector3,this._targetRay.hasAngularVelocity=!1,this._targetRay.angularVelocity=new THREE__namespace.Vector3),this._targetRay},n.prototype.getGripSpace=function(){return this._grip===null&&(this._grip=new THREE__namespace.Group,this._grip.matrixAutoUpdate=!1,this._grip.visible=!1,this._grip.hasLinearVelocity=!1,this._grip.linearVelocity=new THREE__namespace.Vector3,this._grip.hasAngularVelocity=!1,this._grip.angularVelocity=new THREE__namespace.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,o=null,s=null,u=this._targetRay,l=this._grip,d=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(u!==null&&(i=e.getPose(t.targetRaySpace,r),i!==null&&(u.matrix.fromArray(i.transform.matrix),u.matrix.decompose(u.position,u.rotation,u.scale),i.linearVelocity?(u.hasLinearVelocity=!0,u.linearVelocity.copy(i.linearVelocity)):u.hasLinearVelocity=!1,i.angularVelocity?(u.hasAngularVelocity=!0,u.angularVelocity.copy(i.angularVelocity)):u.hasAngularVelocity=!1,this.dispatchEvent(_moveEvent))),d&&t.hand){s=!0;for(var c=0,f=t.hand.values();c<f.length;c++){var h=f[c],v=e.getJointPose(h,r);if(d.joints[h.jointName]===void 0){var A=new THREE__namespace.Group;A.matrixAutoUpdate=!1,A.visible=!1,d.joints[h.jointName]=A,d.add(A)}var m=d.joints[h.jointName];v!==null&&(m.matrix.fromArray(v.transform.matrix),m.matrix.decompose(m.position,m.rotation,m.scale),m.jointRadius=v.radius),m.visible=v!==null}var y=d.joints["index-finger-tip"],p=d.joints["thumb-tip"],g=y.position.distanceTo(p.position),b=.02,T=.005;d.inputState.pinching&&g>b+T?(d.inputState.pinching=!1,this.dispatchEvent({type:"pinchend",handedness:t.handedness,target:this})):!d.inputState.pinching&&g<=b-T&&(d.inputState.pinching=!0,this.dispatchEvent({type:"pinchstart",handedness:t.handedness,target:this}))}else l!==null&&t.gripSpace&&(o=e.getPose(t.gripSpace,r),o!==null&&(l.matrix.fromArray(o.transform.matrix),l.matrix.decompose(l.position,l.rotation,l.scale),o.linearVelocity?(l.hasLinearVelocity=!0,l.linearVelocity.copy(o.linearVelocity)):l.hasLinearVelocity=!1,o.angularVelocity?(l.hasAngularVelocity=!0,l.angularVelocity.copy(o.angularVelocity)):l.hasAngularVelocity=!1));return u!==null&&(u.visible=i!==null),l!==null&&(l.visible=o!==null),d!==null&&(d.visible=s!==null),this},n}(),framebufferScaleFactor=1,XRManager=function(){function n(t,e,r){var i,o,s,u,l;this.isPanorama=(i=r==null?void 0:r.isPanorama)!==null&&i!==void 0?i:!0,this.machineType=(o=r==null?void 0:r.machineType)!==null&&o!==void 0?o:"Pico",this.renderer=t,this.gl=e,this.enabled=!1,this.session=null,this.referenceSpaceType=(s=r==null?void 0:r.referenceSpaceType)!==null&&s!==void 0?s:"local-floor",this.referenceSpace=null,this.onSessionStartCallback=(u=r==null?void 0:r.onSessionStart)!==null&&u!==void 0?u:noop$1,this.onSessionEndCallback=(l=r==null?void 0:r.onSessionEnd)!==null&&l!==void 0?l:noop$1,this.controllers=[new XRController,new XRController],this.inputSourcesMap=new Map,this.cameraVR=new THREE__namespace.ArrayCamera,this.cameraL=new THREE__namespace.PerspectiveCamera,this.cameraR=new THREE__namespace.PerspectiveCamera,this.cameraL.viewport=new THREE__namespace.Vector4,this.cameraR.viewport=new THREE__namespace.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 THREE__namespace.Vector3,this.cameraRPos=new THREE__namespace.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),o=e.projectionMatrix.elements,s=r.projectionMatrix.elements,u=o[14]/(o[10]-1),l=o[14]/(o[10]+1),d=(o[9]+1)/o[5],c=(o[9]-1)/o[5],f=(o[8]-1)/o[0],h=(s[8]+1)/s[0],v=u*f,A=u*h,m=i/(-f+h),y=m*-f;e.matrixWorld.decompose(t.position,t.quaternion,t.scale),t.translateX(y),t.translateZ(m),t.matrixWorld.compose(t.position,t.quaternion,t.scale),t.matrixWorldInverse.getInverse(t.matrixWorld);var p=u+m,g=l+m,b=v-y,T=A+(i-y),_=d*l/g*p,w=c*l/g*p;t.projectionMatrix.makePerspective(b,T,_,w,p,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 o=t.children,i=0,s=o.length;i<s;i++)o[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],o=this.inputSourcesMap.get(i);o&&(o.dispatchEvent({type:"disconnected",data:i}),this.inputSourcesMap.delete(i))}for(var r=0;r<t.added.length;r++){var i=t.added[r],o=this.inputSourcesMap.get(i);o&&o.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,AnimationFrameLoop.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};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(o){e.onRequestReferenceSpace(o)}),e.session.addEventListener("inputsourceschange",function(o){e.updateInputSources(o)})})}},n}(),LineSegmentsGeometry=function(n){__extends(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],o=[0,2,1,2,3,1,2,4,3,4,5,3,4,6,5,6,7,5];return e.setIndex(o),e.setAttribute("position",new THREE__namespace.Float32BufferAttribute(r,3)),e.setAttribute("uv",new THREE__namespace.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 THREE__namespace.InstancedInterleavedBuffer(r,6,1);return this.setAttribute("instanceStart",new THREE__namespace.InterleavedBufferAttribute(i,3,0)),this.setAttribute("instanceEnd",new THREE__namespace.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 THREE__namespace.InstancedInterleavedBuffer(r,6,1);return this.setAttribute("instanceColorStart",new THREE__namespace.InterleavedBufferAttribute(i,3,0)),this.setAttribute("instanceColorEnd",new THREE__namespace.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 THREE__namespace.WireframeGeometry(e.geometry)),this},t.prototype.fromLineSegments=function(e){var r=e.geometry;if(r instanceof THREE__namespace.Geometry){var i=new THREE__namespace.BufferGeometry().fromGeometry(r);this.setPositions(i.attributes.position.array)}else r instanceof THREE__namespace.BufferGeometry&&this.setPositions(r.attributes.position.array);return this},t.prototype.computeBoundingBox=function(){this.boundingBox===null&&(this.boundingBox=new THREE__namespace.Box3);var e=this.attributes.instanceStart,r=this.attributes.instanceEnd;if(e!==void 0&&r!==void 0){var i=new THREE__namespace.Box3;this.boundingBox.setFromBufferAttribute(e),i.setFromBufferAttribute(r),this.boundingBox.union(i)}},t.prototype.computeBoundingSphere=function(){this.boundingSphere===null&&(this.boundingSphere=new THREE__namespace.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 o=0,s=new THREE__namespace.Vector3,u=0,l=e.count;u<l;u++)s.fromBufferAttribute(e,u),o=Math.max(o,i.distanceToSquared(s)),s.fromBufferAttribute(r,u),o=Math.max(o,i.distanceToSquared(s));this.boundingSphere.radius=Math.sqrt(o),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}(THREE__namespace.InstancedBufferGeometry);Object.assign(LineSegmentsGeometry.prototype,{isLineSegmentsGeometry:!0});var lineShader={uniforms:THREE__namespace.UniformsUtils.merge([THREE__namespace.UniformsLib.common,THREE__namespace.UniformsLib.fog,{linewidth:{value:1},resolution:{value:new THREE__namespace.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 HQMaterial=function(n){__extends(t,n);function t(e){var r=n.call(this,{vertexShader:vertex,fragmentShader:fragment})||this;return r.uniforms={uDepthMap:makeUniform("t",null),uWeightMap:makeUniform("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}},__decorate([uniform("uDepthMap"),__metadata("design:type",Number)],t.prototype,"uDepthMap",void 0),__decorate([uniform("uWeightMap"),__metadata("design:type",Number)],t.prototype,"uWeightMap",void 0),t}(THREE__namespace.RawShaderMaterial);function makeUniform(n,t){return{type:n,value:t}}function uniform(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 passCamera=new THREE__namespace.OrthographicCamera(-1,1,1,-1,0,1),geometry$1=new THREE__namespace.BufferGeometry;geometry$1.setAttribute("position",new THREE__namespace.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3)),geometry$1.setAttribute("uv",new THREE__namespace.Float32BufferAttribute([0,2,0,0,2,0],2));var mesh$1=new THREE__namespace.Mesh(geometry$1),hqScene=new THREE__namespace.Scene;hqScene.add(mesh$1);var HQEffect=function(n){__extends(t,n);function t(e,r,i,o){var s=n.call(this,e,r,i,o)||this;return s.sharedV2=new THREE__namespace.Vector2,s.renderer=e,s.material=new HQMaterial,s.scene=r,s.camera=i,mesh$1.material=s.material,s}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(hqScene,passCamera),this.models.setMaterial({useHQWeight:!1,useHQDepth:!0}),this.models.update(this.renderer,this.camera,"Mapview")},t.prototype.dispose=function(){this.copyPass.dispose()},t}(Effect),RAYCASTER_NEAR=.5,minDistance=0,MapviewController=function(n){__extends(t,n);function t(e){var r=this,i,o=t.parseArgs(e);return r=n.call(this,o)||this,r.mode="Mapview",r.defaultLongitude=o.defaultLongitude,r.defaultLatitude=o.defaultLatitude,r.defaultDistance=o.defaultDistance,r.maxLatitude=o.maxLatitude,r.minLatitude=o.minLatitude,r.locationMotion=new Motion({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 Motion({modelAlpha:(i=r.models.getMaterial().modelAlpha)!==null&&i!==void 0?i:0}),r.perspToOrthoMotion=new Motion({perspToOrtho:r.camera.perspToOrtho.x}),r.intersectMeshCreator=o.intersectMeshCreator,r.intersectMesh=r.intersectMeshCreator(),r.intersectMesh.name="intersect",r.intersectMesh.visible=!1,r.currentTapId=null,r.helper.add(r.intersectMesh),r.edlTarget=new THREE__namespace.WebGLRenderTarget(1024,1024,{minFilter:THREE__namespace.NearestFilter,magFilter:THREE__namespace.NearestFilter,format:THREE__namespace.RGBAFormat,type:THREE__namespace.FloatType,depthTexture:new THREE__namespace.DepthTexture(1024,1024,THREE__namespace.UnsignedIntType)}),r.edlEffect=new EDLEffect(r.renderer,r.scene,r.camera,r.models),r.hqEffect=new HQEffect(r.renderer,r.scene,r.camera,r.models),r}return t.parseArgs=function(e){var r,i,o,s,u,l;if(e instanceof t)return e;var d=n.parseArgs.call(this,e);return __assign(__assign({},d),{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:(o=e.defaultDistance)!==null&&o!==void 0?o:150,maxLatitude:(s=e.maxLatitude)!==null&&s!==void 0?s:+Math.PI/2,minLatitude:(u=e.minLatitude)!==null&&u!==void 0?u:0,intersectMeshCreator:(l=e.intersectMeshCreator)!==null&&l!==void 0?l:function(){return new IntersectMesh}})},t.distanceFromModel=function(e,r,i){var o=e.bounding,s=Math.pow(Math.pow(o.max.x-o.min.x+1,2)+Math.pow(o.max.y-o.min.y+1,2)+Math.pow(o.max.z-o.min.z+1,2),1/2),u=s/2/Math.tan(Math.PI*r/360);return i<1&&(u=u/i),isNaN(u)?s:u},t.initAnimationEndState=function(e){var r,i,o,s,u,l,d,c=this.parseArgs(e),f=c.works,h=c.models,v=e.initial,A=v.state,m=v.currentState,y=typeof A.panoIndex=="number"?{workCode:(o=(r=A.workCode)!==null&&r!==void 0?r:(i=c.works[0])===null||i===void 0?void 0:i.workCode)!==null&&o!==void 0?o:"",panoIndex:A.panoIndex}:{workCode:m.workCode,panoIndex:m.panoIndex},p=f.getResolvedObserver(y),g=(s=A.fov)!==null&&s!==void 0?s:60,b=clamp((u=A.latitude)!==null&&u!==void 0?u:isThirdPersonMode(m.mode)?m.latitude:c.defaultLatitude,c.minLatitude,c.maxLatitude),T=t.distanceFromModel(c.models,g,c.camera.aspect),_=new THREE__namespace.Vector3,w=(l=A.distance)!==null&&l!==void 0?l:Math.min(c.defaultDistance,T),x=(d=A.longitude)!==null&&d!==void 0?d:isThirdPersonMode(m.mode)?m.longitude:c.defaultLongitude;return A.offset?_.copy(A.offset):c.defaultDistance<T&&p?(_.copy(p.position),A.longitude===void 0&&(x=m.longitude)):_.copy(h.bounding.getCenter(_)),h.bounding.containsPoint(_)||h.bounding.getCenter(_),__assign(__assign({},y),{mode:"Mapview",longitude:x,latitude:b,fov:g,offset:_,distance:w})},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,o){this.userAction=o,this.works=e;var s=t.initAnimationEndState(__assign(__assign({},this),{initial:{currentState:__assign(__assign({},this.currentPano),this.camera.pose),duration:i,state:r,userAction:o}}));this.currentPano={workCode:s.workCode,panoIndex:s.panoIndex};var u={longitude:s.longitude,latitude:s.latitude,fov:s.fov},l={x:s.offset.x,y:s.offset.y,z:s.offset.z,distance:s.distance,orthoDistance:s.distance};return this.locationMotion.set(l,i).catch(noop$1),this.cameraMotion.set(u,i).catch(noop$1),!0},t.prototype.updateModel=function(e){n.prototype.updateModel.call(this,e)},t.prototype.updateCamera=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();var s={},u={};return e.distance!==void 0&&(s.distance=e.distance),e.offset!==void 0&&(s.x=e.offset.x,s.y=e.offset.y,s.z=e.offset.z),e.longitude!==void 0&&(u.longitude=e.longitude),e.latitude!==void 0&&(u.latitude=e.latitude),e.fov!==void 0&&(u.fov=e.fov),o.locationMotion.set(s,r).catch(noop$1),o.cameraMotion.set(u,r).catch(noop$1)})},t.prototype.updateCameraWithKeyframes=function(e,r,i){var o=this;return this.initAnimationReady.then(function(){o.userAction=i,o.stopMomentumMovement();for(var s=[],u=[],l=0,d=e;l<d.length;l++){var c=d[l];s.push({key:c.key,progress:c.progress,value:{distance:c.value.distance,x:c.value.offset.x,y:c.value.offset.x,z:c.value.offset.x}}),u.push({key:c.key,progress:c.progress,value:{longitude:c.value.longitude,latitude:c.value.latitude,fov:c.value.fov}})}return o.locationMotion.setKeyframes(s,r).catch(noop$1),o.cameraMotion.setKeyframes(e,r)})},t.prototype.updateTime=function(e,r){if(!this.destroyed){var i={},o={};if(this.locationMotion.ended||(this.locationMotion.update(e),o.distance=this.locationMotion.value.distance,o.offset=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z)),!this.cameraMotion.ended){this.cameraMotion.update(e),o.longitude=this.cameraMotion.value.longitude,o.latitude=this.cameraMotion.value.latitude,o.fov=this.cameraMotion.value.fov;var s=Math.PI/2-o.latitude<.02?1:0;this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho!==s&&this.perspToOrthoMotion.set({perspToOrtho:s},500).catch(noop$1)}this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),i.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),isEmptyObject(i)||this.models.setMaterial(i),isEmptyObject(o)||this.setCamera(o)}},t.prototype.getTargetState=function(){var e=this.cameraMotion.getKeyFrameSegment(now())[1],r=this.locationMotion.getKeyFrameSegment(now())[1];return __assign(__assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,distance:r.value.distance,offset:new THREE__namespace.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 o=i.duration,s=i.userAction;e.userAction=s;var u=t.initAnimationEndState(e),l={longitude:u.longitude,latitude:u.latitude,fov:u.fov},d={x:u.offset.x,y:u.offset.y,z:u.offset.z,distance:u.distance},c={modelAlpha:1},f={perspToOrtho:0};e.emit("initAnimation.start",createEvent("initAnimation.start",{state:u,userAction:e.userAction})),e.perspToOrthoMotion.set(f,o).catch(noop$1),e.modelAlphaMotion.set(c,o/3).catch(noop$1),e.cameraMotion.set(l,o).catch(noop$1),e.locationMotion.set(d,o).then(function(){e.emit("initAnimation.end",createEvent("initAnimation.end",{state:u,userAction:e.userAction}))},function(h){var v=__assign(__assign(__assign({},e.currentPano),{mode:e.mode}),clonePose(e.camera.pose));e.emit("initAnimation.end",createEvent("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,o=arrayMin(i,function(l){return l.standingPosition.distanceTo(r.point)},!0),s=o[0],u=o[1];return s&&u<10?s:null},t.prototype.coordinatesForOffset=function(e){var r=this.renderer.getSize(new THREE__namespace.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,o){var s=this;if(this.inMomentumMovement!==null){for(var u=__assign({},i),l={longitude:0,latitude:0,x:0,y:0,z:0},d=0;d<o;d++)u.longitude*=.996,u.latitude*=.996*.998,u.x*=.99,u.y*=.99,u.z*=.99,l.longitude+=u.longitude,l.latitude+=u.latitude,l.x+=u.x,l.y+=u.y,l.z+=u.z;var c=formatRad(this.cameraMotion.value.longitude+l.longitude),f=clamp(this.cameraMotion.value.latitude+l.latitude,this.minLatitude,this.maxLatitude),h=clamp(this.locationMotion.value.x+l.x,this.models.bounding.min.x,this.models.bounding.max.x),v=clamp(this.locationMotion.value.y+l.y,this.models.bounding.min.y,this.models.bounding.max.y),A=clamp(this.locationMotion.value.z+l.z,this.models.bounding.min.z,this.models.bounding.max.z),m=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:c,latitude:f,offset:new THREE__namespace.Vector3(h,v,A),fov:this.cameraMotion.value.fov,distance:this.camera.pose.distance}),y=!(Math.abs(u.longitude)>1e-4||Math.abs(u.latitude)>1e-4||Math.abs(u.x)>1e-4||Math.abs(u.y)>1e-4||Math.abs(u.z)>1e-4),p=createEvent("gesture.momentum",__assign(__assign({},e),{isFirst:r,isFinal:y,state:m}));if(this.inMomentumMovement.event=p,this.emit("gesture.momentum",p),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:c,latitude:f},0).catch(noop$1),this.locationMotion.set({x:m.offset.x,y:m.offset.y,z:m.offset.z},0).catch(noop$1),y?this.inMomentumMovement=null:AnimationFrameLoop.shared.add(function(g,b){s.requestMomentumMovement(e,!1,u,b|0)},!0,1))}},t.prototype.fixFinalState=function(e){if(this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho!==1){var r=coordinatesToVector(e,new THREE__namespace.Vector3),i=new THREE__namespace.Vector3().copy(e.offset).sub(r.clone().multiplyScalar(e.distance)),o=new THREE__namespace.Raycaster(i,r);o.params.Points={threshold:.1},o.near=RAYCASTER_NEAR;var s=this.models.intersectRaycaster(o)[0];if(!s&&o.ray.direction.y<-.3){var u=new THREE__namespace.Plane(new THREE__namespace.Vector3(0,1,0),0),l=o.ray.intersectPlane(u,new THREE__namespace.Vector3);if(l){var d=l.distanceTo(o.ray.origin);d<1e4&&d>=o.near&&(s={distance:d,floor:0,point:l,object:this.scene,face:null})}}s&&(e.distance=clamp(s.distance,minDistance,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,o=0;e.pointerType==="mouse"&&(o=e.srcEvent.buttons),i&&o===0&&i.buttons!==0&&(o=i.buttons);var s=i==null?void 0:i.target;if(!s){var u=this.relativeClientPosition(e.center),l=new THREE__namespace.Raycaster;l.params.Points={threshold:.1},l.setFromCamera(u,this.camera),l.near=RAYCASTER_NEAR,s=new THREE__namespace.Vector3().copy(l.ray.direction).multiplyScalar(3).add(l.ray.origin);var d=this.models.intersectRaycaster(l)[0];if(!d&&l.ray.direction.y<-.3){var c=new THREE__namespace.Plane(new THREE__namespace.Vector3(0,1,0),0),f=l.ray.intersectPlane(c,new THREE__namespace.Vector3);if(f){var h=f.distanceTo(l.ray.origin);h<1e4&&h>=l.near&&(d={distance:h,floor:0,point:f,object:this.scene})}}if(d)s.copy(d.point);else{var v=new THREE__namespace.Vector3().copy(this.camera.pose.offset).sub(this.camera.position),c=new THREE__namespace.Plane().setFromNormalAndCoplanarPoint(v,this.camera.pose.offset);l.ray.intersectPlane(c,s)}}if(e.isFinal?delete this.panState:this.panState={target:s,buttons:o,pointerLength:r,x:e.center.x,y:e.center.y},!(typeof i>"u"||i.pointerLength!==r)){var A=r>1||o===2;if(A){var m={x:e.center.x-i.x,y:e.center.y-i.y},y=new THREE__namespace.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),p=coordinatesToVector(this.cameraMotion.value).setLength(this.locationMotion.value.distance).add(y),g=new THREE__namespace.Vector3().copy(p).sub(i.target).length();g*=Math.tan(this.camera.pose.fov/2*Math.PI/180);var b=this.renderer.getSize(new THREE__namespace.Vector2),T=2*m.x*g/b.y,_=2*m.y*g/b.y,w=new THREE__namespace.Vector3;w.setFromMatrixColumn(this.camera.matrix,0),w.multiplyScalar(-T),y.add(w),this.camera.pose.latitude<Math.PI/12?w.setFromMatrixColumn(this.camera.matrix,1):(w.setFromMatrixColumn(this.camera.matrix,0),w.crossVectors(this.camera.up,w)),w.multiplyScalar(_),y.add(w),y.clamp(this.models.bounding.min,this.models.bounding.max);var x=__assign(__assign({},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=x,this.emit("gesture.pan",e),e.defaultPrevented)return;if(this.locationMotion.set({x:x.offset.x,y:x.offset.y,z:x.offset.z},0).catch(noop$1),e.isFinal&&(this.fixFinalState(x),this.locationMotion.set({distance:x.distance,x:x.offset.x,y:x.offset.y,z:x.offset.z},0).catch(noop$1)),e.isFinal){var M=this.renderer.getSize(new THREE__namespace.Vector2),R=2*e.velocityX*g/M.y,I=2*e.velocityY*g/M.y,S=new THREE__namespace.Vector3,B=new THREE__namespace.Vector3;S.setFromMatrixColumn(this.camera.matrix,0),S.multiplyScalar(-R),B.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(I),B.add(S),this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,{longitude:0,latitude:0,x:B.x,y:B.y,z:B.z},0)}}else{var m={x:e.center.x-i.x,y:e.center.y-i.y},O=this.coordinatesForOffset(m),F=formatRad(this.cameraMotion.value.longitude+O.longitude),H=clamp(this.cameraMotion.value.latitude+O.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&&(H=this.cameraMotion.value.latitude);var x=__assign(__assign({},this.currentPano),{mode:this.mode,longitude:F,latitude:H,fov:this.camera.pose.fov,offset:this.camera.pose.offset,distance:this.camera.pose.distance});if(e.isFinal&&this.fixFinalState(x),e.state=x,this.emit("gesture.pan",e),e.defaultPrevented)return;if(e.isFinal?this.locationMotion.set({distance:x.distance,x:x.offset.x,y:x.offset.y,z:x.offset.z},0).catch(noop$1):this.cameraMotion.set({longitude:x.longitude,latitude:x.latitude},0).catch(noop$1),e.isFinal){var k=e.velocityX,N=e.velocityY;this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,__assign(__assign({},this.coordinatesForOffset({x:k,y:N})),{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 o=this.models.bounding.getCenter(new THREE__namespace.Vector3),s=t.distanceFromModel(this.models,this.cameraMotion.value.fov,this.camera.aspect),u=clamp(i/e.scale,minDistance,1/0),l=e.state.offset.clone().sub(coordinatesToVector(e.state).setLength(u)),d=this.models.bounding.containsPoint(l),c;!d&&this.pinchState&&this.pinchState.scale>e.scale&&o.distanceTo(l)>s?c=e.state.distance:(c=u,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(noop$1),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 o=e.center.raycaster;if(o.near=RAYCASTER_NEAR,o.far=500,e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}var s=this.models.intersectRaycaster(o)[0],u=createEvent("intersect.update",{raycaster:o,intersection:s??null,object:this.intersectMesh});if(this.emit("intersect.update",u),u.defaultPrevented){this.hideIntersectMesh();return}if(s){var l=(i=(r=s.face)===null||r===void 0?void 0:r.normal)!==null&&i!==void 0?i:new THREE__namespace.Vector3().copy(o.ray.direction).multiplyScalar(-1),d=l.clone().multiplyScalar(.05),c=s.point.clone().add(d);this.intersectMesh.position.copy(c);var f=c.clone().add(d);if(this.intersectMesh.lookAt(f),Math.abs(l.y)>.99){var h=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(h.z,h.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(noop$1)}else{var o=e.center.delta/2*Math.max(Math.log(this.locationMotion.value.distance),1),s=this.models.bounding.getCenter(new THREE__namespace.Vector3),u=t.distanceFromModel(this.models,this.cameraMotion.value.fov,this.camera.aspect),l=clamp(this.locationMotion.value.distance-o,minDistance,1/0),d=e.state.offset.clone().sub(coordinatesToVector(e.state).setLength(l)),c=this.models.bounding.containsPoint(d),f=!c&&o<0&&s.distanceTo(d)>u?e.state.distance:l;if(e.state.distance=l,this.emit("gesture.mousewheel",e),e.defaultPrevented)return;this.locationMotion.set({distance:f},0).catch(noop$1)}},t.prototype.onTapGesture=function(e){var r=this;this.userAction=e.userAction,this.stopMomentumMovement();var i=e.center.raycaster,o=this.getForwardObserverOrNot(i);if(!o)this.emit("gesture.tap",e);else{var s={longitude:this.camera.pose.longitude,latitude:0},u=__assign(__assign({},e.state),{mode:"Panorama",workCode:o.pano.workCode,panoIndex:o.pano.panoIndex,longitude:s.longitude,latitude:s.latitude,offset:o?o.position.clone():new THREE__namespace.Vector3,distance:0});if(e.state=u,this.emit("gesture.tap",e),!e.defaultPrevented&&(this.emit("pano.select",createEvent("pano.select",{prevPano:this.currentPano,state:u,userAction:e.userAction,options:s,progress:0,error:null})),o&&o.active)){var l=this.currentTapId=createUuid();this.preloadPano(o.pano).then(function(d){r.currentTapId===l&&r.emit("pano.request",createEvent("pano.request",{userAction:!0,prevPano:r.currentPano,progress:0,state:u,options:s,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}(BaseController);function isNil(n){return n==null}var _moveEvent={type:"move"},XRController=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 THREE__namespace.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 THREE__namespace.Group,this._targetRay.matrixAutoUpdate=!1,this._targetRay.visible=!1,this._targetRay.hasLinearVelocity=!1,this._targetRay.linearVelocity=new THREE__namespace.Vector3,this._targetRay.hasAngularVelocity=!1,this._targetRay.angularVelocity=new THREE__namespace.Vector3),this._targetRay},n.prototype.getGripSpace=function(){return this._grip===null&&(this._grip=new THREE__namespace.Group,this._grip.matrixAutoUpdate=!1,this._grip.visible=!1,this._grip.hasLinearVelocity=!1,this._grip.linearVelocity=new THREE__namespace.Vector3,this._grip.hasAngularVelocity=!1,this._grip.angularVelocity=new THREE__namespace.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,o=null,s=null,u=this._targetRay,l=this._grip,d=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(u!==null&&(i=e.getPose(t.targetRaySpace,r),i!==null&&(u.matrix.fromArray(i.transform.matrix),u.matrix.decompose(u.position,u.rotation,u.scale),i.linearVelocity?(u.hasLinearVelocity=!0,u.linearVelocity.copy(i.linearVelocity)):u.hasLinearVelocity=!1,i.angularVelocity?(u.hasAngularVelocity=!0,u.angularVelocity.copy(i.angularVelocity)):u.hasAngularVelocity=!1,this.dispatchEvent(_moveEvent))),d&&t.hand){s=!0;for(var c=0,f=t.hand.values();c<f.length;c++){var h=f[c],v=e.getJointPose(h,r);if(d.joints[h.jointName]===void 0){var A=new THREE__namespace.Group;A.matrixAutoUpdate=!1,A.visible=!1,d.joints[h.jointName]=A,d.add(A)}var m=d.joints[h.jointName];v!==null&&(m.matrix.fromArray(v.transform.matrix),m.matrix.decompose(m.position,m.rotation,m.scale),m.jointRadius=v.radius),m.visible=v!==null}var y=d.joints["index-finger-tip"],p=d.joints["thumb-tip"],g=y.position.distanceTo(p.position),b=.02,T=.005;d.inputState.pinching&&g>b+T?(d.inputState.pinching=!1,this.dispatchEvent({type:"pinchend",handedness:t.handedness,target:this})):!d.inputState.pinching&&g<=b-T&&(d.inputState.pinching=!0,this.dispatchEvent({type:"pinchstart",handedness:t.handedness,target:this}))}else l!==null&&t.gripSpace&&(o=e.getPose(t.gripSpace,r),o!==null&&(l.matrix.fromArray(o.transform.matrix),l.matrix.decompose(l.position,l.rotation,l.scale),o.linearVelocity?(l.hasLinearVelocity=!0,l.linearVelocity.copy(o.linearVelocity)):l.hasLinearVelocity=!1,o.angularVelocity?(l.hasAngularVelocity=!0,l.angularVelocity.copy(o.angularVelocity)):l.hasAngularVelocity=!1));return u!==null&&(u.visible=i!==null),l!==null&&(l.visible=o!==null),d!==null&&(d.visible=s!==null),this},n}(),framebufferScaleFactor=1,XRManager=function(){function n(t,e,r){var i,o,s,u,l;this.isPanorama=(i=r==null?void 0:r.isPanorama)!==null&&i!==void 0?i:!0,this.machineType=(o=r==null?void 0:r.machineType)!==null&&o!==void 0?o:"Pico",this.renderer=t,this.gl=e,this.enabled=!1,this.session=null,this.referenceSpaceType=(s=r==null?void 0:r.referenceSpaceType)!==null&&s!==void 0?s:"local-floor",this.referenceSpace=null,this.onSessionStartCallback=(u=r==null?void 0:r.onSessionStart)!==null&&u!==void 0?u:noop$1,this.onSessionEndCallback=(l=r==null?void 0:r.onSessionEnd)!==null&&l!==void 0?l:noop$1,this.controllers=[new XRController,new XRController],this.inputSourcesMap=new Map,this.cameraVR=new THREE__namespace.ArrayCamera,this.cameraL=new THREE__namespace.PerspectiveCamera,this.cameraR=new THREE__namespace.PerspectiveCamera,this.cameraL.viewport=new THREE__namespace.Vector4,this.cameraR.viewport=new THREE__namespace.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 THREE__namespace.Vector3,this.cameraRPos=new THREE__namespace.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),o=e.projectionMatrix.elements,s=r.projectionMatrix.elements,u=o[14]/(o[10]-1),l=o[14]/(o[10]+1),d=(o[9]+1)/o[5],c=(o[9]-1)/o[5],f=(o[8]-1)/o[0],h=(s[8]+1)/s[0],v=u*f,A=u*h,m=i/(-f+h),y=m*-f;e.matrixWorld.decompose(t.position,t.quaternion,t.scale),t.translateX(y),t.translateZ(m),t.matrixWorld.compose(t.position,t.quaternion,t.scale),t.matrixWorldInverse.getInverse(t.matrixWorld);var p=u+m,g=l+m,b=v-y,T=A+(i-y),_=d*l/g*p,w=c*l/g*p;t.projectionMatrix.makePerspective(b,T,_,w,p,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 o=t.children,i=0,s=o.length;i<s;i++)o[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],o=this.inputSourcesMap.get(i);o&&(o.dispatchEvent({type:"disconnected",data:i}),this.inputSourcesMap.delete(i))}for(var r=0;r<t.added.length;r++){var i=t.added[r],o=this.inputSourcesMap.get(i);o&&o.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,AnimationFrameLoop.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};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(o){e.onRequestReferenceSpace(o)}),e.session.addEventListener("inputsourceschange",function(o){e.updateInputSources(o)})})}},n}(),LineSegmentsGeometry=function(n){__extends(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],o=[0,2,1,2,3,1,2,4,3,4,5,3,4,6,5,6,7,5];return e.setIndex(o),e.setAttribute("position",new THREE__namespace.Float32BufferAttribute(r,3)),e.setAttribute("uv",new THREE__namespace.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 THREE__namespace.InstancedInterleavedBuffer(r,6,1);return this.setAttribute("instanceStart",new THREE__namespace.InterleavedBufferAttribute(i,3,0)),this.setAttribute("instanceEnd",new THREE__namespace.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 THREE__namespace.InstancedInterleavedBuffer(r,6,1);return this.setAttribute("instanceColorStart",new THREE__namespace.InterleavedBufferAttribute(i,3,0)),this.setAttribute("instanceColorEnd",new THREE__namespace.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 THREE__namespace.WireframeGeometry(e.geometry)),this},t.prototype.fromLineSegments=function(e){var r=e.geometry;if(r instanceof THREE__namespace.Geometry){var i=new THREE__namespace.BufferGeometry().fromGeometry(r);this.setPositions(i.attributes.position.array)}else r instanceof THREE__namespace.BufferGeometry&&this.setPositions(r.attributes.position.array);return this},t.prototype.computeBoundingBox=function(){this.boundingBox===null&&(this.boundingBox=new THREE__namespace.Box3);var e=this.attributes.instanceStart,r=this.attributes.instanceEnd;if(e!==void 0&&r!==void 0){var i=new THREE__namespace.Box3;this.boundingBox.setFromBufferAttribute(e),i.setFromBufferAttribute(r),this.boundingBox.union(i)}},t.prototype.computeBoundingSphere=function(){this.boundingSphere===null&&(this.boundingSphere=new THREE__namespace.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 o=0,s=new THREE__namespace.Vector3,u=0,l=e.count;u<l;u++)s.fromBufferAttribute(e,u),o=Math.max(o,i.distanceToSquared(s)),s.fromBufferAttribute(r,u),o=Math.max(o,i.distanceToSquared(s));this.boundingSphere.radius=Math.sqrt(o),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}(THREE__namespace.InstancedBufferGeometry);Object.assign(LineSegmentsGeometry.prototype,{isLineSegmentsGeometry:!0});var lineShader={uniforms:THREE__namespace.UniformsUtils.merge([THREE__namespace.UniformsLib.common,THREE__namespace.UniformsLib.fog,{linewidth:{value:1},resolution:{value:new THREE__namespace.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
|
-
`},LineMaterial=function(n){__extends(t,n);function t(e){var r=n.call(this,{uniforms:THREE__namespace.UniformsUtils.clone(lineShader.uniforms),vertexShader:lineShader.vertexShader,fragmentShader:lineShader.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}(THREE__namespace.ShaderMaterial);Object.assign(LineMaterial.prototype,{isLineMaterial:!0});var LineSegments2=function(n){__extends(t,n);function t(e,r){var i=n.call(this)||this;return i.type="LineSegments2",i.geometry=e!==void 0?e:new LineSegmentsGeometry,i.material=r!==void 0?r:new LineMaterial({color:Math.random()*16777215}),i}return t.prototype.computeLineDistances=function(){for(var e=this.geometry,r=e.attributes.instanceStart,i=e.attributes.instanceEnd,o=new Float32Array(2*r.count),s=new THREE__namespace.Vector3,u=new THREE__namespace.Vector3,l=0,d=0,c=r.count;l<c;l++,d+=2)s.fromBufferAttribute(r,l),u.fromBufferAttribute(i,l),o[d]=d===0?0:o[d-1],o[d+1]=o[d]+s.distanceTo(u);var f=new THREE__namespace.InstancedInterleavedBuffer(o,2,1);return e.setAttribute("instanceDistanceStart",new THREE__namespace.InterleavedBufferAttribute(f,1,0)),e.setAttribute("instanceDistanceEnd",new THREE__namespace.InterleavedBufferAttribute(f,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,o=e.camera,s=o.projectionMatrix,u=this.geometry,l=this.material,d=l.resolution,c=l.linewidth,f=u.attributes.instanceStart,h=u.attributes.instanceEnd,v=new THREE__namespace.Vector4,A=new THREE__namespace.Vector4,m=new THREE__namespace.Vector4,y=new THREE__namespace.Vector3,p=new THREE__namespace.Matrix4,g=new THREE__namespace.Line3,b=new THREE__namespace.Vector3;i.at(1,m),m.w=1,m.applyMatrix4(o.matrixWorldInverse),m.applyMatrix4(s),m.multiplyScalar(1/m.w),m.x*=d.x/2,m.y*=d.y/2,m.z=0,y.copy(m);var T=this.matrixWorld;p.multiplyMatrices(o.matrixWorldInverse,T);for(var _=0,w=f.count;_<w;_++){v.fromBufferAttribute(f,_),A.fromBufferAttribute(h,_),v.w=1,A.w=1,v.applyMatrix4(p),A.applyMatrix4(p),v.applyMatrix4(s),A.applyMatrix4(s),v.multiplyScalar(1/v.w),A.multiplyScalar(1/A.w);var x=v.z<-1&&A.z<-1,M=v.z>1&&A.z>1;if(!(x||M)){v.x*=d.x/2,v.y*=d.y/2,A.x*=d.x/2,A.y*=d.y/2,g.start.copy(v),g.start.z=0,g.end.copy(A),g.end.z=0;var R=g.closestPointToPointParameter(y,!0);g.at(R,b);var I=THREE__namespace.MathUtils.lerp(v.z,A.z,R),S=I>=-1&&I<=1,B=y.distanceTo(b)<c*.5;if(S&&B){g.start.fromBufferAttribute(f,_),g.end.fromBufferAttribute(h,_),g.start.applyMatrix4(T),g.end.applyMatrix4(T);var F=new THREE__namespace.Vector3,O=new THREE__namespace.Vector3;i.distanceSqToSegment(g.start,g.end,O,F),r.push({point:O,pointOnLine:F,distance:i.origin.distanceTo(O),object:this,faceIndex:_})}}}},t}(THREE__namespace.Mesh);Object.assign(LineSegments2.prototype,{isLineSegments2:!0});var Line2=function(n){__extends(t,n);function t(e,r){var i=n.call(this,e,r)||this;return i.type="Line2",i}return t}(LineSegments2);Object.assign(Line2.prototype,{isLine2:!0});var LineGeometry=function(n){__extends(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),o=0;o<r;o+=3)i[2*o]=e[o],i[2*o+1]=e[o+1],i[2*o+2]=e[o+2],i[2*o+3]=e[o+3],i[2*o+4]=e[o+4],i[2*o+5]=e[o+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),o=0;o<r;o+=3)i[2*o]=e[o],i[2*o+1]=e[o+1],i[2*o+2]=e[o+2],i[2*o+3]=e[o+3],i[2*o+4]=e[o+4],i[2*o+5]=e[o+5];return n.prototype.setColors.call(this,i),this},t.prototype.fromLine=function(e){var r=e.geometry;if(r instanceof THREE__namespace.Geometry){var i=new THREE__namespace.BufferGeometry().fromGeometry(r);this.setPositions(i.attributes.position.array)}else r instanceof THREE__namespace.BufferGeometry&&this.setPositions(r.attributes.position.array);return this},t.prototype.copy=function(){return this},t}(LineSegmentsGeometry);Object.assign(LineGeometry.prototype,{isLineGeometry:!0});var circleImageURL="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==",DEFAULT_COLOR=14467195,POINT_SIZE=8,DEFAULT_LINEWIDTH=2,DEFAULT_DASHSCALE=20,sharedCircleTexture=null,FiveLine=function(n){__extends(t,n);function t(e,r){e===void 0&&(e=new THREE__namespace.Vector3),r===void 0&&(r=new THREE__namespace.Vector3);var i=n.call(this)||this;i.type="FiveLine",i.needsRender=!0;var o=new LineGeometry,s=new LineMaterial({color:DEFAULT_COLOR,linewidth:DEFAULT_LINEWIDTH,dashScale:DEFAULT_DASHSCALE,dashed:!1});i.line=new Line2(o,s);var u=new THREE__namespace.BufferGeometry,l=new THREE__namespace.PointsMaterial({color:DEFAULT_COLOR,size:POINT_SIZE,map:sharedCircleTexture||(sharedCircleTexture=new THREE__namespace.TextureLoader().load(circleImageURL)),sizeAttenuation:!1,transparent:!0});return i.points=new THREE__namespace.Points(u,l),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.64"},enumerable:!1,configurable:!0}),t.prototype.setPoints=function(e,r){var i=[].concat(e.toArray(),r.toArray());this.points.geometry.setAttribute("position",new THREE__namespace.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 THREE__namespace.Vector3(e[0],e[1],e[2]),new THREE__namespace.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 o=e[i];i==="dashed"?(r.dashed=o,o?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}(THREE__namespace.Object3D);Object.assign(FiveLine.prototype,{isFiveLine:!0});var Constants={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 fetchJsonFile(n){return __awaiter(this,void 0,void 0,function(){var t;return __generator(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 fetchProfilesList(n){return __awaiter(this,void 0,void 0,function(){var t,e;return __generator(this,function(r){switch(r.label){case 0:if(!n)throw new Error("No basePath supplied");return t="profilesList.json",[4,fetchJsonFile("".concat(n,"/").concat(t))];case 1:return e=r.sent(),[2,e]}})})}function fetchProfile(n,t,e,r){return e===void 0&&(e=null),r===void 0&&(r=!0),__awaiter(this,void 0,void 0,function(){var i,o,s,u,l,d;return __generator(this,function(c){switch(c.label){case 0:if(!n)throw new Error("No xrInputSource supplied");if(!t)throw new Error("No basePath supplied");return[4,fetchProfilesList(t)];case 1:if(i=c.sent(),n.profiles.some(function(f){var h=i[f];return h&&(o={profileId:f,profilePath:"".concat(t,"/").concat(h.path),deprecated:!!h.deprecated}),!!o}),!o){if(!e)throw new Error("No matching profile name found");if(s=i[e],!s)throw new Error('No matching profile name found and default profile "'.concat(e,'" missing.'));o={profileId:e,profilePath:"".concat(t,"/").concat(s.path),deprecated:!!s.deprecated}}return[4,fetchJsonFile(o.profilePath)];case 2:if(u=c.sent(),r){if(d=void 0,d=u.layouts[n.handedness],!d)throw new Error("No matching handedness, ".concat(n.handedness,", in profile ").concat(o.profileId));d.assetPath&&(l=o.profilePath.replace("profile.json",d.assetPath))}return[2,{profile:u,assetPath:l}]}})})}var defaultComponentValues={xAxis:0,yAxis:0,button:0,state:Constants.ComponentState.DEFAULT};function normalizeAxes(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 o=Math.atan2(t,n);e=Math.cos(o),r=Math.sin(o)}var s={normalizedXAxis:e*.5+.5,normalizedYAxis:r*.5+.5};return s}var VisualResponse=function(){function n(t){this.componentProperty=t.componentProperty,this.states=t.states,this.valueNodeName=t.valueNodeName,this.valueNodeProperty=t.valueNodeProperty,this.valueNodeProperty===Constants.VisualResponseProperty.TRANSFORM&&(this.minNodeName=t.minNodeName,this.maxNodeName=t.maxNodeName),this.value=0,this.updateFromComponent(defaultComponentValues)}return n.prototype.updateFromComponent=function(t){var e=t.xAxis,r=t.yAxis,i=t.button,o=t.state,s=normalizeAxes(e,r),u=s.normalizedXAxis,l=s.normalizedYAxis;switch(this.componentProperty){case Constants.ComponentProperty.X_AXIS:this.value=this.states.includes(o)?u:.5;break;case Constants.ComponentProperty.Y_AXIS:this.value=this.states.includes(o)?l:.5;break;case Constants.ComponentProperty.BUTTON:this.value=this.states.includes(o)?i:0;break;case Constants.ComponentProperty.STATE:this.valueNodeProperty===Constants.VisualResponseProperty.VISIBILITY?this.value=this.states.includes(o):this.value=this.states.includes(o)?1:0;break;default:throw new Error("Unexpected visualResponse componentProperty ".concat(this.componentProperty))}},n}(),Component=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 o=new VisualResponse(e.visualResponses[i]);r.visualResponses[i]=o}),this.gamepadIndices=Object.assign({},e.gamepadIndices),this.values={state:Constants.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=__assign({id:this.id},this.values);return t},enumerable:!1,configurable:!0}),n.prototype.updateFromGamepad=function(t){var e=this;if(this.values.state=Constants.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=Constants.ComponentState.PRESSED:(r.touched||this.values.button>Constants.ButtonTouchThreshold)&&(this.values.state=Constants.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===Constants.ComponentState.DEFAULT&&Math.abs(this.values.xAxis)>Constants.AxisTouchThreshold&&(this.values.state=Constants.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===Constants.ComponentState.DEFAULT&&Math.abs(this.values.yAxis)>Constants.AxisTouchThreshold&&(this.values.state=Constants.ComponentState.TOUCHED)),Object.values(this.visualResponses).forEach(function(i){i.updateFromComponent(e.values)})},n}(),MotionController=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(o){var s=i.layoutDescription.components[o];i.components[o]=new Component(o,s)}),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}(),DEFAULT_PROFILES_PATH="https://cdn.jsdelivr.net/npm/@webxr-input-profiles/assets@1.0/dist/profiles",DEFAULT_PROFILE="generic-trigger",XRControllerModel=function(n){__extends(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 THREE__namespace.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 o=i.valueNode,s=i.minNode,u=i.maxNode,l=i.value,d=i.valueNodeProperty;o&&(d===Constants.VisualResponseProperty.VISIBILITY?o.visible=l:d===Constants.VisualResponseProperty.TRANSFORM&&(o.quaternion.copy(s.quaternion).slerp(u.quaternion,l),o.position.lerpVectors(s.position,u.position,l)))})}))},t}(THREE.Object3D);function findNodes(n,t){Object.values(n.components).forEach(function(e){var r=e.type,i=e.touchPointNodeName,o=e.visualResponses;if(r===Constants.ComponentType.TOUCHPAD)if(e.touchPointNode=t.getObjectByName(i),e.touchPointNode){var s=new THREE.SphereGeometry(.001),u=new THREE.MeshBasicMaterial({color:255}),l=new THREE.Mesh(s,u);e.touchPointNode.add(l)}else console.warn("Could not find touch dot, ".concat(e.touchPointNodeName,", in touchpad component ").concat(e.id));Object.values(o).forEach(function(d){var c=d.valueNodeName,f=d.minNodeName,h=d.maxNodeName,v=d.valueNodeProperty;if(v===Constants.VisualResponseProperty.TRANSFORM){if(d.minNode=t.getObjectByName(f),d.maxNode=t.getObjectByName(h),!d.minNode){console.warn("Could not find ".concat(f," in the model"));return}if(!d.maxNode){console.warn("Could not find ".concat(h," in the model"));return}}d.valueNode=t.getObjectByName(c),d.valueNode||console.warn("Could not find ".concat(c," in the model"))})})}function addAssetSceneToControllerModel(n,t){findNodes(n.motionController,t),n.envMap&&t.traverse(function(e){e instanceof THREE__namespace.Mesh&&e.isMesh&&(e.material.envMap=n.envMap,e.material.needsUpdate=!0)}),n.add(t)}var XRControllerModelFactory=function(){function n(t){t===void 0&&(t=null),this.gltfLoader=t,this.path=DEFAULT_PROFILES_PATH,this._assetCache={}}return n.prototype.createControllerModel=function(t){var e=this,r=new XRControllerModel,i=null;return t.addEventListener("connected",function(o){var s=o.data;s.targetRayMode!=="tracked-pointer"||!s.gamepad||fetchProfile(s,e.path,DEFAULT_PROFILE).then(function(u){var l=u.profile,d=u.assetPath;r.motionController=new MotionController(s,l,d);var c=e._assetCache[r.motionController.assetUrl];if(c)i=c.scene.clone(),addAssetSceneToControllerModel(r,i);else{if(!e.gltfLoader)throw new Error("GLTFLoader not set.");e.gltfLoader.load(r.motionController.assetUrl,function(f){e._assetCache[r.motionController.assetUrl]=f,i=f.scene.clone(),addAssetSceneToControllerModel(r,i)})}}).catch(function(u){console.warn(u)})}),t.addEventListener("disconnected",function(){r.motionController=null,r.remove(i),i=null}),r},n}();function mapPanoResource(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 CONTROLLER_EVNET_DELTA_TIME=300,ROTATE_Y_PI_MATRIX=new THREE__namespace.Matrix4().makeRotationAxis(new THREE__namespace.Vector3(0,1,0),Math.PI),PANO_TEXTURE_SCALE=new THREE__namespace.Vector3(-1,1,1),XRPanoramaController=function(n){__extends(t,n);function t(e){var r,i=n.call(this,e)||this;i.xrManager=new XRManager(i.renderer,i.renderer.getContext(),{onSessionStart:function(d){i.emit("xr.session.start",createEvent("xr.session.start",{session:d,machineType:i.xrManager.machineType}))},onSessionEnd:function(){i.emit("xr.session.end",createEvent("xr.session.end",{session:null,machineType:i.xrManager.machineType}))}}),i.xrControllerRay={left:new THREE__namespace.Raycaster,right:new THREE__namespace.Raycaster},i.xrControllerRay.left.params.Points={threshold:.1},i.xrControllerRay.right.params.Points={threshold:.1},i.pointerLines={left:new FiveLine,right:new FiveLine},i.pointerLines.left.visible=!1,i.pointerLines.right.visible=!0,i.pointerLines.left.setMaterial({color:new THREE__namespace.Vector3(1,1,1)}),i.pointerLines.left.points.material.depthTest=!1,i.pointerLines.right.setMaterial({color:new THREE__namespace.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=createUuid()]={panoId:panoStringify(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 o=AnimationFrameLoop.shared.getContext();if(!o)return console.error("获取session失败,请退出重试"),i;i.on("xr.session.end",function(){i.scene.remove(i.pointerLines.left,i.pointerLines.right)}),i.xrManager.setSession(o),i.controllerWrappers=[new THREE__namespace.Group,new THREE__namespace.Group],i.scene.add(i.controllerWrappers[0],i.controllerWrappers[1]);var s=i.xrManager.getController(0);i.controllerWrappers[0].add(s);var u=i.xrManager.getController(1);i.controllerWrappers[1].add(u);var l=new XRControllerModelFactory;return l.gltfLoader={load:function(d,c){internalFetcher.ajax(d,{responseType:"arraybuffer"}).then(function(f){var h;return parseGltf(f.body,{resourcePath:d.slice(0,d.lastIndexOf("/")+1),search:(h=d.split("?")[1])!==null&&h!==void 0?h:"",fetcher:internalFetcher})}).then(function(f){return c(f)})}},i.on("xr.session.start",function(){var d=i.xrManager.getControllerGrip(0);if(d.add(l.createControllerModel(d)),i.controllerWrappers[0].add(d),!i.onlyUseRightController){var c=i.xrManager.getControllerGrip(1);c.add(l.createControllerModel(c)),i.controllerWrappers[1].add(c)}}),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=__assign(__assign({},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 __assign(__assign({},i),{mode:"XRPanorama"})},t.prototype.moveToPano=function(e,r,i){var o=this,s,u,l,d;this.userAction=i,this.stopMomentumMovement();var c=this.works.getResolvedObserver(e);if(!c)throw new Error("Invalid PanoIndex");var f=this.imageOptions.size;if(typeof f>"u"&&c){var h=c.images.up.match(/\/cube_(\d+)\//);h&&(f=Number(h[1]))}typeof f>"u"&&(f=2048);var v=this.imageOptions.transform,A=function(I,S){return mapPanoResource(applyImageURLOptions(I,v,S))},m=__assign({key:"pano.".concat(c.panoId)},pick(this.imageOptions,["format","size","quality"])),y=c.images,p=(u=(s=c.images.tiles)===null||s===void 0?void 0:s.filter(function(I){return I.size>f}))!==null&&u!==void 0?u:null,g="pano:"+jsonHash([y,m,v]);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===g)return;var b=this.pendingTextureTask.panoId;(l=this.panoMeshes[b])===null||l===void 0||l.setProgress(0),this.emit("pano.texture.abort",createEvent("pano.texture.abort",{error:null,progress:0,meta:null,pano:c.pano})),this.pendingTextureTask.onError(new Error("texture aborted"))}var T=this.models.getMaterial()||{},_=T.pano0,w=T.pano1,x;if((_==null?void 0:_.map.name)===g?x=_:(w==null?void 0:w.map.name)===g&&(x=w),x){var M={panoId:c.panoId,effect:(d=r.effect)!==null&&d!==void 0?d:"fade",leftPanoPicture:{map:x.map,luminanceMap:x.luminanceMap,matrix:new THREE__namespace.Matrix4().compose(c.position,c.quaternion,PANO_TEXTURE_SCALE)},position:c.position.clone()};this.doMoveToPano(c.pano,M,r);return}var R="move-to-pano-"+c.panoId;this.pending.add(R),this.pendingTextureTask={panoId:c.panoId,hash:g,onLoad:function(I){var S;if(o.pending.delete(R),o.destroyed)I.body.dispose();else{I.body.name=g;var B={panoId:c.panoId,effect:(S=r.effect)!==null&&S!==void 0?S:"fade",leftPanoPicture:{map:I.body,luminanceMap:null,matrix:new THREE__namespace.Matrix4().compose(c.position,c.quaternion,PANO_TEXTURE_SCALE)},position:c.position.clone()};o.doMoveToPano(c.pano,B,r)}},onError:function(I){o.pending.delete(R);var S=__assign(__assign(__assign({},c.pano),{mode:o.mode}),clonePose(o.camera.pose));o.emit("pano.error",createEvent("pano.error",{error:I,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:S})),o.emit("pano.cancel",createEvent("pano.cancel",{error:null,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:S})),r.moveCancelCallback&&r.moveCancelCallback()}},Promise.all([this.tileLevelForFov&&p&&p.length?this.textureLoader.loadTiledCubeTexture(y,p,{tileMaxLevel:this.TILED_CUBE_TEXTURE_LEVEL,imageURL:{transform:A,options:m},format:THREE__namespace.RGBAFormat,viaAjax:!0,fetcher:getFetcher(c.work)},void 0,void 0,function(I){var S,B;o.emit("pano.texture.progress",createEvent("pano.texture.progress",{error:null,progress:I,meta:null,pano:c.pano})),((S=o.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&((B=o.panoMeshes[c.panoId])===null||B===void 0||B.setProgress(I))},this.renderer):this.textureLoader.loadCubeTexture(y,{imageURL:{transform:A,options:m},format:THREE__namespace.RGBAFormat,fetcher:getFetcher(c.work)},void 0,void 0,function(I){var S,B;((S=o.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&((B=o.panoMeshes[c.panoId])===null||B===void 0||B.setProgress(I)),o.emit("pano.texture.progress",createEvent("pano.texture.progress",{error:null,progress:I,meta:null,pano:c.pano}))},this.renderer)]).then(function(I){var S,B,F=I[0];((S=o.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g?(o.pendingTextureTask.onLoad(F),(B=o.panoMeshes[c.panoId])===null||B===void 0||B.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.success",createEvent("pano.texture.success",{error:null,progress:1,meta:F.meta,pano:c.pano}))):F.body.dispose()}).catch(function(I){var S,B;((S=o.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&(o.pendingTextureTask.onError(I),(B=o.panoMeshes[c.panoId])===null||B===void 0||B.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.error",createEvent("pano.texture.error",{error:I,progress:0,meta:null,pano:c.pano})),o.emit("error",I))}),this.emit("pano.texture.load",createEvent("pano.texture.load",{error:null,progress:0,meta:null,pano:c.pano}))},t.prototype.doMoveToPano=function(e,r,i){var o=this,s,u,l;i===void 0&&(i={});var d=now(),c=createUuid();this.panoResources[c]=r;var f=1,h,v,A;if(this.locationMotion.ended){var m=this.locationMotion.getKeyFrameSegment(d);m[0];var y=m[1],p=this.locationMotion.value,g=this.panoResourceFromLocationMotionKeyframe(y).position,b=r.position;h=Math.max(g.distanceTo(b),f),v=[{key:y.key,progress:0,value:__assign(__assign({},p),{count:0})},{key:c,progress:1,value:{distance:0,count:1}}],A=0}else{var T=this.locationMotion.getKeyFrameSegment(d),_=T[0],y=T[1],p=this.locationMotion.value,w=this.panoResourceFromLocationMotionKeyframe(_).position,g=this.panoResourceFromLocationMotionKeyframe(y).position,b=r.position,x=y.value.count-p.count,M=Math.max(w.distanceTo(g),f)*x,R=Math.max(g.distanceTo(b),f);h=M+R,v=[{key:_.key,progress:0,value:__assign({},p)},{key:y.key,progress:M/h,value:y.value},{key:c,progress:1,value:{count:y.value.count+1,distance:0}}];var I=this.locationMotionKeyframesLength(this.locationMotion.keyframes),S=this.locationMotionKeyframesLength(v);A=this.locationMotion.getProgressVelocity(d)*I/S}var B=this.calculateMovingDuration(i.duration,h),F={longitude:i.longitude,latitude:i.latitude,fov:i.fov},O=__assign(__assign({},e),{mode:this.mode,longitude:(s=F.longitude)!==null&&s!==void 0?s:this.camera.pose.longitude,latitude:(u=F.latitude)!==null&&u!==void 0?u:this.camera.pose.latitude,fov:(l=F.fov)!==null&&l!==void 0?l:this.camera.pose.fov,offset:r.position.clone(),distance:0}),H=this.currentPano;this.emit("pano.moveTo",createEvent("pano.moveTo",{options:i,prevPano:H,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=noop$1,this.videoTexture.needsUpdate=!0),this.panoVideo.setMaterial(null),this.cameraMotion.set(F,B).catch(noop$1);var k=this.locationMotion.setKeyframes(v,B,A);k.then(function(){var N,q,V,D=__assign(__assign({},e),{mode:o.mode,longitude:o.camera.pose.longitude,latitude:o.camera.pose.latitude,fov:o.camera.pose.fov,offset:o.camera.pose.offset.clone(),distance:0});o.emit("pano.arrived",createEvent("pano.arrived",{options:i,prevPano:H,progress:1,state:D,userAction:o.userAction,error:null})),i.moveEndCallback&&i.moveEndCallback(D);var K=o.works.getResolvedObserver(o.currentPano);if(K&&K.video&&o.videoTexture&&o.videoTexture.image instanceof HTMLVideoElement){var z=ROTATE_Y_PI_MATRIX.clone().multiply((V=(q=(N=o.models.getMaterial())===null||N===void 0?void 0:N.pano1)===null||q===void 0?void 0:q.matrix)!==null&&V!==void 0?V:new THREE__namespace.Matrix4).multiply(K.video.matrix),G={map:o.videoTexture,size:K.video.size,matrix:z,alpha:1},W=createUuid(),Q=o.videoTexture.image;Q.setAttribute("uuid",W),canplayVideo().then(function(X){X&&K.video&&Q.getAttribute("uuid")===W&&(Q.oncanplay=function(){Q.oncanplay=noop$1,Q.play()},Q.ontimeupdate=function(){Q.currentTime>.5&&(Q.ontimeupdate=noop$1,o.panoVideo.setMaterial(G))},Q.src=K.video.source)}).catch(function(){Q.removeAttribute("uuid")})}},function(){o.emit("pano.cancel",createEvent("pano.cancel",{options:i,prevPano:H,progress:0,state:O,userAction:o.userAction,error:null})),i.moveCancelCallback&&i.moveCancelCallback()})},t.prototype.checkSelectedPano=function(e){var r=this,i,o,s,u;this.stopMomentumMovement();var l=this.camera.getDirection(new THREE__namespace.Vector3).setY(0),d=null,c=this.works.getResolvedObserver(this.currentPano);if(!c)return null;var f=c.accessibleIds.filter(function(W){var Q=panoParse(W);if(panoEqual(Q,r.currentPano))return!1;var X=r.works.getResolvedObserver(Q);return!X||X.position.distanceTo(r.camera.position)>r.maxAccessibleDistance?!1:X.loadable||X.active}),h=this.models.intersectRaycaster(e)[0];if(h){var v=arrayMin(f,function(W){var Q=r.works.getResolvedObserver(W);if(!Q)return 1/0;var X=Q.standingPosition.clone();return X.distanceTo(h.point)},!0),A=v[0],m=v[1];A&&m<this.panoTapTriggerRadius&&(d=(i=this.works.getResolvedObserver(A))!==null&&i!==void 0?i:null)}if(isNil(d)){var y=this.getForwardObserverOrNot(e);y&&(d=y)}for(var p=0,g=this.locationMotion.keyframes;p<g.length;p++){var b=g[p],T=this.panoResourceFromLocationMotionKeyframe(b);if(!(b.progress<this.locationMotion.progress)&&d&&T.panoId===d.panoId){d=null;break}}if(isNil(d))return this.locationMotion.ended===!0&&this.cameraBounce(),null;if(d&&!d.active){var _=d.panoId;this.panoMeshes[_]&&(this.panoMeshes[_].setDisabled(!1),this.panoMeshes[_].setLoading(!0))}var w={};if(d){w.effect="fade";for(var x=Math.PI/6,M=Math.PI/12,R=new THREE__namespace.Vector3(0,1,0),I=d.position.clone().setY(0).sub(c.position.clone().setY(0)).normalize(),S=I.clone().applyAxisAngle(R,x),B=I.clone().applyAxisAngle(R,-x),F=[],O=[],H=[],k=0,N=d.accessibleIds;k<N.length;k++){var A=N[k],q=panoParse(A);if(!(panoEqual(q,this.currentPano)||panoEqual(q,d.pano))){var V=this.works.getResolvedObserver(A);if(V){var D=V.position.clone().sub(d.position).setY(0);I.angleTo(D)<x?H.push(D):S.angleTo(D)<x?F.push(D):B.angleTo(D)<x&&O.push(D)}}}var K=H.length>0?H:__spreadArray(__spreadArray([],F,!0),O,!0),z=K.slice().sort(function(W,Q){return W.angleTo(I)-Q.angleTo(I)})[0];z&&z.angleTo(l)>M&&(w.longitude=Math.atan2(-z.x,-z.z))}this.cameraMotion.value.latitude<-Math.PI/4&&(w.latitude=clamp(0,this.minLatitude,this.maxLatitude)),this.cameraMotion.value.fov<60&&(w.fov=this.defaultFov);var G={workCode:d.pano.workCode,panoIndex:d.pano.panoIndex,mode:this.mode,longitude:(o=w.longitude)!==null&&o!==void 0?o:this.camera.pose.longitude,latitude:(s=w.latitude)!==null&&s!==void 0?s:this.camera.pose.latitude,fov:(u=w.fov)!==null&&u!==void 0?u:this.camera.pose.fov,distance:0,offset:d?d.position.clone():new THREE__namespace.Vector3};return this.emit("pano.select",createEvent("pano.select",{prevPano:this.currentPano,state:G,userAction:!0,options:w,progress:0,error:null})),d&&d.active?(this.emit("pano.request",createEvent("pano.request",{userAction:!0,prevPano:this.currentPano,progress:0,state:G,options:w,error:null})),d.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,o,s,u,l,d,c,f,h,v=[],A=2;A<arguments.length;A++)v[A-2]=arguments[A];this.userAction=!0;var m={},y={},p=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),m.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);var T=this.locationMotion.getKeyFrameSegment(e),_=T[0],w=T[1],x=this.panoResourceFromLocationMotionKeyframe(_),M=this.panoResourceFromLocationMotionKeyframe(w),R=new THREE__namespace.Vector3().copy(x.position),I=new THREE__namespace.Vector3().copy(M.position),S=this.locationMotion.value.count-w.value.count+1;m.progress=S,M.leftPanoPicture&&(S<1?x.leftPanoPicture&&(m.pano0=x.leftPanoPicture):m.pano0=M.leftPanoPicture,m.pano1=M.leftPanoPicture),b=m.useBlackTransition=M.effect==="instant"||M.effect==="montage",(M.effect==="fade"||M.effect==="montage")&&(m.pano0&&x.leftPanoPicture&&(m.pano0={map:m.pano0.map,luminanceMap:m.pano0.luminanceMap,matrix:x.leftPanoPicture.matrix.clone().setPosition(M.position)}),R.copy(I)),y.distance=this.locationMotion.value.distance,y.offset=new THREE__namespace.Vector3(R.x+(I.x-R.x)*S,R.y+(I.y-R.y)*S,R.z+(I.z-R.z)*S);for(var B=[],F=[],O=0,H=this.locationMotion.keyframes;O<H.length;O++){var k=H[O],N=k.key,q=k.progress;N!==void 0&&(B.push(N),q>=this.locationMotion.progress&&F.push(N))}for(var V=0,D=Object.keys(this.panoResources);V<D.length;V++){var K=D[V];if(!(F.indexOf(K)>=0)){var z=this.panoResources[K];if(z.leftPanoPicture){var G=z.leftPanoPicture.map;if(G){if(G===((o=m.pano0)===null||o===void 0?void 0:o.map)||G===((s=m.pano1)===null||s===void 0?void 0:s.map))continue;G instanceof TileCubeTextureTarget&&G.cubeRenderTarget&&this.colorCubeRenderTargetPool.push(G.cubeRenderTarget),G.dispose(),z.leftPanoPicture=null}}B.indexOf(K)>=0||delete this.panoResources[K]}}this.currentPano=panoParse(M.panoId),this.emit("pano.moving",createEvent("pano.moving",{userAction:this.userAction,prevPano:panoParse(p.panoId),state:__assign(__assign(__assign(__assign({},panoParse(g.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),y),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(m)===!1&&(!((u=m.pano0)===null||u===void 0)&&u.map&&m.pano0.map instanceof TileCubeTextureTarget&&!m.pano0.map.cubeRenderTarget&&(m.pano0.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((l=m.pano1)===null||l===void 0)&&l.map&&m.pano1.map instanceof TileCubeTextureTarget&&!m.pano1.map.cubeRenderTarget&&(m.pano1.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),this.models.setMaterial(m)),isEmptyObject(y)===!1&&this.setCamera(y);var W=this.works.getResolvedObserver(this.currentPano),Q=v[1];if(!Q){console.error("xrFrame丢失,请重试");return}if(!this.xrManager.session){console.error("session丢失,请重试");return}var X=this.xrManager.referenceSpace;if(X){var ee=this.xrManager.cameraVR,J=this.xrManager.cameraL,Z=this.xrManager.cameraR,te=[J,Z],ae=Q.getViewerPose(X),re=new THREE__namespace.Vector3(0,0,0);if(ae){var ie;ie=this.xrManager.session.renderState.baseLayer;var de=ae.views;if(!ie){console.error("no layer found");return}this.renderer.setFramebuffer(ie.framebuffer);var se=!1;de.length!==ee.cameras.length&&(ee.cameras.length=0,se=!0),this.parallaxCameraMatrixs=[];var pe=new THREE__namespace.Vector3,$=new THREE__namespace.Vector3;new THREE__namespace.Matrix4().fromArray(de[0].transform.matrix).decompose(pe,new THREE__namespace.Quaternion,new THREE__namespace.Vector3),new THREE__namespace.Matrix4().fromArray(de[1].transform.matrix).decompose($,new THREE__namespace.Quaternion,new THREE__namespace.Vector3),$.clone().sub(pe).normalize();var oe=new THREE__namespace.Vector3,j=new THREE__namespace.Quaternion,ve=new THREE__namespace.Vector3;this.camera.matrix.decompose(oe,j,ve);for(var me=0;me<de.length;me++){var Me=de[me],Re=ie.getViewport(Me),ge=te[me];ge.matrix.fromArray(Me.transform.matrix);var we=new THREE__namespace.Vector3,Ae=new THREE__namespace.Quaternion,le=new THREE__namespace.Vector3;ge.matrix.decompose(we,Ae,le),re.copy(oe),ge.position.copy(oe),ge.quaternion.copy(Ae),ge.scale.copy(le),ge.updateMatrix(),ge.projectionMatrix.fromArray(Me.projectionMatrix),ge.viewport.set(Re.x,Re.y,Re.width,Re.height),se===!0&&ee.cameras.push(ge)}ae.views[0].transform.position,ae.views[1].transform.position;for(var ue=this.xrManager.session.inputSources,me=0;me<this.xrManager.controllers.length;me++){var Oe=this.xrManager.controllers[me],fe=ue[me];if(fe){Oe.update(fe,Q,X);var Se=this.xrManager.getController(me),ye=new THREE__namespace.Vector3(0,1.2,0),ke=Se.position.clone().add(re).sub(ye);fe.handedness==="left"?this.xrControllerRay.left.set(ke,new THREE__namespace.Vector3(0,0,-1).applyEuler(Se.rotation)):fe.handedness==="right"&&this.xrControllerRay.right.set(ke,new THREE__namespace.Vector3(0,0,-1).applyEuler(Se.rotation)),this.controllerWrappers[me].position.copy(new THREE__namespace.Vector3(0,0,0).add(re).sub(ye));var _e=this.models.intersectRaycaster(this.xrControllerRay.right);if(_e.length===0&&(_e=this.xrControllerRay.right.intersectObject(this.boundingMesh,!0).map(function(Le){var Ue;return __assign({floor:(Ue=W==null?void 0:W.floorIndex)!==null&&Ue!==void 0?Ue:0},Le)})),_e.length>=1&&_e[0].face)if(fe.handedness==="right"){var We=this.xrControllerRay.right.intersectObject(this.xrCustomObjectsScene,!0),Xe=_e[0].face.normal,Ee=Xe.clone().multiplyScalar(.05),Pe=_e[0].point.clone().add(Ee);this.intersectMesh.position.copy(Pe);var Je=Pe.clone().add(Ee);if(this.intersectMesh.lookAt(Je),Math.abs(Xe.y)>.99){var be=this.camera.position.clone().sub(Pe);this.intersectMesh.rotation.z=-Math.atan2(be.z,be.x)}this.intersectMesh.visible=!0,this.needsRender=!0,We.length>0?(this.pointerLines.right.setPoints(ke,We[0].point),this.pointerLines.right.points.visible=!0,this.intersectMesh.visible=!1):(this.pointerLines.right.points.visible=!1,this.pointerLines.right.setPoints(ke,_e[0].point));var Fe=_e[0],De=createEvent("intersect.update",{raycaster:(d=this.xrControllerRay.right)!==null&&d!==void 0?d:null,intersection:Fe??null,object:this.intersectMesh});if(this.emit("intersect.update",De),De.defaultPrevented){this.hideIntersectMesh();return}}else this.pointerLines.left.setPoints(ke,_e[0].point)}}if(this.camera.pose.distance>.1||b){if(W)for(var qe=0,Ze=Object.keys(this.panoMeshes);qe<Ze.length;qe++){var Ne=Ze[qe],he=this.panoMeshes[Ne];he.setOpacity(0),he.setCurrent(!1),he.updateTime&&he.updateTime(e,r)}}else if(W){var st=arrayMin(W.visibleIds,function(Be){var Le=i.works.getResolvedObserver(Be);return Le?W.standingPosition.distanceTo(Le.standingPosition):1/0},!0),ze=st[1];ze=clamp(ze,2.5,1/0);for(var tt=W.visibleIds.concat(panoStringify(this.currentPano)),Ge=this.getForwardObserverOrNot(),mt=this.camera.getDirection(new THREE__namespace.Vector3),lt=0,ct=Object.keys(this.panoMeshes);lt<ct.length;lt++){var Ne=ct[lt],he=this.panoMeshes[Ne],rt=this.works.getResolvedObserver(Ne);if(tt.indexOf(Ne)===-1)he.setCurrent(!1),he.setOpacity(0);else if(!rt)he.setCurrent(!1),he.setOpacity(0);else if(!rt.loadable&&!rt.active)he.setCurrent(!1),he.setOpacity(0);else{var nt=he.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);he.setCurrent(!he.loading&&he.progress===0&&Ge!==null&&Ge.panoId===Ne),he.setOpacity(nt<.01?0:clamp(ze/nt*1.2,.65,.98));var Ie=this.camera.position.clone().setY(he.position.y),xe=new THREE__namespace.Vector3().copy(he.position).sub(Ie).normalize();if(Ne===panoStringify(this.currentPano)){var je=clamp((.5-Ie.distanceTo(he.position))/.5,0,1);xe.multiplyScalar(1-je).add(mt.clone().multiplyScalar(je))}xe.length()>0&&he.quaternion.setFromEuler(new THREE__namespace.Euler(0,Math.atan2(xe.x,xe.z),0))}he.updateTime&&he.updateTime(e,r)}}var at=function(){if(i.tileLevelForFov===!1)return 0;var Be=new THREE__namespace.Vector2(4e3,4e3),Le=g.panoId,Ue=i.works.getResolvedObserver(Le),Ve=i.imageOptions.size;if(typeof Ve>"u"&&Ue){var Et=Ue.images.up.match(/\/cube_(\d+)\//);Et&&(Ve=Number(Et[1]))}typeof Ve>"u"&&(Ve=2048);var ft=0;Ve>=1024&&(ft=1),Ve>=2048&&(ft=2),Ve>=4096&&(ft=3),Ve>=8192&&(ft=4);var ht=i.tileLevelForFov(J.fov,Be);return ht>ft?ht:0}(),At=function(){var Be=new THREE__namespace.PerspectiveCamera;Be.applyMatrix4(ee.matrix),Be.position.set(0,0,0);var Le=i.works.getResolvedObserver(g.panoId),Ue=Le??W;Ue&&Be.quaternion.premultiply(Ue.quaternion.clone().inverse()),Be.updateProjectionMatrix(),Be.updateMatrixWorld(!0);var Ve=new THREE__namespace.Frustum().setFromProjectionMatrix(new THREE__namespace.Matrix4().multiplyMatrices(Be.projectionMatrix,Be.matrixWorldInverse));return Ve}();g.panoId===panoStringify(this.currentPano)&&((c=g.leftPanoPicture)===null||c===void 0?void 0:c.map)instanceof TileCubeTextureTarget&&(g.leftPanoPicture.map.update(At,at),g.leftPanoPicture.map.needsRender===!0&&(this.needsRender=!0));{var yt=this.tiling.object.visible;if(at>this.TILED_CUBE_TEXTURE_LEVEL&&this.initAnimationed){var dt=g.panoId,He=this.works.getResolvedObserver(dt);He?isSimilarVector3(this.camera.position,He.position)&&this.locationMotion.ended?(this.tiling.object.visible=!0,this.tiling.panoId!==dt&&this.tiling.cleanup(),this.tiling.panoId=dt,this.tiling.setResource((h=(f=He.images)===null||f===void 0?void 0:f.tiles)!==null&&h!==void 0?h:[],this.enableIOSEDR&&He.images.luminance?He.images.luminance:null),this.tiling.setFetcher(getFetcher(He.work)),this.tiling.setRotation(He.quaternion),this.tiling.setPosition(He.position),this.tiling.update(At,at,e)):this.tiling.object.visible=!1:this.tiling.object.visible=!1}else this.tiling.object.visible=!1;yt!==this.tiling.object.visible&&(this.tiling.object.needsRender=!0)}this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e),!(!ue||ue.length<1)&&this.updateControllerHelper(ue,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 o=this.xrControllerRay.left,s=this.xrControllerRay.right;if(!(!e||e.length===0)){for(var u={buttons:{X:!1,Y:!1,LeftTrigger:!1,LeftPinch:!1,A:!1,B:!1,RightTrigger:!1,RightPinch:!1}},l=0;l<e.length;l++){var d=e[l].handedness,c=e[l].gamepad;switch(d){case"left":c.axes&&(this.emitEvent(c.axes[2]===-1,"LeftAxesLeft",r),this.emitEvent(c.axes[2]===1,"LeftAxesRight",r),this.emitEvent(c.axes[3]===-1,"LeftAxesUp",r),this.emitEvent(c.axes[3]===1,"LeftAxesDown",r)),c!=null&&c.buttons&&(this.emitEvent(c==null?void 0:c.buttons[4].pressed,"X",r),this.emitEvent(c.buttons[5].pressed,"Y",r),this.emitEvent(c==null?void 0:c.buttons[0].pressed,"LeftTrigger",r),this.emitEvent(c==null?void 0:c.buttons[1].pressed,"LeftPinch",r));var f={raycaster:o,axes:{up:c.axes&&c.axes[3]<0?Math.abs(c.axes[3]):0,down:c.axes&&c.axes[3]<0?0:Math.abs(c.axes[3]),left:c.axes&&c.axes[2]<0?Math.abs(c.axes[2]):0,right:c.axes&&c.axes[2]<0?0:Math.abs(c.axes[2])},deltaTime:i};u.buttons.X=c.buttons&&c.buttons[4]?c.buttons[4].pressed:!1,u.buttons.Y=c.buttons&&c.buttons[5]?c==null?void 0:c.buttons[5].pressed:!1,u.buttons.LeftTrigger=c.buttons&&c.buttons[0]?c==null?void 0:c.buttons[0].pressed:!1,u.buttons.LeftPinch=c.buttons&&c.buttons[1]?c==null?void 0:c.buttons[1].pressed:!1,u.left=f;break;case"right":c.axes&&(this.emitEvent(c.axes[2]===-1,"RightAxesLeft",r),this.emitEvent(c.axes[2]===1,"RightAxesRight",r),this.emitEvent(c.axes[3]===-1,"RightAxesUp",r),this.emitEvent(c.axes[3]===1,"RightAxesDown",r)),c.buttons&&(this.emitEvent(c==null?void 0:c.buttons[4].pressed,"A",r),this.emitEvent(c.buttons[5].pressed,"B",r),this.emitEvent(c==null?void 0:c.buttons[0].pressed,"RightTrigger",r),this.emitEvent(c==null?void 0:c.buttons[1].pressed,"RightPinch",r));var h={raycaster:s,axes:{up:c.axes&&c.axes[3]<0?Math.abs(c.axes[3]):0,down:c.axes&&c.axes[3]<0?0:Math.abs(c.axes[3]),left:c.axes&&c.axes[2]<0?Math.abs(c.axes[2]):0,right:c.axes&&c.axes[2]<0?0:Math.abs(c.axes[2])},deltaTime:i};u.right=h,u.buttons.A=c.buttons&&c.buttons[4]?c==null?void 0:c.buttons[4].pressed:!1,u.buttons.B=c.buttons&&c.buttons[5]?c==null?void 0:c.buttons[5].pressed:!1,u.buttons.RightTrigger=c.buttons&&c.buttons[0]?c==null?void 0:c.buttons[0].pressed:!1,u.buttons.RightPinch=c.buttons&&c.buttons[1]?c==null?void 0:c.buttons[1].pressed:!1;break}}this.emit("xr.controller.update",createEvent("xr.controller.update",u))}},t.prototype.emitEvent=function(e,r,i){var o=this.xrControllerRay.left,s=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",createEvent("xr.gesture.buttonDown",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!1,isFirst:!0,controllers:{raycaster:{leftRay:o,rightRay:s}}}));else{var u=i-this.xrControllerState[r].touchStartTime;u>CONTROLLER_EVNET_DELTA_TIME&&this.emit("xr.gesture.press",createEvent("xr.gesture.tap",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!0,controllers:{raycaster:{leftRay:o,rightRay:s}}}))}else if(this.xrControllerState[r].touchStart===!0){this.emit("xr.gesture.buttonUp",createEvent("xr.gesture.buttonUp",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:o,rightRay:s}}}));var u=i-this.xrControllerState[r].touchStartTime;if(u<=CONTROLLER_EVNET_DELTA_TIME){var l=this.emit("xr.gesture.tap",createEvent("xr.gesture.tap",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:o,rightRay:s}}}));l||r==="RightTrigger"&&this.checkSelectedPano(this.xrControllerRay.right)}this.xrControllerState[r].touchStart=!1,this.xrControllerState[r].touchStartTime=0}},t}(PanoramaController),Controllers={Floorplan:FloorplanController,Topview:TopviewController,Panorama:PanoramaController,VRPanorama:VRPanoramaController,Model:ModelController,DepthPanorama:DepthPanoramaController,Mapview:MapviewController,XRPanorama:XRPanoramaController},PROXY_CONTROLLER_EVENT_NAMES=["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 initLegacyEvent(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=coordinatesToVector(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 generateDefaultVideoElement(){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 initLights(n){{var t=new THREE__namespace.DirectionalLight(16777215,.5);t.position.copy(new THREE__namespace.Vector3(1,1,1)),n.add(t)}{var t=new THREE__namespace.DirectionalLight(16777215,.3);n.add(t)}{var t=new THREE__namespace.AmbientLight(16777215,.3);n.add(t)}}function parseKeyValue(n){for(var t,e,r={},i=n.split(/(\;|\,)/),o=0,s=i;o<s.length;o++){var u=s[o],l=u.split("="),d=(t=l[0])===null||t===void 0?void 0:t.trim(),c=(e=l[1])===null||e===void 0?void 0:e.trim();d&&c&&(r[d]=c)}return r}function getViewportScale(){for(var n,t=document.getElementsByTagName("meta"),e=0;e<t.length;e++){var r=t[e];if(r.getAttribute("name")==="viewport"){var i=parseKeyValue((n=r.getAttribute("content"))!==null&&n!==void 0?n:""),o=Number(i["initial-scale"]);if(!isNaN(o))return o}}return 1}const textureURL="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAV8AAAA/CAQAAADtPwPkAAAR+0lEQVR4AezYg3LEQACH8d1cbdu23Q5qG9G47z/TN/h6tn2b/H+TUTLc7yjcOXV46OUAnUs6EbUp022ZBXc1NhoZYYd7fjDRvdcHAwrlK2QBVJ4sgoqONmY45RUT23sZ6H42F2hK5CtkMbjhZlDmUUcvq1zyieUVyjbE4I1GBfItwxG56YaUZTQwyh4P6NgJ4YYYvCuQb5kOyI03pORjiqe4Lwpq5pt1vJqfUwKWJVbSMYfppYconG+maNNQOWBZuwHTzicGel75NtFOkxr5apmV8cikcko0DrDQs863AeGl0cE0+1xy573m0/wf0cEKW6H7BWtggiMG8sy3oHRDpJMw4NWb6am/bv9znkqEzjd61t5oo5clTrjhwevO75EJRBKSRt745Z16ZEjcM73sccZplBPm8PyTcxZAkSRdHm/acJ0Z3JZhHB0BxqDHgWFZFmm0ZbCw87twI/zc3e/Cz93vPneXtU/WdQS3oTviXdY/q5PsJKfoGuQjZuO/0in1qsj85cuXrxqeAOJpGqdJOqrUutgVl2Qb0BWqp/RE8AWWVB7t2KrIzY2Wx2fWKl7yfswgxqj8lYummYa3hfwF9MuQRmbfQE4ocPDjtUWQ6Tq1M2w7gC2EcrMGtWS6xlpGKEDDcb1vUQ25zT4lrC2s0dU4gFPppKkbeIYr7NMpqjStuFg5rNU9epGyt8PXyfX4DE1bKLhR/1XPxwJhp5DAV67T9ZPwFdovhBMIGUYoRBN4wim6S3eoXVEHXdLgmwY0x6BQnO4xPJ0Ar5OVxhQF0L9UslRM4yaQQfQImnBegi8vhY2A1k6YLlrj61TwDdNQnIISwiPvpD7TwYQTssZXK47vg8y9Gp2nxRcATkozOEmdCeObSt3IIo+xf/00IDRKAaZ89PBTkHqpkA5LagKeNZKlIhqX8RcQ95GHtdYA62Y6rOg5LLsOSnoyvk4V38hFhytef+V9/3DER1P48W89o1GxE9o5vns2Mk+F7yiftafEN4nhmUv9DKEeyqI0U+l0CQg+B//sZ5+6lOuqKaTgm0LH41RHw/CsLZRk4huiYxrvP2SNr1OSS+Dr1ulBMR+K9SqHa58Oec49VgL3mXHvDr7QfuM7LMNrH1/IS30Moe64SLYBuFVJ+MbnJY7L+GrVQkFcl4ISx/fEll4ZWnz18DpcSzUCX602LqD9svDLzmdaLkP28P1+VsJjsx/4hmh6x/gmm/i6pbrGneCL9iCOg0dQUvF1UwEdVvG19r2uTXxXLz0J37eLjfZoF++tTtPnU/cWp5e8n3An0m/G+U7qjiy4PpHyV16HKx5flCxAV/H9A88nUnZ7l7KN78SBxPcQgzLAepxEScU3l7pZ6fL2+Dot8fXECfj+QRoGYAwlAfBSPrXQXQri0Pd85NJKcVw8XUdt1LZapk7YRhO1RdpmFJwW8ozekYvx2/fjM5Hr5MfQ95HvcY2a/9hoNK4yEntL+dEuGseTdNmxIPqd5v2YRjeaX8pQ8IW2ohuP7+dTN87RMK4aitx8XPsH0r2oBqNRqrv7+gmjjY7uIr6TBxBfL2MlxNRKSVp8S5CTuGgHXxfkFvh69Pq3LD4pkkd2bdRvHaSNC3/l2sQXAccdlIS+lc57qhPJwxPybT7XSxnUrdqnXuHlJHS+mjZfJfUZR9s2FuQR+EQKdSi9Am8UTnsEvlYS+L6TFwW6kl74Vjr6AFHsX89rgg8njRltK0XPOL7NyDL0IurV4VtMwafB1709vu9X4OjWHoP3z1Ii7eaQdG00Lx5n8HXyDSva/dU0Pq2vZnKYxHYMYRo1WY5ov1G7Vh4r3y+kMdgbilxeOrV0aqOFenFl8GGJig7rG0bbPRqiSRpP2AL0w+yon9dHbi43zFetnKcuw9ZLeSa+7kTw/TDfuFu0Z7Vp/uhyHfPkAZ5ufP9wLIfD49E3clR818rR089Lzyy+VRREPneICnYLX9cT8PVKQs36TbQ3i6NcCwYkxEAQ3phN4CjAvC4mFr5vrlKe7AizBKj8cu33s7i9GbeY7BHYujTjjd3Bx54SSyT4m8mxOoYOAGX/DtwvnGE1M+5v5Bgt1hbkJRW9Cxv9X81GL2i5jqaoJ4avBcCsLYp+Ru+VC5sWPpFhXt8/EPvJL2F/alJDEeIjUhcrP5P45rDeATPj+wKl7gBf1fcq+HpVnfHO1vEf//UCHgt/OxfDE3onj5UkfTaThrg3NCGoBUCtZjvgMnwQB0bG5XENeraJ5XEWvtiHkqSVRqN+uQ4lEx2o+69SeY1dC++Wcsj+LCW+H0ZE4KtDWHkGwCtrxstbFqr51e9wbz42E2fpjRQsqEn50PnM4eumO9IbujCi393Hd+3q72TI+p9DPyyfraF+c3rOx0KJyB2z7Fa1yCO8HoHzlDFhPiWD8XoB3aPppRrUQdRp1D8qE9exdgr+Zbpqf8BLfmZ/bMYbh87k58VCSswCjQoLPPw4Jnp4uFi/YQlfKB5eBd/gr6aqB973zbDAF+v5PN+NZEvm+84bSkhxUPE9C9wqbeJ7Hi+gA9Jr5ZM7x9el4mulyK0Bb2xiMTj3/iBtK77Tnii27H/MlCfsjcJY+2oTg2/U4TYWQERE0r+aCouBcx5zEZzEYrqui8JXsQW/X8FLHJ3IVbWXhQV3zAJCjFQst1F25y1arlXwhRR4Bb4rZ3VPy5d+bHEtHIPF27K16ItYuKXM5kHD10M9DKFeSpbqLlOYAlRiC99yCiDmbUf0206jPPO7b/iud71avBkHf+kQP0OrWHBFrhmt75ZyPzbLg5KmWK9oH4Oq1eFZOm0c6n48mdfer46HcLUZU3pGB8R9IDBbJ+N7v1q0J2xhudZ45tcL8PN16vq9WizwtRLwFQtKER+NDypj4QQOdJNY3NC7GEsaGtiSmDsA+CZhyx+hXFHjYrgGGXpZNvDNpn5gWWuiWkUtyEB0UcrO8Y2L9KI9K+cXLmxqruGd6pcKfycj/ij3URVgu6bPUaycN1qXTHD+KoOmjGORnH57q8rh+e9sTHk5r1+7zpEXk36bp7iiXRrBW61e5k/D0fn+EXF/OxYEypFW3ZH1HzPt4Pv5PN2Rd7VJLDZeboGnbpSPwPDcBw5f6AIysadFOR9Hr7vksoFvE91jdbdYvzpYqyIvdQPU87uKL45u3u213CA8qkYPT6H1YgwIfkz7RI5xJdomfjoV4PXjfjgaRkNGhHwG1mNt1oq0y/j+SaZ5pV0LnrlG89Dl1YkmEsc3nKKzMKskJD+fx6NhlFiohdTe5EsZIig5WPgWUYCC9Dx5TG/sA5x15LCBbzXDtx/+uh74VmMZjLDamh8JvhzQtSsoeVTNNXB/Euv96LRR/qjO+By5xTxxJ683/FB00Pj0fZz9F2GPa70Ld2hbbVptWmjWabbGCl/ZAiTsbJa5hQ9OK/eWFE4xva9nG3z1zwCtnFXjYr6c3ykxPn9QiYWEWPhA4uuiDnzBpt4EMcg0QOm28M0gP76hJuELbIdZi4PqaILpJI+RYz4ZV42y+q49wBcxIbyXTmtXgevRWPl3MmjSSJU5vB3J0TA2Uu8mtP+R5/Au4iiF6NrUUiuCieOiJpnJq8gSXzwFLFiLP8X6bV0bYvzt8TXj75eLtKPRauY1RM1HR7GwEHpFbonIWAPwjxpfqJSCyBVUsk/DFOChhC18kyiPHFvwdVGh6XFbmfLx+RRi4jaqYiCnUDO1wc4u4ovo7pfS+XFD32e9GzndwxJiHcbQ/Vz6JrBMDGYyYK5l7YOsfkS2MVePfGkLsNXLGl9hIVbWXAv9fQ5i/j6UFL1RaQffB9qlwn3tS4WxMhaxETCMz6T9ZTqCk5FznoOKL9SEXMMIUwAZW6dNfCEVX61azdxwmIbg4aHdwtcj5KVBeNiqrb2+g5M8hTskSB6exHZ5bMEIF/wCoOT128zvdXziMLbvuDu/Usmh0oG7doMmafKNSmt8hQWUnmzhjJf/RskXCzQL8aYNfLG/QPGLY5KjKtcuNPGsyGytmj0/kPi6qdXwwJCPvOTYI3zTaICCNEh9FGSWM54OX4+A1UI80RV98czWKceJf65ervsleJm164/7ganACHHn+IPz8Nby1ptcnRztRWbipArvp4/gRchodbIFvsBSWPBaW+CHtzWfauFfcmnKRuyr+Fiu1WbzGKtCPWWMHjIgU1/Mgn2B74GKfbkajHwtVIHy3uBbh0Ocj9oplCC+kIJvYuKvI9bbkUUQ2+JaG7AeknwvhLd0YUxx+SZIf4XkGeqHUCNt9N8sQdvYlwtl9H4hMzqI5dHosMIX2taCl2s6LRowaubPyld/IgcvHBJPnKGnHDLh0ArfqzlYtkv5D8++4RsAvPbwTaJzgDcIDzxIRXuEbx4NIsYupjt7gi/6idL3j1AIqPY+OPH5PGO67x/jUS9NvF6hTte7x2kaCvtSZJiMlxjxMSqEtqXr3GPMn/9y4cXUypS/ymPxbIAvmurtYl9o7dqmBV9KdbLOgsik4B3d6xW/lO7w/kfe+yfx7bFuGkwY3/C6sURDj8584rCxJH5QtnYFVrFQVL35HNoQgO0jvt228XVRC4WQPLtANyiEzb1gD/BNoy5kHa5QEnUmiq/uG2fubeXh+kwuNj8IRxAoOqiLIqfTaNw84SfLWsDmqo08k30prHVKbHuYDo7ez6U7EsLX0oJX1ltV2AOg2KfoMPPA/sTx/ZPMqF9YiN11AsHLFrHgaAT3GBvw7hO+U9TH4bX10rgVx7YgMr0p7Pow4tL8XcY3l1kJMfVQmsA3fa/wFQh3JK9eivtV+tCaD4cUjdZvIRI9BfDUDd6PkkbfKhVbOJf/jUpuQcXXlgVNv68ejr4gTflk5AZ71+jR4AvEdPg6PDNpaz6a2AQm2otoWKvVS+LVTyL4OnaE7wSNUjfdpnZb+KbQdcA7Jr5ek0od8MD9dNjiN43t4etk1v0ITfyw6gS+Q4l5XwGwbXli+u/sj6pWGu9XfyYXx75d18+lf6t0tnau/pXKv8+xzorIkltn0l4r2dYCXlO8XDRbu9xw/9g/Zko2FXSFtKPxOxn3q+caluteK5lJsboXwVP/S27cPVz28X3i3/Ll/v8eDVMPDmzwvDbwddMt+NoROhq3yXcC4D7KpmTyA+XnqEzSFQrawDeLrsNemHrEL2+24r7NlENZUMa2vyxkH2DIs628e669ubdsR4VXC7C9u79eIVJtOwgdgO/dOICHGK6jQHaIwdXN4Lwt0LWHr4d6kX8tV+ozqAs+uYCSmO2w+jd4zGNeUYL4nqZxeN5WKVgooSAClmEaYhqhdit89QC7niSbCEM2sdkBuHYxQg9ri5ZjkuhI6DMP+J7cTvEtokEx0aPscyddoFJKpSZqV7G1GTxcpmEthpnw5058c6GfwqpwzGOtGjXSJI3FLYhc+O+jSr9aGhPWQlRshS8AticLX7wnsgbXxt6gsWCpRBa0vRGQM8oB9dhmP3QAwFX4c079dJNq6Qi5xbuyTmpPSJ1Ur4UtF7GoTtmUL3zxaWqMU8P/k3cXSQ1EQRjHGdzdHTa4u7tzBs7CedhykNwF2/5jq56iU11db6Lv2yTj8hs3JoiU9sZZp5/62J5v1z9NjrDHaSbnbFMf52sHrDUVaidDxNG0o9+uLjfosfdb3jT5d5j757riJgst9NIZQ2Pn+ySZll80vjI6Wz/hQJG4vPG0L/H6poQch/dW3vL3B0u8jl0HvVj5PvHCElEF8DUAFikVYTcvmfBdDzQlvvMXSV5lP5zrXj/fJ54zuWaeeuoqkW8AwCIaqeTZKkmYrpPwR2eqN9X72W7EG57vU67OBeuMV8KXLUzv93UTTj42tvaFS++GVsc5JRyLSLJ8nzO555hFBmiSRCqMr4GwrcmGkib5xSvcwmzFK6e8s7DMa2xH4YZdZumSOwsVzFeBWdr37tpIhOpSwXqONNgZq/2KgvBt54znHN1HzlljTO4oVD5fb+prNIJXQNL1ofDKQisbPLJDv3jNSLq9OkYBEIihKIj3v7S1TRQCX5Kdl1ZQlol7LF+E++fwirfiq2sf4cTXxc6hzxffPuLEeqSWrPGWMF58TWr5viyJAP5/4EV4KePiaSE8eNRgjDy8/tyRW+FZjhS+2tlovNJovtJovNJ0uhK6Wo64SDdxEbM//KesjwAAAABJRU5ErkJggg==";var imageSize=[351,63],imageOffset=[20,20],vertices=new Float32Array([-.5,-.5,0,.5,-.5,0,-.5,.5,0,.5,.5,0]),uvs=new Float32Array([0,0,1,0,0,1,1,1]),index=new Uint8Array([0,1,2,1,3,2]),geometry=new THREE__namespace.BufferGeometry;geometry.setAttribute("position",new THREE__namespace.BufferAttribute(vertices,3)),geometry.setAttribute("uv",new THREE__namespace.BufferAttribute(uvs,2)),geometry.setIndex(new THREE__namespace.BufferAttribute(index,1));var material=new THREE__namespace.MeshBasicMaterial({transparent:!0,depthTest:!1,depthWrite:!1,stencilWrite:!1,fog:!1}),mesh=new THREE__namespace.Mesh(geometry,material);mesh.matrixAutoUpdate=!1;var scene=new THREE__namespace.Scene;scene.add(mesh),scene.matrixAutoUpdate=!1;var camera=new THREE__namespace.OrthographicCamera(-.5,.5,.5,-.5,.1,1);camera.position.set(0,0,.5),camera.lookAt(0,0,0),camera.updateMatrixWorld(!0),camera.matrixAutoUpdate=!1;var prevViewport=new THREE__namespace.Vector4,prevScissor=new THREE__namespace.Vector4;function renderPoweredByRealsee(n){if(material.map){var r=n.getViewport(prevViewport),i=n.getScissor(prevScissor),o=n.getScissorTest(),s=n.autoClear,u=i.x+imageOffset[0]/3,l=i.y+imageOffset[1]/3,d=imageSize[0]/3,c=imageSize[1]/3;n.setViewport(u,l,d,c),n.setScissor(u,l,d,c),n.setScissorTest(!0),n.autoClear=!1,n.render(scene,camera),n.setViewport(r),n.setScissor(i),n.setScissorTest(o),n.autoClear=s}else{var t=new THREE__namespace.Texture,e=new Image;e.onload=function(){t.image=e,t.wrapS=THREE__namespace.ClampToEdgeWrapping,t.wrapT=THREE__namespace.ClampToEdgeWrapping,t.minFilter=THREE__namespace.LinearFilter,t.needsUpdate=!0,t.generateMipmaps=!1,material.needsUpdate=!0,e.onload=noop$1},e.src=textureURL,material.map=t}}var DEFAULT_MODE_CHANGE_DURATION=800,DEFAULT_REQUEST_PROXY=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/")},BUILTIN_COORDINATESSYSTEMTRANSFORMERS=[{name:"Z",transformToUpAxisZ:function(){return new THREE__namespace.Matrix4}},{name:"Y",transformToUpAxisZ:function(){return new THREE__namespace.Matrix4().makeRotationAxis(new THREE__namespace.Vector3(1,0,0),+Math.PI/2)}},{name:"-Y",transformToUpAxisZ:function(){return new THREE__namespace.Matrix4().makeRotationAxis(new THREE__namespace.Vector3(1,0,0),-Math.PI/2)}},{name:"WGS84",transformToEarthCentered:function(){return new THREE__namespace.Matrix4}},{name:"GCJ02",transformToEarthCentered:function(){return new THREE__namespace.Matrix4}},{name:"BD09",transformToEarthCentered:function(){return new THREE__namespace.Matrix4}}],sharedVector2=new THREE__namespace.Vector2,sharedFrustum=new THREE__namespace.Frustum,sharedProjScreenMatrix=new THREE__namespace.Matrix4,clockForMixer=new WeakMap,worksMap=new WeakMap,emptyWorks=createWorks([]),Five=function(n){__extends(t,n);function t(e){e===void 0&&(e={});var r,i,o,s,u,l,d,c,f,h,v=n.call(this)||this;v.ident=createUuid(),__FIVE_DEBUG__.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=__assign({},(i=e.imageOptions)!==null&&i!==void 0?i:{}),v.textureOptions=__assign({},(o=e.textureOptions)!==null&&o!==void 0?o:{}),v.poweredByRealsee=(s=e.poweredByRealsee)!==null&&s!==void 0?s:!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=__spreadArray([],(u=e.coordinatesSystemTransformers)!==null&&u!==void 0?u:[],!0);for(var A=function(B){var F=m.coordinatesSystemTransformers.find(function(O){return O.name===B.name});F||m.coordinatesSystemTransformers.push(__assign({},B))},m=this,y=0,p=BUILTIN_COORDINATESSYSTEMTRANSFORMERS;y<p.length;y++){var g=p[y];A(g)}if(v.fps={testCount:0,testTime:now()},v.info=null,v.modeChangeDuration=(l=e.modeChangeDuration)!==null&&l!==void 0?l:DEFAULT_MODE_CHANGE_DURATION,v.enableWheel=(d=e.enableWheel)!==null&&d!==void 0?d:!0,typeof window<"u")if(e.renderer)e.renderer instanceof InternalWebGLRenderer&&v.throwError(new Error("cannot render a internal renderer")),v.renderer=e.renderer;else try{v.renderer=new InternalWebGLRenderer({preserveDrawingBuffer:e.preserveDrawingBuffer,backgroundColor:e.backgroundColor,backgroundAlpha:e.backgroundAlpha,antialias:e.antialias,webgl2:e==null?void 0:e.webgl2});var b=getViewportScale();v.renderer.setPixelRatio(b===1?window.devicePixelRatio:1),v.renderer.setSize(512,512)}catch(B){B instanceof Error&&v.throwError(B)}v.getPixelsRenderTarget=new THREE__namespace.WebGLRenderTarget(1,1,{encoding:(f=(c=v.renderer)===null||c===void 0?void 0:c.outputEncoding)!==null&&f!==void 0?f:THREE__namespace.sRGBEncoding}),v.scissor=Object.assign({left:0,bottom:0,width:1,height:1},e.scissor),v.camera=new Camera(90),v.scene=new Scene,v.xrCustomObjectsScene=new THREE__namespace.Scene,v.scene.add(v.xrCustomObjectsScene),v.scene.matrixAutoUpdate=!1,v.lastLoadWorkTask=Promise.resolve(),v.requestProxy=(h=e.requestProxy)!==null&&h!==void 0?h:DEFAULT_REQUEST_PROXY,v.networkSubscribe=new NetworkSubscribe,v.networkSubscribe.on("network",function(B,F,O,H){var k;v.emit("network.resource",createEvent("network.resource",{source:B,requestType:F,requestState:O,detail:H})),(k=v.analysis)===null||k===void 0||k.network(v.works,B,F,O,H)}),v.boundingMesh=generateBoundingMesh(new THREE__namespace.Box3(new THREE__namespace.Vector3(-.5,-.5,-.5),new THREE__namespace.Vector3(.5,.5,.5))),v.boundingMesh.name="bounding",v.scene.add(v.boundingMesh),v.models=createModels(),v.models.push(new Model),v.lastModels=createModels(),v.readyCallbacks=[],v.syncingState=!1,v.modelGroup=new THREE__namespace.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 THREE__namespace.Group,v.helperGroup.name="helper",v.helperGroup.matrixAutoUpdate=!1,v.scene.add(v.helperGroup),v.videoTexture=new THREE__namespace.VideoTexture(e.videoInstance||generateDefaultVideoElement()),initLights(v.scene),v.copyEffect=new Effect(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=AnimationFrameLoop.shared.add(function(B,F){for(var O=[],H=2;H<arguments.length;H++)O[H-2]=arguments[H];v.updateTime.apply(v,__spreadArray([B,F],O,!1))},!1,0,10));var T=function(){typeof document<"u"&&document.fullscreenElement===null&&v.currentMode==="VRPanorama"&&v.controller.emit("vr.requestExit",createEvent("vr.requestExit",{}))};if(typeof document<"u"&&document.addEventListener("fullscreenchange",T,!1),v.removeEventListeners=function(){typeof document<"u"&&document.removeEventListener("fullscreenchange",T,!1)},v.plugins={},e.plugins&&e.plugins.length)for(var _=0,w=e.plugins;_<w.length;_++){var x=w[_];if(typeof x=="function")x(v);else if(Array.isArray(x)){var M=x[0],R=x[1],I=x[2];if(typeof M=="function"){var S=M(v,I);typeof R=="string"&&(v.plugins[R]?v.throwError(new Error("plugin name ".concat(R," is exists."))):v.plugins[R]=S)}}}return v.gpuPickingRenderTarget=new THREE__namespace.WebGLRenderTarget(1,1),v.meshReplaceMaterialMap=new Map,v.meshOriginMaterialMap=new Map,initLegacyEvent(v),v}return Object.defineProperty(t,"version",{get:function(){return"6.0.0-alpha.64"},enumerable:!1,configurable:!0}),Object.defineProperty(t,"dracoPath",{get:function(){return draco.decoderPath},set:function(e){draco.setDecoderPath(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t,"ktx2Path",{get:function(){return ktx2.transcoderPath},set:function(e){ktx2.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,o,s){var u=this;if(o===void 0&&(o=1),s===void 0&&(s=new THREE__namespace.Vector3(0,0,0)),!this.renderer)throw new Error("renderer is not initialized.");this.models.setMaterial({constantColor:s}),this.scene.traverse(function(f){if(!(!(f instanceof THREE__namespace.Mesh)||f instanceof PBMMesh)){var h=Object.keys(i).filter(function(A){return A===f.uuid})[0];if(h)if(u.meshOriginMaterialMap.set(h,f.material),u.meshReplaceMaterialMap.get(h))f.material=u.meshReplaceMaterialMap.get(h);else{var v=new THREE__namespace.ShaderMaterial({uniforms:{color:{value:i[h]}},vertexShader:`
|
|
2038
|
+
`},LineMaterial=function(n){__extends(t,n);function t(e){var r=n.call(this,{uniforms:THREE__namespace.UniformsUtils.clone(lineShader.uniforms),vertexShader:lineShader.vertexShader,fragmentShader:lineShader.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}(THREE__namespace.ShaderMaterial);Object.assign(LineMaterial.prototype,{isLineMaterial:!0});var LineSegments2=function(n){__extends(t,n);function t(e,r){var i=n.call(this)||this;return i.type="LineSegments2",i.geometry=e!==void 0?e:new LineSegmentsGeometry,i.material=r!==void 0?r:new LineMaterial({color:Math.random()*16777215}),i}return t.prototype.computeLineDistances=function(){for(var e=this.geometry,r=e.attributes.instanceStart,i=e.attributes.instanceEnd,o=new Float32Array(2*r.count),s=new THREE__namespace.Vector3,u=new THREE__namespace.Vector3,l=0,d=0,c=r.count;l<c;l++,d+=2)s.fromBufferAttribute(r,l),u.fromBufferAttribute(i,l),o[d]=d===0?0:o[d-1],o[d+1]=o[d]+s.distanceTo(u);var f=new THREE__namespace.InstancedInterleavedBuffer(o,2,1);return e.setAttribute("instanceDistanceStart",new THREE__namespace.InterleavedBufferAttribute(f,1,0)),e.setAttribute("instanceDistanceEnd",new THREE__namespace.InterleavedBufferAttribute(f,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,o=e.camera,s=o.projectionMatrix,u=this.geometry,l=this.material,d=l.resolution,c=l.linewidth,f=u.attributes.instanceStart,h=u.attributes.instanceEnd,v=new THREE__namespace.Vector4,A=new THREE__namespace.Vector4,m=new THREE__namespace.Vector4,y=new THREE__namespace.Vector3,p=new THREE__namespace.Matrix4,g=new THREE__namespace.Line3,b=new THREE__namespace.Vector3;i.at(1,m),m.w=1,m.applyMatrix4(o.matrixWorldInverse),m.applyMatrix4(s),m.multiplyScalar(1/m.w),m.x*=d.x/2,m.y*=d.y/2,m.z=0,y.copy(m);var T=this.matrixWorld;p.multiplyMatrices(o.matrixWorldInverse,T);for(var _=0,w=f.count;_<w;_++){v.fromBufferAttribute(f,_),A.fromBufferAttribute(h,_),v.w=1,A.w=1,v.applyMatrix4(p),A.applyMatrix4(p),v.applyMatrix4(s),A.applyMatrix4(s),v.multiplyScalar(1/v.w),A.multiplyScalar(1/A.w);var x=v.z<-1&&A.z<-1,M=v.z>1&&A.z>1;if(!(x||M)){v.x*=d.x/2,v.y*=d.y/2,A.x*=d.x/2,A.y*=d.y/2,g.start.copy(v),g.start.z=0,g.end.copy(A),g.end.z=0;var R=g.closestPointToPointParameter(y,!0);g.at(R,b);var I=THREE__namespace.MathUtils.lerp(v.z,A.z,R),S=I>=-1&&I<=1,B=y.distanceTo(b)<c*.5;if(S&&B){g.start.fromBufferAttribute(f,_),g.end.fromBufferAttribute(h,_),g.start.applyMatrix4(T),g.end.applyMatrix4(T);var O=new THREE__namespace.Vector3,F=new THREE__namespace.Vector3;i.distanceSqToSegment(g.start,g.end,F,O),r.push({point:F,pointOnLine:O,distance:i.origin.distanceTo(F),object:this,faceIndex:_})}}}},t}(THREE__namespace.Mesh);Object.assign(LineSegments2.prototype,{isLineSegments2:!0});var Line2=function(n){__extends(t,n);function t(e,r){var i=n.call(this,e,r)||this;return i.type="Line2",i}return t}(LineSegments2);Object.assign(Line2.prototype,{isLine2:!0});var LineGeometry=function(n){__extends(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),o=0;o<r;o+=3)i[2*o]=e[o],i[2*o+1]=e[o+1],i[2*o+2]=e[o+2],i[2*o+3]=e[o+3],i[2*o+4]=e[o+4],i[2*o+5]=e[o+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),o=0;o<r;o+=3)i[2*o]=e[o],i[2*o+1]=e[o+1],i[2*o+2]=e[o+2],i[2*o+3]=e[o+3],i[2*o+4]=e[o+4],i[2*o+5]=e[o+5];return n.prototype.setColors.call(this,i),this},t.prototype.fromLine=function(e){var r=e.geometry;if(r instanceof THREE__namespace.Geometry){var i=new THREE__namespace.BufferGeometry().fromGeometry(r);this.setPositions(i.attributes.position.array)}else r instanceof THREE__namespace.BufferGeometry&&this.setPositions(r.attributes.position.array);return this},t.prototype.copy=function(){return this},t}(LineSegmentsGeometry);Object.assign(LineGeometry.prototype,{isLineGeometry:!0});var circleImageURL="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==",DEFAULT_COLOR=14467195,POINT_SIZE=8,DEFAULT_LINEWIDTH=2,DEFAULT_DASHSCALE=20,sharedCircleTexture=null,FiveLine=function(n){__extends(t,n);function t(e,r){e===void 0&&(e=new THREE__namespace.Vector3),r===void 0&&(r=new THREE__namespace.Vector3);var i=n.call(this)||this;i.type="FiveLine",i.needsRender=!0;var o=new LineGeometry,s=new LineMaterial({color:DEFAULT_COLOR,linewidth:DEFAULT_LINEWIDTH,dashScale:DEFAULT_DASHSCALE,dashed:!1});i.line=new Line2(o,s);var u=new THREE__namespace.BufferGeometry,l=new THREE__namespace.PointsMaterial({color:DEFAULT_COLOR,size:POINT_SIZE,map:sharedCircleTexture||(sharedCircleTexture=new THREE__namespace.TextureLoader().load(circleImageURL)),sizeAttenuation:!1,transparent:!0});return i.points=new THREE__namespace.Points(u,l),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 THREE__namespace.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 THREE__namespace.Vector3(e[0],e[1],e[2]),new THREE__namespace.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 o=e[i];i==="dashed"?(r.dashed=o,o?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}(THREE__namespace.Object3D);Object.assign(FiveLine.prototype,{isFiveLine:!0});var Constants={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 fetchJsonFile(n){return __awaiter(this,void 0,void 0,function(){var t;return __generator(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 fetchProfilesList(n){return __awaiter(this,void 0,void 0,function(){var t,e;return __generator(this,function(r){switch(r.label){case 0:if(!n)throw new Error("No basePath supplied");return t="profilesList.json",[4,fetchJsonFile("".concat(n,"/").concat(t))];case 1:return e=r.sent(),[2,e]}})})}function fetchProfile(n,t,e,r){return e===void 0&&(e=null),r===void 0&&(r=!0),__awaiter(this,void 0,void 0,function(){var i,o,s,u,l,d;return __generator(this,function(c){switch(c.label){case 0:if(!n)throw new Error("No xrInputSource supplied");if(!t)throw new Error("No basePath supplied");return[4,fetchProfilesList(t)];case 1:if(i=c.sent(),n.profiles.some(function(f){var h=i[f];return h&&(o={profileId:f,profilePath:"".concat(t,"/").concat(h.path),deprecated:!!h.deprecated}),!!o}),!o){if(!e)throw new Error("No matching profile name found");if(s=i[e],!s)throw new Error('No matching profile name found and default profile "'.concat(e,'" missing.'));o={profileId:e,profilePath:"".concat(t,"/").concat(s.path),deprecated:!!s.deprecated}}return[4,fetchJsonFile(o.profilePath)];case 2:if(u=c.sent(),r){if(d=void 0,d=u.layouts[n.handedness],!d)throw new Error("No matching handedness, ".concat(n.handedness,", in profile ").concat(o.profileId));d.assetPath&&(l=o.profilePath.replace("profile.json",d.assetPath))}return[2,{profile:u,assetPath:l}]}})})}var defaultComponentValues={xAxis:0,yAxis:0,button:0,state:Constants.ComponentState.DEFAULT};function normalizeAxes(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 o=Math.atan2(t,n);e=Math.cos(o),r=Math.sin(o)}var s={normalizedXAxis:e*.5+.5,normalizedYAxis:r*.5+.5};return s}var VisualResponse=function(){function n(t){this.componentProperty=t.componentProperty,this.states=t.states,this.valueNodeName=t.valueNodeName,this.valueNodeProperty=t.valueNodeProperty,this.valueNodeProperty===Constants.VisualResponseProperty.TRANSFORM&&(this.minNodeName=t.minNodeName,this.maxNodeName=t.maxNodeName),this.value=0,this.updateFromComponent(defaultComponentValues)}return n.prototype.updateFromComponent=function(t){var e=t.xAxis,r=t.yAxis,i=t.button,o=t.state,s=normalizeAxes(e,r),u=s.normalizedXAxis,l=s.normalizedYAxis;switch(this.componentProperty){case Constants.ComponentProperty.X_AXIS:this.value=this.states.includes(o)?u:.5;break;case Constants.ComponentProperty.Y_AXIS:this.value=this.states.includes(o)?l:.5;break;case Constants.ComponentProperty.BUTTON:this.value=this.states.includes(o)?i:0;break;case Constants.ComponentProperty.STATE:this.valueNodeProperty===Constants.VisualResponseProperty.VISIBILITY?this.value=this.states.includes(o):this.value=this.states.includes(o)?1:0;break;default:throw new Error("Unexpected visualResponse componentProperty ".concat(this.componentProperty))}},n}(),Component=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 o=new VisualResponse(e.visualResponses[i]);r.visualResponses[i]=o}),this.gamepadIndices=Object.assign({},e.gamepadIndices),this.values={state:Constants.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=__assign({id:this.id},this.values);return t},enumerable:!1,configurable:!0}),n.prototype.updateFromGamepad=function(t){var e=this;if(this.values.state=Constants.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=Constants.ComponentState.PRESSED:(r.touched||this.values.button>Constants.ButtonTouchThreshold)&&(this.values.state=Constants.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===Constants.ComponentState.DEFAULT&&Math.abs(this.values.xAxis)>Constants.AxisTouchThreshold&&(this.values.state=Constants.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===Constants.ComponentState.DEFAULT&&Math.abs(this.values.yAxis)>Constants.AxisTouchThreshold&&(this.values.state=Constants.ComponentState.TOUCHED)),Object.values(this.visualResponses).forEach(function(i){i.updateFromComponent(e.values)})},n}(),MotionController=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(o){var s=i.layoutDescription.components[o];i.components[o]=new Component(o,s)}),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}(),DEFAULT_PROFILES_PATH="https://cdn.jsdelivr.net/npm/@webxr-input-profiles/assets@1.0/dist/profiles",DEFAULT_PROFILE="generic-trigger",XRControllerModel=function(n){__extends(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 THREE__namespace.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 o=i.valueNode,s=i.minNode,u=i.maxNode,l=i.value,d=i.valueNodeProperty;o&&(d===Constants.VisualResponseProperty.VISIBILITY?o.visible=l:d===Constants.VisualResponseProperty.TRANSFORM&&(o.quaternion.copy(s.quaternion).slerp(u.quaternion,l),o.position.lerpVectors(s.position,u.position,l)))})}))},t}(THREE.Object3D);function findNodes(n,t){Object.values(n.components).forEach(function(e){var r=e.type,i=e.touchPointNodeName,o=e.visualResponses;if(r===Constants.ComponentType.TOUCHPAD)if(e.touchPointNode=t.getObjectByName(i),e.touchPointNode){var s=new THREE.SphereGeometry(.001),u=new THREE.MeshBasicMaterial({color:255}),l=new THREE.Mesh(s,u);e.touchPointNode.add(l)}else console.warn("Could not find touch dot, ".concat(e.touchPointNodeName,", in touchpad component ").concat(e.id));Object.values(o).forEach(function(d){var c=d.valueNodeName,f=d.minNodeName,h=d.maxNodeName,v=d.valueNodeProperty;if(v===Constants.VisualResponseProperty.TRANSFORM){if(d.minNode=t.getObjectByName(f),d.maxNode=t.getObjectByName(h),!d.minNode){console.warn("Could not find ".concat(f," in the model"));return}if(!d.maxNode){console.warn("Could not find ".concat(h," in the model"));return}}d.valueNode=t.getObjectByName(c),d.valueNode||console.warn("Could not find ".concat(c," in the model"))})})}function addAssetSceneToControllerModel(n,t){findNodes(n.motionController,t),n.envMap&&t.traverse(function(e){e instanceof THREE__namespace.Mesh&&e.isMesh&&(e.material.envMap=n.envMap,e.material.needsUpdate=!0)}),n.add(t)}var XRControllerModelFactory=function(){function n(t){t===void 0&&(t=null),this.gltfLoader=t,this.path=DEFAULT_PROFILES_PATH,this._assetCache={}}return n.prototype.createControllerModel=function(t){var e=this,r=new XRControllerModel,i=null;return t.addEventListener("connected",function(o){var s=o.data;s.targetRayMode!=="tracked-pointer"||!s.gamepad||fetchProfile(s,e.path,DEFAULT_PROFILE).then(function(u){var l=u.profile,d=u.assetPath;r.motionController=new MotionController(s,l,d);var c=e._assetCache[r.motionController.assetUrl];if(c)i=c.scene.clone(),addAssetSceneToControllerModel(r,i);else{if(!e.gltfLoader)throw new Error("GLTFLoader not set.");e.gltfLoader.load(r.motionController.assetUrl,function(f){e._assetCache[r.motionController.assetUrl]=f,i=f.scene.clone(),addAssetSceneToControllerModel(r,i)})}}).catch(function(u){console.warn(u)})}),t.addEventListener("disconnected",function(){r.motionController=null,r.remove(i),i=null}),r},n}();function mapPanoResource(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 CONTROLLER_EVNET_DELTA_TIME=300,ROTATE_Y_PI_MATRIX=new THREE__namespace.Matrix4().makeRotationAxis(new THREE__namespace.Vector3(0,1,0),Math.PI),PANO_TEXTURE_SCALE=new THREE__namespace.Vector3(-1,1,1),XRPanoramaController=function(n){__extends(t,n);function t(e){var r,i=n.call(this,e)||this;i.xrManager=new XRManager(i.renderer,i.renderer.getContext(),{onSessionStart:function(d){i.emit("xr.session.start",createEvent("xr.session.start",{session:d,machineType:i.xrManager.machineType}))},onSessionEnd:function(){i.emit("xr.session.end",createEvent("xr.session.end",{session:null,machineType:i.xrManager.machineType}))}}),i.xrControllerRay={left:new THREE__namespace.Raycaster,right:new THREE__namespace.Raycaster},i.xrControllerRay.left.params.Points={threshold:.1},i.xrControllerRay.right.params.Points={threshold:.1},i.pointerLines={left:new FiveLine,right:new FiveLine},i.pointerLines.left.visible=!1,i.pointerLines.right.visible=!0,i.pointerLines.left.setMaterial({color:new THREE__namespace.Vector3(1,1,1)}),i.pointerLines.left.points.material.depthTest=!1,i.pointerLines.right.setMaterial({color:new THREE__namespace.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=createUuid()]={panoId:panoStringify(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 o=AnimationFrameLoop.shared.getContext();if(!o)return console.error("获取session失败,请退出重试"),i;i.on("xr.session.end",function(){i.scene.remove(i.pointerLines.left,i.pointerLines.right)}),i.xrManager.setSession(o),i.controllerWrappers=[new THREE__namespace.Group,new THREE__namespace.Group],i.scene.add(i.controllerWrappers[0],i.controllerWrappers[1]);var s=i.xrManager.getController(0);i.controllerWrappers[0].add(s);var u=i.xrManager.getController(1);i.controllerWrappers[1].add(u);var l=new XRControllerModelFactory;return l.gltfLoader={load:function(d,c){internalFetcher.ajax(d,{responseType:"arraybuffer"}).then(function(f){var h;return parseGltf(f.body,{resourcePath:d.slice(0,d.lastIndexOf("/")+1),search:(h=d.split("?")[1])!==null&&h!==void 0?h:"",fetcher:internalFetcher})}).then(function(f){return c(f)})}},i.on("xr.session.start",function(){var d=i.xrManager.getControllerGrip(0);if(d.add(l.createControllerModel(d)),i.controllerWrappers[0].add(d),!i.onlyUseRightController){var c=i.xrManager.getControllerGrip(1);c.add(l.createControllerModel(c)),i.controllerWrappers[1].add(c)}}),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=__assign(__assign({},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 __assign(__assign({},i),{mode:"XRPanorama"})},t.prototype.moveToPano=function(e,r,i){var o=this,s,u,l,d;this.userAction=i,this.stopMomentumMovement();var c=this.works.getResolvedObserver(e);if(!c)throw new Error("Invalid PanoIndex");var f=this.imageOptions.size;if(typeof f>"u"&&c){var h=c.images.up.match(/\/cube_(\d+)\//);h&&(f=Number(h[1]))}typeof f>"u"&&(f=2048);var v=this.imageOptions.transform,A=function(I,S){return mapPanoResource(applyImageURLOptions(I,v,S))},m=__assign({key:"pano.".concat(c.panoId)},pick(this.imageOptions,["format","size","quality"])),y=c.images,p=(u=(s=c.images.tiles)===null||s===void 0?void 0:s.filter(function(I){return I.size>f}))!==null&&u!==void 0?u:null,g="pano:"+jsonHash([y,m,v]);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===g)return;var b=this.pendingTextureTask.panoId;(l=this.panoMeshes[b])===null||l===void 0||l.setProgress(0),this.emit("pano.texture.abort",createEvent("pano.texture.abort",{error:null,progress:0,meta:null,pano:c.pano})),this.pendingTextureTask.onError(new Error("texture aborted"))}var T=this.models.getMaterial()||{},_=T.pano0,w=T.pano1,x;if((_==null?void 0:_.map.name)===g?x=_:(w==null?void 0:w.map.name)===g&&(x=w),x){var M={panoId:c.panoId,effect:(d=r.effect)!==null&&d!==void 0?d:"fade",leftPanoPicture:{map:x.map,luminanceMap:x.luminanceMap,matrix:new THREE__namespace.Matrix4().compose(c.position,c.quaternion,PANO_TEXTURE_SCALE)},position:c.position.clone()};this.doMoveToPano(c.pano,M,r);return}var R="move-to-pano-"+c.panoId;this.pending.add(R),this.pendingTextureTask={panoId:c.panoId,hash:g,onLoad:function(I){var S;if(o.pending.delete(R),o.destroyed)I.body.dispose();else{I.body.name=g;var B={panoId:c.panoId,effect:(S=r.effect)!==null&&S!==void 0?S:"fade",leftPanoPicture:{map:I.body,luminanceMap:null,matrix:new THREE__namespace.Matrix4().compose(c.position,c.quaternion,PANO_TEXTURE_SCALE)},position:c.position.clone()};o.doMoveToPano(c.pano,B,r)}},onError:function(I){o.pending.delete(R);var S=__assign(__assign(__assign({},c.pano),{mode:o.mode}),clonePose(o.camera.pose));o.emit("pano.error",createEvent("pano.error",{error:I,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:S})),o.emit("pano.cancel",createEvent("pano.cancel",{error:null,userAction:o.userAction,options:r,prevPano:o.currentPano,progress:0,state:S})),r.moveCancelCallback&&r.moveCancelCallback()}},Promise.all([this.tileLevelForFov&&p&&p.length?this.textureLoader.loadTiledCubeTexture(y,p,{tileMaxLevel:this.TILED_CUBE_TEXTURE_LEVEL,imageURL:{transform:A,options:m},format:THREE__namespace.RGBAFormat,viaAjax:!0,fetcher:getFetcher(c.work)},void 0,void 0,function(I){var S,B;o.emit("pano.texture.progress",createEvent("pano.texture.progress",{error:null,progress:I,meta:null,pano:c.pano})),((S=o.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&((B=o.panoMeshes[c.panoId])===null||B===void 0||B.setProgress(I))},this.renderer):this.textureLoader.loadCubeTexture(y,{imageURL:{transform:A,options:m},format:THREE__namespace.RGBAFormat,fetcher:getFetcher(c.work)},void 0,void 0,function(I){var S,B;((S=o.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&((B=o.panoMeshes[c.panoId])===null||B===void 0||B.setProgress(I)),o.emit("pano.texture.progress",createEvent("pano.texture.progress",{error:null,progress:I,meta:null,pano:c.pano}))},this.renderer)]).then(function(I){var S,B,O=I[0];((S=o.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g?(o.pendingTextureTask.onLoad(O),(B=o.panoMeshes[c.panoId])===null||B===void 0||B.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.success",createEvent("pano.texture.success",{error:null,progress:1,meta:O.meta,pano:c.pano}))):O.body.dispose()}).catch(function(I){var S,B;((S=o.pendingTextureTask)===null||S===void 0?void 0:S.hash)===g&&(o.pendingTextureTask.onError(I),(B=o.panoMeshes[c.panoId])===null||B===void 0||B.setProgress(0),delete o.pendingTextureTask,o.emit("pano.texture.error",createEvent("pano.texture.error",{error:I,progress:0,meta:null,pano:c.pano})),o.emit("error",I))}),this.emit("pano.texture.load",createEvent("pano.texture.load",{error:null,progress:0,meta:null,pano:c.pano}))},t.prototype.doMoveToPano=function(e,r,i){var o=this,s,u,l;i===void 0&&(i={});var d=now(),c=createUuid();this.panoResources[c]=r;var f=1,h,v,A;if(this.locationMotion.ended){var m=this.locationMotion.getKeyFrameSegment(d);m[0];var y=m[1],p=this.locationMotion.value,g=this.panoResourceFromLocationMotionKeyframe(y).position,b=r.position;h=Math.max(g.distanceTo(b),f),v=[{key:y.key,progress:0,value:__assign(__assign({},p),{count:0})},{key:c,progress:1,value:{distance:0,count:1}}],A=0}else{var T=this.locationMotion.getKeyFrameSegment(d),_=T[0],y=T[1],p=this.locationMotion.value,w=this.panoResourceFromLocationMotionKeyframe(_).position,g=this.panoResourceFromLocationMotionKeyframe(y).position,b=r.position,x=y.value.count-p.count,M=Math.max(w.distanceTo(g),f)*x,R=Math.max(g.distanceTo(b),f);h=M+R,v=[{key:_.key,progress:0,value:__assign({},p)},{key:y.key,progress:M/h,value:y.value},{key:c,progress:1,value:{count:y.value.count+1,distance:0}}];var I=this.locationMotionKeyframesLength(this.locationMotion.keyframes),S=this.locationMotionKeyframesLength(v);A=this.locationMotion.getProgressVelocity(d)*I/S}var B=this.calculateMovingDuration(i.duration,h),O={longitude:i.longitude,latitude:i.latitude,fov:i.fov},F=__assign(__assign({},e),{mode:this.mode,longitude:(s=O.longitude)!==null&&s!==void 0?s:this.camera.pose.longitude,latitude:(u=O.latitude)!==null&&u!==void 0?u:this.camera.pose.latitude,fov:(l=O.fov)!==null&&l!==void 0?l:this.camera.pose.fov,offset:r.position.clone(),distance:0}),H=this.currentPano;this.emit("pano.moveTo",createEvent("pano.moveTo",{options:i,prevPano:H,progress:0,state:F,userAction:this.userAction,error:null})),i.moveStartCallback&&i.moveStartCallback(F),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=noop$1,this.videoTexture.needsUpdate=!0),this.panoVideo.setMaterial(null),this.cameraMotion.set(O,B).catch(noop$1);var k=this.locationMotion.setKeyframes(v,B,A);k.then(function(){var N,q,V,D=__assign(__assign({},e),{mode:o.mode,longitude:o.camera.pose.longitude,latitude:o.camera.pose.latitude,fov:o.camera.pose.fov,offset:o.camera.pose.offset.clone(),distance:0});o.emit("pano.arrived",createEvent("pano.arrived",{options:i,prevPano:H,progress:1,state:D,userAction:o.userAction,error:null})),i.moveEndCallback&&i.moveEndCallback(D);var K=o.works.getResolvedObserver(o.currentPano);if(K&&K.video&&o.videoTexture&&o.videoTexture.image instanceof HTMLVideoElement){var z=ROTATE_Y_PI_MATRIX.clone().multiply((V=(q=(N=o.models.getMaterial())===null||N===void 0?void 0:N.pano1)===null||q===void 0?void 0:q.matrix)!==null&&V!==void 0?V:new THREE__namespace.Matrix4).multiply(K.video.matrix),G={map:o.videoTexture,size:K.video.size,matrix:z,alpha:1},W=createUuid(),Q=o.videoTexture.image;Q.setAttribute("uuid",W),canplayVideo().then(function(X){X&&K.video&&Q.getAttribute("uuid")===W&&(Q.oncanplay=function(){Q.oncanplay=noop$1,Q.play()},Q.ontimeupdate=function(){Q.currentTime>.5&&(Q.ontimeupdate=noop$1,o.panoVideo.setMaterial(G))},Q.src=K.video.source)}).catch(function(){Q.removeAttribute("uuid")})}},function(){o.emit("pano.cancel",createEvent("pano.cancel",{options:i,prevPano:H,progress:0,state:F,userAction:o.userAction,error:null})),i.moveCancelCallback&&i.moveCancelCallback()})},t.prototype.checkSelectedPano=function(e){var r=this,i,o,s,u;this.stopMomentumMovement();var l=this.camera.getDirection(new THREE__namespace.Vector3).setY(0),d=null,c=this.works.getResolvedObserver(this.currentPano);if(!c)return null;var f=c.accessibleIds.filter(function(W){var Q=panoParse(W);if(panoEqual(Q,r.currentPano))return!1;var X=r.works.getResolvedObserver(Q);return!X||X.position.distanceTo(r.camera.position)>r.maxAccessibleDistance?!1:X.loadable||X.active}),h=this.models.intersectRaycaster(e)[0];if(h){var v=arrayMin(f,function(W){var Q=r.works.getResolvedObserver(W);if(!Q)return 1/0;var X=Q.standingPosition.clone();return X.distanceTo(h.point)},!0),A=v[0],m=v[1];A&&m<this.panoTapTriggerRadius&&(d=(i=this.works.getResolvedObserver(A))!==null&&i!==void 0?i:null)}if(isNil(d)){var y=this.getForwardObserverOrNot(e);y&&(d=y)}for(var p=0,g=this.locationMotion.keyframes;p<g.length;p++){var b=g[p],T=this.panoResourceFromLocationMotionKeyframe(b);if(!(b.progress<this.locationMotion.progress)&&d&&T.panoId===d.panoId){d=null;break}}if(isNil(d))return this.locationMotion.ended===!0&&this.cameraBounce(),null;if(d&&!d.active){var _=d.panoId;this.panoMeshes[_]&&(this.panoMeshes[_].setDisabled(!1),this.panoMeshes[_].setLoading(!0))}var w={};if(d){w.effect="fade";for(var x=Math.PI/6,M=Math.PI/12,R=new THREE__namespace.Vector3(0,1,0),I=d.position.clone().setY(0).sub(c.position.clone().setY(0)).normalize(),S=I.clone().applyAxisAngle(R,x),B=I.clone().applyAxisAngle(R,-x),O=[],F=[],H=[],k=0,N=d.accessibleIds;k<N.length;k++){var A=N[k],q=panoParse(A);if(!(panoEqual(q,this.currentPano)||panoEqual(q,d.pano))){var V=this.works.getResolvedObserver(A);if(V){var D=V.position.clone().sub(d.position).setY(0);I.angleTo(D)<x?H.push(D):S.angleTo(D)<x?O.push(D):B.angleTo(D)<x&&F.push(D)}}}var K=H.length>0?H:__spreadArray(__spreadArray([],O,!0),F,!0),z=K.slice().sort(function(W,Q){return W.angleTo(I)-Q.angleTo(I)})[0];z&&z.angleTo(l)>M&&(w.longitude=Math.atan2(-z.x,-z.z))}this.cameraMotion.value.latitude<-Math.PI/4&&(w.latitude=clamp(0,this.minLatitude,this.maxLatitude)),this.cameraMotion.value.fov<60&&(w.fov=this.defaultFov);var G={workCode:d.pano.workCode,panoIndex:d.pano.panoIndex,mode:this.mode,longitude:(o=w.longitude)!==null&&o!==void 0?o:this.camera.pose.longitude,latitude:(s=w.latitude)!==null&&s!==void 0?s:this.camera.pose.latitude,fov:(u=w.fov)!==null&&u!==void 0?u:this.camera.pose.fov,distance:0,offset:d?d.position.clone():new THREE__namespace.Vector3};return this.emit("pano.select",createEvent("pano.select",{prevPano:this.currentPano,state:G,userAction:!0,options:w,progress:0,error:null})),d&&d.active?(this.emit("pano.request",createEvent("pano.request",{userAction:!0,prevPano:this.currentPano,progress:0,state:G,options:w,error:null})),d.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,o,s,u,l,d,c,f,h,v=[],A=2;A<arguments.length;A++)v[A-2]=arguments[A];this.userAction=!0;var m={},y={},p=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),m.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);var T=this.locationMotion.getKeyFrameSegment(e),_=T[0],w=T[1],x=this.panoResourceFromLocationMotionKeyframe(_),M=this.panoResourceFromLocationMotionKeyframe(w),R=new THREE__namespace.Vector3().copy(x.position),I=new THREE__namespace.Vector3().copy(M.position),S=this.locationMotion.value.count-w.value.count+1;m.progress=S,M.leftPanoPicture&&(S<1?x.leftPanoPicture&&(m.pano0=x.leftPanoPicture):m.pano0=M.leftPanoPicture,m.pano1=M.leftPanoPicture),b=m.useBlackTransition=M.effect==="instant"||M.effect==="montage",(M.effect==="fade"||M.effect==="montage")&&(m.pano0&&x.leftPanoPicture&&(m.pano0={map:m.pano0.map,luminanceMap:m.pano0.luminanceMap,matrix:x.leftPanoPicture.matrix.clone().setPosition(M.position)}),R.copy(I)),y.distance=this.locationMotion.value.distance,y.offset=new THREE__namespace.Vector3(R.x+(I.x-R.x)*S,R.y+(I.y-R.y)*S,R.z+(I.z-R.z)*S);for(var B=[],O=[],F=0,H=this.locationMotion.keyframes;F<H.length;F++){var k=H[F],N=k.key,q=k.progress;N!==void 0&&(B.push(N),q>=this.locationMotion.progress&&O.push(N))}for(var V=0,D=Object.keys(this.panoResources);V<D.length;V++){var K=D[V];if(!(O.indexOf(K)>=0)){var z=this.panoResources[K];if(z.leftPanoPicture){var G=z.leftPanoPicture.map;if(G){if(G===((o=m.pano0)===null||o===void 0?void 0:o.map)||G===((s=m.pano1)===null||s===void 0?void 0:s.map))continue;G instanceof TileCubeTextureTarget&&G.cubeRenderTarget&&this.colorCubeRenderTargetPool.push(G.cubeRenderTarget),G.dispose(),z.leftPanoPicture=null}}B.indexOf(K)>=0||delete this.panoResources[K]}}this.currentPano=panoParse(M.panoId),this.emit("pano.moving",createEvent("pano.moving",{userAction:this.userAction,prevPano:panoParse(p.panoId),state:__assign(__assign(__assign(__assign({},panoParse(g.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),y),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(m)===!1&&(!((u=m.pano0)===null||u===void 0)&&u.map&&m.pano0.map instanceof TileCubeTextureTarget&&!m.pano0.map.cubeRenderTarget&&(m.pano0.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),!((l=m.pano1)===null||l===void 0)&&l.map&&m.pano1.map instanceof TileCubeTextureTarget&&!m.pano1.map.cubeRenderTarget&&(m.pano1.map.cubeRenderTarget=this.colorCubeRenderTargetPool.pop()),this.models.setMaterial(m)),isEmptyObject(y)===!1&&this.setCamera(y);var W=this.works.getResolvedObserver(this.currentPano),Q=v[1];if(!Q){console.error("xrFrame丢失,请重试");return}if(!this.xrManager.session){console.error("session丢失,请重试");return}var X=this.xrManager.referenceSpace;if(X){var ee=this.xrManager.cameraVR,J=this.xrManager.cameraL,Z=this.xrManager.cameraR,te=[J,Z],ae=Q.getViewerPose(X),re=new THREE__namespace.Vector3(0,0,0);if(ae){var ie;ie=this.xrManager.session.renderState.baseLayer;var de=ae.views;if(!ie){console.error("no layer found");return}this.renderer.setFramebuffer(ie.framebuffer);var se=!1;de.length!==ee.cameras.length&&(ee.cameras.length=0,se=!0),this.parallaxCameraMatrixs=[];var pe=new THREE__namespace.Vector3,$=new THREE__namespace.Vector3;new THREE__namespace.Matrix4().fromArray(de[0].transform.matrix).decompose(pe,new THREE__namespace.Quaternion,new THREE__namespace.Vector3),new THREE__namespace.Matrix4().fromArray(de[1].transform.matrix).decompose($,new THREE__namespace.Quaternion,new THREE__namespace.Vector3),$.clone().sub(pe).normalize();var oe=new THREE__namespace.Vector3,j=new THREE__namespace.Quaternion,ve=new THREE__namespace.Vector3;this.camera.matrix.decompose(oe,j,ve);for(var me=0;me<de.length;me++){var Me=de[me],Re=ie.getViewport(Me),ge=te[me];ge.matrix.fromArray(Me.transform.matrix);var we=new THREE__namespace.Vector3,Ae=new THREE__namespace.Quaternion,le=new THREE__namespace.Vector3;ge.matrix.decompose(we,Ae,le),re.copy(oe),ge.position.copy(oe),ge.quaternion.copy(Ae),ge.scale.copy(le),ge.updateMatrix(),ge.projectionMatrix.fromArray(Me.projectionMatrix),ge.viewport.set(Re.x,Re.y,Re.width,Re.height),se===!0&&ee.cameras.push(ge)}ae.views[0].transform.position,ae.views[1].transform.position;for(var ue=this.xrManager.session.inputSources,me=0;me<this.xrManager.controllers.length;me++){var Fe=this.xrManager.controllers[me],fe=ue[me];if(fe){Fe.update(fe,Q,X);var Se=this.xrManager.getController(me),ye=new THREE__namespace.Vector3(0,1.2,0),ke=Se.position.clone().add(re).sub(ye);fe.handedness==="left"?this.xrControllerRay.left.set(ke,new THREE__namespace.Vector3(0,0,-1).applyEuler(Se.rotation)):fe.handedness==="right"&&this.xrControllerRay.right.set(ke,new THREE__namespace.Vector3(0,0,-1).applyEuler(Se.rotation)),this.controllerWrappers[me].position.copy(new THREE__namespace.Vector3(0,0,0).add(re).sub(ye));var _e=this.models.intersectRaycaster(this.xrControllerRay.right);if(_e.length===0&&(_e=this.xrControllerRay.right.intersectObject(this.boundingMesh,!0).map(function(Le){var Ue;return __assign({floor:(Ue=W==null?void 0:W.floorIndex)!==null&&Ue!==void 0?Ue:0},Le)})),_e.length>=1&&_e[0].face)if(fe.handedness==="right"){var We=this.xrControllerRay.right.intersectObject(this.xrCustomObjectsScene,!0),Xe=_e[0].face.normal,Ee=Xe.clone().multiplyScalar(.05),Pe=_e[0].point.clone().add(Ee);this.intersectMesh.position.copy(Pe);var Je=Pe.clone().add(Ee);if(this.intersectMesh.lookAt(Je),Math.abs(Xe.y)>.99){var be=this.camera.position.clone().sub(Pe);this.intersectMesh.rotation.z=-Math.atan2(be.z,be.x)}this.intersectMesh.visible=!0,this.needsRender=!0,We.length>0?(this.pointerLines.right.setPoints(ke,We[0].point),this.pointerLines.right.points.visible=!0,this.intersectMesh.visible=!1):(this.pointerLines.right.points.visible=!1,this.pointerLines.right.setPoints(ke,_e[0].point));var Oe=_e[0],De=createEvent("intersect.update",{raycaster:(d=this.xrControllerRay.right)!==null&&d!==void 0?d:null,intersection:Oe??null,object:this.intersectMesh});if(this.emit("intersect.update",De),De.defaultPrevented){this.hideIntersectMesh();return}}else this.pointerLines.left.setPoints(ke,_e[0].point)}}if(this.camera.pose.distance>.1||b){if(W)for(var qe=0,Ze=Object.keys(this.panoMeshes);qe<Ze.length;qe++){var Ne=Ze[qe],he=this.panoMeshes[Ne];he.setOpacity(0),he.setCurrent(!1),he.updateTime&&he.updateTime(e,r)}}else if(W){var st=arrayMin(W.visibleIds,function(Be){var Le=i.works.getResolvedObserver(Be);return Le?W.standingPosition.distanceTo(Le.standingPosition):1/0},!0),ze=st[1];ze=clamp(ze,2.5,1/0);for(var tt=W.visibleIds.concat(panoStringify(this.currentPano)),Ge=this.getForwardObserverOrNot(),mt=this.camera.getDirection(new THREE__namespace.Vector3),lt=0,ct=Object.keys(this.panoMeshes);lt<ct.length;lt++){var Ne=ct[lt],he=this.panoMeshes[Ne],rt=this.works.getResolvedObserver(Ne);if(tt.indexOf(Ne)===-1)he.setCurrent(!1),he.setOpacity(0);else if(!rt)he.setCurrent(!1),he.setOpacity(0);else if(!rt.loadable&&!rt.active)he.setCurrent(!1),he.setOpacity(0);else{var nt=he.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);he.setCurrent(!he.loading&&he.progress===0&&Ge!==null&&Ge.panoId===Ne),he.setOpacity(nt<.01?0:clamp(ze/nt*1.2,.65,.98));var Ie=this.camera.position.clone().setY(he.position.y),xe=new THREE__namespace.Vector3().copy(he.position).sub(Ie).normalize();if(Ne===panoStringify(this.currentPano)){var je=clamp((.5-Ie.distanceTo(he.position))/.5,0,1);xe.multiplyScalar(1-je).add(mt.clone().multiplyScalar(je))}xe.length()>0&&he.quaternion.setFromEuler(new THREE__namespace.Euler(0,Math.atan2(xe.x,xe.z),0))}he.updateTime&&he.updateTime(e,r)}}var at=function(){if(i.tileLevelForFov===!1)return 0;var Be=new THREE__namespace.Vector2(4e3,4e3),Le=g.panoId,Ue=i.works.getResolvedObserver(Le),Ve=i.imageOptions.size;if(typeof Ve>"u"&&Ue){var Et=Ue.images.up.match(/\/cube_(\d+)\//);Et&&(Ve=Number(Et[1]))}typeof Ve>"u"&&(Ve=2048);var ft=0;Ve>=1024&&(ft=1),Ve>=2048&&(ft=2),Ve>=4096&&(ft=3),Ve>=8192&&(ft=4);var ht=i.tileLevelForFov(J.fov,Be);return ht>ft?ht:0}(),At=function(){var Be=new THREE__namespace.PerspectiveCamera;Be.applyMatrix4(ee.matrix),Be.position.set(0,0,0);var Le=i.works.getResolvedObserver(g.panoId),Ue=Le??W;Ue&&Be.quaternion.premultiply(Ue.quaternion.clone().inverse()),Be.updateProjectionMatrix(),Be.updateMatrixWorld(!0);var Ve=new THREE__namespace.Frustum().setFromProjectionMatrix(new THREE__namespace.Matrix4().multiplyMatrices(Be.projectionMatrix,Be.matrixWorldInverse));return Ve}();g.panoId===panoStringify(this.currentPano)&&((c=g.leftPanoPicture)===null||c===void 0?void 0:c.map)instanceof TileCubeTextureTarget&&(g.leftPanoPicture.map.update(At,at),g.leftPanoPicture.map.needsRender===!0&&(this.needsRender=!0));{var yt=this.tiling.object.visible;if(at>this.TILED_CUBE_TEXTURE_LEVEL&&this.initAnimationed){var dt=g.panoId,He=this.works.getResolvedObserver(dt);He?isSimilarVector3(this.camera.position,He.position)&&this.locationMotion.ended?(this.tiling.object.visible=!0,this.tiling.panoId!==dt&&this.tiling.cleanup(),this.tiling.panoId=dt,this.tiling.setResource((h=(f=He.images)===null||f===void 0?void 0:f.tiles)!==null&&h!==void 0?h:[],this.enableIOSEDR&&He.images.luminance?He.images.luminance:null),this.tiling.setFetcher(getFetcher(He.work)),this.tiling.setRotation(He.quaternion),this.tiling.setPosition(He.position),this.tiling.update(At,at,e)):this.tiling.object.visible=!1:this.tiling.object.visible=!1}else this.tiling.object.visible=!1;yt!==this.tiling.object.visible&&(this.tiling.object.needsRender=!0)}this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e),!(!ue||ue.length<1)&&this.updateControllerHelper(ue,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 o=this.xrControllerRay.left,s=this.xrControllerRay.right;if(!(!e||e.length===0)){for(var u={buttons:{X:!1,Y:!1,LeftTrigger:!1,LeftPinch:!1,A:!1,B:!1,RightTrigger:!1,RightPinch:!1}},l=0;l<e.length;l++){var d=e[l].handedness,c=e[l].gamepad;switch(d){case"left":c.axes&&(this.emitEvent(c.axes[2]===-1,"LeftAxesLeft",r),this.emitEvent(c.axes[2]===1,"LeftAxesRight",r),this.emitEvent(c.axes[3]===-1,"LeftAxesUp",r),this.emitEvent(c.axes[3]===1,"LeftAxesDown",r)),c!=null&&c.buttons&&(this.emitEvent(c==null?void 0:c.buttons[4].pressed,"X",r),this.emitEvent(c.buttons[5].pressed,"Y",r),this.emitEvent(c==null?void 0:c.buttons[0].pressed,"LeftTrigger",r),this.emitEvent(c==null?void 0:c.buttons[1].pressed,"LeftPinch",r));var f={raycaster:o,axes:{up:c.axes&&c.axes[3]<0?Math.abs(c.axes[3]):0,down:c.axes&&c.axes[3]<0?0:Math.abs(c.axes[3]),left:c.axes&&c.axes[2]<0?Math.abs(c.axes[2]):0,right:c.axes&&c.axes[2]<0?0:Math.abs(c.axes[2])},deltaTime:i};u.buttons.X=c.buttons&&c.buttons[4]?c.buttons[4].pressed:!1,u.buttons.Y=c.buttons&&c.buttons[5]?c==null?void 0:c.buttons[5].pressed:!1,u.buttons.LeftTrigger=c.buttons&&c.buttons[0]?c==null?void 0:c.buttons[0].pressed:!1,u.buttons.LeftPinch=c.buttons&&c.buttons[1]?c==null?void 0:c.buttons[1].pressed:!1,u.left=f;break;case"right":c.axes&&(this.emitEvent(c.axes[2]===-1,"RightAxesLeft",r),this.emitEvent(c.axes[2]===1,"RightAxesRight",r),this.emitEvent(c.axes[3]===-1,"RightAxesUp",r),this.emitEvent(c.axes[3]===1,"RightAxesDown",r)),c.buttons&&(this.emitEvent(c==null?void 0:c.buttons[4].pressed,"A",r),this.emitEvent(c.buttons[5].pressed,"B",r),this.emitEvent(c==null?void 0:c.buttons[0].pressed,"RightTrigger",r),this.emitEvent(c==null?void 0:c.buttons[1].pressed,"RightPinch",r));var h={raycaster:s,axes:{up:c.axes&&c.axes[3]<0?Math.abs(c.axes[3]):0,down:c.axes&&c.axes[3]<0?0:Math.abs(c.axes[3]),left:c.axes&&c.axes[2]<0?Math.abs(c.axes[2]):0,right:c.axes&&c.axes[2]<0?0:Math.abs(c.axes[2])},deltaTime:i};u.right=h,u.buttons.A=c.buttons&&c.buttons[4]?c==null?void 0:c.buttons[4].pressed:!1,u.buttons.B=c.buttons&&c.buttons[5]?c==null?void 0:c.buttons[5].pressed:!1,u.buttons.RightTrigger=c.buttons&&c.buttons[0]?c==null?void 0:c.buttons[0].pressed:!1,u.buttons.RightPinch=c.buttons&&c.buttons[1]?c==null?void 0:c.buttons[1].pressed:!1;break}}this.emit("xr.controller.update",createEvent("xr.controller.update",u))}},t.prototype.emitEvent=function(e,r,i){var o=this.xrControllerRay.left,s=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",createEvent("xr.gesture.buttonDown",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!1,isFirst:!0,controllers:{raycaster:{leftRay:o,rightRay:s}}}));else{var u=i-this.xrControllerState[r].touchStartTime;u>CONTROLLER_EVNET_DELTA_TIME&&this.emit("xr.gesture.press",createEvent("xr.gesture.tap",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!0,controllers:{raycaster:{leftRay:o,rightRay:s}}}))}else if(this.xrControllerState[r].touchStart===!0){this.emit("xr.gesture.buttonUp",createEvent("xr.gesture.buttonUp",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:o,rightRay:s}}}));var u=i-this.xrControllerState[r].touchStartTime;if(u<=CONTROLLER_EVNET_DELTA_TIME){var l=this.emit("xr.gesture.tap",createEvent("xr.gesture.tap",{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:r,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:o,rightRay:s}}}));l||r==="RightTrigger"&&this.checkSelectedPano(this.xrControllerRay.right)}this.xrControllerState[r].touchStart=!1,this.xrControllerState[r].touchStartTime=0}},t}(PanoramaController),Controllers={Floorplan:FloorplanController,Topview:TopviewController,Panorama:PanoramaController,VRPanorama:VRPanoramaController,Model:ModelController,DepthPanorama:DepthPanoramaController,Mapview:MapviewController,XRPanorama:XRPanoramaController},PROXY_CONTROLLER_EVENT_NAMES=["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 initLegacyEvent(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=coordinatesToVector(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 generateDefaultVideoElement(){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 initLights(n){{var t=new THREE__namespace.DirectionalLight(16777215,.5);t.position.copy(new THREE__namespace.Vector3(1,1,1)),n.add(t)}{var t=new THREE__namespace.DirectionalLight(16777215,.3);n.add(t)}{var t=new THREE__namespace.AmbientLight(16777215,.3);n.add(t)}}function parseKeyValue(n){for(var t,e,r={},i=n.split(/(\;|\,)/),o=0,s=i;o<s.length;o++){var u=s[o],l=u.split("="),d=(t=l[0])===null||t===void 0?void 0:t.trim(),c=(e=l[1])===null||e===void 0?void 0:e.trim();d&&c&&(r[d]=c)}return r}function getViewportScale(){for(var n,t=document.getElementsByTagName("meta"),e=0;e<t.length;e++){var r=t[e];if(r.getAttribute("name")==="viewport"){var i=parseKeyValue((n=r.getAttribute("content"))!==null&&n!==void 0?n:""),o=Number(i["initial-scale"]);if(!isNaN(o))return o}}return 1}const textureURL="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAV8AAAA/CAQAAADtPwPkAAAR+0lEQVR4AezYg3LEQACH8d1cbdu23Q5qG9G47z/TN/h6tn2b/H+TUTLc7yjcOXV46OUAnUs6EbUp022ZBXc1NhoZYYd7fjDRvdcHAwrlK2QBVJ4sgoqONmY45RUT23sZ6H42F2hK5CtkMbjhZlDmUUcvq1zyieUVyjbE4I1GBfItwxG56YaUZTQwyh4P6NgJ4YYYvCuQb5kOyI03pORjiqe4Lwpq5pt1vJqfUwKWJVbSMYfppYconG+maNNQOWBZuwHTzicGel75NtFOkxr5apmV8cikcko0DrDQs863AeGl0cE0+1xy573m0/wf0cEKW6H7BWtggiMG8sy3oHRDpJMw4NWb6am/bv9znkqEzjd61t5oo5clTrjhwevO75EJRBKSRt745Z16ZEjcM73sccZplBPm8PyTcxZAkSRdHm/acJ0Z3JZhHB0BxqDHgWFZFmm0ZbCw87twI/zc3e/Cz93vPneXtU/WdQS3oTviXdY/q5PsJKfoGuQjZuO/0in1qsj85cuXrxqeAOJpGqdJOqrUutgVl2Qb0BWqp/RE8AWWVB7t2KrIzY2Wx2fWKl7yfswgxqj8lYummYa3hfwF9MuQRmbfQE4ocPDjtUWQ6Tq1M2w7gC2EcrMGtWS6xlpGKEDDcb1vUQ25zT4lrC2s0dU4gFPppKkbeIYr7NMpqjStuFg5rNU9epGyt8PXyfX4DE1bKLhR/1XPxwJhp5DAV67T9ZPwFdovhBMIGUYoRBN4wim6S3eoXVEHXdLgmwY0x6BQnO4xPJ0Ar5OVxhQF0L9UslRM4yaQQfQImnBegi8vhY2A1k6YLlrj61TwDdNQnIISwiPvpD7TwYQTssZXK47vg8y9Gp2nxRcATkozOEmdCeObSt3IIo+xf/00IDRKAaZ89PBTkHqpkA5LagKeNZKlIhqX8RcQ95GHtdYA62Y6rOg5LLsOSnoyvk4V38hFhytef+V9/3DER1P48W89o1GxE9o5vns2Mk+F7yiftafEN4nhmUv9DKEeyqI0U+l0CQg+B//sZ5+6lOuqKaTgm0LH41RHw/CsLZRk4huiYxrvP2SNr1OSS+Dr1ulBMR+K9SqHa58Oec49VgL3mXHvDr7QfuM7LMNrH1/IS30Moe64SLYBuFVJ+MbnJY7L+GrVQkFcl4ISx/fEll4ZWnz18DpcSzUCX602LqD9svDLzmdaLkP28P1+VsJjsx/4hmh6x/gmm/i6pbrGneCL9iCOg0dQUvF1UwEdVvG19r2uTXxXLz0J37eLjfZoF++tTtPnU/cWp5e8n3An0m/G+U7qjiy4PpHyV16HKx5flCxAV/H9A88nUnZ7l7KN78SBxPcQgzLAepxEScU3l7pZ6fL2+Dot8fXECfj+QRoGYAwlAfBSPrXQXQri0Pd85NJKcVw8XUdt1LZapk7YRhO1RdpmFJwW8ozekYvx2/fjM5Hr5MfQ95HvcY2a/9hoNK4yEntL+dEuGseTdNmxIPqd5v2YRjeaX8pQ8IW2ohuP7+dTN87RMK4aitx8XPsH0r2oBqNRqrv7+gmjjY7uIr6TBxBfL2MlxNRKSVp8S5CTuGgHXxfkFvh69Pq3LD4pkkd2bdRvHaSNC3/l2sQXAccdlIS+lc57qhPJwxPybT7XSxnUrdqnXuHlJHS+mjZfJfUZR9s2FuQR+EQKdSi9Am8UTnsEvlYS+L6TFwW6kl74Vjr6AFHsX89rgg8njRltK0XPOL7NyDL0IurV4VtMwafB1709vu9X4OjWHoP3z1Ii7eaQdG00Lx5n8HXyDSva/dU0Pq2vZnKYxHYMYRo1WY5ov1G7Vh4r3y+kMdgbilxeOrV0aqOFenFl8GGJig7rG0bbPRqiSRpP2AL0w+yon9dHbi43zFetnKcuw9ZLeSa+7kTw/TDfuFu0Z7Vp/uhyHfPkAZ5ufP9wLIfD49E3clR818rR089Lzyy+VRREPneICnYLX9cT8PVKQs36TbQ3i6NcCwYkxEAQ3phN4CjAvC4mFr5vrlKe7AizBKj8cu33s7i9GbeY7BHYujTjjd3Bx54SSyT4m8mxOoYOAGX/DtwvnGE1M+5v5Bgt1hbkJRW9Cxv9X81GL2i5jqaoJ4avBcCsLYp+Ru+VC5sWPpFhXt8/EPvJL2F/alJDEeIjUhcrP5P45rDeATPj+wKl7gBf1fcq+HpVnfHO1vEf//UCHgt/OxfDE3onj5UkfTaThrg3NCGoBUCtZjvgMnwQB0bG5XENeraJ5XEWvtiHkqSVRqN+uQ4lEx2o+69SeY1dC++Wcsj+LCW+H0ZE4KtDWHkGwCtrxstbFqr51e9wbz42E2fpjRQsqEn50PnM4eumO9IbujCi393Hd+3q72TI+p9DPyyfraF+c3rOx0KJyB2z7Fa1yCO8HoHzlDFhPiWD8XoB3aPppRrUQdRp1D8qE9exdgr+Zbpqf8BLfmZ/bMYbh87k58VCSswCjQoLPPw4Jnp4uFi/YQlfKB5eBd/gr6aqB973zbDAF+v5PN+NZEvm+84bSkhxUPE9C9wqbeJ7Hi+gA9Jr5ZM7x9el4mulyK0Bb2xiMTj3/iBtK77Tnii27H/MlCfsjcJY+2oTg2/U4TYWQERE0r+aCouBcx5zEZzEYrqui8JXsQW/X8FLHJ3IVbWXhQV3zAJCjFQst1F25y1arlXwhRR4Bb4rZ3VPy5d+bHEtHIPF27K16ItYuKXM5kHD10M9DKFeSpbqLlOYAlRiC99yCiDmbUf0206jPPO7b/iud71avBkHf+kQP0OrWHBFrhmt75ZyPzbLg5KmWK9oH4Oq1eFZOm0c6n48mdfer46HcLUZU3pGB8R9IDBbJ+N7v1q0J2xhudZ45tcL8PN16vq9WizwtRLwFQtKER+NDypj4QQOdJNY3NC7GEsaGtiSmDsA+CZhyx+hXFHjYrgGGXpZNvDNpn5gWWuiWkUtyEB0UcrO8Y2L9KI9K+cXLmxqruGd6pcKfycj/ij3URVgu6bPUaycN1qXTHD+KoOmjGORnH57q8rh+e9sTHk5r1+7zpEXk36bp7iiXRrBW61e5k/D0fn+EXF/OxYEypFW3ZH1HzPt4Pv5PN2Rd7VJLDZeboGnbpSPwPDcBw5f6AIysadFOR9Hr7vksoFvE91jdbdYvzpYqyIvdQPU87uKL45u3u213CA8qkYPT6H1YgwIfkz7RI5xJdomfjoV4PXjfjgaRkNGhHwG1mNt1oq0y/j+SaZ5pV0LnrlG89Dl1YkmEsc3nKKzMKskJD+fx6NhlFiohdTe5EsZIig5WPgWUYCC9Dx5TG/sA5x15LCBbzXDtx/+uh74VmMZjLDamh8JvhzQtSsoeVTNNXB/Euv96LRR/qjO+By5xTxxJ683/FB00Pj0fZz9F2GPa70Ld2hbbVptWmjWabbGCl/ZAiTsbJa5hQ9OK/eWFE4xva9nG3z1zwCtnFXjYr6c3ykxPn9QiYWEWPhA4uuiDnzBpt4EMcg0QOm28M0gP76hJuELbIdZi4PqaILpJI+RYz4ZV42y+q49wBcxIbyXTmtXgevRWPl3MmjSSJU5vB3J0TA2Uu8mtP+R5/Au4iiF6NrUUiuCieOiJpnJq8gSXzwFLFiLP8X6bV0bYvzt8TXj75eLtKPRauY1RM1HR7GwEHpFbonIWAPwjxpfqJSCyBVUsk/DFOChhC18kyiPHFvwdVGh6XFbmfLx+RRi4jaqYiCnUDO1wc4u4ovo7pfS+XFD32e9GzndwxJiHcbQ/Vz6JrBMDGYyYK5l7YOsfkS2MVePfGkLsNXLGl9hIVbWXAv9fQ5i/j6UFL1RaQffB9qlwn3tS4WxMhaxETCMz6T9ZTqCk5FznoOKL9SEXMMIUwAZW6dNfCEVX61azdxwmIbg4aHdwtcj5KVBeNiqrb2+g5M8hTskSB6exHZ5bMEIF/wCoOT128zvdXziMLbvuDu/Usmh0oG7doMmafKNSmt8hQWUnmzhjJf/RskXCzQL8aYNfLG/QPGLY5KjKtcuNPGsyGytmj0/kPi6qdXwwJCPvOTYI3zTaICCNEh9FGSWM54OX4+A1UI80RV98czWKceJf65ervsleJm164/7ganACHHn+IPz8Nby1ptcnRztRWbipArvp4/gRchodbIFvsBSWPBaW+CHtzWfauFfcmnKRuyr+Fiu1WbzGKtCPWWMHjIgU1/Mgn2B74GKfbkajHwtVIHy3uBbh0Ocj9oplCC+kIJvYuKvI9bbkUUQ2+JaG7AeknwvhLd0YUxx+SZIf4XkGeqHUCNt9N8sQdvYlwtl9H4hMzqI5dHosMIX2taCl2s6LRowaubPyld/IgcvHBJPnKGnHDLh0ArfqzlYtkv5D8++4RsAvPbwTaJzgDcIDzxIRXuEbx4NIsYupjt7gi/6idL3j1AIqPY+OPH5PGO67x/jUS9NvF6hTte7x2kaCvtSZJiMlxjxMSqEtqXr3GPMn/9y4cXUypS/ymPxbIAvmurtYl9o7dqmBV9KdbLOgsik4B3d6xW/lO7w/kfe+yfx7bFuGkwY3/C6sURDj8584rCxJH5QtnYFVrFQVL35HNoQgO0jvt228XVRC4WQPLtANyiEzb1gD/BNoy5kHa5QEnUmiq/uG2fubeXh+kwuNj8IRxAoOqiLIqfTaNw84SfLWsDmqo08k30prHVKbHuYDo7ez6U7EsLX0oJX1ltV2AOg2KfoMPPA/sTx/ZPMqF9YiN11AsHLFrHgaAT3GBvw7hO+U9TH4bX10rgVx7YgMr0p7Pow4tL8XcY3l1kJMfVQmsA3fa/wFQh3JK9eivtV+tCaD4cUjdZvIRI9BfDUDd6PkkbfKhVbOJf/jUpuQcXXlgVNv68ejr4gTflk5AZ71+jR4AvEdPg6PDNpaz6a2AQm2otoWKvVS+LVTyL4OnaE7wSNUjfdpnZb+KbQdcA7Jr5ek0od8MD9dNjiN43t4etk1v0ITfyw6gS+Q4l5XwGwbXli+u/sj6pWGu9XfyYXx75d18+lf6t0tnau/pXKv8+xzorIkltn0l4r2dYCXlO8XDRbu9xw/9g/Zko2FXSFtKPxOxn3q+caluteK5lJsboXwVP/S27cPVz28X3i3/Ll/v8eDVMPDmzwvDbwddMt+NoROhq3yXcC4D7KpmTyA+XnqEzSFQrawDeLrsNemHrEL2+24r7NlENZUMa2vyxkH2DIs628e669ubdsR4VXC7C9u79eIVJtOwgdgO/dOICHGK6jQHaIwdXN4Lwt0LWHr4d6kX8tV+ozqAs+uYCSmO2w+jd4zGNeUYL4nqZxeN5WKVgooSAClmEaYhqhdit89QC7niSbCEM2sdkBuHYxQg9ri5ZjkuhI6DMP+J7cTvEtokEx0aPscyddoFJKpSZqV7G1GTxcpmEthpnw5058c6GfwqpwzGOtGjXSJI3FLYhc+O+jSr9aGhPWQlRshS8AticLX7wnsgbXxt6gsWCpRBa0vRGQM8oB9dhmP3QAwFX4c079dJNq6Qi5xbuyTmpPSJ1Ur4UtF7GoTtmUL3zxaWqMU8P/k3cXSQ1EQRjHGdzdHTa4u7tzBs7CedhykNwF2/5jq56iU11db6Lv2yTj8hs3JoiU9sZZp5/62J5v1z9NjrDHaSbnbFMf52sHrDUVaidDxNG0o9+uLjfosfdb3jT5d5j757riJgst9NIZQ2Pn+ySZll80vjI6Wz/hQJG4vPG0L/H6poQch/dW3vL3B0u8jl0HvVj5PvHCElEF8DUAFikVYTcvmfBdDzQlvvMXSV5lP5zrXj/fJ54zuWaeeuoqkW8AwCIaqeTZKkmYrpPwR2eqN9X72W7EG57vU67OBeuMV8KXLUzv93UTTj42tvaFS++GVsc5JRyLSLJ8nzO555hFBmiSRCqMr4GwrcmGkib5xSvcwmzFK6e8s7DMa2xH4YZdZumSOwsVzFeBWdr37tpIhOpSwXqONNgZq/2KgvBt54znHN1HzlljTO4oVD5fb+prNIJXQNL1ofDKQisbPLJDv3jNSLq9OkYBEIihKIj3v7S1TRQCX5Kdl1ZQlol7LF+E++fwirfiq2sf4cTXxc6hzxffPuLEeqSWrPGWMF58TWr5viyJAP5/4EV4KePiaSE8eNRgjDy8/tyRW+FZjhS+2tlovNJovtJovNJ0uhK6Wo64SDdxEbM//KesjwAAAABJRU5ErkJggg==";var imageSize=[351,63],imageOffset=[20,20],vertices=new Float32Array([-.5,-.5,0,.5,-.5,0,-.5,.5,0,.5,.5,0]),uvs=new Float32Array([0,0,1,0,0,1,1,1]),index=new Uint8Array([0,1,2,1,3,2]),geometry=new THREE__namespace.BufferGeometry;geometry.setAttribute("position",new THREE__namespace.BufferAttribute(vertices,3)),geometry.setAttribute("uv",new THREE__namespace.BufferAttribute(uvs,2)),geometry.setIndex(new THREE__namespace.BufferAttribute(index,1));var material=new THREE__namespace.MeshBasicMaterial({transparent:!0,depthTest:!1,depthWrite:!1,stencilWrite:!1,fog:!1}),mesh=new THREE__namespace.Mesh(geometry,material);mesh.matrixAutoUpdate=!1;var scene=new THREE__namespace.Scene;scene.add(mesh),scene.matrixAutoUpdate=!1;var camera=new THREE__namespace.OrthographicCamera(-.5,.5,.5,-.5,.1,1);camera.position.set(0,0,.5),camera.lookAt(0,0,0),camera.updateMatrixWorld(!0),camera.matrixAutoUpdate=!1;var prevViewport=new THREE__namespace.Vector4,prevScissor=new THREE__namespace.Vector4;function renderPoweredByRealsee(n){if(material.map){var r=n.getViewport(prevViewport),i=n.getScissor(prevScissor),o=n.getScissorTest(),s=n.autoClear,u=i.x+imageOffset[0]/3,l=i.y+imageOffset[1]/3,d=imageSize[0]/3,c=imageSize[1]/3;n.setViewport(u,l,d,c),n.setScissor(u,l,d,c),n.setScissorTest(!0),n.autoClear=!1,n.render(scene,camera),n.setViewport(r),n.setScissor(i),n.setScissorTest(o),n.autoClear=s}else{var t=new THREE__namespace.Texture,e=new Image;e.onload=function(){t.image=e,t.wrapS=THREE__namespace.ClampToEdgeWrapping,t.wrapT=THREE__namespace.ClampToEdgeWrapping,t.minFilter=THREE__namespace.LinearFilter,t.needsUpdate=!0,t.generateMipmaps=!1,material.needsUpdate=!0,e.onload=noop$1},e.src=textureURL,material.map=t}}var DEFAULT_MODE_CHANGE_DURATION=800,DEFAULT_REQUEST_PROXY=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/")},BUILTIN_COORDINATESSYSTEMTRANSFORMERS=[{name:"Z",transformToUpAxisZ:function(){return new THREE__namespace.Matrix4}},{name:"Y",transformToUpAxisZ:function(){return new THREE__namespace.Matrix4().makeRotationAxis(new THREE__namespace.Vector3(1,0,0),+Math.PI/2)}},{name:"-Y",transformToUpAxisZ:function(){return new THREE__namespace.Matrix4().makeRotationAxis(new THREE__namespace.Vector3(1,0,0),-Math.PI/2)}},{name:"WGS84",transformToEarthCentered:function(){return new THREE__namespace.Matrix4}},{name:"GCJ02",transformToEarthCentered:function(){return new THREE__namespace.Matrix4}},{name:"BD09",transformToEarthCentered:function(){return new THREE__namespace.Matrix4}}],sharedVector2=new THREE__namespace.Vector2,sharedFrustum=new THREE__namespace.Frustum,sharedProjScreenMatrix=new THREE__namespace.Matrix4,clockForMixer=new WeakMap,worksMap=new WeakMap,emptyWorks=createWorks([]),Five=function(n){__extends(t,n);function t(e){e===void 0&&(e={});var r,i,o,s,u,l,d,c,f,h,v=n.call(this)||this;v.ident=createUuid(),__FIVE_DEBUG__.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=__assign({},(i=e.imageOptions)!==null&&i!==void 0?i:{}),v.textureOptions=__assign({},(o=e.textureOptions)!==null&&o!==void 0?o:{}),v.poweredByRealsee=(s=e.poweredByRealsee)!==null&&s!==void 0?s:!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=__spreadArray([],(u=e.coordinatesSystemTransformers)!==null&&u!==void 0?u:[],!0);for(var A=function(B){var O=m.coordinatesSystemTransformers.find(function(F){return F.name===B.name});O||m.coordinatesSystemTransformers.push(__assign({},B))},m=this,y=0,p=BUILTIN_COORDINATESSYSTEMTRANSFORMERS;y<p.length;y++){var g=p[y];A(g)}if(v.fps={testCount:0,testTime:now()},v.info=null,v.modeChangeDuration=(l=e.modeChangeDuration)!==null&&l!==void 0?l:DEFAULT_MODE_CHANGE_DURATION,v.enableWheel=(d=e.enableWheel)!==null&&d!==void 0?d:!0,typeof window<"u")if(e.renderer)e.renderer instanceof InternalWebGLRenderer&&v.throwError(new Error("cannot render a internal renderer")),v.renderer=e.renderer;else try{v.renderer=new InternalWebGLRenderer({preserveDrawingBuffer:e.preserveDrawingBuffer,backgroundColor:e.backgroundColor,backgroundAlpha:e.backgroundAlpha,antialias:e.antialias,webgl2:e==null?void 0:e.webgl2});var b=getViewportScale();v.renderer.setPixelRatio(b===1?window.devicePixelRatio:1),v.renderer.setSize(512,512)}catch(B){B instanceof Error&&v.throwError(B)}v.getPixelsRenderTarget=new THREE__namespace.WebGLRenderTarget(1,1,{encoding:(f=(c=v.renderer)===null||c===void 0?void 0:c.outputEncoding)!==null&&f!==void 0?f:THREE__namespace.sRGBEncoding}),v.scissor=Object.assign({left:0,bottom:0,width:1,height:1},e.scissor),v.camera=new Camera(90),v.scene=new Scene,v.xrCustomObjectsScene=new THREE__namespace.Scene,v.scene.add(v.xrCustomObjectsScene),v.scene.matrixAutoUpdate=!1,v.lastLoadWorkTask=Promise.resolve(),v.requestProxy=(h=e.requestProxy)!==null&&h!==void 0?h:DEFAULT_REQUEST_PROXY,v.networkSubscribe=new NetworkSubscribe,v.networkSubscribe.on("network",function(B,O,F,H){var k;v.emit("network.resource",createEvent("network.resource",{source:B,requestType:O,requestState:F,detail:H})),(k=v.analysis)===null||k===void 0||k.network(v.works,B,O,F,H)}),v.boundingMesh=generateBoundingMesh(new THREE__namespace.Box3(new THREE__namespace.Vector3(-.5,-.5,-.5),new THREE__namespace.Vector3(.5,.5,.5))),v.boundingMesh.name="bounding",v.scene.add(v.boundingMesh),v.models=createModels(),v.models.push(new Model),v.lastModels=createModels(),v.readyCallbacks=[],v.syncingState=!1,v.modelGroup=new THREE__namespace.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 THREE__namespace.Group,v.helperGroup.name="helper",v.helperGroup.matrixAutoUpdate=!1,v.scene.add(v.helperGroup),v.videoTexture=new THREE__namespace.VideoTexture(e.videoInstance||generateDefaultVideoElement()),initLights(v.scene),v.copyEffect=new Effect(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=AnimationFrameLoop.shared.add(function(B,O){for(var F=[],H=2;H<arguments.length;H++)F[H-2]=arguments[H];v.updateTime.apply(v,__spreadArray([B,O],F,!1))},!1,0,10));var T=function(){typeof document<"u"&&document.fullscreenElement===null&&v.currentMode==="VRPanorama"&&v.controller.emit("vr.requestExit",createEvent("vr.requestExit",{}))};if(typeof document<"u"&&document.addEventListener("fullscreenchange",T,!1),v.removeEventListeners=function(){typeof document<"u"&&document.removeEventListener("fullscreenchange",T,!1)},v.plugins={},e.plugins&&e.plugins.length)for(var _=0,w=e.plugins;_<w.length;_++){var x=w[_];if(typeof x=="function")x(v);else if(Array.isArray(x)){var M=x[0],R=x[1],I=x[2];if(typeof M=="function"){var S=M(v,I);typeof R=="string"&&(v.plugins[R]?v.throwError(new Error("plugin name ".concat(R," is exists."))):v.plugins[R]=S)}}}return v.gpuPickingRenderTarget=new THREE__namespace.WebGLRenderTarget(1,1),v.meshReplaceMaterialMap=new Map,v.meshOriginMaterialMap=new Map,initLegacyEvent(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 draco.decoderPath},set:function(e){draco.setDecoderPath(e)},enumerable:!1,configurable:!0}),Object.defineProperty(t,"ktx2Path",{get:function(){return ktx2.transcoderPath},set:function(e){ktx2.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,o,s){var u=this;if(o===void 0&&(o=1),s===void 0&&(s=new THREE__namespace.Vector3(0,0,0)),!this.renderer)throw new Error("renderer is not initialized.");this.models.setMaterial({constantColor:s}),this.scene.traverse(function(f){if(!(!(f instanceof THREE__namespace.Mesh)||f instanceof PBMMesh)){var h=Object.keys(i).filter(function(A){return A===f.uuid})[0];if(h)if(u.meshOriginMaterialMap.set(h,f.material),u.meshReplaceMaterialMap.get(h))f.material=u.meshReplaceMaterialMap.get(h);else{var v=new THREE__namespace.ShaderMaterial({uniforms:{color:{value:i[h]}},vertexShader:`
|
|
2039
2039
|
void main() {
|
|
2040
2040
|
vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );
|
|
2041
2041
|
gl_Position = projectionMatrix * mvPosition;
|
|
@@ -2045,4 +2045,4 @@ void main() {
|
|
|
2045
2045
|
void main() {
|
|
2046
2046
|
gl_FragColor = vec4( color, 1.0 );
|
|
2047
2047
|
}
|
|
2048
|
-
`});v.depthTest=f.material.depthTest,v.side=f.material.side,u.meshReplaceMaterialMap.set(h,v),f.material=v}}});var l=this.renderer.getSize(new THREE__namespace.Vector2);this.camera.setViewOffset(l.width,l.height,e*o,r*o,1,1),this.renderer.setRenderTarget(this.gpuPickingRenderTarget),this.render();var d=new Uint8Array(4);this.renderer.readRenderTargetPixels(this.gpuPickingRenderTarget,0,0,1,1,d),this.renderer.setRenderTarget(null),this.camera.clearViewOffset(),this.scene.traverse(function(f){!(f instanceof THREE__namespace.Mesh)||f instanceof PBMMesh||u.meshOriginMaterialMap.get(f.uuid)&&(f.material=u.meshOriginMaterialMap.get(f.uuid))}),this.models.setMaterial({constantColor:null});var c=Object.keys(i).filter(function(f){return i[f].equals(new THREE__namespace.Color().setRGB(d[0]/255,d[1]/255,d[2]/255))})[0];return c||!1},t.prototype.dispose=function(){var e,r;if(this.destroyed!==!0){delete __FIVE_DEBUG__.instances[this.ident],this.emit("dispose"),this.destroyed=!0,this.pause(),this.stopAnimationLoop&&(this.stopAnimationLoop(),delete this.stopAnimationLoop),(e=this.renderer)===null||e===void 0||e.setAnimationLoop(null),this.off(),this.networkSubscribe.off(),this.controller&&(this.controller.destroy(),this.controller=void 0);var i=this.getElement();i&&i.parentNode&&i.parentNode.removeChild(i);var o=this.models.getMaterial();o&&(o.pano0&&o.pano0.map.dispose(),o.pano1&&o.pano1.map!==((r=o.pano0)===null||r===void 0?void 0:r.map)&&o.pano1.map.dispose());for(var s=0,u=this.models;s<u.length;s++){var l=u[s];l.dispose()}this.models.length=0,this.models.setMaterial({pano0:null,pano1:null}),this.meshReplaceMaterialMap.forEach(function(d){d.dispose()}),this.meshOriginMaterialMap.forEach(function(d){d.dispose()}),this.renderer instanceof InternalWebGLRenderer&&this.renderer.forceContextLoss&&this.renderer.forceContextLoss()}},t.prototype.setScissor=function(e){Object.assign(this.scissor,e),this.controller&&this.controller.updateRenderSize&&this.controller.updateRenderSize()},Object.defineProperty(t.prototype,"helperVisible",{get:function(){return this.helperGroup.visible},set:function(e){this.helperGroup.visible!==e&&(this.helperGroup.visible=e,this.emit("helpers.visible",createEvent("helpers.visible",{object:this.helperGroup})),this.needsRender=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"enableIOSEDR",{get:function(){return this._enableIOSEDR},set:function(e){this._enableIOSEDR!==e&&(this._enableIOSEDR=e,this.currentMode&&this.currentMode==="Panorama"&&this.changeMode(this.currentMode,this.getCurrentState(),0,!1,!0))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"postProcessingType",{get:function(){return this.currentMode==="Panorama"&&this.enableIOSEDR?"luminance":this.currentMode==="Mapview"&&this.enableEDL?"edl":this.currentMode==="Mapview"&&this.enableHQ?"hq":null},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"enableEDL",{get:function(){return this.models.getMaterial().useEDL},set:function(e){var r,i,o,s;if(e===!0&&this.currentMode!==t.Mode.Mapview)throw new Error("只支持Mapview下开启EDL");if(this.models.setMaterial({useEDL:e}),this.boundingMesh.visible=!e,e){if(!this.screenBuffers){var u=this.getDrawingBufferSize(sharedVector2);this.screenBuffers=[new THREE__namespace.WebGLRenderTarget(u.x,u.y,{encoding:(i=(r=this.renderer)===null||r===void 0?void 0:r.outputEncoding)!==null&&i!==void 0?i:THREE__namespace.sRGBEncoding,minFilter:THREE__namespace.NearestFilter,magFilter:THREE__namespace.NearestFilter,format:THREE__namespace.RGBAFormat,type:THREE__namespace.FloatType}),new THREE__namespace.WebGLRenderTarget(u.x,u.y,{encoding:(s=(o=this.renderer)===null||o===void 0?void 0:o.outputEncoding)!==null&&s!==void 0?s:THREE__namespace.sRGBEncoding,minFilter:THREE__namespace.LinearMipMapLinearFilter,magFilter:THREE__namespace.LinearMipMapLinearFilter})]}}else this.screenBuffers&&(this.screenBuffers.forEach(function(l){l.dispose()}),delete this.screenBuffers);this.needsRender=!0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"enableHQ",{get:function(){return this.models.getMaterial().useHQWeight||this.models.getMaterial().useHQDepth||!1},set:function(e){var r,i;if(e===!0&&this.currentMode!==t.Mode.Mapview)throw new Error("只支持Mapview下开启HQ");if(e===!0?this.models.setMaterial({useHQDepth:!0,useHQWeight:!1,pointShape:"CIRCLE"}):this.models.setMaterial({useHQDepth:!1,useHQWeight:!1}),this.boundingMesh.visible=!e,e){if(!this.screenBuffers){var o=this.getDrawingBufferSize(sharedVector2),s=new THREE__namespace.WebGLRenderTarget(o.x,o.y,{minFilter:THREE__namespace.NearestFilter,magFilter:THREE__namespace.NearestFilter,format:THREE__namespace.RGBAFormat,type:THREE__namespace.FloatType,depthTexture:new THREE__namespace.DepthTexture(o.x,o.y,THREE__namespace.UnsignedIntType)});s.depthTexture.format=THREE__namespace.DepthFormat,s.depthBuffer=!0;var u=new THREE__namespace.WebGLRenderTarget(o.x,o.y,{encoding:(i=(r=this.renderer)===null||r===void 0?void 0:r.outputEncoding)!==null&&i!==void 0?i:THREE__namespace.sRGBEncoding,minFilter:THREE__namespace.NearestFilter,magFilter:THREE__namespace.NearestFilter,format:THREE__namespace.RGBAFormat,type:THREE__namespace.FloatType,depthTexture:s.depthTexture});this.screenBuffers=[s,u]}}else this.screenBuffers&&(this.screenBuffers.forEach(function(l){l.dispose()}),delete this.screenBuffers);this.needsRender=!0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"enablePostProcessing",{get:function(){return this.screenBuffers!==void 0},set:function(e){var r,i,o,s;if(e){if(!this.screenBuffers){var u=this.getDrawingBufferSize(sharedVector2);this.screenBuffers=[new THREE__namespace.WebGLRenderTarget(u.x,u.y,{encoding:(i=(r=this.renderer)===null||r===void 0?void 0:r.outputEncoding)!==null&&i!==void 0?i:THREE__namespace.sRGBEncoding}),new THREE__namespace.WebGLRenderTarget(u.x,u.y,{encoding:(s=(o=this.renderer)===null||o===void 0?void 0:o.outputEncoding)!==null&&s!==void 0?s:THREE__namespace.sRGBEncoding})]}}else this.screenBuffers&&(this.screenBuffers.forEach(function(l){l.dispose()}),delete this.screenBuffers);this.needsRender=!0},enumerable:!1,configurable:!0}),t.prototype.updateConfiguration=function(e){var r=!1;e.panorama&&(Object.assign(this.controllerInits.Panorama,e.panorama),this.currentMode==="Panorama"&&(r=!0)),e.model&&(Object.assign(this.controllerInits.Model,e.model),this.currentMode==="Model"&&(r=!0)),e.floorplan&&(Object.assign(this.controllerInits.Floorplan,e.floorplan),this.currentMode==="Floorplan"&&(r=!0)),e.topview&&(Object.assign(this.controllerInits.Topview,e.topview),this.currentMode==="Topview"&&(r=!0)),e.mapview&&(Object.assign(this.controllerInits.Mapview,e.topview),this.currentMode==="Mapview"&&(r=!0)),e.depthPanorama&&(Object.assign(this.controllerInits.DepthPanorama,e.depthPanorama),this.currentMode==="DepthPanorama"&&(r=!0)),e.vrPanorama&&(Object.assign(this.controllerInits.VRPanorama,e.vrPanorama),this.currentMode==="VRPanorama"&&(r=!0)),e.imageOptions&&(Object.assign(this.imageOptions,e.imageOptions),(this.currentMode==="Panorama"||this.currentMode==="DepthPanorama"||this.currentMode==="VRPanorama")&&(r=!0)),r&&this.controller&&this.currentMode&&this.changeMode(this.currentMode,this.getCurrentState(),0,!1,!0),e.textureOptions&&Object.assign(this.textureOptions,e.textureOptions)},t.prototype.appendTo=function(e,r){if(r===void 0&&(r={}),!!this.renderer){if(!(this.renderer instanceof InternalWebGLRenderer)){this.throwError(new Error("cannot call appendTo method when render a external renderer"));return}var i=this.getElement();if(i){e.appendChild(i),this.refresh(r);var o=window.getComputedStyle(e).position;o!=="relative"&&o!=="absolute"&&o!=="fixed"&&o!=="sticky"&&(e.style.position="relative")}}},t.prototype.refresh=function(e,r){if(e===void 0&&(e={}),!!this.renderer){var i=this.getElement();if(i){var o=i.parentNode;if(o&&o.nodeName){var s=e.width,u=s===void 0?o.offsetWidth:s,l=e.height,d=l===void 0?o.offsetHeight:l;this.renderer instanceof InternalWebGLRenderer&&(r&&this.renderer.setPixelRatio(r),this.renderer.setSize(u,d))}this.controller&&this.controller.updateRenderSize&&this.controller.updateRenderSize(),this.needsRender=!0}}},t.prototype.addExtraElement=function(e){var r=this;return this.extraElements.indexOf(e)===-1&&(this.extraElements.push(e),this.controller&&this.controller.bindExtraElement(e)),function(){return r.removeExtraElement(e)}},t.prototype.removeExtraElement=function(e){var r=this.extraElements.indexOf(e);r!==-1&&(this.extraElements.splice(r,1),this.controller&&this.controller.unbindExtraElement(e))},t.prototype.getPose=function(){var e=this.camera.copyPose(),r=e.longitude,i=e.latitude,o=e.fov,s=e.offset,u=e.distance;return{longitude:r,latitude:i,fov:o,offset:s.clone(),distance:u}},t.prototype.getSize=function(e){if(!this.renderer)throw new Error("renderer is not initialized");return this.renderer.getSize(e),e.x*=this.scissor.width,e.y*=this.scissor.height,e},t.prototype.getDrawingBufferSize=function(e){if(!this.renderer)throw new Error("renderer is not initialized");return this.renderer.getDrawingBufferSize(e),e.x*=this.scissor.width,e.y*=this.scissor.height,e},t.prototype.updateCamera=function(e,r,i){return i===void 0&&(i=!0),this.controller?this.controller.updateCamera(e,r,i):Promise.reject(new Error("controller is not initialized."))},t.prototype.updateCameraWithKeyframes=function(e,r,i){return i===void 0&&(i=!0),this.controller?this.controller.updateCameraWithKeyframes(e,r,i):Promise.reject(new Error("controller is not initialized."))},t.prototype.getLongitudeAndLatitude=function(){var e=this.getPose(),r=e.longitude,i=e.latitude;return{longitude:r,latitude:i}},t.prototype.getOffset=function(){return this.getPose().offset},t.prototype.getCameraLocal=function(){if(this.pano.workCode&&this.controller&&this.works){var e=this.works.getResolvedObserver(this.pano);if(e){var r=new THREE__namespace.Object3D;return r.position.copy(e.position),r.quaternion.copy(e.quaternion),r.scale.set(1,1,1),r.matrix.compose(r.position,r.quaternion,r.scale),r.matrixAutoUpdate=!1,cameraWorldToLocal(this.camera,r)}}return null},Object.defineProperty(t.prototype,"works",{get:function(){var e=worksMap.get(this);if(!e)return emptyWorks;for(var r=0,i=e;r<i.length;r++){var o=i[r];if(!workRawMapping.has(o))return emptyWorks}return e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"work",{get:function(){return this.works[0]},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"model",{get:function(){return this.models[0]},enumerable:!1,configurable:!0}),t.prototype.load=function(e,r,i,o){var s=this;if(o===void 0&&(o=!0),!this.renderer)throw new Error("renderer is not initialized");var u=this.lastLoadWorkTask.then(function(){return isPromise(e)?e.then(function(l){return s.load_(l,r,i,o)}):s.load_(e,r,i,o)});return this.lastLoadWorkTask=u.catch(function(l){s.throwError(l)}),u},t.prototype.load_=function(e,r,i,o){var s=this,u,l,d,c,f,h;o===void 0&&(o=!0);var v=[];if(Array.isArray(e))for(var A=0,m=e;A<m.length;A++){var y=m[A];typeof y!="string"&&"work"in y?v.push(parseWork(y.work,y)):v.push(parseWork(y))}else v.push(parseWork(e));for(var p=createWorks(v),g=function(D){var K=b,z=new Fetcher({allowHosts:D.allowHosts,get requestProxy(){return K.requestProxy},get networkSubscribe(){return K.networkSubscribe}});registerFetcher(D,z)},b=this,T=0,_=p;T<_.length;T++){var w=_[T];g(w)}var x=this.works;r===void 0&&(r=x.length!==0?"inherit":"initial");var M=p.initial,R=M.work.observers[0],I=R?{workCode:R.work.workCode,panoIndex:R.panoIndex}:{workCode:M.work.workCode,panoIndex:0},S=(u=M.mode)!==null&&u!==void 0?u:R?"Panorama":"Mapview",B={};if(r==="inherit"){S=this.currentMode;var F=p.resolvedObservers[this.panoIndex];F?I={workCode:F.work.workCode,panoIndex:F.panoIndex}:typeof p.initial.panoIndex=="number"?I={workCode:p.initial.work.workCode,panoIndex:p.initial.panoIndex}:(S==="Panorama"||S==="DepthPanorama"||S==="VRPanorama"||S==="XRPanorama")&&(S="Mapview"),B={longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,distance:this.camera.pose.distance,offset:this.camera.pose.offset.clone()}}else if(r==="initial")typeof M.panoIndex=="number"&&(I={workCode:M.work.workCode,panoIndex:M.panoIndex}),M.mode&&(S=M.mode),B={longitude:M.longitude,latitude:M.latitude,fov:M.fov,distance:M.distance,offset:(l=M.offset)===null||l===void 0?void 0:l.clone()};else{if(S=(d=r.mode)!==null&&d!==void 0?d:this.currentMode,typeof r.panoIndex=="number"){var F=p.getResolvedObserver({workCode:(f=(c=r.workCode)!==null&&c!==void 0?c:M.work.workCode)!==null&&f!==void 0?f:"",panoIndex:r.panoIndex});F&&(I={workCode:F.work.workCode,panoIndex:F.panoIndex})}B={longitude:r.longitude,latitude:r.latitude,fov:r.fov,distance:r.distance,offset:r.offset}}var O=__assign(__assign(__assign({},I),{mode:S}),B);this.emit("works.request",createEvent("works.request",{input:e,works:p,state:O,userAction:o}));var H=function(){s.pano=I;var D=s.controller?i??s.modeChangeDuration:0,K=__assign(__assign({initial:{state:O,currentState:s.getCurrentState(),duration:D,userAction:o}},s.commonParams()),s.controllerInits[S]);if(s.controller&&s.currentMode===S)s.controller.updateWork(p,O,D,o)===!1&&(s.controller.destroy(),s.controller=s.applyController(S,K));else{var z=s.currentMode,G=Controllers[S].initAnimationEndState(K);if(s.controller)s.controller.destroy();else{var W=Controllers[S].initAnimationEndState(K);s.camera.setFromPose(W),s.modelGroup.visible=!0,s.emit("camera.update",createEvent("camera.update",{state:s.getCurrentState(),userAction:o}))}s.controller=s.applyController(S,K);var Q=createEvent("mode.change",{prevMode:z,mode:S,state:G,userAction:o});s.emit("mode.change",Q)}};if(worksMap.set(this,p),!this.controller){var k=__assign(__assign({initial:{state:O,currentState:this.getCurrentState(),duration:0,userAction:o}},this.commonParams()),this.controllerInits[S]),N=Controllers[S].initAnimationEndState(k);this.camera.setFromPose(N),this.emit("camera.update",createEvent("camera.update",{state:this.getCurrentState(),userAction:o}))}if(S===t.Mode.Floorplan||S===t.Mode.Topview||S===t.Mode.Mapview||S===t.Mode.Model)this.loadModel(p).then(function(){s.needsRender=!0,H(),s.emit("camera.update",createEvent("camera.update",{state:s.getCurrentState(),userAction:o}))});else{if(!this.controller){var q=new THREE__namespace.Vector3,V=p.getResolvedObserver(I);V&&q.copy(V.position),this.camera.setFromPose({fov:B.fov,longitude:B.longitude,latitude:B.latitude,distance:B.distance,offset:(h=B.offset)!==null&&h!==void 0?h:q}),this.needsRender=!0}H(),this.controller.once("pano.moveTo",function(){s.needsRender=!0,s.emit("camera.update",createEvent("camera.update",{state:s.getCurrentState(),userAction:o})),s.loadModel(p)})}return this.emit("works.load",createEvent("works.load",{input:e,state:this.getCurrentState(),userAction:o,works:p})),this.ready().then(function(){var D;s.emit("works.ready",createEvent("works.ready",{input:e,state:s.getCurrentState(),userAction:o,works:p})),(D=s.analysis)===null||D===void 0||D.work(p)})},t.prototype.changeMode=function(e,r,i,o,s){var u=this;return r===void 0&&(r={}),i===void 0&&(i=this.modeChangeDuration),o===void 0&&(o=!0),s===void 0&&(s=!1),new Promise(function(l,d){var c,f,h;if(!u.renderer)throw new Error("renderer is not initialized.");r=__assign({},r);var v=typeof r.panoIndex=="number"?{workCode:(h=(c=r.workCode)!==null&&c!==void 0?c:(f=u.work)===null||f===void 0?void 0:f.workCode)!==null&&h!==void 0?h:"",panoIndex:r.panoIndex}:u.pano;if(!t.Mode.hasOwnProperty(e)){var A=new Error('mode "'.concat(e,'" is not existed'));u.throwError(A),d(A);return}if((e===t.Mode.Floorplan||e===t.Mode.Topview||e===t.Mode.Mapview||e===t.Mode.Model)&&!u.models.loaded){var A=new Error("model is not ready.");u.throwError(A),d(A);return}if((e===t.Mode.Panorama||e===t.Mode.VRPanorama||e===t.Mode.XRPanorama)&&!u.works.getResolvedObserver(v)){var A=new Error("PanoId ".concat(panoStringify(v)," not existed."));u.throwError(A),d(A);return}var m=u.controller,y=u.currentMode,p=function(){if(u.controller&&u.controller.stopMomentumMovement(),u.controller&&s===!1&&y===e)e===t.Mode.Panorama||e===t.Mode.DepthPanorama||e===t.Mode.Model||e===t.Mode.VRPanorama||e===t.Mode.XRPanorama?panoEqual(u.pano,v)&&"moveToPano"in u.controller&&typeof u.controller.moveToPano=="function"?u.controller.moveToPano(v,__assign({duration:i},r),o):u.controller.updateCamera(r,i,o).catch(noop$1):(panoEqual(u.pano,v)||(u.pano=v),u.controller.updateCamera(r,i,o).catch(noop$1));else{var b=__assign(__assign({},r),v),T=__assign(__assign({initial:{state:b,currentState:u.getCurrentState(),duration:i,userAction:o}},u.commonParams()),u.controllerInits[e]),_=Controllers[e].initAnimationEndState(T),w=createEvent("mode.change.request",{prevMode:u.currentMode,mode:e,state:_,userAction:o});if(u.emit("mode.change.request",w),!w.defaultPrevented){m&&m.destroy(),u.controller=u.applyController(e,T);var x=createEvent("mode.change",{prevMode:u.currentMode,mode:e,state:_,userAction:o});u.emit("mode.change",x)}}l()};if(e===t.Mode.VRPanorama)u.requestFullscreen(),requestDeviceOrientationPermission().then(function(){return p()}).catch(function(b){b instanceof Error&&(u.exitFullscreen(),u.throwError(b),d(b))});else if(e===t.Mode.XRPanorama){var g=AnimationFrameLoop.shared.getContext();g?g.end():requestXRSessionPermission().then(function(b){AnimationFrameLoop.shared.setContext(b),p()}).catch(function(b){b instanceof Error&&(u.throwError(b),d(b))})}else p()})},t.prototype.getPixels=function(e,r,i,o,s){if(s===void 0&&(s=1),!this.renderer)throw new Error("renderer is not initialized.");var u=this.getPixelsRenderTarget,l=this.renderer.getSize(new THREE__namespace.Vector2);e=clamp(e,Math.floor(i/2),Math.floor(l.x-i)),r=clamp(r,Math.floor(o/2),Math.floor(l.y-o)),u.setSize(i*s,o*s),this.renderer.setRenderTarget(u),this.camera.setViewOffset(l.width,l.height,e,l.height-r-o,i,o),this.controller?this.controller.render():this.renderer.render(this.scene,this.camera);var d=new Uint8Array(i*s*o*s*4);return this.renderer.readRenderTargetPixels(u,0,0,i*s,o*s,d),this.renderer.setRenderTarget(null),this.camera.clearViewOffset(),d},t.prototype.getElement=function(){var e;return(e=this.renderer)===null||e===void 0?void 0:e.domElement},Object.defineProperty(t.prototype,"observers",{get:function(){return this.works.resolvedObservers},enumerable:!1,configurable:!0}),t.prototype.render=function(e,r){var i=this;if(r===void 0&&(r=!1),!this.renderer)return null;if(r){var o=this.renderer.getSize(sharedVector2);this.scene.traverseVisible(function(u){u.setResolution&&u.setResolution(o.x,o.y)})}if(this.controller&&this.screenBuffers&&this.renderer.getRenderTarget()===null){var s=this.getDrawingBufferSize(sharedVector2);return this.screenBuffers.forEach(function(u){u.setSize(s.x,s.y)}),this.renderer.setRenderTarget(this.screenBuffers[0]),this.controller.render(),this.info={memory:__assign({},this.controller.renderer.info.memory),render:__assign({},this.controller.renderer.info.render)},this.currentMode!=="VRPanorama"&&this.currentMode!=="XRPanorama"&&this.poweredByRealsee&&renderPoweredByRealsee(this.renderer),e&&AnimationFrameLoop.shared.add(e,!0),this.screenBuffers[0]}else return this.aroundScissor(function(){i.renderer&&(i.controller?(i.controller.render(),i.info={memory:__assign({},i.controller.renderer.info.memory),render:__assign({},i.controller.renderer.info.render)}):(i.renderer.render(i.scene,i.camera),i.info={memory:__assign({},i.renderer.info.memory),render:__assign({},i.renderer.info.render)}),i.poweredByRealsee&&i.currentMode!=="VRPanorama"&&i.currentMode!=="XRPanorama"&&renderPoweredByRealsee(i.renderer)),e&&AnimationFrameLoop.shared.add(e,!0)}),null},t.prototype.updateTime=function(e,r){for(var i,o=this,s,u,l=[],d=2;d<arguments.length;d++)l[d-2]=arguments[d];if(!this.destroyed){if(this.works.update(),this.syncingState=this.syncState(e,r),this.controller&&(i=this.controller).updateTime.apply(i,__spreadArray([e,r],l,!1)),this.renderer){var c=this.getSize(sharedVector2),f=this.renderer.getPixelRatio();this.camera.screenHeight=c.height,this.camera.pixelRatio=f,this.camera.aspect=c.width/c.height}if(this.camera.updateTime(e,r),this.renderer){ktx2.detectSupport(this.renderer);var h=this.models.loaded,v=this.models.refined;if(this.models.update(this.renderer,this.camera,this.currentMode),h===!1&&this.models.loaded===!0&&this.emit("models.load",createEvent("models.load",{models:this.models})),v===!1&&this.models.refined===!0&&this.emit("models.refined",createEvent("models.refined",{models:this.models})),this.models.loaded){for(var A=0,m=this.models;A<m.length;A++){var y=m[A];y.parent!==this.modelGroup&&(this.modelGroup.add(y),this.needsRender=!0)}if(this.lastModels.length>0){for(var p=0,g=this.lastModels;p<g.length;p++){var y=g[p];this.modelGroup.remove(y),y.dispose(),this.needsRender=!0}this.lastModels.length=0}}this.lastModels.setMaterial(this.models.getMaterial()),this.lastModels.materialVersion=this.models.materialVersion,this.lastModels.update(this.renderer,this.camera,this.currentMode)}this.syncingState=!1;var b=new THREE__namespace.Vector2(512,512),T=new THREE__namespace.Vector2(512,512);this.renderer&&(this.renderer.getSize(b),b.x*=this.scissor.width,b.y*=this.scissor.height,this.renderer.getDrawingBufferSize(T),T.x*=this.scissor.width,T.y*=this.scissor.height);{for(var _=new THREE__namespace.Box3,w=new THREE__namespace.Box3,x=new THREE__namespace.Vector3(4,4,4),M=0,R=this.works.resolvedObservers;M<R.length;M++){var I=R[M];w.setFromCenterAndSize(I.position,x),_.union(w)}_.union(this.models.bounding),_.getCenter(this.boundingMesh.position),_.getSize(this.boundingMesh.scale),this.boundingMesh.boundingBox.copy(_);var S=(s=this.models.getMaterial())!==null&&s!==void 0?s:{},B=1-((u=S.modelAlpha)!==null&&u!==void 0?u:0);S.opacity=clamp(B*4-3,0,1),S.clippers=null,S.shownFloorIndex=-2,this.boundingMesh.setMaterial(S),this.boundingMesh.needsRender=!1}var F=createEvent("render.prepare",{needsRender:!0,info:null});if(this.emit("render.prepare",F),!F.defaultPrevented){var O=[];sharedProjScreenMatrix.multiplyMatrices(this.camera.projectionMatrix,this.camera.matrixWorldInverse),sharedFrustum.setFromProjectionMatrix(sharedProjScreenMatrix);for(var H=0,k=this.scene.children;H<k.length;H++){var N=k[H];N!==this.modelGroup&&N!==this.boundingMesh&&N instanceof THREE__namespace.Object3D&&N.traverseVisible(function(Q){if(Q.setResolution&&Q.setResolution(b.x,b.y),Q.setTime&&Q.setTime(e),Q.mixer instanceof THREE__namespace.AnimationMixer){var X=clockForMixer.get(Q.mixer);X||(X=new THREE__namespace.Clock,clockForMixer.set(Q.mixer,X)),Q.mixer.update(X.getDelta())}(Q instanceof THREE__namespace.Mesh||Q instanceof THREE__namespace.Line||Q instanceof THREE__namespace.Points)&&(Q instanceof THREE__namespace.ImmediateRenderObject||!Q.frustumCulled||sharedFrustum.intersectsObject(Q))&&O.push(Q)})}if(T.width*T.height>4096*2048?this.renderSwitch01=this.renderSwitch01^1:this.renderSwitch01=0,this.renderer&&this.paused===!1&&this.renderSwitch01===0){var q=void 0;if(this.onlyRenderIfNeeds!==!0)q=this.render();else{if(this.controller&&this.controller.needsRender===!0&&(this.controller.needsRender=!1,this.needsRender=!0),this.camera.needsRender===!0&&(this.camera.needsRender=!1,this.needsRender=!0),this.models.needsRender===!0&&(this.models.needsRender=!1,this.needsRender=!0),this.needsRender!==!0)for(var V=0,D=O;V<D.length;V++){var K=D[V],z=function(Q){Q.needsRender===!0?(Q.needsRender=!1,o.needsRender=!0):Q.mixer&&Q.mixer.stats.actions.inUse>0&&(o.needsRender=!0)};z(K),K.traverseAncestors(z)}this.needsRender!==!1&&(q=this.render())}if(this.needsRender=!1,this.controller&&this.screenBuffers){var G=this.controller,W=this.screenBuffers;this.aroundScissor(function(){G.postProcessing(W,o.postProcessingType)})}this.hasListener("render")&&this.emit("render",createEvent("render",{needsRender:q!==void 0,info:this.info}))}this.needsRender=!1}this.fps.testTime&&e-this.fps.testTime<1e3?this.fps.testCount++:(this.emit("fps",this.fps.testCount),this.fps.testTime=e,this.fps.testCount=0)}},t.prototype.pause=function(){this.paused=!0,this.renderer&&this.renderer instanceof InternalWebGLRenderer&&this.renderer.clear(!0,!0,!0)},t.prototype.play=function(){this.needsRender=!0,this.paused=!1},t.prototype.moveToPano=function(e,r,i){r===void 0&&(r={}),i===void 0&&(i=!0);var o=this,s=o.controller,u=o.renderer;if(!s)return this.throwError(new Error("controller is not initialized.")),Promise.resolve();if(!u)return this.throwError(new Error("renderer is not initialized.")),Promise.resolve();var l=this.works.getResolvedObserver(e);if(!l)return this.throwError(new Error("pano ".concat(JSON.stringify(e)," not existed."))),Promise.resolve();var d={workCode:l.work.workCode,panoIndex:l.panoIndex};return"moveToPano"in s&&typeof s.moveToPano=="function"?s.moveToPano(d,r,i):l&&(this.pano=d,this.once("initAnimation.start",function(c){r.moveStartCallback&&r.moveStartCallback(c.state)}),this.once("initAnimation.end",function(c){r.moveEndCallback&&r.moveEndCallback(c.state)}),this.changeMode(t.Mode.Panorama,r,void 0,i)),this.ready()},t.prototype.preloadPano=function(e,r){var i=this;r===void 0&&(r=noop$1);var o=this.works.getResolvedObserver(e);if(!o)return Promise.reject(new Error("Pano ".concat(JSON.stringify(e)," never found")));o.work.allowHosts;var s=["right","left","up","down","front","back"],u=now();return Promise.all(s.map(function(l){var d=__assign({key:"pano.".concat(o.panoId,".").concat(l)},pick(i.imageOptions,["size","format","quality","mappings"])),c=o.images[l],f=i.imageOptions.transform?i.imageOptions.transform(c,d):imageURL(c,d);return getFetcher(o.work).preload(f)})).then(function(){var l=now()-u;return r(l),l})},t.prototype.project2d=function(e,r){if(r===void 0&&(r=!1),!this.renderer)return null;if(this.models.length>0&&r){var i=this.camera.position,o=e.clone().sub(i),s=new THREE__namespace.Raycaster(i,o.clone().normalize());s.params.Points={threshold:.1};var u=this.models.intersectRaycaster(s)[0];if(u&&u.distance+.01<o.length())return null}var l=e.clone().project(this.camera);if(Math.abs(l.z)>1)return null;var d=this.renderer.getSize(new THREE__namespace.Vector2),c=d.x*this.scissor.width,f=d.y*this.scissor.height,h=d.x*this.scissor.left+(l.x+1)/2*c,v=d.y*(1-this.scissor.bottom-this.scissor.height)+(-l.y+1)/2*f;return new THREE__namespace.Vector2(h,v)},t.prototype.getRenderObjects=function(e){sharedProjScreenMatrix.multiplyMatrices(this.camera.projectionMatrix,this.camera.matrixWorldInverse),sharedFrustum.setFromProjectionMatrix(sharedProjScreenMatrix),e||(e=this.scene);var r=[];return e.traverseVisible(function(i){(i instanceof THREE__namespace.Mesh||i instanceof THREE__namespace.Line||i instanceof THREE__namespace.Points)&&(i instanceof THREE__namespace.ImmediateRenderObject||!i.frustumCulled||sharedFrustum.intersectsObject(i))&&r.push(i)}),r},t.prototype.getCurrentState=function(){return __assign(__assign({},this.getPose()),{mode:this.currentMode,workCode:this.pano.workCode,panoIndex:this.pano.panoIndex})},t.prototype.setState=function(e,r,i){var o,s,u,l,d,c,f,h,v,A;r===void 0&&(r=!1),i===void 0&&(i=!0),e=Object.assign({},e),e.offset&&!(e instanceof THREE__namespace.Vector3)&&(e.offset=new THREE__namespace.Vector3(e.offset.x,e.offset.y,e.offset.z));var m;typeof e.panoIndex=="number"&&(e.workCode?m={workCode:e.workCode,panoIndex:e.panoIndex}:m={workCode:(s=(o=this.work)===null||o===void 0?void 0:o.workCode)!==null&&s!==void 0?s:"",panoIndex:e.panoIndex});var y=(u=e.mode)!==null&&u!==void 0?u:this.state.mode,p,g,b,T,_;if((e.mode===t.Mode.Floorplan||e.mode===t.Mode.Topview||e.mode===t.Mode.Mapview||e.mode===t.Mode.Model)&&!this.models.loaded){this.throwError(new Error("model is not ready."));return}if(this.controller&&this.controller.stopMomentumMovement(),this.state.mode!==y){if(y==="VRPanorama"){this.changeMode("VRPanorama",void 0,void 0,!0);return}var w={workCode:m==null?void 0:m.workCode,panoIndex:m==null?void 0:m.panoIndex};typeof e.longitude=="number"&&(w.longitude=e.longitude),typeof e.latitude=="number"&&(w.latitude=e.latitude),typeof e.fov=="number"&&(w.fov=e.fov),typeof e.distance=="number"&&(w.distance=e.distance),e.offset instanceof THREE__namespace.Vector3&&(w.offset=e.offset);var x=__assign(__assign({initial:{state:w,currentState:this.getCurrentState(),duration:this.modeChangeDuration,userAction:!1}},this.commonParams()),this.controllerInits[y]),M=Controllers[y].initAnimationEndState(x);p=M.longitude,g=M.latitude,b=M.fov,T=M.offset,_=M.distance}else p=(l=e.longitude)!==null&&l!==void 0?l:this.state.longitude,g=(d=e.latitude)!==null&&d!==void 0?d:this.state.latitude,b=(c=e.fov)!==null&&c!==void 0?c:this.state.fov,T=(f=e.offset)!==null&&f!==void 0?f:this.state.offset,_=(h=e.distance)!==null&&h!==void 0?h:this.state.distance;var R={workCode:(m??this.pano).workCode,panoIndex:(m??this.pano).panoIndex,mode:y,longitude:p,latitude:g,fov:b,offset:T,distance:_};this.emit("state.set",createEvent("state.set",{userAction:i,state:R})),stateEqual(this.state,R)||(this.controller&&R.mode==="VRPanorama"&&R.mode!==this.state.mode?(assignState(this.state,R),this.changeMode("VRPanorama")):this.controller&&R.mode==="XRPanorama"&&R.mode!==this.state.mode?(assignState(this.state,R),this.changeMode("XRPanorama")):(assignState(this.state,R),this.controller&&i&&(this.controller.userAction=!1),r&&this.state.mode===R.mode&&(this.syncingState=this.syncState(now(),0,r),this.syncingState&&((v=this.controller)===null||v===void 0||v.updateTime(now(),0),this.syncingState=!1)),this.emit("state.change",createEvent("state.change",{userAction:i,state:this.state})),(A=this.analysis)===null||A===void 0||A.state(this.works,this.state)))},t.prototype.aroundScissor=function(e){if(this.renderer){if(this.state.mode==="XRPanorama"){e();return}var r=new THREE__namespace.Vector2,i=this.scissor.left!==0||this.scissor.bottom!==0||this.scissor.width!==1||this.scissor.height!==1;if(i){this.renderer.getSize(r);var o=Math.floor(r.x*this.scissor.left),s=Math.floor(r.y*this.scissor.bottom),u=Math.floor(r.x*this.scissor.width),l=Math.floor(r.y*this.scissor.height);this.renderer.setViewport(o,s,u,l),this.renderer.setScissor(o,s,u,l),this.renderer.setScissorTest(!0)}e(),i&&(this.renderer.setViewport(0,0,r.x,r.y),this.renderer.setScissor(0,0,r.x,r.y),this.renderer.setScissorTest(!1))}},t.prototype.syncState=function(e,r,i){i===void 0&&(i=!1);var o=this.stateSynced;if(this.stateSynced=!1,this.works.length===0||!this.controller)return!1;if(this.state.mode!==this.currentMode){var s={mode:this.state.mode,workCode:this.state.workCode,panoIndex:this.state.panoIndex,longitude:this.state.longitude,latitude:this.state.latitude,fov:this.state.fov,offset:this.state.offset,distance:this.state.distance};return this.changeMode(this.state.mode,s,this.modeChangeDuration,this.controller.userAction),!0}if(!this.controller.isReady())return!1;if(this.controller instanceof Controllers.Model){if(notSimilarVector3(this.camera.pose.offset,this.state.offset)){var u={longitude:this.state.longitude,latitude:this.state.latitude,fov:this.state.fov,offset:this.state.offset};return this.controller.moveToPosition(this.state.offset,__assign(__assign({},u),{duration:i?0:void 0}),!1),!0}}else{var l={workCode:this.state.workCode,panoIndex:this.state.panoIndex};if(!panoEqual(l,this.pano)&&"moveToPano"in this.controller&&typeof this.controller.moveToPano=="function"){var u={longitude:this.state.longitude,latitude:this.state.latitude,fov:this.state.fov,offset:this.state.offset,distance:this.state.distance};return this.controller.moveToPano(l,u,!1),!0}}if(this.controller instanceof Controllers.Floorplan||this.controller instanceof Controllers.Topview||this.controller instanceof Controllers.Mapview){var d=1,c=.2,f=.2,h=Math.PI/45,v=i?this.state.fov:stepNumber(this.camera.pose.fov,this.state.fov,d),A=Math.abs(this.camera.pose.distance-this.state.distance),m=A>f*15?A/15:c,y=i?this.state.distance:stepNumber(this.camera.pose.distance,this.state.distance,m),p=this.camera.pose.offset.distanceTo(this.state.offset),g=p>f*15?p/15:f,b=i?new THREE__namespace.Vector3().copy(this.state.offset):stepVector(this.camera.pose.offset,this.state.offset,g),T=i?{longitude:this.state.longitude,latitude:this.state.latitude}:stepCoordinates({longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude},{longitude:this.state.longitude,latitude:this.state.latitude},h),_=T.longitude,w=T.latitude;if(notSimilarValue(v,this.camera.pose.fov)||notSimilarVector3(b,this.camera.pose.offset)||notSimilarValue(y,this.camera.pose.distance)||notSimilarValue(_,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(w,this.camera.pose.latitude)){var x={x:b.x,y:b.y,z:b.z},M={fov:v};return Object.assign(x,{distance:y}),Object.assign(M,{longitude:_,latitude:w}),this.controller.stopMomentumMovement(),this.controller.cameraMotion.set(M,0).catch(noop$1),this.controller.locationMotion.set(x,0).catch(noop$1),!0}}else{var R=1,I=Math.PI/45,v=i?this.state.fov:stepNumber(this.camera.pose.fov,this.state.fov,R),S=i?{longitude:this.state.longitude,latitude:this.state.latitude}:stepCoordinates({longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude},{longitude:this.state.longitude,latitude:this.state.latitude},I),_=S.longitude,w=S.latitude;if(notSimilarValue(_,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(w,this.camera.pose.latitude)||notSimilarValue(v,this.camera.pose.fov))return this.controller.stopMomentumMovement(),this.controller.cameraMotion.set({longitude:_,latitude:w,fov:v},0).catch(noop$1),!0}if(this.stateSynced=!0,o===!1&&this.emit("state.synced",createEvent("state.synced",{userAction:!1,state:this.state})),this.readyCallbacks.length&&this.stateSynced){var B=this.currentMode,F=B===t.Mode.Floorplan||B===t.Mode.Topview||B===t.Mode.Mapview||B===t.Mode.Model;if(!F||this.models.loaded){var O=this.readyCallbacks.slice();this.readyCallbacks.length=0;for(var H=0,k=O;H<k.length;H++){var N=k[H];this.controller instanceof Controllers.Panorama&&N.tile===!0&&!this.controller.isTileReady()?this.readyCallbacks.push(N):N()}}}return!1},t.prototype.ready=function(e){var r=this;return e===void 0&&(e={}),new Promise(function(i){var o;r.readyCallbacks.push(Object.assign(i,{tile:(o=e.tile)!==null&&o!==void 0?o:!1}))})},t.prototype.requestFullscreen=function(){var e;if(isMobile()){var r=(e=this.getElement())===null||e===void 0?void 0:e.parentNode;r&&"requestFullscreen"in r&&typeof document<"u"&&document.fullscreenElement===null&&r.requestFullscreen()}},t.prototype.exitFullscreen=function(){typeof document<"u"&&document.fullscreenElement&&"exitFullscreen"in document&&document.exitFullscreen()},t.prototype.throwError=function(e){this.hasListener("error")?this.emit("error",e):console.error(e)},t.prototype.loadModel=function(e){for(var r=this,i=[],o=function(m){var y=s.models.filter(function(g){var b;return((b=g.work)===null||b===void 0?void 0:b.workCode)===m.workCode})[0];if(y)y.work=m,i.push(y);else{var p=new Model({coordinatesSystemTransformers:s.coordinatesSystemTransformers,onError:function(g){r.emit("model.error",createEvent("model.request",{work:m,model:p,error:g}))},onShownFloorChange:function(g){r.emit("model.changeShownFloor",createEvent("model.request",{work:m,model:p,error:null}))},onLoad:function(){r.emit("model.load",createEvent("model.request",{work:m,model:p,error:null}))}});i.push(p),s.emit("model.request",createEvent("model.request",{work:m,model:p,error:null})),p.load(m,{textureOptions:s.textureOptions})}},s=this,u=0,l=e;u<l.length;u++){var d=l[u];o(d)}if(this.models.length>0){for(var c=0,f=this.models;c<f.length;c++){var h=f[c];i.indexOf(h)===-1&&this.lastModels.push(h)}this.models.length=0}for(var v=0,A=i;v<A.length;v++){var h=A[v];this.models.push(h)}return this.renderer&&(this.models.loaded=!1),new Promise(function(m){r.on("models.load",function(){m()})})},t.prototype.commonParams=function(){return{ident:this.ident,scene:this.scene,xrCustomObjectsScene:this.xrCustomObjectsScene,helper:this.helperGroup,boundingMesh:this.boundingMesh,camera:this.camera,renderer:this.renderer,scissor:this.scissor,element:this.getElement(),models:this.models,works:this.works,imageOptions:this.imageOptions,enableWheel:this.enableWheel,enableIOSEDR:this._enableIOSEDR,enableEDL:this.enableEDL,enableHQ:this.enableHQ,extraElements:this.extraElements,videoTexture:this.videoTexture}},t.prototype.applyController=function(e,r){var i=this;if(!this.renderer)throw new Error("renderer is not initialized.");e!==t.Mode.Mapview&&(this.enableEDL=!1,this.enableHQ=!1);var o=Controllers[e];if(e!==this.currentMode)for(var s=0,u=this.models;s<u.length;s++){var l=u[s];l.show()}this.currentMode=e;for(var d=new o(r),c=function(y){d.on(y,function(){for(var p=[],g=0;g<arguments.length;g++)p[g]=arguments[g];var b=i.emit.apply(i,__spreadArray([y],p,!1));if(b)return!1})},f=0,h=PROXY_CONTROLLER_EVENT_NAMES;f<h.length;f++){var v=h[f];c(v)}{var A=Controllers[e].initAnimationEndState(r),m=r.initial.userAction;stateEqual(this.state,A)||(assignState(this.state,A),this.emit("state.change",createEvent("state.change",{userAction:m,state:this.state}))),this.emit("currentState.change",createEvent("currentState.change",{userAction:m,state:this.getCurrentState()}))}return d.on("camera.update",function(y){var p;if(i.controller){var g=i.controller.getTargetState();y.userAction&&i.syncingState===!1&&i.state.mode===g.mode&&!stateEqual(i.state,g)&&(assignState(i.state,g),i.emit("state.change",createEvent("state.change",{userAction:y.userAction,state:i.state})),(p=i.analysis)===null||p===void 0||p.state(i.works,i.state))}i.emit("currentState.change",createEvent("currentState.change",{userAction:y.userAction,state:i.getCurrentState()}))}),d.on("initAnimation.start",function(y){var p,g=y.state,b=y.userAction;b&&i.state.mode===g.mode&&!stateEqual(i.state,g)&&(assignState(i.state,g),i.emit("state.change",createEvent("state.change",{userAction:b,state:i.state})),(p=i.analysis)===null||p===void 0||p.state(i.works,i.state))}),d.on("initAnimation.end",function(y){var p,g=y.state,b=y.userAction;b&&i.state.mode===g.mode&&!stateEqual(i.state,g)&&(assignState(i.state,g),i.emit("state.change",createEvent("state.change",{userAction:b,state:i.state})),(p=i.analysis)===null||p===void 0||p.state(i.works,i.state))}),d.on("pano.moveTo",function(y){var p,g=y.state,b=y.userAction;i.pano={workCode:g.workCode,panoIndex:g.panoIndex},b&&i.state.mode===g.mode&&!stateEqual(i.state,g)&&(assignState(i.state,g),i.emit("state.change",createEvent("state.change",{userAction:b,state:i.state})),(p=i.analysis)===null||p===void 0||p.state(i.works,i.state))}),d.on("pano.arrived",function(y){var p,g=y.state,b=y.userAction;b&&i.state.mode===g.mode&&!stateEqual(i.state,g)&&(assignState(i.state,g),i.emit("state.change",createEvent("state.change",{userAction:b,state:i.state})),(p=i.analysis)===null||p===void 0||p.state(i.works,i.state))}),d.on("pano.moveTo",function(y){var p=y.userAction;i.emit("currentState.change",createEvent("currentState.change",{userAction:p,state:i.getCurrentState()}))}),d.on("pano.request",function(y){i.emit("pano.request",y),y.defaultPrevented||i.moveToPano(y.state,y.options,y.userAction)}),d.on("vr.requestExit",function(){i.currentMode===t.Mode.VRPanorama&&(i.exitFullscreen(),i.changeMode(t.Mode.Panorama))}),d.on("error",function(y){return i.throwError(y)}),d},t.prototype.removeEventListeners=function(){},t.Mode={Panorama:"Panorama",Model:"Model",Floorplan:"Floorplan",Topview:"Topview",Mapview:"Mapview",DepthPanorama:"DepthPanorama",VRPanorama:"VRPanorama",XRPanorama:"XRPanorama"},t.Line=null,t}(Subscribe),__FIVE_DEBUG__={instances:{},constructor:Five};typeof window<"u"&&Object.assign(window,{__FIVE_DEBUG__});var XRButton=function(){function n(){}return n.createButton=function(t){var e=document.createElement("button");function r(){e.style.display="",e.style.cursor="pointer",e.style.left="calc(50% - 50px)",e.style.width="100px",e.textContent="ENTER VR",e.onmouseenter=function(){e.style.opacity="1.0"},e.onmouseleave=function(){e.style.opacity="0.5"},e.onclick=function(){t&&t()}}function i(){e.style.display="",e.style.cursor="auto",e.style.left="calc(50% - 75px)",e.style.width="150px",e.onmouseenter=null,e.onmouseleave=null,e.onclick=null}function o(){i(),e.textContent="VR NOT SUPPORTED"}function s(l){l.style.position="absolute",l.style.bottom="20px",l.style.padding="12px 6px",l.style.border="1px solid #fff",l.style.borderRadius="4px",l.style.background="rgba(0,0,0,0.1)",l.style.color="#fff",l.style.font="normal 13px sans-serif",l.style.textAlign="center",l.style.opacity="0.5",l.style.outline="none",l.style.zIndex="999"}if("xr"in navigator)return e.id="VRButton",e.style.display="none",s(e),navigator.xr.isSessionSupported("immersive-vr").then(function(l){l?r():o()}),e;var u=document.createElement("a");return window.isSecureContext===!1?(u.href=document.location.href.replace(/^http:/,"https:"),u.innerHTML="WEBXR NEEDS HTTPS"):(u.href="https://immersiveweb.dev/",u.innerHTML="WEBXR NOT AVAILABLE"),u.style.left="calc(50% - 90px)",u.style.width="180px",u.style.textDecoration="none",s(u),u},n}();exports.AnimationFrameLoop=AnimationFrameLoop,exports.Camera=Camera,exports.Fetcher=Fetcher,exports.Five=Five,exports.InternalWebGLRenderer=InternalWebGLRenderer,exports.IntersectMesh=IntersectMesh,exports.Model=Model,exports.NetworkSubscribe=NetworkSubscribe,exports.PBMContainer=PBMContainer,exports.PBMGroup=PBMGroup,exports.PBMMesh=PBMMesh,exports.PBMMeshMaterial=PBMMeshMaterial,exports.PROXY_CONTROLLER_EVENT_NAMES=PROXY_CONTROLLER_EVENT_NAMES,exports.PanoCircleMesh=PanoCircleMesh,exports.PanoCircleMeshCustom=PanoCircleMeshCustom,exports.PanoCircleMeshSolid=PanoCircleMeshSolid,exports.RequestScheduler=RequestScheduler,exports.Scene=Scene,exports.Subscribe=Subscribe,exports.TextureLoader=TextureLoader,exports.Tile=Tile,exports.Tile3DModel=Tile3DModel,exports.TileCubeTextureTarget=TileCubeTextureTarget,exports.TileNode=TileNode,exports.Tileset=Tileset,exports.TilesetCache=TilesetCache,exports.TilesetTraverser=TilesetTraverser,exports.Work=Work,exports.XRButton=XRButton,exports.defaultImageURLTransform=imageURL,exports.defaultPbmParameters=defaultPbmParameters,exports.getViewportScale=getViewportScale,exports.imageSupport=imageSupport,exports.isPanoId=isPanoId,exports.loadAt3d=loadAt3d,exports.loadB3dm=loadB3dm,exports.loadDome=loadDome,exports.loadDomez=loadDomez,exports.loadPbm=loadPbm,exports.loadPnts=loadPnts,exports.panoEqual=panoEqual,exports.panoParse=panoParse,exports.panoStringify=panoStringify,exports.parseWork=parseWork,Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"})});
|
|
2048
|
+
`});v.depthTest=f.material.depthTest,v.side=f.material.side,u.meshReplaceMaterialMap.set(h,v),f.material=v}}});var l=this.renderer.getSize(new THREE__namespace.Vector2);this.camera.setViewOffset(l.width,l.height,e*o,r*o,1,1),this.renderer.setRenderTarget(this.gpuPickingRenderTarget),this.render();var d=new Uint8Array(4);this.renderer.readRenderTargetPixels(this.gpuPickingRenderTarget,0,0,1,1,d),this.renderer.setRenderTarget(null),this.camera.clearViewOffset(),this.scene.traverse(function(f){!(f instanceof THREE__namespace.Mesh)||f instanceof PBMMesh||u.meshOriginMaterialMap.get(f.uuid)&&(f.material=u.meshOriginMaterialMap.get(f.uuid))}),this.models.setMaterial({constantColor:null});var c=Object.keys(i).filter(function(f){return i[f].equals(new THREE__namespace.Color().setRGB(d[0]/255,d[1]/255,d[2]/255))})[0];return c||!1},t.prototype.dispose=function(){var e,r;if(this.destroyed!==!0){delete __FIVE_DEBUG__.instances[this.ident],this.emit("dispose"),this.destroyed=!0,this.pause(),this.stopAnimationLoop&&(this.stopAnimationLoop(),delete this.stopAnimationLoop),(e=this.renderer)===null||e===void 0||e.setAnimationLoop(null),this.off(),this.networkSubscribe.off(),this.controller&&(this.controller.destroy(),this.controller=void 0);var i=this.getElement();i&&i.parentNode&&i.parentNode.removeChild(i);var o=this.models.getMaterial();o&&(o.pano0&&o.pano0.map.dispose(),o.pano1&&o.pano1.map!==((r=o.pano0)===null||r===void 0?void 0:r.map)&&o.pano1.map.dispose());for(var s=0,u=this.models;s<u.length;s++){var l=u[s];l.dispose()}this.models.length=0,this.models.setMaterial({pano0:null,pano1:null}),this.meshReplaceMaterialMap.forEach(function(d){d.dispose()}),this.meshOriginMaterialMap.forEach(function(d){d.dispose()}),this.renderer instanceof InternalWebGLRenderer&&this.renderer.forceContextLoss&&this.renderer.forceContextLoss()}},t.prototype.setScissor=function(e){Object.assign(this.scissor,e),this.controller&&this.controller.updateRenderSize&&this.controller.updateRenderSize()},Object.defineProperty(t.prototype,"helperVisible",{get:function(){return this.helperGroup.visible},set:function(e){this.helperGroup.visible!==e&&(this.helperGroup.visible=e,this.emit("helpers.visible",createEvent("helpers.visible",{object:this.helperGroup})),this.needsRender=!0)},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"enableIOSEDR",{get:function(){return this._enableIOSEDR},set:function(e){this._enableIOSEDR!==e&&(this._enableIOSEDR=e,this.currentMode&&this.currentMode==="Panorama"&&this.changeMode(this.currentMode,this.getCurrentState(),0,!1,!0))},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"postProcessingType",{get:function(){return this.currentMode==="Panorama"&&this.enableIOSEDR?"luminance":this.currentMode==="Mapview"&&this.enableEDL?"edl":this.currentMode==="Mapview"&&this.enableHQ?"hq":null},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"enableEDL",{get:function(){return this.models.getMaterial().useEDL},set:function(e){var r,i,o,s;if(e===!0&&this.currentMode!==t.Mode.Mapview)throw new Error("只支持Mapview下开启EDL");if(this.models.setMaterial({useEDL:e}),this.boundingMesh.visible=!e,e){if(!this.screenBuffers){var u=this.getDrawingBufferSize(sharedVector2);this.screenBuffers=[new THREE__namespace.WebGLRenderTarget(u.x,u.y,{encoding:(i=(r=this.renderer)===null||r===void 0?void 0:r.outputEncoding)!==null&&i!==void 0?i:THREE__namespace.sRGBEncoding,minFilter:THREE__namespace.NearestFilter,magFilter:THREE__namespace.NearestFilter,format:THREE__namespace.RGBAFormat,type:THREE__namespace.FloatType}),new THREE__namespace.WebGLRenderTarget(u.x,u.y,{encoding:(s=(o=this.renderer)===null||o===void 0?void 0:o.outputEncoding)!==null&&s!==void 0?s:THREE__namespace.sRGBEncoding,minFilter:THREE__namespace.LinearMipMapLinearFilter,magFilter:THREE__namespace.LinearMipMapLinearFilter})]}}else this.screenBuffers&&(this.screenBuffers.forEach(function(l){l.dispose()}),delete this.screenBuffers);this.needsRender=!0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"enableHQ",{get:function(){return this.models.getMaterial().useHQWeight||this.models.getMaterial().useHQDepth||!1},set:function(e){var r,i;if(e===!0&&this.currentMode!==t.Mode.Mapview)throw new Error("只支持Mapview下开启HQ");if(e===!0?this.models.setMaterial({useHQDepth:!0,useHQWeight:!1,pointShape:"CIRCLE"}):this.models.setMaterial({useHQDepth:!1,useHQWeight:!1}),this.boundingMesh.visible=!e,e){if(!this.screenBuffers){var o=this.getDrawingBufferSize(sharedVector2),s=new THREE__namespace.WebGLRenderTarget(o.x,o.y,{minFilter:THREE__namespace.NearestFilter,magFilter:THREE__namespace.NearestFilter,format:THREE__namespace.RGBAFormat,type:THREE__namespace.FloatType,depthTexture:new THREE__namespace.DepthTexture(o.x,o.y,THREE__namespace.UnsignedIntType)});s.depthTexture.format=THREE__namespace.DepthFormat,s.depthBuffer=!0;var u=new THREE__namespace.WebGLRenderTarget(o.x,o.y,{encoding:(i=(r=this.renderer)===null||r===void 0?void 0:r.outputEncoding)!==null&&i!==void 0?i:THREE__namespace.sRGBEncoding,minFilter:THREE__namespace.NearestFilter,magFilter:THREE__namespace.NearestFilter,format:THREE__namespace.RGBAFormat,type:THREE__namespace.FloatType,depthTexture:s.depthTexture});this.screenBuffers=[s,u]}}else this.screenBuffers&&(this.screenBuffers.forEach(function(l){l.dispose()}),delete this.screenBuffers);this.needsRender=!0},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"enablePostProcessing",{get:function(){return this.screenBuffers!==void 0},set:function(e){var r,i,o,s;if(e){if(!this.screenBuffers){var u=this.getDrawingBufferSize(sharedVector2);this.screenBuffers=[new THREE__namespace.WebGLRenderTarget(u.x,u.y,{encoding:(i=(r=this.renderer)===null||r===void 0?void 0:r.outputEncoding)!==null&&i!==void 0?i:THREE__namespace.sRGBEncoding}),new THREE__namespace.WebGLRenderTarget(u.x,u.y,{encoding:(s=(o=this.renderer)===null||o===void 0?void 0:o.outputEncoding)!==null&&s!==void 0?s:THREE__namespace.sRGBEncoding})]}}else this.screenBuffers&&(this.screenBuffers.forEach(function(l){l.dispose()}),delete this.screenBuffers);this.needsRender=!0},enumerable:!1,configurable:!0}),t.prototype.updateConfiguration=function(e){var r=!1;e.panorama&&(Object.assign(this.controllerInits.Panorama,e.panorama),this.currentMode==="Panorama"&&(r=!0)),e.model&&(Object.assign(this.controllerInits.Model,e.model),this.currentMode==="Model"&&(r=!0)),e.floorplan&&(Object.assign(this.controllerInits.Floorplan,e.floorplan),this.currentMode==="Floorplan"&&(r=!0)),e.topview&&(Object.assign(this.controllerInits.Topview,e.topview),this.currentMode==="Topview"&&(r=!0)),e.mapview&&(Object.assign(this.controllerInits.Mapview,e.topview),this.currentMode==="Mapview"&&(r=!0)),e.depthPanorama&&(Object.assign(this.controllerInits.DepthPanorama,e.depthPanorama),this.currentMode==="DepthPanorama"&&(r=!0)),e.vrPanorama&&(Object.assign(this.controllerInits.VRPanorama,e.vrPanorama),this.currentMode==="VRPanorama"&&(r=!0)),e.imageOptions&&(Object.assign(this.imageOptions,e.imageOptions),(this.currentMode==="Panorama"||this.currentMode==="DepthPanorama"||this.currentMode==="VRPanorama")&&(r=!0)),r&&this.controller&&this.currentMode&&this.changeMode(this.currentMode,this.getCurrentState(),0,!1,!0),e.textureOptions&&Object.assign(this.textureOptions,e.textureOptions)},t.prototype.appendTo=function(e,r){if(r===void 0&&(r={}),!!this.renderer){if(!(this.renderer instanceof InternalWebGLRenderer)){this.throwError(new Error("cannot call appendTo method when render a external renderer"));return}var i=this.getElement();if(i){e.appendChild(i),this.refresh(r);var o=window.getComputedStyle(e).position;o!=="relative"&&o!=="absolute"&&o!=="fixed"&&o!=="sticky"&&(e.style.position="relative")}}},t.prototype.refresh=function(e,r){if(e===void 0&&(e={}),!!this.renderer){var i=this.getElement();if(i){var o=i.parentNode;if(o&&o.nodeName){var s=e.width,u=s===void 0?o.offsetWidth:s,l=e.height,d=l===void 0?o.offsetHeight:l;this.renderer instanceof InternalWebGLRenderer&&(r&&this.renderer.setPixelRatio(r),this.renderer.setSize(u,d))}this.controller&&this.controller.updateRenderSize&&this.controller.updateRenderSize(),this.needsRender=!0}}},t.prototype.addExtraElement=function(e){var r=this;return this.extraElements.indexOf(e)===-1&&(this.extraElements.push(e),this.controller&&this.controller.bindExtraElement(e)),function(){return r.removeExtraElement(e)}},t.prototype.removeExtraElement=function(e){var r=this.extraElements.indexOf(e);r!==-1&&(this.extraElements.splice(r,1),this.controller&&this.controller.unbindExtraElement(e))},t.prototype.getPose=function(){var e=this.camera.copyPose(),r=e.longitude,i=e.latitude,o=e.fov,s=e.offset,u=e.distance;return{longitude:r,latitude:i,fov:o,offset:s.clone(),distance:u}},t.prototype.getSize=function(e){if(!this.renderer)throw new Error("renderer is not initialized");return this.renderer.getSize(e),e.x*=this.scissor.width,e.y*=this.scissor.height,e},t.prototype.getDrawingBufferSize=function(e){if(!this.renderer)throw new Error("renderer is not initialized");return this.renderer.getDrawingBufferSize(e),e.x*=this.scissor.width,e.y*=this.scissor.height,e},t.prototype.updateCamera=function(e,r,i){return i===void 0&&(i=!0),this.controller?this.controller.updateCamera(e,r,i):Promise.reject(new Error("controller is not initialized."))},t.prototype.updateCameraWithKeyframes=function(e,r,i){return i===void 0&&(i=!0),this.controller?this.controller.updateCameraWithKeyframes(e,r,i):Promise.reject(new Error("controller is not initialized."))},t.prototype.getLongitudeAndLatitude=function(){var e=this.getPose(),r=e.longitude,i=e.latitude;return{longitude:r,latitude:i}},t.prototype.getOffset=function(){return this.getPose().offset},t.prototype.getCameraLocal=function(){if(this.pano.workCode&&this.controller&&this.works){var e=this.works.getResolvedObserver(this.pano);if(e){var r=new THREE__namespace.Object3D;return r.position.copy(e.position),r.quaternion.copy(e.quaternion),r.scale.set(1,1,1),r.matrix.compose(r.position,r.quaternion,r.scale),r.matrixAutoUpdate=!1,cameraWorldToLocal(this.camera,r)}}return null},Object.defineProperty(t.prototype,"works",{get:function(){var e=worksMap.get(this);if(!e)return emptyWorks;for(var r=0,i=e;r<i.length;r++){var o=i[r];if(!workRawMapping.has(o))return emptyWorks}return e},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"work",{get:function(){return this.works[0]},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"model",{get:function(){return this.models[0]},enumerable:!1,configurable:!0}),t.prototype.load=function(e,r,i,o){var s=this;if(o===void 0&&(o=!0),!this.renderer)throw new Error("renderer is not initialized");var u=this.lastLoadWorkTask.then(function(){return isPromise(e)?e.then(function(l){return s.load_(l,r,i,o)}):s.load_(e,r,i,o)});return this.lastLoadWorkTask=u.catch(function(l){s.throwError(l)}),u},t.prototype.load_=function(e,r,i,o){var s=this,u,l,d,c,f,h;o===void 0&&(o=!0);var v=[];if(Array.isArray(e))for(var A=0,m=e;A<m.length;A++){var y=m[A];typeof y!="string"&&"work"in y?v.push(parseWork(y.work,y)):v.push(parseWork(y))}else v.push(parseWork(e));for(var p=createWorks(v),g=function(D){var K=b,z=new Fetcher({allowHosts:D.allowHosts,get requestProxy(){return K.requestProxy},get networkSubscribe(){return K.networkSubscribe}});registerFetcher(D,z)},b=this,T=0,_=p;T<_.length;T++){var w=_[T];g(w)}var x=this.works;r===void 0&&(r=x.length!==0?"inherit":"initial");var M=p.initial,R=M.work.observers[0],I=R?{workCode:R.work.workCode,panoIndex:R.panoIndex}:{workCode:M.work.workCode,panoIndex:0},S=(u=M.mode)!==null&&u!==void 0?u:R?"Panorama":"Mapview",B={};if(r==="inherit"){S=this.currentMode;var O=p.resolvedObservers[this.panoIndex];O?I={workCode:O.work.workCode,panoIndex:O.panoIndex}:typeof p.initial.panoIndex=="number"?I={workCode:p.initial.work.workCode,panoIndex:p.initial.panoIndex}:(S==="Panorama"||S==="DepthPanorama"||S==="VRPanorama"||S==="XRPanorama")&&(S="Mapview"),B={longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,distance:this.camera.pose.distance,offset:this.camera.pose.offset.clone()}}else if(r==="initial")typeof M.panoIndex=="number"&&(I={workCode:M.work.workCode,panoIndex:M.panoIndex}),M.mode&&(S=M.mode),B={longitude:M.longitude,latitude:M.latitude,fov:M.fov,distance:M.distance,offset:(l=M.offset)===null||l===void 0?void 0:l.clone()};else{if(S=(d=r.mode)!==null&&d!==void 0?d:this.currentMode,typeof r.panoIndex=="number"){var O=p.getResolvedObserver({workCode:(f=(c=r.workCode)!==null&&c!==void 0?c:M.work.workCode)!==null&&f!==void 0?f:"",panoIndex:r.panoIndex});O&&(I={workCode:O.work.workCode,panoIndex:O.panoIndex})}B={longitude:r.longitude,latitude:r.latitude,fov:r.fov,distance:r.distance,offset:r.offset}}var F=__assign(__assign(__assign({},I),{mode:S}),B);this.emit("works.request",createEvent("works.request",{input:e,works:p,state:F,userAction:o}));var H=function(){s.pano=I;var D=s.controller?i??s.modeChangeDuration:0,K=__assign(__assign({initial:{state:F,currentState:s.getCurrentState(),duration:D,userAction:o}},s.commonParams()),s.controllerInits[S]);if(s.controller&&s.currentMode===S)s.controller.updateWork(p,F,D,o)===!1&&(s.controller.destroy(),s.controller=s.applyController(S,K));else{var z=s.currentMode,G=Controllers[S].initAnimationEndState(K);if(s.controller)s.controller.destroy();else{var W=Controllers[S].initAnimationEndState(K);s.camera.setFromPose(W),s.modelGroup.visible=!0,s.emit("camera.update",createEvent("camera.update",{state:s.getCurrentState(),userAction:o}))}s.controller=s.applyController(S,K);var Q=createEvent("mode.change",{prevMode:z,mode:S,state:G,userAction:o});s.emit("mode.change",Q)}};if(worksMap.set(this,p),!this.controller){var k=__assign(__assign({initial:{state:F,currentState:this.getCurrentState(),duration:0,userAction:o}},this.commonParams()),this.controllerInits[S]),N=Controllers[S].initAnimationEndState(k);this.camera.setFromPose(N),this.emit("camera.update",createEvent("camera.update",{state:this.getCurrentState(),userAction:o}))}if(S===t.Mode.Floorplan||S===t.Mode.Topview||S===t.Mode.Mapview||S===t.Mode.Model)this.loadModel(p).then(function(){s.needsRender=!0,H(),s.emit("camera.update",createEvent("camera.update",{state:s.getCurrentState(),userAction:o}))});else{if(!this.controller){var q=new THREE__namespace.Vector3,V=p.getResolvedObserver(I);V&&q.copy(V.position),this.camera.setFromPose({fov:B.fov,longitude:B.longitude,latitude:B.latitude,distance:B.distance,offset:(h=B.offset)!==null&&h!==void 0?h:q}),this.needsRender=!0}H(),this.controller.once("pano.moveTo",function(){s.needsRender=!0,s.emit("camera.update",createEvent("camera.update",{state:s.getCurrentState(),userAction:o})),s.loadModel(p)})}return this.emit("works.load",createEvent("works.load",{input:e,state:this.getCurrentState(),userAction:o,works:p})),this.ready().then(function(){var D;s.emit("works.ready",createEvent("works.ready",{input:e,state:s.getCurrentState(),userAction:o,works:p})),(D=s.analysis)===null||D===void 0||D.work(p)})},t.prototype.changeMode=function(e,r,i,o,s){var u=this;return r===void 0&&(r={}),i===void 0&&(i=this.modeChangeDuration),o===void 0&&(o=!0),s===void 0&&(s=!1),new Promise(function(l,d){var c,f,h;if(!u.renderer)throw new Error("renderer is not initialized.");r=__assign({},r);var v=typeof r.panoIndex=="number"?{workCode:(h=(c=r.workCode)!==null&&c!==void 0?c:(f=u.work)===null||f===void 0?void 0:f.workCode)!==null&&h!==void 0?h:"",panoIndex:r.panoIndex}:u.pano;if(!t.Mode.hasOwnProperty(e)){var A=new Error('mode "'.concat(e,'" is not existed'));u.throwError(A),d(A);return}if((e===t.Mode.Floorplan||e===t.Mode.Topview||e===t.Mode.Mapview||e===t.Mode.Model)&&!u.models.loaded){var A=new Error("model is not ready.");u.throwError(A),d(A);return}if((e===t.Mode.Panorama||e===t.Mode.VRPanorama||e===t.Mode.XRPanorama)&&!u.works.getResolvedObserver(v)){var A=new Error("PanoId ".concat(panoStringify(v)," not existed."));u.throwError(A),d(A);return}var m=u.controller,y=u.currentMode,p=function(){if(u.controller&&u.controller.stopMomentumMovement(),u.controller&&s===!1&&y===e)e===t.Mode.Panorama||e===t.Mode.DepthPanorama||e===t.Mode.Model||e===t.Mode.VRPanorama||e===t.Mode.XRPanorama?panoEqual(u.pano,v)&&"moveToPano"in u.controller&&typeof u.controller.moveToPano=="function"?u.controller.moveToPano(v,__assign({duration:i},r),o):u.controller.updateCamera(r,i,o).catch(noop$1):(panoEqual(u.pano,v)||(u.pano=v),u.controller.updateCamera(r,i,o).catch(noop$1));else{var b=__assign(__assign({},r),v),T=__assign(__assign({initial:{state:b,currentState:u.getCurrentState(),duration:i,userAction:o}},u.commonParams()),u.controllerInits[e]),_=Controllers[e].initAnimationEndState(T),w=createEvent("mode.change.request",{prevMode:u.currentMode,mode:e,state:_,userAction:o});if(u.emit("mode.change.request",w),!w.defaultPrevented){m&&m.destroy(),u.controller=u.applyController(e,T);var x=createEvent("mode.change",{prevMode:u.currentMode,mode:e,state:_,userAction:o});u.emit("mode.change",x)}}l()};if(e===t.Mode.VRPanorama)u.requestFullscreen(),requestDeviceOrientationPermission().then(function(){return p()}).catch(function(b){b instanceof Error&&(u.exitFullscreen(),u.throwError(b),d(b))});else if(e===t.Mode.XRPanorama){var g=AnimationFrameLoop.shared.getContext();g?g.end():requestXRSessionPermission().then(function(b){AnimationFrameLoop.shared.setContext(b),p()}).catch(function(b){b instanceof Error&&(u.throwError(b),d(b))})}else p()})},t.prototype.getPixels=function(e,r,i,o,s){if(s===void 0&&(s=1),!this.renderer)throw new Error("renderer is not initialized.");var u=this.getPixelsRenderTarget,l=this.renderer.getSize(new THREE__namespace.Vector2);e=clamp(e,Math.floor(i/2),Math.floor(l.x-i)),r=clamp(r,Math.floor(o/2),Math.floor(l.y-o)),u.setSize(i*s,o*s),this.renderer.setRenderTarget(u),this.camera.setViewOffset(l.width,l.height,e,l.height-r-o,i,o),this.controller?this.controller.render():this.renderer.render(this.scene,this.camera);var d=new Uint8Array(i*s*o*s*4);return this.renderer.readRenderTargetPixels(u,0,0,i*s,o*s,d),this.renderer.setRenderTarget(null),this.camera.clearViewOffset(),d},t.prototype.getElement=function(){var e;return(e=this.renderer)===null||e===void 0?void 0:e.domElement},Object.defineProperty(t.prototype,"observers",{get:function(){return this.works.resolvedObservers},enumerable:!1,configurable:!0}),t.prototype.render=function(e,r){var i=this;if(r===void 0&&(r=!1),!this.renderer)return null;if(r){var o=this.renderer.getSize(sharedVector2);this.scene.traverseVisible(function(u){u.setResolution&&u.setResolution(o.x,o.y)})}if(this.controller&&this.screenBuffers&&this.renderer.getRenderTarget()===null){var s=this.getDrawingBufferSize(sharedVector2);return this.screenBuffers.forEach(function(u){u.setSize(s.x,s.y)}),this.renderer.setRenderTarget(this.screenBuffers[0]),this.controller.render(),this.info={memory:__assign({},this.controller.renderer.info.memory),render:__assign({},this.controller.renderer.info.render)},this.currentMode!=="VRPanorama"&&this.currentMode!=="XRPanorama"&&this.poweredByRealsee&&renderPoweredByRealsee(this.renderer),e&&AnimationFrameLoop.shared.add(e,!0),this.screenBuffers[0]}else return this.aroundScissor(function(){i.renderer&&(i.controller?(i.controller.render(),i.info={memory:__assign({},i.controller.renderer.info.memory),render:__assign({},i.controller.renderer.info.render)}):(i.renderer.render(i.scene,i.camera),i.info={memory:__assign({},i.renderer.info.memory),render:__assign({},i.renderer.info.render)}),i.poweredByRealsee&&i.currentMode!=="VRPanorama"&&i.currentMode!=="XRPanorama"&&renderPoweredByRealsee(i.renderer)),e&&AnimationFrameLoop.shared.add(e,!0)}),null},t.prototype.updateTime=function(e,r){for(var i,o=this,s,u,l=[],d=2;d<arguments.length;d++)l[d-2]=arguments[d];if(!this.destroyed){if(this.works.update(),this.syncingState=this.syncState(e,r),this.controller&&(i=this.controller).updateTime.apply(i,__spreadArray([e,r],l,!1)),this.renderer){var c=this.getSize(sharedVector2),f=this.renderer.getPixelRatio();this.camera.screenHeight=c.height,this.camera.pixelRatio=f,this.camera.aspect=c.width/c.height}if(this.camera.updateTime(e,r),this.renderer){ktx2.detectSupport(this.renderer);var h=this.models.loaded,v=this.models.refined;if(this.models.update(this.renderer,this.camera,this.currentMode),h===!1&&this.models.loaded===!0&&this.emit("models.load",createEvent("models.load",{models:this.models})),v===!1&&this.models.refined===!0&&this.emit("models.refined",createEvent("models.refined",{models:this.models})),this.models.loaded){for(var A=0,m=this.models;A<m.length;A++){var y=m[A];y.parent!==this.modelGroup&&(this.modelGroup.add(y),this.needsRender=!0)}if(this.lastModels.length>0){for(var p=0,g=this.lastModels;p<g.length;p++){var y=g[p];this.modelGroup.remove(y),y.dispose(),this.needsRender=!0}this.lastModels.length=0}}this.lastModels.setMaterial(this.models.getMaterial()),this.lastModels.materialVersion=this.models.materialVersion,this.lastModels.update(this.renderer,this.camera,this.currentMode)}this.syncingState=!1;var b=new THREE__namespace.Vector2(512,512),T=new THREE__namespace.Vector2(512,512);this.renderer&&(this.renderer.getSize(b),b.x*=this.scissor.width,b.y*=this.scissor.height,this.renderer.getDrawingBufferSize(T),T.x*=this.scissor.width,T.y*=this.scissor.height);{for(var _=new THREE__namespace.Box3,w=new THREE__namespace.Box3,x=new THREE__namespace.Vector3(4,4,4),M=0,R=this.works.resolvedObservers;M<R.length;M++){var I=R[M];w.setFromCenterAndSize(I.position,x),_.union(w)}_.union(this.models.bounding),_.getCenter(this.boundingMesh.position),_.getSize(this.boundingMesh.scale),this.boundingMesh.boundingBox.copy(_);var S=(s=this.models.getMaterial())!==null&&s!==void 0?s:{},B=1-((u=S.modelAlpha)!==null&&u!==void 0?u:0);S.opacity=clamp(B*4-3,0,1),S.clippers=null,S.shownFloorIndex=-2,this.boundingMesh.setMaterial(S),this.boundingMesh.needsRender=!1}var O=createEvent("render.prepare",{needsRender:!0,info:null});if(this.emit("render.prepare",O),!O.defaultPrevented){var F=[];sharedProjScreenMatrix.multiplyMatrices(this.camera.projectionMatrix,this.camera.matrixWorldInverse),sharedFrustum.setFromProjectionMatrix(sharedProjScreenMatrix);for(var H=0,k=this.scene.children;H<k.length;H++){var N=k[H];N!==this.modelGroup&&N!==this.boundingMesh&&N instanceof THREE__namespace.Object3D&&N.traverseVisible(function(Q){if(Q.setResolution&&Q.setResolution(b.x,b.y),Q.setTime&&Q.setTime(e),Q.mixer instanceof THREE__namespace.AnimationMixer){var X=clockForMixer.get(Q.mixer);X||(X=new THREE__namespace.Clock,clockForMixer.set(Q.mixer,X)),Q.mixer.update(X.getDelta())}(Q instanceof THREE__namespace.Mesh||Q instanceof THREE__namespace.Line||Q instanceof THREE__namespace.Points)&&(Q instanceof THREE__namespace.ImmediateRenderObject||!Q.frustumCulled||sharedFrustum.intersectsObject(Q))&&F.push(Q)})}if(T.width*T.height>4096*2048?this.renderSwitch01=this.renderSwitch01^1:this.renderSwitch01=0,this.renderer&&this.paused===!1&&this.renderSwitch01===0){var q=void 0;if(this.onlyRenderIfNeeds!==!0)q=this.render();else{if(this.controller&&this.controller.needsRender===!0&&(this.controller.needsRender=!1,this.needsRender=!0),this.camera.needsRender===!0&&(this.camera.needsRender=!1,this.needsRender=!0),this.models.needsRender===!0&&(this.models.needsRender=!1,this.needsRender=!0),this.needsRender!==!0)for(var V=0,D=F;V<D.length;V++){var K=D[V],z=function(Q){Q.needsRender===!0?(Q.needsRender=!1,o.needsRender=!0):Q.mixer&&Q.mixer.stats.actions.inUse>0&&(o.needsRender=!0)};z(K),K.traverseAncestors(z)}this.needsRender!==!1&&(q=this.render())}if(this.needsRender=!1,this.controller&&this.screenBuffers){var G=this.controller,W=this.screenBuffers;this.aroundScissor(function(){G.postProcessing(W,o.postProcessingType)})}this.hasListener("render")&&this.emit("render",createEvent("render",{needsRender:q!==void 0,info:this.info}))}this.needsRender=!1}this.fps.testTime&&e-this.fps.testTime<1e3?this.fps.testCount++:(this.emit("fps",this.fps.testCount),this.fps.testTime=e,this.fps.testCount=0)}},t.prototype.pause=function(){this.paused=!0,this.renderer&&this.renderer instanceof InternalWebGLRenderer&&this.renderer.clear(!0,!0,!0)},t.prototype.play=function(){this.needsRender=!0,this.paused=!1},t.prototype.moveToPano=function(e,r,i){r===void 0&&(r={}),i===void 0&&(i=!0);var o=this,s=o.controller,u=o.renderer;if(!s)return this.throwError(new Error("controller is not initialized.")),Promise.resolve();if(!u)return this.throwError(new Error("renderer is not initialized.")),Promise.resolve();var l=this.works.getResolvedObserver(e);if(!l)return this.throwError(new Error("pano ".concat(JSON.stringify(e)," not existed."))),Promise.resolve();var d={workCode:l.work.workCode,panoIndex:l.panoIndex};return"moveToPano"in s&&typeof s.moveToPano=="function"?s.moveToPano(d,r,i):l&&(this.pano=d,this.once("initAnimation.start",function(c){r.moveStartCallback&&r.moveStartCallback(c.state)}),this.once("initAnimation.end",function(c){r.moveEndCallback&&r.moveEndCallback(c.state)}),this.changeMode(t.Mode.Panorama,r,void 0,i)),this.ready()},t.prototype.preloadPano=function(e,r){var i=this;r===void 0&&(r=noop$1);var o=this.works.getResolvedObserver(e);if(!o)return Promise.reject(new Error("Pano ".concat(JSON.stringify(e)," never found")));o.work.allowHosts;var s=["right","left","up","down","front","back"],u=now();return Promise.all(s.map(function(l){var d=__assign({key:"pano.".concat(o.panoId,".").concat(l)},pick(i.imageOptions,["size","format","quality","mappings"])),c=o.images[l],f=i.imageOptions.transform?i.imageOptions.transform(c,d):imageURL(c,d);return getFetcher(o.work).preload(f)})).then(function(){var l=now()-u;return r(l),l})},t.prototype.project2d=function(e,r){if(r===void 0&&(r=!1),!this.renderer)return null;if(this.models.length>0&&r){var i=this.camera.position,o=e.clone().sub(i),s=new THREE__namespace.Raycaster(i,o.clone().normalize());s.params.Points={threshold:.1};var u=this.models.intersectRaycaster(s)[0];if(u&&u.distance+.01<o.length())return null}var l=e.clone().project(this.camera);if(Math.abs(l.z)>1)return null;var d=this.renderer.getSize(new THREE__namespace.Vector2),c=d.x*this.scissor.width,f=d.y*this.scissor.height,h=d.x*this.scissor.left+(l.x+1)/2*c,v=d.y*(1-this.scissor.bottom-this.scissor.height)+(-l.y+1)/2*f;return new THREE__namespace.Vector2(h,v)},t.prototype.getRenderObjects=function(e){sharedProjScreenMatrix.multiplyMatrices(this.camera.projectionMatrix,this.camera.matrixWorldInverse),sharedFrustum.setFromProjectionMatrix(sharedProjScreenMatrix),e||(e=this.scene);var r=[];return e.traverseVisible(function(i){(i instanceof THREE__namespace.Mesh||i instanceof THREE__namespace.Line||i instanceof THREE__namespace.Points)&&(i instanceof THREE__namespace.ImmediateRenderObject||!i.frustumCulled||sharedFrustum.intersectsObject(i))&&r.push(i)}),r},t.prototype.getCurrentState=function(){return __assign(__assign({},this.getPose()),{mode:this.currentMode,workCode:this.pano.workCode,panoIndex:this.pano.panoIndex})},t.prototype.setState=function(e,r,i){var o,s,u,l,d,c,f,h,v,A;r===void 0&&(r=!1),i===void 0&&(i=!0),e=Object.assign({},e),e.offset&&!(e instanceof THREE__namespace.Vector3)&&(e.offset=new THREE__namespace.Vector3(e.offset.x,e.offset.y,e.offset.z));var m;typeof e.panoIndex=="number"&&(e.workCode?m={workCode:e.workCode,panoIndex:e.panoIndex}:m={workCode:(s=(o=this.work)===null||o===void 0?void 0:o.workCode)!==null&&s!==void 0?s:"",panoIndex:e.panoIndex});var y=(u=e.mode)!==null&&u!==void 0?u:this.state.mode,p,g,b,T,_;if((e.mode===t.Mode.Floorplan||e.mode===t.Mode.Topview||e.mode===t.Mode.Mapview||e.mode===t.Mode.Model)&&!this.models.loaded){this.throwError(new Error("model is not ready."));return}if(this.controller&&this.controller.stopMomentumMovement(),this.state.mode!==y){if(y==="VRPanorama"){this.changeMode("VRPanorama",void 0,void 0,!0);return}var w={workCode:m==null?void 0:m.workCode,panoIndex:m==null?void 0:m.panoIndex};typeof e.longitude=="number"&&(w.longitude=e.longitude),typeof e.latitude=="number"&&(w.latitude=e.latitude),typeof e.fov=="number"&&(w.fov=e.fov),typeof e.distance=="number"&&(w.distance=e.distance),e.offset instanceof THREE__namespace.Vector3&&(w.offset=e.offset);var x=__assign(__assign({initial:{state:w,currentState:this.getCurrentState(),duration:this.modeChangeDuration,userAction:!1}},this.commonParams()),this.controllerInits[y]),M=Controllers[y].initAnimationEndState(x);p=M.longitude,g=M.latitude,b=M.fov,T=M.offset,_=M.distance}else p=(l=e.longitude)!==null&&l!==void 0?l:this.state.longitude,g=(d=e.latitude)!==null&&d!==void 0?d:this.state.latitude,b=(c=e.fov)!==null&&c!==void 0?c:this.state.fov,T=(f=e.offset)!==null&&f!==void 0?f:this.state.offset,_=(h=e.distance)!==null&&h!==void 0?h:this.state.distance;var R={workCode:(m??this.pano).workCode,panoIndex:(m??this.pano).panoIndex,mode:y,longitude:p,latitude:g,fov:b,offset:T,distance:_};this.emit("state.set",createEvent("state.set",{userAction:i,state:R})),stateEqual(this.state,R)||(this.controller&&R.mode==="VRPanorama"&&R.mode!==this.state.mode?(assignState(this.state,R),this.changeMode("VRPanorama")):this.controller&&R.mode==="XRPanorama"&&R.mode!==this.state.mode?(assignState(this.state,R),this.changeMode("XRPanorama")):(assignState(this.state,R),this.controller&&i&&(this.controller.userAction=!1),r&&this.state.mode===R.mode&&(this.syncingState=this.syncState(now(),0,r),this.syncingState&&((v=this.controller)===null||v===void 0||v.updateTime(now(),0),this.syncingState=!1)),this.emit("state.change",createEvent("state.change",{userAction:i,state:this.state})),(A=this.analysis)===null||A===void 0||A.state(this.works,this.state)))},t.prototype.aroundScissor=function(e){if(this.renderer){if(this.state.mode==="XRPanorama"){e();return}var r=new THREE__namespace.Vector2,i=this.scissor.left!==0||this.scissor.bottom!==0||this.scissor.width!==1||this.scissor.height!==1;if(i){this.renderer.getSize(r);var o=Math.floor(r.x*this.scissor.left),s=Math.floor(r.y*this.scissor.bottom),u=Math.floor(r.x*this.scissor.width),l=Math.floor(r.y*this.scissor.height);this.renderer.setViewport(o,s,u,l),this.renderer.setScissor(o,s,u,l),this.renderer.setScissorTest(!0)}e(),i&&(this.renderer.setViewport(0,0,r.x,r.y),this.renderer.setScissor(0,0,r.x,r.y),this.renderer.setScissorTest(!1))}},t.prototype.syncState=function(e,r,i){i===void 0&&(i=!1);var o=this.stateSynced;if(this.stateSynced=!1,this.works.length===0||!this.controller)return!1;if(this.state.mode!==this.currentMode){var s={mode:this.state.mode,workCode:this.state.workCode,panoIndex:this.state.panoIndex,longitude:this.state.longitude,latitude:this.state.latitude,fov:this.state.fov,offset:this.state.offset,distance:this.state.distance};return this.changeMode(this.state.mode,s,this.modeChangeDuration,this.controller.userAction),!0}if(!this.controller.isReady())return!1;if(this.controller instanceof Controllers.Model){if(notSimilarVector3(this.camera.pose.offset,this.state.offset)){var u={longitude:this.state.longitude,latitude:this.state.latitude,fov:this.state.fov,offset:this.state.offset};return this.controller.moveToPosition(this.state.offset,__assign(__assign({},u),{duration:i?0:void 0}),!1),!0}}else{var l={workCode:this.state.workCode,panoIndex:this.state.panoIndex};if(!panoEqual(l,this.pano)&&"moveToPano"in this.controller&&typeof this.controller.moveToPano=="function"){var u={longitude:this.state.longitude,latitude:this.state.latitude,fov:this.state.fov,offset:this.state.offset,distance:this.state.distance};return this.controller.moveToPano(l,u,!1),!0}}if(this.controller instanceof Controllers.Floorplan||this.controller instanceof Controllers.Topview||this.controller instanceof Controllers.Mapview){var d=1,c=.2,f=.2,h=Math.PI/45,v=i?this.state.fov:stepNumber(this.camera.pose.fov,this.state.fov,d),A=Math.abs(this.camera.pose.distance-this.state.distance),m=A>f*15?A/15:c,y=i?this.state.distance:stepNumber(this.camera.pose.distance,this.state.distance,m),p=this.camera.pose.offset.distanceTo(this.state.offset),g=p>f*15?p/15:f,b=i?new THREE__namespace.Vector3().copy(this.state.offset):stepVector(this.camera.pose.offset,this.state.offset,g),T=i?{longitude:this.state.longitude,latitude:this.state.latitude}:stepCoordinates({longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude},{longitude:this.state.longitude,latitude:this.state.latitude},h),_=T.longitude,w=T.latitude;if(notSimilarValue(v,this.camera.pose.fov)||notSimilarVector3(b,this.camera.pose.offset)||notSimilarValue(y,this.camera.pose.distance)||notSimilarValue(_,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(w,this.camera.pose.latitude)){var x={x:b.x,y:b.y,z:b.z},M={fov:v};return Object.assign(x,{distance:y}),Object.assign(M,{longitude:_,latitude:w}),this.controller.stopMomentumMovement(),this.controller.cameraMotion.set(M,0).catch(noop$1),this.controller.locationMotion.set(x,0).catch(noop$1),!0}}else{var R=1,I=Math.PI/45,v=i?this.state.fov:stepNumber(this.camera.pose.fov,this.state.fov,R),S=i?{longitude:this.state.longitude,latitude:this.state.latitude}:stepCoordinates({longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude},{longitude:this.state.longitude,latitude:this.state.latitude},I),_=S.longitude,w=S.latitude;if(notSimilarValue(_,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(w,this.camera.pose.latitude)||notSimilarValue(v,this.camera.pose.fov))return this.controller.stopMomentumMovement(),this.controller.cameraMotion.set({longitude:_,latitude:w,fov:v},0).catch(noop$1),!0}if(this.stateSynced=!0,o===!1&&this.emit("state.synced",createEvent("state.synced",{userAction:!1,state:this.state})),this.readyCallbacks.length&&this.stateSynced){var B=this.currentMode,O=B===t.Mode.Floorplan||B===t.Mode.Topview||B===t.Mode.Mapview||B===t.Mode.Model;if(!O||this.models.loaded){var F=this.readyCallbacks.slice();this.readyCallbacks.length=0;for(var H=0,k=F;H<k.length;H++){var N=k[H];this.controller instanceof Controllers.Panorama&&N.tile===!0&&!this.controller.isTileReady()?this.readyCallbacks.push(N):N()}}}return!1},t.prototype.ready=function(e){var r=this;return e===void 0&&(e={}),new Promise(function(i){var o;r.readyCallbacks.push(Object.assign(i,{tile:(o=e.tile)!==null&&o!==void 0?o:!1}))})},t.prototype.requestFullscreen=function(){var e;if(isMobile()){var r=(e=this.getElement())===null||e===void 0?void 0:e.parentNode;r&&"requestFullscreen"in r&&typeof document<"u"&&document.fullscreenElement===null&&r.requestFullscreen()}},t.prototype.exitFullscreen=function(){typeof document<"u"&&document.fullscreenElement&&"exitFullscreen"in document&&document.exitFullscreen()},t.prototype.throwError=function(e){this.hasListener("error")?this.emit("error",e):console.error(e)},t.prototype.loadModel=function(e){for(var r=this,i=[],o=function(m){var y=s.models.filter(function(g){var b;return((b=g.work)===null||b===void 0?void 0:b.workCode)===m.workCode})[0];if(y)y.work=m,i.push(y);else{var p=new Model({coordinatesSystemTransformers:s.coordinatesSystemTransformers,onError:function(g){r.emit("model.error",createEvent("model.request",{work:m,model:p,error:g}))},onShownFloorChange:function(g){r.emit("model.changeShownFloor",createEvent("model.request",{work:m,model:p,error:null}))},onLoad:function(){r.emit("model.load",createEvent("model.request",{work:m,model:p,error:null}))}});i.push(p),s.emit("model.request",createEvent("model.request",{work:m,model:p,error:null})),p.load(m,{textureOptions:s.textureOptions})}},s=this,u=0,l=e;u<l.length;u++){var d=l[u];o(d)}if(this.models.length>0){for(var c=0,f=this.models;c<f.length;c++){var h=f[c];i.indexOf(h)===-1&&this.lastModels.push(h)}this.models.length=0}for(var v=0,A=i;v<A.length;v++){var h=A[v];this.models.push(h)}return this.renderer&&(this.models.loaded=!1),new Promise(function(m){r.on("models.load",function(){m()})})},t.prototype.commonParams=function(){return{ident:this.ident,scene:this.scene,xrCustomObjectsScene:this.xrCustomObjectsScene,helper:this.helperGroup,boundingMesh:this.boundingMesh,camera:this.camera,renderer:this.renderer,scissor:this.scissor,element:this.getElement(),models:this.models,works:this.works,imageOptions:this.imageOptions,enableWheel:this.enableWheel,enableIOSEDR:this._enableIOSEDR,enableEDL:this.enableEDL,enableHQ:this.enableHQ,extraElements:this.extraElements,videoTexture:this.videoTexture}},t.prototype.applyController=function(e,r){var i=this;if(!this.renderer)throw new Error("renderer is not initialized.");e!==t.Mode.Mapview&&(this.enableEDL=!1,this.enableHQ=!1);var o=Controllers[e];if(e!==this.currentMode)for(var s=0,u=this.models;s<u.length;s++){var l=u[s];l.show()}this.currentMode=e;for(var d=new o(r),c=function(y){d.on(y,function(){for(var p=[],g=0;g<arguments.length;g++)p[g]=arguments[g];var b=i.emit.apply(i,__spreadArray([y],p,!1));if(b)return!1})},f=0,h=PROXY_CONTROLLER_EVENT_NAMES;f<h.length;f++){var v=h[f];c(v)}{var A=Controllers[e].initAnimationEndState(r),m=r.initial.userAction;stateEqual(this.state,A)||(assignState(this.state,A),this.emit("state.change",createEvent("state.change",{userAction:m,state:this.state}))),this.emit("currentState.change",createEvent("currentState.change",{userAction:m,state:this.getCurrentState()}))}return d.on("camera.update",function(y){var p;if(i.controller){var g=i.controller.getTargetState();y.userAction&&i.syncingState===!1&&i.state.mode===g.mode&&!stateEqual(i.state,g)&&(assignState(i.state,g),i.emit("state.change",createEvent("state.change",{userAction:y.userAction,state:i.state})),(p=i.analysis)===null||p===void 0||p.state(i.works,i.state))}i.emit("currentState.change",createEvent("currentState.change",{userAction:y.userAction,state:i.getCurrentState()}))}),d.on("initAnimation.start",function(y){var p,g=y.state,b=y.userAction;b&&i.state.mode===g.mode&&!stateEqual(i.state,g)&&(assignState(i.state,g),i.emit("state.change",createEvent("state.change",{userAction:b,state:i.state})),(p=i.analysis)===null||p===void 0||p.state(i.works,i.state))}),d.on("initAnimation.end",function(y){var p,g=y.state,b=y.userAction;b&&i.state.mode===g.mode&&!stateEqual(i.state,g)&&(assignState(i.state,g),i.emit("state.change",createEvent("state.change",{userAction:b,state:i.state})),(p=i.analysis)===null||p===void 0||p.state(i.works,i.state))}),d.on("pano.moveTo",function(y){var p,g=y.state,b=y.userAction;i.pano={workCode:g.workCode,panoIndex:g.panoIndex},b&&i.state.mode===g.mode&&!stateEqual(i.state,g)&&(assignState(i.state,g),i.emit("state.change",createEvent("state.change",{userAction:b,state:i.state})),(p=i.analysis)===null||p===void 0||p.state(i.works,i.state))}),d.on("pano.arrived",function(y){var p,g=y.state,b=y.userAction;b&&i.state.mode===g.mode&&!stateEqual(i.state,g)&&(assignState(i.state,g),i.emit("state.change",createEvent("state.change",{userAction:b,state:i.state})),(p=i.analysis)===null||p===void 0||p.state(i.works,i.state))}),d.on("pano.moveTo",function(y){var p=y.userAction;i.emit("currentState.change",createEvent("currentState.change",{userAction:p,state:i.getCurrentState()}))}),d.on("pano.request",function(y){i.emit("pano.request",y),y.defaultPrevented||i.moveToPano(y.state,y.options,y.userAction)}),d.on("vr.requestExit",function(){i.currentMode===t.Mode.VRPanorama&&(i.exitFullscreen(),i.changeMode(t.Mode.Panorama))}),d.on("error",function(y){return i.throwError(y)}),d},t.prototype.removeEventListeners=function(){},t.Mode={Panorama:"Panorama",Model:"Model",Floorplan:"Floorplan",Topview:"Topview",Mapview:"Mapview",DepthPanorama:"DepthPanorama",VRPanorama:"VRPanorama",XRPanorama:"XRPanorama"},t.Line=null,t}(Subscribe),__FIVE_DEBUG__={instances:{},constructor:Five};typeof window<"u"&&Object.assign(window,{__FIVE_DEBUG__});var XRButton=function(){function n(){}return n.createButton=function(t){var e=document.createElement("button");function r(){e.style.display="",e.style.cursor="pointer",e.style.left="calc(50% - 50px)",e.style.width="100px",e.textContent="ENTER VR",e.onmouseenter=function(){e.style.opacity="1.0"},e.onmouseleave=function(){e.style.opacity="0.5"},e.onclick=function(){t&&t()}}function i(){e.style.display="",e.style.cursor="auto",e.style.left="calc(50% - 75px)",e.style.width="150px",e.onmouseenter=null,e.onmouseleave=null,e.onclick=null}function o(){i(),e.textContent="VR NOT SUPPORTED"}function s(l){l.style.position="absolute",l.style.bottom="20px",l.style.padding="12px 6px",l.style.border="1px solid #fff",l.style.borderRadius="4px",l.style.background="rgba(0,0,0,0.1)",l.style.color="#fff",l.style.font="normal 13px sans-serif",l.style.textAlign="center",l.style.opacity="0.5",l.style.outline="none",l.style.zIndex="999"}if("xr"in navigator)return e.id="VRButton",e.style.display="none",s(e),navigator.xr.isSessionSupported("immersive-vr").then(function(l){l?r():o()}),e;var u=document.createElement("a");return window.isSecureContext===!1?(u.href=document.location.href.replace(/^http:/,"https:"),u.innerHTML="WEBXR NEEDS HTTPS"):(u.href="https://immersiveweb.dev/",u.innerHTML="WEBXR NOT AVAILABLE"),u.style.left="calc(50% - 90px)",u.style.width="180px",u.style.textDecoration="none",s(u),u},n}();exports.AnimationFrameLoop=AnimationFrameLoop,exports.Camera=Camera,exports.Fetcher=Fetcher,exports.Five=Five,exports.InternalWebGLRenderer=InternalWebGLRenderer,exports.IntersectMesh=IntersectMesh,exports.Model=Model,exports.NetworkSubscribe=NetworkSubscribe,exports.PBMContainer=PBMContainer,exports.PBMGroup=PBMGroup,exports.PBMMesh=PBMMesh,exports.PBMMeshMaterial=PBMMeshMaterial,exports.PROXY_CONTROLLER_EVENT_NAMES=PROXY_CONTROLLER_EVENT_NAMES,exports.PanoCircleMesh=PanoCircleMesh,exports.PanoCircleMeshCustom=PanoCircleMeshCustom,exports.PanoCircleMeshSolid=PanoCircleMeshSolid,exports.RequestScheduler=RequestScheduler,exports.Scene=Scene,exports.Subscribe=Subscribe,exports.TextureLoader=TextureLoader,exports.Tile=Tile,exports.Tile3DModel=Tile3DModel,exports.TileCubeTextureTarget=TileCubeTextureTarget,exports.TileNode=TileNode,exports.Tileset=Tileset,exports.TilesetCache=TilesetCache,exports.TilesetTraverser=TilesetTraverser,exports.Work=Work,exports.XRButton=XRButton,exports.defaultImageURLTransform=imageURL,exports.defaultPbmParameters=defaultPbmParameters,exports.getViewportScale=getViewportScale,exports.imageSupport=imageSupport,exports.isPanoId=isPanoId,exports.loadAt3d=loadAt3d,exports.loadB3dm=loadB3dm,exports.loadDome=loadDome,exports.loadDomez=loadDomez,exports.loadPbm=loadPbm,exports.loadPnts=loadPnts,exports.panoEqual=panoEqual,exports.panoParse=panoParse,exports.panoStringify=panoStringify,exports.parseWork=parseWork,Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"})});
|