@realsee/five 6.8.0-alpha.22 → 6.8.0-alpha.24

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.
Files changed (181) hide show
  1. package/ai_guides/features/gesture.md +1 -1
  2. package/ai_guides/features/parameter.md +25 -1
  3. package/ai_guides/release_notes/6.8.md +18 -5
  4. package/docs/assets/hierarchy.js +1 -1
  5. package/docs/assets/navigation.js +1 -1
  6. package/docs/assets/search.js +1 -1
  7. package/docs/classes/five.AdaptiveLuminancePass.html +1 -1
  8. package/docs/classes/five.BoundingMesh.html +2 -2
  9. package/docs/classes/five.EyeDomeLightingPass.html +1 -1
  10. package/docs/classes/five.Five.html +15 -15
  11. package/docs/classes/five.FivePass.html +1 -1
  12. package/docs/classes/five.Model.html +1 -1
  13. package/docs/classes/five.ModelScene.html +1 -1
  14. package/docs/classes/five.NetworkSubscribe.html +4 -4
  15. package/docs/classes/five.PBMContainer.html +1 -1
  16. package/docs/classes/five.PBMCustomShader.html +5 -5
  17. package/docs/classes/five.PBMGSObject.html +1 -1
  18. package/docs/classes/five.PBMGroup.html +1 -1
  19. package/docs/classes/five.PBMMesh.html +1 -1
  20. package/docs/classes/five.PBMMeshMaterial.html +1 -1
  21. package/docs/classes/five.PBMPanoFilter.html +5 -5
  22. package/docs/classes/five.PBMPointCloud.html +1 -1
  23. package/docs/classes/five.PBMPointCloudMaterial.html +1 -1
  24. package/docs/classes/five.PBMSkinnedMesh.html +1 -1
  25. package/docs/classes/five.PBMUpdateable.html +5 -5
  26. package/docs/classes/five.PanoCircleMesh.html +1 -1
  27. package/docs/classes/five.PanoCircleMeshCustom.html +1 -1
  28. package/docs/classes/five.PanoCircleMeshSolid.html +1 -1
  29. package/docs/classes/five.Parameter.html +7 -7
  30. package/docs/classes/five.Subscribe.html +5 -5
  31. package/docs/classes/five.Tile3D.html +22 -22
  32. package/docs/classes/five.TileNode.html +1 -1
  33. package/docs/classes/five.TrajectoryNode.html +1 -1
  34. package/docs/classes/five.Work.html +16 -16
  35. package/docs/classes/five.WorkResolvedObserver.html +22 -22
  36. package/docs/classes/gltf-loader.DDSLoader.html +1 -1
  37. package/docs/classes/gltf-loader.DRACOLoader.html +1 -1
  38. package/docs/classes/gltf-loader.GLTFObject.html +1 -1
  39. package/docs/classes/gltf-loader.THREEGLTFLoader.html +1 -1
  40. package/docs/classes/line.LineGeometry.html +1 -1
  41. package/docs/classes/line.LineMaterial.html +1 -1
  42. package/docs/classes/line.LineSegmentsGeometry.html +1 -1
  43. package/docs/classes/line.THREE_Line2.html +1 -1
  44. package/docs/classes/line.THREE_LineSegments2.html +1 -1
  45. package/docs/classes/plugins.RoundedBoxGeometry.html +1 -1
  46. package/docs/classes/vfx.Airflow.html +1 -1
  47. package/docs/classes/vfx.Flame.html +1 -1
  48. package/docs/classes/vfx.Particle.html +1 -1
  49. package/docs/classes/vfx.ParticleGPU.html +1 -1
  50. package/docs/classes/vfx.SpotLight.html +1 -1
  51. package/docs/documents/features_gesture.html +1 -1
  52. package/docs/documents/features_parameter.html +10 -2
  53. package/docs/documents/release_notes_6.8.html +18 -5
  54. package/docs/functions/five.parseWork.html +1 -1
  55. package/docs/functions/vue.useFiveWorks.html +2 -2
  56. package/docs/hierarchy.html +1 -1
  57. package/docs/interfaces/five.AddableObject.html +1 -1
  58. package/docs/interfaces/five.AjaxOptions.html +1 -1
  59. package/docs/interfaces/five.BaseEvent.html +7 -2
  60. package/docs/interfaces/five.EventCallback.html +6 -6
  61. package/docs/interfaces/five.GestureEvent.html +21 -2
  62. package/docs/interfaces/five.GesturePointer.html +20 -0
  63. package/docs/interfaces/five.ImageOptions.html +1 -1
  64. package/docs/interfaces/five.IntersectEvent.html +10 -2
  65. package/docs/interfaces/five.IntersectMesh.html +1 -1
  66. package/docs/interfaces/five.IntersectMeshInterface.html +1 -1
  67. package/docs/interfaces/five.Intersection.html +1 -1
  68. package/docs/interfaces/five.LooseWorkWithExtrinsics.html +6 -6
  69. package/docs/interfaces/five.ModeChangeEvent.html +9 -2
  70. package/docs/interfaces/five.ModelControllerCustomInitArgs.html +1 -1
  71. package/docs/interfaces/five.ModelEvent.html +7 -2
  72. package/docs/interfaces/five.ModelSceneEvent.html +7 -2
  73. package/docs/interfaces/five.ModelTileEvent.html +7 -2
  74. package/docs/interfaces/five.MovePanoOptions.html +1 -1
  75. package/docs/interfaces/five.NetworkAbortError.html +1 -1
  76. package/docs/interfaces/five.NetworkFirbiddenError.html +1 -1
  77. package/docs/interfaces/five.NetworkOptions.html +1 -1
  78. package/docs/interfaces/five.NetworkProxyError.html +1 -1
  79. package/docs/interfaces/five.NetworkResourceEvent.html +7 -2
  80. package/docs/interfaces/five.NetworkResponseError.html +1 -1
  81. package/docs/interfaces/five.NetworkTimeoutError.html +1 -1
  82. package/docs/interfaces/five.ObjectEvent.html +7 -2
  83. package/docs/interfaces/five.PBMMaterial.html +1 -1
  84. package/docs/interfaces/five.PBMMeshMaterialParameters.html +1 -1
  85. package/docs/interfaces/five.PBMPointCloudMaterialParameters.html +1 -1
  86. package/docs/interfaces/five.PanoCircleMeshInterface.html +1 -1
  87. package/docs/interfaces/five.PanoEvent.html +13 -2
  88. package/docs/interfaces/five.PanoTextureEvent.html +11 -2
  89. package/docs/interfaces/five.PanoramaControllerCustomInitArgs.html +1 -1
  90. package/docs/interfaces/five.PanoramaLikeControllerCustomInitArgs.html +1 -1
  91. package/docs/interfaces/five.ParameterMaterialValue.html +1 -1
  92. package/docs/interfaces/five.ParameterTilesetValue.html +1 -1
  93. package/docs/interfaces/five.ParameterValue.html +1 -1
  94. package/docs/interfaces/five.Pose.html +1 -1
  95. package/docs/interfaces/five.RenderEvent.html +7 -2
  96. package/docs/interfaces/five.ResolvedParameterValue.html +4 -5
  97. package/docs/interfaces/five.State.html +1 -1
  98. package/docs/interfaces/five.StateEvent.html +9 -2
  99. package/docs/interfaces/five.TextureOptions.html +1 -1
  100. package/docs/interfaces/five.TopviewControllerCustomInitArgs.html +1 -1
  101. package/docs/interfaces/five.VRPanoramaControllerCustomInitArgs.html +1 -1
  102. package/docs/interfaces/five.ViewLayer.html +21 -21
  103. package/docs/interfaces/five.WorkCubeImage.html +3 -2
  104. package/docs/interfaces/five.WorkImage.html +6 -5
  105. package/docs/interfaces/five.WorkInitial.html +8 -8
  106. package/docs/interfaces/five.WorkModel.html +8 -8
  107. package/docs/interfaces/five.WorkModelLayer.html +6 -6
  108. package/docs/interfaces/five.WorkObserver.html +29 -29
  109. package/docs/interfaces/five.WorkObserverProto.html +26 -0
  110. package/docs/interfaces/five.WorkTile.html +6 -5
  111. package/docs/interfaces/five.WorkVideo.html +4 -4
  112. package/docs/interfaces/five.WorksEvent.html +7 -2
  113. package/docs/interfaces/five.XRControllerEvent.html +10 -2
  114. package/docs/interfaces/five.XRControllerState.html +8 -0
  115. package/docs/interfaces/five.XRGestureEvent.html +13 -2
  116. package/docs/interfaces/five.XRPanoramaControllerCustomInitArgs.html +1 -1
  117. package/docs/interfaces/five.XRSessionEvent.html +9 -2
  118. package/docs/interfaces/plugins.BackgroundPluginController.html +1 -1
  119. package/docs/interfaces/plugins.BackgroundPluginType.EventMap.html +1 -1
  120. package/docs/interfaces/plugins.DynamicPathLinePluginController.html +1 -1
  121. package/docs/interfaces/plugins.DynamicPathLinePluginType.EventMap.html +1 -1
  122. package/docs/interfaces/plugins.DynamicPathLinePluginType.State.html +1 -1
  123. package/docs/interfaces/plugins.ItemMaskController.html +1 -1
  124. package/docs/interfaces/plugins.ItemMaskPluginType.EventMap.html +1 -1
  125. package/docs/interfaces/plugins.ItemMaskPluginType.State.html +1 -1
  126. package/docs/interfaces/plugins.OrientationPluginController.html +1 -1
  127. package/docs/interfaces/plugins.OrientationPluginType.EventMap.html +1 -1
  128. package/docs/interfaces/plugins.OrientationPluginType.State.html +1 -1
  129. package/docs/interfaces/plugins.PanoAnimeController.html +1 -1
  130. package/docs/interfaces/plugins.PanoAnimePluginType.EventMap.html +1 -1
  131. package/docs/interfaces/plugins.PanoAnimePluginType.State.html +1 -1
  132. package/docs/interfaces/plugins.PluginTemplateType.EventMap.html +1 -1
  133. package/docs/interfaces/plugins.PluginTemplateType.State.html +1 -1
  134. package/docs/interfaces/plugins.TrajectoryController.html +1 -1
  135. package/docs/interfaces/react.FiveInjectionTypes.html +15 -15
  136. package/docs/modules/five.html +1 -1
  137. package/docs/types/five.ControllerEventTypes.html +6 -6
  138. package/docs/types/five.ParseOptions.html +6 -6
  139. package/docs/variables/five.PROXY_CONTROLLER_EVENT_NAMES.html +1 -1
  140. package/five/application/events.d.ts +1 -1
  141. package/five/controllers/events.d.ts +2 -2
  142. package/five/index.d.ts +1 -1
  143. package/five/index.js +60 -60
  144. package/five/index.mjs +3897 -3890
  145. package/five/meshes/boundingMesh.d.ts +1 -0
  146. package/five/model/parameter.d.ts +5 -4
  147. package/five/model/tile3d/index.d.ts +1 -0
  148. package/five/utils/event.d.ts +84 -47
  149. package/five/utils/subscribe.d.ts +2 -2
  150. package/five/work/index.d.ts +1 -0
  151. package/five/work/work.d.ts +4 -34
  152. package/five/work/workObserverProto.d.ts +39 -0
  153. package/gltf-loader/index.js +3 -3
  154. package/gltf-loader/index.mjs +3 -3
  155. package/line/index.js +3 -3
  156. package/line/index.mjs +3 -3
  157. package/package.json +1 -1
  158. package/plugins/index.js +2 -2
  159. package/plugins/index.mjs +2 -2
  160. package/react/index.js +2 -2
  161. package/react/index.mjs +2 -2
  162. package/shader-lib/index.js +2 -2
  163. package/shader-lib/index.mjs +2 -2
  164. package/sticker/index.js +3 -3
  165. package/sticker/index.mjs +3 -3
  166. package/umd/five-gltf-loader.js +3 -3
  167. package/umd/five-line.js +3 -3
  168. package/umd/five-plugins.js +2 -2
  169. package/umd/five-react.js +2 -2
  170. package/umd/five-shader-lib.js +2 -2
  171. package/umd/five-sticker.js +3 -3
  172. package/umd/five-vfx.js +2 -2
  173. package/umd/five-vue.js +2 -2
  174. package/umd/five.js +12 -12
  175. package/vfx/index.js +2 -2
  176. package/vfx/index.mjs +2 -2
  177. package/vue/index.js +2 -2
  178. package/vue/index.mjs +2 -2
  179. package/work-downloader/index.js +2 -2
  180. package/work-downloader/index.mjs +2 -2
  181. package/five/work/workObserverUtils.d.ts +0 -36
package/umd/five.js CHANGED
@@ -1,8 +1,8 @@
1
1
  /**
2
2
  * @license
3
3
  * @realsee/five
4
- * Generated: 3/19/2026
5
- * Version: 6.8.0-alpha.22
4
+ * Generated: 3/27/2026
5
+ * Version: 6.8.0-alpha.24
6
6
  * Terms:
7
7
  * Realsee SDK License Agreement
8
8
  * Update: July 28, 2021
@@ -299,7 +299,7 @@
299
299
  `}else if(d===`subjectAltName`){var g=e(this.getExtSubjectAltName());o+=` `+g+`
300
300
  `}else if(d===`cRLDistributionPoints`){var _=this.getExtCRLDistributionPoints();o+=n(_)}else if(d===`authorityInfoAccess`){var v=this.getExtAuthorityInfoAccess();o+=r(v)}else d===`certificatePolicies`&&(o+=t(this.getExtCertificatePolicies()))}}return o+=`signature algorithm: `+this.getSignatureAlgorithmName()+`
301
301
  `,o+=`signature: `+this.getSignatureValueHex().substr(0,16)+`...
302
- `,o},typeof e==`string`&&(e.indexOf(`-----BEGIN`)==-1?KJUR.lang.String.isHex(e)&&this.readCertHex(e):this.readCertPEM(e))}X509.hex2dn=function(e,t){t===void 0&&(t=0);var n=new X509;return ASN1HEX.getTLV(e,t),n.getX500Name(e).str},X509.hex2rdn=function(e,t){if(t===void 0&&(t=0),e.substr(t,2)!==`31`)throw Error(`malformed RDN`);for(var n=[],r=ASN1HEX.getChildIdx(e,t),o=0;o<r.length;o++)n.push(X509.hex2attrTypeValue(e,r[o]));return n=n.map(function(e){return e.replace(`+`,`\\+`)}),n.join(`+`)},X509.hex2attrTypeValue=function(e,t){var n=ASN1HEX,r=n.getV;if(t===void 0&&(t=0),e.substr(t,2)!==`30`)throw Error(`malformed attribute type and value`);var o=n.getChildIdx(e,t);o.length!==2||e.substr(o[0],2);var s=r(e,o[0]),c=KJUR.asn1.ASN1Util.oidHexToInt(s),l=KJUR.asn1.x509.OID.oid2atype(c),u=hextorstr(r(e,o[1]));return l+`=`+u},X509.getPublicKeyFromCertHex=function(e){var t=new X509;return t.readCertHex(e),t.getPublicKey()},X509.getPublicKeyFromCertPEM=function(e){var t=new X509;return t.readCertPEM(e),t.getPublicKey()},X509.getPublicKeyInfoPropOfCertPEM=function(e){var t=ASN1HEX.getVbyList,n={},r,o;return n.algparam=null,r=new X509,r.readCertPEM(e),o=r.getPublicKeyHex(),n.keyhex=t(o,0,[1],`03`).substr(2),n.algoid=t(o,0,[0,0],`06`),n.algoid===`2a8648ce3d0201`&&(n.algparam=t(o,0,[0,1],`06`)),n},X509.KEYUSAGE_NAME=[`digitalSignature`,`nonRepudiation`,`keyEncipherment`,`dataEncipherment`,`keyAgreement`,`keyCertSign`,`cRLSign`,`encipherOnly`,`decipherOnly`];function sha256(e){return CryptoJS.SHA256(e).toString()}var certificates=[(()=>{let e=new X509;return e.readCertPEM(function(...e){let t=113,n=126,r=0,o=``;return arguments[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}(":::::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:::::")),e})()];function getCertificateBySubjectHex(e,t){for(let n of t)if(n.getSubjectHex()===e)return n}function verifyCertificate_(e,t){let n=e.getIssuerHex();if(n===e.getSubjectHex())return e.verifySignature(e.getPublicKey());let r=getCertificateBySubjectHex(n,t);return!r||e.verifySignature(r.getPublicKey())===!1?!1:verifyCertificate_(r,t)}function verifyCertificate(e){return e.getIssuerHex()===e.getSubjectHex()?!1:verifyCertificate_(e,certificates)}function addCertificate(e){let t=new X509;typeof e==`string`?t.readCertPEM(e):t.readCertHex(e.hex);let n=verifyCertificate(t);return certificates.push(t),n}function verifyMessage(e,t,n){let r=new X509;if(typeof n==`string`?r.readCertPEM(n):r.readCertHex(n.hex),verifyCertificate(r)===!1)return!1;let o=new RSAKey;return o.readCertPubKeyHex(r.hex,6),!!o.verify(e,b64tohex(t))}addCertificate(function(...e){let t=113,n=126,r=0,o=``;return arguments[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}(":::::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 PBMGroup=class extends three.Group{},vertex_default$5=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("n\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{H0v{pyqr-Ip|zz|{K0v{pyqr-Iz|}untrl}nlrr\x07K0v{pyqr-Ixv{{v{tl}nlrr\x07K0v{pyqr-Iy|tqr}uosl}nlrr\x07K0v{pyqr-Ipyv}}v{tl}yn{rl}nlrr\x07KZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--0v{pyqr-Ixv{onrlrr\x07K--0v{pyqr-Iortv{lrr\x07K--0v{pyqr-Iz|}untrlrr\x07K--0v{pyqr-Ixv{{v{tlrr\x07K--0v{pyqr-I}|wrplrr\x07K--0v{pyqr-Iy|tqr}uoslrr\x07K--0v{pyqr-Ipyv}}v{tl}yn{rlrr\x07K--Sv{ny]|vv|{-J-rpA5n{s|zrq9->;=6H--0vsqrs-b`RlV[`aN[PV[T----Sv{ny]|vv|{-J-v{n{prZnv\x07-7-Sv{ny]|vv|{H--0r{qvs--Sv{ny]|vv|{-J-z|qryZnv\x07-7-Sv{ny]|vv|{H--zn@-pnzrn_|nv|{Znv\x07-J-zn@5vrZnv\x07h=jh=j9-vrZnv\x07h>jh=j9-vrZnv\x07h?jh=j9-vrZnv\x07h=jh>j9-vrZnv\x07h>jh>j9-vrZnv\x07h?jh>j9-vrZnv\x07h=jh?j9-vrZnv\x07h>jh?j9-vrZnv\x07h?jh?j6H--PnzrnQvrpv|{-J-{|znyv r5pnzrn_|nv|{Znv\x07-7-rp@5=;=9-=;=9-:>;=66H--0v{pyqr-I|yq}|lrr\x07K--0v{pyqr-Is|tlrr\x07K--ZNV[lR[Q\f"),fragment_default$5=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-OYNPXlP\\Y\\_-rpA5=;=EC9-=;>=C9-=;>AF9->;=60qrsv{r-a_N[`]N_R[alP\\Y\\_-rpA5=;=9-=;=9-=;=9-=;=60qrsv{r-SYV]lPbORlZN]-:>;=p-]n{|-\n--nz}yrPor-zn}H--sy|n-zn}`v rH--rpA-zn}Uv|tnzH-<<-}rnx-zrn{-zv{-zn\x07--znA-znv\x07H--sy|n- ||zH\fH{vs|z-]n{|-}n{|=H{vs|z-]n{|-}n{|>H0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--p-Svyr]nnz-\n----sy|n-nnv|{`nnv|{OvnH----sy|n-p|{nP|{nOvnH----nz}yr?Q-uvtuyvtu`unq|YZn}H----sy|n-p|y|arz}rnrOvnH----sy|n-p|y|av{OvnH--\fH--{vs|z-Svyr]nnz-}n{|SvyrH0r{qvsp-_rsv{rq`prr{-\n--nz}yr?Q-zn}H--znA-}|wrpv|{Znv\x07H--znA-znv\x07V{rrH--sy|n-|}npv\bH--sy|n-}n{|H\fH{vs|z-_rsv{rq`prr{-rsv{rq`prr{H{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-}|trHn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{H{vs|z-sy|n-u|{Sy||V{qr\x07H{vs|z-rp?-r|yv|{H{vs|z-sy|n-}v\x07ry_nv|H0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-Iqvurv{tl}nlsntzr{K0v{pyqr-Is|tl}nlsntzr{K0v{pyqr-I}rpynzn}l}nlsntzr{K0v{pyqr-Iy|tqr}uosl}nlsntzr{K0v{pyqr-Ipyv}}v{tl}yn{rl}nlsntzr{Krp@- ||zcrp|5rp@-qvrpv|{9-rp@-rp|9-sy|n- ||z6-\n--sy|n-urn-J-q|5qvrpv|{9-rp|6H--rp@-q-J-qvrpv|{-7-urnH--rp@-}-J-rp|-:-qH--rp@-\0-J-}-<- ||zH--r{-{|znyv r5q-8-\x006H\frp@-to?u5rp@-p6-\n--rpA-X-J-rpA5=;=9-:>;=-<-@;=9-?;=-<-@;=9-:>;=6H--rpA-}-J-zv\x075rpA5p;ot9-X; 69-rpA5p;to9-X;\x07\b69-r}5p;o9-p;t66H--rpA-\0-J-zv\x075rpA5};\x07\b9-p;69-rpA5p;9-};\b \x0769-r}5};\x079-p;66H--sy|n-q-J-\0;\x07-:-zv{5\0;9-\0;\b6H--sy|n-r-J->;=r:>=H--r{-rp@5no5\0; -8-5\0;-:-\0;\b6-<-5C;=-7-q-8-r669-q-<-5\0;\x07-8-r69-\0;\x076H\frp@-u?to5rp@-p6-\n--rpA-X-J-rpA5>;=9-?;=-<-@;=9->;=-<-@;=9-@;=6H--rp@-}-J-no5snp5p;\x07\x07\x07-8-X;\x07\b 6-7-C;=-:-X;6H--r{-p; -7-zv\x075X;\x07\x07\x079-pynz}5}-:-X;\x07\x07\x079-=;=9->;=69-p;\b6H\f0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--rp@-svyrUvtuyvtu`unq|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-u-J-to?u5p|y|6H----u; -J-r\x07r?Q5}n{|Svyr;uvtuyvtu`unq|YZn}9-rp?5u; 9-=;=66;H----p|y|-J-u?to5u6H----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|arz}rnr5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-rz}rnrOvn-J-pynz}5}n{|Svyr;p|y|arz}rnrOvn9-:>==;=9->==;=6H----sy|n-`pnyr-J->;=-8-rz}rnrOvn-<-@==;=H----sy|n-o`pnyr-J->;=-:-rz}rnrOvn-<-@==;=H----p|y|;-J-p|y|;-7-`pnyrH----p|y|;o-J-p|y|;o-7-o`pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|av{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-v{Ovn-J-pynz}5}n{|Svyr;p|y|av{Ovn9-:>==;=9->==;=6H----rp@-pnyr-J-rp@5>;=6H----vs-5v{Ovn-K-=;=6-\n------pnyr;t-J->;=-:-v{Ovn-<-?==;=H----\f-ryr-\n------pnyr;-J->;=-8-v{Ovn-7-=;B-<-?==;=H------pnyr;t-J->;=-:-v{Ovn-7-=;B-<-?==;=H------pnyr;o-J->;=-8-v{Ovn-7-=;B-<-?==;=H----\f----p|y|-7J-pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrP|y|arz}rnr5to9-uv|tnz6H----to-J-svyrP|y|av{5to9-uv|tnz6H----r{-toH--\f--rp@-svyrP|{n5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-zrn{cny-J-uv|tnzh>jH----sy|n-zv{cny-J-uv|tnzh?jH----sy|n-zn\x07cny-J-uv|tnzh@jH----sy|n-p|{nOvn-J-pynz}5}n{|Svyr;p|{nP|{nOvn9-:>;=9->;=6H----sy|n-rqOvn-J->;=-7-p|{nOvn-8->;=H----sy|n-ovn`\0nrunys-J-p|{nOvn-7-p|{nOvn-<-?;=H----sy|n-y|}ry|-J-5rqOvn-:->;=6-<-zrn{cnyH----sy|n-y|}ruvtu-J-5>;=-:-rqOvn6-<-5>;=-:-zrn{cny6H----sy|n-ovn-J-5rqOvn-:-zrn{cny6-<-5>;=-:-zrn{cny6H----sy|n-pnyrlsnp|-J->;=-<-5zn\x07cny-:-zv{cny6H----rp@-ny-J-p|y|H----sy|n-zn\x07lny-J-zn\x075zn\x075p|y|;9-p|y|;t69-p|y|;o6H----vs-5p|{nOvn-I-=;=6-\n------ny-J-ny-7-5>;=-:-ovn`\0nrunys6-8-zn\x07lny-7-ovn`\0nrunysH----\f----rp@-rzn}-J-rp@5------5ny;-I-zrn{cny6-L-y|}ry|-7-ny;-8->;=-G-y|}ruvtu-7-ny;-8-ovn9------5ny;t-I-zrn{cny6-L-y|}ry|-7-ny;t-8->;=-G-y|}ruvtu-7-ny;t-8-ovn9------5ny;o-I-zrn{cny6-L-y|}ry|-7-ny;o-8->;=-G-y|}ruvtu-7-ny;o-8-ovn----6H----rp@-|`pnyr-J-rzn}-7-pnyrlsnp|H----p|y|-J-5ny-:-zrn{cny6-7-|`pnyr-8-zrn{cnyH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyr`nnv|{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-nnv|{Ovn-J-pynz}5}n{|Svyr;nnv|{`nnv|{Ovn9-:>;=9->;=6H----sy|n-n`pnyr-J->;=-8-nnv|{OvnH----sy|n-yzv{n{pr-J-=;?FF-7-p|y|;-8-=;BED-7-p|y|;t-8-=;>>A-7-p|y|;oH----p|y|-J-5p|y|-:-yzv{n{pr6-7-n`pnyr-8-yzv{n{prH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-r\x07rpSvyr5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrUvtuyvtu`unq|5to9-uv|tnz6H----to-J-svyrP|y|5to9-uv|tnz6H----to-J-svyrP|{n5to9-uv|tnz6H----to-J-svyr`nnv|{5to9-uv|tnz6H----r{-toH--\f0r{qvsZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--0v{pyqr-Ipyv}}v{tl}yn{rlsntzr{K--0v{pyqr-Is|tlsntzr{K--0v{pyqr-I}rzyv}yvrqlny}unlsntzr{K--0v{pyqr-Iqvurv{tlsntzr{K--<<-JJJ-全景图-JJJ--rp@-}n{|=a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 6H--}n{|=a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|=a|crr\x079-}n{|=; ||z6H--}n{|=a|crr\x07-J-}n{|=a|crr\x07-7-zn@5}n{|=;znv\x076H--rp@-}n{|>a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 6H--}n{|>a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|>a|crr\x079-}n{|>; ||z6H--}n{|>a|crr\x07-J-}n{|>a|crr\x07-7-zn@5}n{|>;znv\x076H--rpA-}n{|=P|y|-J-r\x07rPor5}n{|=;zn}9-rp@5SYV]lPbORlZN]-7-}n{|=a|crr\x07;\x079-}n{|=a|crr\x07;\b 66H--rpA-}n{|>P|y|-J-r\x07rPor5}n{|>;zn}9-rp@5SYV]lPbORlZN]-7-}n{|>a|crr\x07;\x079-}n{|>a|crr\x07;\b 66H--<<-JJJ-全景图瓦片细化-JJJ--0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6----rpA-rsv{rqPnzrn]|v|{-J-rsv{rq`prr{;znv\x07V{rr-7-Sv{ny]|vv|{H----sy|n-rsv{rqg||z-J-zv\x075}n{|=; ||z9-}n{|>; ||z9-rsv{rq`prr{;}n{|6H----rp@-rsv{rqPnzrncrr\x07-J-{|znyv r5rsv{rqPnzrn]|v|{;\x07\b 6H----rsv{rqPnzrncrr\x07-J- ||zcrp|5rp@5=;=9-=;=9->;=69-rsv{rqPnzrncrr\x079-rsv{rqg||z6H----rpA-rsv{rq]|v|{-J-rsv{rq`prr{;}|wrpv|{Znv\x07-7-rpA5rsv{rqPnzrncrr\x079->;=6H----rsv{rq]|v|{-J-rsv{rq]|v|{-<-rsv{rq]|v|{;H----rpA-rsv{rqP|y|-J-r\x07r?Q5rsv{rq`prr{;zn}9-5rsv{rq]|v|{;\x07\b-8->;=6-<-?;=6H----rsv{rqP|y|;n-J-rsv{rqP|y|;n-7-rsv{rq`prr{;|}npv\bH----sy|n-rsv{rq\\rsy|]|tr-J-r}5no5rsv{rq]|v|{;\x0769->;=6-7-r}5no5rsv{rq]|v|{;\b69->;=6-7-r}5rsv{rqPnzrn]|v|{; 9-=;=6H----rsv{rqP|y|-J-zv\x075a_N[`]N_R[alP\\Y\\_9-rsv{rqP|y|9-rsv{rq\\rsy|]|tr6H----rpA-rsv{rq]n{|=P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9-rsv{rq`prr{;}n{|6H----rpA-rsv{rq]n{|>P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9->;=-:-rsv{rq`prr{;}n{|6H----}n{|=P|y|-J-zv\x075}n{|=P|y|9-rpA5rsv{rq]n{|=P|y|;to9-}n{|=P|y|;n69-rsv{rq]n{|=P|y|;n6H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-rpA5rsv{rq]n{|>P|y|;to9-}n{|>P|y|;n69-rsv{rq]n{|>P|y|;n6H--0r{qvs--<<-JJJ-全景图滤镜-JJJ--0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6----}n{|=P|y|;to-J-r\x07rpSvyr5}n{|=P|y|;to9-}n{|=;zn}Uv|tnz6H----}n{|>P|y|;to-J-r\x07rpSvyr5}n{|>P|y|;to9-}n{|>;zn}Uv|tnz6H--0r{qvs--ZNV[l]N[\\lP\\Y\\_--<<-JJJ-全景图颜色混合-JJJ--rpA-}n{|P|y|H--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-:-]V-8->;=66H--0ryvs-qrsv{rq5b`Rl`]_RNQla_N[`VaV\\[6----rp?-prr{Pr{rP||q-J-r|yv|{-7-}v\x07ry_nv|-<-?;=H----sy|n-n{vv|{_nqv-J-qvn{pr5rp?5=;=9-=;=69-prr{Pr{rP||q6-7->;?H----sy|n-n{vv|{]|tr-J--qvn{pr5tylSntP||q;\x07\b9-prr{Pr{rP||q6-<-n{vv|{_nqvH----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-z||ur}5=;=9-=;?9-}|tr-:-n{vv|{]|tr66H--0ryr----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-}|tr6H--0r{qvs--tylSntP|y|-J-zv\x075}n{|P|y|9-rpA5}n{|P|y|;to9-=;=69-pynz}5z|qryNy}un-7-@=;=9-=;=9->;=66H--<<-JJJJJJJJJJJJJJJJ--ZNV[lR[Q\f"),vertex_default$4=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-ZN_Xl`aR]->;=0qrsv{r-_\\\\SlZN_X->;=nvor-sy|n-lsrnrlvqlznxHn\bv{t-sy|n-_||sZnxHn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-rp@-cvr]|vv|{H{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rH0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-Il}nlrr\x07K0v{pyqr-I?l}nlrr\x07K0v{pyqr-Ir{zn}l}nlrr\x07K0v{pyqr-Ip|y|l}nlrr\x07K0v{pyqr-Is|tl}nlrr\x07K0v{pyqr-Iz|}untrl}nlrr\x07K0v{pyqr-Ixv{{v{tl}nlrr\x07K0v{pyqr-Iy|tqr}uosl}nlrr\x07K0v{pyqr-Ipyv}}v{tl}yn{rl}nlrr\x07KZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--0v{pyqr-Ilrr\x07K--0v{pyqr-I?lrr\x07K--0v{pyqr-Ip|y|lrr\x07K--0v{pyqr-Ixv{onrlrr\x07K--0v{pyqr-Iortv{{|znylrr\x07K--0v{pyqr-Iz|}u{|znylrr\x07K--0v{pyqr-Ixv{{|znylrr\x07K--0v{pyqr-Iqrsny{|znylrr\x07K--0vs{qrs-SYNal`UNQRQ-<<-[|zny-p|z}rq-vu-qrvnvr-ur{-SYNal`UNQRQ--[|zny-J-{|znyv r5-n{s|zrq[|zny-6H--0r{qvs--0v{pyqr-Iortv{lrr\x07K--0v{pyqr-Iz|}untrlrr\x07K--0v{pyqr-Ixv{{v{tlrr\x07K--0v{pyqr-I}|wrplrr\x07K--0v{pyqr-Iy|tqr}uoslrr\x07K--0v{pyqr-Ipyv}}v{tl}yn{rlrr\x07K--cvr]|vv|{-J-:z]|vv|{;\x07\b H--Sv{ny]|vv|{-J-rpA5n{s|zrq9->;=6H--0vsqrs-b`RlV[`aN[PV[T----Sv{ny]|vv|{-J-v{n{prZnv\x07-7-Sv{ny]|vv|{H--0r{qvs--Sv{ny]|vv|{-J-z|qryZnv\x07-7-Sv{ny]|vv|{H--zn@-pnzrn_|nv|{Znv\x07-J-zn@5vrZnv\x07h=jh=j9-vrZnv\x07h>jh=j9-vrZnv\x07h?jh=j9-vrZnv\x07h=jh>j9-vrZnv\x07h>jh>j9-vrZnv\x07h?jh>j9-vrZnv\x07h=jh?j9-vrZnv\x07h>jh?j9-vrZnv\x07h?jh?j6H--PnzrnQvrpv|{-J-{|znyv r5pnzrn_|nv|{Znv\x07-7-rp@5=;=9-=;=9-:>;=66H--_||sZnx-J-=;=H--0vs-qrsv{rq5b`RlcR_aRelZN_X6----_||sZnx-J-z||ur}5_\\\\SlZN_X-:-ZN_Xl`aR]9-_\\\\SlZN_X9-lsrnrlvqlznx6H--0r{qvs--0v{pyqr-I|yq}|lrr\x07K--0v{pyqr-Ir{zn}lrr\x07K--0v{pyqr-Is|tlrr\x07K--ZNV[lR[Q\f"),fragment_default$4=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-OYNPXlP\\Y\\_-rpA5=;=EC9-=;>=C9-=;>AF9->;=60qrsv{r-a_N[`]N_R[alP\\Y\\_-rpA5=;=9-=;=9-=;=9-=;=60qrsv{r-SYV]lPbORlZN]-:>;=p-]n{|-\n--nz}yrPor-zn}H--sy|n-zn}`v rH--rpA-zn}Uv|tnzH-<<-}rnx-zrn{-zv{-zn\x07--znA-znv\x07H--sy|n- ||zH\fH{vs|z-]n{|-}n{|=H{vs|z-]n{|-}n{|>H0vs-qrsv{rq5b`Rl]N[\\lQR]aU6--p-]n{|Qr}u-\n----nz}yrPor-zn}H----sy|n-zn\x07Qr}uH--\fH--{vs|z-]n{|Qr}u-}n{|=Qr}uH--{vs|z-]n{|Qr}u-}n{|>Qr}uH0r{qvs0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--p-Svyr]nnz-\n----sy|n-nnv|{`nnv|{OvnH----sy|n-p|{nP|{nOvnH----nz}yr?Q-uvtuyvtu`unq|YZn}H----sy|n-p|y|arz}rnrOvnH----sy|n-p|y|av{OvnH--\fH--{vs|z-Svyr]nnz-}n{|SvyrH0r{qvs0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6--p-_rsv{rq`prr{-\n----nz}yr?Q-zn}H----znA-}|wrpv|{Znv\x07H----znA-znv\x07V{rrH----sy|n-|}npv\bH----sy|n-}n{|H--\fH--{vs|z-_rsv{rq`prr{-rsv{rq`prr{H0r{qvs{vs|z-sy|n-sy||V{qr\x07H{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-}|trH0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6--{vs|z-rp@-p|{n{P|y|H0r{qvs0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6--{vs|z-nz}yr?Q-tnqvr{ar\x07rH0r{qvsp-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{qvsn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-rp@-cvr]|vv|{Hn\bv{t-sy|n-_||sZnxH{vs|z-sy|n-u|{Sy||V{qr\x07H{vs|z-rp?-r|yv|{H{vs|z-sy|n-}v\x07ry_nv|H{vs|z-rp@-qvssrH{vs|z-sy|n-p|y|Ny}unH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-ovtu{rH{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rH0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-I}npxv{tK0v{pyqr-Iqvurv{tl}nlsntzr{K0v{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-Ir{zn}lp|zz|{l}nlsntzr{K0v{pyqr-Ir{zn}l}nlsntzr{K0v{pyqr-Iporllrsyrpv|{lsntzr{K0v{pyqr-Is|tl}nlsntzr{K0v{pyqr-I}rpynzn}l}nlsntzr{K0v{pyqr-Iy|tqr}uosl}nlsntzr{K0v{pyqr-Ipyv}}v{tl}yn{rl}nlsntzr{Krp@- ||zcrp|5rp@-qvrpv|{9-rp@-rp|9-sy|n- ||z6-\n--sy|n-urn-J-q|5qvrpv|{9-rp|6H--rp@-q-J-qvrpv|{-7-urnH--rp@-}-J-rp|-:-qH--rp@-\0-J-}-<- ||zH--r{-{|znyv r5q-8-\x006H\frp@-to?u5rp@-p6-\n--rpA-X-J-rpA5=;=9-:>;=-<-@;=9-?;=-<-@;=9-:>;=6H--rpA-}-J-zv\x075rpA5p;ot9-X; 69-rpA5p;to9-X;\x07\b69-r}5p;o9-p;t66H--rpA-\0-J-zv\x075rpA5};\x07\b9-p;69-rpA5p;9-};\b \x0769-r}5};\x079-p;66H--sy|n-q-J-\0;\x07-:-zv{5\0;9-\0;\b6H--sy|n-r-J->;=r:>=H--r{-rp@5no5\0; -8-5\0;-:-\0;\b6-<-5C;=-7-q-8-r669-q-<-5\0;\x07-8-r69-\0;\x076H\frp@-u?to5rp@-p6-\n--rpA-X-J-rpA5>;=9-?;=-<-@;=9->;=-<-@;=9-@;=6H--rp@-}-J-no5snp5p;\x07\x07\x07-8-X;\x07\b 6-7-C;=-:-X;6H--r{-p; -7-zv\x075X;\x07\x07\x079-pynz}5}-:-X;\x07\x07\x079-=;=9->;=69-p;\b6H\frp@-trP|y|O\bUrvtu5nz}yr?Q-tnqvr{ar\x07r9-rpA-Sv{ny]|vv|{6-\n--sy|n--J-5Sv{ny]|vv|{;\b-:-z|qryO|{qv{tZv{;\b6-<-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6H--r{-r\x07r?Q5tnqvr{ar\x07r9-rp?59-=;B66;toH\f0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--rp@-svyrUvtuyvtu`unq|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-u-J-to?u5p|y|6H----u; -J-r\x07r?Q5}n{|Svyr;uvtuyvtu`unq|YZn}9-rp?5u; 9-=;=66;H----p|y|-J-u?to5u6H----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|arz}rnr5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-rz}rnrOvn-J-pynz}5}n{|Svyr;p|y|arz}rnrOvn9-:>==;=9->==;=6H----sy|n-`pnyr-J->;=-8-rz}rnrOvn-<-@==;=H----sy|n-o`pnyr-J->;=-:-rz}rnrOvn-<-@==;=H----p|y|;-J-p|y|;-7-`pnyrH----p|y|;o-J-p|y|;o-7-o`pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|av{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-v{Ovn-J-pynz}5}n{|Svyr;p|y|av{Ovn9-:>==;=9->==;=6H----rp@-pnyr-J-rp@5>;=6H----vs-5v{Ovn-K-=;=6-\n------pnyr;t-J->;=-:-v{Ovn-<-?==;=H----\f-ryr-\n------pnyr;-J->;=-8-v{Ovn-7-=;B-<-?==;=H------pnyr;t-J->;=-:-v{Ovn-7-=;B-<-?==;=H------pnyr;o-J->;=-8-v{Ovn-7-=;B-<-?==;=H----\f----p|y|-7J-pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrP|y|arz}rnr5to9-uv|tnz6H----to-J-svyrP|y|av{5to9-uv|tnz6H----r{-toH--\f--rp@-svyrP|{n5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-zrn{cny-J-uv|tnzh>jH----sy|n-zv{cny-J-uv|tnzh?jH----sy|n-zn\x07cny-J-uv|tnzh@jH----sy|n-p|{nOvn-J-pynz}5}n{|Svyr;p|{nP|{nOvn9-:>;=9->;=6H----sy|n-rqOvn-J->;=-7-p|{nOvn-8->;=H----sy|n-ovn`\0nrunys-J-p|{nOvn-7-p|{nOvn-<-?;=H----sy|n-y|}ry|-J-5rqOvn-:->;=6-<-zrn{cnyH----sy|n-y|}ruvtu-J-5>;=-:-rqOvn6-<-5>;=-:-zrn{cny6H----sy|n-ovn-J-5rqOvn-:-zrn{cny6-<-5>;=-:-zrn{cny6H----sy|n-pnyrlsnp|-J->;=-<-5zn\x07cny-:-zv{cny6H----rp@-ny-J-p|y|H----sy|n-zn\x07lny-J-zn\x075zn\x075p|y|;9-p|y|;t69-p|y|;o6H----vs-5p|{nOvn-I-=;=6-\n------ny-J-ny-7-5>;=-:-ovn`\0nrunys6-8-zn\x07lny-7-ovn`\0nrunysH----\f----rp@-rzn}-J-rp@5------5ny;-I-zrn{cny6-L-y|}ry|-7-ny;-8->;=-G-y|}ruvtu-7-ny;-8-ovn9------5ny;t-I-zrn{cny6-L-y|}ry|-7-ny;t-8->;=-G-y|}ruvtu-7-ny;t-8-ovn9------5ny;o-I-zrn{cny6-L-y|}ry|-7-ny;o-8->;=-G-y|}ruvtu-7-ny;o-8-ovn----6H----rp@-|`pnyr-J-rzn}-7-pnyrlsnp|H----p|y|-J-5ny-:-zrn{cny6-7-|`pnyr-8-zrn{cnyH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyr`nnv|{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-nnv|{Ovn-J-pynz}5}n{|Svyr;nnv|{`nnv|{Ovn9-:>;=9->;=6H----sy|n-n`pnyr-J->;=-8-nnv|{OvnH----sy|n-yzv{n{pr-J-=;?FF-7-p|y|;-8-=;BED-7-p|y|;t-8-=;>>A-7-p|y|;oH----p|y|-J-5p|y|-:-yzv{n{pr6-7-n`pnyr-8-yzv{n{prH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-r\x07rpSvyr5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrUvtuyvtu`unq|5to9-uv|tnz6H----to-J-svyrP|y|5to9-uv|tnz6H----to-J-svyrP|{n5to9-uv|tnz6H----to-J-svyr`nnv|{5to9-uv|tnz6H----r{-toH--\f0r{qvsZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--<<-JJJ-楼层-JJJ--o||y-vPr{Sy||-J-u|{Sy||V{qr\x07-I-:=;=>-\v\v-no5sy||V{qr\x07-:-u|{Sy||V{qr\x076-I-=;FFH--sy|n-sy||\\}npv\b-J->;=H--vs-5.vPr{Sy||6-\n----0vs-qrsv{rq5b`RlSY\\\\_l`afYRlcV`VOVYVaf6------qvpnqH----0r{qvs----sy||\\}npv\b-J-pynz}5=;?-7-zv{55>;=-8-PnzrnQvrpv|{;\b69->;=69-=;=9->;=6H--\f--<<-JJJJJJJJJJJ--<<-JJJ-顶部裁切-JJJ--sy|n-||sP]|tr-J-}|5pynz}5:PnzrnQvrpv|{;\b9-=;=9->;=69-@;=6H--vs-5----_||sZnx-K-=;==>-33----Sv{ny]|vv|{;\b-K-z|qryO|{qv{tZn\x07;\b-:-||sP]|tr-7-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6--6-\n----qvpnqH--\f--<<-JJJJJJJJJJJJJJ--<<-JJJ-前置裁切计算-JJJ--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-Sv{ny]|vv|{H------pyv}}rq-J-5pyv}}rh-v-j;sy||V{qr\x07-I-=;=-\v\v-no5sy||V{qr\x07-:-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--<<-JJJJJJJJJJJJJJJJJJ--0v{pyqr-Ipyv}}v{tl}yn{rlsntzr{K--rpA-qvssrP|y|-J-rpA5-qvssr9-p|y|Ny}un-7-|}npv\b-6H--<<-JJJ-高度色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6----qvssrP|y|;to-J-trP|y|O\bUrvtu5tnqvr{ar\x07r9-Sv{ny]|vv|{6H--0r{qvs--<<-JJJJJJJJJJJ--<<-JJJ-纯色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6----qvssrP|y|;to-J-p|{n{P|y|H--0r{qvs--<<-JJJJJJJJJJJ--0v{pyqr-Iy|tqr}uoslsntzr{K--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--_rsyrprqYvtu-rsyrprqYvtu-J-_rsyrprqYvtu5-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-6-6H--<<-nppzynv|{-5onxrq-v{qvrp-yvtuv{t-|{y\b6--0vsqrs-b`RlYVTUaZN]----rpA-yvtuZn}ar\x07ryJ-r\x07r?Q5-yvtuZn}9-b?-6H----rsyrprqYvtu;v{qvrpQvssr-8J-yvtuZn}ar\x07rya|Yv{rn5-yvtuZn}ar\x07ry-6;to-7-yvtuZn}V{r{v\bH--0ryr----rsyrprqYvtu;v{qvrpQvssr-8J-rp@5->;=-6H--0r{qvs--<<-z|qynv|{--0v{pyqr-In|zn}lsntzr{K--rsyrprqYvtu;v{qvrpQvssr-7J-qvssrP|y|;toH--rp@-|t|v{tYvtu-J-rsyrprqYvtu;v{qvrpQvssrH--0v{pyqr-Ir{zn}lsntzr{K--qvssrP|y|;n-J-qvssrP|y|;n-7-sy||\\}npv\b-7-ovtu{rH--0vs-qrsv{rq5b`Rl\\]N^bR6----qvssrP|y|;n-J->;=H--0r{qvs--tylSntP|y|-J-rpA5-|t|v{tYvtu9-qvssrP|y|;n-6H--<<-JJJ-颜色增益调整-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNQWb`aZR[a6----rp@-uP|y|-J-to?u5tylSntP|y|;to6H----uP|y|;\b-8J-p|y|`nnv|{H----uP|y|; -8J-p|y|Ovtu{rH----tylSntP|y|;to-J-zn\x075u?to5uP|y|69-=;=6H--0r{qvs--<<-JJJJJJJJJJJJJJJJJJ--ZNV[lZ\\QRYlP\\Y\\_--<<色调映射-色彩空间转换--0v{pyqr-I|{rzn}}v{tlsntzr{K--0v{pyqr-Ir{p|qv{tlsntzr{K--0v{pyqr-Is|tlsntzr{K--0v{pyqr-I}rzyv}yvrqlny}unlsntzr{K--0v{pyqr-Iqvurv{tlsntzr{K--<<-JJJ-全景图-JJJ--rp@-}n{|=a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 6H--}n{|=a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|=a|crr\x079-}n{|=; ||z6H--}n{|=a|crr\x07-J-}n{|=a|crr\x07-7-zn@5}n{|=;znv\x076H--rp@-}n{|>a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 6H--}n{|>a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|>a|crr\x079-}n{|>; ||z6H--}n{|>a|crr\x07-J-}n{|>a|crr\x07-7-zn@5}n{|>;znv\x076H--rpA-}n{|=P|y|-J-r\x07rPor5}n{|=;zn}9-rp@5SYV]lPbORlZN]-7-}n{|=a|crr\x07;\x079-}n{|=a|crr\x07;\b 66H--rpA-}n{|>P|y|-J-r\x07rPor5}n{|>;zn}9-rp@5SYV]lPbORlZN]-7-}n{|>a|crr\x07;\x079-}n{|>a|crr\x07;\b 66H--<<-JJJ-全景图瓦片细化-JJJ--0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6----rpA-rsv{rqPnzrn]|v|{-J-rsv{rq`prr{;znv\x07V{rr-7-Sv{ny]|vv|{H----sy|n-rsv{rqg||z-J-zv\x075}n{|=; ||z9-}n{|>; ||z9-rsv{rq`prr{;}n{|6H----rp@-rsv{rqPnzrncrr\x07-J-{|znyv r5rsv{rqPnzrn]|v|{;\x07\b 6H----rsv{rqPnzrncrr\x07-J- ||zcrp|5rp@5=;=9-=;=9->;=69-rsv{rqPnzrncrr\x079-rsv{rqg||z6H----rpA-rsv{rq]|v|{-J-rsv{rq`prr{;}|wrpv|{Znv\x07-7-rpA5rsv{rqPnzrncrr\x079->;=6H----rsv{rq]|v|{-J-rsv{rq]|v|{-<-rsv{rq]|v|{;H----rpA-rsv{rqP|y|-J-r\x07r?Q5rsv{rq`prr{;zn}9-5rsv{rq]|v|{;\x07\b-8->;=6-<-?;=6H----rsv{rqP|y|;n-J-rsv{rqP|y|;n-7-rsv{rq`prr{;|}npv\bH----sy|n-rsv{rq\\rsy|]|tr-J-r}5no5rsv{rq]|v|{;\x0769->;=6-7-r}5no5rsv{rq]|v|{;\b69->;=6-7-r}5rsv{rqPnzrn]|v|{; 9-=;=6H----rsv{rqP|y|-J-zv\x075a_N[`]N_R[alP\\Y\\_9-rsv{rqP|y|9-rsv{rq\\rsy|]|tr6H----rpA-rsv{rq]n{|=P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9-rsv{rq`prr{;}n{|6H----rpA-rsv{rq]n{|>P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9->;=-:-rsv{rq`prr{;}n{|6H----}n{|=P|y|-J-zv\x075}n{|=P|y|9-rpA5rsv{rq]n{|=P|y|;to9-}n{|=P|y|;n69-rsv{rq]n{|=P|y|;n6H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-rpA5rsv{rq]n{|>P|y|;to9-}n{|>P|y|;n69-rsv{rq]n{|>P|y|;n6H--0r{qvs--<<-JJJ-全景图滤镜-JJJ--0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6----}n{|=P|y|;to-J-r\x07rpSvyr5}n{|=P|y|;to9-}n{|=;zn}Uv|tnz6H----}n{|>P|y|;to-J-r\x07rpSvyr5}n{|>P|y|;to9-}n{|>;zn}Uv|tnz6H--0r{qvs--ZNV[l]N[\\lP\\Y\\_--<<-JJJ-运动过程全景图通过深度剔除-JJJ--0vs-qrsv{rq5b`Rl]N[\\lQR]aU6----sy|n-}n{|=crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 69-=;=9-}n{|=Qr}u;zn\x07Qr}u6H----sy|n-}n{|>crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 69-=;=9-}n{|>Qr}u;zn\x07Qr}u6H----sy|n-}n{|=Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|=Qr}u;zn}9-}n{|=a|crr\x0766-7-}n{|=Qr}u;zn\x07Qr}uH----sy|n-}n{|>Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|>Qr}u;zn}9-}n{|>a|crr\x0766-7-}n{|>Qr}u;zn\x07Qr}uH----sy|n-}n{|=Qr}uQryn-J-no5}n{|=Qr}uZn}Qr}u-:-}n{|=crr\x07Qr}u6H----sy|n-}n{|>Qr}uQryn-J-no5}n{|>Qr}uZn}Qr}u-:-}n{|>crr\x07Qr}u6H----sy|n-zn\x07]n{|=Qr}uQryn-J-=;=@-7-}n{|=crr\x07Qr}uH----sy|n-zn\x07]n{|>Qr}uQryn-J-=;=@-7-}n{|>crr\x07Qr}uH----}n{|=P|y|-J-zv\x075}n{|=P|y|9-zv\x075}n{|=P|y|9-tylSntP|y|9-pynz}5}|tr-7->=;=9-=;=9->;=669-r}5zn\x07]n{|=Qr}uQryn9-}n{|=Qr}uQryn66H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-zv\x075}n{|>P|y|9-tylSntP|y|9-pynz}55>;=-:-}|tr6-7->=;=9-=;=9->;=669-r}5zn\x07]n{|>Qr}uQryn9-}n{|>Qr}uQryn66H--0r{qvs--<<-JJJ-全景图颜色混合-JJJ--rpA-}n{|P|y|H--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-:-]V-8->;=66H--0ryvs-qrsv{rq5b`Rl`]_RNQla_N[`VaV\\[6----rp?-prr{Pr{rP||q-J-r|yv|{-7-}v\x07ry_nv|-<-?;=H----sy|n-n{vv|{_nqv-J-qvn{pr5rp?5=;=9-=;=69-prr{Pr{rP||q6-7->;?H----sy|n-n{vv|{]|tr-J-qvn{pr5tylSntP||q;\x07\b9-prr{Pr{rP||q6-<-n{vv|{_nqvH----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-z||ur}5=;=9-=;?9-}|tr-:-n{vv|{]|tr66H--0ryr----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-}|tr6H--0r{qvs--tylSntP|y|-J-zv\x075}n{|P|y|9-tylSntP|y|9-z|qryNy}un6H--ZNV[lR[Q\f"),vertex_default$3=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-]U\\[T0qrsv{r-ZN_Xl`aR]->;=0qrsv{r-_\\\\SlZN_X->;=nvor-sy|n-lsrnrlvqlznxHn\bv{t-sy|n-_||sZnxHn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-rp@-cvr]|vv|{H{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rH0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-Il}nlrr\x07K0v{pyqr-I?l}nlrr\x07K0v{pyqr-Iqv}ynprzr{zn}l}nlrr\x07K0v{pyqr-Ir{zn}l}nlrr\x07K0v{pyqr-Ip|y|l}nlrr\x07K0v{pyqr-Is|tl}nlrr\x07K0v{pyqr-Iz|}untrl}nlrr\x07K0v{pyqr-Ixv{{v{tl}nlrr\x07K0v{pyqr-Iunq|zn}l}nlrr\x07K0v{pyqr-Iy|tqr}uosl}nlrr\x07K0v{pyqr-Ipyv}}v{tl}yn{rl}nlrr\x07KZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--0v{pyqr-Ilrr\x07K--0v{pyqr-I?lrr\x07K--0v{pyqr-Ip|y|lrr\x07K--0v{pyqr-Iortv{{|znylrr\x07K--0v{pyqr-Iz|}u{|znylrr\x07K--0v{pyqr-Ixv{onrlrr\x07K--0v{pyqr-Ixv{{|znylrr\x07K--0v{pyqr-Iqrsny{|znylrr\x07K--0vs{qrs-SYNal`UNQRQ-<<-[|zny-p|z}rq-vu-qrvnvr-ur{-SYNal`UNQRQ----[|zny-J-{|znyv r5-n{s|zrq[|zny-6H----0vsqrs-b`RlaN[TR[a------an{tr{-J-{|znyv r5-n{s|zrqan{tr{-6H------Ovn{tr{-J-{|znyv r5-p|5-[|zny9-an{tr{-6-7-n{tr{;-6H----0r{qvs--0r{qvs--0v{pyqr-Iortv{lrr\x07K--0v{pyqr-Iz|}untrlrr\x07K--0v{pyqr-Ixv{{v{tlrr\x07K--0v{pyqr-Iqv}ynprzr{zn}lrr\x07K--0v{pyqr-I}|wrplrr\x07K--0v{pyqr-Iy|tqr}uoslrr\x07K--0v{pyqr-Ipyv}}v{tl}yn{rlrr\x07K--cvr]|vv|{-J-:-z]|vv|{;\x07\b H--Sv{ny]|vv|{-J-rpA5n{s|zrq9->;=6H--0vsqrs-b`RlV[`aN[PV[T----Sv{ny]|vv|{-J-v{n{prZnv\x07-7-Sv{ny]|vv|{H--0r{qvs--Sv{ny]|vv|{-J-z|qryZnv\x07-7-Sv{ny]|vv|{H--zn@-pnzrn_|nv|{Znv\x07-J-zn@5vrZnv\x07h=jh=j9-vrZnv\x07h>jh=j9-vrZnv\x07h?jh=j9-vrZnv\x07h=jh>j9-vrZnv\x07h>jh>j9-vrZnv\x07h?jh>j9-vrZnv\x07h=jh?j9-vrZnv\x07h>jh?j9-vrZnv\x07h?jh?j6H--PnzrnQvrpv|{-J-{|znyv r5pnzrn_|nv|{Znv\x07-7-rp@5=;=9-=;=9-:>;=66H--_||sZnx-J-=;=H--0vs-qrsv{rq5b`RlcR_aRelZN_X6----_||sZnx-J-z||ur}5_\\\\SlZN_X-:-ZN_Xl`aR]9-_\\\\SlZN_X9-lsrnrlvqlznx6H--0r{qvs--0v{pyqr-I|yq}|lrr\x07K--0v{pyqr-Ir{zn}lrr\x07K--0v{pyqr-Iunq|zn}lrr\x07K--0v{pyqr-Is|tlrr\x07K--ZNV[lR[Q\f"),fragment_default$3=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-]U\\[T0qrsv{r-OYNPXlP\\Y\\_-rpA5=;=EC9-=;>=C9-=;>AF9->;=60qrsv{r-a_N[`]N_R[alP\\Y\\_-rpA5=;=9-=;=9-=;=9-=;=60qrsv{r-SYV]lPbORlZN]-:>;=p-]n{|-\n--nz}yrPor-zn}H--sy|n-zn}`v rH--rpA-zn}Uv|tnzH-<<-}rnx-zrn{-zv{-zn\x07--znA-znv\x07H--sy|n- ||zH\fH{vs|z-]n{|-}n{|=H{vs|z-]n{|-}n{|>H0vs-qrsv{rq5b`Rl]N[\\lQR]aU6--p-]n{|Qr}u-\n----nz}yrPor-zn}H----sy|n-zn\x07Qr}uH--\fH--{vs|z-]n{|Qr}u-}n{|=Qr}uH--{vs|z-]n{|Qr}u-}n{|>Qr}uH0r{qvs0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--p-Svyr]nnz-\n----sy|n-nnv|{`nnv|{OvnH----sy|n-p|{nP|{nOvnH----nz}yr?Q-uvtuyvtu`unq|YZn}H----sy|n-p|y|arz}rnrOvnH----sy|n-p|y|av{OvnH--\fH--{vs|z-Svyr]nnz-}n{|SvyrH0r{qvs0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6--p-_rsv{rq`prr{-\n----nz}yr?Q-zn}H----znA-}|wrpv|{Znv\x07H----znA-znv\x07V{rrH----sy|n-|}npv\bH----sy|n-}n{|H--\fH--{vs|z-_rsv{rq`prr{-rsv{rq`prr{H0r{qvs{vs|z-sy|n-sy||V{qr\x07H{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-}|trH0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6--{vs|z-rp@-p|{n{P|y|H0r{qvs0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6--{vs|z-nz}yr?Q-tnqvr{ar\x07rH0r{qvsp-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{qvsn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-sy|n-_||sZnxH{vs|z-sy|n-u|{Sy||V{qr\x07H{vs|z-rp?-r|yv|{H{vs|z-sy|n-}v\x07ry_nv|H{vs|z-rp@-qvssrH{vs|z-sy|n-p|y|Ny}unH{vs|z-rp@-rzvvrH{vs|z-rp@-}rpynH{vs|z-sy|n-uv{v{rH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-ovtu{rH{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rH0vs{qrs-SYNal`UNQRQ--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-I}npxv{tK0v{pyqr-Iqvurv{tl}nlsntzr{K0v{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-IoqsK0v{pyqr-Iporllrsyrpv|{lsntzr{K0v{pyqr-Ir{zn}lp|zz|{l}nlsntzr{K0v{pyqr-Ir{zn}l}nlsntzr{K0v{pyqr-Is|tl}nlsntzr{K0v{pyqr-Iyvtul}nlortv{K0v{pyqr-Iyvtul}u|{tl}nlsntzr{K0v{pyqr-Iunq|zn}l}nlsntzr{K0v{pyqr-Ioz}zn}l}nlsntzr{K0v{pyqr-I{|znyzn}l}nlsntzr{K0v{pyqr-I}rpynzn}l}nlsntzr{K0v{pyqr-Iy|tqr}uosl}nlsntzr{K0v{pyqr-Ipyv}}v{tl}yn{rl}nlsntzr{Krp@- ||zcrp|5rp@-qvrpv|{9-rp@-rp|9-sy|n- ||z6-\n--sy|n-urn-J-q|5qvrpv|{9-rp|6H--rp@-q-J-qvrpv|{-7-urnH--rp@-}-J-rp|-:-qH--rp@-\0-J-}-<- ||zH--r{-{|znyv r5q-8-\x006H\frp@-to?u5rp@-p6-\n--rpA-X-J-rpA5=;=9-:>;=-<-@;=9-?;=-<-@;=9-:>;=6H--rpA-}-J-zv\x075rpA5p;ot9-X; 69-rpA5p;to9-X;\x07\b69-r}5p;o9-p;t66H--rpA-\0-J-zv\x075rpA5};\x07\b9-p;69-rpA5p;9-};\b \x0769-r}5};\x079-p;66H--sy|n-q-J-\0;\x07-:-zv{5\0;9-\0;\b6H--sy|n-r-J->;=r:>=H--r{-rp@5no5\0; -8-5\0;-:-\0;\b6-<-5C;=-7-q-8-r669-q-<-5\0;\x07-8-r69-\0;\x076H\frp@-u?to5rp@-p6-\n--rpA-X-J-rpA5>;=9-?;=-<-@;=9->;=-<-@;=9-@;=6H--rp@-}-J-no5snp5p;\x07\x07\x07-8-X;\x07\b 6-7-C;=-:-X;6H--r{-p; -7-zv\x075X;\x07\x07\x079-pynz}5}-:-X;\x07\x07\x079-=;=9->;=69-p;\b6H\frp@-trP|y|O\bUrvtu5nz}yr?Q-tnqvr{ar\x07r9-rpA-Sv{ny]|vv|{6-\n--sy|n--J-5Sv{ny]|vv|{;\b-:-z|qryO|{qv{tZv{;\b6-<-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6H--r{-r\x07r?Q5tnqvr{ar\x07r9-rp?59-=;B66;toH\f0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--rp@-svyrUvtuyvtu`unq|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-u-J-to?u5p|y|6H----u; -J-r\x07r?Q5}n{|Svyr;uvtuyvtu`unq|YZn}9-rp?5u; 9-=;=66;H----p|y|-J-u?to5u6H----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|arz}rnr5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-rz}rnrOvn-J-pynz}5}n{|Svyr;p|y|arz}rnrOvn9-:>==;=9->==;=6H----sy|n-`pnyr-J->;=-8-rz}rnrOvn-<-@==;=H----sy|n-o`pnyr-J->;=-:-rz}rnrOvn-<-@==;=H----p|y|;-J-p|y|;-7-`pnyrH----p|y|;o-J-p|y|;o-7-o`pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|av{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-v{Ovn-J-pynz}5}n{|Svyr;p|y|av{Ovn9-:>==;=9->==;=6H----rp@-pnyr-J-rp@5>;=6H----vs-5v{Ovn-K-=;=6-\n------pnyr;t-J->;=-:-v{Ovn-<-?==;=H----\f-ryr-\n------pnyr;-J->;=-8-v{Ovn-7-=;B-<-?==;=H------pnyr;t-J->;=-:-v{Ovn-7-=;B-<-?==;=H------pnyr;o-J->;=-8-v{Ovn-7-=;B-<-?==;=H----\f----p|y|-7J-pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrP|y|arz}rnr5to9-uv|tnz6H----to-J-svyrP|y|av{5to9-uv|tnz6H----r{-toH--\f--rp@-svyrP|{n5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-zrn{cny-J-uv|tnzh>jH----sy|n-zv{cny-J-uv|tnzh?jH----sy|n-zn\x07cny-J-uv|tnzh@jH----sy|n-p|{nOvn-J-pynz}5}n{|Svyr;p|{nP|{nOvn9-:>;=9->;=6H----sy|n-rqOvn-J->;=-7-p|{nOvn-8->;=H----sy|n-ovn`\0nrunys-J-p|{nOvn-7-p|{nOvn-<-?;=H----sy|n-y|}ry|-J-5rqOvn-:->;=6-<-zrn{cnyH----sy|n-y|}ruvtu-J-5>;=-:-rqOvn6-<-5>;=-:-zrn{cny6H----sy|n-ovn-J-5rqOvn-:-zrn{cny6-<-5>;=-:-zrn{cny6H----sy|n-pnyrlsnp|-J->;=-<-5zn\x07cny-:-zv{cny6H----rp@-ny-J-p|y|H----sy|n-zn\x07lny-J-zn\x075zn\x075p|y|;9-p|y|;t69-p|y|;o6H----vs-5p|{nOvn-I-=;=6-\n------ny-J-ny-7-5>;=-:-ovn`\0nrunys6-8-zn\x07lny-7-ovn`\0nrunysH----\f----rp@-rzn}-J-rp@5------5ny;-I-zrn{cny6-L-y|}ry|-7-ny;-8->;=-G-y|}ruvtu-7-ny;-8-ovn9------5ny;t-I-zrn{cny6-L-y|}ry|-7-ny;t-8->;=-G-y|}ruvtu-7-ny;t-8-ovn9------5ny;o-I-zrn{cny6-L-y|}ry|-7-ny;o-8->;=-G-y|}ruvtu-7-ny;o-8-ovn----6H----rp@-|`pnyr-J-rzn}-7-pnyrlsnp|H----p|y|-J-5ny-:-zrn{cny6-7-|`pnyr-8-zrn{cnyH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyr`nnv|{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-nnv|{Ovn-J-pynz}5}n{|Svyr;nnv|{`nnv|{Ovn9-:>;=9->;=6H----sy|n-n`pnyr-J->;=-8-nnv|{OvnH----sy|n-yzv{n{pr-J-=;?FF-7-p|y|;-8-=;BED-7-p|y|;t-8-=;>>A-7-p|y|;oH----p|y|-J-5p|y|-:-yzv{n{pr6-7-n`pnyr-8-yzv{n{prH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-r\x07rpSvyr5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrUvtuyvtu`unq|5to9-uv|tnz6H----to-J-svyrP|y|5to9-uv|tnz6H----to-J-svyrP|{n5to9-uv|tnz6H----to-J-svyr`nnv|{5to9-uv|tnz6H----r{-toH--\f0r{qvsZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--<<-JJJ-楼层-JJJ--o||y-vPr{Sy||-J-u|{Sy||V{qr\x07-I-:=;=>-\v\v-no5sy||V{qr\x07-:-u|{Sy||V{qr\x076-I-=;FFH--sy|n-sy||\\}npv\b-J->;=H--vs-5.vPr{Sy||6-\n----0vs-qrsv{rq5b`RlSY\\\\_l`afYRlcV`VOVYVaf6------qvpnqH----0r{qvs----sy||\\}npv\b-J-pynz}5=;?-7-zv{55>;=-8-PnzrnQvrpv|{;\b69->;=69-=;=9->;=6H--\f--<<-JJJJJJJJJJJ--<<-JJJ-顶部裁切-JJJ--sy|n-||sP]|tr-J-}|5pynz}5:PnzrnQvrpv|{;\b9-=;=9->;=69-@;=6H--vs-5----_||sZnx-K-=;==>-33----Sv{ny]|vv|{;\b-K-z|qryO|{qv{tZn\x07;\b-:-||sP]|tr-7-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6--6-\n----qvpnqH--\f--<<-JJJJJJJJJJJJJJ--<<-JJJ-前置裁切计算-JJJ--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-Sv{ny]|vv|{H------pyv}}rq-J-5pyv}}rh-v-j;sy||V{qr\x07-I-=;=-\v\v-no5sy||V{qr\x07-:-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--<<-JJJJJJJJJJJJJJJJ--0v{pyqr-Ipyv}}v{tl}yn{rlsntzr{K--rpA-qvssrP|y|-J-rpA5-qvssr9-p|y|Ny}un-7-|}npv\b-6H--<<-JJJ-高度色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6----qvssrP|y|;to-J-trP|y|O\bUrvtu5tnqvr{ar\x07r9-Sv{ny]|vv|{6H--0r{qvs--<<-JJJJJJJJJJJ--<<-JJJ-纯色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6----qvssrP|y|;to-J-p|{n{P|y|H--0r{qvs--<<-JJJJJJJJJJJ--_rsyrprqYvtu-rsyrprqYvtu-J-_rsyrprqYvtu5-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-6-6H--rp@-|nyRzvvr_nqvn{pr-J-rzvvrH--0v{pyqr-Iy|tqr}uoslsntzr{K--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--<<-nppzynv|{--0v{pyqr-Iyvtul}u|{tlsntzr{K--0v{pyqr-Iyvtulsntzr{lortv{K--0v{pyqr-Iyvtulsntzr{lzn}K--0v{pyqr-Iyvtulsntzr{lr{qK--<<-z|qynv|{--0v{pyqr-In|zn}lsntzr{K--rp@-|t|v{tYvtu-J-rsyrprqYvtu;qvrpQvssr-8-rsyrprqYvtu;v{qvrpQvssr-8-rsyrprqYvtu;qvrp`}rpyn-8-rsyrprqYvtu;v{qvrp`}rpyn-8-|nyRzvvr_nqvn{prH--0v{pyqr-Ir{zn}lsntzr{K--qvssrP|y|;n-J-qvssrP|y|;n-7-sy||\\}npv\b-7-ovtu{rH--0vs-qrsv{rq5b`Rl\\]N^bR6----qvssrP|y|;n-J->;=H--0r{qvs--tylSntP|y|-J-rpA5|t|v{tYvtu9-qvssrP|y|;n6H--<<-JJJ-颜色增益调整-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNQWb`aZR[a6----rp@-uP|y|-J-to?u5tylSntP|y|;to6H----uP|y|;\b-8J-p|y|`nnv|{H----uP|y|; -8J-p|y|Ovtu{rH----tylSntP|y|;to-J-zn\x075u?to5uP|y|69-=;=6H--0r{qvs--<<-JJJJJJJJJJJJJJJJJJ--ZNV[lZ\\QRYlP\\Y\\_--<<色调映射-色彩空间转换--0v{pyqr-I|{rzn}}v{tlsntzr{K--0v{pyqr-Ir{p|qv{tlsntzr{K--0v{pyqr-Is|tlsntzr{K--0v{pyqr-I}rzyv}yvrqlny}unlsntzr{K--0v{pyqr-Iqvurv{tlsntzr{K--<<-JJJ-全景图-JJJ--rp@-}n{|=a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 6H--}n{|=a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|=a|crr\x079-}n{|=; ||z6H--}n{|=a|crr\x07-J-}n{|=a|crr\x07-7-zn@5}n{|=;znv\x076H--rp@-}n{|>a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 6H--}n{|>a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|>a|crr\x079-}n{|>; ||z6H--}n{|>a|crr\x07-J-}n{|>a|crr\x07-7-zn@5}n{|>;znv\x076H--rpA-}n{|=P|y|-J-r\x07rPor5}n{|=;zn}9-rp@5SYV]lPbORlZN]-7-}n{|=a|crr\x07;\x079-}n{|=a|crr\x07;\b 66H--rpA-}n{|>P|y|-J-r\x07rPor5}n{|>;zn}9-rp@5SYV]lPbORlZN]-7-}n{|>a|crr\x07;\x079-}n{|>a|crr\x07;\b 66H--<<-JJJ-全景图瓦片细化-JJJ--0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6----rpA-rsv{rqPnzrn]|v|{-J-rsv{rq`prr{;znv\x07V{rr-7-Sv{ny]|vv|{H----sy|n-rsv{rqg||z-J-zv\x075}n{|=; ||z9-}n{|>; ||z9-rsv{rq`prr{;}n{|6H----rp@-rsv{rqPnzrncrr\x07-J-{|znyv r5rsv{rqPnzrn]|v|{;\x07\b 6H----rsv{rqPnzrncrr\x07-J- ||zcrp|5rp@5=;=9-=;=9->;=69-rsv{rqPnzrncrr\x079-rsv{rqg||z6H----rpA-rsv{rq]|v|{-J-rsv{rq`prr{;}|wrpv|{Znv\x07-7-rpA5rsv{rqPnzrncrr\x079->;=6H----rsv{rq]|v|{-J-rsv{rq]|v|{-<-rsv{rq]|v|{;H----rpA-rsv{rqP|y|-J-r\x07r?Q5rsv{rq`prr{;zn}9-5rsv{rq]|v|{;\x07\b-8->;=6-<-?;=6H----rsv{rqP|y|;n-J-rsv{rqP|y|;n-7-rsv{rq`prr{;|}npv\bH----sy|n-rsv{rq\\rsy|]|tr-J-r}5no5rsv{rq]|v|{;\x0769->;=6-7-r}5no5rsv{rq]|v|{;\b69->;=6-7-r}5rsv{rqPnzrn]|v|{; 9-=;=6H----rsv{rqP|y|-J-zv\x075a_N[`]N_R[alP\\Y\\_9-rsv{rqP|y|9-rsv{rq\\rsy|]|tr6H----rpA-rsv{rq]n{|=P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9-rsv{rq`prr{;}n{|6H----rpA-rsv{rq]n{|>P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9->;=-:-rsv{rq`prr{;}n{|6H----}n{|=P|y|-J-zv\x075}n{|=P|y|9-rpA5rsv{rq]n{|=P|y|;to9-}n{|=P|y|;n69-rsv{rq]n{|=P|y|;n6H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-rpA5rsv{rq]n{|>P|y|;to9-}n{|>P|y|;n69-rsv{rq]n{|>P|y|;n6H--0r{qvs--<<-JJJ-运动过程全景图通过深度剔除-JJJ--0vs-qrsv{rq5b`Rl]N[\\lQR]aU6----sy|n-}n{|=crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 69-=;=9-}n{|=Qr}u;zn\x07Qr}u6H----sy|n-}n{|>crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 69-=;=9-}n{|>Qr}u;zn\x07Qr}u6H----sy|n-}n{|=Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|=Qr}u;zn}9-}n{|=a|crr\x0766-7-}n{|=Qr}u;zn\x07Qr}uH----sy|n-}n{|>Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|>Qr}u;zn}9-}n{|>a|crr\x0766-7-}n{|>Qr}u;zn\x07Qr}uH----sy|n-}n{|=Qr}uQryn-J-no5}n{|=Qr}uZn}Qr}u-:-}n{|=crr\x07Qr}u6H----sy|n-}n{|>Qr}uQryn-J-no5}n{|>Qr}uZn}Qr}u-:-}n{|>crr\x07Qr}u6H----sy|n-zn\x07]n{|=Qr}uQryn-J-=;=@-7-}n{|=crr\x07Qr}uH----sy|n-zn\x07]n{|>Qr}uQryn-J-=;=@-7-}n{|>crr\x07Qr}uH----}n{|=P|y|-J-zv\x075}n{|=P|y|9-zv\x075}n{|=P|y|9-tylSntP|y|9-pynz}5}|tr-7->=;=9-=;=9->;=669-r}5zn\x07]n{|=Qr}uQryn9-}n{|=Qr}uQryn66H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-zv\x075}n{|>P|y|9-tylSntP|y|9-pynz}55>;=-:-}|tr6-7->=;=9-=;=9->;=669-r}5zn\x07]n{|>Qr}uQryn9-}n{|>Qr}uQryn66H--0r{qvs--<<-JJJ-全景图滤镜-JJJ--0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6----}n{|=P|y|;to-J-r\x07rpSvyr5}n{|=P|y|;to9-}n{|=;zn}Uv|tnz6H----}n{|>P|y|;to-J-r\x07rpSvyr5}n{|>P|y|;to9-}n{|>;zn}Uv|tnz6H--0r{qvs--ZNV[l]N[\\lP\\Y\\_--<<-JJJ-全景图颜色混合-JJJ--rpA-}n{|P|y|H--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-:-]V-8->;=66H--0ryvs-qrsv{rq5b`Rl`]_RNQla_N[`VaV\\[6----rp?-prr{Pr{rP||q-J-r|yv|{-7-}v\x07ry_nv|-<-?;=H----sy|n-n{vv|{_nqv-J-qvn{pr5rp?5=;=9-=;=69-prr{Pr{rP||q6-7->;?H----sy|n-n{vv|{]|tr-J-qvn{pr5tylSntP||q;\x07\b9-prr{Pr{rP||q6-<-n{vv|{_nqvH----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-z||ur}5=;=9-=;?9-}|tr-:-n{vv|{]|tr66H--0ryr----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-}|tr6H--0r{qvs--tylSntP|y|-J-zv\x075}n{|P|y|9-tylSntP|y|9-z|qryNy}un6H--ZNV[lR[Q\f"),vertex_default$2=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-`aN[QN_Q0qrsv{r-ZN_Xl`aR]->;=0qrsv{r-_\\\\SlZN_X->;=nvor-sy|n-lsrnrlvqlznxHn\bv{t-sy|n-_||sZnxHn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-rp@-cvr]|vv|{H{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rH0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-Il}nlrr\x07K0v{pyqr-I?l}nlrr\x07K0v{pyqr-Iqv}ynprzr{zn}l}nlrr\x07K0v{pyqr-Ir{zn}l}nlrr\x07K0v{pyqr-Ip|y|l}nlrr\x07K0v{pyqr-Is|tl}nlrr\x07K0v{pyqr-Iz|}untrl}nlrr\x07K0v{pyqr-Ixv{{v{tl}nlrr\x07K0v{pyqr-Iunq|zn}l}nlrr\x07K0v{pyqr-Iy|tqr}uosl}nlrr\x07K0v{pyqr-Ipyv}}v{tl}yn{rl}nlrr\x07KZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--0v{pyqr-Ilrr\x07K--0v{pyqr-I?lrr\x07K--0v{pyqr-Ip|y|lrr\x07K--0v{pyqr-Iortv{{|znylrr\x07K--0v{pyqr-Iz|}u{|znylrr\x07K--0v{pyqr-Ixv{onrlrr\x07K--0v{pyqr-Ixv{{|znylrr\x07K--0v{pyqr-Iqrsny{|znylrr\x07K0vs{qrs-SYNal`UNQRQ-<<-[|zny-p|z}rq-vu-qrvnvr-ur{-SYNal`UNQRQ--[|zny-J-{|znyv r5-n{s|zrq[|zny-6H--0vsqrs-b`RlaN[TR[a----an{tr{-J-{|znyv r5-n{s|zrqan{tr{-6H----Ovn{tr{-J-{|znyv r5-p|5-[|zny9-an{tr{-6-7-n{tr{;-6H--0r{qvs0r{qvs--0v{pyqr-Iortv{lrr\x07K--0v{pyqr-Iz|}untrlrr\x07K--0v{pyqr-Ixv{{v{tlrr\x07K--0v{pyqr-Iqv}ynprzr{zn}lrr\x07K--0v{pyqr-I}|wrplrr\x07K--0v{pyqr-Iy|tqr}uoslrr\x07K--0v{pyqr-Ipyv}}v{tl}yn{rlrr\x07K--cvr]|vv|{-J-:-z]|vv|{;\x07\b H--Sv{ny]|vv|{-J-rpA5n{s|zrq9->;=6H--0vsqrs-b`RlV[`aN[PV[T----Sv{ny]|vv|{-J-v{n{prZnv\x07-7-Sv{ny]|vv|{H--0r{qvs--Sv{ny]|vv|{-J-z|qryZnv\x07-7-Sv{ny]|vv|{H--zn@-pnzrn_|nv|{Znv\x07-J-zn@5vrZnv\x07h=jh=j9-vrZnv\x07h>jh=j9-vrZnv\x07h?jh=j9-vrZnv\x07h=jh>j9-vrZnv\x07h>jh>j9-vrZnv\x07h?jh>j9-vrZnv\x07h=jh?j9-vrZnv\x07h>jh?j9-vrZnv\x07h?jh?j6H--PnzrnQvrpv|{-J-{|znyv r5pnzrn_|nv|{Znv\x07-7-rp@5=;=9-=;=9-:>;=66H--_||sZnx-J-=;=H--0vs-qrsv{rq5b`RlcR_aRelZN_X6----_||sZnx-J-z||ur}5_\\\\SlZN_X-:-ZN_Xl`aR]9-_\\\\SlZN_X9-lsrnrlvqlznx6H--0r{qvs--0v{pyqr-I|yq}|lrr\x07K--0v{pyqr-Ir{zn}lrr\x07K--0v{pyqr-Iunq|zn}lrr\x07K--0v{pyqr-Is|tlrr\x07K--ZNV[lR[Q\f"),fragment_default$2=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-`aN[QN_Q0qrsv{r-_RSYRPaVcVaf0qrsv{r-PYRN_P\\Na0qrsv{r-a_N[`]N_R[Pf0qrsv{r-OYNPXlP\\Y\\_-rpA5=;=EC9-=;>=C9-=;>AF9->;=60qrsv{r-a_N[`]N_R[alP\\Y\\_-rpA5=;=9-=;=9-=;=9-=;=60qrsv{r-SYV]lPbORlZN]-:>;=p-]n{|-\n--nz}yrPor-zn}H--sy|n-zn}`v rH--rpA-zn}Uv|tnzH-<<-}rnx-zrn{-zv{-zn\x07--znA-znv\x07H--sy|n- ||zH\fH{vs|z-]n{|-}n{|=H{vs|z-]n{|-}n{|>H0vs-qrsv{rq5b`Rl]N[\\lQR]aU6--p-]n{|Qr}u-\n----nz}yrPor-zn}H----sy|n-zn\x07Qr}uH--\fH--{vs|z-]n{|Qr}u-}n{|=Qr}uH--{vs|z-]n{|Qr}u-}n{|>Qr}uH0r{qvs0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--p-Svyr]nnz-\n----sy|n-nnv|{`nnv|{OvnH----sy|n-p|{nP|{nOvnH----nz}yr?Q-uvtuyvtu`unq|YZn}H----sy|n-p|y|arz}rnrOvnH----sy|n-p|y|av{OvnH--\fH--{vs|z-Svyr]nnz-}n{|SvyrH0r{qvs0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6--p-_rsv{rq`prr{-\n----nz}yr?Q-zn}H----znA-}|wrpv|{Znv\x07H----znA-znv\x07V{rrH----sy|n-|}npv\bH----sy|n-}n{|H--\fH--{vs|z-_rsv{rq`prr{-rsv{rq`prr{H0r{qvs{vs|z-sy|n-sy||V{qr\x07H{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-}|trH0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6--{vs|z-rp@-p|{n{P|y|H0r{qvs0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6--{vs|z-nz}yr?Q-tnqvr{ar\x07rH0r{qvsp-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{qvsn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-sy|n-_||sZnxH{vs|z-sy|n-u|{Sy||V{qr\x07H{vs|z-rp?-r|yv|{H{vs|z-sy|n-}v\x07ry_nv|H{vs|z-rp@-qvssrH{vs|z-sy|n-p|y|Ny}unH{vs|z-rp@-rzvvrH{vs|z-sy|n-|tu{rH{vs|z-sy|n-zrny{rH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-ovtu{rH0vsqrs-a_N[`]N_R[Pf--{vs|z-sy|n-n{}nr{p\bH0r{qvs0vsqrs-_RSYRPaVcVaf--{vs|z-sy|n-rsyrpvv\bH0r{qvs0vsqrs-PYRN_P\\Na--{vs|z-sy|n-pyrnp|nH--{vs|z-sy|n-pyrnp|n_|tu{rH0r{qvs0vsqrs-b`Rl`URR[--{vs|z-rp@-urr{H0r{qvs{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rHn\bv{t-rp@-cvr]|vv|{H0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-I}npxv{tK0v{pyqr-Iqvurv{tl}nlsntzr{K0v{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-IoqsK0v{pyqr-Iporllrsyrpv|{lsntzr{K0v{pyqr-Ir{zn}lp|zz|{l}nlsntzr{K0v{pyqr-Ir{zn}l}u\bvpnyl}nlsntzr{K0v{pyqr-Is|tl}nlsntzr{K0v{pyqr-Iyvtul}nlortv{K0v{pyqr-Iyvtul}u\bvpnyl}nlsntzr{K0v{pyqr-Iunq|zn}l}nlsntzr{K0v{pyqr-Ioz}zn}l}nlsntzr{K0v{pyqr-I{|znyzn}l}nlsntzr{K0v{pyqr-Ipyrnp|nl}nlsntzr{K0v{pyqr-I|tu{rzn}l}nlsntzr{K0v{pyqr-Izrny{rzn}l}nlsntzr{K0v{pyqr-Iy|tqr}uosl}nlsntzr{K0v{pyqr-Ipyv}}v{tl}yn{rl}nlsntzr{Krp@- ||zcrp|5rp@-qvrpv|{9-rp@-rp|9-sy|n- ||z6-\n--sy|n-urn-J-q|5qvrpv|{9-rp|6H--rp@-q-J-qvrpv|{-7-urnH--rp@-}-J-rp|-:-qH--rp@-\0-J-}-<- ||zH--r{-{|znyv r5q-8-\x006H\frp@-to?u5rp@-p6-\n--rpA-X-J-rpA5=;=9-:>;=-<-@;=9-?;=-<-@;=9-:>;=6H--rpA-}-J-zv\x075rpA5p;ot9-X; 69-rpA5p;to9-X;\x07\b69-r}5p;o9-p;t66H--rpA-\0-J-zv\x075rpA5};\x07\b9-p;69-rpA5p;9-};\b \x0769-r}5};\x079-p;66H--sy|n-q-J-\0;\x07-:-zv{5\0;9-\0;\b6H--sy|n-r-J->;=r:>=H--r{-rp@5no5\0; -8-5\0;-:-\0;\b6-<-5C;=-7-q-8-r669-q-<-5\0;\x07-8-r69-\0;\x076H\frp@-u?to5rp@-p6-\n--rpA-X-J-rpA5>;=9-?;=-<-@;=9->;=-<-@;=9-@;=6H--rp@-}-J-no5snp5p;\x07\x07\x07-8-X;\x07\b 6-7-C;=-:-X;6H--r{-p; -7-zv\x075X;\x07\x07\x079-pynz}5}-:-X;\x07\x07\x079-=;=9->;=69-p;\b6H\frp@-trP|y|O\bUrvtu5nz}yr?Q-tnqvr{ar\x07r9-rpA-Sv{ny]|vv|{6-\n--sy|n--J-5Sv{ny]|vv|{;\b-:-z|qryO|{qv{tZv{;\b6-<-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6H--r{-r\x07r?Q5tnqvr{ar\x07r9-rp?59-=;B66;toH\f0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--rp@-svyrUvtuyvtu`unq|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-u-J-to?u5p|y|6H----u; -J-r\x07r?Q5}n{|Svyr;uvtuyvtu`unq|YZn}9-rp?5u; 9-=;=66;H----p|y|-J-u?to5u6H----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|arz}rnr5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-rz}rnrOvn-J-pynz}5}n{|Svyr;p|y|arz}rnrOvn9-:>==;=9->==;=6H----sy|n-`pnyr-J->;=-8-rz}rnrOvn-<-@==;=H----sy|n-o`pnyr-J->;=-:-rz}rnrOvn-<-@==;=H----p|y|;-J-p|y|;-7-`pnyrH----p|y|;o-J-p|y|;o-7-o`pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|av{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-v{Ovn-J-pynz}5}n{|Svyr;p|y|av{Ovn9-:>==;=9->==;=6H----rp@-pnyr-J-rp@5>;=6H----vs-5v{Ovn-K-=;=6-\n------pnyr;t-J->;=-:-v{Ovn-<-?==;=H----\f-ryr-\n------pnyr;-J->;=-8-v{Ovn-7-=;B-<-?==;=H------pnyr;t-J->;=-:-v{Ovn-7-=;B-<-?==;=H------pnyr;o-J->;=-8-v{Ovn-7-=;B-<-?==;=H----\f----p|y|-7J-pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrP|y|arz}rnr5to9-uv|tnz6H----to-J-svyrP|y|av{5to9-uv|tnz6H----r{-toH--\f--rp@-svyrP|{n5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-zrn{cny-J-uv|tnzh>jH----sy|n-zv{cny-J-uv|tnzh?jH----sy|n-zn\x07cny-J-uv|tnzh@jH----sy|n-p|{nOvn-J-pynz}5}n{|Svyr;p|{nP|{nOvn9-:>;=9->;=6H----sy|n-rqOvn-J->;=-7-p|{nOvn-8->;=H----sy|n-ovn`\0nrunys-J-p|{nOvn-7-p|{nOvn-<-?;=H----sy|n-y|}ry|-J-5rqOvn-:->;=6-<-zrn{cnyH----sy|n-y|}ruvtu-J-5>;=-:-rqOvn6-<-5>;=-:-zrn{cny6H----sy|n-ovn-J-5rqOvn-:-zrn{cny6-<-5>;=-:-zrn{cny6H----sy|n-pnyrlsnp|-J->;=-<-5zn\x07cny-:-zv{cny6H----rp@-ny-J-p|y|H----sy|n-zn\x07lny-J-zn\x075zn\x075p|y|;9-p|y|;t69-p|y|;o6H----vs-5p|{nOvn-I-=;=6-\n------ny-J-ny-7-5>;=-:-ovn`\0nrunys6-8-zn\x07lny-7-ovn`\0nrunysH----\f----rp@-rzn}-J-rp@5------5ny;-I-zrn{cny6-L-y|}ry|-7-ny;-8->;=-G-y|}ruvtu-7-ny;-8-ovn9------5ny;t-I-zrn{cny6-L-y|}ry|-7-ny;t-8->;=-G-y|}ruvtu-7-ny;t-8-ovn9------5ny;o-I-zrn{cny6-L-y|}ry|-7-ny;o-8->;=-G-y|}ruvtu-7-ny;o-8-ovn----6H----rp@-|`pnyr-J-rzn}-7-pnyrlsnp|H----p|y|-J-5ny-:-zrn{cny6-7-|`pnyr-8-zrn{cnyH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyr`nnv|{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-nnv|{Ovn-J-pynz}5}n{|Svyr;nnv|{`nnv|{Ovn9-:>;=9->;=6H----sy|n-n`pnyr-J->;=-8-nnv|{OvnH----sy|n-yzv{n{pr-J-=;?FF-7-p|y|;-8-=;BED-7-p|y|;t-8-=;>>A-7-p|y|;oH----p|y|-J-5p|y|-:-yzv{n{pr6-7-n`pnyr-8-yzv{n{prH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-r\x07rpSvyr5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrUvtuyvtu`unq|5to9-uv|tnz6H----to-J-svyrP|y|5to9-uv|tnz6H----to-J-svyrP|{n5to9-uv|tnz6H----to-J-svyr`nnv|{5to9-uv|tnz6H----r{-toH--\f0r{qvsZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--<<-JJJ-楼层-JJJ--o||y-vPr{Sy||-J-u|{Sy||V{qr\x07-I-:=;=>-\v\v-no5sy||V{qr\x07-:-u|{Sy||V{qr\x076-I-=;FFH--sy|n-sy||\\}npv\b-J->;=H--vs-5.vPr{Sy||6-\n----0vs-qrsv{rq5b`RlSY\\\\_l`afYRlcV`VOVYVaf6------qvpnqH----0r{qvs----sy||\\}npv\b-J-pynz}5=;?-7-zv{55>;=-8-PnzrnQvrpv|{;\b69->;=69-=;=9->;=6H--\f--<<-JJJJJJJJJJJ--<<-JJJ-顶部裁切-JJJ--sy|n-||sP]|tr-J-}|5pynz}5:PnzrnQvrpv|{;\b9-=;=9->;=69-@;=6H--vs-5----_||sZnx-K-=;==>-33----Sv{ny]|vv|{;\b-K-z|qryO|{qv{tZn\x07;\b-:-||sP]|tr-7-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6--6-\n----qvpnqH--\f--<<-JJJJJJJJJJJJJJ--<<-JJJ-前置裁切计算-JJJ--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-Sv{ny]|vv|{H------pyv}}rq-J-5pyv}}rh-v-j;sy||V{qr\x07-I-=;=-\v\v-no5sy||V{qr\x07-:-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--<<-JJJJJJJJJJJJJJJJ--0v{pyqr-Ipyv}}v{tl}yn{rlsntzr{K--rpA-qvssrP|y|-J-rpA5-qvssr9-p|y|Ny}un-7-|}npv\b-6H--<<-JJJ-高度色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6----qvssrP|y|;to-J-trP|y|O\bUrvtu5tnqvr{ar\x07r9-Sv{ny]|vv|{6H--0r{qvs--<<-JJJJJJJJJJJ--<<-JJJ-纯色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6----qvssrP|y|;to-J-p|{n{P|y|H--0r{qvs--<<-JJJJJJJJJJJ--_rsyrprqYvtu-rsyrprqYvtu-J-_rsyrprqYvtu5-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-6-6H--rp@-|nyRzvvr_nqvn{pr-J-rzvvrH--0v{pyqr-Iy|tqr}uoslsntzr{K--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|tu{rzn}lsntzr{K0v{pyqr-Izrny{rzn}lsntzr{K--0v{pyqr-I{|znylsntzr{lortv{K--0v{pyqr-I{|znylsntzr{lzn}K--0v{pyqr-Ipyrnp|nl{|znylsntzr{lortv{K--0v{pyqr-Ipyrnp|nl{|znylsntzr{lzn}K--0v{pyqr-Irzvvrzn}lsntzr{K--<<-nppzynv|{--0v{pyqr-Iyvtul}u\bvpnylsntzr{K--0v{pyqr-Iyvtulsntzr{lortv{K--0v{pyqr-Iyvtulsntzr{lzn}K--0v{pyqr-Iyvtulsntzr{lr{qK--<<-z|qynv|{--0v{pyqr-In|zn}lsntzr{K--rp@-|t|v{tYvtu-J-rsyrprqYvtu;qvrpQvssr-8-rsyrprqYvtu;v{qvrpQvssr-8-rsyrprqYvtu;qvrp`}rpyn-8-rsyrprqYvtu;v{qvrp`}rpyn-8-|nyRzvvr_nqvn{prH<<-s|-n{zvv|{--0vsqrs-a_N[`]N_R[Pf----qvssrP|y|;n-7J-nnr5->;=-:-n{}nr{p\b-7-5>;=-:-znrvny;}rpyn_|tu{r6-8-yv{rna|_rynvrYzv{n{pr5-rsyrprqYvtu;qvrp`}rpyn-8-rsyrprqYvtu;v{qvrp`}rpyn-6-6H--0r{qvs--qvssrP|y|;n-J-qvssrP|y|;n-7-sy||\\}npv\b-7-ovtu{rH--0vs-qrsv{rq5b`Rl\\]N^bR6----qvssrP|y|;n-J->;=H--0r{qvs--tylSntP|y|-J-rpA5|t|v{tYvtu9-qvssrP|y|;n6H--<<-JJJ-颜色增益调整-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNQWb`aZR[a6----rp@-uP|y|-J-to?u5tylSntP|y|;to6H----uP|y|;\b-8J-p|y|`nnv|{H----uP|y|; -8J-p|y|Ovtu{rH----tylSntP|y|;to-J-zn\x075u?to5uP|y|69-=;=6H--0r{qvs--<<-JJJJJJJJJJJJJJJJJJ--ZNV[lZ\\QRYlP\\Y\\_--<<色调映射-色彩空间转换--0v{pyqr-I|{rzn}}v{tlsntzr{K--0v{pyqr-Ir{p|qv{tlsntzr{K--0v{pyqr-Is|tlsntzr{K--0v{pyqr-I}rzyv}yvrqlny}unlsntzr{K--0v{pyqr-Iqvurv{tlsntzr{K--<<-JJJ-全景图-JJJ--rp@-}n{|=a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 6H--}n{|=a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|=a|crr\x079-}n{|=; ||z6H--}n{|=a|crr\x07-J-}n{|=a|crr\x07-7-zn@5}n{|=;znv\x076H--rp@-}n{|>a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 6H--}n{|>a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|>a|crr\x079-}n{|>; ||z6H--}n{|>a|crr\x07-J-}n{|>a|crr\x07-7-zn@5}n{|>;znv\x076H--rpA-}n{|=P|y|-J-r\x07rPor5}n{|=;zn}9-rp@5SYV]lPbORlZN]-7-}n{|=a|crr\x07;\x079-}n{|=a|crr\x07;\b 66H--rpA-}n{|>P|y|-J-r\x07rPor5}n{|>;zn}9-rp@5SYV]lPbORlZN]-7-}n{|>a|crr\x07;\x079-}n{|>a|crr\x07;\b 66H--<<-JJJ-全景图瓦片细化-JJJ--0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6----rpA-rsv{rqPnzrn]|v|{-J-rsv{rq`prr{;znv\x07V{rr-7-Sv{ny]|vv|{H----sy|n-rsv{rqg||z-J-zv\x075}n{|=; ||z9-}n{|>; ||z9-rsv{rq`prr{;}n{|6H----rp@-rsv{rqPnzrncrr\x07-J-{|znyv r5rsv{rqPnzrn]|v|{;\x07\b 6H----rsv{rqPnzrncrr\x07-J- ||zcrp|5rp@5=;=9-=;=9->;=69-rsv{rqPnzrncrr\x079-rsv{rqg||z6H----rpA-rsv{rq]|v|{-J-rsv{rq`prr{;}|wrpv|{Znv\x07-7-rpA5rsv{rqPnzrncrr\x079->;=6H----rsv{rq]|v|{-J-rsv{rq]|v|{-<-rsv{rq]|v|{;H----rpA-rsv{rqP|y|-J-r\x07r?Q5rsv{rq`prr{;zn}9-5rsv{rq]|v|{;\x07\b-8->;=6-<-?;=6H----rsv{rqP|y|;n-J-rsv{rqP|y|;n-7-rsv{rq`prr{;|}npv\bH----sy|n-rsv{rq\\rsy|]|tr-J-r}5no5rsv{rq]|v|{;\x0769->;=6-7-r}5no5rsv{rq]|v|{;\b69->;=6-7-r}5rsv{rqPnzrn]|v|{; 9-=;=6H----rsv{rqP|y|-J-zv\x075a_N[`]N_R[alP\\Y\\_9-rsv{rqP|y|9-rsv{rq\\rsy|]|tr6H----rpA-rsv{rq]n{|=P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9-rsv{rq`prr{;}n{|6H----rpA-rsv{rq]n{|>P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9->;=-:-rsv{rq`prr{;}n{|6H----}n{|=P|y|-J-zv\x075}n{|=P|y|9-rpA5rsv{rq]n{|=P|y|;to9-}n{|=P|y|;n69-rsv{rq]n{|=P|y|;n6H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-rpA5rsv{rq]n{|>P|y|;to9-}n{|>P|y|;n69-rsv{rq]n{|>P|y|;n6H--0r{qvs--<<-JJJ-运动过程全景图通过深度剔除-JJJ--0vs-qrsv{rq5b`Rl]N[\\lQR]aU6----sy|n-}n{|=crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 69-=;=9-}n{|=Qr}u;zn\x07Qr}u6H----sy|n-}n{|>crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 69-=;=9-}n{|>Qr}u;zn\x07Qr}u6H----sy|n-}n{|=Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|=Qr}u;zn}9-}n{|=a|crr\x0766-7-}n{|=Qr}u;zn\x07Qr}uH----sy|n-}n{|>Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|>Qr}u;zn}9-}n{|>a|crr\x0766-7-}n{|>Qr}u;zn\x07Qr}uH----sy|n-}n{|=Qr}uQryn-J-no5}n{|=Qr}uZn}Qr}u-:-}n{|=crr\x07Qr}u6H----sy|n-}n{|>Qr}uQryn-J-no5}n{|>Qr}uZn}Qr}u-:-}n{|>crr\x07Qr}u6H----sy|n-zn\x07]n{|=Qr}uQryn-J-=;=@-7-}n{|=crr\x07Qr}uH----sy|n-zn\x07]n{|>Qr}uQryn-J-=;=@-7-}n{|>crr\x07Qr}uH----}n{|=P|y|-J-zv\x075}n{|=P|y|9-zv\x075}n{|=P|y|9-tylSntP|y|9-pynz}5}|tr-7->=;=9-=;=9->;=669-r}5zn\x07]n{|=Qr}uQryn9-}n{|=Qr}uQryn66H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-zv\x075}n{|>P|y|9-tylSntP|y|9-pynz}55>;=-:-}|tr6-7->=;=9-=;=9->;=669-r}5zn\x07]n{|>Qr}uQryn9-}n{|>Qr}uQryn66H--0r{qvs--<<-JJJ-全景图滤镜-JJJ--0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6----}n{|=P|y|;to-J-r\x07rpSvyr5}n{|=P|y|;to9-}n{|=;zn}Uv|tnz6H----}n{|>P|y|;to-J-r\x07rpSvyr5}n{|>P|y|;to9-}n{|>;zn}Uv|tnz6H--0r{qvs--ZNV[l]N[\\lP\\Y\\_--<<-JJJ-全景图颜色混合-JJJ--rpA-}n{|P|y|H--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-:-]V-8->;=66H--0ryvs-qrsv{rq5b`Rl`]_RNQla_N[`VaV\\[6----rp?-prr{Pr{rP||q-J-r|yv|{-7-}v\x07ry_nv|-<-?;=H----sy|n-n{vv|{_nqv-J-qvn{pr5rp?5=;=9-=;=69-prr{Pr{rP||q6-7->;?H----sy|n-n{vv|{]|tr-J-qvn{pr5tylSntP||q;\x07\b9-prr{Pr{rP||q6-<-n{vv|{_nqvH----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-z||ur}5=;=9-=;?9-}|tr-:-n{vv|{]|tr66H--0ryr----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-}|tr6H--0r{qvs--tylSntP|y|-J-zv\x075}n{|P|y|9-tylSntP|y|9-z|qryNy}un6H--ZNV[lR[Q\f"),Uniform=class extends three.Uniform{constructor(e){super(e)}};function setUniform(e,t){t&&e.value&&(t instanceof three.Color||t instanceof three.Matrix4||t instanceof three.Matrix3||t instanceof three.Vector2||t instanceof three.Vector3||t instanceof three.Vector4)?e.value.copy(t):Array.isArray(t)?e.value=t.slice():e.value=t}function cloneUniforms(e){return three.UniformsUtils.clone(e)}function mergeUniforms(...e){return three.UniformsUtils.merge(e)}function defineProperty(e,t,n){return Object.defineProperty(e,t,n)}var fastProto=null;function FastObject(e){if(fastProto!==null&&typeof fastProto.property){let e=fastProto;return fastProto=FastObject.prototype=null,e}return fastProto=FastObject.prototype=e==null?Object.create(null):e,new FastObject}var inlineCacheCutoff=10;for(let e=0;e<=inlineCacheCutoff;e++)FastObject();function toFastProperties(e){return FastObject(e)}var TAU$2=Math.PI*2;function formatRad$1(e){return e>=0&&e<TAU$2?e:(e%TAU$2+TAU$2)%TAU$2}function coordinatesToVector(e,t){let n=Math.abs(Math.cos(e.latitude)),r=-Math.sin(e.longitude)*n,o=-Math.sin(e.latitude),s=-Math.cos(e.longitude)*n;return t?t.set(r,o,s):new three.Vector3(r,o,s)}function vectorToCoordinates(e){return{longitude:formatRad$1(-Math.atan2(e.x,-e.z)),latitude:-Math.asin(e.y/1)}}function longitudeToHeading(e){return(-e/Math.PI*180-90)/360+.25}function headingToLongitude(e){return-((e-.25)*360+90)/180*Math.PI}var start=Date.now();typeof performance<`u`&&(typeof performance.timeOrigin==`number`?start=performance.timeOrigin:performance.timing!==void 0&&(start=performance.timing.navigationStart));var now=typeof performance<`u`?(()=>start+performance.now()):(()=>Date.now());function dateNowToDomHighResTimeStamp(e){return e-start}function clamp$1(e,t,n){return e<t?t:typeof n==`number`&&e>n?n:e}var DEFAULT_ASPECT=1,DEFAULT_NEAR=.1,DEFAULT_FAR=2e3,TAU$1=Math.PI*2,PI_2=Math.PI/2;function formatRad(e){return e>0&&e<=TAU$1?e:(e%TAU$1+TAU$1)%TAU$1}function matrixLerp(e,t,n,r){n=Math.pow(n,4);for(var o=0;o<16;o++)r.elements[o]=e.elements[o]+(t.elements[o]-e.elements[o])*n;return r}var Camera=class extends three.Camera{constructor(e,t=DEFAULT_ASPECT,n=DEFAULT_NEAR,r=DEFAULT_FAR,o=new three.Vector2,s=new three.Vector2(512,512),c=1){super(),this.fov=e,this.aspect=t,this.near=n,this.far=r,this.perspToOrtho=o,this.resolution=s,this.pixelRatio=c,this.time=0,this.controllerMode=null,this.needsRender=!0,this.refineModel=!0,this.pose={longitude:0,latitude:0,fov:e,distance:0,offset:new three.Vector3},this.computePose(),this.perspectiveCamera=new three.PerspectiveCamera(this.fov,this.aspect,.001,this.far);let l=Math.max(this.orthoDistance,.01)*Math.tan(.5*this.fov/180*Math.PI),u=-.5*this.aspect*2*l;this.orthographicCamera=new three.OrthographicCamera(u,-u,l,-l,.001,this.far),this.computeProjectionMatrix(),this.lastValues={position:this.position.clone(),quaternion:this.quaternion.clone(),scale:this.scale.clone(),fov:this.fov,aspect:this.aspect,near:this.near,far:this.far,orthoDistance:this.orthoDistance,perspToOrtho:this.perspToOrtho.clone()},this.type=this.perspToOrtho.x<1?`PerspectiveCamera`:`OrthographicCamera`,this.autoNearFar=!0}get orthoDistance(){return this.pose.distance>1?this.pose.distance:1+(this.pose.distance-1)*this.perspToOrtho.x}get zoom(){return this.type===`OrthographicCamera`?this.orthographicCamera.zoom:this.type===`PerspectiveCamera`?this.perspectiveCamera.zoom:1}get top(){return this.type===`OrthographicCamera`?this.orthographicCamera.top:0}get bottom(){return this.type===`OrthographicCamera`?this.orthographicCamera.bottom:0}get left(){return this.type===`OrthographicCamera`?this.orthographicCamera.left:0}get right(){return this.type===`OrthographicCamera`?this.orthographicCamera.right:0}getDirection(e){return coordinatesToVector(this.pose,e)}computePose(e=0){this.updateMatrix();let t=this.matrix.elements;return this.pose.latitude=Math.asin(clamp$1(t[9],-1,1)),Math.abs(t[9])<.9999999?this.pose.longitude=formatRad(Math.atan2(t[8],t[10])):this.pose.longitude=formatRad(Math.atan2(-t[2],t[0])),this.pose.fov=this.fov,this.pose.distance=e,this.pose.offset=new three.Vector3(-t[8],-t[9],-t[10]).setLength(this.pose.distance).add(this.position),this}setFromPose(e){var t,n,r,o,s;let c=formatRad((t=e.longitude)==null?this.pose.longitude:t),l=Math.max(-PI_2+1e-4,Math.min(PI_2-1e-4,(n=e.latitude)==null?this.pose.latitude:n)),u=(r=e.fov)==null?this.pose.fov:r,d=(o=e.distance)==null?this.pose.distance:o,f=(s=e.offset)==null?this.pose.offset:s,p=coordinatesToVector({longitude:c,latitude:l}).normalize();return this.position.set(0,0,0),this.lookAt(p),this.position.add(f).sub(p.clone().setLength(d)),this.fov!==u&&(this.fov=u,this.perspectiveCamera.fov=u,this.updateProjectionMatrix()),this.updateMatrixWorld(!0),this.pose.longitude=c,this.pose.latitude=l,this.pose.fov=u,this.pose.distance=d,this.pose.offset.copy(f),this.needsRender=!0,this}copyPose(){return{longitude:this.pose.longitude,latitude:this.pose.latitude,fov:this.pose.fov,distance:this.pose.distance,offset:this.pose.offset.clone()}}computeProjectionMatrix(){matrixLerp(this.orthographicCamera.projectionMatrix,this.perspectiveCamera.projectionMatrix,1-this.perspToOrtho.x,this.projectionMatrix),this.projectionMatrixInverse.getInverse(this.projectionMatrix),this.needsRender=!0}setViewOffset(e,t,n,r,o,s){this.perspectiveCamera.setViewOffset(e,t,n,r,o,s),this.orthographicCamera.setViewOffset(e,t,n,r,o,s),this.computeProjectionMatrix()}get view(){return this.perspectiveCamera.view?Object.assign({},this.perspectiveCamera.view):null}clearViewOffset(){this.perspectiveCamera.clearViewOffset(),this.orthographicCamera.clearViewOffset(),this.computeProjectionMatrix()}updateProjectionMatrix(){this.perspectiveCamera.updateProjectionMatrix(),this.orthographicCamera.updateProjectionMatrix(),this.computeProjectionMatrix()}get perspectiveProjectionMatrix(){return this.perspectiveCamera.projectionMatrix}get perspectiveProjectionMatrixInverse(){return this.perspectiveCamera.projectionMatrixInverse}get orthographicProjectionMatrix(){return this.orthographicCamera.projectionMatrix}get orthographicProjectionMatrixInverse(){return this.orthographicCamera.projectionMatrixInverse}updateTime(e){this.time=e;let t=!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(),t=!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.orthoDistance!==this.orthoDistance||this.lastValues.aspect!==this.aspect){let e=Math.max(this.orthoDistance,.01)*Math.tan(.5*this.fov/180*Math.PI),n=-.5*this.aspect*2*e;this.orthographicCamera.left=n,this.orthographicCamera.right=-n,this.orthographicCamera.top=e,this.orthographicCamera.bottom=-e,this.orthographicCamera.near=this.near,this.orthographicCamera.far=this.far,this.orthographicCamera.updateProjectionMatrix(),t=!0}t&&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.orthoDistance=this.orthoDistance,this.lastValues.perspToOrtho.copy(this.perspToOrtho),this.type=this.perspToOrtho.x<1?`PerspectiveCamera`:`OrthographicCamera`}get isPerspectiveCamera(){return this.perspToOrtho.x<1}get isOrthographicCamera(){return this.perspToOrtho.x>=1}copy(e,t){return super.copy(e,t),this.fov=e.fov,this.aspect=e.aspect,this.near=e.near,this.far=e.far,this.perspToOrtho.copy(e.perspToOrtho),this.updateTime(now()),this}};function S4(){return((1+Math.random())*65536|0).toString(16).substring(1)}function createUuid(){return(S4()+S4()+`-`+S4()+`-4`+S4().substr(0,3)+`-`+S4()+`-`+S4()+S4()+S4()).toLowerCase()}function createSymbol(e){return typeof Symbol>`u`?`$Symbol<${e}>$`:Symbol(e)}var EVENT_SYMBOL=createSymbol(`$$FIVE_EVENT$$`);function __generateEventIfNotExisted(e){return e[EVENT_SYMBOL]||(e[EVENT_SYMBOL]={}),e[EVENT_SYMBOL]}function __removeEvents(e){e[EVENT_SYMBOL]&&delete e[EVENT_SYMBOL]}var Subscribe=class{hasListener(e){let t=__generateEventIfNotExisted(this);return t&&t[e]&&t[e].callbacks.length>0}on(e,t,n){let r=__generateEventIfNotExisted(this);return r[e]||(r[e]={callbacks:[]}),r[e].callbacks.push([t,n||!1]),()=>this.off(e,t)}once(e,t){return this.on(e,t,!0)}off(e,t){if(e===void 0){__removeEvents(this);return}let n=__generateEventIfNotExisted(this);if(n[e]||(n[e]={callbacks:[]}),t===void 0){n[e].callbacks.length=0;return}let r=0;for(;r<n[e].callbacks.length&&n[e].callbacks[r][0]!==t;r++);r<n[e].callbacks.length&&n[e].callbacks.splice(r,1)}emit(e,...t){let n=!1,r=__generateEventIfNotExisted(this);r[e]||(r[e]={callbacks:[]});let o=r[e].callbacks.slice();for(let[r,s=!1]of o){let o=r(...t);s&&this.off(e,r),o===!1&&(n=!0)}return n}waitUntil(e,t){return new Promise(n=>{let r=this.on(e,(...e)=>{(!t||t(...e)!==!1)&&(n(e),r())})})}},PBMUpdateable=class extends Subscribe{},PBMCustomShader=class extends PBMUpdateable{constructor(e){var t,n,r,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b;super(),this.id=createUuid(),this.version=0,this.uniforms=(t=e.uniforms)==null?{}:t,this.defines=(n=e.defines)==null?{}:n,this.type=e.type,this.vertex={mainBefore:(o=(r=e.vertex)==null?void 0:r.mainBefore)==null?``:o,mainStart:(c=(s=e.vertex)==null?void 0:s.mainStart)==null?``:c,mainEnd:(u=(l=e.vertex)==null?void 0:l.mainEnd)==null?``:u},this.fragment={mainBefore:(f=(d=e.fragment)==null?void 0:d.mainBefore)==null?``:f,mainStart:(m=(p=e.fragment)==null?void 0:p.mainStart)==null?``:m,mainModelColor:(g=(h=e.fragment)==null?void 0:h.mainModelColor)==null?``:g,mainPanoColor:(v=(_=e.fragment)==null?void 0:_.mainPanoColor)==null?``:v,mainEnd:(b=(y=e.fragment)==null?void 0:y.mainEnd)==null?``:b}}get needsUpdate(){return!1}set needsUpdate(e){e===!0&&this.version++}onBeforeCompile(e,t){}},PBMPanoFilter=class e extends PBMUpdateable{static computeLut(e,t,n,r=1024,o=1,s,c){let l=clamp$1(e,-255,255)/255,u=clamp$1(t,-255,255)/255,d=clamp$1(n,-255,255)/255,f=new Float32Array(5),p=new Float32Array(5),m=new Float32Array(5);f[0]=0,f[1]=.125,f[2]=.5,f[3]=.875,f[4]=1;for(let e=0;e<5;e++)m[e]=f[e]*(1+d);m[4]=Math.max(1,m[4]);let h=1/2.2;for(let e=0;e<5;e++){let t=Math.pow(m[e]/m[4],2.2),n=Math.pow(m[e]/m[4],.45454545454545453);e<2?p[e]=m[e]+n*u:e>2?p[e]=m[e]+t*l:p[e]=m[e]}p[0]=0,p[4]=Math.max(1,p[4]),p[1]=Math.max(p[0]+.05,p[1]),p[3]=Math.min(p[4]-.0875,p[3]),p[2]=Math.max(Math.min(p[3]-.275,p[2]),p[1]+.275),s=s==null?new Float32Array(r*o):s,c=c==null?0:c;let g=r*2;for(let e=0;e<g;e++){let t=e/g,n=t*t,l=n*t,u=l*t,d=1-t,m=d*d,h=m*d,_=h*d,v=_*f[0]+4*h*t*f[1]+6*m*n*f[2]+4*d*l*f[3]+u*f[4],y=_*p[0]+4*h*t*p[1]+6*m*n*p[2]+4*d*l*p[3]+u*p[4],b=clamp$1(Math.round(v*(r-1)),0,r-1);for(let e=0;e<o;e++)s[c+b*o+e]=y}return s}constructor(){super(),this.id=createUuid();let t=()=>this.emit(`update`),n=0;this.contrast={get contrastBias(){return n},set contrastBias(e){n=e,t()}};let r=0;this.saturation={get saturationBias(){return r},set saturationBias(e){r=e,t()}};let o=0,s=0;this.color={get temperatureBias(){return o},set temperatureBias(e){o=e,t()},get tintBias(){return s},set tintBias(e){s=e,t()}};let c=0,l=0,u=0,d=[0,0,0].join(`:`),f=1024,p=3,m=new Float32Array(f*3);e.computeLut(0,0,0,f,3,m);let h=new three.DataTexture(m,f,1);h.flipY=!1,h.format=three.RGBFormat,h.type=three.FloatType,h.minFilter=three.NearestFilter,h.magFilter=three.NearestFilter,h.generateMipmaps=!1,h.needsUpdate=!0;let g=()=>{let t=[c,l,u].join(`:`);return t!==d&&(e.computeLut(c,l,u,f,3,m),h.needsUpdate=!0,d=t),h};this.highlightShadow={lutMap:h,get highlightBias(){return c},set highlightBias(e){c=e,g(),t()},get shadowBias(){return l},set shadowBias(e){l=e,g(),t()},get globalBias(){return u},set globalBias(e){u=e,g(),t()}}}toValue(){return{saturationSaturationBias:this.saturation.saturationBias,contrastContrastBias:this.contrast.contrastBias,highlightShadowLutMap:this.highlightShadow.lutMap,colorTemperatureBias:this.color.temperatureBias,colorTintBias:this.color.tintBias}}},PBMMaterial=class extends three.Material{},scratchViewport$5=new three.Vector4,pbmUniforms$1={colorAlpha:new Uniform(1),pano0:new Uniform({map:null,mapSize:1,mapHistogram:new three.Vector4,matrix:new three.Matrix4,zoom:1}),pano1:new Uniform({map:null,mapSize:1,mapHistogram:new three.Vector4,matrix:new three.Matrix4,zoom:1}),pano0Depth:new Uniform({map:null,maxDepth:1}),pano1Depth:new Uniform({map:null,maxDepth:1}),refinedScreen:new Uniform({projectionMatrix:new three.Matrix4,matrixInverse:new three.Matrix4,map:null,pano:0,opacity:1}),panoFilter:new Uniform(null),modelAlpha:new Uniform(1),progress:new Uniform(0),gradientTexture:new Uniform(null),clippers:new Uniform([]),shownFloorIndex:new Uniform(-1),constantColor:new Uniform(new three.Vector3),floorIndex:new Uniform(0),brightness:new Uniform(1),colorSaturation:new Uniform(0),colorBrightness:new Uniform(0),pixelRatio:new Uniform(1),resolution:new Uniform(new three.Vector2(512,512)),modelBoundingMin:new Uniform(new three.Vector3),modelBoundingMax:new Uniform(new three.Vector3)},shaderLib$1={none:{vertexShader:vertex_default$5,fragmentShader:fragment_default$5},basic:{vertexShader:vertex_default$4,fragmentShader:fragment_default$4},phong:{vertexShader:vertex_default$3,fragmentShader:fragment_default$3},standard:{vertexShader:vertex_default$2,fragmentShader:fragment_default$2}},uniformsLib$1=mergeUniforms(three.ShaderLib.basic.uniforms,three.ShaderLib.phong.uniforms,three.ShaderLib.physical.uniforms,pbmUniforms$1),definesLib$1={USE_OPAQUE:!1,USE_VERTEX_MARK:!1,USE_COLOR_CONSTANT:!1,USE_COLOR_ALTITUDE:!1,USE_COLOR_ADJUSTMENT:!1,USE_FLOOR_STYLE_VISIBILITY:!1,USE_BLACK_TRANSITION:!1,USE_SPREAD_TRANSITION:!1,USE_FADE_TRANSITION:!1,USE_REFINED_SCREEN:!1,USE_PANO_DEPTH:!1,USE_PANO_FILTER:!1,USE_HQ_WEIGHT:!1,USE_HQ_DEPTH:!1},PBMMeshMaterial=class extends PBMMaterial{constructor(e){var t,n;typeof e==`string`&&(e={shaderType:e}),super(),this.vertexTangents=!1,this.color=new three.Color(16777215),this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.specularMap=null,this.specular=new three.Color(1118481),this.shininess=30,this.roughnessMap=null,this.roughness=1,this.metalnessMap=null,this.metalness=0,this.alphaMap=null,this.combine=null,this.envMap=null,this.envMapIntensity=1,this.reflectivity=.4,this.refractionRatio=.98,this.emissiveMap=null,this.emissive=new three.Color(0),this.emissiveIntensity=1,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=three.TangentSpaceNormalMap,this.normalScale=new three.Vector2(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.clearcoat=0,this.clearcoatMap=null,this.clearcoatRoughness=0,this.clearcoatRoughnessMap=null,this.clearcoatNormalScale=new three.Vector2(1,1),this.clearcoatNormalMap=null,this.sheen=null,this.transparency=0,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap=`round`,this.wireframeLinejoin=`round`,this.skinning=!1,this.morphTargets=!1,this.morphNormals=!1,this.metal=!1,this.alphaMode=`OPAQUE`,this.clipping=!0,this.customShaders=[],this.type=`PBMMeshMaterial`;let r=Object.assign({},definesLib$1),o=cloneUniforms(uniformsLib$1);toFastProperties(o),toFastProperties(r),this.defines=r,this.onBeforeCompile=(e,t)=>{let n=this.shaderType;e.vertexShader=shaderLib$1[n].vertexShader,e.fragmentShader=shaderLib$1[n].fragmentShader,e.uniforms=o;for(let e of Object.keys(r))e in definesLib$1||delete r[e];for(let e of Object.keys(o))e in uniformsLib$1||delete o[e];let s=this.customShaders.filter(e=>e.type.includes(n));for(let e of s){for(let t in e.defines)t in r||Object.assign(r,{[t]:e.defines[t]});for(let t in e.uniforms)t in o||Object.assign(o,{[t]:e.uniforms[t]})}e.vertexShader=e.vertexShader.replace(/MAIN_BEFORE/g,s.map(e=>e.vertex.mainBefore).filter(e=>!!e).join(`
302
+ `,o},typeof e==`string`&&(e.indexOf(`-----BEGIN`)==-1?KJUR.lang.String.isHex(e)&&this.readCertHex(e):this.readCertPEM(e))}X509.hex2dn=function(e,t){t===void 0&&(t=0);var n=new X509;return ASN1HEX.getTLV(e,t),n.getX500Name(e).str},X509.hex2rdn=function(e,t){if(t===void 0&&(t=0),e.substr(t,2)!==`31`)throw Error(`malformed RDN`);for(var n=[],r=ASN1HEX.getChildIdx(e,t),o=0;o<r.length;o++)n.push(X509.hex2attrTypeValue(e,r[o]));return n=n.map(function(e){return e.replace(`+`,`\\+`)}),n.join(`+`)},X509.hex2attrTypeValue=function(e,t){var n=ASN1HEX,r=n.getV;if(t===void 0&&(t=0),e.substr(t,2)!==`30`)throw Error(`malformed attribute type and value`);var o=n.getChildIdx(e,t);o.length!==2||e.substr(o[0],2);var s=r(e,o[0]),c=KJUR.asn1.ASN1Util.oidHexToInt(s),l=KJUR.asn1.x509.OID.oid2atype(c),u=hextorstr(r(e,o[1]));return l+`=`+u},X509.getPublicKeyFromCertHex=function(e){var t=new X509;return t.readCertHex(e),t.getPublicKey()},X509.getPublicKeyFromCertPEM=function(e){var t=new X509;return t.readCertPEM(e),t.getPublicKey()},X509.getPublicKeyInfoPropOfCertPEM=function(e){var t=ASN1HEX.getVbyList,n={},r,o;return n.algparam=null,r=new X509,r.readCertPEM(e),o=r.getPublicKeyHex(),n.keyhex=t(o,0,[1],`03`).substr(2),n.algoid=t(o,0,[0,0],`06`),n.algoid===`2a8648ce3d0201`&&(n.algparam=t(o,0,[0,1],`06`)),n},X509.KEYUSAGE_NAME=[`digitalSignature`,`nonRepudiation`,`keyEncipherment`,`dataEncipherment`,`keyAgreement`,`keyCertSign`,`cRLSign`,`encipherOnly`,`decipherOnly`];function sha256(e){return CryptoJS.SHA256(e).toString()}var certificates=[(()=>{let e=new X509;return e.readCertPEM(function(...e){let t=113,n=126,r=0,o=``;return arguments[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}(":::::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:::::")),e})()];function getCertificateBySubjectHex(e,t){for(let n of t)if(n.getSubjectHex()===e)return n}function verifyCertificate_(e,t){let n=e.getIssuerHex();if(n===e.getSubjectHex())return e.verifySignature(e.getPublicKey());let r=getCertificateBySubjectHex(n,t);return!r||e.verifySignature(r.getPublicKey())===!1?!1:verifyCertificate_(r,t)}function verifyCertificate(e){return e.getIssuerHex()===e.getSubjectHex()?!1:verifyCertificate_(e,certificates)}function addCertificate(e){let t=new X509;typeof e==`string`?t.readCertPEM(e):t.readCertHex(e.hex);let n=verifyCertificate(t);return certificates.push(t),n}function verifyMessage(e,t,n){let r=new X509;if(typeof n==`string`?r.readCertPEM(n):r.readCertHex(n.hex),verifyCertificate(r)===!1)return!1;let o=new RSAKey;return o.readCertPubKeyHex(r.hex,6),!!o.verify(e,b64tohex(t))}addCertificate(function(...e){let t=113,n=126,r=0,o=``;return arguments[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}(":::::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 PBMGroup=class extends three.Group{},vertex_default$5=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("n\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{H0v{pyqr-Ip|zz|{K0v{pyqr-Iz|}untrl}nlrr\x07K0v{pyqr-Ixv{{v{tl}nlrr\x07K0v{pyqr-Iy|tqr}uosl}nlrr\x07K0v{pyqr-Ipyv}}v{tl}yn{rl}nlrr\x07KZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--0v{pyqr-Ixv{onrlrr\x07K--0v{pyqr-Iortv{lrr\x07K--0v{pyqr-Iz|}untrlrr\x07K--0v{pyqr-Ixv{{v{tlrr\x07K--0v{pyqr-I}|wrplrr\x07K--0v{pyqr-Iy|tqr}uoslrr\x07K--0v{pyqr-Ipyv}}v{tl}yn{rlrr\x07K--Sv{ny]|vv|{-J-rpA5n{s|zrq9->;=6H--0vsqrs-b`RlV[`aN[PV[T----Sv{ny]|vv|{-J-v{n{prZnv\x07-7-Sv{ny]|vv|{H--0r{qvs--Sv{ny]|vv|{-J-z|qryZnv\x07-7-Sv{ny]|vv|{H--zn@-pnzrn_|nv|{Znv\x07-J-zn@5vrZnv\x07h=jh=j9-vrZnv\x07h>jh=j9-vrZnv\x07h?jh=j9-vrZnv\x07h=jh>j9-vrZnv\x07h>jh>j9-vrZnv\x07h?jh>j9-vrZnv\x07h=jh?j9-vrZnv\x07h>jh?j9-vrZnv\x07h?jh?j6H--PnzrnQvrpv|{-J-{|znyv r5pnzrn_|nv|{Znv\x07-7-rp@5=;=9-=;=9-:>;=66H--0v{pyqr-I|yq}|lrr\x07K--0v{pyqr-Is|tlrr\x07K--ZNV[lR[Q\f"),fragment_default$5=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-OYNPXlP\\Y\\_-rpA5=;=EC9-=;>=C9-=;>AF9->;=60qrsv{r-a_N[`]N_R[alP\\Y\\_-rpA5=;=9-=;=9-=;=9-=;=60qrsv{r-SYV]lPbORlZN]-:>;=p-]n{|-\n--nz}yrPor-zn}H--sy|n-zn}`v rH--rpA-zn}Uv|tnzH-<<-}rnx-zrn{-zv{-zn\x07--znA-znv\x07H--sy|n- ||zH\fH{vs|z-]n{|-}n{|=H{vs|z-]n{|-}n{|>H0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--p-Svyr]nnz-\n----sy|n-nnv|{`nnv|{OvnH----sy|n-p|{nP|{nOvnH----nz}yr?Q-uvtuyvtu`unq|YZn}H----sy|n-p|y|arz}rnrOvnH----sy|n-p|y|av{OvnH--\fH--{vs|z-Svyr]nnz-}n{|SvyrH0r{qvsp-_rsv{rq`prr{-\n--nz}yr?Q-zn}H--znA-}|wrpv|{Znv\x07H--znA-znv\x07V{rrH--sy|n-|}npv\bH--sy|n-}n{|H\fH{vs|z-_rsv{rq`prr{-rsv{rq`prr{H{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-}|trHn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{H{vs|z-sy|n-u|{Sy||V{qr\x07H{vs|z-rp?-r|yv|{H{vs|z-sy|n-}v\x07ry_nv|H0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-Iqvurv{tl}nlsntzr{K0v{pyqr-Is|tl}nlsntzr{K0v{pyqr-I}rpynzn}l}nlsntzr{K0v{pyqr-Iy|tqr}uosl}nlsntzr{K0v{pyqr-Ipyv}}v{tl}yn{rl}nlsntzr{Krp@- ||zcrp|5rp@-qvrpv|{9-rp@-rp|9-sy|n- ||z6-\n--sy|n-urn-J-q|5qvrpv|{9-rp|6H--rp@-q-J-qvrpv|{-7-urnH--rp@-}-J-rp|-:-qH--rp@-\0-J-}-<- ||zH--r{-{|znyv r5q-8-\x006H\frp@-to?u5rp@-p6-\n--rpA-X-J-rpA5=;=9-:>;=-<-@;=9-?;=-<-@;=9-:>;=6H--rpA-}-J-zv\x075rpA5p;ot9-X; 69-rpA5p;to9-X;\x07\b69-r}5p;o9-p;t66H--rpA-\0-J-zv\x075rpA5};\x07\b9-p;69-rpA5p;9-};\b \x0769-r}5};\x079-p;66H--sy|n-q-J-\0;\x07-:-zv{5\0;9-\0;\b6H--sy|n-r-J->;=r:>=H--r{-rp@5no5\0; -8-5\0;-:-\0;\b6-<-5C;=-7-q-8-r669-q-<-5\0;\x07-8-r69-\0;\x076H\frp@-u?to5rp@-p6-\n--rpA-X-J-rpA5>;=9-?;=-<-@;=9->;=-<-@;=9-@;=6H--rp@-}-J-no5snp5p;\x07\x07\x07-8-X;\x07\b 6-7-C;=-:-X;6H--r{-p; -7-zv\x075X;\x07\x07\x079-pynz}5}-:-X;\x07\x07\x079-=;=9->;=69-p;\b6H\f0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--rp@-svyrUvtuyvtu`unq|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-u-J-to?u5p|y|6H----u; -J-r\x07r?Q5}n{|Svyr;uvtuyvtu`unq|YZn}9-rp?5u; 9-=;=66;H----p|y|-J-u?to5u6H----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|arz}rnr5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-rz}rnrOvn-J-pynz}5}n{|Svyr;p|y|arz}rnrOvn9-:>==;=9->==;=6H----sy|n-`pnyr-J->;=-8-rz}rnrOvn-<-@==;=H----sy|n-o`pnyr-J->;=-:-rz}rnrOvn-<-@==;=H----p|y|;-J-p|y|;-7-`pnyrH----p|y|;o-J-p|y|;o-7-o`pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|av{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-v{Ovn-J-pynz}5}n{|Svyr;p|y|av{Ovn9-:>==;=9->==;=6H----rp@-pnyr-J-rp@5>;=6H----vs-5v{Ovn-K-=;=6-\n------pnyr;t-J->;=-:-v{Ovn-<-?==;=H----\f-ryr-\n------pnyr;-J->;=-8-v{Ovn-7-=;B-<-?==;=H------pnyr;t-J->;=-:-v{Ovn-7-=;B-<-?==;=H------pnyr;o-J->;=-8-v{Ovn-7-=;B-<-?==;=H----\f----p|y|-7J-pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrP|y|arz}rnr5to9-uv|tnz6H----to-J-svyrP|y|av{5to9-uv|tnz6H----r{-toH--\f--rp@-svyrP|{n5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-zrn{cny-J-uv|tnzh>jH----sy|n-zv{cny-J-uv|tnzh?jH----sy|n-zn\x07cny-J-uv|tnzh@jH----sy|n-p|{nOvn-J-pynz}5}n{|Svyr;p|{nP|{nOvn9-:>;=9->;=6H----sy|n-rqOvn-J->;=-7-p|{nOvn-8->;=H----sy|n-ovn`\0nrunys-J-p|{nOvn-7-p|{nOvn-<-?;=H----sy|n-y|}ry|-J-5rqOvn-:->;=6-<-zrn{cnyH----sy|n-y|}ruvtu-J-5>;=-:-rqOvn6-<-5>;=-:-zrn{cny6H----sy|n-ovn-J-5rqOvn-:-zrn{cny6-<-5>;=-:-zrn{cny6H----sy|n-pnyrlsnp|-J->;=-<-5zn\x07cny-:-zv{cny6H----rp@-ny-J-p|y|H----sy|n-zn\x07lny-J-zn\x075zn\x075p|y|;9-p|y|;t69-p|y|;o6H----vs-5p|{nOvn-I-=;=6-\n------ny-J-ny-7-5>;=-:-ovn`\0nrunys6-8-zn\x07lny-7-ovn`\0nrunysH----\f----rp@-rzn}-J-rp@5------5ny;-I-zrn{cny6-L-y|}ry|-7-ny;-8->;=-G-y|}ruvtu-7-ny;-8-ovn9------5ny;t-I-zrn{cny6-L-y|}ry|-7-ny;t-8->;=-G-y|}ruvtu-7-ny;t-8-ovn9------5ny;o-I-zrn{cny6-L-y|}ry|-7-ny;o-8->;=-G-y|}ruvtu-7-ny;o-8-ovn----6H----rp@-|`pnyr-J-rzn}-7-pnyrlsnp|H----p|y|-J-5ny-:-zrn{cny6-7-|`pnyr-8-zrn{cnyH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyr`nnv|{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-nnv|{Ovn-J-pynz}5}n{|Svyr;nnv|{`nnv|{Ovn9-:>;=9->;=6H----sy|n-n`pnyr-J->;=-8-nnv|{OvnH----sy|n-yzv{n{pr-J-=;?FF-7-p|y|;-8-=;BED-7-p|y|;t-8-=;>>A-7-p|y|;oH----p|y|-J-5p|y|-:-yzv{n{pr6-7-n`pnyr-8-yzv{n{prH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-r\x07rpSvyr5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrUvtuyvtu`unq|5to9-uv|tnz6H----to-J-svyrP|y|5to9-uv|tnz6H----to-J-svyrP|{n5to9-uv|tnz6H----to-J-svyr`nnv|{5to9-uv|tnz6H----r{-toH--\f0r{qvsZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--0v{pyqr-Ipyv}}v{tl}yn{rlsntzr{K--0v{pyqr-Is|tlsntzr{K--0v{pyqr-I}rzyv}yvrqlny}unlsntzr{K--0v{pyqr-Iqvurv{tlsntzr{K--<<-JJJ-全景图-JJJ--rp@-}n{|=a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 6H--}n{|=a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|=a|crr\x079-}n{|=; ||z6H--}n{|=a|crr\x07-J-}n{|=a|crr\x07-7-zn@5}n{|=;znv\x076H--rp@-}n{|>a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 6H--}n{|>a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|>a|crr\x079-}n{|>; ||z6H--}n{|>a|crr\x07-J-}n{|>a|crr\x07-7-zn@5}n{|>;znv\x076H--rpA-}n{|=P|y|-J-r\x07rPor5}n{|=;zn}9-rp@5SYV]lPbORlZN]-7-}n{|=a|crr\x07;\x079-}n{|=a|crr\x07;\b 66H--rpA-}n{|>P|y|-J-r\x07rPor5}n{|>;zn}9-rp@5SYV]lPbORlZN]-7-}n{|>a|crr\x07;\x079-}n{|>a|crr\x07;\b 66H--<<-JJJ-全景图瓦片细化-JJJ--0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6----rpA-rsv{rqPnzrn]|v|{-J-rsv{rq`prr{;znv\x07V{rr-7-Sv{ny]|vv|{H----sy|n-rsv{rqg||z-J-zv\x075}n{|=; ||z9-}n{|>; ||z9-rsv{rq`prr{;}n{|6H----rp@-rsv{rqPnzrncrr\x07-J-{|znyv r5rsv{rqPnzrn]|v|{;\x07\b 6H----rsv{rqPnzrncrr\x07-J- ||zcrp|5rp@5=;=9-=;=9->;=69-rsv{rqPnzrncrr\x079-rsv{rqg||z6H----rpA-rsv{rq]|v|{-J-rsv{rq`prr{;}|wrpv|{Znv\x07-7-rpA5rsv{rqPnzrncrr\x079->;=6H----rsv{rq]|v|{-J-rsv{rq]|v|{-<-rsv{rq]|v|{;H----rpA-rsv{rqP|y|-J-r\x07r?Q5rsv{rq`prr{;zn}9-5rsv{rq]|v|{;\x07\b-8->;=6-<-?;=6H----rsv{rqP|y|;n-J-rsv{rqP|y|;n-7-rsv{rq`prr{;|}npv\bH----sy|n-rsv{rq\\rsy|]|tr-J-r}5no5rsv{rq]|v|{;\x0769->;=6-7-r}5no5rsv{rq]|v|{;\b69->;=6-7-r}5rsv{rqPnzrn]|v|{; 9-=;=6H----rsv{rqP|y|-J-zv\x075a_N[`]N_R[alP\\Y\\_9-rsv{rqP|y|9-rsv{rq\\rsy|]|tr6H----rpA-rsv{rq]n{|=P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9-rsv{rq`prr{;}n{|6H----rpA-rsv{rq]n{|>P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9->;=-:-rsv{rq`prr{;}n{|6H----}n{|=P|y|-J-zv\x075}n{|=P|y|9-rpA5rsv{rq]n{|=P|y|;to9-}n{|=P|y|;n69-rsv{rq]n{|=P|y|;n6H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-rpA5rsv{rq]n{|>P|y|;to9-}n{|>P|y|;n69-rsv{rq]n{|>P|y|;n6H--0r{qvs--<<-JJJ-全景图滤镜-JJJ--0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6----}n{|=P|y|;to-J-r\x07rpSvyr5}n{|=P|y|;to9-}n{|=;zn}Uv|tnz6H----}n{|>P|y|;to-J-r\x07rpSvyr5}n{|>P|y|;to9-}n{|>;zn}Uv|tnz6H--0r{qvs--ZNV[l]N[\\lP\\Y\\_--<<-JJJ-全景图颜色混合-JJJ--rpA-}n{|P|y|H--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-:-]V-8->;=66H--0ryvs-qrsv{rq5b`Rl`]_RNQla_N[`VaV\\[6----rp?-prr{Pr{rP||q-J-r|yv|{-7-}v\x07ry_nv|-<-?;=H----sy|n-n{vv|{_nqv-J-qvn{pr5rp?5=;=9-=;=69-prr{Pr{rP||q6-7->;?H----sy|n-n{vv|{]|tr-J--qvn{pr5tylSntP||q;\x07\b9-prr{Pr{rP||q6-<-n{vv|{_nqvH----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-z||ur}5=;=9-=;?9-}|tr-:-n{vv|{]|tr66H--0ryr----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-}|tr6H--0r{qvs--tylSntP|y|-J-zv\x075}n{|P|y|9-rpA5}n{|P|y|;to9-=;=69-pynz}5z|qryNy}un-7-@=;=9-=;=9->;=66H--<<-JJJJJJJJJJJJJJJJ--ZNV[lR[Q\f"),vertex_default$4=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-ZN_Xl`aR]->;=0qrsv{r-_\\\\SlZN_X->;=nvor-sy|n-lsrnrlvqlznxHn\bv{t-sy|n-_||sZnxHn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-rp@-cvr]|vv|{H{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rH0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-Il}nlrr\x07K0v{pyqr-I?l}nlrr\x07K0v{pyqr-Ir{zn}l}nlrr\x07K0v{pyqr-Ip|y|l}nlrr\x07K0v{pyqr-Is|tl}nlrr\x07K0v{pyqr-Iz|}untrl}nlrr\x07K0v{pyqr-Ixv{{v{tl}nlrr\x07K0v{pyqr-Iy|tqr}uosl}nlrr\x07K0v{pyqr-Ipyv}}v{tl}yn{rl}nlrr\x07KZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--0v{pyqr-Ilrr\x07K--0v{pyqr-I?lrr\x07K--0v{pyqr-Ip|y|lrr\x07K--0v{pyqr-Ixv{onrlrr\x07K--0v{pyqr-Iortv{{|znylrr\x07K--0v{pyqr-Iz|}u{|znylrr\x07K--0v{pyqr-Ixv{{|znylrr\x07K--0v{pyqr-Iqrsny{|znylrr\x07K--0vs{qrs-SYNal`UNQRQ-<<-[|zny-p|z}rq-vu-qrvnvr-ur{-SYNal`UNQRQ--[|zny-J-{|znyv r5-n{s|zrq[|zny-6H--0r{qvs--0v{pyqr-Iortv{lrr\x07K--0v{pyqr-Iz|}untrlrr\x07K--0v{pyqr-Ixv{{v{tlrr\x07K--0v{pyqr-I}|wrplrr\x07K--0v{pyqr-Iy|tqr}uoslrr\x07K--0v{pyqr-Ipyv}}v{tl}yn{rlrr\x07K--cvr]|vv|{-J-:z]|vv|{;\x07\b H--Sv{ny]|vv|{-J-rpA5n{s|zrq9->;=6H--0vsqrs-b`RlV[`aN[PV[T----Sv{ny]|vv|{-J-v{n{prZnv\x07-7-Sv{ny]|vv|{H--0r{qvs--Sv{ny]|vv|{-J-z|qryZnv\x07-7-Sv{ny]|vv|{H--zn@-pnzrn_|nv|{Znv\x07-J-zn@5vrZnv\x07h=jh=j9-vrZnv\x07h>jh=j9-vrZnv\x07h?jh=j9-vrZnv\x07h=jh>j9-vrZnv\x07h>jh>j9-vrZnv\x07h?jh>j9-vrZnv\x07h=jh?j9-vrZnv\x07h>jh?j9-vrZnv\x07h?jh?j6H--PnzrnQvrpv|{-J-{|znyv r5pnzrn_|nv|{Znv\x07-7-rp@5=;=9-=;=9-:>;=66H--_||sZnx-J-=;=H--0vs-qrsv{rq5b`RlcR_aRelZN_X6----_||sZnx-J-z||ur}5_\\\\SlZN_X-:-ZN_Xl`aR]9-_\\\\SlZN_X9-lsrnrlvqlznx6H--0r{qvs--0v{pyqr-I|yq}|lrr\x07K--0v{pyqr-Ir{zn}lrr\x07K--0v{pyqr-Is|tlrr\x07K--ZNV[lR[Q\f"),fragment_default$4=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-OYNPXlP\\Y\\_-rpA5=;=EC9-=;>=C9-=;>AF9->;=60qrsv{r-a_N[`]N_R[alP\\Y\\_-rpA5=;=9-=;=9-=;=9-=;=60qrsv{r-SYV]lPbORlZN]-:>;=p-]n{|-\n--nz}yrPor-zn}H--sy|n-zn}`v rH--rpA-zn}Uv|tnzH-<<-}rnx-zrn{-zv{-zn\x07--znA-znv\x07H--sy|n- ||zH\fH{vs|z-]n{|-}n{|=H{vs|z-]n{|-}n{|>H0vs-qrsv{rq5b`Rl]N[\\lQR]aU6--p-]n{|Qr}u-\n----nz}yrPor-zn}H----sy|n-zn\x07Qr}uH--\fH--{vs|z-]n{|Qr}u-}n{|=Qr}uH--{vs|z-]n{|Qr}u-}n{|>Qr}uH0r{qvs0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--p-Svyr]nnz-\n----sy|n-nnv|{`nnv|{OvnH----sy|n-p|{nP|{nOvnH----nz}yr?Q-uvtuyvtu`unq|YZn}H----sy|n-p|y|arz}rnrOvnH----sy|n-p|y|av{OvnH--\fH--{vs|z-Svyr]nnz-}n{|SvyrH0r{qvs0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6--p-_rsv{rq`prr{-\n----nz}yr?Q-zn}H----znA-}|wrpv|{Znv\x07H----znA-znv\x07V{rrH----sy|n-|}npv\bH----sy|n-}n{|H--\fH--{vs|z-_rsv{rq`prr{-rsv{rq`prr{H0r{qvs{vs|z-sy|n-sy||V{qr\x07H{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-}|trH0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6--{vs|z-rp@-p|{n{P|y|H0r{qvs0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6--{vs|z-nz}yr?Q-tnqvr{ar\x07rH0r{qvsp-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{qvsn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-rp@-cvr]|vv|{Hn\bv{t-sy|n-_||sZnxH{vs|z-sy|n-u|{Sy||V{qr\x07H{vs|z-rp?-r|yv|{H{vs|z-sy|n-}v\x07ry_nv|H{vs|z-rp@-qvssrH{vs|z-sy|n-p|y|Ny}unH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-ovtu{rH{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rH0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-I}npxv{tK0v{pyqr-Iqvurv{tl}nlsntzr{K0v{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-Ir{zn}lp|zz|{l}nlsntzr{K0v{pyqr-Ir{zn}l}nlsntzr{K0v{pyqr-Iporllrsyrpv|{lsntzr{K0v{pyqr-Is|tl}nlsntzr{K0v{pyqr-I}rpynzn}l}nlsntzr{K0v{pyqr-Iy|tqr}uosl}nlsntzr{K0v{pyqr-Ipyv}}v{tl}yn{rl}nlsntzr{Krp@- ||zcrp|5rp@-qvrpv|{9-rp@-rp|9-sy|n- ||z6-\n--sy|n-urn-J-q|5qvrpv|{9-rp|6H--rp@-q-J-qvrpv|{-7-urnH--rp@-}-J-rp|-:-qH--rp@-\0-J-}-<- ||zH--r{-{|znyv r5q-8-\x006H\frp@-to?u5rp@-p6-\n--rpA-X-J-rpA5=;=9-:>;=-<-@;=9-?;=-<-@;=9-:>;=6H--rpA-}-J-zv\x075rpA5p;ot9-X; 69-rpA5p;to9-X;\x07\b69-r}5p;o9-p;t66H--rpA-\0-J-zv\x075rpA5};\x07\b9-p;69-rpA5p;9-};\b \x0769-r}5};\x079-p;66H--sy|n-q-J-\0;\x07-:-zv{5\0;9-\0;\b6H--sy|n-r-J->;=r:>=H--r{-rp@5no5\0; -8-5\0;-:-\0;\b6-<-5C;=-7-q-8-r669-q-<-5\0;\x07-8-r69-\0;\x076H\frp@-u?to5rp@-p6-\n--rpA-X-J-rpA5>;=9-?;=-<-@;=9->;=-<-@;=9-@;=6H--rp@-}-J-no5snp5p;\x07\x07\x07-8-X;\x07\b 6-7-C;=-:-X;6H--r{-p; -7-zv\x075X;\x07\x07\x079-pynz}5}-:-X;\x07\x07\x079-=;=9->;=69-p;\b6H\frp@-trP|y|O\bUrvtu5nz}yr?Q-tnqvr{ar\x07r9-rpA-Sv{ny]|vv|{6-\n--sy|n--J-5Sv{ny]|vv|{;\b-:-z|qryO|{qv{tZv{;\b6-<-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6H--r{-r\x07r?Q5tnqvr{ar\x07r9-rp?59-=;B66;toH\f0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--rp@-svyrUvtuyvtu`unq|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-u-J-to?u5p|y|6H----u; -J-r\x07r?Q5}n{|Svyr;uvtuyvtu`unq|YZn}9-rp?5u; 9-=;=66;H----p|y|-J-u?to5u6H----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|arz}rnr5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-rz}rnrOvn-J-pynz}5}n{|Svyr;p|y|arz}rnrOvn9-:>==;=9->==;=6H----sy|n-`pnyr-J->;=-8-rz}rnrOvn-<-@==;=H----sy|n-o`pnyr-J->;=-:-rz}rnrOvn-<-@==;=H----p|y|;-J-p|y|;-7-`pnyrH----p|y|;o-J-p|y|;o-7-o`pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|av{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-v{Ovn-J-pynz}5}n{|Svyr;p|y|av{Ovn9-:>==;=9->==;=6H----rp@-pnyr-J-rp@5>;=6H----vs-5v{Ovn-K-=;=6-\n------pnyr;t-J->;=-:-v{Ovn-<-?==;=H----\f-ryr-\n------pnyr;-J->;=-8-v{Ovn-7-=;B-<-?==;=H------pnyr;t-J->;=-:-v{Ovn-7-=;B-<-?==;=H------pnyr;o-J->;=-8-v{Ovn-7-=;B-<-?==;=H----\f----p|y|-7J-pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrP|y|arz}rnr5to9-uv|tnz6H----to-J-svyrP|y|av{5to9-uv|tnz6H----r{-toH--\f--rp@-svyrP|{n5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-zrn{cny-J-uv|tnzh>jH----sy|n-zv{cny-J-uv|tnzh?jH----sy|n-zn\x07cny-J-uv|tnzh@jH----sy|n-p|{nOvn-J-pynz}5}n{|Svyr;p|{nP|{nOvn9-:>;=9->;=6H----sy|n-rqOvn-J->;=-7-p|{nOvn-8->;=H----sy|n-ovn`\0nrunys-J-p|{nOvn-7-p|{nOvn-<-?;=H----sy|n-y|}ry|-J-5rqOvn-:->;=6-<-zrn{cnyH----sy|n-y|}ruvtu-J-5>;=-:-rqOvn6-<-5>;=-:-zrn{cny6H----sy|n-ovn-J-5rqOvn-:-zrn{cny6-<-5>;=-:-zrn{cny6H----sy|n-pnyrlsnp|-J->;=-<-5zn\x07cny-:-zv{cny6H----rp@-ny-J-p|y|H----sy|n-zn\x07lny-J-zn\x075zn\x075p|y|;9-p|y|;t69-p|y|;o6H----vs-5p|{nOvn-I-=;=6-\n------ny-J-ny-7-5>;=-:-ovn`\0nrunys6-8-zn\x07lny-7-ovn`\0nrunysH----\f----rp@-rzn}-J-rp@5------5ny;-I-zrn{cny6-L-y|}ry|-7-ny;-8->;=-G-y|}ruvtu-7-ny;-8-ovn9------5ny;t-I-zrn{cny6-L-y|}ry|-7-ny;t-8->;=-G-y|}ruvtu-7-ny;t-8-ovn9------5ny;o-I-zrn{cny6-L-y|}ry|-7-ny;o-8->;=-G-y|}ruvtu-7-ny;o-8-ovn----6H----rp@-|`pnyr-J-rzn}-7-pnyrlsnp|H----p|y|-J-5ny-:-zrn{cny6-7-|`pnyr-8-zrn{cnyH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyr`nnv|{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-nnv|{Ovn-J-pynz}5}n{|Svyr;nnv|{`nnv|{Ovn9-:>;=9->;=6H----sy|n-n`pnyr-J->;=-8-nnv|{OvnH----sy|n-yzv{n{pr-J-=;?FF-7-p|y|;-8-=;BED-7-p|y|;t-8-=;>>A-7-p|y|;oH----p|y|-J-5p|y|-:-yzv{n{pr6-7-n`pnyr-8-yzv{n{prH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-r\x07rpSvyr5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrUvtuyvtu`unq|5to9-uv|tnz6H----to-J-svyrP|y|5to9-uv|tnz6H----to-J-svyrP|{n5to9-uv|tnz6H----to-J-svyr`nnv|{5to9-uv|tnz6H----r{-toH--\f0r{qvsZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--<<-JJJ-楼层-JJJ--o||y-vPr{Sy||-J-u|{Sy||V{qr\x07-I-:=;=>-\v\v-no5sy||V{qr\x07-:-u|{Sy||V{qr\x076-I-=;FFH--sy|n-sy||\\}npv\b-J->;=H--vs-5.vPr{Sy||6-\n----0vs-qrsv{rq5b`RlSY\\\\_l`afYRlcV`VOVYVaf6------qvpnqH----0r{qvs----sy||\\}npv\b-J-pynz}5=;?-7-zv{55>;=-8-PnzrnQvrpv|{;\b69->;=69-=;=9->;=6H--\f--<<-JJJJJJJJJJJ--<<-JJJ-顶部裁切-JJJ--sy|n-||sP]|tr-J-}|5pynz}5:PnzrnQvrpv|{;\b9-=;=9->;=69-@;=6H--vs-5----_||sZnx-K-=;==>-33----Sv{ny]|vv|{;\b-K-z|qryO|{qv{tZn\x07;\b-:-||sP]|tr-7-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6--6-\n----qvpnqH--\f--<<-JJJJJJJJJJJJJJ--<<-JJJ-前置裁切计算-JJJ--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-Sv{ny]|vv|{H------pyv}}rq-J-5pyv}}rh-v-j;sy||V{qr\x07-I-=;=-\v\v-no5sy||V{qr\x07-:-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--<<-JJJJJJJJJJJJJJJJJJ--0v{pyqr-Ipyv}}v{tl}yn{rlsntzr{K--rpA-qvssrP|y|-J-rpA5-qvssr9-p|y|Ny}un-7-|}npv\b-6H--<<-JJJ-高度色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6----qvssrP|y|;to-J-trP|y|O\bUrvtu5tnqvr{ar\x07r9-Sv{ny]|vv|{6H--0r{qvs--<<-JJJJJJJJJJJ--<<-JJJ-纯色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6----qvssrP|y|;to-J-p|{n{P|y|H--0r{qvs--<<-JJJJJJJJJJJ--0v{pyqr-Iy|tqr}uoslsntzr{K--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--_rsyrprqYvtu-rsyrprqYvtu-J-_rsyrprqYvtu5-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-6-6H--<<-nppzynv|{-5onxrq-v{qvrp-yvtuv{t-|{y\b6--0vsqrs-b`RlYVTUaZN]----rpA-yvtuZn}ar\x07ryJ-r\x07r?Q5-yvtuZn}9-b?-6H----rsyrprqYvtu;v{qvrpQvssr-8J-yvtuZn}ar\x07rya|Yv{rn5-yvtuZn}ar\x07ry-6;to-7-yvtuZn}V{r{v\bH--0ryr----rsyrprqYvtu;v{qvrpQvssr-8J-rp@5->;=-6H--0r{qvs--<<-z|qynv|{--0v{pyqr-In|zn}lsntzr{K--rsyrprqYvtu;v{qvrpQvssr-7J-qvssrP|y|;toH--rp@-|t|v{tYvtu-J-rsyrprqYvtu;v{qvrpQvssrH--0v{pyqr-Ir{zn}lsntzr{K--qvssrP|y|;n-J-qvssrP|y|;n-7-sy||\\}npv\b-7-ovtu{rH--0vs-qrsv{rq5b`Rl\\]N^bR6----qvssrP|y|;n-J->;=H--0r{qvs--tylSntP|y|-J-rpA5-|t|v{tYvtu9-qvssrP|y|;n-6H--<<-JJJ-颜色增益调整-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNQWb`aZR[a6----rp@-uP|y|-J-to?u5tylSntP|y|;to6H----uP|y|;\b-8J-p|y|`nnv|{H----uP|y|; -8J-p|y|Ovtu{rH----tylSntP|y|;to-J-zn\x075u?to5uP|y|69-=;=6H--0r{qvs--<<-JJJJJJJJJJJJJJJJJJ--ZNV[lZ\\QRYlP\\Y\\_--<<色调映射-色彩空间转换--0v{pyqr-I|{rzn}}v{tlsntzr{K--0v{pyqr-Ir{p|qv{tlsntzr{K--0v{pyqr-Is|tlsntzr{K--0v{pyqr-I}rzyv}yvrqlny}unlsntzr{K--0v{pyqr-Iqvurv{tlsntzr{K--<<-JJJ-全景图-JJJ--rp@-}n{|=a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 6H--}n{|=a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|=a|crr\x079-}n{|=; ||z6H--}n{|=a|crr\x07-J-}n{|=a|crr\x07-7-zn@5}n{|=;znv\x076H--rp@-}n{|>a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 6H--}n{|>a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|>a|crr\x079-}n{|>; ||z6H--}n{|>a|crr\x07-J-}n{|>a|crr\x07-7-zn@5}n{|>;znv\x076H--rpA-}n{|=P|y|-J-r\x07rPor5}n{|=;zn}9-rp@5SYV]lPbORlZN]-7-}n{|=a|crr\x07;\x079-}n{|=a|crr\x07;\b 66H--rpA-}n{|>P|y|-J-r\x07rPor5}n{|>;zn}9-rp@5SYV]lPbORlZN]-7-}n{|>a|crr\x07;\x079-}n{|>a|crr\x07;\b 66H--<<-JJJ-全景图瓦片细化-JJJ--0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6----rpA-rsv{rqPnzrn]|v|{-J-rsv{rq`prr{;znv\x07V{rr-7-Sv{ny]|vv|{H----sy|n-rsv{rqg||z-J-zv\x075}n{|=; ||z9-}n{|>; ||z9-rsv{rq`prr{;}n{|6H----rp@-rsv{rqPnzrncrr\x07-J-{|znyv r5rsv{rqPnzrn]|v|{;\x07\b 6H----rsv{rqPnzrncrr\x07-J- ||zcrp|5rp@5=;=9-=;=9->;=69-rsv{rqPnzrncrr\x079-rsv{rqg||z6H----rpA-rsv{rq]|v|{-J-rsv{rq`prr{;}|wrpv|{Znv\x07-7-rpA5rsv{rqPnzrncrr\x079->;=6H----rsv{rq]|v|{-J-rsv{rq]|v|{-<-rsv{rq]|v|{;H----rpA-rsv{rqP|y|-J-r\x07r?Q5rsv{rq`prr{;zn}9-5rsv{rq]|v|{;\x07\b-8->;=6-<-?;=6H----rsv{rqP|y|;n-J-rsv{rqP|y|;n-7-rsv{rq`prr{;|}npv\bH----sy|n-rsv{rq\\rsy|]|tr-J-r}5no5rsv{rq]|v|{;\x0769->;=6-7-r}5no5rsv{rq]|v|{;\b69->;=6-7-r}5rsv{rqPnzrn]|v|{; 9-=;=6H----rsv{rqP|y|-J-zv\x075a_N[`]N_R[alP\\Y\\_9-rsv{rqP|y|9-rsv{rq\\rsy|]|tr6H----rpA-rsv{rq]n{|=P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9-rsv{rq`prr{;}n{|6H----rpA-rsv{rq]n{|>P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9->;=-:-rsv{rq`prr{;}n{|6H----}n{|=P|y|-J-zv\x075}n{|=P|y|9-rpA5rsv{rq]n{|=P|y|;to9-}n{|=P|y|;n69-rsv{rq]n{|=P|y|;n6H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-rpA5rsv{rq]n{|>P|y|;to9-}n{|>P|y|;n69-rsv{rq]n{|>P|y|;n6H--0r{qvs--<<-JJJ-全景图滤镜-JJJ--0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6----}n{|=P|y|;to-J-r\x07rpSvyr5}n{|=P|y|;to9-}n{|=;zn}Uv|tnz6H----}n{|>P|y|;to-J-r\x07rpSvyr5}n{|>P|y|;to9-}n{|>;zn}Uv|tnz6H--0r{qvs--ZNV[l]N[\\lP\\Y\\_--<<-JJJ-运动过程全景图通过深度剔除-JJJ--0vs-qrsv{rq5b`Rl]N[\\lQR]aU6----sy|n-}n{|=crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 69-=;=9-}n{|=Qr}u;zn\x07Qr}u6H----sy|n-}n{|>crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 69-=;=9-}n{|>Qr}u;zn\x07Qr}u6H----sy|n-}n{|=Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|=Qr}u;zn}9-}n{|=a|crr\x0766-7-}n{|=Qr}u;zn\x07Qr}uH----sy|n-}n{|>Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|>Qr}u;zn}9-}n{|>a|crr\x0766-7-}n{|>Qr}u;zn\x07Qr}uH----sy|n-}n{|=Qr}uQryn-J-no5}n{|=Qr}uZn}Qr}u-:-}n{|=crr\x07Qr}u6H----sy|n-}n{|>Qr}uQryn-J-no5}n{|>Qr}uZn}Qr}u-:-}n{|>crr\x07Qr}u6H----sy|n-zn\x07]n{|=Qr}uQryn-J-=;=@-7-}n{|=crr\x07Qr}uH----sy|n-zn\x07]n{|>Qr}uQryn-J-=;=@-7-}n{|>crr\x07Qr}uH----}n{|=P|y|-J-zv\x075}n{|=P|y|9-zv\x075}n{|=P|y|9-tylSntP|y|9-pynz}5}|tr-7->=;=9-=;=9->;=669-r}5zn\x07]n{|=Qr}uQryn9-}n{|=Qr}uQryn66H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-zv\x075}n{|>P|y|9-tylSntP|y|9-pynz}55>;=-:-}|tr6-7->=;=9-=;=9->;=669-r}5zn\x07]n{|>Qr}uQryn9-}n{|>Qr}uQryn66H--0r{qvs--<<-JJJ-全景图颜色混合-JJJ--rpA-}n{|P|y|H--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-:-]V-8->;=66H--0ryvs-qrsv{rq5b`Rl`]_RNQla_N[`VaV\\[6----rp?-prr{Pr{rP||q-J-r|yv|{-7-}v\x07ry_nv|-<-?;=H----sy|n-n{vv|{_nqv-J-qvn{pr5rp?5=;=9-=;=69-prr{Pr{rP||q6-7->;?H----sy|n-n{vv|{]|tr-J-qvn{pr5tylSntP||q;\x07\b9-prr{Pr{rP||q6-<-n{vv|{_nqvH----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-z||ur}5=;=9-=;?9-}|tr-:-n{vv|{]|tr66H--0ryr----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-}|tr6H--0r{qvs--tylSntP|y|-J-zv\x075}n{|P|y|9-tylSntP|y|9-z|qryNy}un6H--ZNV[lR[Q\f"),vertex_default$3=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-]U\\[T0qrsv{r-ZN_Xl`aR]->;=0qrsv{r-_\\\\SlZN_X->;=nvor-sy|n-lsrnrlvqlznxHn\bv{t-sy|n-_||sZnxHn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-rp@-cvr]|vv|{H{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rH0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-Il}nlrr\x07K0v{pyqr-I?l}nlrr\x07K0v{pyqr-Iqv}ynprzr{zn}l}nlrr\x07K0v{pyqr-Ir{zn}l}nlrr\x07K0v{pyqr-Ip|y|l}nlrr\x07K0v{pyqr-Is|tl}nlrr\x07K0v{pyqr-Iz|}untrl}nlrr\x07K0v{pyqr-Ixv{{v{tl}nlrr\x07K0v{pyqr-Iunq|zn}l}nlrr\x07K0v{pyqr-Iy|tqr}uosl}nlrr\x07K0v{pyqr-Ipyv}}v{tl}yn{rl}nlrr\x07KZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--0v{pyqr-Ilrr\x07K--0v{pyqr-I?lrr\x07K--0v{pyqr-Ip|y|lrr\x07K--0v{pyqr-Iortv{{|znylrr\x07K--0v{pyqr-Iz|}u{|znylrr\x07K--0v{pyqr-Ixv{onrlrr\x07K--0v{pyqr-Ixv{{|znylrr\x07K--0v{pyqr-Iqrsny{|znylrr\x07K--0vs{qrs-SYNal`UNQRQ-<<-[|zny-p|z}rq-vu-qrvnvr-ur{-SYNal`UNQRQ----[|zny-J-{|znyv r5-n{s|zrq[|zny-6H----0vsqrs-b`RlaN[TR[a------an{tr{-J-{|znyv r5-n{s|zrqan{tr{-6H------Ovn{tr{-J-{|znyv r5-p|5-[|zny9-an{tr{-6-7-n{tr{;-6H----0r{qvs--0r{qvs--0v{pyqr-Iortv{lrr\x07K--0v{pyqr-Iz|}untrlrr\x07K--0v{pyqr-Ixv{{v{tlrr\x07K--0v{pyqr-Iqv}ynprzr{zn}lrr\x07K--0v{pyqr-I}|wrplrr\x07K--0v{pyqr-Iy|tqr}uoslrr\x07K--0v{pyqr-Ipyv}}v{tl}yn{rlrr\x07K--cvr]|vv|{-J-:-z]|vv|{;\x07\b H--Sv{ny]|vv|{-J-rpA5n{s|zrq9->;=6H--0vsqrs-b`RlV[`aN[PV[T----Sv{ny]|vv|{-J-v{n{prZnv\x07-7-Sv{ny]|vv|{H--0r{qvs--Sv{ny]|vv|{-J-z|qryZnv\x07-7-Sv{ny]|vv|{H--zn@-pnzrn_|nv|{Znv\x07-J-zn@5vrZnv\x07h=jh=j9-vrZnv\x07h>jh=j9-vrZnv\x07h?jh=j9-vrZnv\x07h=jh>j9-vrZnv\x07h>jh>j9-vrZnv\x07h?jh>j9-vrZnv\x07h=jh?j9-vrZnv\x07h>jh?j9-vrZnv\x07h?jh?j6H--PnzrnQvrpv|{-J-{|znyv r5pnzrn_|nv|{Znv\x07-7-rp@5=;=9-=;=9-:>;=66H--_||sZnx-J-=;=H--0vs-qrsv{rq5b`RlcR_aRelZN_X6----_||sZnx-J-z||ur}5_\\\\SlZN_X-:-ZN_Xl`aR]9-_\\\\SlZN_X9-lsrnrlvqlznx6H--0r{qvs--0v{pyqr-I|yq}|lrr\x07K--0v{pyqr-Ir{zn}lrr\x07K--0v{pyqr-Iunq|zn}lrr\x07K--0v{pyqr-Is|tlrr\x07K--ZNV[lR[Q\f"),fragment_default$3=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-]U\\[T0qrsv{r-OYNPXlP\\Y\\_-rpA5=;=EC9-=;>=C9-=;>AF9->;=60qrsv{r-a_N[`]N_R[alP\\Y\\_-rpA5=;=9-=;=9-=;=9-=;=60qrsv{r-SYV]lPbORlZN]-:>;=p-]n{|-\n--nz}yrPor-zn}H--sy|n-zn}`v rH--rpA-zn}Uv|tnzH-<<-}rnx-zrn{-zv{-zn\x07--znA-znv\x07H--sy|n- ||zH\fH{vs|z-]n{|-}n{|=H{vs|z-]n{|-}n{|>H0vs-qrsv{rq5b`Rl]N[\\lQR]aU6--p-]n{|Qr}u-\n----nz}yrPor-zn}H----sy|n-zn\x07Qr}uH--\fH--{vs|z-]n{|Qr}u-}n{|=Qr}uH--{vs|z-]n{|Qr}u-}n{|>Qr}uH0r{qvs0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--p-Svyr]nnz-\n----sy|n-nnv|{`nnv|{OvnH----sy|n-p|{nP|{nOvnH----nz}yr?Q-uvtuyvtu`unq|YZn}H----sy|n-p|y|arz}rnrOvnH----sy|n-p|y|av{OvnH--\fH--{vs|z-Svyr]nnz-}n{|SvyrH0r{qvs0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6--p-_rsv{rq`prr{-\n----nz}yr?Q-zn}H----znA-}|wrpv|{Znv\x07H----znA-znv\x07V{rrH----sy|n-|}npv\bH----sy|n-}n{|H--\fH--{vs|z-_rsv{rq`prr{-rsv{rq`prr{H0r{qvs{vs|z-sy|n-sy||V{qr\x07H{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-}|trH0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6--{vs|z-rp@-p|{n{P|y|H0r{qvs0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6--{vs|z-nz}yr?Q-tnqvr{ar\x07rH0r{qvsp-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{qvsn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-sy|n-_||sZnxH{vs|z-sy|n-u|{Sy||V{qr\x07H{vs|z-rp?-r|yv|{H{vs|z-sy|n-}v\x07ry_nv|H{vs|z-rp@-qvssrH{vs|z-sy|n-p|y|Ny}unH{vs|z-rp@-rzvvrH{vs|z-rp@-}rpynH{vs|z-sy|n-uv{v{rH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-ovtu{rH{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rH0vs{qrs-SYNal`UNQRQ--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-I}npxv{tK0v{pyqr-Iqvurv{tl}nlsntzr{K0v{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-IoqsK0v{pyqr-Iporllrsyrpv|{lsntzr{K0v{pyqr-Ir{zn}lp|zz|{l}nlsntzr{K0v{pyqr-Ir{zn}l}nlsntzr{K0v{pyqr-Is|tl}nlsntzr{K0v{pyqr-Iyvtul}nlortv{K0v{pyqr-Iyvtul}u|{tl}nlsntzr{K0v{pyqr-Iunq|zn}l}nlsntzr{K0v{pyqr-Ioz}zn}l}nlsntzr{K0v{pyqr-I{|znyzn}l}nlsntzr{K0v{pyqr-I}rpynzn}l}nlsntzr{K0v{pyqr-Iy|tqr}uosl}nlsntzr{K0v{pyqr-Ipyv}}v{tl}yn{rl}nlsntzr{Krp@- ||zcrp|5rp@-qvrpv|{9-rp@-rp|9-sy|n- ||z6-\n--sy|n-urn-J-q|5qvrpv|{9-rp|6H--rp@-q-J-qvrpv|{-7-urnH--rp@-}-J-rp|-:-qH--rp@-\0-J-}-<- ||zH--r{-{|znyv r5q-8-\x006H\frp@-to?u5rp@-p6-\n--rpA-X-J-rpA5=;=9-:>;=-<-@;=9-?;=-<-@;=9-:>;=6H--rpA-}-J-zv\x075rpA5p;ot9-X; 69-rpA5p;to9-X;\x07\b69-r}5p;o9-p;t66H--rpA-\0-J-zv\x075rpA5};\x07\b9-p;69-rpA5p;9-};\b \x0769-r}5};\x079-p;66H--sy|n-q-J-\0;\x07-:-zv{5\0;9-\0;\b6H--sy|n-r-J->;=r:>=H--r{-rp@5no5\0; -8-5\0;-:-\0;\b6-<-5C;=-7-q-8-r669-q-<-5\0;\x07-8-r69-\0;\x076H\frp@-u?to5rp@-p6-\n--rpA-X-J-rpA5>;=9-?;=-<-@;=9->;=-<-@;=9-@;=6H--rp@-}-J-no5snp5p;\x07\x07\x07-8-X;\x07\b 6-7-C;=-:-X;6H--r{-p; -7-zv\x075X;\x07\x07\x079-pynz}5}-:-X;\x07\x07\x079-=;=9->;=69-p;\b6H\frp@-trP|y|O\bUrvtu5nz}yr?Q-tnqvr{ar\x07r9-rpA-Sv{ny]|vv|{6-\n--sy|n--J-5Sv{ny]|vv|{;\b-:-z|qryO|{qv{tZv{;\b6-<-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6H--r{-r\x07r?Q5tnqvr{ar\x07r9-rp?59-=;B66;toH\f0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--rp@-svyrUvtuyvtu`unq|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-u-J-to?u5p|y|6H----u; -J-r\x07r?Q5}n{|Svyr;uvtuyvtu`unq|YZn}9-rp?5u; 9-=;=66;H----p|y|-J-u?to5u6H----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|arz}rnr5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-rz}rnrOvn-J-pynz}5}n{|Svyr;p|y|arz}rnrOvn9-:>==;=9->==;=6H----sy|n-`pnyr-J->;=-8-rz}rnrOvn-<-@==;=H----sy|n-o`pnyr-J->;=-:-rz}rnrOvn-<-@==;=H----p|y|;-J-p|y|;-7-`pnyrH----p|y|;o-J-p|y|;o-7-o`pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|av{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-v{Ovn-J-pynz}5}n{|Svyr;p|y|av{Ovn9-:>==;=9->==;=6H----rp@-pnyr-J-rp@5>;=6H----vs-5v{Ovn-K-=;=6-\n------pnyr;t-J->;=-:-v{Ovn-<-?==;=H----\f-ryr-\n------pnyr;-J->;=-8-v{Ovn-7-=;B-<-?==;=H------pnyr;t-J->;=-:-v{Ovn-7-=;B-<-?==;=H------pnyr;o-J->;=-8-v{Ovn-7-=;B-<-?==;=H----\f----p|y|-7J-pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrP|y|arz}rnr5to9-uv|tnz6H----to-J-svyrP|y|av{5to9-uv|tnz6H----r{-toH--\f--rp@-svyrP|{n5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-zrn{cny-J-uv|tnzh>jH----sy|n-zv{cny-J-uv|tnzh?jH----sy|n-zn\x07cny-J-uv|tnzh@jH----sy|n-p|{nOvn-J-pynz}5}n{|Svyr;p|{nP|{nOvn9-:>;=9->;=6H----sy|n-rqOvn-J->;=-7-p|{nOvn-8->;=H----sy|n-ovn`\0nrunys-J-p|{nOvn-7-p|{nOvn-<-?;=H----sy|n-y|}ry|-J-5rqOvn-:->;=6-<-zrn{cnyH----sy|n-y|}ruvtu-J-5>;=-:-rqOvn6-<-5>;=-:-zrn{cny6H----sy|n-ovn-J-5rqOvn-:-zrn{cny6-<-5>;=-:-zrn{cny6H----sy|n-pnyrlsnp|-J->;=-<-5zn\x07cny-:-zv{cny6H----rp@-ny-J-p|y|H----sy|n-zn\x07lny-J-zn\x075zn\x075p|y|;9-p|y|;t69-p|y|;o6H----vs-5p|{nOvn-I-=;=6-\n------ny-J-ny-7-5>;=-:-ovn`\0nrunys6-8-zn\x07lny-7-ovn`\0nrunysH----\f----rp@-rzn}-J-rp@5------5ny;-I-zrn{cny6-L-y|}ry|-7-ny;-8->;=-G-y|}ruvtu-7-ny;-8-ovn9------5ny;t-I-zrn{cny6-L-y|}ry|-7-ny;t-8->;=-G-y|}ruvtu-7-ny;t-8-ovn9------5ny;o-I-zrn{cny6-L-y|}ry|-7-ny;o-8->;=-G-y|}ruvtu-7-ny;o-8-ovn----6H----rp@-|`pnyr-J-rzn}-7-pnyrlsnp|H----p|y|-J-5ny-:-zrn{cny6-7-|`pnyr-8-zrn{cnyH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyr`nnv|{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-nnv|{Ovn-J-pynz}5}n{|Svyr;nnv|{`nnv|{Ovn9-:>;=9->;=6H----sy|n-n`pnyr-J->;=-8-nnv|{OvnH----sy|n-yzv{n{pr-J-=;?FF-7-p|y|;-8-=;BED-7-p|y|;t-8-=;>>A-7-p|y|;oH----p|y|-J-5p|y|-:-yzv{n{pr6-7-n`pnyr-8-yzv{n{prH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-r\x07rpSvyr5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrUvtuyvtu`unq|5to9-uv|tnz6H----to-J-svyrP|y|5to9-uv|tnz6H----to-J-svyrP|{n5to9-uv|tnz6H----to-J-svyr`nnv|{5to9-uv|tnz6H----r{-toH--\f0r{qvsZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--<<-JJJ-楼层-JJJ--o||y-vPr{Sy||-J-u|{Sy||V{qr\x07-I-:=;=>-\v\v-no5sy||V{qr\x07-:-u|{Sy||V{qr\x076-I-=;FFH--sy|n-sy||\\}npv\b-J->;=H--vs-5.vPr{Sy||6-\n----0vs-qrsv{rq5b`RlSY\\\\_l`afYRlcV`VOVYVaf6------qvpnqH----0r{qvs----sy||\\}npv\b-J-pynz}5=;?-7-zv{55>;=-8-PnzrnQvrpv|{;\b69->;=69-=;=9->;=6H--\f--<<-JJJJJJJJJJJ--<<-JJJ-顶部裁切-JJJ--sy|n-||sP]|tr-J-}|5pynz}5:PnzrnQvrpv|{;\b9-=;=9->;=69-@;=6H--vs-5----_||sZnx-K-=;==>-33----Sv{ny]|vv|{;\b-K-z|qryO|{qv{tZn\x07;\b-:-||sP]|tr-7-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6--6-\n----qvpnqH--\f--<<-JJJJJJJJJJJJJJ--<<-JJJ-前置裁切计算-JJJ--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-Sv{ny]|vv|{H------pyv}}rq-J-5pyv}}rh-v-j;sy||V{qr\x07-I-=;=-\v\v-no5sy||V{qr\x07-:-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--<<-JJJJJJJJJJJJJJJJ--0v{pyqr-Ipyv}}v{tl}yn{rlsntzr{K--rpA-qvssrP|y|-J-rpA5-qvssr9-p|y|Ny}un-7-|}npv\b-6H--<<-JJJ-高度色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6----qvssrP|y|;to-J-trP|y|O\bUrvtu5tnqvr{ar\x07r9-Sv{ny]|vv|{6H--0r{qvs--<<-JJJJJJJJJJJ--<<-JJJ-纯色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6----qvssrP|y|;to-J-p|{n{P|y|H--0r{qvs--<<-JJJJJJJJJJJ--_rsyrprqYvtu-rsyrprqYvtu-J-_rsyrprqYvtu5-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-6-6H--rp@-|nyRzvvr_nqvn{pr-J-rzvvrH--0v{pyqr-Iy|tqr}uoslsntzr{K--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--<<-nppzynv|{--0v{pyqr-Iyvtul}u|{tlsntzr{K--0v{pyqr-Iyvtulsntzr{lortv{K--0v{pyqr-Iyvtulsntzr{lzn}K--0v{pyqr-Iyvtulsntzr{lr{qK--<<-z|qynv|{--0v{pyqr-In|zn}lsntzr{K--rp@-|t|v{tYvtu-J-rsyrprqYvtu;qvrpQvssr-8-rsyrprqYvtu;v{qvrpQvssr-8-rsyrprqYvtu;qvrp`}rpyn-8-rsyrprqYvtu;v{qvrp`}rpyn-8-|nyRzvvr_nqvn{prH--0v{pyqr-Ir{zn}lsntzr{K--qvssrP|y|;n-J-qvssrP|y|;n-7-sy||\\}npv\b-7-ovtu{rH--0vs-qrsv{rq5b`Rl\\]N^bR6----qvssrP|y|;n-J->;=H--0r{qvs--tylSntP|y|-J-rpA5|t|v{tYvtu9-qvssrP|y|;n6H--<<-JJJ-颜色增益调整-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNQWb`aZR[a6----rp@-uP|y|-J-to?u5tylSntP|y|;to6H----uP|y|;\b-8J-p|y|`nnv|{H----uP|y|; -8J-p|y|Ovtu{rH----tylSntP|y|;to-J-zn\x075u?to5uP|y|69-=;=6H--0r{qvs--<<-JJJJJJJJJJJJJJJJJJ--ZNV[lZ\\QRYlP\\Y\\_--<<色调映射-色彩空间转换--0v{pyqr-I|{rzn}}v{tlsntzr{K--0v{pyqr-Ir{p|qv{tlsntzr{K--0v{pyqr-Is|tlsntzr{K--0v{pyqr-I}rzyv}yvrqlny}unlsntzr{K--0v{pyqr-Iqvurv{tlsntzr{K--<<-JJJ-全景图-JJJ--rp@-}n{|=a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 6H--}n{|=a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|=a|crr\x079-}n{|=; ||z6H--}n{|=a|crr\x07-J-}n{|=a|crr\x07-7-zn@5}n{|=;znv\x076H--rp@-}n{|>a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 6H--}n{|>a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|>a|crr\x079-}n{|>; ||z6H--}n{|>a|crr\x07-J-}n{|>a|crr\x07-7-zn@5}n{|>;znv\x076H--rpA-}n{|=P|y|-J-r\x07rPor5}n{|=;zn}9-rp@5SYV]lPbORlZN]-7-}n{|=a|crr\x07;\x079-}n{|=a|crr\x07;\b 66H--rpA-}n{|>P|y|-J-r\x07rPor5}n{|>;zn}9-rp@5SYV]lPbORlZN]-7-}n{|>a|crr\x07;\x079-}n{|>a|crr\x07;\b 66H--<<-JJJ-全景图瓦片细化-JJJ--0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6----rpA-rsv{rqPnzrn]|v|{-J-rsv{rq`prr{;znv\x07V{rr-7-Sv{ny]|vv|{H----sy|n-rsv{rqg||z-J-zv\x075}n{|=; ||z9-}n{|>; ||z9-rsv{rq`prr{;}n{|6H----rp@-rsv{rqPnzrncrr\x07-J-{|znyv r5rsv{rqPnzrn]|v|{;\x07\b 6H----rsv{rqPnzrncrr\x07-J- ||zcrp|5rp@5=;=9-=;=9->;=69-rsv{rqPnzrncrr\x079-rsv{rqg||z6H----rpA-rsv{rq]|v|{-J-rsv{rq`prr{;}|wrpv|{Znv\x07-7-rpA5rsv{rqPnzrncrr\x079->;=6H----rsv{rq]|v|{-J-rsv{rq]|v|{-<-rsv{rq]|v|{;H----rpA-rsv{rqP|y|-J-r\x07r?Q5rsv{rq`prr{;zn}9-5rsv{rq]|v|{;\x07\b-8->;=6-<-?;=6H----rsv{rqP|y|;n-J-rsv{rqP|y|;n-7-rsv{rq`prr{;|}npv\bH----sy|n-rsv{rq\\rsy|]|tr-J-r}5no5rsv{rq]|v|{;\x0769->;=6-7-r}5no5rsv{rq]|v|{;\b69->;=6-7-r}5rsv{rqPnzrn]|v|{; 9-=;=6H----rsv{rqP|y|-J-zv\x075a_N[`]N_R[alP\\Y\\_9-rsv{rqP|y|9-rsv{rq\\rsy|]|tr6H----rpA-rsv{rq]n{|=P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9-rsv{rq`prr{;}n{|6H----rpA-rsv{rq]n{|>P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9->;=-:-rsv{rq`prr{;}n{|6H----}n{|=P|y|-J-zv\x075}n{|=P|y|9-rpA5rsv{rq]n{|=P|y|;to9-}n{|=P|y|;n69-rsv{rq]n{|=P|y|;n6H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-rpA5rsv{rq]n{|>P|y|;to9-}n{|>P|y|;n69-rsv{rq]n{|>P|y|;n6H--0r{qvs--<<-JJJ-运动过程全景图通过深度剔除-JJJ--0vs-qrsv{rq5b`Rl]N[\\lQR]aU6----sy|n-}n{|=crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 69-=;=9-}n{|=Qr}u;zn\x07Qr}u6H----sy|n-}n{|>crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 69-=;=9-}n{|>Qr}u;zn\x07Qr}u6H----sy|n-}n{|=Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|=Qr}u;zn}9-}n{|=a|crr\x0766-7-}n{|=Qr}u;zn\x07Qr}uH----sy|n-}n{|>Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|>Qr}u;zn}9-}n{|>a|crr\x0766-7-}n{|>Qr}u;zn\x07Qr}uH----sy|n-}n{|=Qr}uQryn-J-no5}n{|=Qr}uZn}Qr}u-:-}n{|=crr\x07Qr}u6H----sy|n-}n{|>Qr}uQryn-J-no5}n{|>Qr}uZn}Qr}u-:-}n{|>crr\x07Qr}u6H----sy|n-zn\x07]n{|=Qr}uQryn-J-=;=@-7-}n{|=crr\x07Qr}uH----sy|n-zn\x07]n{|>Qr}uQryn-J-=;=@-7-}n{|>crr\x07Qr}uH----}n{|=P|y|-J-zv\x075}n{|=P|y|9-zv\x075}n{|=P|y|9-tylSntP|y|9-pynz}5}|tr-7->=;=9-=;=9->;=669-r}5zn\x07]n{|=Qr}uQryn9-}n{|=Qr}uQryn66H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-zv\x075}n{|>P|y|9-tylSntP|y|9-pynz}55>;=-:-}|tr6-7->=;=9-=;=9->;=669-r}5zn\x07]n{|>Qr}uQryn9-}n{|>Qr}uQryn66H--0r{qvs--<<-JJJ-全景图滤镜-JJJ--0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6----}n{|=P|y|;to-J-r\x07rpSvyr5}n{|=P|y|;to9-}n{|=;zn}Uv|tnz6H----}n{|>P|y|;to-J-r\x07rpSvyr5}n{|>P|y|;to9-}n{|>;zn}Uv|tnz6H--0r{qvs--ZNV[l]N[\\lP\\Y\\_--<<-JJJ-全景图颜色混合-JJJ--rpA-}n{|P|y|H--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-:-]V-8->;=66H--0ryvs-qrsv{rq5b`Rl`]_RNQla_N[`VaV\\[6----rp?-prr{Pr{rP||q-J-r|yv|{-7-}v\x07ry_nv|-<-?;=H----sy|n-n{vv|{_nqv-J-qvn{pr5rp?5=;=9-=;=69-prr{Pr{rP||q6-7->;?H----sy|n-n{vv|{]|tr-J-qvn{pr5tylSntP||q;\x07\b9-prr{Pr{rP||q6-<-n{vv|{_nqvH----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-z||ur}5=;=9-=;?9-}|tr-:-n{vv|{]|tr66H--0ryr----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-}|tr6H--0r{qvs--tylSntP|y|-J-zv\x075}n{|P|y|9-tylSntP|y|9-z|qryNy}un6H--ZNV[lR[Q\f"),vertex_default$2=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-`aN[QN_Q0qrsv{r-ZN_Xl`aR]->;=0qrsv{r-_\\\\SlZN_X->;=nvor-sy|n-lsrnrlvqlznxHn\bv{t-sy|n-_||sZnxHn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-rp@-cvr]|vv|{H{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rH0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-Il}nlrr\x07K0v{pyqr-I?l}nlrr\x07K0v{pyqr-Iqv}ynprzr{zn}l}nlrr\x07K0v{pyqr-Ir{zn}l}nlrr\x07K0v{pyqr-Ip|y|l}nlrr\x07K0v{pyqr-Is|tl}nlrr\x07K0v{pyqr-Iz|}untrl}nlrr\x07K0v{pyqr-Ixv{{v{tl}nlrr\x07K0v{pyqr-Iunq|zn}l}nlrr\x07K0v{pyqr-Iy|tqr}uosl}nlrr\x07K0v{pyqr-Ipyv}}v{tl}yn{rl}nlrr\x07KZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--0v{pyqr-Ilrr\x07K--0v{pyqr-I?lrr\x07K--0v{pyqr-Ip|y|lrr\x07K--0v{pyqr-Iortv{{|znylrr\x07K--0v{pyqr-Iz|}u{|znylrr\x07K--0v{pyqr-Ixv{onrlrr\x07K--0v{pyqr-Ixv{{|znylrr\x07K--0v{pyqr-Iqrsny{|znylrr\x07K0vs{qrs-SYNal`UNQRQ-<<-[|zny-p|z}rq-vu-qrvnvr-ur{-SYNal`UNQRQ--[|zny-J-{|znyv r5-n{s|zrq[|zny-6H--0vsqrs-b`RlaN[TR[a----an{tr{-J-{|znyv r5-n{s|zrqan{tr{-6H----Ovn{tr{-J-{|znyv r5-p|5-[|zny9-an{tr{-6-7-n{tr{;-6H--0r{qvs0r{qvs--0v{pyqr-Iortv{lrr\x07K--0v{pyqr-Iz|}untrlrr\x07K--0v{pyqr-Ixv{{v{tlrr\x07K--0v{pyqr-Iqv}ynprzr{zn}lrr\x07K--0v{pyqr-I}|wrplrr\x07K--0v{pyqr-Iy|tqr}uoslrr\x07K--0v{pyqr-Ipyv}}v{tl}yn{rlrr\x07K--cvr]|vv|{-J-:-z]|vv|{;\x07\b H--Sv{ny]|vv|{-J-rpA5n{s|zrq9->;=6H--0vsqrs-b`RlV[`aN[PV[T----Sv{ny]|vv|{-J-v{n{prZnv\x07-7-Sv{ny]|vv|{H--0r{qvs--Sv{ny]|vv|{-J-z|qryZnv\x07-7-Sv{ny]|vv|{H--zn@-pnzrn_|nv|{Znv\x07-J-zn@5vrZnv\x07h=jh=j9-vrZnv\x07h>jh=j9-vrZnv\x07h?jh=j9-vrZnv\x07h=jh>j9-vrZnv\x07h>jh>j9-vrZnv\x07h?jh>j9-vrZnv\x07h=jh?j9-vrZnv\x07h>jh?j9-vrZnv\x07h?jh?j6H--PnzrnQvrpv|{-J-{|znyv r5pnzrn_|nv|{Znv\x07-7-rp@5=;=9-=;=9-:>;=66H--_||sZnx-J-=;=H--0vs-qrsv{rq5b`RlcR_aRelZN_X6----_||sZnx-J-z||ur}5_\\\\SlZN_X-:-ZN_Xl`aR]9-_\\\\SlZN_X9-lsrnrlvqlznx6H--0r{qvs--0v{pyqr-I|yq}|lrr\x07K--0v{pyqr-Ir{zn}lrr\x07K--0v{pyqr-Iunq|zn}lrr\x07K--0v{pyqr-Is|tlrr\x07K--ZNV[lR[Q\f"),fragment_default$2=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("0qrsv{r-`aN[QN_Q0qrsv{r-_RSYRPaVcVaf0qrsv{r-PYRN_P\\Na0qrsv{r-a_N[`]N_R[Pf0qrsv{r-OYNPXlP\\Y\\_-rpA5=;=EC9-=;>=C9-=;>AF9->;=60qrsv{r-a_N[`]N_R[alP\\Y\\_-rpA5=;=9-=;=9-=;=9-=;=60qrsv{r-SYV]lPbORlZN]-:>;=p-]n{|-\n--nz}yrPor-zn}H--sy|n-zn}`v rH--rpA-zn}Uv|tnzH-<<-}rnx-zrn{-zv{-zn\x07--znA-znv\x07H--sy|n- ||zH\fH{vs|z-]n{|-}n{|=H{vs|z-]n{|-}n{|>H0vs-qrsv{rq5b`Rl]N[\\lQR]aU6--p-]n{|Qr}u-\n----nz}yrPor-zn}H----sy|n-zn\x07Qr}uH--\fH--{vs|z-]n{|Qr}u-}n{|=Qr}uH--{vs|z-]n{|Qr}u-}n{|>Qr}uH0r{qvs0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--p-Svyr]nnz-\n----sy|n-nnv|{`nnv|{OvnH----sy|n-p|{nP|{nOvnH----nz}yr?Q-uvtuyvtu`unq|YZn}H----sy|n-p|y|arz}rnrOvnH----sy|n-p|y|av{OvnH--\fH--{vs|z-Svyr]nnz-}n{|SvyrH0r{qvs0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6--p-_rsv{rq`prr{-\n----nz}yr?Q-zn}H----znA-}|wrpv|{Znv\x07H----znA-znv\x07V{rrH----sy|n-|}npv\bH----sy|n-}n{|H--\fH--{vs|z-_rsv{rq`prr{-rsv{rq`prr{H0r{qvs{vs|z-sy|n-sy||V{qr\x07H{vs|z-sy|n-z|qryNy}unH{vs|z-sy|n-}|trH0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6--{vs|z-rp@-p|{n{P|y|H0r{qvs0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6--{vs|z-nz}yr?Q-tnqvr{ar\x07rH0r{qvsp-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{qvsn\bv{t-rpA-Sv{ny]|vv|{Hn\bv{t-rp@-PnzrnQvrpv|{Hn\bv{t-sy|n-_||sZnxH{vs|z-sy|n-u|{Sy||V{qr\x07H{vs|z-rp?-r|yv|{H{vs|z-sy|n-}v\x07ry_nv|H{vs|z-rp@-qvssrH{vs|z-sy|n-p|y|Ny}unH{vs|z-rp@-rzvvrH{vs|z-sy|n-|tu{rH{vs|z-sy|n-zrny{rH{vs|z-sy|n-|}npv\bH{vs|z-sy|n-ovtu{rH0vsqrs-a_N[`]N_R[Pf--{vs|z-sy|n-n{}nr{p\bH0r{qvs0vsqrs-_RSYRPaVcVaf--{vs|z-sy|n-rsyrpvv\bH0r{qvs0vsqrs-PYRN_P\\Na--{vs|z-sy|n-pyrnp|nH--{vs|z-sy|n-pyrnp|n_|tu{rH0r{qvs0vsqrs-b`Rl`URR[--{vs|z-rp@-urr{H0r{qvs{vs|z-rp@-z|qryO|{qv{tZn\x07H{vs|z-rp@-z|qryO|{qv{tZv{H<<u调整{vs|z-sy|n-p|y|`nnv|{H{vs|z-sy|n-p|y|Ovtu{rHn\bv{t-rp@-cvr]|vv|{H0vs{qrs-SYNal`UNQRQ--n\bv{t-rp@-[|znyH--0vsqrs-b`RlaN[TR[a----n\bv{t-rp@-an{tr{H----n\bv{t-rp@-Ovn{tr{H--0r{qvs0r{qvs0v{pyqr-Ip|zz|{K0v{pyqr-I}npxv{tK0v{pyqr-Iqvurv{tl}nlsntzr{K0v{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-IoqsK0v{pyqr-Iporllrsyrpv|{lsntzr{K0v{pyqr-Ir{zn}lp|zz|{l}nlsntzr{K0v{pyqr-Ir{zn}l}u\bvpnyl}nlsntzr{K0v{pyqr-Is|tl}nlsntzr{K0v{pyqr-Iyvtul}nlortv{K0v{pyqr-Iyvtul}u\bvpnyl}nlsntzr{K0v{pyqr-Iunq|zn}l}nlsntzr{K0v{pyqr-Ioz}zn}l}nlsntzr{K0v{pyqr-I{|znyzn}l}nlsntzr{K0v{pyqr-Ipyrnp|nl}nlsntzr{K0v{pyqr-I|tu{rzn}l}nlsntzr{K0v{pyqr-Izrny{rzn}l}nlsntzr{K0v{pyqr-Iy|tqr}uosl}nlsntzr{K0v{pyqr-Ipyv}}v{tl}yn{rl}nlsntzr{Krp@- ||zcrp|5rp@-qvrpv|{9-rp@-rp|9-sy|n- ||z6-\n--sy|n-urn-J-q|5qvrpv|{9-rp|6H--rp@-q-J-qvrpv|{-7-urnH--rp@-}-J-rp|-:-qH--rp@-\0-J-}-<- ||zH--r{-{|znyv r5q-8-\x006H\frp@-to?u5rp@-p6-\n--rpA-X-J-rpA5=;=9-:>;=-<-@;=9-?;=-<-@;=9-:>;=6H--rpA-}-J-zv\x075rpA5p;ot9-X; 69-rpA5p;to9-X;\x07\b69-r}5p;o9-p;t66H--rpA-\0-J-zv\x075rpA5};\x07\b9-p;69-rpA5p;9-};\b \x0769-r}5};\x079-p;66H--sy|n-q-J-\0;\x07-:-zv{5\0;9-\0;\b6H--sy|n-r-J->;=r:>=H--r{-rp@5no5\0; -8-5\0;-:-\0;\b6-<-5C;=-7-q-8-r669-q-<-5\0;\x07-8-r69-\0;\x076H\frp@-u?to5rp@-p6-\n--rpA-X-J-rpA5>;=9-?;=-<-@;=9->;=-<-@;=9-@;=6H--rp@-}-J-no5snp5p;\x07\x07\x07-8-X;\x07\b 6-7-C;=-:-X;6H--r{-p; -7-zv\x075X;\x07\x07\x079-pynz}5}-:-X;\x07\x07\x079-=;=9->;=69-p;\b6H\frp@-trP|y|O\bUrvtu5nz}yr?Q-tnqvr{ar\x07r9-rpA-Sv{ny]|vv|{6-\n--sy|n--J-5Sv{ny]|vv|{;\b-:-z|qryO|{qv{tZv{;\b6-<-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6H--r{-r\x07r?Q5tnqvr{ar\x07r9-rp?59-=;B66;toH\f0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6--rp@-svyrUvtuyvtu`unq|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-u-J-to?u5p|y|6H----u; -J-r\x07r?Q5}n{|Svyr;uvtuyvtu`unq|YZn}9-rp?5u; 9-=;=66;H----p|y|-J-u?to5u6H----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|arz}rnr5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-rz}rnrOvn-J-pynz}5}n{|Svyr;p|y|arz}rnrOvn9-:>==;=9->==;=6H----sy|n-`pnyr-J->;=-8-rz}rnrOvn-<-@==;=H----sy|n-o`pnyr-J->;=-:-rz}rnrOvn-<-@==;=H----p|y|;-J-p|y|;-7-`pnyrH----p|y|;o-J-p|y|;o-7-o`pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|av{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-v{Ovn-J-pynz}5}n{|Svyr;p|y|av{Ovn9-:>==;=9->==;=6H----rp@-pnyr-J-rp@5>;=6H----vs-5v{Ovn-K-=;=6-\n------pnyr;t-J->;=-:-v{Ovn-<-?==;=H----\f-ryr-\n------pnyr;-J->;=-8-v{Ovn-7-=;B-<-?==;=H------pnyr;t-J->;=-:-v{Ovn-7-=;B-<-?==;=H------pnyr;o-J->;=-8-v{Ovn-7-=;B-<-?==;=H----\f----p|y|-7J-pnyrH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyrP|y|5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrP|y|arz}rnr5to9-uv|tnz6H----to-J-svyrP|y|av{5to9-uv|tnz6H----r{-toH--\f--rp@-svyrP|{n5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-zrn{cny-J-uv|tnzh>jH----sy|n-zv{cny-J-uv|tnzh?jH----sy|n-zn\x07cny-J-uv|tnzh@jH----sy|n-p|{nOvn-J-pynz}5}n{|Svyr;p|{nP|{nOvn9-:>;=9->;=6H----sy|n-rqOvn-J->;=-7-p|{nOvn-8->;=H----sy|n-ovn`\0nrunys-J-p|{nOvn-7-p|{nOvn-<-?;=H----sy|n-y|}ry|-J-5rqOvn-:->;=6-<-zrn{cnyH----sy|n-y|}ruvtu-J-5>;=-:-rqOvn6-<-5>;=-:-zrn{cny6H----sy|n-ovn-J-5rqOvn-:-zrn{cny6-<-5>;=-:-zrn{cny6H----sy|n-pnyrlsnp|-J->;=-<-5zn\x07cny-:-zv{cny6H----rp@-ny-J-p|y|H----sy|n-zn\x07lny-J-zn\x075zn\x075p|y|;9-p|y|;t69-p|y|;o6H----vs-5p|{nOvn-I-=;=6-\n------ny-J-ny-7-5>;=-:-ovn`\0nrunys6-8-zn\x07lny-7-ovn`\0nrunysH----\f----rp@-rzn}-J-rp@5------5ny;-I-zrn{cny6-L-y|}ry|-7-ny;-8->;=-G-y|}ruvtu-7-ny;-8-ovn9------5ny;t-I-zrn{cny6-L-y|}ry|-7-ny;t-8->;=-G-y|}ruvtu-7-ny;t-8-ovn9------5ny;o-I-zrn{cny6-L-y|}ry|-7-ny;o-8->;=-G-y|}ruvtu-7-ny;o-8-ovn----6H----rp@-|`pnyr-J-rzn}-7-pnyrlsnp|H----p|y|-J-5ny-:-zrn{cny6-7-|`pnyr-8-zrn{cnyH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-svyr`nnv|{5rp@-p|y|9-rpA-uv|tnz6-\n----sy|n-nnv|{Ovn-J-pynz}5}n{|Svyr;nnv|{`nnv|{Ovn9-:>;=9->;=6H----sy|n-n`pnyr-J->;=-8-nnv|{OvnH----sy|n-yzv{n{pr-J-=;?FF-7-p|y|;-8-=;BED-7-p|y|;t-8-=;>>A-7-p|y|;oH----p|y|-J-5p|y|-:-yzv{n{pr6-7-n`pnyr-8-yzv{n{prH----r{-pynz}5p|y|9-=;=9->;=6H--\f--rp@-r\x07rpSvyr5rp@-p|y|9-rpA-uv|tnz6-\n----rp@-to-J-p|y|H----to-J-svyrUvtuyvtu`unq|5to9-uv|tnz6H----to-J-svyrP|y|5to9-uv|tnz6H----to-J-svyrP|{n5to9-uv|tnz6H----to-J-svyr`nnv|{5to9-uv|tnz6H----r{-toH--\f0r{qvsZNV[lORS\\_R|vq-znv{56-\n--ZNV[l`aN_a--<<-JJJ-楼层-JJJ--o||y-vPr{Sy||-J-u|{Sy||V{qr\x07-I-:=;=>-\v\v-no5sy||V{qr\x07-:-u|{Sy||V{qr\x076-I-=;FFH--sy|n-sy||\\}npv\b-J->;=H--vs-5.vPr{Sy||6-\n----0vs-qrsv{rq5b`RlSY\\\\_l`afYRlcV`VOVYVaf6------qvpnqH----0r{qvs----sy||\\}npv\b-J-pynz}5=;?-7-zv{55>;=-8-PnzrnQvrpv|{;\b69->;=69-=;=9->;=6H--\f--<<-JJJJJJJJJJJ--<<-JJJ-顶部裁切-JJJ--sy|n-||sP]|tr-J-}|5pynz}5:PnzrnQvrpv|{;\b9-=;=9->;=69-@;=6H--vs-5----_||sZnx-K-=;==>-33----Sv{ny]|vv|{;\b-K-z|qryO|{qv{tZn\x07;\b-:-||sP]|tr-7-5z|qryO|{qv{tZn\x07;\b-:-z|qryO|{qv{tZv{;\b6--6-\n----qvpnqH--\f--<<-JJJJJJJJJJJJJJ--<<-JJJ-前置裁切计算-JJJ--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-Sv{ny]|vv|{H------pyv}}rq-J-5pyv}}rh-v-j;sy||V{qr\x07-I-=;=-\v\v-no5sy||V{qr\x07-:-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--<<-JJJJJJJJJJJJJJJJ--0v{pyqr-Ipyv}}v{tl}yn{rlsntzr{K--rpA-qvssrP|y|-J-rpA5-qvssr9-p|y|Ny}un-7-|}npv\b-6H--<<-JJJ-高度色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNYaVabQR6----qvssrP|y|;to-J-trP|y|O\bUrvtu5tnqvr{ar\x07r9-Sv{ny]|vv|{6H--0r{qvs--<<-JJJJJJJJJJJ--<<-JJJ-纯色-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lP\\[`aN[a6----qvssrP|y|;to-J-p|{n{P|y|H--0r{qvs--<<-JJJJJJJJJJJ--_rsyrprqYvtu-rsyrprqYvtu-J-_rsyrprqYvtu5-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-69-rp@5-=;=-6-6H--rp@-|nyRzvvr_nqvn{pr-J-rzvvrH--0v{pyqr-Iy|tqr}uoslsntzr{K--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|tu{rzn}lsntzr{K0v{pyqr-Izrny{rzn}lsntzr{K--0v{pyqr-I{|znylsntzr{lortv{K--0v{pyqr-I{|znylsntzr{lzn}K--0v{pyqr-Ipyrnp|nl{|znylsntzr{lortv{K--0v{pyqr-Ipyrnp|nl{|znylsntzr{lzn}K--0v{pyqr-Irzvvrzn}lsntzr{K--<<-nppzynv|{--0v{pyqr-Iyvtul}u\bvpnylsntzr{K--0v{pyqr-Iyvtulsntzr{lortv{K--0v{pyqr-Iyvtulsntzr{lzn}K--0v{pyqr-Iyvtulsntzr{lr{qK--<<-z|qynv|{--0v{pyqr-In|zn}lsntzr{K--rp@-|t|v{tYvtu-J-rsyrprqYvtu;qvrpQvssr-8-rsyrprqYvtu;v{qvrpQvssr-8-rsyrprqYvtu;qvrp`}rpyn-8-rsyrprqYvtu;v{qvrp`}rpyn-8-|nyRzvvr_nqvn{prH<<-s|-n{zvv|{--0vsqrs-a_N[`]N_R[Pf----qvssrP|y|;n-7J-nnr5->;=-:-n{}nr{p\b-7-5>;=-:-znrvny;}rpyn_|tu{r6-8-yv{rna|_rynvrYzv{n{pr5-rsyrprqYvtu;qvrp`}rpyn-8-rsyrprqYvtu;v{qvrp`}rpyn-6-6H--0r{qvs--qvssrP|y|;n-J-qvssrP|y|;n-7-sy||\\}npv\b-7-ovtu{rH--0vs-qrsv{rq5b`Rl\\]N^bR6----qvssrP|y|;n-J->;=H--0r{qvs--tylSntP|y|-J-rpA5|t|v{tYvtu9-qvssrP|y|;n6H--<<-JJJ-颜色增益调整-JJJ--0vs-qrsv{rq5b`RlP\\Y\\_lNQWb`aZR[a6----rp@-uP|y|-J-to?u5tylSntP|y|;to6H----uP|y|;\b-8J-p|y|`nnv|{H----uP|y|; -8J-p|y|Ovtu{rH----tylSntP|y|;to-J-zn\x075u?to5uP|y|69-=;=6H--0r{qvs--<<-JJJJJJJJJJJJJJJJJJ--ZNV[lZ\\QRYlP\\Y\\_--<<色调映射-色彩空间转换--0v{pyqr-I|{rzn}}v{tlsntzr{K--0v{pyqr-Ir{p|qv{tlsntzr{K--0v{pyqr-Is|tlsntzr{K--0v{pyqr-I}rzyv}yvrqlny}unlsntzr{K--0v{pyqr-Iqvurv{tlsntzr{K--<<-JJJ-全景图-JJJ--rp@-}n{|=a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 6H--}n{|=a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|=a|crr\x079-}n{|=; ||z6H--}n{|=a|crr\x07-J-}n{|=a|crr\x07-7-zn@5}n{|=;znv\x076H--rp@-}n{|>a|crr\x07-J-{|znyv r5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 6H--}n{|>a|crr\x07-J- ||zcrp|5PnzrnQvrpv|{9-}n{|>a|crr\x079-}n{|>; ||z6H--}n{|>a|crr\x07-J-}n{|>a|crr\x07-7-zn@5}n{|>;znv\x076H--rpA-}n{|=P|y|-J-r\x07rPor5}n{|=;zn}9-rp@5SYV]lPbORlZN]-7-}n{|=a|crr\x07;\x079-}n{|=a|crr\x07;\b 66H--rpA-}n{|>P|y|-J-r\x07rPor5}n{|>;zn}9-rp@5SYV]lPbORlZN]-7-}n{|>a|crr\x07;\x079-}n{|>a|crr\x07;\b 66H--<<-JJJ-全景图瓦片细化-JJJ--0vs-qrsv{rq5b`Rl_RSV[RQl`P_RR[6----rpA-rsv{rqPnzrn]|v|{-J-rsv{rq`prr{;znv\x07V{rr-7-Sv{ny]|vv|{H----sy|n-rsv{rqg||z-J-zv\x075}n{|=; ||z9-}n{|>; ||z9-rsv{rq`prr{;}n{|6H----rp@-rsv{rqPnzrncrr\x07-J-{|znyv r5rsv{rqPnzrn]|v|{;\x07\b 6H----rsv{rqPnzrncrr\x07-J- ||zcrp|5rp@5=;=9-=;=9->;=69-rsv{rqPnzrncrr\x079-rsv{rqg||z6H----rpA-rsv{rq]|v|{-J-rsv{rq`prr{;}|wrpv|{Znv\x07-7-rpA5rsv{rqPnzrncrr\x079->;=6H----rsv{rq]|v|{-J-rsv{rq]|v|{-<-rsv{rq]|v|{;H----rpA-rsv{rqP|y|-J-r\x07r?Q5rsv{rq`prr{;zn}9-5rsv{rq]|v|{;\x07\b-8->;=6-<-?;=6H----rsv{rqP|y|;n-J-rsv{rqP|y|;n-7-rsv{rq`prr{;|}npv\bH----sy|n-rsv{rq\\rsy|]|tr-J-r}5no5rsv{rq]|v|{;\x0769->;=6-7-r}5no5rsv{rq]|v|{;\b69->;=6-7-r}5rsv{rqPnzrn]|v|{; 9-=;=6H----rsv{rqP|y|-J-zv\x075a_N[`]N_R[alP\\Y\\_9-rsv{rqP|y|9-rsv{rq\\rsy|]|tr6H----rpA-rsv{rq]n{|=P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9-rsv{rq`prr{;}n{|6H----rpA-rsv{rq]n{|>P|y|-J-zv\x075rsv{rqP|y|9-a_N[`]N_R[alP\\Y\\_9->;=-:-rsv{rq`prr{;}n{|6H----}n{|=P|y|-J-zv\x075}n{|=P|y|9-rpA5rsv{rq]n{|=P|y|;to9-}n{|=P|y|;n69-rsv{rq]n{|=P|y|;n6H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-rpA5rsv{rq]n{|>P|y|;to9-}n{|>P|y|;n69-rsv{rq]n{|>P|y|;n6H--0r{qvs--<<-JJJ-运动过程全景图通过深度剔除-JJJ--0vs-qrsv{rq5b`Rl]N[\\lQR]aU6----sy|n-}n{|=crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|=;znv\x07h@j;\x07\b 69-=;=9-}n{|=Qr}u;zn\x07Qr}u6H----sy|n-}n{|>crr\x07Qr}u-J-pynz}5yr{tu5Sv{ny]|vv|{;\x07\b -:-}n{|>;znv\x07h@j;\x07\b 69-=;=9-}n{|>Qr}u;zn\x07Qr}u6H----sy|n-}n{|=Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|=Qr}u;zn}9-}n{|=a|crr\x0766-7-}n{|=Qr}u;zn\x07Qr}uH----sy|n-}n{|>Qr}uZn}Qr}u-J-{}npx_TONa|Qr}u5r\x07rPor5}n{|>Qr}u;zn}9-}n{|>a|crr\x0766-7-}n{|>Qr}u;zn\x07Qr}uH----sy|n-}n{|=Qr}uQryn-J-no5}n{|=Qr}uZn}Qr}u-:-}n{|=crr\x07Qr}u6H----sy|n-}n{|>Qr}uQryn-J-no5}n{|>Qr}uZn}Qr}u-:-}n{|>crr\x07Qr}u6H----sy|n-zn\x07]n{|=Qr}uQryn-J-=;=@-7-}n{|=crr\x07Qr}uH----sy|n-zn\x07]n{|>Qr}uQryn-J-=;=@-7-}n{|>crr\x07Qr}uH----}n{|=P|y|-J-zv\x075}n{|=P|y|9-zv\x075}n{|=P|y|9-tylSntP|y|9-pynz}5}|tr-7->=;=9-=;=9->;=669-r}5zn\x07]n{|=Qr}uQryn9-}n{|=Qr}uQryn66H----}n{|>P|y|-J-zv\x075}n{|>P|y|9-zv\x075}n{|>P|y|9-tylSntP|y|9-pynz}55>;=-:-}|tr6-7->=;=9-=;=9->;=669-r}5zn\x07]n{|>Qr}uQryn9-}n{|>Qr}uQryn66H--0r{qvs--<<-JJJ-全景图滤镜-JJJ--0vs-qrsv{rq5b`Rl]N[\\lSVYaR_6----}n{|=P|y|;to-J-r\x07rpSvyr5}n{|=P|y|;to9-}n{|=;zn}Uv|tnz6H----}n{|>P|y|;to-J-r\x07rpSvyr5}n{|>P|y|;to9-}n{|>;zn}Uv|tnz6H--0r{qvs--ZNV[l]N[\\lP\\Y\\_--<<-JJJ-全景图颜色混合-JJJ--rpA-}n{|P|y|H--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-:-]V-8->;=66H--0ryvs-qrsv{rq5b`Rl`]_RNQla_N[`VaV\\[6----rp?-prr{Pr{rP||q-J-r|yv|{-7-}v\x07ry_nv|-<-?;=H----sy|n-n{vv|{_nqv-J-qvn{pr5rp?5=;=9-=;=69-prr{Pr{rP||q6-7->;?H----sy|n-n{vv|{]|tr-J-qvn{pr5tylSntP||q;\x07\b9-prr{Pr{rP||q6-<-n{vv|{_nqvH----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-z||ur}5=;=9-=;?9-}|tr-:-n{vv|{]|tr66H--0ryr----}n{|P|y|-J-zv\x075}n{|=P|y|9-}n{|>P|y|9-}|tr6H--0r{qvs--tylSntP|y|-J-zv\x075}n{|P|y|9-tylSntP|y|9-z|qryNy}un6H--ZNV[lR[Q\f"),Uniform=class extends three.Uniform{constructor(e){super(e)}};function setUniform(e,t){t&&e.value&&(t instanceof three.Color||t instanceof three.Matrix4||t instanceof three.Matrix3||t instanceof three.Vector2||t instanceof three.Vector3||t instanceof three.Vector4)?e.value.copy(t):Array.isArray(t)?e.value=t.slice():e.value=t}function cloneUniforms(e){return three.UniformsUtils.clone(e)}function mergeUniforms(...e){return three.UniformsUtils.merge(e)}function defineProperty(e,t,n){return Object.defineProperty(e,t,n)}var fastProto=null;function FastObject(e){if(fastProto!==null&&typeof fastProto.property){let e=fastProto;return fastProto=FastObject.prototype=null,e}return fastProto=FastObject.prototype=e==null?Object.create(null):e,new FastObject}var inlineCacheCutoff=10;for(let e=0;e<=inlineCacheCutoff;e++)FastObject();function toFastProperties(e){return FastObject(e)}var TAU$2=Math.PI*2;function formatRad$1(e){return e>=0&&e<TAU$2?e:(e%TAU$2+TAU$2)%TAU$2}function coordinatesToVector(e,t){let n=Math.abs(Math.cos(e.latitude)),r=-Math.sin(e.longitude)*n,o=-Math.sin(e.latitude),s=-Math.cos(e.longitude)*n;return t?t.set(r,o,s):new three.Vector3(r,o,s)}function vectorToCoordinates(e){return{longitude:formatRad$1(-Math.atan2(e.x,-e.z)),latitude:-Math.asin(e.y/1)}}function longitudeToHeading(e){return(-e/Math.PI*180-90)/360+.25}function headingToLongitude(e){return-((e-.25)*360+90)/180*Math.PI}var start=Date.now();typeof performance<`u`&&(typeof performance.timeOrigin==`number`?start=performance.timeOrigin:performance.timing!==void 0&&(start=performance.timing.navigationStart));var now=typeof performance<`u`?(()=>start+performance.now()):(()=>Date.now());function dateNowToDomHighResTimeStamp(e){return e-start}function clamp$1(e,t,n){return e<t?t:typeof n==`number`&&e>n?n:e}var DEFAULT_ASPECT=1,DEFAULT_NEAR=.1,DEFAULT_FAR=2e3,TAU$1=Math.PI*2,PI_2=Math.PI/2;function formatRad(e){return e>0&&e<=TAU$1?e:(e%TAU$1+TAU$1)%TAU$1}function matrixLerp(e,t,n,r){n=Math.pow(n,4);for(var o=0;o<16;o++)r.elements[o]=e.elements[o]+(t.elements[o]-e.elements[o])*n;return r}var Camera=class extends three.Camera{constructor(e,t=DEFAULT_ASPECT,n=DEFAULT_NEAR,r=DEFAULT_FAR,o=new three.Vector2,s=new three.Vector2(512,512),c=1){super(),this.fov=e,this.aspect=t,this.near=n,this.far=r,this.perspToOrtho=o,this.resolution=s,this.pixelRatio=c,this.time=0,this.controllerMode=null,this.needsRender=!0,this.refineModel=!0,this.pose={longitude:0,latitude:0,fov:e,distance:0,offset:new three.Vector3},this.computePose(),this.perspectiveCamera=new three.PerspectiveCamera(this.fov,this.aspect,.001,this.far);let l=Math.max(this.orthoDistance,.01)*Math.tan(.5*this.fov/180*Math.PI),u=-.5*this.aspect*2*l;this.orthographicCamera=new three.OrthographicCamera(u,-u,l,-l,.001,this.far),this.computeProjectionMatrix(),this.lastValues={position:this.position.clone(),quaternion:this.quaternion.clone(),scale:this.scale.clone(),fov:this.fov,aspect:this.aspect,near:this.near,far:this.far,orthoDistance:this.orthoDistance,perspToOrtho:this.perspToOrtho.clone()},this.type=this.perspToOrtho.x<1?`PerspectiveCamera`:`OrthographicCamera`,this.autoNearFar=!0}get orthoDistance(){return this.pose.distance>1?this.pose.distance:1+(this.pose.distance-1)*this.perspToOrtho.x}get zoom(){return this.type===`OrthographicCamera`?this.orthographicCamera.zoom:this.type===`PerspectiveCamera`?this.perspectiveCamera.zoom:1}get top(){return this.type===`OrthographicCamera`?this.orthographicCamera.top:0}get bottom(){return this.type===`OrthographicCamera`?this.orthographicCamera.bottom:0}get left(){return this.type===`OrthographicCamera`?this.orthographicCamera.left:0}get right(){return this.type===`OrthographicCamera`?this.orthographicCamera.right:0}getDirection(e){return coordinatesToVector(this.pose,e)}computePose(e=0){this.updateMatrix();let t=this.matrix.elements;return this.pose.latitude=Math.asin(clamp$1(t[9],-1,1)),Math.abs(t[9])<.9999999?this.pose.longitude=formatRad(Math.atan2(t[8],t[10])):this.pose.longitude=formatRad(Math.atan2(-t[2],t[0])),this.pose.fov=this.fov,this.pose.distance=e,this.pose.offset=new three.Vector3(-t[8],-t[9],-t[10]).setLength(this.pose.distance).add(this.position),this}setFromPose(e){var t,n,r,o,s;let c=formatRad((t=e.longitude)==null?this.pose.longitude:t),l=Math.max(-PI_2+1e-4,Math.min(PI_2-1e-4,(n=e.latitude)==null?this.pose.latitude:n)),u=(r=e.fov)==null?this.pose.fov:r,d=(o=e.distance)==null?this.pose.distance:o,f=(s=e.offset)==null?this.pose.offset:s,p=coordinatesToVector({longitude:c,latitude:l}).normalize();return this.position.set(0,0,0),this.lookAt(p),this.position.add(f).sub(p.clone().setLength(d)),this.fov!==u&&(this.fov=u,this.perspectiveCamera.fov=u,this.updateProjectionMatrix()),this.updateMatrixWorld(!0),this.pose.longitude=c,this.pose.latitude=l,this.pose.fov=u,this.pose.distance=d,this.pose.offset.copy(f),this.needsRender=!0,this}copyPose(){return{longitude:this.pose.longitude,latitude:this.pose.latitude,fov:this.pose.fov,distance:this.pose.distance,offset:this.pose.offset.clone()}}computeProjectionMatrix(){matrixLerp(this.orthographicCamera.projectionMatrix,this.perspectiveCamera.projectionMatrix,1-this.perspToOrtho.x,this.projectionMatrix),this.projectionMatrixInverse.getInverse(this.projectionMatrix),this.needsRender=!0}setViewOffset(e,t,n,r,o,s){this.perspectiveCamera.setViewOffset(e,t,n,r,o,s),this.orthographicCamera.setViewOffset(e,t,n,r,o,s),this.computeProjectionMatrix()}get view(){return this.perspectiveCamera.view?Object.assign({},this.perspectiveCamera.view):null}clearViewOffset(){this.perspectiveCamera.clearViewOffset(),this.orthographicCamera.clearViewOffset(),this.computeProjectionMatrix()}updateProjectionMatrix(){this.perspectiveCamera.updateProjectionMatrix(),this.orthographicCamera.updateProjectionMatrix(),this.computeProjectionMatrix()}get perspectiveProjectionMatrix(){return this.perspectiveCamera.projectionMatrix}get perspectiveProjectionMatrixInverse(){return this.perspectiveCamera.projectionMatrixInverse}get orthographicProjectionMatrix(){return this.orthographicCamera.projectionMatrix}get orthographicProjectionMatrixInverse(){return this.orthographicCamera.projectionMatrixInverse}updateTime(e){this.time=e;let t=!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(),t=!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.orthoDistance!==this.orthoDistance||this.lastValues.aspect!==this.aspect){let e=Math.max(this.orthoDistance,.01)*Math.tan(.5*this.fov/180*Math.PI),n=-.5*this.aspect*2*e;this.orthographicCamera.left=n,this.orthographicCamera.right=-n,this.orthographicCamera.top=e,this.orthographicCamera.bottom=-e,this.orthographicCamera.near=this.near,this.orthographicCamera.far=this.far,this.orthographicCamera.updateProjectionMatrix(),t=!0}t&&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.orthoDistance=this.orthoDistance,this.lastValues.perspToOrtho.copy(this.perspToOrtho),this.type=this.perspToOrtho.x<1?`PerspectiveCamera`:`OrthographicCamera`}get isPerspectiveCamera(){return this.perspToOrtho.x<1}get isOrthographicCamera(){return this.perspToOrtho.x>=1}copy(e,t){return super.copy(e,t),this.fov=e.fov,this.aspect=e.aspect,this.near=e.near,this.far=e.far,this.perspToOrtho.copy(e.perspToOrtho),this.updateTime(now()),this}};function S4(){return((1+Math.random())*65536|0).toString(16).substring(1)}function createUuid(){return(S4()+S4()+`-`+S4()+`-4`+S4().substr(0,3)+`-`+S4()+`-`+S4()+S4()+S4()).toLowerCase()}function createSymbol(e){return typeof Symbol>`u`?`$Symbol<${e}>$`:Symbol(e)}var EVENT_SYMBOL=createSymbol(`$$FIVE_EVENT$$`);function __generateEventIfNotExisted(e){return e[EVENT_SYMBOL]||(e[EVENT_SYMBOL]={}),e[EVENT_SYMBOL]}function __removeEvents(e){e[EVENT_SYMBOL]&&delete e[EVENT_SYMBOL]}var Subscribe=class{hasListener(e){let t=__generateEventIfNotExisted(this);return t&&t[e]&&t[e].callbacks.length>0}on(e,t,n){let r=__generateEventIfNotExisted(this);return r[e]||(r[e]={callbacks:[]}),r[e].callbacks.push([t,n||!1]),()=>this.off(e,t)}once(e,t){return this.on(e,t,!0)}off(e,t){if(e===void 0){__removeEvents(this);return}let n=__generateEventIfNotExisted(this);if(n[e]||(n[e]={callbacks:[]}),t===void 0){n[e].callbacks.length=0;return}let r=0;for(;r<n[e].callbacks.length&&n[e].callbacks[r][0]!==t;r++);r<n[e].callbacks.length&&n[e].callbacks.splice(r,1)}emit(e,...t){let n=!1,r=__generateEventIfNotExisted(this);r[e]||(r[e]={callbacks:[]});let o=r[e].callbacks.slice();for(let[r,s=!1]of o){let o=r.apply(this,t);s&&this.off(e,r),o===!1&&(n=!0)}return n}waitUntil(e,t){return new Promise(n=>{let r=this.on(e,(...e)=>{(!t||t(...e)!==!1)&&(n(e),r())})})}},PBMUpdateable=class extends Subscribe{},PBMCustomShader=class extends PBMUpdateable{constructor(e){var t,n,r,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b;super(),this.id=createUuid(),this.version=0,this.uniforms=(t=e.uniforms)==null?{}:t,this.defines=(n=e.defines)==null?{}:n,this.type=e.type,this.vertex={mainBefore:(o=(r=e.vertex)==null?void 0:r.mainBefore)==null?``:o,mainStart:(c=(s=e.vertex)==null?void 0:s.mainStart)==null?``:c,mainEnd:(u=(l=e.vertex)==null?void 0:l.mainEnd)==null?``:u},this.fragment={mainBefore:(f=(d=e.fragment)==null?void 0:d.mainBefore)==null?``:f,mainStart:(m=(p=e.fragment)==null?void 0:p.mainStart)==null?``:m,mainModelColor:(g=(h=e.fragment)==null?void 0:h.mainModelColor)==null?``:g,mainPanoColor:(v=(_=e.fragment)==null?void 0:_.mainPanoColor)==null?``:v,mainEnd:(b=(y=e.fragment)==null?void 0:y.mainEnd)==null?``:b}}get needsUpdate(){return!1}set needsUpdate(e){e===!0&&this.version++}onBeforeCompile(e,t){}},PBMPanoFilter=class e extends PBMUpdateable{static computeLut(e,t,n,r=1024,o=1,s,c){let l=clamp$1(e,-255,255)/255,u=clamp$1(t,-255,255)/255,d=clamp$1(n,-255,255)/255,f=new Float32Array(5),p=new Float32Array(5),m=new Float32Array(5);f[0]=0,f[1]=.125,f[2]=.5,f[3]=.875,f[4]=1;for(let e=0;e<5;e++)m[e]=f[e]*(1+d);m[4]=Math.max(1,m[4]);let h=1/2.2;for(let e=0;e<5;e++){let t=Math.pow(m[e]/m[4],2.2),n=Math.pow(m[e]/m[4],.45454545454545453);e<2?p[e]=m[e]+n*u:e>2?p[e]=m[e]+t*l:p[e]=m[e]}p[0]=0,p[4]=Math.max(1,p[4]),p[1]=Math.max(p[0]+.05,p[1]),p[3]=Math.min(p[4]-.0875,p[3]),p[2]=Math.max(Math.min(p[3]-.275,p[2]),p[1]+.275),s=s==null?new Float32Array(r*o):s,c=c==null?0:c;let g=r*2;for(let e=0;e<g;e++){let t=e/g,n=t*t,l=n*t,u=l*t,d=1-t,m=d*d,h=m*d,_=h*d,v=_*f[0]+4*h*t*f[1]+6*m*n*f[2]+4*d*l*f[3]+u*f[4],y=_*p[0]+4*h*t*p[1]+6*m*n*p[2]+4*d*l*p[3]+u*p[4],b=clamp$1(Math.round(v*(r-1)),0,r-1);for(let e=0;e<o;e++)s[c+b*o+e]=y}return s}constructor(){super(),this.id=createUuid();let t=()=>this.emit(`update`),n=0;this.contrast={get contrastBias(){return n},set contrastBias(e){n=e,t()}};let r=0;this.saturation={get saturationBias(){return r},set saturationBias(e){r=e,t()}};let o=0,s=0;this.color={get temperatureBias(){return o},set temperatureBias(e){o=e,t()},get tintBias(){return s},set tintBias(e){s=e,t()}};let c=0,l=0,u=0,d=[0,0,0].join(`:`),f=1024,p=3,m=new Float32Array(f*3);e.computeLut(0,0,0,f,3,m);let h=new three.DataTexture(m,f,1);h.flipY=!1,h.format=three.RGBFormat,h.type=three.FloatType,h.minFilter=three.NearestFilter,h.magFilter=three.NearestFilter,h.generateMipmaps=!1,h.needsUpdate=!0;let g=()=>{let t=[c,l,u].join(`:`);return t!==d&&(e.computeLut(c,l,u,f,3,m),h.needsUpdate=!0,d=t),h};this.highlightShadow={lutMap:h,get highlightBias(){return c},set highlightBias(e){c=e,g(),t()},get shadowBias(){return l},set shadowBias(e){l=e,g(),t()},get globalBias(){return u},set globalBias(e){u=e,g(),t()}}}toValue(){return{saturationSaturationBias:this.saturation.saturationBias,contrastContrastBias:this.contrast.contrastBias,highlightShadowLutMap:this.highlightShadow.lutMap,colorTemperatureBias:this.color.temperatureBias,colorTintBias:this.color.tintBias}}},PBMMaterial=class extends three.Material{},scratchViewport$5=new three.Vector4,pbmUniforms$1={colorAlpha:new Uniform(1),pano0:new Uniform({map:null,mapSize:1,mapHistogram:new three.Vector4,matrix:new three.Matrix4,zoom:1}),pano1:new Uniform({map:null,mapSize:1,mapHistogram:new three.Vector4,matrix:new three.Matrix4,zoom:1}),pano0Depth:new Uniform({map:null,maxDepth:1}),pano1Depth:new Uniform({map:null,maxDepth:1}),refinedScreen:new Uniform({projectionMatrix:new three.Matrix4,matrixInverse:new three.Matrix4,map:null,pano:0,opacity:1}),panoFilter:new Uniform(null),modelAlpha:new Uniform(1),progress:new Uniform(0),gradientTexture:new Uniform(null),clippers:new Uniform([]),shownFloorIndex:new Uniform(-1),constantColor:new Uniform(new three.Vector3),floorIndex:new Uniform(0),brightness:new Uniform(1),colorSaturation:new Uniform(0),colorBrightness:new Uniform(0),pixelRatio:new Uniform(1),resolution:new Uniform(new three.Vector2(512,512)),modelBoundingMin:new Uniform(new three.Vector3),modelBoundingMax:new Uniform(new three.Vector3)},shaderLib$1={none:{vertexShader:vertex_default$5,fragmentShader:fragment_default$5},basic:{vertexShader:vertex_default$4,fragmentShader:fragment_default$4},phong:{vertexShader:vertex_default$3,fragmentShader:fragment_default$3},standard:{vertexShader:vertex_default$2,fragmentShader:fragment_default$2}},uniformsLib$1=mergeUniforms(three.ShaderLib.basic.uniforms,three.ShaderLib.phong.uniforms,three.ShaderLib.physical.uniforms,pbmUniforms$1),definesLib$1={USE_OPAQUE:!1,USE_VERTEX_MARK:!1,USE_COLOR_CONSTANT:!1,USE_COLOR_ALTITUDE:!1,USE_COLOR_ADJUSTMENT:!1,USE_FLOOR_STYLE_VISIBILITY:!1,USE_BLACK_TRANSITION:!1,USE_SPREAD_TRANSITION:!1,USE_FADE_TRANSITION:!1,USE_REFINED_SCREEN:!1,USE_PANO_DEPTH:!1,USE_PANO_FILTER:!1,USE_HQ_WEIGHT:!1,USE_HQ_DEPTH:!1},PBMMeshMaterial=class extends PBMMaterial{constructor(e){var t,n;typeof e==`string`&&(e={shaderType:e}),super(),this.vertexTangents=!1,this.color=new three.Color(16777215),this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.specularMap=null,this.specular=new three.Color(1118481),this.shininess=30,this.roughnessMap=null,this.roughness=1,this.metalnessMap=null,this.metalness=0,this.alphaMap=null,this.combine=null,this.envMap=null,this.envMapIntensity=1,this.reflectivity=.4,this.refractionRatio=.98,this.emissiveMap=null,this.emissive=new three.Color(0),this.emissiveIntensity=1,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=three.TangentSpaceNormalMap,this.normalScale=new three.Vector2(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.clearcoat=0,this.clearcoatMap=null,this.clearcoatRoughness=0,this.clearcoatRoughnessMap=null,this.clearcoatNormalScale=new three.Vector2(1,1),this.clearcoatNormalMap=null,this.sheen=null,this.transparency=0,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap=`round`,this.wireframeLinejoin=`round`,this.skinning=!1,this.morphTargets=!1,this.morphNormals=!1,this.metal=!1,this.alphaMode=`OPAQUE`,this.clipping=!0,this.customShaders=[],this.type=`PBMMeshMaterial`;let r=Object.assign({},definesLib$1),o=cloneUniforms(uniformsLib$1);toFastProperties(o),toFastProperties(r),this.defines=r,this.onBeforeCompile=(e,t)=>{let n=this.shaderType;e.vertexShader=shaderLib$1[n].vertexShader,e.fragmentShader=shaderLib$1[n].fragmentShader,e.uniforms=o;for(let e of Object.keys(r))e in definesLib$1||delete r[e];for(let e of Object.keys(o))e in uniformsLib$1||delete o[e];let s=this.customShaders.filter(e=>e.type.includes(n));for(let e of s){for(let t in e.defines)t in r||Object.assign(r,{[t]:e.defines[t]});for(let t in e.uniforms)t in o||Object.assign(o,{[t]:e.uniforms[t]})}e.vertexShader=e.vertexShader.replace(/MAIN_BEFORE/g,s.map(e=>e.vertex.mainBefore).filter(e=>!!e).join(`
303
303
  `)),e.vertexShader=e.vertexShader.replace(/MAIN_START/g,s.map(e=>e.vertex.mainStart).filter(e=>!!e).join(`
304
304
  `)),e.vertexShader=e.vertexShader.replace(/MAIN_END/g,s.map(e=>e.vertex.mainEnd).filter(e=>!!e).join(`
305
305
  `)),e.fragmentShader=e.fragmentShader.replace(/MAIN_BEFORE/g,s.map(e=>e.fragment.mainBefore).filter(e=>!!e).join(`
@@ -315,7 +315,7 @@
315
315
  `)),e.fragmentShader=e.fragmentShader.replace(/MAIN_END/g,s.map(e=>e.fragment.mainEnd).filter(e=>!!e).join(`
316
316
  `)),e.fragmentShader=e.fragmentShader.replace(/MAIN_MODEL_COLOR/g,s.map(e=>e.fragment.mainModelColor).filter(e=>!!e).join(`
317
317
  `)),e.fragmentShader=e.fragmentShader.replace(/MAIN_PANO_COLOR/g,s.map(e=>e.fragment.mainPanoColor).filter(e=>!!e).join(`
318
- `));let c=String(this.clippers.length);e.vertexShader=e.vertexShader.replace(/NUM_CLIPPERS/g,c),e.fragmentShader=e.fragmentShader.replace(/NUM_CLIPPERS/g,c);for(let t of s)t.onBeforeCompile&&t.onBeforeCompile(e,r)};let r=``;this.onBeforeRender=(e,o,s,c,l,u)=>{let d=this.shaderType;s instanceof Camera?(n.pixelRatio.value=s.pixelRatio,n.resolution.value.copy(s.resolution)):(n.pixelRatio.value=e.getPixelRatio(),e.getViewport(scratchViewport$4),n.resolution.value.set(scratchViewport$4.width,scratchViewport$4.height));let f=this.transparent===!1&&this.blending===three.NormalBlending;t.USE_OPAQUE!==f&&(t.USE_OPAQUE=f,this.needsUpdate=!0);let p=this.customShaders.filter(e=>e.type.includes(d)).map(e=>`${e.id}:${e.version}`).join(`|`);r!==p&&(r=p,this.needsUpdate=!0)},Object.defineProperty(this,`uniform`,{configurable:!1,enumerable:!1,writable:!1,value:n}),defineProperty(this,`isPBMPointCloudMaterial`,{configurable:!1,writable:!1,value:!0}),defineProperty(this,`isShaderMaterial`,{configurable:!1,writable:!1,value:!0}),defineProperty(this,`opacity`,{get(){return n.opacity.value},set(e){n.opacity.value=e}}),defineProperty(this,`vertexMarks`,{get(){return!!t.USE_VERTEX_MARK},set(e){t.USE_VERTEX_MARK!==e&&(t.USE_VERTEX_MARK=e,this.needsUpdate=!0)}}),defineProperty(this,`pointScale`,{get(){return n.pointScale.value},set(e){n.pointScale.value=e}}),defineProperty(this,`pointMinPixel`,{get(){return n.pointMinPixel.value},set(e){n.pointMinPixel.value=e}}),defineProperty(this,`pointMaxPixel`,{get(){return n.pointMinPixel.value},set(e){n.pointMaxPixel.value=e}}),defineProperty(this,`pointSize`,{get(){return this.defines.USE_POINT_SIZE_ATTENUATION===!0?`ATTENUATION`:`FIXED`},set(e){let t=e===`ATTENUATION`;this.defines.USE_POINT_SIZE_ATTENUATION!==t&&(this.defines.USE_POINT_SIZE_ATTENUATION=t,this.needsUpdate=!0)}}),defineProperty(this,`pointShape`,{get(){return this.defines.USE_POINT_SHAPE_CIRCLE===!0?`CIRCLE`:`SQUARE`},set(e){let t=e===`CIRCLE`;this.defines.USE_POINT_SHAPE_CIRCLE!==t&&(this.defines.USE_POINT_SHAPE_CIRCLE=t,this.needsUpdate=!0)}}),defineProperty(this,`pointBack`,{get(){return this.defines.USE_POINT_BACK_HIDDEN===!0?`HIDDEN`:this.defines.USE_POINT_BACK_DARK===!0?`DARK`:`VISIBLE`},set(e){let t=e===`HIDDEN`,n=e===`DARK`;this.defines.USE_POINT_BACK_HIDDEN!==t&&(this.defines.USE_POINT_BACK_HIDDEN=t,this.needsUpdate=!0),this.defines.USE_POINT_BACK_DARK!==n&&(this.defines.USE_POINT_BACK_DARK=n,this.needsUpdate=!0)}}),defineProperty(this,`modelAlpha`,{get(){return n.modelAlpha.value},set(e){n.modelAlpha.value=e}}),defineProperty(this,`colorStyle`,{get(){return t.USE_COLOR_CONSTANT?`CONSTANT`:t.USE_COLOR_ALTITUDE?`ALTITUDE`:`RGB`},set(e){let n=e===`CONSTANT`,r=e===`ALTITUDE`;t.USE_COLOR_CONSTANT!==n&&(t.USE_COLOR_CONSTANT=n,this.needsUpdate=!0),t.USE_COLOR_ALTITUDE!==r&&(t.USE_COLOR_ALTITUDE=r,this.needsUpdate=!0)}}),defineProperty(this,`constantColor`,{get(){return n.constantColor.value},set(e){n.constantColor.value=e}}),defineProperty(this,`floorIndex`,{get(){return n.floorIndex.value},set(e){n.floorIndex.value=e}}),defineProperty(this,`shownFloorIndex`,{get(){return n.shownFloorIndex.value},set(e){n.shownFloorIndex.value=e}}),defineProperty(this,`floorStyle`,{get(){return t.USE_FLOOR_STYLE_VISIBILITY?`VISIBILITY`:`OPACITY`},set(e){let n=e===`VISIBILITY`;t.USE_FLOOR_STYLE_VISIBILITY!==n&&(t.USE_FLOOR_STYLE_VISIBILITY=n,this.needsUpdate=!0)}}),defineProperty(this,`gradientTexture`,{get(){return n.gradientTexture.value},set(e){n.gradientTexture.value=e}}),defineProperty(this,`brightness`,{get(){return n.brightness.value},set(e){n.brightness.value=e}});let o=[];defineProperty(this,`clippers`,{get(){return o},set(e){o!==e&&(o=e,n.clippers.value=o.map(e=>{let t=typeof e.floorIndex==`number`?e.floorIndex:-1;return{matrixInverse:new three.Matrix4().getInverse(e.clippingBoxMatrix),floorIndex:t}}),this.needsUpdate=!0)}}),defineProperty(this,`colorSaturation`,{get(){return n.colorSaturation.value},set(e){n.colorSaturation.value=e;let r=n.colorSaturation.value!==0||n.colorBrightness.value!==0||n.outlineGain.value!==0||n.distanceGain.value!==0;t.USE_COLOR_ADJUSTMENT!==r&&(t.USE_COLOR_ADJUSTMENT=r,this.needsUpdate=!0)}}),defineProperty(this,`colorBrightness`,{get(){return n.colorBrightness.value},set(e){n.colorBrightness.value=e;let r=n.colorSaturation.value!==0||n.colorBrightness.value!==0||n.outlineGain.value!==0||n.distanceGain.value!==0;t.USE_COLOR_ADJUSTMENT!==r&&(t.USE_COLOR_ADJUSTMENT=r,this.needsUpdate=!0)}}),defineProperty(this,`outlineGain`,{get(){return n.outlineGain.value},set(e){n.outlineGain.value=e;let r=n.colorSaturation.value!==0||n.colorBrightness.value!==0||n.outlineGain.value!==0||n.distanceGain.value!==0;t.USE_COLOR_ADJUSTMENT!==r&&(t.USE_COLOR_ADJUSTMENT=r,this.needsUpdate=!0)}}),defineProperty(this,`distanceGain`,{get(){return n.distanceGain.value},set(e){n.distanceGain.value=e;let r=n.colorSaturation.value!==0||n.colorBrightness.value!==0||n.outlineGain.value!==0||n.distanceGain.value!==0;t.USE_COLOR_ADJUSTMENT!==r&&(t.USE_COLOR_ADJUSTMENT=r,this.needsUpdate=!0)}}),defineProperty(this,`useHQWeight`,{get(){return t.USE_HQ_WEIGHT},set(e){e!==t.USE_HQ_WEIGHT&&(t.USE_HQ_WEIGHT=e,this.needsUpdate=!0)}}),defineProperty(this,`useHQDepth`,{get(){return t.USE_HQ_DEPTH},set(e){e!==t.USE_HQ_DEPTH&&(t.USE_HQ_DEPTH=e,this.needsUpdate=!0)}}),defineProperty(this,`modelBoundingMin`,{get(){return n.modelBoundingMin.value},set(e){n.modelBoundingMin.value=e}}),defineProperty(this,`modelBoundingMax`,{get(){return n.modelBoundingMax.value},set(e){n.modelBoundingMax.value=e}}),typeof e==`object`&&this.setValues(e),toFastProperties(this)}copy(e){return super.copy(e),this.pointScale=e.pointScale,this.pointMinPixel=e.pointMinPixel,this.pointMaxPixel=e.pointMaxPixel,this.customShaders=e.customShaders,this.modelAlpha=e.modelAlpha,this.colorStyle=e.colorStyle,this.constantColor.copy(e.constantColor),this.floorIndex=e.floorIndex,this.shownFloorIndex=e.shownFloorIndex,this.floorStyle=e.floorStyle,this.gradientTexture=e.gradientTexture,this.brightness=e.brightness,this.clippers=e.clippers,this.colorSaturation=e.colorSaturation,this.colorBrightness=e.colorBrightness,this.outlineGain=e.outlineGain,this.distanceGain=e.distanceGain,this.useHQWeight=e.useHQWeight,this.useHQDepth=e.useHQDepth,this.modelBoundingMin.copy(e.modelBoundingMin),this.modelBoundingMax.copy(e.modelBoundingMax),this}clone(){let e=this.constructor;return new e().copy(this)}refreshUniforms(){}},PBMPointCloud=class extends three.Points{constructor(e,t){super(e,t),this.onBeforeRender=(e,t,n,r,o,s)=>{o instanceof PBMPointCloudMaterial&&o.onBeforeRender&&o.onBeforeRender(e,t,n,r,this,s)}}},gradient_png_data_url_default=`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=`;function getValueKeys(e){return Object.keys(e)}function valueEqual(e,t){return e==t}function arrayValueEqual(e,t){if(Array.isArray(e)&&Array.isArray(t)){if(e.length!==t.length)return!1;for(let n=0;n<e.length;n++)if(e[n]!==t[n])return!1;return!0}return e===t}function vector3Equal(e,t){return e instanceof three.Vector3&&t instanceof three.Vector3?e.equals(t):e===t}function box3Equal(e,t){return e instanceof three.Box3&&t instanceof three.Box3?e.equals(t):e===t}var parameterValueEqualFn={customShaders:arrayValueEqual,castShadow:valueEqual,receiveShadow:valueEqual,vertexMarks:valueEqual,pano0:valueEqual,pano1:valueEqual,pano0Depth:valueEqual,pano1Depth:valueEqual,panoFilter:valueEqual,refinedScreen:valueEqual,modelAlpha:valueEqual,progress:valueEqual,transition:valueEqual,opacity:valueEqual,floorStyle:valueEqual,colorStyle:valueEqual,constantColor:vector3Equal,shownFloorIndex:valueEqual,clippers:arrayValueEqual,brightness:valueEqual,useHQWeight:valueEqual,useHQDepth:valueEqual,pointShape:valueEqual,pointSize:valueEqual,pointBack:valueEqual,pointScale:valueEqual,pointMinPixel:valueEqual,pointMaxPixel:valueEqual,pointAppearAnimation:valueEqual,colorSaturation:valueEqual,colorBrightness:valueEqual,useAddBlend:valueEqual,outlineGain:valueEqual,distanceGain:valueEqual,gradientTexture:valueEqual,boundingBox:box3Equal,gaussianSplattingSHDegree:valueEqual,minLevelOfDetail:valueEqual,maxLevelOfDetail:valueEqual,minGeometricError:valueEqual,maxGeometricError:valueEqual,panoramaMinGeometricError:valueEqual,skipLevelOfDetail:valueEqual,mostDetail:valueEqual,loadSiblings:valueEqual,cameraCulling:valueEqual,maxMemoryUsage:valueEqual,maxRequests:valueEqual,requestOrder:valueEqual,maxScreenSpaceError:valueEqual,memoryAdjustedScreenSpaceError:valueEqual,cacheCameras:arrayValueEqual},defaultGradientTexture=(()=>{let e;return e=typeof document<`u`?new three.TextureLoader().load(gradient_png_data_url_default):new three.Texture,e.minFilter=three.NearestFilter,e.magFilter=three.NearestFilter,e.wrapS=three.RepeatWrapping,e.wrapT=three.RepeatWrapping,e})(),defineConstantColor=Object.freeze(new three.Vector3(.6,.6,.6)),defineClippers=Object.freeze([]),defineBoundingBox=Object.freeze(new three.Box3),defineCustomShaders=Object.freeze([]),defineCacheCameras=Object.freeze([]);function createUndefindValue(){return{customShaders:void 0,castShadow:void 0,receiveShadow:void 0,vertexMarks:void 0,pano0:void 0,pano1:void 0,pano0Depth:void 0,pano1Depth:void 0,panoFilter:void 0,refinedScreen:void 0,floorStyle:void 0,colorStyle:void 0,constantColor:void 0,shownFloorIndex:void 0,modelAlpha:void 0,opacity:void 0,progress:void 0,transition:void 0,clippers:void 0,brightness:void 0,useHQWeight:void 0,useHQDepth:void 0,pointSize:void 0,pointBack:void 0,pointShape:void 0,pointScale:void 0,pointMaxPixel:void 0,pointMinPixel:void 0,pointAppearAnimation:void 0,gradientTexture:void 0,colorSaturation:void 0,colorBrightness:void 0,outlineGain:void 0,distanceGain:void 0,useAddBlend:void 0,boundingBox:void 0,gaussianSplattingSHDegree:void 0,minLevelOfDetail:void 0,maxLevelOfDetail:void 0,minGeometricError:void 0,maxGeometricError:void 0,panoramaMinGeometricError:void 0,skipLevelOfDetail:void 0,mostDetail:void 0,loadSiblings:void 0,cameraCulling:void 0,maxMemoryUsage:void 0,maxRequests:void 0,requestOrder:void 0,maxScreenSpaceError:void 0,memoryAdjustedScreenSpaceError:void 0,cacheCameras:void 0}}function createDefaultValue(){return{customShaders:defineCustomShaders,castShadow:!1,receiveShadow:!1,vertexMarks:!0,pano0:null,pano1:null,pano0Depth:null,pano1Depth:null,panoFilter:null,refinedScreen:null,floorStyle:`OPACITY`,colorStyle:`RGB`,constantColor:defineConstantColor,shownFloorIndex:-1,modelAlpha:1,opacity:1,progress:0,transition:`FADE`,clippers:defineClippers,brightness:1,useHQWeight:!1,useHQDepth:!1,pointSize:`ATTENUATION`,pointBack:`DARK`,pointShape:`CIRCLE`,pointScale:.02,pointMaxPixel:40,pointMinPixel:0,pointAppearAnimation:!0,gradientTexture:defaultGradientTexture,colorSaturation:0,colorBrightness:0,outlineGain:0,distanceGain:0,useAddBlend:!1,boundingBox:defineBoundingBox,gaussianSplattingSHDegree:0,minLevelOfDetail:0,maxLevelOfDetail:20,minGeometricError:0,maxGeometricError:1e4,panoramaMinGeometricError:.04,skipLevelOfDetail:!1,mostDetail:!1,loadSiblings:!1,cameraCulling:!0,maxMemoryUsage:64,maxRequests:6,requestOrder:`SCREEN_SPACE_ERROR`,maxScreenSpaceError:4,memoryAdjustedScreenSpaceError:!1,cacheCameras:defineCacheCameras}}var parameterKeys=getValueKeys(createUndefindValue());function assignValue(e,t,n){let r=parameterValueEqualFn[t];if(!r)return!1;Array.isArray(n)&&(n=n.slice());let o=e[t];return r(o,n)?!1:(e[t]=n,!0)}var Parameter=class e{static createDefault(){return createDefaultValue()}static resolveValue(...t){let n=Object.assign(this.createDefault(),{versions:[],version:``});for(let r of t){let t=r instanceof e?r.version:createUuid();n.versions.push(t);for(let e of parameterKeys)r[e]!==void 0&&assignValue(n,e,r[e])}return n.version=n.versions.toString(),n}constructor(e){this.id=createUuid(),this.versionNumber=0,this.unbind=new Map,this.value=createUndefindValue(),e&&this.copy(e);for(let e of parameterKeys)Object.defineProperty(this,e,{get(){return this.value[e]}});toFastProperties(this)}get version(){return`${this.id}:${this.versionNumber}`}resolveValue(...t){return e.resolveValue(...t,this)}assignValue(e,t){let n=this.unbind.get(e);n&&(this.unbind.delete(e),n());let r=assignValue(this.value,e,t),o=this.value[e];if(o instanceof PBMUpdateable){let t=o.on(`update`,()=>this.versionNumber++);this.unbind.set(e,t)}return r}set(e,t){let n=!1;if(typeof e==`string`)t!==void 0&&this.assignValue(e,t)&&(n=!0);else{let t=e;for(let e of parameterKeys)t[e]!==void 0&&this.assignValue(e,t[e])&&(n=!0)}return n&&this.versionNumber++,this}reset(...e){let t=!1;for(let n of e)this.assignValue(n,void 0)&&(t=!0);return t&&this.versionNumber++,this}resetAll(){return this.reset(...parameterKeys)}copy(e){let t=!0;for(let n of parameterKeys)this.assignValue(n,e[n])&&(t=!0);return t&&this.versionNumber++,this}},PBMContainer=class extends three.Group{constructor(){super(...arguments),this.parameter=new Parameter,this.needsRender=!0}get materialParameters(){return this.parameter.resolveValue()}get pbmMaterialParametersVersion(){return this.parameter.resolveValue().version}setMaterial(e){this.parameter.set(e),this.update(),this.needsRender=!0}getMaterial(){return this.parameter.resolveValue()}update(){let e=this.parameter.resolveValue();this.traverse(t=>{t instanceof PBMMesh||t instanceof PBMSkinnedMesh?updatePBMMesh$1(t,e):t instanceof PBMPointCloud&&updatePBMPointCloud$1(t,e)})}};function updatePBMMesh$1(e,t){let n=e.material;e.castShadow=t.castShadow,e.receiveShadow=t.receiveShadow;for(let e of n)e.customShaders=t.customShaders,e.pano0=t.pano0,e.pano1=t.pano1,e.pano0Depth=t.pano0Depth,e.pano1Depth=t.pano1Depth,e.refinedScreen=t.refinedScreen,e.modelAlpha=t.modelAlpha,e.progress=t.progress,e.transition=t.transition,e.opacity=t.opacity,e.floorStyle=t.floorStyle,e.constantColor=t.constantColor,e.shownFloorIndex=t.shownFloorIndex,e.clippers=t.clippers,e.brightness=t.brightness,e.useHQWeight=t.useHQWeight,e.useHQDepth=t.useHQDepth,e.colorSaturation=t.colorSaturation,e.colorBrightness=t.colorBrightness,e.gradientTexture=t.gradientTexture,e.shaderType===`none`?(e.transparent=!0,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.depthWrite=!1,e.depthTest=!0):(e.transparent=e.alphaMode===`BLEND`,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.depthWrite=!0,e.depthTest=!0,t.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending),e.shownFloorIndex>-1&&e.shownFloorIndex!==e.floorIndex&&(e.transparent=!0),e.opacity<1&&(e.transparent=!0),e.alphaMap&&(e.transparent=!0),e.brightness<1&&(e.transparent=!0),t.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending))}function updatePBMPointCloud$1(e,t){let n=[e.material];e.castShadow=t.castShadow,e.receiveShadow=t.receiveShadow;for(let e of n)e.customShaders=t.customShaders,e.pointScale=t.pointScale,e.pointMinPixel=t.pointMinPixel,e.pointMaxPixel=t.pointMaxPixel,e.pointSize=t.pointSize,e.pointShape=t.pointShape,e.pointBack=t.pointBack,e.modelAlpha=t.modelAlpha,e.opacity=t.opacity,e.floorStyle=t.floorStyle,e.constantColor=t.constantColor,e.shownFloorIndex=t.shownFloorIndex,e.clippers=t.clippers,e.brightness=t.brightness,e.useHQWeight=t.useHQWeight,e.useHQDepth=t.useHQDepth,e.colorSaturation=t.colorSaturation,e.colorBrightness=t.colorBrightness,e.outlineGain=t.outlineGain,e.distanceGain=t.distanceGain,e.gradientTexture=t.gradientTexture,e.transparent=!1,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.depthWrite=!0,e.depthTest=!0,e.shownFloorIndex>-1&&(e.transparent=e.shownFloorIndex!==e.floorIndex),e.modelAlpha<1&&(e.transparent=!0),e.opacity<1&&(e.transparent=!0),e.brightness<1&&(e.transparent=!0),t.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending),e.useHQWeight&&(e.depthWrite=!1,e.blending=three.CustomBlending,e.blendSrc=three.SrcAlphaFactor,e.blendSrcAlpha=three.SrcAlphaFactor,e.blendDst=three.OneFactor,e.blendDstAlpha=three.OneFactor)}var PBMGaussianSplattingObject=class e extends three.Points{get positions(){let e=this.geometry.getAttribute(`position`);return e?e.array:new Float32Array}get rotations(){let e=this.geometry.getAttribute(`rotation`);return e?e.array:new Float32Array}get scales(){let e=this.geometry.getAttribute(`scale`);return e?e.array:new Float32Array}get colors(){let e=this.geometry.getAttribute(`color`);return e?e.array:new Uint8Array}get selection(){let e=this.geometry.getAttribute(`selection`);return e?e.array:new Uint8Array}get sh1(){let e=this.geometry.getAttribute(`sh1`);return e?e.array:void 0}get sh2(){let e=this.geometry.getAttribute(`sh2`);return e?e.array:void 0}get sh3(){let e=this.geometry.getAttribute(`sh3`);return e?e.array:void 0}constructor(e){var t;let n=new three.BufferGeometry;super(n),this.transformChanged=!1,this.selectedChanged=!1,this.transferDetached=!1,this.maxSHDegree=0,this.usedSHDegree=0,this.gsViewLayerKey=``,this.gsClippers=[],this._selected=!1,this.material.visible=!1,this.numPoints=e?e.numPoints:0,this.maxSHDegree=(t=e==null?void 0:e.shDegree)==null?0:t,this.usedSHDegree=0,e&&e.positions?n.setAttribute(`position`,new three.BufferAttribute(e.positions,3)):n.setAttribute(`position`,new three.BufferAttribute(new Float32Array,3)),e&&e.rotations?n.setAttribute(`rotation`,new three.BufferAttribute(e.rotations,4)):n.setAttribute(`rotation`,new three.BufferAttribute(new Float32Array,4)),e&&e.scales?n.setAttribute(`scale`,new three.BufferAttribute(e.scales,3)):n.setAttribute(`scale`,new three.BufferAttribute(new Float32Array,3)),e&&e.colors?n.setAttribute(`color`,new three.BufferAttribute(e.colors,4,!0)):n.setAttribute(`color`,new three.BufferAttribute(new Uint8Array,4,!0));let r=new Uint8Array(this.numPoints);if(n.setAttribute(`selection`,new three.BufferAttribute(r,1)),e!=null&&e.sh1&&n.setAttribute(`sh1`,new three.BufferAttribute(e.sh1,9)),e!=null&&e.sh2&&n.setAttribute(`sh2`,new three.BufferAttribute(e.sh2,15)),e!=null&&e.sh3&&n.setAttribute(`sh3`,new three.BufferAttribute(e.sh3,21)),this._boundingBox=new three.Box3(new three.Vector3(1/0,1/0,1/0),new three.Vector3(-1/0,-1/0,-1/0)),e&&e.positions)for(let t=0;t<this.numPoints;t++)this._boundingBox.expandByPoint(new three.Vector3(e.positions[3*t],e.positions[3*t+1],e.positions[3*t+2]));this.matrixAutoUpdate=!1,this.lastMatrixWorld=null}serialize(){let t=new Uint8Array(this.numPoints*e.RowLength),n=new Float32Array(t.buffer),r=new Uint8Array(t.buffer),o=this.positions,s=this.colors,c=this.scales,l=this.rotations;for(let e=0;e<this.numPoints;e++)n[8*e+0]=o[3*e+0],n[8*e+1]=o[3*e+1],n[8*e+2]=o[3*e+2],r[32*e+24+0]=s[4*e+0],r[32*e+24+1]=s[4*e+1],r[32*e+24+2]=s[4*e+2],r[32*e+24+3]=s[4*e+3],n[8*e+3+0]=c[3*e+0],n[8*e+3+1]=c[3*e+1],n[8*e+3+2]=c[3*e+2],r[32*e+28+0]=l[4*e+0]*128+128&255,r[32*e+28+1]=l[4*e+1]*128+128&255,r[32*e+28+2]=l[4*e+2]*128+128&255,r[32*e+28+3]=l[4*e+3]*128+128&255;return t}reattach(e,t,n,r,o){let s=new Float32Array(e),c=new Float32Array(t),l=new Float32Array(n),u=new Uint8Array(r),d=new Uint8Array(o);this.geometry.setAttribute(`position`,new three.BufferAttribute(s,3)),this.geometry.setAttribute(`rotation`,new three.BufferAttribute(c,4)),this.geometry.setAttribute(`scale`,new three.BufferAttribute(l,3)),this.geometry.setAttribute(`color`,new three.BufferAttribute(u,4,!0)),this.geometry.setAttribute(`selection`,new three.BufferAttribute(d,1)),this.transferDetached=!1}get selected(){return this._selected}set selected(e){this._selected!==e&&(this._selected=e,this.selectedChanged=!0)}get boundingBox(){let e=new three.Vector3;this._boundingBox.getCenter(e),e.add(this.position);let t=new three.Vector3;this._boundingBox.getSize(t),t.multiply(this.scale);let n=new three.Vector3;return n.copy(t).multiplyScalar(.5),new three.Box3(e.clone().sub(n),e.clone().add(n))}dispose(){}raycast(e,t){var n,r;let o=this.matrixWorld,s=(r=(n=e.params.Points)==null?void 0:n.threshold)==null?0:r;if(this._boundingBox.isEmpty())return;let c=new three.Vector3;this._boundingBox.getCenter(c);let l=new three.Vector3;this._boundingBox.getSize(l);let u=Math.max(l.x,l.y,l.z)*.5,d=new three.Sphere(c,u);if(d.applyMatrix4(o),d.radius+=s,e.ray.intersectsSphere(d)===!1)return;let f=new three.Matrix4;f.getInverse(o);let p=new three.Ray;p.copy(e.ray).applyMatrix4(f);let m=s/((this.scale.x+this.scale.y+this.scale.z)/3),h=m*m,g=this.geometry.getAttribute(`position`);if(!g)return;let _=g.array,v=this.numPoints;for(let n=0;n<v;n++){let r=new three.Vector3(_[n*3],_[n*3+1],_[n*3+2]),s=p.distanceSqToPoint(r);if(s<h){let c=new three.Vector3;p.closestPointToPoint(r,c),c.applyMatrix4(o);let l=e.ray.origin.distanceTo(c);if(l<e.near||l>e.far)continue;t.push({distance:l,distanceToRay:Math.sqrt(s),point:c,index:n,face:null,object:this})}}}};PBMGaussianSplattingObject.RowLength=32;var ROTATE_X_MATRIX$1=new three.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]),ROTATE_X_MATRIX_INVERSE$1=new three.Matrix4().getInverse(ROTATE_X_MATRIX$1);function noop(...e){}var JSONP_REGEXPS=[/\.([0-9a-z]+)\.jsonp([\?\#].*)?$/i,/jsonp_([0-9a-z]+)([\?\#].*)?$/i],locationHref=typeof location<`u`?location.href:``,locationIsHttps=/^https\:/.test(locationHref),NetworkProxyError=class extends Error{constructor(e,t,n){super(`[NETWORK]: request proxy error(type: ${t}, reason: ${n}): ${e}`)}},NetworkResponseError=class extends Error{constructor(e,t,n){super(`[NETWORK]: response error(type: ${t}, status: ${n}): ${e}`),this.httpStatus=n}},NetworkTimeoutError=class extends Error{constructor(e,t,n){super(`[NETWORK]: request timeout(type: ${t}, timeout: ${n}ms): ${e}`)}};function parseHeaders(e){if(!e)return{};let t={},n=e.trim().split(`
318
+ `));let c=String(this.clippers.length);e.vertexShader=e.vertexShader.replace(/NUM_CLIPPERS/g,c),e.fragmentShader=e.fragmentShader.replace(/NUM_CLIPPERS/g,c);for(let t of s)t.onBeforeCompile&&t.onBeforeCompile(e,r)};let r=``;this.onBeforeRender=(e,o,s,c,l,u)=>{let d=this.shaderType;s instanceof Camera?(n.pixelRatio.value=s.pixelRatio,n.resolution.value.copy(s.resolution)):(n.pixelRatio.value=e.getPixelRatio(),e.getViewport(scratchViewport$4),n.resolution.value.set(scratchViewport$4.width,scratchViewport$4.height));let f=this.transparent===!1&&this.blending===three.NormalBlending;t.USE_OPAQUE!==f&&(t.USE_OPAQUE=f,this.needsUpdate=!0);let p=this.customShaders.filter(e=>e.type.includes(d)).map(e=>`${e.id}:${e.version}`).join(`|`);r!==p&&(r=p,this.needsUpdate=!0)},Object.defineProperty(this,`uniform`,{configurable:!1,enumerable:!1,writable:!1,value:n}),defineProperty(this,`isPBMPointCloudMaterial`,{configurable:!1,writable:!1,value:!0}),defineProperty(this,`isShaderMaterial`,{configurable:!1,writable:!1,value:!0}),defineProperty(this,`opacity`,{get(){return n.opacity.value},set(e){n.opacity.value=e}}),defineProperty(this,`vertexMarks`,{get(){return!!t.USE_VERTEX_MARK},set(e){t.USE_VERTEX_MARK!==e&&(t.USE_VERTEX_MARK=e,this.needsUpdate=!0)}}),defineProperty(this,`pointScale`,{get(){return n.pointScale.value},set(e){n.pointScale.value=e}}),defineProperty(this,`pointMinPixel`,{get(){return n.pointMinPixel.value},set(e){n.pointMinPixel.value=e}}),defineProperty(this,`pointMaxPixel`,{get(){return n.pointMinPixel.value},set(e){n.pointMaxPixel.value=e}}),defineProperty(this,`pointSize`,{get(){return this.defines.USE_POINT_SIZE_ATTENUATION===!0?`ATTENUATION`:`FIXED`},set(e){let t=e===`ATTENUATION`;this.defines.USE_POINT_SIZE_ATTENUATION!==t&&(this.defines.USE_POINT_SIZE_ATTENUATION=t,this.needsUpdate=!0)}}),defineProperty(this,`pointShape`,{get(){return this.defines.USE_POINT_SHAPE_CIRCLE===!0?`CIRCLE`:`SQUARE`},set(e){let t=e===`CIRCLE`;this.defines.USE_POINT_SHAPE_CIRCLE!==t&&(this.defines.USE_POINT_SHAPE_CIRCLE=t,this.needsUpdate=!0)}}),defineProperty(this,`pointBack`,{get(){return this.defines.USE_POINT_BACK_HIDDEN===!0?`HIDDEN`:this.defines.USE_POINT_BACK_DARK===!0?`DARK`:`VISIBLE`},set(e){let t=e===`HIDDEN`,n=e===`DARK`;this.defines.USE_POINT_BACK_HIDDEN!==t&&(this.defines.USE_POINT_BACK_HIDDEN=t,this.needsUpdate=!0),this.defines.USE_POINT_BACK_DARK!==n&&(this.defines.USE_POINT_BACK_DARK=n,this.needsUpdate=!0)}}),defineProperty(this,`modelAlpha`,{get(){return n.modelAlpha.value},set(e){n.modelAlpha.value=e}}),defineProperty(this,`colorStyle`,{get(){return t.USE_COLOR_CONSTANT?`CONSTANT`:t.USE_COLOR_ALTITUDE?`ALTITUDE`:`RGB`},set(e){let n=e===`CONSTANT`,r=e===`ALTITUDE`;t.USE_COLOR_CONSTANT!==n&&(t.USE_COLOR_CONSTANT=n,this.needsUpdate=!0),t.USE_COLOR_ALTITUDE!==r&&(t.USE_COLOR_ALTITUDE=r,this.needsUpdate=!0)}}),defineProperty(this,`constantColor`,{get(){return n.constantColor.value},set(e){n.constantColor.value=e}}),defineProperty(this,`floorIndex`,{get(){return n.floorIndex.value},set(e){n.floorIndex.value=e}}),defineProperty(this,`shownFloorIndex`,{get(){return n.shownFloorIndex.value},set(e){n.shownFloorIndex.value=e}}),defineProperty(this,`floorStyle`,{get(){return t.USE_FLOOR_STYLE_VISIBILITY?`VISIBILITY`:`OPACITY`},set(e){let n=e===`VISIBILITY`;t.USE_FLOOR_STYLE_VISIBILITY!==n&&(t.USE_FLOOR_STYLE_VISIBILITY=n,this.needsUpdate=!0)}}),defineProperty(this,`gradientTexture`,{get(){return n.gradientTexture.value},set(e){n.gradientTexture.value=e}}),defineProperty(this,`brightness`,{get(){return n.brightness.value},set(e){n.brightness.value=e}});let o=[];defineProperty(this,`clippers`,{get(){return o},set(e){o!==e&&(o=e,n.clippers.value=o.map(e=>{let t=typeof e.floorIndex==`number`?e.floorIndex:-1;return{matrixInverse:new three.Matrix4().getInverse(e.clippingBoxMatrix),floorIndex:t}}),this.needsUpdate=!0)}}),defineProperty(this,`colorSaturation`,{get(){return n.colorSaturation.value},set(e){n.colorSaturation.value=e;let r=n.colorSaturation.value!==0||n.colorBrightness.value!==0||n.outlineGain.value!==0||n.distanceGain.value!==0;t.USE_COLOR_ADJUSTMENT!==r&&(t.USE_COLOR_ADJUSTMENT=r,this.needsUpdate=!0)}}),defineProperty(this,`colorBrightness`,{get(){return n.colorBrightness.value},set(e){n.colorBrightness.value=e;let r=n.colorSaturation.value!==0||n.colorBrightness.value!==0||n.outlineGain.value!==0||n.distanceGain.value!==0;t.USE_COLOR_ADJUSTMENT!==r&&(t.USE_COLOR_ADJUSTMENT=r,this.needsUpdate=!0)}}),defineProperty(this,`outlineGain`,{get(){return n.outlineGain.value},set(e){n.outlineGain.value=e;let r=n.colorSaturation.value!==0||n.colorBrightness.value!==0||n.outlineGain.value!==0||n.distanceGain.value!==0;t.USE_COLOR_ADJUSTMENT!==r&&(t.USE_COLOR_ADJUSTMENT=r,this.needsUpdate=!0)}}),defineProperty(this,`distanceGain`,{get(){return n.distanceGain.value},set(e){n.distanceGain.value=e;let r=n.colorSaturation.value!==0||n.colorBrightness.value!==0||n.outlineGain.value!==0||n.distanceGain.value!==0;t.USE_COLOR_ADJUSTMENT!==r&&(t.USE_COLOR_ADJUSTMENT=r,this.needsUpdate=!0)}}),defineProperty(this,`useHQWeight`,{get(){return t.USE_HQ_WEIGHT},set(e){e!==t.USE_HQ_WEIGHT&&(t.USE_HQ_WEIGHT=e,this.needsUpdate=!0)}}),defineProperty(this,`useHQDepth`,{get(){return t.USE_HQ_DEPTH},set(e){e!==t.USE_HQ_DEPTH&&(t.USE_HQ_DEPTH=e,this.needsUpdate=!0)}}),defineProperty(this,`modelBoundingMin`,{get(){return n.modelBoundingMin.value},set(e){n.modelBoundingMin.value=e}}),defineProperty(this,`modelBoundingMax`,{get(){return n.modelBoundingMax.value},set(e){n.modelBoundingMax.value=e}}),typeof e==`object`&&this.setValues(e),toFastProperties(this)}copy(e){return super.copy(e),this.pointScale=e.pointScale,this.pointMinPixel=e.pointMinPixel,this.pointMaxPixel=e.pointMaxPixel,this.customShaders=e.customShaders,this.modelAlpha=e.modelAlpha,this.colorStyle=e.colorStyle,this.constantColor.copy(e.constantColor),this.floorIndex=e.floorIndex,this.shownFloorIndex=e.shownFloorIndex,this.floorStyle=e.floorStyle,this.gradientTexture=e.gradientTexture,this.brightness=e.brightness,this.clippers=e.clippers,this.colorSaturation=e.colorSaturation,this.colorBrightness=e.colorBrightness,this.outlineGain=e.outlineGain,this.distanceGain=e.distanceGain,this.useHQWeight=e.useHQWeight,this.useHQDepth=e.useHQDepth,this.modelBoundingMin.copy(e.modelBoundingMin),this.modelBoundingMax.copy(e.modelBoundingMax),this}clone(){let e=this.constructor;return new e().copy(this)}refreshUniforms(){}},PBMPointCloud=class extends three.Points{constructor(e,t){super(e,t),this.onBeforeRender=(e,t,n,r,o,s)=>{o instanceof PBMPointCloudMaterial&&o.onBeforeRender&&o.onBeforeRender(e,t,n,r,this,s)}}},gradient_png_data_url_default=`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=`;function getValueKeys(e){return Object.keys(e)}function valueEqual(e,t){return e==t}function arrayValueEqual(e,t){if(Array.isArray(e)&&Array.isArray(t)){if(e.length!==t.length)return!1;for(let n=0;n<e.length;n++)if(e[n]!==t[n])return!1;return!0}return e===t}function vector3Equal(e,t){return e instanceof three.Vector3&&t instanceof three.Vector3?e.equals(t):e===t}function box3Equal(e,t){return e instanceof three.Box3&&t instanceof three.Box3?e.equals(t):e===t}var parameterValueEqualFn={customShaders:arrayValueEqual,castShadow:valueEqual,receiveShadow:valueEqual,vertexMarks:valueEqual,pano0:valueEqual,pano1:valueEqual,pano0Depth:valueEqual,pano1Depth:valueEqual,panoFilter:valueEqual,refinedScreen:valueEqual,modelAlpha:valueEqual,progress:valueEqual,transition:valueEqual,opacity:valueEqual,floorStyle:valueEqual,colorStyle:valueEqual,constantColor:vector3Equal,shownFloorIndex:valueEqual,clippers:arrayValueEqual,brightness:valueEqual,useHQWeight:valueEqual,useHQDepth:valueEqual,pointShape:valueEqual,pointSize:valueEqual,pointBack:valueEqual,pointScale:valueEqual,pointMinPixel:valueEqual,pointMaxPixel:valueEqual,pointAppearAnimation:valueEqual,colorSaturation:valueEqual,colorBrightness:valueEqual,useAddBlend:valueEqual,outlineGain:valueEqual,distanceGain:valueEqual,gradientTexture:valueEqual,boundingBox:box3Equal,gaussianSplattingSHDegree:valueEqual,minLevelOfDetail:valueEqual,maxLevelOfDetail:valueEqual,minGeometricError:valueEqual,maxGeometricError:valueEqual,panoramaMinGeometricError:valueEqual,skipLevelOfDetail:valueEqual,mostDetail:valueEqual,loadSiblings:valueEqual,cameraCulling:valueEqual,maxMemoryUsage:valueEqual,maxRequests:valueEqual,requestOrder:valueEqual,maxScreenSpaceError:valueEqual,memoryAdjustedScreenSpaceError:valueEqual,cacheCameras:arrayValueEqual},defaultGradientTexture=(()=>{let e;return e=typeof document<`u`?new three.TextureLoader().load(gradient_png_data_url_default):new three.Texture,e.minFilter=three.NearestFilter,e.magFilter=three.NearestFilter,e.wrapS=three.RepeatWrapping,e.wrapT=three.RepeatWrapping,e})(),defineConstantColor=Object.freeze(new three.Vector3(.6,.6,.6)),defineClippers=Object.freeze([]),defineBoundingBox=Object.freeze(new three.Box3),defineCustomShaders=Object.freeze([]),defineCacheCameras=Object.freeze([]),undefinedValue={customShaders:void 0,castShadow:void 0,receiveShadow:void 0,vertexMarks:void 0,pano0:void 0,pano1:void 0,pano0Depth:void 0,pano1Depth:void 0,panoFilter:void 0,refinedScreen:void 0,floorStyle:void 0,colorStyle:void 0,constantColor:void 0,shownFloorIndex:void 0,modelAlpha:void 0,opacity:void 0,progress:void 0,transition:void 0,clippers:void 0,brightness:void 0,useHQWeight:void 0,useHQDepth:void 0,pointSize:void 0,pointBack:void 0,pointShape:void 0,pointScale:void 0,pointMaxPixel:void 0,pointMinPixel:void 0,pointAppearAnimation:void 0,gradientTexture:void 0,colorSaturation:void 0,colorBrightness:void 0,outlineGain:void 0,distanceGain:void 0,useAddBlend:void 0,boundingBox:void 0,gaussianSplattingSHDegree:void 0,minLevelOfDetail:void 0,maxLevelOfDetail:void 0,minGeometricError:void 0,maxGeometricError:void 0,panoramaMinGeometricError:void 0,skipLevelOfDetail:void 0,mostDetail:void 0,loadSiblings:void 0,cameraCulling:void 0,maxMemoryUsage:void 0,maxRequests:void 0,requestOrder:void 0,maxScreenSpaceError:void 0,memoryAdjustedScreenSpaceError:void 0,cacheCameras:void 0},defaultValue={versionNumber:0,customShaders:defineCustomShaders,castShadow:!1,receiveShadow:!1,vertexMarks:!0,pano0:null,pano1:null,pano0Depth:null,pano1Depth:null,panoFilter:null,refinedScreen:null,floorStyle:`OPACITY`,colorStyle:`RGB`,constantColor:defineConstantColor,shownFloorIndex:-1,modelAlpha:1,opacity:1,progress:0,transition:`FADE`,clippers:defineClippers,brightness:1,useHQWeight:!1,useHQDepth:!1,pointSize:`ATTENUATION`,pointBack:`DARK`,pointShape:`CIRCLE`,pointScale:.02,pointMaxPixel:40,pointMinPixel:0,pointAppearAnimation:!0,gradientTexture:defaultGradientTexture,colorSaturation:0,colorBrightness:0,outlineGain:0,distanceGain:0,useAddBlend:!1,boundingBox:defineBoundingBox,gaussianSplattingSHDegree:0,minLevelOfDetail:0,maxLevelOfDetail:20,minGeometricError:0,maxGeometricError:1e4,panoramaMinGeometricError:.04,skipLevelOfDetail:!1,mostDetail:!1,loadSiblings:!1,cameraCulling:!0,maxMemoryUsage:64,maxRequests:6,requestOrder:`SCREEN_SPACE_ERROR`,maxScreenSpaceError:4,memoryAdjustedScreenSpaceError:!1,cacheCameras:defineCacheCameras},parameterVersionSequence=defaultValue.versionNumber,parameterKeys=getValueKeys(undefinedValue);function createUndefindValue(e={}){return Object.assign(e,undefinedValue)}function createDefaultValue(e={}){return Object.assign(e,defaultValue)}function assignValue(e,t,n){let r=parameterValueEqualFn[t];if(!r)return!1;Array.isArray(n)&&(n=n.slice());let o=e[t];return r(o,n)?!1:(e[t]=n,!0)}var Parameter=class e{static createDefault(){return createDefaultValue()}static resolveValueTo(t,...n){let r=createDefaultValue(t);for(let t of n){let n=t instanceof e?t.versionNumber:++parameterVersionSequence;r.versionNumber=r.versionNumber*31+n|0;for(let e of parameterKeys)t[e]!==void 0&&assignValue(r,e,t[e])}return r}static resolveValue(...t){if(typeof t[0]==`string`){let e=t.shift(),n=t,r=defaultValue[e];for(let t of n)t[e]!==void 0&&(r=t[e]);return r}else{let n=t;return e.resolveValueTo({},...n)}}constructor(e){this.id=createUuid(),this.versionNumber=++parameterVersionSequence,this.unbind=new Map,this.value=createUndefindValue(),e&&this.copy(e);for(let e of parameterKeys)Object.defineProperty(this,e,{get(){return this.value[e]}});toFastProperties(this)}resolveValue(...t){return e.resolveValue(...t,this)}assignValue(e,t){let n=this.unbind.get(e);n&&(this.unbind.delete(e),n());let r=assignValue(this.value,e,t),o=this.value[e];if(o instanceof PBMUpdateable){let t=o.on(`update`,()=>{this.versionNumber=++parameterVersionSequence});this.unbind.set(e,t)}return r}set(e,t){let n=!1;if(typeof e==`string`)t!==void 0&&this.assignValue(e,t)&&(n=!0);else{let t=e;for(let e of parameterKeys)t[e]!==void 0&&this.assignValue(e,t[e])&&(n=!0)}return n&&(this.versionNumber=++parameterVersionSequence),this}reset(...e){let t=!1;for(let n of e)this.assignValue(n,void 0)&&(t=!0);return t&&(this.versionNumber=++parameterVersionSequence),this}resetAll(){return this.reset(...parameterKeys)}copy(e){let t=!0;for(let n of parameterKeys)this.assignValue(n,e[n])&&(t=!0);return t&&(this.versionNumber=++parameterVersionSequence),this}},PBMContainer=class extends three.Group{constructor(){super(...arguments),this.parameter=new Parameter,this.needsRender=!0}get materialParameters(){return this.parameter.resolveValue()}get pbmMaterialParametersVersion(){return String(this.parameter.resolveValue().versionNumber)}setMaterial(e){this.parameter.set(e),this.update(),this.needsRender=!0}getMaterial(){return this.parameter.resolveValue()}update(){let e=this.parameter.resolveValue();this.traverse(t=>{t instanceof PBMMesh||t instanceof PBMSkinnedMesh?updatePBMMesh$1(t,e):t instanceof PBMPointCloud&&updatePBMPointCloud$1(t,e)})}};function updatePBMMesh$1(e,t){let n=e.material;e.castShadow=t.castShadow,e.receiveShadow=t.receiveShadow;for(let e of n)e.customShaders=t.customShaders,e.pano0=t.pano0,e.pano1=t.pano1,e.pano0Depth=t.pano0Depth,e.pano1Depth=t.pano1Depth,e.refinedScreen=t.refinedScreen,e.modelAlpha=t.modelAlpha,e.progress=t.progress,e.transition=t.transition,e.opacity=t.opacity,e.floorStyle=t.floorStyle,e.constantColor=t.constantColor,e.shownFloorIndex=t.shownFloorIndex,e.clippers=t.clippers,e.brightness=t.brightness,e.useHQWeight=t.useHQWeight,e.useHQDepth=t.useHQDepth,e.colorSaturation=t.colorSaturation,e.colorBrightness=t.colorBrightness,e.gradientTexture=t.gradientTexture,e.shaderType===`none`?(e.transparent=!0,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.depthWrite=!1,e.depthTest=!0):(e.transparent=e.alphaMode===`BLEND`,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.depthWrite=!0,e.depthTest=!0,t.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending),e.shownFloorIndex>-1&&e.shownFloorIndex!==e.floorIndex&&(e.transparent=!0),e.opacity<1&&(e.transparent=!0),e.alphaMap&&(e.transparent=!0),e.brightness<1&&(e.transparent=!0),t.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending))}function updatePBMPointCloud$1(e,t){let n=[e.material];e.castShadow=t.castShadow,e.receiveShadow=t.receiveShadow;for(let e of n)e.customShaders=t.customShaders,e.pointScale=t.pointScale,e.pointMinPixel=t.pointMinPixel,e.pointMaxPixel=t.pointMaxPixel,e.pointSize=t.pointSize,e.pointShape=t.pointShape,e.pointBack=t.pointBack,e.modelAlpha=t.modelAlpha,e.opacity=t.opacity,e.floorStyle=t.floorStyle,e.constantColor=t.constantColor,e.shownFloorIndex=t.shownFloorIndex,e.clippers=t.clippers,e.brightness=t.brightness,e.useHQWeight=t.useHQWeight,e.useHQDepth=t.useHQDepth,e.colorSaturation=t.colorSaturation,e.colorBrightness=t.colorBrightness,e.outlineGain=t.outlineGain,e.distanceGain=t.distanceGain,e.gradientTexture=t.gradientTexture,e.transparent=!1,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.depthWrite=!0,e.depthTest=!0,e.shownFloorIndex>-1&&(e.transparent=e.shownFloorIndex!==e.floorIndex),e.modelAlpha<1&&(e.transparent=!0),e.opacity<1&&(e.transparent=!0),e.brightness<1&&(e.transparent=!0),t.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending),e.useHQWeight&&(e.depthWrite=!1,e.blending=three.CustomBlending,e.blendSrc=three.SrcAlphaFactor,e.blendSrcAlpha=three.SrcAlphaFactor,e.blendDst=three.OneFactor,e.blendDstAlpha=three.OneFactor)}var PBMGaussianSplattingObject=class e extends three.Points{get positions(){let e=this.geometry.getAttribute(`position`);return e?e.array:new Float32Array}get rotations(){let e=this.geometry.getAttribute(`rotation`);return e?e.array:new Float32Array}get scales(){let e=this.geometry.getAttribute(`scale`);return e?e.array:new Float32Array}get colors(){let e=this.geometry.getAttribute(`color`);return e?e.array:new Uint8Array}get selection(){let e=this.geometry.getAttribute(`selection`);return e?e.array:new Uint8Array}get sh1(){let e=this.geometry.getAttribute(`sh1`);return e?e.array:void 0}get sh2(){let e=this.geometry.getAttribute(`sh2`);return e?e.array:void 0}get sh3(){let e=this.geometry.getAttribute(`sh3`);return e?e.array:void 0}constructor(e){var t;let n=new three.BufferGeometry;super(n),this.transformChanged=!1,this.selectedChanged=!1,this.transferDetached=!1,this.maxSHDegree=0,this.usedSHDegree=0,this.gsViewLayerKey=``,this.gsClippers=[],this._selected=!1,this.material.visible=!1,this.numPoints=e?e.numPoints:0,this.maxSHDegree=(t=e==null?void 0:e.shDegree)==null?0:t,this.usedSHDegree=0,e&&e.positions?n.setAttribute(`position`,new three.BufferAttribute(e.positions,3)):n.setAttribute(`position`,new three.BufferAttribute(new Float32Array,3)),e&&e.rotations?n.setAttribute(`rotation`,new three.BufferAttribute(e.rotations,4)):n.setAttribute(`rotation`,new three.BufferAttribute(new Float32Array,4)),e&&e.scales?n.setAttribute(`scale`,new three.BufferAttribute(e.scales,3)):n.setAttribute(`scale`,new three.BufferAttribute(new Float32Array,3)),e&&e.colors?n.setAttribute(`color`,new three.BufferAttribute(e.colors,4,!0)):n.setAttribute(`color`,new three.BufferAttribute(new Uint8Array,4,!0));let r=new Uint8Array(this.numPoints);if(n.setAttribute(`selection`,new three.BufferAttribute(r,1)),e!=null&&e.sh1&&n.setAttribute(`sh1`,new three.BufferAttribute(e.sh1,9)),e!=null&&e.sh2&&n.setAttribute(`sh2`,new three.BufferAttribute(e.sh2,15)),e!=null&&e.sh3&&n.setAttribute(`sh3`,new three.BufferAttribute(e.sh3,21)),this._boundingBox=new three.Box3(new three.Vector3(1/0,1/0,1/0),new three.Vector3(-1/0,-1/0,-1/0)),e&&e.positions)for(let t=0;t<this.numPoints;t++)this._boundingBox.expandByPoint(new three.Vector3(e.positions[3*t],e.positions[3*t+1],e.positions[3*t+2]));this.matrixAutoUpdate=!1,this.lastMatrixWorld=null}serialize(){let t=new Uint8Array(this.numPoints*e.RowLength),n=new Float32Array(t.buffer),r=new Uint8Array(t.buffer),o=this.positions,s=this.colors,c=this.scales,l=this.rotations;for(let e=0;e<this.numPoints;e++)n[8*e+0]=o[3*e+0],n[8*e+1]=o[3*e+1],n[8*e+2]=o[3*e+2],r[32*e+24+0]=s[4*e+0],r[32*e+24+1]=s[4*e+1],r[32*e+24+2]=s[4*e+2],r[32*e+24+3]=s[4*e+3],n[8*e+3+0]=c[3*e+0],n[8*e+3+1]=c[3*e+1],n[8*e+3+2]=c[3*e+2],r[32*e+28+0]=l[4*e+0]*128+128&255,r[32*e+28+1]=l[4*e+1]*128+128&255,r[32*e+28+2]=l[4*e+2]*128+128&255,r[32*e+28+3]=l[4*e+3]*128+128&255;return t}reattach(e,t,n,r,o){let s=new Float32Array(e),c=new Float32Array(t),l=new Float32Array(n),u=new Uint8Array(r),d=new Uint8Array(o);this.geometry.setAttribute(`position`,new three.BufferAttribute(s,3)),this.geometry.setAttribute(`rotation`,new three.BufferAttribute(c,4)),this.geometry.setAttribute(`scale`,new three.BufferAttribute(l,3)),this.geometry.setAttribute(`color`,new three.BufferAttribute(u,4,!0)),this.geometry.setAttribute(`selection`,new three.BufferAttribute(d,1)),this.transferDetached=!1}get selected(){return this._selected}set selected(e){this._selected!==e&&(this._selected=e,this.selectedChanged=!0)}get boundingBox(){let e=new three.Vector3;this._boundingBox.getCenter(e),e.add(this.position);let t=new three.Vector3;this._boundingBox.getSize(t),t.multiply(this.scale);let n=new three.Vector3;return n.copy(t).multiplyScalar(.5),new three.Box3(e.clone().sub(n),e.clone().add(n))}dispose(){}raycast(e,t){var n,r;let o=this.matrixWorld,s=(r=(n=e.params.Points)==null?void 0:n.threshold)==null?0:r;if(this._boundingBox.isEmpty())return;let c=new three.Vector3;this._boundingBox.getCenter(c);let l=new three.Vector3;this._boundingBox.getSize(l);let u=Math.max(l.x,l.y,l.z)*.5,d=new three.Sphere(c,u);if(d.applyMatrix4(o),d.radius+=s,e.ray.intersectsSphere(d)===!1)return;let f=new three.Matrix4;f.getInverse(o);let p=new three.Ray;p.copy(e.ray).applyMatrix4(f);let m=s/((this.scale.x+this.scale.y+this.scale.z)/3),h=m*m,g=this.geometry.getAttribute(`position`);if(!g)return;let _=g.array,v=this.numPoints;for(let n=0;n<v;n++){let r=new three.Vector3(_[n*3],_[n*3+1],_[n*3+2]),s=p.distanceSqToPoint(r);if(s<h){let c=new three.Vector3;p.closestPointToPoint(r,c),c.applyMatrix4(o);let l=e.ray.origin.distanceTo(c);if(l<e.near||l>e.far)continue;t.push({distance:l,distanceToRay:Math.sqrt(s),point:c,index:n,face:null,object:this})}}}};PBMGaussianSplattingObject.RowLength=32;var ROTATE_X_MATRIX$1=new three.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]),ROTATE_X_MATRIX_INVERSE$1=new three.Matrix4().getInverse(ROTATE_X_MATRIX$1);function noop(...e){}var JSONP_REGEXPS=[/\.([0-9a-z]+)\.jsonp([\?\#].*)?$/i,/jsonp_([0-9a-z]+)([\?\#].*)?$/i],locationHref=typeof location<`u`?location.href:``,locationIsHttps=/^https\:/.test(locationHref),NetworkProxyError=class extends Error{constructor(e,t,n){super(`[NETWORK]: request proxy error(type: ${t}, reason: ${n}): ${e}`)}},NetworkResponseError=class extends Error{constructor(e,t,n){super(`[NETWORK]: response error(type: ${t}, status: ${n}): ${e}`),this.httpStatus=n}},NetworkTimeoutError=class extends Error{constructor(e,t,n){super(`[NETWORK]: request timeout(type: ${t}, timeout: ${n}ms): ${e}`)}};function parseHeaders(e){if(!e)return{};let t={},n=e.trim().split(`
319
319
  `);for(let e=0;e<n.length;e++){let r=n[e],o=r.indexOf(`:`),s=r.slice(0,o).trim().toLowerCase(),c=r.slice(o+1).trim();c&&(t[s]?t[s]+=`, `+c:t[s]=c)}return t}function matchJsonpFunctionName(e){for(let t of JSONP_REGEXPS){let n=e.match(t);if(n)return`jsonp_`+n[1]}return null}function isJsonp(e){return matchJsonpFunctionName(e)!==null}var NetworkSubscribe=class extends Subscribe{};function ajax(e,t={},n=noop,r=noop,o=noop){let s=now(),c=e;return Promise.resolve().then(()=>t.requestProxy?t.requestProxy(e):e).then(e=>locationIsHttps&&/^http\:/.test(e)?(console.warn(`The page at '${locationHref}' was loaded over HTTPS, but requested an insecure element '${e}'. This request was automatically upgraded to HTTPS`),e.replace(/^http\:/,`https:`)):e).catch(n=>{var r;matchJsonpFunctionName(e);let o=new NetworkProxyError(c,`XMLHttpRequest`,n&&n.message?String(n.message):String(n));return(r=t.networkSubscribe)==null||r.emit(`network`,e,`XMLHttpRequest`,`forbidden`,o.message),Promise.reject(o)}).then(e=>new Promise((l,u)=>{let d=matchJsonpFunctionName(e);if(d){let o=window,f=null,p=!1,m=document.createElement(`script`);o[d]=h=>{var g,_;let v=now(),y=v-s;if(delete o[d],m.parentNode&&m.parentNode.removeChild(m),f!==null&&(window.clearTimeout(f),f=null),p===!0)return;if(h.indexOf(`data:`)!==0){let n=new NetworkResponseError(e,`XMLHttpRequest`,500);r(n),u(n),(g=t.networkSubscribe)==null||g.emit(`network`,e,`XMLHttpRequest`,`error`,n.message);return}let b=h.split(`,`),S=(b[0].match(/:(.*?);/)||[])[1],C=b[1];if(t.responseType===`arraybuffer`||t.responseType===`blob`){let e=atob(b[1]),n=e.length,r=new Uint8Array(n);for(let t=0;t<n;t++)r[t]=e.charCodeAt(t);C=t.responseType===`arraybuffer`?r.buffer:new Blob([r],{type:S})}let w={body:C,meta:{origin:c,source:e,requestTime:s,responseTime:v,costs:y,headers:{}}};n(w),l(w),(_=t.networkSubscribe)==null||_.emit(`network`,e,`XMLHttpRequest`,`ok`,JSON.stringify(w.meta)),p=!0},m.src=e,document.body.appendChild(m),typeof t.timeout==`number`&&(f=window.setTimeout(()=>{var n;if(f=null,p!==!0){p=!0;let o=new NetworkTimeoutError(e,`XMLHttpRequest`,t.timeout||NaN);r(o),u(o),(n=t.networkSubscribe)==null||n.emit(`network`,e,`XMLHttpRequest`,`timeout`,o.message)}},t.timeout))}else{let d=!1,f=new XMLHttpRequest,p=()=>{f&&(f.removeEventListener(`timeout`,m,!1),f.removeEventListener(`progress`,h,!1),f.removeEventListener(`load`,g,!1),f.removeEventListener(`error`,_,!1)),f=null,p=noop},m=function(){var n;if(d===!0)return;d=!0,p();let o=new NetworkTimeoutError(e,`XMLHttpRequest`,t.timeout||NaN);r(o),u(o),(n=t.networkSubscribe)==null||n.emit(`network`,e,`XMLHttpRequest`,`timeout`,o.message)},h=function(e){d!==!0&&e.lengthComputable&&(e.total<=0||o(e.loaded/e.total,e.loaded,e.total))},g=function(r){var o;if(d===!0)return;let u=this.status;if(u===0||u>=200&&u<400){d=!0,p();let u=now(),f=u-s,m=parseHeaders(this.getAllResponseHeaders()),h=r.total,g={body:this.response,meta:{origin:c,source:e,requestTime:s,responseTime:u,costs:f,headers:m,size:h}};n(g),l(g),(o=t.networkSubscribe)==null||o.emit(`network`,e,`XMLHttpRequest`,`ok`,JSON.stringify(g.meta))}else _.call(this)},_=function(){var n;if(d===!0)return;d=!0,p();let o=new NetworkResponseError(e,`XMLHttpRequest`,this.status);r(o),u(o),(n=t.networkSubscribe)==null||n.emit(`network`,e,`XMLHttpRequest`,`error`,o.message)};f.addEventListener(`timeout`,m,!1),f.addEventListener(`progress`,h,!1),f.addEventListener(`load`,g,!1),f.addEventListener(`error`,_,!1),t.responseType&&(f.responseType=t.responseType),typeof t.timeout==`number`&&(f.timeout=t.timeout),f.open(`GET`,e,!0),f.send(null)}}))}var preloadCache={};function preload(e,t={}){let n=now(),r=e;return Promise.resolve().then(()=>t.requestProxy?t.requestProxy(e):e).then(e=>locationIsHttps&&/^http\:/.test(e)?(console.warn(`The page at '${locationHref}' was loaded over HTTPS, but requested an insecure element '${e}'. This request was automatically upgraded to HTTPS`),e.replace(/^http\:/,`https:`)):e).catch(n=>{var o;let s=new NetworkProxyError(r,`Link`,n&&n.message?String(n.message):String(n));return(o=t.networkSubscribe)==null||o.emit(`network`,e,`Link`,`forbidden`,s.message),Promise.reject(s)}).then(e=>e in preloadCache?preloadCache[e]:preloadCache[e]=new Promise((o,s)=>{let c=document.head||document.getElementsByTagName(`head`)[0],l=document.createElement(`link`),u=!1,d=null;l.onload=s=>{var c;if(d!==null&&(clearTimeout(d),d=null),u===!0)return;u=!0,o(),l.onerror=noop,l.onload=noop;let f=now(),p={origin:r,source:e,requestTime:n,responseTime:f,costs:f-n,headers:{}};(c=t.networkSubscribe)==null||c.emit(`network`,e,`Link`,`preload`,JSON.stringify(p))},l.onerror=n=>{var r;if(d!==null&&(clearTimeout(d),d=null),u===!0)return;u=!0,delete preloadCache[e],c&&l.parentNode===c&&c.removeChild(l);let o=new NetworkResponseError(e,`Link`,0);s(o),l.onerror=noop,l.onload=noop,(r=t.networkSubscribe)==null||r.emit(`network`,e,`Link`,`error`,o.message)},typeof t.timeout==`number`&&(d=window.setTimeout(()=>{var s;if(d=null,u===!0)return;u=!0,o(),l.onerror=noop,l.onload=noop;let c=now(),f={origin:r,source:e,requestTime:n,responseTime:c,costs:c-n,headers:{}};(s=t.networkSubscribe)==null||s.emit(`network`,e,`Link`,`timeout`,JSON.stringify(f))},t.timeout)),l.rel=l.relList&&l.relList.supports(`prefetch`)?`prefetch`:`preload`,l.as=`fetch`,l.crossOrigin=``,l.fetchPriority=`high`,l.href=e,c&&c.appendChild(l)}))}function loadImage(e,t={},n=noop,r=noop,o=noop,s){let c=now(),l=e;return Promise.resolve().then(()=>t.requestProxy?t.requestProxy(e):e).then(e=>locationIsHttps&&/^http\:/.test(e)?(console.warn(`The page at '${locationHref}' was loaded over HTTPS, but requested an insecure element '${e}'. This request was automatically upgraded to HTTPS`),e.replace(/^http\:/,`https:`)):e).catch(n=>{var r;let o=new NetworkProxyError(l,`Image`,n&&n.message?String(n.message):String(n));return(r=t.networkSubscribe)==null||r.emit(`network`,e,`Image`,`forbidden`,o.message),Promise.reject(o)}).then(e=>isJsonp(e)?ajax(e,{responseType:`blob`,networkSubscribe:t.networkSubscribe}).then(e=>URL.createObjectURL(e.body)):e).then(e=>new Promise((u,d)=>{let f=s==null?new Image:s,p=!1,m=null;typeof t.timeout==`number`&&(m=window.setTimeout(()=>{var n;if(f.onload=noop,f.onerror=noop,m=null,p===!0)return;p=!0;let o=new NetworkTimeoutError(e,`Image`,t.timeout);r(o),d(o),(n=t.networkSubscribe)==null||n.emit(`network`,e,`Image`,`timeout`,o.message)},t.timeout)),f.onload=()=>{var r;if(f.onload=noop,f.onerror=noop,m!==null&&(clearTimeout(m),m=null),p===!0)return;let s=now(),d={headers:{},origin:l,source:e,requestTime:c,responseTime:s,costs:s-c};p=!0;let h={body:f,meta:d};o(1),n(h),u(h),(r=t.networkSubscribe)==null||r.emit(`network`,e,`Image`,`ok`,JSON.stringify(h.meta))},f.onerror=()=>{var n;if(f.onload=noop,f.onerror=noop,m!==null&&(clearTimeout(m),m=null),p===!0)return;p=!0;let o=new NetworkResponseError(e,`Image`,0);r(o),d(o),(n=t.networkSubscribe)==null||n.emit(`network`,e,`Image`,`ok`,o.message)},o(0),f.src=e}))}var Fetcher=class{constructor(e={}){this.options=e}ajax(e,t={},n=noop,r=noop,o=noop){var s;let c=this.options;return ajax(e,{responseType:t.responseType,timeout:(s=t.timeout)==null?c.timeout:s,get requestProxy(){var e;return(e=t.requestProxy)==null?c.requestProxy:e},get networkSubscribe(){var e;return(e=t.networkSubscribe)==null?c.networkSubscribe:e}},n,r,o)}loadImage(e,t={},n=noop,r=noop,o=noop,s){var c;let l=this.options;return loadImage(e,{timeout:(c=t.timeout)==null?l.timeout:c,get requestProxy(){var e;return(e=t.requestProxy)==null?l.requestProxy:e},get networkSubscribe(){var e;return(e=t.networkSubscribe)==null?l.networkSubscribe:e}},n,r,o,s)}preload(e,t={}){var n;let r=this.options;return preload(e,{timeout:(n=t.timeout)==null?r.timeout:n,get requestProxy(){var e;return(e=t.requestProxy)==null?r.requestProxy:e},get networkSubscribe(){var e;return(e=t.networkSubscribe)==null?r.networkSubscribe:e}})}},internalFetcher=new Fetcher;function pick(e,t){let n={};for(let r of t)r in e&&(n[r]=e[r]);return n}function omit(e,t){let n={},r=new Set(t);for(let t of Object.keys(e))r.has(t)||(n[t]=e[t]);return n}function omitUndefinedFields(e){let t={};for(let n in e){let r=e[n];r!==void 0&&(t[n]=r)}return t}var hrefAElement=typeof document<`u`?document.createElement(`a`):{href:``};function isAbsoluteURL(e){return e.indexOf(`/`)===0||/^[0-9a-z]+\:/i.test(e)}function getFullURL(e){if(typeof URL<`u`&&typeof location<`u`)return new URL(e,location.href).href;{hrefAElement.href=e;let t=hrefAElement.href;return hrefAElement.href=``,t}}function pathJoin(...e){let t=[];e=e.map(e=>(e==null?``:e).trim()).filter(e=>e.length>0&&!/^\/+$/.test(e));for(let n=0;n<e.length;n++){let r=n===0,o=n===e.length-1,s=e[n];r||(s=s.replace(/^\.\//,``).replace(/^\/+/,``)),o||(s=s.replace(/\/+$/,``)),t.push(s)}return t.join(`/`)}function appendSearch(e,t=``){if((t[0]===`?`||t[0]===`&`)&&(t=t.slice(1)),!t)return e;let n=e.indexOf(`#`),r=``;return n>=0&&(r=e.slice(n),e=e.slice(0,n)),(e[e.length-1]===`?`||e[e.length-1]===`&`)&&(e=e.slice(0,-1)),e.indexOf(`?`)>=0?`${e}&${t}${r}`:`${e}?${t}${r}`}function normalizeURL(e){var t;let n=/^(http\:|https\:|file\:)?\/\/[^/]/.exec(e);if(!n)return e;let r=n[1]||``,o=e.slice(r.length+2),s=o.indexOf(`#`);s>=0&&(e.slice(s),o=e.slice(0,s));let c=o.indexOf(`?`);c>=0&&(e.slice(c),o=e.slice(0,c));let l=o.split(`/`),u=l.shift(),d=(t=l.pop())==null?``:t,f=[];for(let e of l)if(!(e===``||e===`.`)){if(e===`..`){f.pop();continue}f.push(e)}return r+`//`+u+`/`+f.join(`/`)+`/`+d}function getExtname(e){let t=/([0-9a-z\.\_\-]+)([\?\#].*)?$/i.exec(e);if(t){let e=String(t[1]).trim().split(`.`).slice(1).reverse()[0];if(e)return`.`+e}return``}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(e){return new Promise(t=>{if(typeof Image>`u`){t(!1);return}let n=new Image,r=setTimeout(()=>{n.onload=n.onerror=()=>{},clearTimeout(r),t(!1)},100);n.onload=n.onerror=()=>{n.onload=n.onerror=()=>{},clearTimeout(r),t(n.height===2)},n.src=e})}var imageSupportCache=null;function imageSupport(){return imageSupportCache||(imageSupportCache=Promise.all([checkImage(webp),checkImage(avif),checkImage(heif)]).then(e=>({webp:e[0],avif:e[1],heif:e[2]})))}var _a$4,supportAvif=!1,supportWebp=!1,supportHeif=!1;imageSupport().then(e=>{supportAvif=e.avif,supportWebp=e.webp,supportHeif=e.heif});var IMAGE_FORMATS=[`jpg`,`jpeg`,`png`,`heif`,`heic`,`webp`,`avif`];function isImageExt(e){return IMAGE_FORMATS.indexOf(e)>=0}var 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(e){let t=e.match(URL_DOMAIN_REGEX);return t===null?null:t[1]}function replaceDomain(e,t,n){var r,o;let s=(o=(r=t[n])==null?t[t.length-1]:r)==null?e:o;return e.replace(URL_DOMAIN_REGEX,(e,t)=>e.slice(0,e.length-t.length)+s)}function route(e,t,n){let[r,...o]=t.split(`.`);if(r===`texture`)return replaceDomain(e,n.texture,0);if(r===`pano`){let[t,r]=o;switch(r){case`front`:case`left`:case`up`:return replaceDomain(e,n.pano,0);case`down`:case`right`:case`back`:return replaceDomain(e,n.pano,1);default:break}}else if(r===`pano_tile`){let[t,r,s,c,l]=o,u=Math.pow(2,Number(s))*Number(c)+Number(l);if(!isNaN(u))return replaceDomain(e,n.tile,u%2)}else if(r===`model`){let[t]=o,r=Number(t);if(!isNaN(r))return replaceDomain(e,n.model,r%2)}return replaceDomain(e,n.default,0)}var tencentCloudImageProcesser=(e,t)=>{let n=e.split(`?`)[0],r=n.split(`.`).pop();if(r===`jpeg`&&(r=`jpg`),r===`heif`&&(r=`heic`),r&&!isImageExt(r))return e;let o=[],{format:s,cut:c,quality:l,size:u,sharpen:d,forceUseExifOrientation:f}=t;if(s===`jpeg`&&(s=`jpg`),s===`heif`&&(s=`heic`),(!supportAvif&&(s==null?r:s)===`avif`||!supportWebp&&(s==null?r:s)===`webp`||!supportHeif&&(s==null?r:s)===`heic`)&&(s=`jpg`),s!==void 0&&s!==r&&o.push(`format/${s}`),c!==void 0&&o.push(`cut/${c[2]}x${c[3]}x${c[0]}x${c[1]}`),l!==void 0){let e=s==null?r:s;e&&[`jpg`,`webp`,`heic`,`avif`].indexOf(e)>=0&&o.push(`quality/${l}`)}if(u!==void 0){let t=e.match(/\/cube_(\d+)\//);(t?Number(t[1]):NaN)!==Number(u)&&o.push(`thumbnail/${u}x`)}d!==void 0&&o.push(`sharpen/${d}`),f===!0&&o.push(`auto-orient`);let p=``;return o.length&&(p=`?imageMogr2/`+o.join(`/`)),n+p},aliyunOOSImageProcesser=(e,t)=>{let n=e.split(`?`)[0],r=n.split(`.`).pop();if(r===`jpeg`&&(r=`jpg`),r===`heif`&&(r=`heic`),r&&!isImageExt(r))return e;let o=[],{format:s,cut:c,quality:l,size:u,sharpen:d}=t;if(s===`jpeg`&&(s=`jpg`),s===`heif`&&(s=`heic`),(!supportAvif&&(s==null?r:s)===`avif`||!supportWebp&&(s==null?r:s)===`webp`||!supportHeif&&(s==null?r:s)===`heic`)&&(s=`jpg`),s!==void 0&&s!==r&&o.push(`format,${s}`),c!==void 0){let[e,t,n,r]=c;o.push(`crop,x_${e},y_${t},w_${n},h_${r},g_nw`)}if(l!==void 0&&l!==100){let e=s==null?r:s;e&&[`jpg`,`webp`,`heic`,`avif`].indexOf(e)>=0&&o.push(`quality,Q_${l}`)}u&&u!==2048&&o.push(`resize,w_${u}`),d!==void 0&&o.push(`sharpen,${d}`);let f=``;return o.length&&(f=`?x-oss-process=image/`+o.join(`/`)),n+f},MAX_SAFE_INTEGER=9007199254740991;function formatNumber(e){let t=Math.round(e);return Math.abs(t-e)<.001?t:Math.floor(e)}function formatOptions(e){return e=Object.assign({},e),e.size!==void 0&&(e.size=formatNumber(clamp$1(e.size,0,MAX_SAFE_INTEGER))),e.quality!==void 0&&(e.quality=formatNumber(clamp$1(e.quality,0,100))),e.cut!==void 0&&(e.cut=[formatNumber(clamp$1(e.cut[0],0,MAX_SAFE_INTEGER)),formatNumber(clamp$1(e.cut[1],0,MAX_SAFE_INTEGER)),formatNumber(clamp$1(e.cut[2],0,MAX_SAFE_INTEGER)),formatNumber(clamp$1(e.cut[3],0,MAX_SAFE_INTEGER))]),e.sharpen!==void 0&&(e.sharpen=formatNumber(clamp$1(e.sharpen,0,MAX_SAFE_INTEGER))),e}function imageURL(e,t){let n=Object.assign(Object.assign({},DEFAULT_IMAGE_URL_MAPPINGS),t.mappings),r=getDomain(e);if(r===null)return e;t=formatOptions(t);let o=n[r];return o?(e=route(e,t.key,o),/\.basis(\?|$)/.test(e)&&(e=e.replace(/\.basis(\?|$)/,`.jpg$1`)),o.type===`tencentCloud`?tencentCloudImageProcesser(e,t):o.type===`aliyun`?aliyunOOSImageProcesser(e,t):e):e}function applyImageURLOptions(e,t=imageURL,n){let r=t(e,n);if(r===e&&n.cut)throw Error(`ImageURL: cut option not applied.`);return r}var IMAGE_SIZE_REG=/\/cube_(\d+)\//;function getImageSizeFromURL(e){let t=e.match(IMAGE_SIZE_REG);return t?Number(t[1]):null}function replaceImageSize(e,t){return e.replace(IMAGE_SIZE_REG,`/cube_${t}/`)}var log2=(_a$4=Math.log2)==null?(e=>Math.log(e)*Math.LOG2E):_a$4;function getImageSizeLevel(e){return Math.floor(Math.max(log2(e/512),0))}var windowSTOContext=(()=>{let e=now();return{requestAnimationFrame(t){let n=now(),r=clamp$1(16+(n-e),16,33),o=setTimeout(function(){t(dateNowToDomHighResTimeStamp(n+r))},r);return e=n+r,o},cancelAnimationFrame:e=>clearTimeout(e)}})(),windowRAFContext=typeof requestAnimationFrame==`function`&&typeof cancelAnimationFrame==`function`?{requestAnimationFrame:e=>requestAnimationFrame(e),cancelAnimationFrame:e=>cancelAnimationFrame(e)}:windowSTOContext,DEFAULT_ORDER=5,deviceFrameTime=16,AnimationFrameLoop=class e{static get shared(){return this.sharedInstance||(this.sharedInstance=new e),this.sharedInstance}static getFrameTime(){return deviceFrameTime}constructor(){this.loopType=`raf`,this.frames=[],this.isAnimating=!1,this.context=null;let e=now();this.loop=(...t)=>{if(this.isAnimating===!1)return;let n=now(),r=Math.max(n-e,0);e=n,deviceFrameTime=r;let o=this.frames.slice();for(let e=0;e<o.length;e++){let s=o[e];if(s.delay>0){--s.delay;continue}try{s.callback(n,r,...t)}catch(e){console.error(e)}s.calls++}for(let e=this.frames.length-1;e>=0;e--){let t=this.frames[e];t.once&&t.calls>0&&this.frames.splice(e,1)}this.requestId=this.requestAnimationFrame(this.loop)},this.start()}start(){this.isAnimating!==!0&&(this.isAnimating=!0,this.requestId=this.requestAnimationFrame(this.loop))}stop(){this.isAnimating=!1,this.cancelAnimationFrame(this.requestId)}setContext(e){e!==this.context&&(this.stop(),this.context=e,this.start())}getContext(){return this.context}setLoopType(e){e!==this.loopType&&(this.stop(),this.loopType=e,this.start())}getLoopType(){return this.loopType}requestAnimationFrame(e){let t;if(this.context?t=this.context:this.loopType===`raf`?t=windowRAFContext:this.loopType===`sto`&&(t=windowSTOContext),t)return t.requestAnimationFrame(e)}cancelAnimationFrame(e){let t;this.context?t=this.context:this.loopType===`raf`?t=windowRAFContext:this.loopType===`sto`&&(t=windowSTOContext),t&&t.cancelAnimationFrame(e)}remove(e){let t=this.frames.indexOf(e);t>=0&&this.frames.splice(t,1)}add(e,t=!1,n=0,r=DEFAULT_ORDER){let o={callback:e,once:t,delay:n,order:r,calls:0},s=this.frames.length;for(;--s>=0;)if(this.frames[s].order<=r){this.frames.splice(s+1,0,o);break}return s<0&&this.frames.unshift(o),()=>this.remove(o)}clear(){this.frames.length=0}},browserSupportsImageBitmapApi=typeof createImageBitmap<`u`&&typeof ImageBitmap<`u`,_useNativeImageBitmap=!1;function useNativeImageBitmap(e){_useNativeImageBitmap=e}function canUseNativeImageBitmap(){return _useNativeImageBitmap===!1?!1:browserSupportsImageBitmapApi}function createImageBitmapLikeImage(e={}){let t=e.onClose;return Object.assign(document.createElementNS(`http://www.w3.org/1999/xhtml`,`img`),{crossOrigin:``,close(){t&&t.call(this),this.onerror=this.onload=this.close=noop,this.removeAttribute(`src`),t=void 0}})}function createImageBitmapLike(e){if(canUseNativeImageBitmap())return createImageBitmap(e);{let t=URL.createObjectURL(e),n=function(){this.src===t&&URL.revokeObjectURL(t)};return new Promise((e,r)=>{let o=createImageBitmapLikeImage({onClose:n});o.onload=()=>{o.src===t&&URL.revokeObjectURL(t),o.onload=o.onerror=noop,AnimationFrameLoop.shared.add(()=>{e(o)},!0)},o.onerror=()=>{let e=o.src;o.onload=o.onerror=noop,o.close(),r(Error(`image load error: ${e}`))},o.decoding=`async`,o.src=t})}}var canvasPool=[];function createCanvas(e,t){let n=canvasPool.pop();if(n)return n.width=e,n.height=t,n;let r=Object.assign(document.createElementNS(`http://www.w3.org/1999/xhtml`,`canvas`),{close:()=>{r.close=noop,canvasPool.push(r)}});return r}function imageBitmapToTexture(e,t){if(t&&(e.width>t.width||e.height>t.height)){let n=createCanvas(Math.min(e.width,t.width),Math.min(e.height,t.height)),r=n.getContext(`2d`);r.clearRect(0,0,n.width,n.height),r.drawImage(e,0,0,n.width,n.height),e.close();let o=new three.Texture(n);o.needsUpdate=!0,o.flipY=!0;let s=o.dispose;return o.dispose=function(){n.close(),s.call(o),o.dispose=s},o}else{let t=new three.Texture(e);t.needsUpdate=!0,typeof ImageBitmap<`u`&&e instanceof ImageBitmap?t.flipY=!1:t.flipY=!0,t.flipY===!1&&(t.repeat.y*=-1,t.offset.y+=1,t.updateMatrix());let n=t.dispose;return t.dispose=function(){this.image&&this.image.close(),n.call(t),t.dispose=n},t}}function imageBitmapsToCubeTexture(e){let t=new three.CubeTexture(e);t.needsUpdate=!0,t.flipY=!1;let n=t.dispose;return t.dispose=function(){if(Array.isArray(this.images))for(let e of this.images)e.close();n.call(t),t.dispose=n},t}var FACE_ORDER$2=[`right`,`left`,`up`,`down`,`front`,`back`],TextureLoader=class{loadTexture(e,t,n=noop,r=noop,o=noop,s){var c,l,u,d,f,p,m;let h={};if(t.flipY!==void 0&&(h.flipY=t.flipY),t.format!==void 0)h.format=t.format;else{let t=getExtname(e);(t===`.jpg`||t===`.jpeg`)&&(h.format=three.RGBFormat)}t.encoding!==void 0&&(h.encoding=t.encoding),h.generateMipmaps=(c=t.generateMipmaps)==null?!1:c,h.minFilter=(l=t.minFilter)==null?three.LinearFilter:l,h.magFilter=(u=t.magFilter)==null?three.LinearFilter:u;let g=(f=(d=t.imageURL)==null?void 0:d.options)==null?{key:`unknown`}:f;if(e=applyImageURLOptions(e,(p=t.imageURL)==null?void 0:p.transform,g),(m=t.viaAjax)==null?canUseNativeImageBitmap:m){let s=null;return t.fetcher.ajax(e,{timeout:t.timeout,responseType:`blob`},void 0,void 0,o).then(e=>createImageBitmapLike(e.body)).then(e=>imageBitmapToTexture(e,t.maxSize)).then(e=>(Object.assign(e,h),e)).then(e=>{let t={meta:null,body:e};return n(t),t}).catch(e=>(r(e),Promise.reject(e)))}else{let s=null,c;return Promise.resolve().then(()=>createImageBitmapLikeImage()).then(n=>(c=n,t.fetcher.loadImage(e,{timeout:t.timeout},void 0,void 0,o,n))).then(e=>(s=e.meta,imageBitmapToTexture(e.body,t.maxSize))).then(e=>(Object.assign(e,h),e)).then(e=>{let t={meta:s,body:e};return n(t),t}).catch(e=>(c&&c.close(),r(e),Promise.reject(e)))}}loadCubeTexture(e,t,n=noop,r=noop,o=noop,s){var c,l,u,d,f,p,m;let h={};if(t.format!==void 0)h.format=t.format;else{let t=!0;for(let n of FACE_ORDER$2){let r=getExtname(e[n]);if(r!==`.jpg`&&r!==`.jpeg`){t=!1;break}}t&&(h.format=three.RGBFormat)}h.generateMipmaps=(c=t.generateMipmaps)==null?!1:c,h.minFilter=(l=t.minFilter)==null?three.LinearFilter:l,h.magFilter=(u=t.magFilter)==null?three.LinearFilter:u;let g=[e[FACE_ORDER$2[0]],e[FACE_ORDER$2[1]],e[FACE_ORDER$2[2]],e[FACE_ORDER$2[3]],e[FACE_ORDER$2[4]],e[FACE_ORDER$2[5]]],_=[],v=[0,0,0,0,0,0],y=[];for(let e=0;e<6;e++){let n=(f=(d=t.imageURL)==null?void 0:d.options)==null?{key:`unknown`}:f,r=applyImageURLOptions(g[e],(p=t.imageURL)==null?void 0:p.transform,Object.assign(Object.assign({},n),{key:n.key+`.`+FACE_ORDER$2[e]})),s=t=>{v[e]=t,o(v.reduce((e,t)=>e+t,0)/6)};if((m=t.viaAjax)!=null&&m){let n=t.fetcher.ajax(r,{timeout:t.timeout,responseType:`blob`},void 0,void 0,s).then(t=>(y[e]=t.meta,createImageBitmapLike(t.body)));_.push(n)}else{let n,o=Promise.resolve().then(()=>createImageBitmapLikeImage()).then(e=>(n=e,t.fetcher.loadImage(r,{timeout:t.timeout},void 0,void 0,s,e))).then(t=>(y[e]=t.meta,t.body)).catch(e=>(n&&n.close(),Promise.reject(e)));_.push(o)}}return Promise.all(_).then(e=>imageBitmapsToCubeTexture(e)).then(e=>(Object.assign(e,Object.assign({encoding:three.sRGBEncoding},h)),e)).then(e=>{let t={body:e,meta:y};return n(t),t}).catch(e=>{for(let e of _)e.then(e=>e.close()).catch(noop);return r(e),Promise.reject(e)})}},require_aspromise=__commonJSMin(((e,t)=>{t.exports=n;function n(e,t){for(var n=Array(arguments.length-1),r=0,o=2,s=!0;o<arguments.length;)n[r++]=arguments[o++];return new Promise(function(o,c){n[r]=function(e){if(s)if(s=!1,e)c(e);else{for(var t=Array(arguments.length-1),n=0;n<t.length;)t[n++]=arguments[n];o.apply(null,t)}};try{e.apply(t||null,n)}catch(e){s&&(s=!1,c(e))}})}})),require_base64=__commonJSMin((e=>{var t=e;t.length=function(e){var t=e.length;if(!t)return 0;for(var n=0;--t%4>1&&e.charAt(t)===`=`;)++n;return Math.ceil(e.length*3)/4-n};for(var n=Array(64),r=Array(123),o=0;o<64;)r[n[o]=o<26?o+65:o<52?o+71:o<62?o-4:o-59|43]=o++;t.encode=function(e,t,r){for(var o=null,s=[],c=0,l=0,u;t<r;){var d=e[t++];switch(l){case 0:s[c++]=n[d>>2],u=(d&3)<<4,l=1;break;case 1:s[c++]=n[u|d>>4],u=(d&15)<<2,l=2;break;case 2:s[c++]=n[u|d>>6],s[c++]=n[d&63],l=0;break}c>8191&&((o||(o=[])).push(String.fromCharCode.apply(String,s)),c=0)}return l&&(s[c++]=n[u],s[c++]=61,l===1&&(s[c++]=61)),o?(c&&o.push(String.fromCharCode.apply(String,s.slice(0,c))),o.join(``)):String.fromCharCode.apply(String,s.slice(0,c))};var s=`invalid encoding`;t.decode=function(e,t,n){for(var o=n,c=0,l,u=0;u<e.length;){var d=e.charCodeAt(u++);if(d===61&&c>1)break;if((d=r[d])===void 0)throw Error(s);switch(c){case 0:l=d,c=1;break;case 1:t[n++]=l<<2|(d&48)>>4,l=d,c=2;break;case 2:t[n++]=(l&15)<<4|(d&60)>>2,l=d,c=3;break;case 3:t[n++]=(l&3)<<6|d,c=0;break}}if(c===1)throw Error(s);return n-o},t.test=function(e){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(e)}})),require_eventemitter=__commonJSMin(((e,t)=>{t.exports=n;function n(){this._listeners={}}n.prototype.on=function(e,t,n){return(this._listeners[e]||(this._listeners[e]=[])).push({fn:t,ctx:n||this}),this},n.prototype.off=function(e,t){if(e===void 0)this._listeners={};else if(t===void 0)this._listeners[e]=[];else for(var n=this._listeners[e],r=0;r<n.length;)n[r].fn===t?n.splice(r,1):++r;return this},n.prototype.emit=function(e){var t=this._listeners[e];if(t){for(var n=[],r=1;r<arguments.length;)n.push(arguments[r++]);for(r=0;r<t.length;)t[r].fn.apply(t[r++].ctx,n)}return this}})),require_float=__commonJSMin(((e,t)=>{t.exports=n(n);function n(e){return typeof Float32Array<`u`?(function(){var t=new Float32Array([-0]),n=new Uint8Array(t.buffer),r=n[3]===128;function o(e,r,o){t[0]=e,r[o]=n[0],r[o+1]=n[1],r[o+2]=n[2],r[o+3]=n[3]}function s(e,r,o){t[0]=e,r[o]=n[3],r[o+1]=n[2],r[o+2]=n[1],r[o+3]=n[0]}e.writeFloatLE=r?o:s,e.writeFloatBE=r?s:o;function c(e,r){return n[0]=e[r],n[1]=e[r+1],n[2]=e[r+2],n[3]=e[r+3],t[0]}function l(e,r){return n[3]=e[r],n[2]=e[r+1],n[1]=e[r+2],n[0]=e[r+3],t[0]}e.readFloatLE=r?c:l,e.readFloatBE=r?l:c})():(function(){function t(e,t,n,r){var o=t<0?1:0;if(o&&(t=-t),t===0)e(1/t>0?0:2147483648,n,r);else if(isNaN(t))e(2143289344,n,r);else if(t>34028234663852886e22)e((o<<31|2139095040)>>>0,n,r);else if(t<11754943508222875e-54)e((o<<31|Math.round(t/1401298464324817e-60))>>>0,n,r);else{var s=Math.floor(Math.log(t)/Math.LN2),c=Math.round(t*Math.pow(2,-s)*8388608)&8388607;e((o<<31|s+127<<23|c)>>>0,n,r)}}e.writeFloatLE=t.bind(null,r),e.writeFloatBE=t.bind(null,o);function n(e,t,n){var r=e(t,n),o=(r>>31)*2+1,s=r>>>23&255,c=r&8388607;return s===255?c?NaN:o*(1/0):s===0?o*1401298464324817e-60*c:o*Math.pow(2,s-150)*(c+8388608)}e.readFloatLE=n.bind(null,s),e.readFloatBE=n.bind(null,c)})(),typeof Float64Array<`u`?(function(){var t=new Float64Array([-0]),n=new Uint8Array(t.buffer),r=n[7]===128;function o(e,r,o){t[0]=e,r[o]=n[0],r[o+1]=n[1],r[o+2]=n[2],r[o+3]=n[3],r[o+4]=n[4],r[o+5]=n[5],r[o+6]=n[6],r[o+7]=n[7]}function s(e,r,o){t[0]=e,r[o]=n[7],r[o+1]=n[6],r[o+2]=n[5],r[o+3]=n[4],r[o+4]=n[3],r[o+5]=n[2],r[o+6]=n[1],r[o+7]=n[0]}e.writeDoubleLE=r?o:s,e.writeDoubleBE=r?s:o;function c(e,r){return n[0]=e[r],n[1]=e[r+1],n[2]=e[r+2],n[3]=e[r+3],n[4]=e[r+4],n[5]=e[r+5],n[6]=e[r+6],n[7]=e[r+7],t[0]}function l(e,r){return n[7]=e[r],n[6]=e[r+1],n[5]=e[r+2],n[4]=e[r+3],n[3]=e[r+4],n[2]=e[r+5],n[1]=e[r+6],n[0]=e[r+7],t[0]}e.readDoubleLE=r?c:l,e.readDoubleBE=r?l:c})():(function(){function t(e,t,n,r,o,s){var c=r<0?1:0;if(c&&(r=-r),r===0)e(0,o,s+t),e(1/r>0?0:2147483648,o,s+n);else if(isNaN(r))e(0,o,s+t),e(2146959360,o,s+n);else if(r>17976931348623157e292)e(0,o,s+t),e((c<<31|2146435072)>>>0,o,s+n);else{var l;if(r<22250738585072014e-324)l=r/5e-324,e(l>>>0,o,s+t),e((c<<31|l/4294967296)>>>0,o,s+n);else{var u=Math.floor(Math.log(r)/Math.LN2);u===1024&&(u=1023),l=r*Math.pow(2,-u),e(l*4503599627370496>>>0,o,s+t),e((c<<31|u+1023<<20|l*1048576&1048575)>>>0,o,s+n)}}}e.writeDoubleLE=t.bind(null,r,0,4),e.writeDoubleBE=t.bind(null,o,4,0);function n(e,t,n,r,o){var s=e(r,o+t),c=e(r,o+n),l=(c>>31)*2+1,u=c>>>20&2047,d=4294967296*(c&1048575)+s;return u===2047?d?NaN:l*(1/0):u===0?l*5e-324*d:l*Math.pow(2,u-1075)*(d+4503599627370496)}e.readDoubleLE=n.bind(null,s,0,4),e.readDoubleBE=n.bind(null,c,4,0)})(),e}function r(e,t,n){t[n]=e&255,t[n+1]=e>>>8&255,t[n+2]=e>>>16&255,t[n+3]=e>>>24}function o(e,t,n){t[n]=e>>>24,t[n+1]=e>>>16&255,t[n+2]=e>>>8&255,t[n+3]=e&255}function s(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0}function c(e,t){return(e[t]<<24|e[t+1]<<16|e[t+2]<<8|e[t+3])>>>0}})),require_inquire=__commonJSMin(((exports,module)=>{module.exports=inquire;function inquire(moduleName){try{var mod=eval(`quire`.replace(/^/,`re`))(moduleName);if(mod&&(mod.length||Object.keys(mod).length))return mod}catch(e){}return null}})),require_utf8=__commonJSMin((e=>{var t=e;t.length=function(e){for(var t=0,n=0,r=0;r<e.length;++r)n=e.charCodeAt(r),n<128?t+=1:n<2048?t+=2:(n&64512)==55296&&(e.charCodeAt(r+1)&64512)==56320?(++r,t+=4):t+=3;return t},t.read=function(e,t,n){if(n-t<1)return``;for(var r=null,o=[],s=0,c;t<n;)c=e[t++],c<128?o[s++]=c:c>191&&c<224?o[s++]=(c&31)<<6|e[t++]&63:c>239&&c<365?(c=((c&7)<<18|(e[t++]&63)<<12|(e[t++]&63)<<6|e[t++]&63)-65536,o[s++]=55296+(c>>10),o[s++]=56320+(c&1023)):o[s++]=(c&15)<<12|(e[t++]&63)<<6|e[t++]&63,s>8191&&((r||(r=[])).push(String.fromCharCode.apply(String,o)),s=0);return r?(s&&r.push(String.fromCharCode.apply(String,o.slice(0,s))),r.join(``)):String.fromCharCode.apply(String,o.slice(0,s))},t.write=function(e,t,n){for(var r=n,o,s,c=0;c<e.length;++c)o=e.charCodeAt(c),o<128?t[n++]=o:o<2048?(t[n++]=o>>6|192,t[n++]=o&63|128):(o&64512)==55296&&((s=e.charCodeAt(c+1))&64512)==56320?(o=65536+((o&1023)<<10)+(s&1023),++c,t[n++]=o>>18|240,t[n++]=o>>12&63|128,t[n++]=o>>6&63|128,t[n++]=o&63|128):(t[n++]=o>>12|224,t[n++]=o>>6&63|128,t[n++]=o&63|128);return n-r}})),require_pool=__commonJSMin(((e,t)=>{t.exports=n;function n(e,t,n){var r=n||8192,o=r>>>1,s=null,c=r;return function(n){if(n<1||n>o)return e(n);c+n>r&&(s=e(r),c=0);var l=t.call(s,c,c+=n);return c&7&&(c=(c|7)+1),l}}})),require_longbits=__commonJSMin(((e,t)=>{t.exports=r;var n=require_minimal$1();function r(e,t){this.lo=e>>>0,this.hi=t>>>0}var o=r.zero=new r(0,0);o.toNumber=function(){return 0},o.zzEncode=o.zzDecode=function(){return this},o.length=function(){return 1};var s=r.zeroHash=`\0\0\0\0\0\0\0\0`;r.fromNumber=function(e){if(e===0)return o;var t=e<0;t&&(e=-e);var n=e>>>0,s=(e-n)/4294967296>>>0;return t&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)},r.from=function(e){if(typeof e==`number`)return r.fromNumber(e);if(n.isString(e))if(n.Long)e=n.Long.fromString(e);else return r.fromNumber(parseInt(e,10));return e.low||e.high?new r(e.low>>>0,e.high>>>0):o},r.prototype.toNumber=function(e){if(!e&&this.hi>>>31){var t=~this.lo+1>>>0,n=~this.hi>>>0;return t||(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296},r.prototype.toLong=function(e){return n.Long?new n.Long(this.lo|0,this.hi|0,!!e):{low:this.lo|0,high:this.hi|0,unsigned:!!e}};var c=String.prototype.charCodeAt;r.fromHash=function(e){return e===s?o:new r((c.call(e,0)|c.call(e,1)<<8|c.call(e,2)<<16|c.call(e,3)<<24)>>>0,(c.call(e,4)|c.call(e,5)<<8|c.call(e,6)<<16|c.call(e,7)<<24)>>>0)},r.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)},r.prototype.zzEncode=function(){var e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this},r.prototype.zzDecode=function(){var e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this},r.prototype.length=function(){var e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}})),require_minimal$1=__commonJSMin((e=>{var t=e;t.asPromise=require_aspromise(),t.base64=require_base64(),t.EventEmitter=require_eventemitter(),t.float=require_float(),t.inquire=require_inquire(),t.utf8=require_utf8(),t.pool=require_pool(),t.LongBits=require_longbits(),t.isNode=!!(typeof global<`u`&&global&&global.process&&global.process.versions&&global.process.versions.node),t.global=t.isNode&&global||typeof window<`u`&&window||typeof self<`u`&&self||e,t.emptyArray=Object.freeze?Object.freeze([]):[],t.emptyObject=Object.freeze?Object.freeze({}):{},t.isInteger=Number.isInteger||function(e){return typeof e==`number`&&isFinite(e)&&Math.floor(e)===e},t.isString=function(e){return typeof e==`string`||e instanceof String},t.isObject=function(e){return e&&typeof e==`object`},t.isset=t.isSet=function(e,t){var n=e[t];return n!=null&&e.hasOwnProperty(t)?typeof n!=`object`||(Array.isArray(n)?n.length:Object.keys(n).length)>0:!1},t.Buffer=(function(){try{var e=t.inquire(`buffer`).Buffer;return e.prototype.utf8Write?e:null}catch(e){return null}})(),t._Buffer_from=null,t._Buffer_allocUnsafe=null,t.newBuffer=function(e){return typeof e==`number`?t.Buffer?t._Buffer_allocUnsafe(e):new t.Array(e):t.Buffer?t._Buffer_from(e):typeof Uint8Array>`u`?e:new Uint8Array(e)},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(e){return e?t.LongBits.from(e).toHash():t.LongBits.zeroHash},t.longFromHash=function(e,n){var r=t.LongBits.fromHash(e);return t.Long?t.Long.fromBits(r.lo,r.hi,n):r.toNumber(!!n)};function n(e,t,n){for(var r=Object.keys(t),o=0;o<r.length;++o)(e[r[o]]===void 0||!n)&&(e[r[o]]=t[r[o]]);return e}t.merge=n,t.lcFirst=function(e){return e.charAt(0).toLowerCase()+e.substring(1)};function r(e){function t(e,r){if(!(this instanceof t))return new t(e,r);Object.defineProperty(this,`message`,{get:function(){return e}}),Error.captureStackTrace?Error.captureStackTrace(this,t):Object.defineProperty(this,`stack`,{value:Error().stack||``}),r&&n(this,r)}return t.prototype=Object.create(Error.prototype,{constructor:{value:t,writable:!0,enumerable:!1,configurable:!0},name:{get:function(){return e},set:void 0,enumerable:!1,configurable:!0},toString:{value:function(){return this.name+`: `+this.message},writable:!0,enumerable:!1,configurable:!0}}),t}t.newError=r,t.ProtocolError=r(`ProtocolError`),t.oneOfGetter=function(e){for(var t={},n=0;n<e.length;++n)t[e[n]]=1;return function(){for(var e=Object.keys(this),n=e.length-1;n>-1;--n)if(t[e[n]]===1&&this[e[n]]!==void 0&&this[e[n]]!==null)return e[n]}},t.oneOfSetter=function(e){return function(t){for(var n=0;n<e.length;++n)e[n]!==t&&delete this[e[n]]}},t.toJSONOptions={longs:String,enums:String,bytes:String,json:!0},t._configure=function(){var e=t.Buffer;if(!e){t._Buffer_from=t._Buffer_allocUnsafe=null;return}t._Buffer_from=e.from!==Uint8Array.from&&e.from||function(t,n){return new e(t,n)},t._Buffer_allocUnsafe=e.allocUnsafe||function(t){return new e(t)}}})),require_writer=__commonJSMin(((e,t)=>{t.exports=f;var n=require_minimal$1(),r,o=n.LongBits,s=n.base64,c=n.utf8;function l(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}function u(){}function d(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}function f(){this.len=0,this.head=new l(u,0,0),this.tail=this.head,this.states=null}var p=function(){return n.Buffer?function(){return(f.create=function(){return new r})()}:function(){return new f}};f.create=p(),f.alloc=function(e){return new n.Array(e)},n.Array!==Array&&(f.alloc=n.pool(f.alloc,n.Array.prototype.subarray)),f.prototype._push=function(e,t,n){return this.tail=this.tail.next=new l(e,t,n),this.len+=t,this};function m(e,t,n){t[n]=e&255}function h(e,t,n){for(;e>127;)t[n++]=e&127|128,e>>>=7;t[n]=e}function g(e,t){this.len=e,this.next=void 0,this.val=t}g.prototype=Object.create(l.prototype),g.prototype.fn=h,f.prototype.uint32=function(e){return this.len+=(this.tail=this.tail.next=new g((e>>>=0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this},f.prototype.int32=function(e){return e<0?this._push(_,10,o.fromNumber(e)):this.uint32(e)},f.prototype.sint32=function(e){return this.uint32((e<<1^e>>31)>>>0)};function _(e,t,n){for(;e.hi;)t[n++]=e.lo&127|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[n++]=e.lo&127|128,e.lo>>>=7;t[n++]=e.lo}f.prototype.uint64=function(e){var t=o.from(e);return this._push(_,t.length(),t)},f.prototype.int64=f.prototype.uint64,f.prototype.sint64=function(e){var t=o.from(e).zzEncode();return this._push(_,t.length(),t)},f.prototype.bool=function(e){return this._push(m,1,e?1:0)};function v(e,t,n){t[n]=e&255,t[n+1]=e>>>8&255,t[n+2]=e>>>16&255,t[n+3]=e>>>24}f.prototype.fixed32=function(e){return this._push(v,4,e>>>0)},f.prototype.sfixed32=f.prototype.fixed32,f.prototype.fixed64=function(e){var t=o.from(e);return this._push(v,4,t.lo)._push(v,4,t.hi)},f.prototype.sfixed64=f.prototype.fixed64,f.prototype.float=function(e){return this._push(n.float.writeFloatLE,4,e)},f.prototype.double=function(e){return this._push(n.float.writeDoubleLE,8,e)};var y=n.Array.prototype.set?function(e,t,n){t.set(e,n)}:function(e,t,n){for(var r=0;r<e.length;++r)t[n+r]=e[r]};f.prototype.bytes=function(e){var t=e.length>>>0;if(!t)return this._push(m,1,0);if(n.isString(e)){var r=f.alloc(t=s.length(e));s.decode(e,r,0),e=r}return this.uint32(t)._push(y,t,e)},f.prototype.string=function(e){var t=c.length(e);return t?this.uint32(t)._push(c.write,t,e):this._push(m,1,0)},f.prototype.fork=function(){return this.states=new d(this),this.head=this.tail=new l(u,0,0),this.len=0,this},f.prototype.reset=function(){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 l(u,0,0),this.len=0),this},f.prototype.ldelim=function(){var e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n&&(this.tail.next=e.next,this.tail=t,this.len+=n),this},f.prototype.finish=function(){for(var e=this.head.next,t=this.constructor.alloc(this.len),n=0;e;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t},f._configure=function(e){r=e,f.create=p(),r._configure()}})),require_writer_buffer=__commonJSMin(((e,t)=>{t.exports=o;var n=require_writer();(o.prototype=Object.create(n.prototype)).constructor=o;var r=require_minimal$1();function o(){n.call(this)}o._configure=function(){o.alloc=r._Buffer_allocUnsafe,o.writeBytesBuffer=r.Buffer&&r.Buffer.prototype instanceof Uint8Array&&r.Buffer.prototype.set.name===`set`?function(e,t,n){t.set(e,n)}:function(e,t,n){if(e.copy)e.copy(t,n,0,e.length);else for(var r=0;r<e.length;)t[n++]=e[r++]}},o.prototype.bytes=function(e){r.isString(e)&&(e=r._Buffer_from(e,`base64`));var t=e.length>>>0;return this.uint32(t),t&&this._push(o.writeBytesBuffer,t,e),this};function s(e,t,n){e.length<40?r.utf8.write(e,t,n):t.utf8Write?t.utf8Write(e,n):t.write(e,n)}o.prototype.string=function(e){var t=r.Buffer.byteLength(e);return this.uint32(t),t&&this._push(s,t,e),this},o._configure()})),require_reader=__commonJSMin(((e,t)=>{t.exports=l;var n=require_minimal$1(),r,o=n.LongBits,s=n.utf8;function c(e,t){return RangeError(`index out of range: `+e.pos+` + `+(t||1)+` > `+e.len)}function l(e){this.buf=e,this.pos=0,this.len=e.length}var u=typeof Uint8Array<`u`?function(e){if(e instanceof Uint8Array||Array.isArray(e))return new l(e);throw Error(`illegal buffer`)}:function(e){if(Array.isArray(e))return new l(e);throw Error(`illegal buffer`)},d=function(){return n.Buffer?function(e){return(l.create=function(e){return n.Buffer.isBuffer(e)?new r(e):u(e)})(e)}:u};l.create=d(),l.prototype._slice=n.Array.prototype.subarray||n.Array.prototype.slice,l.prototype.uint32=(function(){var e=4294967295;return function(){if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,c(this,10);return e}})(),l.prototype.int32=function(){return this.uint32()|0},l.prototype.sint32=function(){var e=this.uint32();return e>>>1^-(e&1)|0};function f(){var e=new o(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw c(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw c(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error(`invalid varint encoding`)}l.prototype.bool=function(){return this.uint32()!==0};function p(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}l.prototype.fixed32=function(){if(this.pos+4>this.len)throw c(this,4);return p(this.buf,this.pos+=4)},l.prototype.sfixed32=function(){if(this.pos+4>this.len)throw c(this,4);return p(this.buf,this.pos+=4)|0};function m(){if(this.pos+8>this.len)throw c(this,8);return new o(p(this.buf,this.pos+=4),p(this.buf,this.pos+=4))}l.prototype.float=function(){if(this.pos+4>this.len)throw c(this,4);var e=n.float.readFloatLE(this.buf,this.pos);return this.pos+=4,e},l.prototype.double=function(){if(this.pos+8>this.len)throw c(this,4);var e=n.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,e},l.prototype.bytes=function(){var e=this.uint32(),t=this.pos,r=this.pos+e;if(r>this.len)throw c(this,e);if(this.pos+=e,Array.isArray(this.buf))return this.buf.slice(t,r);if(t===r){var o=n.Buffer;return o?o.alloc(0):new this.buf.constructor(0)}return this._slice.call(this.buf,t,r)},l.prototype.string=function(){var e=this.bytes();return s.read(e,0,e.length)},l.prototype.skip=function(e){if(typeof e==`number`){if(this.pos+e>this.len)throw c(this,e);this.pos+=e}else do if(this.pos>=this.len)throw c(this);while(this.buf[this.pos++]&128);return this},l.prototype.skipType=function(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!=4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type `+e+` at offset `+this.pos)}return this},l._configure=function(e){r=e,l.create=d(),r._configure();var t=n.Long?`toLong`:`toNumber`;n.merge(l.prototype,{int64:function(){return f.call(this)[t](!1)},uint64:function(){return f.call(this)[t](!0)},sint64:function(){return f.call(this).zzDecode()[t](!1)},fixed64:function(){return m.call(this)[t](!0)},sfixed64:function(){return m.call(this)[t](!1)}})}})),require_reader_buffer=__commonJSMin(((e,t)=>{t.exports=o;var n=require_reader();(o.prototype=Object.create(n.prototype)).constructor=o;var r=require_minimal$1();function o(e){n.call(this,e)}o._configure=function(){r.Buffer&&(o.prototype._slice=r.Buffer.prototype.slice)},o.prototype.string=function(){var e=this.uint32();return this.buf.utf8Slice?this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+e,this.len)):this.buf.toString(`utf-8`,this.pos,this.pos=Math.min(this.pos+e,this.len))},o._configure()})),require_service=__commonJSMin(((e,t)=>{t.exports=r;var n=require_minimal$1();(r.prototype=Object.create(n.EventEmitter.prototype)).constructor=r;function r(e,t,r){if(typeof e!=`function`)throw TypeError(`rpcImpl must be a function`);n.EventEmitter.call(this),this.rpcImpl=e,this.requestDelimited=!!t,this.responseDelimited=!!r}r.prototype.rpcCall=function e(t,r,o,s,c){if(!s)throw TypeError(`request must be specified`);var l=this;if(!c)return n.asPromise(e,l,t,r,o,s);if(!l.rpcImpl){setTimeout(function(){c(Error(`already ended`))},0);return}try{return l.rpcImpl(t,r[l.requestDelimited?`encodeDelimited`:`encode`](s).finish(),function(e,n){if(e)return l.emit(`error`,e,t),c(e);if(n===null){l.end(!0);return}if(!(n instanceof o))try{n=o[l.responseDelimited?`decodeDelimited`:`decode`](n)}catch(e){return l.emit(`error`,e,t),c(e)}return l.emit(`data`,n,t),c(null,n)})}catch(e){l.emit(`error`,e,t),setTimeout(function(){c(e)},0);return}},r.prototype.end=function(e){return this.rpcImpl&&(e||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit(`end`).off()),this}})),require_rpc=__commonJSMin((e=>{var t=e;t.Service=require_service()})),require_roots=__commonJSMin(((e,t)=>{t.exports={}})),require_index_minimal=__commonJSMin((e=>{var t=e;t.build=`minimal`,t.Writer=require_writer(),t.BufferWriter=require_writer_buffer(),t.Reader=require_reader(),t.BufferReader=require_reader_buffer(),t.util=require_minimal$1(),t.rpc=require_rpc(),t.roots=require_roots(),t.configure=n;function n(){t.util._configure(),t.Writer._configure(t.BufferWriter),t.Reader._configure(t.BufferReader)}n()})),require_minimal=__commonJSMin(((e,t)=>{t.exports=require_index_minimal()})),import_minimal=__toESM(require_minimal(),1),$Reader$1=import_minimal.Reader,$util$1=import_minimal.util,$root$1=import_minimal.roots[`@REALSEE/FIVE:five/model/loaders/protobuf/pbm.proto`]||(import_minimal.roots[`@REALSEE/FIVE:five/model/loaders/protobuf/pbm.proto`]={}),Model$2=$root$1.Model=(()=>{function e(e){if(this.chunks=[],e)for(let t=Object.keys(e),n=0;n<t.length;++n)e[t[n]]!=null&&(this[t[n]]=e[t[n]])}return e.prototype.chunks=$util$1.emptyArray,e.prototype.createAt=$util$1.Long?$util$1.Long.fromBits(0,0,!0):0,e.prototype.description=``,e.decode=function(e,t,n){e instanceof $Reader$1||(e=$Reader$1.create(e));let r=t===void 0?e.len:e.pos+t,o=new $root$1.Model;for(;e.pos<r;){let t=e.uint32();if(t===n)break;switch(t>>>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(t&7);break}}return o},e.getTypeUrl=function(e){return e===void 0&&(e=`type.googleapis.com`),e+`/Model`},e})(),Chunk$1=$root$1.Chunk=(()=>{function e(e){if(e)for(let t=Object.keys(e),n=0;n<t.length;++n)e[t[n]]!=null&&(this[t[n]]=e[t[n]])}return e.prototype.vertices=null,e.prototype.faces=null,e.prototype.name=``,e.prototype.texture=``,e.decode=function(e,t,n){e instanceof $Reader$1||(e=$Reader$1.create(e));let r=t===void 0?e.len:e.pos+t,o=new $root$1.Chunk;for(;e.pos<r;){let t=e.uint32();if(t===n)break;switch(t>>>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(t&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},e.getTypeUrl=function(e){return e===void 0&&(e=`type.googleapis.com`),e+`/Chunk`},e})(),Vertices=$root$1.Vertices=(()=>{function e(e){if(this.xyz=[],this.uvs=[],this.marks=[],e)for(let t=Object.keys(e),n=0;n<t.length;++n)e[t[n]]!=null&&(this[t[n]]=e[t[n]])}return e.prototype.xyz=$util$1.emptyArray,e.prototype.uvs=$util$1.emptyArray,e.prototype.marks=$util$1.emptyArray,e.decode=function(e,t,n){e instanceof $Reader$1||(e=$Reader$1.create(e));let r=t===void 0?e.len:e.pos+t,o=new $root$1.Vertices;for(;e.pos<r;){let t=e.uint32();if(t===n)break;switch(t>>>3){case 1:if(o.xyz&&o.xyz.length||(o.xyz=[]),(t&7)==2){let t=e.uint32()+e.pos;for(;e.pos<t;)o.xyz.push(e.float())}else o.xyz.push(e.float());break;case 2:if(o.uvs&&o.uvs.length||(o.uvs=[]),(t&7)==2){let t=e.uint32()+e.pos;for(;e.pos<t;)o.uvs.push(e.float())}else o.uvs.push(e.float());break;case 3:if(o.marks&&o.marks.length||(o.marks=[]),(t&7)==2){let t=e.uint32()+e.pos;for(;e.pos<t;)o.marks.push(e.int32())}else o.marks.push(e.int32());break;default:e.skipType(t&7);break}}return o},e.getTypeUrl=function(e){return e===void 0&&(e=`type.googleapis.com`),e+`/Vertices`},e})(),Faces=$root$1.Faces=(()=>{function e(e){if(this.indices=[],this.normals=[],e)for(let t=Object.keys(e),n=0;n<t.length;++n)e[t[n]]!=null&&(this[t[n]]=e[t[n]])}return e.prototype.indices=$util$1.emptyArray,e.prototype.normals=$util$1.emptyArray,e.decode=function(e,t,n){e instanceof $Reader$1||(e=$Reader$1.create(e));let r=t===void 0?e.len:e.pos+t,o=new $root$1.Faces;for(;e.pos<r;){let t=e.uint32();if(t===n)break;switch(t>>>3){case 1:if(o.indices&&o.indices.length||(o.indices=[]),(t&7)==2){let t=e.uint32()+e.pos;for(;e.pos<t;)o.indices.push(e.uint32())}else o.indices.push(e.uint32());break;case 2:if(o.normals&&o.normals.length||(o.normals=[]),(t&7)==2){let t=e.uint32()+e.pos;for(;e.pos<t;)o.normals.push(e.float())}else o.normals.push(e.float());break;default:e.skipType(t&7);break}}return o},e.getTypeUrl=function(e){return e===void 0&&(e=`type.googleapis.com`),e+`/Faces`},e})(),VertexMark=$root$1.VertexMark=(()=>{let e={},t=Object.create(e);return t[e[0]=`VERTEX_MARK_UNSPECIFIED`]=0,t[e[1]=`VERTEX_MARK_ROOF`]=1,t})();function fixNumber(e){return isNaN(e)||!isFinite(e)?0:e}function getGeometryMemoryUsed(e){let t=0;if(e instanceof three.BufferGeometry){for(let n in e.attributes){let r=e.getAttribute(n),o=4;`BYTES_PER_ELEMENT`in r.array&&typeof r.array.BYTES_PER_ELEMENT==`number`&&(o=r.array.BYTES_PER_ELEMENT),t+=fixNumber(r.count*r.itemSize*o)}let n=e.getIndex();if(n){let e=4;`BYTES_PER_ELEMENT`in n.array&&typeof n.array.BYTES_PER_ELEMENT==`number`&&(e=n.array.BYTES_PER_ELEMENT),t+=fixNumber(n.count*n.itemSize*e)}}else e instanceof three.Geometry&&(t+=fixNumber(e.faces.length*3*3*4),t+=fixNumber(e.faceVertexUvs.length*3*2*4));return t}function getPBMGSObjectMemoryUsed(e){let t=[e.positions,e.rotations,e.scales,e.colors,e.sh1,e.sh2,e.sh3],n=0;for(let e of t){if(!e)continue;let t=4;`BYTES_PER_ELEMENT`in e&&typeof e.BYTES_PER_ELEMENT==`number`&&(t=e.BYTES_PER_ELEMENT);let r=e.length*t;isNaN(r)||!isFinite(r)||(n+=r)}return n}function makeComputeBlockRectSizeFunction(e,t,n){return function(r,o,s){return((r+e-1)/e|0)*((o+t-1)/t|0)*n*s}}function makeComputePaddedRectSizeFunction(e,t,n){return function(r,o,s){return(Math.max(r,e)*Math.max(o,t)/n|0)*s}}var compressedTextureFunctions=new Map([[three.RGB_S3TC_DXT1_Format,makeComputeBlockRectSizeFunction(4,4,8)],[three.RGBA_S3TC_DXT1_Format,makeComputeBlockRectSizeFunction(4,4,8)],[three.RGBA_S3TC_DXT3_Format,makeComputeBlockRectSizeFunction(4,4,16)],[three.RGBA_S3TC_DXT5_Format,makeComputeBlockRectSizeFunction(4,4,16)],[three.RGB_ETC1_Format,makeComputeBlockRectSizeFunction(4,4,8)],[three.RGB_PVRTC_4BPPV1_Format,makeComputePaddedRectSizeFunction(8,8,2)],[three.RGBA_PVRTC_4BPPV1_Format,makeComputePaddedRectSizeFunction(8,8,2)],[three.RGB_PVRTC_2BPPV1_Format,makeComputePaddedRectSizeFunction(16,8,4)],[three.RGBA_PVRTC_2BPPV1_Format,makeComputePaddedRectSizeFunction(16,8,4)],[three.RGB_ETC2_Format,makeComputeBlockRectSizeFunction(4,4,8)],[three.RGBA_ETC2_EAC_Format,makeComputeBlockRectSizeFunction(4,4,16)],[three.RGBA_ASTC_4x4_Format,makeComputeBlockRectSizeFunction(4,4,16)],[three.SRGB8_ALPHA8_ASTC_4x4_Format,makeComputeBlockRectSizeFunction(4,4,16)],[three.RGBA_ASTC_5x4_Format,makeComputeBlockRectSizeFunction(5,4,16)],[three.SRGB8_ALPHA8_ASTC_5x4_Format,makeComputeBlockRectSizeFunction(5,4,16)],[three.RGBA_ASTC_5x5_Format,makeComputeBlockRectSizeFunction(5,5,16)],[three.SRGB8_ALPHA8_ASTC_5x5_Format,makeComputeBlockRectSizeFunction(5,5,16)],[three.RGBA_ASTC_6x5_Format,makeComputeBlockRectSizeFunction(6,5,16)],[three.SRGB8_ALPHA8_ASTC_6x5_Format,makeComputeBlockRectSizeFunction(6,5,16)],[three.RGBA_ASTC_6x6_Format,makeComputeBlockRectSizeFunction(6,6,16)],[three.SRGB8_ALPHA8_ASTC_6x6_Format,makeComputeBlockRectSizeFunction(6,6,16)],[three.RGBA_ASTC_8x5_Format,makeComputeBlockRectSizeFunction(8,5,16)],[three.SRGB8_ALPHA8_ASTC_8x5_Format,makeComputeBlockRectSizeFunction(8,5,16)],[three.RGBA_ASTC_8x6_Format,makeComputeBlockRectSizeFunction(8,6,16)],[three.SRGB8_ALPHA8_ASTC_8x6_Format,makeComputeBlockRectSizeFunction(8,6,16)],[three.RGBA_ASTC_8x8_Format,makeComputeBlockRectSizeFunction(8,8,16)],[three.SRGB8_ALPHA8_ASTC_8x8_Format,makeComputeBlockRectSizeFunction(8,8,16)],[three.RGBA_ASTC_10x5_Format,makeComputeBlockRectSizeFunction(10,5,16)],[three.SRGB8_ALPHA8_ASTC_10x5_Format,makeComputeBlockRectSizeFunction(10,5,16)],[three.RGBA_ASTC_10x6_Format,makeComputeBlockRectSizeFunction(10,6,16)],[three.SRGB8_ALPHA8_ASTC_10x6_Format,makeComputeBlockRectSizeFunction(10,6,16)],[three.RGBA_ASTC_10x8_Format,makeComputeBlockRectSizeFunction(10,8,16)],[three.SRGB8_ALPHA8_ASTC_10x8_Format,makeComputeBlockRectSizeFunction(10,8,16)],[three.RGBA_ASTC_10x10_Format,makeComputeBlockRectSizeFunction(10,10,16)],[three.SRGB8_ALPHA8_ASTC_10x10_Format,makeComputeBlockRectSizeFunction(10,10,16)],[three.RGBA_ASTC_12x10_Format,makeComputeBlockRectSizeFunction(12,10,16)],[three.SRGB8_ALPHA8_ASTC_12x10_Format,makeComputeBlockRectSizeFunction(12,10,16)],[three.RGBA_ASTC_12x12_Format,makeComputeBlockRectSizeFunction(12,12,16)],[three.SRGB8_ALPHA8_ASTC_12x12_Format,makeComputeBlockRectSizeFunction(12,12,16)],[three.RGBA_BPTC_Format,makeComputeBlockRectSizeFunction(4,4,16)]]);function getTextureMemoryUsed(e){let t=0,n=1;(e.generateMipmaps===!0||e.mipmaps&&e.mipmaps.length>1)&&(n=1.33);let r=e instanceof three.CompressedTexture?compressedTextureFunctions.get(e.format):void 0,o=[].concat(e.image);for(let e of o)if(e)if(e instanceof three.Texture)t+=getTextureMemoryUsed(e);else{let{width:o=1,height:s=1,depth:c=1}=e;r?t+=fixNumber(r(o,s,c)*n):t+=fixNumber(o*s*c*4*n)}return t}var textureSet=new Set,textureNames=`map.alphaMap.bumpMap.normalMap.displacementMap.emissiveMap.specularMap.envMap.flipEnvMap.lightMap.aoMap.gradientMap.metalnessMap.roughnessMap.sheenColorMap.sheenRoughnessMap.clearcoatMap.clearcoatRoughnessMap.clearcoatNormalMap.iridescenceMap.iridescenceThicknessMap.transmissionMap.thicknessMap.anisotropyMap.specularColorMap.specularIntensityMap`.split(`.`);function getMaterialMemoryUsed(e){let t=0;if(textureSet.clear(),e instanceof three.ShaderMaterial)for(let n in e.uniforms){let r=e.uniforms[n],o=r&&r.value&&r.value instanceof three.Texture?r.value:void 0;o instanceof three.Texture&&(textureSet.has(o)||(t=getTextureMemoryUsed(o),textureSet.add(o)))}else for(let n of textureNames){let r=e[n];r instanceof three.Texture&&(textureSet.has(r)||(t=getTextureMemoryUsed(r),textureSet.add(r)))}return textureSet.clear(),t}var sceneSet=new Set;function getMemoryUsage(e){let t=0;return sceneSet.clear(),e.traverse(e=>{if(e instanceof PBMGaussianSplattingObject&&(t+=getPBMGSObjectMemoryUsed(e)),e instanceof three.Mesh||e instanceof three.Line||e instanceof three.Points){let n=e.geometry;(n instanceof three.BufferGeometry||n instanceof three.Geometry)&&(sceneSet.has(n)||(t+=getGeometryMemoryUsed(n),sceneSet.add(n)));let r=[].concat(e.material);for(let e of r)e instanceof three.Material&&(sceneSet.has(e)||(t+=getMaterialMemoryUsed(e),sceneSet.add(e)))}}),sceneSet.clear(),t}function guessTextureBaseUriFromFileUrl(e){let t=e.lastIndexOf(`/`);return t>=0?e.slice(0,t+1).replace(/\/(model)(\/|$)/,(e,t,n)=>`/materials`+n):``}function loadPbm(e,t={}){var n,r,o,s,c,l,u;let d=(n=t.upAxis)==null?`Z`:n,f=(r=t.light)==null?!1:r,p=(o=t.fetcher)==null?internalFetcher:o,m=(s=t.onDownloadProgress)==null?noop:s,h=(c=t.textureBaseUri)==null?guessTextureBaseUriFromFileUrl(e):c,g=t.textureBaseUri===void 0?[]:((l=t.textureArray)==null?[]:l).slice(),_=autoRestImageOptionsByTextureLength((u=t.textureOptions)==null?{}:u,g.length),v=new Map;for(let e of g){let t=isAbsoluteURL(e)?e:pathJoin(h,e);v.set(t,loadTexture$1(t,_,p))}let y={byteLength:0};return Promise.resolve().then(()=>p.ajax(e,{responseType:`arraybuffer`},void 0,void 0,m)).then(e=>{y.byteLength=e.body.byteLength;let t=new Uint8Array(e.body);return Model$2.decode(t)}).then(e=>parse$4(e,f,h,g,_,v,p)).then(t=>{v.clear();let n=new three.Group;n.name=e;for(let e of t.objects)n.add(e);return d===`Y`&&n.applyMatrix4(ROTATE_X_MATRIX_INVERSE$1),{type:`pbm`,modelUpAxis:`Z`,upAxis:d,uri:e,byteLength:y.byteLength,memoryUsage:getMemoryUsage(n),scene:n,textures:t.textures,animations:[],dispose:()=>t.dispose()}})}function parseFloorName(e){let t=e.match(/(group|floor)-?(\d+)/);return t?parseInt(t[2],10):0}function parseChunkName(e){let t=e.match(/(chunk)-?(\d+)/);return t?parseInt(t[2],10):0}function parseSubName(e){let t=e.match(/(sub)-?(\d+)/);return t?parseInt(t[2],10):0}function chunkOrder(e){let t=parseFloorName(e.name),n=parseChunkName(e.name),r=parseSubName(e.name);return t*1e6+n*1e3+r}function parsePBMModel(e){var t,n,r;let o=typeof e.createAt==`number`?e.createAt:0,s=(t=e.description)==null?``:t,c=[],l=!0,u=!0;for(let t of e.chunks)if(!t.vertices.marks||t.vertices.marks.length===0){u=!1;break}for(let t of e.chunks)if(!t.faces.normals||t.faces.normals.length===0){l=!1;break}let d=e.chunks.sort((e,t)=>chunkOrder(e)-chunkOrder(t)),f=[];for(let e of d){let t=parseFloorName(e.name);f[t]||(f[t]=[]),f[t].push(e)}for(let e=0;e<f.length;e++){let t=f[e];if(t)if(l){let r=0;for(let e=0;e<t.length;e++){let n=t[e];r+=n.faces.indices.length}let l=new Float32Array(r*3),d=new Float32Array(r*2),f=new Float32Array(r*3),p=u?new Float32Array(r):void 0,m=[],h=[1/0,1/0,1/0,-1/0,-1/0,-1/0],g=0;for(let e=0;e<t.length;e++){let r=[1/0,1/0,1/0,-1/0,-1/0,-1/0],o=t[e],s=o.vertices.xyz,c=o.vertices.uvs,u=o.faces.indices,_=o.faces.normals,v=o.vertices.marks,y=u.length;for(let e=0;e<y;e++){let t=u[e],n=l[g*3+e*3]=s[t*3],o=l[g*3+e*3+1]=s[t*3+1],m=l[g*3+e*3+2]=s[t*3+2];p&&(p[g+e]=v[t]),d[g*2+e*2]=c[t*2],d[g*2+e*2+1]=c[t*2+1];let h=Math.floor(e/3)*3;f[g*3+e*3]=_[h],f[g*3+e*3+1]=_[h+1],f[g*3+e*3+2]=_[h+2],n<r[0]&&(r[0]=n),o<r[1]&&(r[1]=o),m<r[2]&&(r[2]=m),n>r[3]&&(r[3]=n),o>r[4]&&(r[4]=o),m>r[5]&&(r[5]=m)}r[0]<h[0]&&(h[0]=r[0]),r[1]<h[1]&&(h[1]=r[1]),r[2]<h[2]&&(h[2]=r[2]),r[3]>h[3]&&(h[3]=r[3]),r[4]>h[4]&&(h[4]=r[4]),r[5]>h[5]&&(h[5]=r[5]),m.push({materialIndex:e,name:o.name,chunkName:parseChunkName(o.name),start:g,count:o.faces.indices.length,texture:(n=o.texture)==null?void 0:n}),g+=y}let _={createAt:o,description:s,vertices:l,uvs:d,normals:f,masks:p,indices:null,floorIndex:e,groups:m,extents:h};c.push(_)}else{let n=0,l=0;for(let e=0;e<t.length;e++){let r=t[e];l+=r.vertices.xyz.length/3,n+=r.faces.indices.length}let d=new Float32Array(l*3),f=new Float32Array(l*2),p,m=new Float32Array(l),h=new Uint32Array(n),g=u?new Float32Array(n):void 0,_=[],v=[1/0,1/0,1/0,-1/0,-1/0,-1/0],y=0,b=0;for(let n=0;n<t.length;n++){let o=[1/0,1/0,1/0,-1/0,-1/0,-1/0],s=t[n],c=s.vertices.xyz,l=s.vertices.marks,u=s.vertices.uvs,p=s.faces.indices,S=c.length/3,C=p.length;for(let t=0;t<S;t++){let n=d[b*3+t*3]=c[t*3],r=d[b*3+t*3+1]=c[t*3+1],s=d[b*3+t*3+2]=c[t*3+2];g&&(g[b+t]=l[t]),f[b*2+t*2]=u[t*2],f[b*2+t*2+1]=u[t*2+1],m[b+t]=e,n<o[0]&&(o[0]=n),r<o[1]&&(o[1]=r),s<o[2]&&(o[2]=s),n>o[3]&&(o[3]=n),r>o[4]&&(o[4]=r),s>o[5]&&(o[5]=s)}o[0]<v[0]&&(v[0]=o[0]),o[1]<v[1]&&(v[1]=o[1]),o[2]<v[2]&&(v[2]=o[2]),o[3]>v[3]&&(v[3]=o[3]),o[4]>v[4]&&(v[4]=o[4]),o[5]>v[5]&&(v[5]=o[5]);for(let e=0;e<C;e++)h[y+e]=b+p[e];_.push({materialIndex:n,name:s.name,chunkName:parseChunkName(s.name),start:y,count:s.faces.indices.length,texture:(r=s.texture)==null?void 0:r}),b+=S,y+=C}let S={createAt:o,description:s,vertices:d,uvs:f,normals:void 0,masks:g,indices:h,floorIndex:e,groups:_,extents:v};c.push(S)}}return c}function loadTexture$1(e,t,n){let r=Object.assign({key:`texture.pbm`},pick(t,[`format`,`quality`,`size`,`sharpen`,`forceUseExifOrientation`,`mappings`]));return new TextureLoader().loadTexture(e,{imageURL:{transform:t.transform,options:r},encoding:three.sRGBEncoding,wrapS:three.ClampToEdgeWrapping,wrapT:three.ClampToEdgeWrapping,minFilter:three.LinearFilter,maxSize:typeof r.size==`number`?new three.Vector2(r.size,r.size):void 0,fetcher:n}).then(e=>{let t=e.body;return t.needsUpdate=!0,t})}function parse$4(e,t,n,r,o,s,c){let l=parsePBMModel(e),u=0,d=``,f=[],p={},m=new Set,h=0;for(let{createAt:e,description:o,vertices:s,masks:c,uvs:g,normals:_,indices:v,floorIndex:y,groups:b,extents:S}of l){let l=new three.Box3;l.min.x=S[0],l.min.y=S[1],l.min.z=S[2],l.max.x=S[3],l.max.y=S[4],l.max.z=S[5];let C=new three.BufferGeometry;C.setAttribute(`position`,new three.BufferAttribute(s,3)),C.setAttribute(`uv`,new three.BufferAttribute(g,2)),_&&C.setAttribute(`normal`,new three.BufferAttribute(_,3)),c&&C.setAttribute(`_feature_id_rsmask`,new three.BufferAttribute(c,1)),v&&C.setIndex(new three.BufferAttribute(v,1)),C.boundingBox=l,C.boundingSphere=l.getBoundingSphere(new three.Sphere);for(let e of b)C.addGroup(e.start,e.count,e.materialIndex);m.add(C);let w=[];for(let e of b){let o;if(e.texture){if(o=e.texture,r.length>0&&r.indexOf(e.texture)===-1){for(let t of r)if((isAbsoluteURL(t)?t:pathJoin(n,t)).slice(e.texture.length*-1)===e.texture){o=t;break}console.warn(`At3d/Pbm texture not matched. Use ends-guessing mode. ${e.texture} -> ${o}`)}isAbsoluteURL(o)||(o=pathJoin(n,o))}let s=new PBMMeshMaterial(t?`phong`:`basic`);s.floorIndex=y,C.attributes.normal===void 0&&(s.flatShading=!0),C.attributes._feature_id_rsmask&&(s.defines.USE_VERTEX_MARK=!0),w.push(s),o?(h++,p[o]?p[o].push(s):p[o]=[s]):s.color=new three.Color(16777215),m.add(s)}let T=new PBMMesh(C,w);T.name=`model_floor_`+y,T.userData.createAt=e,T.userData.description=o,T.matrix.compose(T.position,T.quaternion,T.scale),T.matrixAutoUpdate=!1,T.frustumCulled=!1,u=e,d=o,f.push(T)}o=autoRestImageOptionsByTextureLength(o,h);let g=[];for(let e of Object.keys(p)){let t;s&&(t=s.get(e)),t||(t=loadTexture$1(e,o,c),s&&s.set(e,t)),g.push(t.then(t=>{for(let n of p[e])n.map&&(m.delete(n.map),n.map.dispose()),n.map=t,m.add(t);return t}).catch(()=>{for(let t of p[e])t.map&&(m.delete(t.map),t.map.dispose()),t.map=null,t.color=new three.Color(16777215);return null}))}return Promise.all(g).then(e=>{let t=e.filter(e=>e instanceof three.Texture);return{createAt:u,description:d,objects:f,textures:t,dispose:()=>{m.forEach(e=>{e.dispose()}),m.clear()}}})}function autoRestImageOptionsByTextureLength(e,t){return e=Object.assign({},e),e.autoResize!==!1&&(t>96?e.size=Math.min(e.size||1/0,100):t>48?e.size=Math.min(e.size||1/0,200):t>24?e.size=Math.min(e.size||1/0,400):t>22?e.size=Math.min(e.size||1/0,800):t>5&&(e.size=Math.min(e.size||1/0,1024))),e}function createLZMA(){var e={};return e.OutWindow=function(){this._windowSize=0},e.OutWindow.prototype.create=function(e){(!this._buffer||this._windowSize!==e)&&(this._buffer=[]),this._windowSize=e,this._pos=0,this._streamPos=0},e.OutWindow.prototype.flush=function(){var e=this._pos-this._streamPos;if(e!==0){for(;e--;)this._stream.writeByte(this._buffer[this._streamPos++]);this._pos>=this._windowSize&&(this._pos=0),this._streamPos=this._pos}},e.OutWindow.prototype.releaseStream=function(){this.flush(),this._stream=null},e.OutWindow.prototype.setStream=function(e){this.releaseStream(),this._stream=e},e.OutWindow.prototype.init=function(e){e||(this._streamPos=0,this._pos=0)},e.OutWindow.prototype.copyBlock=function(e,t){var n=this._pos-e-1;for(n<0&&(n+=this._windowSize);t--;)n>=this._windowSize&&(n=0),this._buffer[this._pos++]=this._buffer[n++],this._pos>=this._windowSize&&this.flush()},e.OutWindow.prototype.putByte=function(e){this._buffer[this._pos++]=e,this._pos>=this._windowSize&&this.flush()},e.OutWindow.prototype.getByte=function(e){var t=this._pos-e-1;return t<0&&(t+=this._windowSize),this._buffer[t]},e.RangeDecoder=function(){},e.RangeDecoder.prototype.setStream=function(e){this._stream=e},e.RangeDecoder.prototype.releaseStream=function(){this._stream=null},e.RangeDecoder.prototype.init=function(){var e=5;for(this._code=0,this._range=-1;e--;)this._code=this._code<<8|this._stream.readByte()},e.RangeDecoder.prototype.decodeDirectBits=function(e){for(var t=0,n=e,r;n--;)this._range>>>=1,r=this._code-this._range>>>31,this._code-=this._range&r-1,t=t<<1|1-r,this._range&4278190080||(this._code=this._code<<8|this._stream.readByte(),this._range<<=8);return t},e.RangeDecoder.prototype.decodeBit=function(e,t){var n=e[t],r=(this._range>>>11)*n;return(this._code^2147483648)<(r^2147483648)?(this._range=r,e[t]+=2048-n>>>5,this._range&4278190080||(this._code=this._code<<8|this._stream.readByte(),this._range<<=8),0):(this._range-=r,this._code-=r,e[t]-=n>>>5,this._range&4278190080||(this._code=this._code<<8|this._stream.readByte(),this._range<<=8),1)},e.initBitModels=function(e,t){for(;t--;)e[t]=1024},e.BitTreeDecoder=function(e){this._models=[],this._numBitLevels=e},e.BitTreeDecoder.prototype.init=function(){e.initBitModels(this._models,1<<this._numBitLevels)},e.BitTreeDecoder.prototype.decode=function(e){for(var t=1,n=this._numBitLevels;n--;)t=t<<1|e.decodeBit(this._models,t);return t-(1<<this._numBitLevels)},e.BitTreeDecoder.prototype.reverseDecode=function(e){for(var t=1,n=0,r=0,o;r<this._numBitLevels;++r)o=e.decodeBit(this._models,t),t=t<<1|o,n|=o<<r;return n},e.reverseDecode2=function(e,t,n,r){for(var o=1,s=0,c=0,l;c<r;++c)l=n.decodeBit(e,t+o),o=o<<1|l,s|=l<<c;return s},e.LenDecoder=function(){this._choice=[],this._lowCoder=[],this._midCoder=[],this._highCoder=new e.BitTreeDecoder(8),this._numPosStates=0},e.LenDecoder.prototype.create=function(t){for(;this._numPosStates<t;++this._numPosStates)this._lowCoder[this._numPosStates]=new e.BitTreeDecoder(3),this._midCoder[this._numPosStates]=new e.BitTreeDecoder(3)},e.LenDecoder.prototype.init=function(){var t=this._numPosStates;for(e.initBitModels(this._choice,2);t--;)this._lowCoder[t].init(),this._midCoder[t].init();this._highCoder.init()},e.LenDecoder.prototype.decode=function(e,t){return e.decodeBit(this._choice,0)===0?this._lowCoder[t].decode(e):e.decodeBit(this._choice,1)===0?8+this._midCoder[t].decode(e):16+this._highCoder.decode(e)},e.Decoder2=function(){this._decoders=[]},e.Decoder2.prototype.init=function(){e.initBitModels(this._decoders,768)},e.Decoder2.prototype.decodeNormal=function(e){var t=1;do t=t<<1|e.decodeBit(this._decoders,t);while(t<256);return t&255},e.Decoder2.prototype.decodeWithMatchByte=function(e,t){var n=1,r,o;do if(r=t>>7&1,t<<=1,o=e.decodeBit(this._decoders,(1+r<<8)+n),n=n<<1|o,r!==o){for(;n<256;)n=n<<1|e.decodeBit(this._decoders,n);break}while(n<256);return n&255},e.LiteralDecoder=function(){},e.LiteralDecoder.prototype.create=function(t,n){var r;if(!(this._coders&&this._numPrevBits===n&&this._numPosBits===t))for(this._numPosBits=t,this._posMask=(1<<t)-1,this._numPrevBits=n,this._coders=[],r=1<<this._numPrevBits+this._numPosBits;r--;)this._coders[r]=new e.Decoder2},e.LiteralDecoder.prototype.init=function(){for(var e=1<<this._numPrevBits+this._numPosBits;e--;)this._coders[e].init()},e.LiteralDecoder.prototype.getDecoder=function(e,t){return this._coders[((e&this._posMask)<<this._numPrevBits)+((t&255)>>>8-this._numPrevBits)]},e.Decoder=function(){this._outWindow=new e.OutWindow,this._rangeDecoder=new e.RangeDecoder,this._isMatchDecoders=[],this._isRepDecoders=[],this._isRepG0Decoders=[],this._isRepG1Decoders=[],this._isRepG2Decoders=[],this._isRep0LongDecoders=[],this._posSlotDecoder=[],this._posDecoders=[],this._posAlignDecoder=new e.BitTreeDecoder(4),this._lenDecoder=new e.LenDecoder,this._repLenDecoder=new e.LenDecoder,this._literalDecoder=new e.LiteralDecoder,this._dictionarySize=-1,this._dictionarySizeCheck=-1,this._posSlotDecoder[0]=new e.BitTreeDecoder(6),this._posSlotDecoder[1]=new e.BitTreeDecoder(6),this._posSlotDecoder[2]=new e.BitTreeDecoder(6),this._posSlotDecoder[3]=new e.BitTreeDecoder(6)},e.Decoder.prototype.setDictionarySize=function(e){return e<0?!1:(this._dictionarySize!==e&&(this._dictionarySize=e,this._dictionarySizeCheck=Math.max(this._dictionarySize,1),this._outWindow.create(Math.max(this._dictionarySizeCheck,4096))),!0)},e.Decoder.prototype.setLcLpPb=function(e,t,n){var r=1<<n;return e>8||t>4||n>4?!1:(this._literalDecoder.create(t,e),this._lenDecoder.create(r),this._repLenDecoder.create(r),this._posStateMask=r-1,!0)},e.Decoder.prototype.init=function(){var t=4;for(this._outWindow.init(!1),e.initBitModels(this._isMatchDecoders,192),e.initBitModels(this._isRep0LongDecoders,192),e.initBitModels(this._isRepDecoders,12),e.initBitModels(this._isRepG0Decoders,12),e.initBitModels(this._isRepG1Decoders,12),e.initBitModels(this._isRepG2Decoders,12),e.initBitModels(this._posDecoders,114),this._literalDecoder.init();t--;)this._posSlotDecoder[t].init();this._lenDecoder.init(),this._repLenDecoder.init(),this._posAlignDecoder.init(),this._rangeDecoder.init()},e.Decoder.prototype.decode=function(t,n,r){var o=0,s=0,c=0,l=0,u=0,d=0,f=0,p,m,h,g,_,v;for(this._rangeDecoder.setStream(t),this._outWindow.setStream(n),this.init();r<0||d<r;)if(p=d&this._posStateMask,this._rangeDecoder.decodeBit(this._isMatchDecoders,(o<<4)+p)===0)m=this._literalDecoder.getDecoder(d++,f),f=o>=7?m.decodeWithMatchByte(this._rangeDecoder,this._outWindow.getByte(s)):m.decodeNormal(this._rangeDecoder),this._outWindow.putByte(f),o=o<4?0:o-(o<10?3:6);else{if(this._rangeDecoder.decodeBit(this._isRepDecoders,o)===1)h=0,this._rangeDecoder.decodeBit(this._isRepG0Decoders,o)===0?this._rangeDecoder.decodeBit(this._isRep0LongDecoders,(o<<4)+p)===0&&(o=o<7?9:11,h=1):(this._rangeDecoder.decodeBit(this._isRepG1Decoders,o)===0?g=c:(this._rangeDecoder.decodeBit(this._isRepG2Decoders,o)===0?g=l:(g=u,u=l),l=c),c=s,s=g),h===0&&(h=2+this._repLenDecoder.decode(this._rangeDecoder,p),o=o<7?8:11);else if(u=l,l=c,c=s,h=2+this._lenDecoder.decode(this._rangeDecoder,p),o=o<7?7:10,_=this._posSlotDecoder[h<=5?h-2:3].decode(this._rangeDecoder),_>=4){if(v=(_>>1)-1,s=(2|_&1)<<v,_<14)s+=e.reverseDecode2(this._posDecoders,s-_-1,this._rangeDecoder,v);else if(s+=this._rangeDecoder.decodeDirectBits(v-4)<<4,s+=this._posAlignDecoder.reverseDecode(this._rangeDecoder),s<0){if(s===-1)break;return!1}}else s=_;if(s>=d||s>=this._dictionarySizeCheck)return!1;this._outWindow.copyBlock(s,h),d+=h,f=this._outWindow.getByte(0)}return this._outWindow.flush(),this._outWindow.releaseStream(),this._rangeDecoder.releaseStream(),!0},e.Decoder.prototype.setDecoderProperties=function(e){var t,n,r,o,s;return e.size<5||(t=e.readByte(),n=t%9,t=~~(t/9),r=t%5,o=~~(t/5),!this.setLcLpPb(n,r,o))?!1:(s=e.readByte(),s|=e.readByte()<<8,s|=e.readByte()<<16,s+=e.readByte()*16777216,this.setDictionarySize(s))},e.decompress=function(t,n,r,o){var s=new e.Decoder;if(!s.setDecoderProperties(t))throw`Incorrect stream properties`;if(!s.decode(n,r,o))throw`Error in data stream`;return!0},e.decompressFile=function(t,n){var r=new e.Decoder,o;if(!r.setDecoderProperties(t))throw`Incorrect stream properties`;if(o=t.readByte(),o|=t.readByte()<<8,o|=t.readByte()<<16,o+=t.readByte()*16777216,t.readByte(),t.readByte(),t.readByte(),t.readByte(),!r.decode(t,n,o))throw`Error in data stream`;return!0},e}var LZMA=createLZMA();function createWASM(){function e(e){let t=`ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/`,n=new Uint8Array(256);for(let e=0;e<64;e++)n[`ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/`.charCodeAt(e)]=e;let r=e.length*.75,o=e.length,s,c=0,l,u,d,f;e[e.length-1]===`=`&&(r--,e[e.length-2]===`=`&&r--);let p=new ArrayBuffer(r),m=new Uint8Array(p);for(s=0;s<o;s+=4)l=n[e.charCodeAt(s)],u=n[e.charCodeAt(s+1)],d=n[e.charCodeAt(s+2)],f=n[e.charCodeAt(s+3)],m[c++]=l<<2|u>>4,m[c++]=(u&15)<<4|d>>2,m[c++]=(d&3)<<6|f&63;return p}return e(`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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`)}function decodeLZMA(e,t,n){try{let r={data:t,offset:0,readByte(){return this.data[this.offset++]}},o=r.data.length,s={data:[],offset:0,writeByte(e){let t=Math.floor(this.offset/o);this.data[t]||(this.data[t]=new Uint8Array(o)),this.data[t][this.offset%o]=e,this.offset++}};e.decompressFile(r,s);let c=new Uint8Array(s.offset);for(let e=0;e<s.offset;e++)c[e]=s.data[Math.floor(e/o)][e%o];n(null,c)}catch(e){n(e)}}function decodeLZMAWithWASM(e,t,n){let r=24;try{let r=new WebAssembly.Memory({initial:16}),o=new WebAssembly.Module(e),s=new WebAssembly.Instance(o,{env:{memory:r,abort(){n(Error(`webAssembly abort`))}}}).exports,c=s.newU8Array(t.length);new Uint8Array(r.buffer,c+24,t.length).set(t);let l=s.decode(c),u=new Uint32Array(r.buffer,l,4),d=u[0],f=u[2],p=u[3];d?n(null,new Uint8Array(r.buffer,p+24,f).slice(0,f)):n(Error(`lzma deocder error`))}catch(e){n(e)}}var lzmaWorkerSource=`
320
320
  var decodeLZMA = (function() {
321
321
  var LZMA = (${createLZMA.toString()})();
@@ -828,7 +828,7 @@ self.onmessage = function(event) {
828
828
 
829
829
  }
830
830
  `,EXTENSION_NAME$11=`KHR_texture_basisu`,KHR_texture_basisu=class extends BaseExtension{loadTexture(e,t){let n=t.json.textures[e];if(!n.extensions||!n.extensions[EXTENSION_NAME$11])return null;let r=n.extensions[EXTENSION_NAME$11],o=t.json.images[r.source],s=null;if(o.bufferView!==void 0)s=t.loadBufferView(o.bufferView).then(e=>ktx2.parse(e));else if(o.uri)s=t.options.fetcher.ajax(t.resolveResouce(o.uri),{responseType:`arraybuffer`}).then(e=>ktx2.parse(e.body));else throw Error(`glTF: Invalid image defs.`);let c=(t.json.samplers||{})[n.sampler]||{};return s=s.then(e=>(e.magFilter=three.LinearFilter,e.minFilter=three.LinearFilter,e.wrapS=WEBGL_WRAPPINGS[c.wrapS]||three.RepeatWrapping,e.wrapT=WEBGL_WRAPPINGS[c.wrapT]||three.RepeatWrapping,e)),s}},EXTENSION_NAME$10=`KHR_texture_transform`,KHR_texture_transform=class extends BaseExtension{extendTexture(e,t,n){let r=t.extensions===void 0?void 0:t.extensions[EXTENSION_NAME$10];return r?(r.texCoord!==void 0&&console.warn(`glTF: Custom UV sets in "`+EXTENSION_NAME$10+`" extension not yet supported.`),r.offset===void 0&&r.rotation===void 0&&r.scale===void 0?e:(e=e.clone(),e.needsUpdate=!0,r.offset!==void 0&&e.offset.fromArray(r.offset),r.rotation!==void 0&&(e.rotation=r.rotation),r.scale!==void 0&&e.repeat.fromArray(r.scale),e)):null}},KHR_mesh_quantization=class extends BaseExtension{},EXTENSION_NAME$9=`KHR_materials_unlit`,KHR_materials_unlit=class extends BaseExtension{extendMaterial(e,t,n){var r;return t.material!==void 0&&e instanceof PBMMeshMaterial&&((r=n.json.materials[t.material].extensions)==null?{}:r)[EXTENSION_NAME$9]&&(e.shaderType=`basic`),Promise.all([]).then(noop)}},EXTENSION_NAME$8=`KHR_node_visibility`,KHR_node_visibility=class extends BaseExtension{extendNode(e,t,n){var r;let o=[],s=(r=t.extensions)==null?{}:r;if(s[EXTENSION_NAME$8]){let t=s[EXTENSION_NAME$8];typeof t.visible==`boolean`&&(e.visible=t.visible)}return Promise.all(o).then(noop)}},KHR_animation_pointer=class extends BaseExtension{},EXTENSION_NAME$7=`KHR_materials_clearcoat`,KHR_materials_clearcoat=class extends BaseExtension{extendMaterial(e,t,n){var r;let o=[];if(t.material!==void 0&&(e instanceof PBMMeshMaterial||e instanceof three.MeshPhysicalMaterial)){let s=(r=n.json.materials[t.material].extensions)==null?{}:r;if(s[EXTENSION_NAME$7]){let t=s[EXTENSION_NAME$7];if(t.clearcoatFactor!==void 0&&(e.clearcoat=t.clearcoatFactor),t.clearcoatTexture!==void 0&&o.push(n.createMaterialTexture(t.clearcoatTexture).then(t=>{t.format=three.RGBFormat,e.clearcoatMap=t,n.disposeSet.add(t)})),t.clearcoatRoughnessFactor!==void 0&&(e.clearcoatRoughness=t.clearcoatRoughnessFactor),t.clearcoatRoughnessTexture!==void 0&&o.push(n.createMaterialTexture(t.clearcoatRoughnessTexture).then(t=>{t.format=three.RGBFormat,e.clearcoatRoughnessMap=t,n.disposeSet.add(t)})),t.clearcoatNormalTexture!==void 0&&(o.push(n.createMaterialTexture(t.clearcoatNormalTexture).then(t=>{t.format=three.RGBFormat,e.clearcoatNormalMap=t,n.disposeSet.add(t)})),t.clearcoatNormalTexture.scale!==void 0)){let n=t.clearcoatNormalTexture.scale;e.clearcoatNormalScale=new three.Vector2(n,n)}}}return Promise.all(o).then(noop)}},EXTENSION_NAME$6=`KHR_materials_sheen`,KHR_materials_sheen=class extends BaseExtension{extendMaterial(e,t,n){var r;let o=[];if(t.material!==void 0&&(e instanceof PBMMeshMaterial||e instanceof three.MeshPhysicalMaterial)){let o=(r=n.json.materials[t.material].extensions)==null?{}:r;if(o[EXTENSION_NAME$6]){let t=o[EXTENSION_NAME$6];if(t.sheenColorFactor!==void 0){let n=t.sheenColorFactor;e.sheen=new three.Color().setRGB(n[0],n[1],n[2])}t.sheenRoughnessFactor!==void 0&&console.warn(`glTF: ${EXTENSION_NAME$6} sheenRoughnessFactor unsupported`),t.sheenColorTexture!==void 0&&console.warn(`glTF: ${EXTENSION_NAME$6} sheenColorTexture unsupported`),t.sheenRoughnessTexture!==void 0&&console.warn(`glTF: ${EXTENSION_NAME$6} sheenRoughnessTexture unsupported`)}}return Promise.all(o).then(noop)}},EXTENSION_NAME$5=`KHR_materials_transmission`,KHR_materials_transmission=class extends BaseExtension{extendMaterial(e,t,n){var r;let o=[];if(t.material!==void 0&&(e instanceof PBMMeshMaterial||e instanceof three.MeshPhysicalMaterial)){let o=(r=n.json.materials[t.material].extensions)==null?{}:r;if(o[EXTENSION_NAME$5]){let t=o.KHR_materials_transmission;t.transmissionFactor!==void 0&&(e.transparency=t.transmissionFactor,e.transparency>0&&(e.transparent=!0)),t.transmissionTexture!==void 0&&console.warn(`glTF: ${EXTENSION_NAME$5} transmissionTexture unsupported`)}}return Promise.all(o).then(noop)}},EXTENSION_NAME$4=`KHR_materials_emissive_strength`,KHR_materials_emissive_strength=class extends BaseExtension{extendMaterial(e,t,n){var r;let o=[];if(t.material!==void 0&&(e instanceof PBMMeshMaterial||e instanceof three.MeshStandardMaterial)){let o=(r=n.json.materials[t.material].extensions)==null?{}:r;if(o[EXTENSION_NAME$4]){let t=o[EXTENSION_NAME$4];t.emissiveStrength!==void 0&&(e.emissiveIntensity=t.emissiveStrength)}}return Promise.all(o).then(noop)}},meshoptDecoder=(function(){"use strict";var e=`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`,n=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 o=WebAssembly.validate(n)?t:e,s,c=WebAssembly.instantiate(l(o),{}).then(function(e){s=e.instance,s.exports.__wasm_call_ctors()});function l(e){for(var t=new Uint8Array(e.length),n=0;n<e.length;++n){var o=e.charCodeAt(n);t[n]=o>96?o-97:o>64?o-39:o+4}for(var s=0,n=0;n<e.length;++n)t[s++]=t[n]<60?r[t[n]]:(t[n]-60)*64+t[++n];return t.buffer.slice(0,s)}function u(e,t,n,r,o,c){var l=s.exports.sbrk,u=n+3&-4,d=l(u*r),f=l(o.length),p=new Uint8Array(s.exports.memory.buffer);p.set(o,f);var m=e(d,n,r,f,o.length);if(m==0&&c&&c(d,u,r),t.set(p.subarray(d,d+n*r)),l(d-l(0)),m!=0)throw Error(`Malformed buffer data: `+m)}var d={NONE:``,OCTAHEDRAL:`meshopt_decodeFilterOct`,QUATERNION:`meshopt_decodeFilterQuat`,EXPONENTIAL:`meshopt_decodeFilterExp`},f={ATTRIBUTES:`meshopt_decodeVertexBuffer`,TRIANGLES:`meshopt_decodeIndexBuffer`,INDICES:`meshopt_decodeIndexSequence`},p=[],m=0;function h(e){var t={object:new Worker(e),pending:0,requests:{}};return t.object.onmessage=function(e){var n=e.data;t.pending-=n.count,t.requests[n.id][n.action](n.value),delete t.requests[n.id]},t}function g(e){for(var t=`var instance; var ready = WebAssembly.instantiate(new Uint8Array([`+new Uint8Array(l(o))+`]), {}).then(function(result) { instance = result.instance; instance.exports.__wasm_call_ctors(); });self.onmessage = workerProcess;`+u.toString()+v.toString(),n=new Blob([t],{type:`text/javascript`}),r=URL.createObjectURL(n),s=0;s<e;++s)p[s]=h(r);URL.revokeObjectURL(r)}function _(e,t,n,r,o){for(var s=p[0],c=1;c<p.length;++c)p[c].pending<s.pending&&(s=p[c]);return new Promise(function(c,l){var u=new Uint8Array(n),d=m++;s.pending+=e,s.requests[d]={resolve:c,reject:l},s.object.postMessage({id:d,count:e,size:t,source:u,mode:r,filter:o},[u.buffer])})}function v(e){c.then(function(){var t=e.data;try{var n=new Uint8Array(t.count*t.size);u(s.exports[t.mode],n,t.count,t.size,t.source,s.exports[t.filter]),self.postMessage({id:t.id,count:t.count,action:`resolve`,value:n},[n.buffer])}catch(e){self.postMessage({id:t.id,count:t.count,action:`reject`,value:e})}})}return{ready:c,supported:!0,useWorkers:function(e){g(e)},decodeVertexBuffer:function(e,t,n,r,o){u(s.exports.meshopt_decodeVertexBuffer,e,t,n,r,s.exports[d[o]])},decodeIndexBuffer:function(e,t,n,r){u(s.exports.meshopt_decodeIndexBuffer,e,t,n,r)},decodeIndexSequence:function(e,t,n,r){u(s.exports.meshopt_decodeIndexSequence,e,t,n,r)},decodeGltfBuffer:function(e,t,n,r,o,c){u(s.exports[f[o]],e,t,n,r,s.exports[d[c]])},decodeGltfBufferAsync:function(e,t,n,r,o){return p.length>0?_(e,t,n,f[r],d[o]):c.then(function(){var c=new Uint8Array(e*t);return u(s.exports[f[r]],c,e,t,n,s.exports[d[o]]),c})}}})(),EXTENSION_NAME$3=`EXT_meshopt_compression`,EXT_meshopt_compression=class extends BaseExtension{loadBufferView(e,t){let n=t.json,r=n.bufferViews[e];if(r.extensions&&r.extensions[EXTENSION_NAME$3]){let e=r.extensions[EXTENSION_NAME$3],o=t.loadBuffer(e.buffer);if(!meshoptDecoder.supported){if(n.extensionsRequired&&n.extensionsRequired.indexOf(EXTENSION_NAME$3)>=0)throw Error(`THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files`);return null}return Promise.all([o,meshoptDecoder.ready]).then(([t])=>{let n=e.byteOffset||0,r=e.byteLength||0,o=e.count,s=e.byteStride,c=new ArrayBuffer(o*s),l=new Uint8Array(t,n,r);return meshoptDecoder.decodeGltfBuffer(new Uint8Array(c),o,s,l,e.mode,e.filter),c})}else return null}},EXTENSION_NAME$2=`EXT_texture_webp`,EXT_texture_webp=class extends BaseExtension{constructor(){super(...arguments),this.supportsWep=!1}prepare(e){return imageSupport().then(e=>{this.supportsWep=e.webp})}loadTexture(e,t){let n=t.json.textures[e];if(!n.extensions||!n.extensions[EXTENSION_NAME$2]||!this.supportsWep)return null;let r=n.extensions[EXTENSION_NAME$2];return t.loadImage(r.source).then(e=>{let r=new three.Texture(e);r.needsUpdate=!0,r.flipY=!1,n.name&&(r.name=n.name);let o=(t.json.samplers||{})[n.sampler]||{};return r.magFilter=WEBGL_FILTERS[o.magFilter]||three.LinearFilter,r.minFilter=WEBGL_FILTERS[o.minFilter]||three.LinearMipmapLinearFilter,r.wrapS=WEBGL_WRAPPINGS[o.wrapS]||three.RepeatWrapping,r.wrapT=WEBGL_WRAPPINGS[o.wrapT]||three.RepeatWrapping,r.onUpdate=function(){e.close()},r})}},EXTENSION_NAME$1=`CESIUM_RTC`,CESIUM_RTC=class extends BaseExtension{emitResult(e,t){if(t.json.extensions[EXTENSION_NAME$1]&&t.json.extensions[EXTENSION_NAME$1].center){let n=t.json.extensions[EXTENSION_NAME$1].center;e.CESIUM_RTC={center:new three.Vector3().fromArray(n)}}}},EXTENSION_NAME=`REALSEE_materials_lightmap`,REALSEE_materials_lightmap=class extends BaseExtension{extendMaterial(e,t,n){let r=[];if(n.json.materials&&t.material!==void 0){let o=n.json.materials[t.material].extensions[EXTENSION_NAME];o&&(o.lightMapTexture!==void 0&&r.push(n.createMaterialTexture(o.lightMapTexture).then(t=>{e.lightMap=t})),o.lightMapIntensity!==void 0&&(e.lightMapIntensity=o.lightMapIntensity))}return Promise.all(r).then(()=>{})}};function __awaiter(e,t,n,r){function o(e){return e instanceof n?e:new n(function(t){t(e)})}return new(n||(n=Promise))(function(n,s){function c(e){try{u(r.next(e))}catch(e){s(e)}}function l(e){try{u(r.throw(e))}catch(e){s(e)}}function u(e){e.done?n(e.value):o(e.value).then(c,l)}u((r=r.apply(e,t||[])).next())})}var f32buffer=new Float32Array(1),u32buffer=new Uint32Array(f32buffer.buffer),supportsFloat16Array=typeof Float16Array<`u`,f16buffer=supportsFloat16Array?new Float16Array(1):null,u16buffer=supportsFloat16Array?new Uint16Array(f16buffer.buffer):new Uint16Array(1);function fromHalf(e){if(supportsFloat16Array&&f16buffer)return u16buffer[0]=e,f16buffer[0];let t=e>>15&1,n=e>>10&31,r=e&1023,o;if(n===0)if(r===0)o=t<<31;else{let e=r,n=-14;for(;!(e&1024);)e<<=1,n--;e&=1023;let s=n+127,c=e<<13;o=t<<31|s<<23|c}else if(n===31)o=r===0?t<<31|2139095040:t<<31|2143289344;else{let e=n-15+127,s=r<<13;o=t<<31|e<<23|s}return u32buffer[0]=o,f32buffer[0]}var GunzipReader=class{constructor({fileBytes:e}){this.fileBytes=e,this.chunks=[],this.totalBytes=0;let t=new DecompressionStream(`gzip`);this.reader=new Blob([e]).stream().pipeThrough(t).getReader()}read(e){return __awaiter(this,void 0,void 0,function*(){for(;this.totalBytes<e;){let{value:e,done:t}=yield this.reader.read();if(t)break;this.chunks.push(e),this.totalBytes+=e.length}if(this.totalBytes<e)throw Error(`Unexpected EOF: needed ${e}, got ${this.totalBytes}`);let t=new Uint8Array(this.totalBytes),n=0;for(let e of this.chunks)t.set(e,n),n+=e.length;let r=t.subarray(0,e);return this.chunks=[t.subarray(e)],this.totalBytes-=e,r})}},SH_C0=.28209479177387814,SpzReader=class{constructor({fileBytes:e}){this.version=-1,this.numSplats=0,this.shDegree=0,this.fractionalBits=0,this.flags=0,this.flagAntiAlias=!1,this.reserved=0,this.headerParsed=!1,this.parsed=!1,this.fileBytes=e instanceof ArrayBuffer?new Uint8Array(e):e,this.reader=new GunzipReader({fileBytes:this.fileBytes})}parseHeader(){return __awaiter(this,void 0,void 0,function*(){if(this.headerParsed)throw Error(`SPZ file header already parsed`);let e=new DataView((yield this.reader.read(16)).buffer);if(e.getUint32(0,!0)!==1347635022)throw Error(`Invalid SPZ file`);if(this.version=e.getUint32(4,!0),this.version<1||this.version>3)throw Error(`Unsupported SPZ version: ${this.version}`);this.numSplats=e.getUint32(8,!0),this.shDegree=e.getUint8(12),this.fractionalBits=e.getUint8(13),this.flags=e.getUint8(14),this.flagAntiAlias=(this.flags&1)!=0,this.reserved=e.getUint8(15),this.headerParsed=!0,this.parsed=!1})}parseSplats(e,t,n,r,o,s){return __awaiter(this,void 0,void 0,function*(){if(!this.headerParsed)throw Error(`SPZ file header must be parsed first`);if(this.parsed)throw Error(`SPZ file already parsed`);if(this.parsed=!0,this.version===1){let t=yield this.reader.read(this.numSplats*3*2),n=new Uint16Array(t.buffer);for(let t=0;t<this.numSplats;t++){let r=t*3,o=fromHalf(n[r]),s=fromHalf(n[r+1]),c=fromHalf(n[r+2]);e==null||e(t,o,s,c)}}else if(this.version===2||this.version===3){let t=1<<this.fractionalBits,n=yield this.reader.read(this.numSplats*3*3);for(let r=0;r<this.numSplats;r++){let o=r*9,s=((n[o+2]<<24|n[o+1]<<16|n[o]<<8)>>8)/t,c=((n[o+5]<<24|n[o+4]<<16|n[o+3]<<8)>>8)/t,l=((n[o+8]<<24|n[o+7]<<16|n[o+6]<<8)>>8)/t;e==null||e(r,s,c,l)}}{let e=yield this.reader.read(this.numSplats);for(let n=0;n<this.numSplats;n++)t==null||t(n,e[n]/255)}{let e=yield this.reader.read(this.numSplats*3),t=SH_C0/.15;for(let r=0;r<this.numSplats;r++){let o=r*3,s=(e[o]/255-.5)*t+.5,c=(e[o+1]/255-.5)*t+.5,l=(e[o+2]/255-.5)*t+.5;n==null||n(r,s,c,l)}}{let e=yield this.reader.read(this.numSplats*3);for(let t=0;t<this.numSplats;t++){let n=t*3,o=Math.exp(e[n]/16-10),s=Math.exp(e[n+1]/16-10),c=Math.exp(e[n+2]/16-10);r==null||r(t,o,s,c)}}if(this.version===3){let e=1/Math.sqrt(2),t=yield this.reader.read(this.numSplats*4);for(let n=0;n<this.numSplats;n++){let r=n*4,s=[0,0,0,0],c=[t[r],t[r+1],t[r+2],t[r+3]],l=c[0]+(c[1]<<8)+(c[2]<<16)+(c[3]<<24),u=511,d=l>>>30,f=l,p=0;for(let t=3;t>=0;--t)if(t!==d){let n=f&511,r=f>>>9&1;f>>>=10,s[t]=n/511*e,s[t]=r===0?s[t]:-s[t],p+=s[t]*s[t]}let m=1-p;s[d]=Math.sqrt(Math.max(m,0)),o==null||o(n,s[0],s[1],s[2],s[3])}}else{let e=yield this.reader.read(this.numSplats*3);for(let t=0;t<this.numSplats;t++){let n=t*3,r=e[n]/127.5-1,s=e[n+1]/127.5-1,c=e[n+2]/127.5-1,l=Math.sqrt(Math.max(0,1-r*r-s*s-c*c));o==null||o(t,r,s,c,l)}}if(s&&this.shDegree>=1){let e={1:3,2:8,3:15}[this.shDegree]||0,t=yield this.reader.read(this.numSplats*e*3),n=new Float32Array(9),r=this.shDegree>=2?new Float32Array(15):void 0,o=this.shDegree>=3?new Float32Array(21):void 0,c=0;for(let e=0;e<this.numSplats;e++){for(let e=0;e<9;++e)n[e]=(t[c+e]-128)/128;if(c+=9,r){for(let e=0;e<15;++e)r[e]=(t[c+e]-128)/128;c+=15}if(o){for(let e=0;e<21;++e)o[e]=(t[c+e]-128)/128;c+=21}s==null||s(e,new Float32Array(n),r?new Float32Array(r):void 0,o?new Float32Array(o):void 0)}}})}};function parseSpz(e){return __awaiter(this,void 0,void 0,function*(){let t=new SpzReader({fileBytes:e});yield t.parseHeader();let n=t.numSplats,r=new Float32Array(n*3),o=new Uint8Array(n*4),s=new Float32Array(n*3),c=new Float32Array(n*4),l,u,d;return t.shDegree>=1&&(l=new Float32Array(n*9)),t.shDegree>=2&&(u=new Float32Array(n*15)),t.shDegree>=3&&(d=new Float32Array(n*21)),yield t.parseSplats((e,t,n,o)=>{r[e*3]=t,r[e*3+1]=n,r[e*3+2]=o},(e,t)=>{o[e*4+3]=Math.round(t*255)},(e,t,n,r)=>{o[e*4]=Math.round(Math.max(0,Math.min(1,t))*255),o[e*4+1]=Math.round(Math.max(0,Math.min(1,n))*255),o[e*4+2]=Math.round(Math.max(0,Math.min(1,r))*255)},(e,t,n,r)=>{s[e*3]=t,s[e*3+1]=n,s[e*3+2]=r},(e,t,n,r,o)=>{c[e*4]=o,c[e*4+1]=t,c[e*4+2]=n,c[e*4+3]=r},(e,t,n,r)=>{l&&t&&l.set(t,e*9),u&&n&&u.set(n,e*15),d&&r&&d.set(r,e*21)}),new PBMGaussianSplattingObject({numPoints:n,positions:r,colors:o,scales:s,rotations:c,sh1:l,sh2:u,sh3:d,shDegree:t.shDegree})})}function loadSpz(e,t={}){var n,r,o,s;let c=(n=t.modelUpAxis)==null?`Y`:n,l=(r=t.upAxis)==null?`Z`:r,u=(o=t.fetcher)==null?internalFetcher:o,d=(s=t.onDownloadProgress)==null?noop:s,f=0;return Promise.resolve().then(()=>u.ajax(e,{responseType:`arraybuffer`},void 0,void 0,d)).then(e=>(f=e.body.byteLength,e.body)).then(e=>parseSpz(new Uint8Array(e))).then(t=>(c===`Z`&&(t.applyMatrix4(ROTATE_X_MATRIX_INVERSE$1),t.updateMatrix(),t.updateMatrixWorld(!0),t.transformChanged=!0),{type:`spz`,modelUpAxis:c,upAxis:l,uri:e,byteLength:f,memoryUsage:getMemoryUsage(t),scene:t,textures:[],animations:[],dispose:()=>t.dispose()}))}var ROTATE_X_MATRIX=new three.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]),ROTATE_X_MATRIX_INVERSE=new three.Matrix4().getInverse(ROTATE_X_MATRIX),KHR_gaussian_splatting_compression_spz=class extends BaseExtension{constructor(){super(...arguments),this.name=`KHR_gaussian_splatting_compression_spz`,this.parentName=`KHR_gaussian_splatting`}loadMesh(e,t){let n=t.json.meshes[e].primitives;return n.length===0?null:(n.length===1||console.warn(`KHR_gaussian_splatting_compression_spz: multiple primitives are not supported`),this.loadSpz(n[0],t))}loadSpz(e,t){return __awaiter(this,void 0,void 0,function*(){let n=e.extensions[this.parentName].bufferView;return t.loadBufferView(n).then(e=>parseSpz(new Uint8Array(e))).then(e=>(e.applyMatrix4(ROTATE_X_MATRIX_INVERSE),e.updateMatrix(),e.updateMatrixWorld(!0),e.transformChanged=!0,e))})}},EXTENSIONS={KHR_binary_glTF,KHR_draco_mesh_compression,KHR_texture_basisu,KHR_texture_transform,KHR_mesh_quantization,KHR_materials_unlit,KHR_node_visibility,KHR_animation_pointer,KHR_materials_clearcoat,KHR_materials_sheen,KHR_materials_transmission,KHR_materials_emissive_strength,EXT_meshopt_compression,EXT_texture_webp,CESIUM_RTC,REALSEE_materials_lightmap,KHR_gaussian_splatting_compression_spz};function parseGltf(e,t){var n,r,o;let s={},c,l;if(typeof e==`string`)l=e;else if(EXTENSIONS.KHR_binary_glTF.getMagic(e)===EXTENSIONS.KHR_binary_glTF.HEADER_MAGIC){c=new EXTENSIONS.KHR_binary_glTF;try{c.loadGlbBinary(e)}catch(e){return Promise.reject(e)}s.KHR_binary_glTF=c,l=c.content}else l=decodeText(new Uint8Array(e));let u=JSON.parse(l);if(t.jsonModify&&(u=t.jsonModify(u)),u.asset===void 0||Number(u.asset.version[0])<2)return Promise.reject(Error(`glTF: Unsupported asset. glTF versions >=2.0 are supported.`));if(u.extensionsUsed){let e=u.extensionsRequired||[];for(var d=0;d<u.extensionsUsed.length;d++){let t=u.extensionsUsed[d];s[t]||(EXTENSIONS[t]?s[t]=new EXTENSIONS[t]:e.indexOf(t)>=0&&console.warn(`glTF: Unknown extension "`+t+`".`))}}return new Parser(u,s,{copyUV2:(n=t.copyUV2)==null?!1:n,resourcePath:(r=t.resourcePath)==null?``:r,search:(o=t.search)==null?``:o,fetcher:t.fetcher}).parse().then(e=>(c&&c.clear(),e))}function loadB3dm(e,t={}){var n,r,o,s;let c=(n=t.modelUpAxis)==null?`Y`:n,l=(r=t.upAxis)==null?`Z`:r,u=(o=t.fetcher)==null?internalFetcher:o,d=(s=t.onDownloadProgress)==null?noop:s,f={uri:e,gltfUpAxis:c};return Promise.resolve().then(()=>u.ajax(e,{responseType:`arraybuffer`},void 0,void 0,d).then(e=>e.body)).then(e=>Promise.resolve(0).then(t=>parseHeader$1(f,e,t)).then(t=>parseTable(f,e,t)).then(t=>parseGlTFArrayBuffer(f,e,t))).then(()=>{var n;return parseGltf(f.gltfArrayBuffer,{copyUV2:!1,resourcePath:e.slice(0,e.lastIndexOf(`/`)+1),search:(n=e.split(`?`)[1])==null?``:n,jsonModify(e){var n,r;if(t.light===!1){let t=`KHR_materials_unlit`;if(e.extensionsUsed=(n=e.extensionsUsed)==null?[]:n,e.extensionsUsed.indexOf(t)===-1&&e.extensionsUsed.push(t),e.materials)for(let n of e.materials)n.extensions=(r=n.extensions)==null?{}:r,n.extensions[t]={}}return e},fetcher:u}).then(e=>{let t=new three.Matrix4;c===`Y`&&t.premultiply(ROTATE_X_MATRIX$1);let n;if(f.rtcCenter?n=new three.Vector3().fromArray(f.rtcCenter):e.CESIUM_RTC&&(n=new three.Vector3().copy(e.CESIUM_RTC.center)),n){let e=new three.Matrix4().setPosition(n);t.premultiply(e)}return l===`Y`&&t.premultiply(ROTATE_X_MATRIX_INVERSE$1),e.scene.applyMatrix4(t),f.featureTableBinary=void 0,f.batchTableBinary=void 0,f.gltfArrayBuffer=void 0,{type:`b3dm`,modelUpAxis:c,upAxis:`Z`,uri:f.uri,byteLength:f.byteLength,memoryUsage:getMemoryUsage(e.scene),scene:e.scene,textures:e.textures,animations:[],rtcCenter:n,dispose:()=>e.dispose()}})})}var jsContent$3="(function(){function e(e){onmessage=t=>{Promise.resolve(t.data).then(t=>e(t)).then(({output:e,transfer:t})=>postMessage(e,t)).catch(e=>postMessage({$$error:e}))}}var t;(function(e){e[e.BYTE=5120]=`BYTE`,e[e.UNSIGNED_BYTE=5121]=`UNSIGNED_BYTE`,e[e.SHORT=5122]=`SHORT`,e[e.UNSIGNED_SHORT=5123]=`UNSIGNED_SHORT`,e[e.INT=5124]=`INT`,e[e.UNSIGNED_INT=5125]=`UNSIGNED_INT`,e[e.FLOAT=5126]=`FLOAT`,e[e.DOUBLE=5130]=`DOUBLE`})(t||={});let n={[t.DOUBLE]:Float64Array,[t.FLOAT]:Float32Array,[t.UNSIGNED_SHORT]:Uint16Array,[t.UNSIGNED_INT]:Uint32Array,[t.UNSIGNED_BYTE]:Uint8Array,[t.BYTE]:Int8Array,[t.SHORT]:Int16Array,[t.INT]:Int32Array},r={DOUBLE:t.DOUBLE,FLOAT:t.FLOAT,UNSIGNED_SHORT:t.UNSIGNED_SHORT,UNSIGNED_INT:t.UNSIGNED_INT,UNSIGNED_BYTE:t.UNSIGNED_BYTE,BYTE:t.BYTE,SHORT:t.SHORT,INT:t.INT};function i(e){let t=n[e];if(!t)throw Error(`Failed to convert GL type`);return t}function a(e){return i(e).BYTES_PER_ELEMENT}function o(e,t,n=0,r){let o=i(e);return n%a(e)===0?new o(t,n,r??(t.byteLength-n)/a(e)):new o(r?t.slice(n,n+r*a(e)):t.slice(n))}function s(e){let t=r[e];if(!t)throw Error(`Failed to convert GL type`);return t}var c=class{constructor(e,n){this.featuresLength=0,this.cachedTypedArrays={},this.json=e,this.buffer=n;let r=this.getGlobalProperty(`POINTS_LENGTH`,t.UNSIGNED_INT,1);r&&r.length&&(this.featuresLength=r[0])}getExtension(e){return this.json.extensions&&this.json.extensions[e]}hasProperty(e){return!!this.json[e]}getGlobalProperty(e,t,n){let r=this.json[e];return typeof r==`number`?new(i(t))([r]):Array.isArray(r)?new(i(t))(r):r&&Number.isFinite(r.byteOffset)?this.getTypedArrayFromBinary(e,t,n,1,r.byteOffset):null}getPropertyArray(e,t,n){let r=this.json[e];return r&&Number.isFinite(r.byteOffset)?(`componentType`in r&&(t=s(r.componentType)),this.getTypedArrayFromBinary(e,t,n,this.featuresLength,r.byteOffset)):this.getTypedArrayFromArray(e,t,r)}getProperty(e,t,n,r,i){if(!this.json[e])return null;let a=this.getPropertyArray(e,t,n);if(n===1)return i[0]=a[r],i;for(let e=0;e<n;++e)i[e]=a[n*r+e];return i}getTypedArrayFromBinary(e,t,n,r,i){let a=this.cachedTypedArrays,s=a[e];return s||(s=o(t,this.buffer.buffer,this.buffer.byteOffset+i,r*n),a[e]=s),s}getTypedArrayFromArray(e,t,n){let r=this.cachedTypedArrays,i=r[e];return i||(i=o(t,n),r[e]=i),i}};e(e=>Promise.resolve(e).then(e=>{let t=new c(e.featureTableJson,e.featureTableBinary),n=u(t),r=d(t),i=p(t),a=[];return n&&a.push(n.array.buffer),r&&a.push(r.array.buffer),i&&a.push(i.array.buffer),{output:{position:n,color:r,normal:i},transfer:a}}));let l=65535;function u(e){if(e.hasProperty(`POSITION`))return{array:e.getPropertyArray(`POSITION`,t.FLOAT,3),itemSize:3,normalized:!1};if(e.hasProperty(`POSITION_QUANTIZED`)){let n=e.getPropertyArray(`POSITION_QUANTIZED`,t.UNSIGNED_SHORT,3),r=e.getGlobalProperty(`QUANTIZED_VOLUME_SCALE`,t.FLOAT,3),i=e.getGlobalProperty(`QUANTIZED_VOLUME_OFFSET`,t.FLOAT,3);if(!r||!i)throw Error(`QUANTIZED_VOLUME_SCALE or QUANTIZED_VOLUME_OFFSET never found.`);let a=new Float32Array(n.length),o=n.length/3,s=r[0]/l,c=r[1]/l,u=r[2]/l,d=i[0],f=i[1],p=i[2];for(let e=0,t;e<o;e++)t=e*3,a[t]=n[t]*s+d,a[++t]=n[t]*c+f,a[++t]=n[t]*u+p;return{array:a,itemSize:3,normalized:!1}}return null}function d(e){if(e.hasProperty(`RGB`)){let n=e.getPropertyArray(`RGB`,t.UNSIGNED_BYTE,3),r=n.length/3,i=new Uint8Array(r*4);for(let e=0,t,a;e<r;e++)a=e*4,t=e*3,i[a]=n[t],i[++a]=n[++t],i[++a]=n[++t];return{array:i,itemSize:4,normalized:!0}}else if(e.hasProperty(`RGBA`))return{array:e.getPropertyArray(`RGBA`,t.UNSIGNED_BYTE,4),itemSize:4,normalized:!0};else if(e.hasProperty(`RGB565`)){let n=e.getPropertyArray(`RGB565`,t.UNSIGNED_SHORT,1),r=n.length,i=new Uint8Array(r*4);for(let e=0,t,a;e<r;e++)a=n[e],t=e*4,i[t]=(a>>11&31)<<3,i[++t]=(a>>5&63)<<2,i[++t]=(a&31)<<3;return{array:i,itemSize:4,normalized:!0}}return null}let f=2/255;function p(e){if(e.hasProperty(`NORMAL`)){let n=e.getPropertyArray(`NORMAL`,t.FLOAT,3),r=n.length/3,i=new Int8Array(r*4);for(let e=0,t,a;e<r;e++)a=e*4,t=e*3,i[a]=n[t]*127,i[++a]=n[++t]*127,i[++a]=n[++t]*127;return{array:i,itemSize:4,normalized:!0}}else if(e.hasProperty(`NORMAL_OCT16P`)){let n=e.getPropertyArray(`NORMAL_OCT16P`,t.UNSIGNED_BYTE,2),r=n.length/2,i=new Int8Array(r*4);for(let e=0,t,a,o,s,c,l,u;e<r;e++)t=e*2,a=n[t]*f-1,o=n[++t]*f-1,c=a<0?-a:a,l=o<0?-o:o,s=1-(c+l),s<0&&(a=(1-l)*(a<0?-1:1),o=(1-c)*(o<0?-1:1)),u=Math.sqrt(a*a+o*o+s*s),t=e*4,i[t]=a/u*127,i[++t]=o/u*127,i[++t]=s/u*127;return{array:i,itemSize:4,normalized:!0}}return null}})();",blob$3=typeof self<`u`&&self.Blob&&new Blob([`(self.URL || self.webkitURL).revokeObjectURL(self.location.href);`,jsContent$3],{type:`text/javascript;charset=utf-8`});function WorkerWrapper$3(e){let t;try{if(t=blob$3&&(self.URL||self.webkitURL).createObjectURL(blob$3),!t)throw``;let n=new Worker(t,{name:e==null?void 0:e.name});return n.addEventListener(`error`,()=>{(self.URL||self.webkitURL).revokeObjectURL(t)}),n}catch(t){return new Worker(`data:text/javascript;charset=utf-8,`+encodeURIComponent(jsContent$3),{name:e==null?void 0:e.name})}}var attributeWorkerPool=new WorkerPool(()=>new WorkerWrapper$3,2);function parsePointCloud(e,t,n){let r=new FeatureTable(e.featureTableJson,e.featureTableBinary);return Promise.resolve().then(()=>{let e=r.getExtension(`3DTILES_draco_point_compression`);return e?parseDraco(e,r):attributeWorkerPool.postMessage({featureTableBinary:r.buffer,featureTableJson:r.json},[r.buffer.buffer])}).then(t=>(e.attributes=t,n))}function parseDraco(e,t){return __awaiter(this,void 0,void 0,function*(){let n=e.properties||{},r=e.byteOffset,o=e.byteLength;if(!n||!Number.isFinite(r)||!o)throw Error(`Draco properties, byteOffset, and byteLength must be defined`);let s=t.buffer.slice(r,r+o),c=e.properties;return draco.decodeGeometry(s.buffer,{attributeIDs:c,attributeTypes:{POSITION:`Float32Array`,NORMAL:`Float32Array`,RGB:`Uint8Array`,RGBA:`Uint8Array`},useUniqueIDs:!0}).then(e=>{let t=e.getAttribute(`POSITION`),n=e.getAttribute(`RGB`),r=e.getAttribute(`RGBA`),o=e.getAttribute(`NORMAL`),s;if(r)s=r;else if(n){let e=n.count,t=n.array,r=new Uint8Array(e*4);for(let n=0,o,s;n<e;n++)s=n*4,o=n*3,r[s]=t[o],r[++s]=t[++o],r[++s]=t[++o];s=new three.BufferAttribute(r,4,n.normalized)}return{position:t?{array:t.array,itemSize:t.itemSize,normalized:t.normalized}:null,color:s?{array:s.array,itemSize:s.itemSize,normalized:s.normalized}:null,normal:o?{array:o.array,itemSize:o.itemSize,normalized:o.normalized}:null}})})}function loadPnts(e,t={}){var n,r,o;let s=(n=t.upAxis)==null?`Z`:n,c=(r=t.fetcher)==null?internalFetcher:r,l=(o=t.onDownloadProgress)==null?noop:o,u={uri:e};return Promise.resolve().then(()=>c.ajax(e,{responseType:`arraybuffer`},void 0,void 0,l).then(e=>e.body)).then(e=>Promise.resolve(0).then(t=>parseHeader$1(u,e,t)).then(t=>parseTable(u,e,t)).then(t=>parsePointCloud(u,e,t))).then(()=>{var e;return createPoints(u.attributes,{computeBoundingBox:(e=t.computeBoundingBox)==null?!0:e})}).then(e=>{let t=new three.Matrix4,n;if(u.rtcCenter&&(n=new three.Vector3().fromArray(u.rtcCenter)),n){let e=new three.Matrix4().setPosition(n);t.premultiply(e)}return s===`Y`&&t.premultiply(ROTATE_X_MATRIX_INVERSE$1),e.object.applyMatrix4(t),u.gltfArrayBuffer=void 0,u.featureTableBinary=void 0,u.batchTableBinary=void 0,{type:`pnts`,modelUpAxis:`Z`,upAxis:s,uri:u.uri,byteLength:u.byteLength,memoryUsage:getMemoryUsage(e.object),scene:e.object,textures:[],animations:[],rtcCenter:n,dispose:()=>e.dispose()}})}function createPoints(e,t){let n=new Set,r=new three.BufferGeometry;n.add(r);let o=new PBMPointCloudMaterial;n.add(o),e.position&&r.setAttribute(`position`,new three.BufferAttribute(e.position.array,e.position.itemSize,e.position.normalized)),e.color&&r.setAttribute(`color`,new three.BufferAttribute(e.color.array,e.color.itemSize,e.color.normalized)),e.normal?r.setAttribute(`normal`,new three.BufferAttribute(e.normal.array,e.normal.itemSize,e.normal.normalized)):o.flatShading=!0,t.computeBoundingBox&&r.computeBoundingBox();let s=new PBMPointCloud(r,o);return s.matrix.compose(s.position,s.quaternion,s.scale),s.matrixAutoUpdate=!1,s.frustumCulled=!1,Promise.resolve({object:s,dispose:()=>{n.forEach(e=>{e.dispose()}),n.clear()}})}function loadGltf(e,t={}){var n,r,o,s,c;let l=(n=t.modelUpAxis)==null?`Y`:n,u=(r=t.upAxis)==null?`Z`:r,d=(o=t.fetcher)==null?internalFetcher:o,f=(s=t.onDownloadProgress)==null?noop:s,p=(c=t.jsonModify)==null?noop:c,m=0;return Promise.resolve().then(()=>d.ajax(e,{responseType:`arraybuffer`},void 0,void 0,f).then(e=>(m=e.body.byteLength,e.body))).then(n=>{var r;return parseGltf(n,{copyUV2:!1,resourcePath:e.slice(0,e.lastIndexOf(`/`)+1),search:(r=e.split(`?`)[1])==null?``:r,jsonModify(e){var n,r,o;if(t.light===!1){let t=`KHR_materials_unlit`;if(e.extensionsUsed=(n=e.extensionsUsed)==null?[]:n,e.extensionsUsed.indexOf(t)===-1&&e.extensionsUsed.push(t),e.materials)for(let n of e.materials)n.extensions=(r=n.extensions)==null?{}:r,n.extensions[t]={}}return(o=p(e))==null?e:o},fetcher:d})}).then(t=>{var n;let r=new three.Matrix4;if(l===`Y`&&r.premultiply(ROTATE_X_MATRIX$1),t.CESIUM_RTC){let e=new three.Matrix4().setPosition(t.CESIUM_RTC.center);r.premultiply(e)}return u===`Y`&&r.premultiply(ROTATE_X_MATRIX_INVERSE$1),t.scene.applyMatrix4(r),{type:`gltf`,modelUpAxis:l,upAxis:u,uri:e,byteLength:m,memoryUsage:getMemoryUsage(t.scene),scene:t.scene,textures:t.textures,animations:t.animations,rtcCenter:(n=t.CESIUM_RTC)==null?void 0:n.center,dispose:()=>t.dispose()}})}var scratchColor=new three.Color;function loadPly(e,t={}){var n,r,o,s;let c=(n=t.modelUpAxis)==null?`Z`:n,l=(r=t.upAxis)==null?`Z`:r,u=(o=t.fetcher)==null?internalFetcher:o,d=(s=t.onDownloadProgress)==null?noop:s,f=0;return Promise.resolve().then(()=>u.ajax(e,{responseType:`arraybuffer`},void 0,void 0,d).then(e=>(f=e.body.byteLength,e.body))).then(e=>{var n,r;return parsePly(e,{propertyNameMapping:(n=t.propertyNameMapping)==null?{}:n,customPropertyMapping:(r=t.customPropertyMapping)==null?{}:r})}).then(({geometry:n})=>{switch(t.type){case`geometry`:{let t=n;return c===`Y`&&t.applyMatrix4(ROTATE_X_MATRIX$1),l===`Y`&&t.applyMatrix4(ROTATE_X_MATRIX_INVERSE$1),{type:`ply`,modelUpAxis:c,upAxis:l,uri:e,byteLength:f,memoryUsage:getGeometryMemoryUsed(t),scene:t,textures:[],animations:[],dispose:()=>{n.dispose()}}}case`line`:{let t=`color`in n.attributes,r=new three.LineBasicMaterial({vertexColors:t}),o=new three.Line(n,r);return o.computeLineDistances(),c===`Y`&&o.applyMatrix4(ROTATE_X_MATRIX$1),l===`Y`&&o.applyMatrix4(ROTATE_X_MATRIX_INVERSE$1),{type:`ply`,modelUpAxis:c,upAxis:l,uri:e,byteLength:f,memoryUsage:getMemoryUsage(o),scene:o,textures:[],animations:[],dispose:()=>{n.dispose(),r.dispose()}}}case`pbmMesh`:{let r=new PBMMeshMaterial(t.light?`phong`:`basic`);r.vertexColors=`color`in n.attributes;let o=new three.Mesh(n,r);return c===`Y`&&o.applyMatrix4(ROTATE_X_MATRIX$1),l===`Y`&&o.applyMatrix4(ROTATE_X_MATRIX_INVERSE$1),{type:`ply`,modelUpAxis:c,upAxis:l,uri:e,byteLength:f,memoryUsage:getMemoryUsage(o),scene:o,textures:[],animations:[],dispose:()=>{n.dispose(),r.dispose()}}}case`pbmPointCloud`:{let t=new PBMPointCloudMaterial,r=new PBMPointCloud(n,t);return c===`Y`&&r.applyMatrix4(ROTATE_X_MATRIX$1),l===`Y`&&r.applyMatrix4(ROTATE_X_MATRIX_INVERSE$1),{type:`ply`,modelUpAxis:c,upAxis:l,uri:e,byteLength:f,memoryUsage:getMemoryUsage(r),scene:r,textures:[],animations:[],dispose:()=>{n.dispose(),t.dispose()}}}default:break}throw Error(`Invalid Type: ${t.type}`)})}function parsePly(e,t){let n=new Uint8Array(e),{headerText:r,headerLength:o}=extractHeaderText(n),s=parseHeader(r,o,t);return s.format===`ascii`?{header:s,geometry:parseASCII(new TextDecoder().decode(n),s,t)}:{header:s,geometry:parseBinary(e,s,t)}}function makePlyElementProperty(e,t){let n={name:``,type:e[0]};return n.type===`list`?(n.name=e[3],n.countType=e[1],n.itemType=e[2]):n.name=e[1],n.name in t.propertyNameMapping&&(n.name=t.propertyNameMapping[n.name]),n}function parseHeader(e,t=0,n){let r=/^ply([\s\S]*)end_header(\r\n|\r|\n)/,o=``,s=r.exec(e);s!==null&&(o=s[1]);let c={format:``,version:``,comments:[],elements:[],headerLength:t,objInfo:``},l=o.split(/\r\n|\r|\n/),u=null;for(let e=0;e<l.length;e++){let t=l[e];if(t=t.trim(),t===``)continue;let r=t.split(/\s+/),o=r.shift();switch(t=r.join(` `),o){case`format`:c.format=r[0],c.version=r[1];break;case`comment`:c.comments.push(t);break;case`element`:u&&c.elements.push(u),u={name:r[0],count:parseInt(r[1]),properties:[]};break;case`property`:u&&u.properties.push(makePlyElementProperty(r,n));break;case`obj_info`:c.objInfo=t;break;default:console.log(`unhandled`,o,r)}}return u&&c.elements.push(u),c}function parseASCIINumber(e,t){switch(t){case`char`:case`uchar`:case`short`:case`ushort`:case`int`:case`uint`:case`int8`:case`uint8`:case`int16`:case`uint16`:case`int32`:case`uint32`:return parseInt(e);case`float`:case`double`:case`float32`:case`float64`:return parseFloat(e);default:throw Error(`unspport type: `+t)}}function parseASCIIElement(e,t){let n={};for(let r=0;r<e.length;r++){if(t.empty())return null;if(e[r].type===`list`){let o=[],s=parseASCIINumber(t.next(),e[r].countType);for(let n=0;n<s;n++){if(t.empty())return null;o.push(parseASCIINumber(t.next(),e[r].itemType))}n[e[r].name]=o}else n[e[r].name]=parseASCIINumber(t.next(),e[r].type)}return n}function createBuffer(e){let t={indices:[],vertices:[],normals:[],uvs:[],faceVertexUvs:[],colors:[],faceVertexColors:[]};for(let n of Object.keys(e.customPropertyMapping))t[n]=[];return t}function mapElementAttributes(e){let t=e.map(e=>e.name);function n(e){for(let n=0,r=e.length;n<r;n++){let r=e[n];if(t.includes(r))return r}return null}return{attrX:n([`x`,`px`,`posx`])||`x`,attrY:n([`y`,`py`,`posy`])||`y`,attrZ:n([`z`,`pz`,`posz`])||`z`,attrNX:n([`nx`,`normalx`]),attrNY:n([`ny`,`normaly`]),attrNZ:n([`nz`,`normalz`]),attrS:n([`s`,`u`,`texture_u`,`tx`]),attrT:n([`t`,`v`,`texture_v`,`ty`]),attrR:n([`red`,`diffuse_red`,`r`,`diffuse_r`]),attrG:n([`green`,`diffuse_green`,`g`,`diffuse_g`]),attrB:n([`blue`,`diffuse_blue`,`b`,`diffuse_b`])}}function parseASCII(e,t,n){let r=createBuffer(n),o=/end_header\s+(\S[\s\S]*\S|\S)\s*$/,s,c=null;s=(c=o.exec(e))===null?[]:c[1].split(/\s+/);let l=new ArrayStream(s);loop:for(let e=0;e<t.elements.length;e++){let o=t.elements[e],s=mapElementAttributes(o.properties);for(let e=0;e<o.count;e++){let e=parseASCIIElement(o.properties,l);if(!e)break loop;handleElement(r,o.name,e,s,n)}}return postProcess(r,n)}function postProcess(e,t){let n=new three.BufferGeometry;e.indices.length>0&&n.setIndex(e.indices),n.setAttribute(`position`,new three.Float32BufferAttribute(e.vertices,3)),e.normals.length>0&&n.setAttribute(`normal`,new three.Float32BufferAttribute(e.normals,3)),e.uvs.length>0&&n.setAttribute(`uv`,new three.Float32BufferAttribute(e.uvs,2)),e.colors.length>0&&n.setAttribute(`color`,new three.Float32BufferAttribute(e.colors,3)),(e.faceVertexUvs.length>0||e.faceVertexColors.length>0)&&(n=n.toNonIndexed(),e.faceVertexUvs.length>0&&n.setAttribute(`uv`,new three.Float32BufferAttribute(e.faceVertexUvs,2)),e.faceVertexColors.length>0&&n.setAttribute(`color`,new three.Float32BufferAttribute(e.faceVertexColors,3)));for(let r of Object.keys(t.customPropertyMapping))if(e[r].length>0){let{itemType:o,itemNames:s,normalized:c}=t.customPropertyMapping[r],l=s.length,u;switch(o){case`float32`:u=new three.Float32BufferAttribute(e[r],l,c);break;case`uint32`:u=new three.Uint32BufferAttribute(e[r],l,c);break;case`int32`:u=new three.Int32BufferAttribute(e[r],l,c);break;case`uint16`:u=new three.Uint16BufferAttribute(e[r],l,c);break;case`int16`:u=new three.Int16BufferAttribute(e[r],l,c);break;case`uint8`:u=new three.Uint8BufferAttribute(e[r],l,c);break;case`int8`:u=new three.Int8BufferAttribute(e[r],l,c);break;default:u=new three.Float32BufferAttribute(e[r],l,c);break}n.setAttribute(r,u)}return n.computeBoundingSphere(),n}function handleElement(e,t,n,r,o){if(t===`vertex`){r.attrX!==null&&r.attrY!==null&&r.attrZ!==null&&e.vertices.push(n[r.attrX],n[r.attrY],n[r.attrZ]),r.attrNX!==null&&r.attrNY!==null&&r.attrNZ!==null&&e.normals.push(n[r.attrNX],n[r.attrNY],n[r.attrNZ]),r.attrS!==null&&r.attrT!==null&&e.uvs.push(n[r.attrS],n[r.attrT]),r.attrR!==null&&r.attrG!==null&&r.attrB!==null&&(scratchColor.setRGB(n[r.attrR]/255,n[r.attrG]/255,n[r.attrB]/255),e.colors.push(scratchColor.r,scratchColor.g,scratchColor.b));for(let t of Object.keys(o.customPropertyMapping))for(let r of o.customPropertyMapping[t].itemNames)e[t].push(n[r])}else if(t===`face`){let t=n.vertex_indices||n.vertex_index,o=n.texcoord;t.length===3?(e.indices.push(t[0],t[1],t[2]),o&&o.length===6&&(e.faceVertexUvs.push(o[0],o[1]),e.faceVertexUvs.push(o[2],o[3]),e.faceVertexUvs.push(o[4],o[5]))):t.length===4&&(e.indices.push(t[0],t[1],t[3]),e.indices.push(t[1],t[2],t[3])),r.attrR!==null&&r.attrG!==null&&r.attrB!==null&&(scratchColor.setRGB(n[r.attrR]/255,n[r.attrG]/255,n[r.attrB]/255),e.faceVertexColors.push(scratchColor.r,scratchColor.g,scratchColor.b),e.faceVertexColors.push(scratchColor.r,scratchColor.g,scratchColor.b),e.faceVertexColors.push(scratchColor.r,scratchColor.g,scratchColor.b))}}function binaryReadElement(e,t){let n={},r=0;for(let o=0;o<t.length;o++){let s=t[o],c=s.valueReader;if(s.type===`list`){let t=[],o=s.countReader.read(e+r);r+=s.countReader.size;for(let n=0;n<o;n++)t.push(c.read(e+r)),r+=c.size;n[s.name]=t}else n[s.name]=c.read(e+r),r+=c.size}return[n,r]}function setPropertyBinaryReaders(e,t,n){function r(e,t,n){switch(t){case`int8`:case`char`:return{read:t=>e.getInt8(t),size:1};case`uint8`:case`uchar`:return{read:t=>e.getUint8(t),size:1};case`int16`:case`short`:return{read:t=>e.getInt16(t,n),size:2};case`uint16`:case`ushort`:return{read:t=>e.getUint16(t,n),size:2};case`int32`:case`int`:return{read:t=>e.getInt32(t,n),size:4};case`uint32`:case`uint`:return{read:t=>e.getUint32(t,n),size:4};case`float32`:case`float`:return{read:t=>e.getFloat32(t,n),size:4};case`float64`:case`double`:return{read:t=>e.getFloat64(t,n),size:8};default:throw Error(`not support type: `+t)}}for(let o=0,s=e.length;o<s;o++){let s=e[o];s.type===`list`?(s.countReader=r(t,s.countType,n),s.valueReader=r(t,s.itemType,n)):s.valueReader=r(t,s.type,n)}}function parseBinary(e,t,n){let r=createBuffer(n),o=t.format===`binary_little_endian`,s=new DataView(e,t.headerLength),c,l=0;for(let e=0;e<t.elements.length;e++){let u=t.elements[e],d=u.properties,f=mapElementAttributes(d);setPropertyBinaryReaders(d,s,o);for(let e=0;e<u.count;e++){c=binaryReadElement(l,d),l+=c[1];let e=c[0];handleElement(r,u.name,e,f,n)}}return postProcess(r,n)}function extractHeaderText(e){let t=0,n=!0,r=``,o=[],s=new TextDecoder().decode(e.subarray(0,5)),c=/^ply\r\n/.test(s);do{let s=String.fromCharCode(e[t++]);s!==`
831
- `&&s!==`\r`?r+=s:(r===`end_header`&&(n=!1),r!==``&&(o.push(r),r=``))}while(n&&t<e.length);return c===!0&&t++,{headerText:o.join(`\r`)+`\r`,headerLength:t}}var ArrayStream=class{constructor(e){this.arr=e,this.i=0}empty(){return this.i>=this.arr.length}next(){return this.arr[this.i++]}},u8=Uint8Array,u16=Uint16Array,i32=Int32Array,fleb=new u8([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0,0]),fdeb=new u8([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13,0,0]),clim=new u8([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),freb=function(e,t){for(var n=new u16(31),r=0;r<31;++r)n[r]=t+=1<<e[r-1];for(var o=new i32(n[30]),r=1;r<30;++r)for(var s=n[r];s<n[r+1];++s)o[s]=s-n[r]<<5|r;return{b:n,r:o}},_a$3=freb(fleb,2),fl=_a$3.b,revfl=_a$3.r;fl[28]=258,revfl[258]=28;for(var _b=freb(fdeb,0),fd=_b.b,revfd=_b.r,rev=new u16(32768),i=0;i<32768;++i){var x=(i&43690)>>1|(i&21845)<<1;x=(x&52428)>>2|(x&13107)<<2,x=(x&61680)>>4|(x&3855)<<4,rev[i]=((x&65280)>>8|(x&255)<<8)>>1}for(var hMap=(function(e,t,n){for(var r=e.length,o=0,s=new u16(t);o<r;++o)e[o]&&++s[e[o]-1];var c=new u16(t);for(o=1;o<t;++o)c[o]=c[o-1]+s[o-1]<<1;var l;if(n){l=new u16(1<<t);var u=15-t;for(o=0;o<r;++o)if(e[o])for(var d=o<<4|e[o],f=t-e[o],p=c[e[o]-1]++<<f,m=p|(1<<f)-1;p<=m;++p)l[rev[p]>>u]=d}else for(l=new u16(r),o=0;o<r;++o)e[o]&&(l[o]=rev[c[e[o]-1]++]>>15-e[o]);return l}),flt=new u8(288),i=0;i<144;++i)flt[i]=8;for(var i=144;i<256;++i)flt[i]=9;for(var i=256;i<280;++i)flt[i]=7;for(var i=280;i<288;++i)flt[i]=8;for(var fdt=new u8(32),i=0;i<32;++i)fdt[i]=5;var flm=hMap(flt,9,0),flrm=hMap(flt,9,1),fdm=hMap(fdt,5,0),fdrm=hMap(fdt,5,1),max=function(e){for(var t=e[0],n=1;n<e.length;++n)e[n]>t&&(t=e[n]);return t},bits=function(e,t,n){var r=t/8|0;return(e[r]|e[r+1]<<8)>>(t&7)&n},bits16=function(e,t){var n=t/8|0;return(e[n]|e[n+1]<<8|e[n+2]<<16)>>(t&7)},shft=function(e){return(e+7)/8|0},slc=function(e,t,n){return(t==null||t<0)&&(t=0),(n==null||n>e.length)&&(n=e.length),new u8(e.subarray(t,n))},ec=[`unexpected EOF`,`invalid block type`,`invalid length/literal`,`invalid distance`,`stream finished`,`no stream handler`,,`no callback`,`invalid UTF-8 data`,`extra field too long`,`date not in range 1980-2099`,`filename too long`,`stream finishing`,`invalid zip data`],err=function(e,t,n){var r=Error(t||ec[e]);if(r.code=e,Error.captureStackTrace&&Error.captureStackTrace(r,err),!n)throw r;return r},inflt=function(e,t,n,r){var o=e.length,s=r?r.length:0;if(!o||t.f&&!t.l)return n||new u8(0);var c=!n,l=c||t.i!=2,u=t.i;c&&(n=new u8(o*3));var d=function(e){var t=n.length;if(e>t){var r=new u8(Math.max(t*2,e));r.set(n),n=r}},f=t.f||0,p=t.p||0,m=t.b||0,h=t.l,g=t.d,_=t.m,v=t.n,y=o*8;do{if(!h){f=bits(e,p,1);var b=bits(e,p+1,3);if(p+=3,!b){var S=shft(p)+4,C=e[S-4]|e[S-3]<<8,w=S+C;if(w>o){u&&err(0);break}l&&d(m+C),n.set(e.subarray(S,w),m),t.b=m+=C,t.p=p=w*8,t.f=f;continue}else if(b==1)h=flrm,g=fdrm,_=9,v=5;else if(b==2){var T=bits(e,p,31)+257,E=bits(e,p+10,15)+4,D=T+bits(e,p+5,31)+1;p+=14;for(var O=new u8(D),k=new u8(19),A=0;A<E;++A)k[clim[A]]=bits(e,p+A*3,7);p+=E*3;for(var j=max(k),M=(1<<j)-1,N=hMap(k,j,1),A=0;A<D;){var P=N[bits(e,p,M)];p+=P&15;var S=P>>4;if(S<16)O[A++]=S;else{var F=0,I=0;for(S==16?(I=3+bits(e,p,3),p+=2,F=O[A-1]):S==17?(I=3+bits(e,p,7),p+=3):S==18&&(I=11+bits(e,p,127),p+=7);I--;)O[A++]=F}}var L=O.subarray(0,T),R=O.subarray(T);_=max(L),v=max(R),h=hMap(L,_,1),g=hMap(R,v,1)}else err(1);if(p>y){u&&err(0);break}}l&&d(m+131072);for(var z=(1<<_)-1,B=(1<<v)-1,V=p;;V=p){var F=h[bits16(e,p)&z],H=F>>4;if(p+=F&15,p>y){u&&err(0);break}if(F||err(2),H<256)n[m++]=H;else if(H==256){V=p,h=null;break}else{var ee=H-254;if(H>264){var A=H-257,te=fleb[A];ee=bits(e,p,(1<<te)-1)+fl[A],p+=te}var U=g[bits16(e,p)&B],W=U>>4;U||err(3),p+=U&15;var R=fd[W];if(W>3){var te=fdeb[W];R+=bits16(e,p)&(1<<te)-1,p+=te}if(p>y){u&&err(0);break}l&&d(m+131072);var G=m+ee;if(m<R){var K=s-R,ne=Math.min(R,G);for(K+m<0&&err(3);m<ne;++m)n[m]=r[K+m]}for(;m<G;++m)n[m]=n[m-R]}}t.l=h,t.p=V,t.b=m,t.f=f,h&&(f=1,t.m=_,t.d=g,t.n=v)}while(!f);return m!=n.length&&c?slc(n,0,m):n.subarray(0,m)},et=new u8(0),b2=function(e,t){return e[t]|e[t+1]<<8},b4=function(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0},b8=function(e,t){return b4(e,t)+b4(e,t+4)*4294967296},zls=function(e,t){return((e[0]&15)!=8||e[0]>>4>7||(e[0]<<8|e[1])%31)&&err(6,`invalid zlib data`),(e[1]>>5&1)==+!t&&err(6,`invalid zlib data: `+(e[1]&32?`need`:`unexpected`)+` dictionary`),(e[1]>>3&4)+2};function inflateSync(e,t){return inflt(e,{i:2},t&&t.out,t&&t.dictionary)}function unzlibSync(e,t){return inflt(e.subarray(zls(e,t&&t.dictionary),-4),{i:2},t&&t.out,t&&t.dictionary)}var td=typeof TextDecoder<`u`&&new TextDecoder,tds=0;try{td.decode(et,{stream:!0})}catch(e){}var dutf8=function(e){for(var t=``,n=0;;){var r=e[n++],o=(r>127)+(r>223)+(r>239);if(n+o>e.length)return{s:t,r:slc(e,n-1)};o?o==3?(r=((r&15)<<18|(e[n++]&63)<<12|(e[n++]&63)<<6|e[n++]&63)-65536,t+=String.fromCharCode(55296|r>>10,56320|r&1023)):o&1?t+=String.fromCharCode((r&31)<<6|e[n++]&63):t+=String.fromCharCode((r&15)<<12|(e[n++]&63)<<6|e[n++]&63):t+=String.fromCharCode(r)}};function strFromU8(e,t){if(t){for(var n=``,r=0;r<e.length;r+=16384)n+=String.fromCharCode.apply(null,e.subarray(r,r+16384));return n}else if(td)return td.decode(e);else{var o=dutf8(e),s=o.s,n=o.r;return n.length&&err(8),s}}var slzh=function(e,t){return t+30+b2(e,t+26)+b2(e,t+28)},zh=function(e,t,n){var r=b2(e,t+28),o=strFromU8(e.subarray(t+46,t+46+r),!(b2(e,t+8)&2048)),s=t+46+r,c=b4(e,t+20),l=n&&c==4294967295?z64e(e,s):[c,b4(e,t+24),b4(e,t+42)],u=l[0],d=l[1],f=l[2];return[b2(e,t+10),u,d,o,s+b2(e,t+30)+b2(e,t+32),f]},z64e=function(e,t){for(;b2(e,t)!=1;t+=4+b2(e,t+2));return[b8(e,t+12),b8(e,t+4),b8(e,t+20)]};function unzipSync(e,t){for(var n={},r=e.length-22;b4(e,r)!=101010256;--r)(!r||e.length-r>65558)&&err(13);var o=b2(e,r+8);if(!o)return{};var s=b4(e,r+16),c=s==4294967295||o==65535;if(c){var l=b4(e,r-12);c=b4(e,l)==101075792,c&&(o=b4(e,l+32),s=b4(e,l+48))}for(var u=t&&t.filter,d=0;d<o;++d){var f=zh(e,s,c),p=f[0],m=f[1],h=f[2],g=f[3],_=f[4],v=f[5],y=slzh(e,v);s=_,(!u||u({name:g,size:m,originalSize:h,compression:p}))&&(p?p==8?n[g]=inflateSync(e.subarray(y,y+m),{out:new u8(h)}):err(14,`unknown compression type `+p):n[g]=slc(e,y,y+m))}return n}function loadFbx(e,t={}){var n,r,o;let s=(n=t.upAxis)==null?`Z`:n,c=(r=t.fetcher)==null?internalFetcher:r,l=(o=t.onDownloadProgress)==null?noop:o,u=0;return Promise.resolve().then(()=>c.ajax(e,{responseType:`arraybuffer`},void 0,void 0,l).then(e=>(u=e.body.byteLength,e.body))).then(n=>{var r;return parse$2(n,{light:t.light,resourcePath:e.slice(0,e.lastIndexOf(`/`)+1),search:(r=e.split(`?`)[1])==null?``:r,fetcher:c})}).then(t=>{let n=t.scene,r=t.unitScale/100,o=new three.Matrix4;if(o.makeScale(r,r,r),t.upAxis===`X`)throw Error(`Cannot load fbx x upAxis`);return t.upAxis===`Y`&&o.premultiply(ROTATE_X_MATRIX$1),s===`Y`&&o.premultiply(ROTATE_X_MATRIX_INVERSE$1),n.applyMatrix4(o),{type:`fbx`,modelUpAxis:t.upAxis,upAxis:s,uri:e,byteLength:u,memoryUsage:getMemoryUsage(n),scene:n,textures:t.textures,animations:t.animations,dispose:()=>t.dispose()}})}function parse$2(e,t){let n;if(isFbxFormatBinary(e))n=new BinaryParser().parse(e);else{let t=convertArrayBufferToString(e);if(!isFbxFormatASCII(t))throw Error(`THREE.FBXLoader: Unknown format.`);if(getFbxVersion(t)<7e3)throw Error(`THREE.FBXLoader: FBX version not supported, FileVersion: `+getFbxVersion(t));n=new TextParser().parse(t)}return new FBXTreeParser(t).parse(n)}var FBXTreeParser=class{constructor(e){var t,n,r;this.light=(t=e.light)==null?!0:t,this.resourcePath=(n=e.resourcePath)==null?``:n,this.search=(r=e.search)==null?``:r,this.fetcher=e.fetcher}parse(e){var t,n,r,o,s,c;let l=this.parseConnections(e),u=Object.assign(new three.Group,{animations:[]}),d=[],f=this.parseImages(e),p=this.parseTextures(e,f,l,d),m=this.parseMaterials(e,p,l),h=this.parseDeformers(e,l),g=new GeometryParser().parse(e,h,l);this.parseScene(e,h,g,m,l,u);let _=(n=(t=e.GlobalSettings.UpAxis)==null?void 0:t.value)==null?1:n,v=(o=(r=e.GlobalSettings.FrontAxis)==null?void 0:r.value)==null?2:o,y=(c=(s=e.GlobalSettings.UnitScaleFactor)==null?void 0:s.value)==null?1:c,b;if(e.GlobalSettings.AmbientColor){let t=e.GlobalSettings.AmbientColor.value,n=t[0],r=t[1],o=t[2];if(n!==0||r!==0||o!==0){let e=new three.Color().setRGB(n,r,o);b=new three.AmbientLight(e,1)}}return Promise.all(d).then(e=>{var t;return{scene:u,textures:e,ambientLight:b,upAxis:[`X`,`Y`,`Z`][_],frontAxis:[`X`,`Y`,`Z`][v],unitScale:y,animations:(t=u.animations)==null?[]:t,dispose:()=>{e.forEach(e=>e.dispose()),m.forEach(e=>e.dispose()),g.forEach(e=>e.dispose())}}})}parseConnections(e){let t=new Map;return`Connections`in e&&e.Connections.connections.forEach(function(e){let n=e[0],r=e[1],o=e[2];t.has(n)||t.set(n,{parents:[],children:[]});let s={ID:r,relationship:o};t.get(n).parents.push(s),t.has(r)||t.set(r,{parents:[],children:[]});let c={ID:n,relationship:o};t.get(r).children.push(c)}),t}parseImages(e){let t={},n={};if(`Video`in e.Objects){let r=e.Objects.Video;for(let e in r){let o=r[e],s=parseInt(e);if(t[s]=o.RelativeFilename||o.Filename,`Content`in o){let t=o.Content instanceof ArrayBuffer&&o.Content.byteLength>0,s=typeof o.Content==`string`&&o.Content!==``;if(t||s){let t=this.parseImage(r[e]);n[o.RelativeFilename||o.Filename]=t}}}}for(let e in t){let r=t[e];n[r]===void 0?t[e]=t[e].split(`\\`).pop():t[e]=n[r]}return t}parseImage(e){let t=e.Content,n=e.RelativeFilename||e.Filename,r=n.slice(n.lastIndexOf(`.`)+1).toLowerCase(),o;switch(r){case`bmp`:o=`image/bmp`;break;case`jpg`:case`jpeg`:o=`image/jpeg`;break;case`png`:o=`image/png`;break;case`tif`:o=`image/tiff`;break;case`tga`:o=`image/tga`;break;default:return}if(typeof t==`string`)return`data:`+o+`;base64,`+t;{let e=new Uint8Array(t);return window.URL.createObjectURL(new Blob([e],{type:o}))}}parseTextures(e,t,n,r){let o=new Map;if(`Texture`in e.Objects){let s=e.Objects.Texture;for(let e in s){let c=this.parseTexture(s[e],t,n,r);o.set(parseInt(e),c)}}return o}parseTexture(e,t,n,r){let o=this.loadTexture(e,t,n,r);o.ID=e.id,o.name=e.attrName;let s=e.WrapModeU,c=e.WrapModeV,l=s===void 0?0:s.value,u=c===void 0?0:c.value;if(o.wrapS=l===0?three.RepeatWrapping:three.ClampToEdgeWrapping,o.wrapT=u===0?three.RepeatWrapping:three.ClampToEdgeWrapping,e.Scaling){let t=e.Scaling.value;o.repeat.x=t[0],o.repeat.y=t[1]}if(e.Translation){let t=e.Translation.value;o.offset.x=t[0],o.offset.y=t[1]}return o}loadTexture(e,t,n,r){let o=n.get(e.id).children,s=``;o!==void 0&&o.length>0&&t[o[0].ID]!==void 0&&(s=t[o[0].ID]),s=pathJoin(this.resourcePath,appendSearch(s,this.search));let c=Object.assign(new three.Texture,{ID:0}),l;l=canUseNativeImageBitmap()?this.fetcher.ajax(s,{responseType:`blob`}).then(e=>{let t=e.body;return createImageBitmapLike(t)}):this.fetcher.loadImage(s,{},void 0,void 0,void 0,createImageBitmapLikeImage()).then(e=>e.body);let u=l.then(e=>(c.image=e,c.needsUpdate=!0,c)).catch(e=>(console.warn(e),c));return r.push(u),c}parseMaterials(e,t,n){let r=new Map;if(`Material`in e.Objects){let o=e.Objects.Material;for(let s in o){let c=this.parseMaterial(e,o[s],t,n);c!==null&&r.set(parseInt(s),c)}}return r}parseMaterial(e,t,n,r){let o=t.id,s=t.attrName,c=t.ShadingModel;if(typeof c==`object`&&(c=c.value),c=c.toLowerCase(),!r.has(o))return null;let l=new PBMMeshMaterial(this.light?`phong`:`basic`);l.name=s,t.BumpFactor&&(l.bumpScale=t.BumpFactor.value),t.Diffuse?l.color=new three.Color().fromArray(t.Diffuse.value):t.DiffuseColor&&(t.DiffuseColor.type===`Color`||t.DiffuseColor.type===`ColorRGB`)&&(l.color=new three.Color().fromArray(t.DiffuseColor.value)),t.DisplacementFactor&&(l.displacementScale=t.DisplacementFactor.value),t.Emissive?l.emissive=new three.Color().fromArray(t.Emissive.value):t.EmissiveColor&&(t.EmissiveColor.type===`Color`||t.EmissiveColor.type===`ColorRGB`)&&(l.emissive=new three.Color().fromArray(t.EmissiveColor.value)),t.EmissiveFactor&&(l.emissiveIntensity=parseFloat(t.EmissiveFactor.value));let u=1-(t.TransparencyFactor?parseFloat(t.TransparencyFactor.value):0);(u===1||u===0)&&(u=t.Opacity?parseFloat(t.Opacity.value):null,u===null&&(u=1-(t.TransparentColor?parseFloat(t.TransparentColor.value[0]):0))),l.opacity=u,l.opacity<1&&(l.transparent=!0),t.ReflectionFactor&&(l.reflectivity=t.ReflectionFactor.value),t.Shininess&&(l.shininess=t.Shininess.value),t.Specular?l.specular=new three.Color().fromArray(t.Specular.value):t.SpecularColor&&t.SpecularColor.type===`Color`&&(l.specular=new three.Color().fromArray(t.SpecularColor.value));let d=this;return r.get(o).children.forEach(function(t){let o=t.relationship;switch(o){case`Bump`:l.bumpMap=d.getTexture(e,n,t.ID,r);break;case`Maya|TEX_ao_map`:l.aoMap=d.getTexture(e,n,t.ID,r);break;case`DiffuseColor`:case`Maya|TEX_color_map`:l.map=d.getTexture(e,n,t.ID,r),l.map!==void 0&&(l.map.encoding=three.sRGBEncoding);break;case`DisplacementColor`:l.displacementMap=d.getTexture(e,n,t.ID,r);break;case`EmissiveColor`:l.emissiveMap=d.getTexture(e,n,t.ID,r),l.emissiveMap!==void 0&&(l.emissiveMap.encoding=three.sRGBEncoding);break;case`NormalMap`:case`Maya|TEX_normal_map`:l.normalMap=d.getTexture(e,n,t.ID,r);break;case`ReflectionColor`:l.envMap=d.getTexture(e,n,t.ID,r),l.envMap!==void 0&&(l.envMap.mapping=three.EquirectangularReflectionMapping,l.envMap.encoding=three.sRGBEncoding);break;case`SpecularColor`:l.specularMap=d.getTexture(e,n,t.ID,r),l.specularMap!==void 0&&(l.specularMap.encoding=three.sRGBEncoding);break;case`TransparentColor`:case`TransparencyFactor`:l.alphaMap=d.getTexture(e,n,t.ID,r),l.transparent=!0;break;default:console.warn(`THREE.FBXLoader: %s map is not supported in three.js, skipping texture.`,o);break}}),l}getTexture(e,t,n,r){return e.Objects.LayeredTexture&&n in e.Objects.LayeredTexture&&(console.warn(`THREE.FBXLoader: layered textures are not supported in three.js. Discarding all but first layer.`),n=r.get(n).children[0].ID),t.get(n)}parseDeformers(e,t){let n={},r={};if(`Deformer`in e.Objects){let o=e.Objects.Deformer;for(let e in o){let s=o[e],c=t.get(parseInt(e));if(s.attrType===`Skin`){let t=this.parseSkeleton(c,o);t.ID=e,c.parents.length>1&&console.warn(`THREE.FBXLoader: skeleton attached to more than one geometry is not supported.`),t.geometryID=c.parents[0].ID,n[e]=t}else if(s.attrType===`BlendShape`){let n={id:e};n.rawTargets=this.parseMorphTargets(c,o,t),n.id=e,c.parents.length>1&&console.warn(`THREE.FBXLoader: morph target attached to more than one geometry is not supported.`),r[e]=n}}}return{skeletons:n,morphTargets:r}}parseSkeleton(e,t){let n=[];return e.children.forEach(function(e){let r=t[e.ID];if(r.attrType!==`Cluster`)return;let o={ID:e.ID,indices:[],weights:[],transformLink:new three.Matrix4().fromArray(r.TransformLink.a)};r.Indexes&&(o.indices=r.Indexes.a,o.weights=r.Weights.a),n.push(o)}),{ID:``,geometryID:0,rawBones:n,bones:[]}}parseMorphTargets(e,t,n){let r=[];for(let o=0;o<e.children.length;o++){let s=e.children[o],c=t[s.ID],l={name:c.attrName,initialWeight:c.DeformPercent,id:c.id,fullWeights:c.FullWeights.a,geoID:0};if(c.attrType!==`BlendShapeChannel`)return;l.geoID=n.get(parseInt(s.ID)).children.filter(function(e){return e.relationship===void 0})[0].ID,r.push(l)}return r}parseScene(e,t,n,r,o,s){let c=this.parseModels(e,t.skeletons,n,r,o),l=e.Objects.Model,u=this;c.forEach(function(t){let n=l[t.ID];u.setLookAtProperties(e,t,n,o,s),o.get(t.ID).parents.forEach(function(e){let n=c.get(e.ID);n!==void 0&&n.add(t)}),t.parent===null&&s.add(t)}),this.bindSkeleton(e,t.skeletons,n,c,o),s.traverse(function(e){if(e.userData.transformData){e.parent&&(e.userData.transformData.parentMatrix=e.parent.matrix,e.userData.transformData.parentMatrixWorld=e.parent.matrixWorld);let t=generateTransform(e.userData.transformData);e.applyMatrix4(t),e.updateWorldMatrix(!0,!0)}});let d=new AnimationParser().parse(e,o,s);s.children.length===1&&s.children[0]instanceof three.Group&&(s=s.children[0]),s.animations=d}parseModels(e,t,n,r,o){let s=new Map,c=e.Objects.Model;for(let l in c){let u=parseInt(l),d=c[l],f=o.get(u),p=this.buildSkeleton(f,t,u,d.attrName);if(!p){switch(d.attrType){case`Camera`:p=this.createCamera(e,f);break;case`Light`:p=this.createLight(e,f);break;case`Mesh`:p=this.createMesh(f,n,r);break;case`NurbsCurve`:case`LimbNode`:case`Root`:p=new three.Bone;break;default:p=new three.Group;break}p.name=d.attrName?three.PropertyBinding.sanitizeNodeName(d.attrName):``,p.userData.originalName=d.attrName,p.ID=u}this.getTransformData(p,d),s.set(u,p)}return s}buildSkeleton(e,t,n,r){let o=null;return e.parents.forEach(function(e){for(let s in t){let c=t[s];c.rawBones.forEach(function(t,s){if(t.ID===e.ID){let e=o;o=new three.Bone,o.matrixWorld.copy(t.transformLink),o.name=r?three.PropertyBinding.sanitizeNodeName(r):``,o.userData.originalName=r,o.ID=n,c.bones[s]=o,e!==null&&o.add(e)}})}}),o}createCamera(e,t){let n,r;if(t.children.forEach(function(t){let n=e.Objects.NodeAttribute[t.ID];n!==void 0&&(r=n)}),r===void 0)n=new three.Object3D;else{let e=0;r.CameraProjectionType!==void 0&&r.CameraProjectionType.value===1&&(e=1);let t=1;r.NearPlane!==void 0&&(t=r.NearPlane.value/1e3);let o=1e3;r.FarPlane!==void 0&&(o=r.FarPlane.value/1e3);let s=window.innerWidth,c=window.innerHeight;r.AspectWidth!==void 0&&r.AspectHeight!==void 0&&(s=r.AspectWidth.value,c=r.AspectHeight.value);let l=s/c,u=45;r.FieldOfView!==void 0&&(u=r.FieldOfView.value);let d=r.FocalLength?r.FocalLength.value:null;switch(e){case 0:n=new three.PerspectiveCamera(u,l,t,o),d!==null&&n.setFocalLength(d);break;case 1:console.warn(`THREE.FBXLoader: Orthographic cameras not supported yet.`),n=new three.Object3D;break;default:console.warn(`THREE.FBXLoader: Unknown camera type `+e+`.`),n=new three.Object3D;break}}return n}createLight(e,t){let n,r;if(t.children.forEach(function(t){let n=e.Objects.NodeAttribute[t.ID];n!==void 0&&(r=n)}),r===void 0)n=new three.Object3D;else{let e;e=r.LightType===void 0?0:r.LightType.value;let t=new three.Color(16777215);r.Color!==void 0&&(t=new three.Color().fromArray(r.Color.value));let o=r.Intensity===void 0?1:r.Intensity.value/100;r.CastLightOnObject!==void 0&&r.CastLightOnObject.value===0&&(o=0);let s=0;r.FarAttenuationEnd!==void 0&&(s=r.EnableFarAttenuation!==void 0&&r.EnableFarAttenuation.value===0?0:r.FarAttenuationEnd.value);let c=1;switch(e){case 0:n=new three.PointLight(t,o,s,1);break;case 1:n=new three.DirectionalLight(t,o);break;case 2:let e=Math.PI/3;r.InnerAngle!==void 0&&(e=three.MathUtils.degToRad(r.InnerAngle.value));let c=0;r.OuterAngle!==void 0&&(c=three.MathUtils.degToRad(r.OuterAngle.value),c=Math.max(c,1)),n=new three.SpotLight(t,o,s,e,c,1);break;default:console.warn(`THREE.FBXLoader: Unknown light type `+r.LightType.value+`, defaulting to a PointLight.`),n=new three.PointLight(t,o);break}r.CastShadows!==void 0&&r.CastShadows.value===1&&(n.castShadow=!0)}return n}createMesh(e,t,n){let r,o=null,s=[];if(e.children.forEach(function(e){t.has(e.ID)&&(o=t.get(e.ID)),n.has(e.ID)&&s.push(n.get(e.ID))}),s.length===0){let e=new PBMMeshMaterial(this.light?`phong`:`basic`);e.color=new three.Color(13421772),s.push(e)}return`color`in o.attributes&&s.forEach(function(e){e.vertexColors=!0}),(!o.groups||o.groups.length===0)&&o.addGroup(0,o.index?o.index.count:o.attributes.position.count,0),o.FBX_Deformer?(s.forEach(function(e){e.skinning=!0}),r=new PBMSkinnedMesh(o,s),r.normalizeSkinWeights()):r=new PBMMesh(o,s),r}createCurve(e,t){let n=e.children.reduce(function(e,n){return t.has(n.ID)&&(e=t.get(n.ID)),e},null),r=new three.LineBasicMaterial({name:``,color:3342591,linewidth:1});return new three.Line(n,r)}getTransformData(e,t){let n={};t.InheritType&&(n.inheritType=parseInt(t.InheritType.value)),t.RotationOrder?n.eulerOrder=getEulerOrder(t.RotationOrder.value):n.eulerOrder=getEulerOrder(0),t.Lcl_Translation&&(n.translation=t.Lcl_Translation.value),t.PreRotation&&(n.preRotation=t.PreRotation.value),t.Lcl_Rotation&&(n.rotation=t.Lcl_Rotation.value),t.PostRotation&&(n.postRotation=t.PostRotation.value),t.Lcl_Scaling&&(n.scale=t.Lcl_Scaling.value),t.ScalingOffset&&(n.scalingOffset=t.ScalingOffset.value),t.ScalingPivot&&(n.scalingPivot=t.ScalingPivot.value),t.RotationOffset&&(n.rotationOffset=t.RotationOffset.value),t.RotationPivot&&(n.rotationPivot=t.RotationPivot.value),e.userData.transformData=n}setLookAtProperties(e,t,n,r,o){`LookAtProperty`in n&&r.get(t.ID).children.forEach(function(n){if(n.relationship===`LookAtProperty`){let r=e.Objects.Model[n.ID];if(r.Lcl_Translation){let e=r.Lcl_Translation.value;`target`in t&&t.target instanceof three.Object3D?(t.target.position.fromArray(e),o.add(t.target)):t.lookAt(new three.Vector3().fromArray(e))}}})}bindSkeleton(e,t,n,r,o){let s=this.parsePoseNodes(e);for(let e in t){let c=t[e];o.get(parseInt(c.ID)).parents.forEach(function(e){if(n.has(e.ID)){let t=e.ID;o.get(t).parents.forEach(function(e){if(r.has(e.ID)){let t=r.get(e.ID);t instanceof three.SkinnedMesh&&t.bind(new three.Skeleton(c.bones),s[e.ID])}})}})}}parsePoseNodes(e){let t={};if(e.Objects.Pose){let n=e.Objects.Pose;for(let e in n)if(n[e].attrType===`BindPose`&&n[e].NbPoseNodes>0){let r=n[e].PoseNode;Array.isArray(r)?r.forEach(function(e){t[e.Node]=new three.Matrix4().fromArray(e.Matrix.a)}):t[r.Node]=new three.Matrix4().fromArray(r.Matrix.a)}}return t}},GeometryParser=class{constructor(){this.negativeMaterialIndices=!1}parse(e,t,n){let r=new Map;if(`Geometry`in e.Objects){let o=e.Objects.Geometry;for(let s in o){let c=n.get(parseInt(s)),l=this.parseGeometry(e,c,o[s],t);r.set(parseInt(s),l)}}return this.negativeMaterialIndices===!0&&console.warn(`THREE.FBXLoader: The FBX file contains invalid (negative) material indices. The asset might not render as expected.`),r}parseGeometry(e,t,n,r){switch(n.attrType){case`Mesh`:return this.parseMeshGeometry(e,t,n,r);case`NurbsCurve`:return this.parseNurbsGeometry(n)}}parseMeshGeometry(e,t,n,r){let o=r.skeletons,s=[],c=t.parents.map(function(t){return e.Objects.Model[t.ID]});if(c.length===0)return;let l=t.children.reduce(function(e,t){return o[t.ID]!==void 0&&(e=o[t.ID]),e},null);t.children.forEach(function(e){r.morphTargets[e.ID]!==void 0&&s.push(r.morphTargets[e.ID])});let u=c[0],d={};u.RotationOrder&&(d.eulerOrder=getEulerOrder(u.RotationOrder.value)),u.InheritType&&(d.inheritType=parseInt(u.InheritType.value)),u.GeometricTranslation&&(d.translation=u.GeometricTranslation.value),u.GeometricRotation&&(d.rotation=u.GeometricRotation.value),u.GeometricScaling&&(d.scale=u.GeometricScaling.value);let f=generateTransform(d);return this.genGeometry(e,n,l,s,f)}genGeometry(e,t,n,r,o){let s=new three.BufferGeometry;t.attrName&&(s.name=t.attrName);let c=this.parseGeoNode(t,n),l=this.genBuffers(c),u=new three.Float32BufferAttribute(l.vertex,3);if(u.applyMatrix4(o),s.setAttribute(`position`,u),l.colors.length>0&&s.setAttribute(`color`,new three.Float32BufferAttribute(l.colors,3)),n&&(s.setAttribute(`skinIndex`,new three.Uint16BufferAttribute(l.weightsIndices,4)),s.setAttribute(`skinWeight`,new three.Float32BufferAttribute(l.vertexWeights,4)),s.FBX_Deformer=n),l.normal.length>0){let e=new three.Matrix3().getNormalMatrix(o),t=new three.Float32BufferAttribute(l.normal,3);t.applyNormalMatrix(e),s.setAttribute(`normal`,t)}if(l.uvs.forEach(function(e,t){let n=t===0?`uv`:`uv${t+1}`;s.setAttribute(n,new three.Float32BufferAttribute(l.uvs[t],2))}),c.material&&c.material.mappingType!==`AllSame`){let e=l.materialIndex[0],t=0;if(l.materialIndex.forEach(function(n,r){n!==e&&(s.addGroup(t,r-t,e),e=n,t=r)}),s.groups.length>0){let t=s.groups[s.groups.length-1],n=t.start+t.count;n!==l.materialIndex.length&&s.addGroup(n,l.materialIndex.length-n,e)}s.groups.length===0&&s.addGroup(0,l.materialIndex.length,l.materialIndex[0])}return this.addMorphTargets(e,s,t,r,o),s}parseGeoNode(e,t){let n={};if(n.vertexPositions=e.Vertices===void 0?[]:e.Vertices.a,n.vertexIndices=e.PolygonVertexIndex===void 0?[]:e.PolygonVertexIndex.a,e.LayerElementColor&&(n.color=this.parseVertexColors(e.LayerElementColor[0])),e.LayerElementMaterial&&(n.material=this.parseMaterialIndices(e.LayerElementMaterial[0])),e.LayerElementNormal&&(n.normal=this.parseNormals(e.LayerElementNormal[0])),e.LayerElementUV){n.uv=[];let t=0;for(;e.LayerElementUV[t];)e.LayerElementUV[t].UV&&n.uv.push(this.parseUVs(e.LayerElementUV[t])),t++}return n.weightTable={},t!==null&&(n.skeleton=t,t.rawBones.forEach(function(e,t){e.indices.forEach(function(r,o){n.weightTable[r]===void 0&&(n.weightTable[r]=[]),n.weightTable[r].push({id:t,weight:e.weights[o]})})})),n}genBuffers(e){let t={vertex:[],normal:[],colors:[],uvs:[],materialIndex:[],vertexWeights:[],weightsIndices:[]},n=0,r=0,o=!1,s=[],c=[],l=[],u=[],d=[],f=[],p=this;return e.vertexIndices.forEach(function(m,h){let g=0,_=!1;m<0&&(m^=-1,_=!0);let v=[],y=[];if(s.push(m*3,m*3+1,m*3+2),e.color){let t=getData(h,n,m,e.color);l.push(t[0],t[1],t[2])}if(e.skeleton){if(e.weightTable[m]!==void 0&&e.weightTable[m].forEach(function(e){y.push(e.weight),v.push(e.id)}),y.length>4){o||(console.warn(`THREE.FBXLoader: Vertex has more than 4 skinning weights assigned to vertex. Deleting additional weights.`),o=!0);let e=[0,0,0,0],t=[0,0,0,0];y.forEach(function(n,r){let o=n,s=v[r];t.forEach(function(t,n,r){if(o>t){r[n]=o,o=t;let c=e[n];e[n]=s,s=c}})}),v=e,y=t}for(;y.length<4;)y.push(0),v.push(0);for(let e=0;e<4;++e)d.push(y[e]),f.push(v[e])}if(e.normal){let t=getData(h,n,m,e.normal);c.push(t[0],t[1],t[2])}e.material&&e.material.mappingType!==`AllSame`&&(g=getData(h,n,m,e.material)[0],g<0&&(p.negativeMaterialIndices=!0,g=0)),e.uv&&e.uv.forEach(function(e,t){let r=getData(h,n,m,e);u[t]===void 0&&(u[t]=[]),u[t].push(r[0]),u[t].push(r[1])}),r++,_&&(p.genFace(t,e,s,g,c,l,u,d,f,r),n++,r=0,s=[],c=[],l=[],u=[],d=[],f=[])}),t}getNormalNewell(e){let t=new three.Vector3(0,0,0);for(let n=0;n<e.length;n++){let r=e[n],o=e[(n+1)%e.length];t.x+=(r.y-o.y)*(r.z+o.z),t.y+=(r.z-o.z)*(r.x+o.x),t.z+=(r.x-o.x)*(r.y+o.y)}return t.normalize(),t}getNormalTangentAndBitangent(e){let t=this.getNormalNewell(e),n=(Math.abs(t.z)>.5?new three.Vector3(0,1,0):new three.Vector3(0,0,1)).cross(t).normalize();return{normal:t,tangent:n,bitangent:t.clone().cross(n).normalize()}}flattenVertex(e,t,n){return new three.Vector2(e.dot(t),e.dot(n))}genFace(e,t,n,r,o,s,c,l,u,d){let f;if(d>3){let e=[],r=t.baseVertexPositions||t.vertexPositions;for(let t=0;t<n.length;t+=3)e.push(new three.Vector3(r[n[t]],r[n[t+1]],r[n[t+2]]));let{tangent:o,bitangent:s}=this.getNormalTangentAndBitangent(e),c=[];for(let t of e)c.push(this.flattenVertex(t,o,s));f=three.ShapeUtils.triangulateShape(c,[])}else f=[[0,1,2]];for(let[d,p,m]of f)e.vertex.push(t.vertexPositions[n[d*3]]),e.vertex.push(t.vertexPositions[n[d*3+1]]),e.vertex.push(t.vertexPositions[n[d*3+2]]),e.vertex.push(t.vertexPositions[n[p*3]]),e.vertex.push(t.vertexPositions[n[p*3+1]]),e.vertex.push(t.vertexPositions[n[p*3+2]]),e.vertex.push(t.vertexPositions[n[m*3]]),e.vertex.push(t.vertexPositions[n[m*3+1]]),e.vertex.push(t.vertexPositions[n[m*3+2]]),t.skeleton&&(e.vertexWeights.push(l[d*4]),e.vertexWeights.push(l[d*4+1]),e.vertexWeights.push(l[d*4+2]),e.vertexWeights.push(l[d*4+3]),e.vertexWeights.push(l[p*4]),e.vertexWeights.push(l[p*4+1]),e.vertexWeights.push(l[p*4+2]),e.vertexWeights.push(l[p*4+3]),e.vertexWeights.push(l[m*4]),e.vertexWeights.push(l[m*4+1]),e.vertexWeights.push(l[m*4+2]),e.vertexWeights.push(l[m*4+3]),e.weightsIndices.push(u[d*4]),e.weightsIndices.push(u[d*4+1]),e.weightsIndices.push(u[d*4+2]),e.weightsIndices.push(u[d*4+3]),e.weightsIndices.push(u[p*4]),e.weightsIndices.push(u[p*4+1]),e.weightsIndices.push(u[p*4+2]),e.weightsIndices.push(u[p*4+3]),e.weightsIndices.push(u[m*4]),e.weightsIndices.push(u[m*4+1]),e.weightsIndices.push(u[m*4+2]),e.weightsIndices.push(u[m*4+3])),t.color&&(e.colors.push(s[d*3]),e.colors.push(s[d*3+1]),e.colors.push(s[d*3+2]),e.colors.push(s[p*3]),e.colors.push(s[p*3+1]),e.colors.push(s[p*3+2]),e.colors.push(s[m*3]),e.colors.push(s[m*3+1]),e.colors.push(s[m*3+2])),t.material&&t.material.mappingType!==`AllSame`&&(e.materialIndex.push(r),e.materialIndex.push(r),e.materialIndex.push(r)),t.normal&&(e.normal.push(o[d*3]),e.normal.push(o[d*3+1]),e.normal.push(o[d*3+2]),e.normal.push(o[p*3]),e.normal.push(o[p*3+1]),e.normal.push(o[p*3+2]),e.normal.push(o[m*3]),e.normal.push(o[m*3+1]),e.normal.push(o[m*3+2])),t.uv&&t.uv.forEach(function(t,n){e.uvs[n]===void 0&&(e.uvs[n]=[]),e.uvs[n].push(c[n][d*2]),e.uvs[n].push(c[n][d*2+1]),e.uvs[n].push(c[n][p*2]),e.uvs[n].push(c[n][p*2+1]),e.uvs[n].push(c[n][m*2]),e.uvs[n].push(c[n][m*2+1])})}addMorphTargets(e,t,n,r,o){if(r.length===0)return;t.morphTargetsRelative=!0,t.morphAttributes.position=[];let s=this;r.forEach(function(r){r.rawTargets.forEach(function(r){let c=e.Objects.Geometry[r.geoID];c!==void 0&&s.genMorphGeometry(t,n,c,o,r.name)})})}genMorphGeometry(e,t,n,r,o){let s=t.Vertices===void 0?[]:t.Vertices.a,c=t.PolygonVertexIndex===void 0?[]:t.PolygonVertexIndex.a,l=n.Vertices===void 0?[]:n.Vertices.a,u=n.Indexes?n.Indexes.a:[],d=e.attributes.position.count*3,f=new Float32Array(d);for(let e=0;e<u.length;e++){let t=u[e]*3;f[t]=l[e*3],f[t+1]=l[e*3+1],f[t+2]=l[e*3+2]}let p={vertexIndices:c,vertexPositions:f,baseVertexPositions:s},m=this.genBuffers(p),h=new three.Float32BufferAttribute(m.vertex,3);h.name=o||n.attrName,h.applyMatrix4(r),e.morphAttributes.position.push(h)}parseNormals(e){let t=e.MappingInformationType,n=e.ReferenceInformationType,r=e.Normals.a,o=[];return n===`IndexToDirect`&&(e.NormalIndex?o=e.NormalIndex.a:e.NormalsIndex&&(o=e.NormalsIndex.a)),{dataSize:3,buffer:r,indices:o,mappingType:t,referenceType:n}}parseUVs(e){let t=e.MappingInformationType,n=e.ReferenceInformationType,r=e.UV.a,o=[];return n===`IndexToDirect`&&(o=e.UVIndex.a),{dataSize:2,buffer:r,indices:o,mappingType:t,referenceType:n}}parseVertexColors(e){let t=e.MappingInformationType,n=e.ReferenceInformationType,r=e.Colors.a,o=[];n===`IndexToDirect`&&(o=e.ColorIndex.a);for(let e=0,t=new three.Color;e<r.length;e+=4)t.fromArray(r,e),t.toArray(r,e);return{dataSize:4,buffer:r,indices:o,mappingType:t,referenceType:n}}parseMaterialIndices(e){let t=e.MappingInformationType,n=e.ReferenceInformationType;if(t===`NoMappingInformation`)return{dataSize:1,buffer:[0],indices:[0],mappingType:`AllSame`,referenceType:n};let r=e.Materials.a,o=[];for(let e=0;e<r.length;++e)o.push(e);return{dataSize:1,buffer:r,indices:o,mappingType:t,referenceType:n}}parseNurbsGeometry(e){let t=parseInt(e.Order);if(isNaN(t))return console.error(`THREE.FBXLoader: Invalid Order %s given for geometry ID: %s`,e.Order,e.id),new three.BufferGeometry;let n=t-1,r=e.KnotVector.a,o=[],s=e.Points.a;for(let e=0,t=s.length;e<t;e+=4)o.push(new three.Vector4().fromArray(s,e));let c,l;if(e.Form===`Closed`)o.push(o[0]);else if(e.Form===`Periodic`){c=n,l=r.length-1-c;for(let e=0;e<n;++e)o.push(o[e])}let u=new NURBSCurve(n,r,o,c,l).getPoints(o.length*12);return new three.BufferGeometry().setFromPoints(u)}},AnimationParser=class{parse(e,t,n){let r=[],o=this.parseClips(e,t,n);if(o!==void 0)for(let e in o){let t=o[e],s=this.addClip(t,n);r.push(s)}return r}parseClips(e,t,n){if(e.Objects.AnimationCurve===void 0)return;let r=this.parseAnimationCurveNodes(e);this.parseAnimationCurves(e,r,t);let o=this.parseAnimationLayers(e,r,t,n);return this.parseAnimStacks(e,o,t)}parseAnimationCurveNodes(e){let t=e.Objects.AnimationCurveNode,n=new Map;for(let e in t){let r=t[e];if(r.attrName.match(/S|R|T|DeformPercent/)!==null){let e={id:r.id,attr:r.attrName,curves:{}};n.set(e.id,e)}}return n}parseAnimationCurves(e,t,n){let r=e.Objects.AnimationCurve;for(let e in r){let o={id:r[e].id,times:r[e].KeyTime.a.map(convertFBXTimeToSeconds),values:r[e].KeyValueFloat.a},s=n.get(o.id);if(s!==void 0){let e=s.parents[0].ID,n=s.parents[0].relationship,r=t.get(e);r&&(n.match(/X/)?r.curves.x=o:n.match(/Y/)?r.curves.y=o:n.match(/Z/)?r.curves.z=o:n.match(/DeformPercent/)&&t.has(e)&&(r.curves.morph=o))}}}parseAnimationLayers(e,t,n,r){let o=e.Objects.AnimationLayer,s=new Map;for(let c in o){let o=[],l=n.get(parseInt(c));l!==void 0&&(l.children.forEach((s,c)=>{if(t.has(s.ID)){let l=t.get(s.ID);if(l.curves.x!==void 0||l.curves.y!==void 0||l.curves.z!==void 0){if(o[c]===void 0){let t=n.get(s.ID).parents.filter(function(e){return e.relationship!==void 0})[0].ID;if(t!==void 0){let n=e.Objects.Model[t.toString()];if(n===void 0){console.warn(`THREE.FBXLoader: Encountered a unused curve.`,s);return}let l={modelName:n.attrName?three.PropertyBinding.sanitizeNodeName(n.attrName):``,ID:n.id,initialPosition:[0,0,0],initialRotation:[0,0,0],initialScale:[1,1,1],transform:new three.Matrix4,eulerOrder:``,preRotation:[0,0,0],postRotation:[0,0,0]};r.traverse(function(e){e.ID===n.id&&(l.transform=e.matrix,e.userData.transformData&&(l.eulerOrder=e.userData.transformData.eulerOrder))}),l.transform||(l.transform=new three.Matrix4),n.PreRotation&&(l.preRotation=n.PreRotation.value),n.PostRotation&&(l.postRotation=n.PostRotation.value),o[c]=l}}o[c]&&(o[c][l.attr]=l)}else if(l.curves.morph!==void 0){if(o[c]===void 0){let t=n.get(s.ID).parents.filter(function(e){return e.relationship!==void 0})[0].ID,r=n.get(t).parents[0].ID,l=n.get(r).parents[0].ID,u=n.get(l).parents[0].ID,d=e.Objects.Model[u];o[c]={modelName:d.attrName?three.PropertyBinding.sanitizeNodeName(d.attrName):``,morphName:e.Objects.Deformer[t].attrName}}o[c][l.attr]=l}}}),s.set(parseInt(c),o))}return s}parseAnimStacks(e,t,n){let r=e.Objects.AnimationStack,o={};for(let e in r){let s=n.get(parseInt(e)).children;s.length>1&&console.warn(`THREE.FBXLoader: Encountered an animation stack with multiple layers, this is currently not supported. Ignoring subsequent layers.`);let c=t.get(s[0].ID);o[e]={name:r[e].attrName,layer:c}}return o}addClip(e,t){let n=[],r=this;return e.layer.forEach(function(e){n=n.concat(r.generateTracks(e,t))}),new three.AnimationClip(e.name,-1,n)}generateTracks(e,t){let n=[],r=new three.Vector3,o=new three.Vector3;e.transform&&e.transform.decompose(r,new three.Quaternion,o);let s=r.toArray(),c=o.toArray();if(e.T!==void 0&&Object.keys(e.T.curves).length>0){let t=this.generateVectorTrack(e.modelName,e.T.curves,s,`position`);t!==void 0&&n.push(t)}if(e.R!==void 0&&Object.keys(e.R.curves).length>0){let t=this.generateRotationTrack(e.modelName,e.R.curves,e.preRotation,e.postRotation,e.eulerOrder);t!==void 0&&n.push(t)}if(e.S!==void 0&&Object.keys(e.S.curves).length>0){let t=this.generateVectorTrack(e.modelName,e.S.curves,c,`scale`);t!==void 0&&n.push(t)}if(e.DeformPercent!==void 0){let r=this.generateMorphTrack(e,t);r!==void 0&&n.push(r)}return n}generateVectorTrack(e,t,n,r){let o=this.getTimesForAllAxes(t),s=this.getKeyframeTrackValues(o,t,n);return new three.VectorKeyframeTrack(e+`.`+r,o,s)}generateRotationTrack(e,t,n,r,o){let s,c;if(t.x!==void 0&&t.y!==void 0&&t.z!==void 0){let e=this.interpolateRotations(t.x,t.y,t.z,o);s=e[0],c=e[1]}let l=getEulerOrder(0),u=new three.Quaternion,d=new three.Quaternion;n!==void 0&&(n=n.map(three.MathUtils.degToRad),n.push(l),u.setFromEuler(new three.Euler().fromArray(n))),r!==void 0&&(r=r.map(three.MathUtils.degToRad),r.push(l),d.setFromEuler(new three.Euler().fromArray(r)),d.inverse());let f=new three.Quaternion,p=new three.Euler,m=[];if(!c||!s)return new three.QuaternionKeyframeTrack(e+`.quaternion`,[0],[0]);for(let e=0;e<c.length;e+=3)p.set(c[e],c[e+1],c[e+2],o),f.setFromEuler(p),f.premultiply(u),f.multiply(d),e>2&&new three.Quaternion().fromArray(m,(e-3)/3*4).dot(f)<0&&f.set(-f.x,-f.y,-f.z,-f.w),f.toArray(m,e/3*4);return new three.QuaternionKeyframeTrack(e+`.quaternion`,s,m)}generateMorphTrack(e,t){let n=e.DeformPercent.curves.morph,r=n.values.map(function(e){return e/100}),o=t.getObjectByName(e.modelName).morphTargetDictionary[e.morphName];return new three.NumberKeyframeTrack(e.modelName+`.morphTargetInfluences[`+o+`]`,n.times,r)}getTimesForAllAxes(e){let t=[];if(e.x!==void 0&&(t=t.concat(e.x.times)),e.y!==void 0&&(t=t.concat(e.y.times)),e.z!==void 0&&(t=t.concat(e.z.times)),t=t.sort(function(e,t){return e-t}),t.length>1){let e=1,n=t[0];for(let r=1;r<t.length;r++){let o=t[r];o!==n&&(t[e]=o,n=o,e++)}t=t.slice(0,e)}return t}getKeyframeTrackValues(e,t,n){let r=n,o=[],s=-1,c=-1,l=-1;return e.forEach(function(e){if(t.x&&(s=t.x.times.indexOf(e)),t.y&&(c=t.y.times.indexOf(e)),t.z&&(l=t.z.times.indexOf(e)),s!==-1){let e=t.x.values[s];o.push(e),r[0]=e}else o.push(r[0]);if(c!==-1){let e=t.y.values[c];o.push(e),r[1]=e}else o.push(r[1]);if(l!==-1){let e=t.z.values[l];o.push(e),r[2]=e}else o.push(r[2])}),o}interpolateRotations(e,t,n,r){let o=[],s=[];o.push(e.times[0]),s.push(three.MathUtils.degToRad(e.values[0])),s.push(three.MathUtils.degToRad(t.values[0])),s.push(three.MathUtils.degToRad(n.values[0]));for(let c=1;c<e.values.length;c++){let l=[e.values[c-1],t.values[c-1],n.values[c-1]];if(isNaN(l[0])||isNaN(l[1])||isNaN(l[2]))continue;let u=l.map(three.MathUtils.degToRad),d=[e.values[c],t.values[c],n.values[c]];if(isNaN(d[0])||isNaN(d[1])||isNaN(d[2]))continue;d.map(three.MathUtils.degToRad);let f=[d[0]-l[0],d[1]-l[1],d[2]-l[2]],p=[Math.abs(f[0]),Math.abs(f[1]),Math.abs(f[2])];if(p[0]>=180||p[1]>=180||p[2]>=180){let t=Math.max(...p)/180,n=new three.Euler(u[0],u[1],u[2],r),l=new three.Euler(u[0],u[1],u[2],r),d=new three.Quaternion().setFromEuler(n),f=new three.Quaternion().setFromEuler(l);d.dot(f)&&f.set(-f.x,-f.y,-f.z,-f.w);let m=e.times[c-1],h=e.times[c]-m,g=new three.Quaternion,_=new three.Euler;for(let e=0;e<1;e+=1/t)g.copy(d.clone().slerp(f.clone(),e)),o.push(m+e*h),_.setFromQuaternion(g,r),s.push(_.x),s.push(_.y),s.push(_.z)}else o.push(e.times[c]),s.push(three.MathUtils.degToRad(e.values[c])),s.push(three.MathUtils.degToRad(t.values[c])),s.push(three.MathUtils.degToRad(n.values[c]))}return[o,s]}},TextParser=class{constructor(){this.allNodes=new FBXTree,this.nodeStack=[],this.currentIndent=0,this.currentPropName=``}getPrevNode(){return this.nodeStack[this.currentIndent-2]}getCurrentNode(){return this.nodeStack[this.currentIndent-1]}getCurrentProp(){return this.currentProp}pushStack(e){this.nodeStack.push(e),this.currentIndent+=1}popStack(){this.nodeStack.pop(),--this.currentIndent}setCurrentProp(e,t){this.currentProp=e,this.currentPropName=t}parse(e){this.currentIndent=0,this.allNodes=new FBXTree,this.nodeStack=[],this.currentProp=[],this.currentPropName=``;let t=this,n=e.split(/[\r\n]+/);return n.forEach(function(e,r){let o=e.match(/^[\s\t]*;/),s=e.match(/^[\s\t]*$/);if(o||s)return;let c=e.match(`^\\t{`+t.currentIndent+`}(\\w+):(.*){`),l=e.match(`^\\t{`+t.currentIndent+`}(\\w+):[\\s\\t\\r\\n](.*)`),u=e.match(`^\\t{`+(t.currentIndent-1)+`}}`);c?t.parseNodeBegin(e,c):l?t.parseNodeProperty(e,l,n[++r]):u?t.popStack():e.match(/^[^\s\t}]/)&&t.parseNodePropertyContinued(e)}),this.allNodes}parseNodeBegin(e,t){let n=t[1].trim().replace(/^"/,``).replace(/"$/,``),r=t[2].split(`,`).map(function(e){return e.trim().replace(/^"/,``).replace(/"$/,``)}),o={name:n},s=this.parseNodeAttr(r),c=this.getCurrentNode();this.currentIndent===0?this.allNodes.add(n,o):n in c?(n===`PoseNode`?c.PoseNode.push(o):c[n].id!==void 0&&(c[n]={},c[n][c[n].id]=c[n]),s.id!==``&&(c[n][s.id]=o)):typeof s.id==`number`?(c[n]={},c[n][s.id]=o):n!==`Properties70`&&(n===`PoseNode`?c[n]=[o]:c[n]=o),typeof s.id==`number`&&(o.id=s.id),s.name!==``&&(o.attrName=s.name),s.type!==``&&(o.attrType=s.type),this.pushStack(o)}parseNodeAttr(e){let t=e[0];e[0]!==``&&(t=parseInt(e[0]),isNaN(t)&&(t=e[0]));let n=``,r=``;return e.length>1&&(n=e[1].replace(/^(\w+)::/,``),r=e[2]),{id:t,name:n,type:r}}parseNodeProperty(e,t,n){let r=t[1].replace(/^"/,``).replace(/"$/,``).trim(),o=t[2].replace(/^"/,``).replace(/"$/,``).trim();r===`Content`&&o===`,`&&(o=n.replace(/"/g,``).replace(/,$/,``).trim());let s=this.getCurrentNode();if(s.name===`Properties70`){this.parseNodeSpecialProperty(e,r,o);return}if(r===`C`){let e=o.split(`,`).slice(1),t=parseInt(e[0]),n=parseInt(e[1]),c=o.split(`,`).slice(3);c=c.map(function(e){return e.trim().replace(/^"/,``)}),r=`connections`,o=[t,n],append(o,c),s[r]===void 0&&(s[r]=[])}r===`Node`&&(s.id=o),r in s&&Array.isArray(s[r])?s[r].push(o):r===`a`?s.a=o:s[r]=o,this.setCurrentProp(s,r),r===`a`&&o.slice(-1)!==`,`&&(s.a=parseNumberArray(o))}parseNodePropertyContinued(e){let t=this.getCurrentNode();t.a+=e,e.slice(-1)!==`,`&&(t.a=parseNumberArray(t.a))}parseNodeSpecialProperty(e,t,n){let r=n.split(`",`).map(function(e){return e.trim().replace(/^\"/,``).replace(/\s/,`_`)}),o=r[0],s=r[1],c=r[2],l=r[3],u=r[4];switch(s){case`int`:case`enum`:case`bool`:case`ULongLong`:case`double`:case`Number`:case`FieldOfView`:u=parseFloat(u);break;case`Color`:case`ColorRGB`:case`Vector3D`:case`Lcl_Translation`:case`Lcl_Rotation`:case`Lcl_Scaling`:u=parseNumberArray(u);break}this.getPrevNode()[o]={type:s,type2:c,flag:l,value:u},this.setCurrentProp(this.getPrevNode(),o)}},BinaryParser=class{parse(e){let t=new BinaryReader(e);t.skip(23);let n=t.getUint32();if(n<6400)throw Error(`THREE.FBXLoader: FBX version not supported, FileVersion: `+n);let r=new FBXTree;for(;!this.endOfContent(t);){let e=this.parseNode(t,n);e!==null&&r.add(e.name,e)}return r}endOfContent(e){return e.size()%16==0?(e.getOffset()+160+16&-16)>=e.size():e.getOffset()+160+16>=e.size()}parseNode(e,t){let n={},r=t>=7500?e.getUint64():e.getUint32(),o=t>=7500?e.getUint64():e.getUint32();t>=7500?e.getUint64():e.getUint32();let s=e.getUint8(),c=e.getString(s);if(r===0)return null;let l=[];for(let t=0;t<o;t++)l.push(this.parseProperty(e));let u=l.length>0?l[0]:``,d=l.length>1?l[1]:``,f=l.length>2?l[2]:``;for(n.singleProperty=o===1&&e.getOffset()===r;r>e.getOffset();){let r=this.parseNode(e,t);r!==null&&this.parseSubNode(c,n,r)}return n.propertyList=l,typeof u==`number`&&(n.id=u),d!==``&&(n.attrName=d),f!==``&&(n.attrType=f),c!==``&&(n.name=c),n}parseSubNode(e,t,n){if(n.singleProperty===!0){let e=n.propertyList[0];Array.isArray(e)?(t[n.name]=n,n.a=e):t[n.name]=e}else if(e===`Connections`&&n.name===`C`){let e=[];n.propertyList.forEach(function(t,n){n!==0&&e.push(t)}),t.connections===void 0&&(t.connections=[]),t.connections.push(e)}else if(n.name===`Properties70`)Object.keys(n).forEach(function(e){t[e]=n[e]});else if(e===`Properties70`&&n.name===`P`){let e=n.propertyList[0],r=n.propertyList[1],o=n.propertyList[2],s=n.propertyList[3],c;e.indexOf(`Lcl `)===0&&(e=e.replace(`Lcl `,`Lcl_`)),r.indexOf(`Lcl `)===0&&(r=r.replace(`Lcl `,`Lcl_`)),c=r===`Color`||r===`ColorRGB`||r===`Vector`||r===`Vector3D`||r.indexOf(`Lcl_`)===0?[n.propertyList[4],n.propertyList[5],n.propertyList[6]]:n.propertyList[4],t[e]={type:r,type2:o,flag:s,value:c}}else t[n.name]===void 0?typeof n.id==`number`?(t[n.name]={},t[n.name][n.id]=n):t[n.name]=n:n.name===`PoseNode`?(Array.isArray(t[n.name])||(t[n.name]=[t[n.name]]),t[n.name].push(n)):t[n.name][n.id]===void 0&&(t[n.name][n.id]=n)}parseProperty(e){let t=e.getString(1),n;switch(t){case`C`:return e.getBoolean();case`D`:return e.getFloat64();case`F`:return e.getFloat32();case`I`:return e.getInt32();case`L`:return e.getInt64();case`R`:return n=e.getUint32(),e.getArrayBuffer(n);case`S`:return n=e.getUint32(),e.getString(n);case`Y`:return e.getInt16();case`b`:case`c`:case`d`:case`f`:case`i`:case`l`:let r=e.getUint32(),o=e.getUint32(),s=e.getUint32();if(o===0)switch(t){case`b`:case`c`:return e.getBooleanArray(r);case`d`:return e.getFloat64Array(r);case`f`:return e.getFloat32Array(r);case`i`:return e.getInt32Array(r);case`l`:return e.getInt64Array(r)}let c=new BinaryReader(unzlibSync(new Uint8Array(e.getArrayBuffer(s))).buffer);switch(t){case`b`:case`c`:return c.getBooleanArray(r);case`d`:return c.getFloat64Array(r);case`f`:return c.getFloat32Array(r);case`i`:return c.getInt32Array(r);case`l`:return c.getInt64Array(r)}break;default:throw Error(`THREE.FBXLoader: Unknown property type `+t)}}},BinaryReader=class{constructor(e,t){this.dv=new DataView(e),this.offset=0,this.littleEndian=t===void 0?!0:t,this._textDecoder=new TextDecoder}getOffset(){return this.offset}size(){return this.dv.buffer.byteLength}skip(e){this.offset+=e}getBoolean(){return(this.getUint8()&1)==1}getBooleanArray(e){let t=[];for(let n=0;n<e;n++)t.push(this.getBoolean());return t}getUint8(){let e=this.dv.getUint8(this.offset);return this.offset+=1,e}getInt16(){let e=this.dv.getInt16(this.offset,this.littleEndian);return this.offset+=2,e}getInt32(){let e=this.dv.getInt32(this.offset,this.littleEndian);return this.offset+=4,e}getInt32Array(e){let t=[];for(let n=0;n<e;n++)t.push(this.getInt32());return t}getUint32(){let e=this.dv.getUint32(this.offset,this.littleEndian);return this.offset+=4,e}getInt64(){let e,t;return this.littleEndian?(e=this.getUint32(),t=this.getUint32()):(t=this.getUint32(),e=this.getUint32()),t&2147483648?(t=~t&4294967295,e=~e&4294967295,e===4294967295&&(t=t+1&4294967295),e=e+1&4294967295,-(t*4294967296+e)):t*4294967296+e}getInt64Array(e){let t=[];for(let n=0;n<e;n++)t.push(this.getInt64());return t}getUint64(){let e,t;return this.littleEndian?(e=this.getUint32(),t=this.getUint32()):(t=this.getUint32(),e=this.getUint32()),t*4294967296+e}getFloat32(){let e=this.dv.getFloat32(this.offset,this.littleEndian);return this.offset+=4,e}getFloat32Array(e){let t=[];for(let n=0;n<e;n++)t.push(this.getFloat32());return t}getFloat64(){let e=this.dv.getFloat64(this.offset,this.littleEndian);return this.offset+=8,e}getFloat64Array(e){let t=[];for(let n=0;n<e;n++)t.push(this.getFloat64());return t}getArrayBuffer(e){let t=this.dv.buffer.slice(this.offset,this.offset+e);return this.offset+=e,t}getString(e){let t=this.offset,n=new Uint8Array(this.dv.buffer,t,e);this.skip(e);let r=n.indexOf(0);return r>=0&&(n=new Uint8Array(this.dv.buffer,t,r)),this._textDecoder.decode(n)}},FBXTree=class{constructor(){this.Connections={connections:[]},this.Objects={Model:{},NodeAttribute:{},Geometry:{}},this.GlobalSettings={}}add(e,t){this[e]=t}};function isFbxFormatBinary(e){return e.byteLength>=21&&convertArrayBufferToString(e,0,21)===`Kaydara FBX Binary \0`}function isFbxFormatASCII(e){let t=[`K`,`a`,`y`,`d`,`a`,`r`,`a`,`\\`,`F`,`B`,`X`,`\\`,`B`,`i`,`n`,`a`,`r`,`y`,`\\`,`\\`],n=0;function r(t){let r=e[t-1];return e=e.slice(n+t),n++,r}for(let e=0;e<t.length;++e)if(r(1)===t[e])return!1;return!0}function getFbxVersion(e){let t=e.match(/FBXVersion: (\d+)/);if(t)return parseInt(t[1]);throw Error(`THREE.FBXLoader: Cannot find the version number for the file given.`)}function convertFBXTimeToSeconds(e){return e/46186158e3}var dataArray=[];function getData(e,t,n,r){let o;switch(r.mappingType){case`ByPolygonVertex`:o=e;break;case`ByPolygon`:o=t;break;case`ByVertice`:o=n;break;case`AllSame`:o=r.indices[0];break;default:console.warn(`THREE.FBXLoader: unknown attribute mapping type `+r.mappingType),o=0}r.referenceType===`IndexToDirect`&&(o=r.indices[o]);let s=o*r.dataSize,c=s+r.dataSize;return slice(dataArray,r.buffer,s,c)}var tempEuler=new three.Euler,tempVec=new three.Vector3;function generateTransform(e){let t=new three.Matrix4,n=new three.Matrix4,r=new three.Matrix4,o=new three.Matrix4,s=new three.Matrix4,c=new three.Matrix4,l=new three.Matrix4,u=new three.Matrix4,d=new three.Matrix4,f=new three.Matrix4,p=new three.Matrix4,m=new three.Matrix4,h=e.inheritType?e.inheritType:0;e.translation&&t.setPosition(tempVec.fromArray(e.translation));let g=getEulerOrder(0);if(e.preRotation){let t=e.preRotation.map(three.MathUtils.degToRad);t.push(g),n.makeRotationFromEuler(tempEuler.fromArray(t))}if(e.rotation){let t=e.rotation.map(three.MathUtils.degToRad);t.push(e.eulerOrder||g),r.makeRotationFromEuler(tempEuler.fromArray(t))}if(e.postRotation){let t=e.postRotation.map(three.MathUtils.degToRad);t.push(g),o.makeRotationFromEuler(tempEuler.fromArray(t)),o.copy(new three.Matrix4().getInverse(o))}e.scale&&s.scale(tempVec.fromArray(e.scale)),e.scalingOffset&&l.setPosition(tempVec.fromArray(e.scalingOffset)),e.scalingPivot&&c.setPosition(tempVec.fromArray(e.scalingPivot)),e.rotationOffset&&u.setPosition(tempVec.fromArray(e.rotationOffset)),e.rotationPivot&&d.setPosition(tempVec.fromArray(e.rotationPivot)),e.parentMatrixWorld&&(p.copy(e.parentMatrix),f.copy(e.parentMatrixWorld));let _=n.clone().multiply(r).multiply(o),v=new three.Matrix4;v.extractRotation(f);let y=new three.Matrix4;y.copyPosition(f);let b=new three.Matrix4().getInverse(y).multiply(f),S=new three.Matrix4().getInverse(v).multiply(b),C=s,w=new three.Matrix4;if(h===0)w.copy(v).multiply(_).multiply(S).multiply(C);else if(h===1)w.copy(v).multiply(S).multiply(_).multiply(C);else{let e=new three.Matrix4().scale(new three.Vector3().setFromMatrixScale(p)),t=new three.Matrix4().getInverse(e),n=S.clone().multiply(t);w.copy(v).multiply(_).multiply(n).multiply(C)}let T=new three.Matrix4().getInverse(d),E=new three.Matrix4().getInverse(c),D=t.clone().multiply(u).multiply(d).multiply(n).multiply(r).multiply(o).multiply(T).multiply(l).multiply(c).multiply(s).multiply(E),O=new three.Matrix4().copyPosition(D),k=f.clone().multiply(O);return m.copyPosition(k),D=m.clone().multiply(w),D.premultiply(new three.Matrix4().getInverse(f)),D}function getEulerOrder(e){e=e||0;let t=[`ZYX`,`YZX`,`XZY`,`ZXY`,`YXZ`,`XYZ`];return e===6?(console.warn(`THREE.FBXLoader: unsupported Euler Order: Spherical XYZ. Animations and rotations may be incorrect.`),t[0]):t[e]}function parseNumberArray(e){return e.split(`,`).map(function(e){return parseFloat(e)})}function convertArrayBufferToString(e,t,n){return t===void 0&&(t=0),n===void 0&&(n=e.byteLength),new TextDecoder().decode(new Uint8Array(e,t,n))}function append(e,t){for(let n=0,r=e.length,o=t.length;n<o;n++,r++)e[r]=t[n]}function slice(e,t,n,r){for(let o=n,s=0;o<r;o++,s++)e[s]=t[o];return e}var NURBSCurve=class extends three.Curve{constructor(e,t,n,r,o){super();let s=t?t.length-1:0,c=n?n.length:0;this.degree=e,this.knots=t,this.controlPoints=[],this.startKnot=r||0,this.endKnot=o||s;for(let e=0;e<c;++e){let t=n[e];this.controlPoints[e]=new three.Vector4(t.x,t.y,t.z,t.w)}}getPoint(e,t=new three.Vector3){let n=t,r=this.knots[this.startKnot]+e*(this.knots[this.endKnot]-this.knots[this.startKnot]),o=calcBSplinePoint(this.degree,this.knots,this.controlPoints,r);return o.w!==1&&o.divideScalar(o.w),n.set(o.x,o.y,o.z)}getTangent(e,t=new three.Vector3){let n=t,r=this.knots[0]+e*(this.knots[this.knots.length-1]-this.knots[0]),o=calcNURBSDerivatives(this.degree,this.knots,this.controlPoints,r,1);return n.copy(o[1]).normalize(),n}toJSON(){let e=super.toJSON();return e.degree=this.degree,e.knots=[...this.knots],e.controlPoints=this.controlPoints.map(e=>e.toArray()),e.startKnot=this.startKnot,e.endKnot=this.endKnot,e}fromJSON(e){return super.fromJSON(e),this.degree=e.degree,this.knots=[...e.knots],this.controlPoints=e.controlPoints.map(e=>new three.Vector4(e[0],e[1],e[2],e[3])),this.startKnot=e.startKnot,this.endKnot=e.endKnot,this}};function findSpan(e,t,n){let r=n.length-e-1;if(t>=n[r])return r-1;if(t<=n[e])return e;let o=e,s=r,c=Math.floor((o+s)/2);for(;t<n[c]||t>=n[c+1];)t<n[c]?s=c:o=c,c=Math.floor((o+s)/2);return c}function calcBasisFunctions(e,t,n,r){let o=[],s=[],c=[];o[0]=1;for(let l=1;l<=n;++l){s[l]=t-r[e+1-l],c[l]=r[e+l]-t;let n=0;for(let e=0;e<l;++e){let t=c[e+1],r=s[l-e],u=o[e]/(t+r);o[e]=n+t*u,n=r*u}o[l]=n}return o}function calcBSplinePoint(e,t,n,r){let o=findSpan(e,r,t),s=calcBasisFunctions(o,r,e,t),c=new three.Vector4(0,0,0,0);for(let t=0;t<=e;++t){let r=n[o-e+t],l=s[t],u=r.w*l;c.x+=r.x*u,c.y+=r.y*u,c.z+=r.z*u,c.w+=r.w*l}return c}function calcBasisFunctionDerivatives(e,t,n,r,o){let s=[];for(let e=0;e<=n;++e)s[e]=0;let c=[];for(let e=0;e<=r;++e)c[e]=s.slice(0);let l=[];for(let e=0;e<=n;++e)l[e]=s.slice(0);l[0][0]=1;let u=s.slice(0),d=s.slice(0);for(let r=1;r<=n;++r){u[r]=t-o[e+1-r],d[r]=o[e+r]-t;let n=0;for(let e=0;e<r;++e){let t=d[e+1],o=u[r-e];l[r][e]=t+o;let s=l[e][r-1]/l[r][e];l[e][r]=n+t*s,n=o*s}l[r][r]=n}for(let e=0;e<=n;++e)c[0][e]=l[e][n];for(let e=0;e<=n;++e){let t=0,o=1,u=[];for(let e=0;e<=n;++e)u[e]=s.slice(0);u[0][0]=1;for(let s=1;s<=r;++s){let r=0,d=e-s,f=n-s;e>=s&&(u[o][0]=u[t][0]/l[f+1][d],r=u[o][0]*l[d][f]);let p=d>=-1?1:-d,m=e-1<=f?s-1:n-e;for(let e=p;e<=m;++e)u[o][e]=(u[t][e]-u[t][e-1])/l[f+1][d+e],r+=u[o][e]*l[d+e][f];e<=f&&(u[o][s]=-u[t][s-1]/l[f+1][e],r+=u[o][s]*l[e][f]),c[s][e]=r;let h=t;t=o,o=h}}let f=n;for(let e=1;e<=r;++e){for(let t=0;t<=n;++t)c[e][t]*=f;f*=n-e}return c}function calcBSplineDerivatives(e,t,n,r,o){let s=o<e?o:e,c=[],l=findSpan(e,r,t),u=calcBasisFunctionDerivatives(l,r,e,s,t),d=[];for(let e=0;e<n.length;++e){let t=n[e].clone(),r=t.w;t.x*=r,t.y*=r,t.z*=r,d[e]=t}for(let t=0;t<=s;++t){let n=d[l-e].clone().multiplyScalar(u[t][0]);for(let r=1;r<=e;++r)n.add(d[l-e+r].clone().multiplyScalar(u[t][r]));c[t]=n}for(let e=s+1;e<=o+1;++e)c[e]=new three.Vector4(0,0,0);return c}function calcKoverI(e,t){let n=1;for(let t=2;t<=e;++t)n*=t;let r=1;for(let e=2;e<=t;++e)r*=e;for(let n=2;n<=e-t;++n)r*=n;return n/r}function calcRationalCurveDerivatives(e){let t=e.length,n=[],r=[];for(let o=0;o<t;++o){let t=e[o];n[o]=new three.Vector3(t.x,t.y,t.z),r[o]=t.w}let o=[];for(let e=0;e<t;++e){let t=n[e].clone();for(let n=1;n<=e;++n)t.sub(o[e-n].clone().multiplyScalar(calcKoverI(e,n)*r[n]));o[e]=t.divideScalar(r[0])}return o}function calcNURBSDerivatives(e,t,n,r,o){return calcRationalCurveDerivatives(calcBSplineDerivatives(e,t,n,r,o))}var _vector=new three.Vector3;function getPointArray(e,t){switch(t){case`D`:return new Float64Array(e);case`F`:return new Float32Array(e);case`L`:return new Int32Array(e);case`I`:return new Int16Array(e);default:return new Uint8Array(e)}}function loadX3p(e,t={}){var n,r,o;let s=(n=t.upAxis)==null?`Z`:n,c=(r=t.fetcher)==null?internalFetcher:r,l=(o=t.onDownloadProgress)==null?noop:o,u={byteLength:0};return Promise.resolve().then(()=>c.ajax(e,{responseType:`arraybuffer`},void 0,void 0,l)).then(n=>{var r,o;return u.byteLength=n.body.byteLength,parse$1(new Uint8Array(n.body),{light:(r=t.light)==null?!0:r,color:t.color,resourcePath:e.slice(0,e.lastIndexOf(`/`)+1),search:(o=e.split(`?`)[1])==null?``:o,fetcher:c})}).then(t=>{let n=new three.Group;return n.name=e,n.add(t.object),s===`Y`&&n.applyMatrix4(ROTATE_X_MATRIX_INVERSE$1),{type:`x3p`,modelUpAxis:`Z`,upAxis:s,uri:e,byteLength:u.byteLength,memoryUsage:getMemoryUsage(n),scene:n,textures:[],animations:[],dispose:()=>t.dispose()}})}function parse$1(e,t){var n,r,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b,S,C,w,T,E,D,O,k,A,j,M,N,P,F,I,L,R,z,B,V,H,ee,te,U,W,G,K,ne,re,ie,ae,oe,q,se,ce,le,ue;let J=unzipSync(e),de=``,fe=null;for(let e of Object.keys(J))/(^|\/)main\.xml$/i.test(e)&&(fe=J[e],de=e.slice(0,e.lastIndexOf(`/`)+1));if(!fe)throw Error(`X3p: main.xml not found.`);if(typeof DOMParser>`u`)throw Error(`X3p: DOMParser not found.`);let pe=(n=t.color)==null?new three.Color(10066329):n,me=new DOMParser,he=decodeText(fe),ge=me.parseFromString(he,`text/xml`),Y=ge.querySelector(`Record1 Axes`),_e={x:{type:(s=(o=(r=Y==null?void 0:Y.querySelector(`CX AxisType`))==null?void 0:r.textContent)==null?void 0:o.toUpperCase())==null?`I`:s,dataType:(u=(l=(c=Y==null?void 0:Y.querySelector(`CX DataType`))==null?void 0:c.textContent)==null?void 0:l.toUpperCase())==null?`D`:u,increment:Number((f=(d=Y==null?void 0:Y.querySelector(`CX Increment`))==null?void 0:d.textContent)==null?`1`:f),offset:Number((m=(p=Y==null?void 0:Y.querySelector(`CX Offset`))==null?void 0:p.textContent)==null?`0`:m)},y:{type:(_=(g=(h=Y==null?void 0:Y.querySelector(`CY AxisType`))==null?void 0:h.textContent)==null?void 0:g.toUpperCase())==null?`I`:_,dataType:(b=(y=(v=Y==null?void 0:Y.querySelector(`CY DataType`))==null?void 0:v.textContent)==null?void 0:y.toUpperCase())==null?`D`:b,increment:Number((C=(S=Y==null?void 0:Y.querySelector(`CY Increment`))==null?void 0:S.textContent)==null?`1`:C),offset:Number((T=(w=Y==null?void 0:Y.querySelector(`CY Offset`))==null?void 0:w.textContent)==null?`0`:T)},z:{type:(O=(D=(E=Y==null?void 0:Y.querySelector(`CZ AxisType`))==null?void 0:E.textContent)==null?void 0:D.toUpperCase())==null?`A`:O,dataType:(j=(A=(k=Y==null?void 0:Y.querySelector(`CZ DataType`))==null?void 0:k.textContent)==null?void 0:A.toUpperCase())==null?`D`:j,increment:Number((N=(M=Y==null?void 0:Y.querySelector(`CZ Increment`))==null?void 0:M.textContent)==null?`1`:N),offset:Number((F=(P=Y==null?void 0:Y.querySelector(`CZ Offset`))==null?void 0:P.textContent)==null?`0`:F)}},ve=null,X=ge.querySelector(`Record1 Axes Rotation`);X&&(ve=new three.Matrix3,ve.set(Number((L=(I=X.querySelector(`r11`))==null?void 0:I.textContent)==null?0:L),Number((z=(R=X.querySelector(`r12`))==null?void 0:R.textContent)==null?0:z),Number((V=(B=X.querySelector(`r13`))==null?void 0:B.textContent)==null?0:V),Number((ee=(H=X.querySelector(`r21`))==null?void 0:H.textContent)==null?0:ee),Number((U=(te=X.querySelector(`r22`))==null?void 0:te.textContent)==null?0:U),Number((G=(W=X.querySelector(`r23`))==null?void 0:W.textContent)==null?0:G),Number((ne=(K=X.querySelector(`r31`))==null?void 0:K.textContent)==null?0:ne),Number((ie=(re=X.querySelector(`r32`))==null?void 0:re.textContent)==null?0:ie),Number((oe=(ae=X.querySelector(`r33`))==null?void 0:ae.textContent)==null?0:oe)));let ye=(q=ge.querySelector(`Record3 DataLink PointDataLink`))==null?void 0:q.textContent;if(typeof ye!=`string`)throw Error(`X3p: PointDataLink not found.`);ye=pathJoin(de,ye);let be=J[ye];if(!be)throw Error(`X3p: ${be} not found.`);let xe=getPointArray(be.buffer,_e.z.dataType),Se=Number((ce=(se=ge.querySelector(`Record3 MatrixDimension SizeX`))==null?void 0:se.textContent)==null?`0`:ce),Ce=Number((ue=(le=ge.querySelector(`Record3 MatrixDimension SizeY`))==null?void 0:le.textContent)==null?`0`:ue),we=Math.floor(Se-1),Te=Math.floor(Ce-1),Ee=we+1,De=Te+1,Oe=new Float32Array(Ee*De*3),ke=new Float32Array(Ee*De*2),Ae=new Uint32Array(we*Te*6),je=new three.Box3;for(let e=0;e<De;e++){let t=e*_e.y.increment+_e.y.offset;for(let n=0;n<Ee;n++){let r=e*Ee+n,o=n*_e.x.increment+_e.x.offset,s=xe[r],c=!isNaN(s),l=c?s:NaN;_vector.set(o,-t,l),ve&&_vector.applyMatrix3(ve),c&&je.expandByPoint(_vector),Oe[r*3+0]=_vector.x,Oe[r*3+1]=_vector.y,Oe[r*3+2]=_vector.z,ke[r*2+0]=n/we,ke[r*2+1]=1-e/Te}}for(let e=0;e<Te;e++)for(let t=0;t<we;t++){let n=t+Ee*e,r=t+Ee*(e+1),o=t+1+Ee*(e+1),s=t+1+Ee*e,c=(e*we+t)*6;Ae[c+0]=n,Ae[c+1]=r,Ae[c+2]=s,Ae[c+3]=r,Ae[c+4]=o,Ae[c+5]=s}let Z=new three.BufferGeometry;Z.setAttribute(`position`,new three.BufferAttribute(Oe,3)),Z.setAttribute(`uv`,new three.BufferAttribute(ke,2)),Z.setIndex(new three.BufferAttribute(Ae,1)),(!Z.groups||Z.groups.length===0)&&Z.addGroup(0,Z.index?Z.index.count:Z.attributes.position.count,0),Z.boundingBox=je;let Me=new PBMMeshMaterial(t.light?`phong`:`basic`);return Me.flatShading=!0,Me.color.copy(pe),{object:new PBMMesh(Z,[Me]),dispose:()=>{Z.dispose(),Me.dispose()}}}function parseSplatData(e){let t=32,n=e.length/32;if(e.length%32!=0)throw Error(`Invalid splat file: data length ${e.length} is not a multiple of 32`);let r=new Float32Array(3*n),o=new Float32Array(4*n),s=new Float32Array(3*n),c=new Uint8Array(4*n),l=new Float32Array(e.buffer),u=new Uint8Array(e.buffer);for(let e=0;e<n;e++)r[3*e+0]=l[8*e+0],r[3*e+1]=l[8*e+1],r[3*e+2]=l[8*e+2],s[3*e+0]=l[8*e+3+0],s[3*e+1]=l[8*e+3+1],s[3*e+2]=l[8*e+3+2],c[4*e+0]=u[32*e+24+0],c[4*e+1]=u[32*e+24+1],c[4*e+2]=u[32*e+24+2],c[4*e+3]=u[32*e+24+3],o[4*e+0]=(u[32*e+28+0]-128)/128,o[4*e+1]=(u[32*e+28+1]-128)/128,o[4*e+2]=(u[32*e+28+2]-128)/128,o[4*e+3]=(u[32*e+28+3]-128)/128;return{numPoints:n,positions:r,scales:s,rotations:o,colors:c}}function loadSplat(e,t={}){var n,r,o,s;let c=(n=t.modelUpAxis)==null?`Y`:n,l=(r=t.upAxis)==null?`Z`:r,u=(o=t.fetcher)==null?internalFetcher:o,d=(s=t.onDownloadProgress)==null?noop:s,f=0;return Promise.resolve().then(()=>u.ajax(e,{responseType:`arraybuffer`},void 0,void 0,d)).then(e=>(f=e.body.byteLength,e.body)).then(e=>parseSplatData(new Uint8Array(e))).then(t=>{let n=new PBMGaussianSplattingObject({positions:t.positions,scales:t.scales,rotations:t.rotations,colors:t.colors,numPoints:t.numPoints});return c===`Y`&&n.applyMatrix4(ROTATE_X_MATRIX$1),{type:`splat`,modelUpAxis:c,upAxis:l,uri:e,byteLength:f,memoryUsage:getMemoryUsage(n),scene:n,textures:[],animations:[],dispose:()=>n.dispose()}})}var VolumePlaneIntersect;(function(e){e[e.Outside=-1]=`Outside`,e[e.Intersecting=0]=`Intersecting`,e[e.Inside=1]=`Inside`})(VolumePlaneIntersect||(VolumePlaneIntersect={}));var EPSILON$2=1e-6,identityMatrix4$1=new three.Matrix4().identity(),scratchVector=new three.Vector3,scratchMatrix4$5=new three.Matrix4,scratchXAxis=new three.Vector3,scratchYAxis=new three.Vector3,scratchZAxis=new three.Vector3,scratchSize=new three.Vector3,scratchBox3$1=new three.Box3,scratchSphere$2=new three.Sphere,scratchMatrix4Inverse$1=new three.Matrix4,scratchRay$1=new three.Ray,scratchObject3D=new three.Object3D,scratchFrustum=new three.Frustum;function quaternionFromMatrix3(e,t){let n=e.elements;return t.setFromRotationMatrix(scratchMatrix4$5.set(n[0],n[3],n[6],0,n[1],n[4],n[7],0,n[2],n[5],n[8],0,0,0,0,1)),t}var CullingVolume=class e{static get MASK_OUTSIDE(){return 4294967295}static get MASK_INSIDE(){return 0}static get MASK_INDETERMINATE(){return 2147483647}constructor(e=[]){this.planes=e}setFromFrustum(e){return this.planes=e.planes.map(e=>e.clone()),this}setFromCamera(e){return scratchMatrix4$5.multiplyMatrices(e.projectionMatrix,e.matrixWorldInverse),scratchFrustum.setFromProjectionMatrix(scratchMatrix4$5),this.setFromFrustum(scratchFrustum),this}applyMatrix4(e){for(let t of this.planes)t.applyMatrix4(e)}copy(e){return this.planes=e.planes.map(e=>e.clone()),this}clone(){return new e().copy(this)}computeVisibility(e){let t=VolumePlaneIntersect.Inside;for(let n of this.planes)switch(e.intersectPlane(n)){case VolumePlaneIntersect.Outside:return VolumePlaneIntersect.Outside;case VolumePlaneIntersect.Intersecting:t=VolumePlaneIntersect.Intersecting;break;default:}return t}computeVisibilityWithPlaneMask(t,n){if(n===e.MASK_OUTSIDE||n===e.MASK_INSIDE)return n;let r=e.MASK_INSIDE,o=Math.min(32,this.planes.length);for(let s=0;s<o;++s){let o=1<<s;if((n&o)===0)continue;let c=this.planes[s],l=t.intersectPlane(c);if(l===VolumePlaneIntersect.Outside)return e.MASK_OUTSIDE;l===VolumePlaneIntersect.Intersecting&&(r|=o)}return r}},BoxBoundingVolume=class e{constructor(){this.type=`box`,this.center=new three.Vector3,this.halfSize=new three.Vector3,this.rotation=new three.Matrix3}fromJson({box:e}){this.center.set(e[0],e[1],e[2]);let t=e[3],n=e[4],r=e[5],o=e[6],s=e[7],c=e[8],l=e[9],u=e[10],d=e[11],f=Math.max(Math.sqrt(t*t+n*n+r*r),.001),p=Math.max(Math.sqrt(o*o+s*s+c*c),.001),m=Math.max(Math.sqrt(l*l+u*u+d*d),.001);this.halfSize.set(f,p,m);let h=this.halfSize.toArray().reduce((e,t)=>e+t,0);return(isNaN(h)||h<=0)&&this.halfSize.setScalar(EPSILON$2),this.rotation.fromArray([t/f,n/f,r/f,o/p,s/p,c/p,l/m,u/m,d/m]),isNaN(this.rotation.toArray().reduce((e,t)=>e+t,0))&&this.rotation.identity(),this}toJson(){return this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),{box:[...this.center.toArray(),...scratchXAxis.multiplyScalar(this.halfSize.x).toArray(),...scratchYAxis.multiplyScalar(this.halfSize.y).toArray(),...scratchZAxis.multiplyScalar(this.halfSize.z).toArray()]}}copy(e){return this.center.copy(e.center),this.halfSize.copy(e.halfSize),this.rotation.copy(e.rotation),this}clone(){return new e().copy(this)}applyMatrix4(e){return e.equals(identityMatrix4$1)?this:(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(e),scratchObject3D.matrix.decompose(scratchObject3D.position,scratchObject3D.quaternion,scratchObject3D.scale),this.center.copy(scratchObject3D.position),this.rotation.setFromMatrix4(scratchMatrix4$5.makeRotationFromQuaternion(scratchObject3D.quaternion)),this.halfSize.copy(scratchObject3D.scale),this)}getCenter(e){return e.copy(this.center)}distanceSquaredToPoint(e){let t=this.rotation.elements,n=e.x-this.center.x,r=e.y-this.center.y,o=e.z-this.center.z,s=0,c;return c=n*t[0]+r*t[1]+o*t[2],c<0&&(c=-c),c-=this.halfSize.x,c>0&&(s+=c*c),c=n*t[3]+r*t[4]+o*t[5],c<0&&(c=-c),c-=this.halfSize.y,c>0&&(s+=c*c),c=n*t[6]+r*t[7]+o*t[8],c<0&&(c=-c),c-=this.halfSize.z,c>0&&(s+=c*c),s}distanceToPoint(e){return Math.sqrt(this.distanceSquaredToPoint(e))}distanceToPlane(e){let t=e.projectPoint(this.center,new three.Vector3);return this.distanceToPoint(t)}getBoundingBox(e){return e.makeEmpty(),this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchXAxis.setLength(this.halfSize.x),scratchYAxis.setLength(this.halfSize.y),scratchZAxis.setLength(this.halfSize.z),e.expandByPoint(scratchVector.copy(this.center).add(scratchXAxis)),e.expandByPoint(scratchVector.copy(this.center).sub(scratchXAxis)),e.expandByPoint(scratchVector.copy(this.center).add(scratchYAxis)),e.expandByPoint(scratchVector.copy(this.center).sub(scratchYAxis)),e.expandByPoint(scratchVector.copy(this.center).add(scratchZAxis)),e.expandByPoint(scratchVector.copy(this.center).sub(scratchZAxis)),e}toGeometry(){let e=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(24);scratchVector.set(this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,0),scratchVector.set(-this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,3),scratchVector.set(-this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,6),scratchVector.set(this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,9),scratchVector.set(this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,12),scratchVector.set(-this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,15),scratchVector.set(-this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,18),scratchVector.set(this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,21);let n=new three.BufferGeometry;return n.setIndex(new three.BufferAttribute(e,1)),n.setAttribute(`position`,new three.BufferAttribute(t,3)),n.computeBoundingBox(),n.computeBoundingSphere(),n}intersectPlane(e){let t=this.center,n=e.normal,r=this.rotation.elements,o=this.halfSize,s=n.x,c=n.y,l=n.z,u=Math.abs(s*r[0]*o.x+c*r[1]*o.x+l*r[2]*o.x)+Math.abs(s*r[3]*o.y+c*r[4]*o.y+l*r[5]*o.y)+Math.abs(s*r[6]*o.z+c*r[7]*o.z+l*r[8]*o.z),d=n.dot(t)+e.constant;return d<=-u?VolumePlaneIntersect.Outside:d>=u?VolumePlaneIntersect.Inside:VolumePlaneIntersect.Intersecting}intersectRay(e,t=0,n){if(scratchSize.copy(this.halfSize).multiplyScalar(2),scratchBox3$1.setFromCenterAndSize(scratchVector.set(0,0,0),scratchSize),scratchBox3$1.expandByScalar(t),this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchMatrix4$5.makeBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchMatrix4$5.setPosition(this.center),scratchMatrix4Inverse$1.getInverse(scratchMatrix4$5),scratchRay$1.copy(e).applyMatrix4(scratchMatrix4Inverse$1),scratchBox3$1.containsPoint(scratchRay$1.origin))return!0;let r=scratchRay$1.intersectBox(scratchBox3$1,scratchVector);return r?n===void 0?!0:(n+=t,r.distanceToSquared(scratchRay$1.origin)<=n*n):!1}},SphereBoundingVolume=class e{constructor(){this.type=`sphere`,this.center=new three.Vector3,this.radius=-1}fromJson({sphere:e}){return this.center.set(e[0],e[1],e[2]),this.radius=Math.max(e[3],EPSILON$2),this}toJson(){return{sphere:[...this.center.toArray(),this.radius]}}copy(e){return this.center.copy(e.center),this.radius=e.radius,this}clone(){return new e().copy(this)}getBoundingBox(e){return e.setFromCenterAndSize(this.center,scratchSize.set(1,1,1).multiplyScalar(this.radius*2)),e}toGeometry(){let e=32,t=new Float32Array(384);for(let e=0;e<=32;e++){let n=0;n=e/32*Math.PI*2,t[e*6+0]=this.center.x+Math.cos(n)*this.radius,t[e*6+1]=this.center.y+Math.sin(n)*this.radius,t[e*6+2]=this.center.z+0,n=(e+1)/32*Math.PI*2,t[e*6+3]=this.center.x+Math.cos(n)*this.radius,t[e*6+4]=this.center.y+Math.sin(n)*this.radius,t[e*6+5]=this.center.z+0}for(let e=32;e<=64;e++){let n=0;n=e/32*Math.PI*2,t[e*6+0]=this.center.x+Math.cos(n)*this.radius,t[e*6+1]=this.center.y+0,t[e*6+2]=this.center.z+Math.sin(n)*this.radius,n=(e+1)/32*Math.PI*2,t[e*6+3]=this.center.x+Math.cos(n)*this.radius,t[e*6+4]=this.center.y+0,t[e*6+5]=this.center.z+Math.sin(n)*this.radius}let n=new three.BufferGeometry;return n.setAttribute(`position`,new three.BufferAttribute(t,3)),n.computeBoundingBox(),n.computeBoundingSphere(),n}applyMatrix4(e){return e.equals(identityMatrix4$1)?this:(this.center.applyMatrix4(e),this.radius*=e.getMaxScaleOnAxis(),this)}getCenter(e){return e.copy(this.center)}distanceSquaredToPoint(e){let t=this.distanceToPoint(e);return t*t}distanceToPoint(e){let t=this.center.distanceTo(e)-this.radius;return t<=0?0:t}distanceToPlane(e){let t=Math.abs(e.distanceToPoint(this.center));return Math.max(0,t-this.radius)}intersectPlane(e){let t=this.center,n=this.radius,r=e.normal.dot(t)+e.constant;return r<-n?VolumePlaneIntersect.Outside:r<n?VolumePlaneIntersect.Intersecting:VolumePlaneIntersect.Inside}intersectRay(e,t=0,n){if(scratchSphere$2.set(this.center,this.radius+t),scratchSphere$2.containsPoint(e.origin))return!0;let r=e.intersectSphere(scratchSphere$2,scratchVector);return r?n===void 0?!0:(n+=t,e.origin.distanceToSquared(r)<=n*n):!1}},RegionBoundingVolume=class e{constructor(){throw this.type=`regin`,this.west=0,this.south=0,this.east=0,this.north=0,this.minHeight=0,this.maxHeight=0,Error(`Region bounding volume not supported.`)}fromJson({region:e}){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}toJson(){return{region:[this.west,this.south,this.east,this.north,this.minHeight,this.maxHeight]}}copy(e){return this.west=e.west,this.south=e.south,this.east=e.east,this.north=e.north,this.minHeight=e.minHeight,this.maxHeight=e.maxHeight,this}clone(){return new e().copy(this)}getBoundingBox(e){throw Error(`not implemented`)}toGeometry(){throw Error(`not implemented`)}applyMatrix4(e){throw Error(`not implemented`)}getCenter(e){throw Error(`not implemented`)}distanceToPoint(e){throw Error(`not implemented`)}distanceSquaredToPoint(e){throw Error(`not implemented`)}distanceToPlane(e){throw Error(`not implemented`)}intersectPlane(e){throw Error(`not implemented`)}intersectRay(e,t=0,n){throw Error(`not implemented`)}};function isBoundingVolume(e){return e instanceof BoxBoundingVolume||e instanceof SphereBoundingVolume||e instanceof RegionBoundingVolume}function makeBoundingVolume(e){if(isBoundingVolume(e))return e;if(`box`in e)return new BoxBoundingVolume().fromJson(e);if(`sphere`in e)return new SphereBoundingVolume().fromJson(e);if(`region`in e)return new RegionBoundingVolume().fromJson(e);throw Error(`BoundingVolume ${JSON.stringify(e)} never suppored.`)}var debugMaterials=[4821759,8191922,16637280,16739958,5822969,376977,16747077,9259235,14514687].map(e=>new three.LineBasicMaterial({color:e,depthWrite:!1,depthTest:!0,transparent:!0,opacity:.5})),debugBoxGeometry=(()=>{let e=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(24);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);let n=new three.BufferGeometry;return n.setIndex(new three.BufferAttribute(e,1)),n.setAttribute(`position`,new three.BufferAttribute(t,3)),n.computeBoundingBox(),n.computeBoundingSphere(),n})(),debugSphereGeometry=(()=>{let e=32,t=new Float32Array(384);for(let e=0;e<=32;e++){let n=0;n=e/32*Math.PI*2,t[e*6+0]=Math.cos(n),t[e*6+1]=Math.sin(n),t[e*6+2]=0,n=(e+1)/32*Math.PI*2,t[e*6+3]=Math.cos(n),t[e*6+4]=Math.sin(n),t[e*6+5]=0}for(let e=32;e<=64;e++){let n=0;n=e/32*Math.PI*2,t[e*6+0]=Math.cos(n),t[e*6+1]=0,t[e*6+2]=Math.sin(n),n=(e+1)/32*Math.PI*2,t[e*6+3]=Math.cos(n),t[e*6+4]=0,t[e*6+5]=Math.sin(n)}let n=new three.BufferGeometry;return n.setAttribute(`position`,new three.BufferAttribute(t,3)),n.computeBoundingBox(),n.computeBoundingSphere(),n})();function createDebugBoundingMesh(e,t=0){if(e instanceof BoxBoundingVolume){let n=new three.LineSegments(debugBoxGeometry,debugMaterials[Math.min(t,debugMaterials.length-1)]);return n.position.copy(e.center),quaternionFromMatrix3(e.rotation,n.quaternion),n.scale.set(e.halfSize.x,e.halfSize.y,e.halfSize.z),n.matrix.compose(n.position,n.quaternion,n.scale),n}else if(e instanceof SphereBoundingVolume){let n=new three.LineSegments(debugSphereGeometry,debugMaterials[Math.min(t,debugMaterials.length-1)]);return n.position.copy(e.center),n.scale.set(e.radius,e.radius,e.radius),n.matrix.compose(n.position,n.quaternion,n.scale),n}return null}var scratchVector3$10=new three.Vector3,scratchPlane=new three.Plane,scratchSphereBoundingVolume$1=new SphereBoundingVolume,scratchBoxBoundingVolume$1=new BoxBoundingVolume,Tile=class e{constructor(t,n,r,o){var s,c,l,u;this.parent=null,this.contentParent=null,this.floor=0,this.id=t,this.state={visible:!1,frameNumber:0,selectedFrameNumber:0,requestedFrameNumber:0,touchedFrameNumber:0,distanceToCamera:0,centerZDepth:0,centerScreenY:0,screenSpaceError:0,visibilityPlaneMask:0,inRequestVolume:!1,shouldRefine:!1,stackLength:0,finalResolution:!0,selectionDepth:0,shouldSelect:!1,lastSelect:!1,ancestorWithContent:null,ancestorWithContentAvailable:null},this.parent=o==null?null:o,this.contentParent=o?o.hasRenderContent?o:o.contentParent:null,this.level=this.parent?this.parent.level+1:0,this.tileset=r,this.refine=(s=n.refine)==null?this.parent?this.parent.refine:`REPLACE`:s,this.transform=new three.Matrix4,n.transform&&this.transform.fromArray(n.transform),this.parent&&this.transform.premultiply(this.parent.transform),typeof n.geometricError==`number`?this.geometricError=n.geometricError*this.transform.getMaxScaleOnAxis():this.geometricError=(l=(c=this.parent)==null?void 0:c.geometricError)==null?0:l,n.content&&n.content.uri?(this.content={uri:n.content.uri,loadState:`UNLOADED`,loadProgress:0,loadStateUpdateTime:now(),loadfailRetryDelay:0,byteLength:0,memoryUsage:0},n.content.group!==void 0&&(this.content.group=n.content.group),/\.json$/.test(this.content.uri)?this.type=`TILESET`:this.type=`SCENEGRAPH`):(this.content=null,this.type=`EMPTY`),this.levelOfContent=this.parent?this.parent.levelOfContent:-1,this.type===`SCENEGRAPH`&&(this.levelOfContent+=1),n.boundingVolume&&(this.boundingVolume=makeBoundingVolume(n.boundingVolume).applyMatrix4(this.transform)),n.viewerRequestVolume&&(this.viewerRequestVolume=makeBoundingVolume(n.viewerRequestVolume).applyMatrix4(this.transform)),this.extras=(u=n.extras)==null?{}:u,typeof this.extras.floor!=`number`&&o&&typeof o.extras.floor==`number`&&(this.extras.floor=o.extras.floor),typeof this.extras.floor==`number`&&(this.floor=this.extras.floor,this.tileset.floorLength=Math.max(this.tileset.floorLength,this.floor+1)),n.children?this.children=n.children.map((t,n)=>new e(`${this.id}.${n}`,t,r,this)):this.children=[]}traverse(e){e(this);for(let t of this.children)t.traverse(e)}updateState(e){this.state.frameNumber=e.frameNumber;let t=this.tileset.transform;if(this.boundingVolume){let n;n=this.boundingVolume instanceof BoxBoundingVolume?scratchBoxBoundingVolume$1.copy(this.boundingVolume):this.boundingVolume instanceof SphereBoundingVolume?scratchSphereBoundingVolume$1.copy(this.boundingVolume):this.boundingVolume.clone(),n.applyMatrix4(t),e.camera.type===`OrthographicCamera`?(scratchPlane.setFromNormalAndCoplanarPoint(e.camera.direction,e.camera.position),this.state.distanceToCamera=n.distanceToPlane(scratchPlane)):this.state.distanceToCamera=n.distanceToPoint(e.camera.position);let r=n.getCenter(scratchVector3$10).sub(e.camera.position);this.state.centerZDepth=e.camera.direction.dot(r),this.state.centerScreenY=e.camera.up.dot(r);let o=this.parent?this.parent.state.visibilityPlaneMask:CullingVolume.MASK_INDETERMINATE;this.state.visibilityPlaneMask=e.cullingVolume.computeVisibilityWithPlaneMask(n,o),this.state.visible=this.state.visibilityPlaneMask!==CullingVolume.MASK_OUTSIDE,e.cameraCulling||(this.state.visible=!0)}else this.state.distanceToCamera=0,this.state.centerZDepth=0,this.state.visibilityPlaneMask=CullingVolume.MASK_INDETERMINATE,this.state.visible=!0;if((this.levelOfContent<=e.minLevelOfDetail||this.geometricError>=e.maxGeometricError)&&(this.state.visible=!0),this.viewerRequestVolume){let n;n=this.viewerRequestVolume instanceof BoxBoundingVolume?scratchBoxBoundingVolume$1.copy(this.viewerRequestVolume):this.viewerRequestVolume instanceof SphereBoundingVolume?scratchSphereBoundingVolume$1.copy(this.viewerRequestVolume):this.viewerRequestVolume.clone(),n.applyMatrix4(t),this.state.inRequestVolume=n.distanceSquaredToPoint(e.camera.position)<=0}else this.state.inRequestVolume=!0;this.state.screenSpaceError=this.getScreenSpaceError(e,this.state.distanceToCamera,!1)}get selected(){return this.state.selectedFrameNumber===this.tileset.frameNumber}get hasChildren(){return this.children.length>0}get siblingIndex(){var e,t;return(t=(e=this.parent)==null?void 0:e.children.indexOf(this))==null?0:t}get hasTilesetContent(){return this.children.length>0&&this.type===`TILESET`}get hasRenderContent(){return this.type===`SCENEGRAPH`}get contentAvailable(){var e;return this.hasRenderContent&&((e=this.content)==null?void 0:e.loadState)===`READY`}get hasUnloadedContent(){var e;return((e=this.content)==null?void 0:e.loadState)===`UNLOADED`}get hasEmptyContent(){return this.type===`EMPTY`}get contentReady(){var e;return((e=this.content)==null?void 0:e.loadState)===`READY`||this.hasEmptyContent}get contentByteLength(){return this.content?this.content.byteLength:0}get contentMemoryUsage(){return this.content?this.content.memoryUsage:0}getScreenSpaceError(e,t,n){let r=this.tileset.transform.getMaxScaleOnAxis(),o=this.parent?this.parent.geometricError:this.tileset.geometricError,s=r*(n?o:this.geometricError);if(s===0)return 0;let c=e.height,l=e.sseDenominator;return e.camera.type===`OrthographicCamera`?s/(1/(e.camera.projectionMatrix.elements[5]/2)/c*.9):s/(Math.max(t,.001)*l/c)}getPriority(e){let t=this.refine===`ADD`||e.skipLevelOfDetail;if(t&&!this.state.visible||e.frameNumber-this.state.touchedFrameNumber>=1)return-1;let n=this.parent,r=n&&(!t||this.state.screenSpaceError===0)?n.state.screenSpaceError:this.state.screenSpaceError,o=this.tileset.root?this.tileset.root.state.screenSpaceError:0;return Math.max(o-r,0)}},defaultIterator=e=>Number(e);function arrayMin(e,t=defaultIterator,n=!1){let r,o=1/0;for(let n of e){let e=t(n);e<=o&&(r=n,o=e)}return isFinite(o)||(o=0),n?[r,o]:r}function arrayEqual(e,t,n=(e,t)=>e===t){let r=e.length;if(r!==t.length)return!1;for(let o=0;o<r;o++)if(n(e[o],t[o])===!1)return!1;return!0}var arrayUniqueSet=new Set;function arrayUnique(e){arrayUniqueSet.clear();let t=[],n=e.length;for(let r=0;r<n;r++){let n=e[r];arrayUniqueSet.has(n)||(t.push(n),arrayUniqueSet.add(n))}return arrayUniqueSet.clear(),t}var arrayMinCallback=e=>e.distance,intersectDistanceSortCallback=(e,t)=>e.distance-t.distance;function sortIntersects(e,t=!0,n=!1){if(n&&e.length>1){let t=arrayMin(e,arrayMinCallback);t?(e[0]=t,e.length=1):e.length=0}return t&&e.length>1&&e.sort(intersectDistanceSortCallback),e}var BVHObject=class{constructor(e,t){this.position=e,this.indices=t}getPositionCount(){var e,t;let n=this.indices,r=this.position;return n?n.array.length/((e=n.stride)==null?1:e):r.array.length/((t=r.stride)==null?3:t)}getPositionByIndex(e,t){var n,r,o,s;let c=this.indices,l=this.position,u=e;if(c){let t=c.array,o=(n=c.stride)==null?1:n,s=(r=c.offset)==null?0:r;u=t[e*o+s]}let d=l.array,f=(o=l.stride)==null?3:o,p=(s=l.offset)==null?0:s;return u=u*f+p,t.x=d[u],t.y=d[u+1],t.z=d[u+2],t}createTree(e,t,n){throw Error(`not implemented`)}trianglesInSphere(e,t){throw Error(`not implemented`)}intersectRay(e,t,n=0,r=!1,o){throw Error(`not implemented`)}},BVHNode=class{constructor(e,t,n,r,o){this.id=e,this.extents=t,this.startIndex=n,this.endIndex=r,this.deepth=o}},BYTES_PER_NODE=36;function packBVHNode(e,t){let n=new ArrayBuffer(t*36),r=new Float32Array(n),o=new Uint32Array(n),s=new Uint16Array(n),c=[e],l,u;for(;l=c.pop();)u=l.id*36/4,r[u]=l.extents[0],r[u+1]=l.extents[1],r[u+2]=l.extents[2],r[u+3]=l.extents[3],r[u+4]=l.extents[4],r[u+5]=l.extents[5],o[u+6]=l.startIndex,o[u+7]=l.endIndex,u=l.id*36/2,l.node0&&(s[u+16]=l.node0.id,c.push(l.node0)),l.node1&&(s[u+17]=l.node1.id,c.push(l.node1));return n}function intersectNodeBox(e,t,n,r=0){let o=n.min.x-r,s=n.min.y-r,c=n.min.z-r,l=n.max.x+r,u=n.max.y+r,d=n.max.z+r,f=0,p=0,m=0,h=0,g=0,_=0;return t.x>=0?(f=(o-e.x)*t.x,p=(l-e.x)*t.x):(f=(l-e.x)*t.x,p=(o-e.x)*t.x),t.y>=0?(m=(s-e.y)*t.y,h=(u-e.y)*t.y):(m=(u-e.y)*t.y,h=(s-e.y)*t.y),f>h||m>p||((m>f||f!==f)&&(f=m),(h<p||p!==p)&&(p=h),t.z>=0?(g=(c-e.z)*t.z,_=(d-e.z)*t.z):(g=(d-e.z)*t.z,_=(c-e.z)*t.z),f>_||g>p)||((g>f||f!==f)&&(f=g),(_<p||p!==p)&&(p=_),p<0)?null:f>=0?f:0}var BVHVector3=class e{constructor(e,t,n){this.x=e,this.y=t,this.z=n}copy(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}set(e,t,n){return this.x=e,this.y=t,this.z=n,this}fromArray(e,t=0){return this.x=e[t],this.y=e[t+1],this.z=e[t+2],this}toArray(e=[],t=0){return e[t]=this.x,e[t+1]=this.y,e[t+2]=this.z,e}add(e){return this.x+=e.x,this.y+=e.y,this.z+=e.z,this}multiplyScalar(e){return this.x*=e,this.y*=e,this.z*=e,this}subVectors(e,t){return this.x=e.x-t.x,this.y=e.y-t.y,this.z=e.z-t.z,this}addScaledVector(e,t){return this.x+=e.x*t,this.y+=e.y*t,this.z+=e.z*t,this}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z}cross(e){let t=this.x,n=this.y,r=this.z;return this.x=n*e.z-r*e.y,this.y=r*e.x-t*e.z,this.z=t*e.y-n*e.x,this}crossVectors(e,t){let n=e.x,r=e.y,o=e.z,s=t.x,c=t.y,l=t.z;return this.x=r*l-o*c,this.y=o*s-n*l,this.z=n*c-r*s,this}distanceTo(e){return Math.sqrt(this.distanceToSquared(e))}distanceToSquared(e){let t=this.x-e.x,n=this.y-e.y,r=this.z-e.z;return t*t+n*n+r*r}clone(){return new e(this.x,this.y,this.z)}},BVHIntersect=class{constructor(e,t,n,r,o){this.pointA=e,this.pointB=t,this.pointC=n,this.index=r,this.intersectionPoint=o}},BVHBox3=class{constructor(e,t){this.min=e,this.max=t}},EPSILON$1=1e-6,scratchVector3$9=new BVHVector3(0,0,0),scratchVector3A=new BVHVector3(0,0,0),scratchVector3B=new BVHVector3(0,0,0),scratchVector3C=new BVHVector3(0,0,0),BVHMesh=class extends BVHObject{createTree(e,t,n){t=Math.min(t,16);let r=this.getPositionCount()/3,o=r>65535?new Uint32Array(r):new Uint16Array(r),s=new Float32Array(r*6),c=[],l=0,u=-1;if(n)for(let e=0;e<r;e+=1){let t=e*3,n=e*6,r,c,l,u,d,f,p;o[e]=e,this.getPositionByIndex(t,scratchVector3A),this.getPositionByIndex(t+1,scratchVector3B),this.getPositionByIndex(t+2,scratchVector3C),r=u=scratchVector3A.x,p=scratchVector3B.x,p<r&&(r=p),p>u&&(u=p),p=scratchVector3C.x,p<r&&(r=p),p>u&&(u=p),c=d=scratchVector3A.y,p=scratchVector3B.y,p<c&&(c=p),p>d&&(d=p),p=scratchVector3C.y,p<c&&(c=p),p>d&&(d=p),l=f=scratchVector3A.z,p=scratchVector3B.z,p<l&&(l=p),p>f&&(f=p),p=scratchVector3C.z,p<l&&(l=p),p>f&&(f=p),s[n]=r,s[n+1]=c,s[n+2]=l,s[n+3]=u,s[n+4]=d,s[n+5]=f}else{let e=1/0,t=1/0,c=1/0,l=-1/0,u=-1/0,d=-1/0;for(let n=0;n<r;n+=1){let r=n*3,f=n*6,p,m,h,g,_,v,y;o[n]=n,this.getPositionByIndex(r,scratchVector3A),this.getPositionByIndex(r+1,scratchVector3B),this.getPositionByIndex(r+2,scratchVector3C),p=g=scratchVector3A.x,y=scratchVector3B.x,y<p&&(p=y),y>g&&(g=y),y=scratchVector3C.x,y<p&&(p=y),y>g&&(g=y),m=_=scratchVector3A.y,y=scratchVector3B.y,y<m&&(m=y),y>_&&(_=y),y=scratchVector3C.y,y<m&&(m=y),y>_&&(_=y),h=v=scratchVector3A.z,y=scratchVector3B.z,y<h&&(h=y),y>v&&(v=y),y=scratchVector3C.z,y<h&&(h=y),y>v&&(v=y),s[f]=p,s[f+1]=m,s[f+2]=h,s[f+3]=g,s[f+4]=_,s[f+5]=v,p<e&&(e=p),g>l&&(l=g),m<t&&(t=m),_>u&&(u=_),h<c&&(c=h),v>d&&(d=v)}n=[e,t,c,l,u,d]}let d=new BVHNode(++u,n,0,r,0);c[l++]=d;let f=[],p=[0,1,2],m=function(e,t){return f[t]-f[e]};function h(n){let r=n.startIndex,d=n.endIndex,h=n.extents;f[0]=h[3]-h[0],f[1]=h[4]-h[1],f[2]=h[5]-h[2],p.sort(m);for(let f=0;f<3;f++){let m=p[f],g=h[m]+h[m+3],_=r,v=d-1,y=-1,b;for(;_<=v;)y===-1?(b=o[_],s[b*6+m]+s[b*6+m+3]<g?_++:y=b):(b=o[v],s[b*6+m]+s[b*6+m+3]>=g?v--:(o[_]=b,o[v]=y,y=-1,_++,v--));if(_>r&&_<d){let f=new BVHNode(++u,calcExtents(o,s,r,_,EPSILON$1),r,_,n.deepth+1);f.deepth<t&&f.endIndex-f.startIndex>e&&(c[l++]=f);let p=new BVHNode(++u,calcExtents(o,s,_,d,EPSILON$1),_,d,n.deepth+1);p.deepth<t&&p.endIndex-p.startIndex>e&&(c[l++]=p),n.node0=f,n.node1=p,n.startIndex=0,n.endIndex=0;break}}}for(;l;)h(c[--l]);return this.offsetArray=o,this.rootNodePacked=packBVHNode(d,u+1),c.length=0,this}trianglesInSphere(e,t){let n=this.offsetArray,r=this.rootNodePacked,o=new Float32Array(r),s=new Uint32Array(r),c=new Uint16Array(r),l=[0],u=[],d;for(;(d=l.pop())!==void 0;){let r=d*36/4,f=clamp(e.x,o[r],o[r+3])-e.x,p=clamp(e.y,o[r+1],o[r+4])-e.y,m=clamp(e.z,o[r+2],o[r+5])-e.z;if(f*f+p*p+m*m<=t*t){let e=s[r+6],t=s[r+7];for(let r=e;r<t;r++){let e=n[r];u.push(e)}let o=d*36/2,f=c[o+16],p=c[o+17];f&&l.push(f),p&&l.push(p)}}let f=u.length,p=new Float32Array(f*9);for(let e=0;e<f;e++){let t=u[e]*3;this.getPositionByIndex(t,scratchVector3$9),p[e*9]=scratchVector3$9.x,p[e*9+1]=scratchVector3$9.y,p[e*9+2]=scratchVector3$9.z,this.getPositionByIndex(t+1,scratchVector3$9),p[e*9+3]=scratchVector3$9.x,p[e*9+4]=scratchVector3$9.y,p[e*9+5]=scratchVector3$9.z,this.getPositionByIndex(t+2,scratchVector3$9),p[e*9+6]=scratchVector3$9.x,p[e*9+7]=scratchVector3$9.y,p[e*9+8]=scratchVector3$9.z}return p}intersectRay(e,t,n=0,r=!1,o){let s=[],c=this.offsetArray,l=this.rootNodePacked,u=new Float32Array(l),d=new Uint32Array(l),f=new Uint16Array(l),p=new BVHVector3(1/t.x,1/t.y,1/t.z),m=[0],h,g=1/0,_=new BVHBox3(new BVHVector3(0,0,0),new BVHVector3(0,0,0)),v=new BVHVector3(0,0,0),y=new BVHVector3(0,0,0),b=new BVHVector3(0,0,0);for(;(h=m.pop())!==void 0;){let l=h*36/4;_.min.x=u[l],_.min.y=u[l+1],_.min.z=u[l+2],_.max.x=u[l+3],_.max.y=u[l+4],_.max.z=u[l+5];let S=intersectNodeBox(e,p,_,n);if(S===null||r&&S>g)continue;let C=e.x,w=e.y,T=e.z,E=t.x,D=t.y,O=t.z,k=d[l+6],A=d[l+7];for(let e=k;e<A;e++){let t=c[e],n=t*3;this.getPositionByIndex(n,v);let l=v.x,u=v.y,d=v.z;this.getPositionByIndex(n+1,y);let f=y.x,p=y.y,m=y.z;this.getPositionByIndex(n+2,b);let h=b.x,_=b.y,S=b.z,k=f-l,A=p-u,j=m-d,M=h-l,N=_-u,P=S-d,F=A*P-j*N,I=j*M-k*P,L=k*N-A*M,R=E*F+D*I+O*L,z;if(R>0)z=1;else if(R<0)z=-1,R=-R;else continue;let B=C-l,V=w-u,H=T-d,ee=z*(E*(V*P-H*N)+D*(H*M-B*P)+O*(B*N-V*M));if(ee<0)continue;let te=z*(E*(A*H-j*V)+D*(j*B-k*H)+O*(k*V-A*B));if(te<0||ee+te>R)continue;let U=-z*(B*F+V*I+H*L);if(U<0)continue;let W=U/R,G=new BVHIntersect(v,y,b,t,new BVHVector3(C+E*W,w+D*W,T+O*W));(!o||o(G))&&(r?W<g&&(g=W,s.length>0&&(s.length=0),s.push(G)):s.push(G))}let j=h*36/2,M=f[j+16],N=f[j+17];M&&m.push(M),N&&m.push(N)}return s}};function clamp(e,t,n){return e<t?t:e>n?n:e}function calcExtents(e,t,n,r,o){if(n>=r)return[0,0,0,0,0,0];let s=1/0,c=1/0,l=1/0,u=-1/0,d=-1/0,f=-1/0;for(let o=n;o<r;o++){let n=e[o]*6,r=t[n];r<s&&(s=r),r=t[n+1],r<c&&(c=r),r=t[n+2],r<l&&(l=r),r=t[n+3],r>u&&(u=r),r=t[n+4],r>d&&(d=r),r=t[n+5],r>f&&(f=r)}return[s-o,c-o,l-o,u+o,d+o,f+o]}(function(){let e=new BVHVector3(0,0,0),t=new BVHVector3(0,0,0),n=new BVHVector3(0,0,0),r=new BVHVector3(0,0,0);return function(o,s,c,l,u){t.subVectors(s,o),n.subVectors(c,o),r.crossVectors(t,n);let d=u.dot(r),f;if(d>0)f=1;else if(d<0)f=-1,d=-d;else return null;e.subVectors(l,o);let p=f*u.dot(n.crossVectors(e,n));if(p<0)return null;let m=f*u.dot(t.cross(e));if(m<0||p+m>d)return null;let h=-f*e.dot(r);if(h<0)return null;let g=h/d;return new BVHVector3(0,0,0).copy(u).multiplyScalar(g).add(l)}})();var EPSILON=1e-6,ORDER_AXISES=[`x`,`y`,`z`],scratchVector3$8=new BVHVector3(0,0,0),BVHPoints=class extends BVHObject{createTree(e,t,n){t=Math.min(t,16);let r=this.getPositionByIndex.bind(this),o=this.getPositionCount(),s=o>65535?new Uint32Array(o):new Uint16Array(o),c=[],l=0,u=-1;if(n)for(let e=0;e<o;e+=1)s[e]=e;else{r(0,scratchVector3$8);let e=scratchVector3$8.x,t=scratchVector3$8.y,c=scratchVector3$8.z,l=e,u=t,d=c;for(let n=0;n<o;n+=1){s[n]=n,r(n,scratchVector3$8);let o=scratchVector3$8.x,f=scratchVector3$8.y,p=scratchVector3$8.z;o<e?e=o:o>l&&(l=o),f<t?t=f:f>u&&(u=f),p<c?c=p:p>d&&(d=p)}n=[e,t,c,l,u,d]}let d=new BVHNode(++u,n,0,o,0);c[l++]=d;let f=[],p=[0,1,2],m=function(e,t){return f[t]-f[e]};function h(n){let o=n.startIndex,d=n.endIndex,h=n.extents;f[0]=h[3]-h[0],f[1]=h[4]-h[1],f[2]=h[5]-h[2];let g=p.sort(m)[0],_=ORDER_AXISES[g],v=(h[g]+h[g+3])/2,y=o,b=d-1,S=-1,C;for(;y<=b;)S===-1?(C=s[y],r(C,scratchVector3$8),scratchVector3$8[_]<v?y++:S=C):(C=s[b],r(C,scratchVector3$8),scratchVector3$8[_]>=v?b--:(s[y]=C,s[b]=S,S=-1,y++,b--));if(y>o){let r=h.slice();r[g+3]=v+EPSILON;let s=new BVHNode(++u,r,o,y,n.deepth+1);s.deepth<t&&s.endIndex-s.startIndex>e&&(c[l++]=s),n.node0=s}if(d>y){let r=h.slice();r[g]=v-EPSILON;let o=new BVHNode(++u,r,y,d,n.deepth+1);o.deepth<t&&o.endIndex-o.startIndex>e&&(c[l++]=o),n.node1=o}n.startIndex=0,n.endIndex=0}for(;l;)h(c[--l]);return this.offsetArray=s,this.rootNodePacked=packBVHNode(d,u+1),c.length=0,this}intersectRay(e,t,n=0,r=!1,o){let s=[],c=this.offsetArray,l=this.rootNodePacked,u=new Float32Array(l),d=new Uint32Array(l),f=new Uint16Array(l),p=n*n,m=new BVHVector3(1/t.x,1/t.y,1/t.z),h=[0],g,_=1/0,v=new BVHBox3(new BVHVector3(0,0,0),new BVHVector3(0,0,0)),y=new BVHVector3(0,0,0);for(;(g=h.pop())!==void 0;){let l=g*36/4;v.min.x=u[l],v.min.y=u[l+1],v.min.z=u[l+2],v.max.x=u[l+3],v.max.y=u[l+4],v.max.z=u[l+5];let b=intersectNodeBox(e,m,v,n);if(b===null||r&&b>_)continue;let S=d[l+6],C=d[l+7];for(let n=S;n<C;n++){let l=c[n];this.getPositionByIndex(l,y);let u=y.x,d=y.y,f=y.z,m=e.x,h=e.y,g=e.z,v=t.x,b=t.y,S=t.z,C=v*(u-m)+b*(d-h)+S*(f-g);if(C>0?(m+=v*C,h+=b*C,g+=S*C):C<0&&(C=0),v=u-m,b=d-h,S=f-g,v*v+b*b+S*S<=p){let e=new BVHIntersect(y,y,y,l,new BVHVector3(m,h,g));(!o||o(e))&&(r?C<_&&(_=C,s.length>0&&(s.length=0),s.push(e)):s.push(e))}}let w=g*36/2,T=f[w+16],E=f[w+17];T&&h.push(T),E&&h.push(E)}return s}},jsContent$2="(function(){var e=class{constructor(e,t){this.position=e,this.indices=t}getPositionCount(){let e=this.indices,t=this.position;return e?e.array.length/(e.stride??1):t.array.length/(t.stride??3)}getPositionByIndex(e,t){let n=this.indices,r=this.position,i=e;if(n){let t=n.array,r=n.stride??1,a=n.offset??0;i=t[e*r+a]}let a=r.array,o=r.stride??3,s=r.offset??0;return i=i*o+s,t.x=a[i],t.y=a[i+1],t.z=a[i+2],t}createTree(e,t,n){throw Error(`not implemented`)}trianglesInSphere(e,t){throw Error(`not implemented`)}intersectRay(e,t,n=0,r=!1,i){throw Error(`not implemented`)}},t=class{constructor(e,t,n,r,i){this.id=e,this.extents=t,this.startIndex=n,this.endIndex=r,this.deepth=i}};function n(e,t){let n=new ArrayBuffer(t*36),r=new Float32Array(n),i=new Uint32Array(n),a=new Uint16Array(n),o=[e],s,c;for(;s=o.pop();)c=s.id*36/4,r[c]=s.extents[0],r[c+1]=s.extents[1],r[c+2]=s.extents[2],r[c+3]=s.extents[3],r[c+4]=s.extents[4],r[c+5]=s.extents[5],i[c+6]=s.startIndex,i[c+7]=s.endIndex,c=s.id*36/2,s.node0&&(a[c+16]=s.node0.id,o.push(s.node0)),s.node1&&(a[c+17]=s.node1.id,o.push(s.node1));return n}function r(e,t,n,r=0){let i=n.min.x-r,a=n.min.y-r,o=n.min.z-r,s=n.max.x+r,c=n.max.y+r,l=n.max.z+r,u=0,d=0,f=0,p=0,m=0,h=0;return t.x>=0?(u=(i-e.x)*t.x,d=(s-e.x)*t.x):(u=(s-e.x)*t.x,d=(i-e.x)*t.x),t.y>=0?(f=(a-e.y)*t.y,p=(c-e.y)*t.y):(f=(c-e.y)*t.y,p=(a-e.y)*t.y),u>p||f>d||((f>u||u!==u)&&(u=f),(p<d||d!==d)&&(d=p),t.z>=0?(m=(o-e.z)*t.z,h=(l-e.z)*t.z):(m=(l-e.z)*t.z,h=(o-e.z)*t.z),u>h||m>d)||((m>u||u!==u)&&(u=m),(h<d||d!==d)&&(d=h),d<0)?null:u>=0?u:0}var i=class e{constructor(e,t,n){this.x=e,this.y=t,this.z=n}copy(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}set(e,t,n){return this.x=e,this.y=t,this.z=n,this}fromArray(e,t=0){return this.x=e[t],this.y=e[t+1],this.z=e[t+2],this}toArray(e=[],t=0){return e[t]=this.x,e[t+1]=this.y,e[t+2]=this.z,e}add(e){return this.x+=e.x,this.y+=e.y,this.z+=e.z,this}multiplyScalar(e){return this.x*=e,this.y*=e,this.z*=e,this}subVectors(e,t){return this.x=e.x-t.x,this.y=e.y-t.y,this.z=e.z-t.z,this}addScaledVector(e,t){return this.x+=e.x*t,this.y+=e.y*t,this.z+=e.z*t,this}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z}cross(e){let t=this.x,n=this.y,r=this.z;return this.x=n*e.z-r*e.y,this.y=r*e.x-t*e.z,this.z=t*e.y-n*e.x,this}crossVectors(e,t){let n=e.x,r=e.y,i=e.z,a=t.x,o=t.y,s=t.z;return this.x=r*s-i*o,this.y=i*a-n*s,this.z=n*o-r*a,this}distanceTo(e){return Math.sqrt(this.distanceToSquared(e))}distanceToSquared(e){let t=this.x-e.x,n=this.y-e.y,r=this.z-e.z;return t*t+n*n+r*r}clone(){return new e(this.x,this.y,this.z)}},a=class{constructor(e,t,n,r,i){this.pointA=e,this.pointB=t,this.pointC=n,this.index=r,this.intersectionPoint=i}},o=class{constructor(e,t){this.min=e,this.max=t}};let s=1e-6,c=new i(0,0,0),l=new i(0,0,0),u=new i(0,0,0),d=new i(0,0,0);var f=class extends e{createTree(e,r,i){r=Math.min(r,16);let a=this.getPositionCount()/3,o=a>65535?new Uint32Array(a):new Uint16Array(a),c=new Float32Array(a*6),f=[],p=0,h=-1;if(i)for(let e=0;e<a;e+=1){let t=e*3,n=e*6,r,i,a,s,f,p,m;o[e]=e,this.getPositionByIndex(t,l),this.getPositionByIndex(t+1,u),this.getPositionByIndex(t+2,d),r=s=l.x,m=u.x,m<r&&(r=m),m>s&&(s=m),m=d.x,m<r&&(r=m),m>s&&(s=m),i=f=l.y,m=u.y,m<i&&(i=m),m>f&&(f=m),m=d.y,m<i&&(i=m),m>f&&(f=m),a=p=l.z,m=u.z,m<a&&(a=m),m>p&&(p=m),m=d.z,m<a&&(a=m),m>p&&(p=m),c[n]=r,c[n+1]=i,c[n+2]=a,c[n+3]=s,c[n+4]=f,c[n+5]=p}else{let e=1/0,t=1/0,n=1/0,r=-1/0,s=-1/0,f=-1/0;for(let i=0;i<a;i+=1){let a=i*3,p=i*6,m,h,g,_,v,y,b;o[i]=i,this.getPositionByIndex(a,l),this.getPositionByIndex(a+1,u),this.getPositionByIndex(a+2,d),m=_=l.x,b=u.x,b<m&&(m=b),b>_&&(_=b),b=d.x,b<m&&(m=b),b>_&&(_=b),h=v=l.y,b=u.y,b<h&&(h=b),b>v&&(v=b),b=d.y,b<h&&(h=b),b>v&&(v=b),g=y=l.z,b=u.z,b<g&&(g=b),b>y&&(y=b),b=d.z,b<g&&(g=b),b>y&&(y=b),c[p]=m,c[p+1]=h,c[p+2]=g,c[p+3]=_,c[p+4]=v,c[p+5]=y,m<e&&(e=m),_>r&&(r=_),h<t&&(t=h),v>s&&(s=v),g<n&&(n=g),y>f&&(f=y)}i=[e,t,n,r,s,f]}let g=new t(++h,i,0,a,0);f[p++]=g;let _=[],v=[0,1,2],y=function(e,t){return _[t]-_[e]};function b(n){let i=n.startIndex,a=n.endIndex,l=n.extents;_[0]=l[3]-l[0],_[1]=l[4]-l[1],_[2]=l[5]-l[2],v.sort(y);for(let u=0;u<3;u++){let d=v[u],g=l[d]+l[d+3],_=i,y=a-1,b=-1,x;for(;_<=y;)b===-1?(x=o[_],c[x*6+d]+c[x*6+d+3]<g?_++:b=x):(x=o[y],c[x*6+d]+c[x*6+d+3]>=g?y--:(o[_]=x,o[y]=b,b=-1,_++,y--));if(_>i&&_<a){let l=new t(++h,m(o,c,i,_,s),i,_,n.deepth+1);l.deepth<r&&l.endIndex-l.startIndex>e&&(f[p++]=l);let u=new t(++h,m(o,c,_,a,s),_,a,n.deepth+1);u.deepth<r&&u.endIndex-u.startIndex>e&&(f[p++]=u),n.node0=l,n.node1=u,n.startIndex=0,n.endIndex=0;break}}}for(;p;)b(f[--p]);return this.offsetArray=o,this.rootNodePacked=n(g,h+1),f.length=0,this}trianglesInSphere(e,t){let n=this.offsetArray,r=this.rootNodePacked,i=new Float32Array(r),a=new Uint32Array(r),o=new Uint16Array(r),s=[0],l=[],u;for(;(u=s.pop())!==void 0;){let r=u*36/4,c=p(e.x,i[r],i[r+3])-e.x,d=p(e.y,i[r+1],i[r+4])-e.y,f=p(e.z,i[r+2],i[r+5])-e.z;if(c*c+d*d+f*f<=t*t){let e=a[r+6],t=a[r+7];for(let r=e;r<t;r++){let e=n[r];l.push(e)}let i=u*36/2,c=o[i+16],d=o[i+17];c&&s.push(c),d&&s.push(d)}}let d=l.length,f=new Float32Array(d*9);for(let e=0;e<d;e++){let t=l[e]*3;this.getPositionByIndex(t,c),f[e*9]=c.x,f[e*9+1]=c.y,f[e*9+2]=c.z,this.getPositionByIndex(t+1,c),f[e*9+3]=c.x,f[e*9+4]=c.y,f[e*9+5]=c.z,this.getPositionByIndex(t+2,c),f[e*9+6]=c.x,f[e*9+7]=c.y,f[e*9+8]=c.z}return f}intersectRay(e,t,n=0,s=!1,c){let l=[],u=this.offsetArray,d=this.rootNodePacked,f=new Float32Array(d),p=new Uint32Array(d),m=new Uint16Array(d),h=new i(1/t.x,1/t.y,1/t.z),g=[0],_,v=1/0,y=new o(new i(0,0,0),new i(0,0,0)),b=new i(0,0,0),x=new i(0,0,0),S=new i(0,0,0);for(;(_=g.pop())!==void 0;){let o=_*36/4;y.min.x=f[o],y.min.y=f[o+1],y.min.z=f[o+2],y.max.x=f[o+3],y.max.y=f[o+4],y.max.z=f[o+5];let d=r(e,h,y,n);if(d===null||s&&d>v)continue;let C=e.x,w=e.y,T=e.z,E=t.x,D=t.y,O=t.z,k=p[o+6],A=p[o+7];for(let e=k;e<A;e++){let t=u[e],n=t*3;this.getPositionByIndex(n,b);let r=b.x,o=b.y,d=b.z;this.getPositionByIndex(n+1,x);let f=x.x,p=x.y,m=x.z;this.getPositionByIndex(n+2,S);let h=S.x,g=S.y,_=S.z,y=f-r,k=p-o,A=m-d,j=h-r,M=g-o,N=_-d,P=k*N-A*M,F=A*j-y*N,I=y*M-k*j,L=E*P+D*F+O*I,R;if(L>0)R=1;else if(L<0)R=-1,L=-L;else continue;let z=C-r,B=w-o,V=T-d,H=R*(E*(B*N-V*M)+D*(V*j-z*N)+O*(z*M-B*j));if(H<0)continue;let U=R*(E*(k*V-A*B)+D*(A*z-y*V)+O*(y*B-k*z));if(U<0||H+U>L)continue;let W=-R*(z*P+B*F+V*I);if(W<0)continue;let G=W/L,K=new a(b,x,S,t,new i(C+E*G,w+D*G,T+O*G));(!c||c(K))&&(s?G<v&&(v=G,l.length>0&&(l.length=0),l.push(K)):l.push(K))}let j=_*36/2,M=m[j+16],N=m[j+17];M&&g.push(M),N&&g.push(N)}return l}};function p(e,t,n){return e<t?t:e>n?n:e}function m(e,t,n,r,i){if(n>=r)return[0,0,0,0,0,0];let a=1/0,o=1/0,s=1/0,c=-1/0,l=-1/0,u=-1/0;for(let i=n;i<r;i++){let n=e[i]*6,r=t[n];r<a&&(a=r),r=t[n+1],r<o&&(o=r),r=t[n+2],r<s&&(s=r),r=t[n+3],r>c&&(c=r),r=t[n+4],r>l&&(l=r),r=t[n+5],r>u&&(u=r)}return[a-i,o-i,s-i,c+i,l+i,u+i]}(function(){let e=new i(0,0,0),t=new i(0,0,0),n=new i(0,0,0),r=new i(0,0,0);return function(a,o,s,c,l){t.subVectors(o,a),n.subVectors(s,a),r.crossVectors(t,n);let u=l.dot(r),d;if(u>0)d=1;else if(u<0)d=-1,u=-u;else return null;e.subVectors(c,a);let f=d*l.dot(n.crossVectors(e,n));if(f<0)return null;let p=d*l.dot(t.cross(e));if(p<0||f+p>u)return null;let m=-d*e.dot(r);if(m<0)return null;let h=m/u;return new i(0,0,0).copy(l).multiplyScalar(h).add(c)}})();let h=1e-6,g=[`x`,`y`,`z`],_=new i(0,0,0);var v=class extends e{createTree(e,r,i){r=Math.min(r,16);let a=this.getPositionByIndex.bind(this),o=this.getPositionCount(),s=o>65535?new Uint32Array(o):new Uint16Array(o),c=[],l=0,u=-1;if(i)for(let e=0;e<o;e+=1)s[e]=e;else{a(0,_);let e=_.x,t=_.y,n=_.z,r=e,c=t,l=n;for(let i=0;i<o;i+=1){s[i]=i,a(i,_);let o=_.x,u=_.y,d=_.z;o<e?e=o:o>r&&(r=o),u<t?t=u:u>c&&(c=u),d<n?n=d:d>l&&(l=d)}i=[e,t,n,r,c,l]}let d=new t(++u,i,0,o,0);c[l++]=d;let f=[],p=[0,1,2],m=function(e,t){return f[t]-f[e]};function v(n){let i=n.startIndex,o=n.endIndex,d=n.extents;f[0]=d[3]-d[0],f[1]=d[4]-d[1],f[2]=d[5]-d[2];let v=p.sort(m)[0],y=g[v],b=(d[v]+d[v+3])/2,x=i,S=o-1,C=-1,w;for(;x<=S;)C===-1?(w=s[x],a(w,_),_[y]<b?x++:C=w):(w=s[S],a(w,_),_[y]>=b?S--:(s[x]=w,s[S]=C,C=-1,x++,S--));if(x>i){let a=d.slice();a[v+3]=b+h;let o=new t(++u,a,i,x,n.deepth+1);o.deepth<r&&o.endIndex-o.startIndex>e&&(c[l++]=o),n.node0=o}if(o>x){let i=d.slice();i[v]=b-h;let a=new t(++u,i,x,o,n.deepth+1);a.deepth<r&&a.endIndex-a.startIndex>e&&(c[l++]=a),n.node1=a}n.startIndex=0,n.endIndex=0}for(;l;)v(c[--l]);return this.offsetArray=s,this.rootNodePacked=n(d,u+1),c.length=0,this}intersectRay(e,t,n=0,s=!1,c){let l=[],u=this.offsetArray,d=this.rootNodePacked,f=new Float32Array(d),p=new Uint32Array(d),m=new Uint16Array(d),h=n*n,g=new i(1/t.x,1/t.y,1/t.z),_=[0],v,y=1/0,b=new o(new i(0,0,0),new i(0,0,0)),x=new i(0,0,0);for(;(v=_.pop())!==void 0;){let o=v*36/4;b.min.x=f[o],b.min.y=f[o+1],b.min.z=f[o+2],b.max.x=f[o+3],b.max.y=f[o+4],b.max.z=f[o+5];let d=r(e,g,b,n);if(d===null||s&&d>y)continue;let S=p[o+6],C=p[o+7];for(let n=S;n<C;n++){let r=u[n];this.getPositionByIndex(r,x);let o=x.x,d=x.y,f=x.z,p=e.x,m=e.y,g=e.z,_=t.x,v=t.y,b=t.z,S=_*(o-p)+v*(d-m)+b*(f-g);if(S>0?(p+=_*S,m+=v*S,g+=b*S):S<0&&(S=0),_=o-p,v=d-m,b=f-g,_*_+v*v+b*b<=h){let e=new a(x,x,x,r,new i(p,m,g));(!c||c(e))&&(s?S<y&&(y=S,l.length>0&&(l.length=0),l.push(e)):l.push(e))}}let w=v*36/2,T=m[w+16],E=m[w+17];T&&_.push(T),E&&_.push(E)}return l}};function y(e){onmessage=t=>{Promise.resolve(t.data).then(t=>e(t)).then(({output:e,transfer:t})=>postMessage(e,t)).catch(e=>postMessage({$$error:e}))}}y(e=>Promise.resolve(e).then(e=>{let t=[],n=new Set;for(let r of e){let e;if(r.type===`mesh`)e=new f(r.attributes.position,r.indices);else if(r.type===`points`)e=new v(r.attributes.position,r.indices);else throw Error(`Invalid Type`);e.createTree(r.maxItemPerNode,r.maxTreeDepth,r.extents);let i={type:r.type,attributes:r.attributes,indices:r.indices,offsetArray:e.offsetArray,rootNodePacked:e.rootNodePacked};t.push(i);let a;for(let e in i.attributes){let t=i.attributes[e];t&&t.buffer instanceof ArrayBuffer&&n.add(t.buffer)}a=i.indices,a&&a.buffer instanceof ArrayBuffer&&n.add(a.buffer),a=i.offsetArray,a&&a.buffer instanceof ArrayBuffer&&n.add(a.buffer),n.add(i.rootNodePacked)}return{output:t,transfer:Array.from(n)}}))})();",blob$2=typeof self<`u`&&self.Blob&&new Blob([`(self.URL || self.webkitURL).revokeObjectURL(self.location.href);`,jsContent$2],{type:`text/javascript;charset=utf-8`});function WorkerWrapper$2(e){let t;try{if(t=blob$2&&(self.URL||self.webkitURL).createObjectURL(blob$2),!t)throw``;let n=new Worker(t,{name:e==null?void 0:e.name});return n.addEventListener(`error`,()=>{(self.URL||self.webkitURL).revokeObjectURL(t)}),n}catch(t){return new Worker(`data:text/javascript;charset=utf-8,`+encodeURIComponent(jsContent$2),{name:e==null?void 0:e.name})}}var bvhWorkerPool=new WorkerPool(()=>new WorkerWrapper$2,4),defaultHitFilter=()=>!0,scratchRay=new three.Ray,scratchNormalMatrix=new three.Matrix3,scratchInverseMatrix=new three.Matrix4,scratchIntersectionFaceA=new three.Vector3,scratchIntersectionFaceB=new three.Vector3,scratchIntersectionFaceC=new three.Vector3,intersectsMap=new WeakMap;function raycastMesh(e,t,n,r){var o,s;let c=e.matrixWorld;scratchInverseMatrix.getInverse(c),scratchRay.copy(n.ray).applyMatrix4(scratchInverseMatrix);let l=(o=n.hitFilter)==null?defaultHitFilter:o,u=(s=n.firstHitOnly)==null?!1:s,d=e.geometry,f=e.material,p=d.groups,m=d.index,h=t.intersectRay(scratchRay.origin,scratchRay.direction,0,u,t=>{var r;let o=t.index,s=o*3,u;if(Array.isArray(f)){if(p){for(let e of p)if(s>=e.start&&s-e.start<e.count){u=f[(r=e.materialIndex)==null?0:r];break}}}else u=f;if(!u)return!1;let d=t.intersectionPoint,h=new three.Vector3(d.x,d.y,d.z).applyMatrix4(c),g=n.ray.origin.distanceTo(h);if(g<n.near||g>n.far)return!1;let _=t.pointA,v=t.pointB,y=t.pointC,b=three.Triangle.getNormal(scratchIntersectionFaceA.set(_.x,_.y,_.z).applyMatrix4(c),scratchIntersectionFaceB.set(v.x,v.y,v.z).applyMatrix4(c),scratchIntersectionFaceC.set(y.x,y.y,y.z).applyMatrix4(c),new three.Vector3),S=n.ray.direction.dot(b);if(u.side===three.FrontSide&&S>=0||u.side===three.BackSide&&S<=0)return!1;let C={distance:g,object:e,face:new three.Face3(m?m.array[s]:s,m?m.array[s+1]:s+1,m?m.array[s+2]:s+2,b),point:h,distanceToRay:0,faceIndex:o};return intersectsMap.set(t,C),l(C)}),g=h.length;for(let e=0;e<g;e++){let t=intersectsMap.get(h[e]);t&&r.push(t)}h.length=0}function raycastPoints(e,t,n,r){var o,s,c,l;let u=e.matrixWorld;scratchNormalMatrix.getNormalMatrix(u),scratchInverseMatrix.getInverse(u),scratchRay.copy(n.ray).applyMatrix4(scratchInverseMatrix);let d=((s=(o=n.params.Points)==null?void 0:o.threshold)==null?1:s)*scratchInverseMatrix.getMaxScaleOnAxis(),f=(c=n.hitFilter)==null?defaultHitFilter:c,p=(l=n.firstHitOnly)==null?!1:l,m=e.geometry,h=m.index,g=m.getAttribute(`normal`),_=g instanceof three.BufferAttribute,v=t.intersectRay(scratchRay.origin,scratchRay.direction,d,p,t=>{let r=t.intersectionPoint,o=new three.Vector3(r.x,r.y,r.z).applyMatrix4(u),s=n.ray.origin.distanceTo(o);if(s<n.near||s>n.far)return!1;let c=t.pointA,l=scratchIntersectionFaceA.set(c.x,c.y,c.z).applyMatrix4(u),d=o.distanceTo(l);if(d/s>.07)return!1;let p=t.index,v=h?h.array[p]:p,y;if(_){let e=new three.Vector3().fromBufferAttribute(g,v).applyNormalMatrix(scratchNormalMatrix);y=new three.Face3(v,v,v,e)}else{let e=m.getAttribute(`scale`),t=m.getAttribute(`rotation`);if(e instanceof three.BufferAttribute&&t instanceof three.BufferAttribute){let r=new three.Vector3().fromBufferAttribute(e,v).toArray(),o=new three.Vector4().fromBufferAttribute(t,v).toArray(),s=new three.Quaternion(o[1],o[2],o[3],o[0]),[{axis:c}]=[{axis:`x`,scale:r[0]},{axis:`y`,scale:r[1]},{axis:`z`,scale:r[2]}].sort((e,t)=>e.scale-t.scale),l=new three.Vector3(0,0,0);l[c]=1,l.applyQuaternion(s).applyNormalMatrix(scratchNormalMatrix),n.ray.direction.dot(l)>0&&l.negate(),y=new three.Face3(v,v,v,l)}}let b={distance:s,object:e,face:y,point:o,distanceToRay:d,index:p};return intersectsMap.set(t,b),f(b)}),y=v.length;for(let e=0;e<y;e++){let t=intersectsMap.get(v[e]);t&&r.push(t)}v.length=0}var BVH_MESH_PROP=`__bvh_mesh__`,originMeshRaycast=three.Mesh.prototype.raycast;function overrideMeshRaycast(e,t){let n=getBvhTreeForMesh(this);n?raycastMesh(this,n,e,t):originMeshRaycast.call(this,e,t)}function getBvhTreeForMesh(e){let t=e[BVH_MESH_PROP];return t instanceof BVHMesh,t}function bindBvhTreeForMesh(e,t){Object.assign(e,{[BVH_MESH_PROP]:t,raycast:overrideMeshRaycast})}var BVH_POINTS_PROP=`__bvh_points__`,originPointsRaycast=three.Points.prototype.raycast;function overridePointsRaycast(e,t){let n=getBvhTreeForPoints(this);n?raycastPoints(this,n,e,t):originPointsRaycast.call(this,e,t)}function getBvhTreeForPoints(e){let t=e[BVH_POINTS_PROP];return t instanceof BVHPoints,t}function bindBvhTreeForPoints(e,t){Object.assign(e,{[BVH_POINTS_PROP]:t,raycast:overridePointsRaycast})}function generateBvhTree(e,t=!0,n=100,r=10){let o=[];return e.traverse(e=>{(e instanceof three.Mesh||e instanceof three.Points)&&e.geometry instanceof three.BufferGeometry&&o.push(e)}),t?Promise.resolve().then(()=>{let e=[],t=new Set,s=null;for(let c=0;c<o.length;c++){let l=o[c],u=l.geometry;if(!(u instanceof three.BufferGeometry))continue;let d;if(l instanceof three.Mesh?d=`mesh`:l instanceof three.Points&&(d=`points`),!d)continue;let f=u.boundingBox,p=f?[f.min.x,f.min.y,f.min.z,f.max.x,f.max.y,f.max.z]:void 0,m={};for(let e in u.attributes){let n=u.attributes[e];n instanceof three.InterleavedBufferAttribute?(m[e]={array:n.data.array,stride:n.data.stride,offset:n.offset},s=n.data.array,s&&s.buffer instanceof ArrayBuffer&&t.add(s.buffer)):(m[e]={array:n.array},s=n.array,s&&s.buffer instanceof ArrayBuffer&&t.add(s.buffer))}let h,g=u.getIndex();g&&(g instanceof three.InterleavedBufferAttribute?(h={array:g.data.array,stride:g.data.stride,offset:g.offset},s=g.data.array,s&&s.buffer instanceof ArrayBuffer&&t.add(s.buffer)):(h={array:g.array},s=g.array,s&&s.buffer instanceof ArrayBuffer&&t.add(s.buffer)));let _={type:d,attributes:m,indices:h,maxItemPerNode:n,maxTreeDepth:r,extents:p};e.push(_)}return bvhWorkerPool.postMessage(e,Array.from(t))}).then(t=>{for(let e=0;e<o.length;e++){let n=o[e],r=n.geometry,s=t[e];if(!(r instanceof three.BufferGeometry))continue;for(let e in s.attributes){let t=s.attributes[e].array,n=r.attributes[e];n instanceof three.InterleavedBufferAttribute?n.data.array=t:n.array=t}let c=r.getIndex();if(c&&s.indices){let e=s.indices.array;c instanceof three.InterleavedBufferAttribute?c.data.array=e:c.array=e}if(n instanceof three.Mesh){let e=new BVHMesh(s.attributes.position,s.indices);e.offsetArray=s.offsetArray,e.rootNodePacked=s.rootNodePacked,bindBvhTreeForMesh(n,e)}else if(n instanceof three.Points){let e=new BVHPoints(s.attributes.position,s.indices);e.offsetArray=s.offsetArray,e.rootNodePacked=s.rootNodePacked,bindBvhTreeForPoints(n,e)}}return e}):Promise.resolve().then(()=>{for(let e of o)if(e instanceof three.Mesh){let t=e.geometry,o=t.boundingBox,s=o?[o.min.x,o.min.y,o.min.z,o.max.x,o.max.y,o.max.z]:void 0;if(t instanceof three.BufferGeometry){let o,c,l=t.attributes.position;o=l instanceof three.InterleavedBufferAttribute?{array:l.data.array,stride:l.data.stride,offset:l.offset}:{array:l.array};let u=t.getIndex();u&&(c=u instanceof three.InterleavedBufferAttribute?{array:u.data.array,stride:u.data.stride,offset:u.offset}:{array:u.array});let d=new BVHMesh(o,c);d.createTree(n,r,s),bindBvhTreeForMesh(e,d)}}else if(e instanceof three.Points){let t=e.geometry,o=t.boundingBox,s=o?[o.min.x,o.min.y,o.min.z,o.max.x,o.max.y,o.max.z]:void 0;if(t instanceof three.BufferGeometry){let o,c,l=t.attributes.position;o=l instanceof three.InterleavedBufferAttribute?{array:l.data.array,stride:l.data.stride,offset:l.offset}:{array:l.array};let u=t.getIndex();u&&(c=u instanceof three.InterleavedBufferAttribute?{array:u.data.array,stride:u.data.stride,offset:u.offset}:{array:u.array});let d=new BVHPoints(o,c);d.createTree(n,r,s),bindBvhTreeForPoints(e,d)}}return e})}function mixNumber(e,t,n){return e+(t-e)*n}function value(e,t,n,r){let o=(t*n+2*e)/Math.pow(n,3),s=-(2*t*n+3*e)/Math.pow(n,2),c=t,l=e;return o*Math.pow(r,3)+s*Math.pow(r,2)+c*r+l}function velocity(e,t,n,r){let o=(t*n+2*e)/Math.pow(n,3),s=-(2*t*n+3*e)/Math.pow(n,2),c=t;return 3*o*Math.pow(r,2)+2*s*r+c}function mixCircle(e,t,n,r){let o=r[1]-r[0];return e=circleValue(e,r),t=circleValue(t,r),t-e>o/2?mixNumber(e+o,t,n):e-t>o/2?mixNumber(e-o,t,n):mixNumber(e,t,n)}function circleValue(e,t){let n=t[1]-t[0];return e<t[0]?circleValue(e+n,t):e>=t[1]?circleValue(e-n,t):e}function mixValue(e,t,n,r){return r?mixCircle(e,t,n,r):mixNumber(e,t,n)}function toNumber(e){let t=Number(e);return isNaN(t)||!isFinite(t)?0:t}var Motion=class{constructor(e){this.config={},this.progress=1,this.ended=!0,this.value={},this.startTime=now(),this.startVelocity=0,this.duration=0,this.keyframes=[];for(let t in e){let n=e[t];typeof n==`object`?(this.value[t]=toNumber(n.value),this.config[t]={circle:n.circle}):(this.value[t]=toNumber(n),this.config[t]={circle:!1})}this.keyframes=[{progress:0,value:Object.assign({},this.value)},{progress:1,value:Object.assign({},this.value)}]}getProgress(e){let t=e-this.startTime;return t<0?0:t>=this.duration?1:1-value(1,this.startVelocity,this.duration,t)}getValue(e){for(let t=1;t<this.keyframes.length;t++)if(this.keyframes[t].progress>e){let n=this.keyframes[t-1],r=this.keyframes[t],o={};for(let t in this.config){let s=(e-n.progress)/(r.progress-n.progress);o[t]=mixValue(n.value[t],r.value[t],s,this.config[t].circle)}return o}return Object.assign({},this.keyframes[this.keyframes.length-1].value)}getProgressVelocity(e){let t=e-this.startTime;return t>=this.duration?0:velocity(1,this.startVelocity,this.duration,t)}update(e){return this.ended?!0:(this.progress=Math.min(1,Math.max(0,this.progress,this.getProgress(e))),this.value=this.getValue(this.progress),this.ended=this.progress>=1,this.ended&&this.callbacks&&(this.callbacks[0](),this.callbacks=void 0),this.ended)}getKeyFrameSegment(e){let t=this.getProgress(e);for(let e=1;e<this.keyframes.length;e++)if(this.keyframes[e].progress>t)return[this.keyframes[e-1],this.keyframes[e]];return[this.keyframes[this.keyframes.length-2],this.keyframes[this.keyframes.length-1]]}getTargetKeyframe(){return this.keyframes[this.keyframes.length-1]}set(e,t,n=0,r){var o;isNaN(t)&&(t=0),isNaN(n)&&(n=0),r=r==null?now():r;let s=this.getProgress(r),c=this.getValue(s),l={};for(let t in this.config)l[t]=(o=e[t])==null?c[t]:o;let u=[{progress:0,value:c},{progress:1,value:l}];return this.setKeyframes(u,t,n,r)}setKeyframes(e,t,n=0,r){if(e.length<2)throw Error(`keyframes invalid.`);return isNaN(t)&&(t=0),isNaN(n)&&(n=0),this.callbacks&&(this.callbacks[1](Error(`motion aborted.`)),this.callbacks=void 0),new Promise((o,s)=>{r=r==null?now():r,this.progress=0,this.ended=!1,this.startTime=r,this.startVelocity=n,this.keyframes=e,this.duration=t,t===0?(this.progress=1,this.value=Object.assign({},e[e.length-1].value)):this.value=Object.assign({},e[0].value),this.callbacks=[o,s]})}dispose(){this.callbacks&&(this.callbacks[1](Error(`motion dispose.`)),this.callbacks=void 0)}},PI$1=Math.PI,c1=1.70158,c2=c1*1.525,c3=c1+1,c4=2*PI$1/3,c5=2*PI$1/4.5,linear=function(e){return e},easeInCubic=function(e){return e*e*e},easeInQuart=function(e){return e*e*e*e},APPEAR_ANIMATION_DURATION=500,versionMap$1=new WeakMap,scratchIntersectPoint=new three.Vector3,scratchClippingBoxMatrixInverse=new three.Matrix4,TileNode=class e extends three.Object3D{constructor(e,t,n,r=noop){super(),this.name=e,this.materials=[],this.pbmObjects=[],this.contentObject=t,this.animations=n,this.appearMotion=new Motion({appear:0}),this.disposers=[r],this.add(t),t.traverse(e=>{if(e instanceof three.Mesh||e instanceof three.Points){let t=e.material;if(Array.isArray(t))for(let e=0;e<t.length;e++)this.materials.push(t[e]);else this.materials.push(t)}(e instanceof PBMMesh||e instanceof PBMSkinnedMesh||e instanceof PBMPointCloud||e instanceof PBMGaussianSplattingObject)&&this.pbmObjects.push(e)})}generateBvhTree(){return generateBvhTree(this,!0,200,20)}intersectRaycaster(e,t){let n=t==null?[]:t,r=e.hitFilter;e.hitFilter=t=>{if(t.object instanceof PBMPointCloud&&t.object.material.pointBack===`HIDDEN`&&t.face&&t.face.normal.angleTo(e.ray.direction)<Math.PI/2)return!1;let n=0,o=-1;if((t.object instanceof PBMMesh||t.object instanceof PBMSkinnedMesh||t.object instanceof PBMPointCloud)&&t.face){let e=Array.isArray(t.object.material)?t.object.material[t.face.materialIndex]:t.object.material;if(e){n=e.floorIndex,o=e.shownFloorIndex;for(let r of e.clippers)if(!(typeof r.floorIndex==`number`&&r.floorIndex!==n)&&(scratchClippingBoxMatrixInverse.getInverse(r.clippingBoxMatrix),scratchIntersectPoint.copy(t.point).applyMatrix4(scratchClippingBoxMatrixInverse),Math.abs(scratchIntersectPoint.x)<.5&&Math.abs(scratchIntersectPoint.y)<.5&&Math.abs(scratchIntersectPoint.z)<.5))return!1}}let s=o;return e.floorIndex===void 0?e.floor!==void 0&&(s=e.floor===null?-1:e.floor):s=e.floorIndex,s>=0&&n!==s?!1:(Object.assign(t,{floorIndex:n,floor:n}),r?r.call(e,t):!0)};let o=this.children.slice(),s;for(;s=o.pop();)if(s.visible){s.raycast(e,n);for(let e=0,t=s.children.length;e<t;e++)o.push(s.children[e])}return e.hitFilter=r,sortIntersects(n,e.sortByDistance,e.firstHitOnly),n}update(e,t,n,r,o,s){let c=!1;if(r.visible&&o.state.selectedFrameNumber===o.tileset.frameNumber){let e=1;this.appearMotion.getTargetKeyframe().value.appear!==1&&this.appearMotion.set({appear:1},APPEAR_ANIMATION_DURATION).catch(noop)}else{let e=0;this.appearMotion.getTargetKeyframe().value.appear!==0&&this.appearMotion.set({appear:0},0).catch(noop)}this.appearMotion.ended!==!0&&this.appearMotion.update(t.time);for(let l of this.pbmObjects)l instanceof PBMMesh||l instanceof PBMSkinnedMesh?updatePBMMesh(l,this.appearMotion,e,t,n,o,s)===!0&&(c=!0):l instanceof PBMPointCloud?updatePBMPointCloud(l,this.appearMotion,e,t,n,o,s)===!0&&(c=!0):l instanceof PBMGaussianSplattingObject&&updatePBMGSObject(l,this.appearMotion,e,t,n,r,o,s)===!0&&(c=!0);return c}dispose(){for(let e of this.disposers)e();this.disposers.length=0,this.pbmObjects.length=0}clone(){return new e(this.name,this.contentObject.clone(),this.animations)}};function updatePBMMesh(e,t,n,r,o,s,c){var l,u;let d=!1;if(versionMap$1.get(e)!==c.version){versionMap$1.set(e,c.version),d=!0,e.castShadow=c.castShadow,e.receiveShadow=c.receiveShadow;let t=e.material;for(let e of t)e.customShaders=c.customShaders,e.pano0=c.pano0,e.pano1=c.pano1,e.pano0Depth=c.pano0Depth,e.pano1Depth=c.pano1Depth,e.panoFilter=(u=(l=c.panoFilter)==null?void 0:l.toValue())==null?null:u,e.refinedScreen=c.refinedScreen,e.modelAlpha=c.modelAlpha,e.progress=c.progress,e.transition=c.transition,e.opacity=c.opacity,e.floorStyle=c.floorStyle,e.constantColor=c.constantColor,e.shownFloorIndex=c.shownFloorIndex,e.clippers=c.clippers,e.brightness=c.brightness,e.useHQWeight=c.useHQWeight,e.useHQDepth=c.useHQDepth,e.colorSaturation=c.colorSaturation,e.colorBrightness=c.colorBrightness,e.gradientTexture=c.gradientTexture,e.vertexMarks=c.vertexMarks,e.modelBoundingMax.copy(c.boundingBox.max),e.modelBoundingMin.copy(c.boundingBox.min),e.shaderType===`none`?(e.transparent=!0,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.depthWrite=!1,e.depthTest=!0):(e.transparent=e.alphaMode===`BLEND`,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.depthWrite=!0,e.depthTest=!0,c.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending),e.shownFloorIndex>-1&&e.shownFloorIndex!==e.floorIndex&&(e.transparent=!0),e.opacity<1&&(e.transparent=!0),e.alphaMap&&(e.transparent=!0),e.brightness<1&&(e.transparent=!0),e.modelAlpha<=0&&(e.transparent=!1),e.depthWrite=!e.transparent,c.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending))}return d}function updatePBMPointCloud(e,t,n,r,o,s,c){var l,u;let d=!1;if(c.pointAppearAnimation===!0&&s.refine===`ADD`&&s.tileset.rootMeta.pntsOrder===`RANDOM`){let n=e.geometry,r=s.tileset.currentMaxScreenSpaceError,o=s.state.screenSpaceError,c=(u=(l=s.parent)==null?void 0:l.state.screenSpaceError)==null?o:u,f=1;c!==o&&(f=(c-r)/(c-o)),f=clamp$1(f,0,1),f=easeInCubic(f);let p=n.index?n.index.count:n.attributes.position?n.attributes.position.count:1/0,m=Math.floor(p*f*t.value.appear);n.drawRange.count!==m&&(n.setDrawRange(0,m),d=!0)}if(versionMap$1.get(e)!==c.version){versionMap$1.set(e,c.version),d=!0,e.castShadow=c.castShadow,e.receiveShadow=c.receiveShadow;let t=[e.material];for(let e of t)e.customShaders=c.customShaders,e.pointScale=c.pointScale,e.pointMinPixel=c.pointMinPixel,e.pointMaxPixel=c.pointMaxPixel,e.pointSize=c.pointSize,e.pointShape=c.pointShape,e.pointBack=c.pointBack,e.modelAlpha=c.modelAlpha,e.opacity=c.opacity,e.floorStyle=c.floorStyle,e.constantColor=c.constantColor,e.shownFloorIndex=c.shownFloorIndex,e.clippers=c.clippers,e.brightness=c.brightness,e.useHQWeight=c.useHQWeight,e.useHQDepth=c.useHQDepth,e.colorSaturation=c.colorSaturation,e.colorBrightness=c.colorBrightness,e.outlineGain=c.outlineGain,e.distanceGain=c.distanceGain,e.gradientTexture=c.gradientTexture,e.transparent=!1,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.colorWrite=!0,e.depthWrite=!0,e.depthTest=!0,e.modelBoundingMax.copy(c.boundingBox.max),e.modelBoundingMin.copy(c.boundingBox.min),e.shownFloorIndex>-1&&(e.transparent=e.shownFloorIndex!==e.floorIndex),e.modelAlpha<1&&(e.transparent=!0),e.opacity<1&&(e.transparent=!0),e.brightness<1&&(e.transparent=!0),c.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending),e.useHQWeight&&(e.depthWrite=!1,e.blending=three.CustomBlending,e.blendSrc=three.SrcAlphaFactor,e.blendSrcAlpha=three.SrcAlphaFactor,e.blendDst=three.OneFactor,e.blendDstAlpha=three.OneFactor),e.useHQDepth&&(e.colorWrite=!1)}return d}function updatePBMGSObject(e,t,n,r,o,s,c,l){let u=!1,d=s.uuid;return e.gsViewLayerKey!==d&&(e.gsViewLayerKey=d,u=!0),e.gsClippers!==l.clippers&&(e.gsClippers=l.clippers,u=!0),e.updateMatrix(),e.updateMatrixWorld(),e.usedSHDegree=l.gaussianSplattingSHDegree,e.lastMatrixWorld?e.transformChanged=!e.lastMatrixWorld.equals(e.matrixWorld):(e.lastMatrixWorld=new three.Matrix4,e.transformChanged=!0,u=!0),e.lastMatrixWorld.copy(e.matrixWorld),e.transformChanged&&(u=!0),u}var Trajectory=class{constructor(e,t,n){this.id=e,this.name=t.name,this.visible=!1,this.tileset=n,this.transform=new three.Matrix4,t.transform&&this.transform.fromArray(t.transform),this.transform.premultiply(this.tileset.root.transform),this.content={uri:t.file,byteLength:0,memoryUsage:0,loadState:`UNLOADED`,loadProgress:0,loadStateUpdateTime:now(),loadfailRetryDelay:0,data:void 0}}},TrajectoryNode=class e extends three.Object3D{constructor(e,t,n=noop){super(),this.name=e,this.contentObject=t,this.name=e,this.add(t),this.disposers=[n]}update(e,t,n,r,o,s){let c=this.contentObject.material[2];return c.uniforms.dashOffset.value=(c.uniforms.dashOffset.value-.003)%(c.uniforms.dashSize.value.x+c.uniforms.dashSize.value.y),!0}dispose(){for(let e of this.disposers)e();this.disposers.length=0}clone(){return new e(this.name,this.contentObject.clone())}},priorityCache=new Map;function getPriority(e,t,n){if(n&&n.has(t))return n.get(t);let r=t.refine===`ADD`||e.skipLevelOfDetail,o=t.parent,s=o&&(!r||t.state.screenSpaceError===0)?o.state.screenSpaceError:t.state.screenSpaceError,c=t.tileset.root?t.tileset.root.state.screenSpaceError:0,l=Math.max(c-s,0);return n&&n.set(t,l),l}var TileRequestScheduler=class{constructor(e,t){this.tileset=e,this.options=t,this.activeRequests=0,this.requestQueue=[]}reset(){for(let e of this.requestQueue)this.options.onTileSkip&&(e.tile.content&&this.tileset.options.tileUnloader(e.tile),this.options.onTileSkip(e.tile));this.requestQueue.length=0}update(e,t,n){let r=n.time,o=this.requestQueue,s=new Set(e);for(let e=0;e<o.length;e++){let t=o[e];if(s.has(t.tile)){s.delete(t.tile);continue}t.status===`WAITING`&&(o.splice(e,1),e--,this.options.onTileSkip&&this.options.onTileSkip(t.tile))}s.size>0&&(s.forEach(e=>{o.push({tile:e,status:`WAITING`,time:r,error:null})}),s.clear());let c=n.maxRequests;for(let e=0;e<o.length&&c>0;e++){let t=o[e];if(t.status===`DONE`)t.error===null?(c--,t.tile.content&&(t.tile.content.loadState=`READY`),this.options.onTileLoad&&this.options.onTileLoad(t.tile)):this.options.onTileError&&this.options.onTileError(t.tile,t.error),o.splice(e,1),e--;else if(t.status===`PENDING`&&r-t.time<1e3)break}switch(priorityCache.clear(),t){case`SCREEN_SPACE_ERROR`:o.sort((e,t)=>e.tile.state.requestedFrameNumber===t.tile.state.requestedFrameNumber?e.tile.state.requestedFrameNumber===n.frameNumber?getPriority(n,e.tile,priorityCache)-getPriority(n,t.tile,priorityCache):e.tile.level===t.tile.level?e.tile.state.distanceToCamera-t.tile.state.distanceToCamera:e.tile.level-t.tile.level:t.tile.state.requestedFrameNumber-e.tile.state.requestedFrameNumber);break;case`SCREEN_VERTICAL`:o.sort((e,t)=>e.tile.state.requestedFrameNumber===t.tile.state.requestedFrameNumber?e.tile.state.requestedFrameNumber===n.frameNumber?e.tile.state.centerScreenY===t.tile.state.centerScreenY?e.tile.state.centerZDepth===t.tile.state.centerZDepth?e.tile.level===t.tile.level?e.tile.state.distanceToCamera-t.tile.state.distanceToCamera:e.tile.level-t.tile.level:e.tile.state.centerZDepth-t.tile.state.centerZDepth:e.tile.state.centerScreenY-t.tile.state.centerScreenY:e.tile.level===t.tile.level?e.tile.state.distanceToCamera-t.tile.state.distanceToCamera:e.tile.level-t.tile.level:t.tile.state.requestedFrameNumber-e.tile.state.requestedFrameNumber);break;case`SCREEN_LEVEL_VERTICAL`:o.sort((e,t)=>e.tile.state.requestedFrameNumber===t.tile.state.requestedFrameNumber?e.tile.state.requestedFrameNumber===n.frameNumber?e.tile.level===t.tile.level?e.tile.state.centerScreenY===t.tile.state.centerScreenY?e.tile.state.centerZDepth===t.tile.state.centerZDepth?e.tile.state.distanceToCamera-t.tile.state.distanceToCamera:e.tile.state.centerZDepth-t.tile.state.centerZDepth:e.tile.state.centerScreenY-t.tile.state.centerScreenY:e.tile.level-t.tile.level:e.tile.level===t.tile.level?e.tile.state.distanceToCamera-t.tile.state.distanceToCamera:e.tile.level-t.tile.level:t.tile.state.requestedFrameNumber-e.tile.state.requestedFrameNumber);break;default:break}if(c=Math.max(n.maxRequests-this.activeRequests,0),!n.skipLevelOfDetail){let e=0,t=o.length;for(let r=0;r<t;r++){let t=o[r].tile;if(t.hasTilesetContent||t.contentParent===null||t.contentParent.state.selectedFrameNumber===n.frameNumber){let t=o.splice(r,1);o.splice(e++,0,...t)}}}for(let e=0;e<o.length&&c>0;e++){let t=o[e];t.status===`WAITING`&&(c--,t.status=`PENDING`,t.time=r,this.activeRequests++,this.tileset.options.tileLoader(t.tile).catch(e=>{t.error=e}).then(()=>{t.status=`DONE`,t.tile.content&&t.tile.content.loadState===`READY`&&(t.tile.content.loadState=`LOADING`),this.activeRequests--}))}}},CacheNode=class{constructor(e,t,n){this.item=e,this.previous=t,this.next=n}},CacheNodeList=class{constructor(){this.head=null,this.tail=null,this._length=0}get length(){return this._length}add(e){let t=new CacheNode(e,this.tail,null);return this.tail?(this.tail.next=t,this.tail=t):(this.head=t,this.tail=t),this._length++,t}remove(e){e.previous&&e.next?(e.previous.next=e.next,e.next.previous=e.previous):e.previous?(e.previous.next=null,this.tail=e.previous):e.next?(e.next.previous=null,this.head=e.next):(this.head=null,this.tail=null),e.next=null,e.previous=null,this._length--}splice(e,t){e!==t&&(this.remove(t),this.insert(e,t))}insert(e,t){let n=e.next;e.next=t,this.tail===e?this.tail=t:n.previous=t,t.next=n,t.previous=e,this._length++}toArray(){let e=[],t=this.head;for(;t;)e.push(t),t=t.next;return e}},TileCache=class{constructor(e={}){this.options=e,this.cacheNodeMap=new WeakMap,this.list=new CacheNodeList,this.sentinel=this.list.add(`sentinel`)}reset(){this.list.tail&&this.list.splice(this.list.tail,this.sentinel)}touchTile(e){let t=this.cacheNodeMap.get(e);t&&this.list.splice(this.sentinel,t)}loadTile(e){if(!this.cacheNodeMap.has(e)){let t=this.list.add(e);this.cacheNodeMap.set(e,t),this.options.onTileLoad&&this.options.onTileLoad(e)}}unloadTile(e){let t=this.cacheNodeMap.get(e);t&&(this.list.remove(t),this.cacheNodeMap.delete(e),this.options.onTileUnload&&this.options.onTileUnload(e))}unloadTiles(e){let t=this.list.head;for(;t!==this.sentinel&&e();){let e=t.item;t=t.next,this.unloadTile(e)}}toArray(){let e=[];for(let t of this.list.toArray())t.item!==`sentinel`&&e.push(t.item);return e}},ManagedArray=class{constructor(){this.map=new Map,this.array=[],this._length=0}get length(){return this._length}get(e){return this.array[e]}set(e,t){e>=this.length&&(this._length=e+1),this.map.has(this.array[e])&&this.map.delete(this.array[e]),this.array[e]=t,this.map.set(t,e)}delete(e){let t=this.map.get(e);t!==void 0&&t>=0&&(this.array.splice(t,1),this.map.delete(e),this._length--)}push(e){if(!this.map.has(e)){let t=this._length++;this.array[t]=e,this.map.set(e,t)}}pop(){let e=this.array[--this._length];return this.map.delete(e),this.array[this._length]=void 0,e}reset(){this.array=[],this.map=new Map,this._length=0}find(e){return this.map.has(e)}peek(){return this.array[this._length-1]}},TilesetBaseTraverser=class{constructor(e){this.tileset=e,this._canSelectTile=!0,this._loadAllTilesTraversalStack=new ManagedArray}traverse(e,t,n=[]){this.reset()}reset(){this._loadAllTilesTraversalStack.reset(),this.tileset.hasMixedContent=!1,this.tileset.needsRefinedTiles.clear(),this.tileset.requestedTiles.length=0,this.tileset.selectedTiles.length=0}updateTile(e,t){this.updateTileVisibility(e,t),e.state.shouldSelect=!1,e.state.finalResolution=!0}selectTile(e,t){this._canSelectTile&&e.contentAvailable&&e.state.selectedFrameNumber<t.frameNumber&&(e.state.selectedFrameNumber=t.frameNumber,this.tileset.selectedTiles.push(e),this.tileset.needsRefinedTiles.add(e))}loadTile(e,t){this._canSelectTile&&(e.state.requestedFrameNumber<t.frameNumber&&(e.state.requestedFrameNumber=t.frameNumber,e.content&&(e.content.loadState===`FAILED`&&t.time-e.content.loadStateUpdateTime>e.content.loadfailRetryDelay&&(e.content.loadState=`UNLOADED`,e.content.loadProgress=0,e.content.loadStateUpdateTime=t.time),e.content.loadState===`UNLOADED`&&this.tileset.requestedTiles.push(e))),this.tileset.needsRefinedTiles.add(e))}touchTile(e,t){this._canSelectTile&&(this.tileset.cache.touchTile(e),e.state.touchedFrameNumber=t.frameNumber)}canTraverse(e,t){return!e.state.inRequestVolume||e.hasRenderContent&&(e.levelOfContent>=t.maxLevelOfDetail||e.levelOfContent>=0&&e.geometricError<=t.minGeometricError)||e.children.length===0?!1:e.levelOfContent<t.minLevelOfDetail||e.geometricError>=t.maxGeometricError||e.hasTilesetContent?!0:e.state.screenSpaceError>this.tileset.currentMaxScreenSpaceError}updateTileVisibility(e,t){if(e.updateState(t),!e.state.visible||!e.state.inRequestVolume)return;let n=e.children.length>0;if(e.hasTilesetContent&&n){let n=e.children[0];this.updateTileVisibility(n,t),e.state.visible=n.state.visible;return}if(this.meetsScreenSpaceErrorEarly(e,t)){e.state.visible=!1;return}if(e.refine===`REPLACE`&&n&&!this.anyChildrenVisible(e,t)){e.state.visible=!1;return}}anyChildrenVisible(e,t){let n=!1,r=e.children;for(let e of r)e.updateState(t),n=n||e.state.visible;return n}meetsScreenSpaceErrorEarly(e,t){let{parent:n}=e;return!n||n.refine!==`ADD`||n.levelOfContent<t.minLevelOfDetail||n.geometricError>t.maxGeometricError?!1:n.levelOfContent>t.maxLevelOfDetail||n.levelOfContent>=0&&n.geometricError<t.minGeometricError?!0:e.getScreenSpaceError(t,e.state.distanceToCamera,!0)<this.tileset.currentMaxScreenSpaceError}sortTilesByDistanceToCamera(e){e.sort((e,t)=>t.state.distanceToCamera===0&&e.state.distanceToCamera===0?t.state.centerZDepth-e.state.centerZDepth:t.state.distanceToCamera-e.state.distanceToCamera)}},TilesetNormalTraverser=class extends TilesetBaseTraverser{constructor(e){super(e),this._traversalStack=new ManagedArray,this._emptyTraversalStack=new ManagedArray}traverse(e,t,n=[]){super.traverse(e,t,n);for(let t of n)this._traversalStack.reset(),this._emptyTraversalStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,this.updateTile(e,t),this.executeTraversal(e,t));this._traversalStack.reset(),this._emptyTraversalStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,this.updateTile(e,t),this.executeTraversal(e,t))}reset(){super.reset(),this._traversalStack.reset(),this._emptyTraversalStack.reset()}executeTraversal(e,t){let n=this._traversalStack;for(e.state.visible&&e.state.inRequestVolume&&n.push(e);n.length>0;){let e=n.pop(),r=e.parent,o=!r||r.state.shouldRefine,s=!1;this.canTraverse(e,t)&&(s=this.updateAndPushChildren(e,t,n)&&o);let c=!s&&o;e.hasRenderContent?e.refine===`ADD`?(this.loadTile(e,t),this.selectDesiredTile(e,t)):e.refine===`REPLACE`&&(this.loadTile(e,t),c&&this.selectDesiredTile(e,t)):(this.loadTile(e,t),c&&this.selectDesiredTile(e,t)),this.touchTile(e,t),e.state.shouldRefine=s}}updateAndPushChildren(e,t,n){let r=e.children;for(let e of r)this.updateTile(e,t);this.sortTilesByDistanceToCamera(r);let o=e.refine===`REPLACE`&&e.hasRenderContent,s=!1,c=!0;for(let e of r)if(e.levelOfContent<=t.minLevelOfDetail||e.geometricError>=t.maxGeometricError||e.state.visible&&e.state.inRequestVolume?(n.find(e)&&n.delete(e),n.push(e),s===!1&&(s=!0)):(o||t.loadSiblings)&&(this.loadTile(e,t),this.touchTile(e,t)),o){let n;n=e.state.inRequestVolume?e.hasRenderContent?e.contentAvailable:this.executeEmptyTraversal(e,t):!1,c=c&&n}return s||(c=!1),c}selectDesiredTile(e,t){e.contentAvailable&&super.selectTile(e,t)}executeEmptyTraversal(e,t){let n=!0,r=this._emptyTraversalStack;for(r.push(e);r.length>0&&n;){let e=r.pop(),o=!e.hasRenderContent&&this.canTraverse(e,t);if(!o&&!e.contentAvailable&&(n=!1),this.updateTile(e,t),e.state.visible||(this.loadTile(e,t),this.touchTile(e,t)),o){let t=e.children;for(let e of t)r.find(e)&&r.delete(e),r.push(e)}}return n}},TilesetSkipTraverser=class extends TilesetBaseTraverser{constructor(e){super(e),this.baseScreenSpaceError=1024,this.skipScreenSpaceErrorFactor=16,this.skipLevels=1,this._traversalStack=new ManagedArray,this._descendantTraversalStack=new ManagedArray,this._selectionTraversalStack=new ManagedArray,this._selectionTraversalancestorStack=new ManagedArray}traverse(e,t,n=[]){super.traverse(e,t,n);for(let t of n)this._traversalStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,this.updateTile(e,t),this.executeTraversal(e,t),this.traverseAndSelect(e,t));this.tileset.hasMixedContent=!1,this._traversalStack.reset(),this._descendantTraversalStack.reset(),this._selectionTraversalStack.reset(),this._selectionTraversalancestorStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,this.updateTile(e,t),this.executeTraversal(e,t),this.traverseAndSelect(e,t))}reset(){super.reset(),this._traversalStack.reset(),this._descendantTraversalStack.reset(),this._selectionTraversalStack.reset(),this._selectionTraversalancestorStack.reset()}executeTraversal(e,t){let n=this._traversalStack;for(e.state.visible&&e.state.inRequestVolume&&n.push(e);n.length>0;){let e=n.pop();this.updateTileAncestorContentLinks(e,t);let r=e.parent,o=!r||r.state.shouldRefine,s=!1;this.canTraverse(e,t)&&(s=this.updateAndPushChildren(e,t,n)&&o);let c=!s&&o;e.hasRenderContent?e.refine===`ADD`?(this.loadTile(e,t),this.selectDesiredTile(e,t)):e.refine===`REPLACE`&&(this.inBaseTraversal(e,this.baseScreenSpaceError)?(this.loadTile(e,t),c&&this.selectDesiredTile(e,t)):c?(this.loadTile(e,t),this.selectDesiredTile(e,t)):this.reachedSkippingThreshold(e)&&this.loadTile(e,t)):(this.loadTile(e,t),c&&this.selectDesiredTile(e,t)),this.touchTile(e,t),e.state.shouldRefine=s}}updateAndPushChildren(e,t,n){let r=e.children;for(let e of r)this.updateTile(e,t);this.sortTilesByDistanceToCamera(r);let o=!1;for(let e of r)e.levelOfContent<=t.minLevelOfDetail||e.geometricError>=t.maxGeometricError||e.state.visible&&e.state.inRequestVolume?(n.push(e),o===!1&&(o=!0)):t.loadSiblings&&(this.loadTile(e,t),this.touchTile(e,t));return o}selectDesiredTile(e,t){let n=e.contentAvailable?e:e.state.ancestorWithContentAvailable;n&&(n.state.shouldSelect=!0),e.contentAvailable||this.selectDescendants(e,t)}selectDescendants(e,t){let n=this._descendantTraversalStack;for(n.push(e);n.length>0;){let e=n.pop().children;for(let r of e)r.state.visible&&(r.contentAvailable?(this.updateTile(r,t),this.touchTile(r,t),this.selectTile(r,t)):n.push(r))}}reachedSkippingThreshold(e){let t=e.state.ancestorWithContent;return t!==null&&e.state.screenSpaceError<t.state.screenSpaceError/this.skipScreenSpaceErrorFactor&&e.levelOfContent>t.levelOfContent+this.skipLevels}updateTileAncestorContentLinks(e,t){e.state.ancestorWithContent=null,e.state.ancestorWithContentAvailable=null;let{parent:n}=e;if(!n)return;let r=!(n.hasRenderContent&&n.hasUnloadedContent)||n.state.requestedFrameNumber===t.frameNumber;e.state.ancestorWithContent=r?n:n.state.ancestorWithContent,e.state.ancestorWithContentAvailable=n.contentAvailable?n:n.state.ancestorWithContentAvailable}inBaseTraversal(e,t){return e.state.ancestorWithContent?e.parent&&e.state.screenSpaceError===0?e.parent.state.screenSpaceError>t:e.state.screenSpaceError>t:!0}traverseAndSelect(e,t){let n=this._selectionTraversalStack,r=this._selectionTraversalancestorStack,o;for(n.push(e);n.length>0||r.length>0;){if(r.length>0){let e=r.peek();if(e.state.stackLength===n.length){r.pop(),e!==o&&(e.state.finalResolution=!1),this.selectTile(e,t);continue}}let e=n.pop();if(!e)continue;let s=this.canTraverse(e,t);if(e.state.shouldSelect)if(e.refine===`ADD`)this.selectTile(e,t);else{if(e.state.selectionDepth=r.length,e.state.selectionDepth>0&&(e.tileset.hasMixedContent=!0),o=e,!s){this.selectTile(e,t);continue}r.push(e),e.state.stackLength=n.length}if(s)for(let t of e.children)t.state.visible&&n.push(t)}}},TilesetMostDetailTraverser=class extends TilesetBaseTraverser{constructor(e){super(e),this._traversalStack=new ManagedArray}canTraverse(e,t){return!(!e.state.inRequestVolume||e.levelOfContent>=t.maxLevelOfDetail||e.levelOfContent>=0&&e.geometricError<=t.minGeometricError||e.children.length===0)}traverse(e,t,n){super.traverse(e,t,[]),this._traversalStack.reset(),e.updateState(t);for(let t of n)this._traversalStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,e.updateState(t),this.executeTraversal(e,t));this._traversalStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,e.updateState(t),this.executeTraversal(e,t))}reset(){super.reset(),this._traversalStack.reset()}executeTraversal(e,t){let n=this._traversalStack;for(n.push(e);n.length>0;){let e=n.pop(),r=e.refine===`ADD`,o=e.refine===`REPLACE`,s=this.canTraverse(e,t);s&&this.updateAndPushChildren(e,t,n),(r||o&&!s)&&(this.loadTile(e,t),this.touchTile(e,t),this.selectDesiredTile(e,t))}}updateAndPushChildren(e,t,n){let{children:r}=e;for(let e=0;e<r.length;++e){let o=r[e];o.updateState(t),o.state.visible&&n.push(o)}}selectDesiredTile(e,t){e.contentAvailable&&super.selectTile(e,t)}},Tileset=class{constructor(e,t){var n,r,o,s,c,l,u;if(this.id=e.tilesetUrl,this.transform=new three.Matrix4,this.hasMixedContent=!1,this.frameNumber=0,this.asset={version:e.asset.version,tilesetVersion:e.asset.tilesetVersion||``,gltfUpAxis:(n=e.asset.gltfUpAxis)==null?`Y`:n,overview:e.asset.overview,trajectories:(o=(r=e.asset.trajectories)==null?void 0:r.list)==null?[]:o,extras:e.asset.extras},this.rootMeta=(s=e.rootMeta)==null?{}:s,this.pointLength=(c=this.rootMeta.numTotalPoints)==null?1/0:c,this.floorLength=(l=this.rootMeta.numFloors)==null?1:l,this.properties=(u=e.properties)==null?{}:u,this.options=t,this.requestedTiles=[],this.selectedTiles=[],this.unloadTiles=[],this.needsRefinedTiles=new Set,this.selectedTrajectories=[],this.normalTraverser=new TilesetNormalTraverser(this),this.skipTraverser=new TilesetSkipTraverser(this),this.mostDetailTraverser=new TilesetMostDetailTraverser(this),this.cache=new TileCache({onTileLoad:e=>{this.cacheMemoryUsageInBytes+=e.contentMemoryUsage},onTileUnload:e=>{this.cacheMemoryUsageInBytes-=e.contentMemoryUsage,this.unloadTiles.push(e)}}),this.requestScheduler=new TileRequestScheduler(this,{onTileSkip:e=>{},onTileLoad:e=>{var t;(t=e.content)!=null&&t.data&&(this.loadedTiles.add(e),this.cache.loadTile(e)),this.options.onTileLoad(e)},onTileError:(e,t)=>{this.options.onTileError(e,t)}}),this.loadedTiles=new Set,this.cacheMemoryUsageInBytes=0,this.currentMaxScreenSpaceError=NaN,this.root=new Tile(`${this.id}#tile:0`,e.root,this),this.geometricError=e.geometricError,this.trajectories=[],this.asset.trajectories)for(let e=0;e<this.asset.trajectories.length;e++){let t=new Trajectory(`${this.id}#trajectory:${e}`,this.asset.trajectories[e],this);this.trajectories.push(t)}}adjustScreenSpaceError(e){if((isNaN(this.currentMaxScreenSpaceError)||!isFinite(this.currentMaxScreenSpaceError))&&(this.currentMaxScreenSpaceError=e.maxScreenSpaceError),e.memoryAdjustedScreenSpaceError){let t=0,n=0,r=0;if(this.needsRefinedTiles.forEach(e=>{e.content&&(n++,t+=e.content.memoryUsage,e.content.loadState===`READY`&&r++)}),r<2||n<2)this.currentMaxScreenSpaceError=e.maxScreenSpaceError;else{let o=1024*1024,s=t/r*n,c=e.maxMemoryUsage*o,l=c-clamp$1(c*.1,8*o,64*o),u=this.currentMaxScreenSpaceError;if(s<l){let e=.5*(1-s/l);u-=e}else s>c&&(u+=.3);u=clamp$1(u,1,e.maxScreenSpaceError),Math.abs(u-this.currentMaxScreenSpaceError)>=.1&&(this.currentMaxScreenSpaceError=u)}}else this.currentMaxScreenSpaceError=e.maxScreenSpaceError}getTraverser(e){return e.mostDetail?this.mostDetailTraverser:e.skipLevelOfDetail?this.skipTraverser:this.normalTraverser}reset(){this.cache.reset(),this.skipTraverser.reset(),this.normalTraverser.reset(),this.mostDetailTraverser.reset(),this.requestScheduler.reset();let e=[this.root],t;for(;t=e.pop();){for(let n=0,r=t.children.length;n<r;n++)e.push(t.children[n]);this.cache.unloadTile(t)}for(;this.unloadTiles.length;){let e=this.unloadTiles.pop();e&&(this.loadedTiles.delete(e),this.cacheMemoryUsageInBytes-=e.contentMemoryUsage,this.options.tileUnloader(e).catch(()=>{}).then(()=>{this.options.onTileUnload&&this.options.onTileUnload(e)}))}for(this.loadedTiles.clear();this.trajectories.length;){let e=this.trajectories.pop();e&&this.options.trajectoryUnloader(e).catch(()=>{}).then(()=>{this.options.onTrajectoryUnload&&this.options.onTrajectoryUnload(e)})}}update(e,t=[]){var n;for(this.frameNumber=e.frameNumber,this.adjustScreenSpaceError(e),this.cache.reset(),this.getTraverser(e).traverse(this.root,e,t),this.cache.unloadTiles(()=>this.cacheMemoryUsageInBytes>e.maxMemoryUsage*1024*1024),this.requestScheduler.update(this.requestedTiles,e.requestOrder,e);this.unloadTiles.length;){let e=this.unloadTiles.pop();e&&(this.loadedTiles.delete(e),this.options.tileUnloader(e).catch(()=>{}).then(()=>{this.options.onTileUnload&&this.options.onTileUnload(e)}))}this.selectedTrajectories.length=0;for(let t of this.trajectories)t.visible===!0&&t.content.loadState===`READY`&&(n=t.content.data)!=null&&n.object?this.selectedTrajectories.push(t):t.visible===!0&&(t.content.loadState===`FAILED`&&e.time-t.content.loadStateUpdateTime>t.content.loadfailRetryDelay&&(t.content.loadState=`UNLOADED`,t.content.loadStateUpdateTime=e.time),t.content.loadState===`UNLOADED`&&this.options.trajectoryLoader(t).then(()=>{this.options.onTrajectoryLoad(t)}).catch(e=>{this.options.onTrajectoryError(t,e)}))}};function normalizeTileHeader(e,t){var n;if(e.content){let r=(n=e.content.uri)==null?e.content.url:n;typeof r==`string`&&!isAbsoluteURL(r)&&(e.content.uri=normalizeURL(pathJoin(t,r)))}if(e.transform){let t=!1;for(let n=0;n<16;n++){let r=e.transform[n];if(typeof r!=`number`||isNaN(r)||!isFinite(r)){t=!0;break}}if(e.transform[15]===0&&(t=!0),t)throw Error(`Invalid Tile Transform: `+JSON.stringify(e.transform))}if(e.children)for(let n of e.children)normalizeTileHeader(n,t);return e}function normalizeTilesetHeader(e,t){e.tilesetUrl=t;let n=/^blob\:/.test(t)?``:t.slice(0,t.lastIndexOf(`/`)+1);if(e.asset||(e.asset={}),e.rootMeta||(e.rootMeta={}),e.rootMeta.taskParameters||(e.rootMeta.taskParameters={}),e.asset.overview){let t=e.asset.overview;isAbsoluteURL(t.imageFile)||(t.imageFile=normalizeURL(pathJoin(n,t.imageFile))),isAbsoluteURL(t.worldFile)||(t.worldFile=normalizeURL(pathJoin(n,t.worldFile)))}if(e.asset.trajectories)for(let t=0;t<e.asset.trajectories.list.length;t++){let r=e.asset.trajectories.list[t];r.file=normalizeURL(pathJoin(n,r.file))}return normalizeTileHeader(e.root,n),e}function delay(e){return new Promise(t=>setTimeout(t,e))}var AsyncTaskQueue=class{constructor(e){this.queue=[],this.concurrency=e,this.dequeuing=0}add(e,t=1e3){let n,r,o=new Promise((e,t)=>{n=e,r=t});return this.queue.unshift(()=>{let o=Promise.resolve().then(e);o.then(n,r);let s=delay(t);return Promise.race([o,s]).then(noop,noop)}),this.dequeue(),o}dequeue(){for(;this.dequeuing<this.concurrency&&this.queue.length>0;){let e=this.queue.pop();this.dequeuing++,e().catch(noop).then(()=>{this.dequeuing--,this.dequeue()})}}},initTextureQueue=new AsyncTaskQueue(1),skipImageSize=256;function canInit(e){return typeof e.image==`object`&&e.image.width>0&&e.image.height>0}function initTexture(e,t){if(!canInit(e))return Promise.resolve(e);if(e.image.width<skipImageSize&&e.image.width<skipImageSize)return t.initTexture(e),Promise.resolve(e);let n=!1,r=()=>{n=!0,e.removeEventListener(`dispose`,r)};return e.addEventListener(`dispose`,r),initTextureQueue.add(()=>new Promise(o=>{AnimationFrameLoop.shared.add(()=>{canInit(e)&&n===!1&&t.initTexture(e),e.removeEventListener(`dispose`,r),o(e)},!0)}))}function initTextures(e,t){return Promise.all(e.map(e=>initTexture(e,t)))}var _object_pattern=/^[og]\s*(.+)?/,_material_library_pattern=/^mtllib /,_material_use_pattern=/^usemtl /,_map_use_pattern=/^usemap /,_face_vertex_data_separator_pattern=/\s+/,_color=new three.Color,ObjState=class{constructor(){this.objects=[],this.vertices=[],this.normals=[],this.colors=[],this.uvs=[],this.materials={},this.materialLibraries=[],this.startObject(``,!1)}startObject(e,t){if(this.object&&this.object.fromDeclaration===!1){this.object.name=e,this.object.fromDeclaration=t!==!1;return}let n=this.object&&typeof this.object.currentMaterial==`function`?this.object.currentMaterial():void 0;if(this.object&&typeof this.object._finalize==`function`&&this.object._finalize(!0),this.object={name:e||``,fromDeclaration:t!==!1,geometry:{vertices:[],hasNormal:!0,normals:[],hasColor:!0,colors:[],hasUV:!0,uvs:[],index:[],indexMap:{}},materials:[],smooth:!0,startMaterial:function(e,t){var n,r;let o=this._finalize(!1);o&&(o.inherited||((n=o.groupCount)==null?0:n)<=0)&&this.materials.splice((r=o.index)==null?0:r,1);let s={index:this.materials.length,name:e||``,mtllib:Array.isArray(t)&&t.length>0?t[t.length-1]:``,smooth:o===void 0?this.smooth:o.smooth,groupStart:o===void 0?0:o.groupEnd,groupEnd:-1,groupCount:-1,inherited:!1,clone:function(e){let t={index:typeof e==`number`?e:this.index,name:this.name,mtllib:this.mtllib,smooth:this.smooth,groupStart:0,groupEnd:-1,groupCount:-1,inherited:!1,clone(){return this}};return t.clone=this.clone.bind(t),t}};return this.materials.push(s),s},currentMaterial:function(){if(this.materials.length>0)return this.materials[this.materials.length-1]},_finalize:function(e){var t,n;let r=this.currentMaterial();if(r&&r.groupEnd===-1&&(r.groupEnd=this.geometry.index.length,r.groupCount=r.groupEnd-((t=r.groupStart)==null?0:t),r.inherited=!1),e&&this.materials.length>1)for(let e=this.materials.length-1;e>=0;e--)((n=this.materials[e].groupCount)==null?0:n)<=0&&this.materials.splice(e,1);return e&&this.materials.length===0&&this.materials.push({name:``,smooth:this.smooth}),r}},n&&n.name&&typeof n.clone==`function`){let e=n.clone(0);e.inherited=!0,this.object.materials.push(e)}this.objects.push(this.object)}finalize(){this.object&&typeof this.object._finalize==`function`&&this.object._finalize(!0)}parseVertexIndex(e,t){let n=parseInt(e,10);return(n>=0?n-1:n+t/3)*3}parseNormalIndex(e,t){let n=parseInt(e,10);return(n>=0?n-1:n+t/3)*3}parseUVIndex(e,t){let n=parseInt(e,10);return(n>=0?n-1:n+t/2)*2}addFace(e,t,n,r,o,s,c,l,u){let d=this.object.geometry,f=this.vertices.length,p=this.normals.length,m=this.uvs.length,h=this.parseVertexIndex(e,f),g=this.parseVertexIndex(t,f),_=this.parseVertexIndex(n,f),v=c===void 0?void 0:this.parseNormalIndex(c,p),y=l===void 0?void 0:this.parseNormalIndex(l,p),b=u===void 0?void 0:this.parseNormalIndex(u,p),S=r===void 0?void 0:this.parseUVIndex(r,m),C=o===void 0?void 0:this.parseUVIndex(o,m),w=s===void 0?void 0:this.parseUVIndex(s,m);(d.hasNormal===!0&&v===void 0||y===void 0||b===void 0)&&(d.hasNormal=!1),(d.hasUV===!0&&S===void 0||C===void 0||w===void 0)&&(d.hasUV=!1);let T=[h,S,v].join(`:`),E=d.indexMap[T];E===void 0&&(E=d.vertices.length/3,d.indexMap[T]=E,d.vertices.push(this.vertices[h+0],this.vertices[h+1],this.vertices[h+2]),d.hasColor&&(this.colors[h]===void 0?d.hasColor=!1:d.colors.push(this.colors[h+0],this.colors[h+1],this.colors[h+2])),d.hasNormal&&d.normals.push(this.normals[h+0],this.normals[h+1],this.normals[h+2]),d.hasUV&&d.uvs.push(this.uvs[S+0],this.uvs[S+1])),d.index.push(E);let D=[g,C,y].join(`:`),O=d.indexMap[D];O===void 0&&(O=d.vertices.length/3,d.indexMap[D]=O,d.vertices.push(this.vertices[g+0],this.vertices[g+1],this.vertices[g+2]),d.hasColor&&(this.colors[g]===void 0?d.hasColor=!1:d.colors.push(this.colors[g+0],this.colors[g+1],this.colors[g+2])),d.hasNormal&&d.normals.push(this.normals[g+0],this.normals[g+1],this.normals[g+2]),d.hasUV&&d.uvs.push(this.uvs[C+0],this.uvs[C+1])),d.index.push(O);let k=[_,w,b].join(`:`),A=d.indexMap[k];A===void 0&&(A=d.vertices.length/3,d.indexMap[k]=A,d.vertices.push(this.vertices[_+0],this.vertices[_+1],this.vertices[_+2]),d.hasColor&&(this.colors[_]===void 0?d.hasColor=!1:d.colors.push(this.colors[_+0],this.colors[_+1],this.colors[_+2])),d.hasNormal&&d.normals.push(this.normals[_+0],this.normals[_+1],this.normals[_+2]),d.hasUV&&d.uvs.push(this.uvs[w+0],this.uvs[w+1])),d.index.push(A)}};function parseObj(e){let t=new ObjState;e.indexOf(`\r
831
+ `&&s!==`\r`?r+=s:(r===`end_header`&&(n=!1),r!==``&&(o.push(r),r=``))}while(n&&t<e.length);return c===!0&&t++,{headerText:o.join(`\r`)+`\r`,headerLength:t}}var ArrayStream=class{constructor(e){this.arr=e,this.i=0}empty(){return this.i>=this.arr.length}next(){return this.arr[this.i++]}},u8=Uint8Array,u16=Uint16Array,i32=Int32Array,fleb=new u8([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0,0]),fdeb=new u8([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13,0,0]),clim=new u8([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),freb=function(e,t){for(var n=new u16(31),r=0;r<31;++r)n[r]=t+=1<<e[r-1];for(var o=new i32(n[30]),r=1;r<30;++r)for(var s=n[r];s<n[r+1];++s)o[s]=s-n[r]<<5|r;return{b:n,r:o}},_a$3=freb(fleb,2),fl=_a$3.b,revfl=_a$3.r;fl[28]=258,revfl[258]=28;for(var _b=freb(fdeb,0),fd=_b.b,revfd=_b.r,rev=new u16(32768),i=0;i<32768;++i){var x=(i&43690)>>1|(i&21845)<<1;x=(x&52428)>>2|(x&13107)<<2,x=(x&61680)>>4|(x&3855)<<4,rev[i]=((x&65280)>>8|(x&255)<<8)>>1}for(var hMap=(function(e,t,n){for(var r=e.length,o=0,s=new u16(t);o<r;++o)e[o]&&++s[e[o]-1];var c=new u16(t);for(o=1;o<t;++o)c[o]=c[o-1]+s[o-1]<<1;var l;if(n){l=new u16(1<<t);var u=15-t;for(o=0;o<r;++o)if(e[o])for(var d=o<<4|e[o],f=t-e[o],p=c[e[o]-1]++<<f,m=p|(1<<f)-1;p<=m;++p)l[rev[p]>>u]=d}else for(l=new u16(r),o=0;o<r;++o)e[o]&&(l[o]=rev[c[e[o]-1]++]>>15-e[o]);return l}),flt=new u8(288),i=0;i<144;++i)flt[i]=8;for(var i=144;i<256;++i)flt[i]=9;for(var i=256;i<280;++i)flt[i]=7;for(var i=280;i<288;++i)flt[i]=8;for(var fdt=new u8(32),i=0;i<32;++i)fdt[i]=5;var flm=hMap(flt,9,0),flrm=hMap(flt,9,1),fdm=hMap(fdt,5,0),fdrm=hMap(fdt,5,1),max=function(e){for(var t=e[0],n=1;n<e.length;++n)e[n]>t&&(t=e[n]);return t},bits=function(e,t,n){var r=t/8|0;return(e[r]|e[r+1]<<8)>>(t&7)&n},bits16=function(e,t){var n=t/8|0;return(e[n]|e[n+1]<<8|e[n+2]<<16)>>(t&7)},shft=function(e){return(e+7)/8|0},slc=function(e,t,n){return(t==null||t<0)&&(t=0),(n==null||n>e.length)&&(n=e.length),new u8(e.subarray(t,n))},ec=[`unexpected EOF`,`invalid block type`,`invalid length/literal`,`invalid distance`,`stream finished`,`no stream handler`,,`no callback`,`invalid UTF-8 data`,`extra field too long`,`date not in range 1980-2099`,`filename too long`,`stream finishing`,`invalid zip data`],err=function(e,t,n){var r=Error(t||ec[e]);if(r.code=e,Error.captureStackTrace&&Error.captureStackTrace(r,err),!n)throw r;return r},inflt=function(e,t,n,r){var o=e.length,s=r?r.length:0;if(!o||t.f&&!t.l)return n||new u8(0);var c=!n,l=c||t.i!=2,u=t.i;c&&(n=new u8(o*3));var d=function(e){var t=n.length;if(e>t){var r=new u8(Math.max(t*2,e));r.set(n),n=r}},f=t.f||0,p=t.p||0,m=t.b||0,h=t.l,g=t.d,_=t.m,v=t.n,y=o*8;do{if(!h){f=bits(e,p,1);var b=bits(e,p+1,3);if(p+=3,!b){var S=shft(p)+4,C=e[S-4]|e[S-3]<<8,w=S+C;if(w>o){u&&err(0);break}l&&d(m+C),n.set(e.subarray(S,w),m),t.b=m+=C,t.p=p=w*8,t.f=f;continue}else if(b==1)h=flrm,g=fdrm,_=9,v=5;else if(b==2){var T=bits(e,p,31)+257,E=bits(e,p+10,15)+4,D=T+bits(e,p+5,31)+1;p+=14;for(var O=new u8(D),k=new u8(19),A=0;A<E;++A)k[clim[A]]=bits(e,p+A*3,7);p+=E*3;for(var j=max(k),M=(1<<j)-1,N=hMap(k,j,1),A=0;A<D;){var P=N[bits(e,p,M)];p+=P&15;var S=P>>4;if(S<16)O[A++]=S;else{var F=0,I=0;for(S==16?(I=3+bits(e,p,3),p+=2,F=O[A-1]):S==17?(I=3+bits(e,p,7),p+=3):S==18&&(I=11+bits(e,p,127),p+=7);I--;)O[A++]=F}}var L=O.subarray(0,T),R=O.subarray(T);_=max(L),v=max(R),h=hMap(L,_,1),g=hMap(R,v,1)}else err(1);if(p>y){u&&err(0);break}}l&&d(m+131072);for(var z=(1<<_)-1,B=(1<<v)-1,V=p;;V=p){var F=h[bits16(e,p)&z],H=F>>4;if(p+=F&15,p>y){u&&err(0);break}if(F||err(2),H<256)n[m++]=H;else if(H==256){V=p,h=null;break}else{var ee=H-254;if(H>264){var A=H-257,te=fleb[A];ee=bits(e,p,(1<<te)-1)+fl[A],p+=te}var U=g[bits16(e,p)&B],W=U>>4;U||err(3),p+=U&15;var R=fd[W];if(W>3){var te=fdeb[W];R+=bits16(e,p)&(1<<te)-1,p+=te}if(p>y){u&&err(0);break}l&&d(m+131072);var G=m+ee;if(m<R){var K=s-R,ne=Math.min(R,G);for(K+m<0&&err(3);m<ne;++m)n[m]=r[K+m]}for(;m<G;++m)n[m]=n[m-R]}}t.l=h,t.p=V,t.b=m,t.f=f,h&&(f=1,t.m=_,t.d=g,t.n=v)}while(!f);return m!=n.length&&c?slc(n,0,m):n.subarray(0,m)},et=new u8(0),b2=function(e,t){return e[t]|e[t+1]<<8},b4=function(e,t){return(e[t]|e[t+1]<<8|e[t+2]<<16|e[t+3]<<24)>>>0},b8=function(e,t){return b4(e,t)+b4(e,t+4)*4294967296},zls=function(e,t){return((e[0]&15)!=8||e[0]>>4>7||(e[0]<<8|e[1])%31)&&err(6,`invalid zlib data`),(e[1]>>5&1)==+!t&&err(6,`invalid zlib data: `+(e[1]&32?`need`:`unexpected`)+` dictionary`),(e[1]>>3&4)+2};function inflateSync(e,t){return inflt(e,{i:2},t&&t.out,t&&t.dictionary)}function unzlibSync(e,t){return inflt(e.subarray(zls(e,t&&t.dictionary),-4),{i:2},t&&t.out,t&&t.dictionary)}var td=typeof TextDecoder<`u`&&new TextDecoder,tds=0;try{td.decode(et,{stream:!0})}catch(e){}var dutf8=function(e){for(var t=``,n=0;;){var r=e[n++],o=(r>127)+(r>223)+(r>239);if(n+o>e.length)return{s:t,r:slc(e,n-1)};o?o==3?(r=((r&15)<<18|(e[n++]&63)<<12|(e[n++]&63)<<6|e[n++]&63)-65536,t+=String.fromCharCode(55296|r>>10,56320|r&1023)):o&1?t+=String.fromCharCode((r&31)<<6|e[n++]&63):t+=String.fromCharCode((r&15)<<12|(e[n++]&63)<<6|e[n++]&63):t+=String.fromCharCode(r)}};function strFromU8(e,t){if(t){for(var n=``,r=0;r<e.length;r+=16384)n+=String.fromCharCode.apply(null,e.subarray(r,r+16384));return n}else if(td)return td.decode(e);else{var o=dutf8(e),s=o.s,n=o.r;return n.length&&err(8),s}}var slzh=function(e,t){return t+30+b2(e,t+26)+b2(e,t+28)},zh=function(e,t,n){var r=b2(e,t+28),o=strFromU8(e.subarray(t+46,t+46+r),!(b2(e,t+8)&2048)),s=t+46+r,c=b4(e,t+20),l=n&&c==4294967295?z64e(e,s):[c,b4(e,t+24),b4(e,t+42)],u=l[0],d=l[1],f=l[2];return[b2(e,t+10),u,d,o,s+b2(e,t+30)+b2(e,t+32),f]},z64e=function(e,t){for(;b2(e,t)!=1;t+=4+b2(e,t+2));return[b8(e,t+12),b8(e,t+4),b8(e,t+20)]};function unzipSync(e,t){for(var n={},r=e.length-22;b4(e,r)!=101010256;--r)(!r||e.length-r>65558)&&err(13);var o=b2(e,r+8);if(!o)return{};var s=b4(e,r+16),c=s==4294967295||o==65535;if(c){var l=b4(e,r-12);c=b4(e,l)==101075792,c&&(o=b4(e,l+32),s=b4(e,l+48))}for(var u=t&&t.filter,d=0;d<o;++d){var f=zh(e,s,c),p=f[0],m=f[1],h=f[2],g=f[3],_=f[4],v=f[5],y=slzh(e,v);s=_,(!u||u({name:g,size:m,originalSize:h,compression:p}))&&(p?p==8?n[g]=inflateSync(e.subarray(y,y+m),{out:new u8(h)}):err(14,`unknown compression type `+p):n[g]=slc(e,y,y+m))}return n}function loadFbx(e,t={}){var n,r,o;let s=(n=t.upAxis)==null?`Z`:n,c=(r=t.fetcher)==null?internalFetcher:r,l=(o=t.onDownloadProgress)==null?noop:o,u=0;return Promise.resolve().then(()=>c.ajax(e,{responseType:`arraybuffer`},void 0,void 0,l).then(e=>(u=e.body.byteLength,e.body))).then(n=>{var r;return parse$2(n,{light:t.light,resourcePath:e.slice(0,e.lastIndexOf(`/`)+1),search:(r=e.split(`?`)[1])==null?``:r,fetcher:c})}).then(t=>{let n=t.scene,r=t.unitScale/100,o=new three.Matrix4;if(o.makeScale(r,r,r),t.upAxis===`X`)throw Error(`Cannot load fbx x upAxis`);return t.upAxis===`Y`&&o.premultiply(ROTATE_X_MATRIX$1),s===`Y`&&o.premultiply(ROTATE_X_MATRIX_INVERSE$1),n.applyMatrix4(o),{type:`fbx`,modelUpAxis:t.upAxis,upAxis:s,uri:e,byteLength:u,memoryUsage:getMemoryUsage(n),scene:n,textures:t.textures,animations:t.animations,dispose:()=>t.dispose()}})}function parse$2(e,t){let n;if(isFbxFormatBinary(e))n=new BinaryParser().parse(e);else{let t=convertArrayBufferToString(e);if(!isFbxFormatASCII(t))throw Error(`THREE.FBXLoader: Unknown format.`);if(getFbxVersion(t)<7e3)throw Error(`THREE.FBXLoader: FBX version not supported, FileVersion: `+getFbxVersion(t));n=new TextParser().parse(t)}return new FBXTreeParser(t).parse(n)}var FBXTreeParser=class{constructor(e){var t,n,r;this.light=(t=e.light)==null?!0:t,this.resourcePath=(n=e.resourcePath)==null?``:n,this.search=(r=e.search)==null?``:r,this.fetcher=e.fetcher}parse(e){var t,n,r,o,s,c;let l=this.parseConnections(e),u=Object.assign(new three.Group,{animations:[]}),d=[],f=this.parseImages(e),p=this.parseTextures(e,f,l,d),m=this.parseMaterials(e,p,l),h=this.parseDeformers(e,l),g=new GeometryParser().parse(e,h,l);this.parseScene(e,h,g,m,l,u);let _=(n=(t=e.GlobalSettings.UpAxis)==null?void 0:t.value)==null?1:n,v=(o=(r=e.GlobalSettings.FrontAxis)==null?void 0:r.value)==null?2:o,y=(c=(s=e.GlobalSettings.UnitScaleFactor)==null?void 0:s.value)==null?1:c,b;if(e.GlobalSettings.AmbientColor){let t=e.GlobalSettings.AmbientColor.value,n=t[0],r=t[1],o=t[2];if(n!==0||r!==0||o!==0){let e=new three.Color().setRGB(n,r,o);b=new three.AmbientLight(e,1)}}return Promise.all(d).then(e=>{var t;return{scene:u,textures:e,ambientLight:b,upAxis:[`X`,`Y`,`Z`][_],frontAxis:[`X`,`Y`,`Z`][v],unitScale:y,animations:(t=u.animations)==null?[]:t,dispose:()=>{e.forEach(e=>e.dispose()),m.forEach(e=>e.dispose()),g.forEach(e=>e.dispose())}}})}parseConnections(e){let t=new Map;return`Connections`in e&&e.Connections.connections.forEach(function(e){let n=e[0],r=e[1],o=e[2];t.has(n)||t.set(n,{parents:[],children:[]});let s={ID:r,relationship:o};t.get(n).parents.push(s),t.has(r)||t.set(r,{parents:[],children:[]});let c={ID:n,relationship:o};t.get(r).children.push(c)}),t}parseImages(e){let t={},n={};if(`Video`in e.Objects){let r=e.Objects.Video;for(let e in r){let o=r[e],s=parseInt(e);if(t[s]=o.RelativeFilename||o.Filename,`Content`in o){let t=o.Content instanceof ArrayBuffer&&o.Content.byteLength>0,s=typeof o.Content==`string`&&o.Content!==``;if(t||s){let t=this.parseImage(r[e]);n[o.RelativeFilename||o.Filename]=t}}}}for(let e in t){let r=t[e];n[r]===void 0?t[e]=t[e].split(`\\`).pop():t[e]=n[r]}return t}parseImage(e){let t=e.Content,n=e.RelativeFilename||e.Filename,r=n.slice(n.lastIndexOf(`.`)+1).toLowerCase(),o;switch(r){case`bmp`:o=`image/bmp`;break;case`jpg`:case`jpeg`:o=`image/jpeg`;break;case`png`:o=`image/png`;break;case`tif`:o=`image/tiff`;break;case`tga`:o=`image/tga`;break;default:return}if(typeof t==`string`)return`data:`+o+`;base64,`+t;{let e=new Uint8Array(t);return window.URL.createObjectURL(new Blob([e],{type:o}))}}parseTextures(e,t,n,r){let o=new Map;if(`Texture`in e.Objects){let s=e.Objects.Texture;for(let e in s){let c=this.parseTexture(s[e],t,n,r);o.set(parseInt(e),c)}}return o}parseTexture(e,t,n,r){let o=this.loadTexture(e,t,n,r);o.ID=e.id,o.name=e.attrName;let s=e.WrapModeU,c=e.WrapModeV,l=s===void 0?0:s.value,u=c===void 0?0:c.value;if(o.wrapS=l===0?three.RepeatWrapping:three.ClampToEdgeWrapping,o.wrapT=u===0?three.RepeatWrapping:three.ClampToEdgeWrapping,e.Scaling){let t=e.Scaling.value;o.repeat.x=t[0],o.repeat.y=t[1]}if(e.Translation){let t=e.Translation.value;o.offset.x=t[0],o.offset.y=t[1]}return o}loadTexture(e,t,n,r){let o=n.get(e.id).children,s=``;o!==void 0&&o.length>0&&t[o[0].ID]!==void 0&&(s=t[o[0].ID]),s=pathJoin(this.resourcePath,appendSearch(s,this.search));let c=Object.assign(new three.Texture,{ID:0}),l;l=canUseNativeImageBitmap()?this.fetcher.ajax(s,{responseType:`blob`}).then(e=>{let t=e.body;return createImageBitmapLike(t)}):this.fetcher.loadImage(s,{},void 0,void 0,void 0,createImageBitmapLikeImage()).then(e=>e.body);let u=l.then(e=>(c.image=e,c.needsUpdate=!0,c)).catch(e=>(console.warn(e),c));return r.push(u),c}parseMaterials(e,t,n){let r=new Map;if(`Material`in e.Objects){let o=e.Objects.Material;for(let s in o){let c=this.parseMaterial(e,o[s],t,n);c!==null&&r.set(parseInt(s),c)}}return r}parseMaterial(e,t,n,r){let o=t.id,s=t.attrName,c=t.ShadingModel;if(typeof c==`object`&&(c=c.value),c=c.toLowerCase(),!r.has(o))return null;let l=new PBMMeshMaterial(this.light?`phong`:`basic`);l.name=s,t.BumpFactor&&(l.bumpScale=t.BumpFactor.value),t.Diffuse?l.color=new three.Color().fromArray(t.Diffuse.value):t.DiffuseColor&&(t.DiffuseColor.type===`Color`||t.DiffuseColor.type===`ColorRGB`)&&(l.color=new three.Color().fromArray(t.DiffuseColor.value)),t.DisplacementFactor&&(l.displacementScale=t.DisplacementFactor.value),t.Emissive?l.emissive=new three.Color().fromArray(t.Emissive.value):t.EmissiveColor&&(t.EmissiveColor.type===`Color`||t.EmissiveColor.type===`ColorRGB`)&&(l.emissive=new three.Color().fromArray(t.EmissiveColor.value)),t.EmissiveFactor&&(l.emissiveIntensity=parseFloat(t.EmissiveFactor.value));let u=1-(t.TransparencyFactor?parseFloat(t.TransparencyFactor.value):0);(u===1||u===0)&&(u=t.Opacity?parseFloat(t.Opacity.value):null,u===null&&(u=1-(t.TransparentColor?parseFloat(t.TransparentColor.value[0]):0))),l.opacity=u,l.opacity<1&&(l.transparent=!0),t.ReflectionFactor&&(l.reflectivity=t.ReflectionFactor.value),t.Shininess&&(l.shininess=t.Shininess.value),t.Specular?l.specular=new three.Color().fromArray(t.Specular.value):t.SpecularColor&&t.SpecularColor.type===`Color`&&(l.specular=new three.Color().fromArray(t.SpecularColor.value));let d=this;return r.get(o).children.forEach(function(t){let o=t.relationship;switch(o){case`Bump`:l.bumpMap=d.getTexture(e,n,t.ID,r);break;case`Maya|TEX_ao_map`:l.aoMap=d.getTexture(e,n,t.ID,r);break;case`DiffuseColor`:case`Maya|TEX_color_map`:l.map=d.getTexture(e,n,t.ID,r),l.map!==void 0&&(l.map.encoding=three.sRGBEncoding);break;case`DisplacementColor`:l.displacementMap=d.getTexture(e,n,t.ID,r);break;case`EmissiveColor`:l.emissiveMap=d.getTexture(e,n,t.ID,r),l.emissiveMap!==void 0&&(l.emissiveMap.encoding=three.sRGBEncoding);break;case`NormalMap`:case`Maya|TEX_normal_map`:l.normalMap=d.getTexture(e,n,t.ID,r);break;case`ReflectionColor`:l.envMap=d.getTexture(e,n,t.ID,r),l.envMap!==void 0&&(l.envMap.mapping=three.EquirectangularReflectionMapping,l.envMap.encoding=three.sRGBEncoding);break;case`SpecularColor`:l.specularMap=d.getTexture(e,n,t.ID,r),l.specularMap!==void 0&&(l.specularMap.encoding=three.sRGBEncoding);break;case`TransparentColor`:case`TransparencyFactor`:l.alphaMap=d.getTexture(e,n,t.ID,r),l.transparent=!0;break;default:console.warn(`THREE.FBXLoader: %s map is not supported in three.js, skipping texture.`,o);break}}),l}getTexture(e,t,n,r){return e.Objects.LayeredTexture&&n in e.Objects.LayeredTexture&&(console.warn(`THREE.FBXLoader: layered textures are not supported in three.js. Discarding all but first layer.`),n=r.get(n).children[0].ID),t.get(n)}parseDeformers(e,t){let n={},r={};if(`Deformer`in e.Objects){let o=e.Objects.Deformer;for(let e in o){let s=o[e],c=t.get(parseInt(e));if(s.attrType===`Skin`){let t=this.parseSkeleton(c,o);t.ID=e,c.parents.length>1&&console.warn(`THREE.FBXLoader: skeleton attached to more than one geometry is not supported.`),t.geometryID=c.parents[0].ID,n[e]=t}else if(s.attrType===`BlendShape`){let n={id:e};n.rawTargets=this.parseMorphTargets(c,o,t),n.id=e,c.parents.length>1&&console.warn(`THREE.FBXLoader: morph target attached to more than one geometry is not supported.`),r[e]=n}}}return{skeletons:n,morphTargets:r}}parseSkeleton(e,t){let n=[];return e.children.forEach(function(e){let r=t[e.ID];if(r.attrType!==`Cluster`)return;let o={ID:e.ID,indices:[],weights:[],transformLink:new three.Matrix4().fromArray(r.TransformLink.a)};r.Indexes&&(o.indices=r.Indexes.a,o.weights=r.Weights.a),n.push(o)}),{ID:``,geometryID:0,rawBones:n,bones:[]}}parseMorphTargets(e,t,n){let r=[];for(let o=0;o<e.children.length;o++){let s=e.children[o],c=t[s.ID],l={name:c.attrName,initialWeight:c.DeformPercent,id:c.id,fullWeights:c.FullWeights.a,geoID:0};if(c.attrType!==`BlendShapeChannel`)return;l.geoID=n.get(parseInt(s.ID)).children.filter(function(e){return e.relationship===void 0})[0].ID,r.push(l)}return r}parseScene(e,t,n,r,o,s){let c=this.parseModels(e,t.skeletons,n,r,o),l=e.Objects.Model,u=this;c.forEach(function(t){let n=l[t.ID];u.setLookAtProperties(e,t,n,o,s),o.get(t.ID).parents.forEach(function(e){let n=c.get(e.ID);n!==void 0&&n.add(t)}),t.parent===null&&s.add(t)}),this.bindSkeleton(e,t.skeletons,n,c,o),s.traverse(function(e){if(e.userData.transformData){e.parent&&(e.userData.transformData.parentMatrix=e.parent.matrix,e.userData.transformData.parentMatrixWorld=e.parent.matrixWorld);let t=generateTransform(e.userData.transformData);e.applyMatrix4(t),e.updateWorldMatrix(!0,!0)}});let d=new AnimationParser().parse(e,o,s);s.children.length===1&&s.children[0]instanceof three.Group&&(s=s.children[0]),s.animations=d}parseModels(e,t,n,r,o){let s=new Map,c=e.Objects.Model;for(let l in c){let u=parseInt(l),d=c[l],f=o.get(u),p=this.buildSkeleton(f,t,u,d.attrName);if(!p){switch(d.attrType){case`Camera`:p=this.createCamera(e,f);break;case`Light`:p=this.createLight(e,f);break;case`Mesh`:p=this.createMesh(f,n,r);break;case`NurbsCurve`:case`LimbNode`:case`Root`:p=new three.Bone;break;default:p=new three.Group;break}p.name=d.attrName?three.PropertyBinding.sanitizeNodeName(d.attrName):``,p.userData.originalName=d.attrName,p.ID=u}this.getTransformData(p,d),s.set(u,p)}return s}buildSkeleton(e,t,n,r){let o=null;return e.parents.forEach(function(e){for(let s in t){let c=t[s];c.rawBones.forEach(function(t,s){if(t.ID===e.ID){let e=o;o=new three.Bone,o.matrixWorld.copy(t.transformLink),o.name=r?three.PropertyBinding.sanitizeNodeName(r):``,o.userData.originalName=r,o.ID=n,c.bones[s]=o,e!==null&&o.add(e)}})}}),o}createCamera(e,t){let n,r;if(t.children.forEach(function(t){let n=e.Objects.NodeAttribute[t.ID];n!==void 0&&(r=n)}),r===void 0)n=new three.Object3D;else{let e=0;r.CameraProjectionType!==void 0&&r.CameraProjectionType.value===1&&(e=1);let t=1;r.NearPlane!==void 0&&(t=r.NearPlane.value/1e3);let o=1e3;r.FarPlane!==void 0&&(o=r.FarPlane.value/1e3);let s=window.innerWidth,c=window.innerHeight;r.AspectWidth!==void 0&&r.AspectHeight!==void 0&&(s=r.AspectWidth.value,c=r.AspectHeight.value);let l=s/c,u=45;r.FieldOfView!==void 0&&(u=r.FieldOfView.value);let d=r.FocalLength?r.FocalLength.value:null;switch(e){case 0:n=new three.PerspectiveCamera(u,l,t,o),d!==null&&n.setFocalLength(d);break;case 1:console.warn(`THREE.FBXLoader: Orthographic cameras not supported yet.`),n=new three.Object3D;break;default:console.warn(`THREE.FBXLoader: Unknown camera type `+e+`.`),n=new three.Object3D;break}}return n}createLight(e,t){let n,r;if(t.children.forEach(function(t){let n=e.Objects.NodeAttribute[t.ID];n!==void 0&&(r=n)}),r===void 0)n=new three.Object3D;else{let e;e=r.LightType===void 0?0:r.LightType.value;let t=new three.Color(16777215);r.Color!==void 0&&(t=new three.Color().fromArray(r.Color.value));let o=r.Intensity===void 0?1:r.Intensity.value/100;r.CastLightOnObject!==void 0&&r.CastLightOnObject.value===0&&(o=0);let s=0;r.FarAttenuationEnd!==void 0&&(s=r.EnableFarAttenuation!==void 0&&r.EnableFarAttenuation.value===0?0:r.FarAttenuationEnd.value);let c=1;switch(e){case 0:n=new three.PointLight(t,o,s,1);break;case 1:n=new three.DirectionalLight(t,o);break;case 2:let e=Math.PI/3;r.InnerAngle!==void 0&&(e=three.MathUtils.degToRad(r.InnerAngle.value));let c=0;r.OuterAngle!==void 0&&(c=three.MathUtils.degToRad(r.OuterAngle.value),c=Math.max(c,1)),n=new three.SpotLight(t,o,s,e,c,1);break;default:console.warn(`THREE.FBXLoader: Unknown light type `+r.LightType.value+`, defaulting to a PointLight.`),n=new three.PointLight(t,o);break}r.CastShadows!==void 0&&r.CastShadows.value===1&&(n.castShadow=!0)}return n}createMesh(e,t,n){let r,o=null,s=[];if(e.children.forEach(function(e){t.has(e.ID)&&(o=t.get(e.ID)),n.has(e.ID)&&s.push(n.get(e.ID))}),s.length===0){let e=new PBMMeshMaterial(this.light?`phong`:`basic`);e.color=new three.Color(13421772),s.push(e)}return`color`in o.attributes&&s.forEach(function(e){e.vertexColors=!0}),(!o.groups||o.groups.length===0)&&o.addGroup(0,o.index?o.index.count:o.attributes.position.count,0),o.FBX_Deformer?(s.forEach(function(e){e.skinning=!0}),r=new PBMSkinnedMesh(o,s),r.normalizeSkinWeights()):r=new PBMMesh(o,s),r}createCurve(e,t){let n=e.children.reduce(function(e,n){return t.has(n.ID)&&(e=t.get(n.ID)),e},null),r=new three.LineBasicMaterial({name:``,color:3342591,linewidth:1});return new three.Line(n,r)}getTransformData(e,t){let n={};t.InheritType&&(n.inheritType=parseInt(t.InheritType.value)),t.RotationOrder?n.eulerOrder=getEulerOrder(t.RotationOrder.value):n.eulerOrder=getEulerOrder(0),t.Lcl_Translation&&(n.translation=t.Lcl_Translation.value),t.PreRotation&&(n.preRotation=t.PreRotation.value),t.Lcl_Rotation&&(n.rotation=t.Lcl_Rotation.value),t.PostRotation&&(n.postRotation=t.PostRotation.value),t.Lcl_Scaling&&(n.scale=t.Lcl_Scaling.value),t.ScalingOffset&&(n.scalingOffset=t.ScalingOffset.value),t.ScalingPivot&&(n.scalingPivot=t.ScalingPivot.value),t.RotationOffset&&(n.rotationOffset=t.RotationOffset.value),t.RotationPivot&&(n.rotationPivot=t.RotationPivot.value),e.userData.transformData=n}setLookAtProperties(e,t,n,r,o){`LookAtProperty`in n&&r.get(t.ID).children.forEach(function(n){if(n.relationship===`LookAtProperty`){let r=e.Objects.Model[n.ID];if(r.Lcl_Translation){let e=r.Lcl_Translation.value;`target`in t&&t.target instanceof three.Object3D?(t.target.position.fromArray(e),o.add(t.target)):t.lookAt(new three.Vector3().fromArray(e))}}})}bindSkeleton(e,t,n,r,o){let s=this.parsePoseNodes(e);for(let e in t){let c=t[e];o.get(parseInt(c.ID)).parents.forEach(function(e){if(n.has(e.ID)){let t=e.ID;o.get(t).parents.forEach(function(e){if(r.has(e.ID)){let t=r.get(e.ID);t instanceof three.SkinnedMesh&&t.bind(new three.Skeleton(c.bones),s[e.ID])}})}})}}parsePoseNodes(e){let t={};if(e.Objects.Pose){let n=e.Objects.Pose;for(let e in n)if(n[e].attrType===`BindPose`&&n[e].NbPoseNodes>0){let r=n[e].PoseNode;Array.isArray(r)?r.forEach(function(e){t[e.Node]=new three.Matrix4().fromArray(e.Matrix.a)}):t[r.Node]=new three.Matrix4().fromArray(r.Matrix.a)}}return t}},GeometryParser=class{constructor(){this.negativeMaterialIndices=!1}parse(e,t,n){let r=new Map;if(`Geometry`in e.Objects){let o=e.Objects.Geometry;for(let s in o){let c=n.get(parseInt(s)),l=this.parseGeometry(e,c,o[s],t);r.set(parseInt(s),l)}}return this.negativeMaterialIndices===!0&&console.warn(`THREE.FBXLoader: The FBX file contains invalid (negative) material indices. The asset might not render as expected.`),r}parseGeometry(e,t,n,r){switch(n.attrType){case`Mesh`:return this.parseMeshGeometry(e,t,n,r);case`NurbsCurve`:return this.parseNurbsGeometry(n)}}parseMeshGeometry(e,t,n,r){let o=r.skeletons,s=[],c=t.parents.map(function(t){return e.Objects.Model[t.ID]});if(c.length===0)return;let l=t.children.reduce(function(e,t){return o[t.ID]!==void 0&&(e=o[t.ID]),e},null);t.children.forEach(function(e){r.morphTargets[e.ID]!==void 0&&s.push(r.morphTargets[e.ID])});let u=c[0],d={};u.RotationOrder&&(d.eulerOrder=getEulerOrder(u.RotationOrder.value)),u.InheritType&&(d.inheritType=parseInt(u.InheritType.value)),u.GeometricTranslation&&(d.translation=u.GeometricTranslation.value),u.GeometricRotation&&(d.rotation=u.GeometricRotation.value),u.GeometricScaling&&(d.scale=u.GeometricScaling.value);let f=generateTransform(d);return this.genGeometry(e,n,l,s,f)}genGeometry(e,t,n,r,o){let s=new three.BufferGeometry;t.attrName&&(s.name=t.attrName);let c=this.parseGeoNode(t,n),l=this.genBuffers(c),u=new three.Float32BufferAttribute(l.vertex,3);if(u.applyMatrix4(o),s.setAttribute(`position`,u),l.colors.length>0&&s.setAttribute(`color`,new three.Float32BufferAttribute(l.colors,3)),n&&(s.setAttribute(`skinIndex`,new three.Uint16BufferAttribute(l.weightsIndices,4)),s.setAttribute(`skinWeight`,new three.Float32BufferAttribute(l.vertexWeights,4)),s.FBX_Deformer=n),l.normal.length>0){let e=new three.Matrix3().getNormalMatrix(o),t=new three.Float32BufferAttribute(l.normal,3);t.applyNormalMatrix(e),s.setAttribute(`normal`,t)}if(l.uvs.forEach(function(e,t){let n=t===0?`uv`:`uv${t+1}`;s.setAttribute(n,new three.Float32BufferAttribute(l.uvs[t],2))}),c.material&&c.material.mappingType!==`AllSame`){let e=l.materialIndex[0],t=0;if(l.materialIndex.forEach(function(n,r){n!==e&&(s.addGroup(t,r-t,e),e=n,t=r)}),s.groups.length>0){let t=s.groups[s.groups.length-1],n=t.start+t.count;n!==l.materialIndex.length&&s.addGroup(n,l.materialIndex.length-n,e)}s.groups.length===0&&s.addGroup(0,l.materialIndex.length,l.materialIndex[0])}return this.addMorphTargets(e,s,t,r,o),s}parseGeoNode(e,t){let n={};if(n.vertexPositions=e.Vertices===void 0?[]:e.Vertices.a,n.vertexIndices=e.PolygonVertexIndex===void 0?[]:e.PolygonVertexIndex.a,e.LayerElementColor&&(n.color=this.parseVertexColors(e.LayerElementColor[0])),e.LayerElementMaterial&&(n.material=this.parseMaterialIndices(e.LayerElementMaterial[0])),e.LayerElementNormal&&(n.normal=this.parseNormals(e.LayerElementNormal[0])),e.LayerElementUV){n.uv=[];let t=0;for(;e.LayerElementUV[t];)e.LayerElementUV[t].UV&&n.uv.push(this.parseUVs(e.LayerElementUV[t])),t++}return n.weightTable={},t!==null&&(n.skeleton=t,t.rawBones.forEach(function(e,t){e.indices.forEach(function(r,o){n.weightTable[r]===void 0&&(n.weightTable[r]=[]),n.weightTable[r].push({id:t,weight:e.weights[o]})})})),n}genBuffers(e){let t={vertex:[],normal:[],colors:[],uvs:[],materialIndex:[],vertexWeights:[],weightsIndices:[]},n=0,r=0,o=!1,s=[],c=[],l=[],u=[],d=[],f=[],p=this;return e.vertexIndices.forEach(function(m,h){let g=0,_=!1;m<0&&(m^=-1,_=!0);let v=[],y=[];if(s.push(m*3,m*3+1,m*3+2),e.color){let t=getData(h,n,m,e.color);l.push(t[0],t[1],t[2])}if(e.skeleton){if(e.weightTable[m]!==void 0&&e.weightTable[m].forEach(function(e){y.push(e.weight),v.push(e.id)}),y.length>4){o||(console.warn(`THREE.FBXLoader: Vertex has more than 4 skinning weights assigned to vertex. Deleting additional weights.`),o=!0);let e=[0,0,0,0],t=[0,0,0,0];y.forEach(function(n,r){let o=n,s=v[r];t.forEach(function(t,n,r){if(o>t){r[n]=o,o=t;let c=e[n];e[n]=s,s=c}})}),v=e,y=t}for(;y.length<4;)y.push(0),v.push(0);for(let e=0;e<4;++e)d.push(y[e]),f.push(v[e])}if(e.normal){let t=getData(h,n,m,e.normal);c.push(t[0],t[1],t[2])}e.material&&e.material.mappingType!==`AllSame`&&(g=getData(h,n,m,e.material)[0],g<0&&(p.negativeMaterialIndices=!0,g=0)),e.uv&&e.uv.forEach(function(e,t){let r=getData(h,n,m,e);u[t]===void 0&&(u[t]=[]),u[t].push(r[0]),u[t].push(r[1])}),r++,_&&(p.genFace(t,e,s,g,c,l,u,d,f,r),n++,r=0,s=[],c=[],l=[],u=[],d=[],f=[])}),t}getNormalNewell(e){let t=new three.Vector3(0,0,0);for(let n=0;n<e.length;n++){let r=e[n],o=e[(n+1)%e.length];t.x+=(r.y-o.y)*(r.z+o.z),t.y+=(r.z-o.z)*(r.x+o.x),t.z+=(r.x-o.x)*(r.y+o.y)}return t.normalize(),t}getNormalTangentAndBitangent(e){let t=this.getNormalNewell(e),n=(Math.abs(t.z)>.5?new three.Vector3(0,1,0):new three.Vector3(0,0,1)).cross(t).normalize();return{normal:t,tangent:n,bitangent:t.clone().cross(n).normalize()}}flattenVertex(e,t,n){return new three.Vector2(e.dot(t),e.dot(n))}genFace(e,t,n,r,o,s,c,l,u,d){let f;if(d>3){let e=[],r=t.baseVertexPositions||t.vertexPositions;for(let t=0;t<n.length;t+=3)e.push(new three.Vector3(r[n[t]],r[n[t+1]],r[n[t+2]]));let{tangent:o,bitangent:s}=this.getNormalTangentAndBitangent(e),c=[];for(let t of e)c.push(this.flattenVertex(t,o,s));f=three.ShapeUtils.triangulateShape(c,[])}else f=[[0,1,2]];for(let[d,p,m]of f)e.vertex.push(t.vertexPositions[n[d*3]]),e.vertex.push(t.vertexPositions[n[d*3+1]]),e.vertex.push(t.vertexPositions[n[d*3+2]]),e.vertex.push(t.vertexPositions[n[p*3]]),e.vertex.push(t.vertexPositions[n[p*3+1]]),e.vertex.push(t.vertexPositions[n[p*3+2]]),e.vertex.push(t.vertexPositions[n[m*3]]),e.vertex.push(t.vertexPositions[n[m*3+1]]),e.vertex.push(t.vertexPositions[n[m*3+2]]),t.skeleton&&(e.vertexWeights.push(l[d*4]),e.vertexWeights.push(l[d*4+1]),e.vertexWeights.push(l[d*4+2]),e.vertexWeights.push(l[d*4+3]),e.vertexWeights.push(l[p*4]),e.vertexWeights.push(l[p*4+1]),e.vertexWeights.push(l[p*4+2]),e.vertexWeights.push(l[p*4+3]),e.vertexWeights.push(l[m*4]),e.vertexWeights.push(l[m*4+1]),e.vertexWeights.push(l[m*4+2]),e.vertexWeights.push(l[m*4+3]),e.weightsIndices.push(u[d*4]),e.weightsIndices.push(u[d*4+1]),e.weightsIndices.push(u[d*4+2]),e.weightsIndices.push(u[d*4+3]),e.weightsIndices.push(u[p*4]),e.weightsIndices.push(u[p*4+1]),e.weightsIndices.push(u[p*4+2]),e.weightsIndices.push(u[p*4+3]),e.weightsIndices.push(u[m*4]),e.weightsIndices.push(u[m*4+1]),e.weightsIndices.push(u[m*4+2]),e.weightsIndices.push(u[m*4+3])),t.color&&(e.colors.push(s[d*3]),e.colors.push(s[d*3+1]),e.colors.push(s[d*3+2]),e.colors.push(s[p*3]),e.colors.push(s[p*3+1]),e.colors.push(s[p*3+2]),e.colors.push(s[m*3]),e.colors.push(s[m*3+1]),e.colors.push(s[m*3+2])),t.material&&t.material.mappingType!==`AllSame`&&(e.materialIndex.push(r),e.materialIndex.push(r),e.materialIndex.push(r)),t.normal&&(e.normal.push(o[d*3]),e.normal.push(o[d*3+1]),e.normal.push(o[d*3+2]),e.normal.push(o[p*3]),e.normal.push(o[p*3+1]),e.normal.push(o[p*3+2]),e.normal.push(o[m*3]),e.normal.push(o[m*3+1]),e.normal.push(o[m*3+2])),t.uv&&t.uv.forEach(function(t,n){e.uvs[n]===void 0&&(e.uvs[n]=[]),e.uvs[n].push(c[n][d*2]),e.uvs[n].push(c[n][d*2+1]),e.uvs[n].push(c[n][p*2]),e.uvs[n].push(c[n][p*2+1]),e.uvs[n].push(c[n][m*2]),e.uvs[n].push(c[n][m*2+1])})}addMorphTargets(e,t,n,r,o){if(r.length===0)return;t.morphTargetsRelative=!0,t.morphAttributes.position=[];let s=this;r.forEach(function(r){r.rawTargets.forEach(function(r){let c=e.Objects.Geometry[r.geoID];c!==void 0&&s.genMorphGeometry(t,n,c,o,r.name)})})}genMorphGeometry(e,t,n,r,o){let s=t.Vertices===void 0?[]:t.Vertices.a,c=t.PolygonVertexIndex===void 0?[]:t.PolygonVertexIndex.a,l=n.Vertices===void 0?[]:n.Vertices.a,u=n.Indexes?n.Indexes.a:[],d=e.attributes.position.count*3,f=new Float32Array(d);for(let e=0;e<u.length;e++){let t=u[e]*3;f[t]=l[e*3],f[t+1]=l[e*3+1],f[t+2]=l[e*3+2]}let p={vertexIndices:c,vertexPositions:f,baseVertexPositions:s},m=this.genBuffers(p),h=new three.Float32BufferAttribute(m.vertex,3);h.name=o||n.attrName,h.applyMatrix4(r),e.morphAttributes.position.push(h)}parseNormals(e){let t=e.MappingInformationType,n=e.ReferenceInformationType,r=e.Normals.a,o=[];return n===`IndexToDirect`&&(e.NormalIndex?o=e.NormalIndex.a:e.NormalsIndex&&(o=e.NormalsIndex.a)),{dataSize:3,buffer:r,indices:o,mappingType:t,referenceType:n}}parseUVs(e){let t=e.MappingInformationType,n=e.ReferenceInformationType,r=e.UV.a,o=[];return n===`IndexToDirect`&&(o=e.UVIndex.a),{dataSize:2,buffer:r,indices:o,mappingType:t,referenceType:n}}parseVertexColors(e){let t=e.MappingInformationType,n=e.ReferenceInformationType,r=e.Colors.a,o=[];n===`IndexToDirect`&&(o=e.ColorIndex.a);for(let e=0,t=new three.Color;e<r.length;e+=4)t.fromArray(r,e),t.toArray(r,e);return{dataSize:4,buffer:r,indices:o,mappingType:t,referenceType:n}}parseMaterialIndices(e){let t=e.MappingInformationType,n=e.ReferenceInformationType;if(t===`NoMappingInformation`)return{dataSize:1,buffer:[0],indices:[0],mappingType:`AllSame`,referenceType:n};let r=e.Materials.a,o=[];for(let e=0;e<r.length;++e)o.push(e);return{dataSize:1,buffer:r,indices:o,mappingType:t,referenceType:n}}parseNurbsGeometry(e){let t=parseInt(e.Order);if(isNaN(t))return console.error(`THREE.FBXLoader: Invalid Order %s given for geometry ID: %s`,e.Order,e.id),new three.BufferGeometry;let n=t-1,r=e.KnotVector.a,o=[],s=e.Points.a;for(let e=0,t=s.length;e<t;e+=4)o.push(new three.Vector4().fromArray(s,e));let c,l;if(e.Form===`Closed`)o.push(o[0]);else if(e.Form===`Periodic`){c=n,l=r.length-1-c;for(let e=0;e<n;++e)o.push(o[e])}let u=new NURBSCurve(n,r,o,c,l).getPoints(o.length*12);return new three.BufferGeometry().setFromPoints(u)}},AnimationParser=class{parse(e,t,n){let r=[],o=this.parseClips(e,t,n);if(o!==void 0)for(let e in o){let t=o[e],s=this.addClip(t,n);r.push(s)}return r}parseClips(e,t,n){if(e.Objects.AnimationCurve===void 0)return;let r=this.parseAnimationCurveNodes(e);this.parseAnimationCurves(e,r,t);let o=this.parseAnimationLayers(e,r,t,n);return this.parseAnimStacks(e,o,t)}parseAnimationCurveNodes(e){let t=e.Objects.AnimationCurveNode,n=new Map;for(let e in t){let r=t[e];if(r.attrName.match(/S|R|T|DeformPercent/)!==null){let e={id:r.id,attr:r.attrName,curves:{}};n.set(e.id,e)}}return n}parseAnimationCurves(e,t,n){let r=e.Objects.AnimationCurve;for(let e in r){let o={id:r[e].id,times:r[e].KeyTime.a.map(convertFBXTimeToSeconds),values:r[e].KeyValueFloat.a},s=n.get(o.id);if(s!==void 0){let e=s.parents[0].ID,n=s.parents[0].relationship,r=t.get(e);r&&(n.match(/X/)?r.curves.x=o:n.match(/Y/)?r.curves.y=o:n.match(/Z/)?r.curves.z=o:n.match(/DeformPercent/)&&t.has(e)&&(r.curves.morph=o))}}}parseAnimationLayers(e,t,n,r){let o=e.Objects.AnimationLayer,s=new Map;for(let c in o){let o=[],l=n.get(parseInt(c));l!==void 0&&(l.children.forEach((s,c)=>{if(t.has(s.ID)){let l=t.get(s.ID);if(l.curves.x!==void 0||l.curves.y!==void 0||l.curves.z!==void 0){if(o[c]===void 0){let t=n.get(s.ID).parents.filter(function(e){return e.relationship!==void 0})[0].ID;if(t!==void 0){let n=e.Objects.Model[t.toString()];if(n===void 0){console.warn(`THREE.FBXLoader: Encountered a unused curve.`,s);return}let l={modelName:n.attrName?three.PropertyBinding.sanitizeNodeName(n.attrName):``,ID:n.id,initialPosition:[0,0,0],initialRotation:[0,0,0],initialScale:[1,1,1],transform:new three.Matrix4,eulerOrder:``,preRotation:[0,0,0],postRotation:[0,0,0]};r.traverse(function(e){e.ID===n.id&&(l.transform=e.matrix,e.userData.transformData&&(l.eulerOrder=e.userData.transformData.eulerOrder))}),l.transform||(l.transform=new three.Matrix4),n.PreRotation&&(l.preRotation=n.PreRotation.value),n.PostRotation&&(l.postRotation=n.PostRotation.value),o[c]=l}}o[c]&&(o[c][l.attr]=l)}else if(l.curves.morph!==void 0){if(o[c]===void 0){let t=n.get(s.ID).parents.filter(function(e){return e.relationship!==void 0})[0].ID,r=n.get(t).parents[0].ID,l=n.get(r).parents[0].ID,u=n.get(l).parents[0].ID,d=e.Objects.Model[u];o[c]={modelName:d.attrName?three.PropertyBinding.sanitizeNodeName(d.attrName):``,morphName:e.Objects.Deformer[t].attrName}}o[c][l.attr]=l}}}),s.set(parseInt(c),o))}return s}parseAnimStacks(e,t,n){let r=e.Objects.AnimationStack,o={};for(let e in r){let s=n.get(parseInt(e)).children;s.length>1&&console.warn(`THREE.FBXLoader: Encountered an animation stack with multiple layers, this is currently not supported. Ignoring subsequent layers.`);let c=t.get(s[0].ID);o[e]={name:r[e].attrName,layer:c}}return o}addClip(e,t){let n=[],r=this;return e.layer.forEach(function(e){n=n.concat(r.generateTracks(e,t))}),new three.AnimationClip(e.name,-1,n)}generateTracks(e,t){let n=[],r=new three.Vector3,o=new three.Vector3;e.transform&&e.transform.decompose(r,new three.Quaternion,o);let s=r.toArray(),c=o.toArray();if(e.T!==void 0&&Object.keys(e.T.curves).length>0){let t=this.generateVectorTrack(e.modelName,e.T.curves,s,`position`);t!==void 0&&n.push(t)}if(e.R!==void 0&&Object.keys(e.R.curves).length>0){let t=this.generateRotationTrack(e.modelName,e.R.curves,e.preRotation,e.postRotation,e.eulerOrder);t!==void 0&&n.push(t)}if(e.S!==void 0&&Object.keys(e.S.curves).length>0){let t=this.generateVectorTrack(e.modelName,e.S.curves,c,`scale`);t!==void 0&&n.push(t)}if(e.DeformPercent!==void 0){let r=this.generateMorphTrack(e,t);r!==void 0&&n.push(r)}return n}generateVectorTrack(e,t,n,r){let o=this.getTimesForAllAxes(t),s=this.getKeyframeTrackValues(o,t,n);return new three.VectorKeyframeTrack(e+`.`+r,o,s)}generateRotationTrack(e,t,n,r,o){let s,c;if(t.x!==void 0&&t.y!==void 0&&t.z!==void 0){let e=this.interpolateRotations(t.x,t.y,t.z,o);s=e[0],c=e[1]}let l=getEulerOrder(0),u=new three.Quaternion,d=new three.Quaternion;n!==void 0&&(n=n.map(three.MathUtils.degToRad),n.push(l),u.setFromEuler(new three.Euler().fromArray(n))),r!==void 0&&(r=r.map(three.MathUtils.degToRad),r.push(l),d.setFromEuler(new three.Euler().fromArray(r)),d.inverse());let f=new three.Quaternion,p=new three.Euler,m=[];if(!c||!s)return new three.QuaternionKeyframeTrack(e+`.quaternion`,[0],[0]);for(let e=0;e<c.length;e+=3)p.set(c[e],c[e+1],c[e+2],o),f.setFromEuler(p),f.premultiply(u),f.multiply(d),e>2&&new three.Quaternion().fromArray(m,(e-3)/3*4).dot(f)<0&&f.set(-f.x,-f.y,-f.z,-f.w),f.toArray(m,e/3*4);return new three.QuaternionKeyframeTrack(e+`.quaternion`,s,m)}generateMorphTrack(e,t){let n=e.DeformPercent.curves.morph,r=n.values.map(function(e){return e/100}),o=t.getObjectByName(e.modelName).morphTargetDictionary[e.morphName];return new three.NumberKeyframeTrack(e.modelName+`.morphTargetInfluences[`+o+`]`,n.times,r)}getTimesForAllAxes(e){let t=[];if(e.x!==void 0&&(t=t.concat(e.x.times)),e.y!==void 0&&(t=t.concat(e.y.times)),e.z!==void 0&&(t=t.concat(e.z.times)),t=t.sort(function(e,t){return e-t}),t.length>1){let e=1,n=t[0];for(let r=1;r<t.length;r++){let o=t[r];o!==n&&(t[e]=o,n=o,e++)}t=t.slice(0,e)}return t}getKeyframeTrackValues(e,t,n){let r=n,o=[],s=-1,c=-1,l=-1;return e.forEach(function(e){if(t.x&&(s=t.x.times.indexOf(e)),t.y&&(c=t.y.times.indexOf(e)),t.z&&(l=t.z.times.indexOf(e)),s!==-1){let e=t.x.values[s];o.push(e),r[0]=e}else o.push(r[0]);if(c!==-1){let e=t.y.values[c];o.push(e),r[1]=e}else o.push(r[1]);if(l!==-1){let e=t.z.values[l];o.push(e),r[2]=e}else o.push(r[2])}),o}interpolateRotations(e,t,n,r){let o=[],s=[];o.push(e.times[0]),s.push(three.MathUtils.degToRad(e.values[0])),s.push(three.MathUtils.degToRad(t.values[0])),s.push(three.MathUtils.degToRad(n.values[0]));for(let c=1;c<e.values.length;c++){let l=[e.values[c-1],t.values[c-1],n.values[c-1]];if(isNaN(l[0])||isNaN(l[1])||isNaN(l[2]))continue;let u=l.map(three.MathUtils.degToRad),d=[e.values[c],t.values[c],n.values[c]];if(isNaN(d[0])||isNaN(d[1])||isNaN(d[2]))continue;d.map(three.MathUtils.degToRad);let f=[d[0]-l[0],d[1]-l[1],d[2]-l[2]],p=[Math.abs(f[0]),Math.abs(f[1]),Math.abs(f[2])];if(p[0]>=180||p[1]>=180||p[2]>=180){let t=Math.max(...p)/180,n=new three.Euler(u[0],u[1],u[2],r),l=new three.Euler(u[0],u[1],u[2],r),d=new three.Quaternion().setFromEuler(n),f=new three.Quaternion().setFromEuler(l);d.dot(f)&&f.set(-f.x,-f.y,-f.z,-f.w);let m=e.times[c-1],h=e.times[c]-m,g=new three.Quaternion,_=new three.Euler;for(let e=0;e<1;e+=1/t)g.copy(d.clone().slerp(f.clone(),e)),o.push(m+e*h),_.setFromQuaternion(g,r),s.push(_.x),s.push(_.y),s.push(_.z)}else o.push(e.times[c]),s.push(three.MathUtils.degToRad(e.values[c])),s.push(three.MathUtils.degToRad(t.values[c])),s.push(three.MathUtils.degToRad(n.values[c]))}return[o,s]}},TextParser=class{constructor(){this.allNodes=new FBXTree,this.nodeStack=[],this.currentIndent=0,this.currentPropName=``}getPrevNode(){return this.nodeStack[this.currentIndent-2]}getCurrentNode(){return this.nodeStack[this.currentIndent-1]}getCurrentProp(){return this.currentProp}pushStack(e){this.nodeStack.push(e),this.currentIndent+=1}popStack(){this.nodeStack.pop(),--this.currentIndent}setCurrentProp(e,t){this.currentProp=e,this.currentPropName=t}parse(e){this.currentIndent=0,this.allNodes=new FBXTree,this.nodeStack=[],this.currentProp=[],this.currentPropName=``;let t=this,n=e.split(/[\r\n]+/);return n.forEach(function(e,r){let o=e.match(/^[\s\t]*;/),s=e.match(/^[\s\t]*$/);if(o||s)return;let c=e.match(`^\\t{`+t.currentIndent+`}(\\w+):(.*){`),l=e.match(`^\\t{`+t.currentIndent+`}(\\w+):[\\s\\t\\r\\n](.*)`),u=e.match(`^\\t{`+(t.currentIndent-1)+`}}`);c?t.parseNodeBegin(e,c):l?t.parseNodeProperty(e,l,n[++r]):u?t.popStack():e.match(/^[^\s\t}]/)&&t.parseNodePropertyContinued(e)}),this.allNodes}parseNodeBegin(e,t){let n=t[1].trim().replace(/^"/,``).replace(/"$/,``),r=t[2].split(`,`).map(function(e){return e.trim().replace(/^"/,``).replace(/"$/,``)}),o={name:n},s=this.parseNodeAttr(r),c=this.getCurrentNode();this.currentIndent===0?this.allNodes.add(n,o):n in c?(n===`PoseNode`?c.PoseNode.push(o):c[n].id!==void 0&&(c[n]={},c[n][c[n].id]=c[n]),s.id!==``&&(c[n][s.id]=o)):typeof s.id==`number`?(c[n]={},c[n][s.id]=o):n!==`Properties70`&&(n===`PoseNode`?c[n]=[o]:c[n]=o),typeof s.id==`number`&&(o.id=s.id),s.name!==``&&(o.attrName=s.name),s.type!==``&&(o.attrType=s.type),this.pushStack(o)}parseNodeAttr(e){let t=e[0];e[0]!==``&&(t=parseInt(e[0]),isNaN(t)&&(t=e[0]));let n=``,r=``;return e.length>1&&(n=e[1].replace(/^(\w+)::/,``),r=e[2]),{id:t,name:n,type:r}}parseNodeProperty(e,t,n){let r=t[1].replace(/^"/,``).replace(/"$/,``).trim(),o=t[2].replace(/^"/,``).replace(/"$/,``).trim();r===`Content`&&o===`,`&&(o=n.replace(/"/g,``).replace(/,$/,``).trim());let s=this.getCurrentNode();if(s.name===`Properties70`){this.parseNodeSpecialProperty(e,r,o);return}if(r===`C`){let e=o.split(`,`).slice(1),t=parseInt(e[0]),n=parseInt(e[1]),c=o.split(`,`).slice(3);c=c.map(function(e){return e.trim().replace(/^"/,``)}),r=`connections`,o=[t,n],append(o,c),s[r]===void 0&&(s[r]=[])}r===`Node`&&(s.id=o),r in s&&Array.isArray(s[r])?s[r].push(o):r===`a`?s.a=o:s[r]=o,this.setCurrentProp(s,r),r===`a`&&o.slice(-1)!==`,`&&(s.a=parseNumberArray(o))}parseNodePropertyContinued(e){let t=this.getCurrentNode();t.a+=e,e.slice(-1)!==`,`&&(t.a=parseNumberArray(t.a))}parseNodeSpecialProperty(e,t,n){let r=n.split(`",`).map(function(e){return e.trim().replace(/^\"/,``).replace(/\s/,`_`)}),o=r[0],s=r[1],c=r[2],l=r[3],u=r[4];switch(s){case`int`:case`enum`:case`bool`:case`ULongLong`:case`double`:case`Number`:case`FieldOfView`:u=parseFloat(u);break;case`Color`:case`ColorRGB`:case`Vector3D`:case`Lcl_Translation`:case`Lcl_Rotation`:case`Lcl_Scaling`:u=parseNumberArray(u);break}this.getPrevNode()[o]={type:s,type2:c,flag:l,value:u},this.setCurrentProp(this.getPrevNode(),o)}},BinaryParser=class{parse(e){let t=new BinaryReader(e);t.skip(23);let n=t.getUint32();if(n<6400)throw Error(`THREE.FBXLoader: FBX version not supported, FileVersion: `+n);let r=new FBXTree;for(;!this.endOfContent(t);){let e=this.parseNode(t,n);e!==null&&r.add(e.name,e)}return r}endOfContent(e){return e.size()%16==0?(e.getOffset()+160+16&-16)>=e.size():e.getOffset()+160+16>=e.size()}parseNode(e,t){let n={},r=t>=7500?e.getUint64():e.getUint32(),o=t>=7500?e.getUint64():e.getUint32();t>=7500?e.getUint64():e.getUint32();let s=e.getUint8(),c=e.getString(s);if(r===0)return null;let l=[];for(let t=0;t<o;t++)l.push(this.parseProperty(e));let u=l.length>0?l[0]:``,d=l.length>1?l[1]:``,f=l.length>2?l[2]:``;for(n.singleProperty=o===1&&e.getOffset()===r;r>e.getOffset();){let r=this.parseNode(e,t);r!==null&&this.parseSubNode(c,n,r)}return n.propertyList=l,typeof u==`number`&&(n.id=u),d!==``&&(n.attrName=d),f!==``&&(n.attrType=f),c!==``&&(n.name=c),n}parseSubNode(e,t,n){if(n.singleProperty===!0){let e=n.propertyList[0];Array.isArray(e)?(t[n.name]=n,n.a=e):t[n.name]=e}else if(e===`Connections`&&n.name===`C`){let e=[];n.propertyList.forEach(function(t,n){n!==0&&e.push(t)}),t.connections===void 0&&(t.connections=[]),t.connections.push(e)}else if(n.name===`Properties70`)Object.keys(n).forEach(function(e){t[e]=n[e]});else if(e===`Properties70`&&n.name===`P`){let e=n.propertyList[0],r=n.propertyList[1],o=n.propertyList[2],s=n.propertyList[3],c;e.indexOf(`Lcl `)===0&&(e=e.replace(`Lcl `,`Lcl_`)),r.indexOf(`Lcl `)===0&&(r=r.replace(`Lcl `,`Lcl_`)),c=r===`Color`||r===`ColorRGB`||r===`Vector`||r===`Vector3D`||r.indexOf(`Lcl_`)===0?[n.propertyList[4],n.propertyList[5],n.propertyList[6]]:n.propertyList[4],t[e]={type:r,type2:o,flag:s,value:c}}else t[n.name]===void 0?typeof n.id==`number`?(t[n.name]={},t[n.name][n.id]=n):t[n.name]=n:n.name===`PoseNode`?(Array.isArray(t[n.name])||(t[n.name]=[t[n.name]]),t[n.name].push(n)):t[n.name][n.id]===void 0&&(t[n.name][n.id]=n)}parseProperty(e){let t=e.getString(1),n;switch(t){case`C`:return e.getBoolean();case`D`:return e.getFloat64();case`F`:return e.getFloat32();case`I`:return e.getInt32();case`L`:return e.getInt64();case`R`:return n=e.getUint32(),e.getArrayBuffer(n);case`S`:return n=e.getUint32(),e.getString(n);case`Y`:return e.getInt16();case`b`:case`c`:case`d`:case`f`:case`i`:case`l`:let r=e.getUint32(),o=e.getUint32(),s=e.getUint32();if(o===0)switch(t){case`b`:case`c`:return e.getBooleanArray(r);case`d`:return e.getFloat64Array(r);case`f`:return e.getFloat32Array(r);case`i`:return e.getInt32Array(r);case`l`:return e.getInt64Array(r)}let c=new BinaryReader(unzlibSync(new Uint8Array(e.getArrayBuffer(s))).buffer);switch(t){case`b`:case`c`:return c.getBooleanArray(r);case`d`:return c.getFloat64Array(r);case`f`:return c.getFloat32Array(r);case`i`:return c.getInt32Array(r);case`l`:return c.getInt64Array(r)}break;default:throw Error(`THREE.FBXLoader: Unknown property type `+t)}}},BinaryReader=class{constructor(e,t){this.dv=new DataView(e),this.offset=0,this.littleEndian=t===void 0?!0:t,this._textDecoder=new TextDecoder}getOffset(){return this.offset}size(){return this.dv.buffer.byteLength}skip(e){this.offset+=e}getBoolean(){return(this.getUint8()&1)==1}getBooleanArray(e){let t=[];for(let n=0;n<e;n++)t.push(this.getBoolean());return t}getUint8(){let e=this.dv.getUint8(this.offset);return this.offset+=1,e}getInt16(){let e=this.dv.getInt16(this.offset,this.littleEndian);return this.offset+=2,e}getInt32(){let e=this.dv.getInt32(this.offset,this.littleEndian);return this.offset+=4,e}getInt32Array(e){let t=[];for(let n=0;n<e;n++)t.push(this.getInt32());return t}getUint32(){let e=this.dv.getUint32(this.offset,this.littleEndian);return this.offset+=4,e}getInt64(){let e,t;return this.littleEndian?(e=this.getUint32(),t=this.getUint32()):(t=this.getUint32(),e=this.getUint32()),t&2147483648?(t=~t&4294967295,e=~e&4294967295,e===4294967295&&(t=t+1&4294967295),e=e+1&4294967295,-(t*4294967296+e)):t*4294967296+e}getInt64Array(e){let t=[];for(let n=0;n<e;n++)t.push(this.getInt64());return t}getUint64(){let e,t;return this.littleEndian?(e=this.getUint32(),t=this.getUint32()):(t=this.getUint32(),e=this.getUint32()),t*4294967296+e}getFloat32(){let e=this.dv.getFloat32(this.offset,this.littleEndian);return this.offset+=4,e}getFloat32Array(e){let t=[];for(let n=0;n<e;n++)t.push(this.getFloat32());return t}getFloat64(){let e=this.dv.getFloat64(this.offset,this.littleEndian);return this.offset+=8,e}getFloat64Array(e){let t=[];for(let n=0;n<e;n++)t.push(this.getFloat64());return t}getArrayBuffer(e){let t=this.dv.buffer.slice(this.offset,this.offset+e);return this.offset+=e,t}getString(e){let t=this.offset,n=new Uint8Array(this.dv.buffer,t,e);this.skip(e);let r=n.indexOf(0);return r>=0&&(n=new Uint8Array(this.dv.buffer,t,r)),this._textDecoder.decode(n)}},FBXTree=class{constructor(){this.Connections={connections:[]},this.Objects={Model:{},NodeAttribute:{},Geometry:{}},this.GlobalSettings={}}add(e,t){this[e]=t}};function isFbxFormatBinary(e){return e.byteLength>=21&&convertArrayBufferToString(e,0,21)===`Kaydara FBX Binary \0`}function isFbxFormatASCII(e){let t=[`K`,`a`,`y`,`d`,`a`,`r`,`a`,`\\`,`F`,`B`,`X`,`\\`,`B`,`i`,`n`,`a`,`r`,`y`,`\\`,`\\`],n=0;function r(t){let r=e[t-1];return e=e.slice(n+t),n++,r}for(let e=0;e<t.length;++e)if(r(1)===t[e])return!1;return!0}function getFbxVersion(e){let t=e.match(/FBXVersion: (\d+)/);if(t)return parseInt(t[1]);throw Error(`THREE.FBXLoader: Cannot find the version number for the file given.`)}function convertFBXTimeToSeconds(e){return e/46186158e3}var dataArray=[];function getData(e,t,n,r){let o;switch(r.mappingType){case`ByPolygonVertex`:o=e;break;case`ByPolygon`:o=t;break;case`ByVertice`:o=n;break;case`AllSame`:o=r.indices[0];break;default:console.warn(`THREE.FBXLoader: unknown attribute mapping type `+r.mappingType),o=0}r.referenceType===`IndexToDirect`&&(o=r.indices[o]);let s=o*r.dataSize,c=s+r.dataSize;return slice(dataArray,r.buffer,s,c)}var tempEuler=new three.Euler,tempVec=new three.Vector3;function generateTransform(e){let t=new three.Matrix4,n=new three.Matrix4,r=new three.Matrix4,o=new three.Matrix4,s=new three.Matrix4,c=new three.Matrix4,l=new three.Matrix4,u=new three.Matrix4,d=new three.Matrix4,f=new three.Matrix4,p=new three.Matrix4,m=new three.Matrix4,h=e.inheritType?e.inheritType:0;e.translation&&t.setPosition(tempVec.fromArray(e.translation));let g=getEulerOrder(0);if(e.preRotation){let t=e.preRotation.map(three.MathUtils.degToRad);t.push(g),n.makeRotationFromEuler(tempEuler.fromArray(t))}if(e.rotation){let t=e.rotation.map(three.MathUtils.degToRad);t.push(e.eulerOrder||g),r.makeRotationFromEuler(tempEuler.fromArray(t))}if(e.postRotation){let t=e.postRotation.map(three.MathUtils.degToRad);t.push(g),o.makeRotationFromEuler(tempEuler.fromArray(t)),o.copy(new three.Matrix4().getInverse(o))}e.scale&&s.scale(tempVec.fromArray(e.scale)),e.scalingOffset&&l.setPosition(tempVec.fromArray(e.scalingOffset)),e.scalingPivot&&c.setPosition(tempVec.fromArray(e.scalingPivot)),e.rotationOffset&&u.setPosition(tempVec.fromArray(e.rotationOffset)),e.rotationPivot&&d.setPosition(tempVec.fromArray(e.rotationPivot)),e.parentMatrixWorld&&(p.copy(e.parentMatrix),f.copy(e.parentMatrixWorld));let _=n.clone().multiply(r).multiply(o),v=new three.Matrix4;v.extractRotation(f);let y=new three.Matrix4;y.copyPosition(f);let b=new three.Matrix4().getInverse(y).multiply(f),S=new three.Matrix4().getInverse(v).multiply(b),C=s,w=new three.Matrix4;if(h===0)w.copy(v).multiply(_).multiply(S).multiply(C);else if(h===1)w.copy(v).multiply(S).multiply(_).multiply(C);else{let e=new three.Matrix4().scale(new three.Vector3().setFromMatrixScale(p)),t=new three.Matrix4().getInverse(e),n=S.clone().multiply(t);w.copy(v).multiply(_).multiply(n).multiply(C)}let T=new three.Matrix4().getInverse(d),E=new three.Matrix4().getInverse(c),D=t.clone().multiply(u).multiply(d).multiply(n).multiply(r).multiply(o).multiply(T).multiply(l).multiply(c).multiply(s).multiply(E),O=new three.Matrix4().copyPosition(D),k=f.clone().multiply(O);return m.copyPosition(k),D=m.clone().multiply(w),D.premultiply(new three.Matrix4().getInverse(f)),D}function getEulerOrder(e){e=e||0;let t=[`ZYX`,`YZX`,`XZY`,`ZXY`,`YXZ`,`XYZ`];return e===6?(console.warn(`THREE.FBXLoader: unsupported Euler Order: Spherical XYZ. Animations and rotations may be incorrect.`),t[0]):t[e]}function parseNumberArray(e){return e.split(`,`).map(function(e){return parseFloat(e)})}function convertArrayBufferToString(e,t,n){return t===void 0&&(t=0),n===void 0&&(n=e.byteLength),new TextDecoder().decode(new Uint8Array(e,t,n))}function append(e,t){for(let n=0,r=e.length,o=t.length;n<o;n++,r++)e[r]=t[n]}function slice(e,t,n,r){for(let o=n,s=0;o<r;o++,s++)e[s]=t[o];return e}var NURBSCurve=class extends three.Curve{constructor(e,t,n,r,o){super();let s=t?t.length-1:0,c=n?n.length:0;this.degree=e,this.knots=t,this.controlPoints=[],this.startKnot=r||0,this.endKnot=o||s;for(let e=0;e<c;++e){let t=n[e];this.controlPoints[e]=new three.Vector4(t.x,t.y,t.z,t.w)}}getPoint(e,t=new three.Vector3){let n=t,r=this.knots[this.startKnot]+e*(this.knots[this.endKnot]-this.knots[this.startKnot]),o=calcBSplinePoint(this.degree,this.knots,this.controlPoints,r);return o.w!==1&&o.divideScalar(o.w),n.set(o.x,o.y,o.z)}getTangent(e,t=new three.Vector3){let n=t,r=this.knots[0]+e*(this.knots[this.knots.length-1]-this.knots[0]),o=calcNURBSDerivatives(this.degree,this.knots,this.controlPoints,r,1);return n.copy(o[1]).normalize(),n}toJSON(){let e=super.toJSON();return e.degree=this.degree,e.knots=[...this.knots],e.controlPoints=this.controlPoints.map(e=>e.toArray()),e.startKnot=this.startKnot,e.endKnot=this.endKnot,e}fromJSON(e){return super.fromJSON(e),this.degree=e.degree,this.knots=[...e.knots],this.controlPoints=e.controlPoints.map(e=>new three.Vector4(e[0],e[1],e[2],e[3])),this.startKnot=e.startKnot,this.endKnot=e.endKnot,this}};function findSpan(e,t,n){let r=n.length-e-1;if(t>=n[r])return r-1;if(t<=n[e])return e;let o=e,s=r,c=Math.floor((o+s)/2);for(;t<n[c]||t>=n[c+1];)t<n[c]?s=c:o=c,c=Math.floor((o+s)/2);return c}function calcBasisFunctions(e,t,n,r){let o=[],s=[],c=[];o[0]=1;for(let l=1;l<=n;++l){s[l]=t-r[e+1-l],c[l]=r[e+l]-t;let n=0;for(let e=0;e<l;++e){let t=c[e+1],r=s[l-e],u=o[e]/(t+r);o[e]=n+t*u,n=r*u}o[l]=n}return o}function calcBSplinePoint(e,t,n,r){let o=findSpan(e,r,t),s=calcBasisFunctions(o,r,e,t),c=new three.Vector4(0,0,0,0);for(let t=0;t<=e;++t){let r=n[o-e+t],l=s[t],u=r.w*l;c.x+=r.x*u,c.y+=r.y*u,c.z+=r.z*u,c.w+=r.w*l}return c}function calcBasisFunctionDerivatives(e,t,n,r,o){let s=[];for(let e=0;e<=n;++e)s[e]=0;let c=[];for(let e=0;e<=r;++e)c[e]=s.slice(0);let l=[];for(let e=0;e<=n;++e)l[e]=s.slice(0);l[0][0]=1;let u=s.slice(0),d=s.slice(0);for(let r=1;r<=n;++r){u[r]=t-o[e+1-r],d[r]=o[e+r]-t;let n=0;for(let e=0;e<r;++e){let t=d[e+1],o=u[r-e];l[r][e]=t+o;let s=l[e][r-1]/l[r][e];l[e][r]=n+t*s,n=o*s}l[r][r]=n}for(let e=0;e<=n;++e)c[0][e]=l[e][n];for(let e=0;e<=n;++e){let t=0,o=1,u=[];for(let e=0;e<=n;++e)u[e]=s.slice(0);u[0][0]=1;for(let s=1;s<=r;++s){let r=0,d=e-s,f=n-s;e>=s&&(u[o][0]=u[t][0]/l[f+1][d],r=u[o][0]*l[d][f]);let p=d>=-1?1:-d,m=e-1<=f?s-1:n-e;for(let e=p;e<=m;++e)u[o][e]=(u[t][e]-u[t][e-1])/l[f+1][d+e],r+=u[o][e]*l[d+e][f];e<=f&&(u[o][s]=-u[t][s-1]/l[f+1][e],r+=u[o][s]*l[e][f]),c[s][e]=r;let h=t;t=o,o=h}}let f=n;for(let e=1;e<=r;++e){for(let t=0;t<=n;++t)c[e][t]*=f;f*=n-e}return c}function calcBSplineDerivatives(e,t,n,r,o){let s=o<e?o:e,c=[],l=findSpan(e,r,t),u=calcBasisFunctionDerivatives(l,r,e,s,t),d=[];for(let e=0;e<n.length;++e){let t=n[e].clone(),r=t.w;t.x*=r,t.y*=r,t.z*=r,d[e]=t}for(let t=0;t<=s;++t){let n=d[l-e].clone().multiplyScalar(u[t][0]);for(let r=1;r<=e;++r)n.add(d[l-e+r].clone().multiplyScalar(u[t][r]));c[t]=n}for(let e=s+1;e<=o+1;++e)c[e]=new three.Vector4(0,0,0);return c}function calcKoverI(e,t){let n=1;for(let t=2;t<=e;++t)n*=t;let r=1;for(let e=2;e<=t;++e)r*=e;for(let n=2;n<=e-t;++n)r*=n;return n/r}function calcRationalCurveDerivatives(e){let t=e.length,n=[],r=[];for(let o=0;o<t;++o){let t=e[o];n[o]=new three.Vector3(t.x,t.y,t.z),r[o]=t.w}let o=[];for(let e=0;e<t;++e){let t=n[e].clone();for(let n=1;n<=e;++n)t.sub(o[e-n].clone().multiplyScalar(calcKoverI(e,n)*r[n]));o[e]=t.divideScalar(r[0])}return o}function calcNURBSDerivatives(e,t,n,r,o){return calcRationalCurveDerivatives(calcBSplineDerivatives(e,t,n,r,o))}var _vector=new three.Vector3;function getPointArray(e,t){switch(t){case`D`:return new Float64Array(e);case`F`:return new Float32Array(e);case`L`:return new Int32Array(e);case`I`:return new Int16Array(e);default:return new Uint8Array(e)}}function loadX3p(e,t={}){var n,r,o;let s=(n=t.upAxis)==null?`Z`:n,c=(r=t.fetcher)==null?internalFetcher:r,l=(o=t.onDownloadProgress)==null?noop:o,u={byteLength:0};return Promise.resolve().then(()=>c.ajax(e,{responseType:`arraybuffer`},void 0,void 0,l)).then(n=>{var r,o;return u.byteLength=n.body.byteLength,parse$1(new Uint8Array(n.body),{light:(r=t.light)==null?!0:r,color:t.color,resourcePath:e.slice(0,e.lastIndexOf(`/`)+1),search:(o=e.split(`?`)[1])==null?``:o,fetcher:c})}).then(t=>{let n=new three.Group;return n.name=e,n.add(t.object),s===`Y`&&n.applyMatrix4(ROTATE_X_MATRIX_INVERSE$1),{type:`x3p`,modelUpAxis:`Z`,upAxis:s,uri:e,byteLength:u.byteLength,memoryUsage:getMemoryUsage(n),scene:n,textures:[],animations:[],dispose:()=>t.dispose()}})}function parse$1(e,t){var n,r,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b,S,C,w,T,E,D,O,k,A,j,M,N,P,F,I,L,R,z,B,V,H,ee,te,U,W,G,K,ne,re,ie,ae,oe,q,se,ce,le,ue;let J=unzipSync(e),de=``,fe=null;for(let e of Object.keys(J))/(^|\/)main\.xml$/i.test(e)&&(fe=J[e],de=e.slice(0,e.lastIndexOf(`/`)+1));if(!fe)throw Error(`X3p: main.xml not found.`);if(typeof DOMParser>`u`)throw Error(`X3p: DOMParser not found.`);let pe=(n=t.color)==null?new three.Color(10066329):n,me=new DOMParser,he=decodeText(fe),ge=me.parseFromString(he,`text/xml`),Y=ge.querySelector(`Record1 Axes`),_e={x:{type:(s=(o=(r=Y==null?void 0:Y.querySelector(`CX AxisType`))==null?void 0:r.textContent)==null?void 0:o.toUpperCase())==null?`I`:s,dataType:(u=(l=(c=Y==null?void 0:Y.querySelector(`CX DataType`))==null?void 0:c.textContent)==null?void 0:l.toUpperCase())==null?`D`:u,increment:Number((f=(d=Y==null?void 0:Y.querySelector(`CX Increment`))==null?void 0:d.textContent)==null?`1`:f),offset:Number((m=(p=Y==null?void 0:Y.querySelector(`CX Offset`))==null?void 0:p.textContent)==null?`0`:m)},y:{type:(_=(g=(h=Y==null?void 0:Y.querySelector(`CY AxisType`))==null?void 0:h.textContent)==null?void 0:g.toUpperCase())==null?`I`:_,dataType:(b=(y=(v=Y==null?void 0:Y.querySelector(`CY DataType`))==null?void 0:v.textContent)==null?void 0:y.toUpperCase())==null?`D`:b,increment:Number((C=(S=Y==null?void 0:Y.querySelector(`CY Increment`))==null?void 0:S.textContent)==null?`1`:C),offset:Number((T=(w=Y==null?void 0:Y.querySelector(`CY Offset`))==null?void 0:w.textContent)==null?`0`:T)},z:{type:(O=(D=(E=Y==null?void 0:Y.querySelector(`CZ AxisType`))==null?void 0:E.textContent)==null?void 0:D.toUpperCase())==null?`A`:O,dataType:(j=(A=(k=Y==null?void 0:Y.querySelector(`CZ DataType`))==null?void 0:k.textContent)==null?void 0:A.toUpperCase())==null?`D`:j,increment:Number((N=(M=Y==null?void 0:Y.querySelector(`CZ Increment`))==null?void 0:M.textContent)==null?`1`:N),offset:Number((F=(P=Y==null?void 0:Y.querySelector(`CZ Offset`))==null?void 0:P.textContent)==null?`0`:F)}},ve=null,X=ge.querySelector(`Record1 Axes Rotation`);X&&(ve=new three.Matrix3,ve.set(Number((L=(I=X.querySelector(`r11`))==null?void 0:I.textContent)==null?0:L),Number((z=(R=X.querySelector(`r12`))==null?void 0:R.textContent)==null?0:z),Number((V=(B=X.querySelector(`r13`))==null?void 0:B.textContent)==null?0:V),Number((ee=(H=X.querySelector(`r21`))==null?void 0:H.textContent)==null?0:ee),Number((U=(te=X.querySelector(`r22`))==null?void 0:te.textContent)==null?0:U),Number((G=(W=X.querySelector(`r23`))==null?void 0:W.textContent)==null?0:G),Number((ne=(K=X.querySelector(`r31`))==null?void 0:K.textContent)==null?0:ne),Number((ie=(re=X.querySelector(`r32`))==null?void 0:re.textContent)==null?0:ie),Number((oe=(ae=X.querySelector(`r33`))==null?void 0:ae.textContent)==null?0:oe)));let ye=(q=ge.querySelector(`Record3 DataLink PointDataLink`))==null?void 0:q.textContent;if(typeof ye!=`string`)throw Error(`X3p: PointDataLink not found.`);ye=pathJoin(de,ye);let be=J[ye];if(!be)throw Error(`X3p: ${be} not found.`);let xe=getPointArray(be.buffer,_e.z.dataType),Se=Number((ce=(se=ge.querySelector(`Record3 MatrixDimension SizeX`))==null?void 0:se.textContent)==null?`0`:ce),Ce=Number((ue=(le=ge.querySelector(`Record3 MatrixDimension SizeY`))==null?void 0:le.textContent)==null?`0`:ue),we=Math.floor(Se-1),Te=Math.floor(Ce-1),Ee=we+1,De=Te+1,Oe=new Float32Array(Ee*De*3),ke=new Float32Array(Ee*De*2),Ae=new Uint32Array(we*Te*6),je=new three.Box3;for(let e=0;e<De;e++){let t=e*_e.y.increment+_e.y.offset;for(let n=0;n<Ee;n++){let r=e*Ee+n,o=n*_e.x.increment+_e.x.offset,s=xe[r],c=!isNaN(s),l=c?s:NaN;_vector.set(o,-t,l),ve&&_vector.applyMatrix3(ve),c&&je.expandByPoint(_vector),Oe[r*3+0]=_vector.x,Oe[r*3+1]=_vector.y,Oe[r*3+2]=_vector.z,ke[r*2+0]=n/we,ke[r*2+1]=1-e/Te}}for(let e=0;e<Te;e++)for(let t=0;t<we;t++){let n=t+Ee*e,r=t+Ee*(e+1),o=t+1+Ee*(e+1),s=t+1+Ee*e,c=(e*we+t)*6;Ae[c+0]=n,Ae[c+1]=r,Ae[c+2]=s,Ae[c+3]=r,Ae[c+4]=o,Ae[c+5]=s}let Z=new three.BufferGeometry;Z.setAttribute(`position`,new three.BufferAttribute(Oe,3)),Z.setAttribute(`uv`,new three.BufferAttribute(ke,2)),Z.setIndex(new three.BufferAttribute(Ae,1)),(!Z.groups||Z.groups.length===0)&&Z.addGroup(0,Z.index?Z.index.count:Z.attributes.position.count,0),Z.boundingBox=je;let Me=new PBMMeshMaterial(t.light?`phong`:`basic`);return Me.flatShading=!0,Me.color.copy(pe),{object:new PBMMesh(Z,[Me]),dispose:()=>{Z.dispose(),Me.dispose()}}}function parseSplatData(e){let t=32,n=e.length/32;if(e.length%32!=0)throw Error(`Invalid splat file: data length ${e.length} is not a multiple of 32`);let r=new Float32Array(3*n),o=new Float32Array(4*n),s=new Float32Array(3*n),c=new Uint8Array(4*n),l=new Float32Array(e.buffer),u=new Uint8Array(e.buffer);for(let e=0;e<n;e++)r[3*e+0]=l[8*e+0],r[3*e+1]=l[8*e+1],r[3*e+2]=l[8*e+2],s[3*e+0]=l[8*e+3+0],s[3*e+1]=l[8*e+3+1],s[3*e+2]=l[8*e+3+2],c[4*e+0]=u[32*e+24+0],c[4*e+1]=u[32*e+24+1],c[4*e+2]=u[32*e+24+2],c[4*e+3]=u[32*e+24+3],o[4*e+0]=(u[32*e+28+0]-128)/128,o[4*e+1]=(u[32*e+28+1]-128)/128,o[4*e+2]=(u[32*e+28+2]-128)/128,o[4*e+3]=(u[32*e+28+3]-128)/128;return{numPoints:n,positions:r,scales:s,rotations:o,colors:c}}function loadSplat(e,t={}){var n,r,o,s;let c=(n=t.modelUpAxis)==null?`Y`:n,l=(r=t.upAxis)==null?`Z`:r,u=(o=t.fetcher)==null?internalFetcher:o,d=(s=t.onDownloadProgress)==null?noop:s,f=0;return Promise.resolve().then(()=>u.ajax(e,{responseType:`arraybuffer`},void 0,void 0,d)).then(e=>(f=e.body.byteLength,e.body)).then(e=>parseSplatData(new Uint8Array(e))).then(t=>{let n=new PBMGaussianSplattingObject({positions:t.positions,scales:t.scales,rotations:t.rotations,colors:t.colors,numPoints:t.numPoints});return c===`Y`&&n.applyMatrix4(ROTATE_X_MATRIX$1),{type:`splat`,modelUpAxis:c,upAxis:l,uri:e,byteLength:f,memoryUsage:getMemoryUsage(n),scene:n,textures:[],animations:[],dispose:()=>n.dispose()}})}var VolumePlaneIntersect;(function(e){e[e.Outside=-1]=`Outside`,e[e.Intersecting=0]=`Intersecting`,e[e.Inside=1]=`Inside`})(VolumePlaneIntersect||(VolumePlaneIntersect={}));var EPSILON$2=1e-6,identityMatrix4$1=new three.Matrix4().identity(),scratchVector=new three.Vector3,scratchMatrix4$5=new three.Matrix4,scratchXAxis=new three.Vector3,scratchYAxis=new three.Vector3,scratchZAxis=new three.Vector3,scratchSize=new three.Vector3,scratchBox3$1=new three.Box3,scratchSphere$2=new three.Sphere,scratchMatrix4Inverse$1=new three.Matrix4,scratchRay$1=new three.Ray,scratchObject3D=new three.Object3D,scratchFrustum=new three.Frustum;function quaternionFromMatrix3(e,t){let n=e.elements;return t.setFromRotationMatrix(scratchMatrix4$5.set(n[0],n[3],n[6],0,n[1],n[4],n[7],0,n[2],n[5],n[8],0,0,0,0,1)),t}var CullingVolume=class e{static get MASK_OUTSIDE(){return 4294967295}static get MASK_INSIDE(){return 0}static get MASK_INDETERMINATE(){return 2147483647}constructor(e=[]){this.planes=e}setFromFrustum(e){return this.planes=e.planes.map(e=>e.clone()),this}setFromCamera(e){return scratchMatrix4$5.multiplyMatrices(e.projectionMatrix,e.matrixWorldInverse),scratchFrustum.setFromProjectionMatrix(scratchMatrix4$5),this.setFromFrustum(scratchFrustum),this}applyMatrix4(e){for(let t of this.planes)t.applyMatrix4(e)}copy(e){return this.planes=e.planes.map(e=>e.clone()),this}clone(){return new e().copy(this)}computeVisibility(e){let t=VolumePlaneIntersect.Inside;for(let n of this.planes)switch(e.intersectPlane(n)){case VolumePlaneIntersect.Outside:return VolumePlaneIntersect.Outside;case VolumePlaneIntersect.Intersecting:t=VolumePlaneIntersect.Intersecting;break;default:}return t}computeVisibilityWithPlaneMask(t,n){if(n===e.MASK_OUTSIDE||n===e.MASK_INSIDE)return n;let r=e.MASK_INSIDE,o=Math.min(32,this.planes.length);for(let s=0;s<o;++s){let o=1<<s;if((n&o)===0)continue;let c=this.planes[s],l=t.intersectPlane(c);if(l===VolumePlaneIntersect.Outside)return e.MASK_OUTSIDE;l===VolumePlaneIntersect.Intersecting&&(r|=o)}return r}},BoxBoundingVolume=class e{constructor(){this.type=`box`,this.center=new three.Vector3,this.halfSize=new three.Vector3,this.rotation=new three.Matrix3}fromJson({box:e}){this.center.set(e[0],e[1],e[2]);let t=e[3],n=e[4],r=e[5],o=e[6],s=e[7],c=e[8],l=e[9],u=e[10],d=e[11],f=Math.max(Math.sqrt(t*t+n*n+r*r),.001),p=Math.max(Math.sqrt(o*o+s*s+c*c),.001),m=Math.max(Math.sqrt(l*l+u*u+d*d),.001);this.halfSize.set(f,p,m);let h=this.halfSize.toArray().reduce((e,t)=>e+t,0);return(isNaN(h)||h<=0)&&this.halfSize.setScalar(EPSILON$2),this.rotation.fromArray([t/f,n/f,r/f,o/p,s/p,c/p,l/m,u/m,d/m]),isNaN(this.rotation.toArray().reduce((e,t)=>e+t,0))&&this.rotation.identity(),this}toJson(){return this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),{box:[...this.center.toArray(),...scratchXAxis.multiplyScalar(this.halfSize.x).toArray(),...scratchYAxis.multiplyScalar(this.halfSize.y).toArray(),...scratchZAxis.multiplyScalar(this.halfSize.z).toArray()]}}copy(e){return this.center.copy(e.center),this.halfSize.copy(e.halfSize),this.rotation.copy(e.rotation),this}clone(){return new e().copy(this)}applyMatrix4(e){return e.equals(identityMatrix4$1)?this:(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(e),scratchObject3D.matrix.decompose(scratchObject3D.position,scratchObject3D.quaternion,scratchObject3D.scale),this.center.copy(scratchObject3D.position),this.rotation.setFromMatrix4(scratchMatrix4$5.makeRotationFromQuaternion(scratchObject3D.quaternion)),this.halfSize.copy(scratchObject3D.scale),this)}getCenter(e){return e.copy(this.center)}distanceSquaredToPoint(e){let t=this.rotation.elements,n=e.x-this.center.x,r=e.y-this.center.y,o=e.z-this.center.z,s=0,c;return c=n*t[0]+r*t[1]+o*t[2],c<0&&(c=-c),c-=this.halfSize.x,c>0&&(s+=c*c),c=n*t[3]+r*t[4]+o*t[5],c<0&&(c=-c),c-=this.halfSize.y,c>0&&(s+=c*c),c=n*t[6]+r*t[7]+o*t[8],c<0&&(c=-c),c-=this.halfSize.z,c>0&&(s+=c*c),s}distanceToPoint(e){return Math.sqrt(this.distanceSquaredToPoint(e))}distanceToPlane(e){let t=e.projectPoint(this.center,new three.Vector3);return this.distanceToPoint(t)}getBoundingBox(e){return e.makeEmpty(),this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchXAxis.setLength(this.halfSize.x),scratchYAxis.setLength(this.halfSize.y),scratchZAxis.setLength(this.halfSize.z),e.expandByPoint(scratchVector.copy(this.center).add(scratchXAxis)),e.expandByPoint(scratchVector.copy(this.center).sub(scratchXAxis)),e.expandByPoint(scratchVector.copy(this.center).add(scratchYAxis)),e.expandByPoint(scratchVector.copy(this.center).sub(scratchYAxis)),e.expandByPoint(scratchVector.copy(this.center).add(scratchZAxis)),e.expandByPoint(scratchVector.copy(this.center).sub(scratchZAxis)),e}toGeometry(){let e=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(24);scratchVector.set(this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,0),scratchVector.set(-this.halfSize.x,this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,3),scratchVector.set(-this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,6),scratchVector.set(this.halfSize.x,-this.halfSize.y,this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,9),scratchVector.set(this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,12),scratchVector.set(-this.halfSize.x,this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,15),scratchVector.set(-this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,18),scratchVector.set(this.halfSize.x,-this.halfSize.y,-this.halfSize.z).applyMatrix3(this.rotation).add(this.center).toArray(t,21);let n=new three.BufferGeometry;return n.setIndex(new three.BufferAttribute(e,1)),n.setAttribute(`position`,new three.BufferAttribute(t,3)),n.computeBoundingBox(),n.computeBoundingSphere(),n}intersectPlane(e){let t=this.center,n=e.normal,r=this.rotation.elements,o=this.halfSize,s=n.x,c=n.y,l=n.z,u=Math.abs(s*r[0]*o.x+c*r[1]*o.x+l*r[2]*o.x)+Math.abs(s*r[3]*o.y+c*r[4]*o.y+l*r[5]*o.y)+Math.abs(s*r[6]*o.z+c*r[7]*o.z+l*r[8]*o.z),d=n.dot(t)+e.constant;return d<=-u?VolumePlaneIntersect.Outside:d>=u?VolumePlaneIntersect.Inside:VolumePlaneIntersect.Intersecting}intersectRay(e,t=0,n){if(scratchSize.copy(this.halfSize).multiplyScalar(2),scratchBox3$1.setFromCenterAndSize(scratchVector.set(0,0,0),scratchSize),scratchBox3$1.expandByScalar(t),this.rotation.extractBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchMatrix4$5.makeBasis(scratchXAxis,scratchYAxis,scratchZAxis),scratchMatrix4$5.setPosition(this.center),scratchMatrix4Inverse$1.getInverse(scratchMatrix4$5),scratchRay$1.copy(e).applyMatrix4(scratchMatrix4Inverse$1),scratchBox3$1.containsPoint(scratchRay$1.origin))return!0;let r=scratchRay$1.intersectBox(scratchBox3$1,scratchVector);return r?n===void 0?!0:(n+=t,r.distanceToSquared(scratchRay$1.origin)<=n*n):!1}},SphereBoundingVolume=class e{constructor(){this.type=`sphere`,this.center=new three.Vector3,this.radius=-1}fromJson({sphere:e}){return this.center.set(e[0],e[1],e[2]),this.radius=Math.max(e[3],EPSILON$2),this}toJson(){return{sphere:[...this.center.toArray(),this.radius]}}copy(e){return this.center.copy(e.center),this.radius=e.radius,this}clone(){return new e().copy(this)}getBoundingBox(e){return e.setFromCenterAndSize(this.center,scratchSize.set(1,1,1).multiplyScalar(this.radius*2)),e}toGeometry(){let e=32,t=new Float32Array(384);for(let e=0;e<=32;e++){let n=0;n=e/32*Math.PI*2,t[e*6+0]=this.center.x+Math.cos(n)*this.radius,t[e*6+1]=this.center.y+Math.sin(n)*this.radius,t[e*6+2]=this.center.z+0,n=(e+1)/32*Math.PI*2,t[e*6+3]=this.center.x+Math.cos(n)*this.radius,t[e*6+4]=this.center.y+Math.sin(n)*this.radius,t[e*6+5]=this.center.z+0}for(let e=32;e<=64;e++){let n=0;n=e/32*Math.PI*2,t[e*6+0]=this.center.x+Math.cos(n)*this.radius,t[e*6+1]=this.center.y+0,t[e*6+2]=this.center.z+Math.sin(n)*this.radius,n=(e+1)/32*Math.PI*2,t[e*6+3]=this.center.x+Math.cos(n)*this.radius,t[e*6+4]=this.center.y+0,t[e*6+5]=this.center.z+Math.sin(n)*this.radius}let n=new three.BufferGeometry;return n.setAttribute(`position`,new three.BufferAttribute(t,3)),n.computeBoundingBox(),n.computeBoundingSphere(),n}applyMatrix4(e){return e.equals(identityMatrix4$1)?this:(this.center.applyMatrix4(e),this.radius*=e.getMaxScaleOnAxis(),this)}getCenter(e){return e.copy(this.center)}distanceSquaredToPoint(e){let t=this.distanceToPoint(e);return t*t}distanceToPoint(e){let t=this.center.distanceTo(e)-this.radius;return t<=0?0:t}distanceToPlane(e){let t=Math.abs(e.distanceToPoint(this.center));return Math.max(0,t-this.radius)}intersectPlane(e){let t=this.center,n=this.radius,r=e.normal.dot(t)+e.constant;return r<-n?VolumePlaneIntersect.Outside:r<n?VolumePlaneIntersect.Intersecting:VolumePlaneIntersect.Inside}intersectRay(e,t=0,n){if(scratchSphere$2.set(this.center,this.radius+t),scratchSphere$2.containsPoint(e.origin))return!0;let r=e.intersectSphere(scratchSphere$2,scratchVector);return r?n===void 0?!0:(n+=t,e.origin.distanceToSquared(r)<=n*n):!1}},RegionBoundingVolume=class e{constructor(){throw this.type=`regin`,this.west=0,this.south=0,this.east=0,this.north=0,this.minHeight=0,this.maxHeight=0,Error(`Region bounding volume not supported.`)}fromJson({region:e}){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}toJson(){return{region:[this.west,this.south,this.east,this.north,this.minHeight,this.maxHeight]}}copy(e){return this.west=e.west,this.south=e.south,this.east=e.east,this.north=e.north,this.minHeight=e.minHeight,this.maxHeight=e.maxHeight,this}clone(){return new e().copy(this)}getBoundingBox(e){throw Error(`not implemented`)}toGeometry(){throw Error(`not implemented`)}applyMatrix4(e){throw Error(`not implemented`)}getCenter(e){throw Error(`not implemented`)}distanceToPoint(e){throw Error(`not implemented`)}distanceSquaredToPoint(e){throw Error(`not implemented`)}distanceToPlane(e){throw Error(`not implemented`)}intersectPlane(e){throw Error(`not implemented`)}intersectRay(e,t=0,n){throw Error(`not implemented`)}};function isBoundingVolume(e){return e instanceof BoxBoundingVolume||e instanceof SphereBoundingVolume||e instanceof RegionBoundingVolume}function makeBoundingVolume(e){if(isBoundingVolume(e))return e;if(`box`in e)return new BoxBoundingVolume().fromJson(e);if(`sphere`in e)return new SphereBoundingVolume().fromJson(e);if(`region`in e)return new RegionBoundingVolume().fromJson(e);throw Error(`BoundingVolume ${JSON.stringify(e)} never suppored.`)}var debugMaterials=[4821759,8191922,16637280,16739958,5822969,376977,16747077,9259235,14514687].map(e=>new three.LineBasicMaterial({color:e,depthWrite:!1,depthTest:!0,transparent:!0,opacity:.5})),debugBoxGeometry=(()=>{let e=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(24);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);let n=new three.BufferGeometry;return n.setIndex(new three.BufferAttribute(e,1)),n.setAttribute(`position`,new three.BufferAttribute(t,3)),n.computeBoundingBox(),n.computeBoundingSphere(),n})(),debugSphereGeometry=(()=>{let e=32,t=new Float32Array(384);for(let e=0;e<=32;e++){let n=0;n=e/32*Math.PI*2,t[e*6+0]=Math.cos(n),t[e*6+1]=Math.sin(n),t[e*6+2]=0,n=(e+1)/32*Math.PI*2,t[e*6+3]=Math.cos(n),t[e*6+4]=Math.sin(n),t[e*6+5]=0}for(let e=32;e<=64;e++){let n=0;n=e/32*Math.PI*2,t[e*6+0]=Math.cos(n),t[e*6+1]=0,t[e*6+2]=Math.sin(n),n=(e+1)/32*Math.PI*2,t[e*6+3]=Math.cos(n),t[e*6+4]=0,t[e*6+5]=Math.sin(n)}let n=new three.BufferGeometry;return n.setAttribute(`position`,new three.BufferAttribute(t,3)),n.computeBoundingBox(),n.computeBoundingSphere(),n})();function createDebugBoundingMesh(e,t=0){if(e instanceof BoxBoundingVolume){let n=new three.LineSegments(debugBoxGeometry,debugMaterials[Math.min(t,debugMaterials.length-1)]);return n.position.copy(e.center),quaternionFromMatrix3(e.rotation,n.quaternion),n.scale.set(e.halfSize.x,e.halfSize.y,e.halfSize.z),n.matrix.compose(n.position,n.quaternion,n.scale),n}else if(e instanceof SphereBoundingVolume){let n=new three.LineSegments(debugSphereGeometry,debugMaterials[Math.min(t,debugMaterials.length-1)]);return n.position.copy(e.center),n.scale.set(e.radius,e.radius,e.radius),n.matrix.compose(n.position,n.quaternion,n.scale),n}return null}var scratchVector3$10=new three.Vector3,scratchPlane=new three.Plane,scratchSphereBoundingVolume$1=new SphereBoundingVolume,scratchBoxBoundingVolume$1=new BoxBoundingVolume,Tile=class e{constructor(t,n,r,o){var s,c,l,u;this.parent=null,this.contentParent=null,this.floor=0,this.id=t,this.state={visible:!1,frameNumber:0,selectedFrameNumber:0,requestedFrameNumber:0,touchedFrameNumber:0,distanceToCamera:0,centerZDepth:0,centerScreenY:0,screenSpaceError:0,visibilityPlaneMask:0,inRequestVolume:!1,shouldRefine:!1,stackLength:0,finalResolution:!0,selectionDepth:0,shouldSelect:!1,lastSelect:!1,ancestorWithContent:null,ancestorWithContentAvailable:null},this.parent=o==null?null:o,this.contentParent=o?o.hasRenderContent?o:o.contentParent:null,this.level=this.parent?this.parent.level+1:0,this.tileset=r,this.refine=(s=n.refine)==null?this.parent?this.parent.refine:`REPLACE`:s,this.transform=new three.Matrix4,n.transform&&this.transform.fromArray(n.transform),this.parent&&this.transform.premultiply(this.parent.transform),typeof n.geometricError==`number`?this.geometricError=n.geometricError*this.transform.getMaxScaleOnAxis():this.geometricError=(l=(c=this.parent)==null?void 0:c.geometricError)==null?0:l,n.content&&n.content.uri?(this.content={uri:n.content.uri,loadState:`UNLOADED`,loadProgress:0,loadStateUpdateTime:now(),loadfailRetryDelay:0,byteLength:0,memoryUsage:0},n.content.group!==void 0&&(this.content.group=n.content.group),/\.json$/.test(this.content.uri)?this.type=`TILESET`:this.type=`SCENEGRAPH`):(this.content=null,this.type=`EMPTY`),this.levelOfContent=this.parent?this.parent.levelOfContent:-1,this.type===`SCENEGRAPH`&&(this.levelOfContent+=1),n.boundingVolume&&(this.boundingVolume=makeBoundingVolume(n.boundingVolume).applyMatrix4(this.transform)),n.viewerRequestVolume&&(this.viewerRequestVolume=makeBoundingVolume(n.viewerRequestVolume).applyMatrix4(this.transform)),this.extras=(u=n.extras)==null?{}:u,typeof this.extras.floor!=`number`&&o&&typeof o.extras.floor==`number`&&(this.extras.floor=o.extras.floor),typeof this.extras.floor==`number`&&(this.floor=this.extras.floor,this.tileset.floorLength=Math.max(this.tileset.floorLength,this.floor+1)),n.children?this.children=n.children.map((t,n)=>new e(`${this.id}.${n}`,t,r,this)):this.children=[]}traverse(e){e(this);for(let t of this.children)t.traverse(e)}updateState(e){this.state.frameNumber=e.frameNumber;let t=this.tileset.transform;if(this.boundingVolume){let n;n=this.boundingVolume instanceof BoxBoundingVolume?scratchBoxBoundingVolume$1.copy(this.boundingVolume):this.boundingVolume instanceof SphereBoundingVolume?scratchSphereBoundingVolume$1.copy(this.boundingVolume):this.boundingVolume.clone(),n.applyMatrix4(t),e.camera.type===`OrthographicCamera`?(scratchPlane.setFromNormalAndCoplanarPoint(e.camera.direction,e.camera.position),this.state.distanceToCamera=n.distanceToPlane(scratchPlane)):this.state.distanceToCamera=n.distanceToPoint(e.camera.position);let r=n.getCenter(scratchVector3$10).sub(e.camera.position);this.state.centerZDepth=e.camera.direction.dot(r),this.state.centerScreenY=e.camera.up.dot(r);let o=this.parent?this.parent.state.visibilityPlaneMask:CullingVolume.MASK_INDETERMINATE;this.state.visibilityPlaneMask=e.cullingVolume.computeVisibilityWithPlaneMask(n,o),this.state.visible=this.state.visibilityPlaneMask!==CullingVolume.MASK_OUTSIDE,e.cameraCulling||(this.state.visible=!0)}else this.state.distanceToCamera=0,this.state.centerZDepth=0,this.state.visibilityPlaneMask=CullingVolume.MASK_INDETERMINATE,this.state.visible=!0;if((this.levelOfContent<=e.minLevelOfDetail||this.geometricError>=e.maxGeometricError)&&(this.state.visible=!0),this.viewerRequestVolume){let n;n=this.viewerRequestVolume instanceof BoxBoundingVolume?scratchBoxBoundingVolume$1.copy(this.viewerRequestVolume):this.viewerRequestVolume instanceof SphereBoundingVolume?scratchSphereBoundingVolume$1.copy(this.viewerRequestVolume):this.viewerRequestVolume.clone(),n.applyMatrix4(t),this.state.inRequestVolume=n.distanceSquaredToPoint(e.camera.position)<=0}else this.state.inRequestVolume=!0;this.state.screenSpaceError=this.getScreenSpaceError(e,this.state.distanceToCamera,!1)}get selected(){return this.state.selectedFrameNumber===this.tileset.frameNumber}get hasChildren(){return this.children.length>0}get siblingIndex(){var e,t;return(t=(e=this.parent)==null?void 0:e.children.indexOf(this))==null?0:t}get hasTilesetContent(){return this.children.length>0&&this.type===`TILESET`}get hasRenderContent(){return this.type===`SCENEGRAPH`}get contentAvailable(){var e;return this.hasRenderContent&&((e=this.content)==null?void 0:e.loadState)===`READY`}get hasUnloadedContent(){var e;return((e=this.content)==null?void 0:e.loadState)===`UNLOADED`}get hasEmptyContent(){return this.type===`EMPTY`}get contentReady(){var e;return((e=this.content)==null?void 0:e.loadState)===`READY`||this.hasEmptyContent}get contentByteLength(){return this.content?this.content.byteLength:0}get contentMemoryUsage(){return this.content?this.content.memoryUsage:0}getScreenSpaceError(e,t,n){let r=this.tileset.transform.getMaxScaleOnAxis(),o=this.parent?this.parent.geometricError:this.tileset.geometricError,s=r*(n?o:this.geometricError);if(s===0)return 0;let c=e.height,l=e.sseDenominator;return e.camera.type===`OrthographicCamera`?s/(1/(e.camera.projectionMatrix.elements[5]/2)/c*.9):s/(Math.max(t,.001)*l/c)}getPriority(e){let t=this.refine===`ADD`||e.skipLevelOfDetail;if(t&&!this.state.visible||e.frameNumber-this.state.touchedFrameNumber>=1)return-1;let n=this.parent,r=n&&(!t||this.state.screenSpaceError===0)?n.state.screenSpaceError:this.state.screenSpaceError,o=this.tileset.root?this.tileset.root.state.screenSpaceError:0;return Math.max(o-r,0)}},defaultIterator=e=>Number(e);function arrayMin(e,t=defaultIterator,n=!1){let r,o=1/0;for(let n of e){let e=t(n);e<=o&&(r=n,o=e)}return isFinite(o)||(o=0),n?[r,o]:r}function arrayEqual(e,t,n=(e,t)=>e===t){let r=e.length;if(r!==t.length)return!1;for(let o=0;o<r;o++)if(n(e[o],t[o])===!1)return!1;return!0}var arrayUniqueSet=new Set;function arrayUnique(e){arrayUniqueSet.clear();let t=[],n=e.length;for(let r=0;r<n;r++){let n=e[r];arrayUniqueSet.has(n)||(t.push(n),arrayUniqueSet.add(n))}return arrayUniqueSet.clear(),t}var arrayMinCallback=e=>e.distance,intersectDistanceSortCallback=(e,t)=>e.distance-t.distance;function sortIntersects(e,t=!0,n=!1){if(n&&e.length>1){let t=arrayMin(e,arrayMinCallback);t?(e[0]=t,e.length=1):e.length=0}return t&&e.length>1&&e.sort(intersectDistanceSortCallback),e}var BVHObject=class{constructor(e,t){this.position=e,this.indices=t}getPositionCount(){var e,t;let n=this.indices,r=this.position;return n?n.array.length/((e=n.stride)==null?1:e):r.array.length/((t=r.stride)==null?3:t)}getPositionByIndex(e,t){var n,r,o,s;let c=this.indices,l=this.position,u=e;if(c){let t=c.array,o=(n=c.stride)==null?1:n,s=(r=c.offset)==null?0:r;u=t[e*o+s]}let d=l.array,f=(o=l.stride)==null?3:o,p=(s=l.offset)==null?0:s;return u=u*f+p,t.x=d[u],t.y=d[u+1],t.z=d[u+2],t}createTree(e,t,n){throw Error(`not implemented`)}trianglesInSphere(e,t){throw Error(`not implemented`)}intersectRay(e,t,n=0,r=!1,o){throw Error(`not implemented`)}},BVHNode=class{constructor(e,t,n,r,o){this.id=e,this.extents=t,this.startIndex=n,this.endIndex=r,this.deepth=o}},BYTES_PER_NODE=36;function packBVHNode(e,t){let n=new ArrayBuffer(t*36),r=new Float32Array(n),o=new Uint32Array(n),s=new Uint16Array(n),c=[e],l,u;for(;l=c.pop();)u=l.id*36/4,r[u]=l.extents[0],r[u+1]=l.extents[1],r[u+2]=l.extents[2],r[u+3]=l.extents[3],r[u+4]=l.extents[4],r[u+5]=l.extents[5],o[u+6]=l.startIndex,o[u+7]=l.endIndex,u=l.id*36/2,l.node0&&(s[u+16]=l.node0.id,c.push(l.node0)),l.node1&&(s[u+17]=l.node1.id,c.push(l.node1));return n}function intersectNodeBox(e,t,n,r=0){let o=n.min.x-r,s=n.min.y-r,c=n.min.z-r,l=n.max.x+r,u=n.max.y+r,d=n.max.z+r,f=0,p=0,m=0,h=0,g=0,_=0;return t.x>=0?(f=(o-e.x)*t.x,p=(l-e.x)*t.x):(f=(l-e.x)*t.x,p=(o-e.x)*t.x),t.y>=0?(m=(s-e.y)*t.y,h=(u-e.y)*t.y):(m=(u-e.y)*t.y,h=(s-e.y)*t.y),f>h||m>p||((m>f||f!==f)&&(f=m),(h<p||p!==p)&&(p=h),t.z>=0?(g=(c-e.z)*t.z,_=(d-e.z)*t.z):(g=(d-e.z)*t.z,_=(c-e.z)*t.z),f>_||g>p)||((g>f||f!==f)&&(f=g),(_<p||p!==p)&&(p=_),p<0)?null:f>=0?f:0}var BVHVector3=class e{constructor(e,t,n){this.x=e,this.y=t,this.z=n}copy(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}set(e,t,n){return this.x=e,this.y=t,this.z=n,this}fromArray(e,t=0){return this.x=e[t],this.y=e[t+1],this.z=e[t+2],this}toArray(e=[],t=0){return e[t]=this.x,e[t+1]=this.y,e[t+2]=this.z,e}add(e){return this.x+=e.x,this.y+=e.y,this.z+=e.z,this}multiplyScalar(e){return this.x*=e,this.y*=e,this.z*=e,this}subVectors(e,t){return this.x=e.x-t.x,this.y=e.y-t.y,this.z=e.z-t.z,this}addScaledVector(e,t){return this.x+=e.x*t,this.y+=e.y*t,this.z+=e.z*t,this}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z}cross(e){let t=this.x,n=this.y,r=this.z;return this.x=n*e.z-r*e.y,this.y=r*e.x-t*e.z,this.z=t*e.y-n*e.x,this}crossVectors(e,t){let n=e.x,r=e.y,o=e.z,s=t.x,c=t.y,l=t.z;return this.x=r*l-o*c,this.y=o*s-n*l,this.z=n*c-r*s,this}distanceTo(e){return Math.sqrt(this.distanceToSquared(e))}distanceToSquared(e){let t=this.x-e.x,n=this.y-e.y,r=this.z-e.z;return t*t+n*n+r*r}clone(){return new e(this.x,this.y,this.z)}},BVHIntersect=class{constructor(e,t,n,r,o){this.pointA=e,this.pointB=t,this.pointC=n,this.index=r,this.intersectionPoint=o}},BVHBox3=class{constructor(e,t){this.min=e,this.max=t}},EPSILON$1=1e-6,scratchVector3$9=new BVHVector3(0,0,0),scratchVector3A=new BVHVector3(0,0,0),scratchVector3B=new BVHVector3(0,0,0),scratchVector3C=new BVHVector3(0,0,0),BVHMesh=class extends BVHObject{createTree(e,t,n){t=Math.min(t,16);let r=this.getPositionCount()/3,o=r>65535?new Uint32Array(r):new Uint16Array(r),s=new Float32Array(r*6),c=[],l=0,u=-1;if(n)for(let e=0;e<r;e+=1){let t=e*3,n=e*6,r,c,l,u,d,f,p;o[e]=e,this.getPositionByIndex(t,scratchVector3A),this.getPositionByIndex(t+1,scratchVector3B),this.getPositionByIndex(t+2,scratchVector3C),r=u=scratchVector3A.x,p=scratchVector3B.x,p<r&&(r=p),p>u&&(u=p),p=scratchVector3C.x,p<r&&(r=p),p>u&&(u=p),c=d=scratchVector3A.y,p=scratchVector3B.y,p<c&&(c=p),p>d&&(d=p),p=scratchVector3C.y,p<c&&(c=p),p>d&&(d=p),l=f=scratchVector3A.z,p=scratchVector3B.z,p<l&&(l=p),p>f&&(f=p),p=scratchVector3C.z,p<l&&(l=p),p>f&&(f=p),s[n]=r,s[n+1]=c,s[n+2]=l,s[n+3]=u,s[n+4]=d,s[n+5]=f}else{let e=1/0,t=1/0,c=1/0,l=-1/0,u=-1/0,d=-1/0;for(let n=0;n<r;n+=1){let r=n*3,f=n*6,p,m,h,g,_,v,y;o[n]=n,this.getPositionByIndex(r,scratchVector3A),this.getPositionByIndex(r+1,scratchVector3B),this.getPositionByIndex(r+2,scratchVector3C),p=g=scratchVector3A.x,y=scratchVector3B.x,y<p&&(p=y),y>g&&(g=y),y=scratchVector3C.x,y<p&&(p=y),y>g&&(g=y),m=_=scratchVector3A.y,y=scratchVector3B.y,y<m&&(m=y),y>_&&(_=y),y=scratchVector3C.y,y<m&&(m=y),y>_&&(_=y),h=v=scratchVector3A.z,y=scratchVector3B.z,y<h&&(h=y),y>v&&(v=y),y=scratchVector3C.z,y<h&&(h=y),y>v&&(v=y),s[f]=p,s[f+1]=m,s[f+2]=h,s[f+3]=g,s[f+4]=_,s[f+5]=v,p<e&&(e=p),g>l&&(l=g),m<t&&(t=m),_>u&&(u=_),h<c&&(c=h),v>d&&(d=v)}n=[e,t,c,l,u,d]}let d=new BVHNode(++u,n,0,r,0);c[l++]=d;let f=[],p=[0,1,2],m=function(e,t){return f[t]-f[e]};function h(n){let r=n.startIndex,d=n.endIndex,h=n.extents;f[0]=h[3]-h[0],f[1]=h[4]-h[1],f[2]=h[5]-h[2],p.sort(m);for(let f=0;f<3;f++){let m=p[f],g=h[m]+h[m+3],_=r,v=d-1,y=-1,b;for(;_<=v;)y===-1?(b=o[_],s[b*6+m]+s[b*6+m+3]<g?_++:y=b):(b=o[v],s[b*6+m]+s[b*6+m+3]>=g?v--:(o[_]=b,o[v]=y,y=-1,_++,v--));if(_>r&&_<d){let f=new BVHNode(++u,calcExtents(o,s,r,_,EPSILON$1),r,_,n.deepth+1);f.deepth<t&&f.endIndex-f.startIndex>e&&(c[l++]=f);let p=new BVHNode(++u,calcExtents(o,s,_,d,EPSILON$1),_,d,n.deepth+1);p.deepth<t&&p.endIndex-p.startIndex>e&&(c[l++]=p),n.node0=f,n.node1=p,n.startIndex=0,n.endIndex=0;break}}}for(;l;)h(c[--l]);return this.offsetArray=o,this.rootNodePacked=packBVHNode(d,u+1),c.length=0,this}trianglesInSphere(e,t){let n=this.offsetArray,r=this.rootNodePacked,o=new Float32Array(r),s=new Uint32Array(r),c=new Uint16Array(r),l=[0],u=[],d;for(;(d=l.pop())!==void 0;){let r=d*36/4,f=clamp(e.x,o[r],o[r+3])-e.x,p=clamp(e.y,o[r+1],o[r+4])-e.y,m=clamp(e.z,o[r+2],o[r+5])-e.z;if(f*f+p*p+m*m<=t*t){let e=s[r+6],t=s[r+7];for(let r=e;r<t;r++){let e=n[r];u.push(e)}let o=d*36/2,f=c[o+16],p=c[o+17];f&&l.push(f),p&&l.push(p)}}let f=u.length,p=new Float32Array(f*9);for(let e=0;e<f;e++){let t=u[e]*3;this.getPositionByIndex(t,scratchVector3$9),p[e*9]=scratchVector3$9.x,p[e*9+1]=scratchVector3$9.y,p[e*9+2]=scratchVector3$9.z,this.getPositionByIndex(t+1,scratchVector3$9),p[e*9+3]=scratchVector3$9.x,p[e*9+4]=scratchVector3$9.y,p[e*9+5]=scratchVector3$9.z,this.getPositionByIndex(t+2,scratchVector3$9),p[e*9+6]=scratchVector3$9.x,p[e*9+7]=scratchVector3$9.y,p[e*9+8]=scratchVector3$9.z}return p}intersectRay(e,t,n=0,r=!1,o){let s=[],c=this.offsetArray,l=this.rootNodePacked,u=new Float32Array(l),d=new Uint32Array(l),f=new Uint16Array(l),p=new BVHVector3(1/t.x,1/t.y,1/t.z),m=[0],h,g=1/0,_=new BVHBox3(new BVHVector3(0,0,0),new BVHVector3(0,0,0)),v=new BVHVector3(0,0,0),y=new BVHVector3(0,0,0),b=new BVHVector3(0,0,0);for(;(h=m.pop())!==void 0;){let l=h*36/4;_.min.x=u[l],_.min.y=u[l+1],_.min.z=u[l+2],_.max.x=u[l+3],_.max.y=u[l+4],_.max.z=u[l+5];let S=intersectNodeBox(e,p,_,n);if(S===null||r&&S>g)continue;let C=e.x,w=e.y,T=e.z,E=t.x,D=t.y,O=t.z,k=d[l+6],A=d[l+7];for(let e=k;e<A;e++){let t=c[e],n=t*3;this.getPositionByIndex(n,v);let l=v.x,u=v.y,d=v.z;this.getPositionByIndex(n+1,y);let f=y.x,p=y.y,m=y.z;this.getPositionByIndex(n+2,b);let h=b.x,_=b.y,S=b.z,k=f-l,A=p-u,j=m-d,M=h-l,N=_-u,P=S-d,F=A*P-j*N,I=j*M-k*P,L=k*N-A*M,R=E*F+D*I+O*L,z;if(R>0)z=1;else if(R<0)z=-1,R=-R;else continue;let B=C-l,V=w-u,H=T-d,ee=z*(E*(V*P-H*N)+D*(H*M-B*P)+O*(B*N-V*M));if(ee<0)continue;let te=z*(E*(A*H-j*V)+D*(j*B-k*H)+O*(k*V-A*B));if(te<0||ee+te>R)continue;let U=-z*(B*F+V*I+H*L);if(U<0)continue;let W=U/R,G=new BVHIntersect(v,y,b,t,new BVHVector3(C+E*W,w+D*W,T+O*W));(!o||o(G))&&(r?W<g&&(g=W,s.length>0&&(s.length=0),s.push(G)):s.push(G))}let j=h*36/2,M=f[j+16],N=f[j+17];M&&m.push(M),N&&m.push(N)}return s}};function clamp(e,t,n){return e<t?t:e>n?n:e}function calcExtents(e,t,n,r,o){if(n>=r)return[0,0,0,0,0,0];let s=1/0,c=1/0,l=1/0,u=-1/0,d=-1/0,f=-1/0;for(let o=n;o<r;o++){let n=e[o]*6,r=t[n];r<s&&(s=r),r=t[n+1],r<c&&(c=r),r=t[n+2],r<l&&(l=r),r=t[n+3],r>u&&(u=r),r=t[n+4],r>d&&(d=r),r=t[n+5],r>f&&(f=r)}return[s-o,c-o,l-o,u+o,d+o,f+o]}(function(){let e=new BVHVector3(0,0,0),t=new BVHVector3(0,0,0),n=new BVHVector3(0,0,0),r=new BVHVector3(0,0,0);return function(o,s,c,l,u){t.subVectors(s,o),n.subVectors(c,o),r.crossVectors(t,n);let d=u.dot(r),f;if(d>0)f=1;else if(d<0)f=-1,d=-d;else return null;e.subVectors(l,o);let p=f*u.dot(n.crossVectors(e,n));if(p<0)return null;let m=f*u.dot(t.cross(e));if(m<0||p+m>d)return null;let h=-f*e.dot(r);if(h<0)return null;let g=h/d;return new BVHVector3(0,0,0).copy(u).multiplyScalar(g).add(l)}})();var EPSILON=1e-6,ORDER_AXISES=[`x`,`y`,`z`],scratchVector3$8=new BVHVector3(0,0,0),BVHPoints=class extends BVHObject{createTree(e,t,n){t=Math.min(t,16);let r=this.getPositionByIndex.bind(this),o=this.getPositionCount(),s=o>65535?new Uint32Array(o):new Uint16Array(o),c=[],l=0,u=-1;if(n)for(let e=0;e<o;e+=1)s[e]=e;else{r(0,scratchVector3$8);let e=scratchVector3$8.x,t=scratchVector3$8.y,c=scratchVector3$8.z,l=e,u=t,d=c;for(let n=0;n<o;n+=1){s[n]=n,r(n,scratchVector3$8);let o=scratchVector3$8.x,f=scratchVector3$8.y,p=scratchVector3$8.z;o<e?e=o:o>l&&(l=o),f<t?t=f:f>u&&(u=f),p<c?c=p:p>d&&(d=p)}n=[e,t,c,l,u,d]}let d=new BVHNode(++u,n,0,o,0);c[l++]=d;let f=[],p=[0,1,2],m=function(e,t){return f[t]-f[e]};function h(n){let o=n.startIndex,d=n.endIndex,h=n.extents;f[0]=h[3]-h[0],f[1]=h[4]-h[1],f[2]=h[5]-h[2];let g=p.sort(m)[0],_=ORDER_AXISES[g],v=(h[g]+h[g+3])/2,y=o,b=d-1,S=-1,C;for(;y<=b;)S===-1?(C=s[y],r(C,scratchVector3$8),scratchVector3$8[_]<v?y++:S=C):(C=s[b],r(C,scratchVector3$8),scratchVector3$8[_]>=v?b--:(s[y]=C,s[b]=S,S=-1,y++,b--));if(y>o){let r=h.slice();r[g+3]=v+EPSILON;let s=new BVHNode(++u,r,o,y,n.deepth+1);s.deepth<t&&s.endIndex-s.startIndex>e&&(c[l++]=s),n.node0=s}if(d>y){let r=h.slice();r[g]=v-EPSILON;let o=new BVHNode(++u,r,y,d,n.deepth+1);o.deepth<t&&o.endIndex-o.startIndex>e&&(c[l++]=o),n.node1=o}n.startIndex=0,n.endIndex=0}for(;l;)h(c[--l]);return this.offsetArray=s,this.rootNodePacked=packBVHNode(d,u+1),c.length=0,this}intersectRay(e,t,n=0,r=!1,o){let s=[],c=this.offsetArray,l=this.rootNodePacked,u=new Float32Array(l),d=new Uint32Array(l),f=new Uint16Array(l),p=n*n,m=new BVHVector3(1/t.x,1/t.y,1/t.z),h=[0],g,_=1/0,v=new BVHBox3(new BVHVector3(0,0,0),new BVHVector3(0,0,0)),y=new BVHVector3(0,0,0);for(;(g=h.pop())!==void 0;){let l=g*36/4;v.min.x=u[l],v.min.y=u[l+1],v.min.z=u[l+2],v.max.x=u[l+3],v.max.y=u[l+4],v.max.z=u[l+5];let b=intersectNodeBox(e,m,v,n);if(b===null||r&&b>_)continue;let S=d[l+6],C=d[l+7];for(let n=S;n<C;n++){let l=c[n];this.getPositionByIndex(l,y);let u=y.x,d=y.y,f=y.z,m=e.x,h=e.y,g=e.z,v=t.x,b=t.y,S=t.z,C=v*(u-m)+b*(d-h)+S*(f-g);if(C>0?(m+=v*C,h+=b*C,g+=S*C):C<0&&(C=0),v=u-m,b=d-h,S=f-g,v*v+b*b+S*S<=p){let e=new BVHIntersect(y,y,y,l,new BVHVector3(m,h,g));(!o||o(e))&&(r?C<_&&(_=C,s.length>0&&(s.length=0),s.push(e)):s.push(e))}}let w=g*36/2,T=f[w+16],E=f[w+17];T&&h.push(T),E&&h.push(E)}return s}},jsContent$2="(function(){var e=class{constructor(e,t){this.position=e,this.indices=t}getPositionCount(){let e=this.indices,t=this.position;return e?e.array.length/(e.stride??1):t.array.length/(t.stride??3)}getPositionByIndex(e,t){let n=this.indices,r=this.position,i=e;if(n){let t=n.array,r=n.stride??1,a=n.offset??0;i=t[e*r+a]}let a=r.array,o=r.stride??3,s=r.offset??0;return i=i*o+s,t.x=a[i],t.y=a[i+1],t.z=a[i+2],t}createTree(e,t,n){throw Error(`not implemented`)}trianglesInSphere(e,t){throw Error(`not implemented`)}intersectRay(e,t,n=0,r=!1,i){throw Error(`not implemented`)}},t=class{constructor(e,t,n,r,i){this.id=e,this.extents=t,this.startIndex=n,this.endIndex=r,this.deepth=i}};function n(e,t){let n=new ArrayBuffer(t*36),r=new Float32Array(n),i=new Uint32Array(n),a=new Uint16Array(n),o=[e],s,c;for(;s=o.pop();)c=s.id*36/4,r[c]=s.extents[0],r[c+1]=s.extents[1],r[c+2]=s.extents[2],r[c+3]=s.extents[3],r[c+4]=s.extents[4],r[c+5]=s.extents[5],i[c+6]=s.startIndex,i[c+7]=s.endIndex,c=s.id*36/2,s.node0&&(a[c+16]=s.node0.id,o.push(s.node0)),s.node1&&(a[c+17]=s.node1.id,o.push(s.node1));return n}function r(e,t,n,r=0){let i=n.min.x-r,a=n.min.y-r,o=n.min.z-r,s=n.max.x+r,c=n.max.y+r,l=n.max.z+r,u=0,d=0,f=0,p=0,m=0,h=0;return t.x>=0?(u=(i-e.x)*t.x,d=(s-e.x)*t.x):(u=(s-e.x)*t.x,d=(i-e.x)*t.x),t.y>=0?(f=(a-e.y)*t.y,p=(c-e.y)*t.y):(f=(c-e.y)*t.y,p=(a-e.y)*t.y),u>p||f>d||((f>u||u!==u)&&(u=f),(p<d||d!==d)&&(d=p),t.z>=0?(m=(o-e.z)*t.z,h=(l-e.z)*t.z):(m=(l-e.z)*t.z,h=(o-e.z)*t.z),u>h||m>d)||((m>u||u!==u)&&(u=m),(h<d||d!==d)&&(d=h),d<0)?null:u>=0?u:0}var i=class e{constructor(e,t,n){this.x=e,this.y=t,this.z=n}copy(e){return this.x=e.x,this.y=e.y,this.z=e.z,this}set(e,t,n){return this.x=e,this.y=t,this.z=n,this}fromArray(e,t=0){return this.x=e[t],this.y=e[t+1],this.z=e[t+2],this}toArray(e=[],t=0){return e[t]=this.x,e[t+1]=this.y,e[t+2]=this.z,e}add(e){return this.x+=e.x,this.y+=e.y,this.z+=e.z,this}multiplyScalar(e){return this.x*=e,this.y*=e,this.z*=e,this}subVectors(e,t){return this.x=e.x-t.x,this.y=e.y-t.y,this.z=e.z-t.z,this}addScaledVector(e,t){return this.x+=e.x*t,this.y+=e.y*t,this.z+=e.z*t,this}dot(e){return this.x*e.x+this.y*e.y+this.z*e.z}cross(e){let t=this.x,n=this.y,r=this.z;return this.x=n*e.z-r*e.y,this.y=r*e.x-t*e.z,this.z=t*e.y-n*e.x,this}crossVectors(e,t){let n=e.x,r=e.y,i=e.z,a=t.x,o=t.y,s=t.z;return this.x=r*s-i*o,this.y=i*a-n*s,this.z=n*o-r*a,this}distanceTo(e){return Math.sqrt(this.distanceToSquared(e))}distanceToSquared(e){let t=this.x-e.x,n=this.y-e.y,r=this.z-e.z;return t*t+n*n+r*r}clone(){return new e(this.x,this.y,this.z)}},a=class{constructor(e,t,n,r,i){this.pointA=e,this.pointB=t,this.pointC=n,this.index=r,this.intersectionPoint=i}},o=class{constructor(e,t){this.min=e,this.max=t}};let s=1e-6,c=new i(0,0,0),l=new i(0,0,0),u=new i(0,0,0),d=new i(0,0,0);var f=class extends e{createTree(e,r,i){r=Math.min(r,16);let a=this.getPositionCount()/3,o=a>65535?new Uint32Array(a):new Uint16Array(a),c=new Float32Array(a*6),f=[],p=0,h=-1;if(i)for(let e=0;e<a;e+=1){let t=e*3,n=e*6,r,i,a,s,f,p,m;o[e]=e,this.getPositionByIndex(t,l),this.getPositionByIndex(t+1,u),this.getPositionByIndex(t+2,d),r=s=l.x,m=u.x,m<r&&(r=m),m>s&&(s=m),m=d.x,m<r&&(r=m),m>s&&(s=m),i=f=l.y,m=u.y,m<i&&(i=m),m>f&&(f=m),m=d.y,m<i&&(i=m),m>f&&(f=m),a=p=l.z,m=u.z,m<a&&(a=m),m>p&&(p=m),m=d.z,m<a&&(a=m),m>p&&(p=m),c[n]=r,c[n+1]=i,c[n+2]=a,c[n+3]=s,c[n+4]=f,c[n+5]=p}else{let e=1/0,t=1/0,n=1/0,r=-1/0,s=-1/0,f=-1/0;for(let i=0;i<a;i+=1){let a=i*3,p=i*6,m,h,g,_,v,y,b;o[i]=i,this.getPositionByIndex(a,l),this.getPositionByIndex(a+1,u),this.getPositionByIndex(a+2,d),m=_=l.x,b=u.x,b<m&&(m=b),b>_&&(_=b),b=d.x,b<m&&(m=b),b>_&&(_=b),h=v=l.y,b=u.y,b<h&&(h=b),b>v&&(v=b),b=d.y,b<h&&(h=b),b>v&&(v=b),g=y=l.z,b=u.z,b<g&&(g=b),b>y&&(y=b),b=d.z,b<g&&(g=b),b>y&&(y=b),c[p]=m,c[p+1]=h,c[p+2]=g,c[p+3]=_,c[p+4]=v,c[p+5]=y,m<e&&(e=m),_>r&&(r=_),h<t&&(t=h),v>s&&(s=v),g<n&&(n=g),y>f&&(f=y)}i=[e,t,n,r,s,f]}let g=new t(++h,i,0,a,0);f[p++]=g;let _=[],v=[0,1,2],y=function(e,t){return _[t]-_[e]};function b(n){let i=n.startIndex,a=n.endIndex,l=n.extents;_[0]=l[3]-l[0],_[1]=l[4]-l[1],_[2]=l[5]-l[2],v.sort(y);for(let u=0;u<3;u++){let d=v[u],g=l[d]+l[d+3],_=i,y=a-1,b=-1,x;for(;_<=y;)b===-1?(x=o[_],c[x*6+d]+c[x*6+d+3]<g?_++:b=x):(x=o[y],c[x*6+d]+c[x*6+d+3]>=g?y--:(o[_]=x,o[y]=b,b=-1,_++,y--));if(_>i&&_<a){let l=new t(++h,m(o,c,i,_,s),i,_,n.deepth+1);l.deepth<r&&l.endIndex-l.startIndex>e&&(f[p++]=l);let u=new t(++h,m(o,c,_,a,s),_,a,n.deepth+1);u.deepth<r&&u.endIndex-u.startIndex>e&&(f[p++]=u),n.node0=l,n.node1=u,n.startIndex=0,n.endIndex=0;break}}}for(;p;)b(f[--p]);return this.offsetArray=o,this.rootNodePacked=n(g,h+1),f.length=0,this}trianglesInSphere(e,t){let n=this.offsetArray,r=this.rootNodePacked,i=new Float32Array(r),a=new Uint32Array(r),o=new Uint16Array(r),s=[0],l=[],u;for(;(u=s.pop())!==void 0;){let r=u*36/4,c=p(e.x,i[r],i[r+3])-e.x,d=p(e.y,i[r+1],i[r+4])-e.y,f=p(e.z,i[r+2],i[r+5])-e.z;if(c*c+d*d+f*f<=t*t){let e=a[r+6],t=a[r+7];for(let r=e;r<t;r++){let e=n[r];l.push(e)}let i=u*36/2,c=o[i+16],d=o[i+17];c&&s.push(c),d&&s.push(d)}}let d=l.length,f=new Float32Array(d*9);for(let e=0;e<d;e++){let t=l[e]*3;this.getPositionByIndex(t,c),f[e*9]=c.x,f[e*9+1]=c.y,f[e*9+2]=c.z,this.getPositionByIndex(t+1,c),f[e*9+3]=c.x,f[e*9+4]=c.y,f[e*9+5]=c.z,this.getPositionByIndex(t+2,c),f[e*9+6]=c.x,f[e*9+7]=c.y,f[e*9+8]=c.z}return f}intersectRay(e,t,n=0,s=!1,c){let l=[],u=this.offsetArray,d=this.rootNodePacked,f=new Float32Array(d),p=new Uint32Array(d),m=new Uint16Array(d),h=new i(1/t.x,1/t.y,1/t.z),g=[0],_,v=1/0,y=new o(new i(0,0,0),new i(0,0,0)),b=new i(0,0,0),x=new i(0,0,0),S=new i(0,0,0);for(;(_=g.pop())!==void 0;){let o=_*36/4;y.min.x=f[o],y.min.y=f[o+1],y.min.z=f[o+2],y.max.x=f[o+3],y.max.y=f[o+4],y.max.z=f[o+5];let d=r(e,h,y,n);if(d===null||s&&d>v)continue;let C=e.x,w=e.y,T=e.z,E=t.x,D=t.y,O=t.z,k=p[o+6],A=p[o+7];for(let e=k;e<A;e++){let t=u[e],n=t*3;this.getPositionByIndex(n,b);let r=b.x,o=b.y,d=b.z;this.getPositionByIndex(n+1,x);let f=x.x,p=x.y,m=x.z;this.getPositionByIndex(n+2,S);let h=S.x,g=S.y,_=S.z,y=f-r,k=p-o,A=m-d,j=h-r,M=g-o,N=_-d,P=k*N-A*M,F=A*j-y*N,I=y*M-k*j,L=E*P+D*F+O*I,R;if(L>0)R=1;else if(L<0)R=-1,L=-L;else continue;let z=C-r,B=w-o,V=T-d,H=R*(E*(B*N-V*M)+D*(V*j-z*N)+O*(z*M-B*j));if(H<0)continue;let U=R*(E*(k*V-A*B)+D*(A*z-y*V)+O*(y*B-k*z));if(U<0||H+U>L)continue;let W=-R*(z*P+B*F+V*I);if(W<0)continue;let G=W/L,K=new a(b,x,S,t,new i(C+E*G,w+D*G,T+O*G));(!c||c(K))&&(s?G<v&&(v=G,l.length>0&&(l.length=0),l.push(K)):l.push(K))}let j=_*36/2,M=m[j+16],N=m[j+17];M&&g.push(M),N&&g.push(N)}return l}};function p(e,t,n){return e<t?t:e>n?n:e}function m(e,t,n,r,i){if(n>=r)return[0,0,0,0,0,0];let a=1/0,o=1/0,s=1/0,c=-1/0,l=-1/0,u=-1/0;for(let i=n;i<r;i++){let n=e[i]*6,r=t[n];r<a&&(a=r),r=t[n+1],r<o&&(o=r),r=t[n+2],r<s&&(s=r),r=t[n+3],r>c&&(c=r),r=t[n+4],r>l&&(l=r),r=t[n+5],r>u&&(u=r)}return[a-i,o-i,s-i,c+i,l+i,u+i]}(function(){let e=new i(0,0,0),t=new i(0,0,0),n=new i(0,0,0),r=new i(0,0,0);return function(a,o,s,c,l){t.subVectors(o,a),n.subVectors(s,a),r.crossVectors(t,n);let u=l.dot(r),d;if(u>0)d=1;else if(u<0)d=-1,u=-u;else return null;e.subVectors(c,a);let f=d*l.dot(n.crossVectors(e,n));if(f<0)return null;let p=d*l.dot(t.cross(e));if(p<0||f+p>u)return null;let m=-d*e.dot(r);if(m<0)return null;let h=m/u;return new i(0,0,0).copy(l).multiplyScalar(h).add(c)}})();let h=1e-6,g=[`x`,`y`,`z`],_=new i(0,0,0);var v=class extends e{createTree(e,r,i){r=Math.min(r,16);let a=this.getPositionByIndex.bind(this),o=this.getPositionCount(),s=o>65535?new Uint32Array(o):new Uint16Array(o),c=[],l=0,u=-1;if(i)for(let e=0;e<o;e+=1)s[e]=e;else{a(0,_);let e=_.x,t=_.y,n=_.z,r=e,c=t,l=n;for(let i=0;i<o;i+=1){s[i]=i,a(i,_);let o=_.x,u=_.y,d=_.z;o<e?e=o:o>r&&(r=o),u<t?t=u:u>c&&(c=u),d<n?n=d:d>l&&(l=d)}i=[e,t,n,r,c,l]}let d=new t(++u,i,0,o,0);c[l++]=d;let f=[],p=[0,1,2],m=function(e,t){return f[t]-f[e]};function v(n){let i=n.startIndex,o=n.endIndex,d=n.extents;f[0]=d[3]-d[0],f[1]=d[4]-d[1],f[2]=d[5]-d[2];let v=p.sort(m)[0],y=g[v],b=(d[v]+d[v+3])/2,x=i,S=o-1,C=-1,w;for(;x<=S;)C===-1?(w=s[x],a(w,_),_[y]<b?x++:C=w):(w=s[S],a(w,_),_[y]>=b?S--:(s[x]=w,s[S]=C,C=-1,x++,S--));if(x>i){let a=d.slice();a[v+3]=b+h;let o=new t(++u,a,i,x,n.deepth+1);o.deepth<r&&o.endIndex-o.startIndex>e&&(c[l++]=o),n.node0=o}if(o>x){let i=d.slice();i[v]=b-h;let a=new t(++u,i,x,o,n.deepth+1);a.deepth<r&&a.endIndex-a.startIndex>e&&(c[l++]=a),n.node1=a}n.startIndex=0,n.endIndex=0}for(;l;)v(c[--l]);return this.offsetArray=s,this.rootNodePacked=n(d,u+1),c.length=0,this}intersectRay(e,t,n=0,s=!1,c){let l=[],u=this.offsetArray,d=this.rootNodePacked,f=new Float32Array(d),p=new Uint32Array(d),m=new Uint16Array(d),h=n*n,g=new i(1/t.x,1/t.y,1/t.z),_=[0],v,y=1/0,b=new o(new i(0,0,0),new i(0,0,0)),x=new i(0,0,0);for(;(v=_.pop())!==void 0;){let o=v*36/4;b.min.x=f[o],b.min.y=f[o+1],b.min.z=f[o+2],b.max.x=f[o+3],b.max.y=f[o+4],b.max.z=f[o+5];let d=r(e,g,b,n);if(d===null||s&&d>y)continue;let S=p[o+6],C=p[o+7];for(let n=S;n<C;n++){let r=u[n];this.getPositionByIndex(r,x);let o=x.x,d=x.y,f=x.z,p=e.x,m=e.y,g=e.z,_=t.x,v=t.y,b=t.z,S=_*(o-p)+v*(d-m)+b*(f-g);if(S>0?(p+=_*S,m+=v*S,g+=b*S):S<0&&(S=0),_=o-p,v=d-m,b=f-g,_*_+v*v+b*b<=h){let e=new a(x,x,x,r,new i(p,m,g));(!c||c(e))&&(s?S<y&&(y=S,l.length>0&&(l.length=0),l.push(e)):l.push(e))}}let w=v*36/2,T=m[w+16],E=m[w+17];T&&_.push(T),E&&_.push(E)}return l}};function y(e){onmessage=t=>{Promise.resolve(t.data).then(t=>e(t)).then(({output:e,transfer:t})=>postMessage(e,t)).catch(e=>postMessage({$$error:e}))}}y(e=>Promise.resolve(e).then(e=>{let t=[],n=new Set;for(let r of e){let e;if(r.type===`mesh`)e=new f(r.attributes.position,r.indices);else if(r.type===`points`)e=new v(r.attributes.position,r.indices);else throw Error(`Invalid Type`);e.createTree(r.maxItemPerNode,r.maxTreeDepth,r.extents);let i={type:r.type,attributes:r.attributes,indices:r.indices,offsetArray:e.offsetArray,rootNodePacked:e.rootNodePacked};t.push(i);let a;for(let e in i.attributes){let t=i.attributes[e];t&&t.buffer instanceof ArrayBuffer&&n.add(t.buffer)}a=i.indices,a&&a.buffer instanceof ArrayBuffer&&n.add(a.buffer),a=i.offsetArray,a&&a.buffer instanceof ArrayBuffer&&n.add(a.buffer),n.add(i.rootNodePacked)}return{output:t,transfer:Array.from(n)}}))})();",blob$2=typeof self<`u`&&self.Blob&&new Blob([`(self.URL || self.webkitURL).revokeObjectURL(self.location.href);`,jsContent$2],{type:`text/javascript;charset=utf-8`});function WorkerWrapper$2(e){let t;try{if(t=blob$2&&(self.URL||self.webkitURL).createObjectURL(blob$2),!t)throw``;let n=new Worker(t,{name:e==null?void 0:e.name});return n.addEventListener(`error`,()=>{(self.URL||self.webkitURL).revokeObjectURL(t)}),n}catch(t){return new Worker(`data:text/javascript;charset=utf-8,`+encodeURIComponent(jsContent$2),{name:e==null?void 0:e.name})}}var bvhWorkerPool=new WorkerPool(()=>new WorkerWrapper$2,4),defaultHitFilter=()=>!0,scratchRay=new three.Ray,scratchNormalMatrix=new three.Matrix3,scratchInverseMatrix=new three.Matrix4,scratchIntersectionFaceA=new three.Vector3,scratchIntersectionFaceB=new three.Vector3,scratchIntersectionFaceC=new three.Vector3,intersectsMap=new WeakMap;function raycastMesh(e,t,n,r){var o,s;let c=e.matrixWorld;scratchInverseMatrix.getInverse(c),scratchRay.copy(n.ray).applyMatrix4(scratchInverseMatrix);let l=(o=n.hitFilter)==null?defaultHitFilter:o,u=(s=n.firstHitOnly)==null?!1:s,d=e.geometry,f=e.material,p=d.groups,m=d.index,h=t.intersectRay(scratchRay.origin,scratchRay.direction,0,u,t=>{var r;let o=t.index,s=o*3,u;if(Array.isArray(f)){if(p){for(let e of p)if(s>=e.start&&s-e.start<e.count){u=f[(r=e.materialIndex)==null?0:r];break}}}else u=f;if(!u)return!1;let d=t.intersectionPoint,h=new three.Vector3(d.x,d.y,d.z).applyMatrix4(c),g=n.ray.origin.distanceTo(h);if(g<n.near||g>n.far)return!1;let _=t.pointA,v=t.pointB,y=t.pointC,b=three.Triangle.getNormal(scratchIntersectionFaceA.set(_.x,_.y,_.z).applyMatrix4(c),scratchIntersectionFaceB.set(v.x,v.y,v.z).applyMatrix4(c),scratchIntersectionFaceC.set(y.x,y.y,y.z).applyMatrix4(c),new three.Vector3),S=n.ray.direction.dot(b);if(u.side===three.FrontSide&&S>=0||u.side===three.BackSide&&S<=0)return!1;let C={distance:g,object:e,face:new three.Face3(m?m.array[s]:s,m?m.array[s+1]:s+1,m?m.array[s+2]:s+2,b),point:h,distanceToRay:0,faceIndex:o};return intersectsMap.set(t,C),l(C)}),g=h.length;for(let e=0;e<g;e++){let t=intersectsMap.get(h[e]);t&&r.push(t)}h.length=0}function raycastPoints(e,t,n,r){var o,s,c,l;let u=e.matrixWorld;scratchNormalMatrix.getNormalMatrix(u),scratchInverseMatrix.getInverse(u),scratchRay.copy(n.ray).applyMatrix4(scratchInverseMatrix);let d=((s=(o=n.params.Points)==null?void 0:o.threshold)==null?1:s)*scratchInverseMatrix.getMaxScaleOnAxis(),f=(c=n.hitFilter)==null?defaultHitFilter:c,p=(l=n.firstHitOnly)==null?!1:l,m=e.geometry,h=m.index,g=m.getAttribute(`normal`),_=g instanceof three.BufferAttribute,v=t.intersectRay(scratchRay.origin,scratchRay.direction,d,p,t=>{let r=t.intersectionPoint,o=new three.Vector3(r.x,r.y,r.z).applyMatrix4(u),s=n.ray.origin.distanceTo(o);if(s<n.near||s>n.far)return!1;let c=t.pointA,l=scratchIntersectionFaceA.set(c.x,c.y,c.z).applyMatrix4(u),d=o.distanceTo(l);if(d/s>.07)return!1;let p=t.index,v=h?h.array[p]:p,y;if(_){let e=new three.Vector3().fromBufferAttribute(g,v).applyNormalMatrix(scratchNormalMatrix);y=new three.Face3(v,v,v,e)}else{let e=m.getAttribute(`scale`),t=m.getAttribute(`rotation`);if(e instanceof three.BufferAttribute&&t instanceof three.BufferAttribute){let r=new three.Vector3().fromBufferAttribute(e,v).toArray(),o=new three.Vector4().fromBufferAttribute(t,v).toArray(),s=new three.Quaternion(o[1],o[2],o[3],o[0]),[{axis:c}]=[{axis:`x`,scale:r[0]},{axis:`y`,scale:r[1]},{axis:`z`,scale:r[2]}].sort((e,t)=>e.scale-t.scale),l=new three.Vector3(0,0,0);l[c]=1,l.applyQuaternion(s).applyNormalMatrix(scratchNormalMatrix),n.ray.direction.dot(l)>0&&l.negate(),y=new three.Face3(v,v,v,l)}}let b={distance:s,object:e,face:y,point:o,distanceToRay:d,index:p};return intersectsMap.set(t,b),f(b)}),y=v.length;for(let e=0;e<y;e++){let t=intersectsMap.get(v[e]);t&&r.push(t)}v.length=0}var BVH_MESH_PROP=`__bvh_mesh__`,originMeshRaycast=three.Mesh.prototype.raycast;function overrideMeshRaycast(e,t){let n=getBvhTreeForMesh(this);n?raycastMesh(this,n,e,t):originMeshRaycast.call(this,e,t)}function getBvhTreeForMesh(e){let t=e[BVH_MESH_PROP];return t instanceof BVHMesh,t}function bindBvhTreeForMesh(e,t){Object.assign(e,{[BVH_MESH_PROP]:t,raycast:overrideMeshRaycast})}var BVH_POINTS_PROP=`__bvh_points__`,originPointsRaycast=three.Points.prototype.raycast;function overridePointsRaycast(e,t){let n=getBvhTreeForPoints(this);n?raycastPoints(this,n,e,t):originPointsRaycast.call(this,e,t)}function getBvhTreeForPoints(e){let t=e[BVH_POINTS_PROP];return t instanceof BVHPoints,t}function bindBvhTreeForPoints(e,t){Object.assign(e,{[BVH_POINTS_PROP]:t,raycast:overridePointsRaycast})}function generateBvhTree(e,t=!0,n=100,r=10){let o=[];return e.traverse(e=>{(e instanceof three.Mesh||e instanceof three.Points)&&e.geometry instanceof three.BufferGeometry&&o.push(e)}),t?Promise.resolve().then(()=>{let e=[],t=new Set,s=null;for(let c=0;c<o.length;c++){let l=o[c],u=l.geometry;if(!(u instanceof three.BufferGeometry))continue;let d;if(l instanceof three.Mesh?d=`mesh`:l instanceof three.Points&&(d=`points`),!d)continue;let f=u.boundingBox,p=f?[f.min.x,f.min.y,f.min.z,f.max.x,f.max.y,f.max.z]:void 0,m={};for(let e in u.attributes){let n=u.attributes[e];n instanceof three.InterleavedBufferAttribute?(m[e]={array:n.data.array,stride:n.data.stride,offset:n.offset},s=n.data.array,s&&s.buffer instanceof ArrayBuffer&&t.add(s.buffer)):(m[e]={array:n.array},s=n.array,s&&s.buffer instanceof ArrayBuffer&&t.add(s.buffer))}let h,g=u.getIndex();g&&(g instanceof three.InterleavedBufferAttribute?(h={array:g.data.array,stride:g.data.stride,offset:g.offset},s=g.data.array,s&&s.buffer instanceof ArrayBuffer&&t.add(s.buffer)):(h={array:g.array},s=g.array,s&&s.buffer instanceof ArrayBuffer&&t.add(s.buffer)));let _={type:d,attributes:m,indices:h,maxItemPerNode:n,maxTreeDepth:r,extents:p};e.push(_)}return bvhWorkerPool.postMessage(e,Array.from(t))}).then(t=>{for(let e=0;e<o.length;e++){let n=o[e],r=n.geometry,s=t[e];if(!(r instanceof three.BufferGeometry))continue;for(let e in s.attributes){let t=s.attributes[e].array,n=r.attributes[e];n instanceof three.InterleavedBufferAttribute?n.data.array=t:n.array=t}let c=r.getIndex();if(c&&s.indices){let e=s.indices.array;c instanceof three.InterleavedBufferAttribute?c.data.array=e:c.array=e}if(n instanceof three.Mesh){let e=new BVHMesh(s.attributes.position,s.indices);e.offsetArray=s.offsetArray,e.rootNodePacked=s.rootNodePacked,bindBvhTreeForMesh(n,e)}else if(n instanceof three.Points){let e=new BVHPoints(s.attributes.position,s.indices);e.offsetArray=s.offsetArray,e.rootNodePacked=s.rootNodePacked,bindBvhTreeForPoints(n,e)}}return e}):Promise.resolve().then(()=>{for(let e of o)if(e instanceof three.Mesh){let t=e.geometry,o=t.boundingBox,s=o?[o.min.x,o.min.y,o.min.z,o.max.x,o.max.y,o.max.z]:void 0;if(t instanceof three.BufferGeometry){let o,c,l=t.attributes.position;o=l instanceof three.InterleavedBufferAttribute?{array:l.data.array,stride:l.data.stride,offset:l.offset}:{array:l.array};let u=t.getIndex();u&&(c=u instanceof three.InterleavedBufferAttribute?{array:u.data.array,stride:u.data.stride,offset:u.offset}:{array:u.array});let d=new BVHMesh(o,c);d.createTree(n,r,s),bindBvhTreeForMesh(e,d)}}else if(e instanceof three.Points){let t=e.geometry,o=t.boundingBox,s=o?[o.min.x,o.min.y,o.min.z,o.max.x,o.max.y,o.max.z]:void 0;if(t instanceof three.BufferGeometry){let o,c,l=t.attributes.position;o=l instanceof three.InterleavedBufferAttribute?{array:l.data.array,stride:l.data.stride,offset:l.offset}:{array:l.array};let u=t.getIndex();u&&(c=u instanceof three.InterleavedBufferAttribute?{array:u.data.array,stride:u.data.stride,offset:u.offset}:{array:u.array});let d=new BVHPoints(o,c);d.createTree(n,r,s),bindBvhTreeForPoints(e,d)}}return e})}function mixNumber(e,t,n){return e+(t-e)*n}function value(e,t,n,r){let o=(t*n+2*e)/Math.pow(n,3),s=-(2*t*n+3*e)/Math.pow(n,2),c=t,l=e;return o*Math.pow(r,3)+s*Math.pow(r,2)+c*r+l}function velocity(e,t,n,r){let o=(t*n+2*e)/Math.pow(n,3),s=-(2*t*n+3*e)/Math.pow(n,2),c=t;return 3*o*Math.pow(r,2)+2*s*r+c}function mixCircle(e,t,n,r){let o=r[1]-r[0];return e=circleValue(e,r),t=circleValue(t,r),t-e>o/2?mixNumber(e+o,t,n):e-t>o/2?mixNumber(e-o,t,n):mixNumber(e,t,n)}function circleValue(e,t){let n=t[1]-t[0];return e<t[0]?circleValue(e+n,t):e>=t[1]?circleValue(e-n,t):e}function mixValue(e,t,n,r){return r?mixCircle(e,t,n,r):mixNumber(e,t,n)}function toNumber(e){let t=Number(e);return isNaN(t)||!isFinite(t)?0:t}var Motion=class{constructor(e){this.config={},this.progress=1,this.ended=!0,this.value={},this.startTime=now(),this.startVelocity=0,this.duration=0,this.keyframes=[];for(let t in e){let n=e[t];typeof n==`object`?(this.value[t]=toNumber(n.value),this.config[t]={circle:n.circle}):(this.value[t]=toNumber(n),this.config[t]={circle:!1})}this.keyframes=[{progress:0,value:Object.assign({},this.value)},{progress:1,value:Object.assign({},this.value)}]}getProgress(e){let t=e-this.startTime;return t<0?0:t>=this.duration?1:1-value(1,this.startVelocity,this.duration,t)}getValue(e){for(let t=1;t<this.keyframes.length;t++)if(this.keyframes[t].progress>e){let n=this.keyframes[t-1],r=this.keyframes[t],o={};for(let t in this.config){let s=(e-n.progress)/(r.progress-n.progress);o[t]=mixValue(n.value[t],r.value[t],s,this.config[t].circle)}return o}return Object.assign({},this.keyframes[this.keyframes.length-1].value)}getProgressVelocity(e){let t=e-this.startTime;return t>=this.duration?0:velocity(1,this.startVelocity,this.duration,t)}update(e){return this.ended?!0:(this.progress=Math.min(1,Math.max(0,this.progress,this.getProgress(e))),this.value=this.getValue(this.progress),this.ended=this.progress>=1,this.ended&&this.callbacks&&(this.callbacks[0](),this.callbacks=void 0),this.ended)}getKeyFrameSegment(e){let t=this.getProgress(e);for(let e=1;e<this.keyframes.length;e++)if(this.keyframes[e].progress>t)return[this.keyframes[e-1],this.keyframes[e]];return[this.keyframes[this.keyframes.length-2],this.keyframes[this.keyframes.length-1]]}getTargetKeyframe(){return this.keyframes[this.keyframes.length-1]}set(e,t,n=0,r){var o;isNaN(t)&&(t=0),isNaN(n)&&(n=0),r=r==null?now():r;let s=this.getProgress(r),c=this.getValue(s),l={};for(let t in this.config)l[t]=(o=e[t])==null?c[t]:o;let u=[{progress:0,value:c},{progress:1,value:l}];return this.setKeyframes(u,t,n,r)}setKeyframes(e,t,n=0,r){if(e.length<2)throw Error(`keyframes invalid.`);return isNaN(t)&&(t=0),isNaN(n)&&(n=0),this.callbacks&&(this.callbacks[1](Error(`motion aborted.`)),this.callbacks=void 0),new Promise((o,s)=>{r=r==null?now():r,this.progress=0,this.ended=!1,this.startTime=r,this.startVelocity=n,this.keyframes=e,this.duration=t,t===0?(this.progress=1,this.value=Object.assign({},e[e.length-1].value)):this.value=Object.assign({},e[0].value),this.callbacks=[o,s]})}dispose(){this.callbacks&&(this.callbacks[1](Error(`motion dispose.`)),this.callbacks=void 0)}},PI$1=Math.PI,c1=1.70158,c2=c1*1.525,c3=c1+1,c4=2*PI$1/3,c5=2*PI$1/4.5,linear=function(e){return e},easeInCubic=function(e){return e*e*e},easeInQuart=function(e){return e*e*e*e},APPEAR_ANIMATION_DURATION=500,parameterValueVersionMap$1=new WeakMap,scratchIntersectPoint=new three.Vector3,scratchClippingBoxMatrixInverse=new three.Matrix4,TileNode=class e extends three.Object3D{constructor(e,t,n,r=noop){super(),this.name=e,this.materials=[],this.pbmObjects=[],this.contentObject=t,this.animations=n,this.appearMotion=new Motion({appear:0}),this.disposers=[r],this.add(t),t.traverse(e=>{if(e instanceof three.Mesh||e instanceof three.Points){let t=e.material;if(Array.isArray(t))for(let e=0;e<t.length;e++)this.materials.push(t[e]);else this.materials.push(t)}(e instanceof PBMMesh||e instanceof PBMSkinnedMesh||e instanceof PBMPointCloud||e instanceof PBMGaussianSplattingObject)&&this.pbmObjects.push(e)})}generateBvhTree(){return generateBvhTree(this,!0,200,20)}intersectRaycaster(e,t){let n=t==null?[]:t,r=e.hitFilter;e.hitFilter=t=>{if(t.object instanceof PBMPointCloud&&t.object.material.pointBack===`HIDDEN`&&t.face&&t.face.normal.angleTo(e.ray.direction)<Math.PI/2)return!1;let n=0,o=-1;if((t.object instanceof PBMMesh||t.object instanceof PBMSkinnedMesh||t.object instanceof PBMPointCloud)&&t.face){let e=Array.isArray(t.object.material)?t.object.material[t.face.materialIndex]:t.object.material;if(e){n=e.floorIndex,o=e.shownFloorIndex;for(let r of e.clippers)if(!(typeof r.floorIndex==`number`&&r.floorIndex!==n)&&(scratchClippingBoxMatrixInverse.getInverse(r.clippingBoxMatrix),scratchIntersectPoint.copy(t.point).applyMatrix4(scratchClippingBoxMatrixInverse),Math.abs(scratchIntersectPoint.x)<.5&&Math.abs(scratchIntersectPoint.y)<.5&&Math.abs(scratchIntersectPoint.z)<.5))return!1}}let s=o;return e.floorIndex===void 0?e.floor!==void 0&&(s=e.floor===null?-1:e.floor):s=e.floorIndex,s>=0&&n!==s?!1:(Object.assign(t,{floorIndex:n,floor:n}),r?r.call(e,t):!0)};let o=this.children.slice(),s;for(;s=o.pop();)if(s.visible){s.raycast(e,n);for(let e=0,t=s.children.length;e<t;e++)o.push(s.children[e])}return e.hitFilter=r,sortIntersects(n,e.sortByDistance,e.firstHitOnly),n}update(e,t,n,r,o,s){let c=!1;if(r.visible&&o.state.selectedFrameNumber===o.tileset.frameNumber){let e=1;this.appearMotion.getTargetKeyframe().value.appear!==1&&this.appearMotion.set({appear:1},APPEAR_ANIMATION_DURATION).catch(noop)}else{let e=0;this.appearMotion.getTargetKeyframe().value.appear!==0&&this.appearMotion.set({appear:0},0).catch(noop)}this.appearMotion.ended!==!0&&this.appearMotion.update(t.time);for(let l of this.pbmObjects)l instanceof PBMMesh||l instanceof PBMSkinnedMesh?updatePBMMesh(l,this.appearMotion,e,t,n,o,s)===!0&&(c=!0):l instanceof PBMPointCloud?updatePBMPointCloud(l,this.appearMotion,e,t,n,o,s)===!0&&(c=!0):l instanceof PBMGaussianSplattingObject&&updatePBMGSObject(l,this.appearMotion,e,t,n,r,o,s)===!0&&(c=!0);return c}dispose(){for(let e of this.disposers)e();this.disposers.length=0,this.pbmObjects.length=0}clone(){return new e(this.name,this.contentObject.clone(),this.animations)}};function updatePBMMesh(e,t,n,r,o,s,c){var l,u;let d=!1;if(parameterValueVersionMap$1.get(e)!==c.versionNumber){parameterValueVersionMap$1.set(e,c.versionNumber),d=!0,e.castShadow=c.castShadow,e.receiveShadow=c.receiveShadow;let t=e.material;for(let e of t)e.customShaders=c.customShaders,e.pano0=c.pano0,e.pano1=c.pano1,e.pano0Depth=c.pano0Depth,e.pano1Depth=c.pano1Depth,e.panoFilter=(u=(l=c.panoFilter)==null?void 0:l.toValue())==null?null:u,e.refinedScreen=c.refinedScreen,e.modelAlpha=c.modelAlpha,e.progress=c.progress,e.transition=c.transition,e.opacity=c.opacity,e.floorStyle=c.floorStyle,e.constantColor=c.constantColor,e.shownFloorIndex=c.shownFloorIndex,e.clippers=c.clippers,e.brightness=c.brightness,e.useHQWeight=c.useHQWeight,e.useHQDepth=c.useHQDepth,e.colorSaturation=c.colorSaturation,e.colorBrightness=c.colorBrightness,e.gradientTexture=c.gradientTexture,e.vertexMarks=c.vertexMarks,e.modelBoundingMax.copy(c.boundingBox.max),e.modelBoundingMin.copy(c.boundingBox.min),e.shaderType===`none`?(e.transparent=!0,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.depthWrite=!1,e.depthTest=!0):(e.transparent=e.alphaMode===`BLEND`,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.depthWrite=!0,e.depthTest=!0,c.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending),e.shownFloorIndex>-1&&e.shownFloorIndex!==e.floorIndex&&(e.transparent=!0),e.opacity<1&&(e.transparent=!0),e.alphaMap&&(e.transparent=!0),e.brightness<1&&(e.transparent=!0),e.modelAlpha<=0&&(e.transparent=!1),e.depthWrite=!e.transparent,c.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending))}return d}function updatePBMPointCloud(e,t,n,r,o,s,c){var l,u;let d=!1;if(c.pointAppearAnimation===!0&&s.refine===`ADD`&&s.tileset.rootMeta.pntsOrder===`RANDOM`){let n=e.geometry,r=s.tileset.currentMaxScreenSpaceError,o=s.state.screenSpaceError,c=(u=(l=s.parent)==null?void 0:l.state.screenSpaceError)==null?o:u,f=1;c!==o&&(f=(c-r)/(c-o)),f=clamp$1(f,0,1),f=easeInCubic(f);let p=n.index?n.index.count:n.attributes.position?n.attributes.position.count:1/0,m=Math.floor(p*f*t.value.appear);n.drawRange.count!==m&&(n.setDrawRange(0,m),d=!0)}if(parameterValueVersionMap$1.get(e)!==c.versionNumber){parameterValueVersionMap$1.set(e,c.versionNumber),d=!0,e.castShadow=c.castShadow,e.receiveShadow=c.receiveShadow;let t=[e.material];for(let e of t)e.customShaders=c.customShaders,e.pointScale=c.pointScale,e.pointMinPixel=c.pointMinPixel,e.pointMaxPixel=c.pointMaxPixel,e.pointSize=c.pointSize,e.pointShape=c.pointShape,e.pointBack=c.pointBack,e.modelAlpha=c.modelAlpha,e.opacity=c.opacity,e.floorStyle=c.floorStyle,e.constantColor=c.constantColor,e.shownFloorIndex=c.shownFloorIndex,e.clippers=c.clippers,e.brightness=c.brightness,e.useHQWeight=c.useHQWeight,e.useHQDepth=c.useHQDepth,e.colorSaturation=c.colorSaturation,e.colorBrightness=c.colorBrightness,e.outlineGain=c.outlineGain,e.distanceGain=c.distanceGain,e.gradientTexture=c.gradientTexture,e.transparent=!1,e.blending=three.NormalBlending,e.blendDst=three.OneMinusSrcAlphaFactor,e.blendEquation=three.AddEquation,e.blendSrcAlpha=null,e.blendDstAlpha=null,e.blendEquationAlpha=null,e.colorWrite=!0,e.depthWrite=!0,e.depthTest=!0,e.modelBoundingMax.copy(c.boundingBox.max),e.modelBoundingMin.copy(c.boundingBox.min),e.shownFloorIndex>-1&&(e.transparent=e.shownFloorIndex!==e.floorIndex),e.modelAlpha<1&&(e.transparent=!0),e.opacity<1&&(e.transparent=!0),e.brightness<1&&(e.transparent=!0),c.useAddBlend&&(e.depthWrite=!1,e.depthTest=!1,e.blending=three.AdditiveBlending),e.useHQWeight&&(e.depthWrite=!1,e.blending=three.CustomBlending,e.blendSrc=three.SrcAlphaFactor,e.blendSrcAlpha=three.SrcAlphaFactor,e.blendDst=three.OneFactor,e.blendDstAlpha=three.OneFactor),e.useHQDepth&&(e.colorWrite=!1)}return d}function updatePBMGSObject(e,t,n,r,o,s,c,l){let u=!1,d=s.uuid;return e.gsViewLayerKey!==d&&(e.gsViewLayerKey=d,u=!0),e.gsClippers!==l.clippers&&(e.gsClippers=l.clippers,u=!0),e.updateMatrix(),e.updateMatrixWorld(),e.usedSHDegree=l.gaussianSplattingSHDegree,e.lastMatrixWorld?e.transformChanged=!e.lastMatrixWorld.equals(e.matrixWorld):(e.lastMatrixWorld=new three.Matrix4,e.transformChanged=!0,u=!0),e.lastMatrixWorld.copy(e.matrixWorld),e.transformChanged&&(u=!0),u}var Trajectory=class{constructor(e,t,n){this.id=e,this.name=t.name,this.visible=!1,this.tileset=n,this.transform=new three.Matrix4,t.transform&&this.transform.fromArray(t.transform),this.transform.premultiply(this.tileset.root.transform),this.content={uri:t.file,byteLength:0,memoryUsage:0,loadState:`UNLOADED`,loadProgress:0,loadStateUpdateTime:now(),loadfailRetryDelay:0,data:void 0}}},TrajectoryNode=class e extends three.Object3D{constructor(e,t,n=noop){super(),this.name=e,this.contentObject=t,this.name=e,this.add(t),this.disposers=[n]}update(e,t,n,r,o,s){let c=this.contentObject.material[2];return c.uniforms.dashOffset.value=(c.uniforms.dashOffset.value-.003)%(c.uniforms.dashSize.value.x+c.uniforms.dashSize.value.y),!0}dispose(){for(let e of this.disposers)e();this.disposers.length=0}clone(){return new e(this.name,this.contentObject.clone())}},priorityCache=new Map;function getPriority(e,t,n){if(n&&n.has(t))return n.get(t);let r=t.refine===`ADD`||e.skipLevelOfDetail,o=t.parent,s=o&&(!r||t.state.screenSpaceError===0)?o.state.screenSpaceError:t.state.screenSpaceError,c=t.tileset.root?t.tileset.root.state.screenSpaceError:0,l=Math.max(c-s,0);return n&&n.set(t,l),l}var TileRequestScheduler=class{constructor(e,t){this.tileset=e,this.options=t,this.activeRequests=0,this.requestQueue=[]}reset(){for(let e of this.requestQueue)this.options.onTileSkip&&(e.tile.content&&this.tileset.options.tileUnloader(e.tile),this.options.onTileSkip(e.tile));this.requestQueue.length=0}update(e,t,n){let r=n.time,o=this.requestQueue,s=new Set(e);for(let e=0;e<o.length;e++){let t=o[e];if(s.has(t.tile)){s.delete(t.tile);continue}t.status===`WAITING`&&(o.splice(e,1),e--,this.options.onTileSkip&&this.options.onTileSkip(t.tile))}s.size>0&&(s.forEach(e=>{o.push({tile:e,status:`WAITING`,time:r,error:null})}),s.clear());let c=n.maxRequests;for(let e=0;e<o.length&&c>0;e++){let t=o[e];if(t.status===`DONE`)t.error===null?(c--,t.tile.content&&(t.tile.content.loadState=`READY`),this.options.onTileLoad&&this.options.onTileLoad(t.tile)):this.options.onTileError&&this.options.onTileError(t.tile,t.error),o.splice(e,1),e--;else if(t.status===`PENDING`&&r-t.time<1e3)break}switch(priorityCache.clear(),t){case`SCREEN_SPACE_ERROR`:o.sort((e,t)=>e.tile.state.requestedFrameNumber===t.tile.state.requestedFrameNumber?e.tile.state.requestedFrameNumber===n.frameNumber?getPriority(n,e.tile,priorityCache)-getPriority(n,t.tile,priorityCache):e.tile.level===t.tile.level?e.tile.state.distanceToCamera-t.tile.state.distanceToCamera:e.tile.level-t.tile.level:t.tile.state.requestedFrameNumber-e.tile.state.requestedFrameNumber);break;case`SCREEN_VERTICAL`:o.sort((e,t)=>e.tile.state.requestedFrameNumber===t.tile.state.requestedFrameNumber?e.tile.state.requestedFrameNumber===n.frameNumber?e.tile.state.centerScreenY===t.tile.state.centerScreenY?e.tile.state.centerZDepth===t.tile.state.centerZDepth?e.tile.level===t.tile.level?e.tile.state.distanceToCamera-t.tile.state.distanceToCamera:e.tile.level-t.tile.level:e.tile.state.centerZDepth-t.tile.state.centerZDepth:e.tile.state.centerScreenY-t.tile.state.centerScreenY:e.tile.level===t.tile.level?e.tile.state.distanceToCamera-t.tile.state.distanceToCamera:e.tile.level-t.tile.level:t.tile.state.requestedFrameNumber-e.tile.state.requestedFrameNumber);break;case`SCREEN_LEVEL_VERTICAL`:o.sort((e,t)=>e.tile.state.requestedFrameNumber===t.tile.state.requestedFrameNumber?e.tile.state.requestedFrameNumber===n.frameNumber?e.tile.level===t.tile.level?e.tile.state.centerScreenY===t.tile.state.centerScreenY?e.tile.state.centerZDepth===t.tile.state.centerZDepth?e.tile.state.distanceToCamera-t.tile.state.distanceToCamera:e.tile.state.centerZDepth-t.tile.state.centerZDepth:e.tile.state.centerScreenY-t.tile.state.centerScreenY:e.tile.level-t.tile.level:e.tile.level===t.tile.level?e.tile.state.distanceToCamera-t.tile.state.distanceToCamera:e.tile.level-t.tile.level:t.tile.state.requestedFrameNumber-e.tile.state.requestedFrameNumber);break;default:break}if(c=Math.max(n.maxRequests-this.activeRequests,0),!n.skipLevelOfDetail){let e=0,t=o.length;for(let r=0;r<t;r++){let t=o[r].tile;if(t.hasTilesetContent||t.contentParent===null||t.contentParent.state.selectedFrameNumber===n.frameNumber){let t=o.splice(r,1);o.splice(e++,0,...t)}}}for(let e=0;e<o.length&&c>0;e++){let t=o[e];t.status===`WAITING`&&(c--,t.status=`PENDING`,t.time=r,this.activeRequests++,this.tileset.options.tileLoader(t.tile).catch(e=>{t.error=e}).then(()=>{t.status=`DONE`,t.tile.content&&t.tile.content.loadState===`READY`&&(t.tile.content.loadState=`LOADING`),this.activeRequests--}))}}},CacheNode=class{constructor(e,t,n){this.item=e,this.previous=t,this.next=n}},CacheNodeList=class{constructor(){this.head=null,this.tail=null,this._length=0}get length(){return this._length}add(e){let t=new CacheNode(e,this.tail,null);return this.tail?(this.tail.next=t,this.tail=t):(this.head=t,this.tail=t),this._length++,t}remove(e){e.previous&&e.next?(e.previous.next=e.next,e.next.previous=e.previous):e.previous?(e.previous.next=null,this.tail=e.previous):e.next?(e.next.previous=null,this.head=e.next):(this.head=null,this.tail=null),e.next=null,e.previous=null,this._length--}splice(e,t){e!==t&&(this.remove(t),this.insert(e,t))}insert(e,t){let n=e.next;e.next=t,this.tail===e?this.tail=t:n.previous=t,t.next=n,t.previous=e,this._length++}toArray(){let e=[],t=this.head;for(;t;)e.push(t),t=t.next;return e}},TileCache=class{constructor(e={}){this.options=e,this.cacheNodeMap=new WeakMap,this.list=new CacheNodeList,this.sentinel=this.list.add(`sentinel`)}reset(){this.list.tail&&this.list.splice(this.list.tail,this.sentinel)}touchTile(e){let t=this.cacheNodeMap.get(e);t&&this.list.splice(this.sentinel,t)}loadTile(e){if(!this.cacheNodeMap.has(e)){let t=this.list.add(e);this.cacheNodeMap.set(e,t),this.options.onTileLoad&&this.options.onTileLoad(e)}}unloadTile(e){let t=this.cacheNodeMap.get(e);t&&(this.list.remove(t),this.cacheNodeMap.delete(e),this.options.onTileUnload&&this.options.onTileUnload(e))}unloadTiles(e){let t=this.list.head;for(;t!==this.sentinel&&e();){let e=t.item;t=t.next,this.unloadTile(e)}}toArray(){let e=[];for(let t of this.list.toArray())t.item!==`sentinel`&&e.push(t.item);return e}},ManagedArray=class{constructor(){this.map=new Map,this.array=[],this._length=0}get length(){return this._length}get(e){return this.array[e]}set(e,t){e>=this.length&&(this._length=e+1),this.map.has(this.array[e])&&this.map.delete(this.array[e]),this.array[e]=t,this.map.set(t,e)}delete(e){let t=this.map.get(e);t!==void 0&&t>=0&&(this.array.splice(t,1),this.map.delete(e),this._length--)}push(e){if(!this.map.has(e)){let t=this._length++;this.array[t]=e,this.map.set(e,t)}}pop(){let e=this.array[--this._length];return this.map.delete(e),this.array[this._length]=void 0,e}reset(){this.array=[],this.map=new Map,this._length=0}find(e){return this.map.has(e)}peek(){return this.array[this._length-1]}},TilesetBaseTraverser=class{constructor(e){this.tileset=e,this._canSelectTile=!0,this._loadAllTilesTraversalStack=new ManagedArray}traverse(e,t,n=[]){this.reset()}reset(){this._loadAllTilesTraversalStack.reset(),this.tileset.hasMixedContent=!1,this.tileset.needsRefinedTiles.clear(),this.tileset.requestedTiles.length=0,this.tileset.selectedTiles.length=0}updateTile(e,t){this.updateTileVisibility(e,t),e.state.shouldSelect=!1,e.state.finalResolution=!0}selectTile(e,t){this._canSelectTile&&e.contentAvailable&&e.state.selectedFrameNumber<t.frameNumber&&(e.state.selectedFrameNumber=t.frameNumber,this.tileset.selectedTiles.push(e),this.tileset.needsRefinedTiles.add(e))}loadTile(e,t){this._canSelectTile&&(e.state.requestedFrameNumber<t.frameNumber&&(e.state.requestedFrameNumber=t.frameNumber,e.content&&(e.content.loadState===`FAILED`&&t.time-e.content.loadStateUpdateTime>e.content.loadfailRetryDelay&&(e.content.loadState=`UNLOADED`,e.content.loadProgress=0,e.content.loadStateUpdateTime=t.time),e.content.loadState===`UNLOADED`&&this.tileset.requestedTiles.push(e))),this.tileset.needsRefinedTiles.add(e))}touchTile(e,t){this._canSelectTile&&(this.tileset.cache.touchTile(e),e.state.touchedFrameNumber=t.frameNumber)}canTraverse(e,t){return!e.state.inRequestVolume||e.hasRenderContent&&(e.levelOfContent>=t.maxLevelOfDetail||e.levelOfContent>=0&&e.geometricError<=t.minGeometricError)||e.children.length===0?!1:e.levelOfContent<t.minLevelOfDetail||e.geometricError>=t.maxGeometricError||e.hasTilesetContent?!0:e.state.screenSpaceError>this.tileset.currentMaxScreenSpaceError}updateTileVisibility(e,t){if(e.updateState(t),!e.state.visible||!e.state.inRequestVolume)return;let n=e.children.length>0;if(e.hasTilesetContent&&n){let n=e.children[0];this.updateTileVisibility(n,t),e.state.visible=n.state.visible;return}if(this.meetsScreenSpaceErrorEarly(e,t)){e.state.visible=!1;return}if(e.refine===`REPLACE`&&n&&!this.anyChildrenVisible(e,t)){e.state.visible=!1;return}}anyChildrenVisible(e,t){let n=!1,r=e.children;for(let e of r)e.updateState(t),n=n||e.state.visible;return n}meetsScreenSpaceErrorEarly(e,t){let{parent:n}=e;return!n||n.refine!==`ADD`||n.levelOfContent<t.minLevelOfDetail||n.geometricError>t.maxGeometricError?!1:n.levelOfContent>t.maxLevelOfDetail||n.levelOfContent>=0&&n.geometricError<t.minGeometricError?!0:e.getScreenSpaceError(t,e.state.distanceToCamera,!0)<this.tileset.currentMaxScreenSpaceError}sortTilesByDistanceToCamera(e){e.sort((e,t)=>t.state.distanceToCamera===0&&e.state.distanceToCamera===0?t.state.centerZDepth-e.state.centerZDepth:t.state.distanceToCamera-e.state.distanceToCamera)}},TilesetNormalTraverser=class extends TilesetBaseTraverser{constructor(e){super(e),this._traversalStack=new ManagedArray,this._emptyTraversalStack=new ManagedArray}traverse(e,t,n=[]){super.traverse(e,t,n);for(let t of n)this._traversalStack.reset(),this._emptyTraversalStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,this.updateTile(e,t),this.executeTraversal(e,t));this._traversalStack.reset(),this._emptyTraversalStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,this.updateTile(e,t),this.executeTraversal(e,t))}reset(){super.reset(),this._traversalStack.reset(),this._emptyTraversalStack.reset()}executeTraversal(e,t){let n=this._traversalStack;for(e.state.visible&&e.state.inRequestVolume&&n.push(e);n.length>0;){let e=n.pop(),r=e.parent,o=!r||r.state.shouldRefine,s=!1;this.canTraverse(e,t)&&(s=this.updateAndPushChildren(e,t,n)&&o);let c=!s&&o;e.hasRenderContent?e.refine===`ADD`?(this.loadTile(e,t),this.selectDesiredTile(e,t)):e.refine===`REPLACE`&&(this.loadTile(e,t),c&&this.selectDesiredTile(e,t)):(this.loadTile(e,t),c&&this.selectDesiredTile(e,t)),this.touchTile(e,t),e.state.shouldRefine=s}}updateAndPushChildren(e,t,n){let r=e.children;for(let e of r)this.updateTile(e,t);this.sortTilesByDistanceToCamera(r);let o=e.refine===`REPLACE`&&e.hasRenderContent,s=!1,c=!0;for(let e of r)if(e.levelOfContent<=t.minLevelOfDetail||e.geometricError>=t.maxGeometricError||e.state.visible&&e.state.inRequestVolume?(n.find(e)&&n.delete(e),n.push(e),s===!1&&(s=!0)):(o||t.loadSiblings)&&(this.loadTile(e,t),this.touchTile(e,t)),o){let n;n=e.state.inRequestVolume?e.hasRenderContent?e.contentAvailable:this.executeEmptyTraversal(e,t):!1,c=c&&n}return s||(c=!1),c}selectDesiredTile(e,t){e.contentAvailable&&super.selectTile(e,t)}executeEmptyTraversal(e,t){let n=!0,r=this._emptyTraversalStack;for(r.push(e);r.length>0&&n;){let e=r.pop(),o=!e.hasRenderContent&&this.canTraverse(e,t);if(!o&&!e.contentAvailable&&(n=!1),this.updateTile(e,t),e.state.visible||(this.loadTile(e,t),this.touchTile(e,t)),o){let t=e.children;for(let e of t)r.find(e)&&r.delete(e),r.push(e)}}return n}},TilesetSkipTraverser=class extends TilesetBaseTraverser{constructor(e){super(e),this.baseScreenSpaceError=1024,this.skipScreenSpaceErrorFactor=16,this.skipLevels=1,this._traversalStack=new ManagedArray,this._descendantTraversalStack=new ManagedArray,this._selectionTraversalStack=new ManagedArray,this._selectionTraversalancestorStack=new ManagedArray}traverse(e,t,n=[]){super.traverse(e,t,n);for(let t of n)this._traversalStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,this.updateTile(e,t),this.executeTraversal(e,t),this.traverseAndSelect(e,t));this.tileset.hasMixedContent=!1,this._traversalStack.reset(),this._descendantTraversalStack.reset(),this._selectionTraversalStack.reset(),this._selectionTraversalancestorStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,this.updateTile(e,t),this.executeTraversal(e,t),this.traverseAndSelect(e,t))}reset(){super.reset(),this._traversalStack.reset(),this._descendantTraversalStack.reset(),this._selectionTraversalStack.reset(),this._selectionTraversalancestorStack.reset()}executeTraversal(e,t){let n=this._traversalStack;for(e.state.visible&&e.state.inRequestVolume&&n.push(e);n.length>0;){let e=n.pop();this.updateTileAncestorContentLinks(e,t);let r=e.parent,o=!r||r.state.shouldRefine,s=!1;this.canTraverse(e,t)&&(s=this.updateAndPushChildren(e,t,n)&&o);let c=!s&&o;e.hasRenderContent?e.refine===`ADD`?(this.loadTile(e,t),this.selectDesiredTile(e,t)):e.refine===`REPLACE`&&(this.inBaseTraversal(e,this.baseScreenSpaceError)?(this.loadTile(e,t),c&&this.selectDesiredTile(e,t)):c?(this.loadTile(e,t),this.selectDesiredTile(e,t)):this.reachedSkippingThreshold(e)&&this.loadTile(e,t)):(this.loadTile(e,t),c&&this.selectDesiredTile(e,t)),this.touchTile(e,t),e.state.shouldRefine=s}}updateAndPushChildren(e,t,n){let r=e.children;for(let e of r)this.updateTile(e,t);this.sortTilesByDistanceToCamera(r);let o=!1;for(let e of r)e.levelOfContent<=t.minLevelOfDetail||e.geometricError>=t.maxGeometricError||e.state.visible&&e.state.inRequestVolume?(n.push(e),o===!1&&(o=!0)):t.loadSiblings&&(this.loadTile(e,t),this.touchTile(e,t));return o}selectDesiredTile(e,t){let n=e.contentAvailable?e:e.state.ancestorWithContentAvailable;n&&(n.state.shouldSelect=!0),e.contentAvailable||this.selectDescendants(e,t)}selectDescendants(e,t){let n=this._descendantTraversalStack;for(n.push(e);n.length>0;){let e=n.pop().children;for(let r of e)r.state.visible&&(r.contentAvailable?(this.updateTile(r,t),this.touchTile(r,t),this.selectTile(r,t)):n.push(r))}}reachedSkippingThreshold(e){let t=e.state.ancestorWithContent;return t!==null&&e.state.screenSpaceError<t.state.screenSpaceError/this.skipScreenSpaceErrorFactor&&e.levelOfContent>t.levelOfContent+this.skipLevels}updateTileAncestorContentLinks(e,t){e.state.ancestorWithContent=null,e.state.ancestorWithContentAvailable=null;let{parent:n}=e;if(!n)return;let r=!(n.hasRenderContent&&n.hasUnloadedContent)||n.state.requestedFrameNumber===t.frameNumber;e.state.ancestorWithContent=r?n:n.state.ancestorWithContent,e.state.ancestorWithContentAvailable=n.contentAvailable?n:n.state.ancestorWithContentAvailable}inBaseTraversal(e,t){return e.state.ancestorWithContent?e.parent&&e.state.screenSpaceError===0?e.parent.state.screenSpaceError>t:e.state.screenSpaceError>t:!0}traverseAndSelect(e,t){let n=this._selectionTraversalStack,r=this._selectionTraversalancestorStack,o;for(n.push(e);n.length>0||r.length>0;){if(r.length>0){let e=r.peek();if(e.state.stackLength===n.length){r.pop(),e!==o&&(e.state.finalResolution=!1),this.selectTile(e,t);continue}}let e=n.pop();if(!e)continue;let s=this.canTraverse(e,t);if(e.state.shouldSelect)if(e.refine===`ADD`)this.selectTile(e,t);else{if(e.state.selectionDepth=r.length,e.state.selectionDepth>0&&(e.tileset.hasMixedContent=!0),o=e,!s){this.selectTile(e,t);continue}r.push(e),e.state.stackLength=n.length}if(s)for(let t of e.children)t.state.visible&&n.push(t)}}},TilesetMostDetailTraverser=class extends TilesetBaseTraverser{constructor(e){super(e),this._traversalStack=new ManagedArray}canTraverse(e,t){return!(!e.state.inRequestVolume||e.levelOfContent>=t.maxLevelOfDetail||e.levelOfContent>=0&&e.geometricError<=t.minGeometricError||e.children.length===0)}traverse(e,t,n){super.traverse(e,t,[]),this._traversalStack.reset(),e.updateState(t);for(let t of n)this._traversalStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,e.updateState(t),this.executeTraversal(e,t));this._traversalStack.reset(),t.camera.refine&&(this._canSelectTile=t.camera.visible,e.updateState(t),this.executeTraversal(e,t))}reset(){super.reset(),this._traversalStack.reset()}executeTraversal(e,t){let n=this._traversalStack;for(n.push(e);n.length>0;){let e=n.pop(),r=e.refine===`ADD`,o=e.refine===`REPLACE`,s=this.canTraverse(e,t);s&&this.updateAndPushChildren(e,t,n),(r||o&&!s)&&(this.loadTile(e,t),this.touchTile(e,t),this.selectDesiredTile(e,t))}}updateAndPushChildren(e,t,n){let{children:r}=e;for(let e=0;e<r.length;++e){let o=r[e];o.updateState(t),o.state.visible&&n.push(o)}}selectDesiredTile(e,t){e.contentAvailable&&super.selectTile(e,t)}},Tileset=class{constructor(e,t){var n,r,o,s,c,l,u;if(this.id=e.tilesetUrl,this.transform=new three.Matrix4,this.hasMixedContent=!1,this.frameNumber=0,this.asset={version:e.asset.version,tilesetVersion:e.asset.tilesetVersion||``,gltfUpAxis:(n=e.asset.gltfUpAxis)==null?`Y`:n,overview:e.asset.overview,trajectories:(o=(r=e.asset.trajectories)==null?void 0:r.list)==null?[]:o,extras:e.asset.extras},this.rootMeta=(s=e.rootMeta)==null?{}:s,this.pointLength=(c=this.rootMeta.numTotalPoints)==null?1/0:c,this.floorLength=(l=this.rootMeta.numFloors)==null?1:l,this.properties=(u=e.properties)==null?{}:u,this.options=t,this.requestedTiles=[],this.selectedTiles=[],this.unloadTiles=[],this.needsRefinedTiles=new Set,this.selectedTrajectories=[],this.normalTraverser=new TilesetNormalTraverser(this),this.skipTraverser=new TilesetSkipTraverser(this),this.mostDetailTraverser=new TilesetMostDetailTraverser(this),this.cache=new TileCache({onTileLoad:e=>{this.cacheMemoryUsageInBytes+=e.contentMemoryUsage},onTileUnload:e=>{this.cacheMemoryUsageInBytes-=e.contentMemoryUsage,this.unloadTiles.push(e)}}),this.requestScheduler=new TileRequestScheduler(this,{onTileSkip:e=>{},onTileLoad:e=>{var t;(t=e.content)!=null&&t.data&&(this.loadedTiles.add(e),this.cache.loadTile(e)),this.options.onTileLoad(e)},onTileError:(e,t)=>{this.options.onTileError(e,t)}}),this.loadedTiles=new Set,this.cacheMemoryUsageInBytes=0,this.currentMaxScreenSpaceError=NaN,this.root=new Tile(`${this.id}#tile:0`,e.root,this),this.geometricError=e.geometricError,this.trajectories=[],this.asset.trajectories)for(let e=0;e<this.asset.trajectories.length;e++){let t=new Trajectory(`${this.id}#trajectory:${e}`,this.asset.trajectories[e],this);this.trajectories.push(t)}}adjustScreenSpaceError(e){if((isNaN(this.currentMaxScreenSpaceError)||!isFinite(this.currentMaxScreenSpaceError))&&(this.currentMaxScreenSpaceError=e.maxScreenSpaceError),e.memoryAdjustedScreenSpaceError){let t=0,n=0,r=0;if(this.needsRefinedTiles.forEach(e=>{e.content&&(n++,t+=e.content.memoryUsage,e.content.loadState===`READY`&&r++)}),r<2||n<2)this.currentMaxScreenSpaceError=e.maxScreenSpaceError;else{let o=1024*1024,s=t/r*n,c=e.maxMemoryUsage*o,l=c-clamp$1(c*.1,8*o,64*o),u=this.currentMaxScreenSpaceError;if(s<l){let e=.5*(1-s/l);u-=e}else s>c&&(u+=.3);u=clamp$1(u,1,e.maxScreenSpaceError),Math.abs(u-this.currentMaxScreenSpaceError)>=.1&&(this.currentMaxScreenSpaceError=u)}}else this.currentMaxScreenSpaceError=e.maxScreenSpaceError}getTraverser(e){return e.mostDetail?this.mostDetailTraverser:e.skipLevelOfDetail?this.skipTraverser:this.normalTraverser}reset(){this.cache.reset(),this.skipTraverser.reset(),this.normalTraverser.reset(),this.mostDetailTraverser.reset(),this.requestScheduler.reset();let e=[this.root],t;for(;t=e.pop();){for(let n=0,r=t.children.length;n<r;n++)e.push(t.children[n]);this.cache.unloadTile(t)}for(;this.unloadTiles.length;){let e=this.unloadTiles.pop();e&&(this.loadedTiles.delete(e),this.cacheMemoryUsageInBytes-=e.contentMemoryUsage,this.options.tileUnloader(e).catch(()=>{}).then(()=>{this.options.onTileUnload&&this.options.onTileUnload(e)}))}for(this.loadedTiles.clear();this.trajectories.length;){let e=this.trajectories.pop();e&&this.options.trajectoryUnloader(e).catch(()=>{}).then(()=>{this.options.onTrajectoryUnload&&this.options.onTrajectoryUnload(e)})}}update(e,t=[]){var n;for(this.frameNumber=e.frameNumber,this.adjustScreenSpaceError(e),this.cache.reset(),this.getTraverser(e).traverse(this.root,e,t),this.cache.unloadTiles(()=>this.cacheMemoryUsageInBytes>e.maxMemoryUsage*1024*1024),this.requestScheduler.update(this.requestedTiles,e.requestOrder,e);this.unloadTiles.length;){let e=this.unloadTiles.pop();e&&(this.loadedTiles.delete(e),this.options.tileUnloader(e).catch(()=>{}).then(()=>{this.options.onTileUnload&&this.options.onTileUnload(e)}))}this.selectedTrajectories.length=0;for(let t of this.trajectories)t.visible===!0&&t.content.loadState===`READY`&&(n=t.content.data)!=null&&n.object?this.selectedTrajectories.push(t):t.visible===!0&&(t.content.loadState===`FAILED`&&e.time-t.content.loadStateUpdateTime>t.content.loadfailRetryDelay&&(t.content.loadState=`UNLOADED`,t.content.loadStateUpdateTime=e.time),t.content.loadState===`UNLOADED`&&this.options.trajectoryLoader(t).then(()=>{this.options.onTrajectoryLoad(t)}).catch(e=>{this.options.onTrajectoryError(t,e)}))}};function normalizeTileHeader(e,t){var n;if(e.content){let r=(n=e.content.uri)==null?e.content.url:n;typeof r==`string`&&!isAbsoluteURL(r)&&(e.content.uri=normalizeURL(pathJoin(t,r)))}if(e.transform){let t=!1;for(let n=0;n<16;n++){let r=e.transform[n];if(typeof r!=`number`||isNaN(r)||!isFinite(r)){t=!0;break}}if(e.transform[15]===0&&(t=!0),t)throw Error(`Invalid Tile Transform: `+JSON.stringify(e.transform))}if(e.children)for(let n of e.children)normalizeTileHeader(n,t);return e}function normalizeTilesetHeader(e,t){e.tilesetUrl=t;let n=/^blob\:/.test(t)?``:t.slice(0,t.lastIndexOf(`/`)+1);if(e.asset||(e.asset={}),e.rootMeta||(e.rootMeta={}),e.rootMeta.taskParameters||(e.rootMeta.taskParameters={}),e.asset.overview){let t=e.asset.overview;isAbsoluteURL(t.imageFile)||(t.imageFile=normalizeURL(pathJoin(n,t.imageFile))),isAbsoluteURL(t.worldFile)||(t.worldFile=normalizeURL(pathJoin(n,t.worldFile)))}if(e.asset.trajectories)for(let t=0;t<e.asset.trajectories.list.length;t++){let r=e.asset.trajectories.list[t];r.file=normalizeURL(pathJoin(n,r.file))}return normalizeTileHeader(e.root,n),e}function delay(e){return new Promise(t=>setTimeout(t,e))}var AsyncTaskQueue=class{constructor(e){this.queue=[],this.concurrency=e,this.dequeuing=0}add(e,t=1e3){let n,r,o=new Promise((e,t)=>{n=e,r=t});return this.queue.unshift(()=>{let o=Promise.resolve().then(e);o.then(n,r);let s=delay(t);return Promise.race([o,s]).then(noop,noop)}),this.dequeue(),o}dequeue(){for(;this.dequeuing<this.concurrency&&this.queue.length>0;){let e=this.queue.pop();this.dequeuing++,e().catch(noop).then(()=>{this.dequeuing--,this.dequeue()})}}},initTextureQueue=new AsyncTaskQueue(1),skipImageSize=256;function canInit(e){return typeof e.image==`object`&&e.image.width>0&&e.image.height>0}function initTexture(e,t){if(!canInit(e))return Promise.resolve(e);if(e.image.width<skipImageSize&&e.image.width<skipImageSize)return t.initTexture(e),Promise.resolve(e);let n=!1,r=()=>{n=!0,e.removeEventListener(`dispose`,r)};return e.addEventListener(`dispose`,r),initTextureQueue.add(()=>new Promise(o=>{AnimationFrameLoop.shared.add(()=>{canInit(e)&&n===!1&&t.initTexture(e),e.removeEventListener(`dispose`,r),o(e)},!0)}))}function initTextures(e,t){return Promise.all(e.map(e=>initTexture(e,t)))}var _object_pattern=/^[og]\s*(.+)?/,_material_library_pattern=/^mtllib /,_material_use_pattern=/^usemtl /,_map_use_pattern=/^usemap /,_face_vertex_data_separator_pattern=/\s+/,_color=new three.Color,ObjState=class{constructor(){this.objects=[],this.vertices=[],this.normals=[],this.colors=[],this.uvs=[],this.materials={},this.materialLibraries=[],this.startObject(``,!1)}startObject(e,t){if(this.object&&this.object.fromDeclaration===!1){this.object.name=e,this.object.fromDeclaration=t!==!1;return}let n=this.object&&typeof this.object.currentMaterial==`function`?this.object.currentMaterial():void 0;if(this.object&&typeof this.object._finalize==`function`&&this.object._finalize(!0),this.object={name:e||``,fromDeclaration:t!==!1,geometry:{vertices:[],hasNormal:!0,normals:[],hasColor:!0,colors:[],hasUV:!0,uvs:[],index:[],indexMap:{}},materials:[],smooth:!0,startMaterial:function(e,t){var n,r;let o=this._finalize(!1);o&&(o.inherited||((n=o.groupCount)==null?0:n)<=0)&&this.materials.splice((r=o.index)==null?0:r,1);let s={index:this.materials.length,name:e||``,mtllib:Array.isArray(t)&&t.length>0?t[t.length-1]:``,smooth:o===void 0?this.smooth:o.smooth,groupStart:o===void 0?0:o.groupEnd,groupEnd:-1,groupCount:-1,inherited:!1,clone:function(e){let t={index:typeof e==`number`?e:this.index,name:this.name,mtllib:this.mtllib,smooth:this.smooth,groupStart:0,groupEnd:-1,groupCount:-1,inherited:!1,clone(){return this}};return t.clone=this.clone.bind(t),t}};return this.materials.push(s),s},currentMaterial:function(){if(this.materials.length>0)return this.materials[this.materials.length-1]},_finalize:function(e){var t,n;let r=this.currentMaterial();if(r&&r.groupEnd===-1&&(r.groupEnd=this.geometry.index.length,r.groupCount=r.groupEnd-((t=r.groupStart)==null?0:t),r.inherited=!1),e&&this.materials.length>1)for(let e=this.materials.length-1;e>=0;e--)((n=this.materials[e].groupCount)==null?0:n)<=0&&this.materials.splice(e,1);return e&&this.materials.length===0&&this.materials.push({name:``,smooth:this.smooth}),r}},n&&n.name&&typeof n.clone==`function`){let e=n.clone(0);e.inherited=!0,this.object.materials.push(e)}this.objects.push(this.object)}finalize(){this.object&&typeof this.object._finalize==`function`&&this.object._finalize(!0)}parseVertexIndex(e,t){let n=parseInt(e,10);return(n>=0?n-1:n+t/3)*3}parseNormalIndex(e,t){let n=parseInt(e,10);return(n>=0?n-1:n+t/3)*3}parseUVIndex(e,t){let n=parseInt(e,10);return(n>=0?n-1:n+t/2)*2}addFace(e,t,n,r,o,s,c,l,u){let d=this.object.geometry,f=this.vertices.length,p=this.normals.length,m=this.uvs.length,h=this.parseVertexIndex(e,f),g=this.parseVertexIndex(t,f),_=this.parseVertexIndex(n,f),v=c===void 0?void 0:this.parseNormalIndex(c,p),y=l===void 0?void 0:this.parseNormalIndex(l,p),b=u===void 0?void 0:this.parseNormalIndex(u,p),S=r===void 0?void 0:this.parseUVIndex(r,m),C=o===void 0?void 0:this.parseUVIndex(o,m),w=s===void 0?void 0:this.parseUVIndex(s,m);(d.hasNormal===!0&&v===void 0||y===void 0||b===void 0)&&(d.hasNormal=!1),(d.hasUV===!0&&S===void 0||C===void 0||w===void 0)&&(d.hasUV=!1);let T=[h,S,v].join(`:`),E=d.indexMap[T];E===void 0&&(E=d.vertices.length/3,d.indexMap[T]=E,d.vertices.push(this.vertices[h+0],this.vertices[h+1],this.vertices[h+2]),d.hasColor&&(this.colors[h]===void 0?d.hasColor=!1:d.colors.push(this.colors[h+0],this.colors[h+1],this.colors[h+2])),d.hasNormal&&d.normals.push(this.normals[h+0],this.normals[h+1],this.normals[h+2]),d.hasUV&&d.uvs.push(this.uvs[S+0],this.uvs[S+1])),d.index.push(E);let D=[g,C,y].join(`:`),O=d.indexMap[D];O===void 0&&(O=d.vertices.length/3,d.indexMap[D]=O,d.vertices.push(this.vertices[g+0],this.vertices[g+1],this.vertices[g+2]),d.hasColor&&(this.colors[g]===void 0?d.hasColor=!1:d.colors.push(this.colors[g+0],this.colors[g+1],this.colors[g+2])),d.hasNormal&&d.normals.push(this.normals[g+0],this.normals[g+1],this.normals[g+2]),d.hasUV&&d.uvs.push(this.uvs[C+0],this.uvs[C+1])),d.index.push(O);let k=[_,w,b].join(`:`),A=d.indexMap[k];A===void 0&&(A=d.vertices.length/3,d.indexMap[k]=A,d.vertices.push(this.vertices[_+0],this.vertices[_+1],this.vertices[_+2]),d.hasColor&&(this.colors[_]===void 0?d.hasColor=!1:d.colors.push(this.colors[_+0],this.colors[_+1],this.colors[_+2])),d.hasNormal&&d.normals.push(this.normals[_+0],this.normals[_+1],this.normals[_+2]),d.hasUV&&d.uvs.push(this.uvs[w+0],this.uvs[w+1])),d.index.push(A)}};function parseObj(e){let t=new ObjState;e.indexOf(`\r
832
832
  `)!==-1&&(e=e.replace(/\r\n/g,`
833
833
  `)),e.indexOf(`\\
834
834
  `)!==-1&&(e=e.replace(/\\\n/g,``));let n=e.split(`
@@ -935,7 +935,7 @@ void main() {
935
935
  #include <fog_fragment>
936
936
  #include <premultiplied_alpha_fragment>
937
937
  }
938
- `,uniforms:{diffuse:{value:new three.Color},opacity:{value:1},displacementScalar:{value:0}}};function createPipeBufferGeometry(e,t,n,r){let o=new Float32Array((n+1)*(r+1)*3),s=new Float32Array((n+1)*(r+1)*3),c=new Float32Array((n+1)*(r+1)*2),l=new Uint32Array(n*r*6),u=e.computeFrenetFrames(n),d=new three.Vector3,f=new three.Vector3,p=new three.Vector2,m=new three.Vector3;for(let l=0;l<=n;l++){m=e.getPointAt(l/n,m);let h=u.normals[l],g=u.binormals[l];for(let e=0;e<=r;e++){let u=l*(r+1)+e,_=e/r*Math.PI*2,v=Math.sin(_),y=-Math.cos(_);f.x=y*h.x+v*g.x,f.y=y*h.y+v*g.y,f.z=y*h.z+v*g.z,f.normalize(),f.toArray(s,u*3),d.x=m.x+t*f.x,d.y=m.y+t*f.y,d.z=m.z+t*f.z,d.toArray(o,u*3),p.x=l/n,p.y=e/r,p.toArray(c,u*2)}}for(let e=0;e<n;e++)for(let t=0;t<r;t++){let n=(e*r+t)*6,o=(r+1)*e+t,s=(r+1)*(e+1)+t,c=(r+1)*(e+1)+(t+1),u=(r+1)*e+(t+1);l[n]=o,l[n+1]=s,l[n+2]=u,l[n+3]=s,l[n+4]=c,l[n+5]=u}let h=new three.BufferGeometry;return h.setIndex(new three.BufferAttribute(l,1)),h.setAttribute(`position`,new three.BufferAttribute(o,3)),h.setAttribute(`normal`,new three.BufferAttribute(s,3)),h.setAttribute(`uv`,new three.BufferAttribute(c,2)),h}function parseTrajectoryObject(e,t){let n=new three.Color(0).convertSRGBToLinear(),r=new three.Color(52949).convertSRGBToLinear(),o=new three.Color(3370495).convertSRGBToLinear(),s=new three.Color(16777215).convertSRGBToLinear(),c=0,l=new three.CurvePath,u=e.length;for(let t=3;t<u;t+=3){let n=new three.Vector3().fromArray(e,t-3),r=new three.Vector3().fromArray(e,t);c+=n.distanceTo(r);let o=new three.LineCurve3(n,r);l.add(o)}let d=createPipeBufferGeometry(l,.03,Math.ceil(c*100),6);d.clearGroups(),d.addGroup(0,d.index?d.index.count:d.attributes.position.count,0),d.addGroup(0,d.index?d.index.count:d.attributes.position.count,1),d.addGroup(0,d.index?d.index.count:d.attributes.position.count,2);let f=new three.ShaderMaterial({vertexShader:TRAJECTOR_PIPE_SHADER.vertexShader,fragmentShader:TRAJECTOR_PIPE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_PIPE_SHADER.uniforms),side:three.BackSide});f.uniforms.totalLength.value=c,f.uniforms.diffuse.value=n,f.uniforms.diffuse2.value=n,f.uniforms.opacity.value=.5,f.transparent=!0;let p=new three.ShaderMaterial({vertexShader:TRAJECTOR_PIPE_SHADER.vertexShader,fragmentShader:TRAJECTOR_PIPE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_PIPE_SHADER.uniforms),side:three.BackSide});p.uniforms.totalLength.value=c,p.uniforms.displacementScalar.value=-.01,p.uniforms.diffuse.value=r,p.uniforms.diffuse2.value=o;let m=new three.ShaderMaterial({vertexShader:TRAJECTOR_PIPE_SHADER.vertexShader,fragmentShader:TRAJECTOR_PIPE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_PIPE_SHADER.uniforms),side:three.DoubleSide});m.uniforms.totalLength.value=c,m.uniforms.displacementScalar.value=-.026,m.uniforms.dashSize.value=new three.Vector2(.06,.09),m.uniforms.diffuse.value=s,m.uniforms.diffuse2.value=s;let h=new three.Mesh(d,[f,p,m]),g=.08,_=24,v=new three.SphereBufferGeometry(.08,24,24);v.clearGroups(),v.addGroup(0,d.index?d.index.count:d.attributes.position.count,0),v.addGroup(0,d.index?d.index.count:d.attributes.position.count,1);let y=new three.ShaderMaterial({vertexShader:TRAJECTOR_SPHERE_SHADER.vertexShader,fragmentShader:TRAJECTOR_SPHERE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_SPHERE_SHADER.uniforms),side:three.BackSide});y.uniforms.diffuse.value=n,y.uniforms.opacity.value=.5,y.transparent=!0;let b=new three.ShaderMaterial({vertexShader:TRAJECTOR_SPHERE_SHADER.vertexShader,fragmentShader:TRAJECTOR_SPHERE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_SPHERE_SHADER.uniforms),side:three.FrontSide});b.uniforms.displacementScalar.value=-.01,b.uniforms.diffuse.value=r;let S=new three.Mesh(v,[y,b]);S.position.fromArray(e,0),h.add(S);let C=new three.ShaderMaterial({vertexShader:TRAJECTOR_SPHERE_SHADER.vertexShader,fragmentShader:TRAJECTOR_SPHERE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_SPHERE_SHADER.uniforms),side:three.FrontSide});C.uniforms.displacementScalar.value=-.01,C.uniforms.diffuse.value=o;let w=new three.Mesh(v,[y,C]);return w.position.fromArray(e,e.length-3),h.add(w),{scene:h,dispose:()=>{d.dispose(),f.dispose(),p.dispose(),m.dispose(),v.dispose(),y.dispose(),b.dispose(),C.dispose()}}}function loadTrajectory(e,t){let n=e.name,r=imageURL(appendSearch(e.content.uri,t.search),{key:`model.0`});return e.content.loadState=`LOADING`,e.content.loadStateUpdateTime=now(),loadPly(r,{type:`geometry`,customPropertyMapping:{time:{itemType:`uint32`,itemNames:[`time_milisec`]}},fetcher:t.fetcher}).then(t=>{var o,s,c,l;let u=(s=(o=t.scene.attributes)==null?void 0:o.time.array)==null?[]:s,d=(l=(c=t.scene.attributes)==null?void 0:c.position.array)==null?[]:l,f=t.byteLength,p=t.memoryUsage,m=parseTrajectoryObject(d,u);m.scene.applyMatrix4(e.transform),m.scene.updateWorldMatrix(!1,!0),m.scene.matrixAutoUpdate=!1;let h=new TrajectoryNode(n,m.scene);return e.content.data={uri:r,byteLength:f,memoryUsage:p,positionArray:d,timeArray:u,object:h},e.content.byteLength=f,e.content.memoryUsage=p,e.content.loadState=`READY`,e.content.loadStateUpdateTime=now(),e}).catch(t=>(e.content.data=void 0,e.content.loadState=`FAILED`,e.content.loadStateUpdateTime=now(),t instanceof NetworkResponseError&&t.httpStatus===0||t instanceof NetworkTimeoutError||t instanceof NetworkProxyError?e.content.loadfailRetryDelay=clamp$1(e.content.loadfailRetryDelay+RETRY_DELAY_STEP,RETRY_DELAY_STEP,MAX_RETRY_DELAY):e.content.loadfailRetryDelay=1/0,Promise.reject(t)))}function unloadTrajectory(e){e.content&&(e.content.data&&e.content.data.object.dispose(),e.content.data=void 0,e.content.loadState=`UNLOADED`,e.content.loadProgress=0,e.content.loadStateUpdateTime=now(),e.content.byteLength=0,e.content.memoryUsage=0)}var scratchVector3$7=new three.Vector3,scratchMatrix3=new three.Matrix3,scratchMatrix4$3=new three.Matrix4,a=6378137,invF=298.257223563;function ecefToLla(e){let t=a-a/invF,n=(a*a-t*t)/(a*a),r=Math.sqrt(e.x*e.x+e.y*e.y),o=1e-12,s=1e3,c=0,l=Math.atan2(e.z,r),u=0;for(;c++<1e3;){let t=Math.sin(l),o=a/Math.sqrt(1-n*t*t);u=r/Math.cos(l)-o;let s=Math.atan2(e.z/(o*(1-n)+u),r/(o+u));if(isNaN(s)||Math.abs(s-l)<1e-12)break;l=s}return e.set(l,Math.atan2(e.y,e.x),u)}function llaToEcef(e){let{x:t,y:n,z:r}=e,o=a-a/invF,s=(a*a-o*o)/(a*a),c=Math.sin(t),l=Math.cos(t),u=Math.sin(n),d=Math.cos(n),f=a/Math.sqrt(1-s*c*c),p=(f+r)*l*d,m=(f+r)*l*u,h=(o*o/(a*a)*f+r)*c;return e.set(p,m,h)}function getEcefToEnuMatrix(e,t){let{x:n,y:r,z:o}=ecefToLla(scratchVector3$7.copy(e)),s=Math.sin(n),c=Math.sin(r),l=Math.cos(n),u=Math.cos(r);t.fromArray([-c,-s*u,l*u,0,+u,-s*c,l*c,0,0,l,s,0,0,0,0,1]);let d=scratchMatrix3.setFromMatrix4(t),f=scratchVector3$7.copy(e).applyMatrix3(d).multiplyScalar(-1);t.setPosition(f);let p=scratchMatrix4$3.fromArray([1,0,0,0,0,1,0,0,0,0,1,0,0,0,o,1]);return t.premultiply(p),t}var ROTATE_X_90_MATRIX=new three.Matrix4().fromArray([1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1]),ROTATE_X_90_MATRIX_INVERSE=new three.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]),enuToLocalMatrix=new three.Matrix4().copy(ROTATE_X_90_MATRIX),localToEnuMatrix=new three.Matrix4().copy(ROTATE_X_90_MATRIX_INVERSE);function getRecommendTile3dProps(e,t={}){var n,r,o;let s,c,l;if(typeof e.tileset.rootMeta.creationTime==`string`)if(typeof e.tileset.rootMeta.numTotalPoints==`number`&&e.tileset.rootMeta.numTotalPoints>0){l=4,t.powerPreference===`high`&&(l=2),s=l/1.6;let u=0;if(((n=e.tileset.rootMeta.taskParameters)==null?void 0:n.point_homogenization)===`1`&&(r=e.tileset.rootMeta.taskParameters)!=null&&r.homo_point_density){let t=Number((o=e.tileset.rootMeta.taskParameters)==null?void 0:o.homo_point_density);isFinite(t)&&!isNaN(t)&&(u=t)}u<=0&&(u=.02),c=u*1.4}else l=5,t.powerPreference===`high`&&(l=4),s=0,c=.03;else l=6,s=0,c=.03,e.name===`aerophoto`?(l=12,t.powerPreference===`high`&&(l=10)):e.tileset.asset.extras&&typeof e.tileset.asset.extras.name==`string`&&/^matterport\b/i.test(e.tileset.asset.extras.name)&&(l=5,t.powerPreference===`high`&&(l=4));return{pointScale:c,pointMinPixel:s,maxScreenSpaceError:l}}var scratchVector3$6=new three.Vector3,scratchSphereBoundingVolume=new SphereBoundingVolume,scratchBoxBoundingVolume=new BoxBoundingVolume,parameterVersionMap=new WeakMap,tileVersionMap=new WeakMap,trajectoryVersionMap=new WeakMap,STENCIL_CONSTANT={TILE_MASK:128,SKIP_LOD_MASK:112,SKIP_LOD_BIT_SHIFT:4,CLASSIFICATION_MASK:15},SKIP_BACKFACE_MATERIAL=(()=>{let e=new three.MeshBasicMaterial;return e.side=three.BackSide,e.color.setHex(16711935),e.colorWrite=!1,e.stencilWrite=!0,e.polygonOffset=!0,e.polygonOffsetFactor=2,e.polygonOffsetUnits=2,e.stencilRef=STENCIL_CONSTANT.TILE_MASK,e.stencilFunc=three.AlwaysStencilFunc,e.stencilFuncMask=STENCIL_CONSTANT.TILE_MASK,e.stencilZPass=three.ReplaceStencilOp,e.stencilWriteMask=STENCIL_CONSTANT.TILE_MASK,e})(),SKIP_BACKFACE_TRANSPARENT_MATERIAL=(()=>{let e=new three.MeshBasicMaterial;return e.visible=!1,e})(),CLEAR_STENCIL_GEOMETRY=new three.BufferGeometry,CLEAR_STENCIL_MATERIAL=new three.MeshBasicMaterial;function cloneSkipBackfaceObject(e){let t;t=e instanceof three.Mesh?new three.Mesh(e.geometry,Array.isArray(e.material)?e.material.map(e=>e.transparent?SKIP_BACKFACE_TRANSPARENT_MATERIAL:SKIP_BACKFACE_MATERIAL):e.material&&e.material.transparent?SKIP_BACKFACE_TRANSPARENT_MATERIAL:SKIP_BACKFACE_MATERIAL):e instanceof three.Group?new three.Group:new three.Object3D,t.position.copy(e.position),t.quaternion.copy(e.quaternion),t.scale.copy(e.scale),t.matrix.compose(e.position,e.quaternion,e.scale),t.matrixAutoUpdate=!1,t.frustumCulled=e.frustumCulled,t.visible=e.visible;for(let n of e.children)t.add(cloneSkipBackfaceObject(n));return t}var Tile3D=class extends three.Object3D{constructor(e,t){var n,r;super(),this.parameter=new Parameter,this.renderObjects=[],this.backfaceObjects=[],this.tileObjects=[],this.frameNumber=0,this.error=(n=t.error)==null?null:n,this.name=t.name,this.type=t.type,this.upAxis=t.upAxis,this.light=t.light,this.fetcher=t.fetcher,this.search=(r=t.search)==null?``:r,this.groundHeight=t.groundHeight,this.coordinateSystem=t.coordinateSystem,this.boundingBox=new three.Box3,this.autoRefine=!0,this.refined=!1,this.refineProgress=[0,0],this.loaded=!1,this.disposed=!1,this.clearStencilObject=new three.Mesh(CLEAR_STENCIL_GEOMETRY,CLEAR_STENCIL_MATERIAL),this.clearStencilObject.frustumCulled=!1,this.clearStencilObject.onAfterRender=e=>e.clearStencil(),this.tileset=new Tileset(e,{tileLoader:e=>this.loadContent(e),tileUnloader:e=>this.unloadContent(e),onTileLoad:e=>{this.onTileLoad&&this.onTileLoad(e)},onTileUnload:e=>{this.onTileUnload&&this.onTileUnload(e)},onTileError:(e,t)=>{this.onError&&this.onError(Object.assign(t,{tile:e})),console.error(`Tile error`,e.id,t)},trajectoryLoader:e=>this.loadTrajectory(e),trajectoryUnloader:e=>this.unloadTrajectory(e),onTrajectoryLoad:()=>{},onTrajectoryUnload:e=>{},onTrajectoryError:(e,t)=>{this.onError&&this.onError(Object.assign(t,{error:t})),console.error(`Trajectory error`,e,t)}}),this.tileset.root.boundingVolume&&this.tileset.root.boundingVolume.getBoundingBox(this.boundingBox)}get viewerRequestVolume(){return this.tileset.root.viewerRequestVolume}set viewerRequestVolume(e){this.tileset.root.viewerRequestVolume=e}get tiles(){return this.tileset.selectedTiles}get trajectories(){return this.tileset.trajectories}getRecommendProps(e={}){return getRecommendTile3dProps(this,e)}loadContent(e){return loadTileContent(e,{light:this.light,fetcher:this.fetcher,search:this.search,renderer:this.renderer}).then(t=>{if(e.type===`SCENEGRAPH`){if(this.disposed||!e.content)unloadTileContent(e);else if(e.content.data)if(e.content.data.type===`spz`){let t=e.content.data.object.children[0].boundingBox;this.boundingBox.union(t)}else this.boundingBox.expandByObject(e.content.data.object)}})}unloadContent(e){return unloadTileContent(e),Promise.resolve()}loadAllTilesets(){let e=t=>{let n=[];return this.tileset.root.traverse(e=>{var t;e.type===`TILESET`&&((t=e.content)==null?void 0:t.loadState)!==`READY`&&n.push(e)}),Promise.all(n.map(t=>this.loadContent(t).then(()=>e(t)))).then(()=>{})};return e(this.tileset.root)}loadTrajectory(e){return loadTrajectory(e,{fetcher:this.fetcher,search:this.search,renderer:this.renderer}).then(e=>{this.disposed&&unloadTrajectory(e)})}unloadTrajectory(e){return unloadTrajectory(e),Promise.resolve()}intersectRaycaster(e,t){var n,r;let o=t==null?[]:t,s=[this.tileset.root],c=this.tileset.transform,l=(r=(n=e.params.Points)==null?void 0:n.threshold)==null?0:r,u=e.sortByDistance;e.sortByDistance=!1;let d,f=1/0;for(;d=s.pop();){let t;if(d.boundingVolume){let n;n=d.boundingVolume instanceof BoxBoundingVolume?scratchBoxBoundingVolume.copy(d.boundingVolume):d.boundingVolume instanceof SphereBoundingVolume?scratchSphereBoundingVolume.copy(d.boundingVolume):d.boundingVolume.clone(),n.applyMatrix4(c),t=n.intersectRay(e.ray,l,f)}else t=!0;if(t){for(let e=0,t=d.children.length;e<t;e++)s.push(d.children[e]);if(d.selected&&d.content&&d.content.data&&d.content.data.object.visible){let t=e.hitFilter;if(e.hitFilter=n=>{var r;return Object.assign(n,{model:(r=this.parent)==null?void 0:r,viewLayer:this,tile:d}),t?t.call(e,n):!0},d.content.data.object.intersectRaycaster(e,o),e.hitFilter=t,e.firstHitOnly){let e=o[0];e&&f>e.distance&&(f=e.distance)}}}}return e.sortByDistance=u,sortIntersects(o,e.sortByDistance,e.firstHitOnly),o}update(e,t,n,r){var o,s,c,l,u,d,f;this.renderer=e,this.frameNumber++;let p=!1,m=this.parameter.resolveValue(n.parameter,r.parameter);parameterVersionMap.get(this)!==m.version&&(parameterVersionMap.set(this,m.version),p=!0);let h=(l=this.visible&&((o=this.parent)==null?void 0:o.visible)&&((c=(s=this.parent)==null?void 0:s.parent)==null?void 0:c.visible))==null?!1:l,g=m.maxLevelOfDetail;g=Math.max(g,0);let _=Math.min(m.minLevelOfDetail,g);(!h||!this.loaded||!n.loaded)&&(g=Math.max(_,0));let v=m.maxMemoryUsage;h||(v=Math.min(0,v));let y=m.minGeometricError,b=m.maxRequests,S=m.memoryAdjustedScreenSpaceError;h||(S=!1);let C=t.controllerMode;(C===`Panorama`||C===`VRPanorama`||C===`XRPanorama`)&&(m.modelAlpha<.1&&(y=m.panoramaMinGeometricError,S=!1),m.progress>=.01&&m.progress<=.99&&(b=0));let w=m.maxGeometricError;w=Math.max(y,w);let T={time:t.time,camera:{type:t.type,position:new three.Vector3().copy(t.position),direction:t.getDirection(new three.Vector3),up:new three.Vector3().copy(t.up).applyQuaternion(t.quaternion),projectionMatrix:t.projectionMatrix.clone(),visible:h&&t.visible,refine:t.refineModel},height:t.resolution.height,pixelRatio:t.pixelRatio,frameNumber:this.frameNumber,sseDenominator:2*Math.tan(.5*t.fov/180*Math.PI),cullingVolume:new CullingVolume().setFromCamera(t),minLevelOfDetail:_,maxLevelOfDetail:g,minGeometricError:y,maxGeometricError:w,skipLevelOfDetail:m.skipLevelOfDetail,mostDetail:m.mostDetail,loadSiblings:m.loadSiblings,cameraCulling:m.cameraCulling,maxMemoryUsage:v,maxRequests:b,requestOrder:m.requestOrder,maxScreenSpaceError:m.maxScreenSpaceError,memoryAdjustedScreenSpaceError:S},E=m.cacheCameras.map(e=>(e.updateProjectionMatrix(),Object.assign(Object.assign({},T),{camera:{type:t.type,position:new three.Vector3().copy(e.position),direction:e.getWorldDirection(new three.Vector3),up:new three.Vector3().copy(e.up),projectionMatrix:e.projectionMatrix.clone(),visible:e.visible,refine:!0},cullingVolume:new CullingVolume().setFromCamera(e)})));this.updateWorldMatrix(!0,!1),this.tileset.transform.equals(this.matrixWorld)||(this.tileset.transform.copy(this.matrixWorld),p=!0);let D=!this.autoRefine;if(D===!1&&m.progress>=.01&&m.progress<=.99){let e=new three.Vector3;m.pano0&&e.setFromMatrixPosition(m.pano0.matrix);let t=e.clone();m.pano1&&t.setFromMatrixPosition(m.pano1.matrix),e.distanceTo(t)<10&&(D=!0)}if(D||this.tileset.update(T,E),this.refined=!0,this.refineProgress[0]=0,this.refineProgress[1]=0,this.tileset.needsRefinedTiles.forEach(e=>{if(this.refineProgress[1]++,e.content){let t=e.content.loadState;if(t===`UNLOADED`||t===`LOADING`){this.refined=!1;return}}this.refineProgress[0]++}),this.loaded===!1&&this.autoRefine){this.loaded=!0;let e=!1;this.tileset.needsRefinedTiles.forEach(t=>{if(this.loaded!==!1&&t.content&&(t.state.visible&&(e=!0),m.minLevelOfDetail>=0)){if(T.skipLevelOfDetail){if(t.state.finalResolution){let e=t.state.ancestorWithContentAvailable,n=(e&&e.content?e.content:t.content).loadState;(n===`UNLOADED`||n===`LOADING`)&&(this.loaded=!1)}}else if(t.state.visible&&t.levelOfContent<=0){let e=t.content.loadState;(e===`UNLOADED`||e===`LOADING`)&&(this.loaded=!1)}}}),e&&this.tileset.selectedTiles.length===0&&this.tileset.frameNumber<500&&(this.loaded=!1),this.loaded===!0&&(this.refined=!1,this.refineProgress[1]++)}this.renderObjects.length=0,this.backfaceObjects.length=0,this.tileObjects.length=0;for(let e=this.children.length-1;e>=0;e--)this.remove(this.children[e]);T.skipLevelOfDetail||this.tileset.selectedTiles.sort((e,t)=>e.floor===t.floor?e.levelOfContent===t.levelOfContent?e.state.distanceToCamera===t.state.distanceToCamera?e.state.centerZDepth-t.state.centerZDepth:e.state.distanceToCamera-t.state.distanceToCamera:t.levelOfContent-e.levelOfContent:e.floor-t.floor);let O=[];for(let r of this.tileset.selectedTiles){let o=(d=(u=r.content)==null?void 0:u.data)==null?void 0:d.object;if(!o)continue;let s=o.update(e,t,n,this,r,m);if(O.push(r.id),s&&(p=!0),this.tileset.hasMixedContent&&T.skipLevelOfDetail){if(!r.state.finalResolution){let e=cloneSkipBackfaceObject(o);e.name=`skipBackface:`+o.name,this.backfaceObjects.push(e)}let e=r.state.selectionDepth,t=STENCIL_CONSTANT.TILE_MASK|e<<STENCIL_CONSTANT.SKIP_LOD_BIT_SHIFT,n=three.GreaterEqualStencilFunc,s=STENCIL_CONSTANT.SKIP_LOD_MASK,c=three.ReplaceStencilOp,l=STENCIL_CONSTANT.TILE_MASK|STENCIL_CONSTANT.SKIP_LOD_MASK;for(let e of o.materials)e.stencilWrite=!0,e.stencilRef=t,e.stencilFunc=n,e.stencilFuncMask=s,e.stencilZPass=c,e.stencilWriteMask=l}else for(let e of o.materials)e.stencilWrite=!1,e.stencilRef=STENCIL_CONSTANT.TILE_MASK,e.stencilFunc=three.AlwaysStencilFunc,e.stencilFuncMask=STENCIL_CONSTANT.TILE_MASK,e.stencilZPass=three.ReplaceStencilOp,e.stencilWriteMask=STENCIL_CONSTANT.TILE_MASK;this.tileObjects.push(o)}let k=O.toString();if(tileVersionMap.get(this)!==k&&(tileVersionMap.set(this,k),p=!0),T.skipLevelOfDetail&&this.backfaceObjects.length)for(let e=0;e<this.backfaceObjects.length;e++)this.renderObjects.push(this.backfaceObjects[e]);if(this.tileObjects.length)for(let e=0;e<this.tileObjects.length;e++)this.renderObjects.push(this.tileObjects[e]);T.skipLevelOfDetail&&this.renderObjects.push(this.clearStencilObject);let A=[];for(let r of this.tileset.selectedTrajectories){let o=(f=r.content.data)==null?void 0:f.object;if(!o)continue;let s=o.update(e,t,n,this,r,m);A.push(r.id),s&&(p=!0),this.renderObjects.push(o)}let j=A.toString();if(trajectoryVersionMap.get(this)!==j&&(trajectoryVersionMap.set(this,j),p=!0),this.parent){let e=this.parent.children.length+1,t=(Math.min(0,this.parent.children.indexOf(this))-e)*1e4+1;for(let e=0;e<this.renderObjects.length;e++){let n=this.renderObjects[e],r=e+t;n.traverse(e=>{(e instanceof three.Mesh||e instanceof three.Line||e instanceof three.Points)&&(e.renderOrder=r)})}}if(this.loaded)for(let e=0;e<this.renderObjects.length;e++)this.add(this.renderObjects[e]);return p}dispose(){this.disposed=!0,this.tileset.reset(),this.tileset.root.children.length=0,/^blob\:/.test(this.tileset.id)&&URL.revokeObjectURL(this.tileset.id);for(let e=this.children.length-1;e>=0;e--)this.remove(this.children[e]);this.refined=!1,this.loaded=!1,this.refineProgress[0]=this.refineProgress[1]=0,this.error=null,this.onError=void 0,this.renderer=void 0}get model(){return this.parent}get scene(){return this}get viewLayer(){return this}localToEnu(e){return e.applyMatrix4(localToEnuMatrix)}enuToLocal(e){return e.applyMatrix4(enuToLocalMatrix)}enuToEcef(e){return e.applyMatrix4(this.coordinateSystem.enuToEcefMatrix)}ecefToEnu(e){return e.applyMatrix4(this.coordinateSystem.ecefToEnuMatrix)}localToEcef(e){return this.enuToEcef(this.localToEnu(e))}ecefToLocal(e){return this.enuToLocal(this.ecefToEnu(e))}localToLla(e){return ecefToLla(this.enuToEcef(this.localToEnu(e)))}llaToLocal(e){return this.enuToLocal(this.ecefToEnu(llaToEcef(e)))}worldToEnu(e){return this.localToEnu(this.worldToLocal(e))}enuToWorld(e){return this.localToWorld(this.enuToLocal(e))}worldToEcef(e){return this.localToEcef(this.worldToLocal(e))}ecefToWorld(e){return this.localToWorld(this.ecefToLocal(e))}worldToLla(e){return this.localToLla(this.worldToLocal(e))}llaToWorld(e){return this.localToWorld(this.llaToLocal(e))}get coordinates(){scratchVector3$6.setScalar(0);let{x:e,y:t}=this.localToLla(scratchVector3$6);return[e,t].map(e=>(e/Math.PI*180).toFixed(6)).join(`,`)}getTransformMatrix4(e=new three.Matrix4){return e.copy(this.coordinateSystem.ecefToEnuMatrix),e.premultiply(enuToLocalMatrix),e.premultiply(this.matrixWorld),e}coordinatesToWorldPoint(e){let t=new three.Vector3(e.latitude,e.longitude,e.altitude);return this.llaToWorld(t)}worldPointToCoordinates(e){return scratchVector3$6.copy(e),this.worldToLla(scratchVector3$6),{latitude:scratchVector3$6.x,longitude:scratchVector3$6.y,altitude:scratchVector3$6.z}}resetBrightness(){this.parameter.reset(`brightness`)}get minLevelOfDetail(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).minLevelOfDetail}set minLevelOfDetail(e){this.parameter.set(`minLevelOfDetail`,e)}get maxLevelOfDetail(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).maxLevelOfDetail}set maxLevelOfDetail(e){this.parameter.set(`maxLevelOfDetail`,e)}get minGeometricError(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).minGeometricError}set minGeometricError(e){this.parameter.set(`minGeometricError`,e)}get maxGeometricError(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).maxGeometricError}set maxGeometricError(e){this.parameter.set(`maxGeometricError`,e)}get panoramaMinGeometricError(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).panoramaMinGeometricError}set panoramaMinGeometricError(e){this.parameter.set(`panoramaMinGeometricError`,e)}get skipLevelOfDetail(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).skipLevelOfDetail}set skipLevelOfDetail(e){this.parameter.set(`skipLevelOfDetail`,e)}get mostDetail(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).mostDetail}set mostDetail(e){this.parameter.set(`mostDetail`,e)}get loadSiblings(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).loadSiblings}set loadSiblings(e){this.parameter.set(`loadSiblings`,e)}get maxMemoryUsage(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).maxMemoryUsage}set maxMemoryUsage(e){this.parameter.set(`maxMemoryUsage`,e)}get maxRequests(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).maxRequests}set maxRequests(e){this.parameter.set(`maxRequests`,e)}get requestOrder(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).requestOrder}set requestOrder(e){this.parameter.set(`requestOrder`,e)}get maxScreenSpaceError(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(...e).maxScreenSpaceError}set maxScreenSpaceError(e){this.parameter.set(`maxScreenSpaceError`,e)}},fetchers={};function getFetcher(e,t){let n=fetchers[e];if(n){let e=n.get(t);if(e)return e}throw Error(`fetcher workCode:${t.workCode} never registered.`)}function registerFetcher(e,t,n){let r=fetchers[e];r||(r=fetchers[e]=new WeakMap),r.has(t)||r.set(t,n)}var identityMatrix4=new three.Matrix4,scratchVector3$5=new three.Vector3,scratchMatrix4$2=new three.Matrix4;function getEcefToEnuMatrixFromUpAxis(e,t,n){switch(e){case`Z`:n.identity();break;case`WGS84`:case`GCJ02`:case`BD09`:getEcefToEnuMatrix(t,n);break;default:n.identity();break}return n}function loadViewLayer(e){var t;let[n,r]=e.tilesetUrl.split(`#`),o=(t=(r||n).split(`?`)[1])==null?``:t;return e.fetcher.ajax(e.tilesetUrl,{responseType:`text`}).catch(e=>({error:e,body:JSON.stringify({asset:{version:`0.0`},geometricError:0,root:{geometricError:0}})})).then(t=>{var n;let r=`error`in t?t.error:null,s=normalizeTilesetHeader(JSON.parse(t.body),e.tilesetUrl),{root:c,rootMeta:l={}}=s,u=e.upAxis;l.upAxis&&l.upAxis!==u&&(u=l.upAxis),`lodVersion`in s&&(u=`-Y`,`floorInfo`in s&&(s.properties=s.properties||{},s.properties.floorInfo=s.floorInfo.map(e=>({ground:-e.ground,height:e.height})),s.floorInfo=void 0),s.asset.tilesetVersion=String(s.lodVersion),s.lodVersion=void 0);let d=u,f=new three.Matrix4;d===`Y`?(d=`Z`,f.fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1])):d===`-Y`&&(d=`Z`,f.fromArray([1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1]));let p=c.boundingVolume?makeBoundingVolume(c.boundingVolume):void 0;p&&c.transform&&p.applyMatrix4(scratchMatrix4$2.fromArray(c.transform));let m=null,h=new three.Matrix4,g=new three.Matrix4;return l.coordinate?(m=l.coordinate.ground_height,h.fromArray(l.coordinate.pose_ecef_to_enu),g.fromArray(l.coordinate.pose_enu_to_ecef)):(p?p.getCenter(scratchVector3$5):scratchVector3$5.setScalar(0),scratchVector3$5.applyMatrix4(f),getEcefToEnuMatrixFromUpAxis(d,scratchVector3$5,h),g.getInverse(h)),s.root={refine:(n=c.refine)==null?`REPLACE`:n,geometricError:c.geometricError,transform:scratchMatrix4$2.copy(f).premultiply(d===`Z`?identityMatrix4:h).premultiply(enuToLocalMatrix).toArray(),boundingVolume:p?p.toJson():void 0,children:[c]},new Tile3D(s,{name:e.name,type:e.type,upAxis:u,light:e.light,fetcher:e.fetcher,search:o,groundHeight:m,coordinateSystem:{enuToEcefMatrix:g,ecefToEnuMatrix:h},error:r})})}function loadViewLayers(e,t){var n;let r=e.layers.map(e=>({tilesetUrl:e.work.getURL(e.tileset),name:e.name,type:e.type,upAxis:e.upAxis,light:t.light,fetcher:t.fetcher}));if(e.file){let o=!1;for(let e of r)if(e.type===`mesh`){o=!0;break}if(o===!1){let o=getExtname(e.file)||`.at3d`,s=JSON.stringify({tilesetUrl:``,asset:{version:`0.0`},geometricError:0,root:{refine:`REPLACE`,geometricError:0,transform:[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],content:{uri:e.work.getURL(e.file)},extras:{[o.slice(1)]:{upAxis:e.upAxis,textureBaseUri:typeof e.textureBase==`string`?e.work.getURL(e.textureBase):void 0,textureArray:e.textures,textureOptions:(n=t.textureOptions)==null?{}:n}}},rootMeta:{coordinate:e.coordinate}});r.push({name:`fallback`,type:`mesh`,upAxis:`Z`,tilesetUrl:URL.createObjectURL(new Blob([s],{type:`application/json`})),fetcher:t.fetcher,light:t.light})}}let o=r.map(e=>loadViewLayer(e).then(e=>e));return Promise.all(o)}function createSimpleBoxBufferGeometry(e=1,t=1,n=1){let r=e/2,o=t/2,s=n/2,c=new Float32Array([-r,+o,+s,+r,+o,+s,+r,+o,-s,-r,+o,-s,-r,-o,+s,+r,-o,+s,+r,-o,-s,-r,-o,-s]),l=new Uint32Array([0,4,1,1,4,5,1,5,2,2,5,6,2,6,3,3,6,7,3,7,0,0,7,4,3,0,2,2,0,1,4,7,5,5,7,6]),u=new three.BufferGeometry;return u.setAttribute(`position`,new three.BufferAttribute(c,3)),u.setIndex(new three.BufferAttribute(l,1)),u.addGroup(0,u.index.count,0),u.computeBoundingBox(),u.computeBoundingSphere(),u}function mergeBufferGeometries(e,t){for(var n=e[0].index!==null,r=new Set(Object.keys(e[0].attributes)),o=new Set(Object.keys(e[0].morphAttributes)),s={},c={},l=new three.BufferGeometry,u=0,d=0;d<e.length;++d){var f=e[d];if(n!==(f.index!==null))return null;for(var p in f.attributes){if(!r.has(p))return null;s[p]===void 0&&(s[p]=[]),s[p].push(f.attributes[p])}for(var p in f.morphAttributes){if(!o.has(p))return null;c[p]===void 0&&(c[p]=[]),c[p].push(f.morphAttributes[p])}if(l.userData.mergedUserData=l.userData.mergedUserData||[],l.userData.mergedUserData.push(f.userData),t){var m;if(n)m=f.index.count;else if(f.attributes.position!==void 0)m=f.attributes.position.count;else return null;l.addGroup(u,m,d),u+=m}}if(n){for(var h=0,g=[],d=0;d<e.length;++d){for(var _=e[d].index,v=0;v<_.count;++v)g.push(_.getX(v)+h);h+=e[d].attributes.position.count}l.setIndex(g)}for(var p in s){var y=mergeBufferAttributes(s[p]);if(!y)return null;l.setAttribute(p,y)}for(var p in c){var b=c[p][0].length;if(b===0)break;l.morphAttributes=l.morphAttributes||{},l.morphAttributes[p]=[];for(var d=0;d<b;++d){for(var S=[],v=0;v<c[p].length;++v)S.push(c[p][v][d]);var C=mergeBufferAttributes(S);if(!C)return null;l.morphAttributes[p].push(C)}}return l}function mergeBufferAttributes(e){for(var t,n,r,o=0,s=0;s<e.length;++s){var c=e[s];if(c.isInterleavedBufferAttribute||(t===void 0&&(t=c.array.constructor),t!==c.array.constructor)||(n===void 0&&(n=c.itemSize),n!==c.itemSize)||(r===void 0&&(r=c.normalized),r!==c.normalized))return null;o+=c.array.length}for(var l=new t(o),u=0,s=0;s<e.length;++s)l.set(e[s].array,u),u+=e[s].array.length;return new three.BufferAttribute(l,n,r)}function mergeVertices(e,t=1e-4){t=Math.max(t,Number.EPSILON);for(var n={},r=e.getIndex(),o=e.getAttribute(`position`),s=r?r.count:o.count,c=0,l=Object.keys(e.attributes),u={},d={},f=[],p=[`getX`,`getY`,`getZ`,`getW`],m=0,h=l.length;m<h;m++){var g=l[m];u[g]=[];var _=e.morphAttributes[g];_&&(d[g]=Array(_.length).fill().map(()=>[]))}for(var v=Math.log10(1/t),y=Math.pow(10,v),m=0;m<s;m++){for(var b=r?r.getX(m):m,S=``,C=0,h=l.length;C<h;C++)for(var g=l[C],w=e.getAttribute(g),T=w.itemSize,E=0;E<T;E++)S+=`${~~(w[p[E]](b)*y)},`;if(S in n)f.push(n[S]);else{for(var C=0,h=l.length;C<h;C++)for(var g=l[C],w=e.getAttribute(g),_=e.morphAttributes[g],T=w.itemSize,D=u[g],O=d[g],E=0;E<T;E++){var k=p[E];if(D.push(w[k](b)),_)for(var A=0,j=_.length;A<j;A++)O[A].push(_[A][k](b))}n[S]=c,f.push(c),c++}}let M=e.clone();for(var m=0,h=l.length;m<h;m++){var g=l[m],N=e.getAttribute(g),P=new N.array.constructor(u[g]),w=new three.BufferAttribute(P,N.itemSize,N.normalized);if(M.setAttribute(g,w),g in d)for(var C=0;C<d[g].length;C++){var F=e.morphAttributes[g][C],P=new F.array.constructor(d[g][C]),I=new three.BufferAttribute(P,F.itemSize,F.normalized);M.morphAttributes[g][C]=I}}return M.setIndex(f),M}var scratchSphere$1=new three.Sphere,scratchMatrix4$1=new three.Matrix4,scratchMatrix4Inverse=new three.Matrix4;function getEdgesBySphere(e,t,n=30/180*Math.PI){let r=Math.cos(n),o=[];for(let n of e.children)n instanceof Tile3D&&n.tileset.selectedTiles.forEach(e=>{var n,s,c;let l=(s=(n=e.content)==null?void 0:n.data)==null?void 0:s.object;if(l&&l.visible){let e=[];if(l.traverseVisible(n=>{if(n instanceof three.Mesh){let r=getBvhTreeForMesh(n);if(r){scratchMatrix4$1.copy(n.matrixWorld),scratchMatrix4Inverse.getInverse(scratchMatrix4$1),scratchSphere$1.copy(t).applyMatrix4(scratchMatrix4Inverse);let o=r.trianglesInSphere(scratchSphere$1.center,scratchSphere$1.radius),s=new three.BufferGeometry;s.setAttribute(`position`,new three.BufferAttribute(o,3)),s.applyMatrix4(n.matrixWorld),s=mergeVertices(s,.01),e.push(s)}}}),e.length===0)return;let n=[`a`,`b`,`c`],s=mergeBufferGeometries(e,!1),u=s.getAttribute(`position`).array,d=((c=s.getIndex())==null?void 0:c.array)||[],f=[],p=[];for(let e=0,t=u.length;e<t;e+=3){let t=new three.Vector3(u[e],u[e+1],u[e+2]);f.push(t)}for(let e=0,t=d.length;e<t;e+=3){let t=d[e],n=d[e+1],r=d[e+2],o=new three.Vector3().crossVectors(f[n].clone().sub(f[t]),f[r].clone().sub(f[t])).normalize();p.push({a:t,b:n,c:r,normal:o})}let m={};for(let e=0,t=p.length;e<t;e++){let t=p[e];for(let r=0;r<3;r++){let o=t[n[r]],s=t[n[(r+1)%3]],c=[Math.min(o,s),Math.max(o,s)],l=c[0]+`-`+c[1];m[l]===void 0?m[l]={index1:c[0],index2:c[1],face1:e}:m[l].face2=e}}for(let e in m){let t=m[e];if(t.face2===void 0||p[t.face1].normal.dot(p[t.face2].normal)<=r){let e=f[t.index1],n=f[t.index2];o.push(new three.Line3(e,n))}}f.length=0,p.length=0}});return o}var scratchBoundingBox$1=new three.Box3,scratchViewLayerBox=new three.Box3,scratchObserverBox$3=new three.Box3,Model=class extends three.Object3D{constructor(e,t,n={}){var r;super(),this.disposed=!1,this.parameter=new Parameter,this.outdated=!1,this.autoRefine=!0,this.metaPending=!1,this.loaded=!1,this.refined=!1,this.refineProgress=[0,0],this.boundingBox=new three.Box3,this.fiveId=e,this.needsRender=!1,this.work=t,this.name=t.workCode;let o=0;for(let e of t.observers)o=Math.max(o,e.floorIndex);if(this.floorLength=o+1,t.model){this.metaPending=!0;let e=loadViewLayers(t.model,{fetcher:getFetcher(this.fiveId,t),light:(r=n.light)==null?!1:r,textureOptions:n.textureOptions}),o=e=>this.dispatchEvent({type:`error`,error:e}),s=e=>this.dispatchEvent({type:`tileLoad`,tile:e}),c=e=>this.dispatchEvent({type:`tileUnload`,tile:e});this.initReady=e.then(e=>{var t;this.metaPending=!1;let n=null,r=null,l=null;for(let t of e){if(t.visible=!1,t.onError=o,t.onTileLoad=s,t.onTileUnload=c,t.error){o(t.error);continue}t.type===`mesh`?n===null&&(n=t):t.type===`point_cloud`?r===null&&(r=t):l===null&&(l=t)}let u=(t=n==null?r:n)==null?l:t;if(u&&(u.visible=!0),e.length)if(this.disposed)for(let t of e)t.dispose();else this.add(...e);return this}),this.loadedReady=new Promise(e=>{let t=()=>{e(this),this.removeEventListener(`load`,t),this.removeEventListener(`dispose`,t)};this.addEventListener(`load`,t),this.addEventListener(`dispose`,t)})}else this.refined=!0,this.loaded=!0,this.initReady=Promise.resolve(this),this.loadedReady=Promise.resolve(this);this.parameter.set(`boundingBox`,this.boundingBox.clone())}dispose(){this.disposed=!0;let e;for(;e=this.children[0];)typeof e.dispose==`function`&&e.dispose(),e.onError=void 0,e.onTileLoad=void 0,e.onTileUnload=void 0,this.remove(e);this.dispatchEvent({type:`dispose`})}get empty(){return this.children.length===0}get viewLayers(){return this.children}getEdgesBySphere(e,t=30/180*Math.PI){return getEdgesBySphere(this,e,t)}intersectRaycaster(e,t){let n=t==null?[]:t,r=e.sortByDistance;e.sortByDistance=!1;for(let t=0,r=this.children.length;t<r;t++){let r=this.children[t];r.visible&&typeof r.intersectRaycaster==`function`&&r.intersectRaycaster(e,n)}return e.sortByDistance=r,sortIntersects(n,e.sortByDistance,e.firstHitOnly),n}update(e,t,n){let r=!1;this.needsRender===!0&&(this.needsRender=!1,r=!0);let o=this.loaded;this.refined=!this.metaPending,this.loaded=!this.metaPending,this.refineProgress[0]=this.refineProgress[1]=0,this.work.transform.equals(this.matrix)||(this.matrix.copy(this.work.transform),this.matrix.decompose(this.position,this.quaternion,this.scale),this.matrixAutoUpdate=!1,r=!0);for(let o of this.children)o.autoRefine=this.autoRefine,o.update(e,t,n,this)&&(r=!0),o.refined===!1&&(this.refined=!1),o.loaded===!1&&(this.loaded=!1),this.refineProgress[0]+=o.refineProgress[0],this.refineProgress[1]+=o.refineProgress[1];scratchBoundingBox$1.makeEmpty(),scratchObserverBox$3.copy(this.work.observerBox),scratchObserverBox$3.isEmpty()||(scratchObserverBox$3.max.x+=1,scratchObserverBox$3.max.z+=1,scratchObserverBox$3.max.y+=1,--scratchObserverBox$3.min.x,--scratchObserverBox$3.min.z,scratchBoundingBox$1.union(scratchObserverBox$3));for(let e of this.viewLayers)e.boundingBox.isEmpty()||(scratchViewLayerBox.copy(e.boundingBox),scratchBoundingBox$1.union(scratchViewLayerBox));return scratchBoundingBox$1.applyMatrix4(this.matrix),scratchBoundingBox$1.equals(this.boundingBox)||(this.boundingBox.copy(scratchBoundingBox$1),this.parameter.set(`boundingBox`,scratchBoundingBox$1.clone())),o===!1&&this.loaded===!0&&this.dispatchEvent({type:`load`}),r}localToEnu(e){return e.applyMatrix4(localToEnuMatrix)}enuToLocal(e){return e.applyMatrix4(enuToLocalMatrix)}worldToEnu(e){return this.localToEnu(this.worldToLocal(e))}enuToWorld(e){return this.localToWorld(this.enuToLocal(e))}get shownFloor(){return this.shownFloorIndex===-1?null:this.shownFloorIndex}set shownFloor(e){this.shownFloorIndex=e===null?-1:e}show(e){this.shownFloor=e==null?null:e,this.dispatchEvent({type:`changeShownFloor`,floorIndex:e==null?null:e})}get bounding(){return this.boundingBox}setMaterial(e){this.parameter.set(e)}getMaterial(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&e.unshift(this.parent.parameter),this.parameter.resolveValue(...e)}get shownFloorIndex(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&e.unshift(this.parent.parameter),this.parameter.resolveValue(...e).shownFloorIndex}set shownFloorIndex(e){this.parameter.set(`shownFloorIndex`,e)}get brightness(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&e.unshift(this.parent.parameter),this.parameter.resolveValue(...e).brightness}set brightness(e){this.parameter.set(`brightness`,e)}get clippers(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&e.unshift(this.parent.parameter),this.parameter.resolveValue(...e).clippers}set clippers(e){this.parameter.set(`clippers`,e)}get customShaders(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&e.unshift(this.parent.parameter),this.parameter.resolveValue(...e).customShaders}set customShaders(e){this.parameter.set(`customShaders`,e)}resetBrightness(){this.parameter.reset(`brightness`);for(let e of this.viewLayers)e.resetBrightness()}},scratchGeometry=createSimpleBoxBufferGeometry(1,1,1);scratchGeometry.applyMatrix4(new three.Matrix4().makeScale(-1,1,1));var versionMap=new WeakMap,cameraBoxSize=new three.Vector3(1,1,1),scratchBoundingBox=new three.Box3,scratchBoundingBoxSize=new three.Vector3,scratchCameraBox=new three.Box3,scratchPosition=new three.Vector3,scratchScale=new three.Vector3,BoundingMesh=class extends PBMMesh{constructor(e={}){var t;let n=new PBMMeshMaterial(`none`);n.flatShading=!0,n.depthWrite=!1,n.transparent=!1,n.blending=three.CustomBlending,n.blendSrc=three.SrcAlphaFactor,n.blendDst=three.OneMinusSrcAlphaFactor,n.blendSrcAlpha=three.OneFactor,n.blendDstAlpha=three.OneMinusSrcAlphaFactor,n.floorIndex=-1,super(scratchGeometry,[n]),this.name=(t=e.name)==null?``:t,this.frustumCulled=!1,this.renderOrder=-999999}update(e,t,n){var r,o;let s=!1,c=Parameter.resolveValue(n.parameter);scratchBoundingBox.copy(c.boundingBox),scratchBoundingBox.getSize(scratchBoundingBoxSize);let l=Math.min(scratchBoundingBoxSize.x/2,500);scratchBoundingBox.min.x-=l,scratchBoundingBox.max.x+=l;let u=Math.min(scratchBoundingBoxSize.y/2,500);scratchBoundingBox.min.z-=u,scratchBoundingBox.max.z+=u;let d=scratchBoundingBoxSize.length()/2;if(scratchBoundingBox.max.y=Math.max(scratchBoundingBox.max.y,d),scratchBoundingBox.union(scratchCameraBox.setFromCenterAndSize(t.position,cameraBoxSize)),scratchBoundingBox.expandByScalar(1),scratchBoundingBox.getCenter(scratchPosition),scratchBoundingBox.getSize(scratchScale),scratchPosition.equals(this.position)||(this.position.copy(scratchPosition),s=!0),scratchScale.equals(this.scale)||(this.scale.copy(scratchScale),s=!0),versionMap.get(this)!==c.version){versionMap.set(this,c.version),s=!0;let e=this.material;for(let t of e)t.customShaders=c.customShaders,t.pano0=c.pano0,t.pano1=c.pano1,t.panoFilter=(o=(r=c.panoFilter)==null?void 0:r.toValue())==null?null:o,t.refinedScreen=c.refinedScreen,t.modelAlpha=c.modelAlpha,t.progress=c.progress,t.transition=c.transition,t.opacity=c.opacity,t.floorStyle=c.floorStyle,t.constantColor=c.constantColor,t.shownFloorIndex=c.shownFloorIndex,t.clippers=c.clippers,t.brightness=c.brightness,t.useHQWeight=c.useHQWeight,t.useHQDepth=c.useHQDepth,t.colorSaturation=c.colorSaturation,t.colorBrightness=c.colorBrightness,t.gradientTexture=c.gradientTexture,t.transparent=!1,t.modelBoundingMax.copy(c.boundingBox.max),t.modelBoundingMin.copy(c.boundingBox.min),c.useAddBlend&&(t.opacity=0),t.opacity===0&&(t.visible=!1)}return s}dispose(){for(let e of this.material)e.dispose(),e.pano0=null,e.pano1=null}},scratchBoundingBox3=new three.Box3,ModelScene=class extends three.Scene{constructor(e){super(),this.needsRender=!0,this.autoRefine=!0,this.boundingBox=new three.Box3,this.loaded=!1,this.refined=!1,this.refineProgress=[0,0],this.parameter=new Parameter,this.fiveId=e.fiveId,this.boundingMesh=new BoundingMesh({name:`bounding`}),this.add(this.boundingMesh);let t=this.models=[];this.shownModels=[],this.updateModelMap=new Map,this.parameter.set(`boundingBox`,this.boundingBox.clone());let n=this;defineProperty(t,`autoUpdate`,{get(){return n.autoRefine},set(e){n.autoRefine=e}}),defineProperty(t,`bounding`,{get(){return n.boundingBox}}),defineProperty(t,`loaded`,{get(){return n.loaded}}),defineProperty(t,`refined`,{get(){return n.refined}}),defineProperty(t,`refineProgress`,{get(){return n.refineProgress}}),defineProperty(t,`cacheCameras`,{get(){return n.parameter.resolveValue().cacheCameras},set(e){n.parameter.set(`cacheCameras`,e)}}),defineProperty(t,`intersectRaycaster`,{value:e=>n.intersectRaycaster(e)}),defineProperty(t,`setMaterial`,{value:e=>n.setMaterial(e)}),defineProperty(t,`getMaterial`,{value:()=>n.getMaterial()}),defineProperty(t,`resetBrightness`,{value:()=>n.resetBrightness()})}setModels(e,t){let n=e.map(e=>{let n=this.shownModels.filter(t=>t.work.workCode===e.workCode)[0];if(n||(n=this.models.filter(t=>t.work.workCode===e.workCode)[0],n))return n.work=e,n;n=new Model(this.fiveId,e,{light:t.light,textureOptions:t.textureOptions});let r=t[`3d-tiles`];return n.initReady.then(()=>{if(r)if(typeof r==`function`)for(let e of n.viewLayers){let t=r(e,n);t&&(t.viewerRequestVolume&&(e.viewerRequestVolume=makeBoundingVolume(t.viewerRequestVolume)),e.parameter.set(omit(t,[`showLayers`])),t.showLayers===!1?e.visible=!1:Array.isArray(t.showLayers)&&(e.visible=t.showLayers.includes(e.name)))}else for(let e of n.viewLayers)r.viewerRequestVolume&&(e.viewerRequestVolume=makeBoundingVolume(r.viewerRequestVolume)),e.parameter.set(omit(r,[`showLayers`])),r.showLayers===!1?e.visible=!1:Array.isArray(r.showLayers)&&(e.visible=r.showLayers.includes(e.name))}),this.dispatchEvent({type:`model.create`,model:n}),n});for(let e=0;e<this.models.length;e++){let t=this.models[e];n.indexOf(t)===-1&&this.shownModels.indexOf(t)===-1&&(t.dispose(),this.dispatchEvent({type:`model.dispose`,model:t}))}this.models.length=0;for(let e=0;e<n.length;e++){let t=n[e];this.models.push(t)}if(t.forceReplaceImmediately&&!arrayEqual(this.models,this.shownModels)){for(let e=0;e<this.shownModels.length;e++){let t=this.shownModels[e];this.models.indexOf(t)===-1&&(t.dispose(),this.dispatchEvent({type:`model.dispose`,model:t}))}this.shownModels.length=0;for(let e=0;e<this.models.length;e++)this.shownModels.push(this.models[e])}return this.loaded=!1,this.refined=!1,this.models}get empty(){return this.boundingBox.isEmpty()}intersectRaycaster(e,t){let n=t==null?[]:t,r=this.shownModels.filter(e=>e.visible);if(r.length===1)r[0].intersectRaycaster(e,n);else{let t=e.sortByDistance;e.sortByDistance=!1;for(let t of r)t.intersectRaycaster(e,n);e.sortByDistance=t,sortIntersects(n,e.sortByDistance,e.firstHitOnly)}return n}update(e,t){let n=!1;scratchBoundingBox3.makeEmpty(),this.loaded=this.models.length>0,this.refined=this.models.length>0,this.refineProgress[0]=this.refineProgress[1]=0,this.updateModelMap.clear();for(let n=0;n<this.models.length;n++){let r=this.models[n];if(!this.updateModelMap.has(r)){let n=r.autoRefine;this.autoRefine===!1&&(r.autoRefine=!1);let o=r.update(e,t,this);r.autoRefine=n,this.updateModelMap.set(r,o)}r.loaded===!1&&(this.loaded=!1),r.refined===!1&&(this.refined=!1),this.refineProgress[0]+=r.refineProgress[0],this.refineProgress[1]+=r.refineProgress[1]}if((this.loaded===!0||this.models.length===0)&&!arrayEqual(this.models,this.shownModels)){for(let e=0;e<this.shownModels.length;e++){let t=this.shownModels[e];this.models.indexOf(t)===-1&&(t.dispose(),this.dispatchEvent({type:`model.dispose`,model:t}))}this.shownModels.length=0;for(let e=0;e<this.models.length;e++)this.shownModels.push(this.models[e]);n=!0}for(let n=0;n<this.shownModels.length;n++){let r=this.shownModels[n];if(!this.updateModelMap.has(r)){let n=r.autoRefine;(this.autoRefine===!1||this.models.indexOf(r)<0)&&(r.autoRefine=!1);let o=r.update(e,t,this);r.autoRefine=n,this.updateModelMap.set(r,o)}}for(let e=this.children.length-1;e>=0;e--){let t=this.children[e];t instanceof Model&&this.remove(t)}for(let e=0;e<this.shownModels.length;e++){let t=this.shownModels[e];this.updateModelMap.get(t)===!0&&(n=!0),scratchBoundingBox3.union(t.boundingBox),this.add(t)}for(let e=0;e<this.models.length;e++){let t=this.models[e];this.shownModels.indexOf(t)===-1&&scratchBoundingBox3.union(t.boundingBox)}return scratchBoundingBox3.equals(this.boundingBox)||(this.boundingBox.copy(scratchBoundingBox3),this.parameter.set(`boundingBox`,this.boundingBox.clone()),n=!0),this.boundingMesh.update(e,t,this)&&(n=!0),this.updateModelMap.clear(),this.needsRender=n,n}get bounding(){return this.boundingBox}setMaterial(e){this.parameter.set(e)}getMaterial(){return this.parameter.resolveValue()}resetBrightness(){this.parameter.reset(`brightness`);for(let e of this.models)e.resetBrightness()}dispose(){this.remove(this.boundingMesh),this.boundingMesh.dispose();for(let e=this.children.length-1;e>=0;e--){let t=this.children[e];t instanceof Model&&this.remove(t)}let e=arrayUnique(this.models.concat(this.shownModels));for(let t=0;t<this.shownModels.length;t++)e[t].dispose();this.models.length=0,this.shownModels.length=0,super.dispose()}};function workInitialToJson(e){let t={};return e.mode!==void 0&&(t.mode=e.mode),e.panoIndex!==void 0&&(t.pano_index=e.panoIndex),e.longitude!==void 0&&(t.longitude=e.longitude),e.latitude!==void 0&&(t.latitude=e.latitude),e.fov!==void 0&&(t.fov=e.fov),e.distance!==void 0&&(t.distance=e.distance),e.offset!==void 0&&(t.offset=e.offset.toArray()),t}function workModelToJson(e){var t;if(e)return{file_url:e.file,material_base_url:e.textureBase,material_textures:(t=e.textures)==null?void 0:t.slice(),up_axis:e.upAxis,layers:e.layers.map(e=>({tileset_url:e.tileset,up_axis:e.upAxis,name:e.name,type:e.type}))}}function workObserverToObserverJson(e){return{index:e.index,derived_id:e.derivedId,derived_id_str:e.derivedIdStr,floor_index:e.floorIndex,position:e.position.toArray(),standing_position:e.standingPosition.toArray(),quaternion:{x:e.quaternion.x,y:e.quaternion.y,z:e.quaternion.z,w:e.quaternion.w},visible_nodes:e.accessibleNodes.slice(),accessible_nodes:e.accessibleNodes.slice()}}function workObserverToPanoramaJson(e){return{index:e.index,active:e.active,loadable:e.loadable,derived_id:e.derivedId,derived_id_str:e.derivedIdStr,size_list:e.images.sizeList.slice(),up:e.images.up,down:e.images.down,right:e.images.right,left:e.images.left,front:e.images.front,back:e.images.back,video:e.images.video?{matrix:e.images.video.matrix.toArray(),size:e.images.video.size.toArray(),source:e.images.video.source}:void 0}}function workToJson(e){return{allow_hosts:e.allowHosts.slice(),expire_at:e.expire.getTime().toString(),project_id:e.projectId,code:e.workCode,name:e.name,base_url:e.baseURL,initial:workInitialToJson(e.initial),model:workModelToJson(e.model),observers:e.observers.map(e=>workObserverToObserverJson(e)),panorama:{count:e.observers.length,list:e.observers.map(e=>workObserverToPanoramaJson(e))}}}function equirectangularUvToCubemap(e){let t=(e.x*2+1)*Math.PI,n=(.5-e.y)*Math.PI,r=Math.sin(n),o=Math.cos(n),s=Math.sin(t),c=Math.cos(t),l=o*s,u=r,d=o*c,f=Math.abs(l),p=Math.abs(u),m=Math.abs(d),h,g;if(f>=p&&f>=m){let e=1/f;l>0?(h=`right`,g=new three.Vector2(-d*e,u*e)):(h=`left`,g=new three.Vector2(d*e,u*e))}else if(p>=f&&p>=m){let e=1/p;u>0?(h=`up`,g=new three.Vector2(l*e,-d*e)):(h=`down`,g=new three.Vector2(l*e,d*e))}else{let e=1/m;d>0?(h=`front`,g=new three.Vector2(l*e,u*e)):(h=`back`,g=new three.Vector2(-l*e,u*e))}return g.x=(g.x+1)/2,g.y=1-(g.y+1)/2,[h,g]}function cubemapUvToEquirectangular(e,t){let n=t.x*2-1,r=(1-t.y)*2-1,o=0,s=0,c=0;switch(e){case`right`:o=1,s=r,c=-n;break;case`left`:o=-1,s=r,c=n;break;case`up`:o=n,s=1,c=-r;break;case`down`:o=n,s=-1,c=r;break;case`front`:o=n,s=r,c=1;break;case`back`:o=-n,s=r,c=-1;break;default:throw Error(`Invalid cubFace: ${e}`)}let l=Math.sqrt(o*o+s*s+c*c);if(l===0)return new three.Vector2(.5,.5);o/=l,s/=l,c/=l;let u=Math.atan2(o,c),d=Math.asin(Math.max(-1,Math.min(1,s))),f=(u+Math.PI)/(2*Math.PI),p=(Math.PI/2-d)/Math.PI;return f%=1,f=f<0?f+1:f,p=Math.max(0,Math.min(1,p)),new three.Vector2(f,p)}function vectorToEquirectangularUv(e,t=`top-left`){let n=new three.Quaternion().setFromRotationMatrix(this.work.transform).inverse(),r=new three.Quaternion().copy(this.quaternion).inverse(),o=new three.Quaternion(0,1,0,0).inverse(),s=new three.Vector3().copy(e).normalize().applyQuaternion(n).applyQuaternion(r).applyQuaternion(o),c=Math.atan2(s.x,-s.z),l=Math.asin(-s.y);if(t===`top-left`)return new three.Vector2(c/(Math.PI*2)+.5,l/Math.PI+.5);if(t===`bottom-left`)return new three.Vector2(c/(Math.PI*2)+.5,.5-l/Math.PI);throw Error(`Invalid uvOrigin ${t}`)}function equirectangularUvToVector(e,t=`top-left`){let n=0;if(t===`top-left`)n=1;else if(t===`bottom-left`)n=-1;else throw Error(`Invalid uvOrigin ${t}`);let r=new three.Quaternion().setFromRotationMatrix(this.work.transform),o=new three.Quaternion().copy(this.quaternion),s=new three.Quaternion(0,1,0,0),c=Math.PI*2*(e.x+.5),l=Math.PI*(e.y-.5),u=Math.abs(Math.cos(l)),d=Math.sin(c)*u,f=-Math.sin(l)*n,p=-Math.cos(c)*u;return new three.Vector3(d,f,p).applyQuaternion(s).applyQuaternion(o).applyQuaternion(r)}function vectorToCubemapUv(e,t=`top-left`){let n=equirectangularUvToCubemap(this.vectorToEquirectangularUv(e,`top-left`));if(t===`top-left`)return n;if(t===`bottom-left`){let[e,t]=n;return t.y=1-t.y,n}else throw Error(`Invalid uvOrigin ${t}`)}function cubemapUvToVector(e,t,n=`top-left`){let r;if(n===`top-left`)r=t;else if(n===`bottom-left`)r=new three.Vector2().copy(t),r.y=1-r.y;else throw Error(`Invalid uvOrigin ${n}`);let o=cubemapUvToEquirectangular(e,r);return this.equirectangularUvToVector(o)}function getWorldPosition(){return new three.Vector3().copy(this.position).applyMatrix4(this.work.transform)}function getWorldStandingPosition(){return new three.Vector3().copy(this.standingPosition).applyMatrix4(this.work.transform)}function isNumber(e){return typeof e==`number`}function jsonClone(e){if(typeof e!=`object`||!e)return e;if(Array.isArray(e))return e.map(e=>typeof e!=`object`||!e?e:jsonClone(e));{let t={};for(let n in e){let r=e[n];t[n]=typeof r!=`object`||!r?r:jsonClone(r)}return t}}function getType(e){return e==null?`null`:Array.isArray(e)?`array`:typeof e==`object`?`dict`:`value`}function jsonMerge(e,t){let n=getType(e),r=getType(t);if(r===`null`)return e;if(r===`value`)return t;if(r!==n)return jsonClone(t);if(r===`array`)for(let n=0;n<t.length;n++)e[n]=jsonMerge(e[n],t[n]);else if(r===`dict`)for(let n in t)e[n]=jsonMerge(e[n],t[n]);return e}function jsonStableStrinfiy_(e,t=!1){let n=typeof e;if(n===`string`)return JSON.stringify(e);if(e===!0)return`true`;if(e===!1)return`false`;if(e===null)return`null`;if(e instanceof Array){let t=`[`,n=e.length-1,r=0;for(;r<n;r++)t+=jsonStableStrinfiy_(e[r],!1)+`,`;return n>-1&&(t+=jsonStableStrinfiy_(e[r],!1)),t+`]`}if(e instanceof Object){if(typeof e.toJSON==`function`)return jsonStableStrinfiy_(e.toJSON(),t);let n=Object.keys(e).sort(),r=n.length,o=``,s=0;for(;s<r;){let t=n[s],r=jsonStableStrinfiy_(e[t],!0);r!==void 0&&(s&&o!==``&&(o+=`,`),o+=JSON.stringify(t)+`:`+r),s++}return`{`+o+`}`}switch(n){case`function`:return JSON.stringify(e.toString());case`undefined`:return t?void 0:null;case`number`:return e;default:return isFinite(e)?e:null}}function jsonStableStrinfiy(e){return jsonStableStrinfiy_(e,!1)}function jsonHash(e){return`hash::${sha256(jsonStableStrinfiy(e))}`}var PANO_ID_REG=/^(.*)\[(\d+)\]$/;function panoStringify(e){if(!isNaN(e.panoIndex)&&isFinite(e.panoIndex))return`${e.workCode}[${e.panoIndex}]`;throw Error(`Invalid Pano`)}function panoParse(e){let t=e.match(PANO_ID_REG);if(t){let[e,n,r]=t,o=Math.floor(Number(r));if(!isNaN(o)&&isFinite(o))return{workCode:n,panoIndex:o}}throw Error(`Invalid PanoId`)}function panoEqual(e,t){return panoStringify(e)===panoStringify(t)}function isPanoId(e){return typeof e==`string`&&PANO_ID_REG.test(e)}var REG_STR=`\\{([^\\}]+)\\}`;function escapeRegexp(e){return e.replace(/[|\\{}()[\]^$+*?.]/g,`\\$&`).replace(/-/g,`\\x2d`)}function createRegExp(e){return RegExp(`^`+e.map(e=>escapeRegexp(e)).join(`(.+)`)+`$`)}var StringPattern=class{constructor(e){this.strings=[],this.keys=[];let t=new RegExp(REG_STR,`g`),n,r=0;for(;(n=t.exec(e))!==null;)this.strings.push(e.slice(r,n.index)),this.keys.push(n[1]),r=n.index+n[0].length;this.strings.push(e.slice(r))}stringify(e){let t=[this.strings[0]];for(let n=0;n<this.keys.length;n++){let r=e[this.keys[n]];t.push(String(r),this.strings[n+1])}return t.join(``)}match(e){var t;this.matchRegexp=(t=this.matchRegexp)==null?createRegExp(this.strings):t;let n=e.match(this.matchRegexp);if(!n)return null;let r={};for(let e=0;e<this.keys.length;e++){let t=this.keys[e],o=n[e+1];if(r[t]!==o){if(r[t]!==void 0)return null;r[t]=o}}return r}};function deepFreeze(e){Object.freeze(e);let t=typeof e==`function`,n=Object.prototype.hasOwnProperty;return Object.getOwnPropertyNames(e).forEach(function(r){n.call(e,r)&&(!t||r!==`caller`&&r!==`callee`&&r!==`arguments`)&&e[r]!==null&&(typeof e[r]==`object`||typeof e[r]==`function`)&&!Object.isFrozen(e[r])&&deepFreeze(e[r])}),e}var URL_REGEXP=/^[0-9a-z]+\:\/\/(([^:/?#]*)(?::[0-9]+)?)/i,BUILDIN_ALLOW_HOST=deepFreeze(JSON.parse(function(...e){let t=113,n=126,r=0,o=``;return arguments[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}(`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/rnyrr;p{/9/rnyrr;p|z/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`))),domainRegex=/^([^.]+)(\.([^.]+))*$/,currentHostname=typeof location<`u`?location.hostname:`localhost`;function isIPDomain(e){return/^(([1-9]?\d|1\d\d|2[0-4]\d|25[0-5])(\.(?!$)|$)){4}$/.test(e)}function matchDomain(e,t){if(!domainRegex.test(e)||!domainRegex.test(t))return!1;if(e===`*`)return!0;let n=e.split(`.`).reverse(),r=t.split(`.`).reverse();if(n.length<=1)return e===t;for(let e=0;e<n.length;e++)if(n[e]!==r[e])return!1;return!0}function hostnameFromURL(e){if(/^blob\:/i.test(e)||/^data\:/i.test(e))return currentHostname;let t=e.match(URL_REGEXP);return t?t[2]:currentHostname}var error_invalid_input=()=>Error(`Invalid input.`),error_invalid_certificate=()=>Error(`Invalid certificate.`),error_invalid_signature=()=>Error(`Invalid signature.`),error_date_expired=e=>Error(`Date(${e.toString()}) expired.`),error_host_not_allowed=e=>Error(`Host(${JSON.stringify(e)}) is not allowed.`);function ObjectOmit(e,t){let n={};for(let r of Object.keys(e))t.indexOf(r)===-1&&(n[r]=e[r]);return n}function jsonStableNoneNumberStrinfiy_(e,t=!1){let n=typeof e;if(n===`string`)return JSON.stringify(e);if(e===!0)return`true`;if(e===!1)return`false`;if(e===null)return`null`;if(e instanceof Array){let t=`[`,n=e.length-1,r=0;for(;r<n;r++)t+=jsonStableNoneNumberStrinfiy_(e[r],!1)+`,`;return n>-1&&(t+=jsonStableNoneNumberStrinfiy_(e[r],!1)),t+`]`}if(e instanceof Object){if(typeof e.toJSON==`function`)return jsonStableNoneNumberStrinfiy_(e.toJSON(),t);let n=Object.keys(e).sort(),r=n.length,o=``,s=0;for(;s<r;){let t=n[s],r=jsonStableNoneNumberStrinfiy_(e[t],!0);r!==void 0&&(s&&o!==``&&(o+=`,`),o+=JSON.stringify(t)+`:`+r),s++}return`{`+o+`}`}switch(n){case`function`:case`undefined`:return t?void 0:null;case`number`:return 0;default:return isFinite(e)?e:null}}function jsonStableNoneNumberStrinfiy(e){return String(jsonStableNoneNumberStrinfiy_(e,!1))}function verify(e){var t,n,r;let o={};try{o=typeof e==`string`?JSON.parse(e):e}catch(e){return error_invalid_input()}if(typeof o!=`object`)return error_invalid_input();let s=currentHostname,c=Date.now(),l=new Date(typeof o.expire_at==`string`&&/^\d+$/.test(o.expire_at)?Number(o.expire_at):o.expire_at),u=Array.isArray(o.allow_hosts)?o.allow_hosts:[];if(s.length===0||isIPDomain(s)||BUILDIN_ALLOW_HOST.filter(e=>matchDomain(e,s)).length>0){let e=String((t=o.certificate)==null?``:t);if(e)try{let t=new X509;return t.readCertPEM(e),deepFreeze({issuer:t.getSubjectString(),expire:l,allowHosts:u})}catch(e){let t=e instanceof Error?e.message:String(e);console.warn(`[PARSE Error]: Invalid Certificate. `+t)}return deepFreeze({issuer:`none`,expire:l,allowHosts:u})}let d=String((n=o.certificate)==null?``:n);if(!d)return error_invalid_certificate();let f=new X509;f.readCertPEM(d);let p=String((r=o._signature)==null?``:r);return!p||verifyMessage(jsonStableNoneNumberStrinfiy(ObjectOmit(o,[`_signature`])),p,f)===!1?error_invalid_signature():c<l.getTime()?BUILDIN_ALLOW_HOST.concat(u).filter(e=>matchDomain(e,s)).length===0?error_host_not_allowed(s):deepFreeze({issuer:f.getSubjectString(),expire:l,allowHosts:u}):error_date_expired(l)}function verifyURL(e,t){let n=hostnameFromURL(e);return currentHostname.length!==0&&!isIPDomain(currentHostname)&&BUILDIN_ALLOW_HOST.filter(e=>matchDomain(e,currentHostname)).length===0&&!isIPDomain(n)&&BUILDIN_ALLOW_HOST.concat(t).filter(e=>matchDomain(e,n)).length===0?error_host_not_allowed(n):e}var accessibleNodesSet=new Set,PANO_TEXTURE_SCALE=new three.Vector3(1,1,1),FACE_ORDER$1=[`right`,`left`,`up`,`down`,`front`,`back`],workObserverProto={vectorToEquirectangularUv,vectorToCubemapUv,equirectangularUvToVector,cubemapUvToVector,getWorldPosition,getWorldStandingPosition};function relativeURL(e,t){if(!isAbsoluteURL(e))return e;if(e.indexOf(t)===0)return e.slice(t.length);let n=t.replace(/^https\:/,`http:`);if(e.indexOf(n)===0)return e.slice(n.length);let r=t.replace(/^http\:/,`https:`);return e.indexOf(r)===0?e.slice(r.length):(console.warn(`${e} is not start with base_url(${t}).`),e)}function panoURL(e,t,n){return!isAbsoluteURL(e)&&typeof t==`string`&&t.length>0&&(e=pathJoin(t,String(n),e)),e}function getTileLevel(e){for(let t=10;t>=0;t--)if(512*Math.pow(2,t)<=e)return t;return null}function sortTile(e){e=e.slice().sort((e,t)=>e.level-t.level);let t=[];for(let n of e){if(t.length===0){t.push(n);continue}let e=t[t.length-1];if(n.level>e.level){t.push(n);continue}if(n.size>e.size){t[t.length-1]=n;continue}}return t}function parse(e,t){var n,r,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b,S,C;let w=[],T=null;for(let t of[].concat(e))if(`getURL`in t)T={allowHosts:t.allowHosts,expire:t.expire,issuer:t.issuer},w.push(workToJson(t));else{let e=typeof t==`string`?JSON.parse(t):jsonClone(t),n=verify(e);if(n instanceof Error)return n;T===null&&(T=n),w.push(e)}if(T===null)return Error(`Empty`);defineProperty(t,`issuer`,{enumerable:!0,configurable:!1,writable:!1,value:T.issuer}),defineProperty(t,`expire`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(T.expire)}),defineProperty(t,`allowHosts`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(T.allowHosts)});let E=w.reduce((e,t)=>jsonMerge(e,t));defineProperty(t,`name`,{enumerable:!0,configurable:!1,writable:!1,value:String((n=E.name)==null?`Unknown`:n)}),defineProperty(t,`workCode`,{enumerable:!0,writable:!0,value:String(E.resource_code||E.basic_code||E.vr_code||E.code||E.project_id||E.work_code||E.workCode||createUuid())}),defineProperty(t,`projectId`,{enumerable:!0,writable:!0,value:E.project_id}),defineProperty(t,`baseURL`,{enumerable:!0,writable:!0,value:(()=>{var e;let t=(e=E.base_url)==null?``:e;return t&&t[t.length-1]!==`/`&&(t+=`/`),t})()});let D;typeof E.model==`object`&&(D={},defineProperty(D,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(D,`file`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e=E.model.file_url;if(e)return relativeURL(e,t.baseURL)})()}),defineProperty(D,`textureBase`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e=E.model.material_base_url;return e&&(e=relativeURL(e,t.baseURL)),e})()}),defineProperty(D,`textures`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e;return Array.isArray(E.model.material_textures)&&(e=E.model.material_textures.slice(),Object.freeze(e)),e})()}),defineProperty(D,`upAxis`,{enumerable:!0,configurable:!1,writable:!1,value:E.model.up_axis}),defineProperty(D,`coordinate`,{enumerable:!0,configurable:!1,writable:!1,value:jsonClone(E.model.coordinate)}),defineProperty(D,`layers`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{var e,n,r;let o=[];if(Array.isArray(E.model.layers)){for(let s of E.model.layers)if(s&&s.tileset_url){let c={};defineProperty(c,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(c,`name`,{enumerable:!0,configurable:!1,writable:!1,value:(e=s.name)==null?``:e}),defineProperty(c,`type`,{enumerable:!0,configurable:!1,writable:!1,value:(n=s.type)==null?`mesh`:n}),defineProperty(c,`upAxis`,{enumerable:!0,configurable:!1,writable:!1,value:(r=s.up_axis)==null?`Z`:r}),defineProperty(c,`tileset`,{enumerable:!0,configurable:!1,writable:!1,value:relativeURL(s.tileset_url,t.baseURL)}),o.push(c)}}if(typeof E.model.tiles==`object`){let e=E.model.tiles;if(e&&e.tileset_url){let n={};defineProperty(n,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(n,`name`,{enumerable:!0,configurable:!1,writable:!1,value:`lod`}),defineProperty(n,`type`,{enumerable:!0,configurable:!1,writable:!1,value:`mesh`}),defineProperty(n,`upAxis`,{enumerable:!0,configurable:!1,writable:!1,value:`-Y`}),defineProperty(n,`tileset`,{enumerable:!0,configurable:!1,writable:!1,value:relativeURL(e.tileset_url,t.baseURL)}),o.push(n)}}return Object.freeze(o)})()})),defineProperty(t,`model`,{enumerable:!0,configurable:!1,writable:!1,value:D});let O=[];if(Array.isArray(E.observers)&&E.panorama&&Array.isArray(E.panorama.list||E.panorama.info)){let e=E.observers,n=(r=E.panorama.list||E.panorama.info)==null?[]:r,w=(d=(l=(s=(o=E.panorama)==null?void 0:o.pano_high_cube_base_url)==null?(c=E.panorama)==null?void 0:c.pano_cube_base_url:s)==null?(u=E.panorama)==null?void 0:u.base_url:l)==null?``:d,T=Math.min(e.length,n.length),D={};for(let e of Object.keys((f=E.panorama.pattern)==null?{}:f)){let t=e,n=E.panorama.pattern[t];if(typeof n==`string`){let e=new StringPattern(n);D[t]=t=>e.stringify(t)}else D[t]=()=>n}let k=(e,t)=>{var n;let r=D[t];return(n=e[t])==null?r?r(e):void 0:n};for(let r=0;r<T;r++){let o=e[r],s=n[r],c=Object.create(workObserverProto);defineProperty(c,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(c,`index`,{enumerable:!0,configurable:!1,writable:!1,value:r}),defineProperty(c,`panoIndex`,{enumerable:!0,configurable:!1,writable:!1,value:r}),defineProperty(c,`panoId`,{enumerable:!0,configurable:!1,writable:!1,value:panoStringify({workCode:t.workCode,panoIndex:r})}),defineProperty(c,`floorIndex`,{enumerable:!0,configurable:!1,writable:!1,value:(p=o.floor_index)==null?o.floor:p}),defineProperty(c,`derivedId`,{enumerable:!0,configurable:!1,writable:!1,value:(h=(m=o.derived_id)==null?k(s,`derived_id`):m)==null?0:h}),defineProperty(c,`derivedIdStr`,{enumerable:!0,configurable:!1,writable:!1,value:(_=(g=o.derived_id_str)==null?k(s,`derived_id_str`):g)==null?String(c.derivedId):_}),defineProperty(c,`active`,{enumerable:!0,configurable:!1,writable:!1,value:o.active!==!1&&k(s,`active`)!==!1}),defineProperty(c,`loadable`,{enumerable:!0,configurable:!1,writable:!1,value:(y=(v=o.loadable)==null?k(s,`loadable`):v)==null?!1:y}),defineProperty(c,`position`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new three.Vector3().fromArray((b=o.position)==null?[0,0,0]:b))}),defineProperty(c,`standingPosition`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new three.Vector3().fromArray((C=(S=o.standing_position)==null?o.standingPosition:S)==null?[0,0,0]:C))}),defineProperty(c,`quaternion`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new three.Quaternion().fromArray(o.quaternion?[o.quaternion.x,o.quaternion.y,o.quaternion.z,o.quaternion.w]:[0,0,0,1]))}),defineProperty(c,`matrix`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new three.Matrix4().compose(c.position,c.quaternion,PANO_TEXTURE_SCALE))}),defineProperty(c,`accessibleNodes`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{if(accessibleNodesSet.clear(),o.accessible_nodes&&Array.isArray(o.accessible_nodes))for(let e of o.accessible_nodes)e>=T||e===r||accessibleNodesSet.add(e);else if(o.accessibleNodes&&Array.isArray(o.accessibleNodes))for(let e of o.accessibleNodes)e>=T||e===r||accessibleNodesSet.add(e);else if(o.visible_nodes&&Array.isArray(o.visible_nodes))for(let e of o.visible_nodes)e>=T||e===r||accessibleNodesSet.add(e);else if(o.visibleNodes&&Array.isArray(o.visibleNodes))for(let e of o.visibleNodes)e>=T||e===r||accessibleNodesSet.add(e);if(accessibleNodesSet.size===0)for(let e=0;e<T;e++)e!==r&&accessibleNodesSet.add(e);let e=Array.from(accessibleNodesSet);return accessibleNodesSet.clear(),Object.freeze(e)})()}),defineProperty(c,`visibleNodes`,{enumerable:!0,configurable:!1,writable:!1,value:c.accessibleNodes}),defineProperty(c,`images`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e={};defineProperty(e,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t});for(let n of FACE_ORDER$1)defineProperty(e,n,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{var e;return relativeURL(panoURL((e=k(s,n))==null?``:e,w,r),t.baseURL)})()});return defineProperty(e,`sizeList`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let t=getImageSizeFromURL(e[FACE_ORDER$1[0]]),n=k(s,`size_list`),r=k(s,`tiles`);if(t){if(n){let e=n.slice().sort((e,t)=>e-t);return Object.freeze(e)}else if(r){let e=[t],n=r.slice().sort((e,t)=>e-t);for(let r of n){let n=512*Math.pow(2,r);n>t&&e.push(n)}return Object.freeze(e)}return Object.freeze([t])}return Object.freeze([])})()}),defineProperty(e,`tiles`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let n=getImageSizeFromURL(e.front);if(!n)return;let r=e.sizeList.slice();if(r[0]){let e=getTileLevel(r[0]);if(e)for(let t=e-1;t>=0;t--)r.unshift(512*Math.pow(2,t))}if(r.length<=0)return;let o=[];for(let s of r){let r=getTileLevel(s);if(typeof r!=`number`)continue;let c={};if(defineProperty(c,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(c,`level`,{enumerable:!0,configurable:!1,writable:!1,value:r}),s>n){defineProperty(c,`size`,{enumerable:!0,configurable:!1,writable:!1,value:s}),defineProperty(c,`scale`,{enumerable:!0,configurable:!1,writable:!1,value:1});for(let t of FACE_ORDER$1)defineProperty(c,t,{enumerable:!0,configurable:!1,writable:!1,value:replaceImageSize(e[t],s)})}else{defineProperty(c,`size`,{enumerable:!0,configurable:!1,writable:!1,value:n}),defineProperty(c,`scale`,{enumerable:!0,configurable:!1,writable:!1,value:s/n});for(let t of FACE_ORDER$1)defineProperty(c,t,{enumerable:!0,configurable:!1,writable:!1,value:e[t]})}o.push(c)}return o=sortTile(o),Object.freeze(o)})()}),defineProperty(e,`video`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e=k(s,`video`),n;return e&&(n={},defineProperty(n,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(n,`source`,{enumerable:!0,configurable:!1,writable:!1,value:e.source}),defineProperty(n,`matrix`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Matrix4().fromArray(e.matrix)}),defineProperty(n,`size`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Vector2().fromArray(e.size)})),n})()}),e})()}),O.push(c)}}defineProperty(t,`observers`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(O)});let k={};if(defineProperty(k,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),E.initial){if(t.observers.length>0){let e;isNumber(E.initial.panoIndex)?e=E.initial.panoIndex:isNumber(E.initial.pano_index)?e=E.initial.pano_index:isNumber(E.initial.pano)&&(e=E.initial.pano),typeof e==`number`&&(e=clamp$1(e,0,t.observers.length-1),defineProperty(k,`panoIndex`,{enumerable:!0,writable:!0,value:e}))}if(E.initial.mode===`Panorama`&&t.observers.length===0||E.initial.mode===`Floorplan`||E.initial.mode===`Topview`||E.initial.mode===`Model`||E.initial.mode===`Mapview`?defineProperty(k,`mode`,{enumerable:!0,writable:!0,value:E.initial.mode}):typeof k.panoIndex==`number`?defineProperty(k,`mode`,{enumerable:!0,writable:!0,value:`Panorama`}):defineProperty(k,`mode`,{enumerable:!0,writable:!0,value:`Mapview`}),isNumber(E.initial.latitude)&&defineProperty(k,`latitude`,{enumerable:!0,writable:!0,value:E.initial.latitude}),isNumber(E.initial.longitude)?defineProperty(k,`longitude`,{enumerable:!0,writable:!0,value:E.initial.longitude}):isNumber(E.initial.heading)&&defineProperty(k,`longitude`,{enumerable:!0,writable:!0,value:headingToLongitude(E.initial.heading)}),isNumber(E.initial.fov)&&defineProperty(k,`fov`,{enumerable:!0,writable:!0,value:E.initial.fov}),isNumber(E.initial.distance)&&defineProperty(k,`distance`,{enumerable:!0,writable:!0,value:E.initial.distance}),Array.isArray(E.initial.offset)){let e=E.initial.offset,t=[0,0,0].map((t,n)=>{let r=Number(e[n]);return isNaN(r)||!isFinite(r)?0:r});defineProperty(k,`offset`,{enumerable:!0,writable:!0,value:new three.Vector3().fromArray(t)})}else typeof E.initial.offset==`object`&&typeof E.initial.offset.x==`number`&&typeof E.initial.offset.y==`number`&&typeof E.initial.offset.z==`number`&&defineProperty(k,`offset`,{enumerable:!0,writable:!0,value:new three.Vector3().fromArray([E.initial.offset.x,E.initial.offset.y,E.initial.offset.z])})}return defineProperty(t,`initial`,{enumerable:!0,configurable:!1,writable:!1,value:k}),t}function parseNull(e,t){return defineProperty(t,`issuer`,{enumerable:!0,configurable:!1,writable:!1,value:`null`}),defineProperty(t,`expire`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new Date)}),defineProperty(t,`allowHosts`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze([`*`])}),defineProperty(t,`name`,{enumerable:!0,configurable:!1,writable:!1,value:`Null`}),defineProperty(t,`workCode`,{enumerable:!0,value:`null-`+createUuid()}),defineProperty(t,`baseURL`,{enumerable:!0,value:`/`}),defineProperty(t,`model`,{enumerable:!0,configurable:!1,writable:!1,value:void 0}),defineProperty(t,`observers`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze([])}),defineProperty(t,`initial`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e={};return defineProperty(e,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(e,`mode`,{enumerable:!0,writable:!0,value:`Mapview`}),e})()}),t}function parsePano(e,t){var n,r;return defineProperty(t,`issuer`,{enumerable:!0,configurable:!1,writable:!1,value:`null`}),defineProperty(t,`expire`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new Date)}),defineProperty(t,`allowHosts`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze([`*`])}),defineProperty(t,`name`,{enumerable:!0,configurable:!1,writable:!1,value:String((n=e.name)==null?`Unknown`:n)}),defineProperty(t,`workCode`,{enumerable:!0,writable:!0,value:(r=e.code)==null?createUuid():r}),defineProperty(t,`baseURL`,{enumerable:!0,writable:!0,value:`/`}),defineProperty(t,`model`,{enumerable:!0,configurable:!1,writable:!1,value:void 0}),defineProperty(t,`observers`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let n={};return defineProperty(n,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(n,`index`,{enumerable:!0,configurable:!1,writable:!1,value:0}),defineProperty(n,`panoIndex`,{enumerable:!0,configurable:!1,writable:!1,value:0}),defineProperty(n,`panoId`,{enumerable:!0,configurable:!1,writable:!1,value:panoStringify({workCode:t.workCode,panoIndex:0})}),defineProperty(n,`floorIndex`,{enumerable:!0,configurable:!1,writable:!1,value:0}),defineProperty(n,`derivedId`,{enumerable:!0,configurable:!1,writable:!1,value:void 0}),defineProperty(n,`derivedIdStr`,{enumerable:!0,configurable:!1,writable:!1,value:void 0}),defineProperty(n,`active`,{enumerable:!0,configurable:!1,writable:!1,value:!0}),defineProperty(n,`loadable`,{enumerable:!0,configurable:!1,writable:!1,value:!1}),defineProperty(n,`position`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Vector3(0,1.5,0)}),defineProperty(n,`standingPosition`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Vector3(0,0,0)}),defineProperty(n,`quaternion`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Quaternion(0,1,0,0)}),defineProperty(n,`matrix`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Matrix4().compose(n.position,n.quaternion,PANO_TEXTURE_SCALE)}),defineProperty(n,`accessibleNodes`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze([])}),defineProperty(n,`visibleNodes`,{enumerable:!0,configurable:!1,writable:!1,value:n.accessibleNodes}),defineProperty(n,`images`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let n={};defineProperty(n,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t});for(let t of FACE_ORDER$1)defineProperty(n,t,{enumerable:!0,configurable:!1,writable:!1,value:e[t]});return defineProperty(n,`sizeList`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze([e.size])}),defineProperty(n,`tiles`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e=getImageSizeFromURL(n.front);if(!e)return;let r=n.sizeList.slice();if(r[0]){let e=getTileLevel(r[0]);if(e)for(let t=e-1;t>=0;t--)r.unshift(512*Math.pow(2,t))}if(r.length<=0)return;let o=[];for(let s of r){let r=getTileLevel(s);if(typeof r!=`number`)continue;let c={};if(defineProperty(c,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(c,`level`,{enumerable:!0,configurable:!1,writable:!1,value:r}),s>e){defineProperty(c,`size`,{enumerable:!0,configurable:!1,writable:!1,value:s}),defineProperty(c,`scale`,{enumerable:!0,configurable:!1,writable:!1,value:1});for(let e of FACE_ORDER$1)defineProperty(c,e,{enumerable:!0,configurable:!1,writable:!1,value:replaceImageSize(n[e],s)})}else{defineProperty(c,`size`,{enumerable:!0,configurable:!1,writable:!1,value:e}),defineProperty(c,`scale`,{enumerable:!0,configurable:!1,writable:!1,value:s/e});for(let e of FACE_ORDER$1)defineProperty(c,e,{enumerable:!0,configurable:!1,writable:!1,value:n[e]})}o.push(c)}return o=sortTile(o),Object.freeze(o)})()}),defineProperty(n,`video`,{enumerable:!0,configurable:!1,writable:!1,value:void 0}),n})()}),Object.freeze([n])})()}),defineProperty(t,`initial`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e={};return defineProperty(e,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(e,`mode`,{enumerable:!0,writable:!0,value:`Panorama`}),defineProperty(e,`panoIndex`,{enumerable:!0,writable:!0,value:0}),e})()}),t}var workVerifySet=new WeakSet,Work=class{constructor(e,t){this.observerBox=new three.Box3,this.observerBox=new three.Box3,this.transform=new three.Matrix4,this.shortPath=!1,this.jsonp=!1;let n;if(n=e===null?parseNull(e,this):typeof e==`object`&&typeof e.size==`number`&&typeof e.up==`string`&&typeof e.down==`string`&&typeof e.right==`string`&&typeof e.left==`string`&&typeof e.front==`string`&&typeof e.back==`string`?parsePano(e,this):parse(e,this),n instanceof Error)throw Error(`[PARSE FAILED]: `+n.message+`
938
+ `,uniforms:{diffuse:{value:new three.Color},opacity:{value:1},displacementScalar:{value:0}}};function createPipeBufferGeometry(e,t,n,r){let o=new Float32Array((n+1)*(r+1)*3),s=new Float32Array((n+1)*(r+1)*3),c=new Float32Array((n+1)*(r+1)*2),l=new Uint32Array(n*r*6),u=e.computeFrenetFrames(n),d=new three.Vector3,f=new three.Vector3,p=new three.Vector2,m=new three.Vector3;for(let l=0;l<=n;l++){m=e.getPointAt(l/n,m);let h=u.normals[l],g=u.binormals[l];for(let e=0;e<=r;e++){let u=l*(r+1)+e,_=e/r*Math.PI*2,v=Math.sin(_),y=-Math.cos(_);f.x=y*h.x+v*g.x,f.y=y*h.y+v*g.y,f.z=y*h.z+v*g.z,f.normalize(),f.toArray(s,u*3),d.x=m.x+t*f.x,d.y=m.y+t*f.y,d.z=m.z+t*f.z,d.toArray(o,u*3),p.x=l/n,p.y=e/r,p.toArray(c,u*2)}}for(let e=0;e<n;e++)for(let t=0;t<r;t++){let n=(e*r+t)*6,o=(r+1)*e+t,s=(r+1)*(e+1)+t,c=(r+1)*(e+1)+(t+1),u=(r+1)*e+(t+1);l[n]=o,l[n+1]=s,l[n+2]=u,l[n+3]=s,l[n+4]=c,l[n+5]=u}let h=new three.BufferGeometry;return h.setIndex(new three.BufferAttribute(l,1)),h.setAttribute(`position`,new three.BufferAttribute(o,3)),h.setAttribute(`normal`,new three.BufferAttribute(s,3)),h.setAttribute(`uv`,new three.BufferAttribute(c,2)),h}function parseTrajectoryObject(e,t){let n=new three.Color(0).convertSRGBToLinear(),r=new three.Color(52949).convertSRGBToLinear(),o=new three.Color(3370495).convertSRGBToLinear(),s=new three.Color(16777215).convertSRGBToLinear(),c=0,l=new three.CurvePath,u=e.length;for(let t=3;t<u;t+=3){let n=new three.Vector3().fromArray(e,t-3),r=new three.Vector3().fromArray(e,t);c+=n.distanceTo(r);let o=new three.LineCurve3(n,r);l.add(o)}let d=createPipeBufferGeometry(l,.03,Math.ceil(c*100),6);d.clearGroups(),d.addGroup(0,d.index?d.index.count:d.attributes.position.count,0),d.addGroup(0,d.index?d.index.count:d.attributes.position.count,1),d.addGroup(0,d.index?d.index.count:d.attributes.position.count,2);let f=new three.ShaderMaterial({vertexShader:TRAJECTOR_PIPE_SHADER.vertexShader,fragmentShader:TRAJECTOR_PIPE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_PIPE_SHADER.uniforms),side:three.BackSide});f.uniforms.totalLength.value=c,f.uniforms.diffuse.value=n,f.uniforms.diffuse2.value=n,f.uniforms.opacity.value=.5,f.transparent=!0;let p=new three.ShaderMaterial({vertexShader:TRAJECTOR_PIPE_SHADER.vertexShader,fragmentShader:TRAJECTOR_PIPE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_PIPE_SHADER.uniforms),side:three.BackSide});p.uniforms.totalLength.value=c,p.uniforms.displacementScalar.value=-.01,p.uniforms.diffuse.value=r,p.uniforms.diffuse2.value=o;let m=new three.ShaderMaterial({vertexShader:TRAJECTOR_PIPE_SHADER.vertexShader,fragmentShader:TRAJECTOR_PIPE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_PIPE_SHADER.uniforms),side:three.DoubleSide});m.uniforms.totalLength.value=c,m.uniforms.displacementScalar.value=-.026,m.uniforms.dashSize.value=new three.Vector2(.06,.09),m.uniforms.diffuse.value=s,m.uniforms.diffuse2.value=s;let h=new three.Mesh(d,[f,p,m]),g=.08,_=24,v=new three.SphereBufferGeometry(.08,24,24);v.clearGroups(),v.addGroup(0,d.index?d.index.count:d.attributes.position.count,0),v.addGroup(0,d.index?d.index.count:d.attributes.position.count,1);let y=new three.ShaderMaterial({vertexShader:TRAJECTOR_SPHERE_SHADER.vertexShader,fragmentShader:TRAJECTOR_SPHERE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_SPHERE_SHADER.uniforms),side:three.BackSide});y.uniforms.diffuse.value=n,y.uniforms.opacity.value=.5,y.transparent=!0;let b=new three.ShaderMaterial({vertexShader:TRAJECTOR_SPHERE_SHADER.vertexShader,fragmentShader:TRAJECTOR_SPHERE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_SPHERE_SHADER.uniforms),side:three.FrontSide});b.uniforms.displacementScalar.value=-.01,b.uniforms.diffuse.value=r;let S=new three.Mesh(v,[y,b]);S.position.fromArray(e,0),h.add(S);let C=new three.ShaderMaterial({vertexShader:TRAJECTOR_SPHERE_SHADER.vertexShader,fragmentShader:TRAJECTOR_SPHERE_SHADER.fragmentShader,uniforms:three.UniformsUtils.clone(TRAJECTOR_SPHERE_SHADER.uniforms),side:three.FrontSide});C.uniforms.displacementScalar.value=-.01,C.uniforms.diffuse.value=o;let w=new three.Mesh(v,[y,C]);return w.position.fromArray(e,e.length-3),h.add(w),{scene:h,dispose:()=>{d.dispose(),f.dispose(),p.dispose(),m.dispose(),v.dispose(),y.dispose(),b.dispose(),C.dispose()}}}function loadTrajectory(e,t){let n=e.name,r=imageURL(appendSearch(e.content.uri,t.search),{key:`model.0`});return e.content.loadState=`LOADING`,e.content.loadStateUpdateTime=now(),loadPly(r,{type:`geometry`,customPropertyMapping:{time:{itemType:`uint32`,itemNames:[`time_milisec`]}},fetcher:t.fetcher}).then(t=>{var o,s,c,l;let u=(s=(o=t.scene.attributes)==null?void 0:o.time.array)==null?[]:s,d=(l=(c=t.scene.attributes)==null?void 0:c.position.array)==null?[]:l,f=t.byteLength,p=t.memoryUsage,m=parseTrajectoryObject(d,u);m.scene.applyMatrix4(e.transform),m.scene.updateWorldMatrix(!1,!0),m.scene.matrixAutoUpdate=!1;let h=new TrajectoryNode(n,m.scene);return e.content.data={uri:r,byteLength:f,memoryUsage:p,positionArray:d,timeArray:u,object:h},e.content.byteLength=f,e.content.memoryUsage=p,e.content.loadState=`READY`,e.content.loadStateUpdateTime=now(),e}).catch(t=>(e.content.data=void 0,e.content.loadState=`FAILED`,e.content.loadStateUpdateTime=now(),t instanceof NetworkResponseError&&t.httpStatus===0||t instanceof NetworkTimeoutError||t instanceof NetworkProxyError?e.content.loadfailRetryDelay=clamp$1(e.content.loadfailRetryDelay+RETRY_DELAY_STEP,RETRY_DELAY_STEP,MAX_RETRY_DELAY):e.content.loadfailRetryDelay=1/0,Promise.reject(t)))}function unloadTrajectory(e){e.content&&(e.content.data&&e.content.data.object.dispose(),e.content.data=void 0,e.content.loadState=`UNLOADED`,e.content.loadProgress=0,e.content.loadStateUpdateTime=now(),e.content.byteLength=0,e.content.memoryUsage=0)}var scratchVector3$7=new three.Vector3,scratchMatrix3=new three.Matrix3,scratchMatrix4$3=new three.Matrix4,a=6378137,invF=298.257223563;function ecefToLla(e){let t=a-a/invF,n=(a*a-t*t)/(a*a),r=Math.sqrt(e.x*e.x+e.y*e.y),o=1e-12,s=1e3,c=0,l=Math.atan2(e.z,r),u=0;for(;c++<1e3;){let t=Math.sin(l),o=a/Math.sqrt(1-n*t*t);u=r/Math.cos(l)-o;let s=Math.atan2(e.z/(o*(1-n)+u),r/(o+u));if(isNaN(s)||Math.abs(s-l)<1e-12)break;l=s}return e.set(l,Math.atan2(e.y,e.x),u)}function llaToEcef(e){let{x:t,y:n,z:r}=e,o=a-a/invF,s=(a*a-o*o)/(a*a),c=Math.sin(t),l=Math.cos(t),u=Math.sin(n),d=Math.cos(n),f=a/Math.sqrt(1-s*c*c),p=(f+r)*l*d,m=(f+r)*l*u,h=(o*o/(a*a)*f+r)*c;return e.set(p,m,h)}function getEcefToEnuMatrix(e,t){let{x:n,y:r,z:o}=ecefToLla(scratchVector3$7.copy(e)),s=Math.sin(n),c=Math.sin(r),l=Math.cos(n),u=Math.cos(r);t.fromArray([-c,-s*u,l*u,0,+u,-s*c,l*c,0,0,l,s,0,0,0,0,1]);let d=scratchMatrix3.setFromMatrix4(t),f=scratchVector3$7.copy(e).applyMatrix3(d).multiplyScalar(-1);t.setPosition(f);let p=scratchMatrix4$3.fromArray([1,0,0,0,0,1,0,0,0,0,1,0,0,0,o,1]);return t.premultiply(p),t}var ROTATE_X_90_MATRIX=new three.Matrix4().fromArray([1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1]),ROTATE_X_90_MATRIX_INVERSE=new three.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]),enuToLocalMatrix=new three.Matrix4().copy(ROTATE_X_90_MATRIX),localToEnuMatrix=new three.Matrix4().copy(ROTATE_X_90_MATRIX_INVERSE);function getRecommendTile3dProps(e,t={}){var n,r,o;let s,c,l;if(typeof e.tileset.rootMeta.creationTime==`string`)if(typeof e.tileset.rootMeta.numTotalPoints==`number`&&e.tileset.rootMeta.numTotalPoints>0){l=4,t.powerPreference===`high`&&(l=2),s=l/1.6;let u=0;if(((n=e.tileset.rootMeta.taskParameters)==null?void 0:n.point_homogenization)===`1`&&(r=e.tileset.rootMeta.taskParameters)!=null&&r.homo_point_density){let t=Number((o=e.tileset.rootMeta.taskParameters)==null?void 0:o.homo_point_density);isFinite(t)&&!isNaN(t)&&(u=t)}u<=0&&(u=.02),c=u*1.4}else l=5,t.powerPreference===`high`&&(l=4),s=0,c=.03;else l=6,s=0,c=.03,e.name===`aerophoto`?(l=12,t.powerPreference===`high`&&(l=10)):e.tileset.asset.extras&&typeof e.tileset.asset.extras.name==`string`&&/^matterport\b/i.test(e.tileset.asset.extras.name)&&(l=5,t.powerPreference===`high`&&(l=4));return{pointScale:c,pointMinPixel:s,maxScreenSpaceError:l}}var scratchVector3$6=new three.Vector3,scratchSphereBoundingVolume=new SphereBoundingVolume,scratchBoxBoundingVolume=new BoxBoundingVolume,parameterVersionMap=new WeakMap,tileVersionMap=new WeakMap,trajectoryVersionMap=new WeakMap,STENCIL_CONSTANT={TILE_MASK:128,SKIP_LOD_MASK:112,SKIP_LOD_BIT_SHIFT:4,CLASSIFICATION_MASK:15},SKIP_BACKFACE_MATERIAL=(()=>{let e=new three.MeshBasicMaterial;return e.side=three.BackSide,e.color.setHex(16711935),e.colorWrite=!1,e.stencilWrite=!0,e.polygonOffset=!0,e.polygonOffsetFactor=2,e.polygonOffsetUnits=2,e.stencilRef=STENCIL_CONSTANT.TILE_MASK,e.stencilFunc=three.AlwaysStencilFunc,e.stencilFuncMask=STENCIL_CONSTANT.TILE_MASK,e.stencilZPass=three.ReplaceStencilOp,e.stencilWriteMask=STENCIL_CONSTANT.TILE_MASK,e})(),SKIP_BACKFACE_TRANSPARENT_MATERIAL=(()=>{let e=new three.MeshBasicMaterial;return e.visible=!1,e})(),CLEAR_STENCIL_GEOMETRY=new three.BufferGeometry,CLEAR_STENCIL_MATERIAL=new three.MeshBasicMaterial;function cloneSkipBackfaceObject(e){let t;t=e instanceof three.Mesh?new three.Mesh(e.geometry,Array.isArray(e.material)?e.material.map(e=>e.transparent?SKIP_BACKFACE_TRANSPARENT_MATERIAL:SKIP_BACKFACE_MATERIAL):e.material&&e.material.transparent?SKIP_BACKFACE_TRANSPARENT_MATERIAL:SKIP_BACKFACE_MATERIAL):e instanceof three.Group?new three.Group:new three.Object3D,t.position.copy(e.position),t.quaternion.copy(e.quaternion),t.scale.copy(e.scale),t.matrix.compose(e.position,e.quaternion,e.scale),t.matrixAutoUpdate=!1,t.frustumCulled=e.frustumCulled,t.visible=e.visible;for(let n of e.children)t.add(cloneSkipBackfaceObject(n));return t}var Tile3D=class extends three.Object3D{constructor(e,t){var n,r;super(),this.parameter=new Parameter,this.renderObjects=[],this.backfaceObjects=[],this.tileObjects=[],this.frameNumber=0,this.error=(n=t.error)==null?null:n,this.name=t.name,this.type=t.type,this.upAxis=t.upAxis,this.light=t.light,this.fetcher=t.fetcher,this.search=(r=t.search)==null?``:r,this.groundHeight=t.groundHeight,this.coordinateSystem=t.coordinateSystem,this.boundingBox=new three.Box3,this.autoRefine=!0,this.refined=!1,this.refineProgress=[0,0],this.loaded=!1,this.disposed=!1,this.clearStencilObject=new three.Mesh(CLEAR_STENCIL_GEOMETRY,CLEAR_STENCIL_MATERIAL),this.clearStencilObject.frustumCulled=!1,this.clearStencilObject.onAfterRender=e=>e.clearStencil(),this.tileset=new Tileset(e,{tileLoader:e=>this.loadContent(e),tileUnloader:e=>this.unloadContent(e),onTileLoad:e=>{this.onTileLoad&&this.onTileLoad(e)},onTileUnload:e=>{this.onTileUnload&&this.onTileUnload(e)},onTileError:(e,t)=>{this.onError&&this.onError(Object.assign(t,{tile:e})),console.error(`Tile error`,e.id,t)},trajectoryLoader:e=>this.loadTrajectory(e),trajectoryUnloader:e=>this.unloadTrajectory(e),onTrajectoryLoad:()=>{},onTrajectoryUnload:e=>{},onTrajectoryError:(e,t)=>{this.onError&&this.onError(Object.assign(t,{error:t})),console.error(`Trajectory error`,e,t)}}),this.tileset.root.boundingVolume&&this.tileset.root.boundingVolume.getBoundingBox(this.boundingBox),this.currentResolvedParameterValue=Parameter.resolveValueTo({},this.parameter)}get viewerRequestVolume(){return this.tileset.root.viewerRequestVolume}set viewerRequestVolume(e){this.tileset.root.viewerRequestVolume=e}get tiles(){return this.tileset.selectedTiles}get trajectories(){return this.tileset.trajectories}getRecommendProps(e={}){return getRecommendTile3dProps(this,e)}loadContent(e){return loadTileContent(e,{light:this.light,fetcher:this.fetcher,search:this.search,renderer:this.renderer}).then(t=>{if(e.type===`SCENEGRAPH`){if(this.disposed||!e.content)unloadTileContent(e);else if(e.content.data)if(e.content.data.type===`spz`){let t=e.content.data.object.children[0].boundingBox;this.boundingBox.union(t)}else this.boundingBox.expandByObject(e.content.data.object)}})}unloadContent(e){return unloadTileContent(e),Promise.resolve()}loadAllTilesets(){let e=t=>{let n=[];return this.tileset.root.traverse(e=>{var t;e.type===`TILESET`&&((t=e.content)==null?void 0:t.loadState)!==`READY`&&n.push(e)}),Promise.all(n.map(t=>this.loadContent(t).then(()=>e(t)))).then(()=>{})};return e(this.tileset.root)}loadTrajectory(e){return loadTrajectory(e,{fetcher:this.fetcher,search:this.search,renderer:this.renderer}).then(e=>{this.disposed&&unloadTrajectory(e)})}unloadTrajectory(e){return unloadTrajectory(e),Promise.resolve()}intersectRaycaster(e,t){var n,r;let o=t==null?[]:t,s=[this.tileset.root],c=this.tileset.transform,l=(r=(n=e.params.Points)==null?void 0:n.threshold)==null?0:r,u=e.sortByDistance;e.sortByDistance=!1;let d,f=1/0;for(;d=s.pop();){let t;if(d.boundingVolume){let n;n=d.boundingVolume instanceof BoxBoundingVolume?scratchBoxBoundingVolume.copy(d.boundingVolume):d.boundingVolume instanceof SphereBoundingVolume?scratchSphereBoundingVolume.copy(d.boundingVolume):d.boundingVolume.clone(),n.applyMatrix4(c),t=n.intersectRay(e.ray,l,f)}else t=!0;if(t){for(let e=0,t=d.children.length;e<t;e++)s.push(d.children[e]);if(d.selected&&d.content&&d.content.data&&d.content.data.object.visible){let t=e.hitFilter;if(e.hitFilter=n=>{var r;return Object.assign(n,{model:(r=this.parent)==null?void 0:r,viewLayer:this,tile:d}),t?t.call(e,n):!0},d.content.data.object.intersectRaycaster(e,o),e.hitFilter=t,e.firstHitOnly){let e=o[0];e&&f>e.distance&&(f=e.distance)}}}}return e.sortByDistance=u,sortIntersects(o,e.sortByDistance,e.firstHitOnly),o}update(e,t,n,r){var o,s,c,l,u,d,f;this.renderer=e,this.frameNumber++;let p=!1,m=Parameter.resolveValueTo(this.currentResolvedParameterValue,n.parameter,r.parameter,this.parameter);parameterVersionMap.get(this)!==m.versionNumber&&(parameterVersionMap.set(this,m.versionNumber),p=!0);let h=(l=this.visible&&((o=this.parent)==null?void 0:o.visible)&&((c=(s=this.parent)==null?void 0:s.parent)==null?void 0:c.visible))==null?!1:l,g=m.maxLevelOfDetail;g=Math.max(g,0);let _=Math.min(m.minLevelOfDetail,g);(!h||!this.loaded||!n.loaded)&&(g=Math.max(_,0));let v=m.maxMemoryUsage;h||(v=Math.min(0,v));let y=m.minGeometricError,b=m.maxRequests,S=m.memoryAdjustedScreenSpaceError;h||(S=!1);let C=t.controllerMode;(C===`Panorama`||C===`VRPanorama`||C===`XRPanorama`)&&(m.modelAlpha<.1&&(y=m.panoramaMinGeometricError,S=!1),m.progress>=.01&&m.progress<=.99&&(b=0));let w=m.maxGeometricError;w=Math.max(y,w);let T={time:t.time,camera:{type:t.type,position:new three.Vector3().copy(t.position),direction:t.getDirection(new three.Vector3),up:new three.Vector3().copy(t.up).applyQuaternion(t.quaternion),projectionMatrix:t.projectionMatrix.clone(),visible:h&&t.visible,refine:t.refineModel},height:t.resolution.height,pixelRatio:t.pixelRatio,frameNumber:this.frameNumber,sseDenominator:2*Math.tan(.5*t.fov/180*Math.PI),cullingVolume:new CullingVolume().setFromCamera(t),minLevelOfDetail:_,maxLevelOfDetail:g,minGeometricError:y,maxGeometricError:w,skipLevelOfDetail:m.skipLevelOfDetail,mostDetail:m.mostDetail,loadSiblings:m.loadSiblings,cameraCulling:m.cameraCulling,maxMemoryUsage:v,maxRequests:b,requestOrder:m.requestOrder,maxScreenSpaceError:m.maxScreenSpaceError,memoryAdjustedScreenSpaceError:S},E=m.cacheCameras.map(e=>(e.updateProjectionMatrix(),Object.assign(Object.assign({},T),{camera:{type:t.type,position:new three.Vector3().copy(e.position),direction:e.getWorldDirection(new three.Vector3),up:new three.Vector3().copy(e.up),projectionMatrix:e.projectionMatrix.clone(),visible:e.visible,refine:!0},cullingVolume:new CullingVolume().setFromCamera(e)})));this.updateWorldMatrix(!0,!1),this.tileset.transform.equals(this.matrixWorld)||(this.tileset.transform.copy(this.matrixWorld),p=!0);let D=!this.autoRefine;if(D===!1&&m.progress>=.01&&m.progress<=.99){let e=new three.Vector3;m.pano0&&e.setFromMatrixPosition(m.pano0.matrix);let t=e.clone();m.pano1&&t.setFromMatrixPosition(m.pano1.matrix),e.distanceTo(t)<10&&(D=!0)}if(D||this.tileset.update(T,E),this.refined=!0,this.refineProgress[0]=0,this.refineProgress[1]=0,this.tileset.needsRefinedTiles.forEach(e=>{if(this.refineProgress[1]++,e.content){let t=e.content.loadState;if(t===`UNLOADED`||t===`LOADING`){this.refined=!1;return}}this.refineProgress[0]++}),this.loaded===!1&&this.autoRefine){this.loaded=!0;let e=!1;this.tileset.needsRefinedTiles.forEach(t=>{if(this.loaded!==!1&&t.content&&(t.state.visible&&(e=!0),m.minLevelOfDetail>=0)){if(T.skipLevelOfDetail){if(t.state.finalResolution){let e=t.state.ancestorWithContentAvailable,n=(e&&e.content?e.content:t.content).loadState;(n===`UNLOADED`||n===`LOADING`)&&(this.loaded=!1)}}else if(t.state.visible&&t.levelOfContent<=0){let e=t.content.loadState;(e===`UNLOADED`||e===`LOADING`)&&(this.loaded=!1)}}}),e&&this.tileset.selectedTiles.length===0&&this.tileset.frameNumber<500&&(this.loaded=!1),this.loaded===!0&&(this.refined=!1,this.refineProgress[1]++)}this.renderObjects.length=0,this.backfaceObjects.length=0,this.tileObjects.length=0;for(let e=this.children.length-1;e>=0;e--)this.remove(this.children[e]);T.skipLevelOfDetail||this.tileset.selectedTiles.sort((e,t)=>e.floor===t.floor?e.levelOfContent===t.levelOfContent?e.state.distanceToCamera===t.state.distanceToCamera?e.state.centerZDepth-t.state.centerZDepth:e.state.distanceToCamera-t.state.distanceToCamera:t.levelOfContent-e.levelOfContent:e.floor-t.floor);let O=[];for(let r of this.tileset.selectedTiles){let o=(d=(u=r.content)==null?void 0:u.data)==null?void 0:d.object;if(!o)continue;let s=o.update(e,t,n,this,r,m);if(O.push(r.id),s&&(p=!0),this.tileset.hasMixedContent&&T.skipLevelOfDetail){if(!r.state.finalResolution){let e=cloneSkipBackfaceObject(o);e.name=`skipBackface:`+o.name,this.backfaceObjects.push(e)}let e=r.state.selectionDepth,t=STENCIL_CONSTANT.TILE_MASK|e<<STENCIL_CONSTANT.SKIP_LOD_BIT_SHIFT,n=three.GreaterEqualStencilFunc,s=STENCIL_CONSTANT.SKIP_LOD_MASK,c=three.ReplaceStencilOp,l=STENCIL_CONSTANT.TILE_MASK|STENCIL_CONSTANT.SKIP_LOD_MASK;for(let e of o.materials)e.stencilWrite=!0,e.stencilRef=t,e.stencilFunc=n,e.stencilFuncMask=s,e.stencilZPass=c,e.stencilWriteMask=l}else for(let e of o.materials)e.stencilWrite=!1,e.stencilRef=STENCIL_CONSTANT.TILE_MASK,e.stencilFunc=three.AlwaysStencilFunc,e.stencilFuncMask=STENCIL_CONSTANT.TILE_MASK,e.stencilZPass=three.ReplaceStencilOp,e.stencilWriteMask=STENCIL_CONSTANT.TILE_MASK;this.tileObjects.push(o)}let k=O.toString();if(tileVersionMap.get(this)!==k&&(tileVersionMap.set(this,k),p=!0),T.skipLevelOfDetail&&this.backfaceObjects.length)for(let e=0;e<this.backfaceObjects.length;e++)this.renderObjects.push(this.backfaceObjects[e]);if(this.tileObjects.length)for(let e=0;e<this.tileObjects.length;e++)this.renderObjects.push(this.tileObjects[e]);T.skipLevelOfDetail&&this.renderObjects.push(this.clearStencilObject);let A=[];for(let r of this.tileset.selectedTrajectories){let o=(f=r.content.data)==null?void 0:f.object;if(!o)continue;let s=o.update(e,t,n,this,r,m);A.push(r.id),s&&(p=!0),this.renderObjects.push(o)}let j=A.toString();if(trajectoryVersionMap.get(this)!==j&&(trajectoryVersionMap.set(this,j),p=!0),this.parent){let e=this.parent.children.length+1,t=(Math.min(0,this.parent.children.indexOf(this))-e)*1e4+1;for(let e=0;e<this.renderObjects.length;e++){let n=this.renderObjects[e],r=e+t;n.traverse(e=>{(e instanceof three.Mesh||e instanceof three.Line||e instanceof three.Points)&&(e.renderOrder=r)})}}if(this.loaded)for(let e=0;e<this.renderObjects.length;e++)this.add(this.renderObjects[e]);return p}dispose(){this.disposed=!0,this.tileset.reset(),this.tileset.root.children.length=0,/^blob\:/.test(this.tileset.id)&&URL.revokeObjectURL(this.tileset.id);for(let e=this.children.length-1;e>=0;e--)this.remove(this.children[e]);this.refined=!1,this.loaded=!1,this.refineProgress[0]=this.refineProgress[1]=0,this.error=null,this.onError=void 0,this.renderer=void 0}get model(){return this.parent}get scene(){return this}get viewLayer(){return this}localToEnu(e){return e.applyMatrix4(localToEnuMatrix)}enuToLocal(e){return e.applyMatrix4(enuToLocalMatrix)}enuToEcef(e){return e.applyMatrix4(this.coordinateSystem.enuToEcefMatrix)}ecefToEnu(e){return e.applyMatrix4(this.coordinateSystem.ecefToEnuMatrix)}localToEcef(e){return this.enuToEcef(this.localToEnu(e))}ecefToLocal(e){return this.enuToLocal(this.ecefToEnu(e))}localToLla(e){return ecefToLla(this.enuToEcef(this.localToEnu(e)))}llaToLocal(e){return this.enuToLocal(this.ecefToEnu(llaToEcef(e)))}worldToEnu(e){return this.localToEnu(this.worldToLocal(e))}enuToWorld(e){return this.localToWorld(this.enuToLocal(e))}worldToEcef(e){return this.localToEcef(this.worldToLocal(e))}ecefToWorld(e){return this.localToWorld(this.ecefToLocal(e))}worldToLla(e){return this.localToLla(this.worldToLocal(e))}llaToWorld(e){return this.localToWorld(this.llaToLocal(e))}get coordinates(){scratchVector3$6.setScalar(0);let{x:e,y:t}=this.localToLla(scratchVector3$6);return[e,t].map(e=>(e/Math.PI*180).toFixed(6)).join(`,`)}getTransformMatrix4(e=new three.Matrix4){return e.copy(this.coordinateSystem.ecefToEnuMatrix),e.premultiply(enuToLocalMatrix),e.premultiply(this.matrixWorld),e}coordinatesToWorldPoint(e){let t=new three.Vector3(e.latitude,e.longitude,e.altitude);return this.llaToWorld(t)}worldPointToCoordinates(e){return scratchVector3$6.copy(e),this.worldToLla(scratchVector3$6),{latitude:scratchVector3$6.x,longitude:scratchVector3$6.y,altitude:scratchVector3$6.z}}resetBrightness(){this.parameter.reset(`brightness`)}get minLevelOfDetail(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`minLevelOfDetail`,...e)}set minLevelOfDetail(e){this.parameter.set(`minLevelOfDetail`,e)}get maxLevelOfDetail(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`maxLevelOfDetail`,...e)}set maxLevelOfDetail(e){this.parameter.set(`maxLevelOfDetail`,e)}get minGeometricError(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`minGeometricError`,...e)}set minGeometricError(e){this.parameter.set(`minGeometricError`,e)}get maxGeometricError(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`maxGeometricError`,...e)}set maxGeometricError(e){this.parameter.set(`maxGeometricError`,e)}get panoramaMinGeometricError(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`panoramaMinGeometricError`,...e)}set panoramaMinGeometricError(e){this.parameter.set(`panoramaMinGeometricError`,e)}get skipLevelOfDetail(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`skipLevelOfDetail`,...e)}set skipLevelOfDetail(e){this.parameter.set(`skipLevelOfDetail`,e)}get mostDetail(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`mostDetail`,...e)}set mostDetail(e){this.parameter.set(`mostDetail`,e)}get loadSiblings(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`loadSiblings`,...e)}set loadSiblings(e){this.parameter.set(`loadSiblings`,e)}get maxMemoryUsage(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`maxMemoryUsage`,...e)}set maxMemoryUsage(e){this.parameter.set(`maxMemoryUsage`,e)}get maxRequests(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`maxRequests`,...e)}set maxRequests(e){this.parameter.set(`maxRequests`,e)}get requestOrder(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`requestOrder`,...e)}set requestOrder(e){this.parameter.set(`requestOrder`,e)}get maxScreenSpaceError(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&(e.unshift(this.parent.parameter),this.parent.parent&&this.parent.parent.parameter instanceof Parameter&&e.unshift(this.parent.parent.parameter)),this.parameter.resolveValue(`maxScreenSpaceError`,...e)}set maxScreenSpaceError(e){this.parameter.set(`maxScreenSpaceError`,e)}},fetchers={};function getFetcher(e,t){let n=fetchers[e];if(n){let e=n.get(t);if(e)return e}throw Error(`fetcher workCode:${t.workCode} never registered.`)}function registerFetcher(e,t,n){let r=fetchers[e];r||(r=fetchers[e]=new WeakMap),r.has(t)||r.set(t,n)}var identityMatrix4=new three.Matrix4,scratchVector3$5=new three.Vector3,scratchMatrix4$2=new three.Matrix4;function getEcefToEnuMatrixFromUpAxis(e,t,n){switch(e){case`Z`:n.identity();break;case`WGS84`:case`GCJ02`:case`BD09`:getEcefToEnuMatrix(t,n);break;default:n.identity();break}return n}function loadViewLayer(e){var t;let[n,r]=e.tilesetUrl.split(`#`),o=(t=(r||n).split(`?`)[1])==null?``:t;return e.fetcher.ajax(e.tilesetUrl,{responseType:`text`}).catch(e=>({error:e,body:JSON.stringify({asset:{version:`0.0`},geometricError:0,root:{geometricError:0}})})).then(t=>{var n;let r=`error`in t?t.error:null,s=normalizeTilesetHeader(JSON.parse(t.body),e.tilesetUrl),{root:c,rootMeta:l={}}=s,u=e.upAxis;l.upAxis&&l.upAxis!==u&&(u=l.upAxis),`lodVersion`in s&&(u=`-Y`,`floorInfo`in s&&(s.properties=s.properties||{},s.properties.floorInfo=s.floorInfo.map(e=>({ground:-e.ground,height:e.height})),s.floorInfo=void 0),s.asset.tilesetVersion=String(s.lodVersion),s.lodVersion=void 0);let d=u,f=new three.Matrix4;d===`Y`?(d=`Z`,f.fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1])):d===`-Y`&&(d=`Z`,f.fromArray([1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1]));let p=c.boundingVolume?makeBoundingVolume(c.boundingVolume):void 0;p&&c.transform&&p.applyMatrix4(scratchMatrix4$2.fromArray(c.transform));let m=null,h=new three.Matrix4,g=new three.Matrix4;return l.coordinate?(m=l.coordinate.ground_height,h.fromArray(l.coordinate.pose_ecef_to_enu),g.fromArray(l.coordinate.pose_enu_to_ecef)):(p?p.getCenter(scratchVector3$5):scratchVector3$5.setScalar(0),scratchVector3$5.applyMatrix4(f),getEcefToEnuMatrixFromUpAxis(d,scratchVector3$5,h),g.getInverse(h)),s.root={refine:(n=c.refine)==null?`REPLACE`:n,geometricError:c.geometricError,transform:scratchMatrix4$2.copy(f).premultiply(d===`Z`?identityMatrix4:h).premultiply(enuToLocalMatrix).toArray(),boundingVolume:p?p.toJson():void 0,children:[c]},new Tile3D(s,{name:e.name,type:e.type,upAxis:u,light:e.light,fetcher:e.fetcher,search:o,groundHeight:m,coordinateSystem:{enuToEcefMatrix:g,ecefToEnuMatrix:h},error:r})})}function loadViewLayers(e,t){var n;let r=e.layers.map(e=>({tilesetUrl:e.work.getURL(e.tileset),name:e.name,type:e.type,upAxis:e.upAxis,light:t.light,fetcher:t.fetcher}));if(e.file){let o=!1;for(let e of r)if(e.type===`mesh`){o=!0;break}if(o===!1){let o=getExtname(e.file)||`.at3d`,s=JSON.stringify({tilesetUrl:``,asset:{version:`0.0`},geometricError:0,root:{refine:`REPLACE`,geometricError:0,transform:[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],content:{uri:e.work.getURL(e.file)},extras:{[o.slice(1)]:{upAxis:e.upAxis,textureBaseUri:typeof e.textureBase==`string`?e.work.getURL(e.textureBase):void 0,textureArray:e.textures,textureOptions:(n=t.textureOptions)==null?{}:n}}},rootMeta:{coordinate:e.coordinate}});r.push({name:`fallback`,type:`mesh`,upAxis:`Z`,tilesetUrl:URL.createObjectURL(new Blob([s],{type:`application/json`})),fetcher:t.fetcher,light:t.light})}}let o=r.map(e=>loadViewLayer(e).then(e=>e));return Promise.all(o)}function createSimpleBoxBufferGeometry(e=1,t=1,n=1){let r=e/2,o=t/2,s=n/2,c=new Float32Array([-r,+o,+s,+r,+o,+s,+r,+o,-s,-r,+o,-s,-r,-o,+s,+r,-o,+s,+r,-o,-s,-r,-o,-s]),l=new Uint32Array([0,4,1,1,4,5,1,5,2,2,5,6,2,6,3,3,6,7,3,7,0,0,7,4,3,0,2,2,0,1,4,7,5,5,7,6]),u=new three.BufferGeometry;return u.setAttribute(`position`,new three.BufferAttribute(c,3)),u.setIndex(new three.BufferAttribute(l,1)),u.addGroup(0,u.index.count,0),u.computeBoundingBox(),u.computeBoundingSphere(),u}function mergeBufferGeometries(e,t){for(var n=e[0].index!==null,r=new Set(Object.keys(e[0].attributes)),o=new Set(Object.keys(e[0].morphAttributes)),s={},c={},l=new three.BufferGeometry,u=0,d=0;d<e.length;++d){var f=e[d];if(n!==(f.index!==null))return null;for(var p in f.attributes){if(!r.has(p))return null;s[p]===void 0&&(s[p]=[]),s[p].push(f.attributes[p])}for(var p in f.morphAttributes){if(!o.has(p))return null;c[p]===void 0&&(c[p]=[]),c[p].push(f.morphAttributes[p])}if(l.userData.mergedUserData=l.userData.mergedUserData||[],l.userData.mergedUserData.push(f.userData),t){var m;if(n)m=f.index.count;else if(f.attributes.position!==void 0)m=f.attributes.position.count;else return null;l.addGroup(u,m,d),u+=m}}if(n){for(var h=0,g=[],d=0;d<e.length;++d){for(var _=e[d].index,v=0;v<_.count;++v)g.push(_.getX(v)+h);h+=e[d].attributes.position.count}l.setIndex(g)}for(var p in s){var y=mergeBufferAttributes(s[p]);if(!y)return null;l.setAttribute(p,y)}for(var p in c){var b=c[p][0].length;if(b===0)break;l.morphAttributes=l.morphAttributes||{},l.morphAttributes[p]=[];for(var d=0;d<b;++d){for(var S=[],v=0;v<c[p].length;++v)S.push(c[p][v][d]);var C=mergeBufferAttributes(S);if(!C)return null;l.morphAttributes[p].push(C)}}return l}function mergeBufferAttributes(e){for(var t,n,r,o=0,s=0;s<e.length;++s){var c=e[s];if(c.isInterleavedBufferAttribute||(t===void 0&&(t=c.array.constructor),t!==c.array.constructor)||(n===void 0&&(n=c.itemSize),n!==c.itemSize)||(r===void 0&&(r=c.normalized),r!==c.normalized))return null;o+=c.array.length}for(var l=new t(o),u=0,s=0;s<e.length;++s)l.set(e[s].array,u),u+=e[s].array.length;return new three.BufferAttribute(l,n,r)}function mergeVertices(e,t=1e-4){t=Math.max(t,Number.EPSILON);for(var n={},r=e.getIndex(),o=e.getAttribute(`position`),s=r?r.count:o.count,c=0,l=Object.keys(e.attributes),u={},d={},f=[],p=[`getX`,`getY`,`getZ`,`getW`],m=0,h=l.length;m<h;m++){var g=l[m];u[g]=[];var _=e.morphAttributes[g];_&&(d[g]=Array(_.length).fill().map(()=>[]))}for(var v=Math.log10(1/t),y=Math.pow(10,v),m=0;m<s;m++){for(var b=r?r.getX(m):m,S=``,C=0,h=l.length;C<h;C++)for(var g=l[C],w=e.getAttribute(g),T=w.itemSize,E=0;E<T;E++)S+=`${~~(w[p[E]](b)*y)},`;if(S in n)f.push(n[S]);else{for(var C=0,h=l.length;C<h;C++)for(var g=l[C],w=e.getAttribute(g),_=e.morphAttributes[g],T=w.itemSize,D=u[g],O=d[g],E=0;E<T;E++){var k=p[E];if(D.push(w[k](b)),_)for(var A=0,j=_.length;A<j;A++)O[A].push(_[A][k](b))}n[S]=c,f.push(c),c++}}let M=e.clone();for(var m=0,h=l.length;m<h;m++){var g=l[m],N=e.getAttribute(g),P=new N.array.constructor(u[g]),w=new three.BufferAttribute(P,N.itemSize,N.normalized);if(M.setAttribute(g,w),g in d)for(var C=0;C<d[g].length;C++){var F=e.morphAttributes[g][C],P=new F.array.constructor(d[g][C]),I=new three.BufferAttribute(P,F.itemSize,F.normalized);M.morphAttributes[g][C]=I}}return M.setIndex(f),M}var scratchSphere$1=new three.Sphere,scratchMatrix4$1=new three.Matrix4,scratchMatrix4Inverse=new three.Matrix4;function getEdgesBySphere(e,t,n=30/180*Math.PI){let r=Math.cos(n),o=[];for(let n of e.children)n instanceof Tile3D&&n.tileset.selectedTiles.forEach(e=>{var n,s,c;let l=(s=(n=e.content)==null?void 0:n.data)==null?void 0:s.object;if(l&&l.visible){let e=[];if(l.traverseVisible(n=>{if(n instanceof three.Mesh){let r=getBvhTreeForMesh(n);if(r){scratchMatrix4$1.copy(n.matrixWorld),scratchMatrix4Inverse.getInverse(scratchMatrix4$1),scratchSphere$1.copy(t).applyMatrix4(scratchMatrix4Inverse);let o=r.trianglesInSphere(scratchSphere$1.center,scratchSphere$1.radius),s=new three.BufferGeometry;s.setAttribute(`position`,new three.BufferAttribute(o,3)),s.applyMatrix4(n.matrixWorld),s=mergeVertices(s,.01),e.push(s)}}}),e.length===0)return;let n=[`a`,`b`,`c`],s=mergeBufferGeometries(e,!1),u=s.getAttribute(`position`).array,d=((c=s.getIndex())==null?void 0:c.array)||[],f=[],p=[];for(let e=0,t=u.length;e<t;e+=3){let t=new three.Vector3(u[e],u[e+1],u[e+2]);f.push(t)}for(let e=0,t=d.length;e<t;e+=3){let t=d[e],n=d[e+1],r=d[e+2],o=new three.Vector3().crossVectors(f[n].clone().sub(f[t]),f[r].clone().sub(f[t])).normalize();p.push({a:t,b:n,c:r,normal:o})}let m={};for(let e=0,t=p.length;e<t;e++){let t=p[e];for(let r=0;r<3;r++){let o=t[n[r]],s=t[n[(r+1)%3]],c=[Math.min(o,s),Math.max(o,s)],l=c[0]+`-`+c[1];m[l]===void 0?m[l]={index1:c[0],index2:c[1],face1:e}:m[l].face2=e}}for(let e in m){let t=m[e];if(t.face2===void 0||p[t.face1].normal.dot(p[t.face2].normal)<=r){let e=f[t.index1],n=f[t.index2];o.push(new three.Line3(e,n))}}f.length=0,p.length=0}});return o}var scratchBoundingBox$1=new three.Box3,scratchViewLayerBox=new three.Box3,scratchObserverBox$3=new three.Box3,Model=class extends three.Object3D{constructor(e,t,n={}){var r;super(),this.disposed=!1,this.parameter=new Parameter,this.outdated=!1,this.autoRefine=!0,this.metaPending=!1,this.loaded=!1,this.refined=!1,this.refineProgress=[0,0],this.boundingBox=new three.Box3,this.fiveId=e,this.needsRender=!1,this.work=t,this.name=t.workCode;let o=0;for(let e of t.observers)o=Math.max(o,e.floorIndex);if(this.floorLength=o+1,t.model){this.metaPending=!0;let e=loadViewLayers(t.model,{fetcher:getFetcher(this.fiveId,t),light:(r=n.light)==null?!1:r,textureOptions:n.textureOptions}),o=e=>this.dispatchEvent({type:`error`,error:e}),s=e=>this.dispatchEvent({type:`tileLoad`,tile:e}),c=e=>this.dispatchEvent({type:`tileUnload`,tile:e});this.initReady=e.then(e=>{var t;this.metaPending=!1;let n=null,r=null,l=null;for(let t of e){if(t.visible=!1,t.onError=o,t.onTileLoad=s,t.onTileUnload=c,t.error){o(t.error);continue}t.type===`mesh`?n===null&&(n=t):t.type===`point_cloud`?r===null&&(r=t):l===null&&(l=t)}let u=(t=n==null?r:n)==null?l:t;if(u&&(u.visible=!0),e.length)if(this.disposed)for(let t of e)t.dispose();else this.add(...e);return this}),this.loadedReady=new Promise(e=>{let t=()=>{e(this),this.removeEventListener(`load`,t),this.removeEventListener(`dispose`,t)};this.addEventListener(`load`,t),this.addEventListener(`dispose`,t)})}else this.refined=!0,this.loaded=!0,this.initReady=Promise.resolve(this),this.loadedReady=Promise.resolve(this);this.parameter.set(`boundingBox`,this.boundingBox.clone())}dispose(){this.disposed=!0;let e;for(;e=this.children[0];)typeof e.dispose==`function`&&e.dispose(),e.onError=void 0,e.onTileLoad=void 0,e.onTileUnload=void 0,this.remove(e);this.dispatchEvent({type:`dispose`})}get empty(){return this.children.length===0}get viewLayers(){return this.children}getEdgesBySphere(e,t=30/180*Math.PI){return getEdgesBySphere(this,e,t)}intersectRaycaster(e,t){let n=t==null?[]:t,r=e.sortByDistance;e.sortByDistance=!1;for(let t=0,r=this.children.length;t<r;t++){let r=this.children[t];r.visible&&typeof r.intersectRaycaster==`function`&&r.intersectRaycaster(e,n)}return e.sortByDistance=r,sortIntersects(n,e.sortByDistance,e.firstHitOnly),n}update(e,t,n){let r=!1;this.needsRender===!0&&(this.needsRender=!1,r=!0);let o=this.loaded;this.refined=!this.metaPending,this.loaded=!this.metaPending,this.refineProgress[0]=this.refineProgress[1]=0,this.work.transform.equals(this.matrix)||(this.matrix.copy(this.work.transform),this.matrix.decompose(this.position,this.quaternion,this.scale),this.matrixAutoUpdate=!1,r=!0);for(let o of this.children)o.autoRefine=this.autoRefine,o.update(e,t,n,this)&&(r=!0),o.refined===!1&&(this.refined=!1),o.loaded===!1&&(this.loaded=!1),this.refineProgress[0]+=o.refineProgress[0],this.refineProgress[1]+=o.refineProgress[1];scratchBoundingBox$1.makeEmpty(),scratchObserverBox$3.copy(this.work.observerBox),scratchObserverBox$3.isEmpty()||(scratchObserverBox$3.max.x+=1,scratchObserverBox$3.max.z+=1,scratchObserverBox$3.max.y+=1,--scratchObserverBox$3.min.x,--scratchObserverBox$3.min.z,scratchBoundingBox$1.union(scratchObserverBox$3));for(let e of this.viewLayers)e.boundingBox.isEmpty()||(scratchViewLayerBox.copy(e.boundingBox),scratchBoundingBox$1.union(scratchViewLayerBox));return scratchBoundingBox$1.applyMatrix4(this.matrix),scratchBoundingBox$1.equals(this.boundingBox)||(this.boundingBox.copy(scratchBoundingBox$1),this.parameter.set(`boundingBox`,scratchBoundingBox$1.clone())),o===!1&&this.loaded===!0&&this.dispatchEvent({type:`load`}),r}localToEnu(e){return e.applyMatrix4(localToEnuMatrix)}enuToLocal(e){return e.applyMatrix4(enuToLocalMatrix)}worldToEnu(e){return this.localToEnu(this.worldToLocal(e))}enuToWorld(e){return this.localToWorld(this.enuToLocal(e))}get shownFloor(){return this.shownFloorIndex===-1?null:this.shownFloorIndex}set shownFloor(e){this.shownFloorIndex=e===null?-1:e}show(e){this.shownFloor=e==null?null:e,this.dispatchEvent({type:`changeShownFloor`,floorIndex:e==null?null:e})}get bounding(){return this.boundingBox}setMaterial(e){this.parameter.set(e)}getMaterial(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&e.unshift(this.parent.parameter),this.parameter.resolveValue(...e)}get shownFloorIndex(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&e.unshift(this.parent.parameter),this.parameter.resolveValue(`shownFloorIndex`,...e)}set shownFloorIndex(e){this.parameter.set(`shownFloorIndex`,e)}get brightness(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&e.unshift(this.parent.parameter),this.parameter.resolveValue(`brightness`,...e)}set brightness(e){this.parameter.set(`brightness`,e)}get clippers(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&e.unshift(this.parent.parameter),this.parameter.resolveValue(`clippers`,...e)}set clippers(e){this.parameter.set(`clippers`,e)}get customShaders(){let e=[];return this.parent&&this.parent.parameter instanceof Parameter&&e.unshift(this.parent.parameter),this.parameter.resolveValue(`customShaders`,...e)}set customShaders(e){this.parameter.set(`customShaders`,e)}resetBrightness(){this.parameter.reset(`brightness`);for(let e of this.viewLayers)e.resetBrightness()}},scratchGeometry=createSimpleBoxBufferGeometry(1,1,1);scratchGeometry.applyMatrix4(new three.Matrix4().makeScale(-1,1,1));var parameterValueVersionMap=new WeakMap,cameraBoxSize=new three.Vector3(1,1,1),scratchBoundingBox=new three.Box3,scratchBoundingBoxSize=new three.Vector3,scratchCameraBox=new three.Box3,scratchPosition=new three.Vector3,scratchScale=new three.Vector3,BoundingMesh=class extends PBMMesh{constructor(e={}){var t;let n=new PBMMeshMaterial(`none`);n.flatShading=!0,n.depthWrite=!1,n.transparent=!1,n.blending=three.CustomBlending,n.blendSrc=three.SrcAlphaFactor,n.blendDst=three.OneMinusSrcAlphaFactor,n.blendSrcAlpha=three.OneFactor,n.blendDstAlpha=three.OneMinusSrcAlphaFactor,n.floorIndex=-1,super(scratchGeometry,[n]),this.name=(t=e.name)==null?``:t,this.frustumCulled=!1,this.renderOrder=-999999,this.currentResolvedParameterValue=Parameter.resolveValueTo({})}update(e,t,n){var r,o;let s=!1,c=Parameter.resolveValueTo(this.currentResolvedParameterValue,n.parameter);scratchBoundingBox.copy(c.boundingBox),scratchBoundingBox.getSize(scratchBoundingBoxSize);let l=Math.min(scratchBoundingBoxSize.x/2,500);scratchBoundingBox.min.x-=l,scratchBoundingBox.max.x+=l;let u=Math.min(scratchBoundingBoxSize.y/2,500);scratchBoundingBox.min.z-=u,scratchBoundingBox.max.z+=u;let d=scratchBoundingBoxSize.length()/2;if(scratchBoundingBox.max.y=Math.max(scratchBoundingBox.max.y,d),scratchBoundingBox.union(scratchCameraBox.setFromCenterAndSize(t.position,cameraBoxSize)),scratchBoundingBox.expandByScalar(1),scratchBoundingBox.getCenter(scratchPosition),scratchBoundingBox.getSize(scratchScale),scratchPosition.equals(this.position)||(this.position.copy(scratchPosition),s=!0),scratchScale.equals(this.scale)||(this.scale.copy(scratchScale),s=!0),parameterValueVersionMap.get(this)!==c.versionNumber){parameterValueVersionMap.set(this,c.versionNumber),s=!0;let e=this.material;for(let t of e)t.customShaders=c.customShaders,t.pano0=c.pano0,t.pano1=c.pano1,t.panoFilter=(o=(r=c.panoFilter)==null?void 0:r.toValue())==null?null:o,t.refinedScreen=c.refinedScreen,t.modelAlpha=c.modelAlpha,t.progress=c.progress,t.transition=c.transition,t.opacity=c.opacity,t.floorStyle=c.floorStyle,t.constantColor=c.constantColor,t.shownFloorIndex=c.shownFloorIndex,t.clippers=c.clippers,t.brightness=c.brightness,t.useHQWeight=c.useHQWeight,t.useHQDepth=c.useHQDepth,t.colorSaturation=c.colorSaturation,t.colorBrightness=c.colorBrightness,t.gradientTexture=c.gradientTexture,t.transparent=!1,t.modelBoundingMax.copy(c.boundingBox.max),t.modelBoundingMin.copy(c.boundingBox.min),c.useAddBlend&&(t.opacity=0),t.opacity===0&&(t.visible=!1)}return s}dispose(){for(let e of this.material)e.dispose(),e.pano0=null,e.pano1=null}},scratchBoundingBox3=new three.Box3,ModelScene=class extends three.Scene{constructor(e){super(),this.needsRender=!0,this.autoRefine=!0,this.boundingBox=new three.Box3,this.loaded=!1,this.refined=!1,this.refineProgress=[0,0],this.parameter=new Parameter,this.fiveId=e.fiveId,this.boundingMesh=new BoundingMesh({name:`bounding`}),this.add(this.boundingMesh);let t=this.models=[];this.shownModels=[],this.updateModelMap=new Map,this.parameter.set(`boundingBox`,this.boundingBox.clone());let n=this;defineProperty(t,`autoUpdate`,{get(){return n.autoRefine},set(e){n.autoRefine=e}}),defineProperty(t,`bounding`,{get(){return n.boundingBox}}),defineProperty(t,`loaded`,{get(){return n.loaded}}),defineProperty(t,`refined`,{get(){return n.refined}}),defineProperty(t,`refineProgress`,{get(){return n.refineProgress}}),defineProperty(t,`cacheCameras`,{get(){return n.parameter.resolveValue(`cacheCameras`)},set(e){n.parameter.set(`cacheCameras`,e)}}),defineProperty(t,`intersectRaycaster`,{value:e=>n.intersectRaycaster(e)}),defineProperty(t,`setMaterial`,{value:e=>n.setMaterial(e)}),defineProperty(t,`getMaterial`,{value:()=>n.getMaterial()}),defineProperty(t,`resetBrightness`,{value:()=>n.resetBrightness()})}setModels(e,t){let n=e.map(e=>{let n=this.shownModels.filter(t=>t.work.workCode===e.workCode)[0];if(n||(n=this.models.filter(t=>t.work.workCode===e.workCode)[0],n))return n.work=e,n;n=new Model(this.fiveId,e,{light:t.light,textureOptions:t.textureOptions});let r=t[`3d-tiles`];return n.initReady.then(()=>{if(r)if(typeof r==`function`)for(let e of n.viewLayers){let t=r(e,n);t&&(t.viewerRequestVolume&&(e.viewerRequestVolume=makeBoundingVolume(t.viewerRequestVolume)),e.parameter.set(omit(t,[`showLayers`])),t.showLayers===!1?e.visible=!1:Array.isArray(t.showLayers)&&(e.visible=t.showLayers.includes(e.name)))}else for(let e of n.viewLayers)r.viewerRequestVolume&&(e.viewerRequestVolume=makeBoundingVolume(r.viewerRequestVolume)),e.parameter.set(omit(r,[`showLayers`])),r.showLayers===!1?e.visible=!1:Array.isArray(r.showLayers)&&(e.visible=r.showLayers.includes(e.name))}),this.dispatchEvent({type:`model.create`,model:n}),n});for(let e=0;e<this.models.length;e++){let t=this.models[e];n.indexOf(t)===-1&&this.shownModels.indexOf(t)===-1&&(t.dispose(),this.dispatchEvent({type:`model.dispose`,model:t}))}this.models.length=0;for(let e=0;e<n.length;e++){let t=n[e];this.models.push(t)}if(t.forceReplaceImmediately&&!arrayEqual(this.models,this.shownModels)){for(let e=0;e<this.shownModels.length;e++){let t=this.shownModels[e];this.models.indexOf(t)===-1&&(t.dispose(),this.dispatchEvent({type:`model.dispose`,model:t}))}this.shownModels.length=0;for(let e=0;e<this.models.length;e++)this.shownModels.push(this.models[e])}return this.loaded=!1,this.refined=!1,this.models}get empty(){return this.boundingBox.isEmpty()}intersectRaycaster(e,t){let n=t==null?[]:t,r=this.shownModels.filter(e=>e.visible);if(r.length===1)r[0].intersectRaycaster(e,n);else{let t=e.sortByDistance;e.sortByDistance=!1;for(let t of r)t.intersectRaycaster(e,n);e.sortByDistance=t,sortIntersects(n,e.sortByDistance,e.firstHitOnly)}return n}update(e,t){let n=!1;scratchBoundingBox3.makeEmpty(),this.loaded=this.models.length>0,this.refined=this.models.length>0,this.refineProgress[0]=this.refineProgress[1]=0,this.updateModelMap.clear();for(let n=0;n<this.models.length;n++){let r=this.models[n];if(!this.updateModelMap.has(r)){let n=r.autoRefine;this.autoRefine===!1&&(r.autoRefine=!1);let o=r.update(e,t,this);r.autoRefine=n,this.updateModelMap.set(r,o)}r.loaded===!1&&(this.loaded=!1),r.refined===!1&&(this.refined=!1),this.refineProgress[0]+=r.refineProgress[0],this.refineProgress[1]+=r.refineProgress[1]}if((this.loaded===!0||this.models.length===0)&&!arrayEqual(this.models,this.shownModels)){for(let e=0;e<this.shownModels.length;e++){let t=this.shownModels[e];this.models.indexOf(t)===-1&&(t.dispose(),this.dispatchEvent({type:`model.dispose`,model:t}))}this.shownModels.length=0;for(let e=0;e<this.models.length;e++)this.shownModels.push(this.models[e]);n=!0}for(let n=0;n<this.shownModels.length;n++){let r=this.shownModels[n];if(!this.updateModelMap.has(r)){let n=r.autoRefine;(this.autoRefine===!1||this.models.indexOf(r)<0)&&(r.autoRefine=!1);let o=r.update(e,t,this);r.autoRefine=n,this.updateModelMap.set(r,o)}}for(let e=this.children.length-1;e>=0;e--){let t=this.children[e];t instanceof Model&&this.remove(t)}for(let e=0;e<this.shownModels.length;e++){let t=this.shownModels[e];this.updateModelMap.get(t)===!0&&(n=!0),scratchBoundingBox3.union(t.boundingBox),this.add(t)}for(let e=0;e<this.models.length;e++){let t=this.models[e];this.shownModels.indexOf(t)===-1&&scratchBoundingBox3.union(t.boundingBox)}return scratchBoundingBox3.equals(this.boundingBox)||(this.boundingBox.copy(scratchBoundingBox3),this.parameter.set(`boundingBox`,this.boundingBox.clone()),n=!0),this.boundingMesh.update(e,t,this)&&(n=!0),this.updateModelMap.clear(),this.needsRender=n,n}get bounding(){return this.boundingBox}setMaterial(e){this.parameter.set(e)}getMaterial(){return this.parameter.resolveValue()}resetBrightness(){this.parameter.reset(`brightness`);for(let e of this.models)e.resetBrightness()}dispose(){this.remove(this.boundingMesh),this.boundingMesh.dispose();for(let e=this.children.length-1;e>=0;e--){let t=this.children[e];t instanceof Model&&this.remove(t)}let e=arrayUnique(this.models.concat(this.shownModels));for(let t=0;t<this.shownModels.length;t++)e[t].dispose();this.models.length=0,this.shownModels.length=0,super.dispose()}};function workInitialToJson(e){let t={};return e.mode!==void 0&&(t.mode=e.mode),e.panoIndex!==void 0&&(t.pano_index=e.panoIndex),e.longitude!==void 0&&(t.longitude=e.longitude),e.latitude!==void 0&&(t.latitude=e.latitude),e.fov!==void 0&&(t.fov=e.fov),e.distance!==void 0&&(t.distance=e.distance),e.offset!==void 0&&(t.offset=e.offset.toArray()),t}function workModelToJson(e){var t;if(e)return{file_url:e.file,material_base_url:e.textureBase,material_textures:(t=e.textures)==null?void 0:t.slice(),up_axis:e.upAxis,layers:e.layers.map(e=>({tileset_url:e.tileset,up_axis:e.upAxis,name:e.name,type:e.type}))}}function workObserverToObserverJson(e){return{index:e.index,derived_id:e.derivedId,derived_id_str:e.derivedIdStr,floor_index:e.floorIndex,position:e.position.toArray(),standing_position:e.standingPosition.toArray(),quaternion:{x:e.quaternion.x,y:e.quaternion.y,z:e.quaternion.z,w:e.quaternion.w},visible_nodes:e.accessibleNodes.slice(),accessible_nodes:e.accessibleNodes.slice()}}function workObserverToPanoramaJson(e){return{index:e.index,active:e.active,loadable:e.loadable,derived_id:e.derivedId,derived_id_str:e.derivedIdStr,size_list:e.images.sizeList.slice(),up:e.images.up,down:e.images.down,right:e.images.right,left:e.images.left,front:e.images.front,back:e.images.back,video:e.images.video?{matrix:e.images.video.matrix.toArray(),size:e.images.video.size.toArray(),source:e.images.video.source}:void 0}}function workToJson(e){return{allow_hosts:e.allowHosts.slice(),expire_at:e.expire.getTime().toString(),project_id:e.projectId,code:e.workCode,name:e.name,base_url:e.baseURL,initial:workInitialToJson(e.initial),model:workModelToJson(e.model),observers:e.observers.map(e=>workObserverToObserverJson(e)),panorama:{count:e.observers.length,list:e.observers.map(e=>workObserverToPanoramaJson(e))}}}function equirectangularUvToCubemap(e){let t=(e.x*2+1)*Math.PI,n=(.5-e.y)*Math.PI,r=Math.sin(n),o=Math.cos(n),s=Math.sin(t),c=Math.cos(t),l=o*s,u=r,d=o*c,f=Math.abs(l),p=Math.abs(u),m=Math.abs(d),h,g;if(f>=p&&f>=m){let e=1/f;l>0?(h=`right`,g=new three.Vector2(-d*e,u*e)):(h=`left`,g=new three.Vector2(d*e,u*e))}else if(p>=f&&p>=m){let e=1/p;u>0?(h=`up`,g=new three.Vector2(l*e,-d*e)):(h=`down`,g=new three.Vector2(l*e,d*e))}else{let e=1/m;d>0?(h=`front`,g=new three.Vector2(l*e,u*e)):(h=`back`,g=new three.Vector2(-l*e,u*e))}return g.x=(g.x+1)/2,g.y=1-(g.y+1)/2,[h,g]}function cubemapUvToEquirectangular(e,t){let n=t.x*2-1,r=(1-t.y)*2-1,o=0,s=0,c=0;switch(e){case`right`:o=1,s=r,c=-n;break;case`left`:o=-1,s=r,c=n;break;case`up`:o=n,s=1,c=-r;break;case`down`:o=n,s=-1,c=r;break;case`front`:o=n,s=r,c=1;break;case`back`:o=-n,s=r,c=-1;break;default:throw Error(`Invalid cubFace: ${e}`)}let l=Math.sqrt(o*o+s*s+c*c);if(l===0)return new three.Vector2(.5,.5);o/=l,s/=l,c/=l;let u=Math.atan2(o,c),d=Math.asin(Math.max(-1,Math.min(1,s))),f=(u+Math.PI)/(2*Math.PI),p=(Math.PI/2-d)/Math.PI;return f%=1,f=f<0?f+1:f,p=Math.max(0,Math.min(1,p)),new three.Vector2(f,p)}var workObserverProto={vectorToEquirectangularUv(e,t=`top-left`){let n=new three.Quaternion().setFromRotationMatrix(this.work.transform).inverse(),r=new three.Quaternion().copy(this.quaternion).inverse(),o=new three.Quaternion(0,1,0,0).inverse(),s=new three.Vector3().copy(e).normalize().applyQuaternion(n).applyQuaternion(r).applyQuaternion(o),c=Math.atan2(s.x,-s.z),l=Math.asin(-s.y);if(t===`top-left`)return new three.Vector2(c/(Math.PI*2)+.5,l/Math.PI+.5);if(t===`bottom-left`)return new three.Vector2(c/(Math.PI*2)+.5,.5-l/Math.PI);throw Error(`Invalid uvOrigin ${t}`)},vectorToCubemapUv(e,t=`top-left`){let n=equirectangularUvToCubemap(this.vectorToEquirectangularUv(e,`top-left`));if(t===`top-left`)return n;if(t===`bottom-left`){let[e,t]=n;return t.y=1-t.y,n}else throw Error(`Invalid uvOrigin ${t}`)},equirectangularUvToVector(e,t=`top-left`){let n=0;if(t===`top-left`)n=1;else if(t===`bottom-left`)n=-1;else throw Error(`Invalid uvOrigin ${t}`);let r=new three.Quaternion().setFromRotationMatrix(this.work.transform),o=new three.Quaternion().copy(this.quaternion),s=new three.Quaternion(0,1,0,0),c=Math.PI*2*(e.x+.5),l=Math.PI*(e.y-.5),u=Math.abs(Math.cos(l)),d=Math.sin(c)*u,f=-Math.sin(l)*n,p=-Math.cos(c)*u;return new three.Vector3(d,f,p).applyQuaternion(s).applyQuaternion(o).applyQuaternion(r)},cubemapUvToVector(e,t,n=`top-left`){let r;if(n===`top-left`)r=t;else if(n===`bottom-left`)r=new three.Vector2().copy(t),r.y=1-r.y;else throw Error(`Invalid uvOrigin ${n}`);let o=cubemapUvToEquirectangular(e,r);return this.equirectangularUvToVector(o)},getWorldPosition(){return new three.Vector3().copy(this.position).applyMatrix4(this.work.transform)},getWorldStandingPosition(){return new three.Vector3().copy(this.standingPosition).applyMatrix4(this.work.transform)}};function isNumber(e){return typeof e==`number`}function jsonClone(e){if(typeof e!=`object`||!e)return e;if(Array.isArray(e))return e.map(e=>typeof e!=`object`||!e?e:jsonClone(e));{let t={};for(let n in e){let r=e[n];t[n]=typeof r!=`object`||!r?r:jsonClone(r)}return t}}function getType(e){return e==null?`null`:Array.isArray(e)?`array`:typeof e==`object`?`dict`:`value`}function jsonMerge(e,t){let n=getType(e),r=getType(t);if(r===`null`)return e;if(r===`value`)return t;if(r!==n)return jsonClone(t);if(r===`array`)for(let n=0;n<t.length;n++)e[n]=jsonMerge(e[n],t[n]);else if(r===`dict`)for(let n in t)e[n]=jsonMerge(e[n],t[n]);return e}function jsonStableStrinfiy_(e,t=!1){let n=typeof e;if(n===`string`)return JSON.stringify(e);if(e===!0)return`true`;if(e===!1)return`false`;if(e===null)return`null`;if(e instanceof Array){let t=`[`,n=e.length-1,r=0;for(;r<n;r++)t+=jsonStableStrinfiy_(e[r],!1)+`,`;return n>-1&&(t+=jsonStableStrinfiy_(e[r],!1)),t+`]`}if(e instanceof Object){if(typeof e.toJSON==`function`)return jsonStableStrinfiy_(e.toJSON(),t);let n=Object.keys(e).sort(),r=n.length,o=``,s=0;for(;s<r;){let t=n[s],r=jsonStableStrinfiy_(e[t],!0);r!==void 0&&(s&&o!==``&&(o+=`,`),o+=JSON.stringify(t)+`:`+r),s++}return`{`+o+`}`}switch(n){case`function`:return JSON.stringify(e.toString());case`undefined`:return t?void 0:null;case`number`:return e;default:return isFinite(e)?e:null}}function jsonStableStrinfiy(e){return jsonStableStrinfiy_(e,!1)}function jsonHash(e){return`hash::${sha256(jsonStableStrinfiy(e))}`}var PANO_ID_REG=/^(.*)\[(\d+)\]$/;function panoStringify(e){if(!isNaN(e.panoIndex)&&isFinite(e.panoIndex))return`${e.workCode}[${e.panoIndex}]`;throw Error(`Invalid Pano`)}function panoParse(e){let t=e.match(PANO_ID_REG);if(t){let[e,n,r]=t,o=Math.floor(Number(r));if(!isNaN(o)&&isFinite(o))return{workCode:n,panoIndex:o}}throw Error(`Invalid PanoId`)}function panoEqual(e,t){return panoStringify(e)===panoStringify(t)}function isPanoId(e){return typeof e==`string`&&PANO_ID_REG.test(e)}var REG_STR=`\\{([^\\}]+)\\}`;function escapeRegexp(e){return e.replace(/[|\\{}()[\]^$+*?.]/g,`\\$&`).replace(/-/g,`\\x2d`)}function createRegExp(e){return RegExp(`^`+e.map(e=>escapeRegexp(e)).join(`(.+)`)+`$`)}var StringPattern=class{constructor(e){this.strings=[],this.keys=[];let t=new RegExp(REG_STR,`g`),n,r=0;for(;(n=t.exec(e))!==null;)this.strings.push(e.slice(r,n.index)),this.keys.push(n[1]),r=n.index+n[0].length;this.strings.push(e.slice(r))}stringify(e){let t=[this.strings[0]];for(let n=0;n<this.keys.length;n++){let r=e[this.keys[n]];t.push(String(r),this.strings[n+1])}return t.join(``)}match(e){var t;this.matchRegexp=(t=this.matchRegexp)==null?createRegExp(this.strings):t;let n=e.match(this.matchRegexp);if(!n)return null;let r={};for(let e=0;e<this.keys.length;e++){let t=this.keys[e],o=n[e+1];if(r[t]!==o){if(r[t]!==void 0)return null;r[t]=o}}return r}};function deepFreeze(e){Object.freeze(e);let t=typeof e==`function`,n=Object.prototype.hasOwnProperty;return Object.getOwnPropertyNames(e).forEach(function(r){n.call(e,r)&&(!t||r!==`caller`&&r!==`callee`&&r!==`arguments`)&&e[r]!==null&&(typeof e[r]==`object`||typeof e[r]==`function`)&&!Object.isFrozen(e[r])&&deepFreeze(e[r])}),e}var URL_REGEXP=/^[0-9a-z]+\:\/\/(([^:/?#]*)(?::[0-9]+)?)/i,BUILDIN_ALLOW_HOST=deepFreeze(JSON.parse(function(...e){let t=113,n=126,r=0,o=``;return arguments[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}(`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/rnyrr;p{/9/rnyrr;p|z/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`))),domainRegex=/^([^.]+)(\.([^.]+))*$/,currentHostname=typeof location<`u`?location.hostname:`localhost`;function isIPDomain(e){return/^(([1-9]?\d|1\d\d|2[0-4]\d|25[0-5])(\.(?!$)|$)){4}$/.test(e)}function matchDomain(e,t){if(!domainRegex.test(e)||!domainRegex.test(t))return!1;if(e===`*`)return!0;let n=e.split(`.`).reverse(),r=t.split(`.`).reverse();if(n.length<=1)return e===t;for(let e=0;e<n.length;e++)if(n[e]!==r[e])return!1;return!0}function hostnameFromURL(e){if(/^blob\:/i.test(e)||/^data\:/i.test(e))return currentHostname;let t=e.match(URL_REGEXP);return t?t[2]:currentHostname}var error_invalid_input=()=>Error(`Invalid input.`),error_invalid_certificate=()=>Error(`Invalid certificate.`),error_invalid_signature=()=>Error(`Invalid signature.`),error_date_expired=e=>Error(`Date(${e.toString()}) expired.`),error_host_not_allowed=e=>Error(`Host(${JSON.stringify(e)}) is not allowed.`);function ObjectOmit(e,t){let n={};for(let r of Object.keys(e))t.indexOf(r)===-1&&(n[r]=e[r]);return n}function jsonStableNoneNumberStrinfiy_(e,t=!1){let n=typeof e;if(n===`string`)return JSON.stringify(e);if(e===!0)return`true`;if(e===!1)return`false`;if(e===null)return`null`;if(e instanceof Array){let t=`[`,n=e.length-1,r=0;for(;r<n;r++)t+=jsonStableNoneNumberStrinfiy_(e[r],!1)+`,`;return n>-1&&(t+=jsonStableNoneNumberStrinfiy_(e[r],!1)),t+`]`}if(e instanceof Object){if(typeof e.toJSON==`function`)return jsonStableNoneNumberStrinfiy_(e.toJSON(),t);let n=Object.keys(e).sort(),r=n.length,o=``,s=0;for(;s<r;){let t=n[s],r=jsonStableNoneNumberStrinfiy_(e[t],!0);r!==void 0&&(s&&o!==``&&(o+=`,`),o+=JSON.stringify(t)+`:`+r),s++}return`{`+o+`}`}switch(n){case`function`:case`undefined`:return t?void 0:null;case`number`:return 0;default:return isFinite(e)?e:null}}function jsonStableNoneNumberStrinfiy(e){return String(jsonStableNoneNumberStrinfiy_(e,!1))}function verify(e){var t,n,r;let o={};try{o=typeof e==`string`?JSON.parse(e):e}catch(e){return error_invalid_input()}if(typeof o!=`object`)return error_invalid_input();let s=currentHostname,c=Date.now(),l=new Date(typeof o.expire_at==`string`&&/^\d+$/.test(o.expire_at)?Number(o.expire_at):o.expire_at),u=Array.isArray(o.allow_hosts)?o.allow_hosts:[];if(s.length===0||isIPDomain(s)||BUILDIN_ALLOW_HOST.filter(e=>matchDomain(e,s)).length>0){let e=String((t=o.certificate)==null?``:t);if(e)try{let t=new X509;return t.readCertPEM(e),deepFreeze({issuer:t.getSubjectString(),expire:l,allowHosts:u})}catch(e){let t=e instanceof Error?e.message:String(e);console.warn(`[PARSE Error]: Invalid Certificate. `+t)}return deepFreeze({issuer:`none`,expire:l,allowHosts:u})}let d=String((n=o.certificate)==null?``:n);if(!d)return error_invalid_certificate();let f=new X509;f.readCertPEM(d);let p=String((r=o._signature)==null?``:r);return!p||verifyMessage(jsonStableNoneNumberStrinfiy(ObjectOmit(o,[`_signature`])),p,f)===!1?error_invalid_signature():c<l.getTime()?BUILDIN_ALLOW_HOST.concat(u).filter(e=>matchDomain(e,s)).length===0?error_host_not_allowed(s):deepFreeze({issuer:f.getSubjectString(),expire:l,allowHosts:u}):error_date_expired(l)}function verifyURL(e,t){let n=hostnameFromURL(e);return currentHostname.length!==0&&!isIPDomain(currentHostname)&&BUILDIN_ALLOW_HOST.filter(e=>matchDomain(e,currentHostname)).length===0&&!isIPDomain(n)&&BUILDIN_ALLOW_HOST.concat(t).filter(e=>matchDomain(e,n)).length===0?error_host_not_allowed(n):e}var accessibleNodesSet=new Set,PANO_TEXTURE_SCALE=new three.Vector3(1,1,1),FACE_ORDER$1=[`right`,`left`,`up`,`down`,`front`,`back`];function relativeURL(e,t){if(!isAbsoluteURL(e))return e;if(e.indexOf(t)===0)return e.slice(t.length);let n=t.replace(/^https\:/,`http:`);if(e.indexOf(n)===0)return e.slice(n.length);let r=t.replace(/^http\:/,`https:`);return e.indexOf(r)===0?e.slice(r.length):(console.warn(`${e} is not start with base_url(${t}).`),e)}function panoURL(e,t,n){return!isAbsoluteURL(e)&&typeof t==`string`&&t.length>0&&(e=pathJoin(t,String(n),e)),e}function getTileLevel(e){for(let t=10;t>=0;t--)if(512*Math.pow(2,t)<=e)return t;return null}function sortTile(e){e=e.slice().sort((e,t)=>e.level-t.level);let t=[];for(let n of e){if(t.length===0){t.push(n);continue}let e=t[t.length-1];if(n.level>e.level){t.push(n);continue}if(n.size>e.size){t[t.length-1]=n;continue}}return t}function parse(e,t){var n,r,o,s,c,l,u,d,f,p,m,h,g,_,v,y,b,S,C;let w=[],T=null;for(let t of[].concat(e))if(`getURL`in t)T={allowHosts:t.allowHosts,expire:t.expire,issuer:t.issuer},w.push(workToJson(t));else{let e=typeof t==`string`?JSON.parse(t):jsonClone(t),n=verify(e);if(n instanceof Error)return n;T===null&&(T=n),w.push(e)}if(T===null)return Error(`Empty`);defineProperty(t,`issuer`,{enumerable:!0,configurable:!1,writable:!1,value:T.issuer}),defineProperty(t,`expire`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(T.expire)}),defineProperty(t,`allowHosts`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(T.allowHosts)});let E=w.reduce((e,t)=>jsonMerge(e,t));defineProperty(t,`name`,{enumerable:!0,configurable:!1,writable:!1,value:String((n=E.name)==null?`Unknown`:n)}),defineProperty(t,`workCode`,{enumerable:!0,writable:!0,value:String(E.resource_code||E.basic_code||E.vr_code||E.code||E.project_id||E.work_code||E.workCode||createUuid())}),defineProperty(t,`projectId`,{enumerable:!0,writable:!0,value:E.project_id}),defineProperty(t,`baseURL`,{enumerable:!0,writable:!0,value:(()=>{var e;let t=(e=E.base_url)==null?``:e;return t&&t[t.length-1]!==`/`&&(t+=`/`),t})()});let D;typeof E.model==`object`&&(D={},defineProperty(D,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(D,`file`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e=E.model.file_url;if(e)return relativeURL(e,t.baseURL)})()}),defineProperty(D,`textureBase`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e=E.model.material_base_url;return e&&(e=relativeURL(e,t.baseURL)),e})()}),defineProperty(D,`textures`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e;return Array.isArray(E.model.material_textures)&&(e=E.model.material_textures.slice(),Object.freeze(e)),e})()}),defineProperty(D,`upAxis`,{enumerable:!0,configurable:!1,writable:!1,value:E.model.up_axis}),defineProperty(D,`coordinate`,{enumerable:!0,configurable:!1,writable:!1,value:jsonClone(E.model.coordinate)}),defineProperty(D,`layers`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{var e,n,r;let o=[];if(Array.isArray(E.model.layers)){for(let s of E.model.layers)if(s&&s.tileset_url){let c={};defineProperty(c,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(c,`name`,{enumerable:!0,configurable:!1,writable:!1,value:(e=s.name)==null?``:e}),defineProperty(c,`type`,{enumerable:!0,configurable:!1,writable:!1,value:(n=s.type)==null?`mesh`:n}),defineProperty(c,`upAxis`,{enumerable:!0,configurable:!1,writable:!1,value:(r=s.up_axis)==null?`Z`:r}),defineProperty(c,`tileset`,{enumerable:!0,configurable:!1,writable:!1,value:relativeURL(s.tileset_url,t.baseURL)}),o.push(c)}}if(typeof E.model.tiles==`object`){let e=E.model.tiles;if(e&&e.tileset_url){let n={};defineProperty(n,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(n,`name`,{enumerable:!0,configurable:!1,writable:!1,value:`lod`}),defineProperty(n,`type`,{enumerable:!0,configurable:!1,writable:!1,value:`mesh`}),defineProperty(n,`upAxis`,{enumerable:!0,configurable:!1,writable:!1,value:`-Y`}),defineProperty(n,`tileset`,{enumerable:!0,configurable:!1,writable:!1,value:relativeURL(e.tileset_url,t.baseURL)}),o.push(n)}}return Object.freeze(o)})()})),defineProperty(t,`model`,{enumerable:!0,configurable:!1,writable:!1,value:D});let O=[];if(Array.isArray(E.observers)&&E.panorama&&Array.isArray(E.panorama.list||E.panorama.info)){let e=E.observers,n=(r=E.panorama.list||E.panorama.info)==null?[]:r,w=(d=(l=(s=(o=E.panorama)==null?void 0:o.pano_high_cube_base_url)==null?(c=E.panorama)==null?void 0:c.pano_cube_base_url:s)==null?(u=E.panorama)==null?void 0:u.base_url:l)==null?``:d,T=Math.min(e.length,n.length),D={};for(let e of Object.keys((f=E.panorama.pattern)==null?{}:f)){let t=e,n=E.panorama.pattern[t];if(typeof n==`string`){let e=new StringPattern(n);D[t]=t=>e.stringify(t)}else D[t]=()=>n}let k=(e,t)=>{var n;let r=D[t];return(n=e[t])==null?r?r(e):void 0:n};for(let r=0;r<T;r++){let o=e[r],s=n[r],c=Object.create(workObserverProto);defineProperty(c,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(c,`index`,{enumerable:!0,configurable:!1,writable:!1,value:r}),defineProperty(c,`panoIndex`,{enumerable:!0,configurable:!1,writable:!1,value:r}),defineProperty(c,`panoId`,{enumerable:!0,configurable:!1,writable:!1,value:panoStringify({workCode:t.workCode,panoIndex:r})}),defineProperty(c,`floorIndex`,{enumerable:!0,configurable:!1,writable:!1,value:(p=o.floor_index)==null?o.floor:p}),defineProperty(c,`derivedId`,{enumerable:!0,configurable:!1,writable:!1,value:(h=(m=o.derived_id)==null?k(s,`derived_id`):m)==null?0:h}),defineProperty(c,`derivedIdStr`,{enumerable:!0,configurable:!1,writable:!1,value:(_=(g=o.derived_id_str)==null?k(s,`derived_id_str`):g)==null?String(c.derivedId):_}),defineProperty(c,`active`,{enumerable:!0,configurable:!1,writable:!1,value:o.active!==!1&&k(s,`active`)!==!1}),defineProperty(c,`loadable`,{enumerable:!0,configurable:!1,writable:!1,value:(y=(v=o.loadable)==null?k(s,`loadable`):v)==null?!1:y}),defineProperty(c,`position`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new three.Vector3().fromArray((b=o.position)==null?[0,0,0]:b))}),defineProperty(c,`standingPosition`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new three.Vector3().fromArray((C=(S=o.standing_position)==null?o.standingPosition:S)==null?[0,0,0]:C))}),defineProperty(c,`quaternion`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new three.Quaternion().fromArray(o.quaternion?[o.quaternion.x,o.quaternion.y,o.quaternion.z,o.quaternion.w]:[0,0,0,1]))}),defineProperty(c,`matrix`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new three.Matrix4().compose(c.position,c.quaternion,PANO_TEXTURE_SCALE))}),defineProperty(c,`accessibleNodes`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{if(accessibleNodesSet.clear(),o.accessible_nodes&&Array.isArray(o.accessible_nodes))for(let e of o.accessible_nodes)e>=T||e===r||accessibleNodesSet.add(e);else if(o.accessibleNodes&&Array.isArray(o.accessibleNodes))for(let e of o.accessibleNodes)e>=T||e===r||accessibleNodesSet.add(e);else if(o.visible_nodes&&Array.isArray(o.visible_nodes))for(let e of o.visible_nodes)e>=T||e===r||accessibleNodesSet.add(e);else if(o.visibleNodes&&Array.isArray(o.visibleNodes))for(let e of o.visibleNodes)e>=T||e===r||accessibleNodesSet.add(e);if(accessibleNodesSet.size===0)for(let e=0;e<T;e++)e!==r&&accessibleNodesSet.add(e);let e=Array.from(accessibleNodesSet);return accessibleNodesSet.clear(),Object.freeze(e)})()}),defineProperty(c,`visibleNodes`,{enumerable:!0,configurable:!1,writable:!1,value:c.accessibleNodes}),defineProperty(c,`images`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e={};defineProperty(e,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t});for(let n of FACE_ORDER$1)defineProperty(e,n,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{var e;return relativeURL(panoURL((e=k(s,n))==null?``:e,w,r),t.baseURL)})()});return defineProperty(e,`sizeList`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let t=getImageSizeFromURL(e[FACE_ORDER$1[0]]),n=k(s,`size_list`),r=k(s,`tiles`);if(t){if(n){let e=n.slice().sort((e,t)=>e-t);return Object.freeze(e)}else if(r){let e=[t],n=r.slice().sort((e,t)=>e-t);for(let r of n){let n=512*Math.pow(2,r);n>t&&e.push(n)}return Object.freeze(e)}return Object.freeze([t])}return Object.freeze([])})()}),defineProperty(e,`tiles`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let n=getImageSizeFromURL(e.front);if(!n)return;let r=e.sizeList.slice();if(r[0]){let e=getTileLevel(r[0]);if(e)for(let t=e-1;t>=0;t--)r.unshift(512*Math.pow(2,t))}if(r.length<=0)return;let o=[];for(let s of r){let r=getTileLevel(s);if(typeof r!=`number`)continue;let c={};if(defineProperty(c,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(c,`level`,{enumerable:!0,configurable:!1,writable:!1,value:r}),s>n){defineProperty(c,`size`,{enumerable:!0,configurable:!1,writable:!1,value:s}),defineProperty(c,`scale`,{enumerable:!0,configurable:!1,writable:!1,value:1});for(let t of FACE_ORDER$1)defineProperty(c,t,{enumerable:!0,configurable:!1,writable:!1,value:replaceImageSize(e[t],s)})}else{defineProperty(c,`size`,{enumerable:!0,configurable:!1,writable:!1,value:n}),defineProperty(c,`scale`,{enumerable:!0,configurable:!1,writable:!1,value:s/n});for(let t of FACE_ORDER$1)defineProperty(c,t,{enumerable:!0,configurable:!1,writable:!1,value:e[t]})}o.push(c)}return o=sortTile(o),Object.freeze(o)})()}),defineProperty(e,`video`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e=k(s,`video`),n;return e&&(n={},defineProperty(n,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(n,`source`,{enumerable:!0,configurable:!1,writable:!1,value:e.source}),defineProperty(n,`matrix`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Matrix4().fromArray(e.matrix)}),defineProperty(n,`size`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Vector2().fromArray(e.size)})),n})()}),e})()}),O.push(c)}}defineProperty(t,`observers`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(O)});let k={};if(defineProperty(k,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),E.initial){if(t.observers.length>0){let e;isNumber(E.initial.panoIndex)?e=E.initial.panoIndex:isNumber(E.initial.pano_index)?e=E.initial.pano_index:isNumber(E.initial.pano)&&(e=E.initial.pano),typeof e==`number`&&(e=clamp$1(e,0,t.observers.length-1),defineProperty(k,`panoIndex`,{enumerable:!0,writable:!0,value:e}))}if(E.initial.mode===`Panorama`&&t.observers.length===0||E.initial.mode===`Floorplan`||E.initial.mode===`Topview`||E.initial.mode===`Model`||E.initial.mode===`Mapview`?defineProperty(k,`mode`,{enumerable:!0,writable:!0,value:E.initial.mode}):typeof k.panoIndex==`number`?defineProperty(k,`mode`,{enumerable:!0,writable:!0,value:`Panorama`}):defineProperty(k,`mode`,{enumerable:!0,writable:!0,value:`Mapview`}),isNumber(E.initial.latitude)&&defineProperty(k,`latitude`,{enumerable:!0,writable:!0,value:E.initial.latitude}),isNumber(E.initial.longitude)?defineProperty(k,`longitude`,{enumerable:!0,writable:!0,value:E.initial.longitude}):isNumber(E.initial.heading)&&defineProperty(k,`longitude`,{enumerable:!0,writable:!0,value:headingToLongitude(E.initial.heading)}),isNumber(E.initial.fov)&&defineProperty(k,`fov`,{enumerable:!0,writable:!0,value:E.initial.fov}),isNumber(E.initial.distance)&&defineProperty(k,`distance`,{enumerable:!0,writable:!0,value:E.initial.distance}),Array.isArray(E.initial.offset)){let e=E.initial.offset,t=[0,0,0].map((t,n)=>{let r=Number(e[n]);return isNaN(r)||!isFinite(r)?0:r});defineProperty(k,`offset`,{enumerable:!0,writable:!0,value:new three.Vector3().fromArray(t)})}else typeof E.initial.offset==`object`&&typeof E.initial.offset.x==`number`&&typeof E.initial.offset.y==`number`&&typeof E.initial.offset.z==`number`&&defineProperty(k,`offset`,{enumerable:!0,writable:!0,value:new three.Vector3().fromArray([E.initial.offset.x,E.initial.offset.y,E.initial.offset.z])})}return defineProperty(t,`initial`,{enumerable:!0,configurable:!1,writable:!1,value:k}),t}function parseNull(e,t){return defineProperty(t,`issuer`,{enumerable:!0,configurable:!1,writable:!1,value:`null`}),defineProperty(t,`expire`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new Date)}),defineProperty(t,`allowHosts`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze([`*`])}),defineProperty(t,`name`,{enumerable:!0,configurable:!1,writable:!1,value:`Null`}),defineProperty(t,`workCode`,{enumerable:!0,value:`null-`+createUuid()}),defineProperty(t,`baseURL`,{enumerable:!0,value:`/`}),defineProperty(t,`model`,{enumerable:!0,configurable:!1,writable:!1,value:void 0}),defineProperty(t,`observers`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze([])}),defineProperty(t,`initial`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e={};return defineProperty(e,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(e,`mode`,{enumerable:!0,writable:!0,value:`Mapview`}),e})()}),t}function parsePano(e,t){var n,r;return defineProperty(t,`issuer`,{enumerable:!0,configurable:!1,writable:!1,value:`null`}),defineProperty(t,`expire`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze(new Date)}),defineProperty(t,`allowHosts`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze([`*`])}),defineProperty(t,`name`,{enumerable:!0,configurable:!1,writable:!1,value:String((n=e.name)==null?`Unknown`:n)}),defineProperty(t,`workCode`,{enumerable:!0,writable:!0,value:(r=e.code)==null?createUuid():r}),defineProperty(t,`baseURL`,{enumerable:!0,writable:!0,value:`/`}),defineProperty(t,`model`,{enumerable:!0,configurable:!1,writable:!1,value:void 0}),defineProperty(t,`observers`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let n={};return defineProperty(n,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(n,`index`,{enumerable:!0,configurable:!1,writable:!1,value:0}),defineProperty(n,`panoIndex`,{enumerable:!0,configurable:!1,writable:!1,value:0}),defineProperty(n,`panoId`,{enumerable:!0,configurable:!1,writable:!1,value:panoStringify({workCode:t.workCode,panoIndex:0})}),defineProperty(n,`floorIndex`,{enumerable:!0,configurable:!1,writable:!1,value:0}),defineProperty(n,`derivedId`,{enumerable:!0,configurable:!1,writable:!1,value:void 0}),defineProperty(n,`derivedIdStr`,{enumerable:!0,configurable:!1,writable:!1,value:void 0}),defineProperty(n,`active`,{enumerable:!0,configurable:!1,writable:!1,value:!0}),defineProperty(n,`loadable`,{enumerable:!0,configurable:!1,writable:!1,value:!1}),defineProperty(n,`position`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Vector3(0,1.5,0)}),defineProperty(n,`standingPosition`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Vector3(0,0,0)}),defineProperty(n,`quaternion`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Quaternion(0,1,0,0)}),defineProperty(n,`matrix`,{enumerable:!0,configurable:!1,writable:!1,value:new three.Matrix4().compose(n.position,n.quaternion,PANO_TEXTURE_SCALE)}),defineProperty(n,`accessibleNodes`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze([])}),defineProperty(n,`visibleNodes`,{enumerable:!0,configurable:!1,writable:!1,value:n.accessibleNodes}),defineProperty(n,`images`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let n={};defineProperty(n,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t});for(let t of FACE_ORDER$1)defineProperty(n,t,{enumerable:!0,configurable:!1,writable:!1,value:e[t]});return defineProperty(n,`sizeList`,{enumerable:!0,configurable:!1,writable:!1,value:Object.freeze([e.size])}),defineProperty(n,`tiles`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e=getImageSizeFromURL(n.front);if(!e)return;let r=n.sizeList.slice();if(r[0]){let e=getTileLevel(r[0]);if(e)for(let t=e-1;t>=0;t--)r.unshift(512*Math.pow(2,t))}if(r.length<=0)return;let o=[];for(let s of r){let r=getTileLevel(s);if(typeof r!=`number`)continue;let c={};if(defineProperty(c,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(c,`level`,{enumerable:!0,configurable:!1,writable:!1,value:r}),s>e){defineProperty(c,`size`,{enumerable:!0,configurable:!1,writable:!1,value:s}),defineProperty(c,`scale`,{enumerable:!0,configurable:!1,writable:!1,value:1});for(let e of FACE_ORDER$1)defineProperty(c,e,{enumerable:!0,configurable:!1,writable:!1,value:replaceImageSize(n[e],s)})}else{defineProperty(c,`size`,{enumerable:!0,configurable:!1,writable:!1,value:e}),defineProperty(c,`scale`,{enumerable:!0,configurable:!1,writable:!1,value:s/e});for(let e of FACE_ORDER$1)defineProperty(c,e,{enumerable:!0,configurable:!1,writable:!1,value:n[e]})}o.push(c)}return o=sortTile(o),Object.freeze(o)})()}),defineProperty(n,`video`,{enumerable:!0,configurable:!1,writable:!1,value:void 0}),n})()}),Object.freeze([n])})()}),defineProperty(t,`initial`,{enumerable:!0,configurable:!1,writable:!1,value:(()=>{let e={};return defineProperty(e,`work`,{enumerable:!1,configurable:!1,writable:!1,value:t}),defineProperty(e,`mode`,{enumerable:!0,writable:!0,value:`Panorama`}),defineProperty(e,`panoIndex`,{enumerable:!0,writable:!0,value:0}),e})()}),t}var workVerifySet=new WeakSet,Work=class{constructor(e,t){this.observerBox=new three.Box3,this.observerBox=new three.Box3,this.transform=new three.Matrix4,this.shortPath=!1,this.jsonp=!1;let n;if(n=e===null?parseNull(e,this):typeof e==`object`&&typeof e.size==`number`&&typeof e.up==`string`&&typeof e.down==`string`&&typeof e.right==`string`&&typeof e.left==`string`&&typeof e.front==`string`&&typeof e.back==`string`?parsePano(e,this):parse(e,this),n instanceof Error)throw Error(`[PARSE FAILED]: `+n.message+`
939
939
  Error work input:
940
940
  `+JSON.stringify(e));workVerifySet.add(this);for(let e of this.observers)this.observerBox.expandByPoint(e.position),this.observerBox.expandByPoint(e.standingPosition);t.baseURL&&(this.baseURL=t.baseURL),t.transform&&(Array.isArray(t.transform)?this.transform.fromArray(t.transform):this.transform.copy(t.transform)),typeof t.jsonp==`boolean`&&(this.jsonp=t.jsonp),typeof t.shortPath==`boolean`&&(this.shortPath=t.shortPath),t.workCode&&(typeof t.workCode==`string`?this.workCode=t.workCode:typeof t.workCode==`function`&&(this.workCode=t.workCode(e)));{let e=this;this.options={get transform(){return e.transform}},this.raw={get works(){return[JSON.stringify(workToJson(e))]}}}}getURL(e){var t;if(!isAbsoluteURL(e)){if(this.jsonp===!0){e=e.replace(/([\?\#].*)?$/i,``);let t=sha256(`${e}`).slice(0,7);e=`${e}.${t}.jsonp`}if(this.shortPath===!0){let n=e.replace(e,``).split(`.`),r=(t=n.shift())==null?``:t,o=n.join(`.`);e=sha256(r)+(o?`.`+o:``)}e=pathJoin(this.baseURL,e)}return e=getFullURL(e),e}verifyURL(e){return typeof verifyURL(this.getURL(e),this.allowHosts)==`string`}toJSON(){return workToJson(this)}};Work.parse=parseWork;function parseWork(e,t){typeof e==`string`&&e.trim()[0]===`{`&&(e=JSON.parse(e));try{return new Work(e,t==null?{}:t)}catch(t){console.log(t);let n=t instanceof Error?t.message:String(t);throw Error(`[PARSE Error]: `+n+`
941
941
  Error work input:
@@ -1496,7 +1496,7 @@ void main() {
1496
1496
  }
1497
1497
  `,uniforms:{cubemap:{value:null},scaleY:{value:1}},defines:{},transparent:!0,depthTest:!1,depthWrite:!1}));function renderCubeToEquirectangular(e,t,n){equirectangularFsQuad.material.setUniform(`cubemap`,t),equirectangularFsQuad.material.setUniform(`scaleY`,n?-1:1),equirectangularFsQuad.render(e),equirectangularFsQuad.material.setUniform(`cubemap`,null)}var scratchPrevClearColor$2=new three.Color,clippingPlanes$1=[],clearColor$2=0,clearAlpha$1=1;function getRgbaDataFromCubeTexture(e,t,n,r){let o=new three.WebGLRenderTarget(r.width,r.height,{depthBuffer:!1,stencilBuffer:!1,generateMipmaps:!1,magFilter:three.LinearFilter,minFilter:three.LinearFilter}),s=e.getRenderTarget();scratchPrevClearColor$2.copy(e.getClearColor());let c=e.getClearAlpha(),l=e.autoClear,u=e.autoClearColor,d=e.autoClearDepth,f=e.autoClearStencil,p=e.clippingPlanes;return e.autoClear=!0,e.autoClearColor=!0,e.autoClearDepth=!0,e.autoClearStencil=!0,e.clippingPlanes=clippingPlanes$1,e.setRenderTarget(o),e.setClearColor(clearColor$2,clearAlpha$1),renderCubeToEquirectangular(e,t,n),e.setRenderTarget(s),e.setClearColor(scratchPrevClearColor$2,c),e.autoClear=l,e.autoClearColor=u,e.autoClearDepth=d,e.autoClearStencil=f,e.clippingPlanes=p,e.readRenderTargetPixels(o,0,0,r.width,r.height,r.data),o.dispose(),r}var Hammer=(function(e,t,n,r){"use strict";var o=[``,`webkit`,`Moz`,`MS`,`ms`,`o`],s=t.createElement?t.createElement(`div`):r,c=`function`,l=Math.round,u=Math.abs,d=Date.now;function f(e,t,n){return setTimeout(b(e,n),t)}function p(e,t,n){return Array.isArray(e)?(m(e,n[t],n),!0):!1}function m(e,t,n){var o;if(e)if(e.forEach)e.forEach(t,n);else if(e.length!==r)for(o=0;o<e.length;)t.call(n,e[o],o,e),o++;else for(o in e)e.hasOwnProperty(o)&&t.call(n,e[o],o,e)}function h(t,n,r){var o=`DEPRECATED METHOD: `+n+`
1498
1498
  `+r+` AT
1499
- `;return function(){var n=Error(`get-stack-trace`),r=n&&n.stack?n.stack.replace(/^[^\(]+?[\n$]/gm,``).replace(/^\s+at\s+/gm,``).replace(/^Object.<anonymous>\s*\(/gm,`{anonymous}()@`):`Unknown Stack Trace`,s=e.console&&(e.console.warn||e.console.log);return s&&s.call(e.console,o,r),t.apply(this,arguments)}}var g=typeof Object.assign==`function`?Object.assign:function(e){if(e===r||e===null)throw TypeError(`Cannot convert undefined or null to object`);for(var t=Object(e),n=1;n<arguments.length;n++){var o=arguments[n];if(o!==r&&o!==null)for(var s in o)o.hasOwnProperty(s)&&(t[s]=o[s])}return t},_=h(function(e,t,n){for(var o=Object.keys(t),s=0;s<o.length;)(!n||n&&e[o[s]]===r)&&(e[o[s]]=t[o[s]]),s++;return e},`extend`,"Use `assign`."),v=h(function(e,t){return _(e,t,!0)},`merge`,"Use `assign`.");function y(e,t,n){var r=t.prototype,o=e.prototype=Object.create(r);o.constructor=e,o._super=r,n&&g(o,n)}function b(e,t){return function(){return e.apply(t,arguments)}}function S(e,t){return typeof e==c?e.apply(t&&t[0]||r,t):e}function C(e,t){return e===r?t:e}function w(e,t,n){m(O(t),function(t){e.addEventListener(t,n,!1)})}function T(e,t,n){m(O(t),function(t){e.removeEventListener(t,n,!1)})}function E(e,t){for(;e;){if(e==t)return!0;e=e.parentNode}return!1}function D(e,t){return e.indexOf(t)>-1}function O(e){return e.trim().split(/\s+/g)}function k(e,t,n){if(e.indexOf&&!n)return e.indexOf(t);for(var r=0;r<e.length;){if(n&&e[r][n]==t||!n&&e[r]===t)return r;r++}return-1}function A(e){return Array.prototype.slice.call(e,0)}function j(e,t,n){for(var r=[],o=[],s=0;s<e.length;){var c=t?e[s][t]:e[s];k(o,c)<0&&r.push(e[s]),o[s]=c,s++}return n&&(r=t?r.sort(function(e,n){return e[t]>n[t]}):r.sort()),r}function M(e,t){for(var n,s,c=t[0].toUpperCase()+t.slice(1),l=0;l<o.length;){if(n=o[l],s=n?n+c:t,s in e)return s;l++}return r}var N=1;function P(){return N++}function F(t){var n=t.ownerDocument||t;return n.defaultView||n.parentWindow||e}var I=/mobile|tablet|ip(ad|hone|od)|android/i,L=`ontouchstart`in e,R=M(e,`PointerEvent`)!==r,z=L&&I.test(navigator.userAgent),B=`touch`,V=`pen`,H=`mouse`,ee=`kinect`,te=25,U=1,W=2,G=4,K=8,ne=1,re=2,ie=4,ae=8,oe=16,q=re|ie,se=ae|oe,ce=q|se,le=[`x`,`y`],ue=[`clientX`,`clientY`];function J(e,t){var n=this;this.manager=e,this.callback=t,this.element=e.element,this.target=e.options.inputTarget,this.domHandler=function(t){S(e.options.enable,[e])&&n.handler(t)},this.init()}J.prototype={handler:function(){},init:function(){this.evEl&&w(this.element,this.evEl,this.domHandler),this.evTarget&&w(this.target,this.evTarget,this.domHandler),this.evWin&&w(F(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&T(this.element,this.evEl,this.domHandler),this.evTarget&&T(this.target,this.evTarget,this.domHandler),this.evWin&&T(F(this.element),this.evWin,this.domHandler)}};function de(e){var t;return t=e.options.inputClass||(R?Ae:z?Le:L?Ve:Te),new t(e,fe)}function fe(e,t,n){var r=n.pointers.length,o=n.changedPointers.length,s=t&U&&r-o===0,c=t&(G|K)&&r-o===0;n.isFirst=!!s,n.isFinal=!!c,s&&(e.session={}),n.eventType=t,pe(e,n),e.emit(`hammer.input`,n),e.recognize(n),e.session.prevInput=n}function pe(e,t){var n=e.session,r=t.pointers,o=r.length;n.firstInput||(n.firstInput=ge(t)),o>1&&!n.firstMultiple?n.firstMultiple=ge(t):o===1&&(n.firstMultiple=!1);var s=n.firstInput,c=n.firstMultiple,l=c?c.center:s.center,f=t.center=Y(r);t.timeStamp=d(),t.deltaTime=t.timeStamp-s.timeStamp,t.angle=ye(l,f),t.distance=X(l,f),me(n,t),t.offsetDirection=ve(t.deltaX,t.deltaY);var p=_e(t.deltaTime,t.deltaX,t.deltaY);t.overallVelocityX=p.x,t.overallVelocityY=p.y,t.overallVelocity=u(p.x)>u(p.y)?p.x:p.y,t.scale=c?xe(c.pointers,r):1,t.rotation=c?be(c.pointers,r):0,t.maxPointers=n.prevInput?t.pointers.length>n.prevInput.maxPointers?t.pointers.length:n.prevInput.maxPointers:t.pointers.length,he(n,t);var m=e.element;E(t.srcEvent.target,m)&&(m=t.srcEvent.target),t.target=m}function me(e,t){var n=t.center,r=e.offsetDelta||{},o=e.prevDelta||{},s=e.prevInput||{};(t.eventType===U||s.eventType===G)&&(o=e.prevDelta={x:s.deltaX||0,y:s.deltaY||0},r=e.offsetDelta={x:n.x,y:n.y}),t.deltaX=o.x+(n.x-r.x),t.deltaY=o.y+(n.y-r.y)}function he(e,t){var n=e.lastInterval||t,o=t.timeStamp-n.timeStamp,s,c,l,d;if(t.eventType!=K&&(o>te||n.velocity===r)){var f=t.deltaX-n.deltaX,p=t.deltaY-n.deltaY,m=_e(o,f,p);c=m.x,l=m.y,s=u(m.x)>u(m.y)?m.x:m.y,d=ve(f,p),e.lastInterval=t}else s=n.velocity,c=n.velocityX,l=n.velocityY,d=n.direction;t.velocity=s,t.velocityX=c,t.velocityY=l,t.direction=d}function ge(e){for(var t=[],n=0;n<e.pointers.length;)t[n]={clientX:l(e.pointers[n].clientX),clientY:l(e.pointers[n].clientY)},n++;return{timeStamp:d(),pointers:t,center:Y(t),deltaX:e.deltaX,deltaY:e.deltaY}}function Y(e){var t=e.length;if(t===1)return{x:l(e[0].clientX),y:l(e[0].clientY)};for(var n=0,r=0,o=0;o<t;)n+=e[o].clientX,r+=e[o].clientY,o++;return{x:l(n/t),y:l(r/t)}}function _e(e,t,n){return{x:t/e||0,y:n/e||0}}function ve(e,t){return e===t?ne:u(e)>=u(t)?e<0?re:ie:t<0?ae:oe}function X(e,t,n){n||(n=le);var r=t[n[0]]-e[n[0]],o=t[n[1]]-e[n[1]];return Math.sqrt(r*r+o*o)}function ye(e,t,n){n||(n=le);var r=t[n[0]]-e[n[0]],o=t[n[1]]-e[n[1]];return Math.atan2(o,r)*180/Math.PI}function be(e,t){return ye(t[1],t[0],ue)+ye(e[1],e[0],ue)}function xe(e,t){return X(t[0],t[1],ue)/X(e[0],e[1],ue)}var Se={mousedown:U,mousemove:W,mouseup:G},Ce=`mousedown`,we=`mousemove mouseup`;function Te(){this.evEl=Ce,this.evWin=we,this.pressed=!1,J.apply(this,arguments)}y(Te,J,{handler:function(e){var t=Se[e.type];t&U&&(e.button===0||e.button===2)&&(this.pressed=!0),t&W&&e.which!==1&&(t=G),this.pressed&&(t&G&&(this.pressed=!1),this.callback(this.manager,t,{pointers:[e],changedPointers:[e],pointerType:H,srcEvent:e}))}});var Ee={pointerdown:U,pointermove:W,pointerup:G,pointercancel:K,pointerout:K},De={2:B,3:V,4:H,5:ee},Oe=`pointerdown`,ke=`pointermove pointerup pointercancel`;e.MSPointerEvent&&!e.PointerEvent&&(Oe=`MSPointerDown`,ke=`MSPointerMove MSPointerUp MSPointerCancel`);function Ae(){this.evEl=Oe,this.evWin=ke,J.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}y(Ae,J,{handler:function(e){var t=this.store,n=!1,r=!1,o=Ee[e.type.toLowerCase().replace(`ms`,``)],s=De[e.pointerType]||e.pointerType,c=s==B,l=k(t,e.pointerId,`pointerId`);o&U&&(e.button===0||e.button===2||c)?l<0&&(t.push(e),l=t.length-1):o&(G|K)?n=!0:!c&&e.buttons===0&&(n=!0,r=!0,o=Ee.pointerup),!(l<0)&&(r||(t[l]=e),this.callback(this.manager,o,{pointers:t,changedPointers:[e],pointerType:s,srcEvent:t[l]}),n&&t.splice(l,1))}});var je={touchstart:U,touchmove:W,touchend:G,touchcancel:K},Z=`touchstart`,Me=`touchstart touchmove touchend touchcancel`;function Ne(){this.evTarget=Z,this.evWin=Me,this.started=!1,J.apply(this,arguments)}y(Ne,J,{handler:function(e){var t=je[e.type];if(t===U&&(this.started=!0),this.started){var n=Pe.call(this,e,t);t&(G|K)&&n[0].length-n[1].length===0&&(this.started=!1),this.callback(this.manager,t,{pointers:n[0],changedPointers:n[1],pointerType:B,srcEvent:e})}}});function Pe(e,t){var n=A(e.touches),r=A(e.changedTouches);return t&(G|K)&&(n=j(n.concat(r),`identifier`,!0)),[n,r]}var Fe={touchstart:U,touchmove:W,touchend:G,touchcancel:K},Ie=`touchstart touchmove touchend touchcancel`;function Le(){this.evTarget=Ie,this.targetIds={},J.apply(this,arguments)}y(Le,J,{handler:function(e){var t=Fe[e.type],n=Re.call(this,e,t);n&&this.callback(this.manager,t,{pointers:n[0],changedPointers:n[1],pointerType:B,srcEvent:e})}});function Re(e,t){var n=A(e.touches),r=this.targetIds;if(t&(U|W)&&n.length===1)return r[n[0].identifier]=!0,[n,n];var o,s,c=A(e.changedTouches),l=[],u=this.target;if(s=n.filter(function(e){return E(e.target,u)}),t===U)for(o=0;o<s.length;)r[s[o].identifier]=!0,o++;for(o=0;o<c.length;)r[c[o].identifier]&&l.push(c[o]),t&(G|K)&&delete r[c[o].identifier],o++;if(l.length)return[j(s.concat(l),`identifier`,!0),l]}var ze=2500,Be=25;function Ve(){J.apply(this,arguments);var e=b(this.handler,this);this.touch=new Le(this.manager,e),this.mouse=new Te(this.manager,e),this.primaryTouch=null,this.lastTouches=[]}y(Ve,J,{handler:function(e,t,n){var r=n.pointerType==B,o=n.pointerType==H;if(!(o&&n.sourceCapabilities&&n.sourceCapabilities.firesTouchEvents)){if(r)He.call(this,t,n);else if(o&&We.call(this,n))return;this.callback(e,t,n)}},destroy:function(){this.touch.destroy(),this.mouse.destroy()}});function He(e,t){e&U?(this.primaryTouch=t.changedPointers[0].identifier,Ue.call(this,t)):e&(G|K)&&Ue.call(this,t)}function Ue(e){var t=e.changedPointers[0];if(t.identifier===this.primaryTouch){var n={x:t.clientX,y:t.clientY};this.lastTouches.push(n);var r=this.lastTouches;setTimeout(function(){var e=r.indexOf(n);e>-1&&r.splice(e,1)},ze)}}function We(e){for(var t=e.srcEvent.clientX,n=e.srcEvent.clientY,r=0;r<this.lastTouches.length;r++){var o=this.lastTouches[r],s=Math.abs(t-o.x),c=Math.abs(n-o.y);if(s<=Be&&c<=Be)return!0}return!1}var Ge=s?M(s.style,`touchAction`):r,Ke=Ge!==r,qe=`compute`,Je=`auto`,Ye=`manipulation`,Xe=`none`,Ze=`pan-x`,Qe=`pan-y`,$e=rt();function tt(e,t){this.manager=e,this.set(t)}tt.prototype={set:function(e){e==qe&&(e=this.compute()),Ke&&this.manager.element.style&&$e[e]&&(this.manager.element.style[Ge]=e),this.actions=e.toLowerCase().trim()},update:function(){this.set(this.manager.options.touchAction)},compute:function(){var e=[];return m(this.manager.recognizers,function(t){S(t.options.enable,[t])&&(e=e.concat(t.getTouchAction()))}),nt(e.join(` `))},preventDefaults:function(e){var t=e.srcEvent,n=e.offsetDirection;if(this.manager.session.prevented){t.preventDefault();return}var r=this.actions,o=D(r,Xe)&&!$e[Xe],s=D(r,Qe)&&!$e[Qe],c=D(r,Ze)&&!$e[Ze];if(o){var l=e.pointers.length===1,u=e.distance<2,d=e.deltaTime<250;if(l&&u&&d)return}if(!(c&&s)&&(o||s&&n&q||c&&n&se))return this.preventSrc(t)},preventSrc:function(e){this.manager.session.prevented=!0,e.preventDefault()}};function nt(e){if(D(e,Xe))return Xe;var t=D(e,Ze),n=D(e,Qe);return t&&n?Xe:t||n?t?Ze:Qe:D(e,Ye)?Ye:Je}function rt(){if(!Ke)return!1;var t={},n=e.CSS&&e.CSS.supports;return[`auto`,`manipulation`,`pan-y`,`pan-x`,`pan-x pan-y`,`none`].forEach(function(r){t[r]=n?e.CSS.supports(`touch-action`,r):!0}),t}var it=1,Q=2,at=4,ot=8,st=ot,ct=16,lt=32;function ut(e){this.options=g({},this.defaults,e||{}),this.id=P(),this.manager=null,this.options.enable=C(this.options.enable,!0),this.state=it,this.simultaneous={},this.requireFail=[]}ut.prototype={defaults:{},set:function(e){return g(this.options,e),this.manager&&this.manager.touchAction.update(),this},recognizeWith:function(e){if(p(e,`recognizeWith`,this))return this;var t=this.simultaneous;return e=pt(e,this),t[e.id]||(t[e.id]=e,e.recognizeWith(this)),this},dropRecognizeWith:function(e){return p(e,`dropRecognizeWith`,this)?this:(e=pt(e,this),delete this.simultaneous[e.id],this)},requireFailure:function(e){if(p(e,`requireFailure`,this))return this;var t=this.requireFail;return e=pt(e,this),k(t,e)===-1&&(t.push(e),e.requireFailure(this)),this},dropRequireFailure:function(e){if(p(e,`dropRequireFailure`,this))return this;e=pt(e,this);var t=k(this.requireFail,e);return t>-1&&this.requireFail.splice(t,1),this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(e){return!!this.simultaneous[e.id]},emit:function(e){var t=this,n=this.state;function r(n){t.manager.emit(n,e)}n<ot&&r(t.options.event+dt(n)),r(t.options.event),e.additionalEvent&&r(e.additionalEvent),n>=ot&&r(t.options.event+dt(n))},tryEmit:function(e){if(this.canEmit())return this.emit(e);this.state=lt},canEmit:function(){for(var e=0;e<this.requireFail.length;){if(!(this.requireFail[e].state&(lt|it)))return!1;e++}return!0},recognize:function(e){var t=g({},e);if(!S(this.options.enable,[this,t])){this.reset(),this.state=lt;return}this.state&(st|ct|lt)&&(this.state=it),this.state=this.process(t),this.state&(Q|at|ot|ct)&&this.tryEmit(t)},process:function(e){},getTouchAction:function(){},reset:function(){}};function dt(e){return e&ct?`cancel`:e&ot?`end`:e&at?`move`:e&Q?`start`:``}function ft(e){return e==oe?`down`:e==ae?`up`:e==re?`left`:e==ie?`right`:``}function pt(e,t){var n=t.manager;return n?n.get(e):e}function $(){ut.apply(this,arguments)}y($,ut,{defaults:{pointers:1},attrTest:function(e){var t=this.options.pointers;return t===0||e.pointers.length===t},process:function(e){var t=this.state,n=e.eventType,r=t&(Q|at),o=this.attrTest(e);return r&&(n&K||!o)?t|ct:r||o?n&G?t|ot:t&Q?t|at:Q:lt}});function mt(){$.apply(this,arguments),this.pX=null,this.pY=null}y(mt,$,{defaults:{event:`pan`,threshold:10,pointers:1,direction:ce},getTouchAction:function(){var e=this.options.direction,t=[];return e&q&&t.push(Qe),e&se&&t.push(Ze),t},directionTest:function(e){var t=this.options,n=!0,r=e.distance,o=e.direction,s=e.deltaX,c=e.deltaY;return o&t.direction||(t.direction&q?(o=s===0?ne:s<0?re:ie,n=s!=this.pX,r=Math.abs(e.deltaX)):(o=c===0?ne:c<0?ae:oe,n=c!=this.pY,r=Math.abs(e.deltaY))),e.direction=o,n&&r>t.threshold&&o&t.direction},attrTest:function(e){return $.prototype.attrTest.call(this,e)&&(this.state&Q||!(this.state&Q)&&this.directionTest(e))},emit:function(e){this.pX=e.deltaX,this.pY=e.deltaY;var t=ft(e.direction);t&&(e.additionalEvent=this.options.event+t),this._super.emit.call(this,e)}});function ht(){$.apply(this,arguments)}y(ht,$,{defaults:{event:`pinch`,threshold:0,pointers:2},getTouchAction:function(){return[Xe]},attrTest:function(e){return this._super.attrTest.call(this,e)&&(Math.abs(e.scale-1)>this.options.threshold||this.state&Q)},emit:function(e){if(e.scale!==1){var t=e.scale<1?`in`:`out`;e.additionalEvent=this.options.event+t}this._super.emit.call(this,e)}});function gt(){ut.apply(this,arguments),this._timer=null,this._input=null}y(gt,ut,{defaults:{event:`press`,pointers:1,time:251,threshold:9},getTouchAction:function(){return[Je]},process:function(e){var t=this.options,n=e.pointers.length===t.pointers,r=e.distance<t.threshold,o=e.deltaTime>t.time;if(this._input=e,!r||!n||e.eventType&(G|K)&&!o)this.reset();else if(e.eventType&U)this.reset(),this._timer=f(function(){this.state=st,this.tryEmit()},t.time,this);else if(e.eventType&G)return st;return lt},reset:function(){clearTimeout(this._timer)},emit:function(e){this.state===st&&(e&&e.eventType&G?this.manager.emit(this.options.event+`up`,e):(this._input.timeStamp=d(),this.manager.emit(this.options.event,this._input)))}});function _t(){$.apply(this,arguments)}y(_t,$,{defaults:{event:`rotate`,threshold:0,pointers:2},getTouchAction:function(){return[Xe]},attrTest:function(e){return this._super.attrTest.call(this,e)&&(Math.abs(e.rotation)>this.options.threshold||this.state&Q)}});function vt(){$.apply(this,arguments)}y(vt,$,{defaults:{event:`swipe`,threshold:10,velocity:.3,direction:q|se,pointers:1},getTouchAction:function(){return mt.prototype.getTouchAction.call(this)},attrTest:function(e){var t=this.options.direction,n;return t&(q|se)?n=e.overallVelocity:t&q?n=e.overallVelocityX:t&se&&(n=e.overallVelocityY),this._super.attrTest.call(this,e)&&t&e.offsetDirection&&e.distance>this.options.threshold&&e.maxPointers==this.options.pointers&&u(n)>this.options.velocity&&e.eventType&G},emit:function(e){var t=ft(e.offsetDirection);t&&this.manager.emit(this.options.event+t,e),this.manager.emit(this.options.event,e)}});function yt(){ut.apply(this,arguments),this.pTime=!1,this.pCenter=!1,this._timer=null,this._input=null,this.count=0}y(yt,ut,{defaults:{event:`tap`,pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[Ye]},process:function(e){var t=this.options,n=e.pointers.length===t.pointers,r=e.distance<t.threshold,o=e.deltaTime<t.time;if(this.reset(),e.eventType&U&&this.count===0)return this.failTimeout();if(r&&o&&n){if(e.eventType!=G)return this.failTimeout();var s=this.pTime?e.timeStamp-this.pTime<t.interval:!0,c=!this.pCenter||X(this.pCenter,e.center)<t.posThreshold;if(this.pTime=e.timeStamp,this.pCenter=e.center,!c||!s?this.count=1:this.count+=1,this._input=e,this.count%t.taps===0)return this.hasRequireFailures()?(this._timer=f(function(){this.state=st,this.tryEmit()},t.interval,this),Q):st}return lt},failTimeout:function(){return this._timer=f(function(){this.state=lt},this.options.interval,this),lt},reset:function(){clearTimeout(this._timer)},emit:function(){this.state==st&&(this._input.tapCount=this.count,this.manager.emit(this.options.event,this._input))}});function bt(e,t){return t=t||{},t.recognizers=C(t.recognizers,bt.defaults.preset),new Ct(e,t)}bt.VERSION=`2.0.7`,bt.defaults={domEvents:!1,touchAction:qe,enable:!0,inputTarget:null,inputClass:null,preset:[[_t,{enable:!1}],[ht,{enable:!1},[`rotate`]],[vt,{direction:q}],[mt,{direction:q},[`swipe`]],[yt],[yt,{event:`doubletap`,taps:2},[`tap`]],[gt]],cssProps:{userSelect:`none`,touchSelect:`none`,touchCallout:`none`,contentZooming:`none`,userDrag:`none`,tapHighlightColor:`rgba(0,0,0,0)`}};var xt=1,St=2;function Ct(e,t){this.options=g({},bt.defaults,t||{}),this.options.inputTarget=this.options.inputTarget||e,this.handlers={},this.session={},this.recognizers=[],this.oldCssProps={},this.element=e,this.input=de(this),this.touchAction=new tt(this,this.options.touchAction),wt(this,!0),m(this.options.recognizers,function(e){var t=this.add(new e[0](e[1]));e[2]&&t.recognizeWith(e[2]),e[3]&&t.requireFailure(e[3])},this)}Ct.prototype={set:function(e){return g(this.options,e),e.touchAction&&this.touchAction.update(),e.inputTarget&&(this.input.destroy(),this.input.target=e.inputTarget,this.input.init()),this},stop:function(e){this.session.stopped=e?St:xt},recognize:function(e){var t=this.session;if(!t.stopped){this.touchAction.preventDefaults(e);var n,r=this.recognizers,o=t.curRecognizer;(!o||o&&o.state&st)&&(o=t.curRecognizer=null);for(var s=0;s<r.length;)n=r[s],t.stopped!==St&&(!o||n==o||n.canRecognizeWith(o))?n.recognize(e):n.reset(),!o&&n.state&(Q|at|ot)&&(o=t.curRecognizer=n),s++}},get:function(e){if(e instanceof ut)return e;for(var t=this.recognizers,n=0;n<t.length;n++)if(t[n].options.event==e)return t[n];return null},add:function(e){if(p(e,`add`,this))return this;var t=this.get(e.options.event);return t&&this.remove(t),this.recognizers.push(e),e.manager=this,this.touchAction.update(),e},remove:function(e){if(p(e,`remove`,this))return this;if(e=this.get(e),e){var t=this.recognizers,n=k(t,e);n!==-1&&(t.splice(n,1),this.touchAction.update())}return this},on:function(e,t){if(e!==r&&t!==r){var n=this.handlers;return m(O(e),function(e){n[e]=n[e]||[],n[e].push(t)}),this}},off:function(e,t){if(e!==r){var n=this.handlers;return m(O(e),function(e){t?n[e]&&n[e].splice(k(n[e],t),1):delete n[e]}),this}},emit:function(e,t){this.options.domEvents&&Tt(e,t);var n=this.handlers[e]&&this.handlers[e].slice();if(!(!n||!n.length)){t.type=e,t.preventDefault=function(){t.srcEvent.preventDefault()};for(var r=0;r<n.length;)n[r](t),r++}},destroy:function(){this.element&&wt(this,!1),this.handlers={},this.session={},this.input.destroy(),this.element=null}};function wt(e,t){var n=e.element;if(n.style){var r;m(e.options.cssProps,function(o,s){r=M(n.style,s),t?(e.oldCssProps[r]=n.style[r],n.style[r]=o):n.style[r]=e.oldCssProps[r]||``}),t||(e.oldCssProps={})}}function Tt(e,n){var r=t.createEvent(`Event`);r.initEvent(e,!0,!0),r.gesture=n,n.target.dispatchEvent(r)}return g(bt,{INPUT_START:U,INPUT_MOVE:W,INPUT_END:G,INPUT_CANCEL:K,STATE_POSSIBLE:it,STATE_BEGAN:Q,STATE_CHANGED:at,STATE_ENDED:ot,STATE_RECOGNIZED:st,STATE_CANCELLED:ct,STATE_FAILED:lt,DIRECTION_NONE:ne,DIRECTION_LEFT:re,DIRECTION_RIGHT:ie,DIRECTION_UP:ae,DIRECTION_DOWN:oe,DIRECTION_HORIZONTAL:q,DIRECTION_VERTICAL:se,DIRECTION_ALL:ce,Manager:Ct,Input:J,TouchAction:tt,TouchInput:Le,MouseInput:Te,PointerEventInput:Ae,TouchMouseInput:Ve,SingleTouchInput:Ne,Recognizer:ut,AttrRecognizer:$,Tap:yt,Pan:mt,Swipe:vt,Pinch:ht,Rotate:_t,Press:gt,on:w,off:T,each:m,merge:v,extend:_,assign:g,inherit:y,bindFn:b,prefixed:M}),bt})(typeof window<`u`?window:{},typeof document<`u`?document:{},`Hammer`),BaseController=class e extends Subscribe{static parseArgs(t){return t instanceof e?t:Object.assign({},t)}static initAnimationEndState(e){var t,n,r,o,s,c,l,u;let d=this.parseArgs(e),{state:f,currentState:p}=d.initial,m=typeof f.panoIndex==`number`?{workCode:(r=(t=f.workCode)==null?(n=d.works[0])==null?void 0:n.workCode:t)==null?``:r,panoIndex:f.panoIndex}:{workCode:p.workCode,panoIndex:p.panoIndex};return Object.assign(Object.assign({},m),{mode:``,longitude:(o=f.longitude)==null?p.longitude:o,latitude:(s=f.latitude)==null?p.latitude:s,fov:(c=f.fov)==null?p.fov:c,offset:(l=f.offset)==null?p.offset:l,distance:(u=f.distance)==null?p.distance:u})}constructor(t){var n,r,o;super();let s=e.parseArgs(t);this.mode=``,this.pending=new Set,this.userAction=s.initial.userAction,this.destroyed=!1,this.fiveId=s.fiveId,this.scene=s.scene,this.modelScene=s.modelScene,this.xrCustomObjectsScene=s.xrCustomObjectsScene,this.helper=s.helper,this.camera=s.camera,this.renderer=s.renderer,this.viewport=s.viewport,this.element=s.element,this.enableWheel=s.enableWheel,this.works=s.works,this.imageOptions=s.imageOptions,this.videoTexture=s.videoTexture,this.extraElements=s.extraElements,this.initial=s.initial,this.currentPano=typeof this.initial.state.panoIndex==`number`?{workCode:(o=(n=this.initial.state.workCode)==null?(r=s.works[0])==null?void 0:r.workCode:n)==null?``:o,panoIndex:this.initial.state.panoIndex}:{workCode:this.initial.currentState.workCode,panoIndex:this.initial.currentState.panoIndex},this.needsRender=!0,this.cameraMotion=new Motion({longitude:{value:this.camera.pose.longitude,circle:[0,Math.PI*2]},latitude:this.camera.pose.latitude,fov:this.camera.pose.fov}),this.inMomentumMovement=null,this.eventUnbinds=[s.element].concat(s.extraElements||[]).map(e=>this.bindEvents(e)),this.initAnimationIsReady=!1,this.pending.add(`init-animation`),this.initAnimationReady=new Promise(e=>{AnimationFrameLoop.shared.add(()=>{this.initAnimation().then(()=>{this.initAnimationIsReady=!0,this.pending.delete(`init-animation`),e()})},!0,0)})}updateConfiguration(e){return!0}destroy(){var e;this.stopMomentumMovement(),this.destroyed=!0,this.off(),this.cameraMotion.dispose();for(let e of this.eventUnbinds)e();this.panState=void 0,(e=this.pressState)==null||e.stop(),this.pressState=void 0}isReady(){return this.inMomentumMovement===null&&this.pending.size===0&&this.cameraMotion.ended===!0}bindExtraElement(e){for(let t of this.eventUnbinds)if(t.element===e)return;this.eventUnbinds.push(this.bindEvents(e))}unbindExtraElement(e){let t=[];for(let n of this.eventUnbinds)n.element===e?n():t.push(n);this.eventUnbinds=t}updateModel(e){this.needsRender=!0}updateWork(e,t,n,r){return this.works=e,this.userAction=r,!1}updateTime(e,t,...n){if(this.destroyed)return;let r={};this.cameraMotion.ended&&(this.cameraMotion.update(e),r.longitude=this.cameraMotion.value.longitude,r.latitude=this.cameraMotion.value.latitude,r.fov=this.cameraMotion.value.fov),isEmptyObject(r)&&this.setCamera(r)}render(){return!1}updateCamera(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r={};return e.longitude!==void 0&&(r.longitude=e.longitude),e.latitude!==void 0&&(r.latitude=e.latitude),e.fov!==void 0&&(r.fov=e.fov),this.cameraMotion.set(r,t).catch(noop)})}updateCameraWithKeyframes(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r=[];for(let t of e)r.push({key:t.key,progress:t.progress,value:{longitude:t.value.longitude,latitude:t.value.latitude,fov:t.value.fov}});return this.cameraMotion.setKeyframes(r,t)})}getTargetState(){let e=this.cameraMotion.getKeyFrameSegment(now())[1];return Object.assign(Object.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})}initAnimation(){let{state:t,currentState:n,duration:r,userAction:o}=this.initial,s=e.initAnimationEndState(this);return this.userAction=o,this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:s,userAction:this.userAction})),this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:s,userAction:this.userAction})),Promise.resolve()}setCamera(e={}){var t,n,r,o,s;let c=(t=e.longitude)==null?this.camera.pose.longitude:t,l=(n=e.latitude)==null?this.camera.pose.latitude:n,u=(r=e.fov)==null?this.camera.pose.fov:r,d=(o=e.distance)==null?this.camera.pose.distance:o,f=(s=e.offset)==null?this.camera.pose.offset:s,p=notSimilarValue(c,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(l,this.camera.pose.latitude),m=notSimilarValue(u,this.camera.pose.fov),h=notSimilarValue(d,this.camera.pose.distance),g=notSimilarVector3(f,this.camera.pose.offset);(m||p||g||h)&&(this.camera.setFromPose({longitude:c,latitude:l,fov:u,distance:d,offset:f}),this.emit(`camera.update`,createEvent(`camera.update`,{userAction:this.userAction,state:Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:c,latitude:l,fov:u,offset:f,distance:d})})),this.needsRender=!0)}stopMomentumMovement(){if(this.inMomentumMovement&&this.inMomentumMovement.event&&!this.inMomentumMovement.event.defaultPrevented&&!this.inMomentumMovement.event.isFinal){let e=createEvent(`gesture.momentum`,Object.assign(Object.assign({},this.inMomentumMovement.event),{isFirst:!1,isFinal:!0}));this.emit(`gesture.create`,e),this.emit(`gesture.momentum`,e)}this.inMomentumMovement=null}onPanGesture(e){this.stopMomentumMovement(),this.emit(`gesture.pan`,e)}onTapGesture(e){this.stopMomentumMovement(),this.emit(`gesture.tap`,e)}onDblTapGesture(e){this.stopMomentumMovement(),this.emit(`gesture.dbltap`,e),!e.defaultPrevented&&(e.type=`gesture.tap`,this.onTapGesture(e))}onPressGesture(e){this.stopMomentumMovement(),this.emit(`gesture.press`,e)}onPinchGesture(e){this.stopMomentumMovement(),this.emit(`gesture.pinch`,e)}onMouseWheel(e){this.stopMomentumMovement(),this.emit(`gesture.mousewheel`,e)}onMouseMove(e){this.stopMomentumMovement(),this.emit(`gesture.mousemove`,e)}relativeClientPosition(e){let{top:t,left:n,width:r,height:o}=this.element.getBoundingClientRect();return n+=r*this.viewport.left,t+=o*(1-this.viewport.bottom-this.viewport.height),r*=this.viewport.width,o*=this.viewport.height,new three.Vector2((e.x-n)/r*2-1,-(e.y-t)/o*2+1)}createRaycasterFromCamera(e,t){let n=new three.Raycaster;return n.params.Points={threshold:.1},n.firstHitOnly=!0,n.near=t.near,n.far=t.far,n.setFromCamera(e,this.camera),n}bindEvents(e){let t=e=>{let t=this.relativeClientPosition(e);return!(Math.abs(t.x)>1||Math.abs(t.y)>1)},n=e=>({button:`button`in e?e.button:0,buttons:`buttons`in e?e.buttons:0,shiftKey:`shiftKey`in e?e.shiftKey:!1,ctrlKey:`ctrlKey`in e?e.ctrlKey:!1,altKey:`altKey`in e?e.altKey:!1,metaKey:`metaKey`in e?e.metaKey:!1}),r=new Hammer.Manager(e),o=e=>e.session.firstInput||null,s=new Hammer.Pan({threshold:10,pointers:0}),c=new Hammer.Tap({interval:410}),l=new Hammer.Pinch({threshold:0,pointers:2});r.add([s,c,l]),r.on(`panstart pan`,e=>{let s=n(e.srcEvent),c=o(r);if(c&&!t(c.center))return;let l=createEvent(`gesture.pan`,{target:e.target,pointerType:e.pointerType,srcEvent:e.srcEvent,pointers:e.pointers.map(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})}),isFirst:e.isFirst||e.type==`panstart`,isFinal:e.isFinal,scale:e.scale,center:(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})})(e.center),velocityX:e.velocityX,velocityY:e.velocityY,overallVelocityX:e.overallVelocityX,overallVelocityY:e.overallVelocityY,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.create`,l),this.onPanGesture(l),y()}),r.on(`tap`,e=>{let s=n(e.srcEvent);if(e.pointerType===`mouse`&&s.button!==0)return;let c=o(r);if(c&&!t(c.center))return;let l=createEvent(`gesture.tap`,{target:e.target,pointerType:e.pointerType,srcEvent:e.srcEvent,pointers:e.pointers.map(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})}),isFirst:!0,isFinal:!0,scale:e.scale,center:(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})})(e.center),velocityX:e.velocityX,velocityY:e.velocityY,overallVelocityX:e.overallVelocityX,overallVelocityY:e.overallVelocityY,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.create`,l),this.onTapGesture(l),y()}),r.on(`pinchstart pinch pinchend`,e=>{let s=n(e.srcEvent),c=o(r);if(c&&!t(c.center))return;let l=createEvent(`gesture.pinch`,{target:e.target,pointerType:e.pointerType,srcEvent:e.srcEvent,pointers:e.pointers.map(e=>{var t;let n=this.relativeClientPosition(e),r=new three.Raycaster;return r.params.Points={threshold:.1},r.setFromCamera(n,this.camera),Object.assign(Object.assign({x:e.x,y:e.y,delta:(t=e.delta)==null?0:t},s),{coords:n,raycaster:r})}),isFirst:e.type===`pinchstart`,isFinal:e.type===`pinchend`,scale:e.scale,center:(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})})(e.center),velocityX:e.velocityX,velocityY:e.velocityY,overallVelocityX:e.overallVelocityX,overallVelocityY:e.overallVelocityY,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.create`,l),this.onPinchGesture(l),y()}),r.on(`dbltap`,e=>{let s=n(e.srcEvent);if(e.pointerType===`mouse`&&s.button!==0)return;let c=o(r);if(c&&!t(c.center))return;let l=createEvent(`gesture.dbltap`,{target:e.target,pointerType:e.pointerType,srcEvent:e.srcEvent,pointers:e.pointers.map(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})}),isFirst:!0,isFinal:!0,scale:e.scale,center:(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})})(e.center),velocityX:e.velocityX,velocityY:e.velocityY,overallVelocityX:e.overallVelocityX,overallVelocityY:e.overallVelocityY,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.create`,l),this.onDblTapGesture(l),y()});let u=null,d=null,f=(e,t,r)=>{let o={x:r.clientX,y:r.clientY},s=this.relativeClientPosition(o),c=this.createRaycasterFromCamera(s,this.camera),l=Object.assign(Object.assign(Object.assign(Object.assign({},o),{coords:s,raycaster:c}),n(r)),{delta:0}),u=e===`pinchend`?t:t-r.deltaY/280;return createEvent(`gesture.pinch`,{target:r.target,pointerType:`mouse`,srcEvent:r,pointers:[Object.assign({},l)],isFirst:e===`pinchstart`,isFinal:e===`pinchend`,scale:clamp$1(u,.1,10),center:Object.assign({},l),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))})},p=e=>{var r;if(t({x:e.clientX,y:e.clientY})){if(e.preventDefault(),e.ctrlKey){let t=(r=u==null?void 0:u.prevEvent.scale)==null?1:r,n=f(u?`pinch`:`pinchstart`,t,e);this.emit(`gesture.create`,n),u===null?u={firstEvent:n,prevEvent:n}:u.prevEvent=n,this.emit(`gesture.create`,n),this.onPinchGesture(n),d!==null&&window.clearTimeout(d),d=window.setTimeout(()=>{var t;d=null;let n=f(`pinchend`,(t=u==null?void 0:u.prevEvent.scale)==null?1:t,e);this.emit(`gesture.create`,n),u=null,this.onPinchGesture(n)},200)}else{let t=(Math.abs(e.deltaY)>Math.abs(e.deltaX)?e.deltaY:e.deltaX)/-60,r=this.mouseWheelState!==void 0,o={x:e.clientX,y:e.clientY},s=this.relativeClientPosition(o),c=this.createRaycasterFromCamera(s,this.camera),l=Object.assign(Object.assign(Object.assign(Object.assign({},o),{coords:s,raycaster:c}),n(e)),{delta:t}),u=createEvent(`gesture.mousewheel`,{target:e.target,pointerType:`mouse`,srcEvent:e,pointers:[Object.assign({},l)],isFirst:r,isFinal:!1,scale:0,center:Object.assign({},l),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.create`,u),this.onMouseWheel(u),this.mouseWheelState&&clearTimeout(this.mouseWheelState.timer),this.mouseWheelState={timer:setTimeout(()=>{this.mouseWheelState=void 0;let t=createEvent(`gesture.mousewheel`,{target:e.target,pointerType:`mouse`,srcEvent:e,pointers:[Object.assign(Object.assign({},l),{delta:0})],isFirst:!1,isFinal:!0,scale:0,center:Object.assign(Object.assign({},l),{delta:0}),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.create`,t),this.onMouseWheel(t)},100)}}y()}},m=e=>{if(isMobile)return;if(!t({x:e.clientX,y:e.clientY})){h();return}let r=!1;this.mouseMoveState||(r=!0);let o={x:e.clientX,y:e.clientY},s=this.relativeClientPosition(o),c=this.createRaycasterFromCamera(s,this.camera),l=Object.assign(Object.assign(Object.assign(Object.assign({},o),{coords:s,raycaster:c}),n(e)),{delta:0}),u=createEvent(`gesture.mousemove`,{target:e.target,pointerType:`mouse`,srcEvent:e,pointers:[Object.assign({},l)],isFirst:r,isFinal:!1,scale:0,center:Object.assign({},l),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.create`,u),this.mouseMoveState={timeStamp:now(),event:u},this.onMouseMove(u),this.pressState&&Math.abs(e.clientX-this.pressState.event.center.y)>10&&Math.abs(e.clientY-this.pressState.event.center.y)>10&&y()},h=()=>{if(this.mouseMoveState){let e=createEvent(this.mouseMoveState.event.type,Object.assign(Object.assign({},this.mouseMoveState.event),{isFinal:!0}));this.emit(`gesture.create`,e),this.mouseMoveState=void 0,this.onMouseMove(e)}y()},g=e=>{if(!t(e.center)){y();return}let n=!1;this.pressState||(n=!0,this.pressState={event:e,timeStamp:now(),stop:noop});let r=now()-this.pressState.timeStamp,o=createEvent(this.pressState.event.type,Object.assign(Object.assign({},this.pressState.event),{isFirst:n,isFinal:!1,center:Object.assign(Object.assign({},this.pressState.event.center),{delta:r}),pointers:this.pressState.event.pointers.map(e=>Object.assign(Object.assign({},e),{delta:r}))}));this.emit(`gesture.create`,o),this.onPressGesture(o),this.pressState&&(this.pressState.stop=AnimationFrameLoop.shared.add(t=>{g(e)},!0,1))},_=e=>{if(y(),e.touches.length>1||e.changedTouches.length<=0)return;let t={x:e.changedTouches[0].clientX,y:e.changedTouches[0].clientY},r=this.relativeClientPosition(t),o=this.createRaycasterFromCamera(r,this.camera),s=Object.assign(Object.assign(Object.assign(Object.assign({},t),{coords:r,raycaster:o}),n(e)),{delta:0}),c=createEvent(`gesture.press`,{target:e.target,pointerType:`touch`,srcEvent:e,pointers:[Object.assign({},s)],isFirst:!1,isFinal:!1,scale:0,center:s,velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.create`,c),g(c)},v=e=>{y();let t={x:e.clientX,y:e.clientY},r=this.relativeClientPosition(t),o=this.createRaycasterFromCamera(r,this.camera),s=Object.assign(Object.assign(Object.assign(Object.assign({},t),{coords:r,raycaster:o}),n(e)),{delta:0}),c=createEvent(`gesture.press`,{target:e.target,pointerType:`mouse`,srcEvent:e,pointers:[Object.assign({},s)],isFirst:!1,isFinal:!1,scale:0,center:s,velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.create`,c),g(c)},y=()=>{var e;if(this.pressState){let t=now()-this.pressState.timeStamp,n=createEvent(this.pressState.event.type,Object.assign(Object.assign({},this.pressState.event),{center:Object.assign(Object.assign({},this.pressState.event.center),{delta:t}),isFirst:!1,isFinal:!0,pointers:this.pressState.event.pointers.map(e=>Object.assign(Object.assign({},e),{delta:t}))}));this.emit(`gesture.create`,n),this.onPressGesture(n),(e=this.pressState)==null||e.stop(),this.pressState=void 0}},b=null,S=e=>{var t,r,o;let s=!1,c=!1;switch(e.type){case`gesturestart`:s=!0;break;case`gestureend`:c=!0;break;default:break}let l={x:(t=e.clientX)==null?0:t,y:(r=e.clientY)==null?0:r},u=this.relativeClientPosition(l),d=this.createRaycasterFromCamera(u,this.camera),f=Object.assign(Object.assign(Object.assign(Object.assign({},l),{coords:u,raycaster:d}),n(e)),{delta:0});return createEvent(`gesture.pinch`,{target:e.target,pointerType:`mouse`,srcEvent:e,pointers:[Object.assign({},f)],isFirst:s,isFinal:c,scale:(o=e.scale)==null?1:o,center:Object.assign({},f),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))})},C=e=>{if(e.preventDefault(),isMobile)return;let n=S(e);this.emit(`gesture.create`,n),b={firstEvent:n};let r=b.firstEvent;r&&!t(r.center)||this.onPinchGesture(n)},w=e=>{if(e.preventDefault(),isMobile||!b)return;let n=b.firstEvent;if(n&&!t(n.center))return;let r=S(e);this.emit(`gesture.create`,r),this.onPinchGesture(r)},T=e=>{if(e.preventDefault(),isMobile||!b)return;let n=b.firstEvent;if(b=null,n&&!t(n.center))return;let r=S(e);this.emit(`gesture.create`,r),this.onPinchGesture(r)},E=t=>{if(t&&typeof t.preventDefault==`function`&&t.currentTarget===e&&t.preventDefault(),typeof getSelection==`function`){let e=getSelection();e&&e.focusNode&&(e.removeAllRanges&&e.removeAllRanges(),e.empty&&e.empty())}};return this.enableWheel&&e.addEventListener(`wheel`,p,{passive:!1}),e.addEventListener(`mousemove`,m,!1),e.addEventListener(`mouseout`,h,!1),e.addEventListener(`touchstart`,_,{passive:!0}),e.addEventListener(`touchend`,y,!1),e.addEventListener(`touchcancel`,y,!1),e.addEventListener(`mousedown`,v,!1),e.addEventListener(`mouseup`,y,!1),e.addEventListener(`gesturestart`,C,{passive:!1}),e.addEventListener(`gesturechange`,w,{passive:!1}),e.addEventListener(`gestureend`,T,{passive:!1}),e.addEventListener(`touchstart`,E,{passive:!1}),e.addEventListener(`contextmenu`,E,!1),Object.assign(()=>{r.destroy(),e.removeEventListener(`wheel`,p,!1),e.removeEventListener(`mousemove`,m,!1),e.removeEventListener(`mouseout`,h,!1),e.removeEventListener(`touchstart`,_,!1),e.removeEventListener(`touchend`,y,!1),e.removeEventListener(`touchcancel`,y,!1),e.removeEventListener(`mousedown`,v,!1),e.removeEventListener(`mouseup`,y,!1),e.removeEventListener(`gesturestart`,C,!1),e.removeEventListener(`gesturechange`,w,!1),e.removeEventListener(`gestureend`,T,!1),e.removeEventListener(`touchstart`,E,!1),e.removeEventListener(`contextmenu`,E,!1)},{element:e})}},sharedGeometry$2=new three.CircleBufferGeometry(.1,16),sharedMaterial=new three.ShaderMaterial({vertexShader:`
1499
+ `;return function(){var n=Error(`get-stack-trace`),r=n&&n.stack?n.stack.replace(/^[^\(]+?[\n$]/gm,``).replace(/^\s+at\s+/gm,``).replace(/^Object.<anonymous>\s*\(/gm,`{anonymous}()@`):`Unknown Stack Trace`,s=e.console&&(e.console.warn||e.console.log);return s&&s.call(e.console,o,r),t.apply(this,arguments)}}var g=typeof Object.assign==`function`?Object.assign:function(e){if(e===r||e===null)throw TypeError(`Cannot convert undefined or null to object`);for(var t=Object(e),n=1;n<arguments.length;n++){var o=arguments[n];if(o!==r&&o!==null)for(var s in o)o.hasOwnProperty(s)&&(t[s]=o[s])}return t},_=h(function(e,t,n){for(var o=Object.keys(t),s=0;s<o.length;)(!n||n&&e[o[s]]===r)&&(e[o[s]]=t[o[s]]),s++;return e},`extend`,"Use `assign`."),v=h(function(e,t){return _(e,t,!0)},`merge`,"Use `assign`.");function y(e,t,n){var r=t.prototype,o=e.prototype=Object.create(r);o.constructor=e,o._super=r,n&&g(o,n)}function b(e,t){return function(){return e.apply(t,arguments)}}function S(e,t){return typeof e==c?e.apply(t&&t[0]||r,t):e}function C(e,t){return e===r?t:e}function w(e,t,n){m(O(t),function(t){e.addEventListener(t,n,!1)})}function T(e,t,n){m(O(t),function(t){e.removeEventListener(t,n,!1)})}function E(e,t){for(;e;){if(e==t)return!0;e=e.parentNode}return!1}function D(e,t){return e.indexOf(t)>-1}function O(e){return e.trim().split(/\s+/g)}function k(e,t,n){if(e.indexOf&&!n)return e.indexOf(t);for(var r=0;r<e.length;){if(n&&e[r][n]==t||!n&&e[r]===t)return r;r++}return-1}function A(e){return Array.prototype.slice.call(e,0)}function j(e,t,n){for(var r=[],o=[],s=0;s<e.length;){var c=t?e[s][t]:e[s];k(o,c)<0&&r.push(e[s]),o[s]=c,s++}return n&&(r=t?r.sort(function(e,n){return e[t]>n[t]}):r.sort()),r}function M(e,t){for(var n,s,c=t[0].toUpperCase()+t.slice(1),l=0;l<o.length;){if(n=o[l],s=n?n+c:t,s in e)return s;l++}return r}var N=1;function P(){return N++}function F(t){var n=t.ownerDocument||t;return n.defaultView||n.parentWindow||e}var I=/mobile|tablet|ip(ad|hone|od)|android/i,L=`ontouchstart`in e,R=M(e,`PointerEvent`)!==r,z=L&&I.test(navigator.userAgent),B=`touch`,V=`pen`,H=`mouse`,ee=`kinect`,te=25,U=1,W=2,G=4,K=8,ne=1,re=2,ie=4,ae=8,oe=16,q=re|ie,se=ae|oe,ce=q|se,le=[`x`,`y`],ue=[`clientX`,`clientY`];function J(e,t){var n=this;this.manager=e,this.callback=t,this.element=e.element,this.target=e.options.inputTarget,this.domHandler=function(t){S(e.options.enable,[e])&&n.handler(t)},this.init()}J.prototype={handler:function(){},init:function(){this.evEl&&w(this.element,this.evEl,this.domHandler),this.evTarget&&w(this.target,this.evTarget,this.domHandler),this.evWin&&w(F(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&T(this.element,this.evEl,this.domHandler),this.evTarget&&T(this.target,this.evTarget,this.domHandler),this.evWin&&T(F(this.element),this.evWin,this.domHandler)}};function de(e){var t;return t=e.options.inputClass||(R?Ae:z?Le:L?Ve:Te),new t(e,fe)}function fe(e,t,n){var r=n.pointers.length,o=n.changedPointers.length,s=t&U&&r-o===0,c=t&(G|K)&&r-o===0;n.isFirst=!!s,n.isFinal=!!c,s&&(e.session={}),n.eventType=t,pe(e,n),e.emit(`hammer.input`,n),e.recognize(n),e.session.prevInput=n}function pe(e,t){var n=e.session,r=t.pointers,o=r.length;n.firstInput||(n.firstInput=ge(t)),o>1&&!n.firstMultiple?n.firstMultiple=ge(t):o===1&&(n.firstMultiple=!1);var s=n.firstInput,c=n.firstMultiple,l=c?c.center:s.center,f=t.center=Y(r);t.timeStamp=d(),t.deltaTime=t.timeStamp-s.timeStamp,t.angle=ye(l,f),t.distance=X(l,f),me(n,t),t.offsetDirection=ve(t.deltaX,t.deltaY);var p=_e(t.deltaTime,t.deltaX,t.deltaY);t.overallVelocityX=p.x,t.overallVelocityY=p.y,t.overallVelocity=u(p.x)>u(p.y)?p.x:p.y,t.scale=c?xe(c.pointers,r):1,t.rotation=c?be(c.pointers,r):0,t.maxPointers=n.prevInput?t.pointers.length>n.prevInput.maxPointers?t.pointers.length:n.prevInput.maxPointers:t.pointers.length,he(n,t);var m=e.element;E(t.srcEvent.target,m)&&(m=t.srcEvent.target),t.target=m}function me(e,t){var n=t.center,r=e.offsetDelta||{},o=e.prevDelta||{},s=e.prevInput||{};(t.eventType===U||s.eventType===G)&&(o=e.prevDelta={x:s.deltaX||0,y:s.deltaY||0},r=e.offsetDelta={x:n.x,y:n.y}),t.deltaX=o.x+(n.x-r.x),t.deltaY=o.y+(n.y-r.y)}function he(e,t){var n=e.lastInterval||t,o=t.timeStamp-n.timeStamp,s,c,l,d;if(t.eventType!=K&&(o>te||n.velocity===r)){var f=t.deltaX-n.deltaX,p=t.deltaY-n.deltaY,m=_e(o,f,p);c=m.x,l=m.y,s=u(m.x)>u(m.y)?m.x:m.y,d=ve(f,p),e.lastInterval=t}else s=n.velocity,c=n.velocityX,l=n.velocityY,d=n.direction;t.velocity=s,t.velocityX=c,t.velocityY=l,t.direction=d}function ge(e){for(var t=[],n=0;n<e.pointers.length;)t[n]={clientX:l(e.pointers[n].clientX),clientY:l(e.pointers[n].clientY)},n++;return{timeStamp:d(),pointers:t,center:Y(t),deltaX:e.deltaX,deltaY:e.deltaY}}function Y(e){var t=e.length;if(t===1)return{x:l(e[0].clientX),y:l(e[0].clientY)};for(var n=0,r=0,o=0;o<t;)n+=e[o].clientX,r+=e[o].clientY,o++;return{x:l(n/t),y:l(r/t)}}function _e(e,t,n){return{x:t/e||0,y:n/e||0}}function ve(e,t){return e===t?ne:u(e)>=u(t)?e<0?re:ie:t<0?ae:oe}function X(e,t,n){n||(n=le);var r=t[n[0]]-e[n[0]],o=t[n[1]]-e[n[1]];return Math.sqrt(r*r+o*o)}function ye(e,t,n){n||(n=le);var r=t[n[0]]-e[n[0]],o=t[n[1]]-e[n[1]];return Math.atan2(o,r)*180/Math.PI}function be(e,t){return ye(t[1],t[0],ue)+ye(e[1],e[0],ue)}function xe(e,t){return X(t[0],t[1],ue)/X(e[0],e[1],ue)}var Se={mousedown:U,mousemove:W,mouseup:G},Ce=`mousedown`,we=`mousemove mouseup`;function Te(){this.evEl=Ce,this.evWin=we,this.pressed=!1,J.apply(this,arguments)}y(Te,J,{handler:function(e){var t=Se[e.type];t&U&&(e.button===0||e.button===2)&&(this.pressed=!0),t&W&&e.which!==1&&(t=G),this.pressed&&(t&G&&(this.pressed=!1),this.callback(this.manager,t,{pointers:[e],changedPointers:[e],pointerType:H,srcEvent:e}))}});var Ee={pointerdown:U,pointermove:W,pointerup:G,pointercancel:K,pointerout:K},De={2:B,3:V,4:H,5:ee},Oe=`pointerdown`,ke=`pointermove pointerup pointercancel`;e.MSPointerEvent&&!e.PointerEvent&&(Oe=`MSPointerDown`,ke=`MSPointerMove MSPointerUp MSPointerCancel`);function Ae(){this.evEl=Oe,this.evWin=ke,J.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}y(Ae,J,{handler:function(e){var t=this.store,n=!1,r=!1,o=Ee[e.type.toLowerCase().replace(`ms`,``)],s=De[e.pointerType]||e.pointerType,c=s==B,l=k(t,e.pointerId,`pointerId`);o&U&&(e.button===0||e.button===2||c)?l<0&&(t.push(e),l=t.length-1):o&(G|K)?n=!0:!c&&e.buttons===0&&(n=!0,r=!0,o=Ee.pointerup),!(l<0)&&(r||(t[l]=e),this.callback(this.manager,o,{pointers:t,changedPointers:[e],pointerType:s,srcEvent:t[l]}),n&&t.splice(l,1))}});var je={touchstart:U,touchmove:W,touchend:G,touchcancel:K},Z=`touchstart`,Me=`touchstart touchmove touchend touchcancel`;function Ne(){this.evTarget=Z,this.evWin=Me,this.started=!1,J.apply(this,arguments)}y(Ne,J,{handler:function(e){var t=je[e.type];if(t===U&&(this.started=!0),this.started){var n=Pe.call(this,e,t);t&(G|K)&&n[0].length-n[1].length===0&&(this.started=!1),this.callback(this.manager,t,{pointers:n[0],changedPointers:n[1],pointerType:B,srcEvent:e})}}});function Pe(e,t){var n=A(e.touches),r=A(e.changedTouches);return t&(G|K)&&(n=j(n.concat(r),`identifier`,!0)),[n,r]}var Fe={touchstart:U,touchmove:W,touchend:G,touchcancel:K},Ie=`touchstart touchmove touchend touchcancel`;function Le(){this.evTarget=Ie,this.targetIds={},J.apply(this,arguments)}y(Le,J,{handler:function(e){var t=Fe[e.type],n=Re.call(this,e,t);n&&this.callback(this.manager,t,{pointers:n[0],changedPointers:n[1],pointerType:B,srcEvent:e})}});function Re(e,t){var n=A(e.touches),r=this.targetIds;if(t&(U|W)&&n.length===1)return r[n[0].identifier]=!0,[n,n];var o,s,c=A(e.changedTouches),l=[],u=this.target;if(s=n.filter(function(e){return E(e.target,u)}),t===U)for(o=0;o<s.length;)r[s[o].identifier]=!0,o++;for(o=0;o<c.length;)r[c[o].identifier]&&l.push(c[o]),t&(G|K)&&delete r[c[o].identifier],o++;if(l.length)return[j(s.concat(l),`identifier`,!0),l]}var ze=2500,Be=25;function Ve(){J.apply(this,arguments);var e=b(this.handler,this);this.touch=new Le(this.manager,e),this.mouse=new Te(this.manager,e),this.primaryTouch=null,this.lastTouches=[]}y(Ve,J,{handler:function(e,t,n){var r=n.pointerType==B,o=n.pointerType==H;if(!(o&&n.sourceCapabilities&&n.sourceCapabilities.firesTouchEvents)){if(r)He.call(this,t,n);else if(o&&We.call(this,n))return;this.callback(e,t,n)}},destroy:function(){this.touch.destroy(),this.mouse.destroy()}});function He(e,t){e&U?(this.primaryTouch=t.changedPointers[0].identifier,Ue.call(this,t)):e&(G|K)&&Ue.call(this,t)}function Ue(e){var t=e.changedPointers[0];if(t.identifier===this.primaryTouch){var n={x:t.clientX,y:t.clientY};this.lastTouches.push(n);var r=this.lastTouches;setTimeout(function(){var e=r.indexOf(n);e>-1&&r.splice(e,1)},ze)}}function We(e){for(var t=e.srcEvent.clientX,n=e.srcEvent.clientY,r=0;r<this.lastTouches.length;r++){var o=this.lastTouches[r],s=Math.abs(t-o.x),c=Math.abs(n-o.y);if(s<=Be&&c<=Be)return!0}return!1}var Ge=s?M(s.style,`touchAction`):r,Ke=Ge!==r,qe=`compute`,Je=`auto`,Ye=`manipulation`,Xe=`none`,Ze=`pan-x`,Qe=`pan-y`,$e=rt();function tt(e,t){this.manager=e,this.set(t)}tt.prototype={set:function(e){e==qe&&(e=this.compute()),Ke&&this.manager.element.style&&$e[e]&&(this.manager.element.style[Ge]=e),this.actions=e.toLowerCase().trim()},update:function(){this.set(this.manager.options.touchAction)},compute:function(){var e=[];return m(this.manager.recognizers,function(t){S(t.options.enable,[t])&&(e=e.concat(t.getTouchAction()))}),nt(e.join(` `))},preventDefaults:function(e){var t=e.srcEvent,n=e.offsetDirection;if(this.manager.session.prevented){t.preventDefault();return}var r=this.actions,o=D(r,Xe)&&!$e[Xe],s=D(r,Qe)&&!$e[Qe],c=D(r,Ze)&&!$e[Ze];if(o){var l=e.pointers.length===1,u=e.distance<2,d=e.deltaTime<250;if(l&&u&&d)return}if(!(c&&s)&&(o||s&&n&q||c&&n&se))return this.preventSrc(t)},preventSrc:function(e){this.manager.session.prevented=!0,e.preventDefault()}};function nt(e){if(D(e,Xe))return Xe;var t=D(e,Ze),n=D(e,Qe);return t&&n?Xe:t||n?t?Ze:Qe:D(e,Ye)?Ye:Je}function rt(){if(!Ke)return!1;var t={},n=e.CSS&&e.CSS.supports;return[`auto`,`manipulation`,`pan-y`,`pan-x`,`pan-x pan-y`,`none`].forEach(function(r){t[r]=n?e.CSS.supports(`touch-action`,r):!0}),t}var it=1,Q=2,at=4,ot=8,st=ot,ct=16,lt=32;function ut(e){this.options=g({},this.defaults,e||{}),this.id=P(),this.manager=null,this.options.enable=C(this.options.enable,!0),this.state=it,this.simultaneous={},this.requireFail=[]}ut.prototype={defaults:{},set:function(e){return g(this.options,e),this.manager&&this.manager.touchAction.update(),this},recognizeWith:function(e){if(p(e,`recognizeWith`,this))return this;var t=this.simultaneous;return e=pt(e,this),t[e.id]||(t[e.id]=e,e.recognizeWith(this)),this},dropRecognizeWith:function(e){return p(e,`dropRecognizeWith`,this)?this:(e=pt(e,this),delete this.simultaneous[e.id],this)},requireFailure:function(e){if(p(e,`requireFailure`,this))return this;var t=this.requireFail;return e=pt(e,this),k(t,e)===-1&&(t.push(e),e.requireFailure(this)),this},dropRequireFailure:function(e){if(p(e,`dropRequireFailure`,this))return this;e=pt(e,this);var t=k(this.requireFail,e);return t>-1&&this.requireFail.splice(t,1),this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(e){return!!this.simultaneous[e.id]},emit:function(e){var t=this,n=this.state;function r(n){t.manager.emit(n,e)}n<ot&&r(t.options.event+dt(n)),r(t.options.event),e.additionalEvent&&r(e.additionalEvent),n>=ot&&r(t.options.event+dt(n))},tryEmit:function(e){if(this.canEmit())return this.emit(e);this.state=lt},canEmit:function(){for(var e=0;e<this.requireFail.length;){if(!(this.requireFail[e].state&(lt|it)))return!1;e++}return!0},recognize:function(e){var t=g({},e);if(!S(this.options.enable,[this,t])){this.reset(),this.state=lt;return}this.state&(st|ct|lt)&&(this.state=it),this.state=this.process(t),this.state&(Q|at|ot|ct)&&this.tryEmit(t)},process:function(e){},getTouchAction:function(){},reset:function(){}};function dt(e){return e&ct?`cancel`:e&ot?`end`:e&at?`move`:e&Q?`start`:``}function ft(e){return e==oe?`down`:e==ae?`up`:e==re?`left`:e==ie?`right`:``}function pt(e,t){var n=t.manager;return n?n.get(e):e}function $(){ut.apply(this,arguments)}y($,ut,{defaults:{pointers:1},attrTest:function(e){var t=this.options.pointers;return t===0||e.pointers.length===t},process:function(e){var t=this.state,n=e.eventType,r=t&(Q|at),o=this.attrTest(e);return r&&(n&K||!o)?t|ct:r||o?n&G?t|ot:t&Q?t|at:Q:lt}});function mt(){$.apply(this,arguments),this.pX=null,this.pY=null}y(mt,$,{defaults:{event:`pan`,threshold:10,pointers:1,direction:ce},getTouchAction:function(){var e=this.options.direction,t=[];return e&q&&t.push(Qe),e&se&&t.push(Ze),t},directionTest:function(e){var t=this.options,n=!0,r=e.distance,o=e.direction,s=e.deltaX,c=e.deltaY;return o&t.direction||(t.direction&q?(o=s===0?ne:s<0?re:ie,n=s!=this.pX,r=Math.abs(e.deltaX)):(o=c===0?ne:c<0?ae:oe,n=c!=this.pY,r=Math.abs(e.deltaY))),e.direction=o,n&&r>t.threshold&&o&t.direction},attrTest:function(e){return $.prototype.attrTest.call(this,e)&&(this.state&Q||!(this.state&Q)&&this.directionTest(e))},emit:function(e){this.pX=e.deltaX,this.pY=e.deltaY;var t=ft(e.direction);t&&(e.additionalEvent=this.options.event+t),this._super.emit.call(this,e)}});function ht(){$.apply(this,arguments)}y(ht,$,{defaults:{event:`pinch`,threshold:0,pointers:2},getTouchAction:function(){return[Xe]},attrTest:function(e){return this._super.attrTest.call(this,e)&&(Math.abs(e.scale-1)>this.options.threshold||this.state&Q)},emit:function(e){if(e.scale!==1){var t=e.scale<1?`in`:`out`;e.additionalEvent=this.options.event+t}this._super.emit.call(this,e)}});function gt(){ut.apply(this,arguments),this._timer=null,this._input=null}y(gt,ut,{defaults:{event:`press`,pointers:1,time:251,threshold:9},getTouchAction:function(){return[Je]},process:function(e){var t=this.options,n=e.pointers.length===t.pointers,r=e.distance<t.threshold,o=e.deltaTime>t.time;if(this._input=e,!r||!n||e.eventType&(G|K)&&!o)this.reset();else if(e.eventType&U)this.reset(),this._timer=f(function(){this.state=st,this.tryEmit()},t.time,this);else if(e.eventType&G)return st;return lt},reset:function(){clearTimeout(this._timer)},emit:function(e){this.state===st&&(e&&e.eventType&G?this.manager.emit(this.options.event+`up`,e):(this._input.timeStamp=d(),this.manager.emit(this.options.event,this._input)))}});function _t(){$.apply(this,arguments)}y(_t,$,{defaults:{event:`rotate`,threshold:0,pointers:2},getTouchAction:function(){return[Xe]},attrTest:function(e){return this._super.attrTest.call(this,e)&&(Math.abs(e.rotation)>this.options.threshold||this.state&Q)}});function vt(){$.apply(this,arguments)}y(vt,$,{defaults:{event:`swipe`,threshold:10,velocity:.3,direction:q|se,pointers:1},getTouchAction:function(){return mt.prototype.getTouchAction.call(this)},attrTest:function(e){var t=this.options.direction,n;return t&(q|se)?n=e.overallVelocity:t&q?n=e.overallVelocityX:t&se&&(n=e.overallVelocityY),this._super.attrTest.call(this,e)&&t&e.offsetDirection&&e.distance>this.options.threshold&&e.maxPointers==this.options.pointers&&u(n)>this.options.velocity&&e.eventType&G},emit:function(e){var t=ft(e.offsetDirection);t&&this.manager.emit(this.options.event+t,e),this.manager.emit(this.options.event,e)}});function yt(){ut.apply(this,arguments),this.pTime=!1,this.pCenter=!1,this._timer=null,this._input=null,this.count=0}y(yt,ut,{defaults:{event:`tap`,pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[Ye]},process:function(e){var t=this.options,n=e.pointers.length===t.pointers,r=e.distance<t.threshold,o=e.deltaTime<t.time;if(this.reset(),e.eventType&U&&this.count===0)return this.failTimeout();if(r&&o&&n){if(e.eventType!=G)return this.failTimeout();var s=this.pTime?e.timeStamp-this.pTime<t.interval:!0,c=!this.pCenter||X(this.pCenter,e.center)<t.posThreshold;if(this.pTime=e.timeStamp,this.pCenter=e.center,!c||!s?this.count=1:this.count+=1,this._input=e,this.count%t.taps===0)return this.hasRequireFailures()?(this._timer=f(function(){this.state=st,this.tryEmit()},t.interval,this),Q):st}return lt},failTimeout:function(){return this._timer=f(function(){this.state=lt},this.options.interval,this),lt},reset:function(){clearTimeout(this._timer)},emit:function(){this.state==st&&(this._input.tapCount=this.count,this.manager.emit(this.options.event,this._input))}});function bt(e,t){return t=t||{},t.recognizers=C(t.recognizers,bt.defaults.preset),new Ct(e,t)}bt.VERSION=`2.0.7`,bt.defaults={domEvents:!1,touchAction:qe,enable:!0,inputTarget:null,inputClass:null,preset:[[_t,{enable:!1}],[ht,{enable:!1},[`rotate`]],[vt,{direction:q}],[mt,{direction:q},[`swipe`]],[yt],[yt,{event:`doubletap`,taps:2},[`tap`]],[gt]],cssProps:{userSelect:`none`,touchSelect:`none`,touchCallout:`none`,contentZooming:`none`,userDrag:`none`,tapHighlightColor:`rgba(0,0,0,0)`}};var xt=1,St=2;function Ct(e,t){this.options=g({},bt.defaults,t||{}),this.options.inputTarget=this.options.inputTarget||e,this.handlers={},this.session={},this.recognizers=[],this.oldCssProps={},this.element=e,this.input=de(this),this.touchAction=new tt(this,this.options.touchAction),wt(this,!0),m(this.options.recognizers,function(e){var t=this.add(new e[0](e[1]));e[2]&&t.recognizeWith(e[2]),e[3]&&t.requireFailure(e[3])},this)}Ct.prototype={set:function(e){return g(this.options,e),e.touchAction&&this.touchAction.update(),e.inputTarget&&(this.input.destroy(),this.input.target=e.inputTarget,this.input.init()),this},stop:function(e){this.session.stopped=e?St:xt},recognize:function(e){var t=this.session;if(!t.stopped){this.touchAction.preventDefaults(e);var n,r=this.recognizers,o=t.curRecognizer;(!o||o&&o.state&st)&&(o=t.curRecognizer=null);for(var s=0;s<r.length;)n=r[s],t.stopped!==St&&(!o||n==o||n.canRecognizeWith(o))?n.recognize(e):n.reset(),!o&&n.state&(Q|at|ot)&&(o=t.curRecognizer=n),s++}},get:function(e){if(e instanceof ut)return e;for(var t=this.recognizers,n=0;n<t.length;n++)if(t[n].options.event==e)return t[n];return null},add:function(e){if(p(e,`add`,this))return this;var t=this.get(e.options.event);return t&&this.remove(t),this.recognizers.push(e),e.manager=this,this.touchAction.update(),e},remove:function(e){if(p(e,`remove`,this))return this;if(e=this.get(e),e){var t=this.recognizers,n=k(t,e);n!==-1&&(t.splice(n,1),this.touchAction.update())}return this},on:function(e,t){if(e!==r&&t!==r){var n=this.handlers;return m(O(e),function(e){n[e]=n[e]||[],n[e].push(t)}),this}},off:function(e,t){if(e!==r){var n=this.handlers;return m(O(e),function(e){t?n[e]&&n[e].splice(k(n[e],t),1):delete n[e]}),this}},emit:function(e,t){this.options.domEvents&&Tt(e,t);var n=this.handlers[e]&&this.handlers[e].slice();if(!(!n||!n.length)){t.type=e,t.preventDefault=function(){t.srcEvent.preventDefault()};for(var r=0;r<n.length;)n[r](t),r++}},destroy:function(){this.element&&wt(this,!1),this.handlers={},this.session={},this.input.destroy(),this.element=null}};function wt(e,t){var n=e.element;if(n.style){var r;m(e.options.cssProps,function(o,s){r=M(n.style,s),t?(e.oldCssProps[r]=n.style[r],n.style[r]=o):n.style[r]=e.oldCssProps[r]||``}),t||(e.oldCssProps={})}}function Tt(e,n){var r=t.createEvent(`Event`);r.initEvent(e,!0,!0),r.gesture=n,n.target.dispatchEvent(r)}return g(bt,{INPUT_START:U,INPUT_MOVE:W,INPUT_END:G,INPUT_CANCEL:K,STATE_POSSIBLE:it,STATE_BEGAN:Q,STATE_CHANGED:at,STATE_ENDED:ot,STATE_RECOGNIZED:st,STATE_CANCELLED:ct,STATE_FAILED:lt,DIRECTION_NONE:ne,DIRECTION_LEFT:re,DIRECTION_RIGHT:ie,DIRECTION_UP:ae,DIRECTION_DOWN:oe,DIRECTION_HORIZONTAL:q,DIRECTION_VERTICAL:se,DIRECTION_ALL:ce,Manager:Ct,Input:J,TouchAction:tt,TouchInput:Le,MouseInput:Te,PointerEventInput:Ae,TouchMouseInput:Ve,SingleTouchInput:Ne,Recognizer:ut,AttrRecognizer:$,Tap:yt,Pan:mt,Swipe:vt,Pinch:ht,Rotate:_t,Press:gt,on:w,off:T,each:m,merge:v,extend:_,assign:g,inherit:y,bindFn:b,prefixed:M}),bt})(typeof window<`u`?window:{},typeof document<`u`?document:{},`Hammer`),BaseController=class e extends Subscribe{static parseArgs(t){return t instanceof e?t:Object.assign({},t)}static initAnimationEndState(e){var t,n,r,o,s,c,l,u;let d=this.parseArgs(e),{state:f,currentState:p}=d.initial,m=typeof f.panoIndex==`number`?{workCode:(r=(t=f.workCode)==null?(n=d.works[0])==null?void 0:n.workCode:t)==null?``:r,panoIndex:f.panoIndex}:{workCode:p.workCode,panoIndex:p.panoIndex};return Object.assign(Object.assign({},m),{mode:``,longitude:(o=f.longitude)==null?p.longitude:o,latitude:(s=f.latitude)==null?p.latitude:s,fov:(c=f.fov)==null?p.fov:c,offset:(l=f.offset)==null?p.offset:l,distance:(u=f.distance)==null?p.distance:u})}constructor(t){var n,r,o;super();let s=e.parseArgs(t);this.mode=``,this.pending=new Set,this.userAction=s.initial.userAction,this.destroyed=!1,this.fiveId=s.fiveId,this.scene=s.scene,this.modelScene=s.modelScene,this.xrCustomObjectsScene=s.xrCustomObjectsScene,this.helper=s.helper,this.camera=s.camera,this.renderer=s.renderer,this.viewport=s.viewport,this.element=s.element,this.enableWheel=s.enableWheel,this.works=s.works,this.imageOptions=s.imageOptions,this.videoTexture=s.videoTexture,this.extraElements=s.extraElements,this.initial=s.initial,this.currentPano=typeof this.initial.state.panoIndex==`number`?{workCode:(o=(n=this.initial.state.workCode)==null?(r=s.works[0])==null?void 0:r.workCode:n)==null?``:o,panoIndex:this.initial.state.panoIndex}:{workCode:this.initial.currentState.workCode,panoIndex:this.initial.currentState.panoIndex},this.needsRender=!0,this.cameraMotion=new Motion({longitude:{value:this.camera.pose.longitude,circle:[0,Math.PI*2]},latitude:this.camera.pose.latitude,fov:this.camera.pose.fov}),this.inMomentumMovement=null,this.eventUnbinds=[s.element].concat(s.extraElements||[]).map(e=>this.bindEvents(e)),this.initAnimationIsReady=!1,this.pending.add(`init-animation`),this.initAnimationReady=new Promise(e=>{AnimationFrameLoop.shared.add(()=>{this.initAnimation().then(()=>{this.initAnimationIsReady=!0,this.pending.delete(`init-animation`),e()})},!0,0)})}updateConfiguration(e){return!0}destroy(){var e;this.stopMomentumMovement(),this.destroyed=!0,this.off(),this.cameraMotion.dispose();for(let e of this.eventUnbinds)e();this.panState=void 0,(e=this.pressState)==null||e.stop(),this.pressState=void 0}isReady(){return this.inMomentumMovement===null&&this.pending.size===0&&this.cameraMotion.ended===!0}bindExtraElement(e){for(let t of this.eventUnbinds)if(t.element===e)return;this.eventUnbinds.push(this.bindEvents(e))}unbindExtraElement(e){let t=[];for(let n of this.eventUnbinds)n.element===e?n():t.push(n);this.eventUnbinds=t}updateModel(e){this.needsRender=!0}updateWork(e,t,n,r){return this.works=e,this.userAction=r,!1}updateTime(e,t,...n){if(this.destroyed)return;let r={};this.cameraMotion.ended&&(this.cameraMotion.update(e),r.longitude=this.cameraMotion.value.longitude,r.latitude=this.cameraMotion.value.latitude,r.fov=this.cameraMotion.value.fov),isEmptyObject(r)&&this.setCamera(r)}render(){return!1}updateCamera(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r={};return e.longitude!==void 0&&(r.longitude=e.longitude),e.latitude!==void 0&&(r.latitude=e.latitude),e.fov!==void 0&&(r.fov=e.fov),this.cameraMotion.set(r,t).catch(noop)})}updateCameraWithKeyframes(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r=[];for(let t of e)r.push({key:t.key,progress:t.progress,value:{longitude:t.value.longitude,latitude:t.value.latitude,fov:t.value.fov}});return this.cameraMotion.setKeyframes(r,t)})}getTargetState(){let e=this.cameraMotion.getKeyFrameSegment(now())[1];return Object.assign(Object.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})}initAnimation(){let{state:t,currentState:n,duration:r,userAction:o}=this.initial,s=e.initAnimationEndState(this);return this.userAction=o,this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:s,userAction:this.userAction})),this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:s,userAction:this.userAction})),Promise.resolve()}setCamera(e={}){var t,n,r,o,s;let c=(t=e.longitude)==null?this.camera.pose.longitude:t,l=(n=e.latitude)==null?this.camera.pose.latitude:n,u=(r=e.fov)==null?this.camera.pose.fov:r,d=(o=e.distance)==null?this.camera.pose.distance:o,f=(s=e.offset)==null?this.camera.pose.offset:s,p=notSimilarValue(c,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(l,this.camera.pose.latitude),m=notSimilarValue(u,this.camera.pose.fov),h=notSimilarValue(d,this.camera.pose.distance),g=notSimilarVector3(f,this.camera.pose.offset);(m||p||g||h)&&(this.camera.setFromPose({longitude:c,latitude:l,fov:u,distance:d,offset:f}),this.emit(`camera.update`,createEvent(`camera.update`,{userAction:this.userAction,state:Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:c,latitude:l,fov:u,offset:f,distance:d})})),this.needsRender=!0)}stopMomentumMovement(){if(this.inMomentumMovement&&this.inMomentumMovement.event&&!this.inMomentumMovement.event.defaultPrevented&&!this.inMomentumMovement.event.isFinal){let e=createEvent(`gesture.momentum`,Object.assign(Object.assign({},this.inMomentumMovement.event),{isFirst:!1,isFinal:!0}));this.emit(`gesture.fire`,e),this.emit(`gesture.momentum`,e)}this.inMomentumMovement=null}onPanGesture(e){this.stopMomentumMovement(),this.emit(`gesture.pan`,e)}onTapGesture(e){this.stopMomentumMovement(),this.emit(`gesture.tap`,e)}onDblTapGesture(e){this.stopMomentumMovement(),this.emit(`gesture.dbltap`,e),!e.defaultPrevented&&(e.type=`gesture.tap`,this.onTapGesture(e))}onPressGesture(e){this.stopMomentumMovement(),this.emit(`gesture.press`,e)}onPinchGesture(e){this.stopMomentumMovement(),this.emit(`gesture.pinch`,e)}onMouseWheel(e){this.stopMomentumMovement(),this.emit(`gesture.mousewheel`,e)}onMouseMove(e){this.stopMomentumMovement(),this.emit(`gesture.mousemove`,e)}relativeClientPosition(e){let{top:t,left:n,width:r,height:o}=this.element.getBoundingClientRect();return n+=r*this.viewport.left,t+=o*(1-this.viewport.bottom-this.viewport.height),r*=this.viewport.width,o*=this.viewport.height,new three.Vector2((e.x-n)/r*2-1,-(e.y-t)/o*2+1)}createRaycasterFromCamera(e,t){let n=new three.Raycaster;return n.params.Points={threshold:.1},n.firstHitOnly=!0,n.near=t.near,n.far=t.far,n.setFromCamera(e,this.camera),n}bindEvents(e){let t=e=>{let t=this.relativeClientPosition(e);return!(Math.abs(t.x)>1||Math.abs(t.y)>1)},n=e=>({button:`button`in e?e.button:0,buttons:`buttons`in e?e.buttons:0,shiftKey:`shiftKey`in e?e.shiftKey:!1,ctrlKey:`ctrlKey`in e?e.ctrlKey:!1,altKey:`altKey`in e?e.altKey:!1,metaKey:`metaKey`in e?e.metaKey:!1}),r=new Hammer.Manager(e),o=e=>e.session.firstInput||null,s=new Hammer.Pan({threshold:10,pointers:0}),c=new Hammer.Tap({interval:410}),l=new Hammer.Pinch({threshold:0,pointers:2});r.add([s,c,l]),r.on(`panstart pan`,e=>{let s=n(e.srcEvent),c=o(r);if(c&&!t(c.center))return;let l=createEvent(`gesture.pan`,{target:e.target,pointerType:e.pointerType,srcEvent:e.srcEvent,pointers:e.pointers.map(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})}),isFirst:e.isFirst||e.type==`panstart`,isFinal:e.isFinal,scale:e.scale,center:(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})})(e.center),velocityX:e.velocityX,velocityY:e.velocityY,overallVelocityX:e.overallVelocityX,overallVelocityY:e.overallVelocityY,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.fire`,l),this.onPanGesture(l),y()}),r.on(`tap`,e=>{let s=n(e.srcEvent);if(e.pointerType===`mouse`&&s.button!==0)return;let c=o(r);if(c&&!t(c.center))return;let l=createEvent(`gesture.tap`,{target:e.target,pointerType:e.pointerType,srcEvent:e.srcEvent,pointers:e.pointers.map(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})}),isFirst:!0,isFinal:!0,scale:e.scale,center:(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})})(e.center),velocityX:e.velocityX,velocityY:e.velocityY,overallVelocityX:e.overallVelocityX,overallVelocityY:e.overallVelocityY,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.fire`,l),this.onTapGesture(l),y()}),r.on(`pinchstart pinch pinchend`,e=>{let s=n(e.srcEvent),c=o(r);if(c&&!t(c.center))return;let l=createEvent(`gesture.pinch`,{target:e.target,pointerType:e.pointerType,srcEvent:e.srcEvent,pointers:e.pointers.map(e=>{var t;let n=this.relativeClientPosition(e),r=new three.Raycaster;return r.params.Points={threshold:.1},r.setFromCamera(n,this.camera),Object.assign(Object.assign({x:e.x,y:e.y,delta:(t=e.delta)==null?0:t},s),{coords:n,raycaster:r})}),isFirst:e.type===`pinchstart`,isFinal:e.type===`pinchend`,scale:e.scale,center:(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})})(e.center),velocityX:e.velocityX,velocityY:e.velocityY,overallVelocityX:e.overallVelocityX,overallVelocityY:e.overallVelocityY,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.fire`,l),this.onPinchGesture(l),y()}),r.on(`dbltap`,e=>{let s=n(e.srcEvent);if(e.pointerType===`mouse`&&s.button!==0)return;let c=o(r);if(c&&!t(c.center))return;let l=createEvent(`gesture.dbltap`,{target:e.target,pointerType:e.pointerType,srcEvent:e.srcEvent,pointers:e.pointers.map(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})}),isFirst:!0,isFinal:!0,scale:e.scale,center:(e=>{let t=this.relativeClientPosition(e),n=this.createRaycasterFromCamera(t,this.camera);return Object.assign(Object.assign({x:e.x,y:e.y,delta:0},s),{coords:t,raycaster:n})})(e.center),velocityX:e.velocityX,velocityY:e.velocityY,overallVelocityX:e.overallVelocityX,overallVelocityY:e.overallVelocityY,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.fire`,l),this.onDblTapGesture(l),y()});let u=null,d=null,f=(e,t,r)=>{let o={x:r.clientX,y:r.clientY},s=this.relativeClientPosition(o),c=this.createRaycasterFromCamera(s,this.camera),l=Object.assign(Object.assign(Object.assign(Object.assign({},o),{coords:s,raycaster:c}),n(r)),{delta:0}),u=e===`pinchend`?t:t-r.deltaY/280;return createEvent(`gesture.pinch`,{target:r.target,pointerType:`mouse`,srcEvent:r,pointers:[Object.assign({},l)],isFirst:e===`pinchstart`,isFinal:e===`pinchend`,scale:clamp$1(u,.1,10),center:Object.assign({},l),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))})},p=e=>{var r;if(t({x:e.clientX,y:e.clientY})){if(e.preventDefault(),e.ctrlKey){let t=(r=u==null?void 0:u.prevEvent.scale)==null?1:r,n=f(u?`pinch`:`pinchstart`,t,e);this.emit(`gesture.fire`,n),u===null?u={firstEvent:n,prevEvent:n}:u.prevEvent=n,this.emit(`gesture.fire`,n),this.onPinchGesture(n),d!==null&&window.clearTimeout(d),d=window.setTimeout(()=>{var t;d=null;let n=f(`pinchend`,(t=u==null?void 0:u.prevEvent.scale)==null?1:t,e);this.emit(`gesture.fire`,n),u=null,this.onPinchGesture(n)},200)}else{let t=(Math.abs(e.deltaY)>Math.abs(e.deltaX)?e.deltaY:e.deltaX)/-60,r=this.mouseWheelState!==void 0,o={x:e.clientX,y:e.clientY},s=this.relativeClientPosition(o),c=this.createRaycasterFromCamera(s,this.camera),l=Object.assign(Object.assign(Object.assign(Object.assign({},o),{coords:s,raycaster:c}),n(e)),{delta:t}),u=createEvent(`gesture.mousewheel`,{target:e.target,pointerType:`mouse`,srcEvent:e,pointers:[Object.assign({},l)],isFirst:r,isFinal:!1,scale:0,center:Object.assign({},l),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.fire`,u),this.onMouseWheel(u),this.mouseWheelState&&clearTimeout(this.mouseWheelState.timer),this.mouseWheelState={timer:setTimeout(()=>{this.mouseWheelState=void 0;let t=createEvent(`gesture.mousewheel`,{target:e.target,pointerType:`mouse`,srcEvent:e,pointers:[Object.assign(Object.assign({},l),{delta:0})],isFirst:!1,isFinal:!0,scale:0,center:Object.assign(Object.assign({},l),{delta:0}),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.fire`,t),this.onMouseWheel(t)},100)}}y()}},m=e=>{if(isMobile)return;if(!t({x:e.clientX,y:e.clientY})){h();return}let r=!1;this.mouseMoveState||(r=!0);let o={x:e.clientX,y:e.clientY},s=this.relativeClientPosition(o),c=this.createRaycasterFromCamera(s,this.camera),l=Object.assign(Object.assign(Object.assign(Object.assign({},o),{coords:s,raycaster:c}),n(e)),{delta:0}),u=createEvent(`gesture.mousemove`,{target:e.target,pointerType:`mouse`,srcEvent:e,pointers:[Object.assign({},l)],isFirst:r,isFinal:!1,scale:0,center:Object.assign({},l),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.fire`,u),this.mouseMoveState={timeStamp:now(),event:u},this.onMouseMove(u),this.pressState&&Math.abs(e.clientX-this.pressState.event.center.y)>10&&Math.abs(e.clientY-this.pressState.event.center.y)>10&&y()},h=()=>{if(this.mouseMoveState){let e=createEvent(this.mouseMoveState.event.type,Object.assign(Object.assign({},this.mouseMoveState.event),{isFinal:!0}));this.emit(`gesture.fire`,e),this.mouseMoveState=void 0,this.onMouseMove(e)}y()},g=e=>{if(!t(e.center)){y();return}let n=!1;this.pressState||(n=!0,this.pressState={event:e,timeStamp:now(),stop:noop});let r=now()-this.pressState.timeStamp,o=createEvent(this.pressState.event.type,Object.assign(Object.assign({},this.pressState.event),{isFirst:n,isFinal:!1,center:Object.assign(Object.assign({},this.pressState.event.center),{delta:r}),pointers:this.pressState.event.pointers.map(e=>Object.assign(Object.assign({},e),{delta:r}))}));this.emit(`gesture.fire`,o),this.onPressGesture(o),this.pressState&&(this.pressState.stop=AnimationFrameLoop.shared.add(t=>{g(e)},!0,1))},_=e=>{if(y(),e.touches.length>1||e.changedTouches.length<=0)return;let t={x:e.changedTouches[0].clientX,y:e.changedTouches[0].clientY},r=this.relativeClientPosition(t),o=this.createRaycasterFromCamera(r,this.camera),s=Object.assign(Object.assign(Object.assign(Object.assign({},t),{coords:r,raycaster:o}),n(e)),{delta:0}),c=createEvent(`gesture.press`,{target:e.target,pointerType:`touch`,srcEvent:e,pointers:[Object.assign({},s)],isFirst:!1,isFinal:!1,scale:0,center:s,velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.fire`,c),g(c)},v=e=>{y();let t={x:e.clientX,y:e.clientY},r=this.relativeClientPosition(t),o=this.createRaycasterFromCamera(r,this.camera),s=Object.assign(Object.assign(Object.assign(Object.assign({},t),{coords:r,raycaster:o}),n(e)),{delta:0}),c=createEvent(`gesture.press`,{target:e.target,pointerType:`mouse`,srcEvent:e,pointers:[Object.assign({},s)],isFirst:!1,isFinal:!1,scale:0,center:s,velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))});this.emit(`gesture.fire`,c),g(c)},y=()=>{var e;if(this.pressState){let t=now()-this.pressState.timeStamp,n=createEvent(this.pressState.event.type,Object.assign(Object.assign({},this.pressState.event),{center:Object.assign(Object.assign({},this.pressState.event.center),{delta:t}),isFirst:!1,isFinal:!0,pointers:this.pressState.event.pointers.map(e=>Object.assign(Object.assign({},e),{delta:t}))}));this.emit(`gesture.fire`,n),this.onPressGesture(n),(e=this.pressState)==null||e.stop(),this.pressState=void 0}},b=null,S=e=>{var t,r,o;let s=!1,c=!1;switch(e.type){case`gesturestart`:s=!0;break;case`gestureend`:c=!0;break;default:break}let l={x:(t=e.clientX)==null?0:t,y:(r=e.clientY)==null?0:r},u=this.relativeClientPosition(l),d=this.createRaycasterFromCamera(u,this.camera),f=Object.assign(Object.assign(Object.assign(Object.assign({},l),{coords:u,raycaster:d}),n(e)),{delta:0});return createEvent(`gesture.pinch`,{target:e.target,pointerType:`mouse`,srcEvent:e,pointers:[Object.assign({},f)],isFirst:s,isFinal:c,scale:(o=e.scale)==null?1:o,center:Object.assign({},f),velocityX:0,velocityY:0,overallVelocityX:0,overallVelocityY:0,userAction:!0,state:Object.assign(Object.assign({mode:this.mode},this.currentPano),clonePose(this.camera.pose))})},C=e=>{if(e.preventDefault(),isMobile)return;let n=S(e);this.emit(`gesture.fire`,n),b={firstEvent:n};let r=b.firstEvent;r&&!t(r.center)||this.onPinchGesture(n)},w=e=>{if(e.preventDefault(),isMobile||!b)return;let n=b.firstEvent;if(n&&!t(n.center))return;let r=S(e);this.emit(`gesture.fire`,r),this.onPinchGesture(r)},T=e=>{if(e.preventDefault(),isMobile||!b)return;let n=b.firstEvent;if(b=null,n&&!t(n.center))return;let r=S(e);this.emit(`gesture.fire`,r),this.onPinchGesture(r)},E=t=>{if(t&&typeof t.preventDefault==`function`&&t.currentTarget===e&&t.preventDefault(),typeof getSelection==`function`){let e=getSelection();e&&e.focusNode&&(e.removeAllRanges&&e.removeAllRanges(),e.empty&&e.empty())}};return this.enableWheel&&e.addEventListener(`wheel`,p,{passive:!1}),e.addEventListener(`mousemove`,m,!1),e.addEventListener(`mouseout`,h,!1),e.addEventListener(`touchstart`,_,{passive:!0}),e.addEventListener(`touchend`,y,!1),e.addEventListener(`touchcancel`,y,!1),e.addEventListener(`mousedown`,v,!1),e.addEventListener(`mouseup`,y,!1),e.addEventListener(`gesturestart`,C,{passive:!1}),e.addEventListener(`gesturechange`,w,{passive:!1}),e.addEventListener(`gestureend`,T,{passive:!1}),e.addEventListener(`touchstart`,E,{passive:!1}),e.addEventListener(`contextmenu`,E,!1),Object.assign(()=>{r.destroy(),e.removeEventListener(`wheel`,p,!1),e.removeEventListener(`mousemove`,m,!1),e.removeEventListener(`mouseout`,h,!1),e.removeEventListener(`touchstart`,_,!1),e.removeEventListener(`touchend`,y,!1),e.removeEventListener(`touchcancel`,y,!1),e.removeEventListener(`mousedown`,v,!1),e.removeEventListener(`mouseup`,y,!1),e.removeEventListener(`gesturestart`,C,!1),e.removeEventListener(`gesturechange`,w,!1),e.removeEventListener(`gestureend`,T,!1),e.removeEventListener(`touchstart`,E,!1),e.removeEventListener(`contextmenu`,E,!1)},{element:e})}},sharedGeometry$2=new three.CircleBufferGeometry(.1,16),sharedMaterial=new three.ShaderMaterial({vertexShader:`
1500
1500
  varying vec2 vUv;
1501
1501
  #include <common>
1502
1502
  #include <logdepthbuf_pars_vertex>
@@ -1529,7 +1529,7 @@ void main() {
1529
1529
 
1530
1530
  gl_FragColor = vec4(gl_FragColor.rgb, gl_FragColor.a * outside * inside);
1531
1531
  }
1532
- `,side:three.DoubleSide,blending:three.CustomBlending,blendSrc:three.SrcAlphaFactor,blendDst:three.OneMinusSrcAlphaFactor,blendSrcAlpha:three.OneFactor,blendDstAlpha:three.OneMinusSrcAlphaFactor,depthWrite:!1,transparent:!0}),IntersectMesh=class extends three.Object3D{constructor(){super(),this.ringMesh=new three.Mesh(sharedGeometry$2,sharedMaterial),this.ringMesh.position.z=.01,this.ringMesh.renderOrder=9999999999,this.add(this.ringMesh)}dispose(){this.remove(this.ringMesh)}},scratchObserverBox$2=new three.Box3,scratchVector3$4=new three.Vector3,defaultFloorplanControllerCustomInitArgs={defaultLongitude:Math.PI/4,defaultLatitude:Math.PI/4,defaultFov:80,maxFov:120,minFov:20,maxLatitude:Math.PI/2,minLatitude:-Math.PI/2,intersectMeshCreator:()=>new IntersectMesh},FloorplanController=class e extends BaseController{static distanceFromModel(e,t,n){let r=e.boundingBox,o=r.isEmpty()?10:Math.pow(Math.pow(r.max.x-r.min.x+1,2)+Math.pow(r.max.y-r.min.y+1,2)+Math.pow(r.max.z-r.min.z+1,2),1/2);o=isNaN(o)||!isFinite(o)?1:o;let s=o/2/Math.tan(Math.PI*t/360);return n<1&&(s/=n),isNaN(s)||!isFinite(s)?o:s}static parseArgs(t){var n,r,o,s,c,l,u,d;if(t instanceof e)return t;let f=super.parseArgs(t);return Object.assign(Object.assign({},f),{defaultLongitude:(n=t.defaultLongitude)==null?defaultFloorplanControllerCustomInitArgs.defaultLongitude:n,defaultLatitude:(r=t.defaultLatitude)==null?defaultFloorplanControllerCustomInitArgs.defaultLatitude:r,defaultFov:(o=t.defaultFov)==null?defaultFloorplanControllerCustomInitArgs.defaultFov:o,maxFov:(s=t.maxFov)==null?defaultFloorplanControllerCustomInitArgs.maxFov:s,minFov:(c=t.minFov)==null?defaultFloorplanControllerCustomInitArgs.minFov:c,maxLatitude:(l=t.maxLatitude)==null?defaultFloorplanControllerCustomInitArgs.maxLatitude:l,minLatitude:(u=t.minLatitude)==null?defaultFloorplanControllerCustomInitArgs.minLatitude:u,intersectMeshCreator:(d=t.intersectMeshCreator)==null?defaultFloorplanControllerCustomInitArgs.intersectMeshCreator:d})}static initAnimationEndState(t){var n,r,o,s,c,l,u;let d=this.parseArgs(t),{state:f,currentState:p}=t.initial,m=typeof f.panoIndex==`number`?{workCode:(o=(n=f.workCode)==null?(r=d.works[0])==null?void 0:r.workCode:n)==null?``:o,panoIndex:f.panoIndex}:{workCode:p.workCode,panoIndex:p.panoIndex},h=(s=f.fov)==null?d.defaultFov:s,g=(c=f.longitude)==null?isThirdPersonMode(p.mode)?p.longitude:d.defaultLongitude:c,_=clamp$1(typeof d.minLatitude==`function`?d.minLatitude(h):d.minLatitude,-Math.PI/2,Math.PI/2),v=clamp$1(typeof d.maxLatitude==`function`?d.maxLatitude(h):d.maxLatitude,-Math.PI/2,Math.PI/2),y=clamp$1((l=f.latitude)==null?p.mode===`Floorplan`?p.latitude:d.defaultLatitude:l,_,v),b=f.offset?f.offset.clone():t.modelScene.boundingBox.getCenter(new three.Vector3),S=(u=f.distance)==null?e.distanceFromModel(d.modelScene,d.defaultFov,d.camera.aspect):u;return Object.assign(Object.assign({},m),{mode:`Floorplan`,longitude:g,latitude:y,fov:h,offset:b,distance:S})}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`Floorplan`,this.defaultLongitude=n.defaultLongitude,this.defaultLatitude=n.defaultLatitude,this.defaultFov=n.defaultFov,this.maxFov=n.maxFov,this.minFov=n.minFov,this.maxLatitude=n.maxLatitude,this.minLatitude=n.minLatitude,this.locationMotion=new Motion({x:this.camera.pose.offset.x,y:this.camera.pose.offset.y,z:this.camera.pose.offset.z,distance:this.camera.pose.distance}),this.modelAlphaMotion=new Motion({modelAlpha:this.modelScene.parameter.resolveValue().modelAlpha}),this.perspToOrthoMotion=new Motion({perspToOrtho:this.camera.perspToOrtho.x}),this.pendingTextureId=null,this.textureLoader=new TextureLoader,this.intersectMeshCreator=n.intersectMeshCreator,this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=`intersect`,this.intersectMesh.visible=!1,this.helper.add(this.intersectMesh)}updateConfiguration(e){if(super.updateConfiguration(e)===!1)return!1;if(e.defaultLongitude!==void 0&&this.defaultLongitude!==e.defaultLongitude&&(this.defaultLongitude=e.defaultLongitude),e.defaultLatitude!==void 0&&this.defaultLatitude!==e.defaultLatitude&&(this.defaultLatitude=e.defaultLatitude),e.defaultFov!==void 0&&this.defaultFov!==e.defaultFov&&(this.defaultFov=e.defaultFov),e.maxFov!==void 0&&this.maxFov!==e.maxFov&&(this.maxFov=e.maxFov),e.minFov!==void 0&&this.minFov!==e.minFov&&(this.minFov=e.minFov),e.maxLatitude!==void 0&&this.maxLatitude!==e.maxLatitude&&(this.maxLatitude=e.maxLatitude),e.minLatitude!==void 0&&this.minLatitude!==e.minLatitude&&(this.minLatitude=e.minLatitude),e.intersectMeshCreator!==void 0&&this.intersectMeshCreator!==e.intersectMeshCreator){this.intersectMeshCreator=e.intersectMeshCreator;let t=this.intersectMesh;this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=t.name,this.intersectMesh.visible=t.visible;let n=this.intersectMesh.parent;n&&n.add(this.intersectMesh),t.dispose()}return!0}destroy(){super.destroy(),this.pendingTextureId=null,this.locationMotion.dispose(),this.panState=void 0,this.intersectMesh.dispose(),this.helper.remove(this.intersectMesh)}isReady(){return this.locationMotion.ended===!1?!1:super.isReady()}updateWork(e,t,n,r){var o;return this.works=e,this.updateCamera(t,(o=n.duration)==null?0:o,r),!0}updateModel(t){super.updateModel(t);let n=t.boundingBox.getCenter(new three.Vector3),r=e.distanceFromModel(t,this.defaultFov,this.camera.aspect);this.updateCamera({offset:n,distance:r},0,!0)}updateCamera(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r={},o={};return e.distance!==void 0&&(r.distance=e.distance),e.offset!==void 0&&(r.x=e.offset.x,r.y=e.offset.y,r.z=e.offset.z),e.longitude!==void 0&&(o.longitude=e.longitude),e.latitude!==void 0&&(o.latitude=e.latitude),e.fov!==void 0&&(o.fov=e.fov),this.locationMotion.set(r,t).catch(noop),this.cameraMotion.set(o,t).catch(noop)})}updateCameraWithKeyframes(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r=[],o=[];for(let t of e)r.push({key:t.key,progress:t.progress,value:{distance:t.value.distance,x:t.value.offset.x,y:t.value.offset.x,z:t.value.offset.x}}),o.push({key:t.key,progress:t.progress,value:{longitude:t.value.longitude,latitude:t.value.latitude,fov:t.value.fov}});return this.locationMotion.setKeyframes(r,t).catch(noop),this.cameraMotion.setKeyframes(e,t)})}updateTime(e,t,...n){if(this.destroyed)return;let r={},o={};if(this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),r.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.modelScene.parameter.modelAlpha===0&&this.modelScene.parameter.progress!==1){let{pano0:e,pano1:t}=this.modelScene.parameter;e&&e.map!==(t==null?void 0:t.map)&&e.map.dispose(),r.progress=1,r.pano0=r.pano1=t}if(this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended||(this.locationMotion.update(e),o.distance=this.locationMotion.value.distance,o.offset=new three.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(r)||this.modelScene.parameter.set(r),isEmptyObject(o)||this.setCamera(o),this.intersectMesh&&this.intersectMesh.parent){let e=clamp$1(this.camera.position.distanceTo(this.intersectMesh.position)*(2*Math.tan(.5*this.camera.fov/180*Math.PI))/5,.5);this.intersectMesh.scale.setScalar(e)}else this.intersectMesh.scale.setScalar(1)}getTargetState(){let e=this.cameraMotion.getKeyFrameSegment(now())[1],t=this.locationMotion.getKeyFrameSegment(now())[1];return Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:new three.Vector3(t.value.x,t.value.y,t.value.z),distance:t.value.distance})}initAnimation(){return this.destroyed?Promise.resolve():new Promise(t=>{let{state:n,currentState:r,duration:o,userAction:s}=this.initial;this.userAction=s;let c=e.initAnimationEndState(this),l=pick(c,[`longitude`,`latitude`,`fov`]),u={x:c.offset.x,y:c.offset.y,z:c.offset.z,distance:c.distance};this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:c,userAction:this.userAction})),this.modelAlphaMotion.set({modelAlpha:1},o/3).catch(noop),this.perspToOrthoMotion.set({perspToOrtho:0},o).catch(noop),this.cameraMotion.set(l,o).catch(noop),this.locationMotion.set(u,o).then(()=>{this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:c,userAction:this.userAction}))},e=>{let t=Object.assign(Object.assign(Object.assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:t,userAction:this.userAction}))}).then(()=>{t()})})}updateRenderSize(e){this.needsRender=!0}getForwardObserverOrNot(e){let[t]=this.modelScene.intersectRaycaster(e);if(!t)return null;let n=[];for(let t of this.works){let r=this.modelScene.models.find(e=>e.work===t);if(!(!r||r.visible===!1)&&!(t.observers.length<=0)&&(scratchObserverBox$2.copy(t.observerBox).expandByScalar(10).applyMatrix4(t.transform),scratchObserverBox$2.containsPoint(e.ray.origin)||e.ray.intersectsBox(scratchObserverBox$2)))for(let e of t.observers)n.push(e)}let[r,o]=arrayMin(n,e=>scratchVector3$4.copy(e.standingPosition).applyMatrix4(e.work.transform).distanceTo(t.point),!0);return r&&o<Math.max(r.standingPosition.distanceTo(this.camera.position)/5,10)?r:null}coordinatesForOffset(e){let t=this.renderer.getSize(new three.Vector2);return{longitude:-2*e.x/(t.x*this.viewport.width),latitude:2*e.y/(t.y*this.viewport.height)}}requestMomentumMovement(e,t,n,r){if(this.inMomentumMovement===null)return;r=Math.max(r,1);let o=Object.assign({},n),s={longitude:0,latitude:0};for(let e=0;e<r;e++)o.longitude*=.996,o.latitude*=.996*.998,s.longitude+=o.longitude,s.latitude+=o.latitude;let c=formatRad$1(this.cameraMotion.value.longitude+s.longitude),l=this.cameraMotion.value.fov,u=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(l):this.minLatitude,-Math.PI/2,Math.PI/2),d=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(l):this.maxLatitude,-Math.PI/2,Math.PI/2),f=clamp$1(this.cameraMotion.value.latitude+s.latitude,u,d),p=Object.assign(Object.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}),m=!(o.longitude>1e-4||o.longitude<-1e-4||o.latitude>1e-4||o.latitude<-1e-4),h=createEvent(`gesture.momentum`,Object.assign(Object.assign({},e),{isFirst:t,isFinal:m,state:p}));if(this.emit(`gesture.create`,h),this.inMomentumMovement.event=h,this.emit(`gesture.momentum`,h),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:c,latitude:f},0).catch(noop),m?this.inMomentumMovement=null:AnimationFrameLoop.shared.add((t,n)=>{this.requestMomentumMovement(e,!1,o,n)},!0))}onPanGesture(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();let t=this.panState,n=e.pointers.length;if(e.isFinal?this.panState=void 0:this.panState={pointerLength:n,defaultPrevented:e.defaultPrevented,x:e.center.x,y:e.center.y},t===void 0||t.pointerLength!==n){this.emit(`gesture.pan`,e);return}let r={x:e.center.x-t.x,y:e.center.y-t.y},o=this.relativeClientPosition(e.center),s=1,c=this.camera.pose.latitude;Math.abs(c)>Math.PI/6&&(s=c<0?o.y<0?-1:1:o.y>0?-1:1),r.x*=s;let l=this.coordinatesForOffset(r),u=formatRad$1(this.cameraMotion.value.longitude+l.longitude),d=this.camera.pose.fov,f=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(d):this.minLatitude,-Math.PI/2,Math.PI/2),p=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(d):this.maxLatitude,-Math.PI/2,Math.PI/2),m=clamp$1(this.cameraMotion.value.latitude+l.latitude,f,p);this.camera.aspect<1&&Math.abs(e.overallVelocityX)>.2&&Math.atan2(Math.abs(e.overallVelocityY),Math.abs(e.overallVelocityX))<Math.PI/6.923&&(m=this.cameraMotion.value.latitude);let h=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:u,latitude:m,fov:d,offset:this.camera.pose.offset,distance:this.camera.pose.distance});if(e.state=h,this.emit(`gesture.pan`,e),e.defaultPrevented){this.panState&&(this.panState.defaultPrevented=e.defaultPrevented);return}if(!(e.isFinal&&t.defaultPrevented)&&(this.cameraMotion.set({longitude:h.longitude,latitude:h.latitude},0).catch(noop),e.isFinal)){let t=e.velocityX*s,n=e.velocityY;this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,this.coordinatesForOffset({x:t,y:n}),0)}}onPinchGesture(e){var t;if(!this.initAnimationIsReady)return;this.userAction=e.userAction,this.stopMomentumMovement();let n=(t=this.pinchState)==null?void 0:t.fov;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&(this.panState=void 0,this.pinchState=void 0),n===void 0)return;let r=clamp$1(n/e.scale,this.minFov,this.maxFov),o=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(r):this.minLatitude,-Math.PI/2,Math.PI/2),s=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(r):this.maxLatitude,-Math.PI/2,Math.PI/2),c=clamp$1(this.cameraMotion.value.latitude,o,s);e.state.fov=r,e.state.latitude=c,this.emit(`gesture.pinch`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:r,latitude:c},0).catch(noop),this.onPanGesture(e))}onMouseMove(e){var t,n;if(!this.intersectMesh.parent||this.panState)return;if(this.emit(`gesture.mousemove`,e),e.defaultPrevented){this.hideIntersectMesh();return}let r=e.center.raycaster;if(e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}let[o]=this.modelScene.intersectRaycaster(r),s=createEvent(`intersect.update`,{raycaster:r,intersection:o==null?null:o,object:this.intersectMesh});if(this.emit(`intersect.update`,s),s.defaultPrevented){this.hideIntersectMesh();return}if(o){let e=(n=(t=o.face)==null?void 0:t.normal)==null?new three.Vector3().copy(r.ray.direction).multiplyScalar(-1):n,s=e.clone(),c=o.point.clone();this.intersectMesh.position.copy(c);let l=c.clone().add(s);if(this.intersectMesh.lookAt(l),Math.abs(e.y)>.99){let e=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(e.z,e.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}onMouseWheel(e){if(!this.initAnimationIsReady)return;this.userAction=e.userAction,this.stopMomentumMovement();let{minFov:t,maxFov:n}=this,r=clamp$1(this.camera.fov-e.center.delta,t,n),o=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(r):this.minLatitude,-Math.PI/2,Math.PI/2),s=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(r):this.maxLatitude,-Math.PI/2,Math.PI/2),c=clamp$1(this.cameraMotion.value.latitude,o,s);e.state.fov=r,e.state.latitude=c,this.emit(`gesture.mousewheel`,e),!e.defaultPrevented&&this.cameraMotion.set({fov:r,latitude:c},0).catch(noop)}onTapGesture(e){var t;this.userAction=e.userAction,this.stopMomentumMovement();let n=e.center.raycaster,r=this.getForwardObserverOrNot(n);if(!r)this.emit(`gesture.tap`,e);else{let n={longitude:this.camera.pose.longitude,latitude:0},o=Object.assign(Object.assign({},e.state),{mode:`Panorama`,workCode:r.work.workCode,panoIndex:r.panoIndex,longitude:n.longitude,latitude:n.latitude,offset:r?r.position.clone():new three.Vector3,distance:0});if(e.state=o,this.emit(`gesture.tap`,e),!e.defaultPrevented&&(this.emit(`pano.select`,createEvent(`pano.select`,{prevPano:this.currentPano,state:o,userAction:e.userAction,options:n,progress:0,error:null})),r&&r.active)){let e=this.pendingTextureId=createUuid(),s=panoStringify({panoIndex:r.panoIndex,workCode:r.work.workCode}),c={right:r.images.work.getURL(r.images.right),left:r.images.work.getURL(r.images.left),up:r.images.work.getURL(r.images.up),down:r.images.work.getURL(r.images.down),front:r.images.work.getURL(r.images.front),back:r.images.work.getURL(r.images.back)},l=this.imageOptions.transform,u=Object.assign({key:`pano.${s}`},pick(this.imageOptions,[`format`,`size`,`quality`,`sharpen`,`forceUseExifOrientation`,`mappings`])),d=`pano:`+jsonHash([c,u,l]),f=this.modelScene.parameter,p;f.pano0&&f.pano0.map.name===d?p=f.pano0:f.pano1&&f.pano1.map.name===d&&(p=f.pano1),p?(f.pano0&&f.pano0.map!==p.map&&f.pano0.map.dispose(),f.pano1&&f.pano1.map!==p.map&&f.pano1.map!==((t=f.pano0)==null?void 0:t.map)&&f.pano1.map.dispose(),f.set({pano0:p,pano1:p}),this.emit(`pano.request`,createEvent(`pano.request`,{userAction:!0,prevPano:this.currentPano,progress:0,state:o,options:n,error:null}))):this.textureLoader.loadCubeTexture(c,{imageURL:{transform:l,options:u},format:three.RGBFormat,viaAjax:!0,fetcher:getFetcher(this.fiveId,r.work)},void 0,void 0,void 0,this.renderer).then(t=>{var c,l;let{body:u}=t;if(this.destroyed||this.pendingTextureId!==e){u.dispose();return}this.pendingTextureId=null,u.name=d;let p=Array.isArray(u.image)?u.image[0]:u.image,m=(c=p==null?void 0:p.width)==null?2048:c,h=new Histogram().formPixels(getRgbaDataFromCubeTexture(this.renderer,u,!0,sharedHistogramRgbaData).data),g={panoId:s,map:u,mapSize:m,mapHistogram:new three.Vector4().fromArray(h.toArray()),matrix:r.matrix.clone().premultiply(r.work.transform),zoom:1};f.pano0&&f.pano0.map.dispose(),f.pano1&&f.pano1.map!==((l=f.pano0)==null?void 0:l.map)&&f.pano1.map.dispose(),f.set({pano0:g,pano1:g}),this.emit(`pano.request`,createEvent(`pano.request`,{userAction:!0,prevPano:this.currentPano,progress:0,state:o,options:n,error:null}))}).catch(t=>{this.destroyed||this.pendingTextureId!==e||(this.pendingTextureId=null)})}}}onDblTapGesture(e){this.userAction=e.userAction,this.stopMomentumMovement();let t=this.cameraMotion.value.fov,n=this.minFov-t<t-this.defaultFov?this.minFov:this.defaultFov;e.state.fov=n,this.emit(`gesture.dbltap`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:n},360).catch(noop),this.hideIntersectMesh())}hideIntersectMesh(){this.intersectMesh.visible=!1,this.needsRender=!0}},defaultTopviewControllerCustomInitArgs=Object.assign(Object.assign({},omit(defaultFloorplanControllerCustomInitArgs,[`defaultLongitude`,`defaultLatitude`,`maxLatitude`,`minLatitude`])),{defaultLongitude:0,defaultLatitude:Math.PI/2}),TopviewController=class e extends FloorplanController{static parseArgs(t){var n,r;if(t instanceof e)return t;let o=Object.assign(Object.assign({},t),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2,defaultLongitude:(n=t.defaultLongitude)==null?defaultTopviewControllerCustomInitArgs.defaultLongitude:n,defaultLatitude:(r=t.defaultLatitude)==null?defaultTopviewControllerCustomInitArgs.defaultLatitude:r});return super.parseArgs(o)}static initAnimationEndState(e){var t,n;let r=this.parseArgs(e),o=super.initAnimationEndState(Object.assign(Object.assign({},r),{initial:Object.assign(Object.assign({},r.initial),{state:Object.assign(Object.assign({},r.initial.state),{longitude:(t=r.initial.state.longitude)==null?r.defaultLongitude:t,latitude:(n=r.initial.state.latitude)==null?r.defaultLatitude:n})})}));return Object.assign(Object.assign({},o),{mode:`Topview`})}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`Topview`}updateConfiguration(e){return super.updateConfiguration(Object.assign({},e))}updateModel(e){this.needsRender=!0;let t=this.modelScene.boundingBox.getCenter(new three.Vector3);this.locationMotion.set({x:t.x,y:t.y,z:t.z,distance:FloorplanController.distanceFromModel(this.modelScene,this.defaultFov,this.camera.aspect)},0).catch(noop),this.hideIntersectMesh()}updateCamera(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r={},o={};return e.distance!==void 0&&(r.distance=e.distance),e.offset!==void 0&&(r.x=e.offset.x,r.y=e.offset.y,r.z=e.offset.z),e.longitude!==void 0&&(o.longitude=e.longitude),e.latitude!==void 0&&(o.latitude=e.latitude),e.fov!==void 0&&(o.fov=e.fov),this.locationMotion.set(r,t).catch(noop),this.cameraMotion.set(o,t).catch(noop)})}updateCameraWithKeyframes(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r=[],o=[];for(let t of e)r.push({key:t.key,progress:t.progress,value:{distance:t.value.distance,x:t.value.offset.x,y:t.value.offset.y,z:t.value.offset.z}}),o.push({key:t.key,progress:t.progress,value:{longitude:t.value.longitude,latitude:t.value.latitude,fov:t.value.fov}});return this.locationMotion.setKeyframes(r,t).catch(noop),this.cameraMotion.setKeyframes(e,t)})}initAnimation(){return this.destroyed?Promise.resolve():new Promise(t=>{let{state:n,currentState:r,duration:o,userAction:s}=this.initial;this.userAction=s;let c=e.initAnimationEndState(this),l={longitude:c.longitude,latitude:c.latitude,fov:c.fov},u={x:c.offset.x,y:c.offset.y,z:c.offset.z,distance:c.distance};this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:c,userAction:this.userAction})),this.modelAlphaMotion.set({modelAlpha:1},o/3).catch(noop),this.perspToOrthoMotion.set({perspToOrtho:1},o).catch(noop),this.cameraMotion.set(l,o).catch(noop),this.locationMotion.set(u,o).then(()=>{this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:c,userAction:this.userAction}))},e=>{let t=Object.assign(Object.assign(Object.assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:t,userAction:this.userAction}))}).then(()=>{t()})})}requestMomentumMovement(){this.inMomentumMovement=null}onPanGesture(e){this.userAction=e.userAction,this.stopMomentumMovement();let t=this.panState,n=e.pointers.length;if(e.isFinal?this.panState=void 0:this.panState={pointerLength:n,defaultPrevented:e.defaultPrevented,x:e.center.x,y:e.center.y},t===void 0||t.pointerLength!==n){this.emit(`gesture.pan`,e);return}let r={x:e.center.x-t.x,y:e.center.y-t.y},o=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),s=this.locationMotion.value.distance;s*=Math.tan(this.cameraMotion.value.fov/2*Math.PI/180);let c=this.renderer.getSize(new three.Vector2),l=2*r.x*s/c.y,u=2*r.y*s/c.y,d=new three.Vector3;d.setFromMatrixColumn(this.camera.matrix,0),d.multiplyScalar(-l),o.add(d),d.setFromMatrixColumn(this.camera.matrix,1),d.multiplyScalar(u),o.add(d);let f=this.modelScene.boundingBox.getCenter(new three.Vector3),p=this.modelScene.boundingBox.getSize(new three.Vector3),m=Math.max(p.x,p.y,p.z)/2;if(o.clamp(f.clone().sub(new three.Vector3().setScalar(m)),f.clone().add(new three.Vector3().setScalar(m))),e.state=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:0,latitude:Math.PI/2,fov:this.cameraMotion.value.fov,offset:o,distance:this.locationMotion.value.distance}),this.emit(`gesture.pan`,e),e.defaultPrevented){this.panState&&(this.panState.defaultPrevented=e.defaultPrevented);return}e.isFinal&&t.defaultPrevented||this.locationMotion.set({x:o.x,y:o.y,z:o.z},0).catch(noop)}onPinchGesture(e){var t;if(!this.initAnimationIsReady)return;this.userAction=e.userAction,this.stopMomentumMovement();let n=(t=this.pinchState)==null?void 0:t.fov;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&(this.pinchState=void 0),n===void 0)return;let r=clamp$1(n/e.scale,this.minFov,this.maxFov);e.state.fov=r,this.emit(`gesture.pinch`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:r},0).catch(noop),e.type=`gesture.pan`,this.onPanGesture(e))}onMouseWheel(e){if(!this.initAnimationIsReady)return;this.userAction=e.userAction,this.stopMomentumMovement();let t=clamp$1(this.cameraMotion.value.fov-e.center.delta,this.minFov,this.maxFov);e.state.fov=t,this.emit(`gesture.mousewheel`,e),!e.defaultPrevented&&this.cameraMotion.set({fov:t},0).catch(noop)}},defaultPanoramaLikeControllerCustomInitArgs={defaultLatitude:0,defaultFov:90,maxFov:120,minFov:20,maxLatitude:e=>Math.PI/2-e/2/180*Math.PI,minLatitude:e=>-Math.PI/2+e/2/180*Math.PI,moveSpeed:3.6,intersectMeshCreator:()=>new IntersectMesh,aerialObserverMinHeight:5},PanoramaLikeController=class e extends BaseController{static parseArgs(t){var n,r,o,s,c,l,u,d,f;if(t instanceof e)return t;let p=super.parseArgs(t);return Object.assign(Object.assign({},p),{defaultLatitude:(n=t.defaultLatitude)==null?defaultPanoramaLikeControllerCustomInitArgs.defaultLatitude:n,defaultFov:(r=t.defaultFov)==null?defaultPanoramaLikeControllerCustomInitArgs.defaultFov:r,maxFov:(o=t.maxFov)==null?defaultPanoramaLikeControllerCustomInitArgs.maxFov:o,minFov:(s=t.minFov)==null?defaultPanoramaLikeControllerCustomInitArgs.minFov:s,maxLatitude:(c=t.maxLatitude)==null?defaultPanoramaLikeControllerCustomInitArgs.maxLatitude:c,minLatitude:(l=t.minLatitude)==null?defaultPanoramaLikeControllerCustomInitArgs.minLatitude:l,moveSpeed:(u=t.moveSpeed)==null?defaultPanoramaLikeControllerCustomInitArgs.moveSpeed:u,intersectMeshCreator:(d=t.intersectMeshCreator)==null?defaultPanoramaLikeControllerCustomInitArgs.intersectMeshCreator:d,aerialObserverMinHeight:(f=t.aerialObserverMinHeight)==null?defaultPanoramaLikeControllerCustomInitArgs.aerialObserverMinHeight:f})}static initAnimationEndState(e){var t,n,r,o,s,c;let l=this.parseArgs(e),u=l.works,{state:d,currentState:f}=e.initial,p=typeof d.panoIndex==`number`?{workCode:(r=(t=d.workCode)==null?(n=l.works[0])==null?void 0:n.workCode:t)==null?``:r,panoIndex:d.panoIndex}:{workCode:f.workCode,panoIndex:f.panoIndex},m=u.getObserver(p),h=clamp$1((o=d.fov)==null?isFristPersonMode(f.mode)?f.fov:l.defaultFov:o,l.minFov,l.maxFov),g=(s=d.longitude)==null?f.longitude:s,_=clamp$1(typeof l.minLatitude==`function`?l.minLatitude(h):l.minLatitude,-Math.PI/2,Math.PI/2),v=clamp$1(typeof l.maxLatitude==`function`?l.maxLatitude(h):l.maxLatitude,-Math.PI/2,Math.PI/2),y=clamp$1((c=d.latitude)==null?isFristPersonMode(f.mode)?f.latitude:l.defaultLatitude:c,_,v),b=new three.Vector3;return m&&b.copy(m.position).applyMatrix4(m.work.transform),{workCode:p.workCode,panoIndex:p.panoIndex,mode:`PanoramaLike`,longitude:g,latitude:y,fov:h,offset:b,distance:0}}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`PanoramaLike`,this.defaultLatitude=n.defaultLatitude,this.defaultFov=n.defaultFov,this.maxFov=n.maxFov,this.minFov=n.minFov,this.maxLatitude=n.maxLatitude,this.minLatitude=n.minLatitude,this.moveSpeed=n.moveSpeed,this.intersectMeshCreator=n.intersectMeshCreator,this.aerialObserverMinHeight=n.aerialObserverMinHeight,this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=`intersect`,this.intersectMesh.visible=!1,this.helper.add(this.intersectMesh)}updateConfiguration(e){if(super.updateConfiguration(e)===!1)return!1;if(e.defaultLatitude!==void 0&&this.defaultLatitude!==e.defaultLatitude&&(this.defaultLatitude=e.defaultLatitude),e.maxLatitude!==void 0&&this.maxLatitude!==e.maxLatitude&&(this.maxLatitude=e.maxLatitude),e.minLatitude!==void 0&&this.minLatitude!==e.minLatitude&&(this.minLatitude=e.minLatitude),e.defaultFov!==void 0&&this.defaultFov!==e.defaultFov&&(this.defaultFov=e.defaultFov),e.maxFov!==void 0&&this.maxFov!==e.maxFov&&(this.maxFov=e.maxFov),e.minFov!==void 0&&this.minFov!==e.minFov&&(this.minFov=e.minFov),e.moveSpeed!==void 0&&this.moveSpeed!==e.moveSpeed&&(this.moveSpeed=e.moveSpeed),e.intersectMeshCreator!==void 0&&this.intersectMeshCreator!==e.intersectMeshCreator){this.intersectMeshCreator=e.intersectMeshCreator;let t=this.intersectMesh;this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=t.name,this.intersectMesh.visible=t.visible;let n=this.intersectMesh.parent;n&&n.add(this.intersectMesh),t.dispose()}return e.aerialObserverMinHeight!==void 0&&this.aerialObserverMinHeight!==e.aerialObserverMinHeight&&(this.aerialObserverMinHeight=e.aerialObserverMinHeight),!0}destroy(){super.destroy(),this.intersectMesh&&(this.helper.remove(this.intersectMesh),this.intersectMesh.dispose()),this.panState=void 0}isReady(){return this.panState||this.pinchState?!1:super.isReady()}calculateMovingDuration(e,t){switch(typeof e){case`function`:return e(t,this.moveSpeed);case`number`:return e;case`string`:return Number(e);default:return clamp$1(t,2,5)/this.moveSpeed*1e3}}hideIntersectMesh(){this.intersectMesh.visible=!1,this.needsRender=!0}coordinatesForOffset(e){let t=this.cameraMotion.value.fov,n=this.camera.aspect,r=this.renderer.getSize(new three.Vector2);return{longitude:2*e.x/(r.x*this.viewport.width)*t/95*n,latitude:-2*e.y/(r.y*this.viewport.height)*t/95}}cameraBounce(){let{longitude:e,latitude:t,fov:n}=this.cameraMotion.value,r=[{progress:0,value:{longitude:e,latitude:t,fov:n}},{progress:.5,value:{longitude:e,latitude:t,fov:n*.98}},{progress:1,value:{longitude:e,latitude:t,fov:n}}];this.cameraMotion.setKeyframes(r,500).catch(noop)}requestMomentumMovement(e,t,n,r){if(this.inMomentumMovement===null)return;r=Math.max(r,1);let o=Object.assign({},n),s={longitude:0,latitude:0};for(let e=0;e<r;e++)o.longitude*=.996,o.latitude*=.996*.99,s.longitude+=o.longitude,s.latitude+=o.latitude;let c=this.cameraMotion.value.fov,l=formatRad$1(this.cameraMotion.value.longitude+s.longitude),u=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(c):this.minLatitude,-Math.PI/2,Math.PI/2),d=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(c):this.maxLatitude,-Math.PI/2,Math.PI/2),f=clamp$1(this.cameraMotion.value.latitude+s.latitude,u,d),p=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:l,latitude:f,fov:c,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance}),m=!(o.longitude>1e-4||o.longitude<-1e-4||o.latitude>1e-4||o.latitude<-1e-4),h=createEvent(`gesture.momentum`,Object.assign(Object.assign({},e),{isFirst:t,isFinal:m,state:p}));if(this.emit(`gesture.create`,h),this.inMomentumMovement.event=h,this.emit(`gesture.momentum`,h),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:l,latitude:f},0).catch(noop),m?this.inMomentumMovement=null:AnimationFrameLoop.shared.add((t,n)=>{this.requestMomentumMovement(e,!1,o,n)},!0))}onPanGesture(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();let t=this.panState,n=e.pointers.length;if(e.isFinal?this.panState=void 0:this.panState={pointerLength:n,defaultPrevented:e.defaultPrevented,x:e.center.x,y:e.center.y},t===void 0||t.pointerLength!==n){this.emit(`gesture.pan`,e);return}let r={x:e.center.x-t.x,y:e.center.y-t.y},o=this.coordinatesForOffset(r),s=formatRad$1(this.cameraMotion.value.longitude+o.longitude),c=this.cameraMotion.value.fov,l=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(c):this.minLatitude,-Math.PI/2,Math.PI/2),u=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(c):this.maxLatitude,-Math.PI/2,Math.PI/2),d=clamp$1(this.cameraMotion.value.latitude+o.latitude,l,u);this.camera.aspect<1&&Math.abs(e.overallVelocityX)>.2&&Math.atan2(Math.abs(e.overallVelocityY),Math.abs(e.overallVelocityX))<Math.PI/6.923&&(d=this.cameraMotion.value.latitude);let f=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:s,latitude:d,fov:c,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance});if(e.state=f,this.emit(`gesture.pan`,e),e.defaultPrevented){this.panState&&(this.panState.defaultPrevented=e.defaultPrevented);return}if(e.isFinal&&t.defaultPrevented)return;let p={longitude:f.longitude,latitude:f.latitude,fov:f.fov};if(this.cameraMotion.set(p,0).catch(noop),e.isFinal){let t=e.velocityX,n=e.velocityY*.6;Math.abs(n)>.5&&Math.abs(t)<.5&&(t=0),this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,this.coordinatesForOffset({x:t,y:n}),0)}}onPinchGesture(e){var t;this.userAction=e.userAction,this.stopMomentumMovement();let n=(t=this.pinchState)==null?void 0:t.fov,r=e.scale;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&(this.pinchState=void 0),n===void 0)return;let o=clamp$1(n/r,this.minFov,this.maxFov),s=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(o):this.minLatitude,-Math.PI/2,Math.PI/2),c=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(o):this.maxLatitude,-Math.PI/2,Math.PI/2),l=clamp$1(this.cameraMotion.value.latitude,s,c);e.state.fov=o,e.state.latitude=l,this.emit(`gesture.pinch`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:o,latitude:l},0).catch(noop),e.type=`gesture.pan`,this.onPanGesture(e))}onMouseWheel(e){this.userAction=e.userAction,this.stopMomentumMovement();let t=clamp$1(this.cameraMotion.value.fov-e.center.delta,this.minFov,this.maxFov),n=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(t):this.minLatitude,-Math.PI/2,Math.PI/2),r=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(t):this.maxLatitude,-Math.PI/2,Math.PI/2),o=clamp$1(this.cameraMotion.value.latitude,n,r);e.state.fov=t,e.state.latitude=o,this.emit(`gesture.mousewheel`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:t,latitude:o},0).catch(noop),this.onMouseMove(e))}onMouseMove(e){var t,n;if(!this.intersectMesh.parent||this.panState||(this.emit(`gesture.mousemove`,e),e.defaultPrevented))return;let r=e.center.raycaster;if(e.isFinal&&this.intersectMesh.parent){this.hideIntersectMesh();return}r.floorIndex=-1;let[o]=this.modelScene.intersectRaycaster(r),s=createEvent(`intersect.update`,{raycaster:r,intersection:o==null?null:o,object:this.intersectMesh});if(this.emit(`intersect.update`,s),s.defaultPrevented){this.hideIntersectMesh();return}if(o){let e=(n=(t=o.face)==null?void 0:t.normal)==null?new three.Vector3().copy(r.ray.direction).multiplyScalar(-1):n,s=e.clone(),c=o.point.clone();this.intersectMesh.position.copy(c);let l=c.clone().add(s);if(this.intersectMesh.lookAt(l),Math.abs(e.y)>.99){let e=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(e.z,e.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}onDblTapGesture(e){this.userAction=e.userAction,this.stopMomentumMovement();let t=this.cameraMotion.value.fov,n=2,r=this.works.getObserver(this.currentPano);if(r){let e=r.images.tiles;e&&e.length&&(n=Math.max(...e.map(e=>e.level)))}let o=Math.max(40-n*5,this.minFov,5),s=o-t<t-this.defaultFov?o:this.defaultFov;e.state.fov=s,this.emit(`gesture.dbltap`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:s},360).catch(noop),this.hideIntersectMesh())}},blankVideo=`data:video/mp4;base64,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`,result;function canplayVideo(){return result||(result=new Promise(e=>{let t,n=document.createElement(`video`);n.muted=!0,n.src=blankVideo,n.addEventListener(`timeupdate`,function r(){n.removeEventListener(`timeupdate`,r,!1),clearTimeout(t);let o=document.createElement(`canvas`);o.width=o.height=1;let s=o.getContext(`2d`);if(!s){e(!1);return}s.drawImage(n,0,0,1,1);let{data:c}=s.getImageData(0,0,1,1);c[3]>10?e(!0):e(!1)},!1),n.addEventListener(`canplay`,function e(){n.removeEventListener(`canplay`,e,!1),n.play()},!1),t=window.setTimeout(()=>e(!1),1e3)}))}var FACE_ORDER=[`right`,`left`,`up`,`down`,`front`,`back`];function getBox(e,t,n,r){let o=new three.Box3;switch(e){case`up`:o.min.y=.5,o.max.y=.5,o.min.x=t-.5,o.max.x=t-.5+r,o.min.z=-n+.5-r,o.max.z=-n+.5;break;case`down`:o.min.y=-.5,o.max.y=-.5,o.min.x=t-.5,o.max.x=t-.5+r,o.min.z=n-.5,o.max.z=n-.5+r;break;case`left`:o.min.x=-.5,o.max.x=-.5,o.min.z=-t+.5-r,o.max.z=-t+.5,o.min.y=-n+.5-r,o.max.y=-n+.5;break;case`right`:o.min.x=.5,o.max.x=.5,o.min.z=t-.5,o.max.z=t-.5+r,o.min.y=-n+.5-r,o.max.y=-n+.5;break;case`front`:o.min.z=-.5,o.max.z=-.5,o.min.x=t-.5,o.max.x=t-.5+r,o.min.y=-n+.5-r,o.max.y=-n+.5;break;case`back`:o.min.z=.5,o.max.z=.5,o.min.x=-t+.5-r,o.max.x=-t+.5,o.min.y=-n+.5-r,o.max.y=-n+.5;break;default:break}return o.applyMatrix4(new three.Matrix4().makeRotationY(Math.PI))}var createChildren=(e,t)=>{if(e.level>=t)return;let n=e.level+1,r=e.size/2,o=[new three.Vector2(e.position.x,e.position.y),new three.Vector2(e.position.x+r,e.position.y),new three.Vector2(e.position.x,e.position.y+r),new three.Vector2(e.position.x+r,e.position.y+r)];for(let s of o){let o={face:e.face,level:n,size:r,position:s,box:getBox(e.face,s.x,s.y,r),parent:e,children:[]};e.children.push(o),createChildren(o,t)}};function createTileCubeNode(e,t){let n={level:0,face:e,position:new three.Vector2(0,0),size:1,box:getBox(e,0,0,1),parent:null,children:[]};return createChildren(n,t),n}function createTileCubeTree(e){return{children:FACE_ORDER.map(t=>createTileCubeNode(t,e)),maxLevel:e}}function traverseTileCubeNode(e,t){for(let n of e.children)t(n)!==!1&&traverseTileCubeNode(n,t)}var _a$1,scratchSortVector3=new three.Vector3,scratchCameraQuaternion=new three.Quaternion,scratchCameraMatrix=new three.Matrix4,scratchCameraProjectMatrix=new three.Matrix4,scratchFrustumMatrix=new three.Matrix4,scratchFrustumMatrixInverse=new three.Matrix4,scratchFrustumProjectMatrix=new three.Matrix4,scratchSceneQuaternionInverse=new three.Quaternion,scratchSceneMatrixInverse=new three.Matrix4,clearColor$1=new three.Color(0,0,0),clearAlpha=0,scratchPrevClearColor$1=new three.Color,clippingPlanes=[],SQRT1_2=(_a$1=Math.SQRT1_2)==null?Math.sqrt(2):_a$1,TILE_QUATERNION={up:new three.Quaternion(SQRT1_2,0,0,SQRT1_2),down:new three.Quaternion(-SQRT1_2,0,0,SQRT1_2),left:new three.Quaternion(0,SQRT1_2,0,SQRT1_2),right:new three.Quaternion(0,-SQRT1_2,0,SQRT1_2),front:new three.Quaternion(0,0,0,1),back:new three.Quaternion(0,1,0,0)},tileGeometry=(()=>{let e=new Float32Array([-.5,-.5,0,.5,-.5,0,-.5,.5,0,.5,.5,0]),t=new Float32Array([0,0,1,0,0,1,1,1]),n=new Uint32Array([0,1,2,1,3,2]),r=new three.BufferGeometry;return r.setAttribute(`position`,new three.BufferAttribute(e,3)),r.setAttribute(`uv`,new three.BufferAttribute(t,2)),r.setIndex(new three.BufferAttribute(n,1)),r.computeBoundingBox(),r})(),TILE_MATERIAL_VERTEX_SHADER=`
1532
+ `,side:three.DoubleSide,blending:three.CustomBlending,blendSrc:three.SrcAlphaFactor,blendDst:three.OneMinusSrcAlphaFactor,blendSrcAlpha:three.OneFactor,blendDstAlpha:three.OneMinusSrcAlphaFactor,depthWrite:!1,transparent:!0}),IntersectMesh=class extends three.Object3D{constructor(){super(),this.ringMesh=new three.Mesh(sharedGeometry$2,sharedMaterial),this.ringMesh.position.z=.01,this.ringMesh.renderOrder=9999999999,this.add(this.ringMesh)}dispose(){this.remove(this.ringMesh)}},scratchObserverBox$2=new three.Box3,scratchVector3$4=new three.Vector3,defaultFloorplanControllerCustomInitArgs={defaultLongitude:Math.PI/4,defaultLatitude:Math.PI/4,defaultFov:80,maxFov:120,minFov:20,maxLatitude:Math.PI/2,minLatitude:-Math.PI/2,intersectMeshCreator:()=>new IntersectMesh},FloorplanController=class e extends BaseController{static distanceFromModel(e,t,n){let r=e.boundingBox,o=r.isEmpty()?10:Math.pow(Math.pow(r.max.x-r.min.x+1,2)+Math.pow(r.max.y-r.min.y+1,2)+Math.pow(r.max.z-r.min.z+1,2),1/2);o=isNaN(o)||!isFinite(o)?1:o;let s=o/2/Math.tan(Math.PI*t/360);return n<1&&(s/=n),isNaN(s)||!isFinite(s)?o:s}static parseArgs(t){var n,r,o,s,c,l,u,d;if(t instanceof e)return t;let f=super.parseArgs(t);return Object.assign(Object.assign({},f),{defaultLongitude:(n=t.defaultLongitude)==null?defaultFloorplanControllerCustomInitArgs.defaultLongitude:n,defaultLatitude:(r=t.defaultLatitude)==null?defaultFloorplanControllerCustomInitArgs.defaultLatitude:r,defaultFov:(o=t.defaultFov)==null?defaultFloorplanControllerCustomInitArgs.defaultFov:o,maxFov:(s=t.maxFov)==null?defaultFloorplanControllerCustomInitArgs.maxFov:s,minFov:(c=t.minFov)==null?defaultFloorplanControllerCustomInitArgs.minFov:c,maxLatitude:(l=t.maxLatitude)==null?defaultFloorplanControllerCustomInitArgs.maxLatitude:l,minLatitude:(u=t.minLatitude)==null?defaultFloorplanControllerCustomInitArgs.minLatitude:u,intersectMeshCreator:(d=t.intersectMeshCreator)==null?defaultFloorplanControllerCustomInitArgs.intersectMeshCreator:d})}static initAnimationEndState(t){var n,r,o,s,c,l,u;let d=this.parseArgs(t),{state:f,currentState:p}=t.initial,m=typeof f.panoIndex==`number`?{workCode:(o=(n=f.workCode)==null?(r=d.works[0])==null?void 0:r.workCode:n)==null?``:o,panoIndex:f.panoIndex}:{workCode:p.workCode,panoIndex:p.panoIndex},h=(s=f.fov)==null?d.defaultFov:s,g=(c=f.longitude)==null?isThirdPersonMode(p.mode)?p.longitude:d.defaultLongitude:c,_=clamp$1(typeof d.minLatitude==`function`?d.minLatitude(h):d.minLatitude,-Math.PI/2,Math.PI/2),v=clamp$1(typeof d.maxLatitude==`function`?d.maxLatitude(h):d.maxLatitude,-Math.PI/2,Math.PI/2),y=clamp$1((l=f.latitude)==null?p.mode===`Floorplan`?p.latitude:d.defaultLatitude:l,_,v),b=f.offset?f.offset.clone():t.modelScene.boundingBox.getCenter(new three.Vector3),S=(u=f.distance)==null?e.distanceFromModel(d.modelScene,d.defaultFov,d.camera.aspect):u;return Object.assign(Object.assign({},m),{mode:`Floorplan`,longitude:g,latitude:y,fov:h,offset:b,distance:S})}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`Floorplan`,this.defaultLongitude=n.defaultLongitude,this.defaultLatitude=n.defaultLatitude,this.defaultFov=n.defaultFov,this.maxFov=n.maxFov,this.minFov=n.minFov,this.maxLatitude=n.maxLatitude,this.minLatitude=n.minLatitude,this.locationMotion=new Motion({x:this.camera.pose.offset.x,y:this.camera.pose.offset.y,z:this.camera.pose.offset.z,distance:this.camera.pose.distance}),this.modelAlphaMotion=new Motion({modelAlpha:this.modelScene.parameter.resolveValue(`modelAlpha`)}),this.perspToOrthoMotion=new Motion({perspToOrtho:this.camera.perspToOrtho.x}),this.pendingTextureId=null,this.textureLoader=new TextureLoader,this.intersectMeshCreator=n.intersectMeshCreator,this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=`intersect`,this.intersectMesh.visible=!1,this.helper.add(this.intersectMesh)}updateConfiguration(e){if(super.updateConfiguration(e)===!1)return!1;if(e.defaultLongitude!==void 0&&this.defaultLongitude!==e.defaultLongitude&&(this.defaultLongitude=e.defaultLongitude),e.defaultLatitude!==void 0&&this.defaultLatitude!==e.defaultLatitude&&(this.defaultLatitude=e.defaultLatitude),e.defaultFov!==void 0&&this.defaultFov!==e.defaultFov&&(this.defaultFov=e.defaultFov),e.maxFov!==void 0&&this.maxFov!==e.maxFov&&(this.maxFov=e.maxFov),e.minFov!==void 0&&this.minFov!==e.minFov&&(this.minFov=e.minFov),e.maxLatitude!==void 0&&this.maxLatitude!==e.maxLatitude&&(this.maxLatitude=e.maxLatitude),e.minLatitude!==void 0&&this.minLatitude!==e.minLatitude&&(this.minLatitude=e.minLatitude),e.intersectMeshCreator!==void 0&&this.intersectMeshCreator!==e.intersectMeshCreator){this.intersectMeshCreator=e.intersectMeshCreator;let t=this.intersectMesh;this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=t.name,this.intersectMesh.visible=t.visible;let n=this.intersectMesh.parent;n&&n.add(this.intersectMesh),t.dispose()}return!0}destroy(){super.destroy(),this.pendingTextureId=null,this.locationMotion.dispose(),this.panState=void 0,this.intersectMesh.dispose(),this.helper.remove(this.intersectMesh)}isReady(){return this.locationMotion.ended===!1?!1:super.isReady()}updateWork(e,t,n,r){var o;return this.works=e,this.updateCamera(t,(o=n.duration)==null?0:o,r),!0}updateModel(t){super.updateModel(t);let n=t.boundingBox.getCenter(new three.Vector3),r=e.distanceFromModel(t,this.defaultFov,this.camera.aspect);this.updateCamera({offset:n,distance:r},0,!0)}updateCamera(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r={},o={};return e.distance!==void 0&&(r.distance=e.distance),e.offset!==void 0&&(r.x=e.offset.x,r.y=e.offset.y,r.z=e.offset.z),e.longitude!==void 0&&(o.longitude=e.longitude),e.latitude!==void 0&&(o.latitude=e.latitude),e.fov!==void 0&&(o.fov=e.fov),this.locationMotion.set(r,t).catch(noop),this.cameraMotion.set(o,t).catch(noop)})}updateCameraWithKeyframes(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r=[],o=[];for(let t of e)r.push({key:t.key,progress:t.progress,value:{distance:t.value.distance,x:t.value.offset.x,y:t.value.offset.x,z:t.value.offset.x}}),o.push({key:t.key,progress:t.progress,value:{longitude:t.value.longitude,latitude:t.value.latitude,fov:t.value.fov}});return this.locationMotion.setKeyframes(r,t).catch(noop),this.cameraMotion.setKeyframes(e,t)})}updateTime(e,t,...n){if(this.destroyed)return;let r={},o={};if(this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),r.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.modelScene.parameter.modelAlpha===0&&this.modelScene.parameter.progress!==1){let{pano0:e,pano1:t}=this.modelScene.parameter;e&&e.map!==(t==null?void 0:t.map)&&e.map.dispose(),r.progress=1,r.pano0=r.pano1=t}if(this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended||(this.locationMotion.update(e),o.distance=this.locationMotion.value.distance,o.offset=new three.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(r)||this.modelScene.parameter.set(r),isEmptyObject(o)||this.setCamera(o),this.intersectMesh&&this.intersectMesh.parent){let e=clamp$1(this.camera.position.distanceTo(this.intersectMesh.position)*(2*Math.tan(.5*this.camera.fov/180*Math.PI))/5,.5);this.intersectMesh.scale.setScalar(e)}else this.intersectMesh.scale.setScalar(1)}getTargetState(){let e=this.cameraMotion.getKeyFrameSegment(now())[1],t=this.locationMotion.getKeyFrameSegment(now())[1];return Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:new three.Vector3(t.value.x,t.value.y,t.value.z),distance:t.value.distance})}initAnimation(){return this.destroyed?Promise.resolve():new Promise(t=>{let{state:n,currentState:r,duration:o,userAction:s}=this.initial;this.userAction=s;let c=e.initAnimationEndState(this),l=pick(c,[`longitude`,`latitude`,`fov`]),u={x:c.offset.x,y:c.offset.y,z:c.offset.z,distance:c.distance};this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:c,userAction:this.userAction})),this.modelAlphaMotion.set({modelAlpha:1},o/3).catch(noop),this.perspToOrthoMotion.set({perspToOrtho:0},o).catch(noop),this.cameraMotion.set(l,o).catch(noop),this.locationMotion.set(u,o).then(()=>{this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:c,userAction:this.userAction}))},e=>{let t=Object.assign(Object.assign(Object.assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:t,userAction:this.userAction}))}).then(()=>{t()})})}updateRenderSize(e){this.needsRender=!0}getForwardObserverOrNot(e){let[t]=this.modelScene.intersectRaycaster(e);if(!t)return null;let n=[];for(let t of this.works){let r=this.modelScene.models.find(e=>e.work===t);if(!(!r||r.visible===!1)&&!(t.observers.length<=0)&&(scratchObserverBox$2.copy(t.observerBox).expandByScalar(10).applyMatrix4(t.transform),scratchObserverBox$2.containsPoint(e.ray.origin)||e.ray.intersectsBox(scratchObserverBox$2)))for(let e of t.observers)n.push(e)}let[r,o]=arrayMin(n,e=>scratchVector3$4.copy(e.standingPosition).applyMatrix4(e.work.transform).distanceTo(t.point),!0);return r&&o<Math.max(r.standingPosition.distanceTo(this.camera.position)/5,10)?r:null}coordinatesForOffset(e){let t=this.renderer.getSize(new three.Vector2);return{longitude:-2*e.x/(t.x*this.viewport.width),latitude:2*e.y/(t.y*this.viewport.height)}}requestMomentumMovement(e,t,n,r){if(this.inMomentumMovement===null)return;r=Math.max(r,1);let o=Object.assign({},n),s={longitude:0,latitude:0};for(let e=0;e<r;e++)o.longitude*=.996,o.latitude*=.996*.998,s.longitude+=o.longitude,s.latitude+=o.latitude;let c=formatRad$1(this.cameraMotion.value.longitude+s.longitude),l=this.cameraMotion.value.fov,u=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(l):this.minLatitude,-Math.PI/2,Math.PI/2),d=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(l):this.maxLatitude,-Math.PI/2,Math.PI/2),f=clamp$1(this.cameraMotion.value.latitude+s.latitude,u,d),p=Object.assign(Object.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}),m=!(o.longitude>1e-4||o.longitude<-1e-4||o.latitude>1e-4||o.latitude<-1e-4),h=createEvent(`gesture.momentum`,Object.assign(Object.assign({},e),{isFirst:t,isFinal:m,state:p}));if(this.emit(`gesture.fire`,h),this.inMomentumMovement.event=h,this.emit(`gesture.momentum`,h),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:c,latitude:f},0).catch(noop),m?this.inMomentumMovement=null:AnimationFrameLoop.shared.add((t,n)=>{this.requestMomentumMovement(e,!1,o,n)},!0))}onPanGesture(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();let t=this.panState,n=e.pointers.length;if(e.isFinal?this.panState=void 0:this.panState={pointerLength:n,defaultPrevented:e.defaultPrevented,x:e.center.x,y:e.center.y},t===void 0||t.pointerLength!==n){this.emit(`gesture.pan`,e);return}let r={x:e.center.x-t.x,y:e.center.y-t.y},o=this.relativeClientPosition(e.center),s=1,c=this.camera.pose.latitude;Math.abs(c)>Math.PI/6&&(s=c<0?o.y<0?-1:1:o.y>0?-1:1),r.x*=s;let l=this.coordinatesForOffset(r),u=formatRad$1(this.cameraMotion.value.longitude+l.longitude),d=this.camera.pose.fov,f=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(d):this.minLatitude,-Math.PI/2,Math.PI/2),p=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(d):this.maxLatitude,-Math.PI/2,Math.PI/2),m=clamp$1(this.cameraMotion.value.latitude+l.latitude,f,p);this.camera.aspect<1&&Math.abs(e.overallVelocityX)>.2&&Math.atan2(Math.abs(e.overallVelocityY),Math.abs(e.overallVelocityX))<Math.PI/6.923&&(m=this.cameraMotion.value.latitude);let h=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:u,latitude:m,fov:d,offset:this.camera.pose.offset,distance:this.camera.pose.distance});if(e.state=h,this.emit(`gesture.pan`,e),e.defaultPrevented){this.panState&&(this.panState.defaultPrevented=e.defaultPrevented);return}if(!(e.isFinal&&t.defaultPrevented)&&(this.cameraMotion.set({longitude:h.longitude,latitude:h.latitude},0).catch(noop),e.isFinal)){let t=e.velocityX*s,n=e.velocityY;this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,this.coordinatesForOffset({x:t,y:n}),0)}}onPinchGesture(e){var t;if(!this.initAnimationIsReady)return;this.userAction=e.userAction,this.stopMomentumMovement();let n=(t=this.pinchState)==null?void 0:t.fov;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&(this.panState=void 0,this.pinchState=void 0),n===void 0)return;let r=clamp$1(n/e.scale,this.minFov,this.maxFov),o=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(r):this.minLatitude,-Math.PI/2,Math.PI/2),s=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(r):this.maxLatitude,-Math.PI/2,Math.PI/2),c=clamp$1(this.cameraMotion.value.latitude,o,s);e.state.fov=r,e.state.latitude=c,this.emit(`gesture.pinch`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:r,latitude:c},0).catch(noop),this.onPanGesture(e))}onMouseMove(e){var t,n;if(!this.intersectMesh.parent||this.panState)return;if(this.emit(`gesture.mousemove`,e),e.defaultPrevented){this.hideIntersectMesh();return}let r=e.center.raycaster;if(e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}let[o]=this.modelScene.intersectRaycaster(r),s=createEvent(`intersect.update`,{raycaster:r,intersection:o==null?null:o,object:this.intersectMesh});if(this.emit(`intersect.update`,s),s.defaultPrevented){this.hideIntersectMesh();return}if(o){let e=(n=(t=o.face)==null?void 0:t.normal)==null?new three.Vector3().copy(r.ray.direction).multiplyScalar(-1):n,s=e.clone(),c=o.point.clone();this.intersectMesh.position.copy(c);let l=c.clone().add(s);if(this.intersectMesh.lookAt(l),Math.abs(e.y)>.99){let e=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(e.z,e.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}onMouseWheel(e){if(!this.initAnimationIsReady)return;this.userAction=e.userAction,this.stopMomentumMovement();let{minFov:t,maxFov:n}=this,r=clamp$1(this.camera.fov-e.center.delta,t,n),o=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(r):this.minLatitude,-Math.PI/2,Math.PI/2),s=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(r):this.maxLatitude,-Math.PI/2,Math.PI/2),c=clamp$1(this.cameraMotion.value.latitude,o,s);e.state.fov=r,e.state.latitude=c,this.emit(`gesture.mousewheel`,e),!e.defaultPrevented&&this.cameraMotion.set({fov:r,latitude:c},0).catch(noop)}onTapGesture(e){var t;this.userAction=e.userAction,this.stopMomentumMovement();let n=e.center.raycaster,r=this.getForwardObserverOrNot(n);if(!r)this.emit(`gesture.tap`,e);else{let n={longitude:this.camera.pose.longitude,latitude:0},o=Object.assign(Object.assign({},e.state),{mode:`Panorama`,workCode:r.work.workCode,panoIndex:r.panoIndex,longitude:n.longitude,latitude:n.latitude,offset:r?r.position.clone():new three.Vector3,distance:0});if(e.state=o,this.emit(`gesture.tap`,e),!e.defaultPrevented&&(this.emit(`pano.select`,createEvent(`pano.select`,{prevPano:this.currentPano,state:o,userAction:e.userAction,options:n,progress:0,error:null})),r&&r.active)){let e=this.pendingTextureId=createUuid(),s=panoStringify({panoIndex:r.panoIndex,workCode:r.work.workCode}),c={right:r.images.work.getURL(r.images.right),left:r.images.work.getURL(r.images.left),up:r.images.work.getURL(r.images.up),down:r.images.work.getURL(r.images.down),front:r.images.work.getURL(r.images.front),back:r.images.work.getURL(r.images.back)},l=this.imageOptions.transform,u=Object.assign({key:`pano.${s}`},pick(this.imageOptions,[`format`,`size`,`quality`,`sharpen`,`forceUseExifOrientation`,`mappings`])),d=`pano:`+jsonHash([c,u,l]),f=this.modelScene.parameter,p;f.pano0&&f.pano0.map.name===d?p=f.pano0:f.pano1&&f.pano1.map.name===d&&(p=f.pano1),p?(f.pano0&&f.pano0.map!==p.map&&f.pano0.map.dispose(),f.pano1&&f.pano1.map!==p.map&&f.pano1.map!==((t=f.pano0)==null?void 0:t.map)&&f.pano1.map.dispose(),f.set({pano0:p,pano1:p}),this.emit(`pano.request`,createEvent(`pano.request`,{userAction:!0,prevPano:this.currentPano,progress:0,state:o,options:n,error:null}))):this.textureLoader.loadCubeTexture(c,{imageURL:{transform:l,options:u},format:three.RGBFormat,viaAjax:!0,fetcher:getFetcher(this.fiveId,r.work)},void 0,void 0,void 0,this.renderer).then(t=>{var c,l;let{body:u}=t;if(this.destroyed||this.pendingTextureId!==e){u.dispose();return}this.pendingTextureId=null,u.name=d;let p=Array.isArray(u.image)?u.image[0]:u.image,m=(c=p==null?void 0:p.width)==null?2048:c,h=r.images.histogram;h||(h=new Histogram().formPixels(getRgbaDataFromCubeTexture(this.renderer,u,!0,sharedHistogramRgbaData).data),r.images.histogram=h);let g={panoId:s,map:u,mapSize:m,mapHistogram:new three.Vector4().fromArray(h.toArray()),matrix:r.matrix.clone().premultiply(r.work.transform),zoom:1};f.pano0&&f.pano0.map.dispose(),f.pano1&&f.pano1.map!==((l=f.pano0)==null?void 0:l.map)&&f.pano1.map.dispose(),f.set({pano0:g,pano1:g}),this.emit(`pano.request`,createEvent(`pano.request`,{userAction:!0,prevPano:this.currentPano,progress:0,state:o,options:n,error:null}))}).catch(t=>{this.destroyed||this.pendingTextureId!==e||(this.pendingTextureId=null)})}}}onDblTapGesture(e){this.userAction=e.userAction,this.stopMomentumMovement();let t=this.cameraMotion.value.fov,n=this.minFov-t<t-this.defaultFov?this.minFov:this.defaultFov;e.state.fov=n,this.emit(`gesture.dbltap`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:n},360).catch(noop),this.hideIntersectMesh())}hideIntersectMesh(){this.intersectMesh.visible=!1,this.needsRender=!0}},defaultTopviewControllerCustomInitArgs=Object.assign(Object.assign({},omit(defaultFloorplanControllerCustomInitArgs,[`defaultLongitude`,`defaultLatitude`,`maxLatitude`,`minLatitude`])),{defaultLongitude:0,defaultLatitude:Math.PI/2}),TopviewController=class e extends FloorplanController{static parseArgs(t){var n,r;if(t instanceof e)return t;let o=Object.assign(Object.assign({},t),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2,defaultLongitude:(n=t.defaultLongitude)==null?defaultTopviewControllerCustomInitArgs.defaultLongitude:n,defaultLatitude:(r=t.defaultLatitude)==null?defaultTopviewControllerCustomInitArgs.defaultLatitude:r});return super.parseArgs(o)}static initAnimationEndState(e){var t,n;let r=this.parseArgs(e),o=super.initAnimationEndState(Object.assign(Object.assign({},r),{initial:Object.assign(Object.assign({},r.initial),{state:Object.assign(Object.assign({},r.initial.state),{longitude:(t=r.initial.state.longitude)==null?r.defaultLongitude:t,latitude:(n=r.initial.state.latitude)==null?r.defaultLatitude:n})})}));return Object.assign(Object.assign({},o),{mode:`Topview`})}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`Topview`}updateConfiguration(e){return super.updateConfiguration(Object.assign({},e))}updateModel(e){this.needsRender=!0;let t=this.modelScene.boundingBox.getCenter(new three.Vector3);this.locationMotion.set({x:t.x,y:t.y,z:t.z,distance:FloorplanController.distanceFromModel(this.modelScene,this.defaultFov,this.camera.aspect)},0).catch(noop),this.hideIntersectMesh()}updateCamera(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r={},o={};return e.distance!==void 0&&(r.distance=e.distance),e.offset!==void 0&&(r.x=e.offset.x,r.y=e.offset.y,r.z=e.offset.z),e.longitude!==void 0&&(o.longitude=e.longitude),e.latitude!==void 0&&(o.latitude=e.latitude),e.fov!==void 0&&(o.fov=e.fov),this.locationMotion.set(r,t).catch(noop),this.cameraMotion.set(o,t).catch(noop)})}updateCameraWithKeyframes(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r=[],o=[];for(let t of e)r.push({key:t.key,progress:t.progress,value:{distance:t.value.distance,x:t.value.offset.x,y:t.value.offset.y,z:t.value.offset.z}}),o.push({key:t.key,progress:t.progress,value:{longitude:t.value.longitude,latitude:t.value.latitude,fov:t.value.fov}});return this.locationMotion.setKeyframes(r,t).catch(noop),this.cameraMotion.setKeyframes(e,t)})}initAnimation(){return this.destroyed?Promise.resolve():new Promise(t=>{let{state:n,currentState:r,duration:o,userAction:s}=this.initial;this.userAction=s;let c=e.initAnimationEndState(this),l={longitude:c.longitude,latitude:c.latitude,fov:c.fov},u={x:c.offset.x,y:c.offset.y,z:c.offset.z,distance:c.distance};this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:c,userAction:this.userAction})),this.modelAlphaMotion.set({modelAlpha:1},o/3).catch(noop),this.perspToOrthoMotion.set({perspToOrtho:1},o).catch(noop),this.cameraMotion.set(l,o).catch(noop),this.locationMotion.set(u,o).then(()=>{this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:c,userAction:this.userAction}))},e=>{let t=Object.assign(Object.assign(Object.assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:t,userAction:this.userAction}))}).then(()=>{t()})})}requestMomentumMovement(){this.inMomentumMovement=null}onPanGesture(e){this.userAction=e.userAction,this.stopMomentumMovement();let t=this.panState,n=e.pointers.length;if(e.isFinal?this.panState=void 0:this.panState={pointerLength:n,defaultPrevented:e.defaultPrevented,x:e.center.x,y:e.center.y},t===void 0||t.pointerLength!==n){this.emit(`gesture.pan`,e);return}let r={x:e.center.x-t.x,y:e.center.y-t.y},o=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),s=this.locationMotion.value.distance;s*=Math.tan(this.cameraMotion.value.fov/2*Math.PI/180);let c=this.renderer.getSize(new three.Vector2),l=2*r.x*s/c.y,u=2*r.y*s/c.y,d=new three.Vector3;d.setFromMatrixColumn(this.camera.matrix,0),d.multiplyScalar(-l),o.add(d),d.setFromMatrixColumn(this.camera.matrix,1),d.multiplyScalar(u),o.add(d);let f=this.modelScene.boundingBox.getCenter(new three.Vector3),p=this.modelScene.boundingBox.getSize(new three.Vector3),m=Math.max(p.x,p.y,p.z)/2;if(o.clamp(f.clone().sub(new three.Vector3().setScalar(m)),f.clone().add(new three.Vector3().setScalar(m))),e.state=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:0,latitude:Math.PI/2,fov:this.cameraMotion.value.fov,offset:o,distance:this.locationMotion.value.distance}),this.emit(`gesture.pan`,e),e.defaultPrevented){this.panState&&(this.panState.defaultPrevented=e.defaultPrevented);return}e.isFinal&&t.defaultPrevented||this.locationMotion.set({x:o.x,y:o.y,z:o.z},0).catch(noop)}onPinchGesture(e){var t;if(!this.initAnimationIsReady)return;this.userAction=e.userAction,this.stopMomentumMovement();let n=(t=this.pinchState)==null?void 0:t.fov;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&(this.pinchState=void 0),n===void 0)return;let r=clamp$1(n/e.scale,this.minFov,this.maxFov);e.state.fov=r,this.emit(`gesture.pinch`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:r},0).catch(noop),e.type=`gesture.pan`,this.onPanGesture(e))}onMouseWheel(e){if(!this.initAnimationIsReady)return;this.userAction=e.userAction,this.stopMomentumMovement();let t=clamp$1(this.cameraMotion.value.fov-e.center.delta,this.minFov,this.maxFov);e.state.fov=t,this.emit(`gesture.mousewheel`,e),!e.defaultPrevented&&this.cameraMotion.set({fov:t},0).catch(noop)}},defaultPanoramaLikeControllerCustomInitArgs={defaultLatitude:0,defaultFov:90,maxFov:120,minFov:20,maxLatitude:e=>Math.PI/2-e/2/180*Math.PI,minLatitude:e=>-Math.PI/2+e/2/180*Math.PI,moveSpeed:3.6,intersectMeshCreator:()=>new IntersectMesh,aerialObserverMinHeight:5},PanoramaLikeController=class e extends BaseController{static parseArgs(t){var n,r,o,s,c,l,u,d,f;if(t instanceof e)return t;let p=super.parseArgs(t);return Object.assign(Object.assign({},p),{defaultLatitude:(n=t.defaultLatitude)==null?defaultPanoramaLikeControllerCustomInitArgs.defaultLatitude:n,defaultFov:(r=t.defaultFov)==null?defaultPanoramaLikeControllerCustomInitArgs.defaultFov:r,maxFov:(o=t.maxFov)==null?defaultPanoramaLikeControllerCustomInitArgs.maxFov:o,minFov:(s=t.minFov)==null?defaultPanoramaLikeControllerCustomInitArgs.minFov:s,maxLatitude:(c=t.maxLatitude)==null?defaultPanoramaLikeControllerCustomInitArgs.maxLatitude:c,minLatitude:(l=t.minLatitude)==null?defaultPanoramaLikeControllerCustomInitArgs.minLatitude:l,moveSpeed:(u=t.moveSpeed)==null?defaultPanoramaLikeControllerCustomInitArgs.moveSpeed:u,intersectMeshCreator:(d=t.intersectMeshCreator)==null?defaultPanoramaLikeControllerCustomInitArgs.intersectMeshCreator:d,aerialObserverMinHeight:(f=t.aerialObserverMinHeight)==null?defaultPanoramaLikeControllerCustomInitArgs.aerialObserverMinHeight:f})}static initAnimationEndState(e){var t,n,r,o,s,c;let l=this.parseArgs(e),u=l.works,{state:d,currentState:f}=e.initial,p=typeof d.panoIndex==`number`?{workCode:(r=(t=d.workCode)==null?(n=l.works[0])==null?void 0:n.workCode:t)==null?``:r,panoIndex:d.panoIndex}:{workCode:f.workCode,panoIndex:f.panoIndex},m=u.getObserver(p),h=clamp$1((o=d.fov)==null?isFristPersonMode(f.mode)?f.fov:l.defaultFov:o,l.minFov,l.maxFov),g=(s=d.longitude)==null?f.longitude:s,_=clamp$1(typeof l.minLatitude==`function`?l.minLatitude(h):l.minLatitude,-Math.PI/2,Math.PI/2),v=clamp$1(typeof l.maxLatitude==`function`?l.maxLatitude(h):l.maxLatitude,-Math.PI/2,Math.PI/2),y=clamp$1((c=d.latitude)==null?isFristPersonMode(f.mode)?f.latitude:l.defaultLatitude:c,_,v),b=new three.Vector3;return m&&b.copy(m.position).applyMatrix4(m.work.transform),{workCode:p.workCode,panoIndex:p.panoIndex,mode:`PanoramaLike`,longitude:g,latitude:y,fov:h,offset:b,distance:0}}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`PanoramaLike`,this.defaultLatitude=n.defaultLatitude,this.defaultFov=n.defaultFov,this.maxFov=n.maxFov,this.minFov=n.minFov,this.maxLatitude=n.maxLatitude,this.minLatitude=n.minLatitude,this.moveSpeed=n.moveSpeed,this.intersectMeshCreator=n.intersectMeshCreator,this.aerialObserverMinHeight=n.aerialObserverMinHeight,this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=`intersect`,this.intersectMesh.visible=!1,this.helper.add(this.intersectMesh)}updateConfiguration(e){if(super.updateConfiguration(e)===!1)return!1;if(e.defaultLatitude!==void 0&&this.defaultLatitude!==e.defaultLatitude&&(this.defaultLatitude=e.defaultLatitude),e.maxLatitude!==void 0&&this.maxLatitude!==e.maxLatitude&&(this.maxLatitude=e.maxLatitude),e.minLatitude!==void 0&&this.minLatitude!==e.minLatitude&&(this.minLatitude=e.minLatitude),e.defaultFov!==void 0&&this.defaultFov!==e.defaultFov&&(this.defaultFov=e.defaultFov),e.maxFov!==void 0&&this.maxFov!==e.maxFov&&(this.maxFov=e.maxFov),e.minFov!==void 0&&this.minFov!==e.minFov&&(this.minFov=e.minFov),e.moveSpeed!==void 0&&this.moveSpeed!==e.moveSpeed&&(this.moveSpeed=e.moveSpeed),e.intersectMeshCreator!==void 0&&this.intersectMeshCreator!==e.intersectMeshCreator){this.intersectMeshCreator=e.intersectMeshCreator;let t=this.intersectMesh;this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=t.name,this.intersectMesh.visible=t.visible;let n=this.intersectMesh.parent;n&&n.add(this.intersectMesh),t.dispose()}return e.aerialObserverMinHeight!==void 0&&this.aerialObserverMinHeight!==e.aerialObserverMinHeight&&(this.aerialObserverMinHeight=e.aerialObserverMinHeight),!0}destroy(){super.destroy(),this.intersectMesh&&(this.helper.remove(this.intersectMesh),this.intersectMesh.dispose()),this.panState=void 0}isReady(){return this.panState||this.pinchState?!1:super.isReady()}calculateMovingDuration(e,t){switch(typeof e){case`function`:return e(t,this.moveSpeed);case`number`:return e;case`string`:return Number(e);default:return clamp$1(t,2,5)/this.moveSpeed*1e3}}hideIntersectMesh(){this.intersectMesh.visible=!1,this.needsRender=!0}coordinatesForOffset(e){let t=this.cameraMotion.value.fov,n=this.camera.aspect,r=this.renderer.getSize(new three.Vector2);return{longitude:2*e.x/(r.x*this.viewport.width)*t/95*n,latitude:-2*e.y/(r.y*this.viewport.height)*t/95}}cameraBounce(){let{longitude:e,latitude:t,fov:n}=this.cameraMotion.value,r=[{progress:0,value:{longitude:e,latitude:t,fov:n}},{progress:.5,value:{longitude:e,latitude:t,fov:n*.98}},{progress:1,value:{longitude:e,latitude:t,fov:n}}];this.cameraMotion.setKeyframes(r,500).catch(noop)}requestMomentumMovement(e,t,n,r){if(this.inMomentumMovement===null)return;r=Math.max(r,1);let o=Object.assign({},n),s={longitude:0,latitude:0};for(let e=0;e<r;e++)o.longitude*=.996,o.latitude*=.996*.99,s.longitude+=o.longitude,s.latitude+=o.latitude;let c=this.cameraMotion.value.fov,l=formatRad$1(this.cameraMotion.value.longitude+s.longitude),u=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(c):this.minLatitude,-Math.PI/2,Math.PI/2),d=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(c):this.maxLatitude,-Math.PI/2,Math.PI/2),f=clamp$1(this.cameraMotion.value.latitude+s.latitude,u,d),p=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:l,latitude:f,fov:c,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance}),m=!(o.longitude>1e-4||o.longitude<-1e-4||o.latitude>1e-4||o.latitude<-1e-4),h=createEvent(`gesture.momentum`,Object.assign(Object.assign({},e),{isFirst:t,isFinal:m,state:p}));if(this.emit(`gesture.fire`,h),this.inMomentumMovement.event=h,this.emit(`gesture.momentum`,h),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:l,latitude:f},0).catch(noop),m?this.inMomentumMovement=null:AnimationFrameLoop.shared.add((t,n)=>{this.requestMomentumMovement(e,!1,o,n)},!0))}onPanGesture(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();let t=this.panState,n=e.pointers.length;if(e.isFinal?this.panState=void 0:this.panState={pointerLength:n,defaultPrevented:e.defaultPrevented,x:e.center.x,y:e.center.y},t===void 0||t.pointerLength!==n){this.emit(`gesture.pan`,e);return}let r={x:e.center.x-t.x,y:e.center.y-t.y},o=this.coordinatesForOffset(r),s=formatRad$1(this.cameraMotion.value.longitude+o.longitude),c=this.cameraMotion.value.fov,l=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(c):this.minLatitude,-Math.PI/2,Math.PI/2),u=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(c):this.maxLatitude,-Math.PI/2,Math.PI/2),d=clamp$1(this.cameraMotion.value.latitude+o.latitude,l,u);this.camera.aspect<1&&Math.abs(e.overallVelocityX)>.2&&Math.atan2(Math.abs(e.overallVelocityY),Math.abs(e.overallVelocityX))<Math.PI/6.923&&(d=this.cameraMotion.value.latitude);let f=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:s,latitude:d,fov:c,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance});if(e.state=f,this.emit(`gesture.pan`,e),e.defaultPrevented){this.panState&&(this.panState.defaultPrevented=e.defaultPrevented);return}if(e.isFinal&&t.defaultPrevented)return;let p={longitude:f.longitude,latitude:f.latitude,fov:f.fov};if(this.cameraMotion.set(p,0).catch(noop),e.isFinal){let t=e.velocityX,n=e.velocityY*.6;Math.abs(n)>.5&&Math.abs(t)<.5&&(t=0),this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,this.coordinatesForOffset({x:t,y:n}),0)}}onPinchGesture(e){var t;this.userAction=e.userAction,this.stopMomentumMovement();let n=(t=this.pinchState)==null?void 0:t.fov,r=e.scale;if(e.isFirst){this.pinchState={x:e.center.x,y:e.center.y,fov:this.cameraMotion.value.fov};return}if(e.isFinal&&(this.pinchState=void 0),n===void 0)return;let o=clamp$1(n/r,this.minFov,this.maxFov),s=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(o):this.minLatitude,-Math.PI/2,Math.PI/2),c=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(o):this.maxLatitude,-Math.PI/2,Math.PI/2),l=clamp$1(this.cameraMotion.value.latitude,s,c);e.state.fov=o,e.state.latitude=l,this.emit(`gesture.pinch`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:o,latitude:l},0).catch(noop),e.type=`gesture.pan`,this.onPanGesture(e))}onMouseWheel(e){this.userAction=e.userAction,this.stopMomentumMovement();let t=clamp$1(this.cameraMotion.value.fov-e.center.delta,this.minFov,this.maxFov),n=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(t):this.minLatitude,-Math.PI/2,Math.PI/2),r=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(t):this.maxLatitude,-Math.PI/2,Math.PI/2),o=clamp$1(this.cameraMotion.value.latitude,n,r);e.state.fov=t,e.state.latitude=o,this.emit(`gesture.mousewheel`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:t,latitude:o},0).catch(noop),this.onMouseMove(e))}onMouseMove(e){var t,n;if(!this.intersectMesh.parent||this.panState||(this.emit(`gesture.mousemove`,e),e.defaultPrevented))return;let r=e.center.raycaster;if(e.isFinal&&this.intersectMesh.parent){this.hideIntersectMesh();return}r.floorIndex=-1;let[o]=this.modelScene.intersectRaycaster(r),s=createEvent(`intersect.update`,{raycaster:r,intersection:o==null?null:o,object:this.intersectMesh});if(this.emit(`intersect.update`,s),s.defaultPrevented){this.hideIntersectMesh();return}if(o){let e=(n=(t=o.face)==null?void 0:t.normal)==null?new three.Vector3().copy(r.ray.direction).multiplyScalar(-1):n,s=e.clone(),c=o.point.clone();this.intersectMesh.position.copy(c);let l=c.clone().add(s);if(this.intersectMesh.lookAt(l),Math.abs(e.y)>.99){let e=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(e.z,e.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}onDblTapGesture(e){this.userAction=e.userAction,this.stopMomentumMovement();let t=this.cameraMotion.value.fov,n=2,r=this.works.getObserver(this.currentPano);if(r){let e=r.images.tiles;e&&e.length&&(n=Math.max(...e.map(e=>e.level)))}let o=Math.max(40-n*5,this.minFov,5),s=o-t<t-this.defaultFov?o:this.defaultFov;e.state.fov=s,this.emit(`gesture.dbltap`,e),!e.defaultPrevented&&(this.cameraMotion.set({fov:s},360).catch(noop),this.hideIntersectMesh())}},blankVideo=`data:video/mp4;base64,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`,result;function canplayVideo(){return result||(result=new Promise(e=>{let t,n=document.createElement(`video`);n.muted=!0,n.src=blankVideo,n.addEventListener(`timeupdate`,function r(){n.removeEventListener(`timeupdate`,r,!1),clearTimeout(t);let o=document.createElement(`canvas`);o.width=o.height=1;let s=o.getContext(`2d`);if(!s){e(!1);return}s.drawImage(n,0,0,1,1);let{data:c}=s.getImageData(0,0,1,1);c[3]>10?e(!0):e(!1)},!1),n.addEventListener(`canplay`,function e(){n.removeEventListener(`canplay`,e,!1),n.play()},!1),t=window.setTimeout(()=>e(!1),1e3)}))}var FACE_ORDER=[`right`,`left`,`up`,`down`,`front`,`back`];function getBox(e,t,n,r){let o=new three.Box3;switch(e){case`up`:o.min.y=.5,o.max.y=.5,o.min.x=t-.5,o.max.x=t-.5+r,o.min.z=-n+.5-r,o.max.z=-n+.5;break;case`down`:o.min.y=-.5,o.max.y=-.5,o.min.x=t-.5,o.max.x=t-.5+r,o.min.z=n-.5,o.max.z=n-.5+r;break;case`left`:o.min.x=-.5,o.max.x=-.5,o.min.z=-t+.5-r,o.max.z=-t+.5,o.min.y=-n+.5-r,o.max.y=-n+.5;break;case`right`:o.min.x=.5,o.max.x=.5,o.min.z=t-.5,o.max.z=t-.5+r,o.min.y=-n+.5-r,o.max.y=-n+.5;break;case`front`:o.min.z=-.5,o.max.z=-.5,o.min.x=t-.5,o.max.x=t-.5+r,o.min.y=-n+.5-r,o.max.y=-n+.5;break;case`back`:o.min.z=.5,o.max.z=.5,o.min.x=-t+.5-r,o.max.x=-t+.5,o.min.y=-n+.5-r,o.max.y=-n+.5;break;default:break}return o.applyMatrix4(new three.Matrix4().makeRotationY(Math.PI))}var createChildren=(e,t)=>{if(e.level>=t)return;let n=e.level+1,r=e.size/2,o=[new three.Vector2(e.position.x,e.position.y),new three.Vector2(e.position.x+r,e.position.y),new three.Vector2(e.position.x,e.position.y+r),new three.Vector2(e.position.x+r,e.position.y+r)];for(let s of o){let o={face:e.face,level:n,size:r,position:s,box:getBox(e.face,s.x,s.y,r),parent:e,children:[]};e.children.push(o),createChildren(o,t)}};function createTileCubeNode(e,t){let n={level:0,face:e,position:new three.Vector2(0,0),size:1,box:getBox(e,0,0,1),parent:null,children:[]};return createChildren(n,t),n}function createTileCubeTree(e){return{children:FACE_ORDER.map(t=>createTileCubeNode(t,e)),maxLevel:e}}function traverseTileCubeNode(e,t){for(let n of e.children)t(n)!==!1&&traverseTileCubeNode(n,t)}var _a$1,scratchSortVector3=new three.Vector3,scratchCameraQuaternion=new three.Quaternion,scratchCameraMatrix=new three.Matrix4,scratchCameraProjectMatrix=new three.Matrix4,scratchFrustumMatrix=new three.Matrix4,scratchFrustumMatrixInverse=new three.Matrix4,scratchFrustumProjectMatrix=new three.Matrix4,scratchSceneQuaternionInverse=new three.Quaternion,scratchSceneMatrixInverse=new three.Matrix4,clearColor$1=new three.Color(0,0,0),clearAlpha=0,scratchPrevClearColor$1=new three.Color,clippingPlanes=[],SQRT1_2=(_a$1=Math.SQRT1_2)==null?Math.sqrt(2):_a$1,TILE_QUATERNION={up:new three.Quaternion(SQRT1_2,0,0,SQRT1_2),down:new three.Quaternion(-SQRT1_2,0,0,SQRT1_2),left:new three.Quaternion(0,SQRT1_2,0,SQRT1_2),right:new three.Quaternion(0,-SQRT1_2,0,SQRT1_2),front:new three.Quaternion(0,0,0,1),back:new three.Quaternion(0,1,0,0)},tileGeometry=(()=>{let e=new Float32Array([-.5,-.5,0,.5,-.5,0,-.5,.5,0,.5,.5,0]),t=new Float32Array([0,0,1,0,0,1,1,1]),n=new Uint32Array([0,1,2,1,3,2]),r=new three.BufferGeometry;return r.setAttribute(`position`,new three.BufferAttribute(e,3)),r.setAttribute(`uv`,new three.BufferAttribute(t,2)),r.setIndex(new three.BufferAttribute(n,1)),r.computeBoundingBox(),r})(),TILE_MATERIAL_VERTEX_SHADER=`
1533
1533
  varying vec2 vUV;
1534
1534
  void main() {
1535
1535
  vUV = uv;
@@ -1676,7 +1676,7 @@ void main() {
1676
1676
  float cameraDepth = length(cameraVertex);
1677
1677
  gl_FragColor = packDepthToRGBA(clamp(cameraDepth / maxDepth, 0.0, 1.0));
1678
1678
  }
1679
- `,uniforms:{maxDepth:new three.Uniform(0)}});function renderDepthCube(e,t,n,r=1e3){depthMaterial.uniforms.maxDepth.value=r,scratchPrevClearColor.copy(e.getClearColor());let o=e.getClearAlpha(),s=t.overrideMaterial;t.overrideMaterial=depthMaterial,e.setClearColor(clearColor,0),n.update(e,t),e.setClearColor(scratchPrevClearColor,o),t.overrideMaterial=s}var defaultEffectEase=linear,scratchRaycaster$1=new three.Raycaster,scratchVector3$3=new three.Vector3,adjustPanoCircleMeshVectors=[new three.Vector3(0,0,0).multiplyScalar(.1),new three.Vector3(1,0,0).multiplyScalar(.1),new three.Vector3(-.5,0,-Math.sqrt(3)/2).multiplyScalar(.1),new three.Vector3(-.5,0,Math.sqrt(3)/2).multiplyScalar(.1)],defaultPanoramaControllerCustomInitArgs=Object.assign(Object.assign({},defaultPanoramaLikeControllerCustomInitArgs),{maxAccessibleDistance:5,panoTapTriggerRadius:.5,panoCircleMeshCreator:(e,t)=>e.position.distanceTo(e.standingPosition)>t.aerialObserverMinHeight?new PanoCircleMeshSolid:new PanoCircleMesh,adjustPanoCircleMeshPositionBasedOnModel:!1,tileLevelForFov:((e,t)=>{var n;let r=e=>e/180*Math.PI,o=(n=Math.log2)==null?(e=>Math.log(e)*Math.LOG2E):n,s=t.height/2/Math.tan(r(e/2))*Math.tan(r(45))*2,c=Math.max(o(s/512),0);return c<2.3&&c>.1&&(c=1),c=c%1>.75?Math.ceil(c):Math.floor(c),c}),tileAppearDuration:.5,tileMaxRequest:3,flyEffectUseDepthBuffer:!1}),PanoramaController=class e extends PanoramaLikeController{static parseArgs(t){var n,r,o,s,c,l,u,d;if(t instanceof e)return t;let f=super.parseArgs(t);return Object.assign(Object.assign({},f),{maxAccessibleDistance:(n=t.maxAccessibleDistance)==null?defaultPanoramaControllerCustomInitArgs.maxAccessibleDistance:n,panoTapTriggerRadius:(r=t.panoTapTriggerRadius)==null?defaultPanoramaControllerCustomInitArgs.panoTapTriggerRadius:r,panoCircleMeshCreator:(o=t.panoCircleMeshCreator)==null?defaultPanoramaControllerCustomInitArgs.panoCircleMeshCreator:o,adjustPanoCircleMeshPositionBasedOnModel:(s=t.adjustPanoCircleMeshPositionBasedOnModel)==null?defaultPanoramaControllerCustomInitArgs.adjustPanoCircleMeshPositionBasedOnModel:s,tileLevelForFov:(c=t.tileLevelForFov)==null?defaultPanoramaControllerCustomInitArgs.tileLevelForFov:c,tileAppearDuration:(l=t.tileAppearDuration)==null?defaultPanoramaControllerCustomInitArgs.tileAppearDuration:l,tileMaxRequest:(u=t.tileMaxRequest)==null?defaultPanoramaControllerCustomInitArgs.tileMaxRequest:u,flyEffectUseDepthBuffer:(d=t.flyEffectUseDepthBuffer)==null?defaultPanoramaControllerCustomInitArgs.flyEffectUseDepthBuffer:d})}static initAnimationEndState(e){let t=this.parseArgs(e),n=super.initAnimationEndState(t);return Object.assign(Object.assign({},n),{mode:`Panorama`})}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`Panorama`,this.initAnimationed=!1,this.maxAccessibleDistance=n.maxAccessibleDistance,this.panoTapTriggerRadius=n.panoTapTriggerRadius,this.panoCircleMeshCreator=n.panoCircleMeshCreator,this.adjustPanoCircleMeshPositionBasedOnModel=n.adjustPanoCircleMeshPositionBasedOnModel,this.tileLevelForFov=n.tileLevelForFov,this.tileAppearDuration=n.tileAppearDuration,this.tileMaxRequest=n.tileMaxRequest,this.flyEffectUseDepthBuffer=n.flyEffectUseDepthBuffer,this.adjustPanoCircleMeshPositionFix=new Map;let{pano0:r,pano1:o}=this.modelScene.parameter.resolveValue();r&&(o==null?void 0:o.map)!==r.map&&(this.modelScene.parameter.set({pano0:o}),r.map.dispose());let s=new Set;r&&s.add(r),o&&s.add(o),this.panoMeshes=new Map,this.locationMotion=new Motion({count:0,distance:this.camera.pose.distance}),this.modelAlphaMotion=new Motion({modelAlpha:this.modelScene.parameter.resolveValue().modelAlpha}),this.perspToOrthoMotion=new Motion({perspToOrtho:this.camera.perspToOrtho.x}),this.panoResources={},this.panoResources[this.locationMotion.keyframes[0].key=this.locationMotion.keyframes[1].key=createUuid()]={panoId:panoStringify(this.currentPano),panoPicture:this.modelScene.parameter.resolveValue().pano1,position:this.camera.pose.offset.clone(),effect:`fly`,effectEasing:defaultEffectEase,fixCameraTransform:new three.Matrix4},this.panoPictureObserverMap=new WeakMap,this.textureLoader=new TextureLoader,this.tiling=new Tiling({fiveId:this.fiveId}),this.panoVideo=new PanoVideo,this.scene.add(this.panoVideo.object),this.accessibleObserverFloorCheckCount=0}get tileLevel(){return this.tiling.level}updateConfiguration(e){return super.updateConfiguration(e)===!1?!1:(e.maxAccessibleDistance!==void 0&&this.maxAccessibleDistance!==e.maxAccessibleDistance&&(this.maxAccessibleDistance=e.maxAccessibleDistance),e.panoTapTriggerRadius!==void 0&&this.panoTapTriggerRadius!==e.panoTapTriggerRadius&&(this.panoTapTriggerRadius=e.panoTapTriggerRadius),e.panoCircleMeshCreator!==void 0&&this.panoCircleMeshCreator!==e.panoCircleMeshCreator&&(this.panoCircleMeshCreator=e.panoCircleMeshCreator,this.panoMeshes&&(this.panoMeshes.forEach(e=>{this.helper.remove(e),e.dispose()}),this.panoMeshes.clear())),e.tileLevelForFov!==void 0&&this.tileLevelForFov!==e.tileLevelForFov&&(this.tileLevelForFov=e.tileLevelForFov),e.tileMaxRequest!==void 0&&this.tileMaxRequest!==e.tileMaxRequest&&(this.tileMaxRequest=e.tileMaxRequest),e.flyEffectUseDepthBuffer!==void 0&&this.flyEffectUseDepthBuffer!==e.flyEffectUseDepthBuffer&&(this.flyEffectUseDepthBuffer=e.flyEffectUseDepthBuffer),e.adjustPanoCircleMeshPositionBasedOnModel!==void 0&&this.adjustPanoCircleMeshPositionBasedOnModel!==e.adjustPanoCircleMeshPositionBasedOnModel&&(this.adjustPanoCircleMeshPositionBasedOnModel=e.adjustPanoCircleMeshPositionBasedOnModel,this.adjustPanoCircleMeshPositionBasedOnModel||this.adjustPanoCircleMeshPositionFix.clear()),!0)}destroy(){super.destroy(),this.tiling.dispose(),this.modelScene.parameter.set({refinedScreen:null,pano0Depth:null,pano1Depth:null}),this.pano0DepthCubeRenderTarget&&(this.pano0DepthCubeRenderTarget.dispose(),this.pano0DepthCubeRenderTarget=void 0),this.pano1DepthCubeRenderTarget&&(this.pano1DepthCubeRenderTarget.dispose(),this.pano1DepthCubeRenderTarget=void 0),this.locationMotion.dispose(),this.pendingTextureTask=void 0,this.panoMeshes&&(this.panoMeshes.forEach(e=>{this.helper.remove(e),e.dispose()}),this.panoMeshes.clear());let e=this.videoTexture.image;e.pause(),e.oncanplay=noop,e.ontimeupdate=noop,this.scene.remove(this.panoVideo.object),this.panoVideo.setMaterial(null),this.panoVideo.dispose();let{pano0:t,pano1:n}=this.modelScene.parameter.resolveValue();for(let e of Object.keys(this.panoResources)){let r=this.panoResources[e];if(r.panoPicture){let e=r.panoPicture.map;e&&e!==(t==null?void 0:t.map)&&e!==(n==null?void 0:n.map)&&(e.dispose(),r.panoPicture=null)}delete this.panoResources[e]}}isReady(){return this.locationMotion.ended===!0?super.isReady():!1}isTileReady(){let e=this.tiling.pedding<=0;return this.initAnimationed&&e}updateWork(t,n,r,o){this.userAction=o,this.works=t;let s=e.initAnimationEndState(Object.assign(Object.assign({},this),{initial:{currentState:Object.assign(Object.assign({},this.currentPano),this.camera.pose),duration:r.duration,effect:r.effect,state:n,userAction:o}}));return(s.workCode!==this.currentPano.workCode||s.panoIndex!==this.currentPano.panoIndex||s.longitude!==this.cameraMotion.value.longitude||s.latitude!==this.cameraMotion.value.latitude||s.fov!==this.cameraMotion.value.fov)&&(this.initAnimationed=!1,this.moveToPano({workCode:s.workCode,panoIndex:s.panoIndex},{effect:r.effect,duration:r.duration,longitude:s.longitude,latitude:s.latitude,fov:s.fov,moveEndCallback:()=>{this.initAnimationed=!0},moveCancelCallback:()=>{this.initAnimationed=!0}},o)),!0}updateModel(e){this.modelScene=e,this.hideIntersectMesh()}updateTime(e,t,...n){var r,o,s,c,l,u;if(this.destroyed)return;let d={},f={},p=this.camera.getDirection(new three.Vector3),m=this.locationMotion.keyframes[0],h=this.locationMotion.keyframes[this.locationMotion.keyframes.length-1],[g,_]=this.locationMotion.getKeyFrameSegment(e),v=this.panoResourceFromLocationMotionKeyframe(g),y=this.panoResourceFromLocationMotionKeyframe(_),b=this.panoResourceFromLocationMotionKeyframe(m),S=this.panoResourceFromLocationMotionKeyframe(h),C=!1;if(this.cameraMotion.ended===!1&&(this.cameraMotion.update(e),f.longitude=this.cameraMotion.value.longitude,f.latitude=this.cameraMotion.value.latitude,f.fov=this.cameraMotion.value.fov),this.modelAlphaMotion.ended===!1&&(this.modelAlphaMotion.update(e),d.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);let t=this.locationMotion.value.count-_.value.count+1,n=new three.Vector3().copy(v.position),s=new three.Vector3().copy(y.position);if(d.progress=y.effectEasing(t),t>=.01&&t<=.99&&(d.progress=clamp$1(y.effectEasing(t),.01,.99)),y.panoPicture&&(t<1?v.panoPicture&&(d.pano0=v.panoPicture):d.pano0=y.panoPicture,d.pano1=y.panoPicture),y.effect===`montage`?d.transition=`BLACK`:y.effect===`spread`?d.transition=`SPREAD`:d.transition=`FADE`,y.effect===`zoomin`||y.effect===`zoomout`?d.progress=Math.pow(t,3):y.effect===`model`&&this.camera.pose.distance<.01&&(d.modelAlpha=1-Math.pow(clamp$1(Math.abs(t-.5)*2,0,1),4)),t<1&&y.effect!==`fly`&&y.effect!==`model`){if(d.pano0&&v.panoPicture){let e={panoId:d.pano0.panoId,map:d.pano0.map,mapHistogram:d.pano0.mapHistogram,mapSize:d.pano0.mapSize,zoom:d.pano0.zoom,matrix:v.panoPicture.matrix.clone().premultiply(v.fixCameraTransform).setPosition(y.position)},t=this.panoPictureObserverMap.get(d.pano0);t&&this.panoPictureObserverMap.set(e,t),d.pano0=e}n.copy(s),C=!0}f.distance=this.locationMotion.value.distance,f.offset=new three.Vector3(n.x+(s.x-n.x)*t,n.y+(s.y-n.y)*t,n.z+(s.z-n.z)*t);let c=[],l=[];for(let e of this.locationMotion.keyframes){let{key:t,progress:n}=e;t!==void 0&&(c.push(t),n>this.locationMotion.progress&&l.push(t))}for(let e of Object.keys(this.panoResources)){if(l.indexOf(e)>=0)continue;let t=this.panoResources[e];if(t.panoPicture){let e=t.panoPicture.map;if(e){if(e===((r=d.pano0)==null?void 0:r.map)||e===((o=d.pano1)==null?void 0:o.map))continue;e.dispose(),t.panoPicture=null}}c.indexOf(e)>=0||delete this.panoResources[e]}let u=panoParse(y.panoId);u!==this.currentPano&&(this.currentPano=u,this.accessibleObserverFloorCheckCount=0),this.emit(`pano.moving`,createEvent(`pano.moving`,{userAction:this.userAction,prevPano:panoParse(b.panoId),state:Object.assign(Object.assign(Object.assign(Object.assign({},panoParse(S.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),f),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(d)===!1&&this.modelScene.parameter.set(d),isEmptyObject(f)===!1&&this.setCamera(f);let w=this.works.getObserver(this.currentPano),T=this.locationMotion.ended?this.getForwardObserverOrNot(this.camera):null,E=this.works.getObserver(v.panoId),D=this.works.getObserver(y.panoId);if(this.adjustPanoCircleMeshPositionBasedOnModel&&this.helper.visible&&w){let e=[],t=w.work.observers;for(let n of w.accessibleNodes){let r=t[n];r&&e.push(r)}let n=new Map;if(e.sort((e,t)=>{let r=n.get(e);r===void 0&&(r=e.standingPosition.distanceTo(w.standingPosition),n.set(e,r));let o=n.get(e);return o===void 0&&(o=t.standingPosition.distanceTo(w.standingPosition),n.set(t,o)),r-o}),e.length){this.accessibleObserverFloorCheckCount%=e.length;let t=e[this.accessibleObserverFloorCheckCount],n=this.modelScene.models.find(e=>e.work===(t==null?void 0:t.work));if(t&&n&&n.visible){let e=.3,r=.05,o=.005,s=t.standingPosition.clone().applyMatrix4(t.work.transform),c=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode}),l=adjustPanoCircleMeshVectors.map(t=>{scratchRaycaster$1.ray.origin.copy(s),scratchRaycaster$1.ray.origin.add(scratchVector3$3.copy(t).setY(e)),scratchRaycaster$1.ray.direction.set(0,-1,0),scratchRaycaster$1.firstHitOnly=!0,scratchRaycaster$1.floorIndex=-1;let[r]=n.intersectRaycaster(scratchRaycaster$1);return r&&r.distance-o<=e?new three.Vector3().copy(s).setY(r.point.y+o):s});l.sort((e,t)=>t.y-e.y);let u=l[Math.floor(l.length/2)],[d]=l.filter(e=>e.distanceTo(u)<=.05);if(d){let e=new three.Vector4(s.x,s.y,s.z,d.y-s.y),t=this.adjustPanoCircleMeshPositionFix.get(c);t&&!e.equals(t)&&(this.needsRender=!0),this.adjustPanoCircleMeshPositionFix.set(c,e)}}this.accessibleObserverFloorCheckCount++}}let O=new Map;if(E)for(let e of E.accessibleNodes){let t=E.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});O.set(e,t)}}if(D)for(let e of D.accessibleNodes){let t=D.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});O.set(e,t)}}if(this.panoMeshes.forEach((e,t)=>{O.get(t)?O.delete(t):(this.helper.remove(e),e.dispose(),this.panoMeshes.delete(t))}),O.forEach((e,t)=>{let n=this.panoCircleMeshCreator(e,{aerialObserverMinHeight:this.aerialObserverMinHeight});this.panoMeshes.set(t,n),this.helper.add(n),O.delete(t)}),this.panoMeshes.forEach((e,t)=>{let n=this.works.getObserver(t);if(n){let r=n.position.distanceTo(n.standingPosition)>this.aerialObserverMinHeight;if(r)e.position.copy(n.position).applyMatrix4(n.work.transform),e.scale.setScalar(18);else{e.position.copy(n.standingPosition).applyMatrix4(n.work.transform);let t=this.adjustPanoCircleMeshPositionFix.get(n.panoId);t&&(scratchVector3$3.set(t.x,t.y,t.z),scratchVector3$3.equals(e.position)&&(e.position.y+=t.w)),e.scale.setScalar(1.2)}let o=this.camera.position.clone().setY(e.position.y),s=new three.Vector3().copy(e.position).sub(o).normalize();if(t===panoStringify(this.currentPano)){let t=clamp$1((.5-o.distanceTo(e.position))/.5,0,1);s.multiplyScalar(1-t).add(p.clone().multiplyScalar(t))}if(s.length()>0){let t=r?-Math.PI/2:0,n=Math.atan2(s.x,s.z);e.quaternion.setFromEuler(new three.Euler(t,n,0,`YXZ`))}}else e.visible=!1}),this.camera.pose.distance>.1||C)this.panoMeshes.forEach(n=>{n.setOpacity(0),n.setCurrent(!1),n.updateTime&&n.updateTime(e,t),n.visible=!1});else if(w){let n=w.work.observers,[,r]=arrayMin(w.accessibleNodes,e=>{let t=n[e];return!t||!t.active?1/0:w.standingPosition.distanceTo(t.standingPosition)},!0);r=clamp$1(r,3,1/0);let o=w.accessibleNodes.concat(w.panoIndex).map(e=>panoStringify({panoIndex:e,workCode:w.work.workCode}));this.panoMeshes.forEach((n,s)=>{let c=this.works.getObserver(s),l=!1,u=1;if(o.indexOf(s)===-1)l=!1,u=0;else if(!c)l=!1,u=0;else if(!c.loadable&&!c.active)l=!1,u=0;else{let e=n.position.clone().project(this.camera);l=Math.abs(e.x)<1&&Math.abs(e.y)<1&&Math.abs(e.z)<1&&!n.loading&&n.progress===0&&T!==null&&panoStringify({panoIndex:T.panoIndex,workCode:T.work.workCode})===s;let t=n.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);u=t<.01?0:clamp$1(r/t,.1,.85)}c&&c===D&&c.position.distanceTo(c.standingPosition)>this.aerialObserverMinHeight&&n.position.distanceTo(this.camera.position)<35&&(u=0),this.modelScene.parameter.resolveValue().modelAlpha>0&&(u=0),n.setCurrent(l),n.setOpacity(u),n.updateTime&&n.updateTime(e,t)})}{let e=(s=this.modelScene.parameter.progress)==null?1:s,t=Math.round(e),n=this.modelScene.parameter.pano0,r=this.modelScene.parameter.pano1,o=t===0?n:r,l;if(o&&(l=this.works.getObserver(o.panoId),l||(l=this.panoPictureObserverMap.get(o))),this.tiling.appearDuration=this.tileAppearDuration,this.tiling.maxRequest=e<(canUseNativeImageBitmap()?.6:.99)?0:this.tileMaxRequest,this.tiling.imageOptions=this.imageOptions,!l||!o||this.tileLevelForFov===!1||this.camera.perspToOrtho.x>0){this.tiling.setObserver(null);let e={renderer:this.renderer,resolution:this.camera.resolution,pixelRatio:this.camera.pixelRatio,time:this.camera.time,cameraMatrix:this.camera.matrixWorld,cameraProjectionMatrix:this.camera.projectionMatrix,panoMap:null,panoMatrix:new three.Matrix4,panoZoom:1,minLevel:0,level:0};this.tiling.update(e),this.modelScene.parameter.set(`refinedScreen`,null)}else{let e=getImageSizeLevel(o.mapSize),s=e+1,u=new three.Vector2().copy(this.camera.resolution).multiplyScalar(this.camera.pixelRatio),d=Math.floor(this.tileLevelForFov(this.camera.fov,u)),f=d>e?d:0;this.tiling.setObserver(l);let p={renderer:this.renderer,resolution:this.camera.resolution,pixelRatio:this.camera.pixelRatio,time:this.camera.time,cameraMatrix:this.camera.matrixWorld,cameraProjectionMatrix:this.camera.projectionMatrix,panoMap:o.map,panoMatrix:o.matrix,panoZoom:o.zoom,minLevel:s,level:f},m=this.tiling.update(p),h={map:this.tiling.renderTarget.texture,matrixInverse:this.tiling.camera.matrixWorldInverse,projectionMatrix:this.tiling.camera.projectionMatrix,pano:t,opacity:(n==null?void 0:n.panoId)===(r==null?void 0:r.panoId)?1:easeInQuart(Math.abs(((c=this.modelScene.parameter.progress)==null?0:c)-.5)*2)},g=this.modelScene.parameter.refinedScreen;(m||h.pano!==(g==null?void 0:g.pano)||h.opacity!==(g==null?void 0:g.opacity))&&this.modelScene.parameter.set(`refinedScreen`,h)}}if(this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e),w&&w.images.video&&(this.needsRender=!0),this.intersectMesh&&this.intersectMesh.parent&&w&&w.position.y-w.standingPosition.y>10){let e=clamp$1(this.camera.position.distanceTo(this.intersectMesh.position)*(2*Math.tan(.5*this.camera.fov/180*Math.PI))/5,.5);this.intersectMesh.scale.setScalar(e)}else this.intersectMesh.scale.setScalar(1);{let e=y.effect,{pano0:t,pano1:n}=this.modelScene.parameter;if(t&&n&&t!==n&&(e===`fly`||e===`model`)&&this.flyEffectUseDepthBuffer){if(((l=this.modelScene.parameter.pano0Depth)==null?void 0:l.panoId)!==t.panoId||((u=this.modelScene.parameter.pano1Depth)==null?void 0:u.panoId)!==n.panoId){let e=500,r=512;this.pano0DepthCubeRenderTarget?this.pano0DepthCubeRenderTarget.width!==512&&this.pano0DepthCubeRenderTarget.setSize(512,512):this.pano0DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1}),this.pano1DepthCubeRenderTarget?this.pano1DepthCubeRenderTarget.width!==512&&this.pano1DepthCubeRenderTarget.setSize(512,512):this.pano1DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1});let o=new three.CubeCamera(this.camera.near,this.camera.far,this.pano0DepthCubeRenderTarget);o.matrix.copy(t.matrix),o.matrixWorld.copy(o.matrix),o.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,o,500);let s=new three.CubeCamera(this.camera.near,this.camera.far,this.pano1DepthCubeRenderTarget);s.matrix.copy(n.matrix),s.matrixWorld.copy(s.matrix),s.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,s,500),this.modelScene.parameter.set({pano0Depth:{panoId:t.panoId,map:this.pano0DepthCubeRenderTarget.texture,mapSize:this.pano0DepthCubeRenderTarget.width,maxDepth:500},pano1Depth:{panoId:n.panoId,map:this.pano1DepthCubeRenderTarget.texture,mapSize:this.pano1DepthCubeRenderTarget.width,maxDepth:500}})}}else this.modelScene.parameter.set({pano0Depth:null,pano1Depth:null}),this.flyEffectUseDepthBuffer||(this.pano0DepthCubeRenderTarget&&(this.pano0DepthCubeRenderTarget.dispose(),this.pano0DepthCubeRenderTarget=void 0),this.pano1DepthCubeRenderTarget&&(this.pano1DepthCubeRenderTarget.dispose(),this.pano1DepthCubeRenderTarget=void 0))}}getTargetState(){let e=this.cameraMotion.getKeyFrameSegment(now())[1],t=this.locationMotion.getKeyFrameSegment(now())[1],n=this.panoResourceFromLocationMotionKeyframe(t),r=this.works.getObserver(n.panoId);return{workCode:r?r.work.workCode:this.currentPano.workCode,panoIndex:r?r.panoIndex:this.currentPano.panoIndex,mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:r?r.position.clone().applyMatrix4(r.work.transform):this.camera.position.clone(),distance:this.locationMotion.value.distance}}moveToPano(e,t,n){var r,o,s;let c=(r=t.effect)==null?`fly`:r;this.userAction=n,this.stopMomentumMovement();let l=panoStringify(e),u=this.works.getObserver(e);if(!u)throw Error(`Invalid PanoId ${JSON.stringify(e)}`);let d=getImageSizeFromURL(u.images.up),f=this.imageOptions.size;f===void 0&&u&&d&&(f=Number(d)),f===void 0&&(f=2048);let p=this.imageOptions.transform,m=Object.assign({key:`pano.${l}`},pick(this.imageOptions,[`format`,`size`,`quality`,`sharpen`,`forceUseExifOrientation`,`mappings`])),h={right:u.images.work.getURL(u.images.right),left:u.images.work.getURL(u.images.left),up:u.images.work.getURL(u.images.up),down:u.images.work.getURL(u.images.down),front:u.images.work.getURL(u.images.front),back:u.images.work.getURL(u.images.back)},g=`pano:`+jsonHash([h,m,p]);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===g)return;{let e=this.pendingTextureTask.panoId;(o=this.panoMeshes.get(e))==null||o.setProgress(0),this.emit(`pano.texture.abort`,createEvent(`pano.texture.abort`,{error:null,progress:0,meta:null,pano:{panoIndex:u.panoIndex,workCode:u.work.workCode}}))}}let _=`move-to-pano-`+l;this.pending.add(_);let v=this.modelScene.parameter,y;if(v.pano0&&v.pano0.map.name===g?y=v.pano0:v.pano1&&v.pano1.map.name===g&&(y=v.pano1),y){let n={panoId:l,effect:c,effectEasing:(s=t.effectEasing)==null?defaultEffectEase:s,panoPicture:{panoId:y.panoId,map:y.map,mapHistogram:y.mapHistogram,mapSize:y.mapSize,matrix:u.matrix.clone().premultiply(u.work.transform),zoom:1},position:u.position.clone().applyMatrix4(u.work.transform),fixCameraTransform:new three.Matrix4};n.panoPicture&&this.panoPictureObserverMap.set(n.panoPicture,u),this.pendingTextureTask=void 0,AnimationFrameLoop.shared.add(()=>{this.pending.delete(_),this.doMoveToPano(e,n,t)},!0,1);return}this.pendingTextureTask={panoId:l,hash:g,onLoad:n=>{var r,o;let s=n.body;if(this.destroyed)s.dispose();else{s.name=g;let n=Array.isArray(s.image)?s.image[0]:s.image,d=(r=n==null?void 0:n.width)==null?2048:r,f=new Histogram().formPixels(getRgbaDataFromCubeTexture(this.renderer,s,!0,sharedHistogramRgbaData).data),p={panoId:l,effect:c,effectEasing:(o=t.effectEasing)==null?defaultEffectEase:o,panoPicture:{panoId:l,map:s,mapSize:d,mapHistogram:new three.Vector4().fromArray(f.toArray()),matrix:u.matrix.clone().premultiply(u.work.transform),zoom:1},position:u.position.clone().applyMatrix4(u.work.transform),fixCameraTransform:new three.Matrix4};p.panoPicture&&this.panoPictureObserverMap.set(p.panoPicture,u),this.doMoveToPano(e,p,t)}},onError:n=>{let r=Object.assign(Object.assign(Object.assign({},e),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`pano.error`,createEvent(`pano.error`,{error:n,userAction:this.userAction,options:t,prevPano:this.currentPano,progress:0,state:r})),this.emit(`pano.cancel`,createEvent(`pano.cancel`,{error:n,userAction:this.userAction,options:t,prevPano:this.currentPano,progress:0,state:r})),this.emit(`error`,n),t.moveCancelCallback&&t.moveCancelCallback()}};let b=this.panoMeshes.get(l);b&&b.tap&&b.tap(),this.textureLoader.loadCubeTexture(h,{imageURL:{transform:p,options:m},format:three.RGBFormat,viaAjax:!0,fetcher:getFetcher(this.fiveId,u.work)},void 0,void 0,t=>{var n,r;this.emit(`pano.texture.progress`,createEvent(`pano.texture.progress`,{error:null,progress:t,meta:null,pano:e})),((n=this.pendingTextureTask)==null?void 0:n.hash)===g&&((r=this.panoMeshes.get(l))==null||r.setProgress(t))},this.renderer).then(t=>{var n,r;this.pending.delete(_),((n=this.pendingTextureTask)==null?void 0:n.hash)===g?(this.pendingTextureTask.onLoad(t),this.pendingTextureTask=void 0,(r=this.panoMeshes.get(l))==null||r.setProgress(0)):t.body.dispose(),this.emit(`pano.texture.success`,createEvent(`pano.texture.success`,{error:null,progress:1,meta:t.meta,pano:e}))}).catch(t=>{var n,r;this.pending.delete(_),((n=this.pendingTextureTask)==null?void 0:n.hash)===g&&(this.pendingTextureTask.onError(t),this.pendingTextureTask=void 0,(r=this.panoMeshes.get(l))==null||r.setProgress(0)),this.emit(`pano.texture.error`,createEvent(`pano.texture.error`,{error:t,progress:0,meta:null,pano:e})),this.emit(`error`,t)}),this.emit(`pano.texture.load`,createEvent(`pano.texture.load`,{error:null,progress:0,meta:null,pano:e}))}initAnimation(){return this.destroyed?Promise.resolve():new Promise(t=>{let{duration:n,effect:r,userAction:o}=this.initial;this.userAction=o;let s=e.initAnimationEndState(this),c={workCode:s.workCode,panoIndex:s.panoIndex},l={modelAlpha:0},u={perspToOrtho:0},d=!1;this.moveToPano(c,{longitude:s.longitude,latitude:s.latitude,fov:s.fov,effect:r,duration:n,moveStartCallback:e=>{d=!0,this.perspToOrthoMotion.set(u,n).catch(noop),this.modelAlphaMotion.setKeyframes([{progress:0,value:Object.assign({},this.modelAlphaMotion.value)},{progress:.6,value:Object.assign({},this.modelAlphaMotion.value)},{progress:1,value:l}],n).catch(noop),this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:e,userAction:this.userAction}))},moveEndCallback:e=>{this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:e,userAction:this.userAction})),this.initAnimationed=!0,t()},moveCancelCallback:()=>{let e=Object.assign(Object.assign(Object.assign({},c),{mode:this.mode}),clonePose(this.camera.pose));d===!1&&this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:e,userAction:this.userAction})),this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:e,userAction:this.userAction})),this.initAnimationed=!0,t()}},o)})}panoResourceFromLocationMotionKeyframe(e){return this.panoResources[e.key]}locationMotionKeyframesLength(e){let t=0;for(let n=1;n<e.length;n++){let r=this.panoResourceFromLocationMotionKeyframe(e[n-1]).position,o=this.panoResourceFromLocationMotionKeyframe(e[n]).position,s=r.distanceTo(o)*(e[n].value.count-e[n-1].value.count);t+=s}return t}doMoveToPano(e,t,n={}){var r,o,s,c,l,u,d,f,p,m,h;let g=now(),_=createUuid();this.panoResources[_]=t;let v=1,y,b,S;if(this.locationMotion.ended){let[e,n]=this.locationMotion.getKeyFrameSegment(g),o=this.locationMotion.value,s=((r=this.panoResourceFromLocationMotionKeyframe(n))==null?this.camera:r).position,c=t.position;y=Math.max(s.distanceTo(c),1),b=[{key:n.key,progress:0,value:Object.assign(Object.assign({},o),{count:0})},{key:_,progress:1,value:{distance:0,count:1}}],S=0}else{let[e,n]=this.locationMotion.getKeyFrameSegment(g),r=this.locationMotion.value,o=this.panoResourceFromLocationMotionKeyframe(e).position,s=this.panoResourceFromLocationMotionKeyframe(n).position,c=t.position,l=n.value.count-r.count,u=Math.max(o.distanceTo(s),1)*l;y=u+Math.max(s.distanceTo(c),1),b=[{key:e.key,progress:0,value:Object.assign({},r)},{key:n.key,progress:u/y,value:n.value},{key:_,progress:1,value:{count:n.value.count+1,distance:0}}];let d=this.locationMotionKeyframesLength(this.locationMotion.keyframes),f=this.locationMotionKeyframesLength(b);S=d===0||d===0?0:this.locationMotion.getProgressVelocity(g)*d/f}let C=t.effect===`instant`?0:this.calculateMovingDuration(n.duration,t.effect===`fly`||t.effect===`model`?y:0),w={longitude:n.longitude,latitude:n.latitude,fov:n.fov},T=Object.assign(Object.assign({},e),{mode:this.mode,longitude:(o=w.longitude)==null?this.camera.pose.longitude:o,latitude:(s=w.latitude)==null?this.camera.pose.latitude:s,fov:(c=w.fov)==null?this.camera.pose.fov:c,offset:t.position.clone(),distance:this.camera.pose.distance}),E=this.currentPano;if(this.emit(`pano.moveTo`,createEvent(`pano.moveTo`,{options:n,prevPano:E,progress:0,state:T,userAction:this.userAction,error:null})),n.moveStartCallback&&n.moveStartCallback(T),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,this.videoTexture.needsUpdate=!0),this.panoVideo.setMaterial(null),t.effect===`fly`||t.effect===`model`)this.cameraMotion.set(w,C).catch(noop);else{let e=coordinatesToVector({longitude:this.cameraMotion.value.longitude,latitude:this.cameraMotion.value.latitude}),n=coordinatesToVector({longitude:(l=w.longitude)==null?this.cameraMotion.value.longitude:l,latitude:(u=w.latitude)==null?this.cameraMotion.value.latitude:u}),r=new three.Object3D;r.lookAt(e);let o=new three.Matrix4().makeRotationFromQuaternion(r.quaternion);r.lookAt(n);let s=new three.Matrix4().makeRotationFromQuaternion(r.quaternion),c=new three.Matrix4().getInverse(o).premultiply(s),g=this.cameraMotion.value.fov,_=(d=w.fov)==null?this.cameraMotion.value.fov:d,v=1;t.effect===`zoomin`?v=1.5:t.effect===`zoomout`&&(v=.4);let y=clamp$1(_*v,1,170);for(let e=0;e<b.length-1;e++){let t=b[e].key;if(t){let e=this.panoResources[t];e&&(e.fixCameraTransform.copy(c),e.panoPicture&&(e.panoPicture.zoom=Math.tan(y/2/180*Math.PI)/Math.tan(g/2/180*Math.PI)))}}this.cameraMotion.setKeyframes([{progress:0,value:{longitude:this.cameraMotion.value.longitude,latitude:this.cameraMotion.value.latitude,fov:this.cameraMotion.value.fov}},{progress:0,value:{longitude:(f=w.longitude)==null?this.cameraMotion.value.longitude:f,latitude:(p=w.latitude)==null?this.cameraMotion.value.latitude:p,fov:y}},{progress:1,value:{longitude:(m=w.longitude)==null?this.cameraMotion.value.longitude:m,latitude:(h=w.latitude)==null?this.cameraMotion.value.latitude:h,fov:_}}],C).catch(noop)}this.locationMotion.setKeyframes(b,C,S).then(()=>{for(let e of this.modelScene.children)e instanceof Model&&e.show();let t=Object.assign(Object.assign({},e),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance});this.emit(`pano.arrived`,createEvent(`pano.arrived`,{options:n,prevPano:E,progress:1,state:t,userAction:this.userAction,error:null})),n.moveEndCallback&&n.moveEndCallback(t);let r=this.works.getObserver(e);if(r&&r.images.video&&this.videoTexture&&this.videoTexture.image instanceof HTMLVideoElement){let e={map:this.videoTexture,size:r.images.video.size.clone(),matrix:r.images.video.matrix.clone(),panoMatrix:r.matrix.clone().premultiply(r.work.transform),alpha:1},t=createUuid(),n=this.videoTexture.image;n.setAttribute(`uuid`,t),n.oncanplay=noop,n.ontimeupdate=noop,canplayVideo().then(o=>{o&&r.images.video&&n.getAttribute(`uuid`)===t&&(n.oncanplay=()=>{n.oncanplay=noop,n.play()},n.ontimeupdate=()=>{n.currentTime>.5&&(n.ontimeupdate=noop,this.panoVideo.setMaterial(e))},n.src=r.images.video.source)}).catch((()=>{n.removeAttribute(`uuid`)}))}else{let e=this.videoTexture.image;e.removeAttribute(`uuid`),e.oncanplay=noop,e.ontimeupdate=noop}},()=>{this.emit(`pano.cancel`,createEvent(`pano.cancel`,{options:n,prevPano:E,progress:0,state:T,userAction:this.userAction,error:null})),n.moveCancelCallback&&n.moveCancelCallback()})}getForwardObserverOrNot(e,t){let n=this.works.getObserver(this.currentPano);if(!n)return null;let r=t==null?new three.Raycaster(e.position.clone(),e.getWorldDirection(new three.Vector3)):t;r.params.Points={threshold:.1},r.firstHitOnly=!0,r.floorIndex=-1;let o=n.standingPosition.clone().applyMatrix4(n.work.transform);if(n.position.clone().applyMatrix4(n.work.transform).distanceTo(r.ray.origin)>1){let e=new three.Raycaster(r.ray.origin,new three.Vector3(0,-1,0));e.firstHitOnly=r.firstHitOnly,e.floorIndex=r.floorIndex;let[t]=this.modelScene.intersectRaycaster(e);t&&t.distance<=2?o.copy(t.point):o.copy(r.ray.origin).add(new three.Vector3(0,-1.5,0))}let[s]=this.modelScene.intersectRaycaster(r),c=(s?s.point:r.ray.origin.clone().add(r.ray.direction.clone().normalize().multiplyScalar(3))).clone().sub(o).normalize();if(c.length()===0)return null;let l=n.work.observers,u=n.accessibleNodes.filter(t=>{if(t===this.currentPano.panoIndex&&n.work.workCode===this.currentPano.workCode)return!1;let r=l[t];if(!r)return!1;let o=r.standingPosition.clone().applyMatrix4(r.work.transform).project(e);return Math.abs(o.z)>1||Math.abs(o.x)>1||Math.abs(o.y)>1?!1:r.loadable||r.active}),d=new Map,f=u.slice().sort((e,t)=>{let n=l[e],r=d.get(n);r===void 0&&(r=scratchVector3$3.copy(n.standingPosition).applyMatrix4(n.work.transform).distanceTo(o),d.set(n,r));let s=l[t],c=d.get(s);return c===void 0&&(c=scratchVector3$3.copy(s.standingPosition).applyMatrix4(s.work.transform).distanceTo(o),d.set(s,c)),r-c});d.clear();for(let e of[Math.PI/8,Math.PI/6,Math.PI/4,Math.PI/3])for(let t of f){let n=l[t];if(n){let t=scratchVector3$3.copy(n.standingPosition).applyMatrix4(n.work.transform).sub(o);if(t&&t.length()!==0&&c.angleTo(t)<e)return n}}let p=null;if(t){let n=t.ray.intersectBox(this.modelScene.boundingBox,scratchVector3$3);n&&(n.project(e),Math.abs(n.z)<=1&&(p=n.clone()))}else p=new three.Vector3(0,0,0);if(p){let t=.4,r=n.accessibleNodes.filter(t=>{if(t===this.currentPano.panoIndex&&n.work.workCode===this.currentPano.workCode)return!1;let r=l[t];if(!r)return!1;let o=r.position.clone().applyMatrix4(r.work.transform).project(e);return Math.abs(o.z)>1||Math.abs(o.x)>1||Math.abs(o.y)>1?!1:r.loadable||r.active}),o=new Map,s=r.slice().sort((t,n)=>{let r=l[t],s=o.get(r);s===void 0&&(s=scratchVector3$3.copy(r.position).applyMatrix4(r.work.transform).distanceTo(e.position),o.set(r,s));let c=l[n],u=o.get(c);return u===void 0&&(u=scratchVector3$3.copy(c.position).applyMatrix4(c.work.transform).distanceTo(e.position),o.set(c,u)),s-u});o.clear();for(let t of s){let n=l[t];if(n){let t=scratchVector3$3.copy(n.position).applyMatrix4(n.work.transform);if(t.project(e),Math.abs(t.z)>1)continue;if(Math.pow(p.x-t.x,2)+Math.pow(p.y-t.y,2)<Math.pow(.4,2))return n}}}return null}onTapGesture(e){var t;if(this.userAction=e.userAction,this.stopMomentumMovement(),!this.initAnimationed)return;let n=e.center.raycaster;n.floorIndex=-1;let r=this.camera.getDirection(new three.Vector3).setY(0),o=null,s=this.works.getObserver(this.currentPano);if(!s)return;let c=s.work.observers,l=s.accessibleNodes.filter(e=>{if(e===this.currentPano.panoIndex&&s.work.workCode===this.currentPano.workCode)return!1;let t=c[e];return!t||scratchVector3$3.copy(t.position).applyMatrix4(t.work.transform).distanceTo(this.camera.position)>this.maxAccessibleDistance?!1:t.loadable||t.active}),[u]=this.modelScene.intersectRaycaster(n);if(u){let[e,n]=arrayMin(l,e=>{let t=c[e];return t?scratchVector3$3.copy(t.standingPosition).applyMatrix4(t.work.transform).distanceTo(u.point):1/0},!0);typeof e==`number`&&n<this.panoTapTriggerRadius&&(o=(t=c[e])==null?null:t)}if(o||(o=this.getForwardObserverOrNot(this.camera,n)),o&&o.panoId===panoStringify(this.currentPano)&&(o=null),o&&!this.locationMotion.ended){for(let e of this.locationMotion.keyframes)if(this.panoResourceFromLocationMotionKeyframe(e).panoId===o.panoId){o=null;break}}if(!o)this.emit(`gesture.tap`,e),e.defaultPrevented||this.locationMotion.ended===!0&&this.cameraBounce();else{let t={},n=Math.PI/6,c=Math.PI/12,l=o.position.clone().applyMatrix4(o.work.transform).setY(0).sub(s.position.clone().applyMatrix4(o.work.transform).setY(0)).normalize(),u=[],d=[],f=[],p=o.work.observers;for(let e of o.accessibleNodes){if(o.panoIndex===e||e===this.currentPano.panoIndex&&o.work.workCode===this.currentPano.workCode)continue;let t=p[e];if(!t)continue;let r=t.position.clone().applyMatrix4(t.work.transform).sub(o.position.clone().applyMatrix4(o.work.transform)).setY(0).normalize();l.angleTo(r)<n&&f.push(r)}let[m]=(f.length>0?f:[...u,...d]).slice().sort((e,t)=>e.angleTo(l)-t.angleTo(l));if(m&&m.angleTo(r)>c&&(t.longitude=Math.atan2(-m.x,-m.z)),this.cameraMotion.value.latitude<-Math.PI/4){let n=e.state.fov;t.latitude=clamp$1(0,clamp$1(typeof this.minLatitude==`function`?this.minLatitude(n):this.minLatitude,-Math.PI/2,Math.PI/2),clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(n):this.maxLatitude,-Math.PI/2,Math.PI/2))}let h=Object.assign({},e.state);if(h.workCode=o.work.workCode,h.panoIndex=o.panoIndex,t.longitude!==void 0&&(h.longitude=t.longitude),t.latitude!==void 0&&(h.latitude=t.latitude),t.fov!==void 0&&(h.fov=t.fov),h.distance=0,h.offset=o.position.clone(),e.state=h,this.emit(`gesture.tap`,e),!e.defaultPrevented){if(this.emit(`pano.select`,createEvent(`pano.select`,{prevPano:this.currentPano,state:h,userAction:e.userAction,options:t,progress:0,error:null})),o&&!o.active){let e=panoStringify({panoIndex:o.panoIndex,workCode:o.work.workCode}),t=this.panoMeshes.get(e);t&&(t.setDisabled(!1),t.setLoading(!0))}o&&o.active&&this.emit(`pano.request`,createEvent(`pano.request`,{userAction:e.userAction,prevPano:this.currentPano,progress:0,state:h,options:t,error:null}))}}}},DEG_TO_RAD=Math.PI/180,RAD_TO_DEG=180/Math.PI,MIN_TIMESTEP=.001,MAX_TIMESTEP=1,isIOS=(()=>{let e=typeof navigator<`u`&&/iPad|iPhone|iPod/.test(navigator.platform);return()=>e})(),isSafari=(()=>{let e=typeof navigator<`u`&&/^((?!chrome|android).)*safari/i.test(navigator.userAgent);return()=>e})(),isFirefoxAndroid=(()=>{let e=typeof navigator<`u`&&navigator.userAgent.indexOf(`Firefox`)!==-1&&navigator.userAgent.indexOf(`Android`)!==-1;return()=>e})(),getChromeVersion=(()=>{let e=typeof navigator<`u`?navigator.userAgent.match(/.*Chrome\/([0-9]+)/):null,t=e?parseInt(e[1],10):null;return()=>t})(),isChromeWithoutDeviceMotion=(()=>{let e=!1;if(getChromeVersion()===65){let t=typeof navigator<`u`?navigator.userAgent.match(/.*Chrome\/([0-9\.]*)/):null;if(t){let[n,r,o,s]=t[1].split(`.`);e=parseInt(o,10)===3325&&parseInt(s,10)<148}}return()=>e})(),isSafariWithoutDeviceMotion=(()=>{let e=isIOS()&&isSafari()&&typeof navigator<`u`&&navigator.userAgent.indexOf(`13_4`)!==-1;return()=>e})(),isR7=(()=>{let e=typeof navigator<`u`&&navigator.userAgent.indexOf(`R7 Build`)!==-1;return()=>e})();function isLandscapeMode(){let e=typeof window<`u`&&(window.orientation==90||window.orientation==-90);return isR7()?!e:e}function isTimestampDeltaValid(e){return!(isNaN(e)||e<=MIN_TIMESTEP||e>MAX_TIMESTEP)}function getQuaternionAngle(e){return e.w>1?0:2*Math.acos(e.w)}var warnOnce=(()=>{let e={};return(t,n)=>{e[t]===void 0&&(console.warn(`cardboard: `+n),e[t]=!0)}})();function getOriginFromUrl(e){let t,n=e.indexOf(`://`);t=n===-1?0:n+3;let r=e.indexOf(`/`,t);return r===-1&&(r=e.length),e.substring(0,r)}function isInsideCrossOriginIFrame(){if(typeof window>`u`||typeof document>`u`)return!1;let e=window.self!==window.top,t=getOriginFromUrl(document.referrer),n=getOriginFromUrl(window.location.href);return e&&t!==n}var updateEyeViewMatrices=(()=>{function e(e,t,n){let r=t?t[0]:0,o=t?t[1]:0,s=t?t[2]:0,c=t?t[3]:1,l=r+r,u=o+o,d=s+s,f=r*l,p=r*u,m=r*d,h=o*u,g=o*d,_=s*d,v=c*l,y=c*u,b=c*d;return e[0]=1-(h+_),e[1]=p+b,e[2]=m-y,e[3]=0,e[4]=p-b,e[5]=1-(f+_),e[6]=g+v,e[7]=0,e[8]=m+y,e[9]=g-v,e[10]=1-(f+h),e[11]=0,e[12]=n?n[0]:0,e[13]=n?n[1]:0,e[14]=n?n[2]:0,e[15]=1,e}function t(e,t,n){let r=n[0],o=n[1],s=n[2],c,l,u,d,f,p,m,h,g,_,v,y;return t===e?(e[12]=t[0]*r+t[4]*o+t[8]*s+t[12],e[13]=t[1]*r+t[5]*o+t[9]*s+t[13],e[14]=t[2]*r+t[6]*o+t[10]*s+t[14],e[15]=t[3]*r+t[7]*o+t[11]*s+t[15]):(c=t[0],l=t[1],u=t[2],d=t[3],f=t[4],p=t[5],m=t[6],h=t[7],g=t[8],_=t[9],v=t[10],y=t[11],e[0]=c,e[1]=l,e[2]=u,e[3]=d,e[4]=f,e[5]=p,e[6]=m,e[7]=h,e[8]=g,e[9]=_,e[10]=v,e[11]=y,e[12]=c*r+f*o+g*s+t[12],e[13]=l*r+p*o+_*s+t[13],e[14]=u*r+m*o+v*s+t[14],e[15]=d*r+h*o+y*s+t[15]),e}function n(e,t){let n=t[0],r=t[1],o=t[2],s=t[3],c=t[4],l=t[5],u=t[6],d=t[7],f=t[8],p=t[9],m=t[10],h=t[11],g=t[12],_=t[13],v=t[14],y=t[15],b=n*l-r*c,S=n*u-o*c,C=n*d-s*c,w=r*u-o*l,T=r*d-s*l,E=o*d-s*u,D=f*_-p*g,O=f*v-m*g,k=f*y-h*g,A=p*v-m*_,j=p*y-h*_,M=m*y-h*v,N=b*M-S*j+C*A+w*k-T*O+E*D;return N?(N=1/N,e[0]=(l*M-u*j+d*A)*N,e[1]=(o*j-r*M-s*A)*N,e[2]=(_*E-v*T+y*w)*N,e[3]=(m*T-p*E-h*w)*N,e[4]=(u*k-c*M-d*O)*N,e[5]=(n*M-o*k+s*O)*N,e[6]=(v*C-g*E-y*S)*N,e[7]=(f*E-m*C+h*S)*N,e[8]=(c*j-l*k+d*D)*N,e[9]=(r*k-n*j-s*D)*N,e[10]=(g*T-_*C+y*b)*N,e[11]=(p*C-f*T-h*b)*N,e[12]=(l*O-c*A-u*D)*N,e[13]=(n*A-r*O+o*D)*N,e[14]=(_*S-g*w-v*b)*N,e[15]=(f*w-p*S+m*b)*N,e):null}return(r,o,s)=>{e(r,o),s&&t(r,r,s),n(r,r)}})(),SensorSample=class{constructor(e=new three.Vector3,t=0){this.sample=e,this.timestampS=t}set(e,t){this.sample=e,this.timestampS=t}copy(e){this.set(e.sample,e.timestampS)}},ComplementaryFilter=class{constructor(e,t){this.kFilter=e,this.isDebug=t,this.currentAccelMeasurement=new SensorSample,this.currentGyroMeasurement=new SensorSample,this.previousGyroMeasurement=new SensorSample,isIOS()?this.filterQ=new three.Quaternion(-1,0,0,1):this.filterQ=new three.Quaternion(1,0,0,1),this.previousFilterQ=new three.Quaternion,this.previousFilterQ.copy(this.filterQ),this.accelQ=new three.Quaternion,this.isOrientationInitialized=!1,this.estimatedGravity=new three.Vector3,this.measuredGravity=new three.Vector3,this.gyroIntegralQ=new three.Quaternion}addAccelMeasurement(e,t){this.currentAccelMeasurement.set(e,t)}addGyroMeasurement(e,t){this.currentGyroMeasurement.set(e,t),isTimestampDeltaValid(t-this.previousGyroMeasurement.timestampS)&&this.run_(),this.previousGyroMeasurement.copy(this.currentGyroMeasurement)}getOrientation(){return this.filterQ}run_(){if(!this.isOrientationInitialized){this.accelQ=this.accelToQuaternion_(this.currentAccelMeasurement.sample),this.previousFilterQ.copy(this.accelQ),this.isOrientationInitialized=!0;return}let e=this.currentGyroMeasurement.timestampS-this.previousGyroMeasurement.timestampS,t=this.gyroToQuaternionDelta_(this.currentGyroMeasurement.sample,e);this.gyroIntegralQ.multiply(t),this.filterQ.copy(this.previousFilterQ),this.filterQ.multiply(t);let n=new three.Quaternion;n.copy(this.filterQ),n.inverse(),this.estimatedGravity.set(0,0,-1),this.estimatedGravity.applyQuaternion(n),this.estimatedGravity.normalize(),this.measuredGravity.copy(this.currentAccelMeasurement.sample),this.measuredGravity.normalize();let r=new three.Quaternion;r.setFromUnitVectors(this.estimatedGravity,this.measuredGravity),r.inverse(),this.isDebug&&console.log(`Delta: %d deg, G_est: (%s, %s, %s), G_meas: (%s, %s, %s)`,RAD_TO_DEG*getQuaternionAngle(r),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));let o=new three.Quaternion;o.copy(this.filterQ),o.multiply(r),this.filterQ.slerp(o,1-this.kFilter),this.previousFilterQ.copy(this.filterQ)}accelToQuaternion_(e){let t=new three.Vector3;t.copy(e),t.normalize();let n=new three.Quaternion;return n.setFromUnitVectors(new three.Vector3(0,0,-1),t),n.inverse(),n}gyroToQuaternionDelta_(e,t){let n=new three.Quaternion,r=new three.Vector3;return r.copy(e),r.normalize(),n.setFromAxisAngle(r,e.length()*t),n}},PosePredictor=class{constructor(e,t){this.predictionTimeS=e,this.isDebug=t,this.previousQ=new three.Quaternion,this.previousTimestampS=null,this.deltaQ=new three.Quaternion,this.outQ=new three.Quaternion}getPrediction(e,t,n){if(!this.previousTimestampS)return this.previousQ.copy(e),this.previousTimestampS=n,e;let r=new three.Vector3;r.copy(t),r.normalize();let o=t.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(e),this.previousQ.copy(e),this.outQ;let s=o*this.predictionTimeS;return this.deltaQ.setFromAxisAngle(r,s),this.outQ.copy(this.previousQ),this.outQ.multiply(this.deltaQ),this.previousQ.copy(e),this.previousTimestampS=n,this.outQ}},Distortion=class{constructor(e){this.coefficients=e}distortInverse(e){let t=0,n=1,r=e-this.distort(t);for(;Math.abs(n-t)>1e-4;){let o=e-this.distort(n),s=n-o*((n-t)/(o-r));t=n,n=s,r=o}return n}distort(e){let t=e*e,n=0;for(let e=0;e<this.coefficients.length;e++)n=t*(n+this.coefficients[e]);return(n+1)*e}},Pose=class{constructor(){this.angularAcceleration=null,this.angularVelocity=null,this.linearAcceleration=null,this.linearVelocity=null,this.orientation=null,this.position=null}},FieldOfView=class{constructor(){this.leftDegrees=0,this.rightDegrees=0,this.upDegrees=0,this.downDegrees=0}},Sensor=class{constructor(e,t,n,r){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=n,this.accelerometer=new three.Vector3,this.gyroscope=new three.Vector3,this.filter=new ComplementaryFilter(e,r),this.posePredictor=new PosePredictor(t,r),this.isFirefoxAndroid=isFirefoxAndroid(),this.isIOS=isIOS();let o=getChromeVersion();this.isDeviceMotionInRadians=!this.isIOS&&o!==null&&o<66,this.isWithoutDeviceMotion=isChromeWithoutDeviceMotion()||isSafariWithoutDeviceMotion(),this.filterToWorldQ=new three.Quaternion,isIOS()?this.filterToWorldQ.setFromAxisAngle(new three.Vector3(1,0,0),Math.PI/2):this.filterToWorldQ.setFromAxisAngle(new three.Vector3(1,0,0),-Math.PI/2),this.inverseWorldToScreenQ=new three.Quaternion,this.worldToScreenQ=new three.Quaternion,this.originalPoseAdjustQ=new three.Quaternion;let s=typeof window<`u`?-window.orientation*Math.PI/180:0;this.originalPoseAdjustQ.setFromAxisAngle(new three.Vector3(0,0,1),s),this.setScreenTransform_(),isLandscapeMode()&&this.filterToWorldQ.multiply(this.inverseWorldToScreenQ),this.resetQ=new three.Quaternion,this.orientationOut_=new Float32Array(4),this.previousTimestampS=Date.now()}getPosition(){return null}getOrientation(){let e;if(this.isWithoutDeviceMotion&&this._deviceOrientationQ){this.deviceOrientationFixQ=this.deviceOrientationFixQ||(function(){let e=new three.Quaternion().setFromAxisAngle(new three.Vector3(0,0,-1),0),t=new three.Quaternion;return typeof window<`u`&&window.orientation===-90?t.setFromAxisAngle(new three.Vector3(0,1,0),Math.PI/-2):t.setFromAxisAngle(new three.Vector3(0,1,0),Math.PI/2),e.multiply(t)})(),this.deviceOrientationFilterToWorldQ=this.deviceOrientationFilterToWorldQ||(function(){let e=new three.Quaternion;return e.setFromAxisAngle(new three.Vector3(1,0,0),-Math.PI/2),e})(),e=this._deviceOrientationQ;let t=new three.Quaternion;return t.copy(e),t.multiply(this.deviceOrientationFilterToWorldQ),t.multiply(this.resetQ),t.multiply(this.worldToScreenQ),t.multiplyQuaternions(this.deviceOrientationFixQ,t),this.yawOnly&&(t.x=0,t.z=0,t.normalize()),this.orientationOut_[0]=t.x,this.orientationOut_[1]=t.y,this.orientationOut_[2]=t.z,this.orientationOut_[3]=t.w,this.orientationOut_}else{let t=this.filter.getOrientation();e=this.posePredictor.getPrediction(t,this.gyroscope,this.previousTimestampS)}let t=new three.Quaternion;return t.copy(this.filterToWorldQ),t.multiply(this.resetQ),t.multiply(e),t.multiply(this.worldToScreenQ),this.yawOnly&&(t.x=0,t.z=0,t.normalize()),this.orientationOut_[0]=t.x,this.orientationOut_[1]=t.y,this.orientationOut_[2]=t.z,this.orientationOut_[3]=t.w,this.orientationOut_}getPose(){let e=new Pose;return e.orientation=this.getOrientation(),e}resetPose(){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)}getFrameData(e){let t=this.getOrientation(),n=this.getEyeOffset(),r=this.getEyeProjectionMatrix();return e.pose.angularAcceleration=null,e.pose.angularVelocity=null,e.pose.linearAcceleration=null,e.pose.linearVelocity=null,e.pose.orientation=t,e.pose.position=null,e.timestamp=this.previousTimestampS,e.leftProjectionMatrix.set(r.left),e.rightProjectionMatrix.set(r.right),updateEyeViewMatrices(e.leftViewMatrix,t,n.left),updateEyeViewMatrices(e.rightViewMatrix,t,n.right),e}start(){if(typeof window>`u`)return()=>{};let e=this.onDeviceMotion_.bind(this),t=this.onOrientationChange_.bind(this),n=this.onMessage_.bind(this),r=this.onDeviceOrientation_.bind(this);return isIOS()&&isInsideCrossOriginIFrame()&&window.addEventListener(`message`,n),window.addEventListener(`orientationchange`,t),this.isWithoutDeviceMotion?window.addEventListener(`deviceorientation`,r):window.addEventListener(`devicemotion`,e),()=>{window.removeEventListener(`devicemotion`,e),window.removeEventListener(`deviceorientation`,t),window.removeEventListener(`orientationchange`,t),window.removeEventListener(`message`,n)}}getEyeOffset(){return{left:[-this.viewer.interLensDistance*.5,0,0],right:[this.viewer.interLensDistance*.5,0,0]}}getEyeProjectionMatrix(){let e=this.getEyeFieldOfView(),t=this.depthNear,n=this.depthFar,r={left:[],right:[]};{let o=e.left.upDegrees*DEG_TO_RAD,s=e.left.downDegrees*DEG_TO_RAD,c=e.left.leftDegrees*DEG_TO_RAD,l=e.left.rightDegrees*DEG_TO_RAD,u=2/(c+l),d=2/(o+s);r.left[0]=u,r.left[1]=0,r.left[2]=0,r.left[3]=0,r.left[4]=0,r.left[5]=d,r.left[6]=0,r.left[7]=0,r.left[8]=-((c-l)*u*.5),r.left[9]=(o-s)*d*.5,r.left[10]=n/(t-n),r.left[11]=-1,r.left[12]=0,r.left[13]=0,r.left[14]=n*t/(t-n),r.left[15]=0}{let o=e.right.upDegrees*DEG_TO_RAD,s=e.right.downDegrees*DEG_TO_RAD,c=e.right.leftDegrees*DEG_TO_RAD,l=e.right.rightDegrees*DEG_TO_RAD,u=2/(c+l),d=2/(o+s);r.right[0]=u,r.right[1]=0,r.right[2]=0,r.right[3]=0,r.right[4]=0,r.right[5]=d,r.right[6]=0,r.right[7]=0,r.right[8]=-((c-l)*u*.5),r.right[9]=(o-s)*d*.5,r.right[10]=n/(t-n),r.right[11]=-1,r.right[12]=0,r.right[13]=0,r.right[14]=n*t/(t-n),r.right[15]=0}return r}getEyeFieldOfView(){let e=this.viewer,t=this.device,n=new Distortion(e.distortionCoefficients),r=e.screenLensDistance,o=(t.widthMeters-e.interLensDistance)/2,s=e.interLensDistance/2,c=e.baselineLensDistance-t.bevelMeters,l=t.heightMeters-c,u=RAD_TO_DEG*Math.atan(n.distort(o/r)),d=RAD_TO_DEG*Math.atan(n.distort(s/r)),f=RAD_TO_DEG*Math.atan(n.distort(c/r)),p=RAD_TO_DEG*Math.atan(n.distort(l/r)),m=new FieldOfView,h=new FieldOfView;return m.leftDegrees=Math.min(u,e.fov),m.rightDegrees=Math.min(d,e.fov),m.downDegrees=Math.min(f,e.fov),m.upDegrees=Math.min(p,e.fov),h.leftDegrees=m.rightDegrees,h.rightDegrees=m.leftDegrees,h.upDegrees=m.upDegrees,h.downDegrees=m.downDegrees,{left:m,right:h}}onDeviceOrientation_(e){this._deviceOrientationQ=this._deviceOrientationQ||new three.Quaternion;let{alpha:t,beta:n,gamma:r}=e;t=(t||0)*Math.PI/180,n=(n||0)*Math.PI/180,r=(r||0)*Math.PI/180,this._deviceOrientationQ.setFromEuler(new three.Euler(t,n,-r,`YXZ`))}onDeviceMotion_(e){this.updateDeviceMotion_(e)}updateDeviceMotion_(e){let t=e.accelerationIncludingGravity,n=e.rotationRate,r=e.timeStamp/1e3,o=r-this.previousTimestampS;if(o<0){warnOnce(`fusion-pose-sensor:invalid:non-monotonic`,`Invalid timestamps detected: non-monotonic timestamp from devicemotion`),this.previousTimestampS=r;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=r;return}t&&(this.accelerometer.set(-t.x,-t.y,-t.z),n&&(isR7()?this.gyroscope.set(-n.beta,n.alpha,n.gamma):this.gyroscope.set(n.alpha,n.beta,n.gamma),this.isDeviceMotionInRadians||this.gyroscope.multiplyScalar(Math.PI/180),this.filter.addGyroMeasurement(this.gyroscope,r)),this.filter.addAccelMeasurement(this.accelerometer,r)),this.previousTimestampS=r}onOrientationChange_(){this.setScreenTransform_()}onMessage_(e){let t=e.data;!t||!t.type||t.type.toLowerCase()===`devicemotion`&&this.updateDeviceMotion_(t.deviceMotionEvent)}setScreenTransform_(){switch(this.worldToScreenQ.set(0,0,0,1),typeof window<`u`?window.orientation:0){case 0:break;case 90:this.worldToScreenQ.setFromAxisAngle(new three.Vector3(0,0,1),-Math.PI/2);break;case-90:this.worldToScreenQ.setFromAxisAngle(new three.Vector3(0,0,1),Math.PI/2);break;case 180:break}this.inverseWorldToScreenQ.copy(this.worldToScreenQ),this.inverseWorldToScreenQ.inverse()}},defaultLeftBounds=[0,0,.5,1],defaultRightBounds=[.5,0,.5,1],Cardboard=class{constructor(e){this.renderer=e,this.sensor=new Sensor(.98,.04,!1,!1),this.scale=1,this.cameraL=new three.PerspectiveCamera,this.cameraR=new three.PerspectiveCamera;let t=this.sensor.start();this.dispose=()=>{let e=this.renderer.getSize(new three.Vector2);this.renderer.setScissor(0,0,e.width,e.height),this.renderer.setViewport(0,0,e.width,e.height),this.renderer.setScissorTest(!1),t()}}render(e,t){let n=this.renderer.getSize(new three.Vector2);if(n.width>n.height){var r=e.autoUpdate;r&&(e.updateMatrixWorld(),e.autoUpdate=!1);let o={x:Math.round(n.width*defaultLeftBounds[0]),y:Math.round(n.height*defaultLeftBounds[1]),width:Math.round(n.width*defaultLeftBounds[2]),height:Math.round(n.height*defaultLeftBounds[3])},s={x:Math.round(n.width*defaultRightBounds[0]),y:Math.round(n.height*defaultRightBounds[1]),width:Math.round(n.width*defaultRightBounds[2]),height:Math.round(n.height*defaultRightBounds[3])};this.renderer.setScissorTest(!0),this.renderer.autoClear&&this.renderer.clear(),t.parent===null&&t.updateMatrixWorld(),t.matrixWorld.decompose(this.cameraL.position,this.cameraL.quaternion,this.cameraL.scale),t.matrixWorld.decompose(this.cameraR.position,this.cameraR.quaternion,this.cameraR.scale);let c=this.sensor.getEyeOffset();this.cameraL.translateOnAxis(new three.Vector3().fromArray(c.left),this.scale),this.cameraR.translateOnAxis(new three.Vector3().fromArray(c.right),this.scale);let 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(e,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(e,this.cameraR),this.renderer.setViewport(0,0,n.width,n.height),this.renderer.setScissor(0,0,n.width,n.height),this.renderer.setScissorTest(!1),r&&(e.autoUpdate=!0)}else this.renderer.render(e,t)}dispose(){}},cardboard_png_data_url_default=`data:image/png;base64,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`,phone_png_data_url_default=`data:image/png;base64,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`,_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?LOCALE.zh:_a:LOCALE.zh,CONTENTS=`
1679
+ `,uniforms:{maxDepth:new three.Uniform(0)}});function renderDepthCube(e,t,n,r=1e3){depthMaterial.uniforms.maxDepth.value=r,scratchPrevClearColor.copy(e.getClearColor());let o=e.getClearAlpha(),s=t.overrideMaterial;t.overrideMaterial=depthMaterial,e.setClearColor(clearColor,0),n.update(e,t),e.setClearColor(scratchPrevClearColor,o),t.overrideMaterial=s}var defaultEffectEase=linear,scratchRaycaster$1=new three.Raycaster,scratchVector3$3=new three.Vector3,adjustPanoCircleMeshVectors=[new three.Vector3(0,0,0).multiplyScalar(.1),new three.Vector3(1,0,0).multiplyScalar(.1),new three.Vector3(-.5,0,-Math.sqrt(3)/2).multiplyScalar(.1),new three.Vector3(-.5,0,Math.sqrt(3)/2).multiplyScalar(.1)],defaultPanoramaControllerCustomInitArgs=Object.assign(Object.assign({},defaultPanoramaLikeControllerCustomInitArgs),{maxAccessibleDistance:5,panoTapTriggerRadius:.5,panoCircleMeshCreator:(e,t)=>e.position.distanceTo(e.standingPosition)>t.aerialObserverMinHeight?new PanoCircleMeshSolid:new PanoCircleMesh,adjustPanoCircleMeshPositionBasedOnModel:!1,tileLevelForFov:((e,t)=>{var n;let r=e=>e/180*Math.PI,o=(n=Math.log2)==null?(e=>Math.log(e)*Math.LOG2E):n,s=t.height/2/Math.tan(r(e/2))*Math.tan(r(45))*2,c=Math.max(o(s/512),0);return c<2.3&&c>.1&&(c=1),c=c%1>.75?Math.ceil(c):Math.floor(c),c}),tileAppearDuration:.5,tileMaxRequest:3,flyEffectUseDepthBuffer:!1}),PanoramaController=class e extends PanoramaLikeController{static parseArgs(t){var n,r,o,s,c,l,u,d;if(t instanceof e)return t;let f=super.parseArgs(t);return Object.assign(Object.assign({},f),{maxAccessibleDistance:(n=t.maxAccessibleDistance)==null?defaultPanoramaControllerCustomInitArgs.maxAccessibleDistance:n,panoTapTriggerRadius:(r=t.panoTapTriggerRadius)==null?defaultPanoramaControllerCustomInitArgs.panoTapTriggerRadius:r,panoCircleMeshCreator:(o=t.panoCircleMeshCreator)==null?defaultPanoramaControllerCustomInitArgs.panoCircleMeshCreator:o,adjustPanoCircleMeshPositionBasedOnModel:(s=t.adjustPanoCircleMeshPositionBasedOnModel)==null?defaultPanoramaControllerCustomInitArgs.adjustPanoCircleMeshPositionBasedOnModel:s,tileLevelForFov:(c=t.tileLevelForFov)==null?defaultPanoramaControllerCustomInitArgs.tileLevelForFov:c,tileAppearDuration:(l=t.tileAppearDuration)==null?defaultPanoramaControllerCustomInitArgs.tileAppearDuration:l,tileMaxRequest:(u=t.tileMaxRequest)==null?defaultPanoramaControllerCustomInitArgs.tileMaxRequest:u,flyEffectUseDepthBuffer:(d=t.flyEffectUseDepthBuffer)==null?defaultPanoramaControllerCustomInitArgs.flyEffectUseDepthBuffer:d})}static initAnimationEndState(e){let t=this.parseArgs(e),n=super.initAnimationEndState(t);return Object.assign(Object.assign({},n),{mode:`Panorama`})}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`Panorama`,this.initAnimationed=!1,this.maxAccessibleDistance=n.maxAccessibleDistance,this.panoTapTriggerRadius=n.panoTapTriggerRadius,this.panoCircleMeshCreator=n.panoCircleMeshCreator,this.adjustPanoCircleMeshPositionBasedOnModel=n.adjustPanoCircleMeshPositionBasedOnModel,this.tileLevelForFov=n.tileLevelForFov,this.tileAppearDuration=n.tileAppearDuration,this.tileMaxRequest=n.tileMaxRequest,this.flyEffectUseDepthBuffer=n.flyEffectUseDepthBuffer,this.adjustPanoCircleMeshPositionFix=new Map;let r=this.modelScene.parameter.resolveValue(`pano0`),o=this.modelScene.parameter.resolveValue(`pano1`);r&&(o==null?void 0:o.map)!==r.map&&(this.modelScene.parameter.set({pano0:o}),r.map.dispose());let s=new Set;r&&s.add(r),o&&s.add(o),this.panoMeshes=new Map,this.locationMotion=new Motion({count:0,distance:this.camera.pose.distance}),this.modelAlphaMotion=new Motion({modelAlpha:this.modelScene.parameter.resolveValue(`modelAlpha`)}),this.perspToOrthoMotion=new Motion({perspToOrtho:this.camera.perspToOrtho.x}),this.panoResources={},this.panoResources[this.locationMotion.keyframes[0].key=this.locationMotion.keyframes[1].key=createUuid()]={panoId:panoStringify(this.currentPano),panoPicture:this.modelScene.parameter.resolveValue(`pano1`),position:this.camera.pose.offset.clone(),effect:`fly`,effectEasing:defaultEffectEase,fixCameraTransform:new three.Matrix4},this.panoPictureObserverMap=new WeakMap,this.textureLoader=new TextureLoader,this.tiling=new Tiling({fiveId:this.fiveId}),this.panoVideo=new PanoVideo,this.scene.add(this.panoVideo.object),this.accessibleObserverFloorCheckCount=0}get tileLevel(){return this.tiling.level}updateConfiguration(e){return super.updateConfiguration(e)===!1?!1:(e.maxAccessibleDistance!==void 0&&this.maxAccessibleDistance!==e.maxAccessibleDistance&&(this.maxAccessibleDistance=e.maxAccessibleDistance),e.panoTapTriggerRadius!==void 0&&this.panoTapTriggerRadius!==e.panoTapTriggerRadius&&(this.panoTapTriggerRadius=e.panoTapTriggerRadius),e.panoCircleMeshCreator!==void 0&&this.panoCircleMeshCreator!==e.panoCircleMeshCreator&&(this.panoCircleMeshCreator=e.panoCircleMeshCreator,this.panoMeshes&&(this.panoMeshes.forEach(e=>{this.helper.remove(e),e.dispose()}),this.panoMeshes.clear())),e.tileLevelForFov!==void 0&&this.tileLevelForFov!==e.tileLevelForFov&&(this.tileLevelForFov=e.tileLevelForFov),e.tileMaxRequest!==void 0&&this.tileMaxRequest!==e.tileMaxRequest&&(this.tileMaxRequest=e.tileMaxRequest),e.flyEffectUseDepthBuffer!==void 0&&this.flyEffectUseDepthBuffer!==e.flyEffectUseDepthBuffer&&(this.flyEffectUseDepthBuffer=e.flyEffectUseDepthBuffer),e.adjustPanoCircleMeshPositionBasedOnModel!==void 0&&this.adjustPanoCircleMeshPositionBasedOnModel!==e.adjustPanoCircleMeshPositionBasedOnModel&&(this.adjustPanoCircleMeshPositionBasedOnModel=e.adjustPanoCircleMeshPositionBasedOnModel,this.adjustPanoCircleMeshPositionBasedOnModel||this.adjustPanoCircleMeshPositionFix.clear()),!0)}destroy(){super.destroy(),this.tiling.dispose(),this.modelScene.parameter.set({refinedScreen:null,pano0Depth:null,pano1Depth:null}),this.pano0DepthCubeRenderTarget&&(this.pano0DepthCubeRenderTarget.dispose(),this.pano0DepthCubeRenderTarget=void 0),this.pano1DepthCubeRenderTarget&&(this.pano1DepthCubeRenderTarget.dispose(),this.pano1DepthCubeRenderTarget=void 0),this.locationMotion.dispose(),this.pendingTextureTask=void 0,this.panoMeshes&&(this.panoMeshes.forEach(e=>{this.helper.remove(e),e.dispose()}),this.panoMeshes.clear());let e=this.videoTexture.image;e.pause(),e.oncanplay=noop,e.ontimeupdate=noop,this.scene.remove(this.panoVideo.object),this.panoVideo.setMaterial(null),this.panoVideo.dispose();let t=this.modelScene.parameter.resolveValue(`pano0`),n=this.modelScene.parameter.resolveValue(`pano1`);for(let e of Object.keys(this.panoResources)){let r=this.panoResources[e];if(r.panoPicture){let e=r.panoPicture.map;e&&e!==(t==null?void 0:t.map)&&e!==(n==null?void 0:n.map)&&(e.dispose(),r.panoPicture=null)}delete this.panoResources[e]}}isReady(){return this.locationMotion.ended===!0?super.isReady():!1}isTileReady(){let e=this.tiling.pedding<=0;return this.initAnimationed&&e}updateWork(t,n,r,o){this.userAction=o,this.works=t;let s=e.initAnimationEndState(Object.assign(Object.assign({},this),{initial:{currentState:Object.assign(Object.assign({},this.currentPano),this.camera.pose),duration:r.duration,effect:r.effect,state:n,userAction:o}}));return(s.workCode!==this.currentPano.workCode||s.panoIndex!==this.currentPano.panoIndex||s.longitude!==this.cameraMotion.value.longitude||s.latitude!==this.cameraMotion.value.latitude||s.fov!==this.cameraMotion.value.fov)&&(this.initAnimationed=!1,this.moveToPano({workCode:s.workCode,panoIndex:s.panoIndex},{effect:r.effect,duration:r.duration,longitude:s.longitude,latitude:s.latitude,fov:s.fov,moveEndCallback:()=>{this.initAnimationed=!0},moveCancelCallback:()=>{this.initAnimationed=!0}},o)),!0}updateModel(e){this.modelScene=e,this.hideIntersectMesh()}updateTime(e,t,...n){var r,o,s,c,l,u;if(this.destroyed)return;let d={},f={},p=this.camera.getDirection(new three.Vector3),m=this.locationMotion.keyframes[0],h=this.locationMotion.keyframes[this.locationMotion.keyframes.length-1],[g,_]=this.locationMotion.getKeyFrameSegment(e),v=this.panoResourceFromLocationMotionKeyframe(g),y=this.panoResourceFromLocationMotionKeyframe(_),b=this.panoResourceFromLocationMotionKeyframe(m),S=this.panoResourceFromLocationMotionKeyframe(h),C=!1;if(this.cameraMotion.ended===!1&&(this.cameraMotion.update(e),f.longitude=this.cameraMotion.value.longitude,f.latitude=this.cameraMotion.value.latitude,f.fov=this.cameraMotion.value.fov),this.modelAlphaMotion.ended===!1&&(this.modelAlphaMotion.update(e),d.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);let t=this.locationMotion.value.count-_.value.count+1,n=new three.Vector3().copy(v.position),s=new three.Vector3().copy(y.position);if(d.progress=y.effectEasing(t),t>=.01&&t<=.99&&(d.progress=clamp$1(y.effectEasing(t),.01,.99)),y.panoPicture&&(t<1?v.panoPicture&&(d.pano0=v.panoPicture):d.pano0=y.panoPicture,d.pano1=y.panoPicture),y.effect===`montage`?d.transition=`BLACK`:y.effect===`spread`?d.transition=`SPREAD`:d.transition=`FADE`,y.effect===`zoomin`||y.effect===`zoomout`?d.progress=Math.pow(t,3):y.effect===`model`&&this.camera.pose.distance<.01&&(d.modelAlpha=1-Math.pow(clamp$1(Math.abs(t-.5)*2,0,1),4)),t<1&&y.effect!==`fly`&&y.effect!==`model`){if(d.pano0&&v.panoPicture){let e={panoId:d.pano0.panoId,map:d.pano0.map,mapHistogram:d.pano0.mapHistogram,mapSize:d.pano0.mapSize,zoom:d.pano0.zoom,matrix:v.panoPicture.matrix.clone().premultiply(v.fixCameraTransform).setPosition(y.position)},t=this.panoPictureObserverMap.get(d.pano0);t&&this.panoPictureObserverMap.set(e,t),d.pano0=e}n.copy(s),C=!0}f.distance=this.locationMotion.value.distance,f.offset=new three.Vector3(n.x+(s.x-n.x)*t,n.y+(s.y-n.y)*t,n.z+(s.z-n.z)*t);let c=[],l=[];for(let e of this.locationMotion.keyframes){let{key:t,progress:n}=e;t!==void 0&&(c.push(t),n>this.locationMotion.progress&&l.push(t))}for(let e of Object.keys(this.panoResources)){if(l.indexOf(e)>=0)continue;let t=this.panoResources[e];if(t.panoPicture){let e=t.panoPicture.map;if(e){if(e===((r=d.pano0)==null?void 0:r.map)||e===((o=d.pano1)==null?void 0:o.map))continue;e.dispose(),t.panoPicture=null}}c.indexOf(e)>=0||delete this.panoResources[e]}let u=panoParse(y.panoId);u!==this.currentPano&&(this.currentPano=u,this.accessibleObserverFloorCheckCount=0),this.emit(`pano.moving`,createEvent(`pano.moving`,{userAction:this.userAction,prevPano:panoParse(b.panoId),state:Object.assign(Object.assign(Object.assign(Object.assign({},panoParse(S.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),f),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(d)===!1&&this.modelScene.parameter.set(d),isEmptyObject(f)===!1&&this.setCamera(f);let w=this.works.getObserver(this.currentPano),T=this.locationMotion.ended?this.getForwardObserverOrNot(this.camera):null,E=this.works.getObserver(v.panoId),D=this.works.getObserver(y.panoId);if(this.adjustPanoCircleMeshPositionBasedOnModel&&this.helper.visible&&w){let e=[],t=w.work.observers;for(let n of w.accessibleNodes){let r=t[n];r&&e.push(r)}let n=new Map;if(e.sort((e,t)=>{let r=n.get(e);r===void 0&&(r=e.standingPosition.distanceTo(w.standingPosition),n.set(e,r));let o=n.get(e);return o===void 0&&(o=t.standingPosition.distanceTo(w.standingPosition),n.set(t,o)),r-o}),e.length){this.accessibleObserverFloorCheckCount%=e.length;let t=e[this.accessibleObserverFloorCheckCount],n=this.modelScene.models.find(e=>e.work===(t==null?void 0:t.work));if(t&&n&&n.visible){let e=.3,r=.05,o=.005,s=t.standingPosition.clone().applyMatrix4(t.work.transform),c=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode}),l=adjustPanoCircleMeshVectors.map(t=>{scratchRaycaster$1.ray.origin.copy(s),scratchRaycaster$1.ray.origin.add(scratchVector3$3.copy(t).setY(e)),scratchRaycaster$1.ray.direction.set(0,-1,0),scratchRaycaster$1.firstHitOnly=!0,scratchRaycaster$1.floorIndex=-1;let[r]=n.intersectRaycaster(scratchRaycaster$1);return r&&r.distance-o<=e?new three.Vector3().copy(s).setY(r.point.y+o):s});l.sort((e,t)=>t.y-e.y);let u=l[Math.floor(l.length/2)],[d]=l.filter(e=>e.distanceTo(u)<=.05);if(d){let e=new three.Vector4(s.x,s.y,s.z,d.y-s.y),t=this.adjustPanoCircleMeshPositionFix.get(c);t&&!e.equals(t)&&(this.needsRender=!0),this.adjustPanoCircleMeshPositionFix.set(c,e)}}this.accessibleObserverFloorCheckCount++}}let O=new Map;if(E)for(let e of E.accessibleNodes){let t=E.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});O.set(e,t)}}if(D)for(let e of D.accessibleNodes){let t=D.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});O.set(e,t)}}if(this.panoMeshes.forEach((e,t)=>{O.get(t)?O.delete(t):(this.helper.remove(e),e.dispose(),this.panoMeshes.delete(t))}),O.forEach((e,t)=>{let n=this.panoCircleMeshCreator(e,{aerialObserverMinHeight:this.aerialObserverMinHeight});this.panoMeshes.set(t,n),this.helper.add(n),O.delete(t)}),this.panoMeshes.forEach((e,t)=>{let n=this.works.getObserver(t);if(n){let r=n.position.distanceTo(n.standingPosition)>this.aerialObserverMinHeight;if(r)e.position.copy(n.position).applyMatrix4(n.work.transform),e.scale.setScalar(18);else{e.position.copy(n.standingPosition).applyMatrix4(n.work.transform);let t=this.adjustPanoCircleMeshPositionFix.get(n.panoId);t&&(scratchVector3$3.set(t.x,t.y,t.z),scratchVector3$3.equals(e.position)&&(e.position.y+=t.w)),e.scale.setScalar(1.2)}let o=this.camera.position.clone().setY(e.position.y),s=new three.Vector3().copy(e.position).sub(o).normalize();if(t===panoStringify(this.currentPano)){let t=clamp$1((.5-o.distanceTo(e.position))/.5,0,1);s.multiplyScalar(1-t).add(p.clone().multiplyScalar(t))}if(s.length()>0){let t=r?-Math.PI/2:0,n=Math.atan2(s.x,s.z);e.quaternion.setFromEuler(new three.Euler(t,n,0,`YXZ`))}}else e.visible=!1}),this.camera.pose.distance>.1||C)this.panoMeshes.forEach(n=>{n.setOpacity(0),n.setCurrent(!1),n.updateTime&&n.updateTime(e,t),n.visible=!1});else if(w){let n=w.work.observers,[,r]=arrayMin(w.accessibleNodes,e=>{let t=n[e];return!t||!t.active?1/0:w.standingPosition.distanceTo(t.standingPosition)},!0);r=clamp$1(r,3,1/0);let o=w.accessibleNodes.concat(w.panoIndex).map(e=>panoStringify({panoIndex:e,workCode:w.work.workCode}));this.panoMeshes.forEach((n,s)=>{let c=this.works.getObserver(s),l=!1,u=1;if(o.indexOf(s)===-1)l=!1,u=0;else if(!c)l=!1,u=0;else if(!c.loadable&&!c.active)l=!1,u=0;else{let e=n.position.clone().project(this.camera);l=Math.abs(e.x)<1&&Math.abs(e.y)<1&&Math.abs(e.z)<1&&!n.loading&&n.progress===0&&T!==null&&panoStringify({panoIndex:T.panoIndex,workCode:T.work.workCode})===s;let t=n.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);u=t<.01?0:clamp$1(r/t,.1,.85)}c&&c===D&&c.position.distanceTo(c.standingPosition)>this.aerialObserverMinHeight&&n.position.distanceTo(this.camera.position)<35&&(u=0),this.modelScene.parameter.resolveValue(`modelAlpha`)>0&&(u=0),n.setCurrent(l),n.setOpacity(u),n.updateTime&&n.updateTime(e,t)})}{let e=(s=this.modelScene.parameter.progress)==null?1:s,t=Math.round(e),n=this.modelScene.parameter.pano0,r=this.modelScene.parameter.pano1,o=t===0?n:r,l;if(o&&(l=this.works.getObserver(o.panoId),l||(l=this.panoPictureObserverMap.get(o))),this.tiling.appearDuration=this.tileAppearDuration,this.tiling.maxRequest=e<(canUseNativeImageBitmap()?.6:.99)?0:this.tileMaxRequest,this.tiling.imageOptions=this.imageOptions,!l||!o||this.tileLevelForFov===!1||this.camera.perspToOrtho.x>0){this.tiling.setObserver(null);let e={renderer:this.renderer,resolution:this.camera.resolution,pixelRatio:this.camera.pixelRatio,time:this.camera.time,cameraMatrix:this.camera.matrixWorld,cameraProjectionMatrix:this.camera.projectionMatrix,panoMap:null,panoMatrix:new three.Matrix4,panoZoom:1,minLevel:0,level:0};this.tiling.update(e),this.modelScene.parameter.set(`refinedScreen`,null)}else{let e=getImageSizeLevel(o.mapSize),s=e+1,u=new three.Vector2().copy(this.camera.resolution).multiplyScalar(this.camera.pixelRatio),d=Math.floor(this.tileLevelForFov(this.camera.fov,u)),f=d>e?d:0;this.tiling.setObserver(l);let p={renderer:this.renderer,resolution:this.camera.resolution,pixelRatio:this.camera.pixelRatio,time:this.camera.time,cameraMatrix:this.camera.matrixWorld,cameraProjectionMatrix:this.camera.projectionMatrix,panoMap:o.map,panoMatrix:o.matrix,panoZoom:o.zoom,minLevel:s,level:f},m=this.tiling.update(p),h={map:this.tiling.renderTarget.texture,matrixInverse:this.tiling.camera.matrixWorldInverse,projectionMatrix:this.tiling.camera.projectionMatrix,pano:t,opacity:(n==null?void 0:n.panoId)===(r==null?void 0:r.panoId)?1:easeInQuart(Math.abs(((c=this.modelScene.parameter.progress)==null?0:c)-.5)*2)},g=this.modelScene.parameter.refinedScreen;(m||h.pano!==(g==null?void 0:g.pano)||h.opacity!==(g==null?void 0:g.opacity))&&this.modelScene.parameter.set(`refinedScreen`,h)}}if(this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e),w&&w.images.video&&(this.needsRender=!0),this.intersectMesh&&this.intersectMesh.parent&&w&&w.position.y-w.standingPosition.y>10){let e=clamp$1(this.camera.position.distanceTo(this.intersectMesh.position)*(2*Math.tan(.5*this.camera.fov/180*Math.PI))/5,.5);this.intersectMesh.scale.setScalar(e)}else this.intersectMesh.scale.setScalar(1);{let e=y.effect,{pano0:t,pano1:n}=this.modelScene.parameter;if(t&&n&&t!==n&&(e===`fly`||e===`model`)&&this.flyEffectUseDepthBuffer){if(((l=this.modelScene.parameter.pano0Depth)==null?void 0:l.panoId)!==t.panoId||((u=this.modelScene.parameter.pano1Depth)==null?void 0:u.panoId)!==n.panoId){let e=500,r=512;this.pano0DepthCubeRenderTarget?this.pano0DepthCubeRenderTarget.width!==512&&this.pano0DepthCubeRenderTarget.setSize(512,512):this.pano0DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1}),this.pano1DepthCubeRenderTarget?this.pano1DepthCubeRenderTarget.width!==512&&this.pano1DepthCubeRenderTarget.setSize(512,512):this.pano1DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1});let o=new three.CubeCamera(this.camera.near,this.camera.far,this.pano0DepthCubeRenderTarget);o.matrix.copy(t.matrix),o.matrixWorld.copy(o.matrix),o.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,o,500);let s=new three.CubeCamera(this.camera.near,this.camera.far,this.pano1DepthCubeRenderTarget);s.matrix.copy(n.matrix),s.matrixWorld.copy(s.matrix),s.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,s,500),this.modelScene.parameter.set({pano0Depth:{panoId:t.panoId,map:this.pano0DepthCubeRenderTarget.texture,mapSize:this.pano0DepthCubeRenderTarget.width,maxDepth:500},pano1Depth:{panoId:n.panoId,map:this.pano1DepthCubeRenderTarget.texture,mapSize:this.pano1DepthCubeRenderTarget.width,maxDepth:500}})}}else this.modelScene.parameter.set({pano0Depth:null,pano1Depth:null}),this.flyEffectUseDepthBuffer||(this.pano0DepthCubeRenderTarget&&(this.pano0DepthCubeRenderTarget.dispose(),this.pano0DepthCubeRenderTarget=void 0),this.pano1DepthCubeRenderTarget&&(this.pano1DepthCubeRenderTarget.dispose(),this.pano1DepthCubeRenderTarget=void 0))}}getTargetState(){let e=this.cameraMotion.getKeyFrameSegment(now())[1],t=this.locationMotion.getKeyFrameSegment(now())[1],n=this.panoResourceFromLocationMotionKeyframe(t),r=this.works.getObserver(n.panoId);return{workCode:r?r.work.workCode:this.currentPano.workCode,panoIndex:r?r.panoIndex:this.currentPano.panoIndex,mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:r?r.position.clone().applyMatrix4(r.work.transform):this.camera.position.clone(),distance:this.locationMotion.value.distance}}moveToPano(e,t,n){var r,o,s;let c=(r=t.effect)==null?`fly`:r;this.userAction=n,this.stopMomentumMovement();let l=panoStringify(e),u=this.works.getObserver(e);if(!u)throw Error(`Invalid PanoId ${JSON.stringify(e)}`);let d=getImageSizeFromURL(u.images.up),f=this.imageOptions.size;f===void 0&&u&&d&&(f=Number(d)),f===void 0&&(f=2048);let p=this.imageOptions.transform,m=Object.assign({key:`pano.${l}`},pick(this.imageOptions,[`format`,`size`,`quality`,`sharpen`,`forceUseExifOrientation`,`mappings`])),h={right:u.images.work.getURL(u.images.right),left:u.images.work.getURL(u.images.left),up:u.images.work.getURL(u.images.up),down:u.images.work.getURL(u.images.down),front:u.images.work.getURL(u.images.front),back:u.images.work.getURL(u.images.back)},g=`pano:`+jsonHash([h,m,p]);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===g)return;{let e=this.pendingTextureTask.panoId;(o=this.panoMeshes.get(e))==null||o.setProgress(0),this.emit(`pano.texture.abort`,createEvent(`pano.texture.abort`,{error:null,progress:0,meta:null,pano:{panoIndex:u.panoIndex,workCode:u.work.workCode}}))}}let _=`move-to-pano-`+l;this.pending.add(_);let v=this.modelScene.parameter,y;if(v.pano0&&v.pano0.map.name===g?y=v.pano0:v.pano1&&v.pano1.map.name===g&&(y=v.pano1),y){let n={panoId:l,effect:c,effectEasing:(s=t.effectEasing)==null?defaultEffectEase:s,panoPicture:{panoId:y.panoId,map:y.map,mapHistogram:y.mapHistogram,mapSize:y.mapSize,matrix:u.matrix.clone().premultiply(u.work.transform),zoom:1},position:u.position.clone().applyMatrix4(u.work.transform),fixCameraTransform:new three.Matrix4};n.panoPicture&&this.panoPictureObserverMap.set(n.panoPicture,u),this.pendingTextureTask=void 0,AnimationFrameLoop.shared.add(()=>{this.pending.delete(_),this.doMoveToPano(e,n,t)},!0,1);return}this.pendingTextureTask={panoId:l,hash:g,onLoad:n=>{var r,o;let s=n.body;if(this.destroyed)s.dispose();else{s.name=g;let n=Array.isArray(s.image)?s.image[0]:s.image,d=(r=n==null?void 0:n.width)==null?2048:r,f=u.images.histogram;f||(f=new Histogram().formPixels(getRgbaDataFromCubeTexture(this.renderer,s,!0,sharedHistogramRgbaData).data),u.images.histogram=f);let p={panoId:l,effect:c,effectEasing:(o=t.effectEasing)==null?defaultEffectEase:o,panoPicture:{panoId:l,map:s,mapSize:d,mapHistogram:new three.Vector4().fromArray(f.toArray()),matrix:u.matrix.clone().premultiply(u.work.transform),zoom:1},position:u.position.clone().applyMatrix4(u.work.transform),fixCameraTransform:new three.Matrix4};p.panoPicture&&this.panoPictureObserverMap.set(p.panoPicture,u),this.doMoveToPano(e,p,t)}},onError:n=>{let r=Object.assign(Object.assign(Object.assign({},e),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`pano.error`,createEvent(`pano.error`,{error:n,userAction:this.userAction,options:t,prevPano:this.currentPano,progress:0,state:r})),this.emit(`pano.cancel`,createEvent(`pano.cancel`,{error:n,userAction:this.userAction,options:t,prevPano:this.currentPano,progress:0,state:r})),this.emit(`error`,n),t.moveCancelCallback&&t.moveCancelCallback()}};let b=this.panoMeshes.get(l);b&&b.tap&&b.tap(),this.textureLoader.loadCubeTexture(h,{imageURL:{transform:p,options:m},format:three.RGBFormat,viaAjax:!0,fetcher:getFetcher(this.fiveId,u.work)},void 0,void 0,t=>{var n,r;this.emit(`pano.texture.progress`,createEvent(`pano.texture.progress`,{error:null,progress:t,meta:null,pano:e})),((n=this.pendingTextureTask)==null?void 0:n.hash)===g&&((r=this.panoMeshes.get(l))==null||r.setProgress(t))},this.renderer).then(t=>{var n,r;this.pending.delete(_),((n=this.pendingTextureTask)==null?void 0:n.hash)===g?(this.pendingTextureTask.onLoad(t),this.pendingTextureTask=void 0,(r=this.panoMeshes.get(l))==null||r.setProgress(0)):t.body.dispose(),this.emit(`pano.texture.success`,createEvent(`pano.texture.success`,{error:null,progress:1,meta:t.meta,pano:e}))}).catch(t=>{var n,r;this.pending.delete(_),((n=this.pendingTextureTask)==null?void 0:n.hash)===g&&(this.pendingTextureTask.onError(t),this.pendingTextureTask=void 0,(r=this.panoMeshes.get(l))==null||r.setProgress(0)),this.emit(`pano.texture.error`,createEvent(`pano.texture.error`,{error:t,progress:0,meta:null,pano:e})),this.emit(`error`,t)}),this.emit(`pano.texture.load`,createEvent(`pano.texture.load`,{error:null,progress:0,meta:null,pano:e}))}initAnimation(){return this.destroyed?Promise.resolve():new Promise(t=>{let{duration:n,effect:r,userAction:o}=this.initial;this.userAction=o;let s=e.initAnimationEndState(this),c={workCode:s.workCode,panoIndex:s.panoIndex},l={modelAlpha:0},u={perspToOrtho:0},d=!1;this.moveToPano(c,{longitude:s.longitude,latitude:s.latitude,fov:s.fov,effect:r,duration:n,moveStartCallback:e=>{d=!0,this.perspToOrthoMotion.set(u,n).catch(noop),this.modelAlphaMotion.setKeyframes([{progress:0,value:Object.assign({},this.modelAlphaMotion.value)},{progress:.6,value:Object.assign({},this.modelAlphaMotion.value)},{progress:1,value:l}],n).catch(noop),this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:e,userAction:this.userAction}))},moveEndCallback:e=>{this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:e,userAction:this.userAction})),this.initAnimationed=!0,t()},moveCancelCallback:()=>{let e=Object.assign(Object.assign(Object.assign({},c),{mode:this.mode}),clonePose(this.camera.pose));d===!1&&this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:e,userAction:this.userAction})),this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:e,userAction:this.userAction})),this.initAnimationed=!0,t()}},o)})}panoResourceFromLocationMotionKeyframe(e){return this.panoResources[e.key]}locationMotionKeyframesLength(e){let t=0;for(let n=1;n<e.length;n++){let r=this.panoResourceFromLocationMotionKeyframe(e[n-1]).position,o=this.panoResourceFromLocationMotionKeyframe(e[n]).position,s=r.distanceTo(o)*(e[n].value.count-e[n-1].value.count);t+=s}return t}doMoveToPano(e,t,n={}){var r,o,s,c,l,u,d,f,p,m,h;let g=now(),_=createUuid();this.panoResources[_]=t;let v=1,y,b,S;if(this.locationMotion.ended){let[e,n]=this.locationMotion.getKeyFrameSegment(g),o=this.locationMotion.value,s=((r=this.panoResourceFromLocationMotionKeyframe(n))==null?this.camera:r).position,c=t.position;y=Math.max(s.distanceTo(c),1),b=[{key:n.key,progress:0,value:Object.assign(Object.assign({},o),{count:0})},{key:_,progress:1,value:{distance:0,count:1}}],S=0}else{let[e,n]=this.locationMotion.getKeyFrameSegment(g),r=this.locationMotion.value,o=this.panoResourceFromLocationMotionKeyframe(e).position,s=this.panoResourceFromLocationMotionKeyframe(n).position,c=t.position,l=n.value.count-r.count,u=Math.max(o.distanceTo(s),1)*l;y=u+Math.max(s.distanceTo(c),1),b=[{key:e.key,progress:0,value:Object.assign({},r)},{key:n.key,progress:u/y,value:n.value},{key:_,progress:1,value:{count:n.value.count+1,distance:0}}];let d=this.locationMotionKeyframesLength(this.locationMotion.keyframes),f=this.locationMotionKeyframesLength(b);S=d===0||d===0?0:this.locationMotion.getProgressVelocity(g)*d/f}let C=t.effect===`instant`?0:this.calculateMovingDuration(n.duration,t.effect===`fly`||t.effect===`model`?y:0),w={longitude:n.longitude,latitude:n.latitude,fov:n.fov},T=Object.assign(Object.assign({},e),{mode:this.mode,longitude:(o=w.longitude)==null?this.camera.pose.longitude:o,latitude:(s=w.latitude)==null?this.camera.pose.latitude:s,fov:(c=w.fov)==null?this.camera.pose.fov:c,offset:t.position.clone(),distance:this.camera.pose.distance}),E=this.currentPano;if(this.emit(`pano.moveTo`,createEvent(`pano.moveTo`,{options:n,prevPano:E,progress:0,state:T,userAction:this.userAction,error:null})),n.moveStartCallback&&n.moveStartCallback(T),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,this.videoTexture.needsUpdate=!0),this.panoVideo.setMaterial(null),t.effect===`fly`||t.effect===`model`)this.cameraMotion.set(w,C).catch(noop);else{let e=coordinatesToVector({longitude:this.cameraMotion.value.longitude,latitude:this.cameraMotion.value.latitude}),n=coordinatesToVector({longitude:(l=w.longitude)==null?this.cameraMotion.value.longitude:l,latitude:(u=w.latitude)==null?this.cameraMotion.value.latitude:u}),r=new three.Object3D;r.lookAt(e);let o=new three.Matrix4().makeRotationFromQuaternion(r.quaternion);r.lookAt(n);let s=new three.Matrix4().makeRotationFromQuaternion(r.quaternion),c=new three.Matrix4().getInverse(o).premultiply(s),g=this.cameraMotion.value.fov,_=(d=w.fov)==null?this.cameraMotion.value.fov:d,v=1;t.effect===`zoomin`?v=1.5:t.effect===`zoomout`&&(v=.4);let y=clamp$1(_*v,1,170);for(let e=0;e<b.length-1;e++){let t=b[e].key;if(t){let e=this.panoResources[t];e&&(e.fixCameraTransform.copy(c),e.panoPicture&&(e.panoPicture.zoom=Math.tan(y/2/180*Math.PI)/Math.tan(g/2/180*Math.PI)))}}this.cameraMotion.setKeyframes([{progress:0,value:{longitude:this.cameraMotion.value.longitude,latitude:this.cameraMotion.value.latitude,fov:this.cameraMotion.value.fov}},{progress:0,value:{longitude:(f=w.longitude)==null?this.cameraMotion.value.longitude:f,latitude:(p=w.latitude)==null?this.cameraMotion.value.latitude:p,fov:y}},{progress:1,value:{longitude:(m=w.longitude)==null?this.cameraMotion.value.longitude:m,latitude:(h=w.latitude)==null?this.cameraMotion.value.latitude:h,fov:_}}],C).catch(noop)}this.locationMotion.setKeyframes(b,C,S).then(()=>{for(let e of this.modelScene.children)e instanceof Model&&e.show();let t=Object.assign(Object.assign({},e),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance});this.emit(`pano.arrived`,createEvent(`pano.arrived`,{options:n,prevPano:E,progress:1,state:t,userAction:this.userAction,error:null})),n.moveEndCallback&&n.moveEndCallback(t);let r=this.works.getObserver(e);if(r&&r.images.video&&this.videoTexture&&this.videoTexture.image instanceof HTMLVideoElement){let e={map:this.videoTexture,size:r.images.video.size.clone(),matrix:r.images.video.matrix.clone(),panoMatrix:r.matrix.clone().premultiply(r.work.transform),alpha:1},t=createUuid(),n=this.videoTexture.image;n.setAttribute(`uuid`,t),n.oncanplay=noop,n.ontimeupdate=noop,canplayVideo().then(o=>{o&&r.images.video&&n.getAttribute(`uuid`)===t&&(n.oncanplay=()=>{n.oncanplay=noop,n.play()},n.ontimeupdate=()=>{n.currentTime>.5&&(n.ontimeupdate=noop,this.panoVideo.setMaterial(e))},n.src=r.images.video.source)}).catch((()=>{n.removeAttribute(`uuid`)}))}else{let e=this.videoTexture.image;e.removeAttribute(`uuid`),e.oncanplay=noop,e.ontimeupdate=noop}},()=>{this.emit(`pano.cancel`,createEvent(`pano.cancel`,{options:n,prevPano:E,progress:0,state:T,userAction:this.userAction,error:null})),n.moveCancelCallback&&n.moveCancelCallback()})}getForwardObserverOrNot(e,t){let n=this.works.getObserver(this.currentPano);if(!n)return null;let r=t==null?new three.Raycaster(e.position.clone(),e.getWorldDirection(new three.Vector3)):t;r.params.Points={threshold:.1},r.firstHitOnly=!0,r.floorIndex=-1;let o=n.standingPosition.clone().applyMatrix4(n.work.transform);if(n.position.clone().applyMatrix4(n.work.transform).distanceTo(r.ray.origin)>1){let e=new three.Raycaster(r.ray.origin,new three.Vector3(0,-1,0));e.firstHitOnly=r.firstHitOnly,e.floorIndex=r.floorIndex;let[t]=this.modelScene.intersectRaycaster(e);t&&t.distance<=2?o.copy(t.point):o.copy(r.ray.origin).add(new three.Vector3(0,-1.5,0))}let[s]=this.modelScene.intersectRaycaster(r),c=(s?s.point:r.ray.origin.clone().add(r.ray.direction.clone().normalize().multiplyScalar(3))).clone().sub(o).normalize();if(c.length()===0)return null;let l=n.work.observers,u=n.accessibleNodes.filter(t=>{if(t===this.currentPano.panoIndex&&n.work.workCode===this.currentPano.workCode)return!1;let r=l[t];if(!r)return!1;let o=r.standingPosition.clone().applyMatrix4(r.work.transform).project(e);return Math.abs(o.z)>1||Math.abs(o.x)>1||Math.abs(o.y)>1?!1:r.loadable||r.active}),d=new Map,f=u.slice().sort((e,t)=>{let n=l[e],r=d.get(n);r===void 0&&(r=scratchVector3$3.copy(n.standingPosition).applyMatrix4(n.work.transform).distanceTo(o),d.set(n,r));let s=l[t],c=d.get(s);return c===void 0&&(c=scratchVector3$3.copy(s.standingPosition).applyMatrix4(s.work.transform).distanceTo(o),d.set(s,c)),r-c});d.clear();for(let e of[Math.PI/8,Math.PI/6,Math.PI/4,Math.PI/3])for(let t of f){let n=l[t];if(n){let t=scratchVector3$3.copy(n.standingPosition).applyMatrix4(n.work.transform).sub(o);if(t&&t.length()!==0&&c.angleTo(t)<e)return n}}let p=null;if(t){let n=t.ray.intersectBox(this.modelScene.boundingBox,scratchVector3$3);n&&(n.project(e),Math.abs(n.z)<=1&&(p=n.clone()))}else p=new three.Vector3(0,0,0);if(p){let t=.4,r=n.accessibleNodes.filter(t=>{if(t===this.currentPano.panoIndex&&n.work.workCode===this.currentPano.workCode)return!1;let r=l[t];if(!r)return!1;let o=r.position.clone().applyMatrix4(r.work.transform).project(e);return Math.abs(o.z)>1||Math.abs(o.x)>1||Math.abs(o.y)>1?!1:r.loadable||r.active}),o=new Map,s=r.slice().sort((t,n)=>{let r=l[t],s=o.get(r);s===void 0&&(s=scratchVector3$3.copy(r.position).applyMatrix4(r.work.transform).distanceTo(e.position),o.set(r,s));let c=l[n],u=o.get(c);return u===void 0&&(u=scratchVector3$3.copy(c.position).applyMatrix4(c.work.transform).distanceTo(e.position),o.set(c,u)),s-u});o.clear();for(let t of s){let n=l[t];if(n){let t=scratchVector3$3.copy(n.position).applyMatrix4(n.work.transform);if(t.project(e),Math.abs(t.z)>1)continue;if(Math.pow(p.x-t.x,2)+Math.pow(p.y-t.y,2)<Math.pow(.4,2))return n}}}return null}onTapGesture(e){var t;if(this.userAction=e.userAction,this.stopMomentumMovement(),!this.initAnimationed)return;let n=e.center.raycaster;n.floorIndex=-1;let r=this.camera.getDirection(new three.Vector3).setY(0),o=null,s=this.works.getObserver(this.currentPano);if(!s)return;let c=s.work.observers,l=s.accessibleNodes.filter(e=>{if(e===this.currentPano.panoIndex&&s.work.workCode===this.currentPano.workCode)return!1;let t=c[e];return!t||scratchVector3$3.copy(t.position).applyMatrix4(t.work.transform).distanceTo(this.camera.position)>this.maxAccessibleDistance?!1:t.loadable||t.active}),[u]=this.modelScene.intersectRaycaster(n);if(u){let[e,n]=arrayMin(l,e=>{let t=c[e];return t?scratchVector3$3.copy(t.standingPosition).applyMatrix4(t.work.transform).distanceTo(u.point):1/0},!0);typeof e==`number`&&n<this.panoTapTriggerRadius&&(o=(t=c[e])==null?null:t)}if(o||(o=this.getForwardObserverOrNot(this.camera,n)),o&&o.panoId===panoStringify(this.currentPano)&&(o=null),o&&!this.locationMotion.ended){for(let e of this.locationMotion.keyframes)if(this.panoResourceFromLocationMotionKeyframe(e).panoId===o.panoId){o=null;break}}if(!o)this.emit(`gesture.tap`,e),e.defaultPrevented||this.locationMotion.ended===!0&&this.cameraBounce();else{let t={},n=Math.PI/6,c=Math.PI/12,l=o.position.clone().applyMatrix4(o.work.transform).setY(0).sub(s.position.clone().applyMatrix4(o.work.transform).setY(0)).normalize(),u=[],d=[],f=[],p=o.work.observers;for(let e of o.accessibleNodes){if(o.panoIndex===e||e===this.currentPano.panoIndex&&o.work.workCode===this.currentPano.workCode)continue;let t=p[e];if(!t)continue;let r=t.position.clone().applyMatrix4(t.work.transform).sub(o.position.clone().applyMatrix4(o.work.transform)).setY(0).normalize();l.angleTo(r)<n&&f.push(r)}let[m]=(f.length>0?f:[...u,...d]).slice().sort((e,t)=>e.angleTo(l)-t.angleTo(l));if(m&&m.angleTo(r)>c&&(t.longitude=Math.atan2(-m.x,-m.z)),this.cameraMotion.value.latitude<-Math.PI/4){let n=e.state.fov;t.latitude=clamp$1(0,clamp$1(typeof this.minLatitude==`function`?this.minLatitude(n):this.minLatitude,-Math.PI/2,Math.PI/2),clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(n):this.maxLatitude,-Math.PI/2,Math.PI/2))}let h=Object.assign({},e.state);if(h.workCode=o.work.workCode,h.panoIndex=o.panoIndex,t.longitude!==void 0&&(h.longitude=t.longitude),t.latitude!==void 0&&(h.latitude=t.latitude),t.fov!==void 0&&(h.fov=t.fov),h.distance=0,h.offset=o.position.clone(),e.state=h,this.emit(`gesture.tap`,e),!e.defaultPrevented){if(this.emit(`pano.select`,createEvent(`pano.select`,{prevPano:this.currentPano,state:h,userAction:e.userAction,options:t,progress:0,error:null})),o&&!o.active){let e=panoStringify({panoIndex:o.panoIndex,workCode:o.work.workCode}),t=this.panoMeshes.get(e);t&&(t.setDisabled(!1),t.setLoading(!0))}o&&o.active&&this.emit(`pano.request`,createEvent(`pano.request`,{userAction:e.userAction,prevPano:this.currentPano,progress:0,state:h,options:t,error:null}))}}}},DEG_TO_RAD=Math.PI/180,RAD_TO_DEG=180/Math.PI,MIN_TIMESTEP=.001,MAX_TIMESTEP=1,isIOS=(()=>{let e=typeof navigator<`u`&&/iPad|iPhone|iPod/.test(navigator.platform);return()=>e})(),isSafari=(()=>{let e=typeof navigator<`u`&&/^((?!chrome|android).)*safari/i.test(navigator.userAgent);return()=>e})(),isFirefoxAndroid=(()=>{let e=typeof navigator<`u`&&navigator.userAgent.indexOf(`Firefox`)!==-1&&navigator.userAgent.indexOf(`Android`)!==-1;return()=>e})(),getChromeVersion=(()=>{let e=typeof navigator<`u`?navigator.userAgent.match(/.*Chrome\/([0-9]+)/):null,t=e?parseInt(e[1],10):null;return()=>t})(),isChromeWithoutDeviceMotion=(()=>{let e=!1;if(getChromeVersion()===65){let t=typeof navigator<`u`?navigator.userAgent.match(/.*Chrome\/([0-9\.]*)/):null;if(t){let[n,r,o,s]=t[1].split(`.`);e=parseInt(o,10)===3325&&parseInt(s,10)<148}}return()=>e})(),isSafariWithoutDeviceMotion=(()=>{let e=isIOS()&&isSafari()&&typeof navigator<`u`&&navigator.userAgent.indexOf(`13_4`)!==-1;return()=>e})(),isR7=(()=>{let e=typeof navigator<`u`&&navigator.userAgent.indexOf(`R7 Build`)!==-1;return()=>e})();function isLandscapeMode(){let e=typeof window<`u`&&(window.orientation==90||window.orientation==-90);return isR7()?!e:e}function isTimestampDeltaValid(e){return!(isNaN(e)||e<=MIN_TIMESTEP||e>MAX_TIMESTEP)}function getQuaternionAngle(e){return e.w>1?0:2*Math.acos(e.w)}var warnOnce=(()=>{let e={};return(t,n)=>{e[t]===void 0&&(console.warn(`cardboard: `+n),e[t]=!0)}})();function getOriginFromUrl(e){let t,n=e.indexOf(`://`);t=n===-1?0:n+3;let r=e.indexOf(`/`,t);return r===-1&&(r=e.length),e.substring(0,r)}function isInsideCrossOriginIFrame(){if(typeof window>`u`||typeof document>`u`)return!1;let e=window.self!==window.top,t=getOriginFromUrl(document.referrer),n=getOriginFromUrl(window.location.href);return e&&t!==n}var updateEyeViewMatrices=(()=>{function e(e,t,n){let r=t?t[0]:0,o=t?t[1]:0,s=t?t[2]:0,c=t?t[3]:1,l=r+r,u=o+o,d=s+s,f=r*l,p=r*u,m=r*d,h=o*u,g=o*d,_=s*d,v=c*l,y=c*u,b=c*d;return e[0]=1-(h+_),e[1]=p+b,e[2]=m-y,e[3]=0,e[4]=p-b,e[5]=1-(f+_),e[6]=g+v,e[7]=0,e[8]=m+y,e[9]=g-v,e[10]=1-(f+h),e[11]=0,e[12]=n?n[0]:0,e[13]=n?n[1]:0,e[14]=n?n[2]:0,e[15]=1,e}function t(e,t,n){let r=n[0],o=n[1],s=n[2],c,l,u,d,f,p,m,h,g,_,v,y;return t===e?(e[12]=t[0]*r+t[4]*o+t[8]*s+t[12],e[13]=t[1]*r+t[5]*o+t[9]*s+t[13],e[14]=t[2]*r+t[6]*o+t[10]*s+t[14],e[15]=t[3]*r+t[7]*o+t[11]*s+t[15]):(c=t[0],l=t[1],u=t[2],d=t[3],f=t[4],p=t[5],m=t[6],h=t[7],g=t[8],_=t[9],v=t[10],y=t[11],e[0]=c,e[1]=l,e[2]=u,e[3]=d,e[4]=f,e[5]=p,e[6]=m,e[7]=h,e[8]=g,e[9]=_,e[10]=v,e[11]=y,e[12]=c*r+f*o+g*s+t[12],e[13]=l*r+p*o+_*s+t[13],e[14]=u*r+m*o+v*s+t[14],e[15]=d*r+h*o+y*s+t[15]),e}function n(e,t){let n=t[0],r=t[1],o=t[2],s=t[3],c=t[4],l=t[5],u=t[6],d=t[7],f=t[8],p=t[9],m=t[10],h=t[11],g=t[12],_=t[13],v=t[14],y=t[15],b=n*l-r*c,S=n*u-o*c,C=n*d-s*c,w=r*u-o*l,T=r*d-s*l,E=o*d-s*u,D=f*_-p*g,O=f*v-m*g,k=f*y-h*g,A=p*v-m*_,j=p*y-h*_,M=m*y-h*v,N=b*M-S*j+C*A+w*k-T*O+E*D;return N?(N=1/N,e[0]=(l*M-u*j+d*A)*N,e[1]=(o*j-r*M-s*A)*N,e[2]=(_*E-v*T+y*w)*N,e[3]=(m*T-p*E-h*w)*N,e[4]=(u*k-c*M-d*O)*N,e[5]=(n*M-o*k+s*O)*N,e[6]=(v*C-g*E-y*S)*N,e[7]=(f*E-m*C+h*S)*N,e[8]=(c*j-l*k+d*D)*N,e[9]=(r*k-n*j-s*D)*N,e[10]=(g*T-_*C+y*b)*N,e[11]=(p*C-f*T-h*b)*N,e[12]=(l*O-c*A-u*D)*N,e[13]=(n*A-r*O+o*D)*N,e[14]=(_*S-g*w-v*b)*N,e[15]=(f*w-p*S+m*b)*N,e):null}return(r,o,s)=>{e(r,o),s&&t(r,r,s),n(r,r)}})(),SensorSample=class{constructor(e=new three.Vector3,t=0){this.sample=e,this.timestampS=t}set(e,t){this.sample=e,this.timestampS=t}copy(e){this.set(e.sample,e.timestampS)}},ComplementaryFilter=class{constructor(e,t){this.kFilter=e,this.isDebug=t,this.currentAccelMeasurement=new SensorSample,this.currentGyroMeasurement=new SensorSample,this.previousGyroMeasurement=new SensorSample,isIOS()?this.filterQ=new three.Quaternion(-1,0,0,1):this.filterQ=new three.Quaternion(1,0,0,1),this.previousFilterQ=new three.Quaternion,this.previousFilterQ.copy(this.filterQ),this.accelQ=new three.Quaternion,this.isOrientationInitialized=!1,this.estimatedGravity=new three.Vector3,this.measuredGravity=new three.Vector3,this.gyroIntegralQ=new three.Quaternion}addAccelMeasurement(e,t){this.currentAccelMeasurement.set(e,t)}addGyroMeasurement(e,t){this.currentGyroMeasurement.set(e,t),isTimestampDeltaValid(t-this.previousGyroMeasurement.timestampS)&&this.run_(),this.previousGyroMeasurement.copy(this.currentGyroMeasurement)}getOrientation(){return this.filterQ}run_(){if(!this.isOrientationInitialized){this.accelQ=this.accelToQuaternion_(this.currentAccelMeasurement.sample),this.previousFilterQ.copy(this.accelQ),this.isOrientationInitialized=!0;return}let e=this.currentGyroMeasurement.timestampS-this.previousGyroMeasurement.timestampS,t=this.gyroToQuaternionDelta_(this.currentGyroMeasurement.sample,e);this.gyroIntegralQ.multiply(t),this.filterQ.copy(this.previousFilterQ),this.filterQ.multiply(t);let n=new three.Quaternion;n.copy(this.filterQ),n.inverse(),this.estimatedGravity.set(0,0,-1),this.estimatedGravity.applyQuaternion(n),this.estimatedGravity.normalize(),this.measuredGravity.copy(this.currentAccelMeasurement.sample),this.measuredGravity.normalize();let r=new three.Quaternion;r.setFromUnitVectors(this.estimatedGravity,this.measuredGravity),r.inverse(),this.isDebug&&console.log(`Delta: %d deg, G_est: (%s, %s, %s), G_meas: (%s, %s, %s)`,RAD_TO_DEG*getQuaternionAngle(r),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));let o=new three.Quaternion;o.copy(this.filterQ),o.multiply(r),this.filterQ.slerp(o,1-this.kFilter),this.previousFilterQ.copy(this.filterQ)}accelToQuaternion_(e){let t=new three.Vector3;t.copy(e),t.normalize();let n=new three.Quaternion;return n.setFromUnitVectors(new three.Vector3(0,0,-1),t),n.inverse(),n}gyroToQuaternionDelta_(e,t){let n=new three.Quaternion,r=new three.Vector3;return r.copy(e),r.normalize(),n.setFromAxisAngle(r,e.length()*t),n}},PosePredictor=class{constructor(e,t){this.predictionTimeS=e,this.isDebug=t,this.previousQ=new three.Quaternion,this.previousTimestampS=null,this.deltaQ=new three.Quaternion,this.outQ=new three.Quaternion}getPrediction(e,t,n){if(!this.previousTimestampS)return this.previousQ.copy(e),this.previousTimestampS=n,e;let r=new three.Vector3;r.copy(t),r.normalize();let o=t.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(e),this.previousQ.copy(e),this.outQ;let s=o*this.predictionTimeS;return this.deltaQ.setFromAxisAngle(r,s),this.outQ.copy(this.previousQ),this.outQ.multiply(this.deltaQ),this.previousQ.copy(e),this.previousTimestampS=n,this.outQ}},Distortion=class{constructor(e){this.coefficients=e}distortInverse(e){let t=0,n=1,r=e-this.distort(t);for(;Math.abs(n-t)>1e-4;){let o=e-this.distort(n),s=n-o*((n-t)/(o-r));t=n,n=s,r=o}return n}distort(e){let t=e*e,n=0;for(let e=0;e<this.coefficients.length;e++)n=t*(n+this.coefficients[e]);return(n+1)*e}},Pose=class{constructor(){this.angularAcceleration=null,this.angularVelocity=null,this.linearAcceleration=null,this.linearVelocity=null,this.orientation=null,this.position=null}},FieldOfView=class{constructor(){this.leftDegrees=0,this.rightDegrees=0,this.upDegrees=0,this.downDegrees=0}},Sensor=class{constructor(e,t,n,r){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=n,this.accelerometer=new three.Vector3,this.gyroscope=new three.Vector3,this.filter=new ComplementaryFilter(e,r),this.posePredictor=new PosePredictor(t,r),this.isFirefoxAndroid=isFirefoxAndroid(),this.isIOS=isIOS();let o=getChromeVersion();this.isDeviceMotionInRadians=!this.isIOS&&o!==null&&o<66,this.isWithoutDeviceMotion=isChromeWithoutDeviceMotion()||isSafariWithoutDeviceMotion(),this.filterToWorldQ=new three.Quaternion,isIOS()?this.filterToWorldQ.setFromAxisAngle(new three.Vector3(1,0,0),Math.PI/2):this.filterToWorldQ.setFromAxisAngle(new three.Vector3(1,0,0),-Math.PI/2),this.inverseWorldToScreenQ=new three.Quaternion,this.worldToScreenQ=new three.Quaternion,this.originalPoseAdjustQ=new three.Quaternion;let s=typeof window<`u`?-window.orientation*Math.PI/180:0;this.originalPoseAdjustQ.setFromAxisAngle(new three.Vector3(0,0,1),s),this.setScreenTransform_(),isLandscapeMode()&&this.filterToWorldQ.multiply(this.inverseWorldToScreenQ),this.resetQ=new three.Quaternion,this.orientationOut_=new Float32Array(4),this.previousTimestampS=Date.now()}getPosition(){return null}getOrientation(){let e;if(this.isWithoutDeviceMotion&&this._deviceOrientationQ){this.deviceOrientationFixQ=this.deviceOrientationFixQ||(function(){let e=new three.Quaternion().setFromAxisAngle(new three.Vector3(0,0,-1),0),t=new three.Quaternion;return typeof window<`u`&&window.orientation===-90?t.setFromAxisAngle(new three.Vector3(0,1,0),Math.PI/-2):t.setFromAxisAngle(new three.Vector3(0,1,0),Math.PI/2),e.multiply(t)})(),this.deviceOrientationFilterToWorldQ=this.deviceOrientationFilterToWorldQ||(function(){let e=new three.Quaternion;return e.setFromAxisAngle(new three.Vector3(1,0,0),-Math.PI/2),e})(),e=this._deviceOrientationQ;let t=new three.Quaternion;return t.copy(e),t.multiply(this.deviceOrientationFilterToWorldQ),t.multiply(this.resetQ),t.multiply(this.worldToScreenQ),t.multiplyQuaternions(this.deviceOrientationFixQ,t),this.yawOnly&&(t.x=0,t.z=0,t.normalize()),this.orientationOut_[0]=t.x,this.orientationOut_[1]=t.y,this.orientationOut_[2]=t.z,this.orientationOut_[3]=t.w,this.orientationOut_}else{let t=this.filter.getOrientation();e=this.posePredictor.getPrediction(t,this.gyroscope,this.previousTimestampS)}let t=new three.Quaternion;return t.copy(this.filterToWorldQ),t.multiply(this.resetQ),t.multiply(e),t.multiply(this.worldToScreenQ),this.yawOnly&&(t.x=0,t.z=0,t.normalize()),this.orientationOut_[0]=t.x,this.orientationOut_[1]=t.y,this.orientationOut_[2]=t.z,this.orientationOut_[3]=t.w,this.orientationOut_}getPose(){let e=new Pose;return e.orientation=this.getOrientation(),e}resetPose(){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)}getFrameData(e){let t=this.getOrientation(),n=this.getEyeOffset(),r=this.getEyeProjectionMatrix();return e.pose.angularAcceleration=null,e.pose.angularVelocity=null,e.pose.linearAcceleration=null,e.pose.linearVelocity=null,e.pose.orientation=t,e.pose.position=null,e.timestamp=this.previousTimestampS,e.leftProjectionMatrix.set(r.left),e.rightProjectionMatrix.set(r.right),updateEyeViewMatrices(e.leftViewMatrix,t,n.left),updateEyeViewMatrices(e.rightViewMatrix,t,n.right),e}start(){if(typeof window>`u`)return()=>{};let e=this.onDeviceMotion_.bind(this),t=this.onOrientationChange_.bind(this),n=this.onMessage_.bind(this),r=this.onDeviceOrientation_.bind(this);return isIOS()&&isInsideCrossOriginIFrame()&&window.addEventListener(`message`,n),window.addEventListener(`orientationchange`,t),this.isWithoutDeviceMotion?window.addEventListener(`deviceorientation`,r):window.addEventListener(`devicemotion`,e),()=>{window.removeEventListener(`devicemotion`,e),window.removeEventListener(`deviceorientation`,t),window.removeEventListener(`orientationchange`,t),window.removeEventListener(`message`,n)}}getEyeOffset(){return{left:[-this.viewer.interLensDistance*.5,0,0],right:[this.viewer.interLensDistance*.5,0,0]}}getEyeProjectionMatrix(){let e=this.getEyeFieldOfView(),t=this.depthNear,n=this.depthFar,r={left:[],right:[]};{let o=e.left.upDegrees*DEG_TO_RAD,s=e.left.downDegrees*DEG_TO_RAD,c=e.left.leftDegrees*DEG_TO_RAD,l=e.left.rightDegrees*DEG_TO_RAD,u=2/(c+l),d=2/(o+s);r.left[0]=u,r.left[1]=0,r.left[2]=0,r.left[3]=0,r.left[4]=0,r.left[5]=d,r.left[6]=0,r.left[7]=0,r.left[8]=-((c-l)*u*.5),r.left[9]=(o-s)*d*.5,r.left[10]=n/(t-n),r.left[11]=-1,r.left[12]=0,r.left[13]=0,r.left[14]=n*t/(t-n),r.left[15]=0}{let o=e.right.upDegrees*DEG_TO_RAD,s=e.right.downDegrees*DEG_TO_RAD,c=e.right.leftDegrees*DEG_TO_RAD,l=e.right.rightDegrees*DEG_TO_RAD,u=2/(c+l),d=2/(o+s);r.right[0]=u,r.right[1]=0,r.right[2]=0,r.right[3]=0,r.right[4]=0,r.right[5]=d,r.right[6]=0,r.right[7]=0,r.right[8]=-((c-l)*u*.5),r.right[9]=(o-s)*d*.5,r.right[10]=n/(t-n),r.right[11]=-1,r.right[12]=0,r.right[13]=0,r.right[14]=n*t/(t-n),r.right[15]=0}return r}getEyeFieldOfView(){let e=this.viewer,t=this.device,n=new Distortion(e.distortionCoefficients),r=e.screenLensDistance,o=(t.widthMeters-e.interLensDistance)/2,s=e.interLensDistance/2,c=e.baselineLensDistance-t.bevelMeters,l=t.heightMeters-c,u=RAD_TO_DEG*Math.atan(n.distort(o/r)),d=RAD_TO_DEG*Math.atan(n.distort(s/r)),f=RAD_TO_DEG*Math.atan(n.distort(c/r)),p=RAD_TO_DEG*Math.atan(n.distort(l/r)),m=new FieldOfView,h=new FieldOfView;return m.leftDegrees=Math.min(u,e.fov),m.rightDegrees=Math.min(d,e.fov),m.downDegrees=Math.min(f,e.fov),m.upDegrees=Math.min(p,e.fov),h.leftDegrees=m.rightDegrees,h.rightDegrees=m.leftDegrees,h.upDegrees=m.upDegrees,h.downDegrees=m.downDegrees,{left:m,right:h}}onDeviceOrientation_(e){this._deviceOrientationQ=this._deviceOrientationQ||new three.Quaternion;let{alpha:t,beta:n,gamma:r}=e;t=(t||0)*Math.PI/180,n=(n||0)*Math.PI/180,r=(r||0)*Math.PI/180,this._deviceOrientationQ.setFromEuler(new three.Euler(t,n,-r,`YXZ`))}onDeviceMotion_(e){this.updateDeviceMotion_(e)}updateDeviceMotion_(e){let t=e.accelerationIncludingGravity,n=e.rotationRate,r=e.timeStamp/1e3,o=r-this.previousTimestampS;if(o<0){warnOnce(`fusion-pose-sensor:invalid:non-monotonic`,`Invalid timestamps detected: non-monotonic timestamp from devicemotion`),this.previousTimestampS=r;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=r;return}t&&(this.accelerometer.set(-t.x,-t.y,-t.z),n&&(isR7()?this.gyroscope.set(-n.beta,n.alpha,n.gamma):this.gyroscope.set(n.alpha,n.beta,n.gamma),this.isDeviceMotionInRadians||this.gyroscope.multiplyScalar(Math.PI/180),this.filter.addGyroMeasurement(this.gyroscope,r)),this.filter.addAccelMeasurement(this.accelerometer,r)),this.previousTimestampS=r}onOrientationChange_(){this.setScreenTransform_()}onMessage_(e){let t=e.data;!t||!t.type||t.type.toLowerCase()===`devicemotion`&&this.updateDeviceMotion_(t.deviceMotionEvent)}setScreenTransform_(){switch(this.worldToScreenQ.set(0,0,0,1),typeof window<`u`?window.orientation:0){case 0:break;case 90:this.worldToScreenQ.setFromAxisAngle(new three.Vector3(0,0,1),-Math.PI/2);break;case-90:this.worldToScreenQ.setFromAxisAngle(new three.Vector3(0,0,1),Math.PI/2);break;case 180:break}this.inverseWorldToScreenQ.copy(this.worldToScreenQ),this.inverseWorldToScreenQ.inverse()}},defaultLeftBounds=[0,0,.5,1],defaultRightBounds=[.5,0,.5,1],Cardboard=class{constructor(e){this.renderer=e,this.sensor=new Sensor(.98,.04,!1,!1),this.scale=1,this.cameraL=new three.PerspectiveCamera,this.cameraR=new three.PerspectiveCamera;let t=this.sensor.start();this.dispose=()=>{let e=this.renderer.getSize(new three.Vector2);this.renderer.setScissor(0,0,e.width,e.height),this.renderer.setViewport(0,0,e.width,e.height),this.renderer.setScissorTest(!1),t()}}render(e,t){let n=this.renderer.getSize(new three.Vector2);if(n.width>n.height){var r=e.autoUpdate;r&&(e.updateMatrixWorld(),e.autoUpdate=!1);let o={x:Math.round(n.width*defaultLeftBounds[0]),y:Math.round(n.height*defaultLeftBounds[1]),width:Math.round(n.width*defaultLeftBounds[2]),height:Math.round(n.height*defaultLeftBounds[3])},s={x:Math.round(n.width*defaultRightBounds[0]),y:Math.round(n.height*defaultRightBounds[1]),width:Math.round(n.width*defaultRightBounds[2]),height:Math.round(n.height*defaultRightBounds[3])};this.renderer.setScissorTest(!0),this.renderer.autoClear&&this.renderer.clear(),t.parent===null&&t.updateMatrixWorld(),t.matrixWorld.decompose(this.cameraL.position,this.cameraL.quaternion,this.cameraL.scale),t.matrixWorld.decompose(this.cameraR.position,this.cameraR.quaternion,this.cameraR.scale);let c=this.sensor.getEyeOffset();this.cameraL.translateOnAxis(new three.Vector3().fromArray(c.left),this.scale),this.cameraR.translateOnAxis(new three.Vector3().fromArray(c.right),this.scale);let 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(e,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(e,this.cameraR),this.renderer.setViewport(0,0,n.width,n.height),this.renderer.setScissor(0,0,n.width,n.height),this.renderer.setScissorTest(!1),r&&(e.autoUpdate=!0)}else this.renderer.render(e,t)}dispose(){}},cardboard_png_data_url_default=`data:image/png;base64,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`,phone_png_data_url_default=`data:image/png;base64,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`,_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?LOCALE.zh:_a:LOCALE.zh,CONTENTS=`
1680
1680
  <style>
1681
1681
  .$id {
1682
1682
  all: initial;
@@ -2037,7 +2037,7 @@ void main() {
2037
2037
 
2038
2038
  gl_FragColor = vec4(gl_FragColor.rgb, gl_FragColor.a * opacity * outside * inside);
2039
2039
  }
2040
- `,PanoSphereMesh=class extends three.Object3D{constructor(){super(),this.progress=0,this.opacity=0,this.loading=!1,this.current=!1,this.disabled=!1,this.currentMotion=new Motion({ringScale:1.1,ringOpacity:0,circleFade:0,circleOpacity:.85,circleScale:1}),this.opacityMotion=new Motion({opacity:0}),this.loadingMotion=new Motion({opacity:0}),this.disableMotion=new Motion({opacity:0});let e={blending:three.CustomBlending,blendSrc:three.SrcAlphaFactor,blendDst:three.OneMinusSrcAlphaFactor,blendSrcAlpha:three.OneFactor,blendDstAlpha:three.OneMinusSrcAlphaFactor,depthWrite:!1,transparent:!0};this.hitTestMesh=new three.Mesh(sharedGeometry,new three.MeshBasicMaterial(Object.assign(Object.assign({},e),{color:0,opacity:0}))),this.hitTestMesh.scale.set(1.5,1.5,1.5),this.ringMesh=new three.Mesh(sharedGeometry,new three.ShaderMaterial(Object.assign(Object.assign({},e),{vertexShader:ringVertexShader,fragmentShader:ringFragmentShader,uniforms:{opacity:{value:0}}}))),this.panoMesh=new three.Mesh(sharedGeometry,new three.ShaderMaterial(Object.assign(Object.assign({},e),{vertexShader,fragmentShader,uniforms:{circleScale:{value:1.1},circleFade:{value:0},circleOpacity:{value:.5},loadingAngle:{value:0},loadingOpacity:{value:0},opacity:{value:0},disable:{value:0}}}))),this.add(this.hitTestMesh),this.add(this.ringMesh),this.add(this.panoMesh),this.renderOrder=1e4,this.needsRender=!0}setProgress(e){this.progress=e,this.setLoading(e>0)}setOpacity(e){this.opacity!==e&&(this.opacity=e=clamp$1(e,0,1),this.opacityMotion.set({opacity:e},30).catch(noop))}setCurrent(e){if(this.current!==e){if(e)this.currentMotion.setKeyframes([{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}}],1500).catch(noop);else{let e=[{progress:0,value:Object.assign({},this.currentMotion.value)},{progress:1,value:{ringScale:1.1,ringOpacity:0,circleFade:0,circleOpacity:.85,circleScale:1}}];this.currentMotion.setKeyframes(e,200).catch(noop)}this.current=e}}setLoading(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):this.loadingMotion.set({opacity:0},0).catch(noop),this.loading=e,this.disabled===!0&&this.setDisabled(!1),this.needsRender=!0)}setDisabled(e){this.disabled!==e&&(this.disabled=e,this.loading===!0&&this.setLoading(!1),this.disableMotion.set({opacity:e?1:0},300).catch(noop),this.needsRender=!0)}tap(){return Promise.resolve()}updateTime(e,t){this.opacityMotion.update(e),this.currentMotion.update(e),this.loadingMotion.update(e);let n=this.opacityMotion.value.opacity;this.visible=n!==0;let{ringScale:r,ringOpacity:o,circleFade:s,circleOpacity:c,circleScale:l}=this.currentMotion.value;this.ringMesh.scale.set(r,1,r),this.ringMesh.material.uniforms.opacity.value=o*n,this.panoMesh.material.uniforms.opacity.value=n,this.panoMesh.material.uniforms.circleOpacity.value=c,this.panoMesh.material.uniforms.circleScale.value=l,this.panoMesh.material.uniforms.circleFade.value=s,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}dispose(){this.hitTestMesh.material.dispose(),this.ringMesh.material.dispose(),this.panoMesh.material.dispose()}},ACTIVE_TO_CURRENT_DELAY=1500,defaultVRPanoramaControllerCustomInitArgs=Object.assign({},omit(defaultPanoramaControllerCustomInitArgs,[`maxLatitude`,`minLatitude`])),VRPanoramaController=class e extends PanoramaController{static parseArgs(t){if(t instanceof e)return t;let n=Object.assign(Object.assign({},t),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2});return super.parseArgs(n)}static initAnimationEndState(e){let t=this.parseArgs(e),n=super.initAnimationEndState(t);return Object.assign(Object.assign({},n),{mode:`VRPanorama`})}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`VRPanorama`,this.cardboard=new Cardboard(this.renderer);let r=createHelper();this.helperElement=r;let o=new Hammer(r);this.element.parentNode&&(this.element.parentNode.insertBefore(r,this.element),this.updateHelperElementSize(),o.on(`tap`,()=>this.emit(`vr.requestExit`,createEvent(`vr.requestExit`,{})))),this.destroyHelper=()=>{o.destroy(),r.parentNode&&r.parentNode.removeChild(r),this.helperElement=void 0}}updateConfiguration(e){return super.updateConfiguration(Object.assign(Object.assign({},e),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2}))}destroy(){super.destroy(),this.cardboard.dispose(),this.destroyHelper()}isReady(){return!1}updateRenderSize(){this.needsRender=!0}updateCamera(e,t,n){return Promise.resolve()}updateCameraWithKeyframes(e,t,n){return Promise.resolve()}updateTime(e,t,...n){var r,o,s,c,l,u;if(this.destroyed)return;this.updateHelperElementSize(),this.userAction=!0,this.needsRender=!0;let d={},f={},p=this.locationMotion.keyframes[0],m=this.locationMotion.keyframes[this.locationMotion.keyframes.length-1],[h,g]=this.locationMotion.getKeyFrameSegment(e),_=this.panoResourceFromLocationMotionKeyframe(h),v=this.panoResourceFromLocationMotionKeyframe(g),y=this.panoResourceFromLocationMotionKeyframe(p),b=this.panoResourceFromLocationMotionKeyframe(m),S=!1;if(this.modelAlphaMotion.ended===!1&&(this.modelAlphaMotion.update(e),d.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);let t=this.locationMotion.value.count-g.value.count+1,n=new three.Vector3().copy(_.position),s=new three.Vector3().copy(v.position);if(d.progress=t,t>=.01&&t<=.99&&(d.progress=clamp$1(v.effectEasing(t),.01,.99)),v.panoPicture&&(t<1?_.panoPicture&&(d.pano0=_.panoPicture):d.pano0=v.panoPicture,d.pano1=v.panoPicture),v.effect===`montage`?d.transition=`BLACK`:v.effect===`spread`?d.transition=`SPREAD`:d.transition=`FADE`,v.effect===`zoomin`||v.effect===`zoomout`?d.progress=Math.pow(t,3):v.effect===`model`&&this.camera.pose.distance<.01&&(d.modelAlpha=1-Math.pow(clamp$1(Math.abs(t-.5)*2,0,1),4)),t<1&&v.effect!==`fly`){if(d.pano0&&_.panoPicture){let e={panoId:d.pano0.panoId,map:d.pano0.map,mapHistogram:d.pano0.mapHistogram,mapSize:d.pano0.mapSize,zoom:d.pano0.zoom,matrix:_.panoPicture.matrix.clone().setPosition(v.position)},t=this.panoPictureObserverMap.get(d.pano0);t&&this.panoPictureObserverMap.set(e,t),d.pano0=e}n.copy(s),S=!0}f.distance=this.locationMotion.value.distance,f.offset=new three.Vector3(n.x+(s.x-n.x)*t,n.y+(s.y-n.y)*t,n.z+(s.z-n.z)*t);let c=[],l=[];for(let e of this.locationMotion.keyframes){let{key:t,progress:n}=e;t!==void 0&&(c.push(t),n>this.locationMotion.progress&&l.push(t))}for(let e of Object.keys(this.panoResources)){if(l.indexOf(e)>=0)continue;let t=this.panoResources[e];if(t.panoPicture){let e=t.panoPicture.map;if(e){if(e===((r=d.pano0)==null?void 0:r.map)||e===((o=d.pano1)==null?void 0:o.map))continue;e.dispose(),t.panoPicture=null}}c.indexOf(e)>=0||delete this.panoResources[e]}this.currentPano=panoParse(v.panoId),this.emit(`pano.moving`,createEvent(`pano.moving`,{userAction:this.userAction,prevPano:panoParse(y.panoId),state:Object.assign(Object.assign(Object.assign(Object.assign({},panoParse(b.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),f),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(d)===!1&&this.modelScene.parameter.set(d),f.offset&&this.camera.position.copy(f.offset);let C=this.camera.pose.longitude,w=this.camera.pose.latitude;this.camera.quaternion.fromArray(this.cardboard.sensor.getOrientation()),this.camera.computePose(),(C!==this.camera.pose.longitude||w!==this.camera.pose.latitude)&&(this.cameraMotion.set(pick(this.camera.pose,[`longitude`,`latitude`]),0).catch(noop),this.emit(`camera.update`,createEvent(`camera.update`,{userAction:!0,state:Object.assign(Object.assign(Object.assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose))}))),this.works.getObserver(this.currentPano);let T=this.works.getObserver(_.panoId),E=this.works.getObserver(v.panoId),D=new Map;if(T)for(let e of T.accessibleNodes){let t=T.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});D.set(e,t)}}if(E)for(let e of E.accessibleNodes){let t=E.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});D.set(e,t)}}if(this.panoMeshes.forEach((e,t)=>{let n=D.get(t);n?(e.position.copy(n.position).applyMatrix4(n.work.transform),D.delete(t)):(this.helper.remove(e),e.dispose(),this.panoMeshes.delete(t))}),D.forEach((e,t)=>{let n=new PanoSphereMesh;n.position.copy(e.position).applyMatrix4(e.work.transform),e.position.distanceTo(e.standingPosition)>this.aerialObserverMinHeight?n.scale.setScalar(15):n.scale.setScalar(1),this.panoMeshes.set(t,n),this.helper.add(n),D.delete(t)}),this.camera.pose.distance>.1||S?this.panoMeshes.forEach((n,r)=>{n.setOpacity(0),n.updateTime&&n.updateTime(e,t),n.visible=!1}):this.panoMeshes.forEach((e,t)=>{let n=panoParse(t),r=this.works.getObserver(n);if(!r)return;if(!r.loadable&&!r.active){e.setOpacity(0);return}let o=e.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);o<.05?e.setOpacity(0):e.setOpacity(clamp$1(1.5/o,0,1)),panoEqual(this.currentPano,n)&&e.setOpacity(0),e.lookAt(this.camera.position)}),this.locationMotion.ended){let n=this.intersect(e);this.panoMeshes.forEach((r,o)=>{r.setCurrent(r===n),r.updateTime&&r.updateTime(e,t)})}{let e=(s=this.modelScene.parameter.progress)==null?1:s,t=Math.round(e),n=this.modelScene.parameter.pano0,r=this.modelScene.parameter.pano1,o=t===0?n:r,l;if(o&&(l=this.works.getObserver(o.panoId),l||(l=this.panoPictureObserverMap.get(o))),this.tiling.appearDuration=this.tileAppearDuration,this.tiling.maxRequest=e<(canUseNativeImageBitmap()?.6:.99)?0:this.tileMaxRequest,this.tiling.imageOptions=this.imageOptions,!l||!o||this.tileLevelForFov===!1||this.camera.perspToOrtho.x>0){this.tiling.setObserver(null);let e={renderer:this.renderer,resolution:this.camera.resolution,pixelRatio:this.camera.pixelRatio,time:this.camera.time,cameraMatrix:this.camera.matrixWorld,cameraProjectionMatrix:this.camera.projectionMatrix,panoMap:null,panoMatrix:new three.Matrix4,panoZoom:1,minLevel:0,level:0};this.tiling.update(e),this.modelScene.parameter.set(`refinedScreen`,null)}else{let e=getImageSizeLevel(o.mapSize),s=e+1,u=new three.Vector2().copy(this.camera.resolution).multiplyScalar(this.camera.pixelRatio),d=Math.floor(this.tileLevelForFov(this.camera.fov,u)),f=d>e?d:0;this.tiling.setObserver(l);let p={renderer:this.renderer,resolution:this.camera.resolution,pixelRatio:this.camera.pixelRatio,time:this.camera.time,cameraMatrix:this.camera.matrixWorld,cameraProjectionMatrix:this.camera.projectionMatrix,panoMap:o.map,panoMatrix:o.matrix,panoZoom:o.zoom,minLevel:s,level:f},m=this.tiling.update(p),h={map:this.tiling.renderTarget.texture,matrixInverse:this.tiling.camera.matrixWorldInverse,projectionMatrix:this.tiling.camera.projectionMatrix,pano:t,opacity:(n==null?void 0:n.panoId)===(r==null?void 0:r.panoId)?1:easeInQuart(Math.abs(((c=this.modelScene.parameter.progress)==null?0:c)-.5)*2)},g=this.modelScene.parameter.refinedScreen;(m||h.pano!==(g==null?void 0:g.pano)||h.opacity!==(g==null?void 0:g.opacity))&&this.modelScene.parameter.set(`refinedScreen`,h)}}this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e);{let e=v.effect,{pano0:t,pano1:n}=this.modelScene.parameter;if(t&&n&&t!==n&&(e===`fly`||e===`model`)&&this.flyEffectUseDepthBuffer){if(((l=this.modelScene.parameter.pano0Depth)==null?void 0:l.panoId)!==t.panoId||((u=this.modelScene.parameter.pano1Depth)==null?void 0:u.panoId)!==n.panoId){let e=500,r=512;this.pano0DepthCubeRenderTarget?this.pano0DepthCubeRenderTarget.width!==512&&this.pano0DepthCubeRenderTarget.setSize(512,512):this.pano0DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1}),this.pano1DepthCubeRenderTarget?this.pano1DepthCubeRenderTarget.width!==512&&this.pano1DepthCubeRenderTarget.setSize(512,512):this.pano1DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1});let o=new three.CubeCamera(this.camera.near,this.camera.far,this.pano0DepthCubeRenderTarget);o.matrix.copy(t.matrix),o.matrixWorld.copy(o.matrix),o.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,o,500);let s=new three.CubeCamera(this.camera.near,this.camera.far,this.pano1DepthCubeRenderTarget);s.matrix.copy(n.matrix),s.matrixWorld.copy(s.matrix),s.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,s,500),this.modelScene.parameter.set({pano0Depth:{panoId:t.panoId,map:this.pano0DepthCubeRenderTarget.texture,mapSize:this.pano0DepthCubeRenderTarget.width,maxDepth:500},pano1Depth:{panoId:n.panoId,map:this.pano1DepthCubeRenderTarget.texture,mapSize:this.pano1DepthCubeRenderTarget.width,maxDepth:500}})}}else this.modelScene.parameter.set({pano0Depth:null,pano1Depth:null}),this.flyEffectUseDepthBuffer||(this.pano0DepthCubeRenderTarget&&(this.pano0DepthCubeRenderTarget.dispose(),this.pano0DepthCubeRenderTarget=void 0),this.pano1DepthCubeRenderTarget&&(this.pano1DepthCubeRenderTarget.dispose(),this.pano1DepthCubeRenderTarget=void 0))}}render(){return this.renderer.setRenderTarget(null),this.renderer.setScissorTest(!1),this.cardboard.render(this.scene,this.camera),!0}setCamera(e={}){}destroyHelper(){}updateHelperElementSize(){if(!this.helperElement)return;let e=new three.Vector2(this.element.offsetWidth,this.element.offsetHeight),t=e.x*this.viewport.left,n=e.y*(1-this.viewport.bottom-this.viewport.height),r=e.x*this.viewport.width,o=e.y*this.viewport.height;this.helperElement.style.marginLeft!==t+`px`&&(this.helperElement.style.marginLeft=t+`px`),this.helperElement.style.marginTop!==n+`px`&&(this.helperElement.style.marginTop=n+`px`),this.helperElement.style.width!==r+`px`&&(this.helperElement.style.width=r+`px`),this.helperElement.style.height!==o+`px`&&(this.helperElement.style.height=o+`px`)}intersect(e){var t,n;if(this.locationMotion.ended===!1){this.intersectMesh.visible=!1,this.activePanoMesh=void 0,this.activeTime=void 0;return}if(this.activePanoMesh&&this.activeTime&&e-this.activeTime>ACTIVE_TO_CURRENT_DELAY){let e=this.activePanoMesh,t=null;return this.panoMeshes.forEach((n,r)=>{n===e&&(t=r)}),t!==null&&this.moveToPano(panoParse(t),{},!0),this.activePanoMesh=void 0,this.activeTime=void 0,e}let r=this.camera.getDirection(new three.Vector3),o=new three.Raycaster(this.camera.position,r);o.params.Points={threshold:.1},o.firstHitOnly=!0,o.floorIndex=-1;let s,c=[],l=this.works.getObserver(this.currentPano),u=l?l.accessibleNodes.map(e=>panoStringify({panoIndex:e,workCode:l.work.workCode})):[];for(let e of u){let r=this.panoMeshes.get(e);if(r){let[e]=o.intersectObject((t=r.hitTestMesh)==null?r:t,!0);if(e){let t=(n=l==null?void 0:l.floorIndex)==null?0:n;c.push({panoMesh:r,intersection:Object.assign({floorIndex:t,floor:t},e)})}}}let[d]=c.sort((e,t)=>e.intersection.distance-t.intersection.distance);d?(s=d.intersection,this.activePanoMesh!==d.panoMesh&&(this.activePanoMesh=d.panoMesh,this.activeTime=e),this.intersectMesh.position.copy(d.panoMesh.position),this.intersectMesh.lookAt(this.camera.position)):(this.activePanoMesh=void 0,this.activeTime=void 0),s||(s=this.modelScene.intersectRaycaster(o)[0]);let f=createEvent(`intersect.update`,{raycaster:o,intersection:s==null?null:s,object:this.intersectMesh});if(this.emit(`intersect.update`,f),f.defaultPrevented){this.hideIntersectMesh();return}if(s&&s.face){let e=s.face.normal,t=new three.Quaternion;t.setFromUnitVectors(new three.Vector3(0,0,1),e),this.intersectMesh.quaternion.copy(t);let n=s.point.clone();this.intersectMesh.position.copy(n),d?this.intersectMesh.visible=!1:this.intersectMesh.visible=!0}else this.intersectMesh.visible=!1;return d==null?void 0:d.panoMesh}onPanGesture(){}onTapGesture(){}onPinchGesture(){}onMouseMove(){}onMouseOut(){}},HUMAN_EYE_POSITION=new three.Vector3(0,1.6,0),scratchObserverBox$1=new three.Box3,scratchVector3$2=new three.Vector3,defaultModelControllerCustomInitArgs=Object.assign({},defaultPanoramaLikeControllerCustomInitArgs),ModelController=class e extends PanoramaLikeController{static parseArgs(t){return t instanceof e?t:super.parseArgs(t)}static initAnimationEndState(e){var t,n,r,o,s,c;let l=this.parseArgs(e),u=l.works,{state:d,currentState:f}=e.initial,p=typeof d.panoIndex==`number`?{workCode:(r=(t=d.workCode)==null?(n=l.works[0])==null?void 0:n.workCode:t)==null?``:r,panoIndex:d.panoIndex}:{workCode:f.workCode,panoIndex:f.panoIndex},m=u.getObserver(p),h=clamp$1((o=d.fov)==null?!m||isFristPersonMode(f.mode)?f.fov:l.defaultFov:o,l.minFov,l.maxFov),g=(s=d.longitude)==null?f.longitude:s,_=clamp$1(typeof l.minLatitude==`function`?l.minLatitude(h):l.minLatitude,-Math.PI/2,Math.PI/2),v=clamp$1(typeof l.maxLatitude==`function`?l.maxLatitude(h):l.maxLatitude,-Math.PI/2,Math.PI/2),y=clamp$1((c=d.latitude)==null?!m||isFristPersonMode(f.mode)?f.latitude:l.defaultLatitude:c,_,v),b=new three.Vector3;if(l.initial.state.offset)b.copy(l.initial.state.offset);else if(m)b.copy(m.position).applyMatrix4(m.work.transform);else{let e=coordinatesToVector(f).setLength(f.distance);b.copy(l.initial.currentState.offset).sub(e)}return{workCode:p.workCode,panoIndex:p.panoIndex,mode:`Model`,longitude:g,latitude:y,fov:h,offset:b,distance:0}}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`Model`,this.locationMotion=new Motion({x:this.camera.pose.offset.x,y:this.camera.pose.offset.y,z:this.camera.pose.offset.z,distance:this.camera.pose.distance}),this.modelAlphaMotion=new Motion({modelAlpha:this.modelScene.parameter.resolveValue().modelAlpha}),this.perspToOrthoMotion=new Motion({perspToOrtho:this.camera.perspToOrtho.x})}updateConfiguration(e){return super.updateConfiguration(e)}destroy(){super.destroy(),this.locationMotion.dispose()}isReady(){return this.locationMotion.ended===!1?!1:super.isReady()}updateWork(t,n,r,o){this.works=t;let s=e.initAnimationEndState(Object.assign(Object.assign({},this),{initial:{currentState:Object.assign(Object.assign({},this.currentPano),this.camera.pose),duration:r.duration,effect:r.effect,state:n,userAction:o}}));return(s.workCode!==this.currentPano.workCode||s.panoIndex!==this.currentPano.panoIndex||s.longitude!==this.cameraMotion.value.longitude||s.latitude!==this.cameraMotion.value.latitude||s.fov!==this.cameraMotion.value.fov)&&this.moveToPosition(s.offset,{duration:0,longitude:s.longitude,latitude:s.latitude,fov:s.fov},o),!0}updateCamera(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r={},o={};return r.distance=0,e.offset!==void 0&&(r.x=e.offset.x,r.y=e.offset.y,r.z=e.offset.z),e.longitude!==void 0&&(o.longitude=e.longitude),e.latitude!==void 0&&(o.latitude=e.latitude),e.fov!==void 0&&(o.fov=e.fov),this.locationMotion.set(r,t).catch(noop),this.cameraMotion.set(o,t).catch(noop)})}updateCameraWithKeyframes(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r=[],o=[];for(let t of e)r.push({key:t.key,progress:t.progress,value:{distance:0,x:t.value.offset.x,y:t.value.offset.x,z:t.value.offset.x}}),o.push({key:t.key,progress:t.progress,value:{longitude:t.value.longitude,latitude:t.value.latitude,fov:t.value.fov}});return this.locationMotion.setKeyframes(r,t).catch(noop),this.cameraMotion.setKeyframes(e,t)})}updateTime(e,t,...n){if(this.destroyed)return;let r={},o={};if(this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),r.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.modelScene.parameter.modelAlpha===0&&this.modelScene.parameter.progress!==1){let{pano0:e,pano1:t}=this.modelScene.parameter;e&&e.map!==(t==null?void 0:t.map)&&e.map.dispose(),r.progress=1,r.pano0=r.pano1=t}if(this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),!this.locationMotion.ended){this.locationMotion.update(e),o.distance=this.locationMotion.value.distance,o.offset=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z);let t=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),n=[];for(let e of this.works){let r=this.modelScene.models.find(t=>t.work===e);if(!(!r||r.visible===!1)&&!(e.observers.length<=0)&&(scratchObserverBox$1.copy(e.observerBox).expandByScalar(10).applyMatrix4(e.transform),scratchObserverBox$1.containsPoint(t)))for(let t of e.observers)n.push(t)}let r=arrayMin(n,e=>scratchVector3$2.copy(e.position).applyMatrix4(e.work.transform).distanceTo(t));this.currentPano=r?{workCode:r.work.workCode,panoIndex:r.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(r)||this.modelScene.parameter.set(r),isEmptyObject(o)||this.setCamera(o);let s=this.works.getObserver(this.currentPano);if(this.intersectMesh&&this.intersectMesh.parent&&s&&s.position.y-s.standingPosition.y>10){let e=clamp$1(this.camera.position.distanceTo(this.intersectMesh.position)*(2*Math.tan(.5*this.camera.fov/180*Math.PI))/5,.5);this.intersectMesh.scale.setScalar(e)}else this.intersectMesh.scale.setScalar(1)}initAnimation(){return this.destroyed?Promise.resolve():new Promise(t=>{let{state:n,currentState:r,duration:o,userAction:s}=this.initial;this.userAction=s;let c=e.initAnimationEndState(this),l={modelAlpha:1},u={perspToOrtho:0},d={longitude:c.longitude,latitude:c.latitude,fov:c.fov,duration:o,moveStartCallback:e=>{this.perspToOrthoMotion.set(u,o).catch(noop),this.modelAlphaMotion.set(l,o).catch(noop),this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:e,userAction:this.userAction}))},moveEndCallback:e=>{this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:e,userAction:this.userAction})),t()},moveCancelCallback:()=>{let e=this.currentPano,n=Object.assign(Object.assign({},e),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance});this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:n,userAction:this.userAction})),t()}};this.moveToPosition(c.offset,d,s)})}getTargetState(){let e=this.cameraMotion.getKeyFrameSegment(now())[1],t=this.locationMotion.getKeyFrameSegment(now())[1];return Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:new three.Vector3(t.value.x,t.value.y,t.value.z),distance:t.value.distance})}moveToPano(e,t={},n){let r=this.works.getObserver(e);if(r){let e=new three.Vector3().copy(r.position).applyMatrix4(r.work.transform);this.moveToPosition(e,t,n)}}moveToPosition(e,t={},n){var r,o,s;this.userAction=n,this.stopMomentumMovement();let c=now(),l=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),u=l.distanceTo(e),d=this.locationMotion.getProgressVelocity(c),f=0;for(let e=1;e<this.locationMotion.keyframes.length;e++){let{x:t,y:n,z:r}=this.locationMotion.keyframes[e-1].value,{x:o,y:s,z:c}=this.locationMotion.keyframes[e].value;f+=Math.sqrt(Math.pow(o-t,2)+Math.pow(s-n,2)+Math.pow(c-r,2))}let p=u===0?0:d*f/u,m=this.calculateMovingDuration(t.duration,u),h={x:e.x,y:e.y,z:e.z,distance:0},g={longitude:t.longitude,latitude:t.latitude,fov:t.fov},_=[];for(let e of this.works){let t=this.modelScene.models.find(t=>t.work===e);if(!(!t||t.visible===!1)&&!(e.observers.length<=0)&&(scratchObserverBox$1.copy(e.observerBox).expandByScalar(10).applyMatrix4(e.transform),scratchObserverBox$1.containsPoint(l)))for(let t of e.observers)_.push(t)}let v=arrayMin(_,e=>scratchVector3$2.copy(e.position).applyMatrix4(e.work.transform).distanceTo(l)),y=v?{workCode:v.work.workCode,panoIndex:v.panoIndex}:{workCode:``,panoIndex:0},b=Object.assign(Object.assign({},y),{mode:this.mode,longitude:(r=g.longitude)==null?this.camera.pose.longitude:r,latitude:(o=g.latitude)==null?this.camera.pose.latitude:o,fov:(s=g.fov)==null?this.camera.pose.fov:s,offset:e.clone(),distance:0}),S=this.currentPano;this.emit(`pano.moveTo`,createEvent(`pano.moveTo`,{options:t,prevPano:S,progress:0,state:b,userAction:this.userAction,error:null})),t.moveStartCallback&&t.moveStartCallback(b),this.cameraMotion.set(g,m).catch(noop),this.locationMotion.set(h,m,p).then(()=>{for(let e of this.modelScene.children)e instanceof Model&&e.show();let e=Object.assign(Object.assign(Object.assign({},y),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`pano.arrived`,createEvent(`pano.arrived`,{options:t,prevPano:S,progress:0,state:e,userAction:this.userAction,error:null})),t.moveEndCallback&&t.moveEndCallback(e)},()=>{t.moveCancelCallback&&t.moveCancelCallback(),this.emit(`pano.cancel`,createEvent(`pano.cancel`,{options:t,prevPano:S,progress:0,state:b,userAction:this.userAction,error:null}))})}onTapGesture(e){let t=e.center.raycaster;this.stopMomentumMovement();let[n]=this.modelScene.intersectRaycaster(t);if(n&&n.face){let e=n.face.normal,t=n.point;if(new three.Vector3(0,1,0).angleTo(e)>Math.PI/3){let r=new three.Raycaster;r.firstHitOnly=!0;let o=e.clone().setLength(.3).add(t);r.set(o,new three.Vector3(0,-1,0)),n=this.modelScene.intersectRaycaster(r)[0]}}if(n){let t=new three.Vector3().copy(n.point).add(HUMAN_EYE_POSITION),r=[];for(let e of this.works){let n=this.modelScene.models.find(t=>t.work===e);if(!(!n||n.visible===!1)&&!(e.observers.length<=0)&&(scratchObserverBox$1.copy(e.observerBox).expandByScalar(10).applyMatrix4(e.transform),scratchObserverBox$1.containsPoint(t)))for(let t of e.observers)r.push(t)}let[o,s]=arrayMin(r,e=>scratchVector3$2.copy(e.position).applyMatrix4(e.work.transform).distanceTo(t),!0);o&&s<5&&(t.y=scratchVector3$2.copy(o.position).applyMatrix4(o.work.transform).y),e.state.offset.copy(t),e.state.distance=0,this.emit(`gesture.tap`,e),e.defaultPrevented||this.moveToPosition(t,{},!0)}else this.emit(`gesture.tap`,e),e.defaultPrevented||this.cameraBounce()}},scratchObserverBox=new three.Box3,scratchVector3$1=new three.Vector3,minDistance=.5,PANGESTURE_FORWARD_ANGLE=Math.PI/7,defaultMapviewControllerCustomInitArgs={defaultLongitude:Math.PI/4,defaultLatitude:Math.PI/4,defaultDistance:150,maxLatitude:Math.PI/2,minLatitude:0,cameraType:`auto`,cameraFence:null,intersectMeshCreator:()=>new IntersectMesh},MapviewController=class e extends BaseController{static parseArgs(t){var n,r,o,s,c,l,u,d;if(t instanceof e)return t;let f=super.parseArgs(t);return Object.assign(Object.assign({},f),{defaultLongitude:(n=t.defaultLongitude)==null?defaultMapviewControllerCustomInitArgs.defaultLongitude:n,defaultLatitude:(r=t.defaultLatitude)==null?defaultMapviewControllerCustomInitArgs.defaultLatitude:r,defaultDistance:(o=t.defaultDistance)==null?defaultMapviewControllerCustomInitArgs.defaultDistance:o,maxLatitude:(s=t.maxLatitude)==null?defaultMapviewControllerCustomInitArgs.maxLatitude:s,minLatitude:(c=t.minLatitude)==null?defaultMapviewControllerCustomInitArgs.minLatitude:c,cameraType:(l=t.cameraType)==null?defaultMapviewControllerCustomInitArgs.cameraType:l,cameraFence:(u=t.cameraFence)==null?defaultMapviewControllerCustomInitArgs.cameraFence:u,intersectMeshCreator:(d=t.intersectMeshCreator)==null?defaultMapviewControllerCustomInitArgs.intersectMeshCreator:d})}static distanceFromModel(e,t,n){let r=e.boundingBox,o=r.isEmpty()?10:Math.pow(Math.pow(r.max.x-r.min.x+1,2)+Math.pow(r.max.y-r.min.y+1,2)+Math.pow(r.max.z-r.min.z+1,2),1/2);o=isNaN(o)||!isFinite(o)?1:o;let s=o/2/Math.tan(Math.PI*t/360);return n<1&&(s/=n),isNaN(s)||!isFinite(s)?o:s}static initAnimationEndState(t){var n,r,o,s,c,l,u;let d=this.parseArgs(t),f=d.works,p=d.modelScene,{state:m,currentState:h}=t.initial,g=typeof m.panoIndex==`number`?{workCode:(o=(n=m.workCode)==null?(r=d.works[0])==null?void 0:r.workCode:n)==null?``:o,panoIndex:m.panoIndex}:{workCode:h.workCode,panoIndex:h.panoIndex},_=(s=m.fov)==null?60:s,v=clamp$1(typeof d.minLatitude==`function`?d.minLatitude(_):d.minLatitude,-Math.PI/2,Math.PI/2),y=clamp$1(typeof d.maxLatitude==`function`?d.maxLatitude(_):d.maxLatitude,-Math.PI/2,Math.PI/2),b=clamp$1((c=m.latitude)==null?isThirdPersonMode(h.mode)?h.latitude:d.defaultLatitude:c,v,y),S=e.distanceFromModel(d.modelScene,_,d.camera.aspect),C=new three.Vector3,w=(l=m.distance)==null?Math.min(d.defaultDistance,S):l,T=(u=m.longitude)==null?isThirdPersonMode(h.mode)?h.longitude:d.defaultLongitude:u;if(m.offset)C.copy(m.offset);else{let e=f.getObserver(g);d.defaultDistance<S&&e?(C.copy(e.position).applyMatrix4(e.work.transform),m.longitude===void 0&&(T=h.longitude)):(p.boundingBox.getCenter(C),w=S)}return Object.assign(Object.assign({},g),{mode:`Mapview`,longitude:T,latitude:b,fov:_,offset:C,distance:w})}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`Mapview`,this.defaultLongitude=n.defaultLongitude,this.defaultLatitude=n.defaultLatitude,this.defaultDistance=n.defaultDistance,this.maxLatitude=n.maxLatitude,this.minLatitude=n.minLatitude,this.cameraType=n.cameraType,this.cameraFence=n.cameraFence,this.locationMotion=new Motion({x:this.camera.pose.offset.x,y:this.camera.pose.offset.y,z:this.camera.pose.offset.z,distance:this.camera.pose.distance}),this.modelAlphaMotion=new Motion({modelAlpha:this.modelScene.parameter.resolveValue().modelAlpha}),this.perspToOrthoMotion=new Motion({perspToOrtho:this.camera.perspToOrtho.x}),this.pendingTextureId=null,this.textureLoader=new TextureLoader,this.intersectMeshCreator=n.intersectMeshCreator,this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=`intersect`,this.intersectMesh.visible=!1,this.helper.add(this.intersectMesh)}updateConfiguration(e){if(super.updateConfiguration(e)===!1)return!1;if(e.defaultLongitude!==void 0&&this.defaultLongitude!==e.defaultLongitude&&(this.defaultLongitude=e.defaultLongitude),e.defaultLatitude!==void 0&&this.defaultLatitude!==e.defaultLatitude&&(this.defaultLatitude=e.defaultLatitude),e.defaultDistance!==void 0&&this.defaultDistance!==e.defaultDistance&&(this.defaultDistance=e.defaultDistance),e.maxLatitude!==void 0&&this.maxLatitude!==e.maxLatitude&&(this.maxLatitude=e.maxLatitude),e.minLatitude!==void 0&&this.minLatitude!==e.minLatitude&&(this.minLatitude=e.minLatitude),e.cameraType!==void 0&&this.cameraType!==e.cameraType&&(this.cameraType=e.cameraType),this.cameraFence instanceof three.Box3&&e.cameraFence instanceof three.Box3||this.cameraFence instanceof three.Sphere&&e.cameraFence instanceof three.Sphere?this.cameraFence.equals(e.cameraFence)||(this.cameraFence=e.cameraFence):e.cameraFence!==void 0&&(this.cameraFence=e.cameraFence),e.intersectMeshCreator!==void 0&&this.intersectMeshCreator!==e.intersectMeshCreator){this.intersectMeshCreator=e.intersectMeshCreator;let t=this.intersectMesh;this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=t.name,this.intersectMesh.visible=t.visible;let n=this.intersectMesh.parent;n&&n.add(this.intersectMesh),t.dispose()}return!0}destroy(){super.destroy(),this.pendingTextureId=null,this.locationMotion.dispose(),this.panState=void 0,this.intersectMesh.dispose(),this.helper.remove(this.intersectMesh)}isReady(){return this.locationMotion.ended===!1?!1:super.isReady()}updateWork(t,n,r,o){this.userAction=o,this.works=t;let s=e.initAnimationEndState(Object.assign(Object.assign({},this),{initial:{currentState:Object.assign(Object.assign({},this.currentPano),this.camera.pose),duration:r.duration,effect:r.effect,state:n,userAction:o}}));this.currentPano={workCode:s.workCode,panoIndex:s.panoIndex};let c={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};return(c.longitude!==this.cameraMotion.value.longitude||c.latitude!==this.cameraMotion.value.latitude||c.fov!==this.cameraMotion.value.fov)&&this.cameraMotion.set(c,r.duration).catch(noop),(l.x!==this.locationMotion.value.x||l.y!==this.locationMotion.value.y||l.z!==this.locationMotion.value.z||l.distance!==this.locationMotion.value.distance)&&this.locationMotion.set(l,r.duration).catch(noop),!0}updateModel(e){super.updateModel(e),this.hideIntersectMesh()}updateCamera(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r={},o={};return e.distance!==void 0&&(r.distance=e.distance),e.offset!==void 0&&(r.x=e.offset.x,r.y=e.offset.y,r.z=e.offset.z),e.longitude!==void 0&&(o.longitude=e.longitude),e.latitude!==void 0&&(o.latitude=e.latitude),e.fov!==void 0&&(o.fov=e.fov),this.locationMotion.set(r,t).catch(noop),this.cameraMotion.set(o,t).catch(noop)})}updateCameraWithKeyframes(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r=[],o=[];for(let t of e)r.push({key:t.key,progress:t.progress,value:{distance:t.value.distance,x:t.value.offset.x,y:t.value.offset.x,z:t.value.offset.x}}),o.push({key:t.key,progress:t.progress,value:{longitude:t.value.longitude,latitude:t.value.latitude,fov:t.value.fov}});return this.locationMotion.setKeyframes(r,t).catch(noop),this.cameraMotion.setKeyframes(e,t)})}updateTime(e,t){if(this.destroyed)return;let n={},r={};if(this.locationMotion.ended||(this.locationMotion.update(e),r.distance=this.locationMotion.value.distance,r.offset=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z)),this.cameraMotion.ended||(this.cameraMotion.update(e),r.longitude=this.cameraMotion.value.longitude,r.latitude=this.cameraMotion.value.latitude,r.fov=this.cameraMotion.value.fov),this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),n.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.modelScene.parameter.modelAlpha===0&&this.modelScene.parameter.progress!==1){let{pano0:e,pano1:t}=this.modelScene.parameter;e&&e.map!==(t==null?void 0:t.map)&&e.map.dispose(),n.progress=1,n.pano0=n.pano1=t}let o=0;if(this.cameraType===`auto`?o=Math.abs(Math.PI/2-this.cameraMotion.value.latitude)<.02||Math.abs(-Math.PI/2-this.cameraMotion.value.latitude)<.02?1:0:this.cameraType===`perspective`?o=0:this.cameraType===`orthographic`&&(o=1),this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho!==o&&this.perspToOrthoMotion.set({perspToOrtho:o},500).catch(noop),this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),isEmptyObject(n)||this.modelScene.parameter.set(n),isEmptyObject(r)||this.setCamera(r),this.cameraFence&&!this.panState&&!this.pinchState&&!this.mouseWheelState&&!this.inMomentumMovement&&this.locationMotion.ended&&this.perspToOrthoMotion.ended&&this.cameraMotion.ended){let e=coordinatesToVector(this.camera.pose,new three.Vector3),t=new three.Vector3().copy(this.camera.pose.offset).sub(e.clone().multiplyScalar(this.camera.pose.distance));if(this.cameraFence.distanceToPoint(t)>.01){let e=this.cameraFence.clampPoint(t,new three.Vector3),n=this.camera.pose.offset.clone().add(e).sub(t),r=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:n,distance:this.camera.pose.distance});this.fixFinalState(r),this.locationMotion.set({x:r.offset.x,y:r.offset.y,z:r.offset.z,distance:r.distance},300).catch(noop)}}if(this.intersectMesh&&this.intersectMesh.parent){let e=clamp$1(this.camera.position.distanceTo(this.intersectMesh.position)*(2*Math.tan(.5*this.camera.fov/180*Math.PI))/5,.5);this.intersectMesh.scale.setScalar(e)}else this.intersectMesh.scale.setScalar(1)}getTargetState(){let e=this.cameraMotion.getKeyFrameSegment(now())[1],t=this.locationMotion.getKeyFrameSegment(now())[1];return Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,distance:t.value.distance,offset:new three.Vector3(t.value.x,t.value.y,t.value.z)})}initAnimation(){return this.destroyed?Promise.resolve():new Promise(t=>{let{state:n,currentState:r,duration:o,userAction:s}=this.initial;this.userAction=s;let c=e.initAnimationEndState(this),l={longitude:c.longitude,latitude:c.latitude,fov:c.fov},u={x:c.offset.x,y:c.offset.y,z:c.offset.z,distance:c.distance};this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:c,userAction:this.userAction})),this.perspToOrthoMotion.set({perspToOrtho:0},o).catch(noop),this.modelAlphaMotion.set({modelAlpha:1},o/3).catch(noop),this.cameraMotion.set(l,o).catch(noop),this.locationMotion.set(u,o).then(()=>{this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:c,userAction:this.userAction}))},e=>{let t=Object.assign(Object.assign(Object.assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:t,userAction:this.userAction}))}).then(()=>{t()})})}getForwardObserverOrNot(e){let[t]=this.modelScene.intersectRaycaster(e);if(!t)return null;let n=[];for(let t of this.works){let r=this.modelScene.models.find(e=>e.work===t);if(!(!r||r.visible===!1)&&!(t.observers.length<=0)&&(scratchObserverBox.copy(t.observerBox).expandByScalar(10).applyMatrix4(t.transform),scratchObserverBox.containsPoint(e.ray.origin)||e.ray.intersectsBox(scratchObserverBox)))for(let e of t.observers)n.push(e)}let[r,o]=arrayMin(n,e=>scratchVector3$1.copy(e.standingPosition).applyMatrix4(e.work.transform).distanceTo(t.point),!0);return r&&o<Math.max(r.standingPosition.distanceTo(this.camera.position)/5,10)?r:null}coordinatesForOffset(e){let t=this.renderer.getSize(new three.Vector2);return{longitude:-2*e.x/(t.x*this.viewport.width),latitude:2*e.y/(t.y*this.viewport.height)}}requestMomentumMovement(e,t,n,r){if(this.inMomentumMovement===null)return;r=Math.max(r,1);let o=Object.assign({},n),s={longitude:0,latitude:0,x:0,y:0,z:0};for(let e=0;e<r;e++)o.longitude*=.996,o.latitude*=.996*.998,o.x*=.99,o.y*=.99,o.z*=.99,s.longitude+=o.longitude,s.latitude+=o.latitude,s.x+=o.x,s.y+=o.y,s.z+=o.z;let c=this.cameraMotion.value.fov,l=formatRad$1(this.cameraMotion.value.longitude+s.longitude),u=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(c):this.minLatitude,-Math.PI/2,Math.PI/2),d=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(c):this.maxLatitude,-Math.PI/2,Math.PI/2),f=clamp$1(this.cameraMotion.value.latitude+s.latitude,u,d),p=new three.Vector3(this.locationMotion.value.x+s.x,this.locationMotion.value.y+s.y,this.locationMotion.value.z+s.z),m=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:l,latitude:f,offset:p,fov:c,distance:this.locationMotion.value.distance}),h=e.state.offset.clone().sub(coordinatesToVector(e.state).setLength(m.distance)),g=!(Math.abs(o.longitude)>1e-4||Math.abs(o.latitude)>1e-4||Math.abs(o.x)>1e-4||Math.abs(o.y)>1e-4||Math.abs(o.z)>1e-4);(this.cameraFence?this.cameraFence.containsPoint(h):!0)===!1&&(g=!0);let _=createEvent(`gesture.momentum`,Object.assign(Object.assign({},e),{isFirst:t,isFinal:g,state:m}));if(this.emit(`gesture.create`,_),this.inMomentumMovement.event=_,this.emit(`gesture.momentum`,_),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:l,latitude:f},0).catch(noop),this.locationMotion.set({x:m.offset.x,y:m.offset.y,z:m.offset.z,distance:m.distance},0).catch(noop),g?this.inMomentumMovement=null:AnimationFrameLoop.shared.add((t,n)=>{this.requestMomentumMovement(e,!1,o,n)},!0))}fixFinalState(e){if(this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho===1)return;let t=coordinatesToVector(e,new three.Vector3),n=new three.Vector3().copy(e.offset).sub(t.clone().setLength(e.distance)),r=new three.Raycaster(n,t);r.params.Points={threshold:.1},r.firstHitOnly=!0,r.hitFilter=e=>e.distance>minDistance+r.near,r.near=this.camera.near,r.far=this.camera.far;let o;if(o=this.modelScene.intersectRaycaster(r)[0],o&&o.distance<this.camera.near&&(o=void 0),!o){let e=new three.Plane(new three.Vector3(0,1,0),-this.modelScene.boundingBox.min.y),t=r.ray.intersectPlane(e,new three.Vector3);if(t){let e=t.distanceTo(r.ray.origin);e<1e3&&e>=r.near&&(o={distance:e,floorIndex:0,floor:0,point:t,object:this.scene,face:null})}}if(!o){let r=Math.max(e.distance,3);o={distance:r,floorIndex:0,floor:0,point:n.clone().add(t.clone().setLength(r)),object:this.scene,face:null}}o.distance>=this.camera.near&&notSimilarValue(e.distance,o.distance)&&(e.distance=o.distance,e.offset=o.point)}onPanGesture(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();let t=e.pointers.length,n=this.panState,r=0,o=!1;e.pointerType===`mouse`&&(r=e.center.buttons,o=e.center.shiftKey),n&&r===0&&n.buttons!==0&&(r=n.buttons);let s=n==null?void 0:n.target;if(!s){let t=this.relativeClientPosition(e.center),n=this.createRaycasterFromCamera(t,this.camera);s=new three.Vector3().copy(n.ray.direction).multiplyScalar(3).add(n.ray.origin);let[r]=this.modelScene.intersectRaycaster(n);if(!r&&n.ray.direction.y<-.3){let e=new three.Plane(new three.Vector3(0,1,0),0),t=n.ray.intersectPlane(e,new three.Vector3);if(t){let e=t.distanceTo(n.ray.origin);e<1e4&&e>=n.near&&(r={distance:e,floorIndex:0,floor:0,point:t,object:this.scene})}}if(r)s.copy(r.point);else{let e=new three.Vector3().copy(this.camera.pose.offset).sub(this.camera.position).normalize(),t=new three.Plane().setFromNormalAndCoplanarPoint(e,this.camera.pose.offset);n.ray.intersectPlane(t,s)}}if(e.isFinal?this.panState=void 0:this.panState={target:s,buttons:r,pointerLength:t,defaultPrevented:e.defaultPrevented,x:e.center.x,y:e.center.y},n===void 0||n.pointerLength!==t){this.emit(`gesture.pan`,e);return}if(t>1||r===2||o){let t={x:e.center.x-n.x,y:e.center.y-n.y},r=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),o=coordinatesToVector(this.cameraMotion.value).setLength(this.locationMotion.value.distance).add(r),s=new three.Vector3().copy(o).sub(n.target).length();s*=Math.tan(this.camera.pose.fov/2*Math.PI/180);let c=this.renderer.getSize(new three.Vector2),l=2*t.x*s/c.y,u=2*t.y*s/c.y,d=new three.Vector3;d.setFromMatrixColumn(this.camera.matrix,0),d.multiplyScalar(-l),r.add(d),this.camera.pose.latitude<PANGESTURE_FORWARD_ANGLE?d.setFromMatrixColumn(this.camera.matrix,1):(d.setFromMatrixColumn(this.camera.matrix,0),d.crossVectors(this.camera.up,d)),d.multiplyScalar(u),r.add(d);let f=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:r,distance:this.camera.pose.distance});if(e.state=f,this.emit(`gesture.pan`,e),e.defaultPrevented){this.panState&&(this.panState.defaultPrevented=e.defaultPrevented);return}if(e.isFinal&&n.defaultPrevented)return;if(this.locationMotion.set({x:f.offset.x,y:f.offset.y,z:f.offset.z},0).catch(noop),e.isFinal&&(this.fixFinalState(f),Object.assign(e,{__fixFinalState:!0}),this.locationMotion.set({distance:f.distance,x:f.offset.x,y:f.offset.y,z:f.offset.z},0).catch(noop)),e.isFinal){let t=this.renderer.getSize(new three.Vector2),n=2*e.velocityX*s/t.y,r=2*e.velocityY*s/t.y,o=new three.Vector3,c=new three.Vector3;o.setFromMatrixColumn(this.camera.matrix,0),o.multiplyScalar(-n),c.add(o),this.camera.pose.latitude<PANGESTURE_FORWARD_ANGLE?o.setFromMatrixColumn(this.camera.matrix,1):(o.setFromMatrixColumn(this.camera.matrix,0),o.crossVectors(this.camera.up,o)),o.multiplyScalar(r),c.add(o),this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,{longitude:0,latitude:0,x:c.x,y:c.y,z:c.z},0)}}else{let t={x:e.center.x-n.x,y:e.center.y-n.y},r=this.coordinatesForOffset(t),o=formatRad$1(this.cameraMotion.value.longitude+r.longitude),s=this.camera.pose.fov,c=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(s):this.minLatitude,-Math.PI/2,Math.PI/2),l=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(s):this.maxLatitude,-Math.PI/2,Math.PI/2),u=clamp$1(this.cameraMotion.value.latitude+r.latitude,c,l);this.camera.aspect<1&&Math.abs(e.overallVelocityX)>.2&&Math.atan2(Math.abs(e.overallVelocityY),Math.abs(e.overallVelocityX))<Math.PI/6.923&&(u=this.cameraMotion.value.latitude);let d=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:o,latitude:u,fov:s,offset:this.camera.pose.offset,distance:this.camera.pose.distance});if(e.isFinal&&Object.assign(e,{__fixFinalState:!0}),e.state=d,this.emit(`gesture.pan`,e),e.defaultPrevented||e.isFinal&&n.defaultPrevented)return;if(e.isFinal?this.locationMotion.set({distance:d.distance,x:d.offset.x,y:d.offset.y,z:d.offset.z},0).catch(noop):this.cameraMotion.set({longitude:d.longitude,latitude:d.latitude},0).catch(noop),e.isFinal){let t=e.velocityX,n=e.velocityY;this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,Object.assign(Object.assign({},this.coordinatesForOffset({x:t,y:n})),{x:0,y:0,z:0}),0)}}}onPinchGesture(t){var n;if(!this.initAnimationIsReady)return;this.userAction=t.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();let r=(n=this.pinchState)==null?void 0:n.distance;if(t.isFirst){this.pinchState={x:t.center.x,y:t.center.y,scale:1,distance:this.locationMotion.value.distance};return}if(r===void 0)return;let o=this.modelScene.boundingBox.getCenter(new three.Vector3),s=e.distanceFromModel(this.modelScene,this.cameraMotion.value.fov,this.camera.aspect),c=clamp$1(r/t.scale,minDistance,1/0),l=t.state.offset.clone().sub(coordinatesToVector(t.state).setLength(c)),u=this.modelScene.boundingBox.containsPoint(l),d;if(!u&&this.pinchState&&this.pinchState.scale>t.scale&&o.distanceTo(l)>s?d=t.state.distance:(d=c,this.pinchState&&(this.pinchState.scale=t.scale)),t.state.distance=d,this.emit(`gesture.pinch`,t),!t.defaultPrevented&&(this.locationMotion.set({distance:t.state.distance},0).catch(noop),t.pointerType!==`mouse`&&(t.type=`gesture.pan`,this.onPanGesture(t)),t.isFinal)){if(!(`__fixFinalState`in t)){let e=t.state;this.fixFinalState(t.state);let n={x:e.offset.x,y:e.offset.y,z:e.offset.z,distance:e.distance};this.locationMotion.set(n,0).catch(noop)}this.panState=void 0,this.pinchState=void 0}}onMouseMove(e){var t,n;if(!this.intersectMesh.parent||this.panState||this.pinchState||this.mouseWheelState||(this.emit(`gesture.mousemove`,e),e.defaultPrevented))return;let r=e.center.raycaster;if(e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}let[o]=this.modelScene.intersectRaycaster(r),s=createEvent(`intersect.update`,{raycaster:r,intersection:o==null?null:o,object:this.intersectMesh});if(this.emit(`intersect.update`,s),s.defaultPrevented){this.hideIntersectMesh();return}if(o){let e=(n=(t=o.face)==null?void 0:t.normal)==null?new three.Vector3().copy(r.ray.direction).multiplyScalar(-1):n,s=e.clone(),c=o.point.clone();this.intersectMesh.position.copy(c);let l=c.clone().add(s);if(this.intersectMesh.lookAt(l),Math.abs(e.y)>.99){let e=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(e.z,e.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}onMouseWheel(t){if(this.initAnimationIsReady)if(this.userAction=t.userAction,this.stopMomentumMovement(),this.hideIntersectMesh(),t.isFinal){let e=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:this.cameraMotion.value.longitude,latitude:this.cameraMotion.value.latitude,fov:this.cameraMotion.value.fov,offset:new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),distance:this.locationMotion.value.distance});if(this.fixFinalState(e),this.emit(`gesture.mousewheel`,t),t.defaultPrevented)return;let n={x:e.offset.x,y:e.offset.y,z:e.offset.z,distance:e.distance};this.locationMotion.set(n,0).catch(noop)}else{let n=e.distanceFromModel(this.modelScene,this.cameraMotion.value.fov,this.camera.aspect),r=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),o=coordinatesToVector(this.cameraMotion.value,new three.Vector3).negate(),s=new three.Ray(r,o).intersectBox(this.modelScene.boundingBox,new three.Vector3);s&&(n+=s.distanceTo(r));let c=Math.max(this.locationMotion.value.distance-this.camera.near,0),l=t.center.delta/10*Math.max(c/5,.1);if(c<=n||l>0)if(this.locationMotion.value.distance-l>=minDistance){let e=this.locationMotion.value.distance-l;t.state.distance=e}else{let e=coordinatesToVector(this.cameraMotion.value);e.setLength(l),t.state.offset.add(e)}if(this.emit(`gesture.mousewheel`,t),t.defaultPrevented)return;this.locationMotion.set({distance:t.state.distance,x:t.state.offset.x,y:t.state.offset.y,z:t.state.offset.z},0).catch(noop)}}onTapGesture(e){var t;this.userAction=e.userAction,this.stopMomentumMovement();let n=e.center.raycaster,r=this.getForwardObserverOrNot(n);if(!r)this.emit(`gesture.tap`,e);else{let n={longitude:this.camera.pose.longitude,latitude:0},o=Object.assign(Object.assign({},e.state),{mode:`Panorama`,workCode:r.work.workCode,panoIndex:r.panoIndex,longitude:n.longitude,latitude:n.latitude,offset:r?r.position.clone():new three.Vector3,distance:0});if(e.state=o,this.emit(`gesture.tap`,e),!e.defaultPrevented&&(this.emit(`pano.select`,createEvent(`pano.select`,{prevPano:this.currentPano,state:o,userAction:e.userAction,options:n,progress:0,error:null})),r&&r.active)){let e=this.pendingTextureId=createUuid(),s=panoStringify({panoIndex:r.panoIndex,workCode:r.work.workCode}),c={right:r.images.work.getURL(r.images.right),left:r.images.work.getURL(r.images.left),up:r.images.work.getURL(r.images.up),down:r.images.work.getURL(r.images.down),front:r.images.work.getURL(r.images.front),back:r.images.work.getURL(r.images.back)},l=this.imageOptions.transform,u=Object.assign({key:`pano.${s}`},pick(this.imageOptions,[`format`,`size`,`quality`,`sharpen`,`forceUseExifOrientation`,`mappings`])),d=`pano:`+jsonHash([c,u,l]),f=this.modelScene.parameter,p;f.pano0&&f.pano0.map.name===d?p=f.pano0:f.pano1&&f.pano1.map.name===d&&(p=f.pano1),p?(f.pano0&&f.pano0.map!==p.map&&f.pano0.map.dispose(),f.pano1&&f.pano1.map!==p.map&&f.pano1.map!==((t=f.pano0)==null?void 0:t.map)&&f.pano1.map.dispose(),f.set({pano0:p,pano1:p}),this.emit(`pano.request`,createEvent(`pano.request`,{userAction:!0,prevPano:this.currentPano,progress:0,state:o,options:n,error:null}))):this.textureLoader.loadCubeTexture(c,{imageURL:{transform:l,options:u},format:three.RGBFormat,viaAjax:!0,fetcher:getFetcher(this.fiveId,r.work)},void 0,void 0,void 0,this.renderer).then(t=>{var c,l;let{body:u}=t;if(this.destroyed||this.pendingTextureId!==e){u.dispose();return}this.pendingTextureId=null,u.name=d;let p=Array.isArray(u.image)?u.image[0]:u.image,m=(c=p==null?void 0:p.width)==null?2048:c,h=new Histogram().formPixels(getRgbaDataFromCubeTexture(this.renderer,u,!0,sharedHistogramRgbaData).data),g={panoId:s,map:u,mapSize:m,mapHistogram:new three.Vector4().fromArray(h.toArray()),matrix:r.matrix.clone().premultiply(r.work.transform),zoom:1};f.pano0&&f.pano0.map.dispose(),f.pano1&&f.pano1.map!==((l=f.pano0)==null?void 0:l.map)&&f.pano1.map.dispose(),f.set({pano0:g,pano1:g}),this.emit(`pano.request`,createEvent(`pano.request`,{userAction:!0,prevPano:this.currentPano,progress:0,state:o,options:n,error:null}))}).catch(t=>{this.destroyed||this.pendingTextureId!==e||(this.pendingTextureId=null)})}}}onDblTapGesture(e){if(!this.initAnimationIsReady)return;this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();let t=e.state,n=e.center.raycaster,r=n.ray.origin.clone().add(n.ray.direction.clone().setLength(3)),o=1,s=3,c=1,[l]=this.modelScene.intersectRaycaster(n);if(l&&(r=l.point.clone(),c=l.distance>4/2?1:3),e.state.distance=c,e.state.offset=r,this.emit(`gesture.dbltap`,e),e.defaultPrevented)return;let u={x:t.offset.x,y:t.offset.y,z:t.offset.z,distance:t.distance};this.locationMotion.set(u,360).catch(noop),this.hideIntersectMesh()}hideIntersectMesh(){this.intersectMesh.visible===!0&&(this.intersectMesh.visible=!1,this.needsRender=!0)}};function isNil(e){return e==null}var _moveEvent={type:`move`},XRController=class{constructor(){this._targetRay=null,this._grip=null,this._hand=null,this._axes=[0,0]}getHandSpace(){return this._hand===null&&(this._hand=new three.Group,this._hand.matrixAutoUpdate=!1,this._hand.visible=!1,this._hand.joints={},this._hand.inputState={pinching:!1}),this._hand}getTargetRaySpace(){return this._targetRay===null&&(this._targetRay=new three.Group,this._targetRay.matrixAutoUpdate=!1,this._targetRay.visible=!1,this._targetRay.hasLinearVelocity=!1,this._targetRay.linearVelocity=new three.Vector3,this._targetRay.hasAngularVelocity=!1,this._targetRay.angularVelocity=new three.Vector3),this._targetRay}getGripSpace(){return this._grip===null&&(this._grip=new three.Group,this._grip.matrixAutoUpdate=!1,this._grip.visible=!1,this._grip.hasLinearVelocity=!1,this._grip.linearVelocity=new three.Vector3,this._grip.hasAngularVelocity=!1,this._grip.angularVelocity=new three.Vector3),this._grip}dispatchEvent(e){return this._targetRay!==null&&this._targetRay.dispatchEvent(e),this._grip!==null&&this._grip.dispatchEvent(e),this._hand!==null&&this._hand.dispatchEvent(e),this}disconnect(e){return this.dispatchEvent({type:`disconnected`,data:e}),this._targetRay!==null&&(this._targetRay.visible=!1),this._grip!==null&&(this._grip.visible=!1),this._hand!==null&&(this._hand.visible=!1),this}getAxes(){return this._axes}update(e,t,n){let r=null,o=null,s=null,c=this._targetRay,l=this._grip,u=this._hand;if(e&&e.gamepad&&e.gamepad.axes&&(this._axes=[e.gamepad.axes[2],e.gamepad.axes[3]]),e&&t.session.visibilityState!==`visible-blurred`)if(c!==null&&(r=t.getPose(e.targetRaySpace,n),r!==null&&(c.matrix.fromArray(r.transform.matrix),c.matrix.decompose(c.position,c.rotation,c.scale),r.linearVelocity?(c.hasLinearVelocity=!0,c.linearVelocity.copy(r.linearVelocity)):c.hasLinearVelocity=!1,r.angularVelocity?(c.hasAngularVelocity=!0,c.angularVelocity.copy(r.angularVelocity)):c.hasAngularVelocity=!1,this.dispatchEvent(_moveEvent))),u&&e.hand){s=!0;for(let r of e.hand.values()){let e=t.getJointPose(r,n);if(u.joints[r.jointName]===void 0){let e=new three.Group;e.matrixAutoUpdate=!1,e.visible=!1,u.joints[r.jointName]=e,u.add(e)}let o=u.joints[r.jointName];e!==null&&(o.matrix.fromArray(e.transform.matrix),o.matrix.decompose(o.position,o.rotation,o.scale),o.jointRadius=e.radius),o.visible=e!==null}let r=u.joints[`index-finger-tip`],o=u.joints[`thumb-tip`],c=r.position.distanceTo(o.position),l=.02,d=.005;u.inputState.pinching&&c>l+d?(u.inputState.pinching=!1,this.dispatchEvent({type:`pinchend`,handedness:e.handedness,target:this})):!u.inputState.pinching&&c<=l-d&&(u.inputState.pinching=!0,this.dispatchEvent({type:`pinchstart`,handedness:e.handedness,target:this}))}else l!==null&&e.gripSpace&&(o=t.getPose(e.gripSpace,n),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 c!==null&&(c.visible=r!==null),l!==null&&(l.visible=o!==null),u!==null&&(u.visible=s!==null),this}},framebufferScaleFactor=1,isAppleVisionPro=()=>{try{let e=/Macintosh/i.test(navigator.userAgent),t=navigator.maxTouchPoints===5;return e&&t}catch(e){return console.error(`Error determining if the device is an Apple Vision Pro: `,e),!1}},isOculus=()=>{try{return/Oculus/i.test(navigator.userAgent)}catch(e){return console.error(`Error determining if the device is an Oculus: `,e),!1}},XRManager=class{constructor(e,t,n){var r,o,s,c,l;this.isPanorama=(r=n==null?void 0:n.isPanorama)==null?!0:r,navigator.userAgent.toLowerCase();let u;u=isAppleVisionPro()?`VP`:isOculus()?`Oculus`:`Pico`,this.machineType=(o=n==null?void 0:n.machineType)==null?u:o,this.renderer=e,this.gl=t,this.enabled=!1,this.session=null,this.referenceSpaceType=(s=n==null?void 0:n.referenceSpaceType)==null?`local-floor`:s,this.referenceSpace=null,this.onSessionStartCallback=(c=n==null?void 0:n.onSessionStart)==null?noop:c,this.onSessionEndCallback=(l=n==null?void 0:n.onSessionEnd)==null?noop:l,this.controllers=[new XRController,new XRController],this.inputSourcesMap=new Map,this.cameraVR=new three.ArrayCamera,this.cameraL=new three.PerspectiveCamera,this.cameraR=new three.PerspectiveCamera,this.cameraVR.cameras.push(this.cameraL,this.cameraR),this.cameraL.viewport=new three.Vector4,this.cameraR.viewport=new three.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.Vector3,this.cameraRPos=new three.Vector3}getController(e){let t=this.controllers[e];return t||console.warn(`no controller find`),t.getTargetRaySpace()}getRightController(){if(!this.session||!this.session.inputSources)return null;let e;if(this.session.inputSources.forEach((t,n)=>{t.handedness===`right`&&(e=n)}),e===void 0)return console.warn(`no inputSource for right hand`),null;let t=this.controllers[e];return t?t.getTargetRaySpace():(console.warn(`right controller not find`),null)}getLeftController(){if(!this.session||!this.session.inputSources)return null;let e;if(this.session.inputSources.forEach((t,n)=>{t.handedness===`left`&&(e=n)}),e===void 0)return console.warn(`no inputSource for left hand`),null;let t=this.controllers[e];return t?t.getTargetRaySpace():(console.warn(`left controller not find`),null)}getControllerGrip(e){let t=this.controllers[e];return t||console.warn(`no controller find`),t.getGripSpace()}getCameras(){return{cameraL:this.cameraL,cameraR:this.cameraR,cameraVR:this.cameraVR}}updateCamera(e,t){t===null?e.matrixWorld.copy(e.matrix):e.matrixWorld.multiplyMatrices(t.matrixWorld,e.matrix),e.matrixWorldInverse.getInverse(e.matrixWorld)}setProjectionFromUnion(e,t,n){this.cameraLPos.setFromMatrixPosition(t.matrixWorld),this.cameraRPos.setFromMatrixPosition(n.matrixWorld);var r=this.cameraLPos.distanceTo(this.cameraRPos),o=t.projectionMatrix.elements,s=n.projectionMatrix.elements,c=o[14]/(o[10]-1),l=o[14]/(o[10]+1),u=(o[9]+1)/o[5],d=(o[9]-1)/o[5],f=(o[8]-1)/o[0],p=(s[8]+1)/s[0],m=c*f,h=c*p,g=r/(-f+p),_=g*-f;t.matrixWorld.decompose(e.position,e.quaternion,e.scale),e.translateX(_),e.translateZ(g),e.matrixWorld.compose(e.position,e.quaternion,e.scale),e.matrixWorldInverse.getInverse(e.matrixWorld);var v=c+g,y=l+g,b=m-_,S=h+(r-_),C=u*l/y*v,w=d*l/y*v;e.projectionMatrix.makePerspective(b,S,C,w,v,y)}getCamera(e){this.cameraVR.near=this.cameraR.near=this.cameraL.near=e.near,this.cameraVR.far=this.cameraR.far=this.cameraL.far=e.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);let t=e.parent,n=this.cameraVR.cameras;this.updateCamera(this.cameraVR,t);for(let e=0;e<n.length;e++)this.updateCamera(n[e],t);e.matrixWorld.copy(this.cameraVR.matrixWorld);let r=e.children;for(let e=0,t=r.length;e<t;e++)r[e].updateMatrixWorld(!0);return n.length===2?this.setProjectionFromUnion(this.cameraVR,this.cameraL,this.cameraR):this.cameraVR.projectionMatrix.copy(this.cameraL.projectionMatrix),this.cameraVR}updateInputSources(e){if(!this.session){console.warn(`session is lose!`);return}let t=this.session.inputSources;for(let e=0;e<this.controllers.length;e++)this.inputSourcesMap.set(t[e],this.controllers[e]);for(let t=0;t<e.removed.length;t++){let n=e.removed[t],r=this.inputSourcesMap.get(n);r&&(r.dispatchEvent({type:`disconnected`,data:n}),this.inputSourcesMap.delete(n))}for(let t=0;t<e.added.length;t++){let n=e.added[t],r=this.inputSourcesMap.get(n);r&&r.dispatchEvent({type:`connected`,data:n})}}onSessionEvent(e){let t=this.inputSourcesMap.get(e.inputSource);t&&t.dispatchEvent({type:e.type})}onSessionEnd(){this.inputSourcesMap.forEach(function(e,t){e.disconnect(t)}),this.inputSourcesMap.clear(),this.isPresenting=!1,this.session=null,AnimationFrameLoop.shared.setContext(null),this.onSessionEndCallback()}onRequestReferenceSpace(e){this.referenceSpace=e,this.isPresenting=!0,this.session&&this.onSessionStartCallback(this.session)}setSession(e){if(this.session=e,this.session){this.session.addEventListener(`select`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`selectstart`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`selectend`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`squeeze`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`squeezestart`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`squeezeend`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`end`,e=>{this.onSessionEnd()});let e=this.gl.getContextAttributes();this.gl.makeXRCompatible().then(()=>{let t={antialias:e==null?void 0:e.antialias,alpha:e==null?void 0:e.alpha,depth:e==null?void 0:e.depth,stencil:e==null?void 0:e.stencil,framebufferScaleFactor};if(!this.session){console.error(`session is lose while set session!`);return}switch(this.machineType){case`Pico`:case`VP`:this.session.updateRenderState({baseLayer:new XRWebGLLayer(this.session,this.gl,t)});break;case`Oculus`:this.session.updateRenderState({baseLayer:new XRWebGLLayer(this.session,this.gl,t)});break;default:this.machineType;break}this.session.requestReferenceSpace(this.referenceSpaceType).then(e=>{this.onRequestReferenceSpace(e)}),this.session.addEventListener(`inputsourceschange`,e=>{this.updateInputSources(e)})})}}},LineSegmentsGeometry=class extends three.InstancedBufferGeometry{constructor(){super(),this.type=`LineSegmentsGeometry`,this.setIndex([0,2,1,2,3,1,2,4,3,4,5,3,4,6,5,6,7,5]),this.setAttribute(`position`,new three.Float32BufferAttribute([-1,2,0,1,2,0,-1,1,0,1,1,0,-1,0,0,1,0,0,-1,-1,0,1,-1,0],3)),this.setAttribute(`uv`,new three.Float32BufferAttribute([-1,2,1,2,-1,1,1,1,-1,-1,1,-1,-1,-2,1,-2],2))}applyMatrix4(e){let t=this.attributes.instanceStart,n=this.attributes.instanceEnd;return t!==void 0&&(t.applyMatrix4(e),n.applyMatrix4(e),t.needsUpdate=!0),this.boundingBox!==null&&this.computeBoundingBox(),this.boundingSphere!==null&&this.computeBoundingSphere(),this}setPositions(e){let t;t=e instanceof Float32Array?e:Array.isArray(e)?new Float32Array(e):new Float32Array;let n=new three.InstancedInterleavedBuffer(t,6,1);return this.setAttribute(`instanceStart`,new three.InterleavedBufferAttribute(n,3,0)),this.setAttribute(`instanceEnd`,new three.InterleavedBufferAttribute(n,3,3)),this.computeBoundingBox(),this.computeBoundingSphere(),this}setColors(e){let t;t=e instanceof Float32Array?e:Array.isArray(e)?new Float32Array(e):new Float32Array;let n=new three.InstancedInterleavedBuffer(t,6,1);return this.setAttribute(`instanceColorStart`,new three.InterleavedBufferAttribute(n,3,0)),this.setAttribute(`instanceColorEnd`,new three.InterleavedBufferAttribute(n,3,3)),this}fromWireframeGeometry(e){return this.setPositions(e.attributes.position.array),this}fromEdgesGeometry(e){return this.setPositions(e.attributes.position.array),this}fromMesh(e){return this.fromWireframeGeometry(new three.WireframeGeometry(e.geometry)),this}fromLineSegments(e){var t=e.geometry;if(t instanceof three.Geometry){let e=new three.BufferGeometry().fromGeometry(t);this.setPositions(e.attributes.position.array)}else t instanceof three.BufferGeometry&&this.setPositions(t.attributes.position.array);return this}computeBoundingBox(){this.boundingBox===null&&(this.boundingBox=new three.Box3);let e=this.attributes.instanceStart,t=this.attributes.instanceEnd;if(e!==void 0&&t!==void 0){let n=new three.Box3;this.boundingBox.setFromBufferAttribute(e),n.setFromBufferAttribute(t),this.boundingBox.union(n)}}computeBoundingSphere(){this.boundingSphere===null&&(this.boundingSphere=new three.Sphere),this.boundingBox===null&&this.computeBoundingBox();let e=this.attributes.instanceStart,t=this.attributes.instanceEnd;if(e!==void 0&&t!==void 0){let n=this.boundingSphere.center;this.boundingBox.getCenter(n);let r=0,o=new three.Vector3;for(let s=0,c=e.count;s<c;s++)o.fromBufferAttribute(e,s),r=Math.max(r,n.distanceToSquared(o)),o.fromBufferAttribute(t,s),r=Math.max(r,n.distanceToSquared(o));this.boundingSphere.radius=Math.sqrt(r),isNaN(this.boundingSphere.radius)&&console.error(`THREE.LineSegmentsGeometry.computeBoundingSphere(): Computed radius is NaN. The instanced position data is likely to have NaN values.`,this)}}toJSON(){}};Object.assign(LineSegmentsGeometry.prototype,{isLineSegmentsGeometry:!0});var lineShader={uniforms:three.UniformsUtils.merge([three.UniformsLib.common,three.UniformsLib.fog,{linewidth:{value:1},resolution:{value:new three.Vector2(1,1)},dashScale:{value:1},dashSize:{value:1},gapSize:{value:1},opacity:{value:1}}]),vertexShader:`
2040
+ `,PanoSphereMesh=class extends three.Object3D{constructor(){super(),this.progress=0,this.opacity=0,this.loading=!1,this.current=!1,this.disabled=!1,this.currentMotion=new Motion({ringScale:1.1,ringOpacity:0,circleFade:0,circleOpacity:.85,circleScale:1}),this.opacityMotion=new Motion({opacity:0}),this.loadingMotion=new Motion({opacity:0}),this.disableMotion=new Motion({opacity:0});let e={blending:three.CustomBlending,blendSrc:three.SrcAlphaFactor,blendDst:three.OneMinusSrcAlphaFactor,blendSrcAlpha:three.OneFactor,blendDstAlpha:three.OneMinusSrcAlphaFactor,depthWrite:!1,transparent:!0};this.hitTestMesh=new three.Mesh(sharedGeometry,new three.MeshBasicMaterial(Object.assign(Object.assign({},e),{color:0,opacity:0}))),this.hitTestMesh.scale.set(1.5,1.5,1.5),this.ringMesh=new three.Mesh(sharedGeometry,new three.ShaderMaterial(Object.assign(Object.assign({},e),{vertexShader:ringVertexShader,fragmentShader:ringFragmentShader,uniforms:{opacity:{value:0}}}))),this.panoMesh=new three.Mesh(sharedGeometry,new three.ShaderMaterial(Object.assign(Object.assign({},e),{vertexShader,fragmentShader,uniforms:{circleScale:{value:1.1},circleFade:{value:0},circleOpacity:{value:.5},loadingAngle:{value:0},loadingOpacity:{value:0},opacity:{value:0},disable:{value:0}}}))),this.add(this.hitTestMesh),this.add(this.ringMesh),this.add(this.panoMesh),this.renderOrder=1e4,this.needsRender=!0}setProgress(e){this.progress=e,this.setLoading(e>0)}setOpacity(e){this.opacity!==e&&(this.opacity=e=clamp$1(e,0,1),this.opacityMotion.set({opacity:e},30).catch(noop))}setCurrent(e){if(this.current!==e){if(e)this.currentMotion.setKeyframes([{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}}],1500).catch(noop);else{let e=[{progress:0,value:Object.assign({},this.currentMotion.value)},{progress:1,value:{ringScale:1.1,ringOpacity:0,circleFade:0,circleOpacity:.85,circleScale:1}}];this.currentMotion.setKeyframes(e,200).catch(noop)}this.current=e}}setLoading(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):this.loadingMotion.set({opacity:0},0).catch(noop),this.loading=e,this.disabled===!0&&this.setDisabled(!1),this.needsRender=!0)}setDisabled(e){this.disabled!==e&&(this.disabled=e,this.loading===!0&&this.setLoading(!1),this.disableMotion.set({opacity:e?1:0},300).catch(noop),this.needsRender=!0)}tap(){return Promise.resolve()}updateTime(e,t){this.opacityMotion.update(e),this.currentMotion.update(e),this.loadingMotion.update(e);let n=this.opacityMotion.value.opacity;this.visible=n!==0;let{ringScale:r,ringOpacity:o,circleFade:s,circleOpacity:c,circleScale:l}=this.currentMotion.value;this.ringMesh.scale.set(r,1,r),this.ringMesh.material.uniforms.opacity.value=o*n,this.panoMesh.material.uniforms.opacity.value=n,this.panoMesh.material.uniforms.circleOpacity.value=c,this.panoMesh.material.uniforms.circleScale.value=l,this.panoMesh.material.uniforms.circleFade.value=s,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}dispose(){this.hitTestMesh.material.dispose(),this.ringMesh.material.dispose(),this.panoMesh.material.dispose()}},ACTIVE_TO_CURRENT_DELAY=1500,defaultVRPanoramaControllerCustomInitArgs=Object.assign({},omit(defaultPanoramaControllerCustomInitArgs,[`maxLatitude`,`minLatitude`])),VRPanoramaController=class e extends PanoramaController{static parseArgs(t){if(t instanceof e)return t;let n=Object.assign(Object.assign({},t),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2});return super.parseArgs(n)}static initAnimationEndState(e){let t=this.parseArgs(e),n=super.initAnimationEndState(t);return Object.assign(Object.assign({},n),{mode:`VRPanorama`})}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`VRPanorama`,this.cardboard=new Cardboard(this.renderer);let r=createHelper();this.helperElement=r;let o=new Hammer(r);this.element.parentNode&&(this.element.parentNode.insertBefore(r,this.element),this.updateHelperElementSize(),o.on(`tap`,()=>this.emit(`vr.requestExit`,createEvent(`vr.requestExit`,{})))),this.destroyHelper=()=>{o.destroy(),r.parentNode&&r.parentNode.removeChild(r),this.helperElement=void 0}}updateConfiguration(e){return super.updateConfiguration(Object.assign(Object.assign({},e),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2}))}destroy(){super.destroy(),this.cardboard.dispose(),this.destroyHelper()}isReady(){return!1}updateRenderSize(){this.needsRender=!0}updateCamera(e,t,n){return Promise.resolve()}updateCameraWithKeyframes(e,t,n){return Promise.resolve()}updateTime(e,t,...n){var r,o,s,c,l,u;if(this.destroyed)return;this.updateHelperElementSize(),this.userAction=!0,this.needsRender=!0;let d={},f={},p=this.locationMotion.keyframes[0],m=this.locationMotion.keyframes[this.locationMotion.keyframes.length-1],[h,g]=this.locationMotion.getKeyFrameSegment(e),_=this.panoResourceFromLocationMotionKeyframe(h),v=this.panoResourceFromLocationMotionKeyframe(g),y=this.panoResourceFromLocationMotionKeyframe(p),b=this.panoResourceFromLocationMotionKeyframe(m),S=!1;if(this.modelAlphaMotion.ended===!1&&(this.modelAlphaMotion.update(e),d.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.perspToOrthoMotion.ended===!1&&(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);let t=this.locationMotion.value.count-g.value.count+1,n=new three.Vector3().copy(_.position),s=new three.Vector3().copy(v.position);if(d.progress=t,t>=.01&&t<=.99&&(d.progress=clamp$1(v.effectEasing(t),.01,.99)),v.panoPicture&&(t<1?_.panoPicture&&(d.pano0=_.panoPicture):d.pano0=v.panoPicture,d.pano1=v.panoPicture),v.effect===`montage`?d.transition=`BLACK`:v.effect===`spread`?d.transition=`SPREAD`:d.transition=`FADE`,v.effect===`zoomin`||v.effect===`zoomout`?d.progress=Math.pow(t,3):v.effect===`model`&&this.camera.pose.distance<.01&&(d.modelAlpha=1-Math.pow(clamp$1(Math.abs(t-.5)*2,0,1),4)),t<1&&v.effect!==`fly`){if(d.pano0&&_.panoPicture){let e={panoId:d.pano0.panoId,map:d.pano0.map,mapHistogram:d.pano0.mapHistogram,mapSize:d.pano0.mapSize,zoom:d.pano0.zoom,matrix:_.panoPicture.matrix.clone().setPosition(v.position)},t=this.panoPictureObserverMap.get(d.pano0);t&&this.panoPictureObserverMap.set(e,t),d.pano0=e}n.copy(s),S=!0}f.distance=this.locationMotion.value.distance,f.offset=new three.Vector3(n.x+(s.x-n.x)*t,n.y+(s.y-n.y)*t,n.z+(s.z-n.z)*t);let c=[],l=[];for(let e of this.locationMotion.keyframes){let{key:t,progress:n}=e;t!==void 0&&(c.push(t),n>this.locationMotion.progress&&l.push(t))}for(let e of Object.keys(this.panoResources)){if(l.indexOf(e)>=0)continue;let t=this.panoResources[e];if(t.panoPicture){let e=t.panoPicture.map;if(e){if(e===((r=d.pano0)==null?void 0:r.map)||e===((o=d.pano1)==null?void 0:o.map))continue;e.dispose(),t.panoPicture=null}}c.indexOf(e)>=0||delete this.panoResources[e]}this.currentPano=panoParse(v.panoId),this.emit(`pano.moving`,createEvent(`pano.moving`,{userAction:this.userAction,prevPano:panoParse(y.panoId),state:Object.assign(Object.assign(Object.assign(Object.assign({},panoParse(b.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),f),options:{},progress:this.locationMotion.progress,error:null}))}isEmptyObject(d)===!1&&this.modelScene.parameter.set(d),f.offset&&this.camera.position.copy(f.offset);let C=this.camera.pose.longitude,w=this.camera.pose.latitude;this.camera.quaternion.fromArray(this.cardboard.sensor.getOrientation()),this.camera.computePose(),(C!==this.camera.pose.longitude||w!==this.camera.pose.latitude)&&(this.cameraMotion.set(pick(this.camera.pose,[`longitude`,`latitude`]),0).catch(noop),this.emit(`camera.update`,createEvent(`camera.update`,{userAction:!0,state:Object.assign(Object.assign(Object.assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose))}))),this.works.getObserver(this.currentPano);let T=this.works.getObserver(_.panoId),E=this.works.getObserver(v.panoId),D=new Map;if(T)for(let e of T.accessibleNodes){let t=T.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});D.set(e,t)}}if(E)for(let e of E.accessibleNodes){let t=E.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});D.set(e,t)}}if(this.panoMeshes.forEach((e,t)=>{let n=D.get(t);n?(e.position.copy(n.position).applyMatrix4(n.work.transform),D.delete(t)):(this.helper.remove(e),e.dispose(),this.panoMeshes.delete(t))}),D.forEach((e,t)=>{let n=new PanoSphereMesh;n.position.copy(e.position).applyMatrix4(e.work.transform),e.position.distanceTo(e.standingPosition)>this.aerialObserverMinHeight?n.scale.setScalar(15):n.scale.setScalar(1),this.panoMeshes.set(t,n),this.helper.add(n),D.delete(t)}),this.camera.pose.distance>.1||S?this.panoMeshes.forEach((n,r)=>{n.setOpacity(0),n.updateTime&&n.updateTime(e,t),n.visible=!1}):this.panoMeshes.forEach((e,t)=>{let n=panoParse(t),r=this.works.getObserver(n);if(!r)return;if(!r.loadable&&!r.active){e.setOpacity(0);return}let o=e.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);o<.05?e.setOpacity(0):e.setOpacity(clamp$1(1.5/o,0,1)),panoEqual(this.currentPano,n)&&e.setOpacity(0),e.lookAt(this.camera.position)}),this.locationMotion.ended){let n=this.intersect(e);this.panoMeshes.forEach((r,o)=>{r.setCurrent(r===n),r.updateTime&&r.updateTime(e,t)})}{let e=(s=this.modelScene.parameter.progress)==null?1:s,t=Math.round(e),n=this.modelScene.parameter.pano0,r=this.modelScene.parameter.pano1,o=t===0?n:r,l;if(o&&(l=this.works.getObserver(o.panoId),l||(l=this.panoPictureObserverMap.get(o))),this.tiling.appearDuration=this.tileAppearDuration,this.tiling.maxRequest=e<(canUseNativeImageBitmap()?.6:.99)?0:this.tileMaxRequest,this.tiling.imageOptions=this.imageOptions,!l||!o||this.tileLevelForFov===!1||this.camera.perspToOrtho.x>0){this.tiling.setObserver(null);let e={renderer:this.renderer,resolution:this.camera.resolution,pixelRatio:this.camera.pixelRatio,time:this.camera.time,cameraMatrix:this.camera.matrixWorld,cameraProjectionMatrix:this.camera.projectionMatrix,panoMap:null,panoMatrix:new three.Matrix4,panoZoom:1,minLevel:0,level:0};this.tiling.update(e),this.modelScene.parameter.set(`refinedScreen`,null)}else{let e=getImageSizeLevel(o.mapSize),s=e+1,u=new three.Vector2().copy(this.camera.resolution).multiplyScalar(this.camera.pixelRatio),d=Math.floor(this.tileLevelForFov(this.camera.fov,u)),f=d>e?d:0;this.tiling.setObserver(l);let p={renderer:this.renderer,resolution:this.camera.resolution,pixelRatio:this.camera.pixelRatio,time:this.camera.time,cameraMatrix:this.camera.matrixWorld,cameraProjectionMatrix:this.camera.projectionMatrix,panoMap:o.map,panoMatrix:o.matrix,panoZoom:o.zoom,minLevel:s,level:f},m=this.tiling.update(p),h={map:this.tiling.renderTarget.texture,matrixInverse:this.tiling.camera.matrixWorldInverse,projectionMatrix:this.tiling.camera.projectionMatrix,pano:t,opacity:(n==null?void 0:n.panoId)===(r==null?void 0:r.panoId)?1:easeInQuart(Math.abs(((c=this.modelScene.parameter.progress)==null?0:c)-.5)*2)},g=this.modelScene.parameter.refinedScreen;(m||h.pano!==(g==null?void 0:g.pano)||h.opacity!==(g==null?void 0:g.opacity))&&this.modelScene.parameter.set(`refinedScreen`,h)}}this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e);{let e=v.effect,{pano0:t,pano1:n}=this.modelScene.parameter;if(t&&n&&t!==n&&(e===`fly`||e===`model`)&&this.flyEffectUseDepthBuffer){if(((l=this.modelScene.parameter.pano0Depth)==null?void 0:l.panoId)!==t.panoId||((u=this.modelScene.parameter.pano1Depth)==null?void 0:u.panoId)!==n.panoId){let e=500,r=512;this.pano0DepthCubeRenderTarget?this.pano0DepthCubeRenderTarget.width!==512&&this.pano0DepthCubeRenderTarget.setSize(512,512):this.pano0DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1}),this.pano1DepthCubeRenderTarget?this.pano1DepthCubeRenderTarget.width!==512&&this.pano1DepthCubeRenderTarget.setSize(512,512):this.pano1DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1});let o=new three.CubeCamera(this.camera.near,this.camera.far,this.pano0DepthCubeRenderTarget);o.matrix.copy(t.matrix),o.matrixWorld.copy(o.matrix),o.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,o,500);let s=new three.CubeCamera(this.camera.near,this.camera.far,this.pano1DepthCubeRenderTarget);s.matrix.copy(n.matrix),s.matrixWorld.copy(s.matrix),s.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,s,500),this.modelScene.parameter.set({pano0Depth:{panoId:t.panoId,map:this.pano0DepthCubeRenderTarget.texture,mapSize:this.pano0DepthCubeRenderTarget.width,maxDepth:500},pano1Depth:{panoId:n.panoId,map:this.pano1DepthCubeRenderTarget.texture,mapSize:this.pano1DepthCubeRenderTarget.width,maxDepth:500}})}}else this.modelScene.parameter.set({pano0Depth:null,pano1Depth:null}),this.flyEffectUseDepthBuffer||(this.pano0DepthCubeRenderTarget&&(this.pano0DepthCubeRenderTarget.dispose(),this.pano0DepthCubeRenderTarget=void 0),this.pano1DepthCubeRenderTarget&&(this.pano1DepthCubeRenderTarget.dispose(),this.pano1DepthCubeRenderTarget=void 0))}}render(){return this.renderer.setRenderTarget(null),this.renderer.setScissorTest(!1),this.cardboard.render(this.scene,this.camera),!0}setCamera(e={}){}destroyHelper(){}updateHelperElementSize(){if(!this.helperElement)return;let e=new three.Vector2(this.element.offsetWidth,this.element.offsetHeight),t=e.x*this.viewport.left,n=e.y*(1-this.viewport.bottom-this.viewport.height),r=e.x*this.viewport.width,o=e.y*this.viewport.height;this.helperElement.style.marginLeft!==t+`px`&&(this.helperElement.style.marginLeft=t+`px`),this.helperElement.style.marginTop!==n+`px`&&(this.helperElement.style.marginTop=n+`px`),this.helperElement.style.width!==r+`px`&&(this.helperElement.style.width=r+`px`),this.helperElement.style.height!==o+`px`&&(this.helperElement.style.height=o+`px`)}intersect(e){var t,n;if(this.locationMotion.ended===!1){this.intersectMesh.visible=!1,this.activePanoMesh=void 0,this.activeTime=void 0;return}if(this.activePanoMesh&&this.activeTime&&e-this.activeTime>ACTIVE_TO_CURRENT_DELAY){let e=this.activePanoMesh,t=null;return this.panoMeshes.forEach((n,r)=>{n===e&&(t=r)}),t!==null&&this.moveToPano(panoParse(t),{},!0),this.activePanoMesh=void 0,this.activeTime=void 0,e}let r=this.camera.getDirection(new three.Vector3),o=new three.Raycaster(this.camera.position,r);o.params.Points={threshold:.1},o.firstHitOnly=!0,o.floorIndex=-1;let s,c=[],l=this.works.getObserver(this.currentPano),u=l?l.accessibleNodes.map(e=>panoStringify({panoIndex:e,workCode:l.work.workCode})):[];for(let e of u){let r=this.panoMeshes.get(e);if(r){let[e]=o.intersectObject((t=r.hitTestMesh)==null?r:t,!0);if(e){let t=(n=l==null?void 0:l.floorIndex)==null?0:n;c.push({panoMesh:r,intersection:Object.assign({floorIndex:t,floor:t},e)})}}}let[d]=c.sort((e,t)=>e.intersection.distance-t.intersection.distance);d?(s=d.intersection,this.activePanoMesh!==d.panoMesh&&(this.activePanoMesh=d.panoMesh,this.activeTime=e),this.intersectMesh.position.copy(d.panoMesh.position),this.intersectMesh.lookAt(this.camera.position)):(this.activePanoMesh=void 0,this.activeTime=void 0),s||(s=this.modelScene.intersectRaycaster(o)[0]);let f=createEvent(`intersect.update`,{raycaster:o,intersection:s==null?null:s,object:this.intersectMesh});if(this.emit(`intersect.update`,f),f.defaultPrevented){this.hideIntersectMesh();return}if(s&&s.face){let e=s.face.normal,t=new three.Quaternion;t.setFromUnitVectors(new three.Vector3(0,0,1),e),this.intersectMesh.quaternion.copy(t);let n=s.point.clone();this.intersectMesh.position.copy(n),d?this.intersectMesh.visible=!1:this.intersectMesh.visible=!0}else this.intersectMesh.visible=!1;return d==null?void 0:d.panoMesh}onPanGesture(){}onTapGesture(){}onPinchGesture(){}onMouseMove(){}onMouseOut(){}},HUMAN_EYE_POSITION=new three.Vector3(0,1.6,0),scratchObserverBox$1=new three.Box3,scratchVector3$2=new three.Vector3,defaultModelControllerCustomInitArgs=Object.assign({},defaultPanoramaLikeControllerCustomInitArgs),ModelController=class e extends PanoramaLikeController{static parseArgs(t){return t instanceof e?t:super.parseArgs(t)}static initAnimationEndState(e){var t,n,r,o,s,c;let l=this.parseArgs(e),u=l.works,{state:d,currentState:f}=e.initial,p=typeof d.panoIndex==`number`?{workCode:(r=(t=d.workCode)==null?(n=l.works[0])==null?void 0:n.workCode:t)==null?``:r,panoIndex:d.panoIndex}:{workCode:f.workCode,panoIndex:f.panoIndex},m=u.getObserver(p),h=clamp$1((o=d.fov)==null?!m||isFristPersonMode(f.mode)?f.fov:l.defaultFov:o,l.minFov,l.maxFov),g=(s=d.longitude)==null?f.longitude:s,_=clamp$1(typeof l.minLatitude==`function`?l.minLatitude(h):l.minLatitude,-Math.PI/2,Math.PI/2),v=clamp$1(typeof l.maxLatitude==`function`?l.maxLatitude(h):l.maxLatitude,-Math.PI/2,Math.PI/2),y=clamp$1((c=d.latitude)==null?!m||isFristPersonMode(f.mode)?f.latitude:l.defaultLatitude:c,_,v),b=new three.Vector3;if(l.initial.state.offset)b.copy(l.initial.state.offset);else if(m)b.copy(m.position).applyMatrix4(m.work.transform);else{let e=coordinatesToVector(f).setLength(f.distance);b.copy(l.initial.currentState.offset).sub(e)}return{workCode:p.workCode,panoIndex:p.panoIndex,mode:`Model`,longitude:g,latitude:y,fov:h,offset:b,distance:0}}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`Model`,this.locationMotion=new Motion({x:this.camera.pose.offset.x,y:this.camera.pose.offset.y,z:this.camera.pose.offset.z,distance:this.camera.pose.distance}),this.modelAlphaMotion=new Motion({modelAlpha:this.modelScene.parameter.resolveValue(`modelAlpha`)}),this.perspToOrthoMotion=new Motion({perspToOrtho:this.camera.perspToOrtho.x})}updateConfiguration(e){return super.updateConfiguration(e)}destroy(){super.destroy(),this.locationMotion.dispose()}isReady(){return this.locationMotion.ended===!1?!1:super.isReady()}updateWork(t,n,r,o){this.works=t;let s=e.initAnimationEndState(Object.assign(Object.assign({},this),{initial:{currentState:Object.assign(Object.assign({},this.currentPano),this.camera.pose),duration:r.duration,effect:r.effect,state:n,userAction:o}}));return(s.workCode!==this.currentPano.workCode||s.panoIndex!==this.currentPano.panoIndex||s.longitude!==this.cameraMotion.value.longitude||s.latitude!==this.cameraMotion.value.latitude||s.fov!==this.cameraMotion.value.fov)&&this.moveToPosition(s.offset,{duration:0,longitude:s.longitude,latitude:s.latitude,fov:s.fov},o),!0}updateCamera(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r={},o={};return r.distance=0,e.offset!==void 0&&(r.x=e.offset.x,r.y=e.offset.y,r.z=e.offset.z),e.longitude!==void 0&&(o.longitude=e.longitude),e.latitude!==void 0&&(o.latitude=e.latitude),e.fov!==void 0&&(o.fov=e.fov),this.locationMotion.set(r,t).catch(noop),this.cameraMotion.set(o,t).catch(noop)})}updateCameraWithKeyframes(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r=[],o=[];for(let t of e)r.push({key:t.key,progress:t.progress,value:{distance:0,x:t.value.offset.x,y:t.value.offset.x,z:t.value.offset.x}}),o.push({key:t.key,progress:t.progress,value:{longitude:t.value.longitude,latitude:t.value.latitude,fov:t.value.fov}});return this.locationMotion.setKeyframes(r,t).catch(noop),this.cameraMotion.setKeyframes(e,t)})}updateTime(e,t,...n){if(this.destroyed)return;let r={},o={};if(this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),r.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.modelScene.parameter.modelAlpha===0&&this.modelScene.parameter.progress!==1){let{pano0:e,pano1:t}=this.modelScene.parameter;e&&e.map!==(t==null?void 0:t.map)&&e.map.dispose(),r.progress=1,r.pano0=r.pano1=t}if(this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),!this.locationMotion.ended){this.locationMotion.update(e),o.distance=this.locationMotion.value.distance,o.offset=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z);let t=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),n=[];for(let e of this.works){let r=this.modelScene.models.find(t=>t.work===e);if(!(!r||r.visible===!1)&&!(e.observers.length<=0)&&(scratchObserverBox$1.copy(e.observerBox).expandByScalar(10).applyMatrix4(e.transform),scratchObserverBox$1.containsPoint(t)))for(let t of e.observers)n.push(t)}let r=arrayMin(n,e=>scratchVector3$2.copy(e.position).applyMatrix4(e.work.transform).distanceTo(t));this.currentPano=r?{workCode:r.work.workCode,panoIndex:r.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(r)||this.modelScene.parameter.set(r),isEmptyObject(o)||this.setCamera(o);let s=this.works.getObserver(this.currentPano);if(this.intersectMesh&&this.intersectMesh.parent&&s&&s.position.y-s.standingPosition.y>10){let e=clamp$1(this.camera.position.distanceTo(this.intersectMesh.position)*(2*Math.tan(.5*this.camera.fov/180*Math.PI))/5,.5);this.intersectMesh.scale.setScalar(e)}else this.intersectMesh.scale.setScalar(1)}initAnimation(){return this.destroyed?Promise.resolve():new Promise(t=>{let{state:n,currentState:r,duration:o,userAction:s}=this.initial;this.userAction=s;let c=e.initAnimationEndState(this),l={modelAlpha:1},u={perspToOrtho:0},d={longitude:c.longitude,latitude:c.latitude,fov:c.fov,duration:o,moveStartCallback:e=>{this.perspToOrthoMotion.set(u,o).catch(noop),this.modelAlphaMotion.set(l,o).catch(noop),this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:e,userAction:this.userAction}))},moveEndCallback:e=>{this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:e,userAction:this.userAction})),t()},moveCancelCallback:()=>{let e=this.currentPano,n=Object.assign(Object.assign({},e),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance});this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:n,userAction:this.userAction})),t()}};this.moveToPosition(c.offset,d,s)})}getTargetState(){let e=this.cameraMotion.getKeyFrameSegment(now())[1],t=this.locationMotion.getKeyFrameSegment(now())[1];return Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,offset:new three.Vector3(t.value.x,t.value.y,t.value.z),distance:t.value.distance})}moveToPano(e,t={},n){let r=this.works.getObserver(e);if(r){let e=new three.Vector3().copy(r.position).applyMatrix4(r.work.transform);this.moveToPosition(e,t,n)}}moveToPosition(e,t={},n){var r,o,s;this.userAction=n,this.stopMomentumMovement();let c=now(),l=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),u=l.distanceTo(e),d=this.locationMotion.getProgressVelocity(c),f=0;for(let e=1;e<this.locationMotion.keyframes.length;e++){let{x:t,y:n,z:r}=this.locationMotion.keyframes[e-1].value,{x:o,y:s,z:c}=this.locationMotion.keyframes[e].value;f+=Math.sqrt(Math.pow(o-t,2)+Math.pow(s-n,2)+Math.pow(c-r,2))}let p=u===0?0:d*f/u,m=this.calculateMovingDuration(t.duration,u),h={x:e.x,y:e.y,z:e.z,distance:0},g={longitude:t.longitude,latitude:t.latitude,fov:t.fov},_=[];for(let e of this.works){let t=this.modelScene.models.find(t=>t.work===e);if(!(!t||t.visible===!1)&&!(e.observers.length<=0)&&(scratchObserverBox$1.copy(e.observerBox).expandByScalar(10).applyMatrix4(e.transform),scratchObserverBox$1.containsPoint(l)))for(let t of e.observers)_.push(t)}let v=arrayMin(_,e=>scratchVector3$2.copy(e.position).applyMatrix4(e.work.transform).distanceTo(l)),y=v?{workCode:v.work.workCode,panoIndex:v.panoIndex}:{workCode:``,panoIndex:0},b=Object.assign(Object.assign({},y),{mode:this.mode,longitude:(r=g.longitude)==null?this.camera.pose.longitude:r,latitude:(o=g.latitude)==null?this.camera.pose.latitude:o,fov:(s=g.fov)==null?this.camera.pose.fov:s,offset:e.clone(),distance:0}),S=this.currentPano;this.emit(`pano.moveTo`,createEvent(`pano.moveTo`,{options:t,prevPano:S,progress:0,state:b,userAction:this.userAction,error:null})),t.moveStartCallback&&t.moveStartCallback(b),this.cameraMotion.set(g,m).catch(noop),this.locationMotion.set(h,m,p).then(()=>{for(let e of this.modelScene.children)e instanceof Model&&e.show();let e=Object.assign(Object.assign(Object.assign({},y),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`pano.arrived`,createEvent(`pano.arrived`,{options:t,prevPano:S,progress:0,state:e,userAction:this.userAction,error:null})),t.moveEndCallback&&t.moveEndCallback(e)},()=>{t.moveCancelCallback&&t.moveCancelCallback(),this.emit(`pano.cancel`,createEvent(`pano.cancel`,{options:t,prevPano:S,progress:0,state:b,userAction:this.userAction,error:null}))})}onTapGesture(e){let t=e.center.raycaster;this.stopMomentumMovement();let[n]=this.modelScene.intersectRaycaster(t);if(n&&n.face){let e=n.face.normal,t=n.point;if(new three.Vector3(0,1,0).angleTo(e)>Math.PI/3){let r=new three.Raycaster;r.firstHitOnly=!0;let o=e.clone().setLength(.3).add(t);r.set(o,new three.Vector3(0,-1,0)),n=this.modelScene.intersectRaycaster(r)[0]}}if(n){let t=new three.Vector3().copy(n.point).add(HUMAN_EYE_POSITION),r=[];for(let e of this.works){let n=this.modelScene.models.find(t=>t.work===e);if(!(!n||n.visible===!1)&&!(e.observers.length<=0)&&(scratchObserverBox$1.copy(e.observerBox).expandByScalar(10).applyMatrix4(e.transform),scratchObserverBox$1.containsPoint(t)))for(let t of e.observers)r.push(t)}let[o,s]=arrayMin(r,e=>scratchVector3$2.copy(e.position).applyMatrix4(e.work.transform).distanceTo(t),!0);o&&s<5&&(t.y=scratchVector3$2.copy(o.position).applyMatrix4(o.work.transform).y),e.state.offset.copy(t),e.state.distance=0,this.emit(`gesture.tap`,e),e.defaultPrevented||this.moveToPosition(t,{},!0)}else this.emit(`gesture.tap`,e),e.defaultPrevented||this.cameraBounce()}},scratchObserverBox=new three.Box3,scratchVector3$1=new three.Vector3,minDistance=.5,PANGESTURE_FORWARD_ANGLE=Math.PI/7,defaultMapviewControllerCustomInitArgs={defaultLongitude:Math.PI/4,defaultLatitude:Math.PI/4,defaultDistance:150,maxLatitude:Math.PI/2,minLatitude:0,cameraType:`auto`,cameraFence:null,intersectMeshCreator:()=>new IntersectMesh},MapviewController=class e extends BaseController{static parseArgs(t){var n,r,o,s,c,l,u,d;if(t instanceof e)return t;let f=super.parseArgs(t);return Object.assign(Object.assign({},f),{defaultLongitude:(n=t.defaultLongitude)==null?defaultMapviewControllerCustomInitArgs.defaultLongitude:n,defaultLatitude:(r=t.defaultLatitude)==null?defaultMapviewControllerCustomInitArgs.defaultLatitude:r,defaultDistance:(o=t.defaultDistance)==null?defaultMapviewControllerCustomInitArgs.defaultDistance:o,maxLatitude:(s=t.maxLatitude)==null?defaultMapviewControllerCustomInitArgs.maxLatitude:s,minLatitude:(c=t.minLatitude)==null?defaultMapviewControllerCustomInitArgs.minLatitude:c,cameraType:(l=t.cameraType)==null?defaultMapviewControllerCustomInitArgs.cameraType:l,cameraFence:(u=t.cameraFence)==null?defaultMapviewControllerCustomInitArgs.cameraFence:u,intersectMeshCreator:(d=t.intersectMeshCreator)==null?defaultMapviewControllerCustomInitArgs.intersectMeshCreator:d})}static distanceFromModel(e,t,n){let r=e.boundingBox,o=r.isEmpty()?10:Math.pow(Math.pow(r.max.x-r.min.x+1,2)+Math.pow(r.max.y-r.min.y+1,2)+Math.pow(r.max.z-r.min.z+1,2),1/2);o=isNaN(o)||!isFinite(o)?1:o;let s=o/2/Math.tan(Math.PI*t/360);return n<1&&(s/=n),isNaN(s)||!isFinite(s)?o:s}static initAnimationEndState(t){var n,r,o,s,c,l,u;let d=this.parseArgs(t),f=d.works,p=d.modelScene,{state:m,currentState:h}=t.initial,g=typeof m.panoIndex==`number`?{workCode:(o=(n=m.workCode)==null?(r=d.works[0])==null?void 0:r.workCode:n)==null?``:o,panoIndex:m.panoIndex}:{workCode:h.workCode,panoIndex:h.panoIndex},_=(s=m.fov)==null?60:s,v=clamp$1(typeof d.minLatitude==`function`?d.minLatitude(_):d.minLatitude,-Math.PI/2,Math.PI/2),y=clamp$1(typeof d.maxLatitude==`function`?d.maxLatitude(_):d.maxLatitude,-Math.PI/2,Math.PI/2),b=clamp$1((c=m.latitude)==null?isThirdPersonMode(h.mode)?h.latitude:d.defaultLatitude:c,v,y),S=e.distanceFromModel(d.modelScene,_,d.camera.aspect),C=new three.Vector3,w=(l=m.distance)==null?Math.min(d.defaultDistance,S):l,T=(u=m.longitude)==null?isThirdPersonMode(h.mode)?h.longitude:d.defaultLongitude:u;if(m.offset)C.copy(m.offset);else{let e=f.getObserver(g);d.defaultDistance<S&&e?(C.copy(e.position).applyMatrix4(e.work.transform),m.longitude===void 0&&(T=h.longitude)):(p.boundingBox.getCenter(C),w=S)}return Object.assign(Object.assign({},g),{mode:`Mapview`,longitude:T,latitude:b,fov:_,offset:C,distance:w})}constructor(t){let n=e.parseArgs(t);super(n),this.mode=`Mapview`,this.defaultLongitude=n.defaultLongitude,this.defaultLatitude=n.defaultLatitude,this.defaultDistance=n.defaultDistance,this.maxLatitude=n.maxLatitude,this.minLatitude=n.minLatitude,this.cameraType=n.cameraType,this.cameraFence=n.cameraFence,this.locationMotion=new Motion({x:this.camera.pose.offset.x,y:this.camera.pose.offset.y,z:this.camera.pose.offset.z,distance:this.camera.pose.distance}),this.modelAlphaMotion=new Motion({modelAlpha:this.modelScene.parameter.resolveValue(`modelAlpha`)}),this.perspToOrthoMotion=new Motion({perspToOrtho:this.camera.perspToOrtho.x}),this.pendingTextureId=null,this.textureLoader=new TextureLoader,this.intersectMeshCreator=n.intersectMeshCreator,this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=`intersect`,this.intersectMesh.visible=!1,this.helper.add(this.intersectMesh)}updateConfiguration(e){if(super.updateConfiguration(e)===!1)return!1;if(e.defaultLongitude!==void 0&&this.defaultLongitude!==e.defaultLongitude&&(this.defaultLongitude=e.defaultLongitude),e.defaultLatitude!==void 0&&this.defaultLatitude!==e.defaultLatitude&&(this.defaultLatitude=e.defaultLatitude),e.defaultDistance!==void 0&&this.defaultDistance!==e.defaultDistance&&(this.defaultDistance=e.defaultDistance),e.maxLatitude!==void 0&&this.maxLatitude!==e.maxLatitude&&(this.maxLatitude=e.maxLatitude),e.minLatitude!==void 0&&this.minLatitude!==e.minLatitude&&(this.minLatitude=e.minLatitude),e.cameraType!==void 0&&this.cameraType!==e.cameraType&&(this.cameraType=e.cameraType),this.cameraFence instanceof three.Box3&&e.cameraFence instanceof three.Box3||this.cameraFence instanceof three.Sphere&&e.cameraFence instanceof three.Sphere?this.cameraFence.equals(e.cameraFence)||(this.cameraFence=e.cameraFence):e.cameraFence!==void 0&&(this.cameraFence=e.cameraFence),e.intersectMeshCreator!==void 0&&this.intersectMeshCreator!==e.intersectMeshCreator){this.intersectMeshCreator=e.intersectMeshCreator;let t=this.intersectMesh;this.intersectMesh=this.intersectMeshCreator(),this.intersectMesh.name=t.name,this.intersectMesh.visible=t.visible;let n=this.intersectMesh.parent;n&&n.add(this.intersectMesh),t.dispose()}return!0}destroy(){super.destroy(),this.pendingTextureId=null,this.locationMotion.dispose(),this.panState=void 0,this.intersectMesh.dispose(),this.helper.remove(this.intersectMesh)}isReady(){return this.locationMotion.ended===!1?!1:super.isReady()}updateWork(t,n,r,o){this.userAction=o,this.works=t;let s=e.initAnimationEndState(Object.assign(Object.assign({},this),{initial:{currentState:Object.assign(Object.assign({},this.currentPano),this.camera.pose),duration:r.duration,effect:r.effect,state:n,userAction:o}}));this.currentPano={workCode:s.workCode,panoIndex:s.panoIndex};let c={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};return(c.longitude!==this.cameraMotion.value.longitude||c.latitude!==this.cameraMotion.value.latitude||c.fov!==this.cameraMotion.value.fov)&&this.cameraMotion.set(c,r.duration).catch(noop),(l.x!==this.locationMotion.value.x||l.y!==this.locationMotion.value.y||l.z!==this.locationMotion.value.z||l.distance!==this.locationMotion.value.distance)&&this.locationMotion.set(l,r.duration).catch(noop),!0}updateModel(e){super.updateModel(e),this.hideIntersectMesh()}updateCamera(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r={},o={};return e.distance!==void 0&&(r.distance=e.distance),e.offset!==void 0&&(r.x=e.offset.x,r.y=e.offset.y,r.z=e.offset.z),e.longitude!==void 0&&(o.longitude=e.longitude),e.latitude!==void 0&&(o.latitude=e.latitude),e.fov!==void 0&&(o.fov=e.fov),this.locationMotion.set(r,t).catch(noop),this.cameraMotion.set(o,t).catch(noop)})}updateCameraWithKeyframes(e,t,n){return this.initAnimationReady.then(()=>{this.userAction=n,this.stopMomentumMovement();let r=[],o=[];for(let t of e)r.push({key:t.key,progress:t.progress,value:{distance:t.value.distance,x:t.value.offset.x,y:t.value.offset.x,z:t.value.offset.x}}),o.push({key:t.key,progress:t.progress,value:{longitude:t.value.longitude,latitude:t.value.latitude,fov:t.value.fov}});return this.locationMotion.setKeyframes(r,t).catch(noop),this.cameraMotion.setKeyframes(e,t)})}updateTime(e,t){if(this.destroyed)return;let n={},r={};if(this.locationMotion.ended||(this.locationMotion.update(e),r.distance=this.locationMotion.value.distance,r.offset=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z)),this.cameraMotion.ended||(this.cameraMotion.update(e),r.longitude=this.cameraMotion.value.longitude,r.latitude=this.cameraMotion.value.latitude,r.fov=this.cameraMotion.value.fov),this.modelAlphaMotion.ended||(this.modelAlphaMotion.update(e),n.modelAlpha=this.modelAlphaMotion.value.modelAlpha),this.modelScene.parameter.modelAlpha===0&&this.modelScene.parameter.progress!==1){let{pano0:e,pano1:t}=this.modelScene.parameter;e&&e.map!==(t==null?void 0:t.map)&&e.map.dispose(),n.progress=1,n.pano0=n.pano1=t}let o=0;if(this.cameraType===`auto`?o=Math.abs(Math.PI/2-this.cameraMotion.value.latitude)<.02||Math.abs(-Math.PI/2-this.cameraMotion.value.latitude)<.02?1:0:this.cameraType===`perspective`?o=0:this.cameraType===`orthographic`&&(o=1),this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho!==o&&this.perspToOrthoMotion.set({perspToOrtho:o},500).catch(noop),this.perspToOrthoMotion.ended||(this.perspToOrthoMotion.update(e),this.camera.perspToOrtho.setScalar(clamp$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),isEmptyObject(n)||this.modelScene.parameter.set(n),isEmptyObject(r)||this.setCamera(r),this.cameraFence&&!this.panState&&!this.pinchState&&!this.mouseWheelState&&!this.inMomentumMovement&&this.locationMotion.ended&&this.perspToOrthoMotion.ended&&this.cameraMotion.ended){let e=coordinatesToVector(this.camera.pose,new three.Vector3),t=new three.Vector3().copy(this.camera.pose.offset).sub(e.clone().multiplyScalar(this.camera.pose.distance));if(this.cameraFence.distanceToPoint(t)>.01){let e=this.cameraFence.clampPoint(t,new three.Vector3),n=this.camera.pose.offset.clone().add(e).sub(t),r=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:n,distance:this.camera.pose.distance});this.fixFinalState(r),this.locationMotion.set({x:r.offset.x,y:r.offset.y,z:r.offset.z,distance:r.distance},300).catch(noop)}}if(this.intersectMesh&&this.intersectMesh.parent){let e=clamp$1(this.camera.position.distanceTo(this.intersectMesh.position)*(2*Math.tan(.5*this.camera.fov/180*Math.PI))/5,.5);this.intersectMesh.scale.setScalar(e)}else this.intersectMesh.scale.setScalar(1)}getTargetState(){let e=this.cameraMotion.getKeyFrameSegment(now())[1],t=this.locationMotion.getKeyFrameSegment(now())[1];return Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:e.value.longitude,latitude:e.value.latitude,fov:e.value.fov,distance:t.value.distance,offset:new three.Vector3(t.value.x,t.value.y,t.value.z)})}initAnimation(){return this.destroyed?Promise.resolve():new Promise(t=>{let{state:n,currentState:r,duration:o,userAction:s}=this.initial;this.userAction=s;let c=e.initAnimationEndState(this),l={longitude:c.longitude,latitude:c.latitude,fov:c.fov},u={x:c.offset.x,y:c.offset.y,z:c.offset.z,distance:c.distance};this.emit(`initAnimation.start`,createEvent(`initAnimation.start`,{state:c,userAction:this.userAction})),this.perspToOrthoMotion.set({perspToOrtho:0},o).catch(noop),this.modelAlphaMotion.set({modelAlpha:1},o/3).catch(noop),this.cameraMotion.set(l,o).catch(noop),this.locationMotion.set(u,o).then(()=>{this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:c,userAction:this.userAction}))},e=>{let t=Object.assign(Object.assign(Object.assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`initAnimation.end`,createEvent(`initAnimation.end`,{state:t,userAction:this.userAction}))}).then(()=>{t()})})}getForwardObserverOrNot(e){let[t]=this.modelScene.intersectRaycaster(e);if(!t)return null;let n=[];for(let t of this.works){let r=this.modelScene.models.find(e=>e.work===t);if(!(!r||r.visible===!1)&&!(t.observers.length<=0)&&(scratchObserverBox.copy(t.observerBox).expandByScalar(10).applyMatrix4(t.transform),scratchObserverBox.containsPoint(e.ray.origin)||e.ray.intersectsBox(scratchObserverBox)))for(let e of t.observers)n.push(e)}let[r,o]=arrayMin(n,e=>scratchVector3$1.copy(e.standingPosition).applyMatrix4(e.work.transform).distanceTo(t.point),!0);return r&&o<Math.max(r.standingPosition.distanceTo(this.camera.position)/5,10)?r:null}coordinatesForOffset(e){let t=this.renderer.getSize(new three.Vector2);return{longitude:-2*e.x/(t.x*this.viewport.width),latitude:2*e.y/(t.y*this.viewport.height)}}requestMomentumMovement(e,t,n,r){if(this.inMomentumMovement===null)return;r=Math.max(r,1);let o=Object.assign({},n),s={longitude:0,latitude:0,x:0,y:0,z:0};for(let e=0;e<r;e++)o.longitude*=.996,o.latitude*=.996*.998,o.x*=.99,o.y*=.99,o.z*=.99,s.longitude+=o.longitude,s.latitude+=o.latitude,s.x+=o.x,s.y+=o.y,s.z+=o.z;let c=this.cameraMotion.value.fov,l=formatRad$1(this.cameraMotion.value.longitude+s.longitude),u=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(c):this.minLatitude,-Math.PI/2,Math.PI/2),d=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(c):this.maxLatitude,-Math.PI/2,Math.PI/2),f=clamp$1(this.cameraMotion.value.latitude+s.latitude,u,d),p=new three.Vector3(this.locationMotion.value.x+s.x,this.locationMotion.value.y+s.y,this.locationMotion.value.z+s.z),m=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:l,latitude:f,offset:p,fov:c,distance:this.locationMotion.value.distance}),h=e.state.offset.clone().sub(coordinatesToVector(e.state).setLength(m.distance)),g=!(Math.abs(o.longitude)>1e-4||Math.abs(o.latitude)>1e-4||Math.abs(o.x)>1e-4||Math.abs(o.y)>1e-4||Math.abs(o.z)>1e-4);(this.cameraFence?this.cameraFence.containsPoint(h):!0)===!1&&(g=!0);let _=createEvent(`gesture.momentum`,Object.assign(Object.assign({},e),{isFirst:t,isFinal:g,state:m}));if(this.emit(`gesture.fire`,_),this.inMomentumMovement.event=_,this.emit(`gesture.momentum`,_),e.defaultPrevented){this.inMomentumMovement=null;return}this.inMomentumMovement&&(this.cameraMotion.set({longitude:l,latitude:f},0).catch(noop),this.locationMotion.set({x:m.offset.x,y:m.offset.y,z:m.offset.z,distance:m.distance},0).catch(noop),g?this.inMomentumMovement=null:AnimationFrameLoop.shared.add((t,n)=>{this.requestMomentumMovement(e,!1,o,n)},!0))}fixFinalState(e){if(this.perspToOrthoMotion.getTargetKeyframe().value.perspToOrtho===1)return;let t=coordinatesToVector(e,new three.Vector3),n=new three.Vector3().copy(e.offset).sub(t.clone().setLength(e.distance)),r=new three.Raycaster(n,t);r.params.Points={threshold:.1},r.firstHitOnly=!0,r.hitFilter=e=>e.distance>minDistance+r.near,r.near=this.camera.near,r.far=this.camera.far;let o;if(o=this.modelScene.intersectRaycaster(r)[0],o&&o.distance<this.camera.near&&(o=void 0),!o){let e=new three.Plane(new three.Vector3(0,1,0),-this.modelScene.boundingBox.min.y),t=r.ray.intersectPlane(e,new three.Vector3);if(t){let e=t.distanceTo(r.ray.origin);e<1e3&&e>=r.near&&(o={distance:e,floorIndex:0,floor:0,point:t,object:this.scene,face:null})}}if(!o){let r=Math.max(e.distance,3);o={distance:r,floorIndex:0,floor:0,point:n.clone().add(t.clone().setLength(r)),object:this.scene,face:null}}o.distance>=this.camera.near&&notSimilarValue(e.distance,o.distance)&&(e.distance=o.distance,e.offset=o.point)}onPanGesture(e){this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();let t=e.pointers.length,n=this.panState,r=0,o=!1;e.pointerType===`mouse`&&(r=e.center.buttons,o=e.center.shiftKey),n&&r===0&&n.buttons!==0&&(r=n.buttons);let s=n==null?void 0:n.target;if(!s){let t=this.relativeClientPosition(e.center),n=this.createRaycasterFromCamera(t,this.camera);s=new three.Vector3().copy(n.ray.direction).multiplyScalar(3).add(n.ray.origin);let[r]=this.modelScene.intersectRaycaster(n);if(!r&&n.ray.direction.y<-.3){let e=new three.Plane(new three.Vector3(0,1,0),0),t=n.ray.intersectPlane(e,new three.Vector3);if(t){let e=t.distanceTo(n.ray.origin);e<1e4&&e>=n.near&&(r={distance:e,floorIndex:0,floor:0,point:t,object:this.scene})}}if(r)s.copy(r.point);else{let e=new three.Vector3().copy(this.camera.pose.offset).sub(this.camera.position).normalize(),t=new three.Plane().setFromNormalAndCoplanarPoint(e,this.camera.pose.offset);n.ray.intersectPlane(t,s)}}if(e.isFinal?this.panState=void 0:this.panState={target:s,buttons:r,pointerLength:t,defaultPrevented:e.defaultPrevented,x:e.center.x,y:e.center.y},n===void 0||n.pointerLength!==t){this.emit(`gesture.pan`,e);return}if(t>1||r===2||o){let t={x:e.center.x-n.x,y:e.center.y-n.y},r=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),o=coordinatesToVector(this.cameraMotion.value).setLength(this.locationMotion.value.distance).add(r),s=new three.Vector3().copy(o).sub(n.target).length();s*=Math.tan(this.camera.pose.fov/2*Math.PI/180);let c=this.renderer.getSize(new three.Vector2),l=2*t.x*s/c.y,u=2*t.y*s/c.y,d=new three.Vector3;d.setFromMatrixColumn(this.camera.matrix,0),d.multiplyScalar(-l),r.add(d),this.camera.pose.latitude<PANGESTURE_FORWARD_ANGLE?d.setFromMatrixColumn(this.camera.matrix,1):(d.setFromMatrixColumn(this.camera.matrix,0),d.crossVectors(this.camera.up,d)),d.multiplyScalar(u),r.add(d);let f=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:r,distance:this.camera.pose.distance});if(e.state=f,this.emit(`gesture.pan`,e),e.defaultPrevented){this.panState&&(this.panState.defaultPrevented=e.defaultPrevented);return}if(e.isFinal&&n.defaultPrevented)return;if(this.locationMotion.set({x:f.offset.x,y:f.offset.y,z:f.offset.z},0).catch(noop),e.isFinal&&(this.fixFinalState(f),Object.assign(e,{__fixFinalState:!0}),this.locationMotion.set({distance:f.distance,x:f.offset.x,y:f.offset.y,z:f.offset.z},0).catch(noop)),e.isFinal){let t=this.renderer.getSize(new three.Vector2),n=2*e.velocityX*s/t.y,r=2*e.velocityY*s/t.y,o=new three.Vector3,c=new three.Vector3;o.setFromMatrixColumn(this.camera.matrix,0),o.multiplyScalar(-n),c.add(o),this.camera.pose.latitude<PANGESTURE_FORWARD_ANGLE?o.setFromMatrixColumn(this.camera.matrix,1):(o.setFromMatrixColumn(this.camera.matrix,0),o.crossVectors(this.camera.up,o)),o.multiplyScalar(r),c.add(o),this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,{longitude:0,latitude:0,x:c.x,y:c.y,z:c.z},0)}}else{let t={x:e.center.x-n.x,y:e.center.y-n.y},r=this.coordinatesForOffset(t),o=formatRad$1(this.cameraMotion.value.longitude+r.longitude),s=this.camera.pose.fov,c=clamp$1(typeof this.minLatitude==`function`?this.minLatitude(s):this.minLatitude,-Math.PI/2,Math.PI/2),l=clamp$1(typeof this.maxLatitude==`function`?this.maxLatitude(s):this.maxLatitude,-Math.PI/2,Math.PI/2),u=clamp$1(this.cameraMotion.value.latitude+r.latitude,c,l);this.camera.aspect<1&&Math.abs(e.overallVelocityX)>.2&&Math.atan2(Math.abs(e.overallVelocityY),Math.abs(e.overallVelocityX))<Math.PI/6.923&&(u=this.cameraMotion.value.latitude);let d=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:o,latitude:u,fov:s,offset:this.camera.pose.offset,distance:this.camera.pose.distance});if(e.isFinal&&Object.assign(e,{__fixFinalState:!0}),e.state=d,this.emit(`gesture.pan`,e),e.defaultPrevented||e.isFinal&&n.defaultPrevented)return;if(e.isFinal?this.locationMotion.set({distance:d.distance,x:d.offset.x,y:d.offset.y,z:d.offset.z},0).catch(noop):this.cameraMotion.set({longitude:d.longitude,latitude:d.latitude},0).catch(noop),e.isFinal){let t=e.velocityX,n=e.velocityY;this.inMomentumMovement={uuid:createUuid()},this.requestMomentumMovement(e,!0,Object.assign(Object.assign({},this.coordinatesForOffset({x:t,y:n})),{x:0,y:0,z:0}),0)}}}onPinchGesture(t){var n;if(!this.initAnimationIsReady)return;this.userAction=t.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();let r=(n=this.pinchState)==null?void 0:n.distance;if(t.isFirst){this.pinchState={x:t.center.x,y:t.center.y,scale:1,distance:this.locationMotion.value.distance};return}if(r===void 0)return;let o=this.modelScene.boundingBox.getCenter(new three.Vector3),s=e.distanceFromModel(this.modelScene,this.cameraMotion.value.fov,this.camera.aspect),c=clamp$1(r/t.scale,minDistance,1/0),l=t.state.offset.clone().sub(coordinatesToVector(t.state).setLength(c)),u=this.modelScene.boundingBox.containsPoint(l),d;if(!u&&this.pinchState&&this.pinchState.scale>t.scale&&o.distanceTo(l)>s?d=t.state.distance:(d=c,this.pinchState&&(this.pinchState.scale=t.scale)),t.state.distance=d,this.emit(`gesture.pinch`,t),!t.defaultPrevented&&(this.locationMotion.set({distance:t.state.distance},0).catch(noop),t.pointerType!==`mouse`&&(t.type=`gesture.pan`,this.onPanGesture(t)),t.isFinal)){if(!(`__fixFinalState`in t)){let e=t.state;this.fixFinalState(t.state);let n={x:e.offset.x,y:e.offset.y,z:e.offset.z,distance:e.distance};this.locationMotion.set(n,0).catch(noop)}this.panState=void 0,this.pinchState=void 0}}onMouseMove(e){var t,n;if(!this.intersectMesh.parent||this.panState||this.pinchState||this.mouseWheelState||(this.emit(`gesture.mousemove`,e),e.defaultPrevented))return;let r=e.center.raycaster;if(e.isFinal&&this.intersectMesh.parent&&this.intersectMesh.visible===!0){this.hideIntersectMesh();return}let[o]=this.modelScene.intersectRaycaster(r),s=createEvent(`intersect.update`,{raycaster:r,intersection:o==null?null:o,object:this.intersectMesh});if(this.emit(`intersect.update`,s),s.defaultPrevented){this.hideIntersectMesh();return}if(o){let e=(n=(t=o.face)==null?void 0:t.normal)==null?new three.Vector3().copy(r.ray.direction).multiplyScalar(-1):n,s=e.clone(),c=o.point.clone();this.intersectMesh.position.copy(c);let l=c.clone().add(s);if(this.intersectMesh.lookAt(l),Math.abs(e.y)>.99){let e=this.camera.position.clone().sub(c);this.intersectMesh.rotation.z=-Math.atan2(e.z,e.x)}this.intersectMesh.visible=!0,this.needsRender=!0}else this.hideIntersectMesh()}onMouseWheel(t){if(this.initAnimationIsReady)if(this.userAction=t.userAction,this.stopMomentumMovement(),this.hideIntersectMesh(),t.isFinal){let e=Object.assign(Object.assign({},this.currentPano),{mode:this.mode,longitude:this.cameraMotion.value.longitude,latitude:this.cameraMotion.value.latitude,fov:this.cameraMotion.value.fov,offset:new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),distance:this.locationMotion.value.distance});if(this.fixFinalState(e),this.emit(`gesture.mousewheel`,t),t.defaultPrevented)return;let n={x:e.offset.x,y:e.offset.y,z:e.offset.z,distance:e.distance};this.locationMotion.set(n,0).catch(noop)}else{let n=e.distanceFromModel(this.modelScene,this.cameraMotion.value.fov,this.camera.aspect),r=new three.Vector3(this.locationMotion.value.x,this.locationMotion.value.y,this.locationMotion.value.z),o=coordinatesToVector(this.cameraMotion.value,new three.Vector3).negate(),s=new three.Ray(r,o).intersectBox(this.modelScene.boundingBox,new three.Vector3);s&&(n+=s.distanceTo(r));let c=Math.max(this.locationMotion.value.distance-this.camera.near,0),l=t.center.delta/10*Math.max(c/5,.1);if(c<=n||l>0)if(this.locationMotion.value.distance-l>=minDistance){let e=this.locationMotion.value.distance-l;t.state.distance=e}else{let e=coordinatesToVector(this.cameraMotion.value);e.setLength(l),t.state.offset.add(e)}if(this.emit(`gesture.mousewheel`,t),t.defaultPrevented)return;this.locationMotion.set({distance:t.state.distance,x:t.state.offset.x,y:t.state.offset.y,z:t.state.offset.z},0).catch(noop)}}onTapGesture(e){var t;this.userAction=e.userAction,this.stopMomentumMovement();let n=e.center.raycaster,r=this.getForwardObserverOrNot(n);if(!r)this.emit(`gesture.tap`,e);else{let n={longitude:this.camera.pose.longitude,latitude:0},o=Object.assign(Object.assign({},e.state),{mode:`Panorama`,workCode:r.work.workCode,panoIndex:r.panoIndex,longitude:n.longitude,latitude:n.latitude,offset:r?r.position.clone():new three.Vector3,distance:0});if(e.state=o,this.emit(`gesture.tap`,e),!e.defaultPrevented&&(this.emit(`pano.select`,createEvent(`pano.select`,{prevPano:this.currentPano,state:o,userAction:e.userAction,options:n,progress:0,error:null})),r&&r.active)){let e=this.pendingTextureId=createUuid(),s=panoStringify({panoIndex:r.panoIndex,workCode:r.work.workCode}),c={right:r.images.work.getURL(r.images.right),left:r.images.work.getURL(r.images.left),up:r.images.work.getURL(r.images.up),down:r.images.work.getURL(r.images.down),front:r.images.work.getURL(r.images.front),back:r.images.work.getURL(r.images.back)},l=this.imageOptions.transform,u=Object.assign({key:`pano.${s}`},pick(this.imageOptions,[`format`,`size`,`quality`,`sharpen`,`forceUseExifOrientation`,`mappings`])),d=`pano:`+jsonHash([c,u,l]),f=this.modelScene.parameter,p;f.pano0&&f.pano0.map.name===d?p=f.pano0:f.pano1&&f.pano1.map.name===d&&(p=f.pano1),p?(f.pano0&&f.pano0.map!==p.map&&f.pano0.map.dispose(),f.pano1&&f.pano1.map!==p.map&&f.pano1.map!==((t=f.pano0)==null?void 0:t.map)&&f.pano1.map.dispose(),f.set({pano0:p,pano1:p}),this.emit(`pano.request`,createEvent(`pano.request`,{userAction:!0,prevPano:this.currentPano,progress:0,state:o,options:n,error:null}))):this.textureLoader.loadCubeTexture(c,{imageURL:{transform:l,options:u},format:three.RGBFormat,viaAjax:!0,fetcher:getFetcher(this.fiveId,r.work)},void 0,void 0,void 0,this.renderer).then(t=>{var c,l;let{body:u}=t;if(this.destroyed||this.pendingTextureId!==e){u.dispose();return}this.pendingTextureId=null,u.name=d;let p=Array.isArray(u.image)?u.image[0]:u.image,m=(c=p==null?void 0:p.width)==null?2048:c,h=r.images.histogram;h||(h=new Histogram().formPixels(getRgbaDataFromCubeTexture(this.renderer,u,!0,sharedHistogramRgbaData).data),r.images.histogram=h);let g={panoId:s,map:u,mapSize:m,mapHistogram:new three.Vector4().fromArray(h.toArray()),matrix:r.matrix.clone().premultiply(r.work.transform),zoom:1};f.pano0&&f.pano0.map.dispose(),f.pano1&&f.pano1.map!==((l=f.pano0)==null?void 0:l.map)&&f.pano1.map.dispose(),f.set({pano0:g,pano1:g}),this.emit(`pano.request`,createEvent(`pano.request`,{userAction:!0,prevPano:this.currentPano,progress:0,state:o,options:n,error:null}))}).catch(t=>{this.destroyed||this.pendingTextureId!==e||(this.pendingTextureId=null)})}}}onDblTapGesture(e){if(!this.initAnimationIsReady)return;this.userAction=e.userAction,this.stopMomentumMovement(),this.hideIntersectMesh();let t=e.state,n=e.center.raycaster,r=n.ray.origin.clone().add(n.ray.direction.clone().setLength(3)),o=1,s=3,c=1,[l]=this.modelScene.intersectRaycaster(n);if(l&&(r=l.point.clone(),c=l.distance>4/2?1:3),e.state.distance=c,e.state.offset=r,this.emit(`gesture.dbltap`,e),e.defaultPrevented)return;let u={x:t.offset.x,y:t.offset.y,z:t.offset.z,distance:t.distance};this.locationMotion.set(u,360).catch(noop),this.hideIntersectMesh()}hideIntersectMesh(){this.intersectMesh.visible===!0&&(this.intersectMesh.visible=!1,this.needsRender=!0)}};function isNil(e){return e==null}var _moveEvent={type:`move`},XRController=class{constructor(){this._targetRay=null,this._grip=null,this._hand=null,this._axes=[0,0]}getHandSpace(){return this._hand===null&&(this._hand=new three.Group,this._hand.matrixAutoUpdate=!1,this._hand.visible=!1,this._hand.joints={},this._hand.inputState={pinching:!1}),this._hand}getTargetRaySpace(){return this._targetRay===null&&(this._targetRay=new three.Group,this._targetRay.matrixAutoUpdate=!1,this._targetRay.visible=!1,this._targetRay.hasLinearVelocity=!1,this._targetRay.linearVelocity=new three.Vector3,this._targetRay.hasAngularVelocity=!1,this._targetRay.angularVelocity=new three.Vector3),this._targetRay}getGripSpace(){return this._grip===null&&(this._grip=new three.Group,this._grip.matrixAutoUpdate=!1,this._grip.visible=!1,this._grip.hasLinearVelocity=!1,this._grip.linearVelocity=new three.Vector3,this._grip.hasAngularVelocity=!1,this._grip.angularVelocity=new three.Vector3),this._grip}dispatchEvent(e){return this._targetRay!==null&&this._targetRay.dispatchEvent(e),this._grip!==null&&this._grip.dispatchEvent(e),this._hand!==null&&this._hand.dispatchEvent(e),this}disconnect(e){return this.dispatchEvent({type:`disconnected`,data:e}),this._targetRay!==null&&(this._targetRay.visible=!1),this._grip!==null&&(this._grip.visible=!1),this._hand!==null&&(this._hand.visible=!1),this}getAxes(){return this._axes}update(e,t,n){let r=null,o=null,s=null,c=this._targetRay,l=this._grip,u=this._hand;if(e&&e.gamepad&&e.gamepad.axes&&(this._axes=[e.gamepad.axes[2],e.gamepad.axes[3]]),e&&t.session.visibilityState!==`visible-blurred`)if(c!==null&&(r=t.getPose(e.targetRaySpace,n),r!==null&&(c.matrix.fromArray(r.transform.matrix),c.matrix.decompose(c.position,c.rotation,c.scale),r.linearVelocity?(c.hasLinearVelocity=!0,c.linearVelocity.copy(r.linearVelocity)):c.hasLinearVelocity=!1,r.angularVelocity?(c.hasAngularVelocity=!0,c.angularVelocity.copy(r.angularVelocity)):c.hasAngularVelocity=!1,this.dispatchEvent(_moveEvent))),u&&e.hand){s=!0;for(let r of e.hand.values()){let e=t.getJointPose(r,n);if(u.joints[r.jointName]===void 0){let e=new three.Group;e.matrixAutoUpdate=!1,e.visible=!1,u.joints[r.jointName]=e,u.add(e)}let o=u.joints[r.jointName];e!==null&&(o.matrix.fromArray(e.transform.matrix),o.matrix.decompose(o.position,o.rotation,o.scale),o.jointRadius=e.radius),o.visible=e!==null}let r=u.joints[`index-finger-tip`],o=u.joints[`thumb-tip`],c=r.position.distanceTo(o.position),l=.02,d=.005;u.inputState.pinching&&c>l+d?(u.inputState.pinching=!1,this.dispatchEvent({type:`pinchend`,handedness:e.handedness,target:this})):!u.inputState.pinching&&c<=l-d&&(u.inputState.pinching=!0,this.dispatchEvent({type:`pinchstart`,handedness:e.handedness,target:this}))}else l!==null&&e.gripSpace&&(o=t.getPose(e.gripSpace,n),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 c!==null&&(c.visible=r!==null),l!==null&&(l.visible=o!==null),u!==null&&(u.visible=s!==null),this}},framebufferScaleFactor=1,isAppleVisionPro=()=>{try{let e=/Macintosh/i.test(navigator.userAgent),t=navigator.maxTouchPoints===5;return e&&t}catch(e){return console.error(`Error determining if the device is an Apple Vision Pro: `,e),!1}},isOculus=()=>{try{return/Oculus/i.test(navigator.userAgent)}catch(e){return console.error(`Error determining if the device is an Oculus: `,e),!1}},XRManager=class{constructor(e,t,n){var r,o,s,c,l;this.isPanorama=(r=n==null?void 0:n.isPanorama)==null?!0:r,navigator.userAgent.toLowerCase();let u;u=isAppleVisionPro()?`VP`:isOculus()?`Oculus`:`Pico`,this.machineType=(o=n==null?void 0:n.machineType)==null?u:o,this.renderer=e,this.gl=t,this.enabled=!1,this.session=null,this.referenceSpaceType=(s=n==null?void 0:n.referenceSpaceType)==null?`local-floor`:s,this.referenceSpace=null,this.onSessionStartCallback=(c=n==null?void 0:n.onSessionStart)==null?noop:c,this.onSessionEndCallback=(l=n==null?void 0:n.onSessionEnd)==null?noop:l,this.controllers=[new XRController,new XRController],this.inputSourcesMap=new Map,this.cameraVR=new three.ArrayCamera,this.cameraL=new three.PerspectiveCamera,this.cameraR=new three.PerspectiveCamera,this.cameraVR.cameras.push(this.cameraL,this.cameraR),this.cameraL.viewport=new three.Vector4,this.cameraR.viewport=new three.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.Vector3,this.cameraRPos=new three.Vector3}getController(e){let t=this.controllers[e];return t||console.warn(`no controller find`),t.getTargetRaySpace()}getRightController(){if(!this.session||!this.session.inputSources)return null;let e;if(this.session.inputSources.forEach((t,n)=>{t.handedness===`right`&&(e=n)}),e===void 0)return console.warn(`no inputSource for right hand`),null;let t=this.controllers[e];return t?t.getTargetRaySpace():(console.warn(`right controller not find`),null)}getLeftController(){if(!this.session||!this.session.inputSources)return null;let e;if(this.session.inputSources.forEach((t,n)=>{t.handedness===`left`&&(e=n)}),e===void 0)return console.warn(`no inputSource for left hand`),null;let t=this.controllers[e];return t?t.getTargetRaySpace():(console.warn(`left controller not find`),null)}getControllerGrip(e){let t=this.controllers[e];return t||console.warn(`no controller find`),t.getGripSpace()}getCameras(){return{cameraL:this.cameraL,cameraR:this.cameraR,cameraVR:this.cameraVR}}updateCamera(e,t){t===null?e.matrixWorld.copy(e.matrix):e.matrixWorld.multiplyMatrices(t.matrixWorld,e.matrix),e.matrixWorldInverse.getInverse(e.matrixWorld)}setProjectionFromUnion(e,t,n){this.cameraLPos.setFromMatrixPosition(t.matrixWorld),this.cameraRPos.setFromMatrixPosition(n.matrixWorld);var r=this.cameraLPos.distanceTo(this.cameraRPos),o=t.projectionMatrix.elements,s=n.projectionMatrix.elements,c=o[14]/(o[10]-1),l=o[14]/(o[10]+1),u=(o[9]+1)/o[5],d=(o[9]-1)/o[5],f=(o[8]-1)/o[0],p=(s[8]+1)/s[0],m=c*f,h=c*p,g=r/(-f+p),_=g*-f;t.matrixWorld.decompose(e.position,e.quaternion,e.scale),e.translateX(_),e.translateZ(g),e.matrixWorld.compose(e.position,e.quaternion,e.scale),e.matrixWorldInverse.getInverse(e.matrixWorld);var v=c+g,y=l+g,b=m-_,S=h+(r-_),C=u*l/y*v,w=d*l/y*v;e.projectionMatrix.makePerspective(b,S,C,w,v,y)}getCamera(e){this.cameraVR.near=this.cameraR.near=this.cameraL.near=e.near,this.cameraVR.far=this.cameraR.far=this.cameraL.far=e.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);let t=e.parent,n=this.cameraVR.cameras;this.updateCamera(this.cameraVR,t);for(let e=0;e<n.length;e++)this.updateCamera(n[e],t);e.matrixWorld.copy(this.cameraVR.matrixWorld);let r=e.children;for(let e=0,t=r.length;e<t;e++)r[e].updateMatrixWorld(!0);return n.length===2?this.setProjectionFromUnion(this.cameraVR,this.cameraL,this.cameraR):this.cameraVR.projectionMatrix.copy(this.cameraL.projectionMatrix),this.cameraVR}updateInputSources(e){if(!this.session){console.warn(`session is lose!`);return}let t=this.session.inputSources;for(let e=0;e<this.controllers.length;e++)this.inputSourcesMap.set(t[e],this.controllers[e]);for(let t=0;t<e.removed.length;t++){let n=e.removed[t],r=this.inputSourcesMap.get(n);r&&(r.dispatchEvent({type:`disconnected`,data:n}),this.inputSourcesMap.delete(n))}for(let t=0;t<e.added.length;t++){let n=e.added[t],r=this.inputSourcesMap.get(n);r&&r.dispatchEvent({type:`connected`,data:n})}}onSessionEvent(e){let t=this.inputSourcesMap.get(e.inputSource);t&&t.dispatchEvent({type:e.type})}onSessionEnd(){this.inputSourcesMap.forEach(function(e,t){e.disconnect(t)}),this.inputSourcesMap.clear(),this.isPresenting=!1,this.session=null,AnimationFrameLoop.shared.setContext(null),this.onSessionEndCallback()}onRequestReferenceSpace(e){this.referenceSpace=e,this.isPresenting=!0,this.session&&this.onSessionStartCallback(this.session)}setSession(e){if(this.session=e,this.session){this.session.addEventListener(`select`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`selectstart`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`selectend`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`squeeze`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`squeezestart`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`squeezeend`,e=>{this.onSessionEvent(e)}),this.session.addEventListener(`end`,e=>{this.onSessionEnd()});let e=this.gl.getContextAttributes();this.gl.makeXRCompatible().then(()=>{let t={antialias:e==null?void 0:e.antialias,alpha:e==null?void 0:e.alpha,depth:e==null?void 0:e.depth,stencil:e==null?void 0:e.stencil,framebufferScaleFactor};if(!this.session){console.error(`session is lose while set session!`);return}switch(this.machineType){case`Pico`:case`VP`:this.session.updateRenderState({baseLayer:new XRWebGLLayer(this.session,this.gl,t)});break;case`Oculus`:this.session.updateRenderState({baseLayer:new XRWebGLLayer(this.session,this.gl,t)});break;default:this.machineType;break}this.session.requestReferenceSpace(this.referenceSpaceType).then(e=>{this.onRequestReferenceSpace(e)}),this.session.addEventListener(`inputsourceschange`,e=>{this.updateInputSources(e)})})}}},LineSegmentsGeometry=class extends three.InstancedBufferGeometry{constructor(){super(),this.type=`LineSegmentsGeometry`,this.setIndex([0,2,1,2,3,1,2,4,3,4,5,3,4,6,5,6,7,5]),this.setAttribute(`position`,new three.Float32BufferAttribute([-1,2,0,1,2,0,-1,1,0,1,1,0,-1,0,0,1,0,0,-1,-1,0,1,-1,0],3)),this.setAttribute(`uv`,new three.Float32BufferAttribute([-1,2,1,2,-1,1,1,1,-1,-1,1,-1,-1,-2,1,-2],2))}applyMatrix4(e){let t=this.attributes.instanceStart,n=this.attributes.instanceEnd;return t!==void 0&&(t.applyMatrix4(e),n.applyMatrix4(e),t.needsUpdate=!0),this.boundingBox!==null&&this.computeBoundingBox(),this.boundingSphere!==null&&this.computeBoundingSphere(),this}setPositions(e){let t;t=e instanceof Float32Array?e:Array.isArray(e)?new Float32Array(e):new Float32Array;let n=new three.InstancedInterleavedBuffer(t,6,1);return this.setAttribute(`instanceStart`,new three.InterleavedBufferAttribute(n,3,0)),this.setAttribute(`instanceEnd`,new three.InterleavedBufferAttribute(n,3,3)),this.computeBoundingBox(),this.computeBoundingSphere(),this}setColors(e){let t;t=e instanceof Float32Array?e:Array.isArray(e)?new Float32Array(e):new Float32Array;let n=new three.InstancedInterleavedBuffer(t,6,1);return this.setAttribute(`instanceColorStart`,new three.InterleavedBufferAttribute(n,3,0)),this.setAttribute(`instanceColorEnd`,new three.InterleavedBufferAttribute(n,3,3)),this}fromWireframeGeometry(e){return this.setPositions(e.attributes.position.array),this}fromEdgesGeometry(e){return this.setPositions(e.attributes.position.array),this}fromMesh(e){return this.fromWireframeGeometry(new three.WireframeGeometry(e.geometry)),this}fromLineSegments(e){var t=e.geometry;if(t instanceof three.Geometry){let e=new three.BufferGeometry().fromGeometry(t);this.setPositions(e.attributes.position.array)}else t instanceof three.BufferGeometry&&this.setPositions(t.attributes.position.array);return this}computeBoundingBox(){this.boundingBox===null&&(this.boundingBox=new three.Box3);let e=this.attributes.instanceStart,t=this.attributes.instanceEnd;if(e!==void 0&&t!==void 0){let n=new three.Box3;this.boundingBox.setFromBufferAttribute(e),n.setFromBufferAttribute(t),this.boundingBox.union(n)}}computeBoundingSphere(){this.boundingSphere===null&&(this.boundingSphere=new three.Sphere),this.boundingBox===null&&this.computeBoundingBox();let e=this.attributes.instanceStart,t=this.attributes.instanceEnd;if(e!==void 0&&t!==void 0){let n=this.boundingSphere.center;this.boundingBox.getCenter(n);let r=0,o=new three.Vector3;for(let s=0,c=e.count;s<c;s++)o.fromBufferAttribute(e,s),r=Math.max(r,n.distanceToSquared(o)),o.fromBufferAttribute(t,s),r=Math.max(r,n.distanceToSquared(o));this.boundingSphere.radius=Math.sqrt(r),isNaN(this.boundingSphere.radius)&&console.error(`THREE.LineSegmentsGeometry.computeBoundingSphere(): Computed radius is NaN. The instanced position data is likely to have NaN values.`,this)}}toJSON(){}};Object.assign(LineSegmentsGeometry.prototype,{isLineSegmentsGeometry:!0});var lineShader={uniforms:three.UniformsUtils.merge([three.UniformsLib.common,three.UniformsLib.fog,{linewidth:{value:1},resolution:{value:new three.Vector2(1,1)},dashScale:{value:1},dashSize:{value:1},gapSize:{value:1},opacity:{value:1}}]),vertexShader:`
2041
2041
  #include <common>
2042
2042
  #include <color_pars_vertex>
2043
2043
  #include <fog_pars_vertex>
@@ -2236,7 +2236,7 @@ void main() {
2236
2236
  #include <premultiplied_alpha_fragment>
2237
2237
 
2238
2238
  }
2239
- `},LineMaterial=class extends three.ShaderMaterial{constructor(e){super({uniforms:three.UniformsUtils.clone(lineShader.uniforms),vertexShader:lineShader.vertexShader,fragmentShader:lineShader.fragmentShader,clipping:!0}),this.type=`LineMaterial`,this.dashed=!1,Object.defineProperties(this,{color:{enumerable:!0,get(){return this.uniforms.diffuse.value},set(e){this.uniforms.diffuse.value=e}},linewidth:{enumerable:!0,get(){return this.uniforms.linewidth.value},set(e){this.uniforms.linewidth.value=e}},dashScale:{enumerable:!0,get(){return this.uniforms.dashScale.value},set(e){this.uniforms.dashScale.value=e}},dashSize:{enumerable:!0,get(){return this.uniforms.dashSize.value},set(e){this.uniforms.dashSize.value=e}},gapSize:{enumerable:!0,get(){return this.uniforms.gapSize.value},set(e){this.uniforms.gapSize.value=e}},opacity:{enumerable:!0,get(){return this.uniforms.opacity.value},set(e){this.uniforms.opacity.value=e}},resolution:{enumerable:!0,get(){return this.uniforms.resolution.value},set(e){this.uniforms.resolution.value.copy(e)}}}),this.setValues(e)}};Object.assign(LineMaterial.prototype,{isLineMaterial:!0});var LineSegments2=class extends three.Mesh{constructor(e,t){super(),this.type=`LineSegments2`,this.geometry=e===void 0?new LineSegmentsGeometry:e,this.material=t===void 0?new LineMaterial({color:Math.random()*16777215}):t}computeLineDistances(){let e=this.geometry,t=e.attributes.instanceStart,n=e.attributes.instanceEnd,r=new Float32Array(2*t.count),o=new three.Vector3,s=new three.Vector3;for(var c=0,l=0,u=t.count;c<u;c++,l+=2)o.fromBufferAttribute(t,c),s.fromBufferAttribute(n,c),r[l]=l===0?0:r[l-1],r[l+1]=r[l]+o.distanceTo(s);let d=new three.InstancedInterleavedBuffer(r,2,1);return e.setAttribute(`instanceDistanceStart`,new three.InterleavedBufferAttribute(d,1,0)),e.setAttribute(`instanceDistanceEnd`,new three.InterleavedBufferAttribute(d,1,1)),this}raycast(e,t){e.camera===null&&console.error(`LineSegments2: "Raycaster.camera" needs to be set in order to raycast against LineSegments2.`);let n=e.ray,r=e.camera,o=r.projectionMatrix,s=this.geometry,c=this.material,l=c.resolution,u=c.linewidth,d=s.attributes.instanceStart,f=s.attributes.instanceEnd,p=new three.Vector4,m=new three.Vector4,h=new three.Vector4,g=new three.Vector3,_=new three.Matrix4,v=new three.Line3,y=new three.Vector3;n.at(1,h),h.w=1,h.applyMatrix4(r.matrixWorldInverse),h.applyMatrix4(o),h.multiplyScalar(1/h.w),h.x*=l.x/2,h.y*=l.y/2,h.z=0,g.copy(h);let b=this.matrixWorld;_.multiplyMatrices(r.matrixWorldInverse,b);for(var S=0,C=d.count;S<C;S++){p.fromBufferAttribute(d,S),m.fromBufferAttribute(f,S),p.w=1,m.w=1,p.applyMatrix4(_),m.applyMatrix4(_),p.applyMatrix4(o),m.applyMatrix4(o),p.multiplyScalar(1/p.w),m.multiplyScalar(1/m.w);var w=p.z<-1&&m.z<-1,T=p.z>1&&m.z>1;if(w||T)continue;p.x*=l.x/2,p.y*=l.y/2,m.x*=l.x/2,m.y*=l.y/2,v.start.copy(p),v.start.z=0,v.end.copy(m),v.end.z=0;let e=v.closestPointToPointParameter(g,!0);v.at(e,y);let r=three.MathUtils.lerp(p.z,m.z,e),s=r>=-1&&r<=1;var E=g.distanceTo(y)<u*.5;if(s&&E){v.start.fromBufferAttribute(d,S),v.end.fromBufferAttribute(f,S),v.start.applyMatrix4(b),v.end.applyMatrix4(b);var D=new three.Vector3,O=new three.Vector3;n.distanceSqToSegment(v.start,v.end,O,D),t.push({point:O,pointOnLine:D,distance:n.origin.distanceTo(O),object:this,faceIndex:S})}}}};Object.assign(LineSegments2.prototype,{isLineSegments2:!0});var Line2=class extends LineSegments2{constructor(e,t){super(e,t),this.type=`Line2`}};Object.assign(Line2.prototype,{isLine2:!0});var LineGeometry=class extends LineSegmentsGeometry{constructor(){super(),this.type=`LineGeometry`}setPositions(e){let t=e.length-3,n=new Float32Array(2*t);for(let r=0;r<t;r+=3)n[2*r]=e[r],n[2*r+1]=e[r+1],n[2*r+2]=e[r+2],n[2*r+3]=e[r+3],n[2*r+4]=e[r+4],n[2*r+5]=e[r+5];return super.setPositions(n),this}setColors(e){let t=e.length-3,n=new Float32Array(2*t);for(let r=0;r<t;r+=3)n[2*r]=e[r],n[2*r+1]=e[r+1],n[2*r+2]=e[r+2],n[2*r+3]=e[r+3],n[2*r+4]=e[r+4],n[2*r+5]=e[r+5];return super.setColors(n),this}fromLine(e){let t=e.geometry;if(t instanceof three.Geometry){let e=new three.BufferGeometry().fromGeometry(t);this.setPositions(e.attributes.position.array)}else t instanceof three.BufferGeometry&&this.setPositions(t.attributes.position.array);return this}copy(){return this}};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=class extends three.Object3D{static get version(){return`6.8.0-alpha.22`}constructor(e=new three.Vector3,t=new three.Vector3){super(),this.type=`FiveLine`,this.needsRender=!0,this.line=new Line2(new LineGeometry,new LineMaterial({color:DEFAULT_COLOR,linewidth:DEFAULT_LINEWIDTH,dashScale:DEFAULT_DASHSCALE,dashed:!1}));let n=new three.BufferGeometry,r=new three.PointsMaterial({color:DEFAULT_COLOR,size:POINT_SIZE,map:sharedCircleTexture||(sharedCircleTexture=new three.TextureLoader().load(`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==`)),sizeAttenuation:!1,transparent:!0});this.points=new three.Points(n,r),this.points.renderOrder=11,this.points.frustumCulled=!1,this.setPoints(e,t),this.add(this.line,this.points)}setPoints(e,t){let n=[].concat(e.toArray(),t.toArray());this.points.geometry.setAttribute(`position`,new three.BufferAttribute(new Float32Array(n),3)),this.line.geometry.setPositions(n),this.line.computeLineDistances(),this.needsRender=!0}getPoints(){let e=this.points.geometry.attributes.position.array;return[new three.Vector3(e[0],e[1],e[2]),new three.Vector3(e[3],e[4],e[5])]}setMaterial(e){let t=this.line.material;for(let n in e){if(!e.hasOwnProperty(n))continue;let r=e[n];n===`dashed`?(t.dashed=r,r?t.defines.USE_DASH=``:delete t.defines.USE_DASH,t.needsUpdate=!0):t[n]=e[n]}this.needsRender=!0}setResolution(e,t){let n=this.line.material.resolution;(n.x!==e||n.y!==t)&&(n.set(e,t),this.needsRender=!0)}};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(e){return __awaiter(this,void 0,void 0,function*(){let t=yield fetch(e);if(t.ok)return t.json();throw Error(t.statusText)})}function fetchProfilesList(e){return __awaiter(this,void 0,void 0,function*(){if(!e)throw Error(`No basePath supplied`);return yield fetchJsonFile(`${e}/profilesList.json`)})}function fetchProfile(e,t){return __awaiter(this,arguments,void 0,function*(e,t,n=null,r=!0){if(!e)throw Error(`No xrInputSource supplied`);if(!t)throw Error(`No basePath supplied`);let o=yield fetchProfilesList(t),s;if(e.profiles.some(e=>{let n=o[e];return n&&(s={profileId:e,profilePath:`${t}/${n.path}`,deprecated:!!n.deprecated}),!!s}),!s){if(!n)throw Error(`No matching profile name found`);let e=o[n];if(!e)throw Error(`No matching profile name found and default profile "${n}" missing.`);s={profileId:n,profilePath:`${t}/${e.path}`,deprecated:!!e.deprecated}}let c=yield fetchJsonFile(s.profilePath),l;if(r){let t;if(t=c.layouts[e.handedness],!t)throw Error(`No matching handedness, ${e.handedness}, in profile ${s.profileId}`);t.assetPath&&(l=s.profilePath.replace(`profile.json`,t.assetPath))}return{profile:c,assetPath:l}})}var defaultComponentValues={xAxis:0,yAxis:0,button:0,state:Constants.ComponentState.DEFAULT};function normalizeAxes(e=0,t=0){let n=e,r=t;if(Math.sqrt(e*e+t*t)>1){let o=Math.atan2(t,e);n=Math.cos(o),r=Math.sin(o)}return{normalizedXAxis:n*.5+.5,normalizedYAxis:r*.5+.5}}var VisualResponse=class{constructor(e){this.componentProperty=e.componentProperty,this.states=e.states,this.valueNodeName=e.valueNodeName,this.valueNodeProperty=e.valueNodeProperty,this.valueNodeProperty===Constants.VisualResponseProperty.TRANSFORM&&(this.minNodeName=e.minNodeName,this.maxNodeName=e.maxNodeName),this.value=0,this.updateFromComponent(defaultComponentValues)}updateFromComponent({xAxis:e,yAxis:t,button:n,state:r}){let{normalizedXAxis:o,normalizedYAxis:s}=normalizeAxes(e,t);switch(this.componentProperty){case Constants.ComponentProperty.X_AXIS:this.value=this.states.includes(r)?o:.5;break;case Constants.ComponentProperty.Y_AXIS:this.value=this.states.includes(r)?s:.5;break;case Constants.ComponentProperty.BUTTON:this.value=this.states.includes(r)?n:0;break;case Constants.ComponentProperty.STATE:this.valueNodeProperty===Constants.VisualResponseProperty.VISIBILITY?this.value=this.states.includes(r):this.value=this.states.includes(r)?1:0;break;default:throw Error(`Unexpected visualResponse componentProperty ${this.componentProperty}`)}}},Component=class{constructor(e,t){if(!e||!t||!t.visualResponses||!t.gamepadIndices||Object.keys(t.gamepadIndices).length===0)throw Error(`Invalid arguments supplied`);this.id=e,this.type=t.type,this.rootNodeName=t.rootNodeName,this.touchPointNodeName=t.touchPointNodeName,this.visualResponses={},Object.keys(t.visualResponses).forEach(e=>{let n=new VisualResponse(t.visualResponses[e]);this.visualResponses[e]=n}),this.gamepadIndices=Object.assign({},t.gamepadIndices),this.values={state:Constants.ComponentState.DEFAULT,button:this.gamepadIndices.button===void 0?void 0:0,xAxis:this.gamepadIndices.xAxis===void 0?void 0:0,yAxis:this.gamepadIndices.yAxis===void 0?void 0:0}}get data(){return Object.assign({id:this.id},this.values)}updateFromGamepad(e){if(this.values.state=Constants.ComponentState.DEFAULT,this.gamepadIndices.button!==void 0&&e.buttons.length>this.gamepadIndices.button){let t=e.buttons[this.gamepadIndices.button];this.values.button=t.value,this.values.button=this.values.button<0?0:this.values.button,this.values.button=this.values.button>1?1:this.values.button,t.pressed||this.values.button===1?this.values.state=Constants.ComponentState.PRESSED:(t.touched||this.values.button>Constants.ButtonTouchThreshold)&&(this.values.state=Constants.ComponentState.TOUCHED)}this.gamepadIndices.xAxis!==void 0&&e.axes.length>this.gamepadIndices.xAxis&&(this.values.xAxis=e.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&&e.axes.length>this.gamepadIndices.yAxis&&(this.values.yAxis=e.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(e=>{e.updateFromComponent(this.values)})}},MotionController=class{constructor(e,t,n){if(!e)throw Error(`No xrInputSource supplied`);if(!t)throw Error(`No profile supplied`);this.xrInputSource=e,this.assetUrl=n,this.id=t.profileId,this.layoutDescription=t.layouts[e.handedness],this.components={},Object.keys(this.layoutDescription.components).forEach(e=>{let t=this.layoutDescription.components[e];this.components[e]=new Component(e,t)}),this.updateFromGamepad()}get gripSpace(){return this.xrInputSource.gripSpace}get targetRaySpace(){return this.xrInputSource.targetRaySpace}get data(){let e=[];return Object.values(this.components).forEach(t=>{e.push(t.data)}),e}updateFromGamepad(){Object.values(this.components).forEach(e=>{e.updateFromGamepad(this.xrInputSource.gamepad)})}},DEFAULT_PROFILES_PATH=`https://cdn.jsdelivr.net/npm/@webxr-input-profiles/assets@1.0/dist/profiles`,DEFAULT_PROFILE=`generic-trigger`,XRControllerModel=class extends three.Object3D{constructor(){super(),this.motionController=null,this.envMap=null}setEnvironmentMap(e){return this.envMap==e?this:(this.envMap=e,this.traverse(e=>{e instanceof three.Mesh&&e.isMesh&&(e.material.envMap=this.envMap,e.material.needsUpdate=!0)}),this)}updateMatrixWorld(e){super.updateMatrixWorld(e),this.motionController&&(this.motionController.updateFromGamepad(),Object.values(this.motionController.components).forEach(e=>{Object.values(e.visualResponses).forEach(e=>{let{valueNode:t,minNode:n,maxNode:r,value:o,valueNodeProperty:s}=e;t&&(s===Constants.VisualResponseProperty.VISIBILITY?t.visible=o:s===Constants.VisualResponseProperty.TRANSFORM&&(t.quaternion.copy(n.quaternion).slerp(r.quaternion,o),t.position.lerpVectors(n.position,r.position,o)))})}))}};function findNodes(e,t){Object.values(e.components).forEach(e=>{let{type:n,touchPointNodeName:r,visualResponses:o}=e;if(n===Constants.ComponentType.TOUCHPAD)if(e.touchPointNode=t.getObjectByName(r),e.touchPointNode){let t=new three.Mesh(new three.SphereGeometry(.001),new three.MeshBasicMaterial({color:255}));e.touchPointNode.add(t)}else console.warn(`Could not find touch dot, ${e.touchPointNodeName}, in touchpad component ${e.id}`);Object.values(o).forEach(e=>{let{valueNodeName:n,minNodeName:r,maxNodeName:o,valueNodeProperty:s}=e;if(s===Constants.VisualResponseProperty.TRANSFORM){if(e.minNode=t.getObjectByName(r),e.maxNode=t.getObjectByName(o),!e.minNode){console.warn(`Could not find ${r} in the model`);return}if(!e.maxNode){console.warn(`Could not find ${o} in the model`);return}}e.valueNode=t.getObjectByName(n),e.valueNode||console.warn(`Could not find ${n} in the model`)})})}function addAssetSceneToControllerModel(e,t){findNodes(e.motionController,t),e.envMap&&t.traverse(t=>{t instanceof three.Mesh&&t.isMesh&&(t.material.envMap=e.envMap,t.material.needsUpdate=!0)}),e.add(t)}var XRControllerModelFactory=class{constructor(e=null){this.gltfLoader=e,this.path=DEFAULT_PROFILES_PATH,this._assetCache={}}createControllerModel(e){let t=new XRControllerModel,n=null;return e.addEventListener(`connected`,e=>{let r=e.data;r.targetRayMode!==`tracked-pointer`||!r.gamepad||fetchProfile(r,this.path,DEFAULT_PROFILE).then(({profile:e,assetPath:o})=>{t.motionController=new MotionController(r,e,o);let s=this._assetCache[t.motionController.assetUrl];if(s)n=s.scene.clone(),addAssetSceneToControllerModel(t,n);else{if(!this.gltfLoader)throw Error(`GLTFLoader not set.`);this.gltfLoader.load(t.motionController.assetUrl,e=>{this._assetCache[t.motionController.assetUrl]=e,n=e.scene.clone(),addAssetSceneToControllerModel(t,n)})}}).catch(e=>{console.warn(e)})}),e.addEventListener(`disconnected`,()=>{t.motionController=null,t.remove(n),n=null}),t}},defaultXRPanoramaControllerInitArgs=Object.assign({},omit(defaultPanoramaControllerCustomInitArgs,[`maxLatitude`,`minLatitude`]));function mapPanoResource(e,t){if(!t)return e;let n=e.match(/\d+_[a-z].png/);return e.substring(0,n.index)+t+`/`+e.substring(n.index)}var CONTROLLER_EVNET_DELTA_TIME=300,scratchRaycaster=new three.Raycaster,scratchVector3=new three.Vector3,XRPanoramaController=class e extends PanoramaController{static parseArgs(t){if(t instanceof e)return t;let n=Object.assign(Object.assign({},t),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2});return super.parseArgs(n)}static initAnimationEndState(e){let t=this.parseArgs(e),n=super.initAnimationEndState(t);return Object.assign(Object.assign({},n),{mode:`XRPanorama`})}constructor(e){super(e),this.xrManager=new XRManager(this.renderer,this.renderer.getContext(),{onSessionStart:e=>{this.emit(`xr.session.start`,createEvent(`xr.session.start`,{session:e,machineType:this.xrManager.machineType}))},onSessionEnd:()=>{this.emit(`xr.session.end`,createEvent(`xr.session.end`,{session:null,machineType:this.xrManager.machineType}))}}),this.xrControllerRay={left:new three.Raycaster,right:new three.Raycaster},this.xrControllerRay.left.params.Points={threshold:.1},this.xrControllerRay.left.firstHitOnly=!0,this.xrControllerRay.left.floorIndex=-1,this.xrControllerRay.right.params.Points={threshold:.1},this.xrControllerRay.right.firstHitOnly=!0,this.xrControllerRay.right.floorIndex=-1,this.gazeRay=null,this.pointerLines={left:new FiveLine,right:new FiveLine},this.pointerLines.left.visible=!1,this.pointerLines.right.visible=!0,this.pointerLines.left.setMaterial({color:new three.Vector3(1,1,1)}),this.pointerLines.left.points.material.depthTest=!1,this.pointerLines.right.setMaterial({color:new three.Vector3(1,1,1)}),this.pointerLines.right.points.material.depthTest=!1,this.controllerWrappers=[new three.Group,new three.Group];let t=this.xrManager.getController(0);this.controllerWrappers[0].add(t);let n=this.xrManager.getController(1);this.controllerWrappers[1].add(n);let r=new XRControllerModelFactory;r.gltfLoader={load(e,t){internalFetcher.ajax(e,{responseType:`arraybuffer`}).then(t=>{var n;return parseGltf(t.body,{resourcePath:e.slice(0,e.lastIndexOf(`/`)+1),search:(n=e.split(`?`)[1])==null?``:n,fetcher:internalFetcher})}).then(e=>t(e))}},(this.xrManager.machineType===`Oculus`||this.xrManager.machineType===`Pico`)&&this.scene.add(this.pointerLines.left,this.pointerLines.right,this.controllerWrappers[0],this.controllerWrappers[1]),this.panoResources={},this.panoResources[this.locationMotion.keyframes[0].key=this.locationMotion.keyframes[1].key=createUuid()]={panoId:panoStringify(this.currentPano),leftPanoPicture:null,position:this.camera.pose.offset.clone(),effect:`fade`,effectEasing:defaultEffectEase,fixCameraTransform:new three.Matrix4},this.parallaxCameraMatrixs=[];let o=AnimationFrameLoop.shared.getContext();if(!o){console.error(`获取session失败,请退出重试`);return}this.on(`xr.session.end`,()=>{this.scene.remove(this.pointerLines.left,this.pointerLines.right)}),this.xrManager.setSession(o),this.on(`xr.session.start`,()=>{let e=this.xrManager.getControllerGrip(0);e.add(r.createControllerModel(e)),this.controllerWrappers[0].add(e);let t=this.xrManager.getControllerGrip(1);t.add(r.createControllerModel(t)),this.controllerWrappers[1].add(t)}),this.xrHandleState={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}},this.xrManager.machineType===`VP`&&this.initHandEvent()}updateConfiguration(e){return super.updateConfiguration(Object.assign(Object.assign({},e),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2}))}moveToPano(e,t,n){var r,o,s;let c=(r=t.effect)==null?`fade`:r;this.userAction=n,this.stopMomentumMovement();let l=panoStringify(e),u=this.works.getObserver(e);if(!u)throw Error(`Invalid PanoIndex`);let d=getImageSizeFromURL(u.images.up),f=this.imageOptions.size;f===void 0&&u&&d&&(f=Number(d)),f===void 0&&(f=2048);let p=this.imageOptions.transform,m=(e,t)=>mapPanoResource(applyImageURLOptions(e,p,t)),h=Object.assign({key:`pano.${l}`},pick(this.imageOptions,[`format`,`size`,`quality`])),g={right:u.images.work.getURL(u.images.right),left:u.images.work.getURL(u.images.left),up:u.images.work.getURL(u.images.up),down:u.images.work.getURL(u.images.down),front:u.images.work.getURL(u.images.front),back:u.images.work.getURL(u.images.back)},_=`pano:`+jsonHash([g,h,p]);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===_)return;{let t=this.pendingTextureTask.panoId;(o=this.panoMeshes.get(t))==null||o.setProgress(0),this.emit(`pano.texture.abort`,createEvent(`pano.texture.abort`,{error:null,progress:0,meta:null,pano:e}))}}let{pano0:v,pano1:y}=this.modelScene.parameter.resolveValue(),b;if((v==null?void 0:v.map.name)===_?b=v:(y==null?void 0:y.map.name)===_&&(b=y),b){let n={panoId:l,effect:c,effectEasing:(s=t.effectEasing)==null?defaultEffectEase:s,leftPanoPicture:{panoId:b.panoId,map:b.map,mapHistogram:b.mapHistogram,mapSize:b.mapSize,matrix:u.matrix.clone().premultiply(u.work.transform),zoom:1},position:u.position.clone().applyMatrix4(u.work.transform),fixCameraTransform:new three.Matrix4};this.doMoveToPano(e,n,t);return}let S=`move-to-pano-`+l;this.pending.add(S),this.pendingTextureTask={panoId:l,hash:_,onLoad:n=>{var r,o;let s=n.body;if(this.destroyed)s.dispose();else{s.name=_;let n=Array.isArray(s.image)?s.image[0]:s.image,d=(r=n==null?void 0:n.width)==null?2048:r,f=new Histogram().formPixels(getRgbaDataFromCubeTexture(this.renderer,s,!0,sharedHistogramRgbaData).data),p={panoId:l,effect:c,effectEasing:(o=t.effectEasing)==null?defaultEffectEase:o,leftPanoPicture:{panoId:l,map:s,mapSize:d,mapHistogram:new three.Vector4().fromArray(f.toArray()),matrix:u.matrix.clone(),zoom:1},position:u.position.clone(),fixCameraTransform:new three.Matrix4};this.doMoveToPano(e,p,t)}},onError:n=>{let r=Object.assign(Object.assign(Object.assign({},e),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`pano.error`,createEvent(`pano.error`,{error:n,userAction:this.userAction,options:t,prevPano:this.currentPano,progress:0,state:r})),this.emit(`pano.cancel`,createEvent(`pano.cancel`,{error:null,userAction:this.userAction,options:t,prevPano:this.currentPano,progress:0,state:r})),t.moveCancelCallback&&t.moveCancelCallback()}};let C=this.panoMeshes.get(l);C&&C.tap&&C.tap(),this.textureLoader.loadCubeTexture(g,{imageURL:{transform:m,options:h},format:three.RGBFormat,fetcher:getFetcher(this.fiveId,u.work)},void 0,void 0,t=>{var n,r;((n=this.pendingTextureTask)==null?void 0:n.hash)===_&&((r=this.panoMeshes.get(l))==null||r.setProgress(t)),this.emit(`pano.texture.progress`,createEvent(`pano.texture.progress`,{error:null,progress:t,meta:null,pano:e}))},this.renderer).then(t=>{var n,r;this.pending.delete(S),((n=this.pendingTextureTask)==null?void 0:n.hash)===_?(this.pendingTextureTask.onLoad(t),this.pendingTextureTask=void 0,(r=this.panoMeshes.get(l))==null||r.setProgress(0)):t.body.dispose(),this.emit(`pano.texture.success`,createEvent(`pano.texture.success`,{error:null,progress:1,meta:t.meta,pano:e}))}).then(()=>new Promise(e=>{AnimationFrameLoop.shared.add(()=>e(),!0)})).catch(t=>{var n,r;this.pending.delete(S),((n=this.pendingTextureTask)==null?void 0:n.hash)===_&&(this.pendingTextureTask.onError(t),this.pendingTextureTask=void 0,(r=this.panoMeshes.get(l))==null||r.setProgress(0)),this.emit(`pano.texture.error`,createEvent(`pano.texture.error`,{error:t,progress:0,meta:null,pano:e})),this.emit(`error`,t)}),this.emit(`pano.texture.load`,createEvent(`pano.texture.load`,{error:null,progress:0,meta:null,pano:e}))}doMoveToPano(e,t,n={}){var r,o,s,c,l,u,d,f,p,m;let h=now(),g=createUuid();this.panoResources[g]=t;let _=1,v,y,b;if(this.locationMotion.ended){let[e,n]=this.locationMotion.getKeyFrameSegment(h),r=this.locationMotion.value,o=this.panoResourceFromLocationMotionKeyframe(n).position,s=t.position;v=Math.max(o.distanceTo(s),1),y=[{key:n.key,progress:0,value:Object.assign(Object.assign({},r),{count:0})},{key:g,progress:1,value:{distance:0,count:1}}],b=0}else{let[e,n]=this.locationMotion.getKeyFrameSegment(h),r=this.locationMotion.value,o=this.panoResourceFromLocationMotionKeyframe(e).position,s=this.panoResourceFromLocationMotionKeyframe(n).position,c=t.position,l=n.value.count-r.count,u=Math.max(o.distanceTo(s),1)*l;v=u+Math.max(s.distanceTo(c),1),y=[{key:e.key,progress:0,value:Object.assign({},r)},{key:n.key,progress:u/v,value:n.value},{key:g,progress:1,value:{count:n.value.count+1,distance:0}}];let d=this.locationMotionKeyframesLength(this.locationMotion.keyframes),f=this.locationMotionKeyframesLength(y);b=this.locationMotion.getProgressVelocity(h)*d/f}let S=t.effect===`instant`?0:this.calculateMovingDuration(n.duration,t.effect===`fly`||t.effect===`model`?v:0),C={longitude:n.longitude,latitude:n.latitude,fov:n.fov},w=Object.assign(Object.assign({},e),{mode:this.mode,longitude:(r=C.longitude)==null?this.camera.pose.longitude:r,latitude:(o=C.latitude)==null?this.camera.pose.latitude:o,fov:(s=C.fov)==null?this.camera.pose.fov:s,offset:t.position.clone(),distance:0}),T=this.currentPano;if(this.emit(`pano.moveTo`,createEvent(`pano.moveTo`,{options:n,prevPano:T,progress:0,state:w,userAction:this.userAction,error:null})),n.moveStartCallback&&n.moveStartCallback(w),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,this.videoTexture.needsUpdate=!0),this.panoVideo.setMaterial(null),t.effect===`fly`||t.effect===`model`)this.cameraMotion.set(C,S).catch(noop);else{let e=coordinatesToVector({longitude:this.cameraMotion.value.longitude,latitude:this.cameraMotion.value.latitude}),n=coordinatesToVector({longitude:(c=C.longitude)==null?this.cameraMotion.value.longitude:c,latitude:(l=C.latitude)==null?this.cameraMotion.value.latitude:l}),r=new three.Object3D;r.lookAt(e);let o=new three.Matrix4().makeRotationFromQuaternion(r.quaternion);r.lookAt(n);let s=new three.Matrix4().makeRotationFromQuaternion(r.quaternion),h=new three.Matrix4().getInverse(o).premultiply(s),g=this.cameraMotion.value.fov,_=(u=C.fov)==null?this.cameraMotion.value.fov:u,v=1;t.effect===`zoomin`?v=1.5:t.effect===`zoomout`&&(v=.4);let b=_*v;for(let e=0;e<y.length-1;e++){let t=y[e].key;if(t){let e=this.panoResources[t];e&&(e.fixCameraTransform.copy(h),e.leftPanoPicture&&(e.leftPanoPicture.zoom=Math.tan(b/2/180*Math.PI)/Math.tan(g/2/180*Math.PI)))}}this.cameraMotion.setKeyframes([{progress:0,value:{longitude:this.cameraMotion.value.longitude,latitude:this.cameraMotion.value.latitude,fov:this.cameraMotion.value.fov}},{progress:0,value:{longitude:(d=C.longitude)==null?this.cameraMotion.value.longitude:d,latitude:(f=C.latitude)==null?this.cameraMotion.value.latitude:f,fov:b}},{progress:1,value:{longitude:(p=C.longitude)==null?this.cameraMotion.value.longitude:p,latitude:(m=C.latitude)==null?this.cameraMotion.value.latitude:m,fov:_}}],S).catch(noop)}this.locationMotion.setKeyframes(y,S,b).then(()=>{for(let e of this.modelScene.children)e instanceof Model&&e.show();let t=Object.assign(Object.assign({},e),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:this.camera.pose.offset.clone(),distance:0});this.emit(`pano.arrived`,createEvent(`pano.arrived`,{options:n,prevPano:T,progress:1,state:t,userAction:this.userAction,error:null})),n.moveEndCallback&&n.moveEndCallback(t);let r=this.works.getObserver(this.currentPano);if(r&&r.images.video&&this.videoTexture&&this.videoTexture.image instanceof HTMLVideoElement){let e={map:this.videoTexture,size:r.images.video.size.clone(),matrix:r.images.video.matrix.clone(),panoMatrix:r.matrix.clone().premultiply(r.work.transform),alpha:1},t=createUuid(),n=this.videoTexture.image;n.setAttribute(`uuid`,t),canplayVideo().then(o=>{o&&r.images.video&&n.getAttribute(`uuid`)===t&&(n.oncanplay=()=>{n.oncanplay=noop,n.play()},n.ontimeupdate=()=>{n.currentTime>.5&&(n.ontimeupdate=noop,this.panoVideo.setMaterial(e))},n.src=r.images.video.source)}).catch((()=>{n.removeAttribute(`uuid`)}))}},()=>{this.emit(`pano.cancel`,createEvent(`pano.cancel`,{options:n,prevPano:T,progress:0,state:w,userAction:this.userAction,error:null})),n.moveCancelCallback&&n.moveCancelCallback()})}checkSelectedPano(e){var t;this.stopMomentumMovement(),this.camera.getDirection(new three.Vector3).setY(0);let n=null,r=this.works.getObserver(this.currentPano);if(!r)return null;let o=r.work.observers,s=r.accessibleNodes.filter(e=>{if(e===this.currentPano.panoIndex&&r.work.workCode===this.currentPano.workCode)return!1;let t=o[e];return!t||scratchVector3.copy(t.position).applyMatrix4(t.work.transform).distanceTo(this.camera.position)>this.maxAccessibleDistance?!1:t.loadable||t.active}),[c]=this.modelScene.intersectRaycaster(e);if(c){let[e,r]=arrayMin(s,e=>{let t=o[e];return t?scratchVector3.copy(t.standingPosition).applyMatrix4(t.work.transform).distanceTo(c.point):1/0},!0);typeof e==`number`&&r<this.panoTapTriggerRadius&&(n=(t=o[e])==null?null:t)}if(isNil(n)){let t=this.getForwardObserverOrNot(this.xrManager.cameraVR,e);t&&(n=t)}for(let e of this.locationMotion.keyframes){let t=this.panoResourceFromLocationMotionKeyframe(e);if(!(e.progress<this.locationMotion.progress)&&n){let e=panoStringify({panoIndex:n.panoIndex,workCode:n.work.workCode});if(t.panoId===e){n=null;break}}}if(isNil(n))return this.locationMotion.ended===!0&&this.cameraBounce(),null;if(!n.active){let e=panoStringify({panoIndex:n.panoIndex,workCode:n.work.workCode}),t=this.panoMeshes.get(e);t&&(t.setDisabled(!1),t.setLoading(!0))}let l={workCode:n.work.workCode,panoIndex:n.panoIndex,mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,distance:0,offset:n?n.position.clone():new three.Vector3};return this.emit(`pano.select`,createEvent(`pano.select`,{prevPano:this.currentPano,state:l,userAction:!0,options:{},progress:0,error:null})),n&&n.active?(this.emit(`pano.request`,createEvent(`pano.request`,{userAction:!0,prevPano:this.currentPano,progress:0,state:l,options:{},error:null})),{workCode:n.work.workCode,panoIndex:n.panoIndex}):null}destroy(){super.destroy()}isReady(){return!1}updateCamera(e,t,n){return Promise.resolve()}updateCameraWithKeyframes(e,t,n){return Promise.resolve()}updateTime(e,t,...n){var r,o,s,c,l,u,d,f,p;this.userAction=!0;let m={},h={},g=this.camera.getDirection(new three.Vector3),_=this.locationMotion.keyframes[0],v=this.locationMotion.keyframes[this.locationMotion.keyframes.length-1],[y,b]=this.locationMotion.getKeyFrameSegment(e),S=this.panoResourceFromLocationMotionKeyframe(y),C=this.panoResourceFromLocationMotionKeyframe(b),w=this.panoResourceFromLocationMotionKeyframe(_),T=this.panoResourceFromLocationMotionKeyframe(v),E=!1;if(this.cameraMotion.ended===!1&&(this.cameraMotion.update(e),h.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$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);let t=this.locationMotion.value.count-b.value.count+1,n=new three.Vector3().copy(S.position),s=new three.Vector3().copy(C.position);if(m.progress=t,t>=.01&&t<=.99&&(m.progress=clamp$1(C.effectEasing(t),.01,.99)),C.leftPanoPicture&&(t<1?S.leftPanoPicture&&(m.pano0=S.leftPanoPicture):m.pano0=C.leftPanoPicture,m.pano1=C.leftPanoPicture),C.effect===`montage`?m.transition=`BLACK`:C.effect===`spread`?m.transition=`SPREAD`:m.transition=`FADE`,C.effect===`zoomin`||C.effect===`zoomout`?m.progress=Math.pow(t,3):C.effect===`model`&&this.camera.pose.distance<.01&&(m.modelAlpha=1-Math.pow(clamp$1(Math.abs(t-.5)*2,0,1),4)),t<1&&C.effect!==`fly`){if(m.pano0&&S.leftPanoPicture){let e={panoId:m.pano0.panoId,map:m.pano0.map,mapHistogram:m.pano0.mapHistogram,mapSize:m.pano0.mapSize,zoom:m.pano0.zoom,matrix:S.leftPanoPicture.matrix.clone().setPosition(C.position)},t=this.panoPictureObserverMap.get(m.pano0);t&&this.panoPictureObserverMap.set(e,t),m.pano0=e}n.copy(s),E=!0}h.distance=this.locationMotion.value.distance,h.offset=new three.Vector3(n.x+(s.x-n.x)*t,n.y+(s.y-n.y)*t,n.z+(s.z-n.z)*t);let c=[],l=[];for(let e of this.locationMotion.keyframes){let{key:t,progress:n}=e;t!==void 0&&(c.push(t),n>this.locationMotion.progress&&l.push(t))}for(let e of Object.keys(this.panoResources)){if(l.indexOf(e)>=0)continue;let t=this.panoResources[e];if(t.leftPanoPicture){let e=t.leftPanoPicture.map;if(e){if(e===((r=m.pano0)==null?void 0:r.map)||e===((o=m.pano1)==null?void 0:o.map))continue;e.dispose(),t.leftPanoPicture=null}}c.indexOf(e)>=0||delete this.panoResources[e]}let u=panoParse(C.panoId);u!==this.currentPano&&(this.currentPano=u,this.accessibleObserverFloorCheckCount=0),this.emit(`pano.moving`,createEvent(`pano.moving`,{userAction:this.userAction,prevPano:panoParse(w.panoId),state:Object.assign(Object.assign(Object.assign(Object.assign({},panoParse(T.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),h),options:{},progress:this.locationMotion.progress,error:null}))}this.camera.setFromPose(h),this.xrManager.cameraVR.projectionMatrix.copy(this.camera.projectionMatrix),this.xrManager.cameraVR.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse),this.xrManager.cameraVR.matrix.copy(this.camera.matrix),this.xrManager.cameraVR.position.copy(this.camera.position),this.xrManager.cameraVR.quaternion.copy(this.camera.quaternion),this.xrManager.cameraVR.scale.copy(this.camera.scale),this.xrManager.cameraVR.matrixAutoUpdate=!1,this.xrManager.cameraVR.matrixWorld.copy(this.camera.matrixWorld);let[D,O]=n,k=new three.Vector3(0,0,0),A=new three.Vector2().copy(this.camera.resolution);if(O&&this.xrManager.session&&this.xrManager.referenceSpace&&this.xrManager.session.renderState.baseLayer){let n=this.xrManager.cameraVR,r=this.xrManager.referenceSpace,o=this.xrManager.session.renderState.baseLayer,u=O.getViewerPose(r),d=(s=u==null?void 0:u.views)==null?[]:s;for(let e=0;e<d.length;e++){let t=d[e],r=n.cameras[e],s=o.getViewport(t);s&&(r.projectionMatrix.fromArray(t.projectionMatrix),r.projectionMatrixInverse.getInverse(r.projectionMatrix),r.matrix.fromArray(t.transform.matrix),r.matrix.setPosition(this.camera.position),r.matrix.decompose(r.position,r.quaternion,r.scale),r.matrixWorld.copy(r.matrix),r.matrixWorldInverse.getInverse(r.matrixWorld),r.matrixAutoUpdate=!1,k.copy(r.position),r.viewport.set(s.x,s.y,s.width,s.height),A.set(s.width,s.height))}if(this.xrManager.setProjectionFromUnion(this.xrManager.cameraVR,this.xrManager.cameraL,this.xrManager.cameraR),this.camera.quaternion.copy(this.xrManager.cameraVR.quaternion),this.camera.scale.copy(this.xrManager.cameraVR.scale),this.camera.matrix.compose(this.camera.position,this.camera.quaternion,this.camera.scale),this.camera.computePose((c=h.distance)==null?this.camera.pose.distance:c),this.xrManager.session.inputSources){for(let e=0;e<this.xrManager.session.inputSources.length;e++)if(this.xrManager.session.inputSources[e]&&this.xrManager.session.inputSources[e].targetRayMode===`transient-pointer`){let t=O.getPose(this.xrManager.session.inputSources[e].targetRaySpace,r);if(t){let e=t.transform.orientation,n=new three.Quaternion(e.x,e.y,e.z,e.w),r=new three.Vector3(0,0,-1).applyQuaternion(n);this.gazeRay=new three.Raycaster(this.camera.position,r)}}}if(this.xrManager.machineType===`Oculus`||this.xrManager.machineType===`Pico`){let n=this.xrManager.session.inputSources;for(let e=0;e<n.length;e++){let t=this.xrManager.controllers[e],o=n[e];if(!o)continue;t&&t.update(o,O,r);let s=this.xrManager.getController(e),c=new three.Vector3(0,1.2,0),u=s.position.clone().add(k).sub(c);o.handedness===`left`?this.xrControllerRay.left.set(u,new three.Vector3(0,0,-1).applyEuler(s.rotation)):o.handedness===`right`&&this.xrControllerRay.right.set(u,new three.Vector3(0,0,-1).applyEuler(s.rotation)),this.controllerWrappers[e].position.copy(new three.Vector3(0,0,0).add(k).sub(c));let d=this.modelScene.intersectRaycaster(this.xrControllerRay.right);if(d.length===0){let e=this.works.getResolvedObserver(this.currentPano);d=this.xrControllerRay.right.intersectObject(this.modelScene.boundingMesh,!0).map(t=>{var n;let r=(n=e==null?void 0:e.floorIndex)==null?0:n;return Object.assign({floorIndex:r,floor:r},t)})}if(d.length>=1&&d[0].face)if(o.handedness===`right`){let e=this.xrControllerRay.right.intersectObject(this.xrCustomObjectsScene,!0),t=d[0].face.normal,n=t.clone(),r=d[0].point.clone();this.intersectMesh.position.copy(r);let o=r.clone().add(n);if(this.intersectMesh.lookAt(o),Math.abs(t.y)>.99){let e=this.camera.position.clone().sub(r);this.intersectMesh.rotation.z=-Math.atan2(e.z,e.x)}this.intersectMesh.visible=!0,this.needsRender=!0,e.length>0?(this.pointerLines.right.setPoints(u,e[0].point),this.pointerLines.right.points.visible=!0,this.intersectMesh.visible=!1):(this.pointerLines.right.points.visible=!1,this.pointerLines.right.setPoints(u,d[0].point));let s=d[0],c=createEvent(`intersect.update`,{raycaster:(l=this.xrControllerRay.right)==null?null:l,intersection:s==null?null:s,object:this.intersectMesh});if(this.emit(`intersect.update`,c),c.defaultPrevented){this.hideIntersectMesh();return}}else this.pointerLines.left.setPoints(u,d[0].point)}this.updateControllerHelper(n,e,t)}}else O||console.error(`xrFrame丢失,请重试`),this.xrManager.session||console.error(`session丢失,请重试`),this.xrManager.session&&!this.xrManager.session.renderState.baseLayer&&console.error(`no layer found`);isEmptyObject(m)===!1&&this.modelScene.parameter.set(m),this.emit(`camera.update`,createEvent(`camera.update`,{userAction:this.userAction,state:Object.assign(Object.assign(Object.assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose))}));let j=this.works.getResolvedObserver(this.currentPano),M=this.locationMotion.ended?this.getForwardObserverOrNot(this.xrManager.cameraVR):null,N=this.works.getObserver(S.panoId),P=this.works.getObserver(C.panoId);if(this.adjustPanoCircleMeshPositionBasedOnModel&&this.helper.visible&&j){let e=[],t=j.work.observers;for(let n of j.accessibleNodes){let r=t[n];r&&e.push(r)}let n=new Map;if(e.sort((e,t)=>{let r=n.get(e);r===void 0&&(r=e.standingPosition.distanceTo(j.standingPosition),n.set(e,r));let o=n.get(e);return o===void 0&&(o=t.standingPosition.distanceTo(j.standingPosition),n.set(t,o)),r-o}),e.length){this.accessibleObserverFloorCheckCount%=e.length;let t=e[this.accessibleObserverFloorCheckCount],n=this.modelScene.models.find(e=>e.work===(t==null?void 0:t.work));if(t&&n&&n.visible){let e=.3,r=.05,o=.005,s=t.standingPosition.clone().applyMatrix4(t.work.transform),c=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode}),l=adjustPanoCircleMeshVectors.map(t=>{scratchRaycaster.ray.origin.copy(s),scratchRaycaster.ray.origin.add(scratchVector3.copy(t).setY(e)),scratchRaycaster.ray.direction.set(0,-1,0),scratchRaycaster.firstHitOnly=!0,scratchRaycaster.floorIndex=-1;let[r]=n.intersectRaycaster(scratchRaycaster);return r&&r.distance-o<=e?new three.Vector3().copy(s).setY(r.point.y+o):s});l.sort((e,t)=>t.y-e.y);let u=l[Math.floor(l.length/2)],[d]=l.filter(e=>e.distanceTo(u)<=.05);if(d){let e=new three.Vector4(s.x,s.y,s.z,d.y-s.y),t=this.adjustPanoCircleMeshPositionFix.get(c);t&&!e.equals(t)&&(this.needsRender=!0),this.adjustPanoCircleMeshPositionFix.set(c,e)}}this.accessibleObserverFloorCheckCount++}}let F=new Map;if(N)for(let e of N.accessibleNodes){let t=N.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});F.set(e,t)}}if(P)for(let e of P.accessibleNodes){let t=P.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});F.set(e,t)}}if(this.panoMeshes.forEach((e,t)=>{F.get(t)?F.delete(t):(this.helper.remove(e),e.dispose(),this.panoMeshes.delete(t))}),F.forEach((e,t)=>{let n=this.panoCircleMeshCreator(e,{aerialObserverMinHeight:this.aerialObserverMinHeight});this.panoMeshes.set(t,n),this.helper.add(n),F.delete(t)}),this.panoMeshes.forEach((e,t)=>{let n=this.works.getObserver(t);if(n){let r=n.position.distanceTo(n.standingPosition)>this.aerialObserverMinHeight;if(r)e.position.copy(n.position).applyMatrix4(n.work.transform),e.scale.setScalar(18);else{e.position.copy(n.standingPosition).applyMatrix4(n.work.transform);let t=this.adjustPanoCircleMeshPositionFix.get(n.panoId);t&&(scratchVector3.set(t.x,t.y,t.z),scratchVector3.equals(e.position)&&(e.position.y+=t.w)),e.scale.setScalar(1.2)}let o=this.camera.position.clone().setY(e.position.y),s=new three.Vector3().copy(e.position).sub(o).normalize();if(t===panoStringify(this.currentPano)){let t=clamp$1((.5-o.distanceTo(e.position))/.5,0,1);s.multiplyScalar(1-t).add(g.clone().multiplyScalar(t))}if(s.length()>0){let t=r?-Math.PI/2:0,n=Math.atan2(s.x,s.z);e.quaternion.setFromEuler(new three.Euler(t,n,0,`YXZ`))}}else e.visible=!1}),this.camera.pose.distance>.1||E)this.panoMeshes.forEach(n=>{n.setOpacity(0),n.setCurrent(!1),n.updateTime&&n.updateTime(e,t),n.visible=!1});else if(j){let n=j.work.observers,[,r]=arrayMin(j.accessibleNodes,e=>{let t=n[e];return!t||!t.active?1/0:j.standingPosition.distanceTo(t.standingPosition)},!0);r=clamp$1(r,2.5,1/0);let o=j.accessibleNodes.concat(j.panoIndex).map(e=>panoStringify({panoIndex:e,workCode:j.work.workCode}));this.panoMeshes.forEach((n,s)=>{let c=this.works.getObserver(s),l=!1,u=1;if(o.indexOf(s)===-1)l=!1,u=0;else if(!c)l=!1,u=0;else if(!c.loadable&&!c.active)l=!1,u=0;else{let e=n.position.clone().project(this.camera);l=Math.abs(e.x)<1&&Math.abs(e.y)<1&&Math.abs(e.z)<1&&!n.loading&&n.progress===0&&M!==null&&panoStringify({panoIndex:M.panoIndex,workCode:M.work.workCode})===s;let t=n.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);u=t<.01?0:clamp$1(r/t,.1,.85)}c&&c===P&&c.position.distanceTo(c.standingPosition)>this.aerialObserverMinHeight&&n.position.distanceTo(this.camera.position)<35&&(u=0),this.modelScene.parameter.resolveValue().modelAlpha>0&&(u=0),n.setCurrent(l),n.setOpacity(u),n.updateTime&&n.updateTime(e,t)})}{let e=(u=this.modelScene.parameter.progress)==null?1:u,t=Math.round(e),n=this.modelScene.parameter.pano0,r=this.modelScene.parameter.pano1,o=t===0?n:r,s;if(o&&(s=this.works.getObserver(o.panoId),s||(s=this.panoPictureObserverMap.get(o))),this.tiling.appearDuration=this.tileAppearDuration,this.tiling.maxRequest=e<(canUseNativeImageBitmap()?.6:.99)?0:this.tileMaxRequest,this.tiling.imageOptions=this.imageOptions,!s||!o||this.tileLevelForFov===!1||this.camera.perspToOrtho.x>0){this.tiling.setObserver(null);let e={renderer:this.renderer,resolution:A,pixelRatio:1,time:this.camera.time,cameraMatrix:this.xrManager.cameraVR.matrixWorld,cameraProjectionMatrix:this.xrManager.cameraVR.projectionMatrix,panoMap:null,panoMatrix:new three.Matrix4,panoZoom:1,minLevel:0,level:0};this.tiling.update(e),this.modelScene.parameter.set(`refinedScreen`,null)}else{let e=getImageSizeLevel(o.mapSize)+1,c=4;this.tiling.setObserver(s);let l={renderer:this.renderer,resolution:A,pixelRatio:1,time:this.camera.time,cameraMatrix:this.xrManager.cameraVR.matrixWorld,cameraProjectionMatrix:this.xrManager.cameraVR.projectionMatrix,panoMap:o.map,panoMatrix:o.matrix,panoZoom:o.zoom,minLevel:e,level:4},u=this.tiling.update(l),f={map:this.tiling.renderTarget.texture,matrixInverse:this.tiling.camera.matrixWorldInverse,projectionMatrix:this.tiling.camera.projectionMatrix,pano:t,opacity:(n==null?void 0:n.panoId)===(r==null?void 0:r.panoId)?1:easeInQuart(Math.abs(((d=this.modelScene.parameter.progress)==null?0:d)-.5)*2)},p=this.modelScene.parameter.refinedScreen;(u||f.pano!==(p==null?void 0:p.pano)||f.opacity!==(p==null?void 0:p.opacity))&&this.modelScene.parameter.set(`refinedScreen`,f)}}if(this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e),this.intersectMesh&&this.intersectMesh.parent&&j&&j.position.y-j.standingPosition.y>10){let e=clamp$1(this.camera.position.distanceTo(this.intersectMesh.position)*(2*Math.tan(.5*this.camera.fov/180*Math.PI))/5,.5);this.intersectMesh.scale.setScalar(e)}else this.intersectMesh.scale.setScalar(1);{let e=C.effect,{pano0:t,pano1:n}=this.modelScene.parameter;if(t&&n&&t!==n&&(e===`fly`||e===`model`)&&this.flyEffectUseDepthBuffer){if(((f=this.modelScene.parameter.pano0Depth)==null?void 0:f.panoId)!==t.panoId||((p=this.modelScene.parameter.pano1Depth)==null?void 0:p.panoId)!==n.panoId){let e=500,r=512;this.pano0DepthCubeRenderTarget?this.pano0DepthCubeRenderTarget.width!==512&&this.pano0DepthCubeRenderTarget.setSize(512,512):this.pano0DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1}),this.pano1DepthCubeRenderTarget?this.pano1DepthCubeRenderTarget.width!==512&&this.pano1DepthCubeRenderTarget.setSize(512,512):this.pano1DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1});let o=new three.CubeCamera(this.camera.near,this.camera.far,this.pano0DepthCubeRenderTarget);o.matrix.copy(t.matrix),o.matrixWorld.copy(o.matrix),o.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,o,500);let s=new three.CubeCamera(this.camera.near,this.camera.far,this.pano1DepthCubeRenderTarget);s.matrix.copy(n.matrix),s.matrixWorld.copy(s.matrix),s.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,s,500),this.modelScene.parameter.set({pano0Depth:{panoId:t.panoId,map:this.pano0DepthCubeRenderTarget.texture,mapSize:this.pano0DepthCubeRenderTarget.width,maxDepth:500},pano1Depth:{panoId:n.panoId,map:this.pano1DepthCubeRenderTarget.texture,mapSize:this.pano1DepthCubeRenderTarget.width,maxDepth:500}})}}else this.modelScene.parameter.set({pano0Depth:null,pano1Depth:null}),this.flyEffectUseDepthBuffer||(this.pano0DepthCubeRenderTarget&&(this.pano0DepthCubeRenderTarget.dispose(),this.pano0DepthCubeRenderTarget=void 0),this.pano1DepthCubeRenderTarget&&(this.pano1DepthCubeRenderTarget.dispose(),this.pano1DepthCubeRenderTarget=void 0))}}render(){if(this.xrManager.session&&this.xrManager.session.renderState.baseLayer){let e=this.xrManager.session.renderState.baseLayer;return this.renderer.setRenderTarget(null),this.renderer.setScissorTest(!1),this.renderer.setFramebuffer(e.framebuffer),this.renderer.render(this.scene,this.xrManager.cameraVR),this.renderer.setFramebuffer(null),!0}return!1}onPanGesture(){}onTapGesture(){}onPinchGesture(){}onMouseMove(){}onMouseOut(){}panoResourceFromLocationMotionKeyframe(e){return this.panoResources[e.key]}updateControllerHelper(e,t,n){let r=this.xrControllerRay.left,o=this.xrControllerRay.right;if(!e||e.length===0)return;let s={buttons:{X:!1,Y:!1,LeftTrigger:!1,LeftPinch:!1,A:!1,B:!1,RightTrigger:!1,RightPinch:!1}};for(let c=0;c<e.length;c++){let l=e[c].handedness,u=e[c].gamepad;switch(l){case`left`:u.axes&&(this.emitHandleEvent(u.axes[2]===-1,`LeftAxesLeft`,t),this.emitHandleEvent(u.axes[2]===1,`LeftAxesRight`,t),this.emitHandleEvent(u.axes[3]===-1,`LeftAxesUp`,t),this.emitHandleEvent(u.axes[3]===1,`LeftAxesDown`,t)),u!=null&&u.buttons&&(u.buttons[4]&&this.emitHandleEvent(u.buttons[4].pressed,`X`,t),u.buttons[5]&&this.emitHandleEvent(u.buttons[5].pressed,`Y`,t),u.buttons[0]&&this.emitHandleEvent(u.buttons[0].pressed,`LeftTrigger`,t),u.buttons[1]&&this.emitHandleEvent(u.buttons[1].pressed,`LeftPinch`,t));let e={raycaster:r,axes:{up:u.axes&&u.axes[3]<0?Math.abs(u.axes[3]):0,down:u.axes&&u.axes[3]<0?0:Math.abs(u.axes[3]),left:u.axes&&u.axes[2]<0?Math.abs(u.axes[2]):0,right:u.axes&&u.axes[2]<0?0:Math.abs(u.axes[2])},deltaTime:n};s.buttons.X=u.buttons&&u.buttons[4]?u.buttons[4].pressed:!1,s.buttons.Y=u.buttons&&u.buttons[5]?u==null?void 0:u.buttons[5].pressed:!1,s.buttons.LeftTrigger=u.buttons&&u.buttons[0]?u==null?void 0:u.buttons[0].pressed:!1,s.buttons.LeftPinch=u.buttons&&u.buttons[1]?u==null?void 0:u.buttons[1].pressed:!1,s.left=e;break;case`right`:u.axes&&(this.emitHandleEvent(u.axes[2]===-1,`RightAxesLeft`,t),this.emitHandleEvent(u.axes[2]===1,`RightAxesRight`,t),this.emitHandleEvent(u.axes[3]===-1,`RightAxesUp`,t),this.emitHandleEvent(u.axes[3]===1,`RightAxesDown`,t)),u.buttons&&(u.buttons[4]&&this.emitHandleEvent(u.buttons[4].pressed,`A`,t),u.buttons[5]&&this.emitHandleEvent(u.buttons[5].pressed,`B`,t),u.buttons[0]&&this.emitHandleEvent(u.buttons[0].pressed,`RightTrigger`,t),u.buttons[1]&&this.emitHandleEvent(u.buttons[1].pressed,`RightPinch`,t)),s.right={raycaster:o,axes:{up:u.axes&&u.axes[3]<0?Math.abs(u.axes[3]):0,down:u.axes&&u.axes[3]<0?0:Math.abs(u.axes[3]),left:u.axes&&u.axes[2]<0?Math.abs(u.axes[2]):0,right:u.axes&&u.axes[2]<0?0:Math.abs(u.axes[2])},deltaTime:n},s.buttons.A=u.buttons&&u.buttons[4]?u==null?void 0:u.buttons[4].pressed:!1,s.buttons.B=u.buttons&&u.buttons[5]?u==null?void 0:u.buttons[5].pressed:!1,s.buttons.RightTrigger=u.buttons&&u.buttons[0]?u==null?void 0:u.buttons[0].pressed:!1,s.buttons.RightPinch=u.buttons&&u.buttons[1]?u==null?void 0:u.buttons[1].pressed:!1;break;default:break}}this.emit(`xr.controller.update`,createEvent(`xr.controller.update`,s))}emitHandleEvent(e,t,n){let r=this.xrControllerRay.left,o=this.xrControllerRay.right;if(e)this.xrHandleState[t].touchStart===!1?(this.xrHandleState[t].touchStartTime=n,this.xrHandleState[t].touchStart=!0,this.emit(`xr.gesture.buttonDown`,createEvent(`xr.gesture.buttonDown`,{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:t,isFinal:!1,isFirst:!0,controllers:{raycaster:{leftRay:r,rightRay:o}}}))):n-this.xrHandleState[t].touchStartTime>CONTROLLER_EVNET_DELTA_TIME&&this.emit(`xr.gesture.press`,createEvent(`xr.gesture.tap`,{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:t,isFinal:!0,isFirst:!0,controllers:{raycaster:{leftRay:r,rightRay:o}}}));else if(this.xrHandleState[t].touchStart===!0){if(this.emit(`xr.gesture.buttonUp`,createEvent(`xr.gesture.buttonUp`,{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:t,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:r,rightRay:o}}})),n-this.xrHandleState[t].touchStartTime<=CONTROLLER_EVNET_DELTA_TIME){let e=createEvent(`xr.gesture.tap`,{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:t,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:r,rightRay:o}}});!this.emit(`xr.gesture.tap`,e)&&!e.defaultPrevented&&t===`RightTrigger`&&this.checkSelectedPano(this.xrControllerRay.right)}this.xrHandleState[t].touchStart=!1,this.xrHandleState[t].touchStartTime=0}}initHandEvent(){if(!this.xrManager.session)throw Error(`初始化失败`);this.xrManager.session.addEventListener(`select`,e=>{this.gazeRay&&this.checkSelectedPano(this.gazeRay)})}},Controllers={Floorplan:FloorplanController,Topview:TopviewController,Panorama:PanoramaController,VRPanorama:VRPanoramaController,Model:ModelController,Mapview:MapviewController,XRPanorama:XRPanoramaController},controllersDefaultInitArgs={Floorplan:defaultFloorplanControllerCustomInitArgs,Topview:defaultTopviewControllerCustomInitArgs,Panorama:defaultPanoramaControllerCustomInitArgs,VRPanorama:defaultVRPanoramaControllerCustomInitArgs,Model:defaultModelControllerCustomInitArgs,Mapview:defaultMapviewControllerCustomInitArgs,XRPanorama:defaultXRPanoramaControllerInitArgs},PROXY_CONTROLLER_EVENT_NAMES=`gesture.pan,gesture.tap,gesture.dbltap,gesture.press,gesture.pinch,gesture.mousewheel,gesture.mousemove,gesture.momentum,gesture.create,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`.split(`,`);function initLegacyEvent(e){e.on(`initAnimation.start`,t=>{e.emit(`initAnimationWillStart`,t.state.panoIndex,t.state,t.userAction)}),e.on(`initAnimation.end`,t=>{e.emit(`initAnimationEnded`,t.state.panoIndex,t.state,t.userAction)}),e.on(`gesture.pan`,t=>{let n=!1;n=e.emit(`wantsGesture`,`pan`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsPanGesture`,t.state,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`pan`,t.pointers,t.isFinal),e.emit(`panGesture`,t.state,t.isFinal))}),e.on(`gesture.tap`,t=>{let n=!1;n=e.emit(`wantsGesture`,`tap`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsTapGesture`,t.center.raycaster,t.center.coords,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`tap`,t.pointers,t.isFinal),e.emit(`tapGesture`,t.center.raycaster,t.center.coords,t.isFinal))}),e.on(`gesture.dbltap`,t=>{let n=!1;n=e.emit(`wantsGesture`,`dbltap`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsDblTapGesture`,t.center.raycaster,t.center.coords,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`dbltap`,t.pointers,t.isFinal),e.emit(`dblTapGesture`,t.center.raycaster,t.center.coords,t.isFinal))}),e.on(`gesture.press`,t=>{let n=!1;n=e.emit(`wantsGesture`,`press`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsPressGesture`,t.center.raycaster,t.center.coords,t.center.delta,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`press`,t.pointers,t.isFinal),e.emit(`pressGesture`,t.center.raycaster,t.center.coords,t.center.delta,t.isFinal))}),e.on(`gesture.pinch`,t=>{let n=!1;n=e.emit(`wantsGesture`,`pinch`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsPinchGesture`,t.scale,t.state.fov,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`pinch`,t.pointers,t.isFinal),e.emit(`pinchGesture`,t.scale,t.state.fov,t.isFinal))}),e.on(`gesture.mousewheel`,t=>{let n=!1;n=e.emit(`wantsGesture`,`mouseWheel`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsMouseWheel`,t.center.delta,t.state.fov,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`mouseWheel`,t.pointers,t.isFinal),e.emit(`mouseWheel`,t.center.delta,t.state.fov,t.isFinal))}),e.on(`gesture.mousemove`,t=>{let n=!1;n=e.emit(`wantsGesture`,`mouseMove`,t.pointers,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`mouseMove`,t.pointers,t.isFinal),n=e.emit(`wantsChangeCameraFov`,t.state.fov),n&&t.preventDefault())}),e.on(`gesture.momentum`,t=>{let n=!1;n=e.emit(`wantsInteriaPan`,t.state),n&&t.preventDefault(),t.defaultPrevented||e.emit(`interiaPan`,t.state,t.isFinal)}),e.on(`camera.update`,t=>{e.emit(`cameraFovUpdate`,t.state.fov,t.userAction),e.emit(`cameraDirectionUpdate`,t.state,t.userAction);let n=coordinatesToVector(t.state);n.setLength(t.state.distance);let r=t.state.offset.clone().sub(n);e.emit(`cameraPositionUpdate`,r,t.userAction),e.emit(`cameraUpdate`,t.state,t.userAction)}),e.on(`intersect.update`,t=>{if(t.intersection){let n=!1;n=e.emit(`wantsShowIntersectionOnModel`,t.raycaster),n&&t.preventDefault(),t.defaultPrevented||e.emit(`intersectionOnModelUpdate`,t.intersection,t.object)}else e.emit(`intersectionHidden`)}),e.on(`pano.request`,t=>{let n=e.emit(`wantsMoveToPano`,t.state.panoIndex,t.options,t.userAction);n||(n=e.emit(`wantsToMoveToPano`,t.state.panoIndex,t.options,t.userAction)),n&&t.preventDefault(),t.defaultPrevented||e.emit(`panoWillLoad`,t.state.panoIndex)}),e.on(`pano.select`,t=>{e.emit(`panoSelected`,t.state.panoIndex)}),e.on(`pano.moveTo`,t=>{e.emit(`panoLoaded`,t.state.panoIndex),e.emit(`moveToPano`,t.state.panoIndex,t.userAction),e.emit(`panoWillArrive`,t.state.panoIndex,t.state,t.userAction)}),e.on(`pano.moving`,t=>{e.emit(`movingToPano`,t.state.panoIndex,t.prevPano.panoIndex,t.progress)}),e.on(`pano.arrived`,t=>{e.emit(`panoArrived`,t.state.panoIndex,t.state,t.userAction)}),e.on(`pano.cancel`,t=>{e.emit(`moveToPanoCanceled`,t.state.panoIndex)}),e.on(`pano.error`,t=>{e.emit(`panoLoadError`,t.error,t.state.panoIndex)}),e.on(`pano.texture.load`,t=>{e.emit(`textureStartLoad`,t.pano.panoIndex)}),e.on(`pano.texture.success`,t=>{e.emit(`textureLoaded`,t.pano.panoIndex,t.meta)}),e.on(`pano.texture.error`,t=>{e.emit(`textureError`,t.error,t.pano.panoIndex)}),e.on(`pano.texture.abort`,t=>{e.emit(`textureAbort`,t.pano.panoIndex)}),e.on(`pano.texture.progress`,t=>{e.emit(`textureLoading`,t.progress,t.pano.panoIndex)}),e.on(`xr.session.start`,t=>{e.emit(`webXRSessionStart`)}),e.on(`xr.session.end`,t=>{e.emit(`webXRSessionEnd`)}),e.on(`xr.gesture.tap`,t=>{e.emit(`webXRControllerEvent`,`tap`,t.buttons,{raycaster:t.controllers.raycaster})}),e.on(`xr.gesture.press`,t=>{e.emit(`webXRControllerEvent`,`press`,t.buttons,{raycaster:t.controllers.raycaster})}),e.on(`xr.gesture.buttonUp`,t=>{e.emit(`webXRControllerEvent`,`buttonUp`,t.buttons,{raycaster:t.controllers.raycaster})}),e.on(`xr.gesture.buttonDown`,t=>{e.emit(`webXRControllerEvent`,`buttonDown`,t.buttons,{raycaster:t.controllers.raycaster})}),e.on(`xr.controller.update`,t=>{e.emit(`webXRControllerRayUpdate`,{leftRay:t.left?t.left.raycaster:void 0,rightRay:t.right?t.right.raycaster:void 0}),t.left&&e.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&&e.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})}),e.on(`works.request`,t=>{e.emit(`willLoad`,t.input,t.works[0],e.getCurrentState())}),e.on(`works.load`,t=>{e.emit(`load`,t.input,t.works[0],e.getCurrentState())}),e.on(`works.ready`,t=>{e.emit(`loaded`,t.input,t.works[0])}),e.on(`state.change`,t=>{e.emit(`stateChange`,t.state,t.userAction)}),e.on(`currentState.change`,t=>{e.emit(`currentStateChange`,t.state,t.userAction)}),e.on(`state.set`,t=>{e.emit(`setState`,t.state)}),e.on(`state.synced`,t=>{e.emit(`stateSynced`,t.state)}),e.on(`model.request`,t=>{e.emit(`modelWillLoad`,t.work.model)}),e.on(`model.error`,t=>{e.emit(`modelLoadError`,t.error,t.model)}),e.on(`model.load`,t=>{e.emit(`modelLoaded`,t.model)}),e.on(`model.changeShownFloor`,t=>{e.emit(`modelShownFloorChange`,t.model.shownFloor,t.model.floorLength)}),e.on(`render`,t=>{e.emit(`renderFrame`,t.needsRender)}),e.on(`mode.change.request`,t=>{e.emit(`wantsChangeMode`,t.mode,t.prevMode)}),e.on(`mode.change`,t=>{e.emit(`modeChange`,t.mode,t.prevMode,t.state.panoIndex,t.state,t.userAction)}),e.on(`helpers.visible`,t=>{e.emit(`helpersVisibleChange`,t.object.visible)}),e.on(`network.resource`,t=>{e.emit(`network`,t.source,t.requestType,t.requestState,t.detail)})}function generateDefaultVideoElement(){if(typeof window<`u`){let e=document.createElement(`video`);e.loop=!0,e.autoplay=!0,e.playsInline=!0,e.muted=!0,e.crossOrigin=``;let t=()=>{document.removeEventListener(`touchstart`,t,!1),document.removeEventListener(`mousedown`,t,!1),e.muted=!1};return document.addEventListener(`touchstart`,t,!1),document.addEventListener(`mousedown`,t,!1),e}else return{}}function initLights(){let e=new three.Group;e.name=`internalLights`;{let t=new three.DirectionalLight(16777215,.1);t.name=`direction0`,t.position.copy(new three.Vector3(0,1,0)),e.add(t)}{let t=new three.DirectionalLight(16777215,.1);t.name=`direction1`,t.position.copy(new three.Vector3(-1,-1,-1)),e.add(t)}{let t=new three.DirectionalLight(16777215,.3);t.name=`direction2`,t.position.copy(new three.Vector3(1,1,1)),e.add(t)}{let t=new three.AmbientLight(16777215,.6);t.name=`ambient0`,e.add(t)}return e}function parseKeyValue(e){var t,n;let r={},o=e.split(/(\;|\,)/);for(let e of o){let o=e.split(`=`),s=(t=o[0])==null?void 0:t.trim(),c=(n=o[1])==null?void 0:n.trim();s&&c&&(r[s]=c)}return r}function getViewportScale(){var e;if(typeof document<`u`){let t=document.getElementsByTagName(`meta`);for(let n=0;n<t.length;n++){let r=t[n];if(r.getAttribute(`name`)===`viewport`){let t=parseKeyValue((e=r.getAttribute(`content`))==null?``:e),n=Number(t[`initial-scale`]);if(!isNaN(n))return n}}}return 1}var realsee_png_data_url_default=`data:image/png;base64,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`,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.BufferGeometry;geometry.setAttribute(`position`,new three.BufferAttribute(vertices,3)),geometry.setAttribute(`uv`,new three.BufferAttribute(uvs,2)),geometry.setIndex(new three.BufferAttribute(index,1));var material=new three.MeshBasicMaterial({transparent:!0,depthTest:!1,depthWrite:!1,stencilWrite:!1,fog:!1}),mesh=new three.Mesh(geometry,material);mesh.matrixAutoUpdate=!1;var scene=new three.Scene;scene.add(mesh),scene.matrixAutoUpdate=!1;var camera=new three.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.Vector4,prevScissor=new three.Vector4;function renderPoweredByRealsee(e){if(material.map){let t=e.getViewport(prevViewport),n=e.getScissor(prevScissor),r=e.getScissorTest(),o=e.autoClear,s=n.x+imageOffset[0]/3,c=n.y+imageOffset[1]/3,l=imageSize[0]/3,u=imageSize[1]/3;e.setViewport(s,c,l,u),e.setScissor(s,c,l,u),e.setScissorTest(!0),e.autoClear=!1,e.render(scene,camera),e.setViewport(t),e.setScissor(n),e.setScissorTest(r),e.autoClear=o}else{let e=new three.Texture,t=new Image;t.onload=()=>{e.image=t,e.wrapS=three.ClampToEdgeWrapping,e.wrapT=three.ClampToEdgeWrapping,e.minFilter=three.LinearFilter,e.needsUpdate=!0,e.generateMipmaps=!1,material.needsUpdate=!0,t.onload=noop},t.src=realsee_png_data_url_default,material.map=e}}var jsContent$1=`(function(){function e(e,t,n,r){function i(e){return e instanceof n?e:new n(function(t){t(e)})}return new(n||=Promise)(function(n,a){function o(e){try{c(r.next(e))}catch(e){a(e)}}function s(e){try{c(r.throw(e))}catch(e){a(e)}}function c(e){e.done?n(e.value):i(e.value).then(o,s)}c((r=r.apply(e,t||[])).next())})}async function t(e={}){var t,n=e,r=!1,i=!0,a=self.location.href;if(r||i)try{new URL(\`.\`,a).href}catch{}console.log.bind(console),console.error.bind(console);var o=!1;function s(e){for(var t=0,n=e.length,r=new Uint8Array(n),i;t<n;++t)i=e.charCodeAt(t),r[t]=~i>>8&i;return r}var c,l,u=!1;function d(){var e=M.buffer;new Int8Array(e),new Int16Array(e),n.HEAPU8=l=new Uint8Array(e),new Uint16Array(e),new Int32Array(e),n.HEAPU32=new Uint32Array(e),n.HEAPF32=new Float32Array(e),new Float64Array(e),new BigInt64Array(e),new BigUint64Array(e)}function f(){if(n.preRun)for(typeof n.preRun==\`function\`&&(n.preRun=[n.preRun]);n.preRun.length;)T(n.preRun.shift());x(w)}function p(){u=!0,I.c()}function m(){if(n.postRun)for(typeof n.postRun==\`function\`&&(n.postRun=[n.postRun]);n.postRun.length;)C(n.postRun.shift());x(S)}var h;function g(){return s(\`\\0asm\\0\\0\\0&\\\`\\\`}}\\\`}\\\`\\0\\\`\\v\\0\\\`\\0\\0\\x07aa\\0\\0\\b\\x07\\0\\0\\x07‚€€\\bA€Œ\\v\\x07b\\0c\\0\\x07d\\0e\\0f\\0\\f
2239
+ `},LineMaterial=class extends three.ShaderMaterial{constructor(e){super({uniforms:three.UniformsUtils.clone(lineShader.uniforms),vertexShader:lineShader.vertexShader,fragmentShader:lineShader.fragmentShader,clipping:!0}),this.type=`LineMaterial`,this.dashed=!1,Object.defineProperties(this,{color:{enumerable:!0,get(){return this.uniforms.diffuse.value},set(e){this.uniforms.diffuse.value=e}},linewidth:{enumerable:!0,get(){return this.uniforms.linewidth.value},set(e){this.uniforms.linewidth.value=e}},dashScale:{enumerable:!0,get(){return this.uniforms.dashScale.value},set(e){this.uniforms.dashScale.value=e}},dashSize:{enumerable:!0,get(){return this.uniforms.dashSize.value},set(e){this.uniforms.dashSize.value=e}},gapSize:{enumerable:!0,get(){return this.uniforms.gapSize.value},set(e){this.uniforms.gapSize.value=e}},opacity:{enumerable:!0,get(){return this.uniforms.opacity.value},set(e){this.uniforms.opacity.value=e}},resolution:{enumerable:!0,get(){return this.uniforms.resolution.value},set(e){this.uniforms.resolution.value.copy(e)}}}),this.setValues(e)}};Object.assign(LineMaterial.prototype,{isLineMaterial:!0});var LineSegments2=class extends three.Mesh{constructor(e,t){super(),this.type=`LineSegments2`,this.geometry=e===void 0?new LineSegmentsGeometry:e,this.material=t===void 0?new LineMaterial({color:Math.random()*16777215}):t}computeLineDistances(){let e=this.geometry,t=e.attributes.instanceStart,n=e.attributes.instanceEnd,r=new Float32Array(2*t.count),o=new three.Vector3,s=new three.Vector3;for(var c=0,l=0,u=t.count;c<u;c++,l+=2)o.fromBufferAttribute(t,c),s.fromBufferAttribute(n,c),r[l]=l===0?0:r[l-1],r[l+1]=r[l]+o.distanceTo(s);let d=new three.InstancedInterleavedBuffer(r,2,1);return e.setAttribute(`instanceDistanceStart`,new three.InterleavedBufferAttribute(d,1,0)),e.setAttribute(`instanceDistanceEnd`,new three.InterleavedBufferAttribute(d,1,1)),this}raycast(e,t){e.camera===null&&console.error(`LineSegments2: "Raycaster.camera" needs to be set in order to raycast against LineSegments2.`);let n=e.ray,r=e.camera,o=r.projectionMatrix,s=this.geometry,c=this.material,l=c.resolution,u=c.linewidth,d=s.attributes.instanceStart,f=s.attributes.instanceEnd,p=new three.Vector4,m=new three.Vector4,h=new three.Vector4,g=new three.Vector3,_=new three.Matrix4,v=new three.Line3,y=new three.Vector3;n.at(1,h),h.w=1,h.applyMatrix4(r.matrixWorldInverse),h.applyMatrix4(o),h.multiplyScalar(1/h.w),h.x*=l.x/2,h.y*=l.y/2,h.z=0,g.copy(h);let b=this.matrixWorld;_.multiplyMatrices(r.matrixWorldInverse,b);for(var S=0,C=d.count;S<C;S++){p.fromBufferAttribute(d,S),m.fromBufferAttribute(f,S),p.w=1,m.w=1,p.applyMatrix4(_),m.applyMatrix4(_),p.applyMatrix4(o),m.applyMatrix4(o),p.multiplyScalar(1/p.w),m.multiplyScalar(1/m.w);var w=p.z<-1&&m.z<-1,T=p.z>1&&m.z>1;if(w||T)continue;p.x*=l.x/2,p.y*=l.y/2,m.x*=l.x/2,m.y*=l.y/2,v.start.copy(p),v.start.z=0,v.end.copy(m),v.end.z=0;let e=v.closestPointToPointParameter(g,!0);v.at(e,y);let r=three.MathUtils.lerp(p.z,m.z,e),s=r>=-1&&r<=1;var E=g.distanceTo(y)<u*.5;if(s&&E){v.start.fromBufferAttribute(d,S),v.end.fromBufferAttribute(f,S),v.start.applyMatrix4(b),v.end.applyMatrix4(b);var D=new three.Vector3,O=new three.Vector3;n.distanceSqToSegment(v.start,v.end,O,D),t.push({point:O,pointOnLine:D,distance:n.origin.distanceTo(O),object:this,faceIndex:S})}}}};Object.assign(LineSegments2.prototype,{isLineSegments2:!0});var Line2=class extends LineSegments2{constructor(e,t){super(e,t),this.type=`Line2`}};Object.assign(Line2.prototype,{isLine2:!0});var LineGeometry=class extends LineSegmentsGeometry{constructor(){super(),this.type=`LineGeometry`}setPositions(e){let t=e.length-3,n=new Float32Array(2*t);for(let r=0;r<t;r+=3)n[2*r]=e[r],n[2*r+1]=e[r+1],n[2*r+2]=e[r+2],n[2*r+3]=e[r+3],n[2*r+4]=e[r+4],n[2*r+5]=e[r+5];return super.setPositions(n),this}setColors(e){let t=e.length-3,n=new Float32Array(2*t);for(let r=0;r<t;r+=3)n[2*r]=e[r],n[2*r+1]=e[r+1],n[2*r+2]=e[r+2],n[2*r+3]=e[r+3],n[2*r+4]=e[r+4],n[2*r+5]=e[r+5];return super.setColors(n),this}fromLine(e){let t=e.geometry;if(t instanceof three.Geometry){let e=new three.BufferGeometry().fromGeometry(t);this.setPositions(e.attributes.position.array)}else t instanceof three.BufferGeometry&&this.setPositions(t.attributes.position.array);return this}copy(){return this}};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=class extends three.Object3D{static get version(){return`6.8.0-alpha.24`}constructor(e=new three.Vector3,t=new three.Vector3){super(),this.type=`FiveLine`,this.needsRender=!0,this.line=new Line2(new LineGeometry,new LineMaterial({color:DEFAULT_COLOR,linewidth:DEFAULT_LINEWIDTH,dashScale:DEFAULT_DASHSCALE,dashed:!1}));let n=new three.BufferGeometry,r=new three.PointsMaterial({color:DEFAULT_COLOR,size:POINT_SIZE,map:sharedCircleTexture||(sharedCircleTexture=new three.TextureLoader().load(`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==`)),sizeAttenuation:!1,transparent:!0});this.points=new three.Points(n,r),this.points.renderOrder=11,this.points.frustumCulled=!1,this.setPoints(e,t),this.add(this.line,this.points)}setPoints(e,t){let n=[].concat(e.toArray(),t.toArray());this.points.geometry.setAttribute(`position`,new three.BufferAttribute(new Float32Array(n),3)),this.line.geometry.setPositions(n),this.line.computeLineDistances(),this.needsRender=!0}getPoints(){let e=this.points.geometry.attributes.position.array;return[new three.Vector3(e[0],e[1],e[2]),new three.Vector3(e[3],e[4],e[5])]}setMaterial(e){let t=this.line.material;for(let n in e){if(!e.hasOwnProperty(n))continue;let r=e[n];n===`dashed`?(t.dashed=r,r?t.defines.USE_DASH=``:delete t.defines.USE_DASH,t.needsUpdate=!0):t[n]=e[n]}this.needsRender=!0}setResolution(e,t){let n=this.line.material.resolution;(n.x!==e||n.y!==t)&&(n.set(e,t),this.needsRender=!0)}};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(e){return __awaiter(this,void 0,void 0,function*(){let t=yield fetch(e);if(t.ok)return t.json();throw Error(t.statusText)})}function fetchProfilesList(e){return __awaiter(this,void 0,void 0,function*(){if(!e)throw Error(`No basePath supplied`);return yield fetchJsonFile(`${e}/profilesList.json`)})}function fetchProfile(e,t){return __awaiter(this,arguments,void 0,function*(e,t,n=null,r=!0){if(!e)throw Error(`No xrInputSource supplied`);if(!t)throw Error(`No basePath supplied`);let o=yield fetchProfilesList(t),s;if(e.profiles.some(e=>{let n=o[e];return n&&(s={profileId:e,profilePath:`${t}/${n.path}`,deprecated:!!n.deprecated}),!!s}),!s){if(!n)throw Error(`No matching profile name found`);let e=o[n];if(!e)throw Error(`No matching profile name found and default profile "${n}" missing.`);s={profileId:n,profilePath:`${t}/${e.path}`,deprecated:!!e.deprecated}}let c=yield fetchJsonFile(s.profilePath),l;if(r){let t;if(t=c.layouts[e.handedness],!t)throw Error(`No matching handedness, ${e.handedness}, in profile ${s.profileId}`);t.assetPath&&(l=s.profilePath.replace(`profile.json`,t.assetPath))}return{profile:c,assetPath:l}})}var defaultComponentValues={xAxis:0,yAxis:0,button:0,state:Constants.ComponentState.DEFAULT};function normalizeAxes(e=0,t=0){let n=e,r=t;if(Math.sqrt(e*e+t*t)>1){let o=Math.atan2(t,e);n=Math.cos(o),r=Math.sin(o)}return{normalizedXAxis:n*.5+.5,normalizedYAxis:r*.5+.5}}var VisualResponse=class{constructor(e){this.componentProperty=e.componentProperty,this.states=e.states,this.valueNodeName=e.valueNodeName,this.valueNodeProperty=e.valueNodeProperty,this.valueNodeProperty===Constants.VisualResponseProperty.TRANSFORM&&(this.minNodeName=e.minNodeName,this.maxNodeName=e.maxNodeName),this.value=0,this.updateFromComponent(defaultComponentValues)}updateFromComponent({xAxis:e,yAxis:t,button:n,state:r}){let{normalizedXAxis:o,normalizedYAxis:s}=normalizeAxes(e,t);switch(this.componentProperty){case Constants.ComponentProperty.X_AXIS:this.value=this.states.includes(r)?o:.5;break;case Constants.ComponentProperty.Y_AXIS:this.value=this.states.includes(r)?s:.5;break;case Constants.ComponentProperty.BUTTON:this.value=this.states.includes(r)?n:0;break;case Constants.ComponentProperty.STATE:this.valueNodeProperty===Constants.VisualResponseProperty.VISIBILITY?this.value=this.states.includes(r):this.value=this.states.includes(r)?1:0;break;default:throw Error(`Unexpected visualResponse componentProperty ${this.componentProperty}`)}}},Component=class{constructor(e,t){if(!e||!t||!t.visualResponses||!t.gamepadIndices||Object.keys(t.gamepadIndices).length===0)throw Error(`Invalid arguments supplied`);this.id=e,this.type=t.type,this.rootNodeName=t.rootNodeName,this.touchPointNodeName=t.touchPointNodeName,this.visualResponses={},Object.keys(t.visualResponses).forEach(e=>{let n=new VisualResponse(t.visualResponses[e]);this.visualResponses[e]=n}),this.gamepadIndices=Object.assign({},t.gamepadIndices),this.values={state:Constants.ComponentState.DEFAULT,button:this.gamepadIndices.button===void 0?void 0:0,xAxis:this.gamepadIndices.xAxis===void 0?void 0:0,yAxis:this.gamepadIndices.yAxis===void 0?void 0:0}}get data(){return Object.assign({id:this.id},this.values)}updateFromGamepad(e){if(this.values.state=Constants.ComponentState.DEFAULT,this.gamepadIndices.button!==void 0&&e.buttons.length>this.gamepadIndices.button){let t=e.buttons[this.gamepadIndices.button];this.values.button=t.value,this.values.button=this.values.button<0?0:this.values.button,this.values.button=this.values.button>1?1:this.values.button,t.pressed||this.values.button===1?this.values.state=Constants.ComponentState.PRESSED:(t.touched||this.values.button>Constants.ButtonTouchThreshold)&&(this.values.state=Constants.ComponentState.TOUCHED)}this.gamepadIndices.xAxis!==void 0&&e.axes.length>this.gamepadIndices.xAxis&&(this.values.xAxis=e.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&&e.axes.length>this.gamepadIndices.yAxis&&(this.values.yAxis=e.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(e=>{e.updateFromComponent(this.values)})}},MotionController=class{constructor(e,t,n){if(!e)throw Error(`No xrInputSource supplied`);if(!t)throw Error(`No profile supplied`);this.xrInputSource=e,this.assetUrl=n,this.id=t.profileId,this.layoutDescription=t.layouts[e.handedness],this.components={},Object.keys(this.layoutDescription.components).forEach(e=>{let t=this.layoutDescription.components[e];this.components[e]=new Component(e,t)}),this.updateFromGamepad()}get gripSpace(){return this.xrInputSource.gripSpace}get targetRaySpace(){return this.xrInputSource.targetRaySpace}get data(){let e=[];return Object.values(this.components).forEach(t=>{e.push(t.data)}),e}updateFromGamepad(){Object.values(this.components).forEach(e=>{e.updateFromGamepad(this.xrInputSource.gamepad)})}},DEFAULT_PROFILES_PATH=`https://cdn.jsdelivr.net/npm/@webxr-input-profiles/assets@1.0/dist/profiles`,DEFAULT_PROFILE=`generic-trigger`,XRControllerModel=class extends three.Object3D{constructor(){super(),this.motionController=null,this.envMap=null}setEnvironmentMap(e){return this.envMap==e?this:(this.envMap=e,this.traverse(e=>{e instanceof three.Mesh&&e.isMesh&&(e.material.envMap=this.envMap,e.material.needsUpdate=!0)}),this)}updateMatrixWorld(e){super.updateMatrixWorld(e),this.motionController&&(this.motionController.updateFromGamepad(),Object.values(this.motionController.components).forEach(e=>{Object.values(e.visualResponses).forEach(e=>{let{valueNode:t,minNode:n,maxNode:r,value:o,valueNodeProperty:s}=e;t&&(s===Constants.VisualResponseProperty.VISIBILITY?t.visible=o:s===Constants.VisualResponseProperty.TRANSFORM&&(t.quaternion.copy(n.quaternion).slerp(r.quaternion,o),t.position.lerpVectors(n.position,r.position,o)))})}))}};function findNodes(e,t){Object.values(e.components).forEach(e=>{let{type:n,touchPointNodeName:r,visualResponses:o}=e;if(n===Constants.ComponentType.TOUCHPAD)if(e.touchPointNode=t.getObjectByName(r),e.touchPointNode){let t=new three.Mesh(new three.SphereGeometry(.001),new three.MeshBasicMaterial({color:255}));e.touchPointNode.add(t)}else console.warn(`Could not find touch dot, ${e.touchPointNodeName}, in touchpad component ${e.id}`);Object.values(o).forEach(e=>{let{valueNodeName:n,minNodeName:r,maxNodeName:o,valueNodeProperty:s}=e;if(s===Constants.VisualResponseProperty.TRANSFORM){if(e.minNode=t.getObjectByName(r),e.maxNode=t.getObjectByName(o),!e.minNode){console.warn(`Could not find ${r} in the model`);return}if(!e.maxNode){console.warn(`Could not find ${o} in the model`);return}}e.valueNode=t.getObjectByName(n),e.valueNode||console.warn(`Could not find ${n} in the model`)})})}function addAssetSceneToControllerModel(e,t){findNodes(e.motionController,t),e.envMap&&t.traverse(t=>{t instanceof three.Mesh&&t.isMesh&&(t.material.envMap=e.envMap,t.material.needsUpdate=!0)}),e.add(t)}var XRControllerModelFactory=class{constructor(e=null){this.gltfLoader=e,this.path=DEFAULT_PROFILES_PATH,this._assetCache={}}createControllerModel(e){let t=new XRControllerModel,n=null;return e.addEventListener(`connected`,e=>{let r=e.data;r.targetRayMode!==`tracked-pointer`||!r.gamepad||fetchProfile(r,this.path,DEFAULT_PROFILE).then(({profile:e,assetPath:o})=>{t.motionController=new MotionController(r,e,o);let s=this._assetCache[t.motionController.assetUrl];if(s)n=s.scene.clone(),addAssetSceneToControllerModel(t,n);else{if(!this.gltfLoader)throw Error(`GLTFLoader not set.`);this.gltfLoader.load(t.motionController.assetUrl,e=>{this._assetCache[t.motionController.assetUrl]=e,n=e.scene.clone(),addAssetSceneToControllerModel(t,n)})}}).catch(e=>{console.warn(e)})}),e.addEventListener(`disconnected`,()=>{t.motionController=null,t.remove(n),n=null}),t}},defaultXRPanoramaControllerInitArgs=Object.assign({},omit(defaultPanoramaControllerCustomInitArgs,[`maxLatitude`,`minLatitude`]));function mapPanoResource(e,t){if(!t)return e;let n=e.match(/\d+_[a-z].png/);return e.substring(0,n.index)+t+`/`+e.substring(n.index)}var CONTROLLER_EVNET_DELTA_TIME=300,scratchRaycaster=new three.Raycaster,scratchVector3=new three.Vector3,XRPanoramaController=class e extends PanoramaController{static parseArgs(t){if(t instanceof e)return t;let n=Object.assign(Object.assign({},t),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2});return super.parseArgs(n)}static initAnimationEndState(e){let t=this.parseArgs(e),n=super.initAnimationEndState(t);return Object.assign(Object.assign({},n),{mode:`XRPanorama`})}constructor(e){super(e),this.xrManager=new XRManager(this.renderer,this.renderer.getContext(),{onSessionStart:e=>{this.emit(`xr.session.start`,createEvent(`xr.session.start`,{session:e,machineType:this.xrManager.machineType}))},onSessionEnd:()=>{this.emit(`xr.session.end`,createEvent(`xr.session.end`,{session:null,machineType:this.xrManager.machineType}))}}),this.xrControllerRay={left:new three.Raycaster,right:new three.Raycaster},this.xrControllerRay.left.params.Points={threshold:.1},this.xrControllerRay.left.firstHitOnly=!0,this.xrControllerRay.left.floorIndex=-1,this.xrControllerRay.right.params.Points={threshold:.1},this.xrControllerRay.right.firstHitOnly=!0,this.xrControllerRay.right.floorIndex=-1,this.gazeRay=null,this.pointerLines={left:new FiveLine,right:new FiveLine},this.pointerLines.left.visible=!1,this.pointerLines.right.visible=!0,this.pointerLines.left.setMaterial({color:new three.Vector3(1,1,1)}),this.pointerLines.left.points.material.depthTest=!1,this.pointerLines.right.setMaterial({color:new three.Vector3(1,1,1)}),this.pointerLines.right.points.material.depthTest=!1,this.controllerWrappers=[new three.Group,new three.Group];let t=this.xrManager.getController(0);this.controllerWrappers[0].add(t);let n=this.xrManager.getController(1);this.controllerWrappers[1].add(n);let r=new XRControllerModelFactory;r.gltfLoader={load(e,t){internalFetcher.ajax(e,{responseType:`arraybuffer`}).then(t=>{var n;return parseGltf(t.body,{resourcePath:e.slice(0,e.lastIndexOf(`/`)+1),search:(n=e.split(`?`)[1])==null?``:n,fetcher:internalFetcher})}).then(e=>t(e))}},(this.xrManager.machineType===`Oculus`||this.xrManager.machineType===`Pico`)&&this.scene.add(this.pointerLines.left,this.pointerLines.right,this.controllerWrappers[0],this.controllerWrappers[1]),this.panoResources={},this.panoResources[this.locationMotion.keyframes[0].key=this.locationMotion.keyframes[1].key=createUuid()]={panoId:panoStringify(this.currentPano),leftPanoPicture:null,position:this.camera.pose.offset.clone(),effect:`fade`,effectEasing:defaultEffectEase,fixCameraTransform:new three.Matrix4},this.parallaxCameraMatrixs=[];let o=AnimationFrameLoop.shared.getContext();if(!o){console.error(`获取session失败,请退出重试`);return}this.on(`xr.session.end`,()=>{this.scene.remove(this.pointerLines.left,this.pointerLines.right)}),this.xrManager.setSession(o),this.on(`xr.session.start`,()=>{let e=this.xrManager.getControllerGrip(0);e.add(r.createControllerModel(e)),this.controllerWrappers[0].add(e);let t=this.xrManager.getControllerGrip(1);t.add(r.createControllerModel(t)),this.controllerWrappers[1].add(t)}),this.xrHandleState={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}},this.xrManager.machineType===`VP`&&this.initHandEvent()}updateConfiguration(e){return super.updateConfiguration(Object.assign(Object.assign({},e),{maxLatitude:Math.PI/2,minLatitude:-Math.PI/2}))}moveToPano(e,t,n){var r,o,s;let c=(r=t.effect)==null?`fade`:r;this.userAction=n,this.stopMomentumMovement();let l=panoStringify(e),u=this.works.getObserver(e);if(!u)throw Error(`Invalid PanoIndex`);let d=getImageSizeFromURL(u.images.up),f=this.imageOptions.size;f===void 0&&u&&d&&(f=Number(d)),f===void 0&&(f=2048);let p=this.imageOptions.transform,m=(e,t)=>mapPanoResource(applyImageURLOptions(e,p,t)),h=Object.assign({key:`pano.${l}`},pick(this.imageOptions,[`format`,`size`,`quality`])),g={right:u.images.work.getURL(u.images.right),left:u.images.work.getURL(u.images.left),up:u.images.work.getURL(u.images.up),down:u.images.work.getURL(u.images.down),front:u.images.work.getURL(u.images.front),back:u.images.work.getURL(u.images.back)},_=`pano:`+jsonHash([g,h,p]);if(this.pendingTextureTask){if(this.pendingTextureTask.hash===_)return;{let t=this.pendingTextureTask.panoId;(o=this.panoMeshes.get(t))==null||o.setProgress(0),this.emit(`pano.texture.abort`,createEvent(`pano.texture.abort`,{error:null,progress:0,meta:null,pano:e}))}}let v=this.modelScene.parameter.resolveValue(`pano0`),y=this.modelScene.parameter.resolveValue(`pano1`),b;if((v==null?void 0:v.map.name)===_?b=v:(y==null?void 0:y.map.name)===_&&(b=y),b){let n={panoId:l,effect:c,effectEasing:(s=t.effectEasing)==null?defaultEffectEase:s,leftPanoPicture:{panoId:b.panoId,map:b.map,mapHistogram:b.mapHistogram,mapSize:b.mapSize,matrix:u.matrix.clone().premultiply(u.work.transform),zoom:1},position:u.position.clone().applyMatrix4(u.work.transform),fixCameraTransform:new three.Matrix4};this.doMoveToPano(e,n,t);return}let S=`move-to-pano-`+l;this.pending.add(S),this.pendingTextureTask={panoId:l,hash:_,onLoad:n=>{var r,o;let s=n.body;if(this.destroyed)s.dispose();else{s.name=_;let n=Array.isArray(s.image)?s.image[0]:s.image,d=(r=n==null?void 0:n.width)==null?2048:r,f=new Histogram().formPixels(getRgbaDataFromCubeTexture(this.renderer,s,!0,sharedHistogramRgbaData).data),p={panoId:l,effect:c,effectEasing:(o=t.effectEasing)==null?defaultEffectEase:o,leftPanoPicture:{panoId:l,map:s,mapSize:d,mapHistogram:new three.Vector4().fromArray(f.toArray()),matrix:u.matrix.clone(),zoom:1},position:u.position.clone(),fixCameraTransform:new three.Matrix4};this.doMoveToPano(e,p,t)}},onError:n=>{let r=Object.assign(Object.assign(Object.assign({},e),{mode:this.mode}),clonePose(this.camera.pose));this.emit(`pano.error`,createEvent(`pano.error`,{error:n,userAction:this.userAction,options:t,prevPano:this.currentPano,progress:0,state:r})),this.emit(`pano.cancel`,createEvent(`pano.cancel`,{error:null,userAction:this.userAction,options:t,prevPano:this.currentPano,progress:0,state:r})),t.moveCancelCallback&&t.moveCancelCallback()}};let C=this.panoMeshes.get(l);C&&C.tap&&C.tap(),this.textureLoader.loadCubeTexture(g,{imageURL:{transform:m,options:h},format:three.RGBFormat,fetcher:getFetcher(this.fiveId,u.work)},void 0,void 0,t=>{var n,r;((n=this.pendingTextureTask)==null?void 0:n.hash)===_&&((r=this.panoMeshes.get(l))==null||r.setProgress(t)),this.emit(`pano.texture.progress`,createEvent(`pano.texture.progress`,{error:null,progress:t,meta:null,pano:e}))},this.renderer).then(t=>{var n,r;this.pending.delete(S),((n=this.pendingTextureTask)==null?void 0:n.hash)===_?(this.pendingTextureTask.onLoad(t),this.pendingTextureTask=void 0,(r=this.panoMeshes.get(l))==null||r.setProgress(0)):t.body.dispose(),this.emit(`pano.texture.success`,createEvent(`pano.texture.success`,{error:null,progress:1,meta:t.meta,pano:e}))}).then(()=>new Promise(e=>{AnimationFrameLoop.shared.add(()=>e(),!0)})).catch(t=>{var n,r;this.pending.delete(S),((n=this.pendingTextureTask)==null?void 0:n.hash)===_&&(this.pendingTextureTask.onError(t),this.pendingTextureTask=void 0,(r=this.panoMeshes.get(l))==null||r.setProgress(0)),this.emit(`pano.texture.error`,createEvent(`pano.texture.error`,{error:t,progress:0,meta:null,pano:e})),this.emit(`error`,t)}),this.emit(`pano.texture.load`,createEvent(`pano.texture.load`,{error:null,progress:0,meta:null,pano:e}))}doMoveToPano(e,t,n={}){var r,o,s,c,l,u,d,f,p,m;let h=now(),g=createUuid();this.panoResources[g]=t;let _=1,v,y,b;if(this.locationMotion.ended){let[e,n]=this.locationMotion.getKeyFrameSegment(h),r=this.locationMotion.value,o=this.panoResourceFromLocationMotionKeyframe(n).position,s=t.position;v=Math.max(o.distanceTo(s),1),y=[{key:n.key,progress:0,value:Object.assign(Object.assign({},r),{count:0})},{key:g,progress:1,value:{distance:0,count:1}}],b=0}else{let[e,n]=this.locationMotion.getKeyFrameSegment(h),r=this.locationMotion.value,o=this.panoResourceFromLocationMotionKeyframe(e).position,s=this.panoResourceFromLocationMotionKeyframe(n).position,c=t.position,l=n.value.count-r.count,u=Math.max(o.distanceTo(s),1)*l;v=u+Math.max(s.distanceTo(c),1),y=[{key:e.key,progress:0,value:Object.assign({},r)},{key:n.key,progress:u/v,value:n.value},{key:g,progress:1,value:{count:n.value.count+1,distance:0}}];let d=this.locationMotionKeyframesLength(this.locationMotion.keyframes),f=this.locationMotionKeyframesLength(y);b=this.locationMotion.getProgressVelocity(h)*d/f}let S=t.effect===`instant`?0:this.calculateMovingDuration(n.duration,t.effect===`fly`||t.effect===`model`?v:0),C={longitude:n.longitude,latitude:n.latitude,fov:n.fov},w=Object.assign(Object.assign({},e),{mode:this.mode,longitude:(r=C.longitude)==null?this.camera.pose.longitude:r,latitude:(o=C.latitude)==null?this.camera.pose.latitude:o,fov:(s=C.fov)==null?this.camera.pose.fov:s,offset:t.position.clone(),distance:0}),T=this.currentPano;if(this.emit(`pano.moveTo`,createEvent(`pano.moveTo`,{options:n,prevPano:T,progress:0,state:w,userAction:this.userAction,error:null})),n.moveStartCallback&&n.moveStartCallback(w),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,this.videoTexture.needsUpdate=!0),this.panoVideo.setMaterial(null),t.effect===`fly`||t.effect===`model`)this.cameraMotion.set(C,S).catch(noop);else{let e=coordinatesToVector({longitude:this.cameraMotion.value.longitude,latitude:this.cameraMotion.value.latitude}),n=coordinatesToVector({longitude:(c=C.longitude)==null?this.cameraMotion.value.longitude:c,latitude:(l=C.latitude)==null?this.cameraMotion.value.latitude:l}),r=new three.Object3D;r.lookAt(e);let o=new three.Matrix4().makeRotationFromQuaternion(r.quaternion);r.lookAt(n);let s=new three.Matrix4().makeRotationFromQuaternion(r.quaternion),h=new three.Matrix4().getInverse(o).premultiply(s),g=this.cameraMotion.value.fov,_=(u=C.fov)==null?this.cameraMotion.value.fov:u,v=1;t.effect===`zoomin`?v=1.5:t.effect===`zoomout`&&(v=.4);let b=_*v;for(let e=0;e<y.length-1;e++){let t=y[e].key;if(t){let e=this.panoResources[t];e&&(e.fixCameraTransform.copy(h),e.leftPanoPicture&&(e.leftPanoPicture.zoom=Math.tan(b/2/180*Math.PI)/Math.tan(g/2/180*Math.PI)))}}this.cameraMotion.setKeyframes([{progress:0,value:{longitude:this.cameraMotion.value.longitude,latitude:this.cameraMotion.value.latitude,fov:this.cameraMotion.value.fov}},{progress:0,value:{longitude:(d=C.longitude)==null?this.cameraMotion.value.longitude:d,latitude:(f=C.latitude)==null?this.cameraMotion.value.latitude:f,fov:b}},{progress:1,value:{longitude:(p=C.longitude)==null?this.cameraMotion.value.longitude:p,latitude:(m=C.latitude)==null?this.cameraMotion.value.latitude:m,fov:_}}],S).catch(noop)}this.locationMotion.setKeyframes(y,S,b).then(()=>{for(let e of this.modelScene.children)e instanceof Model&&e.show();let t=Object.assign(Object.assign({},e),{mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:this.camera.pose.offset.clone(),distance:0});this.emit(`pano.arrived`,createEvent(`pano.arrived`,{options:n,prevPano:T,progress:1,state:t,userAction:this.userAction,error:null})),n.moveEndCallback&&n.moveEndCallback(t);let r=this.works.getObserver(this.currentPano);if(r&&r.images.video&&this.videoTexture&&this.videoTexture.image instanceof HTMLVideoElement){let e={map:this.videoTexture,size:r.images.video.size.clone(),matrix:r.images.video.matrix.clone(),panoMatrix:r.matrix.clone().premultiply(r.work.transform),alpha:1},t=createUuid(),n=this.videoTexture.image;n.setAttribute(`uuid`,t),canplayVideo().then(o=>{o&&r.images.video&&n.getAttribute(`uuid`)===t&&(n.oncanplay=()=>{n.oncanplay=noop,n.play()},n.ontimeupdate=()=>{n.currentTime>.5&&(n.ontimeupdate=noop,this.panoVideo.setMaterial(e))},n.src=r.images.video.source)}).catch((()=>{n.removeAttribute(`uuid`)}))}},()=>{this.emit(`pano.cancel`,createEvent(`pano.cancel`,{options:n,prevPano:T,progress:0,state:w,userAction:this.userAction,error:null})),n.moveCancelCallback&&n.moveCancelCallback()})}checkSelectedPano(e){var t;this.stopMomentumMovement(),this.camera.getDirection(new three.Vector3).setY(0);let n=null,r=this.works.getObserver(this.currentPano);if(!r)return null;let o=r.work.observers,s=r.accessibleNodes.filter(e=>{if(e===this.currentPano.panoIndex&&r.work.workCode===this.currentPano.workCode)return!1;let t=o[e];return!t||scratchVector3.copy(t.position).applyMatrix4(t.work.transform).distanceTo(this.camera.position)>this.maxAccessibleDistance?!1:t.loadable||t.active}),[c]=this.modelScene.intersectRaycaster(e);if(c){let[e,r]=arrayMin(s,e=>{let t=o[e];return t?scratchVector3.copy(t.standingPosition).applyMatrix4(t.work.transform).distanceTo(c.point):1/0},!0);typeof e==`number`&&r<this.panoTapTriggerRadius&&(n=(t=o[e])==null?null:t)}if(isNil(n)){let t=this.getForwardObserverOrNot(this.xrManager.cameraVR,e);t&&(n=t)}for(let e of this.locationMotion.keyframes){let t=this.panoResourceFromLocationMotionKeyframe(e);if(!(e.progress<this.locationMotion.progress)&&n){let e=panoStringify({panoIndex:n.panoIndex,workCode:n.work.workCode});if(t.panoId===e){n=null;break}}}if(isNil(n))return this.locationMotion.ended===!0&&this.cameraBounce(),null;if(!n.active){let e=panoStringify({panoIndex:n.panoIndex,workCode:n.work.workCode}),t=this.panoMeshes.get(e);t&&(t.setDisabled(!1),t.setLoading(!0))}let l={workCode:n.work.workCode,panoIndex:n.panoIndex,mode:this.mode,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,distance:0,offset:n?n.position.clone():new three.Vector3};return this.emit(`pano.select`,createEvent(`pano.select`,{prevPano:this.currentPano,state:l,userAction:!0,options:{},progress:0,error:null})),n&&n.active?(this.emit(`pano.request`,createEvent(`pano.request`,{userAction:!0,prevPano:this.currentPano,progress:0,state:l,options:{},error:null})),{workCode:n.work.workCode,panoIndex:n.panoIndex}):null}destroy(){super.destroy()}isReady(){return!1}updateCamera(e,t,n){return Promise.resolve()}updateCameraWithKeyframes(e,t,n){return Promise.resolve()}updateTime(e,t,...n){var r,o,s,c,l,u,d,f,p;this.userAction=!0;let m={},h={},g=this.camera.getDirection(new three.Vector3),_=this.locationMotion.keyframes[0],v=this.locationMotion.keyframes[this.locationMotion.keyframes.length-1],[y,b]=this.locationMotion.getKeyFrameSegment(e),S=this.panoResourceFromLocationMotionKeyframe(y),C=this.panoResourceFromLocationMotionKeyframe(b),w=this.panoResourceFromLocationMotionKeyframe(_),T=this.panoResourceFromLocationMotionKeyframe(v),E=!1;if(this.cameraMotion.ended===!1&&(this.cameraMotion.update(e),h.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$1(this.perspToOrthoMotion.value.perspToOrtho,0,1))),this.locationMotion.ended===!1){this.locationMotion.update(e);let t=this.locationMotion.value.count-b.value.count+1,n=new three.Vector3().copy(S.position),s=new three.Vector3().copy(C.position);if(m.progress=t,t>=.01&&t<=.99&&(m.progress=clamp$1(C.effectEasing(t),.01,.99)),C.leftPanoPicture&&(t<1?S.leftPanoPicture&&(m.pano0=S.leftPanoPicture):m.pano0=C.leftPanoPicture,m.pano1=C.leftPanoPicture),C.effect===`montage`?m.transition=`BLACK`:C.effect===`spread`?m.transition=`SPREAD`:m.transition=`FADE`,C.effect===`zoomin`||C.effect===`zoomout`?m.progress=Math.pow(t,3):C.effect===`model`&&this.camera.pose.distance<.01&&(m.modelAlpha=1-Math.pow(clamp$1(Math.abs(t-.5)*2,0,1),4)),t<1&&C.effect!==`fly`){if(m.pano0&&S.leftPanoPicture){let e={panoId:m.pano0.panoId,map:m.pano0.map,mapHistogram:m.pano0.mapHistogram,mapSize:m.pano0.mapSize,zoom:m.pano0.zoom,matrix:S.leftPanoPicture.matrix.clone().setPosition(C.position)},t=this.panoPictureObserverMap.get(m.pano0);t&&this.panoPictureObserverMap.set(e,t),m.pano0=e}n.copy(s),E=!0}h.distance=this.locationMotion.value.distance,h.offset=new three.Vector3(n.x+(s.x-n.x)*t,n.y+(s.y-n.y)*t,n.z+(s.z-n.z)*t);let c=[],l=[];for(let e of this.locationMotion.keyframes){let{key:t,progress:n}=e;t!==void 0&&(c.push(t),n>this.locationMotion.progress&&l.push(t))}for(let e of Object.keys(this.panoResources)){if(l.indexOf(e)>=0)continue;let t=this.panoResources[e];if(t.leftPanoPicture){let e=t.leftPanoPicture.map;if(e){if(e===((r=m.pano0)==null?void 0:r.map)||e===((o=m.pano1)==null?void 0:o.map))continue;e.dispose(),t.leftPanoPicture=null}}c.indexOf(e)>=0||delete this.panoResources[e]}let u=panoParse(C.panoId);u!==this.currentPano&&(this.currentPano=u,this.accessibleObserverFloorCheckCount=0),this.emit(`pano.moving`,createEvent(`pano.moving`,{userAction:this.userAction,prevPano:panoParse(w.panoId),state:Object.assign(Object.assign(Object.assign(Object.assign({},panoParse(T.panoId)),{mode:this.mode}),clonePose(this.camera.pose)),h),options:{},progress:this.locationMotion.progress,error:null}))}this.camera.setFromPose(h),this.xrManager.cameraVR.projectionMatrix.copy(this.camera.projectionMatrix),this.xrManager.cameraVR.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse),this.xrManager.cameraVR.matrix.copy(this.camera.matrix),this.xrManager.cameraVR.position.copy(this.camera.position),this.xrManager.cameraVR.quaternion.copy(this.camera.quaternion),this.xrManager.cameraVR.scale.copy(this.camera.scale),this.xrManager.cameraVR.matrixAutoUpdate=!1,this.xrManager.cameraVR.matrixWorld.copy(this.camera.matrixWorld);let[D,O]=n,k=new three.Vector3(0,0,0),A=new three.Vector2().copy(this.camera.resolution);if(O&&this.xrManager.session&&this.xrManager.referenceSpace&&this.xrManager.session.renderState.baseLayer){let n=this.xrManager.cameraVR,r=this.xrManager.referenceSpace,o=this.xrManager.session.renderState.baseLayer,u=O.getViewerPose(r),d=(s=u==null?void 0:u.views)==null?[]:s;for(let e=0;e<d.length;e++){let t=d[e],r=n.cameras[e],s=o.getViewport(t);s&&(r.projectionMatrix.fromArray(t.projectionMatrix),r.projectionMatrixInverse.getInverse(r.projectionMatrix),r.matrix.fromArray(t.transform.matrix),r.matrix.setPosition(this.camera.position),r.matrix.decompose(r.position,r.quaternion,r.scale),r.matrixWorld.copy(r.matrix),r.matrixWorldInverse.getInverse(r.matrixWorld),r.matrixAutoUpdate=!1,k.copy(r.position),r.viewport.set(s.x,s.y,s.width,s.height),A.set(s.width,s.height))}if(this.xrManager.setProjectionFromUnion(this.xrManager.cameraVR,this.xrManager.cameraL,this.xrManager.cameraR),this.camera.quaternion.copy(this.xrManager.cameraVR.quaternion),this.camera.scale.copy(this.xrManager.cameraVR.scale),this.camera.matrix.compose(this.camera.position,this.camera.quaternion,this.camera.scale),this.camera.computePose((c=h.distance)==null?this.camera.pose.distance:c),this.xrManager.session.inputSources){for(let e=0;e<this.xrManager.session.inputSources.length;e++)if(this.xrManager.session.inputSources[e]&&this.xrManager.session.inputSources[e].targetRayMode===`transient-pointer`){let t=O.getPose(this.xrManager.session.inputSources[e].targetRaySpace,r);if(t){let e=t.transform.orientation,n=new three.Quaternion(e.x,e.y,e.z,e.w),r=new three.Vector3(0,0,-1).applyQuaternion(n);this.gazeRay=new three.Raycaster(this.camera.position,r)}}}if(this.xrManager.machineType===`Oculus`||this.xrManager.machineType===`Pico`){let n=this.xrManager.session.inputSources;for(let e=0;e<n.length;e++){let t=this.xrManager.controllers[e],o=n[e];if(!o)continue;t&&t.update(o,O,r);let s=this.xrManager.getController(e),c=new three.Vector3(0,1.2,0),u=s.position.clone().add(k).sub(c);o.handedness===`left`?this.xrControllerRay.left.set(u,new three.Vector3(0,0,-1).applyEuler(s.rotation)):o.handedness===`right`&&this.xrControllerRay.right.set(u,new three.Vector3(0,0,-1).applyEuler(s.rotation)),this.controllerWrappers[e].position.copy(new three.Vector3(0,0,0).add(k).sub(c));let d=this.modelScene.intersectRaycaster(this.xrControllerRay.right);if(d.length===0){let e=this.works.getResolvedObserver(this.currentPano);d=this.xrControllerRay.right.intersectObject(this.modelScene.boundingMesh,!0).map(t=>{var n;let r=(n=e==null?void 0:e.floorIndex)==null?0:n;return Object.assign({floorIndex:r,floor:r},t)})}if(d.length>=1&&d[0].face)if(o.handedness===`right`){let e=this.xrControllerRay.right.intersectObject(this.xrCustomObjectsScene,!0),t=d[0].face.normal,n=t.clone(),r=d[0].point.clone();this.intersectMesh.position.copy(r);let o=r.clone().add(n);if(this.intersectMesh.lookAt(o),Math.abs(t.y)>.99){let e=this.camera.position.clone().sub(r);this.intersectMesh.rotation.z=-Math.atan2(e.z,e.x)}this.intersectMesh.visible=!0,this.needsRender=!0,e.length>0?(this.pointerLines.right.setPoints(u,e[0].point),this.pointerLines.right.points.visible=!0,this.intersectMesh.visible=!1):(this.pointerLines.right.points.visible=!1,this.pointerLines.right.setPoints(u,d[0].point));let s=d[0],c=createEvent(`intersect.update`,{raycaster:(l=this.xrControllerRay.right)==null?null:l,intersection:s==null?null:s,object:this.intersectMesh});if(this.emit(`intersect.update`,c),c.defaultPrevented){this.hideIntersectMesh();return}}else this.pointerLines.left.setPoints(u,d[0].point)}this.updateControllerHelper(n,e,t)}}else O||console.error(`xrFrame丢失,请重试`),this.xrManager.session||console.error(`session丢失,请重试`),this.xrManager.session&&!this.xrManager.session.renderState.baseLayer&&console.error(`no layer found`);isEmptyObject(m)===!1&&this.modelScene.parameter.set(m),this.emit(`camera.update`,createEvent(`camera.update`,{userAction:this.userAction,state:Object.assign(Object.assign(Object.assign({},this.currentPano),{mode:this.mode}),clonePose(this.camera.pose))}));let j=this.works.getResolvedObserver(this.currentPano),M=this.locationMotion.ended?this.getForwardObserverOrNot(this.xrManager.cameraVR):null,N=this.works.getObserver(S.panoId),P=this.works.getObserver(C.panoId);if(this.adjustPanoCircleMeshPositionBasedOnModel&&this.helper.visible&&j){let e=[],t=j.work.observers;for(let n of j.accessibleNodes){let r=t[n];r&&e.push(r)}let n=new Map;if(e.sort((e,t)=>{let r=n.get(e);r===void 0&&(r=e.standingPosition.distanceTo(j.standingPosition),n.set(e,r));let o=n.get(e);return o===void 0&&(o=t.standingPosition.distanceTo(j.standingPosition),n.set(t,o)),r-o}),e.length){this.accessibleObserverFloorCheckCount%=e.length;let t=e[this.accessibleObserverFloorCheckCount],n=this.modelScene.models.find(e=>e.work===(t==null?void 0:t.work));if(t&&n&&n.visible){let e=.3,r=.05,o=.005,s=t.standingPosition.clone().applyMatrix4(t.work.transform),c=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode}),l=adjustPanoCircleMeshVectors.map(t=>{scratchRaycaster.ray.origin.copy(s),scratchRaycaster.ray.origin.add(scratchVector3.copy(t).setY(e)),scratchRaycaster.ray.direction.set(0,-1,0),scratchRaycaster.firstHitOnly=!0,scratchRaycaster.floorIndex=-1;let[r]=n.intersectRaycaster(scratchRaycaster);return r&&r.distance-o<=e?new three.Vector3().copy(s).setY(r.point.y+o):s});l.sort((e,t)=>t.y-e.y);let u=l[Math.floor(l.length/2)],[d]=l.filter(e=>e.distanceTo(u)<=.05);if(d){let e=new three.Vector4(s.x,s.y,s.z,d.y-s.y),t=this.adjustPanoCircleMeshPositionFix.get(c);t&&!e.equals(t)&&(this.needsRender=!0),this.adjustPanoCircleMeshPositionFix.set(c,e)}}this.accessibleObserverFloorCheckCount++}}let F=new Map;if(N)for(let e of N.accessibleNodes){let t=N.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});F.set(e,t)}}if(P)for(let e of P.accessibleNodes){let t=P.work.observers[e];if(t){let e=panoStringify({panoIndex:t.panoIndex,workCode:t.work.workCode});F.set(e,t)}}if(this.panoMeshes.forEach((e,t)=>{F.get(t)?F.delete(t):(this.helper.remove(e),e.dispose(),this.panoMeshes.delete(t))}),F.forEach((e,t)=>{let n=this.panoCircleMeshCreator(e,{aerialObserverMinHeight:this.aerialObserverMinHeight});this.panoMeshes.set(t,n),this.helper.add(n),F.delete(t)}),this.panoMeshes.forEach((e,t)=>{let n=this.works.getObserver(t);if(n){let r=n.position.distanceTo(n.standingPosition)>this.aerialObserverMinHeight;if(r)e.position.copy(n.position).applyMatrix4(n.work.transform),e.scale.setScalar(18);else{e.position.copy(n.standingPosition).applyMatrix4(n.work.transform);let t=this.adjustPanoCircleMeshPositionFix.get(n.panoId);t&&(scratchVector3.set(t.x,t.y,t.z),scratchVector3.equals(e.position)&&(e.position.y+=t.w)),e.scale.setScalar(1.2)}let o=this.camera.position.clone().setY(e.position.y),s=new three.Vector3().copy(e.position).sub(o).normalize();if(t===panoStringify(this.currentPano)){let t=clamp$1((.5-o.distanceTo(e.position))/.5,0,1);s.multiplyScalar(1-t).add(g.clone().multiplyScalar(t))}if(s.length()>0){let t=r?-Math.PI/2:0,n=Math.atan2(s.x,s.z);e.quaternion.setFromEuler(new three.Euler(t,n,0,`YXZ`))}}else e.visible=!1}),this.camera.pose.distance>.1||E)this.panoMeshes.forEach(n=>{n.setOpacity(0),n.setCurrent(!1),n.updateTime&&n.updateTime(e,t),n.visible=!1});else if(j){let n=j.work.observers,[,r]=arrayMin(j.accessibleNodes,e=>{let t=n[e];return!t||!t.active?1/0:j.standingPosition.distanceTo(t.standingPosition)},!0);r=clamp$1(r,2.5,1/0);let o=j.accessibleNodes.concat(j.panoIndex).map(e=>panoStringify({panoIndex:e,workCode:j.work.workCode}));this.panoMeshes.forEach((n,s)=>{let c=this.works.getObserver(s),l=!1,u=1;if(o.indexOf(s)===-1)l=!1,u=0;else if(!c)l=!1,u=0;else if(!c.loadable&&!c.active)l=!1,u=0;else{let e=n.position.clone().project(this.camera);l=Math.abs(e.x)<1&&Math.abs(e.y)<1&&Math.abs(e.z)<1&&!n.loading&&n.progress===0&&M!==null&&panoStringify({panoIndex:M.panoIndex,workCode:M.work.workCode})===s;let t=n.position.clone().setY(this.camera.position.y).distanceTo(this.camera.position);u=t<.01?0:clamp$1(r/t,.1,.85)}c&&c===P&&c.position.distanceTo(c.standingPosition)>this.aerialObserverMinHeight&&n.position.distanceTo(this.camera.position)<35&&(u=0),this.modelScene.parameter.resolveValue(`modelAlpha`)>0&&(u=0),n.setCurrent(l),n.setOpacity(u),n.updateTime&&n.updateTime(e,t)})}{let e=(u=this.modelScene.parameter.progress)==null?1:u,t=Math.round(e),n=this.modelScene.parameter.pano0,r=this.modelScene.parameter.pano1,o=t===0?n:r,s;if(o&&(s=this.works.getObserver(o.panoId),s||(s=this.panoPictureObserverMap.get(o))),this.tiling.appearDuration=this.tileAppearDuration,this.tiling.maxRequest=e<(canUseNativeImageBitmap()?.6:.99)?0:this.tileMaxRequest,this.tiling.imageOptions=this.imageOptions,!s||!o||this.tileLevelForFov===!1||this.camera.perspToOrtho.x>0){this.tiling.setObserver(null);let e={renderer:this.renderer,resolution:A,pixelRatio:1,time:this.camera.time,cameraMatrix:this.xrManager.cameraVR.matrixWorld,cameraProjectionMatrix:this.xrManager.cameraVR.projectionMatrix,panoMap:null,panoMatrix:new three.Matrix4,panoZoom:1,minLevel:0,level:0};this.tiling.update(e),this.modelScene.parameter.set(`refinedScreen`,null)}else{let e=getImageSizeLevel(o.mapSize)+1,c=4;this.tiling.setObserver(s);let l={renderer:this.renderer,resolution:A,pixelRatio:1,time:this.camera.time,cameraMatrix:this.xrManager.cameraVR.matrixWorld,cameraProjectionMatrix:this.xrManager.cameraVR.projectionMatrix,panoMap:o.map,panoMatrix:o.matrix,panoZoom:o.zoom,minLevel:e,level:4},u=this.tiling.update(l),f={map:this.tiling.renderTarget.texture,matrixInverse:this.tiling.camera.matrixWorldInverse,projectionMatrix:this.tiling.camera.projectionMatrix,pano:t,opacity:(n==null?void 0:n.panoId)===(r==null?void 0:r.panoId)?1:easeInQuart(Math.abs(((d=this.modelScene.parameter.progress)==null?0:d)-.5)*2)},p=this.modelScene.parameter.refinedScreen;(u||f.pano!==(p==null?void 0:p.pano)||f.opacity!==(p==null?void 0:p.opacity))&&this.modelScene.parameter.set(`refinedScreen`,f)}}if(this.panoVideo.object.position.copy(this.camera.position),this.panoVideo.updateTime(e),this.intersectMesh&&this.intersectMesh.parent&&j&&j.position.y-j.standingPosition.y>10){let e=clamp$1(this.camera.position.distanceTo(this.intersectMesh.position)*(2*Math.tan(.5*this.camera.fov/180*Math.PI))/5,.5);this.intersectMesh.scale.setScalar(e)}else this.intersectMesh.scale.setScalar(1);{let e=C.effect,{pano0:t,pano1:n}=this.modelScene.parameter;if(t&&n&&t!==n&&(e===`fly`||e===`model`)&&this.flyEffectUseDepthBuffer){if(((f=this.modelScene.parameter.pano0Depth)==null?void 0:f.panoId)!==t.panoId||((p=this.modelScene.parameter.pano1Depth)==null?void 0:p.panoId)!==n.panoId){let e=500,r=512;this.pano0DepthCubeRenderTarget?this.pano0DepthCubeRenderTarget.width!==512&&this.pano0DepthCubeRenderTarget.setSize(512,512):this.pano0DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1}),this.pano1DepthCubeRenderTarget?this.pano1DepthCubeRenderTarget.width!==512&&this.pano1DepthCubeRenderTarget.setSize(512,512):this.pano1DepthCubeRenderTarget=new three.WebGLCubeRenderTarget(512,{minFilter:three.NearestFilter,magFilter:three.NearestFilter,generateMipmaps:!1});let o=new three.CubeCamera(this.camera.near,this.camera.far,this.pano0DepthCubeRenderTarget);o.matrix.copy(t.matrix),o.matrixWorld.copy(o.matrix),o.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,o,500);let s=new three.CubeCamera(this.camera.near,this.camera.far,this.pano1DepthCubeRenderTarget);s.matrix.copy(n.matrix),s.matrixWorld.copy(s.matrix),s.matrixAutoUpdate=!1,renderDepthCube(this.renderer,this.modelScene,s,500),this.modelScene.parameter.set({pano0Depth:{panoId:t.panoId,map:this.pano0DepthCubeRenderTarget.texture,mapSize:this.pano0DepthCubeRenderTarget.width,maxDepth:500},pano1Depth:{panoId:n.panoId,map:this.pano1DepthCubeRenderTarget.texture,mapSize:this.pano1DepthCubeRenderTarget.width,maxDepth:500}})}}else this.modelScene.parameter.set({pano0Depth:null,pano1Depth:null}),this.flyEffectUseDepthBuffer||(this.pano0DepthCubeRenderTarget&&(this.pano0DepthCubeRenderTarget.dispose(),this.pano0DepthCubeRenderTarget=void 0),this.pano1DepthCubeRenderTarget&&(this.pano1DepthCubeRenderTarget.dispose(),this.pano1DepthCubeRenderTarget=void 0))}}render(){if(this.xrManager.session&&this.xrManager.session.renderState.baseLayer){let e=this.xrManager.session.renderState.baseLayer;return this.renderer.setRenderTarget(null),this.renderer.setScissorTest(!1),this.renderer.setFramebuffer(e.framebuffer),this.renderer.render(this.scene,this.xrManager.cameraVR),this.renderer.setFramebuffer(null),!0}return!1}onPanGesture(){}onTapGesture(){}onPinchGesture(){}onMouseMove(){}onMouseOut(){}panoResourceFromLocationMotionKeyframe(e){return this.panoResources[e.key]}updateControllerHelper(e,t,n){let r=this.xrControllerRay.left,o=this.xrControllerRay.right;if(!e||e.length===0)return;let s={buttons:{X:!1,Y:!1,LeftTrigger:!1,LeftPinch:!1,A:!1,B:!1,RightTrigger:!1,RightPinch:!1}};for(let c=0;c<e.length;c++){let l=e[c].handedness,u=e[c].gamepad;switch(l){case`left`:u.axes&&(this.emitHandleEvent(u.axes[2]===-1,`LeftAxesLeft`,t),this.emitHandleEvent(u.axes[2]===1,`LeftAxesRight`,t),this.emitHandleEvent(u.axes[3]===-1,`LeftAxesUp`,t),this.emitHandleEvent(u.axes[3]===1,`LeftAxesDown`,t)),u!=null&&u.buttons&&(u.buttons[4]&&this.emitHandleEvent(u.buttons[4].pressed,`X`,t),u.buttons[5]&&this.emitHandleEvent(u.buttons[5].pressed,`Y`,t),u.buttons[0]&&this.emitHandleEvent(u.buttons[0].pressed,`LeftTrigger`,t),u.buttons[1]&&this.emitHandleEvent(u.buttons[1].pressed,`LeftPinch`,t));let e={raycaster:r,axes:{up:u.axes&&u.axes[3]<0?Math.abs(u.axes[3]):0,down:u.axes&&u.axes[3]<0?0:Math.abs(u.axes[3]),left:u.axes&&u.axes[2]<0?Math.abs(u.axes[2]):0,right:u.axes&&u.axes[2]<0?0:Math.abs(u.axes[2])},deltaTime:n};s.buttons.X=u.buttons&&u.buttons[4]?u.buttons[4].pressed:!1,s.buttons.Y=u.buttons&&u.buttons[5]?u==null?void 0:u.buttons[5].pressed:!1,s.buttons.LeftTrigger=u.buttons&&u.buttons[0]?u==null?void 0:u.buttons[0].pressed:!1,s.buttons.LeftPinch=u.buttons&&u.buttons[1]?u==null?void 0:u.buttons[1].pressed:!1,s.left=e;break;case`right`:u.axes&&(this.emitHandleEvent(u.axes[2]===-1,`RightAxesLeft`,t),this.emitHandleEvent(u.axes[2]===1,`RightAxesRight`,t),this.emitHandleEvent(u.axes[3]===-1,`RightAxesUp`,t),this.emitHandleEvent(u.axes[3]===1,`RightAxesDown`,t)),u.buttons&&(u.buttons[4]&&this.emitHandleEvent(u.buttons[4].pressed,`A`,t),u.buttons[5]&&this.emitHandleEvent(u.buttons[5].pressed,`B`,t),u.buttons[0]&&this.emitHandleEvent(u.buttons[0].pressed,`RightTrigger`,t),u.buttons[1]&&this.emitHandleEvent(u.buttons[1].pressed,`RightPinch`,t)),s.right={raycaster:o,axes:{up:u.axes&&u.axes[3]<0?Math.abs(u.axes[3]):0,down:u.axes&&u.axes[3]<0?0:Math.abs(u.axes[3]),left:u.axes&&u.axes[2]<0?Math.abs(u.axes[2]):0,right:u.axes&&u.axes[2]<0?0:Math.abs(u.axes[2])},deltaTime:n},s.buttons.A=u.buttons&&u.buttons[4]?u==null?void 0:u.buttons[4].pressed:!1,s.buttons.B=u.buttons&&u.buttons[5]?u==null?void 0:u.buttons[5].pressed:!1,s.buttons.RightTrigger=u.buttons&&u.buttons[0]?u==null?void 0:u.buttons[0].pressed:!1,s.buttons.RightPinch=u.buttons&&u.buttons[1]?u==null?void 0:u.buttons[1].pressed:!1;break;default:break}}this.emit(`xr.controller.update`,createEvent(`xr.controller.update`,s))}emitHandleEvent(e,t,n){let r=this.xrControllerRay.left,o=this.xrControllerRay.right;if(e)this.xrHandleState[t].touchStart===!1?(this.xrHandleState[t].touchStartTime=n,this.xrHandleState[t].touchStart=!0,this.emit(`xr.gesture.buttonDown`,createEvent(`xr.gesture.buttonDown`,{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:t,isFinal:!1,isFirst:!0,controllers:{raycaster:{leftRay:r,rightRay:o}}}))):n-this.xrHandleState[t].touchStartTime>CONTROLLER_EVNET_DELTA_TIME&&this.emit(`xr.gesture.press`,createEvent(`xr.gesture.tap`,{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:t,isFinal:!0,isFirst:!0,controllers:{raycaster:{leftRay:r,rightRay:o}}}));else if(this.xrHandleState[t].touchStart===!0){if(this.emit(`xr.gesture.buttonUp`,createEvent(`xr.gesture.buttonUp`,{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:t,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:r,rightRay:o}}})),n-this.xrHandleState[t].touchStartTime<=CONTROLLER_EVNET_DELTA_TIME){let e=createEvent(`xr.gesture.tap`,{session:this.xrManager.session,machineType:this.xrManager.machineType,buttons:t,isFinal:!0,isFirst:!1,controllers:{raycaster:{leftRay:r,rightRay:o}}});!this.emit(`xr.gesture.tap`,e)&&!e.defaultPrevented&&t===`RightTrigger`&&this.checkSelectedPano(this.xrControllerRay.right)}this.xrHandleState[t].touchStart=!1,this.xrHandleState[t].touchStartTime=0}}initHandEvent(){if(!this.xrManager.session)throw Error(`初始化失败`);this.xrManager.session.addEventListener(`select`,e=>{this.gazeRay&&this.checkSelectedPano(this.gazeRay)})}},Controllers={Floorplan:FloorplanController,Topview:TopviewController,Panorama:PanoramaController,VRPanorama:VRPanoramaController,Model:ModelController,Mapview:MapviewController,XRPanorama:XRPanoramaController},controllersDefaultInitArgs={Floorplan:defaultFloorplanControllerCustomInitArgs,Topview:defaultTopviewControllerCustomInitArgs,Panorama:defaultPanoramaControllerCustomInitArgs,VRPanorama:defaultVRPanoramaControllerCustomInitArgs,Model:defaultModelControllerCustomInitArgs,Mapview:defaultMapviewControllerCustomInitArgs,XRPanorama:defaultXRPanoramaControllerInitArgs},PROXY_CONTROLLER_EVENT_NAMES=`gesture.pan,gesture.tap,gesture.dbltap,gesture.press,gesture.pinch,gesture.mousewheel,gesture.mousemove,gesture.momentum,gesture.fire,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`.split(`,`);function initLegacyEvent(e){e.on(`initAnimation.start`,t=>{e.emit(`initAnimationWillStart`,t.state.panoIndex,t.state,t.userAction)}),e.on(`initAnimation.end`,t=>{e.emit(`initAnimationEnded`,t.state.panoIndex,t.state,t.userAction)}),e.on(`gesture.pan`,t=>{let n=!1;n=e.emit(`wantsGesture`,`pan`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsPanGesture`,t.state,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`pan`,t.pointers,t.isFinal),e.emit(`panGesture`,t.state,t.isFinal))}),e.on(`gesture.tap`,t=>{let n=!1;n=e.emit(`wantsGesture`,`tap`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsTapGesture`,t.center.raycaster,t.center.coords,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`tap`,t.pointers,t.isFinal),e.emit(`tapGesture`,t.center.raycaster,t.center.coords,t.isFinal))}),e.on(`gesture.dbltap`,t=>{let n=!1;n=e.emit(`wantsGesture`,`dbltap`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsDblTapGesture`,t.center.raycaster,t.center.coords,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`dbltap`,t.pointers,t.isFinal),e.emit(`dblTapGesture`,t.center.raycaster,t.center.coords,t.isFinal))}),e.on(`gesture.press`,t=>{let n=!1;n=e.emit(`wantsGesture`,`press`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsPressGesture`,t.center.raycaster,t.center.coords,t.center.delta,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`press`,t.pointers,t.isFinal),e.emit(`pressGesture`,t.center.raycaster,t.center.coords,t.center.delta,t.isFinal))}),e.on(`gesture.pinch`,t=>{let n=!1;n=e.emit(`wantsGesture`,`pinch`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsPinchGesture`,t.scale,t.state.fov,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`pinch`,t.pointers,t.isFinal),e.emit(`pinchGesture`,t.scale,t.state.fov,t.isFinal))}),e.on(`gesture.mousewheel`,t=>{let n=!1;n=e.emit(`wantsGesture`,`mouseWheel`,t.pointers,t.isFinal),n&&t.preventDefault(),n=e.emit(`wantsMouseWheel`,t.center.delta,t.state.fov,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`mouseWheel`,t.pointers,t.isFinal),e.emit(`mouseWheel`,t.center.delta,t.state.fov,t.isFinal))}),e.on(`gesture.mousemove`,t=>{let n=!1;n=e.emit(`wantsGesture`,`mouseMove`,t.pointers,t.isFinal),n&&t.preventDefault(),t.defaultPrevented||(e.emit(`gesture`,`mouseMove`,t.pointers,t.isFinal),n=e.emit(`wantsChangeCameraFov`,t.state.fov),n&&t.preventDefault())}),e.on(`gesture.momentum`,t=>{let n=!1;n=e.emit(`wantsInteriaPan`,t.state),n&&t.preventDefault(),t.defaultPrevented||e.emit(`interiaPan`,t.state,t.isFinal)}),e.on(`camera.update`,t=>{e.emit(`cameraFovUpdate`,t.state.fov,t.userAction),e.emit(`cameraDirectionUpdate`,t.state,t.userAction);let n=coordinatesToVector(t.state);n.setLength(t.state.distance);let r=t.state.offset.clone().sub(n);e.emit(`cameraPositionUpdate`,r,t.userAction),e.emit(`cameraUpdate`,t.state,t.userAction)}),e.on(`intersect.update`,t=>{if(t.intersection){let n=!1;n=e.emit(`wantsShowIntersectionOnModel`,t.raycaster),n&&t.preventDefault(),t.defaultPrevented||e.emit(`intersectionOnModelUpdate`,t.intersection,t.object)}else e.emit(`intersectionHidden`)}),e.on(`pano.request`,t=>{let n=e.emit(`wantsMoveToPano`,t.state.panoIndex,t.options,t.userAction);n||(n=e.emit(`wantsToMoveToPano`,t.state.panoIndex,t.options,t.userAction)),n&&t.preventDefault(),t.defaultPrevented||e.emit(`panoWillLoad`,t.state.panoIndex)}),e.on(`pano.select`,t=>{e.emit(`panoSelected`,t.state.panoIndex)}),e.on(`pano.moveTo`,t=>{e.emit(`panoLoaded`,t.state.panoIndex),e.emit(`moveToPano`,t.state.panoIndex,t.userAction),e.emit(`panoWillArrive`,t.state.panoIndex,t.state,t.userAction)}),e.on(`pano.moving`,t=>{e.emit(`movingToPano`,t.state.panoIndex,t.prevPano.panoIndex,t.progress)}),e.on(`pano.arrived`,t=>{e.emit(`panoArrived`,t.state.panoIndex,t.state,t.userAction)}),e.on(`pano.cancel`,t=>{e.emit(`moveToPanoCanceled`,t.state.panoIndex)}),e.on(`pano.error`,t=>{e.emit(`panoLoadError`,t.error,t.state.panoIndex)}),e.on(`pano.texture.load`,t=>{e.emit(`textureStartLoad`,t.pano.panoIndex)}),e.on(`pano.texture.success`,t=>{e.emit(`textureLoaded`,t.pano.panoIndex,t.meta)}),e.on(`pano.texture.error`,t=>{e.emit(`textureError`,t.error,t.pano.panoIndex)}),e.on(`pano.texture.abort`,t=>{e.emit(`textureAbort`,t.pano.panoIndex)}),e.on(`pano.texture.progress`,t=>{e.emit(`textureLoading`,t.progress,t.pano.panoIndex)}),e.on(`xr.session.start`,t=>{e.emit(`webXRSessionStart`)}),e.on(`xr.session.end`,t=>{e.emit(`webXRSessionEnd`)}),e.on(`xr.gesture.tap`,t=>{e.emit(`webXRControllerEvent`,`tap`,t.buttons,{raycaster:t.controllers.raycaster})}),e.on(`xr.gesture.press`,t=>{e.emit(`webXRControllerEvent`,`press`,t.buttons,{raycaster:t.controllers.raycaster})}),e.on(`xr.gesture.buttonUp`,t=>{e.emit(`webXRControllerEvent`,`buttonUp`,t.buttons,{raycaster:t.controllers.raycaster})}),e.on(`xr.gesture.buttonDown`,t=>{e.emit(`webXRControllerEvent`,`buttonDown`,t.buttons,{raycaster:t.controllers.raycaster})}),e.on(`xr.controller.update`,t=>{e.emit(`webXRControllerRayUpdate`,{leftRay:t.left?t.left.raycaster:void 0,rightRay:t.right?t.right.raycaster:void 0}),t.left&&e.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&&e.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})}),e.on(`works.request`,t=>{e.emit(`willLoad`,t.input,t.works[0],e.getCurrentState())}),e.on(`works.load`,t=>{e.emit(`load`,t.input,t.works[0],e.getCurrentState())}),e.on(`works.ready`,t=>{e.emit(`loaded`,t.input,t.works[0])}),e.on(`state.change`,t=>{e.emit(`stateChange`,t.state,t.userAction)}),e.on(`currentState.change`,t=>{e.emit(`currentStateChange`,t.state,t.userAction)}),e.on(`state.set`,t=>{e.emit(`setState`,t.state)}),e.on(`state.synced`,t=>{e.emit(`stateSynced`,t.state)}),e.on(`model.request`,t=>{e.emit(`modelWillLoad`,t.work.model)}),e.on(`model.error`,t=>{e.emit(`modelLoadError`,t.error,t.model)}),e.on(`model.load`,t=>{e.emit(`modelLoaded`,t.model)}),e.on(`model.changeShownFloor`,t=>{e.emit(`modelShownFloorChange`,t.model.shownFloor,t.model.floorLength)}),e.on(`render`,t=>{e.emit(`renderFrame`,t.needsRender)}),e.on(`mode.change.request`,t=>{e.emit(`wantsChangeMode`,t.mode,t.prevMode)}),e.on(`mode.change`,t=>{e.emit(`modeChange`,t.mode,t.prevMode,t.state.panoIndex,t.state,t.userAction)}),e.on(`helpers.visible`,t=>{e.emit(`helpersVisibleChange`,t.object.visible)}),e.on(`network.resource`,t=>{e.emit(`network`,t.source,t.requestType,t.requestState,t.detail)})}function generateDefaultVideoElement(){if(typeof window<`u`){let e=document.createElement(`video`);e.loop=!0,e.autoplay=!0,e.playsInline=!0,e.muted=!0,e.crossOrigin=``;let t=()=>{document.removeEventListener(`touchstart`,t,!1),document.removeEventListener(`mousedown`,t,!1),e.muted=!1};return document.addEventListener(`touchstart`,t,!1),document.addEventListener(`mousedown`,t,!1),e}else return{}}function initLights(){let e=new three.Group;e.name=`internalLights`;{let t=new three.DirectionalLight(16777215,.1);t.name=`direction0`,t.position.copy(new three.Vector3(0,1,0)),e.add(t)}{let t=new three.DirectionalLight(16777215,.1);t.name=`direction1`,t.position.copy(new three.Vector3(-1,-1,-1)),e.add(t)}{let t=new three.DirectionalLight(16777215,.3);t.name=`direction2`,t.position.copy(new three.Vector3(1,1,1)),e.add(t)}{let t=new three.AmbientLight(16777215,.6);t.name=`ambient0`,e.add(t)}return e}function parseKeyValue(e){var t,n;let r={},o=e.split(/(\;|\,)/);for(let e of o){let o=e.split(`=`),s=(t=o[0])==null?void 0:t.trim(),c=(n=o[1])==null?void 0:n.trim();s&&c&&(r[s]=c)}return r}function getViewportScale(){var e;if(typeof document<`u`){let t=document.getElementsByTagName(`meta`);for(let n=0;n<t.length;n++){let r=t[n];if(r.getAttribute(`name`)===`viewport`){let t=parseKeyValue((e=r.getAttribute(`content`))==null?``:e),n=Number(t[`initial-scale`]);if(!isNaN(n))return n}}}return 1}var realsee_png_data_url_default=`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==`,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.BufferGeometry;geometry.setAttribute(`position`,new three.BufferAttribute(vertices,3)),geometry.setAttribute(`uv`,new three.BufferAttribute(uvs,2)),geometry.setIndex(new three.BufferAttribute(index,1));var material=new three.MeshBasicMaterial({transparent:!0,depthTest:!1,depthWrite:!1,stencilWrite:!1,fog:!1}),mesh=new three.Mesh(geometry,material);mesh.matrixAutoUpdate=!1;var scene=new three.Scene;scene.add(mesh),scene.matrixAutoUpdate=!1;var camera=new three.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.Vector4,prevScissor=new three.Vector4;function renderPoweredByRealsee(e){if(material.map){let t=e.getViewport(prevViewport),n=e.getScissor(prevScissor),r=e.getScissorTest(),o=e.autoClear,s=n.x+imageOffset[0]/3,c=n.y+imageOffset[1]/3,l=imageSize[0]/3,u=imageSize[1]/3;e.setViewport(s,c,l,u),e.setScissor(s,c,l,u),e.setScissorTest(!0),e.autoClear=!1,e.render(scene,camera),e.setViewport(t),e.setScissor(n),e.setScissorTest(r),e.autoClear=o}else{let e=new three.Texture,t=new Image;t.onload=()=>{e.image=t,e.wrapS=three.ClampToEdgeWrapping,e.wrapT=three.ClampToEdgeWrapping,e.minFilter=three.LinearFilter,e.needsUpdate=!0,e.generateMipmaps=!1,material.needsUpdate=!0,t.onload=noop},t.src=realsee_png_data_url_default,material.map=e}}var jsContent$1=`(function(){function e(e,t,n,r){function i(e){return e instanceof n?e:new n(function(t){t(e)})}return new(n||=Promise)(function(n,a){function o(e){try{c(r.next(e))}catch(e){a(e)}}function s(e){try{c(r.throw(e))}catch(e){a(e)}}function c(e){e.done?n(e.value):i(e.value).then(o,s)}c((r=r.apply(e,t||[])).next())})}async function t(e={}){var t,n=e,r=!1,i=!0,a=self.location.href;if(r||i)try{new URL(\`.\`,a).href}catch{}console.log.bind(console),console.error.bind(console);var o=!1;function s(e){for(var t=0,n=e.length,r=new Uint8Array(n),i;t<n;++t)i=e.charCodeAt(t),r[t]=~i>>8&i;return r}var c,l,u=!1;function d(){var e=M.buffer;new Int8Array(e),new Int16Array(e),n.HEAPU8=l=new Uint8Array(e),new Uint16Array(e),new Int32Array(e),n.HEAPU32=new Uint32Array(e),n.HEAPF32=new Float32Array(e),new Float64Array(e),new BigInt64Array(e),new BigUint64Array(e)}function f(){if(n.preRun)for(typeof n.preRun==\`function\`&&(n.preRun=[n.preRun]);n.preRun.length;)T(n.preRun.shift());x(w)}function p(){u=!0,I.c()}function m(){if(n.postRun)for(typeof n.postRun==\`function\`&&(n.postRun=[n.postRun]);n.postRun.length;)C(n.postRun.shift());x(S)}var h;function g(){return s(\`\\0asm\\0\\0\\0&\\\`\\\`}}\\\`}\\\`\\0\\\`\\v\\0\\\`\\0\\0\\x07aa\\0\\0\\b\\x07\\0\\0\\x07‚€€\\bA€Œ\\v\\x07b\\0c\\0\\x07d\\0e\\0f\\0\\f
2240
2240
  ™@\\x07T~@A€\\b(\\0"­ \\0­B\\x07|Bøÿÿÿƒ|"BÿÿÿÿX@ §"\\0?\\0AtM\\r \\0\\0\\r\\vA„\\bA06\\0A\\vA€\\b \\x006\\0 \\v\\0 \\0 Atr\\vr \\0¼"Aÿÿÿq!@ AvAÿq"E\\r\\0 Að\\0M@ A€€€rAñ\\0 kv!\\f\\v AK@A€ø!A\\0!\\f\\v A
2241
2241
  tA€€\\x07k!\\v  AvA€€qr A\\rvr\\vß\\v\\b@ \\0E\\r\\0 \\0A\\bk" \\0Ak(\\0"Axq"\\0j!@ Aq\\r\\0 AqE\\r  (\\0"k"A˜\\b(\\0I\\r \\0 j!\\0@@@Aœ\\b(\\0 G@ (\\f! AÿM@  (\\b"G\\rAˆ\\bAˆ\\b(\\0A~ Avwq6\\0\\f\\v (!\\x07  G@ (\\b" 6\\f  6\\b\\f\\v (" Aj ("E\\r Aj\\v!@ ! "Aj! ("\\r\\0 Aj! ("\\r\\0\\v A\\x006\\0\\f\\v ("AqAG\\rA\\b \\x006\\0  A~q6  \\0Ar6  \\x006\\0\\v  6\\f  6\\b\\f\\vA\\0!\\v \\x07E\\r\\0@ ("At"(¸
2242
2242
  F@ A¸
@@ -2322,4 +2322,4 @@ A\\0H@@@ \\0 F\\r\\0 \\x07  \\0Atj(\\0Atj" (\\0"Aj6\\0  Atj \\x
2322
2322
  At"j \\b Aj"j(\\0  \\x07j(\\0j6\\0
2323
2323
  Ak!
2324
2324
  \\f\\v\\v\\v\\0\\v\\v \\0A\\b\\v\`)}function _(e){return e}function v(e,t){var n,r=_(e);return n=new WebAssembly.Module(r),[new WebAssembly.Instance(n,t),n]}function y(){return{a:P}}function b(){function e(e,t){return I=e.exports,N(I),d(),I}var t=y();return n.instantiateWasm?new Promise((r,i)=>{n.instantiateWasm(t,(t,n)=>{r(e(t,n))})}):(h??=g(),e(v(h,t)[0]))}for(var x=e=>{for(;e.length>0;)e.shift()(n)},S=[],C=e=>S.push(e),w=[],T=e=>w.push(e),E=()=>2147483648,D=(e,t)=>Math.ceil(e/t)*t,O=e=>{var t=(e-M.buffer.byteLength+65535)/65536|0;try{return M.grow(t),d(),1}catch{}},k=e=>{var t=l.length;e>>>=0;var n=E();if(e>n)return!1;for(var r=1;r<=4;r*=2){var i=t*(1+.2/r);if(i=Math.min(i,e+100663296),O(Math.min(n,D(Math.max(e,i),65536))))return!0}return!1},A=new Uint8Array(123),j=25;j>=0;--j)A[48+j]=52+j,A[65+j]=j,A[97+j]=26+j;if(A[43]=62,A[47]=63,n.noExitRuntime&&n.noExitRuntime,n.print&&n.print,n.printErr&&n.printErr,n.wasmBinary&&n.wasmBinary,n.arguments&&n.arguments,n.thisProgram&&n.thisProgram,n.preInit)for(typeof n.preInit==\`function\`&&(n.preInit=[n.preInit]);n.preInit.length>0;)n.preInit.shift()();var M;function N(e){n._sort=e.d,n._malloc=e.e,n._free=e.f,M=e.b,e.__indirect_function_table}var P={a:k};function F(){f();function e(){n.calledRun=!0,!o&&(p(),c?.(n),n.onRuntimeInitialized?.(),m())}n.setStatus?(n.setStatus(\`Running...\`),setTimeout(()=>{setTimeout(()=>n.setStatus(\`\`),1),e()},1)):e()}var I=b();return F(),t=u?n:new Promise((e,t)=>{c=e}),t}let n;function r(){return e(this,void 0,void 0,function*(){n=yield t()})}let i,a,o,s,c,l,u,d,f,p=0,m=0,h=[],g=!0,_=!1,v=!1,y=!1,b=()=>e(void 0,void 0,void 0,function*(){if(_){v=!0;return}_=!0,v=!1,n||(yield r());let e=2**Math.ceil(Math.log2(i.vertexCount));p<e&&(p>0&&(n._free(a),n._free(s),n._free(c),n._free(l),n._free(u),n._free(d),n._free(f)),p=e,a=n._malloc(64),s=n._malloc(p*4),c=n._malloc(3*p*4),l=n._malloc(p*4),u=n._malloc(p*4),d=n._malloc(p*4),f=n._malloc(p*4)),m<i.transforms.length&&(m>0&&n._free(o),m=i.transforms.length,o=n._malloc(m*4)),_=!1,v&&(v=!1,yield b())}),x=()=>{if(_||v||!n)return;_=!0,n.HEAPF32.set(i.positions,c/4),n.HEAPF32.set(i.transforms,o/4),n.HEAPU32.set(i.transformIndices,s/4),n.HEAPF32.set(new Float32Array(h),a/4),n._sort(a,o,s,i.vertexCount,c,l,u,d,f);let e=new Uint32Array(n.HEAPU32.buffer,u,i.vertexCount),t=new Uint32Array(e.slice().buffer);self.postMessage({depthIndex:t,generation:i.generation},[t.buffer]),_=!1,g=!1},S=()=>{y||(y=!0,g&&x(),setTimeout(()=>{y=!1,S()}))};self.onmessage=e=>new Promise(t=>{if(e.data.warmup){r().finally(()=>t(!0));return}e.data.sortData&&(i={positions:new Float32Array(e.data.sortData.positions),transforms:new Float32Array(e.data.sortData.transforms),transformIndices:new Uint32Array(e.data.sortData.transformIndices),vertexCount:e.data.sortData.vertexCount,generation:e.data.sortData.generation??0},g=!0,b()),e.data.viewProj?(e.data.viewProj.every(e=>h.includes(e))===!1&&(h=e.data.viewProj,g=!0),S(),t(!0)):t(!0)})})();`,blob=typeof self<`u`&&self.Blob&&new Blob([`(self.URL || self.webkitURL).revokeObjectURL(self.location.href);`,jsContent],{type:`text/javascript;charset=utf-8`});function WorkerWrapper(e){let t;try{if(t=blob&&(self.URL||self.webkitURL).createObjectURL(blob),!t)throw``;let n=new Worker(t,{name:e==null?void 0:e.name});return n.addEventListener(`error`,()=>{(self.URL||self.webkitURL).revokeObjectURL(t)}),n}catch(t){return new Worker(`data:text/javascript;charset=utf-8,`+encodeURIComponent(jsContent),{name:e==null?void 0:e.name})}}var vertex_default=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}("}rpvv|{-uvtu}-sy|nH}rpvv|{-uvtu}-v{Hnvor-sy|n-}ynV{qr\x07H{vs|z-uvtu}-nz}yr?Q-lr\x07rH{vs|z-uvtu}-nz}yr?Q-ln{s|zH{vs|z-uvtu}-nz}yr?Q-ln{s|zV{qvprH{vs|z-uvtu}-nz}yr?Q-lyn\brV{qvprH{vs|z-uvtu}-nz}yr?Q-luar\x07rH{vs|z-rp?-luar\x07r`v rH{vs|z-v{-lzn\x07`uQrtrrH0vs-[bZlT`lPYV]]R_`-K-=----{vs|z-rp?-lyn\brPyv}}r_n{trh[bZlT`lYNfR_`jH----{vs|z-znA-lpyv}}rZnvprV{rrh[bZlT`lPYV]]R_`jH0r{qvs{vs|z-rp?-r|yv|{Hn\bv{t-rpA-P|y|Hn\bv{t-rp?-]|vv|{Hn\bv{t-rp?-bH<<参考Tnvn{`}yn@qp|{-sy|n-\0E-J-\05E;=6H<<原版的固定xr{ry`v r,不要轻易调整这个数p|{-sy|n-xr{ry?Q`v r-J-=;@Hp|{-sy|n-zn\x07`prr{`}npr`}yn`v r-J-?=AE;=H<<固定的u相关系数p|{-sy|n-`UlP>-J-=;AEEC=?B>>F=?F>FFHp|{-sy|n-`UlP?l=-J->;=F?BAEAHp|{-sy|n-`UlP?l>-J-:>;=F?BAEAHp|{-sy|n-`UlP?l?-J-=;@>B@F>CHp|{-sy|n-`UlP?l@-J-:>;=F?BAEAHp|{-sy|n-`UlP?lA-J-=;BAC?DA?Hrp?-tr`UQnnbc5v{-}ynVq\x079-v{-p|z}|{r{\\ssr9-rp?-r\x07r`v r6-\n----v{-uP|z}|{r{P|{-J-=H----vs-5lzn\x07`uQrtrr-KJ->6-uP|z}|{r{P|{-8J-FH----vs-5lzn\x07`uQrtrr-KJ-?6-uP|z}|{r{P|{-8J->BH----vs-5lzn\x07`uQrtrr-KJ-@6-uP|z}|{r{P|{-8J-?>H--------v{-}nqqrqP|z}|{r{P|{-J-uP|z}|{r{P|{H----vs-5}nqqrqP|z}|{r{P|{-2-A-.J-=6-\n--------}nqqrqP|z}|{r{P|{-J-55}nqqrqP|z}|{r{P|{-<-A6-8->6-7-AH----\f--------sy|n-yv{rnP|z}|{r{V{qr\x07-J-sy|n5}ynVq\x07-7-}nqqrqP|z}|{r{P|{-8-p|z}|{r{\\ssr6H----sy|n-r\x07ryV{qr\x07-J-yv{rnP|z}|{r{V{qr\x07-<-A;=H------sy|n-q-J-r\x07ryV{qr\x07-<-r\x07r`v r;\x07H----sy|n-\b-J-sy||5q6-<-r\x07r`v r;\bH----sy|n-\x07-J-snp5q6H----r{-rp?5\x079-\b6H\f|vq-znv{-56-\n----v{-}ynV{qr\x07b-J-v{5}ynV{qr\x07-8-=;B6H----v{-}ynV{qr\x07V-J-v{5}ynV{qr\x07b6H----rpA-pr{-J-r\x07rySrpu5lr\x07r9-vrp?55}ynV{qr\x07b-3-=\x07@ss6-II->9-}ynV{qr\x07b-KK->=69-=6H--------v{-n{s|zV{qr\x07-J-r\x07rySrpu5ln{s|zV{qvpr9-vrp?5}ynV{qr\x07b-3-=\x07@ss9-}ynV{qr\x07b-KK->=69-=6;\x07H----znA-n{s|z-J-znA5--------r\x07rySrpu5ln{s|z9-vrp?5=9-n{s|zV{qr\x0769-=69--------r\x07rySrpu5ln{s|z9-vrp?5>9-n{s|zV{qr\x0769-=69--------r\x07rySrpu5ln{s|z9-vrp?5?9-n{s|zV{qr\x0769-=69--------r\x07rySrpu5ln{s|z9-vrp?5@9-n{s|zV{qr\x0769-=6----6H----znA-n{s|zZ|qrycvrZnv\x07-J-vrZnv\x07-7-n{s|zH----rp@-}ynPr{r-J-v{Ova|Sy|n5pr{;\x07\b 6H----rpA-|yqPr{r-J-n{s|z-7-rpA5}ynPr{r9->;=6H----0vs-[bZlT`lPYV]]R_`-K-=----v{-yn\brV{qr\x07-J-v{5r\x07rySrpu5lyn\brV{qvpr9-vrp?5}ynV{qr\x07b-3-=\x07@ss9-}ynV{qr\x07b-KK->=69-=6;\x076H----vs-5yn\brV{qr\x07-KJ-=-33-yn\brV{qr\x07-I-[bZlT`lYNfR_`6-\n--------rp?-pyv}_n{tr-J-lyn\brPyv}}r_n{trhyn\brV{qr\x07jH--------v{-pyv}`n-J-v{5pyv}_n{tr;\x07-8-=;B6H--------v{-pyv}P|{-J-v{5pyv}_n{tr;\b-8-=;B6H--------v{-pyv}R{q-J-pyv}`n-8-pyv}P|{H--------s|-5v{-v-J-=H-v-I-[bZlT`lPYV]]R_`H-v886-\n----------------vs-5v-I-pyv}`n-\v\v-v-KJ-pyv}R{q6-\n--------------------p|{v{rH----------------\f----------------rpA-pyv}}r]|vv|{-J-lpyv}}rZnvprV{rrhvj-7-|yqPr{rH----------------o||y-pyv}}rq-J-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--------------------tyl]|vv|{-J-rpA5=;=9-=;=9-?;=9->;=6H--------------------r{H----------------\f--------\f----\f----0r{qvs----rpA-vrPr{r-J-n{s|zZ|qrycvrZnv\x07-7-rpA5}ynPr{r9->;=6H----rpA-pyv}Pr{r-J-}|wrpv|{Znv\x07-7-vrPr{rH----<<剔除超出视锥体的}yn----sy|n-pyv}-J->;?-7-pyv}Pr{r;H----vs-5pyv}Pr{r; -I-:pyv}Pr{r;-\v\v-pyv}Pr{r; -K-pyv}Pr{r;-\v\v---------pyv}Pr{r;\x07-I-:pyv}-\v\v-pyv}Pr{r;\x07-K-pyv}-\v\v---------pyv}Pr{r;\b-I-:pyv}-\v\v-pyv}Pr{r;\b-K-pyv}6-\n--------tyl]|vv|{-J-rpA5=;=9-=;=9-?;=9->;=6H--------r{H----\f----rp@-{qpPr{r-J-pyv}Pr{r;\x07\b -<-pyv}Pr{r;H----rp?-s|pny-J-rp?5--------}|wrpv|{Znv\x07h=jh=j-7-r|yv|{;\x07-7-=;B9--------}|wrpv|{Znv\x07h>jh>j-7-r|yv|{;\b-7-=;B----6H--------]|vv|{-J-}|vv|{;\x07\bH----<<-读取协方差数据(使用-unys?\x07>C-打包)----rpA-p|-J-r\x07rySrpu5lr\x07r9-vrp?555}ynV{qr\x07b-3-=\x07@ss6-II->6-\v->9-}ynV{qr\x07b-KK->=69-=6H----rp?->-J-{}npxUnys?\x07>C5p|;\x076H-----rp?-?-J-{}npxUnys?\x07>C5p|;\b6H------rp?-@-J-{}npxUnys?\x07>C5p|; 6H----------sy|n-Z>>-J->;\x07-<-A;=H----sy|n-Z>?-J->;\b-<-A;=H----sy|n-Z>@-J-?;\x07-<-A;=H----sy|n-Z??-J-?;\b-<-A;=H----sy|n-Z?@-J-@;\x07-<-A;=H----sy|n-Z@@-J-@;\b-<-A;=H--------zn@-cx-J-zn@5--------Z>>9-Z>?9-Z>@9--------Z>?9-Z??9-Z?@9----------Z>@9-Z?@9-Z@@-------6H----<<-判断是否是正交模式:透视时-}|wrpv|{Znv\x07h@jh@j-J-=,正交时-J->----o||y-v\\u|tn}uvp-J-}|wrpv|{Znv\x07h@jh@j-K-=;DH----sy|n-n{vznv|{]|tr-J--}|wrpv|{Znv\x07h@jh@jH----zn@-WH----vs-5v\\u|tn}uvp6-\n--------<<-正交模式的雅可比矩阵--------W-J-n{}|r5zn@5------------s|pny;\x079-=;=9-=;=9------------=;=9-s|pny;\b9-=;=9------------=;=9-=;=9-=;=--------66H----\f-ryr-\n--------<<-透视模式的雅可比矩阵--------sy|n--J->;=-<-5vrPr{r; -7-vrPr{r; 6H--------W-J-zn@5------------s|pny;\x07-<-vrPr{r; 9-=;=9-:5s|pny;\x07-7-vrPr{r;\x076-7-9------------=;=9-s|pny;\b-<-vrPr{r; 9-:5s|pny;\b-7-vrPr{r;\b6-7-9------------=;=9-=;=9-=;=--------6H----\f----zn@-d-J-n{}|r5zn@5n{s|zZ|qrycvrZnv\x0766H----zn@-a-J-d-7-WH----<<-将-@Q-协方差矩阵变换为-?Q-协方差矩阵----zn@-p|?Qz-J-n{}|r5a6-7-cx-7-aH----p|?Qzh=jh=j-8J-xr{ry?Q`v rH----p|?Qzh>jh>j-8J-xr{ry?Q`v rH----rp@-p|?Q-J-rp@5p|?Qzh=jh=j9-p|?Qzh=jh>j9-p|?Qzh>jh>j6H----sy|n-n-J-p|?Q;\x07H----sy|n-q-J-p|?Q; H----sy|n-o-J-p|?Q;\bH----sy|n-Q-J-n-7-q-:-o-7-oH----sy|n-npr-J-n-8-qH----sy|n-npr\\r?-J-=;B-7-nprH----sy|n-rz?-J-\05zn\x075=;>9-npr\\r?-7-npr\\r?-:-Q66H----sy|n-rvtr{cnyr>-J-npr\\r?-8-rz?H----sy|n-rvtr{cnyr?-J-npr\\r?-:-rz?H----vs-5rvtr{cnyr?-IJ-=;=6-\n--------r{H----\f----rp?-rvtr{crp|>-J-{|znyv r5rp?5o9-rvtr{cnyr>-:-n66H----rp?-rvtr{crp|?-J-rp?5rvtr{crp|>;\b9-:rvtr{crp|>;\x076H----rp?-onvcrp|>-J-rvtr{crp|>--7-zv{5\0E-7-\05rvtr{cnyr>69-zn\x07`prr{`}npr`}yn`v r6H----rp?-onvcrp|?-J-rvtr{crp|?--7-zv{5\0E-7-\05rvtr{cnyr?69-zn\x07`prr{`}npr`}yn`v r6H----rp?-onvcvr}|-J-rp?5>;=-<-r|yv|{;\x079->;=-<-r|yv|{;\b6H----rp?-{qp\\ssr-J-rp?5]|vv|{;\x07-7-onvcrp|>-8-]|vv|{;\b-7-onvcrp|?6-7---------------------onvcvr}|-7-?;=H----rpA-\0nq]|-J-rpA5{qpPr{r;\x07\b-8-{qp\\ssr9-{qpPr{r; 9->;=6H----tyl]|vv|{-J-\0nq]|H----<<-读取颜色----rpA-p|y|-J-rpA5--------5p|;6-3-=\x07ss9--------5p|;-KK-E6-3-=\x07ss9--------5p|;-KK->C6-3-=\x07ss9--------5p|;-KK-?A6-3-=\x07ss----6-<-?BB;=H----<<应用球谐光照,目前只兼容=>?----vs-5lzn\x07`uQrtrr-KJ->6-\n--------rp@-pnzrn]|V{\\owrp-J-rp@5v{rr5n{s|z6-7-rpA5pnzrn]|vv|{9->;=66H--------rp@-|owrpcvrQv-J-{|znyv r5}ynPr{r-:-pnzrn]|V{\\owrp6H----------------rpA-u=>?@-J-r\x07r5luar\x07r9-tr`UQnnbc5}ynV{qr\x07V9-=9-luar\x07r`v r66H----------rpA-uABCD-J-r\x07r5luar\x07r9-tr`UQnnbc5}ynV{qr\x07V9-A9-luar\x07r`v r66H----------rpA-uEF>=>>-J-r\x07r5luar\x07r9-tr`UQnnbc5}ynV{qr\x07V9-E9-luar\x07r`v r66H-----------------rp@-u>-J-u=>?@;toH-----------------------------------rp@-u?-J-rp@5u=>?@;n9-uABCD;t6H---------------------rp@-u@-J-rp@5uABCD;on9-uEF>=>>;6H-----------------------------sy|n-\x07-J-|owrpcvrQv;\x07H--------sy|n-\b-J-|owrpcvrQv;\bH--------sy|n- -J-|owrpcvrQv; H--------rp@-uP|y|-J-u>-7-5:=;AEEC=?B-7-\b6-8-u?-7-5=;AEEC=?B-7- 6-8-u@-7-5:=;AEEC=?B-7-\x076H--------p|y|;to-8J-uP|y|H----------------vs-5lzn\x07`uQrtrr-KJ-?6-\n----------------------rpA-u>?>@>A>B-J-r\x07r5luar\x07r9-tr`UQnnbc5}ynV{qr\x07V9->?9-luar\x07r`v r66H------------rpA-u>C>D>E>F-J-r\x07r5luar\x07r9-tr`UQnnbc5}ynV{qr\x07V9->C9-luar\x07r`v r66H-------------rpA-u?=?>???@-J-r\x07r5luar\x07r9-tr`UQnnbc5}ynV{qr\x07V9-?=9-luar\x07r`v r66H-------------------------rp@-uA-J-uEF>=>>;tonH------------------------------------rp@-uB-J-u>?>@>A>B;toH----------------------------------rp@-uC-J-rp@5u>?>@>A>B;n9-u>C>D>E>F;t6H---------------rp@-uD-J-rp@5u>C>D>E>F;on9-u?=?>???@;6H---------------rp@-uElqrt?-J-u?=?>???@;tonH-----------------------------------------sy|n-\x07\x07-J-\x07-7-\x07H------------sy|n-\b\b-J-\b-7-\bH------------sy|n- -J- -7- H------------sy|n-\x07\b-J-\x07-7-\bH------------sy|n-\b -J-\b-7- H------------sy|n-\x07 -J-\x07-7- H------------------------p|y|;to-8J----------------5`UlP?l=-7-\x07\b6-7-uA-8----------------5`UlP?l>-7-\b 6-7-uB-8----------------5`UlP?l?-7-5?;=-7- -:-\x07\x07-:-\b\b66-7-uC-8----------------5`UlP?l@-7-\x07 6-7-uD-8----------------5`UlP?lA-7-5\x07\x07-:-\b\b66-7-uElqrt?H--------\f----\f--------p|y|;to-J-pynz}5p|y|;to9-rp@5=;=69-rp@5>;=66H----P|y|-J-p|y|H----]|vv|{-7J-\0EH----b-J-}|vv|{;\x07\bH\f"),fragment_default=function(...e){let t=113,n=126,r=0,o=``;return e[0].split(``).map(e=>e.charCodeAt(0)>126?e:String.fromCharCode((e.charCodeAt(0)+113)%126)).join(``)}(`}rpvv|{-uvtu}-sy|nH0v{pyqr-Ip|zz|{Kn\bv{t-rpA-P|y|Hn\bv{t-rp?-]|vv|{Hn\bv{t-rp?-bH|vq-znv{-56-
2325
- ----<<-计算从-}yn-中心到当前片段的平方距离----<<-由于-]|vv|{-已经按-\05E6-缩放,平方结果会被缩放-E-倍----<<-如果平方结果大于-E,说明在椭圆外,距离均值超过-\05E6-个标准差----sy|n-N-J-q|5]|vv|{9-]|vv|{6H----vs-5N-K-E;=6-qvpnqH--------rp@-p|y|-J-P|y|;toH--------<<-由于渲染的-}yn-按-\05E6-缩放,高斯公式中的逆协方差矩阵部分变成单位矩阵----<<-因此只剩下-5e-:-zrn{6-7-5e-:-zrn{6,而-zrn{-为零,所以是-e-7-e,即-N----sy|n-|}npv\b-J-r\x07}5:=;B-7-N6-7-P|y|;nH--------tylSntP|y|-J-rpA5p|y|;to9-|}npv\b6H\f`),PBMGaussianSplattingRenderMesh=class extends three.Mesh{constructor(){super(),this.renderData=null,this.needsRender=!1,this.sortWorker=null,this.depthIndex=new Uint32Array,this.splatIndexCapacity=0,this.activeSlot=null,this.pendingSlot=null,this.rebuildGeneration=0,this.forceClipperUniformRefresh=!1,this.incrementalUpdateInFlight=!1,this.dataTexture=null,this.transformsTexture=null,this.transformIndicesTexture=null,this.layerIndicesTexture=null,this.shTexture=null,this.usedSHDegree=0,this.onBeforeRender=(e,t,n)=>{let r=n,o=this.collectObjects(t);if(o.length===0){this.geometry.instanceCount=0;return}let s=0;o.forEach(e=>{e.usedSHDegree>s&&(s=e.usedSHDegree)}),this.setMaxShDegree(s),this.isSceneNeedsRebuild(o)&&(this.tryStartIncrementalUpdate(o)||(this.startPendingRebuild(o),this.gsSceneState.lastClipperHash=``));let c=o.filter(e=>e.transformChanged);c.length>0&&(this.syncTransformsForSlot(this.activeSlot,c),this.syncTransformsForSlot(this.pendingSlot,c),c.forEach(e=>{e.transformChanged=!1,e.selectedChanged=!1})),this.activeSlot&&this.updateSlotTextures(this.activeSlot),this.pendingSlot&&this.updateSlotTextures(this.pendingSlot);let l=new three.Matrix4().multiplyMatrices(r.perspectiveProjectionMatrix,r.matrixWorldInverse).elements;this.pendingSlot&&this.pendingSlot.renderData.initialBuildComplete&&this.pendingSlot.awaitingFirstSort?this.requestSort(this.pendingSlot,l):this.activeSlot&&this.requestSort(this.activeSlot,l);let u=this.getClipperHash(o);if((this.forceClipperUniformRefresh||u!==this.gsSceneState.lastClipperHash)&&(this.updateClipperUniforms(o),this.gsSceneState.lastClipperHash=u,this.forceClipperUniformRefresh=!1,this.needsRender=!0),this.activeSlot){let e=Math.min(this.usedSHDegree,this.activeSlot.renderData.maxShDegree);this.material.uniforms.u_maxShDegree.value=e,e>0&&!this.activeSlot.textures.shTexture?this.createSHTexture(this.activeSlot):e===0&&this.activeSlot.textures.shTexture&&(this.activeSlot.textures.shTexture.dispose(),this.activeSlot.textures.shTexture=null),this.material.uniforms.u_shTexture.value=this.activeSlot.textures.shTexture,this.renderData=this.activeSlot.renderData}else this.pendingSlot||(this.bindSlotTextures(null),this.material.uniforms.u_maxShDegree.value=0,this.geometry.instanceCount=0);this.material.uniforms.resolution.value.set(r.resolution.x,r.resolution.y)};let e=this.createGeometry(),t=this.createMaterial();this.geometry=e,this.material=t,this.frustumCulled=!1,this.renderOrder=-99999999999,this.gsSceneState={lastObjectsHash:``,lastClipperHash:``},this.sortWorker=new WorkerWrapper,this.sortWorker.postMessage({warmup:!0}),RenderData.warmupWasm(),this.sortWorker.onmessage=e=>{if(e.data.depthIndex){let t=e.data.generation;if(this.pendingSlot&&t===this.pendingSlot.generation){this.pendingSlot.awaitingFirstSort=!1,this.swapPendingToActive(e.data.depthIndex);return}this.activeSlot&&t===this.activeSlot.generation&&(this.activeSlot.awaitingFirstSort=!1,this.applyDepthIndex(e.data.depthIndex))}}}ensureSplatIndexCapacity(e){let t=this.geometry.getAttribute(`splatIndex`);if(e<=this.splatIndexCapacity)return t;let n=this.getExpandedCapacity(e),r=t.array,o=new Float32Array(n);o.set(r.subarray(0,Math.min(r.length,n)));let s=new three.InstancedBufferAttribute(o,1,!1,1);return s.setUsage(three.DynamicDrawUsage),this.geometry.setAttribute(`splatIndex`,s),this.splatIndexCapacity=n,this.geometry._maxInstanceCount=n,s}getExpandedCapacity(e){let t=Math.max(this.splatIndexCapacity,1);for(;t<e;)t*=2;return t}createGeometry(){let e=new three.InstancedBufferGeometry,t=new Float32Array([-1,-1,0,1,-1,0,1,1,0,-1,1,0]);e.setAttribute(`position`,new three.BufferAttribute(t,3));let n=new Uint16Array([0,1,2,0,2,3]);e.setIndex(new three.BufferAttribute(n,1)),this.splatIndexCapacity=1;let r=new Float32Array(this.splatIndexCapacity);for(let e=0;e<r.length;e++)r[e]=e;let o=new three.InstancedBufferAttribute(r,1,!1,1);return o.setUsage(three.DynamicDrawUsage),e.setAttribute(`splatIndex`,o),e._maxInstanceCount=this.splatIndexCapacity,e.instanceCount=0,e}createMaterial(){return new three.ShaderMaterial({vertexShader:vertex_default,fragmentShader:fragment_default,defines:{NUM_GS_LAYERS:0,NUM_GS_CLIPPERS:0},uniforms:{u_texture:{value:null},u_transforms:{value:null},u_transformIndices:{value:null},u_layerIndices:{value:null},u_numGsLayers:{value:0},u_numGsClippers:{value:0},u_layerClipperRanges:{value:[]},u_clipperMatricesInverse:{value:[]},u_shTexture:{value:null},u_shTextureSize:{value:new three.Vector2},u_maxShDegree:{value:0},resolution:{value:new three.Vector2}},side:three.DoubleSide,transparent:!0,blending:three.NormalBlending,depthTest:!0,depthWrite:!1})}createDefaultLayerClipperRanges(e){return Array.from({length:e},()=>new three.Vector2(-1,0))}createDefaultClipperMatrices(e){return Array.from({length:e},()=>new three.Matrix4)}createTextures(e){let t=new three.DataTexture(e.data,e.width,e.height,three.RGBAIntegerFormat,three.UnsignedIntType);t.internalFormat=`RGBA32UI`,t.minFilter=three.NearestFilter,t.magFilter=three.NearestFilter,t.needsUpdate=!0;let n=new three.DataTexture(e.transforms,e.transformsWidth,e.transformsHeight,three.RGBAFormat,three.FloatType);n.internalFormat=`RGBA32F`,n.minFilter=three.NearestFilter,n.magFilter=three.NearestFilter,n.needsUpdate=!0;let r=new three.DataTexture(e.transformIndices,e.transformIndicesWidth,e.transformIndicesHeight,three.RedIntegerFormat,three.UnsignedIntType);r.internalFormat=`R32UI`,r.minFilter=three.NearestFilter,r.magFilter=three.NearestFilter,r.needsUpdate=!0;let o=new three.DataTexture(e.layerIndices,e.layerIndicesWidth,e.layerIndicesHeight,three.RedIntegerFormat,three.UnsignedIntType);return o.internalFormat=`R32UI`,o.minFilter=three.NearestFilter,o.magFilter=three.NearestFilter,o.needsUpdate=!0,{dataTexture:t,transformsTexture:n,transformIndicesTexture:r,layerIndicesTexture:o,shTexture:null}}createSHTexture(e){let{renderData:t,textures:n}=e;n.shTexture&&(n.shTexture.dispose(),n.shTexture=null);let r=Math.min(this.usedSHDegree,t.maxShDegree),o=0;if(r>=1&&(o+=9),r>=2&&(o+=15),r>=3&&(o+=21),o===0)return;let s=4,c=o;c%4!=0&&(c=Math.ceil(c/4)*4);let l=t.numPoints*c/4,u=2048,d=Math.ceil(l/u),f=new Float32Array(u*d*4);for(let e=0;e<t.numPoints;e++){let n=c/4*e,o=0;if(t.sh1&&r>=1)for(let r=0;r<9;r++){let s=n+Math.floor(o/4),c=o%4,l=s*4+c;f[l]=t.sh1[e*9+r],o++}if(t.sh2&&r>=2)for(let r=0;r<15;r++){let s=n+Math.floor(o/4),c=o%4,l=s*4+c;f[l]=t.sh2[e*15+r],o++}if(t.sh3&&r>=3)for(let r=0;r<21;r++){let s=n+Math.floor(o/4),c=o%4,l=s*4+c;f[l]=t.sh3[e*21+r],o++}}n.shTexture=new three.DataTexture(f,u,d,three.RGBAFormat,three.FloatType),n.shTexture.internalFormat=`RGBA32F`,n.shTexture.minFilter=three.NearestFilter,n.shTexture.magFilter=three.NearestFilter,n.shTexture.needsUpdate=!0,this.material.uniforms.u_shTextureSize.value.set(u,d),this.material.uniforms.u_maxShDegree.value=r}setMaxShDegree(e){var t,n;if(e<0||e>2){console.warn(`现在只支持012三种阶数,你输入的是${e}`);return}let r=this.usedSHDegree;this.usedSHDegree=e,r!==e&&((t=this.activeSlot)!=null&&t.textures.shTexture&&(this.activeSlot.textures.shTexture.dispose(),this.activeSlot.textures.shTexture=null),(n=this.pendingSlot)!=null&&n.textures.shTexture&&(this.pendingSlot.textures.shTexture.dispose(),this.pendingSlot.textures.shTexture=null),this.material.uniforms.u_maxShDegree.value=e,e===0?this.material.uniforms.u_shTexture.value=null:this.activeSlot&&this.activeSlot.renderData.maxShDegree>0&&(this.createSHTexture(this.activeSlot),this.material.uniforms.u_shTexture.value=this.activeSlot.textures.shTexture))}bindSlotTextures(e){if(!e){this.dataTexture=null,this.transformsTexture=null,this.transformIndicesTexture=null,this.layerIndicesTexture=null,this.shTexture=null,this.material.uniforms.u_texture.value=null,this.material.uniforms.u_transforms.value=null,this.material.uniforms.u_transformIndices.value=null,this.material.uniforms.u_layerIndices.value=null,this.material.uniforms.u_shTexture.value=null;return}this.dataTexture=e.textures.dataTexture,this.transformsTexture=e.textures.transformsTexture,this.transformIndicesTexture=e.textures.transformIndicesTexture,this.layerIndicesTexture=e.textures.layerIndicesTexture,this.shTexture=e.textures.shTexture,this.material.uniforms.u_texture.value=this.dataTexture,this.material.uniforms.u_transforms.value=this.transformsTexture,this.material.uniforms.u_transformIndices.value=this.transformIndicesTexture,this.material.uniforms.u_layerIndices.value=this.layerIndicesTexture,this.material.uniforms.u_shTexture.value=this.shTexture}disposeSlot(e){e&&(e.renderData.dispose(),this.disposeTextures(e.textures))}disposeTextures(e){e.dataTexture.dispose(),e.transformsTexture.dispose(),e.transformIndicesTexture.dispose(),e.layerIndicesTexture.dispose(),e.shTexture&&(e.shTexture.dispose(),e.shTexture=null)}applyDepthIndex(e){this.depthIndex=e;let t=this.depthIndex.length,n=this.ensureSplatIndexCapacity(t);n.array.set(this.depthIndex,0),n.count=this.depthIndex.length,n.updateRange.offset=0,n.updateRange.count=t,n.needsUpdate=!0,this.geometry.instanceCount=this.depthIndex.length,this.needsRender=!0}swapPendingToActive(e){if(!this.pendingSlot)return;let t=this.activeSlot;this.activeSlot=this.pendingSlot,this.pendingSlot=null,this.renderData=this.activeSlot.renderData,this.ensureSplatIndexCapacity(this.activeSlot.renderData.numPoints),this.bindSlotTextures(this.activeSlot),this.activeSlot.sortDataUploaded=!0,this.forceClipperUniformRefresh=!0,this.applyDepthIndex(e),t&&this.disposeSlot(t)}createSlot(e){let t={generation:e.generation,renderData:e,textures:this.createTextures(e),awaitingFirstSort:!0,sortDataUploaded:!1};return this.usedSHDegree>0&&e.maxShDegree>0&&this.createSHTexture(t),t}updateSlotTextures(e){e.renderData.dataChanged&&(e.textures.dataTexture.needsUpdate=!0,e.renderData.dataChanged=!1),e.renderData.transformsChanged&&(e.textures.transformsTexture.needsUpdate=!0,e.textures.transformIndicesTexture.needsUpdate=!0,e.renderData.transformsChanged=!1)}postSortData(e){var t;let n=new Float32Array(e.renderData.positions.slice().buffer),r=new Float32Array(e.renderData.transforms.slice().buffer),o=new Uint32Array(e.renderData.transformIndices.slice().buffer);(t=this.sortWorker)==null||t.postMessage({sortData:{positions:n,transforms:r,transformIndices:o,vertexCount:e.renderData.numPoints,generation:e.generation}},[n.buffer,r.buffer,o.buffer]),e.sortDataUploaded=!0}requestSort(e,t){var n;e.renderData.initialBuildComplete&&((e.renderData.dataChanged||e.renderData.transformsChanged||!e.sortDataUploaded)&&this.postSortData(e),(n=this.sortWorker)==null||n.postMessage({viewProj:t}))}syncTransformsForSlot(e,t){e&&t.forEach(t=>{e.renderData.splatIndices.has(t)&&e.renderData.updateTransform(t)})}collectObjects(e){let t=[];return e.traverse(e=>{e instanceof PBMGaussianSplattingObject&&e.visible&&t.push(e)}),t.sort((e,t)=>{let n=e.uuid+e.gsViewLayerKey,r=t.uuid+t.gsViewLayerKey;return n<r?-1:n>r?1:0}),t}isSceneNeedsRebuild(e){let t=e.map(e=>`${e.uuid}:${e.gsViewLayerKey}`).join(`|`),n=t!==this.gsSceneState.lastObjectsHash;return this.gsSceneState.lastObjectsHash=t,n}getClipperHash(e){return e.map(e=>{let t=e.gsClippers.map(e=>{var t;return`${(t=e.floorIndex)==null?-1:t}:${e.clippingBoxMatrix.elements.join(`,`)}`}).join(`;`);return`${e.gsViewLayerKey}:${t}`}).join(`|`)}updateClipperCounts(e,t){let n=Math.max(0,e|0),r=Math.max(0,t|0),o=this.material.defines;(o.NUM_GS_LAYERS!==n||o.NUM_GS_CLIPPERS!==r)&&(o.NUM_GS_LAYERS=n,o.NUM_GS_CLIPPERS=r,this.material.needsUpdate=!0),this.material.uniforms.u_numGsLayers.value=e,this.material.uniforms.u_numGsClippers.value=t}updateClipperUniforms(e){var t,n,r,o;let s=(n=(t=this.activeSlot)==null?void 0:t.renderData)==null?null:n;if(!s){this.material.uniforms.u_layerClipperRanges.value=[],this.material.uniforms.u_clipperMatricesInverse.value=[],this.updateClipperCounts(0,0);return}let c=new Map;for(let t of e)c.has(t.gsViewLayerKey)||c.set(t.gsViewLayerKey,t.gsClippers);let l=s.layerKeys.length,u=0;for(let e of s.layerKeys)u+=((r=c.get(e))==null?[]:r).length;let d=this.createDefaultLayerClipperRanges(l),f=this.createDefaultClipperMatrices(u),p=0;for(let e of s.layerKeys){let t=s.layerKeyToIndex.get(e);if(t===void 0)continue;let n=(o=c.get(e))==null?[]:o,r=p,l=0;for(let e of n)f[p].getInverse(e.clippingBoxMatrix),p++,l++;l>0&&d[t].set(r,l)}this.material.uniforms.u_layerClipperRanges.value=d,this.material.uniforms.u_clipperMatricesInverse.value=f,this.updateClipperCounts(l,p)}startPendingRebuild(e){this.pendingSlot&&(this.disposeSlot(this.pendingSlot),this.pendingSlot=null),this.rebuildGeneration+=1;let t=new RenderData(e,this.rebuildGeneration);this.pendingSlot=this.createSlot(t)}tryStartIncrementalUpdate(e){if(!this.activeSlot||this.pendingSlot||this.incrementalUpdateInFlight)return!1;let t=this.activeSlot.renderData.getObjectsInOrder();if(!this.activeSlot.renderData.canIncrementalAppend(e))return!1;let n=e.slice(t.length);if(n.length===0)return!1;this.incrementalUpdateInFlight=!0;let r=this.activeSlot;return r.renderData.appendObjects(n).then(e=>{if(!e||this.activeSlot!==r||r.renderData.disposed)return;let t=r.textures;r.textures=this.createTextures(r.renderData),this.usedSHDegree>0&&r.renderData.maxShDegree>0&&this.createSHTexture(r),this.bindSlotTextures(r),this.ensureSplatIndexCapacity(r.renderData.numPoints),r.sortDataUploaded=!1,r.awaitingFirstSort=!0,this.disposeTextures(t),this.forceClipperUniformRefresh=!0,this.gsSceneState.lastClipperHash=``,this.needsRender=!0}).catch(e=>{console.warn(`Incremental append failed, fallback to rebuild:`,e)}).finally(()=>{this.incrementalUpdateInFlight=!1}),!0}dispose(){this.disposeSlot(this.pendingSlot),this.pendingSlot=null,this.disposeSlot(this.activeSlot),this.activeSlot=null,this.renderData=null,this.sortWorker&&this.sortWorker.terminate(),this.bindSlotTextures(null),this.geometry.dispose(),this.material.dispose()}},PBMGaussianSplattingTestMesh=class extends three.Mesh{constructor(){super(),this.onBeforeRender=(e,t,n)=>{this.collectObjects(t).length>0&&console.warn(`未开启webgl2, 3dgs仅支持在开启webgl2模式后使用`)}}collectObjects(e){let t=[];return e.traverse(e=>{e instanceof PBMGaussianSplattingObject&&e.visible&&t.push(e)}),t}},DEFAULT_MODE_CHANGE_DURATION=1e3,DEFAULT_CAMERA_FOV=90,DEFAULT_REQUEST_PROXY=e=>e.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/`),scratchSphere=new three.Sphere,scratchBox3=new three.Box3,scratchViewport=new three.Vector4,scratchScissor=new three.Vector4,scratchClearColor=new three.Color,scratchRenderSize=new three.Vector2,worksMap=new WeakMap,emptyWorks=createWorks([parseWork(null)]),Five_Instances={},Five=class e extends Subscribe{static get version(){return`6.8.0-alpha.22`}static get dracoPath(){return draco.decoderPath}static set dracoPath(e){draco.setDecoderPath(e)}static get ktx2Path(){return ktx2.transcoderPath}static set ktx2Path(e){ktx2.setTranscoderPath(e)}static get useNativeImageBitmap(){return canUseNativeImageBitmap()}static set useNativeImageBitmap(e){useNativeImageBitmap(e)}constructor(e={}){var t,n,r,o,s,c,l,u,d,f,p;if(super(),this.pbmGaussianSplattingRenderMesh=null,this.fiveId=createUuid(),Five_Instances[this.fiveId]=this,this.currentUpdateArgs={time:now(),args:[]},this.currentMode=`Panorama`,this.pano={workCode:``,panoIndex:0},this.needsRender=!1,this.onlyRenderIfNeeds=(t=e.onlyRenderIfNeeds)==null?!0:t,this.imageOptions=Object.assign({},(n=e.imageOptions)==null?{}:n),this.textureOptions=Object.assign({},(r=e.textureOptions)==null?{}:r),this.poweredByRealsee=(o=e.poweredByRealsee)==null?!0:o,this.backgroundColor=new three.Color((s=e.backgroundColor)==null?1579548:s),this.backgroundAlpha=(c=e.backgroundAlpha)==null?1:c,this.extraElements=[],this.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),VRPanorama:Object.assign({},e.vrPanorama),XRPanorama:Object.assign({},e.xrPanorama)},this.fps={testCount:0,testTime:now()},this.modeChangeDuration=(l=e.modeChangeDuration)==null?DEFAULT_MODE_CHANGE_DURATION:l,this.enableWheel=(u=e.enableWheel)==null?!0:u,typeof window<`u`)if(`renderer`in e)e.renderer instanceof InternalWebGLRenderer&&this.throwError(Error(`cannot render a internal renderer`)),this.renderer=e.renderer;else try{this.renderer=new InternalWebGLRenderer({preserveDrawingBuffer:e.preserveDrawingBuffer,antialias:e.antialias,webgl2:e.webgl2,logarithmicDepthBuffer:e.logarithmicDepthBuffer,precision:e.precision,powerPreference:e.powerPreference});let t=getViewportScale();this.renderer.setPixelRatio(t===1?window.devicePixelRatio:1),this.renderer.setSize(512,512),this.renderer.setClearColor(this.backgroundColor,this.backgroundAlpha)}catch(e){let t=e instanceof Error?e:Error(String(e));this.throwError(t)}this.getPixelsRenderTarget=new three.WebGLRenderTarget(1,1,{encoding:(f=(d=this.renderer)==null?void 0:d.outputEncoding)==null?three.sRGBEncoding:f,generateMipmaps:!1}),this.viewport=Object.assign({left:0,bottom:0,width:1,height:1},e.viewport),this.camera=new Camera(DEFAULT_CAMERA_FOV),this.scene=new Scene,this.xrCustomObjectsScene=new three.Scene,this.scene.add(this.xrCustomObjectsScene),this.scene.matrixAutoUpdate=!1,this.loadWorkTask=Promise.resolve(),this.requestProxy=(p=e.requestProxy)==null?DEFAULT_REQUEST_PROXY:p,this.networkSubscribe=new NetworkSubscribe,this.networkSubscribe.on(`network`,(e,t,n,r)=>{var o;this.emit(`network.resource`,createEvent(`network.resource`,{source:e,requestType:t,requestState:n,detail:r})),(o=this.analysis)==null||o.network(this.works,e,t,n,r)}),this.readyCallbacks=[],this.syncingState=!1,this.helperGroup=new three.Group,this.helperGroup.name=`helper`,this.helperGroup.matrixAutoUpdate=!1,this.scene.add(this.helperGroup),worksMap.set(this,emptyWorks),this.modelScene=new ModelScene({fiveId:this.fiveId}),this.modelScene.addEventListener(`model.create`,e=>{this.bindModel(e.model)}),this.scene.add(this.modelScene);let[m]=this.modelScene.setModels(emptyWorks,{forceReplaceImmediately:!0});defineProperty(m,`loaded`,{get(){return!1},set(e){}}),this.videoTexture=new three.VideoTexture(e.videoInstance||generateDefaultVideoElement());let h=initLights();this.scene.add(h),this.state={mode:this.currentMode,workCode:this.pano.workCode,panoIndex:this.pano.panoIndex,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance},this.stateSynced=!1,this.destroyed=!1,this.paused=!0,typeof window<`u`&&(e.play!==!1&&this.play(),this.stopAnimationLoop=AnimationFrameLoop.shared.add((e,t,...n)=>{this.updateTime(e,t,...n)},!1,0,10));let g=()=>{typeof document<`u`&&document.fullscreenElement===null&&this.currentMode===`VRPanorama`&&this.controller.emit(`vr.requestExit`,createEvent(`vr.requestExit`,{}))},_=()=>{this.needsRender=!0};if(typeof document<`u`&&document.addEventListener(`fullscreenchange`,g,!1),this.renderer&&this.renderer.domElement.addEventListener(`webglcontextrestored`,_,!1),this.removeEventListeners=()=>{typeof document<`u`&&document.removeEventListener(`fullscreenchange`,g,!1),this.renderer&&this.renderer.domElement.removeEventListener(`webglcontextrestored`,_,!1)},this.plugins={},e.plugins&&e.plugins.length){for(let t of e.plugins)if(typeof t==`function`)t(this);else if(Array.isArray(t)){let[e,n,r]=t;if(typeof e==`function`){let t=e(this,r);typeof n==`string`&&(this.plugins[n]?this.throwError(Error(`plugin name ${n} is exists.`)):this.plugins[n]=t)}}}initLegacyEvent(this),this.fiveRenderer=new FiveRenderer,this.adaptiveLuminancePass=new AdaptiveLuminancePass,this.adaptiveLuminancePass.enabled=!1,this.fiveRenderer.composer.addPass(this.adaptiveLuminancePass),this.eyeDomeLightingPass=new EyeDomeLightingPass(this.camera),this.eyeDomeLightingPass.enabled=!1,this.fiveRenderer.composer.addPass(this.eyeDomeLightingPass),e.webgl2?(this.pbmGaussianSplattingRenderMesh=new PBMGaussianSplattingRenderMesh,this.scene.add(this.pbmGaussianSplattingRenderMesh)):this.scene.add(new PBMGaussianSplattingTestMesh)}get ident(){return this.fiveId}get panoIndex(){return this.pano.panoIndex}get panoId(){return panoStringify(this.pano)}dispose(){var e;if(this.destroyed===!0)return;delete Five_Instances[this.fiveId],this.emit(`dispose`),this.destroyed=!0,this.pause(),this.stopAnimationLoop&&(this.stopAnimationLoop(),this.stopAnimationLoop=void 0),this.off(),this.networkSubscribe.off(),this.controller&&(this.controller.destroy(),this.controller=void 0);let t=this.getElement();t&&t.parentNode&&t.parentNode.removeChild(t);let n=this.modelScene.parameter;n.pano0&&n.pano0.map.dispose(),n.pano1&&n.pano1.map!==((e=n.pano0)==null?void 0:e.map)&&n.pano1.map.dispose(),n.reset(`pano0`,`pano1`),this.modelScene.dispose(),this.scene.dispose(),this.xrCustomObjectsScene.dispose(),worksMap.set(this,emptyWorks),this.renderer&&this.renderer.render(new three.Scene,new three.Camera),this.fiveRenderer.dispose(),this.renderer instanceof InternalWebGLRenderer&&(this.renderer.forceContextLoss&&this.renderer.forceContextLoss(),this.renderer.dispose())}setViewport(e){Object.assign(this.viewport,e),this.needsRender=!0}get boundingMesh(){return this.modelScene.boundingMesh}get helperVisible(){return this.helperGroup.visible}set helperVisible(e){this.helperGroup.visible!==e&&(this.helperGroup.visible=e,this.emit(`helpers.visible`,createEvent(`helpers.visible`,{object:this.helperGroup})),this.needsRender=!0)}updateConfiguration(e,t=!0){let n=!1,r=!1;e.panorama&&(Object.assign(this.controllerInits.Panorama,omitUndefinedFields(e.panorama)),this.currentMode===`Panorama`&&(n=!0)),e.model&&(Object.assign(this.controllerInits.Model,omitUndefinedFields(e.model)),this.currentMode===`Model`&&(n=!0)),e.floorplan&&(Object.assign(this.controllerInits.Floorplan,omitUndefinedFields(e.floorplan)),this.currentMode===`Floorplan`&&(n=!0)),e.topview&&(Object.assign(this.controllerInits.Topview,omitUndefinedFields(e.topview)),this.currentMode===`Topview`&&(n=!0)),e.mapview&&(Object.assign(this.controllerInits.Mapview,omitUndefinedFields(e.mapview)),this.currentMode===`Mapview`&&(n=!0)),e.vrPanorama&&(Object.assign(this.controllerInits.VRPanorama,omitUndefinedFields(e.vrPanorama)),this.currentMode===`VRPanorama`&&(n=!0)),e.imageOptions&&(Object.assign(this.imageOptions,e.imageOptions),(this.currentMode===`Panorama`||this.currentMode===`VRPanorama`)&&(r=!0,n=!0)),e.textureOptions&&Object.assign(this.textureOptions,e.textureOptions),t&&n&&this.controller&&this.currentMode&&(!this.controller.updateConfiguration(this.controllerInits[this.currentMode])||r)&&this.changeMode(this.currentMode,this.getCurrentState(),0,!1,!0)}appendTo(e,t={}){if(!this.renderer)return;if(!(this.renderer instanceof InternalWebGLRenderer)){this.throwError(Error(`cannot call appendTo method when render a external renderer`));return}let n=this.getElement();if(!n)return;e.appendChild(n),this.refresh(t);let r=window.getComputedStyle(e).position;r!==`relative`&&r!==`absolute`&&r!==`fixed`&&r!==`sticky`&&(e.style.position=`relative`)}refresh(e={},t){var n,r,o;if(!this.renderer)return;let s=this.renderer.domElement.parentNode,{width:c=(n=s==null?void 0:s.offsetWidth)==null?512:n,height:l=(r=s==null?void 0:s.offsetHeight)==null?512:r}=e;if(c=Math.max(1,c),l=Math.max(1,l),!t){let e=getViewportScale(),n=typeof window<`u`?window.devicePixelRatio:1;if(t=(o=e===1?n:1)==null?1:o,t>1){let e=Math.max(c,l)*t,n=Math.min(this.renderer.capabilities.maxTextureSize,4096);e>n&&(t=Math.max(t/e*n,1),t=Math.floor(t*100)/100)}}this.renderer.setPixelRatio(t),this.renderer.setSize(c,l),this.needsRender=!0;let u=now(),d=u-this.currentUpdateArgs.time,f=this.currentUpdateArgs.args;this.updateTime(u,d,...f)}addExtraElement(e){return this.extraElements.indexOf(e)===-1&&(this.extraElements.push(e),this.controller&&this.controller.bindExtraElement(e)),()=>this.removeExtraElement(e)}removeExtraElement(e){let t=this.extraElements.indexOf(e);t!==-1&&(this.extraElements.splice(t,1),this.controller&&this.controller.unbindExtraElement(e))}getSize(e){if(!this.renderer)throw Error(`renderer is not initialized`);return this.renderer.getSize(e),e.x*=this.viewport.width,e.y*=this.viewport.height,e}getDrawingBufferSize(e){if(!this.renderer)throw Error(`renderer is not initialized`);return this.renderer.getDrawingBufferSize(e),e.x*=this.viewport.width,e.y*=this.viewport.height,e}updateCamera(e,t,n=!0){if(!this.controller)throw Error(`controller is not initialized.`);return this.controller.updateCamera(e,t,n)}updateCameraWithKeyframes(e,t,n=!0){if(!this.controller)throw Error(`controller is not initialized.`);return this.controller.updateCameraWithKeyframes(e,t,n)}get works(){return worksMap.get(this)||emptyWorks}get work(){return this.works[0]}get observers(){return this.work.observers}get models(){return this.modelScene.models}get model(){return this.modelScene.models[0]}load(e,t,n,r=!0){if(!this.renderer)throw Error(`renderer is not initialized`);let o=this.loadWorkTask.then(()=>isPromise(e)?e.then(e=>this.load_(e,t,n,r)):this.load_(e,t,n,r));return this.loadWorkTask=o.catch(e=>{this.throwError(e)}),o}load_(t,n,r,o=!0){var s,c,l,u,d,f,p,m,h,g;let _={};typeof r==`number`?_.duration=r:typeof r==`object`&&Object.assign(_,r),this.works===emptyWorks&&(_.duration===void 0&&(_.duration=0),_.effect===void 0&&(_.effect=`instant`));let v={};Object.assign(v,_.model),!v[`3d-tiles`]&&_[`3d-tiles`]&&(v[`3d-tiles`]=_[`3d-tiles`]),!v.textureOptions&&_.textureOptions&&(v.textureOptions=_.textureOptions),!v.textureOptions&&this.textureOptions&&(v.textureOptions=this.textureOptions);let y=[];if(Array.isArray(t))for(let e of t)e instanceof Work?y.push(e):typeof e!=`string`&&`work`in e?y.push(parseWork(e.work,e)):y.push(parseWork(e));else t instanceof Work?y.push(t):y.push(parseWork(t));_.mode===`add`&&(y=[].concat(this.works,y));let b;try{b=createWorks(y)}catch(e){return this.throwError(e),Promise.reject(e)}for(let e of b)this.bindWorkFetcher(e);n===void 0&&(n=`inherit`),n===`inherit`&&this.works===emptyWorks&&(n=`initial`);let S=this.currentMode,C=b.initial,w=C.work.observers[0],T=w?{workCode:w.work.workCode,panoIndex:w.panoIndex}:{workCode:C.work.workCode,panoIndex:0},E=(s=C.mode)==null?w?`Panorama`:`Mapview`:s,D={};if(n===`inherit`){let e=this.getCurrentState(),[t]=b.filter(t=>t.workCode===e.workCode);if(t)T={workCode:e.workCode,panoIndex:e.panoIndex},E=e.mode,D={longitude:e.latitude,latitude:e.latitude,fov:e.fov,distance:e.distance,offset:e.offset.clone()};else{n={mode:S};let e=(l=(c=b[0])==null?void 0:c.observers)==null?void 0:l[this.panoIndex];e?(n.workCode=e.work.workCode,n.panoIndex=e.panoIndex):typeof b.initial.panoIndex==`number`?(n.workCode=b.initial.work.workCode,n.panoIndex=b.initial.panoIndex):(n.mode===`Panorama`||n.mode===`VRPanorama`||n.mode===`XRPanorama`)&&(n.mode=`Mapview`),n.mode===S&&(n.longitude=this.camera.pose.longitude,n.latitude=this.camera.pose.latitude,n.fov=this.camera.pose.fov)}}if(n===`initial`&&(typeof C.panoIndex==`number`&&(T={workCode:C.work.workCode,panoIndex:C.panoIndex}),C.mode&&(E=C.mode),D={longitude:C.longitude,latitude:C.latitude,fov:C.fov,distance:C.distance,offset:(u=C.offset)==null?void 0:u.clone()}),typeof n==`object`){if(E=(d=n.mode)==null?S:d,typeof n.panoIndex==`number`){let e=b.getObserver({workCode:(p=(f=n.workCode)==null?C.work.workCode:f)==null?``:p,panoIndex:n.panoIndex});e&&(T={workCode:e.work.workCode,panoIndex:e.panoIndex})}D={longitude:n.longitude,latitude:n.latitude,fov:n.fov,distance:n.distance,offset:n.offset?new three.Vector3().copy(n.offset):void 0}}let O=(m=_.duration)==null?this.modeChangeDuration:m;(E===`Floorplan`||E===`Topview`||E===`Mapview`)&&S===E&&(O=0);let k=`fly`;(E===`Panorama`||E===`VRPanorama`||E===`XRPanorama`)&&S===E&&(k=(h=_.effect)==null?`fade`:h),this.emit(`works.request`,createEvent(`works.request`,{input:t,works:b,userAction:o}));let A=(e,t,r)=>{let s=this.getCurrentState(),c=Object.assign(Object.assign({mode:e},t),r);n===`inherit`&&(c=this.getCurrentState()),this.pano=t;let l=Object.assign(Object.assign({initial:{state:c,currentState:s,duration:O,effect:k,userAction:o}},this.commonParams()),this.controllerInits[e]),u=Controllers[c.mode].initAnimationEndState(l);if(this.controller&&S===e)this.controller.updateWork(b,u,{effect:k,duration:O},o)===!1&&(this.controller.destroy(),this.controller=this.applyController(e,l));else{if(this.controller)this.controller.destroy();else{let t=Controllers[e].initAnimationEndState(l);this.camera.setFromPose(t),this.emit(`camera.update`,createEvent(`camera.update`,{state:this.getCurrentState(),userAction:o}))}this.controller=this.applyController(e,l);let t=createEvent(`mode.change`,{prevMode:S,mode:e,state:u,userAction:o});try{this.emit(`mode.change`,t)}catch(e){console.error(e)}}this.updateTime(this.currentUpdateArgs.time,0,...this.currentUpdateArgs.args)};worksMap.set(this,b);let j=Promise.resolve();if(E===e.Mode.Floorplan||E===e.Mode.Topview||E===e.Mode.Mapview||E===e.Mode.Model){this.modelScene.loaded===!1&&(this.camera.setFromPose(D),assignPose(this.state,this.camera.pose));let e=this.modelScene.setModels(b,v);j=Promise.all(e.map(e=>e.loadedReady)).then(()=>{this.needsRender=!0,A(E,T,D),this.emit(`camera.update`,createEvent(`camera.update`,{state:this.getCurrentState(),userAction:o}))})}else{A(E,T,D);let e=this.controller,t=!1;this.modelScene.autoRefine=!1;let n=()=>{this.works===b&&t===!1&&(this.needsRender=!0,this.emit(`camera.update`,createEvent(`camera.update`,{state:this.getCurrentState(),userAction:o})),t=!0,this.modelScene.autoRefine=!0),e.off(`pano.arrived`,n),e.off(`pano.cancel`,n)},r=this.modelScene.setModels(b,v);j=Promise.all(r.map(e=>e.initReady)).then(noop),e.once(`pano.arrived`,n),e.once(`pano.cancel`,n),setTimeout(n,((g=_.duration)==null?this.modeChangeDuration:g)+1e3)}return this.emit(`works.load`,createEvent(`works.load`,{input:t,userAction:o,works:b})),j.then(()=>this.ready()).then(()=>{var e;this.emit(`works.ready`,createEvent(`works.ready`,{input:t,userAction:o,works:b})),(e=this.analysis)==null||e.work(b)})}reset(){let e=this.loadWorkTask.then(()=>this.reset_());return this.loadWorkTask=e.catch(e=>{this.throwError(e)}),e}reset_(){return new Promise(e=>{var t;this.controller&&(this.controller.destroy(),this.controller=void 0);let n=this.modelScene.parameter;n.pano0&&n.pano0.map.dispose(),n.pano1&&n.pano1.map!==((t=n.pano0)==null?void 0:t.map)&&n.pano1.map.dispose(),n.set({pano0:null,pano1:null,modelAlpha:1}),worksMap.set(this,emptyWorks),this.modelScene.setModels(emptyWorks,{forceReplaceImmediately:!0}),this.renderer&&this.modelScene.update(this.renderer,this.camera),this.needsRender=!0,this.currentMode=`Panorama`,this.pano={workCode:``,panoIndex:0},this.camera.setFromPose({distance:0,fov:DEFAULT_CAMERA_FOV,longitude:0,latitude:0,offset:new three.Vector3(0,0,0)}),this.state={mode:this.currentMode,workCode:this.pano.workCode,panoIndex:this.pano.panoIndex,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance},this.camera.needsRender=!1,this.needsRender=!1,e()})}changeMode(t,n={},r,o=!0,s=!1){return new Promise((c,l)=>{var u,d,f,p;if(!this.renderer)throw Error(`renderer is not initialized.`);n=Object.assign({},n);let m=0;this.controller&&(m=typeof r==`number`?r:(u=r==null?void 0:r.duration)==null?this.modeChangeDuration:u);let h=`fly`;this.controller&&typeof r==`object`&&r.effect&&(h=r.effect);let g=typeof n.panoIndex==`number`?{workCode:(p=(d=n.workCode)==null?(f=this.work)==null?void 0:f.workCode:d)==null?``:p,panoIndex:n.panoIndex}:this.pano;if(!e.Mode.hasOwnProperty(t)){let e=Error(`mode "${t}" is not existed`);this.throwError(e),l(e);return}if((t===e.Mode.Panorama||t===e.Mode.VRPanorama||t===e.Mode.XRPanorama)&&!this.works.getObserver(g)){let e=Error(`PanoId ${panoStringify(g)} not existed.`);this.throwError(e),l(e);return}(t===e.Mode.Floorplan||t===e.Mode.Topview||t===e.Mode.Mapview||t===e.Mode.Model)&&this.modelScene.empty&&(m=0);let _=this.controller,v=this.currentMode,y=()=>{if(this.controller&&this.controller.stopMomentumMovement(),this.controller&&s===!1&&v===t)t===e.Mode.Panorama||t===e.Mode.Model||t===e.Mode.VRPanorama||t===e.Mode.XRPanorama?!panoEqual(this.pano,g)&&`moveToPano`in this.controller&&typeof this.controller.moveToPano==`function`?this.controller.moveToPano(g,Object.assign({duration:m},n),o):this.controller.updateCamera(n,m,o).catch(noop):(panoEqual(this.pano,g)||(this.pano=g),this.controller.updateCamera(n,m,o).catch(noop));else{let e=Object.assign(Object.assign({},n),g),r=Object.assign(Object.assign({initial:{state:e,currentState:this.getCurrentState(),duration:m,effect:h,userAction:o}},this.commonParams()),this.controllerInits[t]),s=Controllers[t].initAnimationEndState(r),c=createEvent(`mode.change.request`,{prevMode:this.currentMode,mode:t,state:s,userAction:o});if(this.emit(`mode.change.request`,c),!c.defaultPrevented){_&&_.destroy(),this.controller=this.applyController(t,r);let e=createEvent(`mode.change`,{prevMode:this.currentMode,mode:t,state:s,userAction:o});this.emit(`mode.change`,e)}}c()},b=AnimationFrameLoop.shared.getContext();b&&(typeof XRSession<`u`&&b instanceof XRSession&&b.end(),AnimationFrameLoop.shared.setContext(null)),t===e.Mode.VRPanorama?(this.requestFullscreen(),requestDeviceOrientationPermission().then(()=>y()).catch(e=>{let t=e instanceof Error?e:Error(String(e));this.exitFullscreen(),this.throwError(t),l(t)})):t===e.Mode.XRPanorama?requestXRSessionPermission().then(e=>{AnimationFrameLoop.shared.setContext(e),s=!0,y()}).catch(e=>{let t=e instanceof Error?e:Error(String(e));this.throwError(t),l(t)}):y()})}getPixels(e,t,n,r,o,s,c){if(!this.renderer)throw Error(`renderer is not initialized.`);let l=now(),u=this.renderer.getPixelRatio(),d=this.renderer.getRenderTarget(),f=this.getSize(new three.Vector2),p=0,m=0,h=1,g=1,_,v,y,b,S;typeof e==`number`?(p=e,typeof t==`number`&&(m=t),typeof n==`number`&&(h=n),typeof r==`number`&&(g=r),_=o,v=s,S=c):(p=e.x,m=e.y,h=e.width,g=e.height,_=e.pixelRatio,v=e.flipY,y=e.helperVisible,b=e.skipPanorama,S=e.buffer),p=Math.floor(p),m=Math.floor(m),h=Math.floor(h),g=Math.floor(g),_=Math.floor(_==null?u:_),v=v==null?!1:v;let C=this.helperVisible,w=this.modelScene.parameter.modelAlpha;this.helperVisible=y==null?this.helperVisible:y,b&&(this.controller instanceof Controllers.Panorama||this.controller instanceof Controllers.VRPanorama||this.controller instanceof Controllers.XRPanorama)&&b===!0&&this.modelScene.parameter.set(`modelAlpha`,1),this.modelScene.update(this.renderer,this.camera);let T=this.getPixelsRenderTarget;T.setSize(h*_,g*_),this.renderer.setRenderTarget(T),this.camera.pixelRatio=_,this.camera.resolution.set(h,g),this.camera.setViewOffset(f.width,f.height,p,f.height-m-g,h,g),this.camera.aspect=f.width/f.height,this.camera.updateTime(l),this.scene.update(this.renderer,this.camera);let E=this.renderer.autoClear,D=this.renderer.autoClearColor,O=this.renderer.autoClearDepth,k=this.renderer.autoClearStencil,A=scratchClearColor.copy(this.renderer.getClearColor()),j=this.renderer.getClearAlpha(),M=this.renderer.getScissorTest();this.renderer.autoClear=!0,this.renderer.autoClearColor=!0,this.renderer.autoClearDepth=!0,this.renderer.autoClearStencil=!0,this.renderer.setScissorTest(!1);let N=this.scene.background;this.scene.background=this.camera.isOrthographicCamera?null:N,this.renderer.render(this.scene,this.camera),this.scene.background=N,this.renderer.autoClear=E,this.renderer.autoClearColor=D,this.renderer.autoClearDepth=O,this.renderer.autoClearStencil=k,this.renderer.setClearColor(A,j),this.renderer.setScissorTest(M),this.helperVisible=C,w===void 0?this.modelScene.parameter.reset(`modelAlpha`):this.modelScene.parameter.set(`modelAlpha`,w),this.renderer.setRenderTarget(d),this.camera.clearViewOffset(),this.camera.pixelRatio=u,this.camera.resolution.copy(f),this.camera.aspect=this.camera.resolution.width/this.camera.resolution.height,this.camera.updateTime(l),this.modelScene.update(this.renderer,this.camera),this.scene.update(this.renderer,this.camera);let P=h*_,F=g*_,I=P*F,L=I*4;if(S){if(S.length!==L)throw Error(`buffer length is not equals pixels ${L}`)}else S=new Uint8Array(L);if(this.renderer.readRenderTargetPixels(T,0,0,h*_,g*_,S),v){let e=I/2;for(let t=0,n=0,r=0,o=0;n<e;n++)for(o=(F-Math.floor(n/P)-1)*P+n%P,r=0;r<4;r++)t=S[n*4+r],S[n*4+r]=S[o*4+r],S[o*4+r]=t}return S}getElement(){var e;return(e=this.renderer)==null?void 0:e.domElement}render(e){let t=this.renderer;if(!t)return;let n=t.getRenderTarget();t.setRenderTarget(null);let r=t.autoClear,o=t.autoClearColor,s=t.autoClearDepth,c=t.autoClearStencil,l=scratchClearColor.copy(t.getClearColor()),u=t.getClearAlpha(),d=t.getViewport(scratchViewport),f=t.getScissor(scratchScissor),p=t.getScissorTest();t.autoClear=!0,t.autoClearColor=!0,t.autoClearDepth=!0,t.autoClearStencil=!0;let m=t.getSize(scratchRenderSize),h=Math.floor(m.x*this.viewport.left),g=Math.floor(m.y*this.viewport.bottom),_=Math.floor(m.x*this.viewport.width),v=Math.floor(m.y*this.viewport.height);t.setClearColor(this.backgroundColor,this.backgroundAlpha),t.setViewport(h,g,_,v),t.setScissor(h,g,_,v);let y=this.viewport.bottom!==0||this.viewport.left!==0||this.viewport.width!==1||this.viewport.height!==1;t.setScissorTest(y);let b=this.scene.background;this.scene.background=this.camera.isOrthographicCamera?null:b;let S=!0;if(this.controller&&this.controller.render()&&(S=!1),S){let e=this.fiveRenderer.render(t,this.scene,this.modelScene,this.camera,this.needsRender);this.poweredByRealsee&&e&&renderPoweredByRealsee(t)}this.scene.background=b,t.autoClear=r,t.autoClearColor=o,t.autoClearDepth=s,t.autoClearStencil=c,t.setClearColor(l,u),t.setViewport(d),t.setScissor(f),t.setScissorTest(p),t.setRenderTarget(n),e&&AnimationFrameLoop.shared.add(e,!0)}updateTime(e,t,...n){if(this.currentUpdateArgs={time:e,args:n},this.destroyed)return;if(this.renderer&&ktx2.detectSupport(this.renderer),this.syncingState=this.syncState(e,t),this.controller&&this.controller.updateTime(e,t,...n),this.renderer&&(this.camera.pixelRatio=this.renderer.getPixelRatio(),this.getSize(this.camera.resolution),this.camera.aspect=this.camera.resolution.width/this.camera.resolution.height),this.camera.controllerMode=this.currentMode,this.camera.updateTime(e),this.renderer){let e=this.modelScene.loaded,t=this.modelScene.refined;this.modelScene.update(this.renderer,this.camera),e===!1&&this.modelScene.loaded===!0&&(this.controller&&this.controller.updateModel(this.modelScene),AnimationFrameLoop.shared.add(()=>{this.emit(`models.load`,createEvent(`models.load`,{modelScene:this.modelScene}))},!0,0,10)),t===!1&&this.modelScene.refined===!0&&AnimationFrameLoop.shared.add(()=>{this.emit(`models.refined`,createEvent(`models.refined`,{modelScene:this.modelScene}))},!0,0,10)}if(this.camera.autoNearFar){scratchBox3.makeEmpty(),scratchBox3.expandByObject(this.modelScene.boundingMesh);let t=scratchBox3.getBoundingSphere(scratchSphere),n=t.radius*2;t.containsPoint(this.camera.position)||(n=this.camera.position.distanceTo(t.center)+t.radius),n=clamp$1(n,800);let r=n/1e4;r=clamp$1(r,.03,.1),this.camera.near!==r&&(this.camera.near=r),this.camera.far!==n&&(this.camera.far=n),this.camera.updateTime(e)}if(this.renderer){let e=this.modelScene.visible;this.modelScene.visible=!1,this.scene.update(this.renderer,this.camera),this.modelScene.visible=e}if(this.syncingState=!1,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.modelScene.needsRender===!0&&(this.modelScene.needsRender=!1,this.needsRender=!0),this.scene.needsRender===!0&&(this.scene.needsRender=!1,this.needsRender=!0),this.pbmGaussianSplattingRenderMesh&&this.pbmGaussianSplattingRenderMesh.needsRender===!0&&(this.pbmGaussianSplattingRenderMesh.needsRender=!1,this.needsRender=!0),this.onlyRenderIfNeeds!==!0&&(this.needsRender=!0),this.paused===!0)return;let r=createEvent(`render.prepare`,{needsRender:this.needsRender});this.emit(`render.prepare`,r),r.defaultPrevented&&(this.needsRender=!1);let o=this.needsRender;this.render(),this.needsRender=!1,this.emit(`render`,createEvent(`render`,{needsRender:o})),this.hasListener(`fps`)&&(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))}pause(){this.paused=!0,this.renderer&&this.renderer instanceof InternalWebGLRenderer&&this.renderer.clear(!0,!0,!0)}play(){this.needsRender=!0,this.paused=!1}moveToPano(t,n={},r=!0){let{controller:o,renderer:s}=this;if(!o)return this.throwError(Error(`controller is not initialized.`)),Promise.resolve();if(!s)return this.throwError(Error(`renderer is not initialized.`)),Promise.resolve();typeof t==`number`&&this.pano.workCode&&(t={workCode:this.pano.workCode,panoIndex:t});let c=this.works.getObserver(t);if(!c)return this.throwError(Error(`pano ${JSON.stringify(t)} not existed.`)),Promise.resolve();let l={workCode:c.work.workCode,panoIndex:c.panoIndex};return`moveToPano`in o&&typeof o.moveToPano==`function`?o.moveToPano(l,n,r):c&&(this.pano=l,this.once(`initAnimation.start`,e=>{n.moveStartCallback&&n.moveStartCallback(e.state)}),this.once(`initAnimation.end`,e=>{n.moveEndCallback&&n.moveEndCallback(e.state)}),this.changeMode(e.Mode.Panorama,n,{effect:n.effect},r)),this.ready()}preloadPano(e,t=noop){let n=this.works.getObserver(e);if(!n)return Promise.reject(Error(`Pano ${JSON.stringify(e)} never found`));let r=[`right`,`left`,`up`,`down`,`front`,`back`],o=now();return Promise.all(r.map(e=>{let t=panoStringify({panoIndex:n.panoIndex,workCode:n.work.workCode}),r=Object.assign({key:`pano.${t}.${e}`},pick(this.imageOptions,[`size`,`format`,`quality`,`forceUseExifOrientation`,`mappings`])),o=n.work.getURL(n.images[e]),s=this.imageOptions.transform?this.imageOptions.transform(o,r):imageURL(o,r);return getFetcher(this.fiveId,n.work).preload(s)})).then(()=>{let e=now()-o;return t(e),e})}project2d(e,t=!1){if(!this.renderer)return null;if(t){let t=this.camera.position,n=e.clone().sub(t),r=new three.Raycaster(t,n.clone().normalize());r.params.Points={threshold:.1};let[o]=this.modelScene.intersectRaycaster(r);if(o&&o.distance+.01<n.length())return null}let n=e.clone().project(this.camera);if(Math.abs(n.z)>1)return null;let r=this.renderer.getSize(new three.Vector2),o=r.x*this.viewport.width,s=r.y*this.viewport.height,c=r.x*this.viewport.left+(n.x+1)/2*o,l=r.y*(1-this.viewport.bottom-this.viewport.height)+(-n.y+1)/2*s;return new three.Vector2(c,l)}getCurrentState(){return Object.assign(Object.assign({},this.camera.copyPose()),{mode:this.currentMode,workCode:this.pano.workCode,panoIndex:this.pano.panoIndex})}setState(e,t=!1,n=!0){var r,o,s,c,l,u,d,f,p,m;e=pick(e,[`mode`,`workCode`,`panoIndex`,`longitude`,`latitude`,`fov`,`offset`,`distance`]),e.offset&&!(e instanceof three.Vector3)&&(e.offset=new three.Vector3(e.offset.x,e.offset.y,e.offset.z));let h;if(typeof e.panoIndex==`number`)if(e.workCode)h={workCode:e.workCode,panoIndex:e.panoIndex};else{let t=(o=(r=this.work)==null?void 0:r.workCode)==null?``:o,n=this.state.workCode;this.works.filter(e=>e.workCode===n).length>0&&(t=n),h={workCode:t,panoIndex:e.panoIndex}}let g=(s=e.mode)==null?this.state.mode:s,_,v,y,b,S;if(this.controller&&this.controller.stopMomentumMovement(),this.state.mode!==g){if(g===`VRPanorama`){this.changeMode(`VRPanorama`,void 0,void 0,!0);return}let t={workCode:h==null?void 0:h.workCode,panoIndex:h==null?void 0:h.panoIndex};typeof e.longitude==`number`&&(t.longitude=e.longitude),typeof e.latitude==`number`&&(t.latitude=e.latitude),typeof e.fov==`number`&&(t.fov=e.fov),typeof e.distance==`number`&&(t.distance=e.distance),e.offset instanceof three.Vector3&&(t.offset=e.offset);let n=Object.assign(Object.assign({initial:{state:t,currentState:this.getCurrentState(),duration:this.modeChangeDuration,effect:`fly`,userAction:!1}},this.commonParams()),this.controllerInits[g]),r=Controllers[g].initAnimationEndState(n);_=r.longitude,v=r.latitude,y=r.fov,b=r.offset,S=r.distance}else _=(c=e.longitude)==null?this.state.longitude:c,v=(l=e.latitude)==null?this.state.latitude:l,y=(u=e.fov)==null?this.state.fov:u,b=(d=e.offset)==null?this.state.offset:d,S=(f=e.distance)==null?this.state.distance:f;let C={workCode:(h==null?this.pano:h).workCode,panoIndex:(h==null?this.pano:h).panoIndex,mode:g,longitude:_,latitude:v,fov:y,offset:b,distance:S};this.emit(`state.set`,createEvent(`state.set`,{userAction:n,state:C})),stateEqual(this.state,C)||(this.controller&&C.mode===`VRPanorama`&&C.mode!==this.state.mode?(assignState(this.state,C),this.changeMode(`VRPanorama`)):this.controller&&C.mode===`XRPanorama`&&C.mode!==this.state.mode?(assignState(this.state,C),this.changeMode(`XRPanorama`)):(assignState(this.state,C),this.controller&&n&&(this.controller.userAction=!1),t&&this.state.mode===C.mode&&(this.syncingState=this.syncState(now(),0,t),this.syncingState&&((p=this.controller)==null||p.updateTime(now(),0),this.syncingState=!1)),this.emit(`state.change`,createEvent(`state.change`,{userAction:n,state:this.state})),(m=this.analysis)==null||m.state(this.works,this.state)))}syncState(t,n,r=!1){let o=this.stateSynced;if(this.stateSynced=!1,!this.controller)return!1;if(this.state.mode!==this.currentMode){let e={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,e,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)){let e={longitude:this.state.longitude,latitude:this.state.latitude,fov:this.state.fov,offset:this.state.offset};return this.controller.moveToPosition(this.state.offset,Object.assign(Object.assign({},e),{duration:r?0:void 0}),!1),!0}}else{let e={workCode:this.state.workCode,panoIndex:this.state.panoIndex};if(!panoEqual(e,this.pano)&&`moveToPano`in this.controller&&typeof this.controller.moveToPano==`function`){let t={longitude:this.state.longitude,latitude:this.state.latitude,fov:this.state.fov,offset:this.state.offset,distance:this.state.distance};return this.controller.moveToPano(e,t,!1),!0}}if(this.controller instanceof Controllers.Floorplan||this.controller instanceof Controllers.Topview||this.controller instanceof Controllers.Mapview){let e=1,t=.2,n=.2,o=Math.PI/45,s=r?this.state.fov:stepNumber(this.camera.pose.fov,this.state.fov,1),c=Math.abs(this.camera.pose.distance-this.state.distance),l=c>n*15?c/15:.2,u=r?this.state.distance:stepNumber(this.camera.pose.distance,this.state.distance,l),d=this.camera.pose.offset.distanceTo(this.state.offset),f=d>n*15?d/15:n,p=r?new three.Vector3().copy(this.state.offset):stepVector(this.camera.pose.offset,this.state.offset,f),{longitude:m,latitude:h}=r?{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},o);if(notSimilarValue(s,this.camera.pose.fov)||notSimilarVector3(p,this.camera.pose.offset)||notSimilarValue(u,this.camera.pose.distance)||notSimilarValue(m,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(h,this.camera.pose.latitude)){let e={x:p.x,y:p.y,z:p.z},t={fov:s};return Object.assign(e,{distance:u}),Object.assign(t,{longitude:m,latitude:h}),this.controller.stopMomentumMovement(),this.controller.cameraMotion.set(t,0).catch(noop),this.controller.locationMotion.set(e,0).catch(noop),!0}}else{let e=1,t=Math.PI/45,n=r?this.state.fov:stepNumber(this.camera.pose.fov,this.state.fov,1),{longitude:o,latitude:s}=r?{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},t),c=this.state.distance,l=new three.Vector3().copy(this.state.offset);if(notSimilarValue(c,this.camera.pose.distance)&&(this.state.distance=this.camera.pose.distance),notSimilarVector3(l,this.camera.pose.offset)&&(this.state.offset=this.camera.pose.offset.clone()),notSimilarValue(o,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(s,this.camera.pose.latitude)||notSimilarValue(n,this.camera.pose.fov))return this.controller.stopMomentumMovement(),this.controller.cameraMotion.set({longitude:o,latitude:s,fov:n},0).catch(noop),!0}if(this.stateSynced=!0,o===!1&&this.emit(`state.synced`,createEvent(`state.synced`,{userAction:!1,state:this.state})),this.readyCallbacks.length&&this.stateSynced){let t=this.currentMode;if(!(t===e.Mode.Floorplan||t===e.Mode.Topview||t===e.Mode.Mapview||t===e.Mode.Model)||this.modelScene.loaded){let e=this.readyCallbacks.slice();this.readyCallbacks.length=0;for(let t of e)this.controller instanceof Controllers.Panorama&&t.tile===!0&&!this.controller.isTileReady()?this.readyCallbacks.push(t):t()}}return!1}ready(e={}){return new Promise(t=>{var n;this.readyCallbacks.push(Object.assign(t,{tile:(n=e.tile)==null?!1:n}))}).then(()=>this.model.initReady).then(noop)}requestFullscreen(){var e;if(!isMobile)return;let t=(e=this.getElement())==null?void 0:e.parentNode;t&&`requestFullscreen`in t&&typeof document<`u`&&document.fullscreenElement===null&&t.requestFullscreen()}exitFullscreen(){typeof document<`u`&&document.fullscreenElement&&`exitFullscreen`in document&&document.exitFullscreen()}throwError(e){this.hasListener(`error`)?this.emit(`error`,e):console.error(e)}bindModel(e){let t=()=>{AnimationFrameLoop.shared.add(()=>{this.emit(`model.load`,createEvent(`model.load`,{work:e.work,model:e,error:null}))},!0)},n=t=>{let{error:n}=t;this.emit(`model.error`,createEvent(`model.error`,{work:e.work,model:e,error:n})),this.throwError(n)},r=()=>{this.emit(`model.changeShownFloor`,createEvent(`model.changeShownFloor`,{work:e.work,model:e,error:null}))},o=t=>{this.emit(`models.tileLoad`,createEvent(`model.tileLoad`,{work:e.work,model:e,tile:t.tile}))},s=t=>{this.emit(`models.tileUnload`,createEvent(`model.tileUnload`,{work:e.work,model:e,tile:t.tile}))},c=()=>{e.removeEventListener(`load`,t),e.removeEventListener(`error`,n),e.removeEventListener(`changeShownFloor`,r),e.removeEventListener(`tileLoad`,o),e.removeEventListener(`tileUnload`,s),e.removeEventListener(`dispose`,c)};e.addEventListener(`load`,t),e.addEventListener(`error`,n),e.addEventListener(`changeShownFloor`,r),e.addEventListener(`tileLoad`,o),e.addEventListener(`tileUnload`,s),e.addEventListener(`dispose`,c),this.emit(`model.request`,createEvent(`model.request`,{work:e.work,model:e,error:null}))}bindWorkFetcher(e){let t=this,n=e.workCode,r=e.allowHosts,o=new Fetcher({get networkSubscribe(){return t.networkSubscribe},requestProxy(e){return Promise.resolve(e).then(e=>t.requestProxy(e,n)).then(e=>{let t=verifyURL(e,r);return t instanceof Error?Promise.reject(t):t})}});registerFetcher(this.fiveId,e,o)}commonParams(){return{fiveId:this.fiveId,scene:this.scene,xrCustomObjectsScene:this.xrCustomObjectsScene,helper:this.helperGroup,camera:this.camera,renderer:this.renderer,viewport:this.viewport,element:this.getElement(),works:this.works,imageOptions:this.imageOptions,enableWheel:this.enableWheel,extraElements:this.extraElements,videoTexture:this.videoTexture,modelScene:this.modelScene}}applyController(t,n){if(!this.renderer)throw Error(`renderer is not initialized.`);let r=Controllers[t];this.currentMode=t;let o=new r(n);for(let e of PROXY_CONTROLLER_EVENT_NAMES)o.on(e,(...t)=>{if(this.emit(e,...t))return!1});{let e=Controllers[t].initAnimationEndState(n),r=n.initial.userAction;stateEqual(this.state,e)||(assignState(this.state,e),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state}))),this.emit(`currentState.change`,createEvent(`currentState.change`,{userAction:r,state:this.getCurrentState()}))}return o.on(`camera.update`,e=>{var t;if(this.controller){let n=this.controller.getTargetState();e.userAction&&this.syncingState===!1&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:e.userAction,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}this.emit(`currentState.change`,createEvent(`currentState.change`,{userAction:e.userAction,state:this.getCurrentState()}))}),o.on(`initAnimation.start`,e=>{var t;let{state:n,userAction:r}=e;r&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}),o.on(`initAnimation.end`,e=>{var t;let{state:n,userAction:r}=e;this.pano={workCode:n.workCode,panoIndex:n.panoIndex},r&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}),o.on(`pano.moveTo`,e=>{var t;let{state:n,userAction:r}=e;this.pano={workCode:n.workCode,panoIndex:n.panoIndex},r&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}),o.on(`pano.arrived`,e=>{var t;let{state:n,userAction:r}=e;this.pano={workCode:n.workCode,panoIndex:n.panoIndex},r&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}),o.on(`pano.cancel`,e=>{var t;let{state:n,userAction:r}=e;r&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}),o.on(`pano.moveTo`,e=>{let{userAction:t}=e;this.emit(`currentState.change`,createEvent(`currentState.change`,{userAction:t,state:this.getCurrentState()}))}),o.on(`pano.request`,e=>{this.emit(`pano.request`,e),e.defaultPrevented||this.moveToPano(e.state,e.options,e.userAction)}),o.on(`vr.requestExit`,()=>{this.currentMode===e.Mode.VRPanorama&&(this.exitFullscreen(),this.changeMode(e.Mode.Panorama))}),o.on(`error`,e=>this.throwError(e)),o}removeEventListeners(){}get internalLightsEnabled(){let e=this.scene.children.find(e=>e.name===`internalLights`);return e?e.visible:!1}set internalLightsEnabled(e){let t=this.scene.children.find(e=>e.name===`internalLights`);t&&(t.visible=e),t=this.modelScene.children.find(e=>e.name===`internalLights`),t&&(t.visible=e)}get scissor(){return this.viewport}setScissor(e){return this.setViewport(e)}getPose(){let{longitude:e,latitude:t,fov:n,offset:r,distance:o}=this.camera.copyPose();return{longitude:e,latitude:t,fov:n,offset:r.clone(),distance:o}}getLongitudeAndLatitude(){let{longitude:e,latitude:t}=this.getPose();return{longitude:e,latitude:t}}getOffset(){return this.getPose().offset}getCameraLocal(){if(this.pano.workCode&&this.controller&&this.works){let e=this.works.getObserver(this.pano);if(e){let t=new three.Object3D;t.matrix.copy(e.matrix).premultiply(e.work.transform),t.matrix.decompose(t.position,t.quaternion,t.scale),t.matrixAutoUpdate=!1;let n=new three.Vector3(0,0,-1);n.applyQuaternion(this.camera.quaternion);let r=t.quaternion.clone().inverse();return n.applyQuaternion(r),{theta:Math.atan2(n.x,-n.z),phi:-Math.asin(n.y),lookAtVector:n}}}return null}addPass(e){this.fiveRenderer.composer.addPass(e)}removePass(e){let t=this.fiveRenderer.composer.passes.indexOf(e);t!==-1&&this.fiveRenderer.composer.passes.splice(t,1)}insertPass(e,t){this.fiveRenderer.composer.insertPass(e,t)}get renderMode(){return this.fiveRenderer.renderMode}set renderMode(e){this.fiveRenderer.renderMode=e}get enableHQ(){return this.fiveRenderer.renderMode===`point-cloud-high-quality`}set enableHQ(e){this.fiveRenderer.renderMode=e?`point-cloud-high-quality`:`default`,this.needsRender=!0}get enableEDL(){return this.eyeDomeLightingPass.enabled}set enableEDL(e){this.eyeDomeLightingPass.enabled=e,this.needsRender=!0}get enableAdaptiveLuminance(){return this.adaptiveLuminancePass.enabled}set enableAdaptiveLuminance(e){this.adaptiveLuminancePass.enabled=e,this.needsRender=!0}get enableIOSEDR(){return!1}set enableIOSEDR(e){}get enablePostProcessing(){return!0}set enablePostProcessing(e){}get modelSceneNeedsRender(){return this.modelScene.needsRender}set modelSceneNeedsRender(e){this.modelScene.needsRender=e}};Five.Mode={Panorama:`Panorama`,Model:`Model`,Floorplan:`Floorplan`,Topview:`Topview`,Mapview:`Mapview`,VRPanorama:`VRPanorama`,XRPanorama:`XRPanorama`},typeof window<`u`&&Object.assign(window,{__FIVE_DEBUG__:{THREE:three,constructor:Five,instances:Five_Instances}});var XRButton=class{static createButton(e){let t=document.createElement(`button`);function n(){t.style.display=``,t.style.cursor=`pointer`,t.style.left=`calc(50% - 50px)`,t.style.width=`100px`,t.textContent=`ENTER VR`,t.onmouseenter=function(){t.style.opacity=`1.0`},t.onmouseleave=function(){t.style.opacity=`0.5`},t.onclick=function(){e&&e()}}function r(){t.style.display=``,t.style.cursor=`auto`,t.style.left=`calc(50% - 75px)`,t.style.width=`150px`,t.onmouseenter=null,t.onmouseleave=null,t.onclick=null}function o(){r(),t.textContent=`VR NOT SUPPORTED`}function s(e){e.style.position=`absolute`,e.style.bottom=`20px`,e.style.padding=`12px 6px`,e.style.border=`1px solid #fff`,e.style.borderRadius=`4px`,e.style.background=`rgba(0,0,0,0.1)`,e.style.color=`#fff`,e.style.font=`normal 13px sans-serif`,e.style.textAlign=`center`,e.style.opacity=`0.5`,e.style.outline=`none`,e.style.zIndex=`999`}if(`xr`in navigator)return t.id=`VRButton`,t.style.display=`none`,s(t),navigator.xr.isSessionSupported(`immersive-vr`).then(function(e){e?n():o()}),t;{let e=document.createElement(`a`);return window.isSecureContext===!1?(e.href=document.location.href.replace(/^http:/,`https:`),e.innerHTML=`WEBXR NEEDS HTTPS`):(e.href=`https://immersiveweb.dev/`,e.innerHTML=`WEBXR NOT AVAILABLE`),e.style.left=`calc(50% - 90px)`,e.style.width=`180px`,e.style.textDecoration=`none`,s(e),e}}};exports.AdaptiveLuminancePass=AdaptiveLuminancePass,exports.AnimationFrameLoop=AnimationFrameLoop,exports.BoundingMesh=BoundingMesh,exports.Camera=Camera,exports.CustomShader=PBMCustomShader,exports.PBMCustomShader=PBMCustomShader,exports.EffectComposer=EffectComposer,exports.EyeDomeLightingPass=EyeDomeLightingPass,exports.Fetcher=Fetcher,exports.Five=Five,exports.FivePass=FivePass,exports.FiveRenderer=FiveRenderer,exports.FullScreenQuad=FullScreenQuad,exports.Histogram=Histogram,exports.InternalWebGLRenderer=InternalWebGLRenderer,exports.Model=Model,exports.ModelScene=ModelScene,exports.Motion=Motion,exports.NetworkSubscribe=NetworkSubscribe,exports.PBMContainer=PBMContainer,exports.PBMGSObject=PBMGaussianSplattingObject,exports.PBMGroup=PBMGroup,exports.PBMMesh=PBMMesh,exports.PBMMeshMaterial=PBMMeshMaterial,exports.PBMPanoFilter=PBMPanoFilter,exports.PBMPointCloud=PBMPointCloud,exports.PBMPointCloudMaterial=PBMPointCloudMaterial,exports.PBMSkinnedMesh=PBMSkinnedMesh,exports.PBMUpdateable=PBMUpdateable,exports.PROXY_CONTROLLER_EVENT_NAMES=PROXY_CONTROLLER_EVENT_NAMES,exports.PanoCircleMesh=PanoCircleMesh,exports.PanoCircleMeshCustom=PanoCircleMeshCustom,exports.PanoCircleMeshSolid=PanoCircleMeshSolid,exports.Parameter=Parameter,exports.Scene=Scene,exports.Subscribe=Subscribe,exports.TextureLoader=TextureLoader,exports.Tile=Tile,exports.Tile3D=Tile3D,exports.Tile3DModel=Tile3D,exports.TileCache=TileCache,exports.TileNode=TileNode,exports.TileRequestScheduler=TileRequestScheduler,exports.Tileset=Tileset,exports.Trajectory=Trajectory,exports.TrajectoryNode=TrajectoryNode,exports.Work=Work,exports.WorkResolvedObserver=WorkResolvedObserver,exports.XRButton=XRButton,exports.controllersDefaultInitArgs=controllersDefaultInitArgs,exports.coordinatesToVector=coordinatesToVector,exports.createDebugBoundingMesh=createDebugBoundingMesh,exports.createWorks=createWorks,exports.defaultImageURLTransform=imageURL,exports.draco=draco,exports.getViewportScale=getViewportScale,exports.headingToLongitude=headingToLongitude,exports.imageSupport=imageSupport,exports.isBoundingVolume=isBoundingVolume,exports.isPanoId=isPanoId,exports.ktx2=ktx2,exports.loadAt3d=loadAt3d,exports.loadB3dm=loadB3dm,exports.loadDome=loadDome,exports.loadDomez=loadDomez,exports.loadFbx=loadFbx,exports.loadGltf=loadGltf,exports.loadPbm=loadPbm,exports.loadPly=loadPly,exports.loadPnts=loadPnts,exports.loadSplat=loadSplat,exports.loadSpz=loadSpz,exports.loadX3p=loadX3p,exports.longitudeToHeading=longitudeToHeading,exports.makeBoundingVolume=makeBoundingVolume,exports.panoEqual=panoEqual,exports.panoParse=panoParse,exports.panoStringify=panoStringify,exports.parseWork=parseWork,exports.vectorToCoordinates=vectorToCoordinates,exports.workToJson=workToJson});
2325
+ ----<<-计算从-}yn-中心到当前片段的平方距离----<<-由于-]|vv|{-已经按-\05E6-缩放,平方结果会被缩放-E-倍----<<-如果平方结果大于-E,说明在椭圆外,距离均值超过-\05E6-个标准差----sy|n-N-J-q|5]|vv|{9-]|vv|{6H----vs-5N-K-E;=6-qvpnqH--------rp@-p|y|-J-P|y|;toH--------<<-由于渲染的-}yn-按-\05E6-缩放,高斯公式中的逆协方差矩阵部分变成单位矩阵----<<-因此只剩下-5e-:-zrn{6-7-5e-:-zrn{6,而-zrn{-为零,所以是-e-7-e,即-N----sy|n-|}npv\b-J-r\x07}5:=;B-7-N6-7-P|y|;nH--------tylSntP|y|-J-rpA5p|y|;to9-|}npv\b6H\f`),PBMGaussianSplattingRenderMesh=class extends three.Mesh{constructor(){super(),this.renderData=null,this.needsRender=!1,this.sortWorker=null,this.depthIndex=new Uint32Array,this.splatIndexCapacity=0,this.activeSlot=null,this.pendingSlot=null,this.rebuildGeneration=0,this.forceClipperUniformRefresh=!1,this.incrementalUpdateInFlight=!1,this.dataTexture=null,this.transformsTexture=null,this.transformIndicesTexture=null,this.layerIndicesTexture=null,this.shTexture=null,this.usedSHDegree=0,this.onBeforeRender=(e,t,n)=>{let r=n,o=this.collectObjects(t);if(o.length===0){this.geometry.instanceCount=0;return}let s=0;o.forEach(e=>{e.usedSHDegree>s&&(s=e.usedSHDegree)}),this.setMaxShDegree(s),this.isSceneNeedsRebuild(o)&&(this.tryStartIncrementalUpdate(o)||(this.startPendingRebuild(o),this.gsSceneState.lastClipperHash=``));let c=o.filter(e=>e.transformChanged);c.length>0&&(this.syncTransformsForSlot(this.activeSlot,c),this.syncTransformsForSlot(this.pendingSlot,c),c.forEach(e=>{e.transformChanged=!1,e.selectedChanged=!1})),this.activeSlot&&this.updateSlotTextures(this.activeSlot),this.pendingSlot&&this.updateSlotTextures(this.pendingSlot);let l=new three.Matrix4().multiplyMatrices(r.perspectiveProjectionMatrix,r.matrixWorldInverse).elements;this.pendingSlot&&this.pendingSlot.renderData.initialBuildComplete&&this.pendingSlot.awaitingFirstSort?this.requestSort(this.pendingSlot,l):this.activeSlot&&this.requestSort(this.activeSlot,l);let u=this.getClipperHash(o);if((this.forceClipperUniformRefresh||u!==this.gsSceneState.lastClipperHash)&&(this.updateClipperUniforms(o),this.gsSceneState.lastClipperHash=u,this.forceClipperUniformRefresh=!1,this.needsRender=!0),this.activeSlot){let e=Math.min(this.usedSHDegree,this.activeSlot.renderData.maxShDegree);this.material.uniforms.u_maxShDegree.value=e,e>0&&!this.activeSlot.textures.shTexture?this.createSHTexture(this.activeSlot):e===0&&this.activeSlot.textures.shTexture&&(this.activeSlot.textures.shTexture.dispose(),this.activeSlot.textures.shTexture=null),this.material.uniforms.u_shTexture.value=this.activeSlot.textures.shTexture,this.renderData=this.activeSlot.renderData}else this.pendingSlot||(this.bindSlotTextures(null),this.material.uniforms.u_maxShDegree.value=0,this.geometry.instanceCount=0);this.material.uniforms.resolution.value.set(r.resolution.x,r.resolution.y)};let e=this.createGeometry(),t=this.createMaterial();this.geometry=e,this.material=t,this.frustumCulled=!1,this.renderOrder=-99999999999,this.gsSceneState={lastObjectsHash:``,lastClipperHash:``},this.sortWorker=new WorkerWrapper,this.sortWorker.postMessage({warmup:!0}),RenderData.warmupWasm(),this.sortWorker.onmessage=e=>{if(e.data.depthIndex){let t=e.data.generation;if(this.pendingSlot&&t===this.pendingSlot.generation){this.pendingSlot.awaitingFirstSort=!1,this.swapPendingToActive(e.data.depthIndex);return}this.activeSlot&&t===this.activeSlot.generation&&(this.activeSlot.awaitingFirstSort=!1,this.applyDepthIndex(e.data.depthIndex))}}}ensureSplatIndexCapacity(e){let t=this.geometry.getAttribute(`splatIndex`);if(e<=this.splatIndexCapacity)return t;let n=this.getExpandedCapacity(e),r=t.array,o=new Float32Array(n);o.set(r.subarray(0,Math.min(r.length,n)));let s=new three.InstancedBufferAttribute(o,1,!1,1);return s.setUsage(three.DynamicDrawUsage),this.geometry.setAttribute(`splatIndex`,s),this.splatIndexCapacity=n,this.geometry._maxInstanceCount=n,s}getExpandedCapacity(e){let t=Math.max(this.splatIndexCapacity,1);for(;t<e;)t*=2;return t}createGeometry(){let e=new three.InstancedBufferGeometry,t=new Float32Array([-1,-1,0,1,-1,0,1,1,0,-1,1,0]);e.setAttribute(`position`,new three.BufferAttribute(t,3));let n=new Uint16Array([0,1,2,0,2,3]);e.setIndex(new three.BufferAttribute(n,1)),this.splatIndexCapacity=1;let r=new Float32Array(this.splatIndexCapacity);for(let e=0;e<r.length;e++)r[e]=e;let o=new three.InstancedBufferAttribute(r,1,!1,1);return o.setUsage(three.DynamicDrawUsage),e.setAttribute(`splatIndex`,o),e._maxInstanceCount=this.splatIndexCapacity,e.instanceCount=0,e}createMaterial(){return new three.ShaderMaterial({vertexShader:vertex_default,fragmentShader:fragment_default,defines:{NUM_GS_LAYERS:0,NUM_GS_CLIPPERS:0},uniforms:{u_texture:{value:null},u_transforms:{value:null},u_transformIndices:{value:null},u_layerIndices:{value:null},u_numGsLayers:{value:0},u_numGsClippers:{value:0},u_layerClipperRanges:{value:[]},u_clipperMatricesInverse:{value:[]},u_shTexture:{value:null},u_shTextureSize:{value:new three.Vector2},u_maxShDegree:{value:0},resolution:{value:new three.Vector2}},side:three.DoubleSide,transparent:!0,blending:three.NormalBlending,depthTest:!0,depthWrite:!1})}createDefaultLayerClipperRanges(e){return Array.from({length:e},()=>new three.Vector2(-1,0))}createDefaultClipperMatrices(e){return Array.from({length:e},()=>new three.Matrix4)}createTextures(e){let t=new three.DataTexture(e.data,e.width,e.height,three.RGBAIntegerFormat,three.UnsignedIntType);t.internalFormat=`RGBA32UI`,t.minFilter=three.NearestFilter,t.magFilter=three.NearestFilter,t.needsUpdate=!0;let n=new three.DataTexture(e.transforms,e.transformsWidth,e.transformsHeight,three.RGBAFormat,three.FloatType);n.internalFormat=`RGBA32F`,n.minFilter=three.NearestFilter,n.magFilter=three.NearestFilter,n.needsUpdate=!0;let r=new three.DataTexture(e.transformIndices,e.transformIndicesWidth,e.transformIndicesHeight,three.RedIntegerFormat,three.UnsignedIntType);r.internalFormat=`R32UI`,r.minFilter=three.NearestFilter,r.magFilter=three.NearestFilter,r.needsUpdate=!0;let o=new three.DataTexture(e.layerIndices,e.layerIndicesWidth,e.layerIndicesHeight,three.RedIntegerFormat,three.UnsignedIntType);return o.internalFormat=`R32UI`,o.minFilter=three.NearestFilter,o.magFilter=three.NearestFilter,o.needsUpdate=!0,{dataTexture:t,transformsTexture:n,transformIndicesTexture:r,layerIndicesTexture:o,shTexture:null}}createSHTexture(e){let{renderData:t,textures:n}=e;n.shTexture&&(n.shTexture.dispose(),n.shTexture=null);let r=Math.min(this.usedSHDegree,t.maxShDegree),o=0;if(r>=1&&(o+=9),r>=2&&(o+=15),r>=3&&(o+=21),o===0)return;let s=4,c=o;c%4!=0&&(c=Math.ceil(c/4)*4);let l=t.numPoints*c/4,u=2048,d=Math.ceil(l/u),f=new Float32Array(u*d*4);for(let e=0;e<t.numPoints;e++){let n=c/4*e,o=0;if(t.sh1&&r>=1)for(let r=0;r<9;r++){let s=n+Math.floor(o/4),c=o%4,l=s*4+c;f[l]=t.sh1[e*9+r],o++}if(t.sh2&&r>=2)for(let r=0;r<15;r++){let s=n+Math.floor(o/4),c=o%4,l=s*4+c;f[l]=t.sh2[e*15+r],o++}if(t.sh3&&r>=3)for(let r=0;r<21;r++){let s=n+Math.floor(o/4),c=o%4,l=s*4+c;f[l]=t.sh3[e*21+r],o++}}n.shTexture=new three.DataTexture(f,u,d,three.RGBAFormat,three.FloatType),n.shTexture.internalFormat=`RGBA32F`,n.shTexture.minFilter=three.NearestFilter,n.shTexture.magFilter=three.NearestFilter,n.shTexture.needsUpdate=!0,this.material.uniforms.u_shTextureSize.value.set(u,d),this.material.uniforms.u_maxShDegree.value=r}setMaxShDegree(e){var t,n;if(e<0||e>2){console.warn(`现在只支持012三种阶数,你输入的是${e}`);return}let r=this.usedSHDegree;this.usedSHDegree=e,r!==e&&((t=this.activeSlot)!=null&&t.textures.shTexture&&(this.activeSlot.textures.shTexture.dispose(),this.activeSlot.textures.shTexture=null),(n=this.pendingSlot)!=null&&n.textures.shTexture&&(this.pendingSlot.textures.shTexture.dispose(),this.pendingSlot.textures.shTexture=null),this.material.uniforms.u_maxShDegree.value=e,e===0?this.material.uniforms.u_shTexture.value=null:this.activeSlot&&this.activeSlot.renderData.maxShDegree>0&&(this.createSHTexture(this.activeSlot),this.material.uniforms.u_shTexture.value=this.activeSlot.textures.shTexture))}bindSlotTextures(e){if(!e){this.dataTexture=null,this.transformsTexture=null,this.transformIndicesTexture=null,this.layerIndicesTexture=null,this.shTexture=null,this.material.uniforms.u_texture.value=null,this.material.uniforms.u_transforms.value=null,this.material.uniforms.u_transformIndices.value=null,this.material.uniforms.u_layerIndices.value=null,this.material.uniforms.u_shTexture.value=null;return}this.dataTexture=e.textures.dataTexture,this.transformsTexture=e.textures.transformsTexture,this.transformIndicesTexture=e.textures.transformIndicesTexture,this.layerIndicesTexture=e.textures.layerIndicesTexture,this.shTexture=e.textures.shTexture,this.material.uniforms.u_texture.value=this.dataTexture,this.material.uniforms.u_transforms.value=this.transformsTexture,this.material.uniforms.u_transformIndices.value=this.transformIndicesTexture,this.material.uniforms.u_layerIndices.value=this.layerIndicesTexture,this.material.uniforms.u_shTexture.value=this.shTexture}disposeSlot(e){e&&(e.renderData.dispose(),this.disposeTextures(e.textures))}disposeTextures(e){e.dataTexture.dispose(),e.transformsTexture.dispose(),e.transformIndicesTexture.dispose(),e.layerIndicesTexture.dispose(),e.shTexture&&(e.shTexture.dispose(),e.shTexture=null)}applyDepthIndex(e){this.depthIndex=e;let t=this.depthIndex.length,n=this.ensureSplatIndexCapacity(t);n.array.set(this.depthIndex,0),n.count=this.depthIndex.length,n.updateRange.offset=0,n.updateRange.count=t,n.needsUpdate=!0,this.geometry.instanceCount=this.depthIndex.length,this.needsRender=!0}swapPendingToActive(e){if(!this.pendingSlot)return;let t=this.activeSlot;this.activeSlot=this.pendingSlot,this.pendingSlot=null,this.renderData=this.activeSlot.renderData,this.ensureSplatIndexCapacity(this.activeSlot.renderData.numPoints),this.bindSlotTextures(this.activeSlot),this.activeSlot.sortDataUploaded=!0,this.forceClipperUniformRefresh=!0,this.applyDepthIndex(e),t&&this.disposeSlot(t)}createSlot(e){let t={generation:e.generation,renderData:e,textures:this.createTextures(e),awaitingFirstSort:!0,sortDataUploaded:!1};return this.usedSHDegree>0&&e.maxShDegree>0&&this.createSHTexture(t),t}updateSlotTextures(e){e.renderData.dataChanged&&(e.textures.dataTexture.needsUpdate=!0,e.renderData.dataChanged=!1),e.renderData.transformsChanged&&(e.textures.transformsTexture.needsUpdate=!0,e.textures.transformIndicesTexture.needsUpdate=!0,e.renderData.transformsChanged=!1)}postSortData(e){var t;let n=new Float32Array(e.renderData.positions.slice().buffer),r=new Float32Array(e.renderData.transforms.slice().buffer),o=new Uint32Array(e.renderData.transformIndices.slice().buffer);(t=this.sortWorker)==null||t.postMessage({sortData:{positions:n,transforms:r,transformIndices:o,vertexCount:e.renderData.numPoints,generation:e.generation}},[n.buffer,r.buffer,o.buffer]),e.sortDataUploaded=!0}requestSort(e,t){var n;e.renderData.initialBuildComplete&&((e.renderData.dataChanged||e.renderData.transformsChanged||!e.sortDataUploaded)&&this.postSortData(e),(n=this.sortWorker)==null||n.postMessage({viewProj:t}))}syncTransformsForSlot(e,t){e&&t.forEach(t=>{e.renderData.splatIndices.has(t)&&e.renderData.updateTransform(t)})}collectObjects(e){let t=[];return e.traverse(e=>{e instanceof PBMGaussianSplattingObject&&e.visible&&t.push(e)}),t.sort((e,t)=>{let n=e.uuid+e.gsViewLayerKey,r=t.uuid+t.gsViewLayerKey;return n<r?-1:n>r?1:0}),t}isSceneNeedsRebuild(e){let t=e.map(e=>`${e.uuid}:${e.gsViewLayerKey}`).join(`|`),n=t!==this.gsSceneState.lastObjectsHash;return this.gsSceneState.lastObjectsHash=t,n}getClipperHash(e){return e.map(e=>{let t=e.gsClippers.map(e=>{var t;return`${(t=e.floorIndex)==null?-1:t}:${e.clippingBoxMatrix.elements.join(`,`)}`}).join(`;`);return`${e.gsViewLayerKey}:${t}`}).join(`|`)}updateClipperCounts(e,t){let n=Math.max(0,e|0),r=Math.max(0,t|0),o=this.material.defines;(o.NUM_GS_LAYERS!==n||o.NUM_GS_CLIPPERS!==r)&&(o.NUM_GS_LAYERS=n,o.NUM_GS_CLIPPERS=r,this.material.needsUpdate=!0),this.material.uniforms.u_numGsLayers.value=e,this.material.uniforms.u_numGsClippers.value=t}updateClipperUniforms(e){var t,n,r,o;let s=(n=(t=this.activeSlot)==null?void 0:t.renderData)==null?null:n;if(!s){this.material.uniforms.u_layerClipperRanges.value=[],this.material.uniforms.u_clipperMatricesInverse.value=[],this.updateClipperCounts(0,0);return}let c=new Map;for(let t of e)c.has(t.gsViewLayerKey)||c.set(t.gsViewLayerKey,t.gsClippers);let l=s.layerKeys.length,u=0;for(let e of s.layerKeys)u+=((r=c.get(e))==null?[]:r).length;let d=this.createDefaultLayerClipperRanges(l),f=this.createDefaultClipperMatrices(u),p=0;for(let e of s.layerKeys){let t=s.layerKeyToIndex.get(e);if(t===void 0)continue;let n=(o=c.get(e))==null?[]:o,r=p,l=0;for(let e of n)f[p].getInverse(e.clippingBoxMatrix),p++,l++;l>0&&d[t].set(r,l)}this.material.uniforms.u_layerClipperRanges.value=d,this.material.uniforms.u_clipperMatricesInverse.value=f,this.updateClipperCounts(l,p)}startPendingRebuild(e){this.pendingSlot&&(this.disposeSlot(this.pendingSlot),this.pendingSlot=null),this.rebuildGeneration+=1;let t=new RenderData(e,this.rebuildGeneration);this.pendingSlot=this.createSlot(t)}tryStartIncrementalUpdate(e){if(!this.activeSlot||this.pendingSlot||this.incrementalUpdateInFlight)return!1;let t=this.activeSlot.renderData.getObjectsInOrder();if(!this.activeSlot.renderData.canIncrementalAppend(e))return!1;let n=e.slice(t.length);if(n.length===0)return!1;this.incrementalUpdateInFlight=!0;let r=this.activeSlot;return r.renderData.appendObjects(n).then(e=>{if(!e||this.activeSlot!==r||r.renderData.disposed)return;let t=r.textures;r.textures=this.createTextures(r.renderData),this.usedSHDegree>0&&r.renderData.maxShDegree>0&&this.createSHTexture(r),this.bindSlotTextures(r),this.ensureSplatIndexCapacity(r.renderData.numPoints),r.sortDataUploaded=!1,r.awaitingFirstSort=!0,this.disposeTextures(t),this.forceClipperUniformRefresh=!0,this.gsSceneState.lastClipperHash=``,this.needsRender=!0}).catch(e=>{console.warn(`Incremental append failed, fallback to rebuild:`,e)}).finally(()=>{this.incrementalUpdateInFlight=!1}),!0}dispose(){this.disposeSlot(this.pendingSlot),this.pendingSlot=null,this.disposeSlot(this.activeSlot),this.activeSlot=null,this.renderData=null,this.sortWorker&&this.sortWorker.terminate(),this.bindSlotTextures(null),this.geometry.dispose(),this.material.dispose()}},PBMGaussianSplattingTestMesh=class extends three.Mesh{constructor(){super(),this.onBeforeRender=(e,t,n)=>{this.collectObjects(t).length>0&&console.warn(`未开启webgl2, 3dgs仅支持在开启webgl2模式后使用`)}}collectObjects(e){let t=[];return e.traverse(e=>{e instanceof PBMGaussianSplattingObject&&e.visible&&t.push(e)}),t}},DEFAULT_MODE_CHANGE_DURATION=1e3,DEFAULT_CAMERA_FOV=90,DEFAULT_REQUEST_PROXY=e=>e.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/`),scratchSphere=new three.Sphere,scratchBox3=new three.Box3,scratchViewport=new three.Vector4,scratchScissor=new three.Vector4,scratchClearColor=new three.Color,scratchRenderSize=new three.Vector2,worksMap=new WeakMap,emptyWorks=createWorks([parseWork(null)]),Five_Instances={},Five=class e extends Subscribe{static get version(){return`6.8.0-alpha.24`}static get dracoPath(){return draco.decoderPath}static set dracoPath(e){draco.setDecoderPath(e)}static get ktx2Path(){return ktx2.transcoderPath}static set ktx2Path(e){ktx2.setTranscoderPath(e)}static get useNativeImageBitmap(){return canUseNativeImageBitmap()}static set useNativeImageBitmap(e){useNativeImageBitmap(e)}constructor(e={}){var t,n,r,o,s,c,l,u,d,f,p;if(super(),this.pbmGaussianSplattingRenderMesh=null,this.fiveId=createUuid(),Five_Instances[this.fiveId]=this,this.currentUpdateArgs={time:now(),args:[]},this.currentMode=`Panorama`,this.pano={workCode:``,panoIndex:0},this.needsRender=!1,this.onlyRenderIfNeeds=(t=e.onlyRenderIfNeeds)==null?!0:t,this.imageOptions=Object.assign({},(n=e.imageOptions)==null?{}:n),this.textureOptions=Object.assign({},(r=e.textureOptions)==null?{}:r),this.poweredByRealsee=(o=e.poweredByRealsee)==null?!0:o,this.backgroundColor=new three.Color((s=e.backgroundColor)==null?1579548:s),this.backgroundAlpha=(c=e.backgroundAlpha)==null?1:c,this.extraElements=[],this.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),VRPanorama:Object.assign({},e.vrPanorama),XRPanorama:Object.assign({},e.xrPanorama)},this.fps={testCount:0,testTime:now()},this.modeChangeDuration=(l=e.modeChangeDuration)==null?DEFAULT_MODE_CHANGE_DURATION:l,this.enableWheel=(u=e.enableWheel)==null?!0:u,typeof window<`u`)if(`renderer`in e)e.renderer instanceof InternalWebGLRenderer&&this.throwError(Error(`cannot render a internal renderer`)),this.renderer=e.renderer;else try{this.renderer=new InternalWebGLRenderer({preserveDrawingBuffer:e.preserveDrawingBuffer,antialias:e.antialias,webgl2:e.webgl2,logarithmicDepthBuffer:e.logarithmicDepthBuffer,precision:e.precision,powerPreference:e.powerPreference});let t=getViewportScale();this.renderer.setPixelRatio(t===1?window.devicePixelRatio:1),this.renderer.setSize(512,512),this.renderer.setClearColor(this.backgroundColor,this.backgroundAlpha)}catch(e){let t=e instanceof Error?e:Error(String(e));this.throwError(t)}this.getPixelsRenderTarget=new three.WebGLRenderTarget(1,1,{encoding:(f=(d=this.renderer)==null?void 0:d.outputEncoding)==null?three.sRGBEncoding:f,generateMipmaps:!1}),this.viewport=Object.assign({left:0,bottom:0,width:1,height:1},e.viewport),this.camera=new Camera(DEFAULT_CAMERA_FOV),this.scene=new Scene,this.xrCustomObjectsScene=new three.Scene,this.scene.add(this.xrCustomObjectsScene),this.scene.matrixAutoUpdate=!1,this.loadWorkTask=Promise.resolve(),this.requestProxy=(p=e.requestProxy)==null?DEFAULT_REQUEST_PROXY:p,this.networkSubscribe=new NetworkSubscribe,this.networkSubscribe.on(`network`,(e,t,n,r)=>{var o;this.emit(`network.resource`,createEvent(`network.resource`,{source:e,requestType:t,requestState:n,detail:r})),(o=this.analysis)==null||o.network(this.works,e,t,n,r)}),this.readyCallbacks=[],this.syncingState=!1,this.helperGroup=new three.Group,this.helperGroup.name=`helper`,this.helperGroup.matrixAutoUpdate=!1,this.scene.add(this.helperGroup),worksMap.set(this,emptyWorks),this.modelScene=new ModelScene({fiveId:this.fiveId}),this.modelScene.addEventListener(`model.create`,e=>{this.bindModel(e.model)}),this.scene.add(this.modelScene);let[m]=this.modelScene.setModels(emptyWorks,{forceReplaceImmediately:!0});defineProperty(m,`loaded`,{get(){return!1},set(e){}}),this.videoTexture=new three.VideoTexture(e.videoInstance||generateDefaultVideoElement());let h=initLights();this.scene.add(h),this.state={mode:this.currentMode,workCode:this.pano.workCode,panoIndex:this.pano.panoIndex,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance},this.stateSynced=!1,this.destroyed=!1,this.paused=!0,typeof window<`u`&&(e.play!==!1&&this.play(),this.stopAnimationLoop=AnimationFrameLoop.shared.add((e,t,...n)=>{this.updateTime(e,t,...n)},!1,0,10));let g=()=>{typeof document<`u`&&document.fullscreenElement===null&&this.currentMode===`VRPanorama`&&this.controller.emit(`vr.requestExit`,createEvent(`vr.requestExit`,{}))},_=()=>{this.needsRender=!0};if(typeof document<`u`&&document.addEventListener(`fullscreenchange`,g,!1),this.renderer&&this.renderer.domElement.addEventListener(`webglcontextrestored`,_,!1),this.removeEventListeners=()=>{typeof document<`u`&&document.removeEventListener(`fullscreenchange`,g,!1),this.renderer&&this.renderer.domElement.removeEventListener(`webglcontextrestored`,_,!1)},this.plugins={},e.plugins&&e.plugins.length){for(let t of e.plugins)if(typeof t==`function`)t(this);else if(Array.isArray(t)){let[e,n,r]=t;if(typeof e==`function`){let t=e(this,r);typeof n==`string`&&(this.plugins[n]?this.throwError(Error(`plugin name ${n} is exists.`)):this.plugins[n]=t)}}}initLegacyEvent(this),this.fiveRenderer=new FiveRenderer,this.adaptiveLuminancePass=new AdaptiveLuminancePass,this.adaptiveLuminancePass.enabled=!1,this.fiveRenderer.composer.addPass(this.adaptiveLuminancePass),this.eyeDomeLightingPass=new EyeDomeLightingPass(this.camera),this.eyeDomeLightingPass.enabled=!1,this.fiveRenderer.composer.addPass(this.eyeDomeLightingPass),e.webgl2?(this.pbmGaussianSplattingRenderMesh=new PBMGaussianSplattingRenderMesh,this.scene.add(this.pbmGaussianSplattingRenderMesh)):this.scene.add(new PBMGaussianSplattingTestMesh)}get ident(){return this.fiveId}get panoIndex(){return this.pano.panoIndex}get panoId(){return panoStringify(this.pano)}dispose(){var e;if(this.destroyed===!0)return;delete Five_Instances[this.fiveId],this.emit(`dispose`),this.destroyed=!0,this.pause(),this.stopAnimationLoop&&(this.stopAnimationLoop(),this.stopAnimationLoop=void 0),this.off(),this.networkSubscribe.off(),this.controller&&(this.controller.destroy(),this.controller=void 0);let t=this.getElement();t&&t.parentNode&&t.parentNode.removeChild(t);let n=this.modelScene.parameter;n.pano0&&n.pano0.map.dispose(),n.pano1&&n.pano1.map!==((e=n.pano0)==null?void 0:e.map)&&n.pano1.map.dispose(),n.reset(`pano0`,`pano1`),this.modelScene.dispose(),this.scene.dispose(),this.xrCustomObjectsScene.dispose(),worksMap.set(this,emptyWorks),this.renderer&&this.renderer.render(new three.Scene,new three.Camera),this.fiveRenderer.dispose(),this.renderer instanceof InternalWebGLRenderer&&(this.renderer.forceContextLoss&&this.renderer.forceContextLoss(),this.renderer.dispose())}setViewport(e){Object.assign(this.viewport,e),this.needsRender=!0}get boundingMesh(){return this.modelScene.boundingMesh}get helperVisible(){return this.helperGroup.visible}set helperVisible(e){this.helperGroup.visible!==e&&(this.helperGroup.visible=e,this.emit(`helpers.visible`,createEvent(`helpers.visible`,{object:this.helperGroup})),this.needsRender=!0)}updateConfiguration(e,t=!0){let n=!1,r=!1;e.panorama&&(Object.assign(this.controllerInits.Panorama,omitUndefinedFields(e.panorama)),this.currentMode===`Panorama`&&(n=!0)),e.model&&(Object.assign(this.controllerInits.Model,omitUndefinedFields(e.model)),this.currentMode===`Model`&&(n=!0)),e.floorplan&&(Object.assign(this.controllerInits.Floorplan,omitUndefinedFields(e.floorplan)),this.currentMode===`Floorplan`&&(n=!0)),e.topview&&(Object.assign(this.controllerInits.Topview,omitUndefinedFields(e.topview)),this.currentMode===`Topview`&&(n=!0)),e.mapview&&(Object.assign(this.controllerInits.Mapview,omitUndefinedFields(e.mapview)),this.currentMode===`Mapview`&&(n=!0)),e.vrPanorama&&(Object.assign(this.controllerInits.VRPanorama,omitUndefinedFields(e.vrPanorama)),this.currentMode===`VRPanorama`&&(n=!0)),e.imageOptions&&(Object.assign(this.imageOptions,e.imageOptions),(this.currentMode===`Panorama`||this.currentMode===`VRPanorama`)&&(r=!0,n=!0)),e.textureOptions&&Object.assign(this.textureOptions,e.textureOptions),t&&n&&this.controller&&this.currentMode&&(!this.controller.updateConfiguration(this.controllerInits[this.currentMode])||r)&&this.changeMode(this.currentMode,this.getCurrentState(),0,!1,!0)}appendTo(e,t={}){if(!this.renderer)return;if(!(this.renderer instanceof InternalWebGLRenderer)){this.throwError(Error(`cannot call appendTo method when render a external renderer`));return}let n=this.getElement();if(!n)return;e.appendChild(n),this.refresh(t);let r=window.getComputedStyle(e).position;r!==`relative`&&r!==`absolute`&&r!==`fixed`&&r!==`sticky`&&(e.style.position=`relative`)}refresh(e={},t){var n,r,o;if(!this.renderer)return;let s=this.renderer.domElement.parentNode,{width:c=(n=s==null?void 0:s.offsetWidth)==null?512:n,height:l=(r=s==null?void 0:s.offsetHeight)==null?512:r}=e;if(c=Math.max(1,c),l=Math.max(1,l),!t){let e=getViewportScale(),n=typeof window<`u`?window.devicePixelRatio:1;if(t=(o=e===1?n:1)==null?1:o,t>1){let e=Math.max(c,l)*t,n=Math.min(this.renderer.capabilities.maxTextureSize,4096);e>n&&(t=Math.max(t/e*n,1),t=Math.floor(t*100)/100)}}this.renderer.setPixelRatio(t),this.renderer.setSize(c,l),this.needsRender=!0;let u=now(),d=u-this.currentUpdateArgs.time,f=this.currentUpdateArgs.args;this.updateTime(u,d,...f)}addExtraElement(e){return this.extraElements.indexOf(e)===-1&&(this.extraElements.push(e),this.controller&&this.controller.bindExtraElement(e)),()=>this.removeExtraElement(e)}removeExtraElement(e){let t=this.extraElements.indexOf(e);t!==-1&&(this.extraElements.splice(t,1),this.controller&&this.controller.unbindExtraElement(e))}getSize(e){if(!this.renderer)throw Error(`renderer is not initialized`);return this.renderer.getSize(e),e.x*=this.viewport.width,e.y*=this.viewport.height,e}getDrawingBufferSize(e){if(!this.renderer)throw Error(`renderer is not initialized`);return this.renderer.getDrawingBufferSize(e),e.x*=this.viewport.width,e.y*=this.viewport.height,e}updateCamera(e,t,n=!0){if(!this.controller)throw Error(`controller is not initialized.`);return this.controller.updateCamera(e,t,n)}updateCameraWithKeyframes(e,t,n=!0){if(!this.controller)throw Error(`controller is not initialized.`);return this.controller.updateCameraWithKeyframes(e,t,n)}get works(){return worksMap.get(this)||emptyWorks}get work(){return this.works[0]}get observers(){return this.work.observers}get models(){return this.modelScene.models}get model(){return this.modelScene.models[0]}load(e,t,n,r=!0){if(!this.renderer)throw Error(`renderer is not initialized`);let o=this.loadWorkTask.then(()=>isPromise(e)?e.then(e=>this.load_(e,t,n,r)):this.load_(e,t,n,r));return this.loadWorkTask=o.catch(e=>{this.throwError(e)}),o}load_(t,n,r,o=!0){var s,c,l,u,d,f,p,m,h,g;let _={};typeof r==`number`?_.duration=r:typeof r==`object`&&Object.assign(_,r),this.works===emptyWorks&&(_.duration===void 0&&(_.duration=0),_.effect===void 0&&(_.effect=`instant`));let v={};Object.assign(v,_.model),!v[`3d-tiles`]&&_[`3d-tiles`]&&(v[`3d-tiles`]=_[`3d-tiles`]),!v.textureOptions&&_.textureOptions&&(v.textureOptions=_.textureOptions),!v.textureOptions&&this.textureOptions&&(v.textureOptions=this.textureOptions);let y=[];if(Array.isArray(t))for(let e of t)e instanceof Work?y.push(e):typeof e!=`string`&&`work`in e?y.push(parseWork(e.work,e)):y.push(parseWork(e));else t instanceof Work?y.push(t):y.push(parseWork(t));_.mode===`add`&&(y=[].concat(this.works,y));let b;try{b=createWorks(y)}catch(e){return this.throwError(e),Promise.reject(e)}for(let e of b)this.bindWorkFetcher(e);n===void 0&&(n=`inherit`),n===`inherit`&&this.works===emptyWorks&&(n=`initial`);let S=this.currentMode,C=b.initial,w=C.work.observers[0],T=w?{workCode:w.work.workCode,panoIndex:w.panoIndex}:{workCode:C.work.workCode,panoIndex:0},E=(s=C.mode)==null?w?`Panorama`:`Mapview`:s,D={};if(n===`inherit`){let e=this.getCurrentState(),[t]=b.filter(t=>t.workCode===e.workCode);if(t)T={workCode:e.workCode,panoIndex:e.panoIndex},E=e.mode,D={longitude:e.latitude,latitude:e.latitude,fov:e.fov,distance:e.distance,offset:e.offset.clone()};else{n={mode:S};let e=(l=(c=b[0])==null?void 0:c.observers)==null?void 0:l[this.panoIndex];e?(n.workCode=e.work.workCode,n.panoIndex=e.panoIndex):typeof b.initial.panoIndex==`number`?(n.workCode=b.initial.work.workCode,n.panoIndex=b.initial.panoIndex):(n.mode===`Panorama`||n.mode===`VRPanorama`||n.mode===`XRPanorama`)&&(n.mode=`Mapview`),n.mode===S&&(n.longitude=this.camera.pose.longitude,n.latitude=this.camera.pose.latitude,n.fov=this.camera.pose.fov)}}if(n===`initial`&&(typeof C.panoIndex==`number`&&(T={workCode:C.work.workCode,panoIndex:C.panoIndex}),C.mode&&(E=C.mode),D={longitude:C.longitude,latitude:C.latitude,fov:C.fov,distance:C.distance,offset:(u=C.offset)==null?void 0:u.clone()}),typeof n==`object`){if(E=(d=n.mode)==null?S:d,typeof n.panoIndex==`number`){let e=b.getObserver({workCode:(p=(f=n.workCode)==null?C.work.workCode:f)==null?``:p,panoIndex:n.panoIndex});e&&(T={workCode:e.work.workCode,panoIndex:e.panoIndex})}D={longitude:n.longitude,latitude:n.latitude,fov:n.fov,distance:n.distance,offset:n.offset?new three.Vector3().copy(n.offset):void 0}}let O=(m=_.duration)==null?this.modeChangeDuration:m;(E===`Floorplan`||E===`Topview`||E===`Mapview`)&&S===E&&(O=0);let k=`fly`;(E===`Panorama`||E===`VRPanorama`||E===`XRPanorama`)&&S===E&&(k=(h=_.effect)==null?`fade`:h),this.emit(`works.request`,createEvent(`works.request`,{input:t,works:b,userAction:o}));let A=(e,t,r)=>{let s=this.getCurrentState(),c=Object.assign(Object.assign({mode:e},t),r);n===`inherit`&&(c=this.getCurrentState()),this.pano=t;let l=Object.assign(Object.assign({initial:{state:c,currentState:s,duration:O,effect:k,userAction:o}},this.commonParams()),this.controllerInits[e]),u=Controllers[c.mode].initAnimationEndState(l);if(this.controller&&S===e)this.controller.updateWork(b,u,{effect:k,duration:O},o)===!1&&(this.controller.destroy(),this.controller=this.applyController(e,l));else{if(this.controller)this.controller.destroy();else{let t=Controllers[e].initAnimationEndState(l);this.camera.setFromPose(t),this.emit(`camera.update`,createEvent(`camera.update`,{state:this.getCurrentState(),userAction:o}))}this.controller=this.applyController(e,l);let t=createEvent(`mode.change`,{prevMode:S,mode:e,state:u,userAction:o});try{this.emit(`mode.change`,t)}catch(e){console.error(e)}}this.updateTime(this.currentUpdateArgs.time,0,...this.currentUpdateArgs.args)};worksMap.set(this,b);let j=Promise.resolve();if(E===e.Mode.Floorplan||E===e.Mode.Topview||E===e.Mode.Mapview||E===e.Mode.Model){this.modelScene.loaded===!1&&(this.camera.setFromPose(D),assignPose(this.state,this.camera.pose));let e=this.modelScene.setModels(b,v);j=Promise.all(e.map(e=>e.loadedReady)).then(()=>{this.needsRender=!0,A(E,T,D),this.emit(`camera.update`,createEvent(`camera.update`,{state:this.getCurrentState(),userAction:o}))})}else{A(E,T,D);let e=this.controller,t=!1;this.modelScene.autoRefine=!1;let n=()=>{this.works===b&&t===!1&&(this.needsRender=!0,this.emit(`camera.update`,createEvent(`camera.update`,{state:this.getCurrentState(),userAction:o})),t=!0,this.modelScene.autoRefine=!0),e.off(`pano.arrived`,n),e.off(`pano.cancel`,n)},r=this.modelScene.setModels(b,v);j=Promise.all(r.map(e=>e.initReady)).then(noop),e.once(`pano.arrived`,n),e.once(`pano.cancel`,n),setTimeout(n,((g=_.duration)==null?this.modeChangeDuration:g)+1e3)}return this.emit(`works.load`,createEvent(`works.load`,{input:t,userAction:o,works:b})),j.then(()=>this.ready()).then(()=>{var e;this.emit(`works.ready`,createEvent(`works.ready`,{input:t,userAction:o,works:b})),(e=this.analysis)==null||e.work(b)})}reset(){let e=this.loadWorkTask.then(()=>this.reset_());return this.loadWorkTask=e.catch(e=>{this.throwError(e)}),e}reset_(){return new Promise(e=>{var t;this.controller&&(this.controller.destroy(),this.controller=void 0);let n=this.modelScene.parameter;n.pano0&&n.pano0.map.dispose(),n.pano1&&n.pano1.map!==((t=n.pano0)==null?void 0:t.map)&&n.pano1.map.dispose(),n.set({pano0:null,pano1:null,modelAlpha:1}),worksMap.set(this,emptyWorks),this.modelScene.setModels(emptyWorks,{forceReplaceImmediately:!0}),this.renderer&&this.modelScene.update(this.renderer,this.camera),this.needsRender=!0,this.currentMode=`Panorama`,this.pano={workCode:``,panoIndex:0},this.camera.setFromPose({distance:0,fov:DEFAULT_CAMERA_FOV,longitude:0,latitude:0,offset:new three.Vector3(0,0,0)}),this.state={mode:this.currentMode,workCode:this.pano.workCode,panoIndex:this.pano.panoIndex,longitude:this.camera.pose.longitude,latitude:this.camera.pose.latitude,fov:this.camera.pose.fov,offset:this.camera.pose.offset.clone(),distance:this.camera.pose.distance},this.camera.needsRender=!1,this.needsRender=!1,e()})}changeMode(t,n={},r,o=!0,s=!1){return new Promise((c,l)=>{var u,d,f,p;if(!this.renderer)throw Error(`renderer is not initialized.`);n=Object.assign({},n);let m=0;this.controller&&(m=typeof r==`number`?r:(u=r==null?void 0:r.duration)==null?this.modeChangeDuration:u);let h=`fly`;this.controller&&typeof r==`object`&&r.effect&&(h=r.effect);let g=typeof n.panoIndex==`number`?{workCode:(p=(d=n.workCode)==null?(f=this.work)==null?void 0:f.workCode:d)==null?``:p,panoIndex:n.panoIndex}:this.pano;if(!e.Mode.hasOwnProperty(t)){let e=Error(`mode "${t}" is not existed`);this.throwError(e),l(e);return}if((t===e.Mode.Panorama||t===e.Mode.VRPanorama||t===e.Mode.XRPanorama)&&!this.works.getObserver(g)){let e=Error(`PanoId ${panoStringify(g)} not existed.`);this.throwError(e),l(e);return}(t===e.Mode.Floorplan||t===e.Mode.Topview||t===e.Mode.Mapview||t===e.Mode.Model)&&this.modelScene.empty&&(m=0);let _=this.controller,v=this.currentMode,y=()=>{if(this.controller&&this.controller.stopMomentumMovement(),this.controller&&s===!1&&v===t)t===e.Mode.Panorama||t===e.Mode.Model||t===e.Mode.VRPanorama||t===e.Mode.XRPanorama?!panoEqual(this.pano,g)&&`moveToPano`in this.controller&&typeof this.controller.moveToPano==`function`?this.controller.moveToPano(g,Object.assign({duration:m},n),o):this.controller.updateCamera(n,m,o).catch(noop):(panoEqual(this.pano,g)||(this.pano=g),this.controller.updateCamera(n,m,o).catch(noop));else{let e=Object.assign(Object.assign({},n),g),r=Object.assign(Object.assign({initial:{state:e,currentState:this.getCurrentState(),duration:m,effect:h,userAction:o}},this.commonParams()),this.controllerInits[t]),s=Controllers[t].initAnimationEndState(r),c=createEvent(`mode.change.request`,{prevMode:this.currentMode,mode:t,state:s,userAction:o});if(this.emit(`mode.change.request`,c),!c.defaultPrevented){_&&_.destroy(),this.controller=this.applyController(t,r);let e=createEvent(`mode.change`,{prevMode:this.currentMode,mode:t,state:s,userAction:o});this.emit(`mode.change`,e)}}c()},b=AnimationFrameLoop.shared.getContext();b&&(typeof XRSession<`u`&&b instanceof XRSession&&b.end(),AnimationFrameLoop.shared.setContext(null)),t===e.Mode.VRPanorama?(this.requestFullscreen(),requestDeviceOrientationPermission().then(()=>y()).catch(e=>{let t=e instanceof Error?e:Error(String(e));this.exitFullscreen(),this.throwError(t),l(t)})):t===e.Mode.XRPanorama?requestXRSessionPermission().then(e=>{AnimationFrameLoop.shared.setContext(e),s=!0,y()}).catch(e=>{let t=e instanceof Error?e:Error(String(e));this.throwError(t),l(t)}):y()})}getPixels(e,t,n,r,o,s,c){if(!this.renderer)throw Error(`renderer is not initialized.`);let l=now(),u=this.renderer.getPixelRatio(),d=this.renderer.getRenderTarget(),f=this.getSize(new three.Vector2),p=0,m=0,h=1,g=1,_,v,y,b,S;typeof e==`number`?(p=e,typeof t==`number`&&(m=t),typeof n==`number`&&(h=n),typeof r==`number`&&(g=r),_=o,v=s,S=c):(p=e.x,m=e.y,h=e.width,g=e.height,_=e.pixelRatio,v=e.flipY,y=e.helperVisible,b=e.skipPanorama,S=e.buffer),p=Math.floor(p),m=Math.floor(m),h=Math.floor(h),g=Math.floor(g),_=Math.floor(_==null?u:_),v=v==null?!1:v;let C=this.helperVisible,w=this.modelScene.parameter.modelAlpha;this.helperVisible=y==null?this.helperVisible:y,b&&(this.controller instanceof Controllers.Panorama||this.controller instanceof Controllers.VRPanorama||this.controller instanceof Controllers.XRPanorama)&&b===!0&&this.modelScene.parameter.set(`modelAlpha`,1),this.modelScene.update(this.renderer,this.camera);let T=this.getPixelsRenderTarget;T.setSize(h*_,g*_),this.renderer.setRenderTarget(T),this.camera.pixelRatio=_,this.camera.resolution.set(h,g),this.camera.setViewOffset(f.width,f.height,p,f.height-m-g,h,g),this.camera.aspect=f.width/f.height,this.camera.updateTime(l),this.scene.update(this.renderer,this.camera);let E=this.renderer.autoClear,D=this.renderer.autoClearColor,O=this.renderer.autoClearDepth,k=this.renderer.autoClearStencil,A=scratchClearColor.copy(this.renderer.getClearColor()),j=this.renderer.getClearAlpha(),M=this.renderer.getScissorTest();this.renderer.autoClear=!0,this.renderer.autoClearColor=!0,this.renderer.autoClearDepth=!0,this.renderer.autoClearStencil=!0,this.renderer.setScissorTest(!1);let N=this.scene.background;this.scene.background=this.camera.isOrthographicCamera?null:N,this.renderer.render(this.scene,this.camera),this.scene.background=N,this.renderer.autoClear=E,this.renderer.autoClearColor=D,this.renderer.autoClearDepth=O,this.renderer.autoClearStencil=k,this.renderer.setClearColor(A,j),this.renderer.setScissorTest(M),this.helperVisible=C,w===void 0?this.modelScene.parameter.reset(`modelAlpha`):this.modelScene.parameter.set(`modelAlpha`,w),this.renderer.setRenderTarget(d),this.camera.clearViewOffset(),this.camera.pixelRatio=u,this.camera.resolution.copy(f),this.camera.aspect=this.camera.resolution.width/this.camera.resolution.height,this.camera.updateTime(l),this.modelScene.update(this.renderer,this.camera),this.scene.update(this.renderer,this.camera);let P=h*_,F=g*_,I=P*F,L=I*4;if(S){if(S.length!==L)throw Error(`buffer length is not equals pixels ${L}`)}else S=new Uint8Array(L);if(this.renderer.readRenderTargetPixels(T,0,0,h*_,g*_,S),v){let e=I/2;for(let t=0,n=0,r=0,o=0;n<e;n++)for(o=(F-Math.floor(n/P)-1)*P+n%P,r=0;r<4;r++)t=S[n*4+r],S[n*4+r]=S[o*4+r],S[o*4+r]=t}return S}getElement(){var e;return(e=this.renderer)==null?void 0:e.domElement}render(e){let t=this.renderer;if(!t)return;let n=t.getRenderTarget();t.setRenderTarget(null);let r=t.autoClear,o=t.autoClearColor,s=t.autoClearDepth,c=t.autoClearStencil,l=scratchClearColor.copy(t.getClearColor()),u=t.getClearAlpha(),d=t.getViewport(scratchViewport),f=t.getScissor(scratchScissor),p=t.getScissorTest();t.autoClear=!0,t.autoClearColor=!0,t.autoClearDepth=!0,t.autoClearStencil=!0;let m=t.getSize(scratchRenderSize),h=Math.floor(m.x*this.viewport.left),g=Math.floor(m.y*this.viewport.bottom),_=Math.floor(m.x*this.viewport.width),v=Math.floor(m.y*this.viewport.height);t.setClearColor(this.backgroundColor,this.backgroundAlpha),t.setViewport(h,g,_,v),t.setScissor(h,g,_,v);let y=this.viewport.bottom!==0||this.viewport.left!==0||this.viewport.width!==1||this.viewport.height!==1;t.setScissorTest(y);let b=this.scene.background;this.scene.background=this.camera.isOrthographicCamera?null:b;let S=!0;if(this.controller&&this.controller.render()&&(S=!1),S){let e=this.fiveRenderer.render(t,this.scene,this.modelScene,this.camera,this.needsRender);this.poweredByRealsee&&e&&renderPoweredByRealsee(t)}this.scene.background=b,t.autoClear=r,t.autoClearColor=o,t.autoClearDepth=s,t.autoClearStencil=c,t.setClearColor(l,u),t.setViewport(d),t.setScissor(f),t.setScissorTest(p),t.setRenderTarget(n),e&&AnimationFrameLoop.shared.add(e,!0)}updateTime(e,t,...n){if(this.currentUpdateArgs={time:e,args:n},this.destroyed)return;if(this.renderer&&ktx2.detectSupport(this.renderer),this.syncingState=this.syncState(e,t),this.controller&&this.controller.updateTime(e,t,...n),this.renderer&&(this.camera.pixelRatio=this.renderer.getPixelRatio(),this.getSize(this.camera.resolution),this.camera.aspect=this.camera.resolution.width/this.camera.resolution.height),this.camera.controllerMode=this.currentMode,this.camera.updateTime(e),this.renderer){let e=this.modelScene.loaded,t=this.modelScene.refined;this.modelScene.update(this.renderer,this.camera),e===!1&&this.modelScene.loaded===!0&&(this.controller&&this.controller.updateModel(this.modelScene),AnimationFrameLoop.shared.add(()=>{this.emit(`models.load`,createEvent(`models.load`,{modelScene:this.modelScene}))},!0,0,10)),t===!1&&this.modelScene.refined===!0&&AnimationFrameLoop.shared.add(()=>{this.emit(`models.refined`,createEvent(`models.refined`,{modelScene:this.modelScene}))},!0,0,10)}if(this.camera.autoNearFar){scratchBox3.makeEmpty(),scratchBox3.expandByObject(this.modelScene.boundingMesh);let t=scratchBox3.getBoundingSphere(scratchSphere),n=t.radius*2;t.containsPoint(this.camera.position)||(n=this.camera.position.distanceTo(t.center)+t.radius),n=clamp$1(n,800);let r=n/1e4;r=clamp$1(r,.03,.1),this.camera.near!==r&&(this.camera.near=r),this.camera.far!==n&&(this.camera.far=n),this.camera.updateTime(e)}if(this.renderer){let e=this.modelScene.visible;this.modelScene.visible=!1,this.scene.update(this.renderer,this.camera),this.modelScene.visible=e}if(this.syncingState=!1,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.modelScene.needsRender===!0&&(this.modelScene.needsRender=!1,this.needsRender=!0),this.scene.needsRender===!0&&(this.scene.needsRender=!1,this.needsRender=!0),this.pbmGaussianSplattingRenderMesh&&this.pbmGaussianSplattingRenderMesh.needsRender===!0&&(this.pbmGaussianSplattingRenderMesh.needsRender=!1,this.needsRender=!0),this.onlyRenderIfNeeds!==!0&&(this.needsRender=!0),this.paused===!0)return;let r=createEvent(`render.prepare`,{needsRender:this.needsRender});this.emit(`render.prepare`,r),r.defaultPrevented&&(this.needsRender=!1);let o=this.needsRender;this.render(),this.needsRender=!1,this.emit(`render`,createEvent(`render`,{needsRender:o})),this.hasListener(`fps`)&&(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))}pause(){this.paused=!0,this.renderer&&this.renderer instanceof InternalWebGLRenderer&&this.renderer.clear(!0,!0,!0)}play(){this.needsRender=!0,this.paused=!1}moveToPano(t,n={},r=!0){let{controller:o,renderer:s}=this;if(!o)return this.throwError(Error(`controller is not initialized.`)),Promise.resolve();if(!s)return this.throwError(Error(`renderer is not initialized.`)),Promise.resolve();typeof t==`number`&&this.pano.workCode&&(t={workCode:this.pano.workCode,panoIndex:t});let c=this.works.getObserver(t);if(!c)return this.throwError(Error(`pano ${JSON.stringify(t)} not existed.`)),Promise.resolve();let l={workCode:c.work.workCode,panoIndex:c.panoIndex};return`moveToPano`in o&&typeof o.moveToPano==`function`?o.moveToPano(l,n,r):c&&(this.pano=l,this.once(`initAnimation.start`,e=>{n.moveStartCallback&&n.moveStartCallback(e.state)}),this.once(`initAnimation.end`,e=>{n.moveEndCallback&&n.moveEndCallback(e.state)}),this.changeMode(e.Mode.Panorama,n,{effect:n.effect},r)),this.ready()}preloadPano(e,t=noop){let n=this.works.getObserver(e);if(!n)return Promise.reject(Error(`Pano ${JSON.stringify(e)} never found`));let r=[`right`,`left`,`up`,`down`,`front`,`back`],o=now();return Promise.all(r.map(e=>{let t=panoStringify({panoIndex:n.panoIndex,workCode:n.work.workCode}),r=Object.assign({key:`pano.${t}.${e}`},pick(this.imageOptions,[`size`,`format`,`quality`,`forceUseExifOrientation`,`mappings`])),o=n.work.getURL(n.images[e]),s=this.imageOptions.transform?this.imageOptions.transform(o,r):imageURL(o,r);return getFetcher(this.fiveId,n.work).preload(s)})).then(()=>{let e=now()-o;return t(e),e})}project2d(e,t=!1){if(!this.renderer)return null;if(t){let t=this.camera.position,n=e.clone().sub(t),r=new three.Raycaster(t,n.clone().normalize());r.params.Points={threshold:.1};let[o]=this.modelScene.intersectRaycaster(r);if(o&&o.distance+.01<n.length())return null}let n=e.clone().project(this.camera);if(Math.abs(n.z)>1)return null;let r=this.renderer.getSize(new three.Vector2),o=r.x*this.viewport.width,s=r.y*this.viewport.height,c=r.x*this.viewport.left+(n.x+1)/2*o,l=r.y*(1-this.viewport.bottom-this.viewport.height)+(-n.y+1)/2*s;return new three.Vector2(c,l)}getCurrentState(){return Object.assign(Object.assign({},this.camera.copyPose()),{mode:this.currentMode,workCode:this.pano.workCode,panoIndex:this.pano.panoIndex})}setState(e,t=!1,n=!0){var r,o,s,c,l,u,d,f,p,m;e=pick(e,[`mode`,`workCode`,`panoIndex`,`longitude`,`latitude`,`fov`,`offset`,`distance`]),e.offset&&!(e instanceof three.Vector3)&&(e.offset=new three.Vector3(e.offset.x,e.offset.y,e.offset.z));let h;if(typeof e.panoIndex==`number`)if(e.workCode)h={workCode:e.workCode,panoIndex:e.panoIndex};else{let t=(o=(r=this.work)==null?void 0:r.workCode)==null?``:o,n=this.state.workCode;this.works.filter(e=>e.workCode===n).length>0&&(t=n),h={workCode:t,panoIndex:e.panoIndex}}let g=(s=e.mode)==null?this.state.mode:s,_,v,y,b,S;if(this.controller&&this.controller.stopMomentumMovement(),this.state.mode!==g){if(g===`VRPanorama`){this.changeMode(`VRPanorama`,void 0,void 0,!0);return}let t={workCode:h==null?void 0:h.workCode,panoIndex:h==null?void 0:h.panoIndex};typeof e.longitude==`number`&&(t.longitude=e.longitude),typeof e.latitude==`number`&&(t.latitude=e.latitude),typeof e.fov==`number`&&(t.fov=e.fov),typeof e.distance==`number`&&(t.distance=e.distance),e.offset instanceof three.Vector3&&(t.offset=e.offset);let n=Object.assign(Object.assign({initial:{state:t,currentState:this.getCurrentState(),duration:this.modeChangeDuration,effect:`fly`,userAction:!1}},this.commonParams()),this.controllerInits[g]),r=Controllers[g].initAnimationEndState(n);_=r.longitude,v=r.latitude,y=r.fov,b=r.offset,S=r.distance}else _=(c=e.longitude)==null?this.state.longitude:c,v=(l=e.latitude)==null?this.state.latitude:l,y=(u=e.fov)==null?this.state.fov:u,b=(d=e.offset)==null?this.state.offset:d,S=(f=e.distance)==null?this.state.distance:f;let C={workCode:(h==null?this.pano:h).workCode,panoIndex:(h==null?this.pano:h).panoIndex,mode:g,longitude:_,latitude:v,fov:y,offset:b,distance:S};this.emit(`state.set`,createEvent(`state.set`,{userAction:n,state:C})),stateEqual(this.state,C)||(this.controller&&C.mode===`VRPanorama`&&C.mode!==this.state.mode?(assignState(this.state,C),this.changeMode(`VRPanorama`)):this.controller&&C.mode===`XRPanorama`&&C.mode!==this.state.mode?(assignState(this.state,C),this.changeMode(`XRPanorama`)):(assignState(this.state,C),this.controller&&n&&(this.controller.userAction=!1),t&&this.state.mode===C.mode&&(this.syncingState=this.syncState(now(),0,t),this.syncingState&&((p=this.controller)==null||p.updateTime(now(),0),this.syncingState=!1)),this.emit(`state.change`,createEvent(`state.change`,{userAction:n,state:this.state})),(m=this.analysis)==null||m.state(this.works,this.state)))}syncState(t,n,r=!1){let o=this.stateSynced;if(this.stateSynced=!1,!this.controller)return!1;if(this.state.mode!==this.currentMode){let e={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,e,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)){let e={longitude:this.state.longitude,latitude:this.state.latitude,fov:this.state.fov,offset:this.state.offset};return this.controller.moveToPosition(this.state.offset,Object.assign(Object.assign({},e),{duration:r?0:void 0}),!1),!0}}else{let e={workCode:this.state.workCode,panoIndex:this.state.panoIndex};if(!panoEqual(e,this.pano)&&`moveToPano`in this.controller&&typeof this.controller.moveToPano==`function`){let t={longitude:this.state.longitude,latitude:this.state.latitude,fov:this.state.fov,offset:this.state.offset,distance:this.state.distance};return this.controller.moveToPano(e,t,!1),!0}}if(this.controller instanceof Controllers.Floorplan||this.controller instanceof Controllers.Topview||this.controller instanceof Controllers.Mapview){let e=1,t=.2,n=.2,o=Math.PI/45,s=r?this.state.fov:stepNumber(this.camera.pose.fov,this.state.fov,1),c=Math.abs(this.camera.pose.distance-this.state.distance),l=c>n*15?c/15:.2,u=r?this.state.distance:stepNumber(this.camera.pose.distance,this.state.distance,l),d=this.camera.pose.offset.distanceTo(this.state.offset),f=d>n*15?d/15:n,p=r?new three.Vector3().copy(this.state.offset):stepVector(this.camera.pose.offset,this.state.offset,f),{longitude:m,latitude:h}=r?{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},o);if(notSimilarValue(s,this.camera.pose.fov)||notSimilarVector3(p,this.camera.pose.offset)||notSimilarValue(u,this.camera.pose.distance)||notSimilarValue(m,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(h,this.camera.pose.latitude)){let e={x:p.x,y:p.y,z:p.z},t={fov:s};return Object.assign(e,{distance:u}),Object.assign(t,{longitude:m,latitude:h}),this.controller.stopMomentumMovement(),this.controller.cameraMotion.set(t,0).catch(noop),this.controller.locationMotion.set(e,0).catch(noop),!0}}else{let e=1,t=Math.PI/45,n=r?this.state.fov:stepNumber(this.camera.pose.fov,this.state.fov,1),{longitude:o,latitude:s}=r?{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},t),c=this.state.distance,l=new three.Vector3().copy(this.state.offset);if(notSimilarValue(c,this.camera.pose.distance)&&(this.state.distance=this.camera.pose.distance),notSimilarVector3(l,this.camera.pose.offset)&&(this.state.offset=this.camera.pose.offset.clone()),notSimilarValue(o,this.camera.pose.longitude,Math.PI*2)||notSimilarValue(s,this.camera.pose.latitude)||notSimilarValue(n,this.camera.pose.fov))return this.controller.stopMomentumMovement(),this.controller.cameraMotion.set({longitude:o,latitude:s,fov:n},0).catch(noop),!0}if(this.stateSynced=!0,o===!1&&this.emit(`state.synced`,createEvent(`state.synced`,{userAction:!1,state:this.state})),this.readyCallbacks.length&&this.stateSynced){let t=this.currentMode;if(!(t===e.Mode.Floorplan||t===e.Mode.Topview||t===e.Mode.Mapview||t===e.Mode.Model)||this.modelScene.loaded){let e=this.readyCallbacks.slice();this.readyCallbacks.length=0;for(let t of e)this.controller instanceof Controllers.Panorama&&t.tile===!0&&!this.controller.isTileReady()?this.readyCallbacks.push(t):t()}}return!1}ready(e={}){return new Promise(t=>{var n;this.readyCallbacks.push(Object.assign(t,{tile:(n=e.tile)==null?!1:n}))}).then(()=>this.model.initReady).then(noop)}requestFullscreen(){var e;if(!isMobile)return;let t=(e=this.getElement())==null?void 0:e.parentNode;t&&`requestFullscreen`in t&&typeof document<`u`&&document.fullscreenElement===null&&t.requestFullscreen()}exitFullscreen(){typeof document<`u`&&document.fullscreenElement&&`exitFullscreen`in document&&document.exitFullscreen()}throwError(e){this.hasListener(`error`)?this.emit(`error`,e):console.error(e)}bindModel(e){let t=()=>{AnimationFrameLoop.shared.add(()=>{this.emit(`model.load`,createEvent(`model.load`,{work:e.work,model:e,error:null}))},!0)},n=t=>{let{error:n}=t;this.emit(`model.error`,createEvent(`model.error`,{work:e.work,model:e,error:n})),this.throwError(n)},r=()=>{this.emit(`model.changeShownFloor`,createEvent(`model.changeShownFloor`,{work:e.work,model:e,error:null}))},o=t=>{this.emit(`models.tileLoad`,createEvent(`model.tileLoad`,{work:e.work,model:e,tile:t.tile}))},s=t=>{this.emit(`models.tileUnload`,createEvent(`model.tileUnload`,{work:e.work,model:e,tile:t.tile}))},c=()=>{e.removeEventListener(`load`,t),e.removeEventListener(`error`,n),e.removeEventListener(`changeShownFloor`,r),e.removeEventListener(`tileLoad`,o),e.removeEventListener(`tileUnload`,s),e.removeEventListener(`dispose`,c)};e.addEventListener(`load`,t),e.addEventListener(`error`,n),e.addEventListener(`changeShownFloor`,r),e.addEventListener(`tileLoad`,o),e.addEventListener(`tileUnload`,s),e.addEventListener(`dispose`,c),this.emit(`model.request`,createEvent(`model.request`,{work:e.work,model:e,error:null}))}bindWorkFetcher(e){let t=this,n=e.workCode,r=e.allowHosts,o=new Fetcher({get networkSubscribe(){return t.networkSubscribe},requestProxy(e){return Promise.resolve(e).then(e=>t.requestProxy(e,n)).then(e=>{let t=verifyURL(e,r);return t instanceof Error?Promise.reject(t):t})}});registerFetcher(this.fiveId,e,o)}commonParams(){return{fiveId:this.fiveId,scene:this.scene,xrCustomObjectsScene:this.xrCustomObjectsScene,helper:this.helperGroup,camera:this.camera,renderer:this.renderer,viewport:this.viewport,element:this.getElement(),works:this.works,imageOptions:this.imageOptions,enableWheel:this.enableWheel,extraElements:this.extraElements,videoTexture:this.videoTexture,modelScene:this.modelScene}}applyController(t,n){if(!this.renderer)throw Error(`renderer is not initialized.`);let r=Controllers[t];this.currentMode=t;let o=new r(n);for(let e of PROXY_CONTROLLER_EVENT_NAMES)o.on(e,(...t)=>{if(this.emit(e,...t))return!1});{let e=Controllers[t].initAnimationEndState(n),r=n.initial.userAction;stateEqual(this.state,e)||(assignState(this.state,e),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state}))),this.emit(`currentState.change`,createEvent(`currentState.change`,{userAction:r,state:this.getCurrentState()}))}return o.on(`camera.update`,e=>{var t;if(this.controller){let n=this.controller.getTargetState();e.userAction&&this.syncingState===!1&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:e.userAction,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}this.emit(`currentState.change`,createEvent(`currentState.change`,{userAction:e.userAction,state:this.getCurrentState()}))}),o.on(`initAnimation.start`,e=>{var t;let{state:n,userAction:r}=e;r&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}),o.on(`initAnimation.end`,e=>{var t;let{state:n,userAction:r}=e;this.pano={workCode:n.workCode,panoIndex:n.panoIndex},r&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}),o.on(`pano.moveTo`,e=>{var t;let{state:n,userAction:r}=e;this.pano={workCode:n.workCode,panoIndex:n.panoIndex},r&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}),o.on(`pano.arrived`,e=>{var t;let{state:n,userAction:r}=e;this.pano={workCode:n.workCode,panoIndex:n.panoIndex},r&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}),o.on(`pano.cancel`,e=>{var t;let{state:n,userAction:r}=e;r&&this.state.mode===n.mode&&!stateEqual(this.state,n)&&(assignState(this.state,n),this.emit(`state.change`,createEvent(`state.change`,{userAction:r,state:this.state})),(t=this.analysis)==null||t.state(this.works,this.state))}),o.on(`pano.moveTo`,e=>{let{userAction:t}=e;this.emit(`currentState.change`,createEvent(`currentState.change`,{userAction:t,state:this.getCurrentState()}))}),o.on(`pano.request`,e=>{this.emit(`pano.request`,e),e.defaultPrevented||this.moveToPano(e.state,e.options,e.userAction)}),o.on(`vr.requestExit`,()=>{this.currentMode===e.Mode.VRPanorama&&(this.exitFullscreen(),this.changeMode(e.Mode.Panorama))}),o.on(`error`,e=>this.throwError(e)),o}removeEventListeners(){}get internalLightsEnabled(){let e=this.scene.children.find(e=>e.name===`internalLights`);return e?e.visible:!1}set internalLightsEnabled(e){let t=this.scene.children.find(e=>e.name===`internalLights`);t&&(t.visible=e),t=this.modelScene.children.find(e=>e.name===`internalLights`),t&&(t.visible=e)}get scissor(){return this.viewport}setScissor(e){return this.setViewport(e)}getPose(){let{longitude:e,latitude:t,fov:n,offset:r,distance:o}=this.camera.copyPose();return{longitude:e,latitude:t,fov:n,offset:r.clone(),distance:o}}getLongitudeAndLatitude(){let{longitude:e,latitude:t}=this.getPose();return{longitude:e,latitude:t}}getOffset(){return this.getPose().offset}getCameraLocal(){if(this.pano.workCode&&this.controller&&this.works){let e=this.works.getObserver(this.pano);if(e){let t=new three.Object3D;t.matrix.copy(e.matrix).premultiply(e.work.transform),t.matrix.decompose(t.position,t.quaternion,t.scale),t.matrixAutoUpdate=!1;let n=new three.Vector3(0,0,-1);n.applyQuaternion(this.camera.quaternion);let r=t.quaternion.clone().inverse();return n.applyQuaternion(r),{theta:Math.atan2(n.x,-n.z),phi:-Math.asin(n.y),lookAtVector:n}}}return null}addPass(e){this.fiveRenderer.composer.addPass(e)}removePass(e){let t=this.fiveRenderer.composer.passes.indexOf(e);t!==-1&&this.fiveRenderer.composer.passes.splice(t,1)}insertPass(e,t){this.fiveRenderer.composer.insertPass(e,t)}get renderMode(){return this.fiveRenderer.renderMode}set renderMode(e){this.fiveRenderer.renderMode=e}get enableHQ(){return this.fiveRenderer.renderMode===`point-cloud-high-quality`}set enableHQ(e){this.fiveRenderer.renderMode=e?`point-cloud-high-quality`:`default`,this.needsRender=!0}get enableEDL(){return this.eyeDomeLightingPass.enabled}set enableEDL(e){this.eyeDomeLightingPass.enabled=e,this.needsRender=!0}get enableAdaptiveLuminance(){return this.adaptiveLuminancePass.enabled}set enableAdaptiveLuminance(e){this.adaptiveLuminancePass.enabled=e,this.needsRender=!0}get enableIOSEDR(){return!1}set enableIOSEDR(e){}get enablePostProcessing(){return!0}set enablePostProcessing(e){}get modelSceneNeedsRender(){return this.modelScene.needsRender}set modelSceneNeedsRender(e){this.modelScene.needsRender=e}};Five.Mode={Panorama:`Panorama`,Model:`Model`,Floorplan:`Floorplan`,Topview:`Topview`,Mapview:`Mapview`,VRPanorama:`VRPanorama`,XRPanorama:`XRPanorama`},typeof window<`u`&&Object.assign(window,{__FIVE_DEBUG__:{THREE:three,constructor:Five,instances:Five_Instances}});var XRButton=class{static createButton(e){let t=document.createElement(`button`);function n(){t.style.display=``,t.style.cursor=`pointer`,t.style.left=`calc(50% - 50px)`,t.style.width=`100px`,t.textContent=`ENTER VR`,t.onmouseenter=function(){t.style.opacity=`1.0`},t.onmouseleave=function(){t.style.opacity=`0.5`},t.onclick=function(){e&&e()}}function r(){t.style.display=``,t.style.cursor=`auto`,t.style.left=`calc(50% - 75px)`,t.style.width=`150px`,t.onmouseenter=null,t.onmouseleave=null,t.onclick=null}function o(){r(),t.textContent=`VR NOT SUPPORTED`}function s(e){e.style.position=`absolute`,e.style.bottom=`20px`,e.style.padding=`12px 6px`,e.style.border=`1px solid #fff`,e.style.borderRadius=`4px`,e.style.background=`rgba(0,0,0,0.1)`,e.style.color=`#fff`,e.style.font=`normal 13px sans-serif`,e.style.textAlign=`center`,e.style.opacity=`0.5`,e.style.outline=`none`,e.style.zIndex=`999`}if(`xr`in navigator)return t.id=`VRButton`,t.style.display=`none`,s(t),navigator.xr.isSessionSupported(`immersive-vr`).then(function(e){e?n():o()}),t;{let e=document.createElement(`a`);return window.isSecureContext===!1?(e.href=document.location.href.replace(/^http:/,`https:`),e.innerHTML=`WEBXR NEEDS HTTPS`):(e.href=`https://immersiveweb.dev/`,e.innerHTML=`WEBXR NOT AVAILABLE`),e.style.left=`calc(50% - 90px)`,e.style.width=`180px`,e.style.textDecoration=`none`,s(e),e}}};exports.AdaptiveLuminancePass=AdaptiveLuminancePass,exports.AnimationFrameLoop=AnimationFrameLoop,exports.BoundingMesh=BoundingMesh,exports.Camera=Camera,exports.CustomShader=PBMCustomShader,exports.PBMCustomShader=PBMCustomShader,exports.EffectComposer=EffectComposer,exports.EyeDomeLightingPass=EyeDomeLightingPass,exports.Fetcher=Fetcher,exports.Five=Five,exports.FivePass=FivePass,exports.FiveRenderer=FiveRenderer,exports.FullScreenQuad=FullScreenQuad,exports.Histogram=Histogram,exports.InternalWebGLRenderer=InternalWebGLRenderer,exports.Model=Model,exports.ModelScene=ModelScene,exports.Motion=Motion,exports.NetworkSubscribe=NetworkSubscribe,exports.PBMContainer=PBMContainer,exports.PBMGSObject=PBMGaussianSplattingObject,exports.PBMGroup=PBMGroup,exports.PBMMesh=PBMMesh,exports.PBMMeshMaterial=PBMMeshMaterial,exports.PBMPanoFilter=PBMPanoFilter,exports.PBMPointCloud=PBMPointCloud,exports.PBMPointCloudMaterial=PBMPointCloudMaterial,exports.PBMSkinnedMesh=PBMSkinnedMesh,exports.PBMUpdateable=PBMUpdateable,exports.PROXY_CONTROLLER_EVENT_NAMES=PROXY_CONTROLLER_EVENT_NAMES,exports.PanoCircleMesh=PanoCircleMesh,exports.PanoCircleMeshCustom=PanoCircleMeshCustom,exports.PanoCircleMeshSolid=PanoCircleMeshSolid,exports.Parameter=Parameter,exports.Scene=Scene,exports.Subscribe=Subscribe,exports.TextureLoader=TextureLoader,exports.Tile=Tile,exports.Tile3D=Tile3D,exports.Tile3DModel=Tile3D,exports.TileCache=TileCache,exports.TileNode=TileNode,exports.TileRequestScheduler=TileRequestScheduler,exports.Tileset=Tileset,exports.Trajectory=Trajectory,exports.TrajectoryNode=TrajectoryNode,exports.Work=Work,exports.WorkResolvedObserver=WorkResolvedObserver,exports.XRButton=XRButton,exports.controllersDefaultInitArgs=controllersDefaultInitArgs,exports.coordinatesToVector=coordinatesToVector,exports.createDebugBoundingMesh=createDebugBoundingMesh,exports.createWorks=createWorks,exports.defaultImageURLTransform=imageURL,exports.draco=draco,exports.getViewportScale=getViewportScale,exports.headingToLongitude=headingToLongitude,exports.imageSupport=imageSupport,exports.isBoundingVolume=isBoundingVolume,exports.isPanoId=isPanoId,exports.ktx2=ktx2,exports.loadAt3d=loadAt3d,exports.loadB3dm=loadB3dm,exports.loadDome=loadDome,exports.loadDomez=loadDomez,exports.loadFbx=loadFbx,exports.loadGltf=loadGltf,exports.loadPbm=loadPbm,exports.loadPly=loadPly,exports.loadPnts=loadPnts,exports.loadSplat=loadSplat,exports.loadSpz=loadSpz,exports.loadX3p=loadX3p,exports.longitudeToHeading=longitudeToHeading,exports.makeBoundingVolume=makeBoundingVolume,exports.panoEqual=panoEqual,exports.panoParse=panoParse,exports.panoStringify=panoStringify,exports.parseWork=parseWork,exports.vectorToCoordinates=vectorToCoordinates,exports.workToJson=workToJson});