@realsee/five 6.7.0-alpha.9 → 6.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/docs/assets/hierarchy.js +1 -1
- package/docs/assets/navigation.js +1 -1
- package/docs/assets/search.js +1 -1
- package/docs/classes/five.AdaptiveLuminancePass.html +22 -0
- package/docs/classes/five.AnimationFrameLoop.html +4 -4
- package/docs/classes/five.BoundingMesh.html +4 -0
- package/docs/classes/five.Camera.html +6 -5
- package/docs/classes/five.EffectComposer.html +21 -0
- package/docs/classes/five.EyeDomeLightingPass.html +21 -0
- package/docs/classes/five.Five.html +90 -76
- package/docs/classes/five.FivePass.html +18 -0
- package/docs/classes/five.FiveRenderer.html +9 -0
- package/docs/classes/five.FullScreenQuad.html +6 -0
- package/docs/classes/five.InternalWebGLRenderer.html +1 -1
- package/docs/classes/five.Model.html +32 -31
- package/docs/classes/five.ModelScene.html +23 -20
- package/docs/classes/five.NetworkSubscribe.html +1 -1
- package/docs/classes/five.PBMContainer.html +1 -1
- package/docs/classes/five.PBMGroup.html +1 -1
- package/docs/classes/five.PBMMesh.html +1 -1
- package/docs/classes/five.PBMMeshMaterial.html +6 -7
- package/docs/classes/five.PBMPointCloud.html +1 -1
- package/docs/classes/five.PBMPointCloudMaterial.html +5 -6
- package/docs/classes/five.PBMSkinnedMesh.html +1 -1
- package/docs/classes/five.PanoCircleMesh.html +3 -3
- package/docs/classes/five.PanoCircleMeshCustom.html +4 -4
- package/docs/classes/five.PanoCircleMeshSolid.html +5 -5
- package/docs/classes/five.Parameter.html +44 -47
- package/docs/classes/five.Scene.html +1 -1
- package/docs/classes/five.Subscribe.html +1 -1
- package/docs/classes/five.TextureLoader.html +2 -2
- package/docs/classes/five.Tile3D.html +21 -21
- package/docs/classes/five.TileNode.html +4 -3
- package/docs/classes/five.Tileset.html +4 -4
- package/docs/classes/five.TrajectoryNode.html +1 -1
- package/docs/classes/five.Work.html +16 -16
- package/docs/classes/five.WorkResolvedObserver.html +20 -21
- package/docs/classes/gltf-loader.DDSLoader.html +1 -1
- package/docs/classes/gltf-loader.DRACOLoader.html +1 -1
- package/docs/classes/gltf-loader.GLTFLoader.html +1 -1
- package/docs/classes/gltf-loader.GLTFObject.html +1 -1
- package/docs/classes/gltf-loader.THREEGLTFLoader.html +1 -1
- package/docs/classes/line.Line.html +1 -1
- package/docs/classes/line.LineGeometry.html +1 -1
- package/docs/classes/line.LineMaterial.html +1 -1
- package/docs/classes/line.LineSegmentsGeometry.html +1 -1
- package/docs/classes/line.THREE_Line2.html +1 -1
- package/docs/classes/line.THREE_LineSegments2.html +1 -1
- package/docs/classes/plugins.BasePlugin.Controller.html +1 -1
- package/docs/classes/plugins.RoundedBoxGeometry.html +1 -1
- package/docs/classes/sticker.Sticker.html +1 -1
- package/docs/classes/vfx.Airflow.html +1 -1
- package/docs/classes/vfx.Flame.html +1 -1
- package/docs/classes/vfx.Particle.html +1 -1
- package/docs/classes/vfx.ParticleGPU.html +1 -1
- package/docs/classes/vfx.SpotLight.html +1 -1
- package/docs/functions/five.loadAt3d.html +1 -1
- package/docs/functions/five.parseWork.html +1 -1
- package/docs/functions/five.workToJson.html +1 -1
- package/docs/functions/plugins.DynamicPathLinePlugin.html +1 -0
- package/docs/functions/react.withFive.html +1 -1
- package/docs/functions/vue.useFiveWorks.html +2 -2
- package/docs/hierarchy.html +1 -1
- package/docs/interfaces/five.AddableObject.html +1 -1
- package/docs/interfaces/five.AjaxOptions.html +1 -1
- package/docs/interfaces/five.AnimationFrame.html +3 -2
- package/docs/interfaces/five.AnimationFrameContext.html +2 -2
- package/docs/interfaces/five.BaseEvent.html +1 -1
- package/docs/interfaces/five.EventCallback.html +1 -1
- package/docs/interfaces/five.FiveInitArgs.html +3 -3
- package/docs/interfaces/five.FiveLoadOptions.html +8 -10
- package/docs/interfaces/five.GestureEvent.html +1 -1
- package/docs/interfaces/five.ImageOptions.html +1 -1
- package/docs/interfaces/five.IntersectEvent.html +1 -1
- package/docs/interfaces/five.IntersectMesh.html +2 -2
- package/docs/interfaces/five.IntersectMeshInterface.html +1 -1
- package/docs/interfaces/five.Intersection.html +1 -1
- package/docs/interfaces/five.LoosePanoWork.html +2 -2
- package/docs/interfaces/five.LooseWork.html +2 -2
- package/docs/interfaces/five.LooseWorkInitial.html +2 -2
- package/docs/interfaces/five.LooseWorkModel.html +3 -2
- package/docs/interfaces/five.LooseWorkObserver.html +3 -2
- package/docs/interfaces/five.LooseWorkPanorama.html +8 -8
- package/docs/interfaces/five.LooseWorkVideo.html +2 -2
- package/docs/interfaces/five.LooseWorkWithExtrinsics.html +7 -7
- package/docs/interfaces/five.ModeChangeEvent.html +2 -2
- package/docs/interfaces/five.ModelControllerCustomInitArgs.html +5 -3
- package/docs/interfaces/five.ModelEvent.html +2 -2
- package/docs/interfaces/five.ModelOptions.html +11 -0
- package/docs/interfaces/five.ModelSceneEvent.html +2 -2
- package/docs/interfaces/five.MovePanoOptions.html +1 -1
- package/docs/interfaces/five.NetworkAbortError.html +1 -1
- package/docs/interfaces/five.NetworkFirbiddenError.html +1 -1
- package/docs/interfaces/five.NetworkOptions.html +1 -1
- package/docs/interfaces/five.NetworkProxyError.html +1 -1
- package/docs/interfaces/five.NetworkResourceEvent.html +2 -2
- package/docs/interfaces/five.NetworkResponseError.html +1 -1
- package/docs/interfaces/five.NetworkTimeoutError.html +1 -1
- package/docs/interfaces/five.ObjectEvent.html +2 -2
- package/docs/interfaces/five.PBMMaterial.html +1 -1
- package/docs/interfaces/five.PBMMeshMaterialParameters.html +2 -3
- package/docs/interfaces/five.PBMPointCloudMaterialParameters.html +2 -3
- package/docs/interfaces/five.PanoCircleMeshInterface.html +1 -1
- package/docs/interfaces/five.PanoCircleMeshSolidOptions.html +2 -2
- package/docs/interfaces/five.PanoEvent.html +1 -1
- package/docs/interfaces/five.PanoTextureEvent.html +1 -1
- package/docs/interfaces/five.PanoramaControllerCustomInitArgs.html +12 -10
- package/docs/interfaces/five.PanoramaLikeControllerCustomInitArgs.html +5 -3
- package/docs/interfaces/five.ParameterMaterialValue.html +29 -31
- package/docs/interfaces/five.ParameterTilesetValue.html +15 -16
- package/docs/interfaces/five.ParameterValue.html +43 -46
- package/docs/interfaces/five.Pass.html +9 -0
- package/docs/interfaces/five.Pose.html +1 -1
- package/docs/interfaces/five.RenderEvent.html +2 -2
- package/docs/interfaces/five.ResolvedParameterValue.html +43 -46
- package/docs/interfaces/five.State.html +1 -1
- package/docs/interfaces/five.StateEvent.html +1 -1
- package/docs/interfaces/five.TextureOptions.html +1 -1
- package/docs/interfaces/five.TilesetOptions.html +2 -2
- package/docs/interfaces/five.TopviewControllerCustomInitArgs.html +7 -3
- package/docs/interfaces/five.VRPanoramaControllerCustomInitArgs.html +12 -10
- package/docs/interfaces/five.ViewLayer.html +21 -21
- package/docs/interfaces/five.WorkCubeImage.html +2 -2
- package/docs/interfaces/five.WorkImage.html +5 -3
- package/docs/interfaces/five.WorkInitial.html +8 -8
- package/docs/interfaces/five.WorkModel.html +9 -7
- package/docs/interfaces/five.WorkModelJson.html +3 -2
- package/docs/interfaces/five.WorkModelLayer.html +7 -2
- package/docs/interfaces/five.WorkModelLayerJson.html +2 -2
- package/docs/interfaces/five.WorkObserver.html +21 -22
- package/docs/interfaces/five.WorkObserverJson.html +4 -2
- package/docs/interfaces/five.WorkPanoramaJson.html +2 -2
- package/docs/interfaces/five.WorkPanoramasJson.html +2 -2
- package/docs/interfaces/five.WorkTile.html +4 -4
- package/docs/interfaces/five.WorkVideo.html +4 -4
- package/docs/interfaces/five.WorksEvent.html +2 -3
- package/docs/interfaces/five.XRControllerEvent.html +1 -1
- package/docs/interfaces/five.XRGestureEvent.html +1 -1
- package/docs/interfaces/five.XRPanoramaControllerCustomInitArgs.html +12 -10
- package/docs/interfaces/five.XRSessionEvent.html +1 -1
- package/docs/interfaces/plugins.BackgroundPluginController.html +1 -1
- package/docs/interfaces/plugins.BackgroundPluginType.EventMap.html +1 -1
- package/docs/interfaces/plugins.BasePlugin.State.html +1 -1
- package/docs/interfaces/plugins.DynamicPathLinePluginController.html +83 -0
- package/docs/interfaces/plugins.DynamicPathLinePluginType.Config.html +36 -0
- package/docs/interfaces/plugins.DynamicPathLinePluginType.EventMap.html +26 -0
- package/docs/interfaces/plugins.DynamicPathLinePluginType.Params.html +6 -0
- package/docs/interfaces/plugins.DynamicPathLinePluginType.PathConfig.html +28 -0
- package/docs/interfaces/plugins.DynamicPathLinePluginType.State.html +10 -0
- package/docs/interfaces/plugins.ItemMaskController.html +1 -1
- package/docs/interfaces/plugins.ItemMaskPluginType.EventMap.html +1 -1
- package/docs/interfaces/plugins.ItemMaskPluginType.State.html +1 -1
- package/docs/interfaces/plugins.OrientationPluginController.html +1 -1
- package/docs/interfaces/plugins.OrientationPluginType.EventMap.html +1 -1
- package/docs/interfaces/plugins.OrientationPluginType.State.html +1 -1
- package/docs/interfaces/plugins.PanoAnimeController.html +1 -1
- package/docs/interfaces/plugins.PanoAnimePluginType.EventMap.html +1 -1
- package/docs/interfaces/plugins.PanoAnimePluginType.State.html +1 -1
- package/docs/interfaces/plugins.PluginTemplateType.EventMap.html +1 -1
- package/docs/interfaces/plugins.PluginTemplateType.State.html +1 -1
- package/docs/interfaces/plugins.TrajectoryController.html +1 -1
- package/docs/interfaces/react.FiveInjectionTypes.html +4 -4
- package/docs/modules/five.html +1 -1
- package/docs/modules/plugins.DynamicPathLinePluginType.html +1 -0
- package/docs/modules/plugins.html +1 -1
- package/docs/types/five.AnimationFrameLoopType.html +1 -1
- package/docs/types/five.Models.html +4 -4
- package/docs/types/five.ParseOptions.html +6 -6
- package/docs/types/five.PostProcessingType.html +1 -1
- package/docs/types/five.RequestAnimationFrameArgs.html +1 -0
- package/docs/types/five.TilesetFrameState.html +2 -3
- package/docs/types/plugins.BasePlugin.EventMap.html +1 -1
- package/docs/types/plugins.DynamicPathLinePluginType.PluginData.html +3 -0
- package/docs/types/plugins.DynamicPathLinePluginType.ServerData.html +3 -0
- package/docs/types/vue.FiveProviderComponent.html +1 -1
- package/five/index.d.ts +311 -85
- package/five/index.js +299 -198
- package/five/index.mjs +7306 -6940
- package/gltf-loader/index.js +3 -3
- package/gltf-loader/index.mjs +146 -146
- package/line/index.js +3 -3
- package/line/index.mjs +10 -10
- package/package.json +1 -1
- package/plugins/index.d.ts +314 -0
- package/plugins/index.js +296 -15
- package/plugins/index.mjs +2615 -1503
- package/react/index.d.ts +1 -1
- package/react/index.js +2 -2
- package/react/index.mjs +2 -2
- package/shader-lib/index.d.ts +24 -1
- package/shader-lib/index.js +22 -13
- package/shader-lib/index.mjs +408 -171
- package/sticker/index.js +3 -3
- package/sticker/index.mjs +7 -7
- package/umd/five-gltf-loader.js +3 -3
- package/umd/five-line.js +3 -3
- package/umd/five-plugins.js +296 -15
- package/umd/five-react.js +2 -2
- package/umd/five-shader-lib.js +22 -13
- package/umd/five-sticker.js +3 -3
- package/umd/five-vfx.js +2 -2
- package/umd/five-vue.js +2 -2
- package/umd/five.js +299 -198
- package/vfx/index.js +2 -2
- package/vfx/index.mjs +2 -2
- package/vue/index.d.ts +1 -1
- package/vue/index.js +2 -2
- package/vue/index.mjs +2 -2
- package/work-downloader/index.js +3 -3
- package/work-downloader/index.mjs +13 -11
- package/docs/interfaces/five.ModelLike.html +0 -3
- package/docs/types/five.Tile3dOptions.html +0 -1
package/plugins/index.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* @license
|
|
3
3
|
* @realsee/five
|
|
4
|
-
* Generated:
|
|
5
|
-
* Version: 6.7.0
|
|
4
|
+
* Generated: 12/29/2025
|
|
5
|
+
* Version: 6.7.0
|
|
6
6
|
* Terms:
|
|
7
7
|
* Realsee SDK License Agreement
|
|
8
8
|
* Update: July 28, 2021
|
|
@@ -252,13 +252,13 @@
|
|
|
252
252
|
* No amendment to or modification of this Agreement will be binding unless in
|
|
253
253
|
* writing and signed by Realsee. You and Realsee hereto confirm that this
|
|
254
254
|
* Agreement and all related documents shall be drafted in English.
|
|
255
|
-
*/"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
255
|
+
*/"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const Se=require("@realsee/five"),N=require("three"),At=require("@realsee/five/plugins");function yn(h){const s=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(h){for(const e in h)if(e!=="default"){const n=Object.getOwnPropertyDescriptor(h,e);Object.defineProperty(s,e,n.get?n:{enumerable:!0,get:()=>h[e]})}}return s.default=h,Object.freeze(s)}const p=yn(N);function bn(h){return/^https?:\/\/|^\/\//.test(h)||/^data:/.test(h)}function wn(h,s){return bn(s)?s:"".concat(h).concat(s)}exports.BasePlugin=void 0;(function(h){var s=(function(){function e(n,t){this.hooks=new Se.Subscribe,this.staticPrefix="//vr-image-4.realsee-cdn.cn",this.five=n,t!=null&&t.staticPrefix&&(this.staticPrefix=t.staticPrefix)}return e.prototype.getCurrentState=function(){return this.state},e.prototype.absoluteUrl=function(n){return wn(this.staticPrefix,n)},e})();h.Controller=s})(exports.BasePlugin||(exports.BasePlugin={}));var Pt=function(h,s){return Pt=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,n){e.__proto__=n}||function(e,n){for(var t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=n[t])},Pt(h,s)};function de(h,s){if(typeof s!="function"&&s!==null)throw new TypeError("Class extends value "+String(s)+" is not a constructor or null");Pt(h,s);function e(){this.constructor=h}h.prototype=s===null?Object.create(s):(e.prototype=s.prototype,new e)}var j=function(){return j=Object.assign||function(s){for(var e,n=1,t=arguments.length;n<t;n++){e=arguments[n];for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&(s[r]=e[r])}return s},j.apply(this,arguments)};function Fe(h,s,e,n){function t(r){return r instanceof e?r:new e(function(l){l(r)})}return new(e||(e=Promise))(function(r,l){function o(m){try{c(n.next(m))}catch(y){l(y)}}function d(m){try{c(n.throw(m))}catch(y){l(y)}}function c(m){m.done?r(m.value):t(m.value).then(o,d)}c((n=n.apply(h,s||[])).next())})}function Ie(h,s){var e={label:0,sent:function(){if(r[0]&1)throw r[1];return r[1]},trys:[],ops:[]},n,t,r,l=Object.create((typeof Iterator=="function"?Iterator:Object).prototype);return l.next=o(0),l.throw=o(1),l.return=o(2),typeof Symbol=="function"&&(l[Symbol.iterator]=function(){return this}),l;function o(c){return function(m){return d([c,m])}}function d(c){if(n)throw new TypeError("Generator is already executing.");for(;l&&(l=0,c[0]&&(e=0)),e;)try{if(n=1,t&&(r=c[0]&2?t.return:c[0]?t.throw||((r=t.return)&&r.call(t),0):t.next)&&!(r=r.call(t,c[1])).done)return r;switch(t=0,r&&(c=[c[0]&2,r.value]),c[0]){case 0:case 1:r=c;break;case 4:return e.label++,{value:c[1],done:!1};case 5:e.label++,t=c[1],c=[0];continue;case 7:c=e.ops.pop(),e.trys.pop();continue;default:if(r=e.trys,!(r=r.length>0&&r[r.length-1])&&(c[0]===6||c[0]===2)){e=0;continue}if(c[0]===3&&(!r||c[1]>r[0]&&c[1]<r[3])){e.label=c[1];break}if(c[0]===6&&e.label<r[1]){e.label=r[1],r=c;break}if(r&&e.label<r[2]){e.label=r[2],e.ops.push(c);break}r[2]&&e.ops.pop(),e.trys.pop();continue}c=s.call(h,e)}catch(m){c=[6,m],t=0}finally{n=r=0}if(c[0]&5)throw c[1];return{value:c[0]?c[1]:void 0,done:!0}}}function zt(h,s,e){if(e||arguments.length===2)for(var n=0,t=s.length,r;n<t;n++)(r||!(n in s))&&(r||(r=Array.prototype.slice.call(s,0,n)),r[n]=s[n]);return h.concat(r||Array.prototype.slice.call(s))}function En(h){return new Promise(function(s,e){var n=new Image;n.onload=function(){n.onload=n.onerror=function(){},s(n)},n.onerror=function(t){n.onload=n.onerror=function(){},e(t)},n.crossOrigin="",n.src=h})}var Tn=typeof performance!="undefined"&&typeof performance.timing!="undefined"?performance.timing.navigationStart:Date.now(),gt=typeof performance!="undefined"?(function(){return Tn+performance.now()}):(function(){return Date.now()});function at(h,s,e){return h+(s-h)*e}function Pn(h,s,e,n){var t=(s*e+2*h)/Math.pow(e,3),r=-(2*s*e+3*h)/Math.pow(e,2),l=s,o=h;return t*Math.pow(n,3)+r*Math.pow(n,2)+l*n+o}function Mn(h,s,e,n){var t=(s*e+2*h)/Math.pow(e,3),r=-(2*s*e+3*h)/Math.pow(e,2),l=s;return 3*t*Math.pow(n,2)+2*r*n+l}function An(h,s,e,n){var t=n[1]-n[0];return h=it(h,n),s=it(s,n),s-h>t/2?at(h+t,s,e):h-s>t/2?at(h-t,s,e):at(h,s,e)}function it(h,s){var e=s[1]-s[0];return h<s[0]?it(h+e,s):h>=s[1]?it(h-e,s):h}function Sn(h,s,e,n){return n?An(h,s,e,n):at(h,s,e)}var Gt=(function(){function h(s){this.config={},this.progress=1,this.ended=!0,this.value={},this.startTime=gt(),this.startVelocity=0,this.duration=0,this.keyframes=[];for(var e in s){var n=s[e];typeof n=="number"?(this.value[e]=n,this.config[e]={circle:!1}):(this.value[e]=n.value,this.config[e]={circle:n.circle})}this.keyframes=[{progress:0,value:j({},this.value)},{progress:1,value:j({},this.value)}]}return h.prototype.getProgress=function(s){var e=s-this.startTime;return e<0?0:e>=this.duration?1:1-Pn(1,this.startVelocity,this.duration,e)},h.prototype.getValue=function(s){for(var e=1;e<this.keyframes.length;e++)if(this.keyframes[e].progress>s){var n=this.keyframes[e-1],t=this.keyframes[e],r={};for(var l in this.config){var o=(s-n.progress)/(t.progress-n.progress);r[l]=Sn(n.value[l],t.value[l],o,this.config[l].circle)}return r}return j({},this.keyframes[this.keyframes.length-1].value)},h.prototype.getProgressVelocity=function(s){var e=s-this.startTime;return e>=this.duration?0:Mn(1,this.startVelocity,this.duration,e)},h.prototype.update=function(s){return this.ended?!0:(this.progress=Math.min(1,Math.max(0,this.progress,this.getProgress(s))),this.value=this.getValue(this.progress),this.ended=this.progress>=1,this.ended&&this.callbacks&&(this.callbacks[0](),this.callbacks=void 0),this.ended)},h.prototype.getKeyFrameSegment=function(s){for(var e=this.getProgress(s),n=1;n<this.keyframes.length;n++)if(this.keyframes[n].progress>e)return[this.keyframes[n-1],this.keyframes[n]];return[this.keyframes[this.keyframes.length-2],this.keyframes[this.keyframes.length-1]]},h.prototype.getTargetKeyframe=function(){return this.keyframes[this.keyframes.length-1]},h.prototype.set=function(s,e,n,t){var r;n===void 0&&(n=0),isNaN(e)&&(e=0),isNaN(n)&&(n=0),t=t!=null?t:gt();var l=this.getProgress(t),o=this.getValue(l),d={};for(var c in this.config)d[c]=(r=s[c])!==null&&r!==void 0?r:o[c];var m=[{progress:0,value:o},{progress:1,value:d}];return this.setKeyframes(m,e,n,t)},h.prototype.setKeyframes=function(s,e,n,t){var r=this;if(n===void 0&&(n=0),s.length<2)throw new Error("keyframes invalid.");return isNaN(e)&&(e=0),isNaN(n)&&(n=0),this.callbacks&&(this.callbacks[1](new Error("motion aborted.")),this.callbacks=void 0),new Promise(function(l,o){t=t!=null?t:gt(),r.progress=0,r.ended=!1,r.startTime=t,r.startVelocity=n,r.keyframes=s,r.duration=e,e===0?(r.progress=1,r.value=j({},s[s.length-1].value)):r.value=j({},s[0].value),r.callbacks=[l,o]})},h.prototype.dispose=function(){this.callbacks&&(this.callbacks[1](new Error("motion dispose.")),this.callbacks=void 0)},h})(),xn=[{progress:0,value:{scale:0,opacity:0,shadow:2}},{progress:.2,value:{scale:.5,opacity:1,shadow:1}},{progress:.8,value:{scale:2,opacity:0,shadow:.5}},{progress:1,value:{scale:2,opacity:0,shadow:.5}}],On=[{progress:0,value:{scale:0,opacity:0,shadow:2}},{progress:.2,value:{scale:.4,opacity:1,shadow:2}},{progress:.8,value:{scale:1.6,opacity:.4,shadow:.5}},{progress:1,value:{scale:2,opacity:0,shadow:.5}}],_n=`
|
|
256
256
|
varying vec2 vUv;
|
|
257
257
|
void main() {
|
|
258
258
|
vUv = uv;
|
|
259
259
|
gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);
|
|
260
260
|
}
|
|
261
|
-
`,
|
|
261
|
+
`,Cn=`
|
|
262
262
|
varying vec2 vUv;
|
|
263
263
|
uniform sampler2D map;
|
|
264
264
|
uniform vec4 color;
|
|
@@ -304,7 +304,7 @@ void main() {
|
|
|
304
304
|
}
|
|
305
305
|
}
|
|
306
306
|
}
|
|
307
|
-
`,
|
|
307
|
+
`,Ln=(function(h){de(s,h);function s(e,n){var t=h.call(this,e)||this;t.canvas=document.createElement("canvas"),t.group=new p.Group,t.wrapper=document.createElement("div"),t.style=document.createElement("style"),t.itemMaskMesh=(function(){var o=new p.Mesh(new p.SphereBufferGeometry(1,60,40),new p.ShaderMaterial({vertexShader:_n,fragmentShader:Cn,uniforms:{map:{value:new p.Texture},color:{value:new p.Vector4}},depthWrite:!1,depthTest:!1,transparent:!0}));return o.renderOrder=-3,o.geometry.rotateY(-Math.PI/2),o.geometry.scale(-1,1,1),o})(),t.onFivePanoArrived=function(o){t.state.mode==="mask"&&t.loadPanoMask(o)},t.onFiveWantsMoveToPano=function(o){t.state.mode==="box"&&t.select()},t.loadPanoMask=function(o){return Fe(t,void 0,void 0,function(){var d,c,m,y,M,w,A,S,C,E;return Ie(this,function(b){switch(b.label){case 0:return d=this,c=d.five,m=d.canvas,y=d.itemMaskMesh,M=d.data,w=m.getContext("2d"),A=c.observers[o],S=(E=M==null?void 0:M.object_mask_list.find(function(T){return T.derived_id===String(A.derivedId)}))===null||E===void 0?void 0:E.object_mask_url,S?[4,En(S)]:[2];case 1:return C=b.sent(),m.width=C.width,m.height=C.height,w==null||w.drawImage(C,0,0,C.width,C.height),y.material.uniforms.map.value.image=C,y.material.uniforms.map.value.minFilter=p.LinearFilter,y.material.uniforms.map.value.needsUpdate=!0,y.position.copy(A.position),y.quaternion.copy(A.quaternion),c.scene.add(y),c.needsRender=!0,[2]}})})},t.onFiveMouseMove=function(o){var d;if(t.state.mode==="mask"&&t.five.state.mode==="Panorama"){var c=t,m=c.five,y=c.itemMaskMesh,M=m.observers[m.state.panoIndex],w=(d=o.pointers[0])===null||d===void 0?void 0:d.raycaster;if(w){var A=w.intersectObjects(t.group.children.filter(function(S){return S.userData.visible_viewpoint.includes(String(M.derivedId))}),!0)[0];A?y.material.uniforms.color.value=A.object.userData.color:y.material.uniforms.color.value=new p.Vector4(0,0,0,1)}}},t.onFiveTapGesture=function(o){var d=t.five,c=d.observers[d.state.panoIndex];if(o){var m=o.intersectObjects(t.group.children.filter(function(w){return w.userData.visible_viewpoint.includes(String(c.derivedId))}),!0)[0];if(m){t.select(m.object.name),t.stopAnimation&&t.stopAnimation(),t.tapPosition=m.point,t.changeTapScreenPosition();var y=new Gt({opacity:0,scale:0,shadow:2}),M=new Gt({opacity:0,scale:0,shadow:2});return y.setKeyframes(xn,1e3),M.setKeyframes(On,1e3),t.stopAnimation=Se.AnimationFrameLoop.shared.add(function(w,A){var S,C=y.update(w),E=M.update(w);t.wrapper.firstChild.style.opacity="".concat(y.value.opacity),t.wrapper.firstChild.style.transform="scale(".concat(y.value.scale,")"),t.wrapper.firstChild.style.boxShadow="0 0 0 ".concat(y.value.shadow,"px #fff"),t.wrapper.lastChild.style.opacity="".concat(M.value.opacity),t.wrapper.lastChild.style.transform="scale(".concat(M.value.scale,")"),t.wrapper.lastChild.style.boxShadow="0 0 0 ".concat(M.value.shadow,"px #fff"),C&&E&&((S=t.stopAnimation)===null||S===void 0||S.call(t),t.stopAnimation=void 0,d.getElement().parentElement.removeChild(t.wrapper))},!1,0,10),d.getElement().parentElement.appendChild(t.wrapper),!1}}},t.changeTapScreenPosition=function(){if(t.tapPosition){var o=t.tapPosition.clone().project(t.five.camera),d=(o.x+1)/2,c=-(o.y-1)/2;t.wrapper.style.opacity=o.z>0&&o.z<1?"1":"0",t.wrapper.style.transform="translate(".concat(d*100,"%, ").concat(c*100,"%)")}},t.onFiveCameraUpdate=function(o){t.changeTapScreenPosition()},t.dispose=function(){t.disable()},t.five=e;var r={enabled:!0,visible:!0,mode:"box",selectedId:null,selectAll:!1};t.state=Object.assign(r,n==null?void 0:n.initialState);var l=j({},n==null?void 0:n.config);return t._config=l,t.group.rotateX(Math.PI),t.wrapper.className="ItemMaskPlugin",t.wrapper.innerHTML='<span class="ItemMaskPluginCircle"></span><span class="ItemMaskPluginCircle"></span>',t.style.innerHTML=`
|
|
308
308
|
.ItemMaskPlugin {
|
|
309
309
|
position: absolute;
|
|
310
310
|
top: 0;
|
|
@@ -322,7 +322,7 @@ void main() {
|
|
|
322
322
|
border-radius: 50%;
|
|
323
323
|
box-shadow: 0px 0px 0px 2px #fff;
|
|
324
324
|
}
|
|
325
|
-
`,t.state.enabled&&t._enable({userAction:!1}),t}return Object.defineProperty(
|
|
325
|
+
`,t.state.enabled&&t._enable({userAction:!1}),t}return Object.defineProperty(s.prototype,"config",{get:function(){return j({},this._config)},enumerable:!1,configurable:!0}),s.prototype.updateState=function(e,n){var t=this.state;this.state=j(j({},this.state),e),this.hooks.emit("stateChange",{state:this.state,prevState:t,userAction:n})},s.prototype.load=function(e){return Fe(this,void 0,void 0,function(){var n,t,r=this;return Ie(this,function(l){return this.data=e,n=e.data_list.map(function(o){var d,c=o.position.end.map(function(_){return Number(_)}),m=o.position.start.map(function(_){return Number(_)}),y=Math.abs(c[0]-m[0]),M=Math.abs(c[1]-m[1]),w=Math.abs(c[2]-m[2]),A=c[0]/2+m[0]/2,S=c[1]/2+m[1]/2,C=c[2]/2+m[2]/2,E=new p.Vector3(A,S,C),b=new p.BoxBufferGeometry(y,M,w),T=new p.ShaderMaterial({vertexShader:`
|
|
326
326
|
varying vec2 vUv;
|
|
327
327
|
void main() {
|
|
328
328
|
vUv = uv;
|
|
@@ -347,13 +347,13 @@ void main() {
|
|
|
347
347
|
gl_FragColor = vec4(1.0, 1.0, 1.0, alpha / 4.0 * opacity);
|
|
348
348
|
}
|
|
349
349
|
}
|
|
350
|
-
`,side:
|
|
350
|
+
`,side:p.DoubleSide,visible:r.state.selectedId==="".concat(o.category_name).concat(o.index),uniforms:{opacity:{value:r.state.mode==="box"?1:0}},depthWrite:!1,depthTest:!1,transparent:!0}),f=new p.Mesh(b,T);return f.position.copy(E),f.name="".concat(o.category_name).concat(o.index),f.userData.color=new((d=p.Vector4).bind.apply(d,zt(zt([void 0],o.mask_color.map(function(_){return _/255}).reverse(),!1),[1],!1))),f.userData.visible_viewpoint=Object.keys(o.visible_viewpoint),f}),(t=this.group).add.apply(t,n),[2]})})},s.prototype.setState=function(e,n){n===void 0&&(n={});var t=this.state,r=n.userAction!==void 0?n.userAction:!0;if(this.updateState(e,r),e.enabled!==void 0&&t.enabled!==e.enabled){var l={userAction:r};e.enabled?this._enable(l):this._disable(l)}},s.prototype.setMode=function(e){this.updateState({mode:e},!1),e==="mask"?(this.group.children.forEach(function(n){n.material.uniforms.opacity.value=0}),this.loadPanoMask(this.five.state.panoIndex)):e==="box"&&(this.itemMaskMesh.material.uniforms.color.value=new p.Vector4(0,0,0,1),this.group.children.forEach(function(n){n.material.uniforms.opacity.value=1}),this.five.needsRender=!0)},s.prototype.select=function(e,n){var t=this,r;this.updateState({selectedId:e!=null?e:null},(r=n==null?void 0:n.userAction)!==null&&r!==void 0?r:!1),this.group.children.forEach(function(l){l.material.visible=t.state.selectAll||l.name===e}),this.five.needsRender=!0},s.prototype.selectAll=function(e){e===void 0&&(e=!0),this.updateState({selectAll:!!e},!1),this.select()},s.prototype._enable=function(e){this.five.on("panoArrived",this.onFivePanoArrived),this.five.on("wantsMoveToPano",this.onFiveWantsMoveToPano),this.five.on("gesture.mousemove",this.onFiveMouseMove),this.five.on("wantsTapGesture",this.onFiveTapGesture),this.five.on("cameraUpdate",this.onFiveCameraUpdate),this.five.scene.add(this.group),document.head.appendChild(this.style)},s.prototype._disable=function(e){this.five.off("panoArrived",this.onFivePanoArrived),this.five.off("wantsMoveToPano",this.onFiveWantsMoveToPano),this.five.off("gesture.mousemove",this.onFiveMouseMove),this.five.off("wantsTapGesture",this.onFiveTapGesture),this.five.off("cameraUpdate",this.onFiveCameraUpdate),this.five.scene.remove(this.group),document.head.removeChild(this.style)},s.prototype.enable=function(e){var n;if(!this.state.enabled){var t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.updateState({enabled:!0},t),this._enable({userAction:t})}},s.prototype.disable=function(e){var n;if(this.state.enabled!==!1){var t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.updateState({enabled:!1},t),this._disable({userAction:t})}},s})(exports.BasePlugin.Controller),Fn=function(h,s){return new Ln(h,s)};/*! Hammer.JS - v2.0.7 - 2016-04-22
|
|
351
351
|
* http://hammerjs.github.io/
|
|
352
352
|
*
|
|
353
353
|
* Copyright (c) 2016 Jorik Tangelder;
|
|
354
|
-
* Licensed under the MIT license */var yt=(function(
|
|
355
|
-
`+
|
|
356
|
-
`;return function(){var m=new Error("get-stack-trace"),E=m&&m.stack?m.stack.replace(/^[^\(]+?[\n$]/gm,"").replace(/^\s+at\s+/gm,"").replace(/^Object.<anonymous>\s*\(/gm,"{anonymous}()@"):"Unknown Stack Trace",k=f.console&&(f.console.warn||f.console.log);return k&&k.call(f.console,h,E),n.apply(this,arguments)}}var O;typeof Object.assign!="function"?O=function(r){if(r===a||r===null)throw new TypeError("Cannot convert undefined or null to object");for(var i=Object(r),h=1;h<arguments.length;h++){var m=arguments[h];if(m!==a&&m!==null)for(var E in m)m.hasOwnProperty(E)&&(i[E]=m[E])}return i}:O=Object.assign;var C=P(function(r,i,h){for(var m=Object.keys(i),E=0;E<m.length;)(!h||h&&r[m[E]]===a)&&(r[m[E]]=i[m[E]]),E++;return r},"extend","Use `assign`."),D=P(function(r,i){return C(r,i,!0)},"merge","Use `assign`.");function b(n,r,i){var h=r.prototype,m;m=n.prototype=Object.create(h),m.constructor=n,m._super=h,i&&O(m,i)}function y(n,r){return function(){return n.apply(r,arguments)}}function x(n,r){return typeof n==c?n.apply(r&&r[0]||a,r):n}function p(n,r){return n===a?r:n}function I(n,r,i){A(ne(r),function(h){n.addEventListener(h,i,!1)})}function M(n,r,i){A(ne(r),function(h){n.removeEventListener(h,i,!1)})}function te(n,r){for(;n;){if(n==r)return!0;n=n.parentNode}return!1}function Q(n,r){return n.indexOf(r)>-1}function ne(n){return n.trim().split(/\s+/g)}function ce(n,r,i){if(n.indexOf&&!i)return n.indexOf(r);for(var h=0;h<n.length;){if(i&&n[h][i]==r||!i&&n[h]===r)return h;h++}return-1}function me(n){return Array.prototype.slice.call(n,0)}function xe(n,r,i){for(var h=[],m=[],E=0;E<n.length;){var k=n[E][r];ce(m,k)<0&&h.push(n[E]),m[E]=k,E++}return h=h.sort(function(le,q){return le[r]>q[r]}),h}function ae(n,r){for(var i,h,m=r[0].toUpperCase()+r.slice(1),E=0;E<t.length;){if(i=t[E],h=i?i+m:r,h in n)return h;E++}return a}var oe=1;function U(){return oe++}function N(n){var r=n.ownerDocument||n;return r.defaultView||r.parentWindow||f}var S=/mobile|tablet|ip(ad|hone|od)|android/i,F="ontouchstart"in f,H=ae(f,"PointerEvent")!==a,re=F&&S.test(navigator.userAgent),G="touch",V="pen",K="mouse",Y="kinect",B=25,L=1,ee=2,z=4,X=8,Ae=1,we=2,Me=4,Ce=8,Ee=16,se=we|Me,he=Ce|Ee,Ue=se|he,Fe=["x","y"],Oe=["clientX","clientY"];function ie(n,r){var i=this;this.manager=n,this.callback=r,this.element=n.element,this.target=n.options.inputTarget,this.domHandler=function(h){x(n.options.enable,[n])&&i.handler(h)},this.init()}ie.prototype={handler:function(){},init:function(){this.evEl&&I(this.element,this.evEl,this.domHandler),this.evTarget&&I(this.target,this.evTarget,this.domHandler),this.evWin&&I(N(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&M(this.element,this.evEl,this.domHandler),this.evTarget&&M(this.target,this.evTarget,this.domHandler),this.evWin&&M(N(this.element),this.evWin,this.domHandler)}};function Xe(n){var r,i=n.options.inputClass;return i?r=i:H?r=lt:re?r=Ze:F?r=ct:r=Ke,new r(n,We)}function We(n,r,i){var h=i.pointers.length,m=i.changedPointers.length,E=r&L&&h-m===0,k=r&(z|X)&&h-m===0;i.isFirst=!!E,i.isFinal=!!k,E&&(n.session={}),i.eventType=r,u(n,i),n.emit("hammer.input",i),n.recognize(i),n.session.prevInput=i}function u(n,r){var i=n.session,h=r.pointers,m=h.length;i.firstInput||(i.firstInput=Z(r)),m>1&&!i.firstMultiple?i.firstMultiple=Z(r):m===1&&(i.firstMultiple=!1);var E=i.firstInput,k=i.firstMultiple,J=k?k.center:E.center,le=r.center=pe(h);r.timeStamp=d(),r.deltaTime=r.timeStamp-E.timeStamp,r.angle=st(J,le),r.distance=qe(J,le),R(i,r),r.offsetDirection=ge(r.deltaX,r.deltaY);var q=Ve(r.deltaTime,r.deltaX,r.deltaY);r.overallVelocityX=q.x,r.overallVelocityY=q.y,r.overallVelocity=g(q.x)>g(q.y)?q.x:q.y,r.scale=k?Xt(k.pointers,h):1,r.rotation=k?Gt(k.pointers,h):0,r.maxPointers=i.prevInput?r.pointers.length>i.prevInput.maxPointers?r.pointers.length:i.prevInput.maxPointers:r.pointers.length,W(i,r);var ve=n.element;te(r.srcEvent.target,ve)&&(ve=r.srcEvent.target),r.target=ve}function R(n,r){var i=r.center,h=n.offsetDelta||{},m=n.prevDelta||{},E=n.prevInput||{};(r.eventType===L||E.eventType===z)&&(m=n.prevDelta={x:E.deltaX||0,y:E.deltaY||0},h=n.offsetDelta={x:i.x,y:i.y}),r.deltaX=m.x+(i.x-h.x),r.deltaY=m.y+(i.y-h.y)}function W(n,r){var i=n.lastInterval||r,h=r.timeStamp-i.timeStamp,m,E,k,J;if(r.eventType!=X&&(h>B||i.velocity===a)){var le=r.deltaX-i.deltaX,q=r.deltaY-i.deltaY,ve=Ve(h,le,q);E=ve.x,k=ve.y,m=g(ve.x)>g(ve.y)?ve.x:ve.y,J=ge(le,q),n.lastInterval=r}else m=i.velocity,E=i.velocityX,k=i.velocityY,J=i.direction;r.velocity=m,r.velocityX=E,r.velocityY=k,r.direction=J}function Z(n){for(var r=[],i=0;i<n.pointers.length;)r[i]={clientX:l(n.pointers[i].clientX),clientY:l(n.pointers[i].clientY)},i++;return{timeStamp:d(),pointers:r,center:pe(r),deltaX:n.deltaX,deltaY:n.deltaY}}function pe(n){var r=n.length;if(r===1)return{x:l(n[0].clientX),y:l(n[0].clientY)};for(var i=0,h=0,m=0;m<r;)i+=n[m].clientX,h+=n[m].clientY,m++;return{x:l(i/r),y:l(h/r)}}function Ve(n,r,i){return{x:r/n||0,y:i/n||0}}function ge(n,r){return n===r?Ae:g(n)>=g(r)?n<0?we:Me:r<0?Ce:Ee}function qe(n,r,i){i||(i=Fe);var h=r[i[0]]-n[i[0]],m=r[i[1]]-n[i[1]];return Math.sqrt(h*h+m*m)}function st(n,r,i){i||(i=Fe);var h=r[i[0]]-n[i[0]],m=r[i[1]]-n[i[1]];return Math.atan2(m,h)*180/Math.PI}function Gt(n,r){return st(r[1],r[0],Oe)+st(n[1],n[0],Oe)}function Xt(n,r){return qe(r[0],r[1],Oe)/qe(n[0],n[1],Oe)}var Wt={mousedown:L,mousemove:ee,mouseup:z},qt="mousedown",Kt="mousemove mouseup";function Ke(){this.evEl=qt,this.evWin=Kt,this.pressed=!1,ie.apply(this,arguments)}b(Ke,ie,{handler:function(r){var i=Wt[r.type];i&L&&(r.button===0||r.button===2)&&(this.pressed=!0),i&ee&&r.which!==1&&(i=z),this.pressed&&(i&z&&(this.pressed=!1),this.callback(this.manager,i,{pointers:[r],changedPointers:[r],pointerType:K,srcEvent:r}))}});var xt={pointerdown:L,pointermove:ee,pointerup:z,pointercancel:X,pointerout:X},Zt={2:G,3:V,4:K,5:Y},At="pointerdown",Mt="pointermove pointerup pointercancel";f.MSPointerEvent&&!f.PointerEvent&&(At="MSPointerDown",Mt="MSPointerMove MSPointerUp MSPointerCancel");function lt(){this.evEl=At,this.evWin=Mt,ie.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}b(lt,ie,{handler:function(r){var i=this.store,h=!1,m=!1,E=r.type.toLowerCase().replace("ms",""),k=xt[E],J=Zt[r.pointerType]||r.pointerType,le=J==G,q=ce(i,r.pointerId,"pointerId");k&L&&(r.button===0||r.button===2||le)?q<0&&(i.push(r),q=i.length-1):k&(z|X)?h=!0:!le&&r.buttons===0&&(h=!0,m=!0,k=xt.pointerup),!(q<0)&&(m||(i[q]=r),this.callback(this.manager,k,{pointers:i,changedPointers:[r],pointerType:J,srcEvent:i[q]}),h&&i.splice(q,1))}});var Qt={touchstart:L,touchmove:ee,touchend:z,touchcancel:X},Jt="touchstart",$t="touchstart touchmove touchend touchcancel";function Ct(){this.evTarget=Jt,this.evWin=$t,this.started=!1,ie.apply(this,arguments)}b(Ct,ie,{handler:function(r){var i=Qt[r.type];if(i===L&&(this.started=!0),!!this.started){var h=en.call(this,r,i);i&(z|X)&&h[0].length-h[1].length===0&&(this.started=!1),this.callback(this.manager,i,{pointers:h[0],changedPointers:h[1],pointerType:G,srcEvent:r})}}});function en(n,r){var i=me(n.touches),h=me(n.changedTouches);return r&(z|X)&&(i=xe(i.concat(h),"identifier")),[i,h]}var tn={touchstart:L,touchmove:ee,touchend:z,touchcancel:X},nn="touchstart touchmove touchend touchcancel";function Ze(){this.evTarget=nn,this.targetIds={},ie.apply(this,arguments)}b(Ze,ie,{handler:function(r){var i=tn[r.type],h=rn.call(this,r,i);h&&this.callback(this.manager,i,{pointers:h[0],changedPointers:h[1],pointerType:G,srcEvent:r})}});function rn(n,r){var i=me(n.touches),h=this.targetIds;if(r&(L|ee)&&i.length===1)return h[i[0].identifier]=!0,[i,i];var m,E,k=me(n.changedTouches),J=[],le=this.target;if(E=i.filter(function(q){return te(q.target,le)}),r===L)for(m=0;m<E.length;)h[E[m].identifier]=!0,m++;for(m=0;m<k.length;)h[k[m].identifier]&&J.push(k[m]),r&(z|X)&&delete h[k[m].identifier],m++;if(J.length)return[xe(E.concat(J),"identifier"),J]}var an=2500,Ot=25;function ct(){ie.apply(this,arguments);var n=y(this.handler,this);this.touch=new Ze(this.manager,n),this.mouse=new Ke(this.manager,n),this.primaryTouch=null,this.lastTouches=[]}b(ct,ie,{handler:function(r,i,h){var m=h.pointerType==G,E=h.pointerType==K;if(!(E&&h.sourceCapabilities&&h.sourceCapabilities.firesTouchEvents)){if(m)on.call(this,i,h);else if(E&&sn.call(this,h))return;this.callback(r,i,h)}},destroy:function(){this.touch.destroy(),this.mouse.destroy()}});function on(n,r){n&L?(this.primaryTouch=r.changedPointers[0].identifier,_t.call(this,r)):n&(z|X)&&_t.call(this,r)}function _t(n){var r=n.changedPointers[0];if(r.identifier===this.primaryTouch){var i={x:r.clientX,y:r.clientY};this.lastTouches.push(i);var h=this.lastTouches,m=function(){var E=h.indexOf(i);E>-1&&h.splice(E,1)};setTimeout(m,an)}}function sn(n){for(var r=n.srcEvent.clientX,i=n.srcEvent.clientY,h=0;h<this.lastTouches.length;h++){var m=this.lastTouches[h],E=Math.abs(r-m.x),k=Math.abs(i-m.y);if(E<=Ot&&k<=Ot)return!0}return!1}var St=s?ae(s.style,"touchAction"):a,It=St!==a,Nt="compute",kt="auto",ut="manipulation",_e="none",Be="pan-x",Ye="pan-y",Qe=cn();function ht(n,r){this.manager=n,this.set(r)}ht.prototype={set:function(n){n==Nt&&(n=this.compute()),It&&this.manager.element.style&&Qe[n]&&(this.manager.element.style[St]=n),this.actions=n.toLowerCase().trim()},update:function(){this.set(this.manager.options.touchAction)},compute:function(){var n=[];return A(this.manager.recognizers,function(r){x(r.options.enable,[r])&&(n=n.concat(r.getTouchAction()))}),ln(n.join(" "))},preventDefaults:function(n){var r=n.srcEvent,i=n.offsetDirection;if(this.manager.session.prevented){r.preventDefault();return}var h=this.actions,m=Q(h,_e)&&!Qe[_e],E=Q(h,Ye)&&!Qe[Ye],k=Q(h,Be)&&!Qe[Be];if(m){var J=n.pointers.length===1,le=n.distance<2,q=n.deltaTime<250;if(J&&le&&q)return}if(!(k&&E)&&(m||E&&i&se||k&&i&he))return this.preventSrc(r)},preventSrc:function(n){this.manager.session.prevented=!0,n.preventDefault()}};function ln(n){if(Q(n,_e))return _e;var r=Q(n,Be),i=Q(n,Ye);return r&&i?_e:r||i?r?Be:Ye:Q(n,ut)?ut:kt}function cn(){if(!It)return!1;var n={},r=f.CSS&&f.CSS.supports;return["auto","manipulation","pan-y","pan-x","pan-x pan-y","none"].forEach(function(i){n[i]=r?f.CSS.supports("touch-action",i):!0}),n}var Je=1,ue=2,Se=4,Pe=8,ye=Pe,He=16,de=32;function be(n){this.options=O({},this.defaults,n||{}),this.id=U(),this.manager=null,this.options.enable=p(this.options.enable,!0),this.state=Je,this.simultaneous={},this.requireFail=[]}be.prototype={defaults:{},set:function(n){return O(this.options,n),this.manager&&this.manager.touchAction.update(),this},recognizeWith:function(n){if(T(n,"recognizeWith",this))return this;var r=this.simultaneous;return n=$e(n,this),r[n.id]||(r[n.id]=n,n.recognizeWith(this)),this},dropRecognizeWith:function(n){return T(n,"dropRecognizeWith",this)?this:(n=$e(n,this),delete this.simultaneous[n.id],this)},requireFailure:function(n){if(T(n,"requireFailure",this))return this;var r=this.requireFail;return n=$e(n,this),ce(r,n)===-1&&(r.push(n),n.requireFailure(this)),this},dropRequireFailure:function(n){if(T(n,"dropRequireFailure",this))return this;n=$e(n,this);var r=ce(this.requireFail,n);return r>-1&&this.requireFail.splice(r,1),this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(n){return!!this.simultaneous[n.id]},emit:function(n){var r=this,i=this.state;function h(m){r.manager.emit(m,n)}i<Pe&&h(r.options.event+Lt(i)),h(r.options.event),n.additionalEvent&&h(n.additionalEvent),i>=Pe&&h(r.options.event+Lt(i))},tryEmit:function(n){if(this.canEmit())return this.emit(n);this.state=de},canEmit:function(){for(var n=0;n<this.requireFail.length;){if(!(this.requireFail[n].state&(de|Je)))return!1;n++}return!0},recognize:function(n){var r=O({},n);if(!x(this.options.enable,[this,r])){this.reset(),this.state=de;return}this.state&(ye|He|de)&&(this.state=Je),this.state=this.process(r),this.state&(ue|Se|Pe|He)&&this.tryEmit(r)},process:function(n){},getTouchAction:function(){},reset:function(){}};function Lt(n){return n&He?"cancel":n&Pe?"end":n&Se?"move":n&ue?"start":""}function Dt(n){return n==Ee?"down":n==Ce?"up":n==we?"left":n==Me?"right":""}function $e(n,r){var i=r.manager;return i?i.get(n):n}function fe(){be.apply(this,arguments)}b(fe,be,{defaults:{pointers:1},attrTest:function(n){var r=this.options.pointers;return r===0||n.pointers.length===r},process:function(n){var r=this.state,i=n.eventType,h=r&(ue|Se),m=this.attrTest(n);return h&&(i&X||!m)?r|He:h||m?i&z?r|Pe:r&ue?r|Se:ue:de}});function et(){fe.apply(this,arguments),this.pX=null,this.pY=null}b(et,fe,{defaults:{event:"pan",threshold:10,pointers:1,direction:Ue},getTouchAction:function(){var n=this.options.direction,r=[];return n&se&&r.push(Ye),n&he&&r.push(Be),r},directionTest:function(n){var r=this.options,i=!0,h=n.distance,m=n.direction,E=n.deltaX,k=n.deltaY;return m&r.direction||(r.direction&se?(m=E===0?Ae:E<0?we:Me,i=E!=this.pX,h=Math.abs(n.deltaX)):(m=k===0?Ae:k<0?Ce:Ee,i=k!=this.pY,h=Math.abs(n.deltaY))),n.direction=m,i&&h>r.threshold&&m&r.direction},attrTest:function(n){return fe.prototype.attrTest.call(this,n)&&(this.state&ue||!(this.state&ue)&&this.directionTest(n))},emit:function(n){this.pX=n.deltaX,this.pY=n.deltaY;var r=Dt(n.direction);r&&(n.additionalEvent=this.options.event+r),this._super.emit.call(this,n)}});function ft(){fe.apply(this,arguments)}b(ft,fe,{defaults:{event:"pinch",threshold:0,pointers:2},getTouchAction:function(){return[_e]},attrTest:function(n){return this._super.attrTest.call(this,n)&&(Math.abs(n.scale-1)>this.options.threshold||this.state&ue)},emit:function(n){if(n.scale!==1){var r=n.scale<1?"in":"out";n.additionalEvent=this.options.event+r}this._super.emit.call(this,n)}});function pt(){be.apply(this,arguments),this._timer=null,this._input=null}b(pt,be,{defaults:{event:"press",pointers:1,time:251,threshold:9},getTouchAction:function(){return[kt]},process:function(n){var r=this.options,i=n.pointers.length===r.pointers,h=n.distance<r.threshold,m=n.deltaTime>r.time;if(this._input=n,!h||!i||n.eventType&(z|X)&&!m)this.reset();else if(n.eventType&L)this.reset(),this._timer=v(function(){this.state=ye,this.tryEmit()},r.time,this);else if(n.eventType&z)return ye;return de},reset:function(){clearTimeout(this._timer)},emit:function(n){this.state===ye&&(n&&n.eventType&z?this.manager.emit(this.options.event+"up",n):(this._input.timeStamp=d(),this.manager.emit(this.options.event,this._input)))}});function dt(){fe.apply(this,arguments)}b(dt,fe,{defaults:{event:"rotate",threshold:0,pointers:2},getTouchAction:function(){return[_e]},attrTest:function(n){return this._super.attrTest.call(this,n)&&(Math.abs(n.rotation)>this.options.threshold||this.state&ue)}});function vt(){fe.apply(this,arguments)}b(vt,fe,{defaults:{event:"swipe",threshold:10,velocity:.3,direction:se|he,pointers:1},getTouchAction:function(){return et.prototype.getTouchAction.call(this)},attrTest:function(n){var r=this.options.direction,i;return r&(se|he)?i=n.overallVelocity:r&se?i=n.overallVelocityX:r&he&&(i=n.overallVelocityY),this._super.attrTest.call(this,n)&&r&n.offsetDirection&&n.distance>this.options.threshold&&n.maxPointers==this.options.pointers&&g(i)>this.options.velocity&&n.eventType&z},emit:function(n){var r=Dt(n.offsetDirection);r&&this.manager.emit(this.options.event+r,n),this.manager.emit(this.options.event,n)}});function tt(){be.apply(this,arguments),this.pTime=!1,this.pCenter=!1,this._timer=null,this._input=null,this.count=0}b(tt,be,{defaults:{event:"tap",pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[ut]},process:function(n){var r=this.options,i=n.pointers.length===r.pointers,h=n.distance<r.threshold,m=n.deltaTime<r.time;if(this.reset(),n.eventType&L&&this.count===0)return this.failTimeout();if(h&&m&&i){if(n.eventType!=z)return this.failTimeout();var E=this.pTime?n.timeStamp-this.pTime<r.interval:!0,k=!this.pCenter||qe(this.pCenter,n.center)<r.posThreshold;this.pTime=n.timeStamp,this.pCenter=n.center,!k||!E?this.count=1:this.count+=1,this._input=n;var J=this.count%r.taps;if(J===0)return this.hasRequireFailures()?(this._timer=v(function(){this.state=ye,this.tryEmit()},r.interval,this),ue):ye}return de},failTimeout:function(){return this._timer=v(function(){this.state=de},this.options.interval,this),de},reset:function(){clearTimeout(this._timer)},emit:function(){this.state==ye&&(this._input.tapCount=this.count,this.manager.emit(this.options.event,this._input))}});function Ie(n,r){return r=r||{},r.recognizers=p(r.recognizers,Ie.defaults.preset),new mt(n,r)}Ie.VERSION="2.0.7",Ie.defaults={domEvents:!1,touchAction:Nt,enable:!0,inputTarget:null,inputClass:null,preset:[[dt,{enable:!1}],[ft,{enable:!1},["rotate"]],[vt,{direction:se}],[et,{direction:se},["swipe"]],[tt],[tt,{event:"doubletap",taps:2},["tap"]],[pt]],cssProps:{userSelect:"none",touchSelect:"none",touchCallout:"none",contentZooming:"none",userDrag:"none",tapHighlightColor:"rgba(0,0,0,0)"}};var un=1,Rt=2;function mt(n,r){this.options=O({},Ie.defaults,r||{}),this.options.inputTarget=this.options.inputTarget||n,this.handlers={},this.session={},this.recognizers=[],this.oldCssProps={},this.element=n,this.input=Xe(this),this.touchAction=new ht(this,this.options.touchAction),Ut(this,!0),A(this.options.recognizers,function(i){var h=this.add(new i[0](i[1]));i[2]&&h.recognizeWith(i[2]),i[3]&&h.requireFailure(i[3])},this)}mt.prototype={set:function(n){return O(this.options,n),n.touchAction&&this.touchAction.update(),n.inputTarget&&(this.input.destroy(),this.input.target=n.inputTarget,this.input.init()),this},stop:function(n){this.session.stopped=n?Rt:un},recognize:function(n){var r=this.session;if(!r.stopped){this.touchAction.preventDefaults(n);var i,h=this.recognizers,m=r.curRecognizer;(!m||m&&m.state&ye)&&(m=r.curRecognizer=null);for(var E=0;E<h.length;)i=h[E],r.stopped!==Rt&&(!m||i==m||i.canRecognizeWith(m))?i.recognize(n):i.reset(),!m&&i.state&(ue|Se|Pe)&&(m=r.curRecognizer=i),E++}},get:function(n){if(n instanceof be)return n;for(var r=this.recognizers,i=0;i<r.length;i++)if(r[i].options.event==n)return r[i];return null},add:function(n){if(T(n,"add",this))return this;var r=this.get(n.options.event);return r&&this.remove(r),this.recognizers.push(n),n.manager=this,this.touchAction.update(),n},remove:function(n){if(T(n,"remove",this))return this;if(n=this.get(n),n){var r=this.recognizers,i=ce(r,n);i!==-1&&(r.splice(i,1),this.touchAction.update())}return this},on:function(n,r){if(n!==a&&r!==a){var i=this.handlers;return A(ne(n),function(h){i[h]=i[h]||[],i[h].push(r)}),this}},off:function(n,r){if(n!==a){var i=this.handlers;return A(ne(n),function(h){r?i[h]&&i[h].splice(ce(i[h],r),1):delete i[h]}),this}},emit:function(n,r){this.options.domEvents&&hn(n,r);var i=this.handlers[n]&&this.handlers[n].slice();if(!(!i||!i.length)){r.type=n,r.preventDefault=function(){r.srcEvent.preventDefault()};for(var h=0;h<i.length;)i[h](r),h++}},destroy:function(){this.element&&Ut(this,!1),this.handlers={},this.session={},this.input.destroy(),this.element=null}};function Ut(n,r){var i=n.element;if(i.style){var h;A(n.options.cssProps,function(m,E){h=ae(i.style,E),r?(n.oldCssProps[h]=i.style[h],i.style[h]=m):i.style[h]=n.oldCssProps[h]||""}),r||(n.oldCssProps={})}}function hn(n,r){var i=o.createEvent("Event");i.initEvent(n,!0,!0),i.gesture=r,r.target.dispatchEvent(i)}return O(Ie,{INPUT_START:L,INPUT_MOVE:ee,INPUT_END:z,INPUT_CANCEL:X,STATE_POSSIBLE:Je,STATE_BEGAN:ue,STATE_CHANGED:Se,STATE_ENDED:Pe,STATE_RECOGNIZED:ye,STATE_CANCELLED:He,STATE_FAILED:de,DIRECTION_NONE:Ae,DIRECTION_LEFT:we,DIRECTION_RIGHT:Me,DIRECTION_UP:Ce,DIRECTION_DOWN:Ee,DIRECTION_HORIZONTAL:se,DIRECTION_VERTICAL:he,DIRECTION_ALL:Ue,Manager:mt,Input:ie,TouchAction:ht,TouchInput:Ze,MouseInput:Ke,PointerEventInput:lt,TouchMouseInput:ct,SingleTouchInput:Ct,Recognizer:be,AttrRecognizer:fe,Tap:tt,Pan:et,Swipe:vt,Pinch:ft,Rotate:dt,Press:pt,on:I,off:M,each:A,merge:D,extend:C,assign:O,inherit:b,bindFn:y,prefixed:ae}),Ie})(typeof window!="undefined"?window:{},typeof document!="undefined"?document:{}),De=function(f,o){o===void 0&&console.warn('THREE.OrbitControls: The second parameter "domElement" is now mandatory.'),o===document&&console.error('THREE.OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.'),this.object=f,this.domElement=o,this.enabled=!0,this.target=new _.Vector3,this.minDistance=0,this.maxDistance=1/0,this.minZoom=0,this.maxZoom=1/0,this.minPolarAngle=0,this.maxPolarAngle=Math.PI,this.minAzimuthAngle=-1/0,this.maxAzimuthAngle=1/0,this.enableDamping=!1,this.dampingFactor=.05,this.enableZoom=!0,this.zoomSpeed=1,this.enableRotate=!0,this.rotateSpeed=1,this.enablePan=!0,this.panSpeed=1,this.screenSpacePanning=!1,this.keyPanSpeed=7,this.autoRotate=!1,this.autoRotateSpeed=2,this.enableKeys=!0,this.keys={LEFT:37,UP:38,RIGHT:39,BOTTOM:40},this.mouseButtons={LEFT:_.MOUSE.ROTATE,MIDDLE:_.MOUSE.DOLLY,RIGHT:_.MOUSE.PAN},this.touches={ONE:_.TOUCH.ROTATE,TWO:_.TOUCH.DOLLY_PAN},this.target0=this.target.clone(),this.position0=this.object.position.clone(),this.zoom0=this.object.zoom,this.getPolarAngle=function(){return d.phi},this.getAzimuthalAngle=function(){return d.theta},this.saveState=function(){e.target0.copy(e.target),e.position0.copy(e.object.position),e.zoom0=e.object.zoom},this.reset=function(){e.target.copy(e.target0),e.object.position.copy(e.position0),e.object.zoom=e.zoom0,e.object.updateProjectionMatrix(),e.dispatchEvent(a),e.update(),l=c.NONE},this.update=(function(){var u=new _.Vector3,R=new _.Quaternion().setFromUnitVectors(f.up,new _.Vector3(0,1,0)),W=R.clone().inverse(),Z=new _.Vector3,pe=new _.Quaternion;return function(){var ge=e.object.position;return u.copy(ge).sub(e.target),u.applyQuaternion(R),d.setFromVector3(u),e.autoRotate&&l===c.NONE&&ne(te()),e.enableDamping?(d.theta+=v.theta*e.dampingFactor,d.phi+=v.phi*e.dampingFactor):(d.theta+=v.theta,d.phi+=v.phi),d.theta=Math.max(e.minAzimuthAngle,Math.min(e.maxAzimuthAngle,d.theta)),d.phi=Math.max(e.minPolarAngle,Math.min(e.maxPolarAngle,d.phi)),d.makeSafe(),d.radius*=T,d.radius=Math.max(e.minDistance,Math.min(e.maxDistance,d.radius)),e.enableDamping===!0?e.target.addScaledVector(A,e.dampingFactor):e.target.add(A),u.setFromSpherical(d),u.applyQuaternion(W),ge.copy(e.target).add(u),e.object.lookAt(e.target),e.enableDamping===!0?(v.theta*=1-e.dampingFactor,v.phi*=1-e.dampingFactor,A.multiplyScalar(1-e.dampingFactor)):(v.set(0,0,0),A.set(0,0,0)),T=1,P||Z.distanceToSquared(e.object.position)>g||8*(1-pe.dot(e.object.quaternion))>g?(e.dispatchEvent(a),Z.copy(e.object.position),pe.copy(e.object.quaternion),P=!1,!0):!1}})(),this.dispose=function(){e.domElement.removeEventListener("contextmenu",We,!1),e.domElement.removeEventListener("mousedown",Ee,!1),e.domElement.removeEventListener("wheel",Ue,!1),e.domElement.removeEventListener("touchstart",Oe,!1),e.domElement.removeEventListener("touchend",Xe,!1),e.domElement.removeEventListener("touchmove",ie,!1),document.removeEventListener("mousemove",se,!1),document.removeEventListener("mouseup",he,!1),e.domElement.removeEventListener("keydown",Fe,!1)};var e=this,a={type:"change"},t={type:"start"},s={type:"end"},c={NONE:-1,ROTATE:0,DOLLY:1,PAN:2,TOUCH_ROTATE:3,TOUCH_PAN:4,TOUCH_DOLLY_PAN:5,TOUCH_DOLLY_ROTATE:6},l=c.NONE,g=1e-6,d=new _.Spherical,v=new _.Spherical,T=1,A=new _.Vector3,P=!1,O=new _.Vector2,C=new _.Vector2,D=new _.Vector2,b=new _.Vector2,y=new _.Vector2,x=new _.Vector2,p=new _.Vector2,I=new _.Vector2,M=new _.Vector2;function te(){return 2*Math.PI/60/60*e.autoRotateSpeed}function Q(){return Math.pow(.95,e.zoomSpeed)}function ne(u){v.theta-=u}function ce(u){v.phi-=u}var me=(function(){var u=new _.Vector3;return function(W,Z){u.setFromMatrixColumn(Z,0),u.multiplyScalar(-W),A.add(u)}})(),xe=(function(){var u=new _.Vector3;return function(W,Z){e.screenSpacePanning===!0?u.setFromMatrixColumn(Z,1):(u.setFromMatrixColumn(Z,0),u.crossVectors(e.object.up,u)),u.multiplyScalar(W),A.add(u)}})(),ae=(function(){var u=new _.Vector3;return function(W,Z){var pe=e.domElement;if(e.object.isPerspectiveCamera){var Ve=e.object.position;u.copy(Ve).sub(e.target);var ge=u.length();ge*=Math.tan(e.object.fov/2*Math.PI/180),me(2*W*ge/pe.clientHeight,e.object.matrix),xe(2*Z*ge/pe.clientHeight,e.object.matrix)}else e.object.isOrthographicCamera?(me(W*(e.object.right-e.object.left)/e.object.zoom/pe.clientWidth,e.object.matrix),xe(Z*(e.object.top-e.object.bottom)/e.object.zoom/pe.clientHeight,e.object.matrix)):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."),e.enablePan=!1)}})();function oe(u){e.object.isPerspectiveCamera?T/=u:e.object.isOrthographicCamera?(e.object.zoom=Math.max(e.minZoom,Math.min(e.maxZoom,e.object.zoom*u)),e.object.updateProjectionMatrix(),P=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),e.enableZoom=!1)}function U(u){e.object.isPerspectiveCamera?T*=u:e.object.isOrthographicCamera?(e.object.zoom=Math.max(e.minZoom,Math.min(e.maxZoom,e.object.zoom/u)),e.object.updateProjectionMatrix(),P=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),e.enableZoom=!1)}function N(u){O.set(u.clientX,u.clientY)}function S(u){p.set(u.clientX,u.clientY)}function F(u){b.set(u.clientX,u.clientY)}function H(u){C.set(u.clientX,u.clientY),D.subVectors(C,O).multiplyScalar(e.rotateSpeed);var R=e.domElement;ne(2*Math.PI*D.x/R.clientHeight),ce(2*Math.PI*D.y/R.clientHeight),O.copy(C),e.update()}function re(u){I.set(u.clientX,u.clientY),M.subVectors(I,p),M.y>0?oe(Q()):M.y<0&&U(Q()),p.copy(I),e.update()}function G(u){y.set(u.clientX,u.clientY),x.subVectors(y,b).multiplyScalar(e.panSpeed),ae(x.x,x.y),b.copy(y),e.update()}function V(u){u.deltaY<0?U(Q()):u.deltaY>0&&oe(Q()),e.update()}function K(u){var R=!1;switch(u.keyCode){case e.keys.UP:ae(0,e.keyPanSpeed),R=!0;break;case e.keys.BOTTOM:ae(0,-e.keyPanSpeed),R=!0;break;case e.keys.LEFT:ae(e.keyPanSpeed,0),R=!0;break;case e.keys.RIGHT:ae(-e.keyPanSpeed,0),R=!0;break}R&&(u.preventDefault(),e.update())}function Y(u){if(u.touches.length==1)O.set(u.touches[0].pageX,u.touches[0].pageY);else{var R=.5*(u.touches[0].pageX+u.touches[1].pageX),W=.5*(u.touches[0].pageY+u.touches[1].pageY);O.set(R,W)}}function B(u){if(u.touches.length==1)b.set(u.touches[0].pageX,u.touches[0].pageY);else{var R=.5*(u.touches[0].pageX+u.touches[1].pageX),W=.5*(u.touches[0].pageY+u.touches[1].pageY);b.set(R,W)}}function L(u){var R=u.touches[0].pageX-u.touches[1].pageX,W=u.touches[0].pageY-u.touches[1].pageY,Z=Math.sqrt(R*R+W*W);p.set(0,Z)}function ee(u){e.enableZoom&&L(u),e.enablePan&&B(u)}function z(u){e.enableZoom&&L(u),e.enableRotate&&Y(u)}function X(u){if(u.touches.length==1)C.set(u.touches[0].pageX,u.touches[0].pageY);else{var R=.5*(u.touches[0].pageX+u.touches[1].pageX),W=.5*(u.touches[0].pageY+u.touches[1].pageY);C.set(R,W)}D.subVectors(C,O).multiplyScalar(e.rotateSpeed);var Z=e.domElement;ne(2*Math.PI*D.x/Z.clientHeight),ce(2*Math.PI*D.y/Z.clientHeight),O.copy(C)}function Ae(u){if(u.touches.length==1)y.set(u.touches[0].pageX,u.touches[0].pageY);else{var R=.5*(u.touches[0].pageX+u.touches[1].pageX),W=.5*(u.touches[0].pageY+u.touches[1].pageY);y.set(R,W)}x.subVectors(y,b).multiplyScalar(e.panSpeed),ae(x.x,x.y),b.copy(y)}function we(u){var R=u.touches[0].pageX-u.touches[1].pageX,W=u.touches[0].pageY-u.touches[1].pageY,Z=Math.sqrt(R*R+W*W);I.set(0,Z),M.set(0,Math.pow(I.y/p.y,e.zoomSpeed)),oe(M.y),p.copy(I)}function Me(u){e.enableZoom&&we(u),e.enablePan&&Ae(u)}function Ce(u){e.enableZoom&&we(u),e.enableRotate&&X(u)}function Ee(u){if(e.enabled!==!1){u.preventDefault(),e.domElement.focus?e.domElement.focus():window.focus();var R;switch(u.button){case 0:R=e.mouseButtons.LEFT;break;case 1:R=e.mouseButtons.MIDDLE;break;case 2:R=e.mouseButtons.RIGHT;break;default:R=-1}switch(R){case _.MOUSE.DOLLY:if(e.enableZoom===!1)return;S(u),l=c.DOLLY;break;case _.MOUSE.ROTATE:if(u.ctrlKey||u.metaKey||u.shiftKey){if(e.enablePan===!1)return;F(u),l=c.PAN}else{if(e.enableRotate===!1)return;N(u),l=c.ROTATE}break;case _.MOUSE.PAN:if(u.ctrlKey||u.metaKey||u.shiftKey){if(e.enableRotate===!1)return;N(u),l=c.ROTATE}else{if(e.enablePan===!1)return;F(u),l=c.PAN}break;default:l=c.NONE}l!==c.NONE&&(document.addEventListener("mousemove",se,!1),document.addEventListener("mouseup",he,!1),e.dispatchEvent(t))}}function se(u){if(e.enabled!==!1)switch(u.preventDefault(),l){case c.ROTATE:if(e.enableRotate===!1)return;H(u);break;case c.DOLLY:if(e.enableZoom===!1)return;re(u);break;case c.PAN:if(e.enablePan===!1)return;G(u);break}}function he(u){e.enabled!==!1&&(document.removeEventListener("mousemove",se,!1),document.removeEventListener("mouseup",he,!1),e.dispatchEvent(s),l=c.NONE)}function Ue(u){e.enabled===!1||e.enableZoom===!1||l!==c.NONE&&l!==c.ROTATE||(u.preventDefault(),u.stopPropagation(),e.dispatchEvent(t),V(u),e.dispatchEvent(s))}function Fe(u){e.enabled===!1||e.enableKeys===!1||e.enablePan===!1||K(u)}function Oe(u){if(e.enabled!==!1){switch(u.preventDefault(),u.touches.length){case 1:switch(e.touches.ONE){case _.TOUCH.ROTATE:if(e.enableRotate===!1)return;Y(u),l=c.TOUCH_ROTATE;break;case _.TOUCH.PAN:if(e.enablePan===!1)return;B(u),l=c.TOUCH_PAN;break;default:l=c.NONE}break;case 2:switch(e.touches.TWO){case _.TOUCH.DOLLY_PAN:if(e.enableZoom===!1&&e.enablePan===!1)return;ee(u),l=c.TOUCH_DOLLY_PAN;break;case _.TOUCH.DOLLY_ROTATE:if(e.enableZoom===!1&&e.enableRotate===!1)return;z(u),l=c.TOUCH_DOLLY_ROTATE;break;default:l=c.NONE}break;default:l=c.NONE}l!==c.NONE&&e.dispatchEvent(t)}}function ie(u){if(e.enabled!==!1)switch(u.preventDefault(),u.stopPropagation(),l){case c.TOUCH_ROTATE:if(e.enableRotate===!1)return;X(u),e.update();break;case c.TOUCH_PAN:if(e.enablePan===!1)return;Ae(u),e.update();break;case c.TOUCH_DOLLY_PAN:if(e.enableZoom===!1&&e.enablePan===!1)return;Me(u),e.update();break;case c.TOUCH_DOLLY_ROTATE:if(e.enableZoom===!1&&e.enableRotate===!1)return;Ce(u),e.update();break;default:l=c.NONE}}function Xe(u){e.enabled!==!1&&(e.dispatchEvent(s),l=c.NONE)}function We(u){e.enabled!==!1&&u.preventDefault()}e.domElement.addEventListener("contextmenu",We,!1),e.domElement.addEventListener("mousedown",Ee,!1),e.domElement.addEventListener("wheel",Ue,!1),e.domElement.addEventListener("touchstart",Oe,!1),e.domElement.addEventListener("touchend",Xe,!1),e.domElement.addEventListener("touchmove",ie,!1),e.domElement.addEventListener("keydown",Fe,!1),e.domElement.tabIndex===-1&&(e.domElement.tabIndex=0),this.update()};De.prototype=Object.create(_.EventDispatcher.prototype);De.prototype.constructor=De;var Pt=function(f,o){De.call(this,f,o),this.mouseButtons.LEFT=_.MOUSE.PAN,this.mouseButtons.RIGHT=_.MOUSE.ROTATE,this.touches.ONE=_.TOUCH.PAN,this.touches.TWO=_.TOUCH.DOLLY_ROTATE};Pt.prototype=Object.create(_.EventDispatcher.prototype);Pt.prototype.constructor=Pt;var Te=function(f){_.Object3D.call(this),this.element=f,this.element.style.position="absolute",this.element.style.pointerEvents="auto",this.addEventListener("removed",function(){this.traverse(function(o){o.element instanceof Element&&o.element.parentNode!==null&&o.element.parentNode.removeChild(o.element)})})};Te.prototype=Object.create(_.Object3D.prototype);Te.prototype.constructor=Te;var ot=function(f){Te.call(this,f)};ot.prototype=Object.create(Te.prototype);ot.prototype.constructor=ot;var jt=function(){var f=this,o,e,a,t,s=new _.Matrix4,c={camera:{fov:0,style:""},objects:new WeakMap},l=document.createElement("div");l.style.overflow="hidden",this.domElement=l;var g=document.createElement("div");g.style.WebkitTransformStyle="preserve-3d",g.style.transformStyle="preserve-3d",g.style.pointerEvents="none",l.appendChild(g);var d=/Trident/i.test(navigator.userAgent);this.getSize=function(){return{width:o,height:e}},this.setSize=function(b,y){o=b,e=y,a=o/2,t=e/2,l.style.width=b+"px",l.style.height=y+"px",g.style.width=b+"px",g.style.height=y+"px"};function v(b){return Math.abs(b)<1e-10?0:b}function T(b){var y=b.elements;return"matrix3d("+v(y[0])+","+v(-y[1])+","+v(y[2])+","+v(y[3])+","+v(y[4])+","+v(-y[5])+","+v(y[6])+","+v(y[7])+","+v(y[8])+","+v(-y[9])+","+v(y[10])+","+v(y[11])+","+v(y[12])+","+v(-y[13])+","+v(y[14])+","+v(y[15])+")"}function A(b,y){var x=b.elements,p="matrix3d("+v(x[0])+","+v(x[1])+","+v(x[2])+","+v(x[3])+","+v(-x[4])+","+v(-x[5])+","+v(-x[6])+","+v(-x[7])+","+v(x[8])+","+v(x[9])+","+v(x[10])+","+v(x[11])+","+v(x[12])+","+v(x[13])+","+v(x[14])+","+v(x[15])+")";return d?"translate(-50%,-50%)translate("+a+"px,"+t+"px)"+y+p:"translate(-50%,-50%)"+p}function P(b,y,x,p){if(b instanceof Te){b.onBeforeRender(f,y,x);var I;b instanceof ot?(s.copy(x.matrixWorldInverse),s.transpose(),s.copyPosition(b.matrixWorld),s.scale(b.scale),s.elements[3]=0,s.elements[7]=0,s.elements[11]=0,s.elements[15]=1,I=A(s,p)):I=A(b.matrixWorld,p);var M=b.element,te=c.objects.get(b);if(te===void 0||te.style!==I){M.style.WebkitTransform=I,M.style.transform=I;var Q={style:I};d&&(Q.distanceToCameraSquared=O(x,b)),c.objects.set(b,Q)}M.style.display=b.visible?"":"none",M.parentNode!==g&&g.appendChild(M),b.onAfterRender(f,y,x)}for(var ne=0,ce=b.children.length;ne<ce;ne++)P(b.children[ne],y,x,p)}var O=(function(){var b=new _.Vector3,y=new _.Vector3;return function(x,p){return b.setFromMatrixPosition(x.matrixWorld),y.setFromMatrixPosition(p.matrixWorld),b.distanceToSquared(y)}})();function C(b){var y=[];return b.traverse(function(x){x instanceof Te&&y.push(x)}),y}function D(b){for(var y=C(b).sort(function(M,te){var Q=c.objects.get(M).distanceToCameraSquared,ne=c.objects.get(te).distanceToCameraSquared;return Q-ne}),x=y.length,p=0,I=y.length;p<I;p++)y[p].element.style.zIndex=x-p}this.render=function(b,y){var x=y.projectionMatrix.elements[5]*t;if(c.camera.fov!==x&&(y.isPerspectiveCamera?(l.style.WebkitPerspective=x+"px",l.style.perspective=x+"px"):(l.style.WebkitPerspective="",l.style.perspective=""),c.camera.fov=x),b.autoUpdate===!0&&b.updateMatrixWorld(),y.parent===null&&y.updateMatrixWorld(),y.isOrthographicCamera)var p=-(y.right+y.left)/2,I=(y.top+y.bottom)/2;var M=y.isOrthographicCamera?"scale("+x+")translate("+v(p)+"px,"+v(I)+"px)"+T(y.matrixWorldInverse):"translateZ("+x+"px)"+T(y.matrixWorldInverse),te=M+"translate("+a+"px,"+t+"px)";c.camera.style!==te&&!d&&(g.style.WebkitTransform=te,g.style.transform=te,c.camera.style=te),P(b,b,y,M),d&&D(b)}};function Bt(f,o,e){var a=o.getBoundingClientRect(),t=a.top,s=a.left,c=a.width,l=a.height;return new w.Vector2((f.x-s)/c*2-1,-(f.y-t)/l*2+1)}var zt=(function(f){Re(o,f);function o(e,a,t,s,c){var l=f.call(this)||this;l.type="RoundedBoxGeometry",c=isNaN(c)?1:Math.max(1,Math.floor(c)),e=isNaN(e)?1:e,a=isNaN(a)?1:a,t=isNaN(t)?1:t,s=isNaN(s)?.15:s,s=Math.min(s,Math.min(e,Math.min(a,Math.min(t)))/2);var g=e/2-s,d=a/2-s,v=t/2-s;l.parameters={width:e,height:a,depth:t,radius:s,radiusSegments:c};var T=c+1,A=T*c+1<<3,P=new w.BufferAttribute(new Float32Array(A*3),3),O=new w.BufferAttribute(new Float32Array(A*3),3),C=[],D=[];new w.Vector3;var b=new w.Vector3,y=[],x=[],p=[],I=T*c,M=T*c+1;te(),ne(),Q(),ce(),xe(),me();function te(){for(var U=[new w.Vector3(1,1,1),new w.Vector3(1,1,-1),new w.Vector3(-1,1,-1),new w.Vector3(-1,1,1),new w.Vector3(1,-1,1),new w.Vector3(1,-1,-1),new w.Vector3(-1,-1,-1),new w.Vector3(-1,-1,1)],N=0;N<8;N++)C.push([]),D.push([]);for(var S=Math.PI/2,F=new w.Vector3(g,d,v),H=0;H<=c;H++){var re=H/c,G=re*S,V=Math.cos(G),K=Math.sin(G);if(H==c){b.set(0,1,0);var Y=b.clone().multiplyScalar(s).add(F);C[0].push(Y),y.push(Y);var B=b.clone();D[0].push(B),x.push(B);continue}for(var L=0;L<=c;L++){var ee=L/c,z=ee*S;b.x=V*Math.cos(z),b.y=K,b.z=V*Math.sin(z);var Y=b.clone().multiplyScalar(s).add(F);C[0].push(Y),y.push(Y);var B=b.clone().normalize();D[0].push(B),x.push(B)}}for(var X=1;X<8;X++)for(var N=0;N<C[0].length;N++){var Y=C[0][N].clone().multiply(U[X]);C[X].push(Y),y.push(Y);var B=D[0][N].clone().multiply(U[X]);D[X].push(B),x.push(B)}}function Q(){for(var U=[!0,!1,!0,!1,!1,!0,!1,!0],N=T*(c-1),S=0;S<8;S++){for(var F=M*S,H=0;H<c-1;H++)for(var re=H*T,G=(H+1)*T,V=0;V<c;V++){var K=V+1,Y=F+re+V,B=F+re+K,L=F+G+V,ee=F+G+K;U[S]?(p.push(Y),p.push(L),p.push(B),p.push(B),p.push(L),p.push(ee)):(p.push(Y),p.push(B),p.push(L),p.push(B),p.push(ee),p.push(L))}for(var V=0;V<c;V++){var Y=F+N+V,B=F+N+V+1,L=F+I;U[S]?(p.push(Y),p.push(L),p.push(B)):(p.push(Y),p.push(B),p.push(L))}}}function ne(){var U=I,N=I+M,S=I+M*2,F=I+M*3;p.push(U),p.push(N),p.push(S),p.push(U),p.push(S),p.push(F),U=I+M*4,N=I+M*5,S=I+M*6,F=I+M*7,p.push(U),p.push(S),p.push(N),p.push(U),p.push(F),p.push(S),U=0,N=M,S=M*4,F=M*5,p.push(U),p.push(S),p.push(N),p.push(N),p.push(S),p.push(F),U=M*2,N=M*3,S=M*6,F=M*7,p.push(U),p.push(S),p.push(N),p.push(N),p.push(S),p.push(F),U=c,N=c+M*3,S=c+M*4,F=c+M*7,p.push(U),p.push(N),p.push(S),p.push(N),p.push(F),p.push(S),U=c+M,N=c+M*2,S=c+M*5,F=c+M*6,p.push(U),p.push(S),p.push(N),p.push(N),p.push(S),p.push(F)}function ce(){for(var U=0;U<4;U++)for(var N=U*M,S=4*M+N,F=(U&1)===1,H=0;H<c;H++){var re=H+1,G=N+H,V=N+re,K=S+H,Y=S+re;F?(p.push(G),p.push(K),p.push(V),p.push(V),p.push(K),p.push(Y)):(p.push(G),p.push(V),p.push(K),p.push(V),p.push(Y),p.push(K))}}function me(){for(var U=[0,2,4,6],N=[1,3,5,7],S=0;S<4;S++)for(var F=M*U[S],H=M*N[S],re=1>=S,G=0;G<c;G++){var V=G*T,K=(G+1)*T,Y=F+V,B=F+K,L=H+V,ee=H+K;re?(p.push(Y),p.push(L),p.push(B),p.push(B),p.push(L),p.push(ee)):(p.push(Y),p.push(B),p.push(L),p.push(B),p.push(ee),p.push(L))}}function xe(){for(var U=c-1,N=[0,1,4,5],S=[3,2,7,6],F=[0,1,1,0],H=0;H<4;H++)for(var re=N[H]*M,G=S[H]*M,V=0;V<=U;V++){var K=re+c+V*T,Y=re+(V!=U?c+(V+1)*T:M-1),B=G+c+V*T,L=G+(V!=U?c+(V+1)*T:M-1);F[H]?(p.push(K),p.push(B),p.push(Y),p.push(Y),p.push(B),p.push(L)):(p.push(K),p.push(Y),p.push(B),p.push(Y),p.push(L),p.push(B))}}for(var ae=0,oe=0;oe<y.length;oe++)P.setXYZ(ae,y[oe].x,y[oe].y,y[oe].z),O.setXYZ(ae,x[oe].x,x[oe].y,x[oe].z),ae++;return l.setIndex(new w.BufferAttribute(new Uint16Array(p),1)),l.setAttribute("position",P),l.setAttribute("normal",O),l}return o})(w.BufferGeometry);function je(f,o){return typeof f!="number"||typeof o!="number"?!1:Math.abs(f-o)<.001}function ze(f,o,e,a){a===void 0&&(a=function(s){return s});var t=a(e);return f*(1-t)+o*t}var $=Number((Math.PI/2).toFixed(5));function Cn(f,o,e){var a=new w.Shape;return a.moveTo(e,0),a.lineTo(f-e,0),a.absarc(f-e,e,e,-$,0,!1),a.lineTo(f,o-e),a.absarc(f-e,o-e,e,0,$,!1),a.lineTo(e,o),a.absarc(e,o-e,e,$,Math.PI,!1),a.lineTo(0,e),a.absarc(e,e,e,Math.PI,Math.PI*1.5,!1),a}var Ge=function(f){var o=document.createElement("div");o.innerText=f;var e=new Te(o);return e.name=f,e.scale.set(.3,.3,.3),o.style.pointerEvents="none",o.style.backfaceVisibility="hidden",e},nt=function(f){var o=new w.PlaneGeometry(5,5),e=new w.MeshBasicMaterial({transparent:!0,opacity:0}),a=new w.Mesh(o,e),t=document.createElement("div");t.innerText=f;var s=new Te(t);return s.name=f,s.scale.set(.3,.3,.3),t.style.color="#ffffff",t.style.opacity="0.5",t.style.pointerEvents="none",t.style.backfaceVisibility="hidden",a.rotateX(-$),a.add(s),a},On=(function(f){Re(o,f);function o(e,a){var t=f.call(this,e)||this;t.camera=new Ne.Camera(90),t.scene=new w.Scene,t.renderer=new w.WebGLRenderer({antialias:!0,alpha:!0}),t.css3drenderer=new jt,t.ambientLight=new w.AmbientLight(16777215,.7),t.wrapper=document.createElement("div"),t.arrows=document.createElement("div"),t.arrowLeft=document.createElement("div"),t.arrowRight=document.createElement("div"),t.arrowFront=document.createElement("div"),t.arrowBack=document.createElement("div"),t.arrowTop=document.createElement("div"),t.arrowBottom=document.createElement("div"),t.spherical=null,t.dragging=!1,t.style=document.createElement("style"),t.directionalLight=new w.DirectionalLight(16777215,.2),t.box=new w.Mesh(new zt(8,8,8,.5,20),new w.MeshPhongMaterial({color:16777215})),t.faces=new w.Group,t.orient=function(l){var g=l.longitude,d=l.latitude;t.dragging=!1,t.spherical=null,t.controls.enableDamping=!1,t.five.setState(Object.assign({latitude:d},g!==void 0?{longitude:g+t.config.fixedLongitude}:{})),t.five.ready().then(function(){t.controls.enableDamping=!0,t.setState({arrowsVisible:!0})})},t.onRenderFrame=function(){var l,g,d,v,T;if(t.renderer.render(t.scene,t.camera),t.css3drenderer.render(t.scene,t.camera),t.directionalLight.position.copy(t.camera.position),(l=t.controls)===null||l===void 0||l.update(),t.dragging){t.camera.computePose(),t.updateByCamera();var A=t.camera.pose,P=A.longitude,O=A.latitude;t.five.setState({longitude:P,latitude:O},!0),t.updateArrows({longitude:P,latitude:O})}else if(t.spherical&&(!je(t.spherical.pi,(g=t.controls)===null||g===void 0?void 0:g.getPolarAngle())||!je(t.spherical.theta,(d=t.controls)===null||d===void 0?void 0:d.getAzimuthalAngle()))){t.spherical={pi:(v=t.controls)===null||v===void 0?void 0:v.getPolarAngle(),theta:(T=t.controls)===null||T===void 0?void 0:T.getAzimuthalAngle()},t.camera.computePose(),t.updateByCamera();var C=t.camera.pose,P=C.longitude,O=C.latitude;t.five.setState({longitude:P,latitude:O},!0),t.updateArrows({longitude:P,latitude:O})}else t.spherical=null},t.onTapGesture=function(l){var g=l.pointers[0].clientX,d=l.pointers[0].clientY,v=Bt({x:g,y:d},t.wrapper),T=new w.Raycaster;T.setFromCamera(v,t.camera);var A=T.intersectObjects(t.faces.children,!1)[0];if(A){var P=A.object.userData,O=P.longitude,C=P.latitude;t.orient({longitude:O,latitude:C})}},t.onFiveWantsGesture=function(){if(t.spherical)return!1},t.onFiveModeChange=function(l){t.controls&&(t.controls.maxPolarAngle=l==="Topview"?0:$)},t.onCameraUpdate=function(l){var g=l.state;if(!t.dragging&&!t.spherical){var d=g.longitude,v=g.latitude;t.camera.pose.longitude===d&&t.camera.pose.latitude===v||(t.camera.setFromPose({longitude:d,latitude:v,distance:20,offset:new w.Vector3(0,0,0)}),t.updateByCamera(),t.updateArrows({longitude:d,latitude:v}))}},t.onPanStart=function(l){t.dragging=!0,t.spherical={}},t.onMouseMove=function(l){if(!t.dragging){var g=Bt({x:l.clientX,y:l.clientY},t.wrapper),d=new w.Raycaster;d.setFromCamera(g,t.camera);var v=d.intersectObjects(t.faces.children,!1)[0];t.faces.children.forEach(function(T){T.material.opacity=0,T.children[0].element.style.color=""}),v&&(v.object.material.opacity=.3,v.object.children[0].element.style.color="#336dff")}},t.onPanEnd=function(l){t.dragging=!1,t.spherical={pi:t.controls.getPolarAngle(),theta:t.controls.getAzimuthalAngle()}},t.dispose=function(){t.disable()},t.five=e;var s={enabled:!1,visible:!0,arrowsVisible:!1};t.state=Object.assign(s,a==null?void 0:a.initialState);var c=j({fixedLongitude:0,orthoView:!0},a==null?void 0:a.config);return t._config=c,t.state.enabled&&t._enable({userAction:!1}),t.mc=new yt.Manager(t.wrapper),t.mc.add(new yt.Tap({interval:410})),t.mc.add(new yt.Pan({threshold:10,pointers:0})),t.camera.setFromPose({distance:20,offset:new w.Vector3(0,0,0),longitude:e.camera.pose.latitude,latitude:e.camera.pose.latitude}),t.cylinder=new w.Mesh(new w.CylinderGeometry(13.2,14,.01,50,1,!0),new w.ShaderMaterial({uniforms:{radiusTop:{value:13.2},radiusBottom:{value:14},opacity:{value:1}},vertexShader:`
|
|
354
|
+
* Licensed under the MIT license */var yt=(function(h,s,e,n){var t=["","webkit","Moz","MS","ms","o"],r=s.createElement?s.createElement("div"):n,l="function",o=Math.round,d=Math.abs,c=Date.now;function m(a,i,u){return setTimeout(b(a,u),i)}function y(a,i,u){return Array.isArray(a)?(M(a,u[i],u),!0):!1}function M(a,i,u){var g;if(a)if(a.forEach)a.forEach(i,u);else if(a.length!==n)for(g=0;g<a.length;)i.call(u,a[g],g,a),g++;else for(g in a)a.hasOwnProperty(g)&&i.call(u,a[g],g,a)}function w(a,i,u){var g="DEPRECATED METHOD: "+i+`
|
|
355
|
+
`+u+` AT
|
|
356
|
+
`;return function(){var P=new Error("get-stack-trace"),O=P&&P.stack?P.stack.replace(/^[^\(]+?[\n$]/gm,"").replace(/^\s+at\s+/gm,"").replace(/^Object.<anonymous>\s*\(/gm,"{anonymous}()@"):"Unknown Stack Trace",B=h.console&&(h.console.warn||h.console.log);return B&&B.call(h.console,g,O),a.apply(this,arguments)}}var A;typeof Object.assign!="function"?A=function(i){if(i===n||i===null)throw new TypeError("Cannot convert undefined or null to object");for(var u=Object(i),g=1;g<arguments.length;g++){var P=arguments[g];if(P!==n&&P!==null)for(var O in P)P.hasOwnProperty(O)&&(u[O]=P[O])}return u}:A=Object.assign;var S=w(function(i,u,g){for(var P=Object.keys(u),O=0;O<P.length;)(!g||g&&i[P[O]]===n)&&(i[P[O]]=u[P[O]]),O++;return i},"extend","Use `assign`."),C=w(function(i,u){return S(i,u,!0)},"merge","Use `assign`.");function E(a,i,u){var g=i.prototype,P;P=a.prototype=Object.create(g),P.constructor=a,P._super=g,u&&A(P,u)}function b(a,i){return function(){return a.apply(i,arguments)}}function T(a,i){return typeof a==l?a.apply(i&&i[0]||n,i):a}function f(a,i){return a===n?i:a}function _(a,i,u){M(W(i),function(g){a.addEventListener(g,u,!1)})}function x(a,i,u){M(W(i),function(g){a.removeEventListener(g,u,!1)})}function D(a,i){for(;a;){if(a==i)return!0;a=a.parentNode}return!1}function X(a,i){return a.indexOf(i)>-1}function W(a){return a.trim().split(/\s+/g)}function q(a,i,u){if(a.indexOf&&!u)return a.indexOf(i);for(var g=0;g<a.length;){if(u&&a[g][u]==i||!u&&a[g]===i)return g;g++}return-1}function ee(a){return Array.prototype.slice.call(a,0)}function ie(a,i,u){for(var g=[],P=[],O=0;O<a.length;){var B=a[O][i];q(P,B)<0&&g.push(a[O]),P[O]=B,O++}return g=g.sort(function(fe,te){return fe[i]>te[i]}),g}function z(a,i){for(var u,g,P=i[0].toUpperCase()+i.slice(1),O=0;O<t.length;){if(u=t[O],g=u?u+P:i,g in a)return g;O++}return n}var K=1;function I(){return K++}function L(a){var i=a.ownerDocument||a;return i.defaultView||i.parentWindow||h}var F=/mobile|tablet|ip(ad|hone|od)|android/i,k="ontouchstart"in h,G=z(h,"PointerEvent")!==n,re=k&&F.test(navigator.userAgent),Z="touch",V="pen",ne="mouse",Y="kinect",H=25,U=1,le=2,Q=4,J=8,xe=1,Pe=2,Oe=4,_e=8,Me=16,ce=Pe|Oe,ve=_e|Me,Be=ce|ve,Ue=["x","y"],Ce=["clientX","clientY"];function ue(a,i){var u=this;this.manager=a,this.callback=i,this.element=a.element,this.target=a.options.inputTarget,this.domHandler=function(g){T(a.options.enable,[a])&&u.handler(g)},this.init()}ue.prototype={handler:function(){},init:function(){this.evEl&&_(this.element,this.evEl,this.domHandler),this.evTarget&&_(this.target,this.evTarget,this.domHandler),this.evWin&&_(L(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&x(this.element,this.evEl,this.domHandler),this.evTarget&&x(this.target,this.evTarget,this.domHandler),this.evWin&&x(L(this.element),this.evWin,this.domHandler)}};function We(a){var i,u=a.options.inputClass;return u?i=u:G?i=lt:re?i=Ze:k?i=ut:i=Ke,new i(a,Xe)}function Xe(a,i,u){var g=u.pointers.length,P=u.changedPointers.length,O=i&U&&g-P===0,B=i&(Q|J)&&g-P===0;u.isFirst=!!O,u.isFinal=!!B,O&&(a.session={}),u.eventType=i,v(a,u),a.emit("hammer.input",u),a.recognize(u),a.session.prevInput=u}function v(a,i){var u=a.session,g=i.pointers,P=g.length;u.firstInput||(u.firstInput=ae(i)),P>1&&!u.firstMultiple?u.firstMultiple=ae(i):P===1&&(u.firstMultiple=!1);var O=u.firstInput,B=u.firstMultiple,oe=B?B.center:O.center,fe=i.center=me(g);i.timeStamp=c(),i.deltaTime=i.timeStamp-O.timeStamp,i.angle=st(oe,fe),i.distance=qe(oe,fe),R(u,i),i.offsetDirection=be(i.deltaX,i.deltaY);var te=Ve(i.deltaTime,i.deltaX,i.deltaY);i.overallVelocityX=te.x,i.overallVelocityY=te.y,i.overallVelocity=d(te.x)>d(te.y)?te.x:te.y,i.scale=B?Jt(B.pointers,g):1,i.rotation=B?Qt(B.pointers,g):0,i.maxPointers=u.prevInput?i.pointers.length>u.prevInput.maxPointers?i.pointers.length:u.prevInput.maxPointers:i.pointers.length,$(u,i);var ye=a.element;D(i.srcEvent.target,ye)&&(ye=i.srcEvent.target),i.target=ye}function R(a,i){var u=i.center,g=a.offsetDelta||{},P=a.prevDelta||{},O=a.prevInput||{};(i.eventType===U||O.eventType===Q)&&(P=a.prevDelta={x:O.deltaX||0,y:O.deltaY||0},g=a.offsetDelta={x:u.x,y:u.y}),i.deltaX=P.x+(u.x-g.x),i.deltaY=P.y+(u.y-g.y)}function $(a,i){var u=a.lastInterval||i,g=i.timeStamp-u.timeStamp,P,O,B,oe;if(i.eventType!=J&&(g>H||u.velocity===n)){var fe=i.deltaX-u.deltaX,te=i.deltaY-u.deltaY,ye=Ve(g,fe,te);O=ye.x,B=ye.y,P=d(ye.x)>d(ye.y)?ye.x:ye.y,oe=be(fe,te),a.lastInterval=i}else P=u.velocity,O=u.velocityX,B=u.velocityY,oe=u.direction;i.velocity=P,i.velocityX=O,i.velocityY=B,i.direction=oe}function ae(a){for(var i=[],u=0;u<a.pointers.length;)i[u]={clientX:o(a.pointers[u].clientX),clientY:o(a.pointers[u].clientY)},u++;return{timeStamp:c(),pointers:i,center:me(i),deltaX:a.deltaX,deltaY:a.deltaY}}function me(a){var i=a.length;if(i===1)return{x:o(a[0].clientX),y:o(a[0].clientY)};for(var u=0,g=0,P=0;P<i;)u+=a[P].clientX,g+=a[P].clientY,P++;return{x:o(u/i),y:o(g/i)}}function Ve(a,i,u){return{x:i/a||0,y:u/a||0}}function be(a,i){return a===i?xe:d(a)>=d(i)?a<0?Pe:Oe:i<0?_e:Me}function qe(a,i,u){u||(u=Ue);var g=i[u[0]]-a[u[0]],P=i[u[1]]-a[u[1]];return Math.sqrt(g*g+P*P)}function st(a,i,u){u||(u=Ue);var g=i[u[0]]-a[u[0]],P=i[u[1]]-a[u[1]];return Math.atan2(P,g)*180/Math.PI}function Qt(a,i){return st(i[1],i[0],Ce)+st(a[1],a[0],Ce)}function Jt(a,i){return qe(i[0],i[1],Ce)/qe(a[0],a[1],Ce)}var $t={mousedown:U,mousemove:le,mouseup:Q},en="mousedown",tn="mousemove mouseup";function Ke(){this.evEl=en,this.evWin=tn,this.pressed=!1,ue.apply(this,arguments)}E(Ke,ue,{handler:function(i){var u=$t[i.type];u&U&&(i.button===0||i.button===2)&&(this.pressed=!0),u&le&&i.which!==1&&(u=Q),this.pressed&&(u&Q&&(this.pressed=!1),this.callback(this.manager,u,{pointers:[i],changedPointers:[i],pointerType:ne,srcEvent:i}))}});var Ot={pointerdown:U,pointermove:le,pointerup:Q,pointercancel:J,pointerout:J},nn={2:Z,3:V,4:ne,5:Y},_t="pointerdown",Ct="pointermove pointerup pointercancel";h.MSPointerEvent&&!h.PointerEvent&&(_t="MSPointerDown",Ct="MSPointerMove MSPointerUp MSPointerCancel");function lt(){this.evEl=_t,this.evWin=Ct,ue.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}E(lt,ue,{handler:function(i){var u=this.store,g=!1,P=!1,O=i.type.toLowerCase().replace("ms",""),B=Ot[O],oe=nn[i.pointerType]||i.pointerType,fe=oe==Z,te=q(u,i.pointerId,"pointerId");B&U&&(i.button===0||i.button===2||fe)?te<0&&(u.push(i),te=u.length-1):B&(Q|J)?g=!0:!fe&&i.buttons===0&&(g=!0,P=!0,B=Ot.pointerup),!(te<0)&&(P||(u[te]=i),this.callback(this.manager,B,{pointers:u,changedPointers:[i],pointerType:oe,srcEvent:u[te]}),g&&u.splice(te,1))}});var rn={touchstart:U,touchmove:le,touchend:Q,touchcancel:J},an="touchstart",on="touchstart touchmove touchend touchcancel";function Lt(){this.evTarget=an,this.evWin=on,this.started=!1,ue.apply(this,arguments)}E(Lt,ue,{handler:function(i){var u=rn[i.type];if(u===U&&(this.started=!0),!!this.started){var g=sn.call(this,i,u);u&(Q|J)&&g[0].length-g[1].length===0&&(this.started=!1),this.callback(this.manager,u,{pointers:g[0],changedPointers:g[1],pointerType:Z,srcEvent:i})}}});function sn(a,i){var u=ee(a.touches),g=ee(a.changedTouches);return i&(Q|J)&&(u=ie(u.concat(g),"identifier")),[u,g]}var ln={touchstart:U,touchmove:le,touchend:Q,touchcancel:J},un="touchstart touchmove touchend touchcancel";function Ze(){this.evTarget=un,this.targetIds={},ue.apply(this,arguments)}E(Ze,ue,{handler:function(i){var u=ln[i.type],g=cn.call(this,i,u);g&&this.callback(this.manager,u,{pointers:g[0],changedPointers:g[1],pointerType:Z,srcEvent:i})}});function cn(a,i){var u=ee(a.touches),g=this.targetIds;if(i&(U|le)&&u.length===1)return g[u[0].identifier]=!0,[u,u];var P,O,B=ee(a.changedTouches),oe=[],fe=this.target;if(O=u.filter(function(te){return D(te.target,fe)}),i===U)for(P=0;P<O.length;)g[O[P].identifier]=!0,P++;for(P=0;P<B.length;)g[B[P].identifier]&&oe.push(B[P]),i&(Q|J)&&delete g[B[P].identifier],P++;if(oe.length)return[ie(O.concat(oe),"identifier"),oe]}var fn=2500,Ft=25;function ut(){ue.apply(this,arguments);var a=b(this.handler,this);this.touch=new Ze(this.manager,a),this.mouse=new Ke(this.manager,a),this.primaryTouch=null,this.lastTouches=[]}E(ut,ue,{handler:function(i,u,g){var P=g.pointerType==Z,O=g.pointerType==ne;if(!(O&&g.sourceCapabilities&&g.sourceCapabilities.firesTouchEvents)){if(P)hn.call(this,u,g);else if(O&&dn.call(this,g))return;this.callback(i,u,g)}},destroy:function(){this.touch.destroy(),this.mouse.destroy()}});function hn(a,i){a&U?(this.primaryTouch=i.changedPointers[0].identifier,It.call(this,i)):a&(Q|J)&&It.call(this,i)}function It(a){var i=a.changedPointers[0];if(i.identifier===this.primaryTouch){var u={x:i.clientX,y:i.clientY};this.lastTouches.push(u);var g=this.lastTouches,P=function(){var O=g.indexOf(u);O>-1&&g.splice(O,1)};setTimeout(P,fn)}}function dn(a){for(var i=a.srcEvent.clientX,u=a.srcEvent.clientY,g=0;g<this.lastTouches.length;g++){var P=this.lastTouches[g],O=Math.abs(i-P.x),B=Math.abs(u-P.y);if(O<=Ft&&B<=Ft)return!0}return!1}var Dt=r?z(r.style,"touchAction"):n,Nt=Dt!==n,kt="compute",Bt="auto",ct="manipulation",Le="none",Re="pan-x",je="pan-y",Qe=pn();function ft(a,i){this.manager=a,this.set(i)}ft.prototype={set:function(a){a==kt&&(a=this.compute()),Nt&&this.manager.element.style&&Qe[a]&&(this.manager.element.style[Dt]=a),this.actions=a.toLowerCase().trim()},update:function(){this.set(this.manager.options.touchAction)},compute:function(){var a=[];return M(this.manager.recognizers,function(i){T(i.options.enable,[i])&&(a=a.concat(i.getTouchAction()))}),vn(a.join(" "))},preventDefaults:function(a){var i=a.srcEvent,u=a.offsetDirection;if(this.manager.session.prevented){i.preventDefault();return}var g=this.actions,P=X(g,Le)&&!Qe[Le],O=X(g,je)&&!Qe[je],B=X(g,Re)&&!Qe[Re];if(P){var oe=a.pointers.length===1,fe=a.distance<2,te=a.deltaTime<250;if(oe&&fe&&te)return}if(!(B&&O)&&(P||O&&u&ce||B&&u&ve))return this.preventSrc(i)},preventSrc:function(a){this.manager.session.prevented=!0,a.preventDefault()}};function vn(a){if(X(a,Le))return Le;var i=X(a,Re),u=X(a,je);return i&&u?Le:i||u?i?Re:je:X(a,ct)?ct:Bt}function pn(){if(!Nt)return!1;var a={},i=h.CSS&&h.CSS.supports;return["auto","manipulation","pan-y","pan-x","pan-x pan-y","none"].forEach(function(u){a[u]=i?h.CSS.supports("touch-action",u):!0}),a}var Je=1,he=2,De=4,Ae=8,we=Ae,ze=16,ge=32;function Ee(a){this.options=A({},this.defaults,a||{}),this.id=I(),this.manager=null,this.options.enable=f(this.options.enable,!0),this.state=Je,this.simultaneous={},this.requireFail=[]}Ee.prototype={defaults:{},set:function(a){return A(this.options,a),this.manager&&this.manager.touchAction.update(),this},recognizeWith:function(a){if(y(a,"recognizeWith",this))return this;var i=this.simultaneous;return a=$e(a,this),i[a.id]||(i[a.id]=a,a.recognizeWith(this)),this},dropRecognizeWith:function(a){return y(a,"dropRecognizeWith",this)?this:(a=$e(a,this),delete this.simultaneous[a.id],this)},requireFailure:function(a){if(y(a,"requireFailure",this))return this;var i=this.requireFail;return a=$e(a,this),q(i,a)===-1&&(i.push(a),a.requireFailure(this)),this},dropRequireFailure:function(a){if(y(a,"dropRequireFailure",this))return this;a=$e(a,this);var i=q(this.requireFail,a);return i>-1&&this.requireFail.splice(i,1),this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(a){return!!this.simultaneous[a.id]},emit:function(a){var i=this,u=this.state;function g(P){i.manager.emit(P,a)}u<Ae&&g(i.options.event+Ut(u)),g(i.options.event),a.additionalEvent&&g(a.additionalEvent),u>=Ae&&g(i.options.event+Ut(u))},tryEmit:function(a){if(this.canEmit())return this.emit(a);this.state=ge},canEmit:function(){for(var a=0;a<this.requireFail.length;){if(!(this.requireFail[a].state&(ge|Je)))return!1;a++}return!0},recognize:function(a){var i=A({},a);if(!T(this.options.enable,[this,i])){this.reset(),this.state=ge;return}this.state&(we|ze|ge)&&(this.state=Je),this.state=this.process(i),this.state&(he|De|Ae|ze)&&this.tryEmit(i)},process:function(a){},getTouchAction:function(){},reset:function(){}};function Ut(a){return a&ze?"cancel":a&Ae?"end":a&De?"move":a&he?"start":""}function Vt(a){return a==Me?"down":a==_e?"up":a==Pe?"left":a==Oe?"right":""}function $e(a,i){var u=i.manager;return u?u.get(a):a}function pe(){Ee.apply(this,arguments)}E(pe,Ee,{defaults:{pointers:1},attrTest:function(a){var i=this.options.pointers;return i===0||a.pointers.length===i},process:function(a){var i=this.state,u=a.eventType,g=i&(he|De),P=this.attrTest(a);return g&&(u&J||!P)?i|ze:g||P?u&Q?i|Ae:i&he?i|De:he:ge}});function et(){pe.apply(this,arguments),this.pX=null,this.pY=null}E(et,pe,{defaults:{event:"pan",threshold:10,pointers:1,direction:Be},getTouchAction:function(){var a=this.options.direction,i=[];return a&ce&&i.push(je),a&ve&&i.push(Re),i},directionTest:function(a){var i=this.options,u=!0,g=a.distance,P=a.direction,O=a.deltaX,B=a.deltaY;return P&i.direction||(i.direction&ce?(P=O===0?xe:O<0?Pe:Oe,u=O!=this.pX,g=Math.abs(a.deltaX)):(P=B===0?xe:B<0?_e:Me,u=B!=this.pY,g=Math.abs(a.deltaY))),a.direction=P,u&&g>i.threshold&&P&i.direction},attrTest:function(a){return pe.prototype.attrTest.call(this,a)&&(this.state&he||!(this.state&he)&&this.directionTest(a))},emit:function(a){this.pX=a.deltaX,this.pY=a.deltaY;var i=Vt(a.direction);i&&(a.additionalEvent=this.options.event+i),this._super.emit.call(this,a)}});function ht(){pe.apply(this,arguments)}E(ht,pe,{defaults:{event:"pinch",threshold:0,pointers:2},getTouchAction:function(){return[Le]},attrTest:function(a){return this._super.attrTest.call(this,a)&&(Math.abs(a.scale-1)>this.options.threshold||this.state&he)},emit:function(a){if(a.scale!==1){var i=a.scale<1?"in":"out";a.additionalEvent=this.options.event+i}this._super.emit.call(this,a)}});function dt(){Ee.apply(this,arguments),this._timer=null,this._input=null}E(dt,Ee,{defaults:{event:"press",pointers:1,time:251,threshold:9},getTouchAction:function(){return[Bt]},process:function(a){var i=this.options,u=a.pointers.length===i.pointers,g=a.distance<i.threshold,P=a.deltaTime>i.time;if(this._input=a,!g||!u||a.eventType&(Q|J)&&!P)this.reset();else if(a.eventType&U)this.reset(),this._timer=m(function(){this.state=we,this.tryEmit()},i.time,this);else if(a.eventType&Q)return we;return ge},reset:function(){clearTimeout(this._timer)},emit:function(a){this.state===we&&(a&&a.eventType&Q?this.manager.emit(this.options.event+"up",a):(this._input.timeStamp=c(),this.manager.emit(this.options.event,this._input)))}});function vt(){pe.apply(this,arguments)}E(vt,pe,{defaults:{event:"rotate",threshold:0,pointers:2},getTouchAction:function(){return[Le]},attrTest:function(a){return this._super.attrTest.call(this,a)&&(Math.abs(a.rotation)>this.options.threshold||this.state&he)}});function pt(){pe.apply(this,arguments)}E(pt,pe,{defaults:{event:"swipe",threshold:10,velocity:.3,direction:ce|ve,pointers:1},getTouchAction:function(){return et.prototype.getTouchAction.call(this)},attrTest:function(a){var i=this.options.direction,u;return i&(ce|ve)?u=a.overallVelocity:i&ce?u=a.overallVelocityX:i&ve&&(u=a.overallVelocityY),this._super.attrTest.call(this,a)&&i&a.offsetDirection&&a.distance>this.options.threshold&&a.maxPointers==this.options.pointers&&d(u)>this.options.velocity&&a.eventType&Q},emit:function(a){var i=Vt(a.offsetDirection);i&&this.manager.emit(this.options.event+i,a),this.manager.emit(this.options.event,a)}});function tt(){Ee.apply(this,arguments),this.pTime=!1,this.pCenter=!1,this._timer=null,this._input=null,this.count=0}E(tt,Ee,{defaults:{event:"tap",pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[ct]},process:function(a){var i=this.options,u=a.pointers.length===i.pointers,g=a.distance<i.threshold,P=a.deltaTime<i.time;if(this.reset(),a.eventType&U&&this.count===0)return this.failTimeout();if(g&&P&&u){if(a.eventType!=Q)return this.failTimeout();var O=this.pTime?a.timeStamp-this.pTime<i.interval:!0,B=!this.pCenter||qe(this.pCenter,a.center)<i.posThreshold;this.pTime=a.timeStamp,this.pCenter=a.center,!B||!O?this.count=1:this.count+=1,this._input=a;var oe=this.count%i.taps;if(oe===0)return this.hasRequireFailures()?(this._timer=m(function(){this.state=we,this.tryEmit()},i.interval,this),he):we}return ge},failTimeout:function(){return this._timer=m(function(){this.state=ge},this.options.interval,this),ge},reset:function(){clearTimeout(this._timer)},emit:function(){this.state==we&&(this._input.tapCount=this.count,this.manager.emit(this.options.event,this._input))}});function Ne(a,i){return i=i||{},i.recognizers=f(i.recognizers,Ne.defaults.preset),new mt(a,i)}Ne.VERSION="2.0.7",Ne.defaults={domEvents:!1,touchAction:kt,enable:!0,inputTarget:null,inputClass:null,preset:[[vt,{enable:!1}],[ht,{enable:!1},["rotate"]],[pt,{direction:ce}],[et,{direction:ce},["swipe"]],[tt],[tt,{event:"doubletap",taps:2},["tap"]],[dt]],cssProps:{userSelect:"none",touchSelect:"none",touchCallout:"none",contentZooming:"none",userDrag:"none",tapHighlightColor:"rgba(0,0,0,0)"}};var mn=1,Rt=2;function mt(a,i){this.options=A({},Ne.defaults,i||{}),this.options.inputTarget=this.options.inputTarget||a,this.handlers={},this.session={},this.recognizers=[],this.oldCssProps={},this.element=a,this.input=We(this),this.touchAction=new ft(this,this.options.touchAction),jt(this,!0),M(this.options.recognizers,function(u){var g=this.add(new u[0](u[1]));u[2]&&g.recognizeWith(u[2]),u[3]&&g.requireFailure(u[3])},this)}mt.prototype={set:function(a){return A(this.options,a),a.touchAction&&this.touchAction.update(),a.inputTarget&&(this.input.destroy(),this.input.target=a.inputTarget,this.input.init()),this},stop:function(a){this.session.stopped=a?Rt:mn},recognize:function(a){var i=this.session;if(!i.stopped){this.touchAction.preventDefaults(a);var u,g=this.recognizers,P=i.curRecognizer;(!P||P&&P.state&we)&&(P=i.curRecognizer=null);for(var O=0;O<g.length;)u=g[O],i.stopped!==Rt&&(!P||u==P||u.canRecognizeWith(P))?u.recognize(a):u.reset(),!P&&u.state&(he|De|Ae)&&(P=i.curRecognizer=u),O++}},get:function(a){if(a instanceof Ee)return a;for(var i=this.recognizers,u=0;u<i.length;u++)if(i[u].options.event==a)return i[u];return null},add:function(a){if(y(a,"add",this))return this;var i=this.get(a.options.event);return i&&this.remove(i),this.recognizers.push(a),a.manager=this,this.touchAction.update(),a},remove:function(a){if(y(a,"remove",this))return this;if(a=this.get(a),a){var i=this.recognizers,u=q(i,a);u!==-1&&(i.splice(u,1),this.touchAction.update())}return this},on:function(a,i){if(a!==n&&i!==n){var u=this.handlers;return M(W(a),function(g){u[g]=u[g]||[],u[g].push(i)}),this}},off:function(a,i){if(a!==n){var u=this.handlers;return M(W(a),function(g){i?u[g]&&u[g].splice(q(u[g],i),1):delete u[g]}),this}},emit:function(a,i){this.options.domEvents&&gn(a,i);var u=this.handlers[a]&&this.handlers[a].slice();if(!(!u||!u.length)){i.type=a,i.preventDefault=function(){i.srcEvent.preventDefault()};for(var g=0;g<u.length;)u[g](i),g++}},destroy:function(){this.element&&jt(this,!1),this.handlers={},this.session={},this.input.destroy(),this.element=null}};function jt(a,i){var u=a.element;if(u.style){var g;M(a.options.cssProps,function(P,O){g=z(u.style,O),i?(a.oldCssProps[g]=u.style[g],u.style[g]=P):u.style[g]=a.oldCssProps[g]||""}),i||(a.oldCssProps={})}}function gn(a,i){var u=s.createEvent("Event");u.initEvent(a,!0,!0),u.gesture=i,i.target.dispatchEvent(u)}return A(Ne,{INPUT_START:U,INPUT_MOVE:le,INPUT_END:Q,INPUT_CANCEL:J,STATE_POSSIBLE:Je,STATE_BEGAN:he,STATE_CHANGED:De,STATE_ENDED:Ae,STATE_RECOGNIZED:we,STATE_CANCELLED:ze,STATE_FAILED:ge,DIRECTION_NONE:xe,DIRECTION_LEFT:Pe,DIRECTION_RIGHT:Oe,DIRECTION_UP:_e,DIRECTION_DOWN:Me,DIRECTION_HORIZONTAL:ce,DIRECTION_VERTICAL:ve,DIRECTION_ALL:Be,Manager:mt,Input:ue,TouchAction:ft,TouchInput:Ze,MouseInput:Ke,PointerEventInput:lt,TouchMouseInput:ut,SingleTouchInput:Lt,Recognizer:Ee,AttrRecognizer:pe,Tap:tt,Pan:et,Swipe:pt,Pinch:ht,Rotate:vt,Press:dt,on:_,off:x,each:M,merge:C,extend:S,assign:A,inherit:E,bindFn:b,prefixed:z}),Ne})(typeof window!="undefined"?window:{},typeof document!="undefined"?document:{}),ke=function(h,s){s===void 0&&console.warn('THREE.OrbitControls: The second parameter "domElement" is now mandatory.'),s===document&&console.error('THREE.OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.'),this.object=h,this.domElement=s,this.enabled=!0,this.target=new N.Vector3,this.minDistance=0,this.maxDistance=1/0,this.minZoom=0,this.maxZoom=1/0,this.minPolarAngle=0,this.maxPolarAngle=Math.PI,this.minAzimuthAngle=-1/0,this.maxAzimuthAngle=1/0,this.enableDamping=!1,this.dampingFactor=.05,this.enableZoom=!0,this.zoomSpeed=1,this.enableRotate=!0,this.rotateSpeed=1,this.enablePan=!0,this.panSpeed=1,this.screenSpacePanning=!1,this.keyPanSpeed=7,this.autoRotate=!1,this.autoRotateSpeed=2,this.enableKeys=!0,this.keys={LEFT:37,UP:38,RIGHT:39,BOTTOM:40},this.mouseButtons={LEFT:N.MOUSE.ROTATE,MIDDLE:N.MOUSE.DOLLY,RIGHT:N.MOUSE.PAN},this.touches={ONE:N.TOUCH.ROTATE,TWO:N.TOUCH.DOLLY_PAN},this.target0=this.target.clone(),this.position0=this.object.position.clone(),this.zoom0=this.object.zoom,this.getPolarAngle=function(){return c.phi},this.getAzimuthalAngle=function(){return c.theta},this.saveState=function(){e.target0.copy(e.target),e.position0.copy(e.object.position),e.zoom0=e.object.zoom},this.reset=function(){e.target.copy(e.target0),e.object.position.copy(e.position0),e.object.zoom=e.zoom0,e.object.updateProjectionMatrix(),e.dispatchEvent(n),e.update(),o=l.NONE},this.update=(function(){var v=new N.Vector3,R=new N.Quaternion().setFromUnitVectors(h.up,new N.Vector3(0,1,0)),$=R.clone().inverse(),ae=new N.Vector3,me=new N.Quaternion;return function(){var be=e.object.position;return v.copy(be).sub(e.target),v.applyQuaternion(R),c.setFromVector3(v),e.autoRotate&&o===l.NONE&&W(D()),e.enableDamping?(c.theta+=m.theta*e.dampingFactor,c.phi+=m.phi*e.dampingFactor):(c.theta+=m.theta,c.phi+=m.phi),c.theta=Math.max(e.minAzimuthAngle,Math.min(e.maxAzimuthAngle,c.theta)),c.phi=Math.max(e.minPolarAngle,Math.min(e.maxPolarAngle,c.phi)),c.makeSafe(),c.radius*=y,c.radius=Math.max(e.minDistance,Math.min(e.maxDistance,c.radius)),e.enableDamping===!0?e.target.addScaledVector(M,e.dampingFactor):e.target.add(M),v.setFromSpherical(c),v.applyQuaternion($),be.copy(e.target).add(v),e.object.lookAt(e.target),e.enableDamping===!0?(m.theta*=1-e.dampingFactor,m.phi*=1-e.dampingFactor,M.multiplyScalar(1-e.dampingFactor)):(m.set(0,0,0),M.set(0,0,0)),y=1,w||ae.distanceToSquared(e.object.position)>d||8*(1-me.dot(e.object.quaternion))>d?(e.dispatchEvent(n),ae.copy(e.object.position),me.copy(e.object.quaternion),w=!1,!0):!1}})(),this.dispose=function(){e.domElement.removeEventListener("contextmenu",Xe,!1),e.domElement.removeEventListener("mousedown",Me,!1),e.domElement.removeEventListener("wheel",Be,!1),e.domElement.removeEventListener("touchstart",Ce,!1),e.domElement.removeEventListener("touchend",We,!1),e.domElement.removeEventListener("touchmove",ue,!1),document.removeEventListener("mousemove",ce,!1),document.removeEventListener("mouseup",ve,!1),e.domElement.removeEventListener("keydown",Ue,!1)};var e=this,n={type:"change"},t={type:"start"},r={type:"end"},l={NONE:-1,ROTATE:0,DOLLY:1,PAN:2,TOUCH_ROTATE:3,TOUCH_PAN:4,TOUCH_DOLLY_PAN:5,TOUCH_DOLLY_ROTATE:6},o=l.NONE,d=1e-6,c=new N.Spherical,m=new N.Spherical,y=1,M=new N.Vector3,w=!1,A=new N.Vector2,S=new N.Vector2,C=new N.Vector2,E=new N.Vector2,b=new N.Vector2,T=new N.Vector2,f=new N.Vector2,_=new N.Vector2,x=new N.Vector2;function D(){return 2*Math.PI/60/60*e.autoRotateSpeed}function X(){return Math.pow(.95,e.zoomSpeed)}function W(v){m.theta-=v}function q(v){m.phi-=v}var ee=(function(){var v=new N.Vector3;return function($,ae){v.setFromMatrixColumn(ae,0),v.multiplyScalar(-$),M.add(v)}})(),ie=(function(){var v=new N.Vector3;return function($,ae){e.screenSpacePanning===!0?v.setFromMatrixColumn(ae,1):(v.setFromMatrixColumn(ae,0),v.crossVectors(e.object.up,v)),v.multiplyScalar($),M.add(v)}})(),z=(function(){var v=new N.Vector3;return function($,ae){var me=e.domElement;if(e.object.isPerspectiveCamera){var Ve=e.object.position;v.copy(Ve).sub(e.target);var be=v.length();be*=Math.tan(e.object.fov/2*Math.PI/180),ee(2*$*be/me.clientHeight,e.object.matrix),ie(2*ae*be/me.clientHeight,e.object.matrix)}else e.object.isOrthographicCamera?(ee($*(e.object.right-e.object.left)/e.object.zoom/me.clientWidth,e.object.matrix),ie(ae*(e.object.top-e.object.bottom)/e.object.zoom/me.clientHeight,e.object.matrix)):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."),e.enablePan=!1)}})();function K(v){e.object.isPerspectiveCamera?y/=v:e.object.isOrthographicCamera?(e.object.zoom=Math.max(e.minZoom,Math.min(e.maxZoom,e.object.zoom*v)),e.object.updateProjectionMatrix(),w=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),e.enableZoom=!1)}function I(v){e.object.isPerspectiveCamera?y*=v:e.object.isOrthographicCamera?(e.object.zoom=Math.max(e.minZoom,Math.min(e.maxZoom,e.object.zoom/v)),e.object.updateProjectionMatrix(),w=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),e.enableZoom=!1)}function L(v){A.set(v.clientX,v.clientY)}function F(v){f.set(v.clientX,v.clientY)}function k(v){E.set(v.clientX,v.clientY)}function G(v){S.set(v.clientX,v.clientY),C.subVectors(S,A).multiplyScalar(e.rotateSpeed);var R=e.domElement;W(2*Math.PI*C.x/R.clientHeight),q(2*Math.PI*C.y/R.clientHeight),A.copy(S),e.update()}function re(v){_.set(v.clientX,v.clientY),x.subVectors(_,f),x.y>0?K(X()):x.y<0&&I(X()),f.copy(_),e.update()}function Z(v){b.set(v.clientX,v.clientY),T.subVectors(b,E).multiplyScalar(e.panSpeed),z(T.x,T.y),E.copy(b),e.update()}function V(v){v.deltaY<0?I(X()):v.deltaY>0&&K(X()),e.update()}function ne(v){var R=!1;switch(v.keyCode){case e.keys.UP:z(0,e.keyPanSpeed),R=!0;break;case e.keys.BOTTOM:z(0,-e.keyPanSpeed),R=!0;break;case e.keys.LEFT:z(e.keyPanSpeed,0),R=!0;break;case e.keys.RIGHT:z(-e.keyPanSpeed,0),R=!0;break}R&&(v.preventDefault(),e.update())}function Y(v){if(v.touches.length==1)A.set(v.touches[0].pageX,v.touches[0].pageY);else{var R=.5*(v.touches[0].pageX+v.touches[1].pageX),$=.5*(v.touches[0].pageY+v.touches[1].pageY);A.set(R,$)}}function H(v){if(v.touches.length==1)E.set(v.touches[0].pageX,v.touches[0].pageY);else{var R=.5*(v.touches[0].pageX+v.touches[1].pageX),$=.5*(v.touches[0].pageY+v.touches[1].pageY);E.set(R,$)}}function U(v){var R=v.touches[0].pageX-v.touches[1].pageX,$=v.touches[0].pageY-v.touches[1].pageY,ae=Math.sqrt(R*R+$*$);f.set(0,ae)}function le(v){e.enableZoom&&U(v),e.enablePan&&H(v)}function Q(v){e.enableZoom&&U(v),e.enableRotate&&Y(v)}function J(v){if(v.touches.length==1)S.set(v.touches[0].pageX,v.touches[0].pageY);else{var R=.5*(v.touches[0].pageX+v.touches[1].pageX),$=.5*(v.touches[0].pageY+v.touches[1].pageY);S.set(R,$)}C.subVectors(S,A).multiplyScalar(e.rotateSpeed);var ae=e.domElement;W(2*Math.PI*C.x/ae.clientHeight),q(2*Math.PI*C.y/ae.clientHeight),A.copy(S)}function xe(v){if(v.touches.length==1)b.set(v.touches[0].pageX,v.touches[0].pageY);else{var R=.5*(v.touches[0].pageX+v.touches[1].pageX),$=.5*(v.touches[0].pageY+v.touches[1].pageY);b.set(R,$)}T.subVectors(b,E).multiplyScalar(e.panSpeed),z(T.x,T.y),E.copy(b)}function Pe(v){var R=v.touches[0].pageX-v.touches[1].pageX,$=v.touches[0].pageY-v.touches[1].pageY,ae=Math.sqrt(R*R+$*$);_.set(0,ae),x.set(0,Math.pow(_.y/f.y,e.zoomSpeed)),K(x.y),f.copy(_)}function Oe(v){e.enableZoom&&Pe(v),e.enablePan&&xe(v)}function _e(v){e.enableZoom&&Pe(v),e.enableRotate&&J(v)}function Me(v){if(e.enabled!==!1){v.preventDefault(),e.domElement.focus?e.domElement.focus():window.focus();var R;switch(v.button){case 0:R=e.mouseButtons.LEFT;break;case 1:R=e.mouseButtons.MIDDLE;break;case 2:R=e.mouseButtons.RIGHT;break;default:R=-1}switch(R){case N.MOUSE.DOLLY:if(e.enableZoom===!1)return;F(v),o=l.DOLLY;break;case N.MOUSE.ROTATE:if(v.ctrlKey||v.metaKey||v.shiftKey){if(e.enablePan===!1)return;k(v),o=l.PAN}else{if(e.enableRotate===!1)return;L(v),o=l.ROTATE}break;case N.MOUSE.PAN:if(v.ctrlKey||v.metaKey||v.shiftKey){if(e.enableRotate===!1)return;L(v),o=l.ROTATE}else{if(e.enablePan===!1)return;k(v),o=l.PAN}break;default:o=l.NONE}o!==l.NONE&&(document.addEventListener("mousemove",ce,!1),document.addEventListener("mouseup",ve,!1),e.dispatchEvent(t))}}function ce(v){if(e.enabled!==!1)switch(v.preventDefault(),o){case l.ROTATE:if(e.enableRotate===!1)return;G(v);break;case l.DOLLY:if(e.enableZoom===!1)return;re(v);break;case l.PAN:if(e.enablePan===!1)return;Z(v);break}}function ve(v){e.enabled!==!1&&(document.removeEventListener("mousemove",ce,!1),document.removeEventListener("mouseup",ve,!1),e.dispatchEvent(r),o=l.NONE)}function Be(v){e.enabled===!1||e.enableZoom===!1||o!==l.NONE&&o!==l.ROTATE||(v.preventDefault(),v.stopPropagation(),e.dispatchEvent(t),V(v),e.dispatchEvent(r))}function Ue(v){e.enabled===!1||e.enableKeys===!1||e.enablePan===!1||ne(v)}function Ce(v){if(e.enabled!==!1){switch(v.preventDefault(),v.touches.length){case 1:switch(e.touches.ONE){case N.TOUCH.ROTATE:if(e.enableRotate===!1)return;Y(v),o=l.TOUCH_ROTATE;break;case N.TOUCH.PAN:if(e.enablePan===!1)return;H(v),o=l.TOUCH_PAN;break;default:o=l.NONE}break;case 2:switch(e.touches.TWO){case N.TOUCH.DOLLY_PAN:if(e.enableZoom===!1&&e.enablePan===!1)return;le(v),o=l.TOUCH_DOLLY_PAN;break;case N.TOUCH.DOLLY_ROTATE:if(e.enableZoom===!1&&e.enableRotate===!1)return;Q(v),o=l.TOUCH_DOLLY_ROTATE;break;default:o=l.NONE}break;default:o=l.NONE}o!==l.NONE&&e.dispatchEvent(t)}}function ue(v){if(e.enabled!==!1)switch(v.preventDefault(),v.stopPropagation(),o){case l.TOUCH_ROTATE:if(e.enableRotate===!1)return;J(v),e.update();break;case l.TOUCH_PAN:if(e.enablePan===!1)return;xe(v),e.update();break;case l.TOUCH_DOLLY_PAN:if(e.enableZoom===!1&&e.enablePan===!1)return;Oe(v),e.update();break;case l.TOUCH_DOLLY_ROTATE:if(e.enableZoom===!1&&e.enableRotate===!1)return;_e(v),e.update();break;default:o=l.NONE}}function We(v){e.enabled!==!1&&(e.dispatchEvent(r),o=l.NONE)}function Xe(v){e.enabled!==!1&&v.preventDefault()}e.domElement.addEventListener("contextmenu",Xe,!1),e.domElement.addEventListener("mousedown",Me,!1),e.domElement.addEventListener("wheel",Be,!1),e.domElement.addEventListener("touchstart",Ce,!1),e.domElement.addEventListener("touchend",We,!1),e.domElement.addEventListener("touchmove",ue,!1),e.domElement.addEventListener("keydown",Ue,!1),e.domElement.tabIndex===-1&&(e.domElement.tabIndex=0),this.update()};ke.prototype=Object.create(N.EventDispatcher.prototype);ke.prototype.constructor=ke;var Mt=function(h,s){ke.call(this,h,s),this.mouseButtons.LEFT=N.MOUSE.PAN,this.mouseButtons.RIGHT=N.MOUSE.ROTATE,this.touches.ONE=N.TOUCH.PAN,this.touches.TWO=N.TOUCH.DOLLY_ROTATE};Mt.prototype=Object.create(N.EventDispatcher.prototype);Mt.prototype.constructor=Mt;var Te=function(h){N.Object3D.call(this),this.element=h,this.element.style.position="absolute",this.element.style.pointerEvents="auto",this.addEventListener("removed",function(){this.traverse(function(s){s.element instanceof Element&&s.element.parentNode!==null&&s.element.parentNode.removeChild(s.element)})})};Te.prototype=Object.create(N.Object3D.prototype);Te.prototype.constructor=Te;var ot=function(h){Te.call(this,h)};ot.prototype=Object.create(Te.prototype);ot.prototype.constructor=ot;var Wt=function(){var h=this,s,e,n,t,r=new N.Matrix4,l={camera:{fov:0,style:""},objects:new WeakMap},o=document.createElement("div");o.style.overflow="hidden",this.domElement=o;var d=document.createElement("div");d.style.WebkitTransformStyle="preserve-3d",d.style.transformStyle="preserve-3d",d.style.pointerEvents="none",o.appendChild(d);var c=/Trident/i.test(navigator.userAgent);this.getSize=function(){return{width:s,height:e}},this.setSize=function(E,b){s=E,e=b,n=s/2,t=e/2,o.style.width=E+"px",o.style.height=b+"px",d.style.width=E+"px",d.style.height=b+"px"};function m(E){return Math.abs(E)<1e-10?0:E}function y(E){var b=E.elements;return"matrix3d("+m(b[0])+","+m(-b[1])+","+m(b[2])+","+m(b[3])+","+m(b[4])+","+m(-b[5])+","+m(b[6])+","+m(b[7])+","+m(b[8])+","+m(-b[9])+","+m(b[10])+","+m(b[11])+","+m(b[12])+","+m(-b[13])+","+m(b[14])+","+m(b[15])+")"}function M(E,b){var T=E.elements,f="matrix3d("+m(T[0])+","+m(T[1])+","+m(T[2])+","+m(T[3])+","+m(-T[4])+","+m(-T[5])+","+m(-T[6])+","+m(-T[7])+","+m(T[8])+","+m(T[9])+","+m(T[10])+","+m(T[11])+","+m(T[12])+","+m(T[13])+","+m(T[14])+","+m(T[15])+")";return c?"translate(-50%,-50%)translate("+n+"px,"+t+"px)"+b+f:"translate(-50%,-50%)"+f}function w(E,b,T,f){if(E instanceof Te){E.onBeforeRender(h,b,T);var _;E instanceof ot?(r.copy(T.matrixWorldInverse),r.transpose(),r.copyPosition(E.matrixWorld),r.scale(E.scale),r.elements[3]=0,r.elements[7]=0,r.elements[11]=0,r.elements[15]=1,_=M(r,f)):_=M(E.matrixWorld,f);var x=E.element,D=l.objects.get(E);if(D===void 0||D.style!==_){x.style.WebkitTransform=_,x.style.transform=_;var X={style:_};c&&(X.distanceToCameraSquared=A(T,E)),l.objects.set(E,X)}x.style.display=E.visible?"":"none",x.parentNode!==d&&d.appendChild(x),E.onAfterRender(h,b,T)}for(var W=0,q=E.children.length;W<q;W++)w(E.children[W],b,T,f)}var A=(function(){var E=new N.Vector3,b=new N.Vector3;return function(T,f){return E.setFromMatrixPosition(T.matrixWorld),b.setFromMatrixPosition(f.matrixWorld),E.distanceToSquared(b)}})();function S(E){var b=[];return E.traverse(function(T){T instanceof Te&&b.push(T)}),b}function C(E){for(var b=S(E).sort(function(x,D){var X=l.objects.get(x).distanceToCameraSquared,W=l.objects.get(D).distanceToCameraSquared;return X-W}),T=b.length,f=0,_=b.length;f<_;f++)b[f].element.style.zIndex=T-f}this.render=function(E,b){var T=b.projectionMatrix.elements[5]*t;if(l.camera.fov!==T&&(b.isPerspectiveCamera?(o.style.WebkitPerspective=T+"px",o.style.perspective=T+"px"):(o.style.WebkitPerspective="",o.style.perspective=""),l.camera.fov=T),E.autoUpdate===!0&&E.updateMatrixWorld(),b.parent===null&&b.updateMatrixWorld(),b.isOrthographicCamera)var f=-(b.right+b.left)/2,_=(b.top+b.bottom)/2;var x=b.isOrthographicCamera?"scale("+T+")translate("+m(f)+"px,"+m(_)+"px)"+y(b.matrixWorldInverse):"translateZ("+T+"px)"+y(b.matrixWorldInverse),D=x+"translate("+n+"px,"+t+"px)";l.camera.style!==D&&!c&&(d.style.WebkitTransform=D,d.style.transform=D,l.camera.style=D),w(E,E,b,x),c&&C(E)}};function Ht(h,s,e){var n=s.getBoundingClientRect(),t=n.top,r=n.left,l=n.width,o=n.height;return new p.Vector2((h.x-r)/l*2-1,-(h.y-t)/o*2+1)}var Xt=(function(h){de(s,h);function s(e,n,t,r,l){var o=h.call(this)||this;o.type="RoundedBoxGeometry",l=isNaN(l)?1:Math.max(1,Math.floor(l)),e=isNaN(e)?1:e,n=isNaN(n)?1:n,t=isNaN(t)?1:t,r=isNaN(r)?.15:r,r=Math.min(r,Math.min(e,Math.min(n,Math.min(t)))/2);var d=e/2-r,c=n/2-r,m=t/2-r;o.parameters={width:e,height:n,depth:t,radius:r,radiusSegments:l};var y=l+1,M=y*l+1<<3,w=new p.BufferAttribute(new Float32Array(M*3),3),A=new p.BufferAttribute(new Float32Array(M*3),3),S=[],C=[];new p.Vector3;var E=new p.Vector3,b=[],T=[],f=[],_=y*l,x=y*l+1;D(),W(),X(),q(),ie(),ee();function D(){for(var I=[new p.Vector3(1,1,1),new p.Vector3(1,1,-1),new p.Vector3(-1,1,-1),new p.Vector3(-1,1,1),new p.Vector3(1,-1,1),new p.Vector3(1,-1,-1),new p.Vector3(-1,-1,-1),new p.Vector3(-1,-1,1)],L=0;L<8;L++)S.push([]),C.push([]);for(var F=Math.PI/2,k=new p.Vector3(d,c,m),G=0;G<=l;G++){var re=G/l,Z=re*F,V=Math.cos(Z),ne=Math.sin(Z);if(G==l){E.set(0,1,0);var Y=E.clone().multiplyScalar(r).add(k);S[0].push(Y),b.push(Y);var H=E.clone();C[0].push(H),T.push(H);continue}for(var U=0;U<=l;U++){var le=U/l,Q=le*F;E.x=V*Math.cos(Q),E.y=ne,E.z=V*Math.sin(Q);var Y=E.clone().multiplyScalar(r).add(k);S[0].push(Y),b.push(Y);var H=E.clone().normalize();C[0].push(H),T.push(H)}}for(var J=1;J<8;J++)for(var L=0;L<S[0].length;L++){var Y=S[0][L].clone().multiply(I[J]);S[J].push(Y),b.push(Y);var H=C[0][L].clone().multiply(I[J]);C[J].push(H),T.push(H)}}function X(){for(var I=[!0,!1,!0,!1,!1,!0,!1,!0],L=y*(l-1),F=0;F<8;F++){for(var k=x*F,G=0;G<l-1;G++)for(var re=G*y,Z=(G+1)*y,V=0;V<l;V++){var ne=V+1,Y=k+re+V,H=k+re+ne,U=k+Z+V,le=k+Z+ne;I[F]?(f.push(Y),f.push(U),f.push(H),f.push(H),f.push(U),f.push(le)):(f.push(Y),f.push(H),f.push(U),f.push(H),f.push(le),f.push(U))}for(var V=0;V<l;V++){var Y=k+L+V,H=k+L+V+1,U=k+_;I[F]?(f.push(Y),f.push(U),f.push(H)):(f.push(Y),f.push(H),f.push(U))}}}function W(){var I=_,L=_+x,F=_+x*2,k=_+x*3;f.push(I),f.push(L),f.push(F),f.push(I),f.push(F),f.push(k),I=_+x*4,L=_+x*5,F=_+x*6,k=_+x*7,f.push(I),f.push(F),f.push(L),f.push(I),f.push(k),f.push(F),I=0,L=x,F=x*4,k=x*5,f.push(I),f.push(F),f.push(L),f.push(L),f.push(F),f.push(k),I=x*2,L=x*3,F=x*6,k=x*7,f.push(I),f.push(F),f.push(L),f.push(L),f.push(F),f.push(k),I=l,L=l+x*3,F=l+x*4,k=l+x*7,f.push(I),f.push(L),f.push(F),f.push(L),f.push(k),f.push(F),I=l+x,L=l+x*2,F=l+x*5,k=l+x*6,f.push(I),f.push(F),f.push(L),f.push(L),f.push(F),f.push(k)}function q(){for(var I=0;I<4;I++)for(var L=I*x,F=4*x+L,k=(I&1)===1,G=0;G<l;G++){var re=G+1,Z=L+G,V=L+re,ne=F+G,Y=F+re;k?(f.push(Z),f.push(ne),f.push(V),f.push(V),f.push(ne),f.push(Y)):(f.push(Z),f.push(V),f.push(ne),f.push(V),f.push(Y),f.push(ne))}}function ee(){for(var I=[0,2,4,6],L=[1,3,5,7],F=0;F<4;F++)for(var k=x*I[F],G=x*L[F],re=1>=F,Z=0;Z<l;Z++){var V=Z*y,ne=(Z+1)*y,Y=k+V,H=k+ne,U=G+V,le=G+ne;re?(f.push(Y),f.push(U),f.push(H),f.push(H),f.push(U),f.push(le)):(f.push(Y),f.push(H),f.push(U),f.push(H),f.push(le),f.push(U))}}function ie(){for(var I=l-1,L=[0,1,4,5],F=[3,2,7,6],k=[0,1,1,0],G=0;G<4;G++)for(var re=L[G]*x,Z=F[G]*x,V=0;V<=I;V++){var ne=re+l+V*y,Y=re+(V!=I?l+(V+1)*y:x-1),H=Z+l+V*y,U=Z+(V!=I?l+(V+1)*y:x-1);k[G]?(f.push(ne),f.push(H),f.push(Y),f.push(Y),f.push(H),f.push(U)):(f.push(ne),f.push(Y),f.push(H),f.push(Y),f.push(U),f.push(H))}}for(var z=0,K=0;K<b.length;K++)w.setXYZ(z,b[K].x,b[K].y,b[K].z),A.setXYZ(z,T[K].x,T[K].y,T[K].z),z++;return o.setIndex(new p.BufferAttribute(new Uint16Array(f),1)),o.setAttribute("position",w),o.setAttribute("normal",A),o}return s})(p.BufferGeometry);function Ge(h,s){return typeof h!="number"||typeof s!="number"?!1:Math.abs(h-s)<.001}function He(h,s,e,n){n===void 0&&(n=function(r){return r});var t=n(e);return h*(1-t)+s*t}var se=Number((Math.PI/2).toFixed(5));function In(h,s,e){var n=new p.Shape;return n.moveTo(e,0),n.lineTo(h-e,0),n.absarc(h-e,e,e,-se,0,!1),n.lineTo(h,s-e),n.absarc(h-e,s-e,e,0,se,!1),n.lineTo(e,s),n.absarc(e,s-e,e,se,Math.PI,!1),n.lineTo(0,e),n.absarc(e,e,e,Math.PI,Math.PI*1.5,!1),n}var Ye=function(h){var s=document.createElement("div");s.innerText=h;var e=new Te(s);return e.name=h,e.scale.set(.3,.3,.3),s.style.pointerEvents="none",s.style.backfaceVisibility="hidden",e},nt=function(h){var s=new p.PlaneGeometry(5,5),e=new p.MeshBasicMaterial({transparent:!0,opacity:0}),n=new p.Mesh(s,e),t=document.createElement("div");t.innerText=h;var r=new Te(t);return r.name=h,r.scale.set(.3,.3,.3),t.style.color="#ffffff",t.style.opacity="0.5",t.style.pointerEvents="none",t.style.backfaceVisibility="hidden",n.rotateX(-se),n.add(r),n},Dn=(function(h){de(s,h);function s(e,n){var t=h.call(this,e)||this;t.camera=new Se.Camera(90),t.scene=new p.Scene,t.renderer=new p.WebGLRenderer({antialias:!0,alpha:!0}),t.css3drenderer=new Wt,t.ambientLight=new p.AmbientLight(16777215,.7),t.wrapper=document.createElement("div"),t.arrows=document.createElement("div"),t.arrowLeft=document.createElement("div"),t.arrowRight=document.createElement("div"),t.arrowFront=document.createElement("div"),t.arrowBack=document.createElement("div"),t.arrowTop=document.createElement("div"),t.arrowBottom=document.createElement("div"),t.spherical=null,t.dragging=!1,t.style=document.createElement("style"),t.directionalLight=new p.DirectionalLight(16777215,.2),t.box=new p.Mesh(new Xt(8,8,8,.5,20),new p.MeshPhongMaterial({color:16777215})),t.faces=new p.Group,t.orient=function(o){var d=o.longitude,c=o.latitude;t.dragging=!1,t.spherical=null,t.controls.enableDamping=!1,t.five.setState(Object.assign({latitude:c},d!==void 0?{longitude:d+t.config.fixedLongitude}:{})),t.five.ready().then(function(){t.controls.enableDamping=!0,t.setState({arrowsVisible:!0})})},t.onRenderFrame=function(){var o,d,c,m,y;if(t.renderer.render(t.scene,t.camera),t.css3drenderer.render(t.scene,t.camera),t.directionalLight.position.copy(t.camera.position),(o=t.controls)===null||o===void 0||o.update(),t.dragging){t.camera.computePose(),t.updateByCamera();var M=t.camera.pose,w=M.longitude,A=M.latitude;t.five.setState({longitude:w,latitude:A},!0),t.updateArrows({longitude:w,latitude:A})}else if(t.spherical&&(!Ge(t.spherical.pi,(d=t.controls)===null||d===void 0?void 0:d.getPolarAngle())||!Ge(t.spherical.theta,(c=t.controls)===null||c===void 0?void 0:c.getAzimuthalAngle()))){t.spherical={pi:(m=t.controls)===null||m===void 0?void 0:m.getPolarAngle(),theta:(y=t.controls)===null||y===void 0?void 0:y.getAzimuthalAngle()},t.camera.computePose(),t.updateByCamera();var S=t.camera.pose,w=S.longitude,A=S.latitude;t.five.setState({longitude:w,latitude:A},!0),t.updateArrows({longitude:w,latitude:A})}else t.spherical=null},t.onTapGesture=function(o){var d=o.pointers[0].clientX,c=o.pointers[0].clientY,m=Ht({x:d,y:c},t.wrapper),y=new p.Raycaster;y.setFromCamera(m,t.camera);var M=y.intersectObjects(t.faces.children,!1)[0];if(M){var w=M.object.userData,A=w.longitude,S=w.latitude;t.orient({longitude:A,latitude:S})}},t.onFiveWantsGesture=function(){if(t.spherical)return!1},t.onFiveModeChange=function(o){t.controls&&(t.controls.maxPolarAngle=o==="Topview"?0:se)},t.onCameraUpdate=function(o){var d=o.state;if(!t.dragging&&!t.spherical){var c=d.longitude,m=d.latitude;t.camera.pose.longitude===c&&t.camera.pose.latitude===m||(t.camera.setFromPose({longitude:c,latitude:m,distance:20,offset:new p.Vector3(0,0,0)}),t.updateByCamera(),t.updateArrows({longitude:c,latitude:m}))}},t.onPanStart=function(o){t.dragging=!0,t.spherical={}},t.onMouseMove=function(o){if(!t.dragging){var d=Ht({x:o.clientX,y:o.clientY},t.wrapper),c=new p.Raycaster;c.setFromCamera(d,t.camera);var m=c.intersectObjects(t.faces.children,!1)[0];t.faces.children.forEach(function(y){y.material.opacity=0,y.children[0].element.style.color=""}),m&&(m.object.material.opacity=.3,m.object.children[0].element.style.color="#336dff")}},t.onPanEnd=function(o){t.dragging=!1,t.spherical={pi:t.controls.getPolarAngle(),theta:t.controls.getAzimuthalAngle()}},t.dispose=function(){t.disable()},t.five=e;var r={enabled:!1,visible:!0,arrowsVisible:!1};t.state=Object.assign(r,n==null?void 0:n.initialState);var l=j({fixedLongitude:0,orthoView:!0},n==null?void 0:n.config);return t._config=l,t.state.enabled&&t._enable({userAction:!1}),t.mc=new yt.Manager(t.wrapper),t.mc.add(new yt.Tap({interval:410})),t.mc.add(new yt.Pan({threshold:10,pointers:0})),t.camera.setFromPose({distance:20,offset:new p.Vector3(0,0,0),longitude:e.camera.pose.latitude,latitude:e.camera.pose.latitude}),t.cylinder=new p.Mesh(new p.CylinderGeometry(13.2,14,.01,50,1,!0),new p.ShaderMaterial({uniforms:{radiusTop:{value:13.2},radiusBottom:{value:14},opacity:{value:1}},vertexShader:`
|
|
357
357
|
varying vec3 pos;
|
|
358
358
|
varying mat4 vViewMatrix;
|
|
359
359
|
void main() {
|
|
@@ -383,7 +383,7 @@ void main() {
|
|
|
383
383
|
vec4 color = mix(color1, color2, z);
|
|
384
384
|
gl_FragColor = color;
|
|
385
385
|
}
|
|
386
|
-
`,transparent:!0})),t.init(),t}return Object.defineProperty(
|
|
386
|
+
`,transparent:!0})),t.init(),t}return Object.defineProperty(s.prototype,"config",{get:function(){return j({},this._config)},enumerable:!1,configurable:!0}),s.prototype.updateState=function(e,n){var t=this.state;this.state=j(j({},this.state),e),typeof e.arrowsVisible=="boolean"&&this.handleArrowsVisible(e.arrowsVisible),this.hooks.emit("stateChange",{state:this.state,prevState:t,userAction:n})},s.prototype.appendTo=function(e){if(e){e.appendChild(this.wrapper);var n=this.wrapper.getBoundingClientRect(),t=n.width,r=n.height;this.renderer.setSize(t,r),this.css3drenderer.setSize(t,r)}},s.prototype.init=function(){this.renderer.setClearAlpha(0),this.renderer.domElement.style.outline="none",this.initDom(),this.initFaces(),this.initControls(),this.initLights();var e=this.cylinder;e.position.y=-3;var n=nt("西");n.position.set(-19,0,0),e.add(n);var t=nt("东");t.position.set(19,0,0),e.add(t);var r=nt("北");r.position.set(0,0,-19),e.add(r);var l=nt("南");l.position.set(0,0,19),e.add(l),this.updateByCamera(),this.scene.add(e,this.box,this.faces),this.scene.rotation.y=this.config.fixedLongitude},s.prototype.initDom=function(){this.style.innerHTML=`
|
|
387
387
|
.OrientationPlugin .OrientationArrows {
|
|
388
388
|
position: absolute;
|
|
389
389
|
top: 0;
|
|
@@ -483,7 +483,7 @@ void main() {
|
|
|
483
483
|
border-color: transparent transparent var(--color) transparent;
|
|
484
484
|
transform: translate(0, -15px);
|
|
485
485
|
}
|
|
486
|
-
`,this.wrapper.className="OrientationPlugin",this.arrows.className="OrientationArrows",this.wrapper.style.cssText="position: relative; width: 100%; height: 100%",this.wrapper.appendChild(this.arrows),this.arrowLeft.className=this.arrowRight.className=this.arrowTop.className=this.arrowBack.className=this.arrowFront.className="OrientationArrow",this.arrowBottom.className="OrientationArrow disabled",this.arrowBack.innerText="后",this.arrowFront.innerText="前",this.arrowLeft.innerText="左",this.arrowRight.innerText="右",this.arrowTop.innerText="上",this.arrowBottom.innerText="下",this.css3drenderer.domElement.style.cssText="position: absolute; top: 0; right: 0; bottom: 0; left: 0; pointer-events: none; color: #00000090;"},
|
|
486
|
+
`,this.wrapper.className="OrientationPlugin",this.arrows.className="OrientationArrows",this.wrapper.style.cssText="position: relative; width: 100%; height: 100%",this.wrapper.appendChild(this.arrows),this.arrowLeft.className=this.arrowRight.className=this.arrowTop.className=this.arrowBack.className=this.arrowFront.className="OrientationArrow",this.arrowBottom.className="OrientationArrow disabled",this.arrowBack.innerText="后",this.arrowFront.innerText="前",this.arrowLeft.innerText="左",this.arrowRight.innerText="右",this.arrowTop.innerText="上",this.arrowBottom.innerText="下",this.css3drenderer.domElement.style.cssText="position: absolute; top: 0; right: 0; bottom: 0; left: 0; pointer-events: none; color: #00000090;"},s.prototype.bindEvents=function(){var e=this;this.five.on("renderFrame",this.onRenderFrame),this.five.on("camera.update",this.onCameraUpdate),this.five.on("wantsGesture",this.onFiveWantsGesture),this.five.on("modeChange",this.onFiveModeChange),this.mc.on("tap",this.onTapGesture),this.mc.on("panstart",this.onPanStart),this.mc.on("panend",this.onPanEnd),this.wrapper.addEventListener("mousemove",this.onMouseMove),this.arrowTop.onclick=function(){return e.orient({longitude:0,latitude:se})},this.arrowLeft.onclick=function(){return e.orient({longitude:-se,latitude:0})},this.arrowRight.onclick=function(){return e.orient({longitude:se,latitude:0})},this.arrowFront.onclick=function(){return e.orient({longitude:0,latitude:0})},this.arrowBack.onclick=function(){return e.orient({longitude:Math.PI,latitude:0})}},s.prototype.unbindEvents=function(){this.five.off("renderFrame",this.onRenderFrame),this.five.off("camera.update",this.onCameraUpdate),this.five.off("wantsGesture",this.onFiveWantsGesture),this.five.off("modeChange",this.onFiveModeChange),this.mc.off("tap",this.onTapGesture),this.mc.off("panstart",this.onPanStart),this.mc.off("panend",this.onPanEnd),this.wrapper.removeEventListener("mousemove",this.onMouseMove),this.arrowTop.onclick=null,this.arrowLeft.onclick=null,this.arrowRight.onclick=null,this.arrowFront.onclick=null,this.arrowBack.onclick=null},s.prototype.updateByCamera=function(){var e=He(.2,1,this.camera.pose.latitude/Math.PI*2,function(o){return o*o}),n=He(11,13,this.camera.pose.latitude/Math.PI*2,function(o){return o*o}),t=He(12,15,this.camera.pose.latitude/Math.PI*2,function(o){return o*o}),r=He(13,19,this.camera.pose.latitude/Math.PI*2,function(o){return o*o}),l=He(-.2,.5,this.camera.pose.latitude/Math.PI*2,function(o){return o*o});this.cylinder.geometry=new p.CylinderGeometry(n,t,.01,50,1,!0),this.cylinder.material.uniforms.radiusTop.value=n,this.cylinder.material.uniforms.radiusBottom.value=t,this.cylinder.material.needsUpdate=!0,this.cylinder.children.forEach(function(o){o.position.normalize().multiplyScalar(r),o.scale.set(e,e,e);var d=o.children[0];d&&(d.element.style.opacity=l.toString())})},s.prototype.updateArrows=function(e){e.longitude;var n=e.latitude,t=se-n<.02;this.setState({arrowsVisible:t})},s.prototype.handleArrowsVisible=function(e){var n=this;if(this.state.enabled)if(this.cylinder.material.uniforms.opacity.value=e?.4:1,this.cylinder.material.needsUpdate=!0,e){var t=this.five.getCurrentState(),r=t.longitude,l=t.latitude;if(se-l<.03)this.five.state.mode==="Topview"||this.five.state.mode==="Mapview"?(this.faces.getObjectByName("上").element.className="active",this.arrows.innerHTML="",this.arrows.appendChild(this.arrowBack),this.arrows.appendChild(this.arrowLeft),this.arrows.appendChild(this.arrowRight),this.arrows.appendChild(this.arrowFront),this.arrows.style.transform="rotate(".concat((r-this.config.fixedLongitude)/Math.PI*180,"deg)")):(this.arrows.innerHTML="",this.faces.getObjectByName("上").element.className="");else{switch(this.arrows.innerHTML="",this.arrows.appendChild(this.arrowTop),this.config.orthoView&&this.five.ready().then(function(){n.five.controller.cameraType="orthographic",n.five.ready().then(function(){return n.five.controller.cameraMotion.ended=!1})}),!0){case Ge(0,r-this.config.fixedLongitude):this.arrows.appendChild(this.arrowLeft),this.arrows.appendChild(this.arrowRight),this.arrows.appendChild(this.arrowBottom),this.faces.getObjectByName("前").element.className="active";break;case Ge(se,r-this.config.fixedLongitude):this.arrows.appendChild(this.arrowFront),this.arrows.appendChild(this.arrowBack),this.arrows.appendChild(this.arrowBottom),this.faces.getObjectByName("右").element.className="active";break;case Ge(Math.PI,r-this.config.fixedLongitude):this.arrows.appendChild(this.arrowRight),this.arrows.appendChild(this.arrowLeft),this.arrows.appendChild(this.arrowBottom),this.faces.getObjectByName("后").element.className="active";break;default:this.arrows.appendChild(this.arrowBack),this.arrows.appendChild(this.arrowFront),this.arrows.appendChild(this.arrowBottom),this.faces.getObjectByName("左").element.className="active";break}this.arrows.style.transform=""}this.arrows.style.display="block"}else this.config.orthoView&&(this.five.controller.cameraType="auto",this.five.ready().then(function(){return n.five.controller.cameraMotion.ended=!1})),this.arrows.style.display="none",this.faces.children.forEach(function(o){o.children[0].element.className=""})},s.prototype.setState=function(e,n){n===void 0&&(n={});var t=this.state,r=n.userAction!==void 0?n.userAction:!0;if(this.updateState(e,r),e.enabled!==void 0&&t.enabled!==e.enabled){var l={userAction:r};e.enabled?this._enable(l):this._disable(l)}},s.prototype.initLights=function(){this.directionalLight.target=this.box,this.scene.add(this.ambientLight,this.directionalLight)},s.prototype.initFaces=function(){var e=In(7,7,.5),n=new p.ShapeGeometry(e);n.translate(-3.5,-3.5,0);var t=new p.Mesh(n,new p.MeshBasicMaterial({transparent:!0,color:3370495,opacity:0}));t.userData={longitude:0,latitude:0},t.position.z=4.1,t.add(Ye("前"));var r=new p.Mesh(n,new p.MeshBasicMaterial({transparent:!0,color:3370495,opacity:0}));r.rotateY(Math.PI),r.position.z=-4.1,r.add(Ye("后")),r.userData={longitude:Math.PI,latitude:0};var l=new p.Mesh(n,new p.MeshBasicMaterial({transparent:!0,color:3370495,opacity:0}));l.rotateY(se),l.position.x=4.1,l.add(Ye("右")),l.userData={longitude:se,latitude:0};var o=new p.Mesh(n,new p.MeshBasicMaterial({transparent:!0,color:3370495,opacity:0}));o.rotateY(-se),o.position.x=-4.1,o.add(Ye("左")),o.userData={longitude:-se,latitude:0};var d=new p.Mesh(n,new p.MeshBasicMaterial({transparent:!0,color:3370495,opacity:0}));d.rotateX(-se),d.position.y=4.1,d.add(Ye("上")),d.userData={longitude:0,latitude:se},this.faces.add(t,r,o,l,d)},s.prototype.initControls=function(){var e=this.controls=new ke(this.camera,this.renderer.domElement);e.enableZoom=!1,e.enableDamping=!0,e.enablePan=!1,e.maxPolarAngle=se,e.dampingFactor=.15,e.rotateSpeed=.25},s.prototype.load=function(e){return Fe(this,void 0,void 0,function(){return Ie(this,function(n){return[2]})})},s.prototype._enable=function(e){var n=this.five.getCurrentState(),t=n.longitude,r=n.latitude;this.camera.setFromPose({longitude:t,latitude:r,distance:20,offset:new p.Vector3(0,0,0)}),this.updateByCamera(),this.wrapper.appendChild(this.renderer.domElement),this.wrapper.appendChild(this.css3drenderer.domElement),this.bindEvents()},s.prototype._disable=function(e){this.wrapper.removeChild(this.renderer.domElement),this.wrapper.removeChild(this.css3drenderer.domElement),this.unbindEvents()},s.prototype.enable=function(e){var n;if(!this.state.enabled){var t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.updateState({enabled:!0},t),this._enable({userAction:t}),document.head.appendChild(this.style)}},s.prototype.disable=function(e){var n;if(this.state.enabled!==!1){var t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.updateState({enabled:!1},t),this._disable({userAction:t}),document.head.removeChild(this.style)}},s})(exports.BasePlugin.Controller),Nn=function(h,s){return new Dn(h,s)},kn=(function(h){de(s,h);function s(e,n){var t=h.call(this,e)||this;return t.data={},t.pluginName="BackgroundPlugin",t._onFiveCameraUpdate=function(r){var l=(Math.PI/2-Math.max(r.latitude,0))/(Math.PI/2),o=Math.max(.2-l,0)*10;t.gradientBg&&(t.gradientBg.style.transform="translateY(-".concat((1-l)*50,"%)")),t.groundBg&&(t.groundBg.style.backgroundImage="radial-gradient(circle, #2E303350 ".concat(o*100,"%, transparent ").concat(o*120,"%)"))},t._addEventListener=function(){t.five.on("cameraUpdate",t._onFiveCameraUpdate)},t._removeEventListener=function(){t.five.off("cameraUpdate",t._onFiveCameraUpdate)},t.load=function(){return Fe(t,void 0,void 0,function(){return Ie(this,function(r){return[2]})})},t.setState=function(r,l){},t.enable=function(){var r,l=(r=t.five.getElement())===null||r===void 0?void 0:r.parentNode;if(!l){t.five.ready().then(function(){return t.enable()});return}t.state.enabled||(t._onFiveCameraUpdate(t.five.getPose(),!1),t.gradientBg&&l.appendChild(t.gradientBg),t.groundBg&&l.appendChild(t.groundBg),t.style&&document.head.appendChild(t.style),t._addEventListener(),t.hooks.emit("enable",{userAction:!0}),t.state.enabled=!0)},t.disable=function(r){var l,o,d,c;t.state.enabled&&((o=(l=t.gradientBg)===null||l===void 0?void 0:l.parentNode)===null||o===void 0||o.removeChild(t.gradientBg),(c=(d=t.groundBg)===null||d===void 0?void 0:d.parentNode)===null||c===void 0||c.removeChild(t.groundBg),t.style&&document.head.removeChild(t.style),t._removeEventListener(),t.hooks.emit("disable",{userAction:!0}),t.state.enabled=!1)},t.dispose=function(){t._removeEventListener(),t.hooks.emit("disable",{userAction:!0}),t.state.enabled=!1},t.state={enabled:!1},typeof document=="undefined"||(t.gradientBg=document.createElement("div"),t.groundBg=document.createElement("div"),t.style=document.createElement("style"),t.gradientBg.className="BackgroundPluginBg",t.groundBg.className="BackgroundPluginGroundBg",t.style.innerHTML=`
|
|
487
487
|
.BackgroundPluginBg {
|
|
488
488
|
position: absolute;
|
|
489
489
|
top: 0;
|
|
@@ -504,7 +504,7 @@ void main() {
|
|
|
504
504
|
z-index: -1;
|
|
505
505
|
pointerEvents: none;
|
|
506
506
|
}
|
|
507
|
-
`,t.enable()),t}return
|
|
507
|
+
`,t.enable()),t}return s})(At.BasePlugin.Controller),Bn=function(h,s){return new kn(h,s)};new p.Matrix4().fromArray([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]);var bt=(function(){function h(s,e,n,t,r){this.R=s,this.Q=e,this.A=n,this.B=t,this.C=r,this.cov=NaN,this.x=NaN}return h.prototype.filter=function(s,e){if(e===void 0&&(e=0),isNaN(this.x))this.x=1/this.C*s,this.cov=1/this.C*this.Q*(1/this.C);else{var n=this.A*this.x+this.B*e,t=this.A*this.cov*this.A+this.R,r=t*this.C*(1/(this.C*t*this.C+this.Q));this.x=n+r*(s-this.C*n),this.cov=t-r*this.C*t}return this.x},h})(),Un=(function(h){de(s,h);function s(e,n){var t=h.call(this,e)||this;t.dispose=function(){t.disable()},t.five=e;var r={enabled:!0,visible:!0};t.state=Object.assign(r,n==null?void 0:n.initialState);var l=j({},n==null?void 0:n.config);return t._config=l,t.state.enabled&&t._enable({userAction:!1}),t.cancelAnimation=null,t.skipStart=0,t.skipEnd=0,t.location=0,t.totalDistance=0,t.trajectory=null,t.currentKeyFrame=null,t.nextKeyframe=null,t.nextButOneKeyframe=null,t.keyframes=[],t.rate=t.config.rate||1,t.virualCamera=t.five.camera.clone(),t.playingState={keyframeIndex:null,progress:null},Object.defineProperties(t,{currentDistance:{get:function(){return this._currentDistance},set:function(o){this._currentDistance=o}}}),t}return Object.defineProperty(s.prototype,"config",{get:function(){return j({},this._config)},enumerable:!1,configurable:!0}),s.prototype.updateState=function(e,n){var t=this.state;this.state=j(j({},this.state),e),this.hooks.emit("stateChange",{state:this.state,prevState:t,userAction:n})},s.prototype.load=function(e){return Fe(this,void 0,void 0,function(){return Ie(this,function(n){return[2]})})},s.prototype.loadTrajectory=function(e){this.trajectory=e,this.cancelAnimation&&this.cancelAnimation(),this.playingState.keyframeIndex=null,this.playingState.progress=null;var n=.01,t=.1,r=1,l=0,o=1,d=new bt(n,t,r,l,o),c=new bt(n,t,r,l,o),m=new bt(n,t,r,l,o);if(this.trajectory&&this.trajectory.content.loadState==="READY"){for(var y=this.trajectory.content.data.positionArray,M=new Float32Array(y.length/3),w=0;w<M.length;w++)if(w===0)M[w]=0;else{var A=new p.Vector3(y[w-3],y[w-2],y[w-1]),S=new p.Vector3(y[w],y[w+1],y[w+2]);M[w]=S.distanceTo(A)+M[w-1]}this.totalDistance=M[M.length-1];for(var w=0;w<M.length;w++){for(var C=new p.Vector3(0,0,0),E=0,b=w-5;b<w+6;b++)b>=0&&b<M.length&&(C.add(new p.Vector3(y[b*3],y[b*3+1],y[b*3+2])),E++);C.divideScalar(E).applyMatrix4(e.transform);var T=d.filter(C.x),f=c.filter(C.y),_=m.filter(C.z),x={position:new p.Vector3(T,f,_),location:M[w]};this.keyframes.push(x)}}else throw new Error("trajectory content is not ready")},s.prototype.setPlayingState=function(e){(e.keyframeIndex!==null||e.progress!==null)&&(this.cancelAnimation&&this.cancelAnimation(),this.playingState.keyframeIndex=e.keyframeIndex?e.keyframeIndex:this.playingState.keyframeIndex,this.playingState.progress=e.progress?e.progress:this.playingState.progress,this.play())},s.prototype._enable=function(e){},s.prototype.play=function(){var e=this,n=this.keyframes.length;if(n<2)throw new Error("keyframes length must be greater than 2");var t={keyframeIndex:null,progress:null};this.playingState.keyframeIndex!==null&&this.playingState.progress!==null?(t.keyframeIndex=this.playingState.keyframeIndex,t.progress=this.playingState.progress):this.playingState.keyframeIndex===null&&this.playingState.progress===null&&(this.playingState.keyframeIndex=this.skipStart,this.playingState.progress=0,this.virualCamera.position.copy(this.keyframes[this.playingState.keyframeIndex].position.clone()),this.virualCamera.lookAt(this.keyframes[1].position.clone()),this.virualCamera.computePose(),this.five.setState(j({},this.virualCamera.pose)));var r=this.playingState.keyframeIndex,l=0;this.cancelAnimation=Se.AnimationFrameLoop.shared.add(function(o,d){if(r===n-1-e.skipEnd&&e.cancelAnimation){e.cancelAnimation();return}e.currentKeyFrame=e.keyframes[r],e.nextKeyframe=e.keyframes[r+1],r+2<=n-1?e.nextButOneKeyframe=e.keyframes[r+2]:e.nextButOneKeyframe=null;var c=e.currentKeyFrame.position.clone(),m=e.nextKeyframe.position.clone(),y=e.nextKeyframe.position.clone().sub(e.currentKeyFrame.position.clone()).normalize(),M=c.clone().add(y.clone().multiplyScalar(.01)),w=new p.Vector3;e.nextButOneKeyframe!==null?w=e.nextButOneKeyframe.position.clone().sub(e.nextKeyframe.position.clone()).normalize():w.copy(y);var A=m.clone().add(w.clone().multiplyScalar(.01));l+=d/1e3*e.rate;var S=l/c.distanceTo(m);S=S>=1?1:S,t.keyframeIndex!==null&&t.progress!==null&&(S=t.progress,t.keyframeIndex=null,t.progress=null);var C=c.clone().lerp(m,S),E=M.clone().lerp(A,S);e.virualCamera.position.copy(C),e.virualCamera.lookAt(E),e.virualCamera.updateMatrixWorld(),e.virualCamera.updateMatrix(),e.virualCamera.computePose(),e.five.setState(j({},e.virualCamera.pose)),e.location=e.keyframes[r].location+c.clone().distanceTo(C),S===1?(l=0,r++,e.playingState.keyframeIndex=r,e.playingState.progress=0):(e.playingState.keyframeIndex=r,e.playingState.progress=S)})},s.prototype.pause=function(){this.cancelAnimation&&this.cancelAnimation()},s.prototype.findKeyFrameByLocation=function(e){if(this.keyframes.length!==0){for(var n=0,t=this.keyframes.length-1;n<=t;){var r=Math.floor((n+t)/2);if(this.keyframes[r].location===e)return r;this.keyframes[r].location<e?n=r+1:t=r-1}return{keyframeIndex:n-1,progress:0}}},s.prototype.resetPlayingState=function(){this.playingState.keyframeIndex=null,this.playingState.progress=null},s.prototype._disable=function(e){},s.prototype.enable=function(e){var n;if(!this.state.enabled){var t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.updateState({enabled:!0},t),this._enable({userAction:t})}},s.prototype.disable=function(e){var n;if(this.state.enabled!==!1){var t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.updateState({enabled:!1},t),this._disable({userAction:t})}},s})(exports.BasePlugin.Controller),Vn=function(h,s){return new Un(h,s)};function Yt(h,s,e){return h<s?s:h>e?e:h}var Rn=`
|
|
508
508
|
varying vec2 vUv;
|
|
509
509
|
varying vec3 vPosition;
|
|
510
510
|
void main() {
|
|
@@ -512,7 +512,7 @@ void main() {
|
|
|
512
512
|
vPosition = position;
|
|
513
513
|
gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);
|
|
514
514
|
}
|
|
515
|
-
`,
|
|
515
|
+
`,jn=`
|
|
516
516
|
varying vec2 vUv;
|
|
517
517
|
uniform sampler2D map;
|
|
518
518
|
uniform float progress;
|
|
@@ -531,4 +531,285 @@ void main() {
|
|
|
531
531
|
}
|
|
532
532
|
gl_FragColor.a = gl_FragColor.a * opacity;
|
|
533
533
|
}
|
|
534
|
-
`,
|
|
534
|
+
`,zn=[1,5,2,6,3,7,4,8,9,13,10,14,11,15,12,16],wt=512,Et=512,rt=128,Gn=(function(h){de(s,h);function s(e,n){var t=h.call(this,e)||this;t.group=new p.Group,t.mesh=(function(){var o=new p.CylinderGeometry(.12,.12,1,32,1,!0);o.translate(0,.5,0);var d=new p.ShaderMaterial({vertexShader:Rn,fragmentShader:jn,uniforms:{map:{value:new p.Texture},progress:{value:0},opacity:{value:0}},transparent:!0,depthTest:!1}),c=new p.Mesh(o,d);return c})(),t.panoMesh=new Se.PanoCircleMesh({scale:1.5}),t.stop=function(){},t.drawLine=function(o,d){if(t.ctx){var c=(function(){var M,w=wt/16|0;return w*((M=zn[o])!==null&&M!==void 0?M:0)})(),m=(1-(d+o*150)%1200/1200)*(Et+rt),y=t.ctx.createLinearGradient(0,m-rt,0,m);y.addColorStop(0,"rgba(255,255,255,0)"),y.addColorStop(.5,"rgba(255,255,255,1)"),y.addColorStop(1,"rgba(255,255,255,0)"),t.ctx.fillStyle=y,t.ctx.fillRect(c,m-rt,3,rt)}},t.anime=function(o){if(t.ctx&&t.startTime){t.ctx.clearRect(0,0,wt,Et);for(var d=0;d<16;d++)t.drawLine(d,o-t.startTime);var c=Yt((o-t.startTime)/1e3,0,1),m=Yt((o-t.startTime)/300,0,t.config.maxOpacity);t.panoMesh.setOpacity(m),t.mesh.material.uniforms.progress.value=c,t.mesh.material.uniforms.opacity.value=m,t.mesh.material.uniforms.map.value.needsUpdate=!0,t.five.needsRender=!0}},t.dispose=function(){t.disable()},t.five=e;var r={enabled:!1,visible:!0};t.state=Object.assign(r,n==null?void 0:n.initialState);var l=j(j({},n==null?void 0:n.config),{maxOpacity:1});return t._config=l,typeof document=="undefined"||(t.canvas=document.createElement("canvas"),t.ctx=t.canvas.getContext("2d"),t.canvas.width=wt,t.canvas.height=Et,t.ctx.shadowColor="rgba(255,255,255,0.5)",t.ctx.shadowBlur=6,t.ctx.shadowOffsetX=0,t.ctx.shadowOffsetY=0,t.mesh.material.uniforms.map.value=new p.CanvasTexture(t.canvas),t.group.add(t.mesh),t.panoMesh.setProgress(1),t.panoMesh.setOpacity(0),t.group.add(t.panoMesh),t.state.enabled&&t._enable({userAction:!1})),t}return Object.defineProperty(s.prototype,"config",{get:function(){return j({},this._config)},enumerable:!1,configurable:!0}),s.prototype.updateState=function(e,n){var t=this.state;this.state=j(j({},this.state),e),this.hooks.emit("stateChange",{state:this.state,prevState:t,userAction:n})},s.prototype.updateConfig=function(e,n){var t;n===void 0&&(n={});var r=this.config,l=j(j({},r),e);this._config=l,this.hooks.emit("configChange",{prevConfig:r,config:l,userAction:(t=n.userAction)!==null&&t!==void 0?t:!0})},s.prototype.load=function(e){return Fe(this,void 0,void 0,function(){return Ie(this,function(n){return[2]})})},s.prototype._enable=function(e){var n=this;this.mesh.position.copy(this.five.observers[this.five.state.panoIndex].standingPosition),this.panoMesh.position.copy(this.five.observers[this.five.state.panoIndex].standingPosition),this.five.ready().then(function(){n.five.scene.add(n.group),n.stop=Se.AnimationFrameLoop.shared.add(function(t,r){n.startTime||(n.startTime=t),n.panoMesh.updateTime(t,r),n.anime(t)})})},s.prototype._disable=function(e){this.five.scene.remove(this.group),this.panoMesh.setOpacity(0),this.startTime=void 0,this.stop(),this.five.needsRender=!0},s.prototype.enable=function(e){var n;if(this.ctx&&!this.state.enabled&&this.five.observers[this.five.state.panoIndex]){var t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.updateState({enabled:!0},t),this._enable({userAction:t})}},s.prototype.disable=function(e){var n;if(this.state.enabled!==!1){var t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.updateState({enabled:!1},t),this._disable({userAction:t})}},s.prototype.setState=function(e,n){n===void 0&&(n={});var t=this.state,r=n.userAction!==void 0?n.userAction:!0;if(this.updateState(e,r),e.enabled!==void 0&&t.enabled!==e.enabled){var l={userAction:r};e.enabled?this._enable(l):this._disable(l)}},s})(At.BasePlugin.Controller),Hn=function(h,s){return new Gn(h,s)},St=(function(h){de(s,h);function s(){var e=h.call(this)||this;e.type="LineSegmentsGeometry";var n=[-1,2,0,1,2,0,-1,1,0,1,1,0,-1,0,0,1,0,0,-1,-1,0,1,-1,0],t=[-1,2,1,2,-1,1,1,1,-1,-1,1,-1,-1,-2,1,-2],r=[0,2,1,2,3,1,2,4,3,4,5,3,4,6,5,6,7,5];return e.setIndex(r),e.setAttribute("position",new p.Float32BufferAttribute(n,3)),e.setAttribute("uv",new p.Float32BufferAttribute(t,2)),e}return s.prototype.applyMatrix4=function(e){var n=this.attributes.instanceStart,t=this.attributes.instanceEnd;return n!==void 0&&(n.applyMatrix4(e),t.applyMatrix4(e),n.needsUpdate=!0),this.boundingBox!==null&&this.computeBoundingBox(),this.boundingSphere!==null&&this.computeBoundingSphere(),this},s.prototype.setPositions=function(e){var n;e instanceof Float32Array?n=e:Array.isArray(e)?n=new Float32Array(e):n=new Float32Array;var t=new p.InstancedInterleavedBuffer(n,6,1);return this.setAttribute("instanceStart",new p.InterleavedBufferAttribute(t,3,0)),this.setAttribute("instanceEnd",new p.InterleavedBufferAttribute(t,3,3)),this.computeBoundingBox(),this.computeBoundingSphere(),this},s.prototype.setColors=function(e){var n;e instanceof Float32Array?n=e:Array.isArray(e)?n=new Float32Array(e):n=new Float32Array;var t=new p.InstancedInterleavedBuffer(n,6,1);return this.setAttribute("instanceColorStart",new p.InterleavedBufferAttribute(t,3,0)),this.setAttribute("instanceColorEnd",new p.InterleavedBufferAttribute(t,3,3)),this},s.prototype.fromWireframeGeometry=function(e){return this.setPositions(e.attributes.position.array),this},s.prototype.fromEdgesGeometry=function(e){return this.setPositions(e.attributes.position.array),this},s.prototype.fromMesh=function(e){return this.fromWireframeGeometry(new p.WireframeGeometry(e.geometry)),this},s.prototype.fromLineSegments=function(e){var n=e.geometry;if(n instanceof p.Geometry){var t=new p.BufferGeometry().fromGeometry(n);this.setPositions(t.attributes.position.array)}else n instanceof p.BufferGeometry&&this.setPositions(n.attributes.position.array);return this},s.prototype.computeBoundingBox=function(){this.boundingBox===null&&(this.boundingBox=new p.Box3);var e=this.attributes.instanceStart,n=this.attributes.instanceEnd;if(e!==void 0&&n!==void 0){var t=new p.Box3;this.boundingBox.setFromBufferAttribute(e),t.setFromBufferAttribute(n),this.boundingBox.union(t)}},s.prototype.computeBoundingSphere=function(){this.boundingSphere===null&&(this.boundingSphere=new p.Sphere),this.boundingBox===null&&this.computeBoundingBox();var e=this.attributes.instanceStart,n=this.attributes.instanceEnd;if(e!==void 0&&n!==void 0){var t=this.boundingSphere.center;this.boundingBox.getCenter(t);for(var r=0,l=new p.Vector3,o=0,d=e.count;o<d;o++)l.fromBufferAttribute(e,o),r=Math.max(r,t.distanceToSquared(l)),l.fromBufferAttribute(n,o),r=Math.max(r,t.distanceToSquared(l));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)}},s.prototype.toJSON=function(){},s})(p.InstancedBufferGeometry);Object.assign(St.prototype,{isLineSegmentsGeometry:!0});var Tt={uniforms:p.UniformsUtils.merge([p.UniformsLib.common,p.UniformsLib.fog,{linewidth:{value:1},resolution:{value:new p.Vector2(1,1)},dashScale:{value:1},dashSize:{value:1},gapSize:{value:1},opacity:{value:1},totalLength:{value:1},animationProgress:{value:0},time:{value:0},waveAmp:{value:.15},waveFreq:{value:5},waveDir:{value:2},startOffset:{value:0},endOffset:{value:0},range:{value:.3}}]),vertexShader:`
|
|
535
|
+
#include <common>
|
|
536
|
+
#include <color_pars_vertex>
|
|
537
|
+
#include <fog_pars_vertex>
|
|
538
|
+
#include <logdepthbuf_pars_vertex>
|
|
539
|
+
#include <clipping_planes_pars_vertex>
|
|
540
|
+
|
|
541
|
+
uniform float linewidth;
|
|
542
|
+
uniform vec2 resolution;
|
|
543
|
+
uniform float totalLength;
|
|
544
|
+
uniform float time;
|
|
545
|
+
uniform float waveAmp;
|
|
546
|
+
uniform float waveFreq;
|
|
547
|
+
uniform float waveDir;
|
|
548
|
+
uniform float startOffset;
|
|
549
|
+
uniform float endOffset; // 新增
|
|
550
|
+
|
|
551
|
+
attribute vec3 instanceStart;
|
|
552
|
+
attribute vec3 instanceEnd;
|
|
553
|
+
attribute float distanceProgress;
|
|
554
|
+
attribute vec3 instanceColorStart;
|
|
555
|
+
attribute vec3 instanceColorEnd;
|
|
556
|
+
attribute float instanceDistanceStart;
|
|
557
|
+
attribute float instanceDistanceEnd;
|
|
558
|
+
|
|
559
|
+
varying vec2 vUv;
|
|
560
|
+
varying float vDistanceProgress;
|
|
561
|
+
|
|
562
|
+
#ifdef USE_DASH
|
|
563
|
+
uniform float dashScale;
|
|
564
|
+
varying float vLineDistance;
|
|
565
|
+
#endif
|
|
566
|
+
|
|
567
|
+
void trimSegment(const in vec4 start, inout vec4 end) {
|
|
568
|
+
float a = projectionMatrix[2][2];
|
|
569
|
+
float b = projectionMatrix[3][2];
|
|
570
|
+
float nearEstimate = -0.5 * b / a;
|
|
571
|
+
float alpha = (nearEstimate - start.z) / (end.z - start.z);
|
|
572
|
+
end.xyz = mix(start.xyz, end.xyz, alpha);
|
|
573
|
+
}
|
|
574
|
+
|
|
575
|
+
void main() {
|
|
576
|
+
#ifdef USE_COLOR
|
|
577
|
+
vColor.xyz = (position.y < 0.5) ? instanceColorStart : instanceColorEnd;
|
|
578
|
+
#endif
|
|
579
|
+
|
|
580
|
+
#ifdef USE_DASH
|
|
581
|
+
vLineDistance = (position.y < 0.5) ? dashScale * instanceDistanceStart : dashScale * instanceDistanceEnd;
|
|
582
|
+
#endif
|
|
583
|
+
|
|
584
|
+
float aspect = resolution.x / resolution.y;
|
|
585
|
+
vUv = uv;
|
|
586
|
+
|
|
587
|
+
// camera space
|
|
588
|
+
vec4 start = modelViewMatrix * vec4(instanceStart, 1.0);
|
|
589
|
+
vec4 end = modelViewMatrix * vec4(instanceEnd, 1.0);
|
|
590
|
+
|
|
591
|
+
// ===== 波浪偏移逻辑 =====
|
|
592
|
+
if (waveDir > 0.5) { // 0 表示不波动
|
|
593
|
+
float adjustedDistanceStart = max(0.0, instanceDistanceStart - startOffset);
|
|
594
|
+
float adjustedDistanceEnd = max(0.0, instanceDistanceEnd - startOffset);
|
|
595
|
+
float adjustedTotalLength = totalLength - startOffset - endOffset;
|
|
596
|
+
adjustedTotalLength = max(0.01, adjustedTotalLength);
|
|
597
|
+
float phaseStart = adjustedDistanceStart / adjustedTotalLength;
|
|
598
|
+
float phaseEnd = adjustedDistanceEnd / adjustedTotalLength;
|
|
599
|
+
float waveStart = sin(phaseStart * waveFreq - time * 2.0) * waveAmp;
|
|
600
|
+
float waveEnd = sin(phaseEnd * waveFreq - time * 2.0) * waveAmp;
|
|
601
|
+
|
|
602
|
+
if (abs(waveDir - 1.0) < 0.1) { // X 方向
|
|
603
|
+
start.x += waveStart;
|
|
604
|
+
end.x += waveEnd;
|
|
605
|
+
} else if (abs(waveDir - 2.0) < 0.1) { // Y 方向
|
|
606
|
+
start.y += waveStart;
|
|
607
|
+
end.y += waveEnd;
|
|
608
|
+
} else if (abs(waveDir - 3.0) < 0.1) { // Z 方向
|
|
609
|
+
start.z += waveStart;
|
|
610
|
+
end.z += waveEnd;
|
|
611
|
+
}
|
|
612
|
+
}
|
|
613
|
+
// ======================
|
|
614
|
+
|
|
615
|
+
bool perspective = (projectionMatrix[2][3] == -1.0);
|
|
616
|
+
if (perspective) {
|
|
617
|
+
if (start.z < 0.0 && end.z >= 0.0) {
|
|
618
|
+
trimSegment(start, end);
|
|
619
|
+
} else if (end.z < 0.0 && start.z >= 0.0) {
|
|
620
|
+
trimSegment(end, start);
|
|
621
|
+
}
|
|
622
|
+
}
|
|
623
|
+
|
|
624
|
+
vec4 clipStart = projectionMatrix * start;
|
|
625
|
+
vec4 clipEnd = projectionMatrix * end;
|
|
626
|
+
|
|
627
|
+
vec2 ndcStart = clipStart.xy / clipStart.w;
|
|
628
|
+
vec2 ndcEnd = clipEnd.xy / clipEnd.w;
|
|
629
|
+
|
|
630
|
+
vec2 dir = ndcEnd - ndcStart;
|
|
631
|
+
dir.x *= aspect;
|
|
632
|
+
dir = normalize(dir);
|
|
633
|
+
|
|
634
|
+
vec2 offset = vec2(dir.y, -dir.x);
|
|
635
|
+
dir.x /= aspect;
|
|
636
|
+
offset.x /= aspect;
|
|
637
|
+
|
|
638
|
+
if (position.x < 0.0) offset *= -1.0;
|
|
639
|
+
if (position.y < 0.0) {
|
|
640
|
+
offset += -dir;
|
|
641
|
+
} else if (position.y > 1.0) {
|
|
642
|
+
offset += dir;
|
|
643
|
+
}
|
|
644
|
+
|
|
645
|
+
offset *= linewidth;
|
|
646
|
+
offset /= resolution.y;
|
|
647
|
+
|
|
648
|
+
vec4 clip = (position.y < 0.5) ? clipStart : clipEnd;
|
|
649
|
+
offset *= clip.w;
|
|
650
|
+
clip.xy += offset;
|
|
651
|
+
|
|
652
|
+
gl_Position = clip;
|
|
653
|
+
|
|
654
|
+
float adjustedDistanceEnd = max(0.0, instanceDistanceEnd - startOffset);
|
|
655
|
+
float adjustedTotalLength = totalLength - startOffset - endOffset;
|
|
656
|
+
adjustedTotalLength = max(0.01, adjustedTotalLength);
|
|
657
|
+
vDistanceProgress = adjustedDistanceEnd / adjustedTotalLength;
|
|
658
|
+
|
|
659
|
+
#include <logdepthbuf_vertex>
|
|
660
|
+
#include <clipping_planes_vertex>
|
|
661
|
+
#include <fog_vertex>
|
|
662
|
+
}
|
|
663
|
+
`,fragmentShader:`
|
|
664
|
+
uniform vec3 diffuse;
|
|
665
|
+
uniform float opacity;
|
|
666
|
+
uniform float animationProgress;
|
|
667
|
+
uniform float range;
|
|
668
|
+
uniform float totalLength;
|
|
669
|
+
varying float vDistanceProgress;
|
|
670
|
+
|
|
671
|
+
#ifdef USE_DASH
|
|
672
|
+
uniform float dashSize;
|
|
673
|
+
uniform float gapSize;
|
|
674
|
+
#endif
|
|
675
|
+
|
|
676
|
+
varying float vLineDistance;
|
|
677
|
+
#include <common>
|
|
678
|
+
#include <color_pars_fragment>
|
|
679
|
+
#include <fog_pars_fragment>
|
|
680
|
+
#include <logdepthbuf_pars_fragment>
|
|
681
|
+
#include <clipping_planes_pars_fragment>
|
|
682
|
+
varying vec2 vUv;
|
|
683
|
+
|
|
684
|
+
void main() {
|
|
685
|
+
#include <clipping_planes_fragment>
|
|
686
|
+
|
|
687
|
+
#ifdef USE_DASH
|
|
688
|
+
if (vUv.y < -1.0 || vUv.y > 1.0) discard;
|
|
689
|
+
if (mod(vLineDistance, dashSize + gapSize) > dashSize) discard;
|
|
690
|
+
#endif
|
|
691
|
+
|
|
692
|
+
if (abs(vUv.y) > 1.0) {
|
|
693
|
+
float a = vUv.x;
|
|
694
|
+
float b = (vUv.y > 0.0) ? vUv.y - 1.0 : vUv.y + 1.0;
|
|
695
|
+
float len2 = a * a + b * b;
|
|
696
|
+
if (len2 > 1.0) discard;
|
|
697
|
+
}
|
|
698
|
+
|
|
699
|
+
vec4 diffuseColor = vec4(diffuse, 1.0);
|
|
700
|
+
#include <logdepthbuf_fragment>
|
|
701
|
+
#include <color_fragment>
|
|
702
|
+
|
|
703
|
+
gl_FragColor = vec4(diffuseColor.rgb, diffuseColor.a);
|
|
704
|
+
|
|
705
|
+
float alpha = 0.0;
|
|
706
|
+
float diff = (1.0 - 2.0 * range) * vDistanceProgress + range - animationProgress;
|
|
707
|
+
// 使用绝对值计算,在animationProgress前后range范围内过渡
|
|
708
|
+
if (abs(diff) < range) {
|
|
709
|
+
alpha = 1.0 - abs(diff) / range;
|
|
710
|
+
} else {
|
|
711
|
+
alpha = 0.0;
|
|
712
|
+
}
|
|
713
|
+
|
|
714
|
+
alpha = clamp(alpha, 0.0, 1.0);
|
|
715
|
+
gl_FragColor.a = alpha;
|
|
716
|
+
|
|
717
|
+
// 增加开头和结尾的渐变alpha遮罩,固定物理距离为 1 米
|
|
718
|
+
float startFadeLength = 1.0 / totalLength;
|
|
719
|
+
if (vDistanceProgress < startFadeLength) {
|
|
720
|
+
gl_FragColor.a *= vDistanceProgress / startFadeLength;
|
|
721
|
+
}
|
|
722
|
+
float endFadeStart = 1.0 - startFadeLength;
|
|
723
|
+
if (vDistanceProgress > endFadeStart) {
|
|
724
|
+
gl_FragColor.a *= (1.0 - vDistanceProgress) / startFadeLength;
|
|
725
|
+
}
|
|
726
|
+
gl_FragColor.a *= opacity;
|
|
727
|
+
#include <tonemapping_fragment>
|
|
728
|
+
#include <fog_fragment>
|
|
729
|
+
#include <premultiplied_alpha_fragment>
|
|
730
|
+
}
|
|
731
|
+
`},xt=(function(h){de(s,h);function s(e){var n=h.call(this,{uniforms:p.UniformsUtils.clone(Tt.uniforms),vertexShader:Tt.vertexShader,fragmentShader:Tt.fragmentShader,clipping:!0})||this;return n.type="LineMaterial",n.dashed=!1,Object.defineProperties(n,{color:{enumerable:!0,get:function(){return this.uniforms.diffuse.value},set:function(t){this.uniforms.diffuse.value=t}},linewidth:{enumerable:!0,get:function(){return this.uniforms.linewidth.value},set:function(t){this.uniforms.linewidth.value=t}},dashScale:{enumerable:!0,get:function(){return this.uniforms.dashScale.value},set:function(t){this.uniforms.dashScale.value=t}},dashSize:{enumerable:!0,get:function(){return this.uniforms.dashSize.value},set:function(t){this.uniforms.dashSize.value=t}},gapSize:{enumerable:!0,get:function(){return this.uniforms.gapSize.value},set:function(t){this.uniforms.gapSize.value=t}},opacity:{enumerable:!0,get:function(){return this.uniforms.opacity.value},set:function(t){this.uniforms.opacity.value=t}},resolution:{enumerable:!0,get:function(){return this.uniforms.resolution.value},set:function(t){this.uniforms.resolution.value.copy(t)}},time:{enumerable:!0,get:function(){return this.uniforms.time.value},set:function(t){this.uniforms.time.value=t}},waveAmp:{enumerable:!0,get:function(){return this.uniforms.waveAmp.value},set:function(t){this.uniforms.waveAmp.value=t}},waveFreq:{enumerable:!0,get:function(){return this.uniforms.waveFreq.value},set:function(t){this.uniforms.waveFreq.value=t}},waveDir:{enumerable:!0,get:function(){return this.uniforms.waveDir.value},set:function(t){this.uniforms.waveDir.value=t}},startOffset:{enumerable:!0,get:function(){return this.uniforms.startOffset.value},set:function(t){this.uniforms.startOffset.value=t}},endOffset:{enumerable:!0,get:function(){return this.uniforms.endOffset.value},set:function(t){this.uniforms.endOffset.value=t}},range:{enumerable:!0,get:function(){return this.uniforms.range.value},set:function(t){this.uniforms.range.value=t}},animationProgress:{enumerable:!0,get:function(){return this.uniforms.animationProgress.value},set:function(t){this.uniforms.animationProgress.value=t}}}),n.setValues(e),n}return s})(p.ShaderMaterial);Object.assign(xt.prototype,{isLineMaterial:!0});var qt=(function(h){de(s,h);function s(e,n){var t=h.call(this)||this;return t.type="LineSegments2",t.geometry=e!==void 0?e:new St,t.material=n!==void 0?n:new xt({color:Math.random()*16777215}),t}return s.prototype.computeLineDistances=function(){for(var e=this.geometry,n=e.attributes.instanceStart,t=e.attributes.instanceEnd,r=new Float32Array(2*n.count),l=new p.Vector3,o=new p.Vector3,d=0,c=0,m=n.count;c<m;c++)l.fromBufferAttribute(n,c),o.fromBufferAttribute(t,c),d+=l.distanceTo(o);this.material.uniforms.totalLength.value=d;for(var c=0,y=0,m=n.count;c<m;c++,y+=2){l.fromBufferAttribute(n,c),o.fromBufferAttribute(t,c);var M=l.distanceTo(o);r[y]=y===0?0:r[y-1],r[y+1]=r[y]+M}var w=new p.InstancedInterleavedBuffer(r,2,1);return e.setAttribute("instanceDistanceStart",new p.InterleavedBufferAttribute(w,1,0)),e.setAttribute("instanceDistanceEnd",new p.InterleavedBufferAttribute(w,1,1)),this},s.prototype.raycast=function(e,n){e.camera===null&&console.error('LineSegments2: "Raycaster.camera" needs to be set in order to raycast against LineSegments2.');var t=e.ray,r=e.camera,l=r.projectionMatrix,o=this.geometry,d=this.material,c=d.resolution,m=d.linewidth,y=o.attributes.instanceStart,M=o.attributes.instanceEnd,w=new p.Vector4,A=new p.Vector4,S=new p.Vector4,C=new p.Vector3,E=new p.Matrix4,b=new p.Line3,T=new p.Vector3;t.at(1,S),S.w=1,S.applyMatrix4(r.matrixWorldInverse),S.applyMatrix4(l),S.multiplyScalar(1/S.w),S.x*=c.x/2,S.y*=c.y/2,S.z=0,C.copy(S);var f=this.matrixWorld;E.multiplyMatrices(r.matrixWorldInverse,f);for(var _=0,x=y.count;_<x;_++){w.fromBufferAttribute(y,_),A.fromBufferAttribute(M,_),w.w=1,A.w=1,w.applyMatrix4(E),A.applyMatrix4(E),w.applyMatrix4(l),A.applyMatrix4(l),w.multiplyScalar(1/w.w),A.multiplyScalar(1/A.w);var D=w.z<-1&&A.z<-1,X=w.z>1&&A.z>1;if(!(D||X)){w.x*=c.x/2,w.y*=c.y/2,A.x*=c.x/2,A.y*=c.y/2,b.start.copy(w),b.start.z=0,b.end.copy(A),b.end.z=0;var W=b.closestPointToPointParameter(C,!0);b.at(W,T);var q=p.MathUtils.lerp(w.z,A.z,W),ee=q>=-1&&q<=1,ie=C.distanceTo(T)<m*.5;if(ee&&ie){b.start.fromBufferAttribute(y,_),b.end.fromBufferAttribute(M,_),b.start.applyMatrix4(f),b.end.applyMatrix4(f);var z=new p.Vector3,K=new p.Vector3;t.distanceSqToSegment(b.start,b.end,K,z),n.push({point:K,pointOnLine:z,distance:t.origin.distanceTo(K),object:this,faceIndex:_})}}}},s})(p.Mesh);Object.assign(qt.prototype,{isLineSegments2:!0});var Kt=(function(h){de(s,h);function s(e,n){var t=h.call(this,e,n)||this;return t.type="Line2",t}return s})(qt);Object.assign(Kt.prototype,{isLine2:!0});var Zt=(function(h){de(s,h);function s(){var e=h.call(this)||this;return e.type="LineGeometry",e}return s.prototype.setPositions=function(e){for(var n=e.length-3,t=new Float32Array(2*n),r=0;r<n;r+=3)t[2*r]=e[r],t[2*r+1]=e[r+1],t[2*r+2]=e[r+2],t[2*r+3]=e[r+3],t[2*r+4]=e[r+4],t[2*r+5]=e[r+5];return h.prototype.setPositions.call(this,t),this},s.prototype.setColors=function(e){for(var n=e.length-3,t=new Float32Array(2*n),r=0;r<n;r+=3)t[2*r]=e[r],t[2*r+1]=e[r+1],t[2*r+2]=e[r+2],t[2*r+3]=e[r+3],t[2*r+4]=e[r+4],t[2*r+5]=e[r+5];return h.prototype.setColors.call(this,t),this},s.prototype.fromLine=function(e){var n=e.geometry;if(n instanceof p.Geometry){var t=new p.BufferGeometry().fromGeometry(n);this.setPositions(t.attributes.position.array)}else n instanceof p.BufferGeometry&&this.setPositions(n.attributes.position.array);return this},s.prototype.copy=function(){return this},s})(St);Object.assign(Zt.prototype,{isLineGeometry:!0});var Yn=(function(h){de(s,h);function s(e,n){var t=h.call(this,e)||this;t.paths=new Map,t.up=new p.Vector3(0,1,0);var r={enabled:!0,visible:!0,playing:!1};t.state=Object.assign(r,n==null?void 0:n.initialState);var l={lineCount:6,spacing:.02,lineWidth:2,color:16777215,speed:2,range:.3,waveAmp:.05,waveFreq:20,particleCount:50,maxDistance:.1,lineYOffset:.1,subMeshWidth:.3,subMeshColor:65535,subMeshOpacity:.3,subMeshMaxOpacity:.5,subMeshSegmentInterval:3,subMeshHighlightWidth:1};return t._config=j(j({},l),n==null?void 0:n.config),n!=null&&n.paths&&n.paths.length>0&&n.paths.forEach(function(o){t.addPath(o)}),t.state.enabled&&t._enable({userAction:!1}),t}return Object.defineProperty(s.prototype,"config",{get:function(){return j({},this._config)},enumerable:!1,configurable:!0}),s.prototype.updateState=function(e,n){var t=this.state;this.state=j(j({},this.state),e),this.hooks.emit("stateChange",{state:this.state,prevState:t,userAction:n})},s.prototype.load=function(e,n){return Fe(this,void 0,void 0,function(){var t,r=this;return Ie(this,function(l){return this.clearAllPaths(),e.paths.forEach(function(o){var d,c,m=o.points.map(function(y){return new p.Vector3(y.x,y.y,y.z)});r.addPath({id:o.id,points:m,enabled:(d=o.enabled)!==null&&d!==void 0?d:!0,visible:(c=o.visible)!==null&&c!==void 0?c:!0,color:o.color,lineWidth:o.lineWidth,speed:o.speed})}),t=new Map,this.paths.forEach(function(o,d){t.set(d,o.config)}),this.data={paths:t},this.hooks.emit("dataLoaded",this.data),n&&this.setState(n),[2]})})},s.prototype.addPath=function(e){var n,t,r,l,o,d,c,m;if(e.points.length<2)return console.warn("DynamicPathLinePlugin: 路径 ".concat(e.id," 至少需要2个点")),!1;if(this.paths.has(e.id))return console.warn("DynamicPathLinePlugin: 路径 ".concat(e.id," 已存在")),!1;var y=new p.CatmullRomCurve3(e.points),M=(n=e.subMeshColor)!==null&&n!==void 0?n:this._config.subMeshColor,w=(t=e.subMeshWidth)!==null&&t!==void 0?t:this._config.subMeshWidth,A=(r=e.subMeshOpacity)!==null&&r!==void 0?r:this._config.subMeshOpacity,S=(l=e.enableSubMesh)!==null&&l!==void 0?l:!0,C=(o=e.speed)!==null&&o!==void 0?o:this._config.speed,E=(d=e.range)!==null&&d!==void 0?d:this._config.range,b=this.createLines(e,y,E),T=this.createParticles(),f=T.particles,_=T.particleGeometry,x=T.particleMaterial,D=T.particleInfos,X=T.particlePositions,W=this.createSubMeshGeometry(e,y,w),q=y.getLength(),ee=this.createSubMeshMaterial(M,A,q,E);ee.uniforms.totalLength.value=q;var ie=new p.Mesh(W,ee);ie.visible=S,this.five.scene.add(ie);var z={id:e.id,config:e,curve:y,lines:b,particles:f,particleGeometry:_,particleMaterial:x,particleInfos:D,particlePositions:X,enabled:(c=e.enabled)!==null&&c!==void 0?c:!0,visible:(m=e.visible)!==null&&m!==void 0?m:!0,startOffset:0,endOffset:0,lastAnimationProgress:0,cycleStartTime:performance.now()/1e3,isInitialAnimation:!0,isPathlineInitialAnimation:!0,subMeshUnfoldProgress:0,subMeshUnfoldStarted:!1,subMeshUnfoldStartTime:0,lastUpdateTime:performance.now()/1e3,subMesh:ie,subMeshGeometry:W,subMeshMaterial:ee,subMeshColor:M,subMeshWidth:w,subMeshOpacity:A,speed:C,animationId:null,enableSubMesh:S,isPaused:!1,pausedProgress:0,pausedTime:0};this.paths.set(e.id,z);var K=this.data,I=new Map;return this.paths.forEach(function(L,F){I.set(F,L.config)}),this.data={paths:I},this.hooks.emit("dataChange",this.data,K),this.hooks.emit("pathAdd",e.id,e),this.state.playing&&this.startPathAnimation(e.id),!0},s.prototype.removePath=function(e){var n=this.paths.get(e);if(!n)return console.warn("DynamicPathLinePlugin: 路径 ".concat(e," 不存在")),!1;this.stopPathAnimation(e),this.disposePathResources(n),this.paths.delete(e);var t=this.data,r=new Map;return this.paths.forEach(function(l,o){r.set(o,l.config)}),this.data={paths:r},this.hooks.emit("dataChange",this.data,t),this.hooks.emit("pathRemove",e),!0},s.prototype.enablePath=function(e){var n=this.paths.get(e);return n?(n.enabled=!0,this.hooks.emit("pathEnable",e),!0):(console.warn("DynamicPathLinePlugin: 路径 ".concat(e," 不存在")),!1)},s.prototype.disablePath=function(e){var n=this.paths.get(e);return n?(n.enabled=!1,this.hooks.emit("pathDisable",e),!0):(console.warn("DynamicPathLinePlugin: 路径 ".concat(e," 不存在")),!1)},s.prototype.showPath=function(e){var n=this.paths.get(e);return n?(n.visible=!0,n.lines.forEach(function(t){return t.visible=!0}),n.particles.visible=!0,n.subMesh.visible=!0,this.hooks.emit("pathShow",e),!0):(console.warn("DynamicPathLinePlugin: 路径 ".concat(e," 不存在")),!1)},s.prototype.hidePath=function(e){var n=this.paths.get(e);return n?(n.visible=!1,n.lines.forEach(function(t){return t.visible=!1}),n.particles.visible=!1,n.subMesh.visible=!1,this.hooks.emit("pathHide",e),!0):(console.warn("DynamicPathLinePlugin: 路径 ".concat(e," 不存在")),!1)},s.prototype.getPathIds=function(){return Array.from(this.paths.keys())},s.prototype.getPathConfig=function(e){var n=this.paths.get(e);return n?j({},n.config):void 0},s.prototype.clearAllPaths=function(){var e=this;this.paths.forEach(function(r,l){e.stopPathAnimation(l),e.disposePathResources(r)}),this.paths.clear();var n=this.data,t=new Map;this.paths.forEach(function(r,l){t.set(l,r.config)}),this.data={paths:t},this.hooks.emit("dataChange",this.data,n)},s.prototype.getPositions=function(e,n){for(var t=[],r=[],l=0,o=[],d=0;d<=n;d++){var c=d/n,m=e.getPoint(c);o.push(m.clone()),d>0&&(l+=m.distanceTo(o[d-1]))}for(var y=0,d=0;d<n;d++){d>0&&(y+=o[d].distanceTo(o[d-1]));var M=y/l;t.push(o[d].x,o[d].y,o[d].z),r.push(M)}return{positions:t,distanceProgress:r}},s.prototype.createLines=function(e,n,t){for(var r=this,l,o,d=[],c=e.points.length*40,m=this._config,y=m.lineCount,M=m.spacing,w=m.waveAmp,A=m.waveFreq,S=m.lineYOffset,C=(l=e.lineWidth)!==null&&l!==void 0?l:this._config.lineWidth,E=(o=e.color)!==null&&o!==void 0?o:this._config.color,b=n.getLength(),T=t/b,f=function(D){var X=(D-(y-1)/2)*M,W=e.points.map(function(I,L){var F=L/(e.points.length-1),k=n.getTangent(F).normalize(),G=new p.Vector3().crossVectors(r.up,k).normalize(),re=X*Math.abs((L-e.points.length/2)/e.points.length-.5)*-1;return I.clone().addScaledVector(G,X+re).add(new p.Vector3(0,S+.02*(D%2===0?1:0),0))}),q=new p.CatmullRomCurve3(W),ee=_.getPositions(q,c).positions,ie=new Zt;ie.setPositions(ee);var z=new xt({color:E,linewidth:C*(D%2===0?1:.5),transparent:!0,opacity:1,depthWrite:!1});z.resolution.set(_.five.camera.resolution.x,_.five.camera.resolution.y),D===0?z.waveDir=1:D===1?z.waveDir=2:D===2?z.waveDir=0:D===3?z.waveDir=3:D===4&&(z.waveDir=1),z.waveAmp=w,z.waveFreq=A,Object.assign(z.uniforms,{time:{value:0},startOffset:{value:0},range:{value:T}});var K=new Kt(ie,z);K.computeLineDistances(),d.push(K),_.five.scene.add(K)},_=this,x=0;x<y;x++)f(x);return d},s.prototype.createParticleMaterial=function(){return new p.ShaderMaterial({transparent:!0,blending:p.AdditiveBlending,depthWrite:!1,uniforms:{pointTexture:{value:new p.TextureLoader().load("https://threejs.org/examples/textures/sprites/circle.png")}},vertexShader:`
|
|
732
|
+
attribute float size;
|
|
733
|
+
varying vec2 vUv;
|
|
734
|
+
void main() {
|
|
735
|
+
vUv = uv;
|
|
736
|
+
vec4 mvPosition = modelViewMatrix * vec4(position, 1.0);
|
|
737
|
+
gl_PointSize = size * (1.0 / -mvPosition.z);
|
|
738
|
+
gl_Position = projectionMatrix * mvPosition;
|
|
739
|
+
}
|
|
740
|
+
`,fragmentShader:`
|
|
741
|
+
uniform sampler2D pointTexture;
|
|
742
|
+
void main() {
|
|
743
|
+
gl_FragColor = texture2D(pointTexture, gl_PointCoord);
|
|
744
|
+
gl_FragColor.a *= 0.15;
|
|
745
|
+
}
|
|
746
|
+
`})},s.prototype.createParticles=function(){for(var e=this._config.particleCount,n=new Float32Array(e*3),t=new p.BufferGeometry,r=this.createParticleMaterial(),l=new p.Points(t,r),o=new Float32Array(e),d=[],c=0;c<e;c++)n[c*3]=9999,n[c*3+1]=9999,n[c*3+2]=9999,o[c]=p.MathUtils.randFloat(3,9),d.push({velocity:new p.Vector3,life:3+Math.random()*2,age:0,active:!1,alpha:0,startPos:new p.Vector3});return t.setAttribute("position",new p.BufferAttribute(n,3)),t.setAttribute("size",new p.BufferAttribute(o,1)),l.frustumCulled=!1,this.five.scene.add(l),{particles:l,particleGeometry:t,particleMaterial:r,particleInfos:d,particlePositions:n}},s.prototype.createSubMeshGeometry=function(e,n,t){for(var r=e.points.length*40,l=new p.BufferGeometry,o=n.getPoints(r),d=[],c=[],m=[],y=[],M=0,w=[0],A=1;A<o.length;A++)M+=o[A].distanceTo(o[A-1]),w.push(M);for(var S=M,A=0;A<o.length;A++){var C=o[A],E=A/(o.length-1),b=n.getTangent(E).normalize(),T=new p.Vector3().crossVectors(this.up,b).normalize(),f=t/2,_=C.clone().addScaledVector(T,-f);d.push(_.x,_.y,_.z),c.push(0,w[A]/S),y.push(w[A]/S);var x=C.clone().addScaledVector(T,f);d.push(x.x,x.y,x.z),c.push(1,w[A]/S),y.push(w[A]/S)}for(var A=0;A<o.length-1;A++){var D=A*2;m.push(D,D+1,D+2),m.push(D+1,D+3,D+2)}return l.setAttribute("position",new p.Float32BufferAttribute(d,3)),l.setAttribute("uv",new p.Float32BufferAttribute(c,2)),l.setAttribute("distanceProgress",new p.Float32BufferAttribute(y,1)),l.setIndex(m),l.computeVertexNormals(),l},s.prototype.createAlphaMapTexture=function(e,n,t,r,l){for(var o=1024,d=1,c=o*d,m=new Uint8Array(c),y=1/e,M=t/e,w=n/M,A=w/2,S=0;S<o;S++){var C=S/o,E=Math.floor(C/y),b=(C-E*y)/y,T=0,f=b;if(f>.5&&(f=1-f),f<A){var _=1-f/A,x=_;T=r+(l-r)*x}else T=r;m[S]=Math.floor(T*255)}var D=new p.DataTexture(m,o,d,p.RedFormat);return D.needsUpdate=!0,D.wrapS=p.RepeatWrapping,D.wrapT=p.ClampToEdgeWrapping,D.minFilter=p.LinearFilter,D.magFilter=p.LinearFilter,D},s.prototype.createSubMeshMaterial=function(e,n,t,r){var l=this._config,o=l.subMeshSegmentInterval,d=l.subMeshHighlightWidth,c=l.subMeshMaxOpacity,m=Math.max(1,Math.round(t/o)),y=r/t,M=this.createAlphaMapTexture(m,d,t,n,c);return new p.ShaderMaterial({transparent:!0,side:p.BackSide,depthWrite:!1,uniforms:{baseColor:{value:new p.Color(e)},baseOpacity:{value:n},globalOpacity:{value:1},animationProgress:{value:0},range:{value:y},startOffset:{value:0},endOffset:{value:0},totalLength:{value:1},unfoldProgress:{value:0},alphaMap:{value:M}},vertexShader:`
|
|
747
|
+
attribute float distanceProgress;
|
|
748
|
+
varying vec2 vUv;
|
|
749
|
+
varying float vDistanceProgress;
|
|
750
|
+
|
|
751
|
+
void main() {
|
|
752
|
+
vUv = uv;
|
|
753
|
+
vDistanceProgress = distanceProgress;
|
|
754
|
+
gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);
|
|
755
|
+
}
|
|
756
|
+
`,fragmentShader:`
|
|
757
|
+
uniform vec3 baseColor;
|
|
758
|
+
uniform float baseOpacity;
|
|
759
|
+
uniform float globalOpacity;
|
|
760
|
+
uniform float animationProgress;
|
|
761
|
+
uniform float range;
|
|
762
|
+
uniform float startOffset;
|
|
763
|
+
uniform float endOffset;
|
|
764
|
+
uniform float totalLength;
|
|
765
|
+
uniform float unfoldProgress;
|
|
766
|
+
uniform sampler2D alphaMap;
|
|
767
|
+
|
|
768
|
+
varying vec2 vUv;
|
|
769
|
+
varying float vDistanceProgress;
|
|
770
|
+
|
|
771
|
+
void main() {
|
|
772
|
+
// 计算调整后的距离进度
|
|
773
|
+
float adjustedDistanceStart = max(0.0, startOffset);
|
|
774
|
+
float adjustedTotalLength = totalLength - startOffset - endOffset;
|
|
775
|
+
adjustedTotalLength = max(0.01, adjustedTotalLength);
|
|
776
|
+
float adjustedProgress = (vDistanceProgress * totalLength - adjustedDistanceStart) / adjustedTotalLength;
|
|
777
|
+
|
|
778
|
+
// 如果在裁剪范围外,丢弃片段
|
|
779
|
+
if (adjustedProgress < 0.0 || adjustedProgress > 1.0) {
|
|
780
|
+
discard;
|
|
781
|
+
}
|
|
782
|
+
|
|
783
|
+
// 展开效果:只显示已展开的部分
|
|
784
|
+
if (adjustedProgress > unfoldProgress) {
|
|
785
|
+
discard;
|
|
786
|
+
}
|
|
787
|
+
|
|
788
|
+
// 计算 UV 坐标用于采样 alphaMap
|
|
789
|
+
// u 坐标 = 当前位置 + 动画进度(形成移动效果)
|
|
790
|
+
float u = fract(adjustedProgress - animationProgress);
|
|
791
|
+
vec2 uv = vec2(u, 0.5);
|
|
792
|
+
|
|
793
|
+
// 从 alphaMap 采样透明度
|
|
794
|
+
float sampledAlpha = texture2D(alphaMap, uv).r;
|
|
795
|
+
|
|
796
|
+
// 展开前进头部的渐变遮罩,固定物理距离为 1 米
|
|
797
|
+
float unfoldFadeLength = 1.0 / totalLength; // 1米 / 总长度 = 百分比
|
|
798
|
+
float distanceToUnfoldEdge = unfoldProgress - adjustedProgress;
|
|
799
|
+
if (distanceToUnfoldEdge < unfoldFadeLength && distanceToUnfoldEdge > 0.0) {
|
|
800
|
+
sampledAlpha *= distanceToUnfoldEdge / unfoldFadeLength;
|
|
801
|
+
}
|
|
802
|
+
|
|
803
|
+
// 增加开头和结尾的渐变 alpha 遮罩,固定物理距离为 1 米
|
|
804
|
+
float fadeLength = 1.0 / totalLength; // 1米 / 总长度 = 百分比
|
|
805
|
+
if (adjustedProgress < fadeLength) {
|
|
806
|
+
sampledAlpha *= adjustedProgress / fadeLength;
|
|
807
|
+
}
|
|
808
|
+
float endFadeStart = 1.0 - fadeLength;
|
|
809
|
+
if (adjustedProgress > endFadeStart) {
|
|
810
|
+
sampledAlpha *= (1.0 - adjustedProgress) / fadeLength;
|
|
811
|
+
}
|
|
812
|
+
|
|
813
|
+
gl_FragColor = vec4(baseColor, sampledAlpha * globalOpacity);
|
|
814
|
+
}
|
|
815
|
+
`})},s.prototype.projectPointsToScreen=function(e,n){for(var t=[],r=0,l=0;l<e.length;l++){var o=e[l];l>0&&(r+=o.distanceTo(e[l-1]));var d=o.clone().project(n),c=d.x<-1||d.x>1||d.y<-1||d.y>1||d.z<-1||d.z>1;t.push({point:o.clone(),screenPos:new p.Vector2(d.x,d.y),distanceFromStart:r,isOffscreen:c})}return t},s.prototype.findNearestOffscreenPoint=function(e){for(var n=-1,t=0,r=-1,l=0;l<e.length;l++)if(!e[l].isOffscreen){r=l;break}if(r===-1)return null;for(var l=r-1;l>=0;l--)if(e[l].isOffscreen){n=l,t=e[l].distanceFromStart;break}return n===-1?{index:0,distance:0}:{index:n,distance:t}},s.prototype.findFarestOffscreenPoint=function(e){for(var n,t=((n=e[e.length-1])===null||n===void 0?void 0:n.distanceFromStart)||0,r=-1,l=e.length-1;l>=0;l--)if(!e[l].isOffscreen){r=l;break}if(r===-1)return null;var o=r+1;return o<e.length&&e[o].isOffscreen?{index:o,distance:e[o].distanceFromStart,totalLength:t}:{index:e.length-1,distance:t,totalLength:t}},s.prototype.updatePathAnimation=function(e){var n,t,r=this.paths.get(e);if(!(!r||!r.enabled)){var l=performance.now()/1e3,o=this._config,d=o.particleCount,c=o.maxDistance,m=((n=r.lines[0])===null||n===void 0?void 0:n.material.uniforms.totalLength.value)||1,y=Math.max(.01,m-r.startOffset-r.endOffset),M=r.speed,w=(l-r.cycleStartTime)*M/y%1;if(r.isInitialAnimation){var A=w*y;if(r.enableSubMesh&&A>=1&&!r.subMeshUnfoldStarted&&(r.subMeshUnfoldStarted=!0,r.subMeshUnfoldStartTime=l),r.enableSubMesh&&r.subMeshUnfoldStarted&&r.subMeshUnfoldProgress<1&&!r.isPaused){var S=(t=r.config.range)!==null&&t!==void 0?t:this._config.range,C=l-r.subMeshUnfoldStartTime;r.subMeshUnfoldProgress=Math.min(1,C*M/(y-2*S)),r.subMeshMaterial.uniforms.unfoldProgress.value=r.subMeshUnfoldProgress}w<r.lastAnimationProgress&&(r.isPathlineInitialAnimation=!1,(!r.enableSubMesh||r.subMeshUnfoldProgress>=1)&&(r.isInitialAnimation=!1))}else r.enableSubMesh&&(r.subMeshMaterial.uniforms.unfoldProgress.value=1);if(r.lastAnimationProgress=w,r.lastUpdateTime=l,r.isPathlineInitialAnimation&&r.lines.forEach(function(q){q.material.uniforms.time.value=l,q.material.uniforms.animationProgress.value=w}),r.isPathlineInitialAnimation){var E=null,b=1/0;if(r.lines.forEach(function(q){for(var ee=q.geometry,ie=ee.attributes.instanceDistanceStart,z=ee.attributes.instanceDistanceEnd,K=ie.count,I=0;I<K;I++){var L=ie.getX(I)/q.material.uniforms.totalLength.value,F=z.getX(I)/q.material.uniforms.totalLength.value;if(w>=L&&w<=F){var k=(w-L)/(F-L),G=new p.Vector3().fromBufferAttribute(ee.attributes.instanceStart,I),re=new p.Vector3().fromBufferAttribute(ee.attributes.instanceEnd,I),Z=new p.Vector3().lerpVectors(G,re,k),V=Math.abs(w-(L+F)/2);V<b&&(b=V,E=Z)}}}),E)for(var T=0;T<d;T++){var f=r.particleInfos[T];!f.active&&Math.random()<.05&&(f.active=!0,f.age=0,f.life=3+Math.random()*2,f.velocity.set((Math.random()-.5)*1e-4,(Math.random()-.5)*1e-4,(Math.random()-.5)*1e-4),r.particlePositions[T*3]=E.x,r.particlePositions[T*3+1]=E.y,r.particlePositions[T*3+2]=E.z,f.startPos.copy(E),f.alpha=0)}for(var T=0;T<d;T++){var f=r.particleInfos[T];if(f.active){f.age+=.016;var _=r.particlePositions[T*3]-f.startPos.x,x=r.particlePositions[T*3+1]-f.startPos.y,D=r.particlePositions[T*3+2]-f.startPos.z,X=Math.sqrt(_*_+x*x+D*D);(X>=c||f.age>=f.life)&&(f.active=!1,r.particlePositions[T*3]=9999,r.particlePositions[T*3+1]=9999,r.particlePositions[T*3+2]=9999,f.alpha=0),f.velocity.x+=(Math.random()-.5)*1e-4,f.velocity.z+=(Math.random()-.5)*1e-4,f.velocity.y+=1e-4,f.velocity.multiplyScalar(.99),r.particlePositions[T*3]+=f.velocity.x,r.particlePositions[T*3+1]+=f.velocity.y,r.particlePositions[T*3+2]+=f.velocity.z;var W=f.age/f.life;W<.2?f.alpha=W/.2:W>.8?f.alpha=(1-W)/.2:f.alpha=1}}r.particleGeometry.attributes.position.needsUpdate=!0,r.particleMaterial.opacity=.6}r.enableSubMesh&&(r.subMeshMaterial.uniforms.animationProgress.value=w),this.five.needsRender=!0}},s.prototype.startPathAnimation=function(e,n){var t=this,r,l,o=this.paths.get(e);if(!o)return console.warn("DynamicPathLinePlugin: 路径 ".concat(e," 不存在")),!1;if(o.animationId!==null)return!1;var d=(r=n==null?void 0:n.startPointIndex)!==null&&r!==void 0?r:0,c=(l=n==null?void 0:n.fromStart)!==null&&l!==void 0?l:!1;if(!o.isPaused||c){var m=0,y=d;if(y>0){var M=o.config.points;y>=M.length&&(console.warn("DynamicPathLinePlugin: startPointIndex ".concat(y," 超出范围,路径只有 ").concat(M.length," 个点")),y=M.length-1);for(var w=0;w<y;w++)m+=M[w].distanceTo(M[w+1])}o.startOffset=m,o.lines.forEach(function(T){T.material.uniforms.startOffset.value=m}),o.enableSubMesh&&(o.subMeshMaterial.uniforms.startOffset.value=m)}var A=performance.now()/1e3;if(!c&&o.isPaused&&o.pausedProgress>0){var S=o.curve.getLength(),C=Math.max(.01,S-o.startOffset-o.endOffset),E=o.speed;if(o.cycleStartTime=A-o.pausedProgress*C/E,o.subMeshUnfoldStarted&&o.subMeshUnfoldProgress<1){var b=o.pausedTime-o.subMeshUnfoldStartTime;o.subMeshUnfoldStartTime=A-b}o.isPaused=!1}else o.cycleStartTime=A,o.isPaused=!1,o.pausedProgress=0;return o.lastUpdateTime=A,this.highlightPath(e,!0),o.animationId=Se.AnimationFrameLoop.shared.add(function(){t.updatePathAnimation(e)}),!0},s.prototype.stopPathAnimation=function(e,n){n===void 0&&(n=!1);var t=this.paths.get(e);if(!t)return console.warn("DynamicPathLinePlugin: 路径 ".concat(e," 不存在")),!1;if(this.highlightPath(e,!1),t.animationId!==null){if(n){var r=performance.now()/1e3,l=t.curve.getLength(),o=Math.max(.01,l-t.startOffset-t.endOffset),d=t.speed;if(t.pausedProgress=(r-t.cycleStartTime)*d/o%1,t.pausedTime=r,t.isPaused=!0,t.subMeshUnfoldStarted&&t.subMeshUnfoldProgress<1){var c=r-t.subMeshUnfoldStartTime;t.subMeshUnfoldStartTime=r-c}}else t.isPaused=!1,t.pausedProgress=0,t.pausedTime=0;t.animationId(),t.animationId=null}return!0},s.prototype._enable=function(e){this.paths.size>0&&this.state.playing&&this.play()},s.prototype._disable=function(e){this.pause()},s.prototype.enable=function(e){var n;if(!this.state.enabled){var t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.updateState({enabled:!0},t),this._enable({userAction:t})}},s.prototype.disable=function(e){var n;if(this.state.enabled!==!1){var t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.updateState({enabled:!1},t),this._disable({userAction:t})}},s.prototype.show=function(e){var n,t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.paths.forEach(function(r){r.lines.forEach(function(l){return l.visible=!0}),r.particles.visible=!0,r.subMesh.visible=!0}),this.updateState({visible:!0},t)},s.prototype.hide=function(e){var n,t=(n=e==null?void 0:e.userAction)!==null&&n!==void 0?n:!0;this.paths.forEach(function(r){r.lines.forEach(function(l){return l.visible=!1}),r.particles.visible=!1,r.subMesh.visible=!1}),this.updateState({visible:!1},t)},s.prototype.setState=function(e,n){var t;t=n==null?void 0:n.userAction,e.enabled!==void 0&&e.enabled!==this.state.enabled&&(e.enabled?this.enable(n):this.disable(n)),e.visible!==void 0&&e.visible!==this.state.visible&&(e.visible?this.show(n):this.hide(n))},s.prototype.play=function(e){var n=this;e===void 0&&(e=!1),this.paths.forEach(function(t,r){n.startPathAnimation(r,{fromStart:e})}),this.updateState({playing:!0},!1),this.hooks.emit("animationStart")},s.prototype.pause=function(){var e=this;this.paths.forEach(function(n,t){e.stopPathAnimation(t,!0)}),this.updateState({playing:!1},!1),this.hooks.emit("animationStop")},s.prototype.reset=function(){var e=this;this.paths.forEach(function(n,t){e.stopPathAnimation(t)}),this.paths.forEach(function(n){n.isInitialAnimation=!0,n.isPathlineInitialAnimation=!0,n.subMeshUnfoldProgress=0,n.subMeshUnfoldStarted=!1,n.subMeshUnfoldStartTime=0,n.lastAnimationProgress=0,n.cycleStartTime=performance.now()/1e3,n.lastUpdateTime=performance.now()/1e3,n.startOffset=0,n.endOffset=0,n.isPaused=!1,n.pausedProgress=0,n.pausedTime=0,n.lines.forEach(function(o){o.visible=!0,o.material.uniforms.time.value=0,o.material.uniforms.animationProgress.value=0,o.material.uniforms.startOffset.value=0,o.material.uniforms.endOffset.value=0}),n.particles.visible=!0;for(var t=e._config.particleCount,r=0;r<t;r++){var l=n.particleInfos[r];l.active=!1,l.age=0,l.alpha=0,n.particlePositions[r*3]=9999,n.particlePositions[r*3+1]=9999,n.particlePositions[r*3+2]=9999}n.particleGeometry.attributes.position.needsUpdate=!0,n.subMeshMaterial&&(n.subMeshMaterial.uniforms.unfoldProgress.value=0,n.subMeshMaterial.uniforms.animationProgress.value=0,n.subMeshMaterial.uniforms.startOffset.value=0,n.subMeshMaterial.uniforms.endOffset.value=0)})},s.prototype.highlightPath=function(e,n){var t=this,r=this.paths.get(e);if(r)var l=r.lines,o=0,d=250,c=Se.AnimationFrameLoop.shared.add(function(m,y){o=Math.min(1,o+y/d),n?(l.forEach(function(M){M.material.uniforms.opacity.value=.3+o*.7}),r.particleMaterial.opacity=.3+o*.7,r.enableSubMesh&&(r.subMeshMaterial.uniforms.globalOpacity.value=.3+o*.7)):(l.forEach(function(M){M.material.uniforms.opacity.value=1-o*.7}),r.particleMaterial.opacity=.6*(1-o*.7),r.enableSubMesh&&(r.subMeshMaterial.uniforms.globalOpacity.value=1-o*.7)),t.five.needsRender=!0,o===1&&c()})},s.prototype.updateScreenProjection=function(e){var n=this,t=function(l){var o=n.projectPointsToScreen(l.config.points,n.five.camera),d=n.findNearestOffscreenPoint(o);d&&(l.startOffset=d.distance);var c=n.findFarestOffscreenPoint(o);c&&(l.endOffset=c.totalLength-c.distance),l.lines.forEach(function(m){m.material.uniforms.startOffset.value=l.startOffset,m.material.uniforms.endOffset.value=l.endOffset}),l.subMeshMaterial.uniforms.startOffset.value=l.startOffset,l.subMeshMaterial.uniforms.endOffset.value=l.endOffset,l.cycleStartTime=performance.now()/1e3,l.lastAnimationProgress=0};if(e){var r=this.paths.get(e);r&&t(r)}else this.paths.forEach(function(l){l.enabled&&t(l)})},s.prototype.disposePathResources=function(e){var n=this;e.lines.forEach(function(t){n.five.scene.remove(t),t.geometry.dispose(),t.material.dispose()}),this.five.scene.remove(e.particles),e.particleGeometry.dispose(),e.particleMaterial.dispose(),this.five.scene.remove(e.subMesh),e.subMeshGeometry.dispose(),e.subMeshMaterial.dispose()},s.prototype.dispose=function(){this.pause(),this.clearAllPaths(),this.hooks.emit("dispose")},s})(At.BasePlugin.Controller),Wn=function(h,s){return new Yn(h,s)};exports.BackgroundPlugin=Bn;exports.CSS3DRenderer=Wt;exports.DynamicPathLinePlugin=Wn;exports.ItemMaskPlugin=Fn;exports.OrbitControls=ke;exports.OrientationPlugin=Nn;exports.PanoAnimePlugin=Hn;exports.RoundedBoxGeometry=Xt;exports.TrajectoryPlugin=Vn;
|