@aibee/crc-bmap 0.0.41 → 0.0.43

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.
@@ -1,3 +1,3 @@
1
- var zt=Object.defineProperty,Ht=Object.defineProperties;var Bt=Object.getOwnPropertyDescriptors;var ut=Object.getOwnPropertySymbols;var It=Object.prototype.hasOwnProperty,Vt=Object.prototype.propertyIsEnumerable;var b=Math.pow,ot=(r,s,t)=>s in r?zt(r,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[s]=t,D=(r,s)=>{for(var t in s||(s={}))It.call(s,t)&&ot(r,t,s[t]);if(ut)for(var t of ut(s))Vt.call(s,t)&&ot(r,t,s[t]);return r},rt=(r,s)=>Ht(r,Bt(s));var o=(r,s,t)=>(ot(r,typeof s!="symbol"?s+"":s,t),t);var G=(r,s,t)=>new Promise((e,i)=>{var n=p=>{try{c(t.next(p))}catch(h){i(h)}},a=p=>{try{c(t.throw(p))}catch(h){i(h)}},c=p=>p.done?e(p.value):Promise.resolve(p.value).then(n,a);c((t=t.apply(r,s)).next())});import{EventDispatcher as oi}from"three";var M=class{constructor(){o(this,"tasks",{requestAnimation:new Set,timeout:new Set,interval:new Set})}requestAnimationFrame(s){let t=window.requestAnimationFrame(()=>{this.tasks.requestAnimation.delete(t),s()});return this.tasks.requestAnimation.add(t),t}cancelAnimationFrame(s){this.tasks.requestAnimation.delete(s),window.cancelAnimationFrame(s)}setTimeout(s,t){let e=window.setTimeout(()=>{this.tasks.timeout.delete(e),s()},t);return this.tasks.timeout.add(e),e}clearTimeout(s){this.tasks.timeout.delete(s),window.clearTimeout(s)}setInterval(s,t){let e=window.setInterval(()=>{this.tasks.interval.delete(e),s()},t);return this.tasks.interval.add(e),e}clearInterval(s){this.tasks.interval.delete(s),window.clearInterval(s)}dispose(){this.tasks.requestAnimation.forEach(s=>{window.cancelAnimationFrame(s)}),this.tasks.requestAnimation.clear(),this.tasks.timeout.forEach(s=>{window.clearTimeout(s)}),this.tasks.timeout.clear(),this.tasks.interval.forEach(s=>{window.clearInterval(s)}),this.tasks.interval.clear()}};import{Scene as $t,WebGLRenderer as Kt,OrthographicCamera as Ut,HemisphereLight as jt,Shape as _t,PCFSoftShadowMap as Xt,Group as Wt,Color as Zt,DirectionalLight as Yt,AmbientLight as qt,Path as Nt,Vector2 as gt}from"three";import{MapControls as Qt}from"three/examples/jsm/controls/MapControls";function ft(){let r=new $t;return r.background=new Zt(16777215),r}function vt(){let r=new Kt({antialias:!0});return r.setClearColor(16777215),r.setPixelRatio(window.devicePixelRatio),r.shadowMap.enabled=!0,r.shadowMap.autoUpdate=!0,r.shadowMap.type=Xt,r}function yt(r,s){let t=new Ut(-r/2,r/2,s/2,-s/2,-1e3,5e3);return t.up.set(0,0,1),t.position.set(0,0,100),t.lookAt(0,0,0),t}function xt(){let r=new Wt,s=new jt(16777215,16777215,2);s.intensity=1,s.position.set(0,0,10),s.up.set(0,0,1),r.add(s);let t=new qt(16777215,1);return r.add(t),r}function bt(r,s){let t=new Qt(r,s);return t.enableDamping=!1,t.zoomSpeed=2,t}function Et(r,s=[]){let t=new _t(r.map(e=>new gt(...e)));return s.length&&s.forEach(e=>{var i=new Nt(e.map(n=>new gt(...n)));t.holes.push(i)}),t}function Pt(r=16777215,s=1){let t=new Yt(r,s);return t.castShadow=!0,t.shadow.radius=8,t.shadow.bias=-.001,t.shadow.mapSize.set(128,128),t.shadow.camera.left=-200,t.shadow.camera.right=200,t.shadow.camera.top=200,t.shadow.camera.bottom=-200,t}function L(r,s){var t;if(s&&r.children&&r.children.length&&r.children.forEach(e=>{L(e,s)}),r.isMesh){let e=r;e.geometry&&e.geometry.dispose(),e.material&&(Array.isArray(e.material)?e.material.forEach(i=>{i.dispose()}):e.material.dispose())}r.isLight&&((t=r.dispose)==null||t.call(r))}function wt(r){return/[\u4E00-\u9FA5]+/g.test(r)}import{DataTexture as Jt,RGBAFormat as te,LinearFilter as Ct}from"three";var B=new Map;function ee(){let r=document.createElement("canvas");r.width=1024,r.height=64;let s=r.getContext("2d",{willReadFrequently:!0});return s.font="54px sans-serif",s.textBaseline="hanging",s.lineWidth=12,s.fillStyle="rgba(0,0,0,1)",s.strokeStyle="white",{canvas:r,ctx:s}}var st,S;function ie(){if(!st){let{canvas:r,ctx:s}=ee();st=r,S=s}}function gi(r){if(B.has(r))return B.get(r);ie(),S.clearRect(0,0,1024,64);let s=wt(r)?4:8;S.strokeText(r,2,s),S.fillText(r,2,s);let t=Math.ceil(S.measureText(r).width);t=t%2===0?t:t+1,t+=2;let e=S.getImageData(0,0,t,64),i=new Jt(Uint8Array.from(e.data),t,64,te);return i.flipY=!0,i.minFilter=Ct,i.magFilter=Ct,B.set(r,i),i}function Lt(){B.clear()}function Gt(){S=null,st=null}import{point as ne,featureCollection as oe,center as re}from"@turf/turf";function f(r,s,t,e){let i=r.clone().project(s),n=t/2,a=e/2,c=Math.round(i.x*n+n),p=Math.round(-i.y*a+a);return{x:c,y:p}}function at(r){let s=oe(r.map(e=>ne(e)));return re(s).geometry.coordinates}function I(r,s,t){return r.x>=s.x&&r.x<=t.x&&r.y>=s.y&&r.y<=t.y}function V(r,s){return new Proxy(r,{get:(t,e,i)=>Reflect.get(t,e,i),set:(t,e,i,n)=>{let a=Reflect.set(t,e,i,n);return s.dispatchEvent({type:`change-${e}`,value:i}),a}})}function $(r,s){return Promise.race([r,new Promise((t,e)=>{setTimeout(()=>e(new Error("Promise timeout")),s)})])}function K(r){return document.createElementNS("http://www.w3.org/2000/svg",r)}function Mt(r,s){let t=K("svg");return t.setAttribute("width",r),t.setAttribute("height",s),t.style.cssText="position: absolute; left: 0; top: 0; pointer-events: none;",t}function k(r="2",s){let t=K("circle");return t.setAttribute("r",r),t.setAttribute("fill",s),t}function U(r){let s=K("line");return s.setAttribute("stroke",r),s}function O(r,s){let t=K("rect");return t.setAttribute("stroke",r),t.setAttribute("fill",s),t}function F(r,s,t){r.setAttribute("cx",`${s}`),r.setAttribute("cy",`${t}`)}function E(r,s,t){s&&(r.setAttribute("x1",`${s.x}`),r.setAttribute("y1",`${s.y}`)),t&&(r.setAttribute("x2",`${t.x}`),r.setAttribute("y2",`${t.y}`))}function P(r,s,t,e,i){r.setAttribute("x",`${s}`),r.setAttribute("y",`${t}`),r.setAttribute("width",`${e}`),r.setAttribute("height",`${i}`)}function ct(){return Promise.resolve()}function wi(r){return parseInt(r.replace("#","0x"),16)}import{EventDispatcher as Ye,Box2 as qe,Vector3 as et,Vector2 as it,Raycaster as Ne,Box3 as Qe,Color as Je,AmbientLight as ti}from"three";import{Group as ei,Tween as dt}from"@tweenjs/tween.js";import{EventDispatcher as We}from"three";import{Object3D as se,ExtrudeGeometry as ae,MeshStandardMaterial as ce,Mesh as he,Color as ht,Box3 as Dt,EdgesGeometry as pe,Vector3 as pt}from"three";import{merge as le}from"lodash";import{LineMaterial as me}from"three/examples/jsm/lines/LineMaterial.js";import{LineSegmentsGeometry as de}from"three/examples/jsm/lines/LineSegmentsGeometry.js";import{LineSegments2 as ue}from"three/examples/jsm/lines/LineSegments2.js";var ge={id:"",height:.1,airHeight:0,area:0,group:"",fillColor:"#EFF4FB",strokeColor:"#ffffff",fillOpacity:1,strokeOpacity:1,strokeWidth:1,doors:[],locked:!1,visible:!0,geometry:{type:"polygon",cds:[],curveCpt:[],curveIndex:[]},layerType:"",zIndex:0},w=class extends se{constructor(t,e){super();this.context=t;o(this,"geometry");o(this,"material");o(this,"mesh");o(this,"line");o(this,"options");if(this.options=V(le({},ge,e),this),this.options.geometry.type==="point"){let[i,n]=this.options.geometry.cds;return this.position.set(i,n,this.options.height+this.options.airHeight),this}this.init(),this.visible=this.options.visible,this.addEventListener("change-fillColor",({value:i})=>{this.material.color=new ht(i)}),this.addEventListener("change-fillOpacity",({value:i})=>{this.material.opacity=i}),this.addEventListener("change-height",({value:i})=>{this.dispose(),this.init()}),this.addEventListener("change-strokeColor",({value:i})=>{this.line.material.color=new ht(i)}),this.addEventListener("change-strokeOpacity",({value:i})=>{this.line.material.opacity=i}),this.addEventListener("change-strokeWidth",({value:i})=>{this.line.material.linewidth=i}),this.addEventListener("change-airHeight",({value:i})=>{this.position.z=i}),this.addEventListener("change-visible",({value:i})=>{this.visible=i})}getCenter(){if(this.options.geometry.type==="point")return this.position;let t=new pt,e=new Dt;return e.setFromObject(this),e.getCenter(t),t}getSize(){if(this.options.geometry.type==="point")return new pt(0,0,0);let t=new Dt,e=new pt;return t.setFromObject(this),t.getSize(e),e}getPosition(){let t=this.getCenter();return t.setZ(t.z+this.options.height),t}init(){this.geometry=this.initGeometry(),this.material=this.initMaterial(),this.mesh=this.initMesh(),this.mesh.position.z=this.options.airHeight,this.mesh.castShadow=!0,this.add(this.mesh),this.line=this.createBorder(),this.add(this.line)}initGeometry(){let t=Et(this.options.geometry.cds[0],this.options.geometry.cds.slice(1));return new ae(t,{steps:1,bevelEnabled:!1,depth:this.options.height,curveSegments:4})}initMaterial(){return new ce({color:this.options.fillColor,roughness:1,transparent:!0,opacity:this.options.fillOpacity,depthWrite:!0})}initLineMaterial(){let t=new me({color:new ht(this.options.strokeColor).getHex(),opacity:this.options.strokeOpacity,transparent:!0,depthWrite:!0,linewidth:this.options.strokeWidth,wireframe:!1,dashed:!1}),{clientSize:{width:e,height:i}}=this.context;return t.resolution.set(e,i),t}initMesh(){return new he(this.geometry,this.material)}createBorder(){let t=this.initLineMaterial(),e=new pe(this.geometry),i=new de;i.fromEdgesGeometry(e);let n=new ue(i,t);return n.position.z=this.options.airHeight,n}raycast(t){if(!this.visible||this.options.geometry.type==="point")return!1;let e=t.intersectObject(this.mesh);if(e[0]){let{point:i,distance:n}=e[0];return{position:i,distance:n}}return!1}dispose(){L(this),this.clear()}};import{Object3D as fe,PlaneGeometry as ve,Mesh as ye,ShadowMaterial as xe,Color as be,DoubleSide as Ee}from"three";var j=class extends fe{constructor(){super();o(this,"directionalLight");o(this,"plane");o(this,"basicOpacity",.15);this.directionalLight=this.initLight(),this.initPlane()}initLight(){let t=Pt(16777215,1);return t.position.set(0,0,100),this.add(t),t}changeLightCamera(t){let e=t.x,i=t.y;this.directionalLight.shadow.camera.left=-e,this.directionalLight.shadow.camera.right=e,this.directionalLight.shadow.camera.top=i,this.directionalLight.shadow.camera.bottom=-i,this.directionalLight.shadow.camera.near=.5,this.directionalLight.shadow.camera.far=Math.max(e,i)}changeLightColor(t){this.directionalLight.color=new be(t)}setPosition(t){this.position.copy(t),this.directionalLight.position.set(-t.x/2,-t.y/2,100)}initPlane(t=1e3,e=1e3){let i=new ve(t,e),n=new xe({transparent:!0,opacity:0,side:Ee}),a=new ye(i,n);return a.receiveShadow=!0,a.position.z=-10,this.add(a),this.plane=a,a}setTarget(t){this.directionalLight.target=t}transformOpacity(t){return t*this.basicOpacity}setOpacity(t){this.plane.material.opacity=this.transformOpacity(t)}dispose(){L(this,!0)}};import{Object3D as Ce}from"three";import{merge as Le}from"lodash";import{Box3 as Pe,EventDispatcher as we,Vector3 as St}from"three";var _=class extends we{constructor(t){super();this.context=t;o(this,"div");o(this,"element");o(this,"position",new St);o(this,"clientPos",{x:0,y:0});o(this,"visible",!0);o(this,"onUpdate",()=>{let t=this.getPosition(),{width:e,height:i}=this.context.clientSize,{x:n,y:a}=f(t,this.context.camera,e,i);this.clientPos.x===n&&this.clientPos.y===a||(this.clientPos={x:n,y:a},this.div.style.left=`${n}px`,this.div.style.top=`${a}px`)});this.registryEvent(),this.div=this.initDiv(),this.context.container.appendChild(this.div)}initDiv(){let t=document.createElement("div");return t.style.position="absolute",t}bindElement(t){this.element=t,this.onUpdate()}unBindElement(){this.element=void 0}setVisible(t,e="block"){t!==this.visible&&(this.div.style.display=t?e:"none",this.visible=t)}setOpacity(t){this.div.style.opacity=`${t}`}getPosition(){return this.element?typeof this.element.getPosition=="function"?this.element.getPosition():new Pe().setFromObject(this.element).getCenter(new St):this.position}get withinDisplayRange(){let{x:t,y:e}=this.clientPos,{width:i,height:n}=this.context.clientSize;return t>=0&&t<=i&&e>=0&&e<=n}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}dispose(){this.unRegistryEvent(),this.unBindElement(),this.context.container.removeChild(this.div),this.div=null}};var Ge={text:"",level:1,collision_enable:!0,opacity:1,id:"",position:{x:0,y:0,z:0}},z=class extends Ce{constructor(t,e){var i,n,a;super();this.context=t;o(this,"textDiv");o(this,"img");o(this,"overlay");o(this,"options");o(this,"size",{width:0,height:0});o(this,"_changePosition",()=>{this.overlay.div.style.transform=`translate3d(-50%, ${this.options.icon?"-100%":"-50%"}, 0)`});this.options=V(Le({},Ge,e),this),this.position.set(((i=e.position)==null?void 0:i.x)||0,((n=e.position)==null?void 0:n.y)||0,((a=e.position)==null?void 0:a.z)||0),this.overlay=new _(this.context),this.overlay.bindElement(this),this.registryEvent(),this.initDiv(),this.addEventListener("change-icon",({value:c})=>{c?this.img?this.img.setAttribute("src",c):this.overlay.div.appendChild(this.initIcon()):(this.img&&this.overlay.div.removeChild(this.img),this.img=void 0,this.resetSize())}),this.addEventListener("change-text",({value:c})=>{this.overlay.div.removeChild(this.textDiv),this.overlay.div.appendChild(this.initText()),this.resetSize()}),this.addEventListener("change-opacity",({value:c})=>{this.overlay.setOpacity(c)}),this.addEventListener("change-icon_size",({value:c})=>{this.img&&(this.img.style.width=`${(c==null?void 0:c[0])||32}px`,this.img.style.height=`${(c==null?void 0:c[1])||32}px`,this.resetSize())})}get withinDisplayRange(){return this.overlay.withinDisplayRange}resetSize(){return G(this,null,function*(){let t=this.overlay.visible;this.setVisible(!0),yield ct();let{width:e,height:i}=this.overlay.div.getBoundingClientRect();this.size={width:e,height:i},yield ct(),this._changePosition(),this.setVisible(t)})}get clientPos(){return this.overlay.clientPos}initDiv(){let t=this.overlay.div;return t.appendChild(this.initText()),this.options.icon&&t.appendChild(this.initIcon()),t.style.fontSize="12px",t.style.display="flex",t.style.flexDirection="column",t.style.justifyContent="center",t.style.alignItems="center",t.style.pointerEvents="none",this.overlay.setOpacity(this.options.opacity),this.resetSize(),t}getPosition(){return this.position}initText(){let t=document.createElement("div");return t.appendChild(this.createTextFragment()),t.style.background="rgba(255, 255, 255, .7)",t.style.padding="2px",t.style.borderRadius="4px",this.textDiv=t,t}createTextFragment(){let t=document.createDocumentFragment();return this.options.text.split(`\r
2
- `).forEach(e=>{let i=document.createElement("div");i.style.whiteSpace="nowrap",i.textContent=e,t.appendChild(i)}),t}initIcon(){var e,i;let t=document.createElement("img");return t.setAttribute("src",this.options.icon),t.style.width=`${((e=this.options.icon_size)==null?void 0:e[0])||32}px`,t.style.height=`${((i=this.options.icon_size)==null?void 0:i[1])||32}px`,t.onload=()=>{this.resetSize()},this.img=t,t}registryEvent(){}unRegistryEvent(){}setVisible(t){this.overlay.setVisible(t,"flex")}getBox(){let{width:t,height:e}=this.size,{x:i,y:n}=this.overlay.clientPos;return{left:i-t/2,right:i+t/2,top:this.options.icon?n-e:n-e/2,bottom:this.options.icon?n:n+e/2}}isContain(t,e){if(!this.overlay.visible)return!1;let i=this.getBox();return t>=i.left&&t<=i.right&&e>=i.top&&e<=i.bottom}dispose(){this.unRegistryEvent(),this.textDiv=null,this.img=void 0,this.overlay.dispose()}};import{Box3 as lt,Object3D as Ot,Vector3 as mt}from"three";import{Box3 as De,Vector3 as Se}from"three";import{Object3D as Me}from"three";var A=class extends Me{constructor(t){super();this.context=t}dispose(){L(this),this.clear()}};var X=class extends A{constructor(t){super(t);o(this,"graphicMap",new Map)}getCenter(){return new De().setFromObject(this).getCenter(new Se)}createGraphic(t){let e=new w(this.context,t);return this.add(e),this.graphicMap.set(t.id,e),e}removeGraphic(t){this.remove(t),this.graphicMap.delete(t.options.id),t.dispose()}removeGraphicById(t){this.graphicMap.has(t)&&this.removeGraphic(this.graphicMap.get(t))}getGraphicByNodeId(t){return this.graphicMap.get(t)||null}getGraphicByRaycaster(t){let e={distance:1e4,graphic:null,position:null},i=this.children.reduce((n,a)=>{if(a instanceof w){let c=a.raycast(t);if(c){let{distance:p}=c;if(p<n.distance)return{distance:n.distance,position:n.position,graphic:a}}return n}else return n},e);return i===e?{graphics:[],position:null}:{graphics:[i.graphic],position:i.position}}};import{debounce as Fe}from"lodash";var W=class extends A{constructor(t){super(t);o(this,"pois",[]);o(this,"debounceCollisionDetection");o(this,"timer",new M);o(this,"onUpdate",()=>{this.timer.requestAnimationFrame(()=>{this.collisionDetection()})});this.registryEvent(),this.debounceCollisionDetection=Fe(this.collisionDetection,10)}clear(){return super.clear(),this.pois=[],this}createPoi(t){let e=new z(this.context,t);return this.add(e),this.pushPoi(e),e.addEventListener("change-level",()=>this.changePoiLevelOrCollisionEnable(e)),e.addEventListener("change-collision_enable",()=>this.changePoiLevelOrCollisionEnable(e)),Promise.resolve().then(()=>{this.debounceCollisionDetection()}),e}changePoiLevelOrCollisionEnable(t){let e=this.pois.findIndex(i=>i===t);e!==-1&&(this.pois.splice(e,1),this.pushPoi(t))}removePoi(t){let e=this.pois.findIndex(i=>i===t);e!==-1&&(this.pois.splice(e,1),this.remove(t),t.dispose())}removePoiById(t){let e=this.pois.find(i=>i.options.id===t);e&&this.removePoi(e)}getPoiById(t){return this.pois.find(i=>i.options.id===t)||null}pushPoi(t){if(!t.options.collision_enable){this.pois.unshift(t);return}if(t.options.level===1){this.pois.push(t);return}for(let e=0;e<this.pois.length;e++){let i=this.pois[e];if(i.options.collision_enable&&i.options.level<=t.options.level){this.pois.splice(e,0,t);return}}this.pois.push(t)}getPoiByDeviceXy(t,e){return this.children.filter(n=>n instanceof z&&n.isContain(t,e))}collisionDetection(){let{clientSize:{width:t,height:e}}=this.context,i=[];this.pois.filter(a=>a.withinDisplayRange).forEach((a,c)=>{let{left:p,right:h,top:l,bottom:d}=a.getBox();if(c===0){i.push({left:p,right:h,top:l,bottom:d});return}let g=i.some(m=>h<m.right&&h>m.left||p>m.left&&p<m.right||p===m.left&&h===m.right?d<=m.bottom&&d>m.top||l>=m.top&&l<m.bottom:!1);a.setVisible(!g),i.push({left:p,right:h,top:l,bottom:d})})}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}dispose(){this.timer.dispose(),this.pois.forEach(t=>t.dispose()),this.pois.length=0,this.debounceCollisionDetection=()=>{},super.dispose(),this.unRegistryEvent()}};import{MeshBasicMaterial as Oe,Object3D as Ae,PlaneGeometry as Te,Texture as Re,DoubleSide as ke,Mesh as ze,Matrix3 as Ft,Vector2 as He}from"three";import{create as Be}from"@mars3d/heatmap.js";import{featureCollection as Ie,point as Ve,bbox as $e,center as Ke}from"@turf/turf";var Z=class extends Ae{constructor(t){super();this.context=t;o(this,"heatmap");o(this,"div");o(this,"plane");this.div=document.createElement("div")}clearHeatmap(){this.div.firstChild&&this.div.removeChild(this.div.firstChild),this.heatmap=void 0}loadData(t){this.clearHeatmap();let{width:e,height:i,leftTop:n,center:a}=this.getBox(t);this.heatmap=Be(D({width:e,height:i,container:this.div},this.context.config.heatMap)),this.heatmap.setData(this.transformData(t,n)),this.initPlane(e,i),this.position.set(a[0],a[1],this.position.z)}initPlane(t,e){this.plane&&this.remove(this.plane);let i=new Te(t,e),n=new Re(this.div.firstChild);n.needsUpdate=!0;let a=new Oe({transparent:!0,side:ke,map:n});a.needsUpdate=!0,this.plane=new ze(i,a),this.add(this.plane)}getTransMatrix({x:t,y:e}){return new Ft().makeScale(1,-1).multiply(new Ft().makeTranslation(0-t,0-e))}transformData(t,e){let i=this.getTransMatrix(e);return{data:t.data.map(a=>{let c=new He(a.x,a.y).applyMatrix3(i);return{x:c.x,y:c.y,value:a.value}}),max:t.max,min:t.min}}getBox(t){let e=Ie(t.data.map(h=>Ve([h.x,h.y]))),i=$e(e),n=i[2]-i[0],a=i[3]-i[1],c={x:i[0],y:i[3]},p=Ke(e);return{width:n,height:a,leftTop:c,center:p.geometry.coordinates}}dispose(){this.div=null,this.heatmap=void 0}};var Y=class extends Ot{constructor(t){super();this.context=t;o(this,"graphicLayer");o(this,"poiLayer");o(this,"grounds",new Set);o(this,"shadow",new j);o(this,"heatmap");o(this,"groundUpper",new Ot);o(this,"groundMaxHeight",0);this.graphicLayer=new X(this.context),this.poiLayer=new W(this.context),this.groundUpper.add(this.graphicLayer),this.groundUpper.add(this.poiLayer),this.add(this.groundUpper)}addGrounds(t){t.forEach(e=>{this.grounds.has(e)||(this.grounds.add(e),this.groundUpper.add(e))}),this.changeGroundMaxHeight()}changeGroundMaxHeight(){let t=Array.from(this.grounds);this.groundMaxHeight=this.grounds.size>0?Math.max(...t.map(e=>e.options.height+e.options.airHeight)):0}get hasElement(){return!!(this.grounds.size||this.graphicLayer.children.length)}getCenter(){return new lt().setFromObject(this.groundUpper).getCenter(new mt)}addShadow(){let t=new lt().setFromObject(this.groundUpper),e=t.getCenter(new mt),i=t.getSize(new mt);this.shadow.setPosition(e),this.shadow.changeLightCamera(i),this.add(this.shadow)}addGraphic(t){return t.airHeight=Math.max(this.groundMaxHeight,t.airHeight||0),this.graphicLayer.createGraphic(t)}addPoi(t){return this.poiLayer.createPoi(t)}addHeatmap(t){this.heatmap||(this.heatmap=new Z(this.context),this.add(this.heatmap)),this.heatmap.loadData(t);let e=new lt().setFromObject(this.graphicLayer);return this.heatmap.position.setZ(e.max.z),this.heatmap}removeHeatMap(){this.heatmap&&(this.remove(this.heatmap),this.heatmap.dispose(),this.heatmap=void 0)}setShadowOpacity(t){this.shadow.setOpacity(t)}setShadowVisible(t){this.shadow.visible=t}dispose(){var t;this.shadow.dispose(),this.graphicLayer.dispose(),this.poiLayer.dispose(),this.grounds.forEach(e=>e.dispose()),(t=this.heatmap)==null||t.dispose(),this.groundUpper.clear(),this.clear()}};import{EventDispatcher as Ue,Vector3 as je}from"three";var C=class extends Ue{constructor(t){super();this.context=t;o(this,"points",[]);o(this,"svg");o(this,"enable",!0);this.svg=Mt(`${t.container.clientWidth}`,`${t.container.clientHeight}`),t.container.appendChild(this.svg)}setEnable(t){this.enable=t,t?this.svg.style.display="block":this.svg.style.display="none"}getIntersectByPointerEvent(t){let{camera:e,renderer:i}=this.context,{offsetX:n,offsetY:a}=t,{clientWidth:c,clientHeight:p}=i.domElement,h=n/c*2-1,l=1-a/p*2;return new je(h,l,0).unproject(e)}getSvgCoordinate(t){let{camera:e,container:i}=this.context;return f(t,e,i.clientWidth,i.clientHeight)}dispose(){this.context.container.removeChild(this.svg),this.svg=null}};var q=class extends C{constructor(t){super(t);this.context=t;o(this,"circles");o(this,"line");o(this,"onUpdate",()=>{if(this.points[0]){let t=this.getSvgCoordinate(this.points[0]);F(this.circles[0],t.x,t.y),E(this.line,t)}if(this.points[1]){let t=this.getSvgCoordinate(this.points[1]);F(this.circles[1],t.x,t.y),E(this.line,void 0,t)}});o(this,"onPointermove",t=>{this.points.length===1&&(this.line.style.display="block",E(this.line,void 0,{x:t.offsetX,y:t.offsetY}))});o(this,"onPointerleave",()=>{this.points[1]||(this.line.style.display="none")});o(this,"onPointerdown",t=>{if(this.points[1])return;let e=this.getIntersectByPointerEvent(t);if(e){let{offsetX:i,offsetY:n}=t,a=this.circles[this.points.length];F(a,i,n),this.points.length||E(this.line,{x:i,y:n},{x:i,y:n}),this.addPoint(e)}});let{config:{svg:{circle:e,line:i}}}=t;this.circles=[k(e.radius,e.fill),k(e.radius,e.fill)],this.line=U(i.stroke),this.svg.appendChild(this.circles[0]),this.svg.appendChild(this.circles[1]),this.svg.appendChild(this.line),this.registryEvent()}setEnable(t){super.setEnable(t),t?this.registryEvent():this.unRegistryEvent()}registryEvent(){this.context.container.addEventListener("pointerenter",this.onPointermove),this.context.container.addEventListener("pointermove",this.onPointermove),this.context.container.addEventListener("pointerleave",this.onPointerleave),this.context.container.addEventListener("pointerdown",this.onPointerdown),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerenter",this.onPointermove),this.context.container.removeEventListener("pointermove",this.onPointermove),this.context.container.removeEventListener("pointerleave",this.onPointerleave),this.context.container.removeEventListener("pointerdown",this.onPointerdown),this.context.removeEventListener("update",this.onUpdate)}addPoint(t){if(this.points.push(t),this.points.length>=2){let e=this.calculatedDistance();this.dispatchEvent({type:"distance",distance:e})}}calculatedDistance(){let[{x:t,y:e},{x:i,y:n}]=this.points;return Math.sqrt(b(i-t,2)+b(n-e,2))}dispose(){super.dispose(),this.unRegistryEvent(),this.line=null,this.circles=[]}};var N=class extends C{constructor(t){super(t);o(this,"circles",[]);o(this,"lines",[]);o(this,"isClose",!1);o(this,"onUpdate",()=>{this.points.length&&this.points.forEach((t,e)=>{let i=this.getSvgCoordinate(t);this.circles[e]&&F(this.circles[e],i.x,i.y),e!==0&&E(this.lines[e-1],void 0,i),this.lines[e]&&E(this.lines[e],i)})});o(this,"onPointermove",t=>{!this.lastLine||this.isClose||(this.lastLine.style.display="block",E(this.lastLine,void 0,{x:t.offsetX,y:t.offsetY}))});o(this,"onPointerleave",()=>{this.isClose||(this.lastLine.style.display="none")});o(this,"onPointerdown",t=>{if(this.isClose)return;let e=this.getIntersectByPointerEvent(t);if(e){let{offsetX:i,offsetY:n}=t;this.checkAdsorb(i,n)?(this.isClose=!0,this.addPoint(this.points[0])):this.addPoint(e);let{circle:{fill:a,radius:c},line:{stroke:p}}=this.context.config.svg;if(!this.isClose){let h=k(c,a);F(h,i,n),this.addCircle(h)}if(this.lines.length&&E(this.lastLine,void 0,{x:i,y:n}),!this.isClose){let h=U(p);E(h,{x:i,y:n},{x:i,y:n}),this.addLine(h)}}});this.registryEvent()}setEnable(t){super.setEnable(t),t?this.registryEvent():this.unRegistryEvent()}get lastLine(){return this.lines.slice(-1)[0]}addCircle(t){this.circles.push(t),this.svg.appendChild(t)}addLine(t){this.lines.push(t),this.svg.appendChild(t)}registryEvent(){this.context.container.addEventListener("pointerenter",this.onPointermove),this.context.container.addEventListener("pointermove",this.onPointermove),this.context.container.addEventListener("pointerleave",this.onPointerleave),this.context.container.addEventListener("pointerdown",this.onPointerdown),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerenter",this.onPointermove),this.context.container.removeEventListener("pointermove",this.onPointermove),this.context.container.removeEventListener("pointerleave",this.onPointerleave),this.context.container.removeEventListener("pointerdown",this.onPointerdown),this.context.removeEventListener("update",this.onUpdate)}checkAdsorb(t,e){if(this.points.length<3)return!1;let i=this.circles[0],n=+i.getAttribute("cx"),a=+i.getAttribute("cy");return Math.sqrt(b(t-n,2)+b(e-a,2))<=5}addPoint(t){if(this.points.push(t),this.isClose){let e=this.calculatedArea();this.dispatchEvent({type:"area",area:e})}}calculatedArea(){let t=this.points.map(n=>[n.x,n.y]),e=0,i=t.length;for(let n=0;n<i;n++){let a=(n+1)%i;e+=t[n][0]*t[a][1]-t[a][0]*t[n][1]}return Math.abs(e/2)}dispose(){super.dispose(),this.unRegistryEvent(),this.lines=[],this.circles=[]}};import{Box3 as _e}from"three";var At=class extends C{constructor(t){super(t);this.context=t;o(this,"rect");o(this,"cornerRect",[]);o(this,"centerRect",[]);o(this,"graphic");o(this,"onUpdate",()=>{if(this.graphic){let t=new _e().setFromObject(this.graphic),{camera:e,container:{clientWidth:i,clientHeight:n}}=this.context,{min:a,max:c}=t,p=f(a,e,i,n),h=f(c,e,i,n);P(this.rect,p.x,h.y,Math.abs(h.x-p.x),Math.abs(h.y-p.y));let{x:l,y:d}=p,{x:g,y:m}=h,u=5,v=[{x:l-u,y:m-u},{x:g-u,y:m-u},{x:l-u,y:d-u},{x:g-u,y:d-u}];for(let x=0;x<v.length;x++)P(this.cornerRect[x],v[x].x,v[x].y,u*2,u*2);let y=4,T=(l+g)/2,H=(d+m)/2,R=[{x:T-y,y:m-y},{x:l-y,y:H-y},{x:g-y,y:H-y},{x:T-y,y:d-y}];for(let x=0;x<R.length;x++)P(this.centerRect[x],R[x].x,R[x].y,y*2,y*2)}else{P(this.rect,0,0,0,0);for(let t=0;t<this.cornerRect.length;t++)P(this.cornerRect[t],0,0,0,0),P(this.centerRect[t],0,0,0,0)}});let{config:{svg:{line:e}}}=t;this.rect=O(e.stroke,"transparent"),this.svg.appendChild(this.rect);for(let i=0;i<4;i++)this.cornerRect[i]=O(e.stroke,"#ffffff"),this.centerRect[i]=O(e.stroke,"#ffffff"),this.svg.appendChild(this.cornerRect[i]),this.svg.appendChild(this.centerRect[i]);this.registryEvent()}setEnable(t){super.setEnable(t),t?this.registryEvent():this.unRegistryEvent()}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}selectGraphic(t){this.graphic=t}dispose(){super.dispose(),this.unRegistryEvent(),this.rect=null,this.cornerRect=[],this.centerRect=[]}};import{Frustum as Xe}from"three";var Q=class extends C{constructor(t){super(t);o(this,"startPoint");o(this,"endPoint");o(this,"rect");o(this,"frustum",new Xe);o(this,"onPointerDown",t=>{if(!this.enable)return;let e=this.getIntersectByPointerEvent(t);e&&(this.startPoint=e),this.endPoint=void 0});o(this,"onPointerMove",t=>{if(!this.enable||!this.startPoint)return;let e=this.getIntersectByPointerEvent(t);e&&(this.endPoint=e)});o(this,"onPointerUp",t=>{if(!this.enable)return;let e=this.getIntersectByPointerEvent(t);e&&(this.endPoint=e),this.doSelect(),this.startPoint=void 0});o(this,"onUpdate",()=>{if(this.startPoint){let t=this.getSvgCoordinate(this.startPoint),e=D({},t);this.endPoint&&(e=this.getSvgCoordinate(this.endPoint));let i={x:Math.min(t.x,e.x),y:Math.min(t.y,e.y)},n=Math.abs(e.x-t.x),a=Math.abs(e.y-t.y);P(this.rect,i.x,i.y,n,a)}else P(this.rect,0,0,0,0)});let{config:{selectBox:{fill:e,stroke:i}}}=t;this.rect=O(i,e),this.svg.appendChild(this.rect),this.registryEvent()}setEnable(t){super.setEnable(t),P(this.rect,0,0,0,0),t?this.registryEvent():(this.startPoint=void 0,this.unRegistryEvent())}registryEvent(){this.context.container.addEventListener("pointerdown",this.onPointerDown),this.context.container.addEventListener("pointermove",this.onPointerMove),this.context.container.addEventListener("pointerup",this.onPointerUp),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerdown",this.onPointerDown),this.context.container.removeEventListener("pointermove",this.onPointerMove),this.context.container.removeEventListener("pointerup",this.onPointerUp),this.context.removeEventListener("update",this.onUpdate)}doSelect(){if(this.startPoint&&this.endPoint){if(this.startPoint.distanceTo(this.endPoint)<.1)return;let{context:{camera:e,container:{clientWidth:i,clientHeight:n}}}=this,a=f(this.startPoint,e,i,n),c=f(this.endPoint,e,i,n),p={x:Math.min(a.x,c.x),y:Math.min(a.y,c.y)},h={x:Math.max(a.x,c.x),y:Math.max(a.y,c.y)},l=this.searchMapInFrustum(p,h);this.dispatchEvent({type:"selected",list:l})}}searchMapInFrustum(t,e){var n;let{context:i}=this;return((n=i.currentFloor)==null?void 0:n.graphicLayer.children.filter(a=>a instanceof w&&this.searchChildInFrustum(a,t,e)))||[]}searchChildInFrustum(t,e,i){let{context:{camera:n,container:{clientWidth:a,clientHeight:c}}}=this;if(!t)return!1;if(!t.mesh){let m=t.getPosition();if(m){let u=f(m,n,a,c);return I(u,e,i)}return!1}t.mesh.geometry.boundingBox||t.mesh.geometry.computeBoundingBox();let p=t.mesh.geometry.boundingBox;if(!p)return!1;let{min:h,max:l}=p,d=f(h,n,a,c),g=f(l,n,a,c);return!(!I(d,e,i)||!I(g,e,i))}dispose(){this.unRegistryEvent()}};var J=class extends We{constructor(t){super();this.context=t;o(this,"_list",new Set);o(this,"boxSelection");o(this,"prevPanStatus");o(this,"prevRotateStatus");o(this,"downPoint",null);o(this,"onPointerDown",t=>{this.downPoint={x:t.offsetX,y:t.offsetY}});o(this,"onPointerUp",t=>{if(!this.downPoint)return;let{offsetX:e,offsetY:i}=t,{x:n,y:a}=this.downPoint;if(Math.sqrt(b(n-e,2)+b(a-i,2))>3)return;let{graphics:c}=this.context.getGraphicsByDeviceXy(e,i),p=new Set(c.map(l=>l.options.id));this.context.getPoisByDeviceXy(e,i).forEach(l=>{var d;if(!p.has(l.options.id)){let g=((d=this.context.currentFloor)==null?void 0:d.graphicLayer.graphicMap.get(l.options.id))||null;g&&(c.push(g),p.add(l.options.id))}}),t.ctrlKey||this._list.clear(),c.forEach(l=>this._list.add(l)),this.selectEnd(),this.downPoint=null});o(this,"onKeyDown",t=>{t.key==="Control"&&(this.boxSelection.setEnable(!0),this.prevPanStatus=this.context.control.enablePan,this.prevRotateStatus=this.context.control.enableRotate,this.context.control.enablePan=!1,this.context.control.enableRotate=!1)});o(this,"onKeyUp",t=>{t.key==="Control"&&(this.boxSelection.setEnable(!1),this.context.control.enablePan=!!this.prevPanStatus,this.context.control.enableRotate=!!this.prevRotateStatus)});o(this,"onBoxSelected",({list:t})=>{this._list.clear(),t.forEach(e=>{this._list.add(e)}),this.selectEnd()});this.boxSelection=new Q(t),this.boxSelection.setEnable(!1),this.registryEvent()}get list(){return this._list}selectEnd(){this.dispatchEvent({type:"select",graphics:[...this._list]})}registryEvent(){this.context.container.addEventListener("pointerdown",this.onPointerDown),this.context.container.addEventListener("pointerup",this.onPointerUp),window.addEventListener("keydown",this.onKeyDown),window.addEventListener("keyup",this.onKeyUp),this.boxSelection.addEventListener("selected",this.onBoxSelected)}unRegistryEvent(){this.context.container.removeEventListener("pointerdown",this.onPointerDown),this.context.container.removeEventListener("pointerup",this.onPointerUp),window.removeEventListener("keydown",this.onKeyDown),window.removeEventListener("keyup",this.onKeyUp),this.boxSelection.removeEventListener("selected",this.onBoxSelected)}clear(){this._list.clear()}remove(t){this._list.delete(t)}dispose(){this.unRegistryEvent()}};import{EventDispatcher as Ze}from"three";var tt=class extends Ze{constructor(t){super();this.context=t;o(this,"curGraphics",new Set);o(this,"timer",new M);o(this,"graphicTimerMap",new Map);o(this,"onPointerMove",({graphics:t})=>{if(!t.length&&this.curGraphics.size){this.curGraphics.clear(),this.handleHoverGraphicsChange();return}let{time:e}=this.context.config.hover;t.forEach(n=>{if(this.graphicTimerMap.get(n)||this.curGraphics.has(n))return;let a=this.timer.setTimeout(()=>{this.curGraphics.add(n),this.handleHoverGraphicsChange()},e);this.graphicTimerMap.set(n,a)}),this.graphicTimerMap.forEach((n,a)=>{t.includes(a)||(this.timer.clearTimeout(n),this.graphicTimerMap.delete(a))});let i=this.curGraphics.size;this.curGraphics.forEach(n=>{t.includes(n)||this.curGraphics.delete(n)}),i!==this.curGraphics.size&&this.handleHoverGraphicsChange()});o(this,"onPointerLevel",()=>{this.curGraphics.clear(),this.handleHoverGraphicsChange()});this.registryEvent()}handleHoverGraphicsChange(t=this.curGraphics){this.dispatchEvent({type:"hover-change",graphics:Array.from(this.curGraphics)})}registryEvent(){this.context.addEventListener("pointer-over",this.onPointerMove),this.context.addEventListener("pointer-move",this.onPointerMove),this.context.addEventListener("pointer-level",this.onPointerLevel)}unRegistryEvent(){this.context.removeEventListener("pointer-over",this.onPointerMove),this.context.removeEventListener("pointer-move",this.onPointerMove),this.context.removeEventListener("pointer-level",this.onPointerLevel)}dispose(){this.unRegistryEvent(),this.timer.dispose()}};var nt=class extends Ye{constructor(t,e){super();this.container=t;this.config=e;o(this,"scene",ft());o(this,"renderer",vt());o(this,"camera");o(this,"control");o(this,"lights",xt());o(this,"timer",new M);o(this,"tweenGroup",new ei);o(this,"currentFloor");o(this,"selection");o(this,"hoverHelper");o(this,"basicRatio");o(this,"clientSize",{width:0,height:0});o(this,"onWindowResize",()=>{let{container:t,camera:e,renderer:i}=this,{clientWidth:n,clientHeight:a}=t;e.left=-n/2,e.right=n/2,e.top=a/2,e.bottom=-a/2,e.updateProjectionMatrix(),i.setSize(n,a),this.resizeClientSize(n,a)});o(this,"onClick",t=>{let{graphics:e,position:i}=this.getGraphicsByDeviceXy(t.offsetX,t.offsetY);e.length&&this.dispatchEvent({type:"graphic-click",graphics:e,position:i});let n=this.getPoisByDeviceXy(t.offsetX,t.offsetY);n.length&&this.dispatchEvent({type:"poi-click",pois:n})});o(this,"onPointerover",t=>{let{graphics:e,position:i}=this.getGraphicsByDeviceXy(t.offsetX,t.offsetY),n=this.getPoisByDeviceXy(t.offsetX,t.offsetY);this.dispatchEvent({type:"pointer-over",graphics:e,pois:n,position:i})});o(this,"onPointermove",t=>{let{graphics:e,position:i}=this.getGraphicsByDeviceXy(t.offsetX,t.offsetY),n=this.getPoisByDeviceXy(t.offsetX,t.offsetY);this.dispatchEvent({type:"pointer-move",graphics:e,pois:n,position:i})});o(this,"onPointerleave",()=>{this.dispatchEvent({type:"pointer-level"})});o(this,"onSelectionSelect",({graphics:t})=>{this.dispatchEvent({type:"select-graphic",graphics:t})});o(this,"onHoverChange",({graphics:t})=>{this.dispatchEvent({type:"hover",graphics:t})});this.container.style.position="relative",this.container.style.overflow="hidden",this.init(),this.selection=new J(this),this.hoverHelper=new tt(this),this.resizeClientSize(),this.registryEvent()}resizeClientSize(t,e){this.clientSize={width:t||this.container.clientWidth,height:e||this.container.clientHeight}}init(){let{clientWidth:t,clientHeight:e}=this.container;this.camera=yt(t,e),this.renderer.setSize(t,e),this.control=bt(this.camera,this.renderer.domElement),this.control.maxPolarAngle=this.config.control.maxPolar,this.container.appendChild(this.renderer.domElement),this.scene.add(this.lights),this.basicRatio=this.getRatio(),this.control.addEventListener("change",()=>{var n;let i=this.control.getPolarAngle();(n=this.currentFloor)==null||n.setShadowOpacity(i/this.config.control.maxPolar),this.dispatchEvent({type:"change-ratio",px:(this.basicRatio||0)*this.camera.zoom}),this.dispatchEvent({type:"control-change"})})}getRatio(t=new et(0,0,0),e=new et(100,0,0)){let{clientWidth:i,clientHeight:n}=this.container,a=f(t,this.camera,i,n),c=f(e,this.camera,i,n);return Math.ceil(Math.sqrt(b(c.x-a.x,2)+b(c.y-a.y,2)))}changeAmbientLightColor(t){this.lights.children.forEach(e=>{e instanceof ti&&(e.color=new Je(t))})}switchFloor(t){this.currentFloor&&(this.scene.remove(this.currentFloor),this.currentFloor.dispose()),this.currentFloor=t,this.scene.add(t);let e=t.getCenter();e&&(this.lights.position.x=e.x,this.lights.position.y=e.y)}getGraphicsByDeviceXy(t,e){var c;let i=new it;i.x=t/this.container.clientWidth*2-1,i.y=e/this.container.clientHeight*-2+1;let n=new Ne;return n.setFromCamera(i,this.camera),((c=this.currentFloor)==null?void 0:c.graphicLayer.getGraphicByRaycaster(n))||{graphics:[],position:null}}getPoisByDeviceXy(t,e){var n;return((n=this.currentFloor)==null?void 0:n.poiLayer.getPoiByDeviceXy(t,e))||[]}registryEvent(){window.addEventListener("resize",this.onWindowResize),this.container.addEventListener("click",this.onClick),this.container.addEventListener("pointerover",this.onPointerover),this.container.addEventListener("pointermove",this.onPointermove),this.container.addEventListener("pointerleave",this.onPointerleave),this.selection.addEventListener("select",this.onSelectionSelect),this.hoverHelper.addEventListener("hover-change",this.onHoverChange)}unRegistryEvent(){window.removeEventListener("resize",this.onWindowResize),this.container.removeEventListener("click",this.onClick),this.container.removeEventListener("pointerover",this.onPointerover),this.container.removeEventListener("pointermove",this.onPointermove),this.container.removeEventListener("pointerleave",this.onPointerleave),this.selection.removeEventListener("select",this.onSelectionSelect),this.hoverHelper.removeEventListener("hover-change",this.onHoverChange)}setPolarAngle(t,e=500){return $(new Promise(i=>{let n={polar:this.control.getPolarAngle()},a={polar:t},c=new dt(n,this.tweenGroup).to(a,e).onUpdate(()=>{this.control.maxPolarAngle=n.polar,this.control.minPolarAngle=n.polar,this.control.update()}).onComplete(()=>{this.control.enabled=!0,this.control.maxPolarAngle=this.config.control.maxPolar,this.control.minPolarAngle=0,this.tweenGroup.remove(c),i(!0)}).onStart(()=>{this.control.enabled=!1}).start()}),e+500)}getCameraLookAt(){return new et().subVectors(this.control.target,this.camera.position)}setZoom(t,e,i=500){return $(new Promise(n=>{let a={zoom:this.camera.zoom,target:this.control.target.clone()},c=this.getCameraLookAt(),p=new dt(a,this.tweenGroup).to({zoom:t,target:e},i).onUpdate(()=>{this.camera.position.copy(a.target.clone().sub(c)),this.control.target.copy(a.target),this.camera.zoom=a.zoom,this.control.update()}).onComplete(()=>{this.tweenGroup.remove(p),this.control.enabled=!0,n(!0)}).onStart(()=>{this.control.enabled=!1}).start()}),i+500)}fitCameraToObject(t,e=[20,20,20,20],i=500){let[n,a,c,p]=e,{clientWidth:h,clientHeight:l}=this.container,d=new Qe().setFromObject(t),{max:g,min:m}=d,u=f(g,this.camera,h,l),v=f(m,this.camera,h,l),T=new qe().setFromPoints([new it(u.x,u.y),new it(v.x,v.y)]).getSize(new it),H=(h-a-p)/T.x,R=(l-n-c)/T.y,x=Math.min(H,R),kt=new et((g.x+m.x)/2,(g.y+m.y)/2,g.z);return this.setZoom(x*this.camera.zoom,kt,i)}fitCameraToGround(t=[20,20,20,20],e=500){return this.currentFloor&&this.currentFloor.hasElement?this.fitCameraToObject(this.currentFloor.groundUpper,t,e):Promise.resolve(!1)}setCameraPosition(t,e){return $(new Promise(i=>{let n=this.camera.position.clone(),a=this.getCameraLookAt(),c=new dt(n,this.tweenGroup).to(t,e).onUpdate(()=>{this.camera.position.copy(n),this.control.target.copy(t.clone().add(a))}).onComplete(()=>{this.tweenGroup.remove(c),this.control.update(),this.control.enabled=!0,i(!0)}).onStart(()=>{this.control.enabled=!1}).start()}),e+500)}render(){this.renderer.render(this.scene,this.camera),this.dispatchEvent({type:"update"}),this.timer.requestAnimationFrame(()=>{this.render()}),this.tweenGroup.update()}dispose(){this.selection.dispose(),this.hoverHelper.dispose(),this.tweenGroup.getAll().forEach(t=>t.stop()),this.tweenGroup.removeAll(),this.unRegistryEvent(),this.container.removeChild(this.renderer.domElement),this.timer.dispose(),this.renderer.dispose(),this.lights.children.forEach(t=>t.dispose()),L(this.scene)}};import{merge as ii}from"lodash";var ni={apiDomain:"",apiInfo:{},apiPath:{floorGraphic:"/api/inception-map/floor/get",floorRange:"/api/inception-map/range/get"},heatMap:{radius:50,gradient:{0:"#8F9FCD",.5:"#6284FF",1:"#F95D5D"}},useFloorCache:!0,control:{maxPolar:.9},svg:{circle:{radius:"2",fill:"#1CADFF"},line:{stroke:"#1CADFF"}},selectBox:{stroke:"#1CADFF",fill:"rgba(28, 173, 255, 0.3)"},hover:{time:500}};function Tt(r){return ii({},ni,r)}var Rt=class extends oi{constructor(t,e={}){super();this.container=t;o(this,"config");o(this,"context");o(this,"polarKeys",[]);o(this,"azimuthalKeys",[]);o(this,"svgLine");o(this,"svgPolygon");o(this,"basicZoom",1);o(this,"prevCameraZoom",1);o(this,"floorDataMap",new Map);o(this,"buildingGroundMap",new Map);o(this,"currentBuildGround",null);o(this,"onControlChange",()=>{let{camera:{zoom:t}}=this.context;t!==this.prevCameraZoom&&(this.dispatchEvent({type:"zoom-change",basicZoom:this.basicZoom,cameraZoom:this.context.camera.zoom}),this.prevCameraZoom=t)});o(this,"onKeydown",t=>{this.polarKeys.includes(t.code)&&(this.context.control.maxPolarAngle=this.config.control.maxPolar,this.context.control.minPolarAngle=0),this.azimuthalKeys.includes(t.code)&&(this.context.control.maxAzimuthAngle=1/0,this.context.control.minAzimuthAngle=1/0)});o(this,"onKeyUp",t=>{if(this.polarKeys.includes(t.code)){let e=this.context.control.getPolarAngle();this.context.control.maxPolarAngle=e,this.context.control.minPolarAngle=e}if(this.azimuthalKeys.includes(t.code)){let e=this.context.control.getAzimuthalAngle();this.context.control.maxAzimuthAngle=e,this.context.control.minAzimuthAngle=e}});this.config=Tt(e),this.context=new nt(t,this.config),this.registryEvent(),this.context.render()}loadGraphics(h){return G(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:p}){let{apiDomain:l,apiPath:{floorGraphic:d},apiInfo:g}=this.config,m=`${l}${d}?brand=${t}&project=${e}&phase=${i}&building=${n}&floor=${a}&ts=${c}&resource_type_list=${p}`;return yield fetch(m,g).then(v=>v.json()).then(v=>v.data).then(v=>((v||[]).map(y=>y.info=JSON.parse(y.info)),v||[]))})}getBuildingKey({brand:t,project:e,phase:i,building:n}){return`${t}-${e}-${i}-${n}`}loadBuildingGround(a){return G(this,arguments,function*({brand:t,project:e,phase:i,building:n}){let c=this.getBuildingKey({brand:t,project:e,phase:i,building:n});if(this.buildingGroundMap.get(c))return this.buildingGroundMap.get(c)||null;let{apiDomain:p,apiPath:{floorRange:h},apiInfo:l}=this.config,d=`${p}${h}?brand=${t}&project=${e}&phase=${i}&building=${n}`,g=yield fetch(d,l).then(m=>m.json()).then(m=>m.data).then(m=>{let u=(m||[])[0];return u&&(u.info=JSON.parse(u.info)),u});return this.buildingGroundMap.set(c,g),g})}getFloorKey({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:p}){return`${t}-${e}-${i}-${n}-${a}-${c}-${p}`}load(h){return G(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:p}){let l=this.getFloorKey({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:p});if(this.floorDataMap.get(l))return;let[d,g]=yield Promise.all([this.loadGraphics({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:p}),this.loadBuildingGround({brand:t,project:e,phase:i,building:n})]);if(g){let m=at(g.info.geometry.cds[0]);d.forEach(u=>{if(u.info.geometry.type==="polygon")u.info.geometry.cds.map(v=>{Array.isArray(v)&&v.forEach(y=>{y[0]-=m[0],y[1]-=m[1]})});else{let[v,y]=u.info.geometry.cds;u.info.geometry.cds=[v-m[0],y-m[1]]}u.info.transformToBuildingGround=!0})}return this.config.useFloorCache||this.floorDataMap.clear(),this.floorDataMap.set(l,d),d})}createFloor(t){let e=new Y(this.context);if(!t.length)return{curFloor:e,graphics:[]};let i=t.filter(h=>h.info.group==="ground");i.forEach(h=>{h.info.fillColor="#F5F7F9",h.info.fillOpacity=1,h.info.strokeOpacity=0,h.info.height=5});let n=i.map(h=>new w(this.context,h.info));e.addGrounds(n);let a=t.filter(h=>h.info.group!=="ground");a.forEach((h,l)=>{h.info.airHeight=5,h.info.height=5+l*1e-4});let c=new Map,p=a.map(h=>{let l=e.addGraphic(h.info);return l.userData.data=h,c.set(h.legacy_id,l),l});return e.addShadow(),e.userData.legacyToGraphicMap=c,{curFloor:e,graphics:p}}switchFloor(h){return G(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:p}){let l=this.getFloorKey({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:p}),d=this.floorDataMap.get(l);if(this.context.control.removeEventListener("change",this.onControlChange),d){let g=this.getBuildingKey({brand:t,project:e,phase:i,building:n});this.currentBuildGround=this.buildingGroundMap.get(g)||null;let m=this.createFloor(d);m?(this.context.switchFloor(m.curFloor),this.context.control.minZoom=0,this.context.control.maxZoom=1/0,yield this.context.fitCameraToGround(void 0,0),this.basicZoom=this.context.camera.zoom,this.context.control.minZoom=this.basicZoom,this.context.control.maxZoom=this.basicZoom*25,this.context.control.addEventListener("change",this.onControlChange),this.onControlChange()):console.warn("[switchFloor error] ["+a+"] \u697C\u5C42\u6CA1\u6709\u6570\u636E")}else console.warn("[switchFloor error] \u6CA1\u6709\u8FD9\u4E2A\u697C\u5C42\uFF0C\u8BF7\u5148\u8C03\u7528load\u65B9\u6CD5\u52A0\u8F7D\u697C\u5C42")})}addHeatmap(t){var e;return(e=this.context.currentFloor)==null?void 0:e.addHeatmap(t)}getLegacyToGraphicMap(){var t;return((t=this.context.currentFloor)==null?void 0:t.userData.legacyToGraphicMap)||new Map}getFloorAllGraphics(){var t;return((t=this.context.currentFloor)==null?void 0:t.graphicLayer.children.filter(e=>e instanceof w))||[]}createGraphicPoi(t,e){if(this.context.currentFloor){e.id===void 0&&(e.id=t.options.id);let i=t.getCenter();return this.context.currentFloor.addPoi(rt(D({},e),{position:rt(D({},i),{z:i.z+t.options.height/2})}))}return null}removeHeatMap(){var t;(t=this.context.currentFloor)==null||t.removeHeatMap()}translateElementToCenter(t,e=500){let i=t.position.clone().setFromMatrixPosition(t.matrixWorld);return this.context.setCameraPosition(i,e)}getElementDeviceCoordinate(t){let e=t.position.clone(),{clientWidth:i,clientHeight:n}=this.container;return f(e,this.context.camera,i,n)}changeMapType(t,e=500){return t==="2d"?this.context.setPolarAngle(0,e):this.context.setPolarAngle(.9,e)}reduceMap(t=.5,e=500){let i=this.context.camera.zoom;return this.context.setZoom(i-t,this.context.control.target,e)}enlargeMap(t=.5,e=500){let i=this.context.camera.zoom;return this.context.setZoom(i+t,this.context.control.target,e)}registryEvent(){window.addEventListener("keydown",this.onKeydown),window.addEventListener("keyup",this.onKeyUp)}unRegistryEvent(){window.removeEventListener("keydown",this.onKeydown),window.removeEventListener("keyup",this.onKeyUp)}configurePolarShortcutKeys(t){this.polarKeys=t}configureAzimuthalShortcutKeys(t){this.azimuthalKeys=t}rotateMap(t=.1){let e=this.context.control.getAzimuthalAngle();this.context.control.maxAzimuthAngle=e+t,this.context.control.minAzimuthAngle=e+t,this.context.control.update()}measureDistance(){return G(this,null,function*(){return this.cancelDistance(),new Promise((t,e)=>{this.changeMapType("2d",0),this.context.control.enableRotate=!1,this.svgLine=new q(this.context);let i=this.svgLine.dispose.bind(this.svgLine);this.svgLine.dispose=function(){i(),e("cancel")},this.svgLine.addEventListener("distance",({distance:n})=>{t(n)})})})}cancelDistance(){this.svgLine&&(this.svgLine.dispose(),this.svgLine=void 0,this.context.control.enableRotate=!0)}measureArea(){return this.cancelArea(),new Promise((t,e)=>{this.changeMapType("2d",0),this.context.control.enableRotate=!1,this.svgPolygon=new N(this.context);let i=this.svgPolygon.dispose.bind(this.svgPolygon);this.svgPolygon.dispose=function(){i(),e("cancel")},this.svgPolygon.addEventListener("area",({area:n})=>{t(n)})})}cancelArea(){this.svgPolygon&&(this.svgPolygon.dispose(),this.svgPolygon=void 0,this.context.control.enableRotate=!0)}getGraphicByNodeId(t){var e;return((e=this.context.currentFloor)==null?void 0:e.graphicLayer.getGraphicByNodeId(t))||null}deleteGraphic(t){var e;(e=this.context.currentFloor)==null||e.graphicLayer.removeGraphic(t)}createGraphicByOptions(t){var e;if(!t.transformToBuildingGround&&this.currentBuildGround){let i=at(this.currentBuildGround.info.geometry.cds[0]);if(t.geometry.type==="polygon")t.geometry.cds.map(n=>{Array.isArray(n)&&n.forEach(a=>{a[0]-=i[0],a[1]-=i[1]})});else{let[n,a]=t.geometry.cds;t.geometry.cds=[n-i[0],a-i[1]]}}return(e=this.context.currentFloor)==null?void 0:e.graphicLayer.createGraphic(t)}removePoiById(t){var e;return(e=this.context.currentFloor)==null?void 0:e.poiLayer.removePoiById(t)}getPoiById(t){var e;return(e=this.context.currentFloor)==null?void 0:e.poiLayer.getPoiById(t)}getPois(){var t;return((t=this.context.currentFloor)==null?void 0:t.poiLayer.pois)||[]}clearPoi(){this.context.currentFloor&&(this.getPois().forEach(t=>t.dispose()),this.context.currentFloor.poiLayer.clear())}removeSelectGraphic(t){this.context.selection.remove(t)}dispose(){this.context.dispose(),Lt(),Gt(),this.unRegistryEvent()}};export{Rt as BMap,C as BaseSvg,nt as Context,Y as Floor,w as Graphic,X as GraphicLayer,Z as HeatmapElement,tt as HoverHelper,A as Layer,_ as Overlay,z as Poi,W as PoiLayer,At as SelectBox,J as Selection,j as Shadow,q as SvgLine,N as SvgPolygon,M as Timer,Gt as clearCanvas,Lt as clearTextTexture,ie as createCanvas,k as createCircle,U as createLine,O as createRect,Mt as createSvg,K as createSvgElement,ni as defaultConfig,L as dispose,at as getCenter,Tt as getConfig,gi as getTextureByText,wt as hasChinese,yt as initCamera,ee as initCanvas,bt as initControl,Pt as initDirectionalLight,xt as initLight,vt as initRenderer,ft as initScene,Et as initShape,I as isContain,V as proxyOptions,F as setCirclePosition,E as setLineStartEnd,P as setRectPosition,ct as sleepOnePromise,wi as strToNumber,$ as timeoutPromise,f as vector3ToDevice};
1
+ var Bt=Object.defineProperty,Ht=Object.defineProperties;var It=Object.getOwnPropertyDescriptors;var ut=Object.getOwnPropertySymbols;var Vt=Object.prototype.hasOwnProperty,$t=Object.prototype.propertyIsEnumerable;var b=Math.pow,rt=(r,a,t)=>a in r?Bt(r,a,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[a]=t,D=(r,a)=>{for(var t in a||(a={}))Vt.call(a,t)&&rt(r,t,a[t]);if(ut)for(var t of ut(a))$t.call(a,t)&&rt(r,t,a[t]);return r},st=(r,a)=>Ht(r,It(a));var o=(r,a,t)=>(rt(r,typeof a!="symbol"?a+"":a,t),t);var G=(r,a,t)=>new Promise((e,i)=>{var n=h=>{try{c(t.next(h))}catch(p){i(p)}},s=h=>{try{c(t.throw(h))}catch(p){i(p)}},c=h=>h.done?e(h.value):Promise.resolve(h.value).then(n,s);c((t=t.apply(r,a)).next())});import{EventDispatcher as ri}from"three";var M=class{constructor(){o(this,"tasks",{requestAnimation:new Set,timeout:new Set,interval:new Set})}requestAnimationFrame(a){let t=window.requestAnimationFrame(()=>{this.tasks.requestAnimation.delete(t),a()});return this.tasks.requestAnimation.add(t),t}cancelAnimationFrame(a){this.tasks.requestAnimation.delete(a),window.cancelAnimationFrame(a)}setTimeout(a,t){let e=window.setTimeout(()=>{this.tasks.timeout.delete(e),a()},t);return this.tasks.timeout.add(e),e}clearTimeout(a){this.tasks.timeout.delete(a),window.clearTimeout(a)}setInterval(a,t){let e=window.setInterval(()=>{this.tasks.interval.delete(e),a()},t);return this.tasks.interval.add(e),e}clearInterval(a){this.tasks.interval.delete(a),window.clearInterval(a)}dispose(){this.tasks.requestAnimation.forEach(a=>{window.cancelAnimationFrame(a)}),this.tasks.requestAnimation.clear(),this.tasks.timeout.forEach(a=>{window.clearTimeout(a)}),this.tasks.timeout.clear(),this.tasks.interval.forEach(a=>{window.clearInterval(a)}),this.tasks.interval.clear()}};import{Scene as Ut,WebGLRenderer as Kt,OrthographicCamera as jt,HemisphereLight as _t,Shape as Xt,PCFSoftShadowMap as Wt,Group as Zt,Color as Yt,DirectionalLight as qt,AmbientLight as Nt,Path as Qt,Vector2 as gt}from"three";import{MapControls as Jt}from"three/examples/jsm/controls/MapControls";function ft(){let r=new Ut;return r.background=new Yt(16777215),r}function vt(){let r=new Kt({antialias:!0});return r.setClearColor(16777215),r.setPixelRatio(window.devicePixelRatio),r.shadowMap.enabled=!0,r.shadowMap.autoUpdate=!0,r.shadowMap.type=Wt,r}function yt(r,a){let t=new jt(-r/2,r/2,a/2,-a/2,-1e3,5e3);return t.up.set(0,0,1),t.position.set(0,0,100),t.lookAt(0,0,0),t}function xt(){let r=new Zt,a=new _t(16777215,16777215,2);a.intensity=1,a.position.set(0,0,10),a.up.set(0,0,1),r.add(a);let t=new Nt(16777215,1);return r.add(t),r}function bt(r,a){let t=new Jt(r,a);return t.enableDamping=!1,t.zoomSpeed=2,t}function Pt(r,a=[]){let t=new Xt(r.map(e=>new gt(...e)));return a.length&&a.forEach(e=>{var i=new Qt(e.map(n=>new gt(...n)));t.holes.push(i)}),t}function Et(r=16777215,a=1){let t=new qt(r,a);return t.castShadow=!0,t.shadow.radius=8,t.shadow.bias=-.001,t.shadow.mapSize.set(128,128),t.shadow.camera.left=-200,t.shadow.camera.right=200,t.shadow.camera.top=200,t.shadow.camera.bottom=-200,t}function L(r,a){var t;if(a&&r.children&&r.children.length&&r.children.forEach(e=>{L(e,a)}),r.isMesh){let e=r;e.geometry&&e.geometry.dispose(),e.material&&(Array.isArray(e.material)?e.material.forEach(i=>{i.dispose()}):e.material.dispose())}r.isLight&&((t=r.dispose)==null||t.call(r))}function wt(r){return/[\u4E00-\u9FA5]+/g.test(r)}import{DataTexture as te,RGBAFormat as ee,LinearFilter as Ct}from"three";var H=new Map;function ie(){let r=document.createElement("canvas");r.width=1024,r.height=64;let a=r.getContext("2d",{willReadFrequently:!0});return a.font="54px sans-serif",a.textBaseline="hanging",a.lineWidth=12,a.fillStyle="rgba(0,0,0,1)",a.strokeStyle="white",{canvas:r,ctx:a}}var at,S;function ne(){if(!at){let{canvas:r,ctx:a}=ie();at=r,S=a}}function vi(r){if(H.has(r))return H.get(r);ne(),S.clearRect(0,0,1024,64);let a=wt(r)?4:8;S.strokeText(r,2,a),S.fillText(r,2,a);let t=Math.ceil(S.measureText(r).width);t=t%2===0?t:t+1,t+=2;let e=S.getImageData(0,0,t,64),i=new te(Uint8Array.from(e.data),t,64,ee);return i.flipY=!0,i.minFilter=Ct,i.magFilter=Ct,H.set(r,i),i}function Lt(){H.clear()}function Gt(){S=null,at=null}import{point as oe,featureCollection as re,center as se}from"@turf/turf";function v(r,a,t,e){let i=r.clone().project(a),n=t/2,s=e/2,c=Math.round(i.x*n+n),h=Math.round(-i.y*s+s);return{x:c,y:h}}function ct(r){let a=re(r.map(e=>oe(e)));return se(a).geometry.coordinates}function I(r,a,t){return r.x>=a.x&&r.x<=t.x&&r.y>=a.y&&r.y<=t.y}function V(r,a){return new Proxy(r,{get:(t,e,i)=>Reflect.get(t,e,i),set:(t,e,i,n)=>{let s=Reflect.set(t,e,i,n);return a.dispatchEvent({type:`change-${e}`,value:i}),s}})}function R(r,a){return Promise.race([r,new Promise((t,e)=>{setTimeout(()=>e(new Error("Promise timeout")),a)})])}function $(r){return document.createElementNS("http://www.w3.org/2000/svg",r)}function Mt(r,a){let t=$("svg");return t.setAttribute("width",r),t.setAttribute("height",a),t.style.cssText="position: absolute; left: 0; top: 0; pointer-events: none;",t}function k(r="2",a){let t=$("circle");return t.setAttribute("r",r),t.setAttribute("fill",a),t}function U(r){let a=$("line");return a.setAttribute("stroke",r),a}function z(r,a){let t=$("rect");return t.setAttribute("stroke",r),t.setAttribute("fill",a),t}function A(r,a,t){r.setAttribute("cx",`${a}`),r.setAttribute("cy",`${t}`)}function P(r,a,t){a&&(r.setAttribute("x1",`${a.x}`),r.setAttribute("y1",`${a.y}`)),t&&(r.setAttribute("x2",`${t.x}`),r.setAttribute("y2",`${t.y}`))}function E(r,a,t,e,i){r.setAttribute("x",`${a}`),r.setAttribute("y",`${t}`),r.setAttribute("width",`${e}`),r.setAttribute("height",`${i}`)}function ht(){return Promise.resolve()}function Li(r){return parseInt(r.replace("#","0x"),16)}import{EventDispatcher as qe,Box2 as Ne,Vector3 as tt,Vector2 as et,Raycaster as Qe,Box3 as Je,Color as ti,AmbientLight as ei}from"three";import{Group as ii,Tween as it}from"@tweenjs/tween.js";import{EventDispatcher as Ze}from"three";import{Object3D as ae,ExtrudeGeometry as ce,MeshStandardMaterial as he,Mesh as pe,Color as pt,Box3 as Dt,EdgesGeometry as le,Vector3 as lt}from"three";import{merge as me}from"lodash";import{LineMaterial as de}from"three/examples/jsm/lines/LineMaterial.js";import{LineSegmentsGeometry as ue}from"three/examples/jsm/lines/LineSegmentsGeometry.js";import{LineSegments2 as ge}from"three/examples/jsm/lines/LineSegments2.js";var fe={id:"",height:.1,airHeight:0,area:0,group:"",fillColor:"#EFF4FB",strokeColor:"#ffffff",fillOpacity:1,strokeOpacity:1,strokeWidth:1,doors:[],locked:!1,visible:!0,geometry:{type:"polygon",cds:[],curveCpt:[],curveIndex:[]},layerType:"",zIndex:0},w=class extends ae{constructor(t,e){super();this.context=t;o(this,"geometry");o(this,"material");o(this,"mesh");o(this,"line");o(this,"options");if(this.options=V(me({},fe,e),this),this.options.geometry.type==="point"){let[i,n]=this.options.geometry.cds;return this.position.set(i,n,this.options.height+this.options.airHeight),this}this.init(),this.visible=this.options.visible,this.addEventListener("change-fillColor",({value:i})=>{this.material.color=new pt(i)}),this.addEventListener("change-fillOpacity",({value:i})=>{this.material.opacity=i}),this.addEventListener("change-height",({value:i})=>{this.dispose(),this.init()}),this.addEventListener("change-strokeColor",({value:i})=>{this.line.material.color=new pt(i)}),this.addEventListener("change-strokeOpacity",({value:i})=>{this.line.material.opacity=i}),this.addEventListener("change-strokeWidth",({value:i})=>{this.line.material.linewidth=i}),this.addEventListener("change-airHeight",({value:i})=>{this.position.z=i}),this.addEventListener("change-visible",({value:i})=>{this.visible=i})}getCenter(){if(this.options.geometry.type==="point")return this.position;let t=new lt,e=new Dt;return e.setFromObject(this),e.getCenter(t),t}getSize(){if(this.options.geometry.type==="point")return new lt(0,0,0);let t=new Dt,e=new lt;return t.setFromObject(this),t.getSize(e),e}getPosition(){let t=this.getCenter();return t.setZ(t.z+this.options.height),t}init(){this.geometry=this.initGeometry(),this.material=this.initMaterial(),this.mesh=this.initMesh(),this.mesh.position.z=this.options.airHeight,this.mesh.castShadow=!0,this.add(this.mesh),this.line=this.createBorder(),this.add(this.line)}initGeometry(){let t=Pt(this.options.geometry.cds[0],this.options.geometry.cds.slice(1));return new ce(t,{steps:1,bevelEnabled:!1,depth:this.options.height,curveSegments:4})}initMaterial(){return new he({color:this.options.fillColor,roughness:1,transparent:!0,opacity:this.options.fillOpacity,depthWrite:!0})}initLineMaterial(){let t=new de({color:new pt(this.options.strokeColor).getHex(),opacity:this.options.strokeOpacity,transparent:!0,depthWrite:!0,linewidth:this.options.strokeWidth,wireframe:!1,dashed:!1}),{clientSize:{width:e,height:i}}=this.context;return t.resolution.set(e,i),t}initMesh(){return new pe(this.geometry,this.material)}createBorder(){let t=this.initLineMaterial(),e=new le(this.geometry),i=new ue;i.fromEdgesGeometry(e);let n=new ge(i,t);return n.position.z=this.options.airHeight,n}raycast(t){if(!this.visible||this.options.geometry.type==="point")return!1;let e=t.intersectObject(this.mesh);if(e[0]){let{point:i,distance:n}=e[0];return{position:i,distance:n}}return!1}dispose(){L(this),this.clear()}};import{Object3D as ve,PlaneGeometry as ye,Mesh as xe,ShadowMaterial as be,Color as Pe,DoubleSide as Ee}from"three";var K=class extends ve{constructor(){super();o(this,"directionalLight");o(this,"plane");o(this,"basicOpacity",.15);this.directionalLight=this.initLight(),this.initPlane()}initLight(){let t=Et(16777215,1);return t.position.set(0,0,100),this.add(t),t}changeLightCamera(t){let e=t.x,i=t.y;this.directionalLight.shadow.camera.left=-e,this.directionalLight.shadow.camera.right=e,this.directionalLight.shadow.camera.top=i,this.directionalLight.shadow.camera.bottom=-i,this.directionalLight.shadow.camera.near=.5,this.directionalLight.shadow.camera.far=Math.max(e,i)}changeLightColor(t){this.directionalLight.color=new Pe(t)}setPosition(t){this.position.copy(t),this.directionalLight.position.set(-t.x/2,-t.y/2,100)}initPlane(t=1e3,e=1e3){let i=new ye(t,e),n=new be({transparent:!0,opacity:0,side:Ee}),s=new xe(i,n);return s.receiveShadow=!0,s.position.z=-10,this.add(s),this.plane=s,s}setTarget(t){this.directionalLight.target=t}transformOpacity(t){return t*this.basicOpacity}setOpacity(t){this.plane.material.opacity=this.transformOpacity(t)}dispose(){L(this,!0)}};import{Object3D as Le}from"three";import{merge as Ge}from"lodash";import{Box3 as we,EventDispatcher as Ce,Vector3 as St}from"three";var j=class extends Ce{constructor(t){super();this.context=t;o(this,"div");o(this,"element");o(this,"position",new St);o(this,"clientPos",{x:0,y:0});o(this,"visible",!0);o(this,"onUpdate",()=>{let t=this.getPosition(),{width:e,height:i}=this.context.clientSize,{x:n,y:s}=v(t,this.context.camera,e,i);this.clientPos.x===n&&this.clientPos.y===s||(this.clientPos={x:n,y:s},this.div.style.left=`${n}px`,this.div.style.top=`${s}px`)});this.registryEvent(),this.div=this.initDiv(),this.context.container.appendChild(this.div)}initDiv(){let t=document.createElement("div");return t.style.position="absolute",t}bindElement(t){this.element=t,this.onUpdate()}unBindElement(){this.element=void 0}setVisible(t,e="block"){t!==this.visible&&(this.div.style.display=t?e:"none",this.visible=t)}setOpacity(t){this.div.style.opacity=`${t}`}getPosition(){return this.element?typeof this.element.getPosition=="function"?this.element.getPosition():new we().setFromObject(this.element).getCenter(new St):this.position}get withinDisplayRange(){let{x:t,y:e}=this.clientPos,{width:i,height:n}=this.context.clientSize;return t>=0&&t<=i&&e>=0&&e<=n}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}dispose(){this.unRegistryEvent(),this.unBindElement(),this.context.container.removeChild(this.div),this.div=null}};var Me={text:"",level:1,collision_enable:!0,opacity:1,id:"",position:{x:0,y:0,z:0}},B=class extends Le{constructor(t,e){var i,n,s;super();this.context=t;o(this,"textDiv");o(this,"img");o(this,"overlay");o(this,"options");o(this,"size",{width:0,height:0});o(this,"_changePosition",()=>{this.overlay.div.style.transform=`translate3d(-50%, ${this.options.icon?"-100%":"-50%"}, 0)`});this.options=V(Ge({},Me,e),this),this.position.set(((i=e.position)==null?void 0:i.x)||0,((n=e.position)==null?void 0:n.y)||0,((s=e.position)==null?void 0:s.z)||0),this.overlay=new j(this.context),this.overlay.bindElement(this),this.registryEvent(),this.initDiv(),this.addEventListener("change-icon",({value:c})=>{c?this.img?this.img.setAttribute("src",c):this.overlay.div.appendChild(this.initIcon()):(this.img&&this.overlay.div.removeChild(this.img),this.img=void 0,this.resetSize())}),this.addEventListener("change-text",({value:c})=>{this.overlay.div.removeChild(this.textDiv),this.overlay.div.appendChild(this.initText()),this.resetSize()}),this.addEventListener("change-opacity",({value:c})=>{this.overlay.setOpacity(c)}),this.addEventListener("change-icon_size",({value:c})=>{this.img&&(this.img.style.width=`${(c==null?void 0:c[0])||32}px`,this.img.style.height=`${(c==null?void 0:c[1])||32}px`,this.resetSize())})}get withinDisplayRange(){return this.overlay.withinDisplayRange}resetSize(){return G(this,null,function*(){let t=this.overlay.visible;this.setVisible(!0),yield ht();let{width:e,height:i}=this.overlay.div.getBoundingClientRect();this.size={width:e,height:i},yield ht(),this._changePosition(),this.setVisible(t)})}get clientPos(){return this.overlay.clientPos}initDiv(){let t=this.overlay.div;return t.appendChild(this.initText()),this.options.icon&&t.appendChild(this.initIcon()),t.style.fontSize="12px",t.style.display="flex",t.style.flexDirection="column",t.style.justifyContent="center",t.style.alignItems="center",t.style.pointerEvents="none",this.overlay.setOpacity(this.options.opacity),this.resetSize(),t}getPosition(){return this.position}initText(){let t=document.createElement("div");return t.appendChild(this.createTextFragment()),t.style.background="rgba(255, 255, 255, .7)",t.style.padding="2px",t.style.borderRadius="4px",this.textDiv=t,t}createTextFragment(){let t=document.createDocumentFragment();return this.options.text.split(`\r
2
+ `).forEach(e=>{let i=document.createElement("div");i.style.whiteSpace="nowrap",i.textContent=e,t.appendChild(i)}),t}initIcon(){var e,i;let t=document.createElement("img");return t.setAttribute("src",this.options.icon),t.style.width=`${((e=this.options.icon_size)==null?void 0:e[0])||32}px`,t.style.height=`${((i=this.options.icon_size)==null?void 0:i[1])||32}px`,t.onload=()=>{this.resetSize()},this.img=t,t}registryEvent(){}unRegistryEvent(){}setVisible(t){this.overlay.setVisible(t,"flex")}getBox(){let{width:t,height:e}=this.size,{x:i,y:n}=this.overlay.clientPos;return{left:i-t/2,right:i+t/2,top:this.options.icon?n-e:n-e/2,bottom:this.options.icon?n:n+e/2}}isContain(t,e){if(!this.overlay.visible)return!1;let i=this.getBox();return t>=i.left&&t<=i.right&&e>=i.top&&e<=i.bottom}dispose(){this.unRegistryEvent(),this.textDiv=null,this.img=void 0,this.overlay.dispose()}};import{Box3 as mt,Object3D as zt,Vector3 as dt}from"three";import{Box3 as Se,Vector3 as Ae}from"three";import{Object3D as De}from"three";var F=class extends De{constructor(t){super();this.context=t}dispose(){L(this),this.clear()}};var _=class extends F{constructor(t){super(t);o(this,"graphicMap",new Map)}getCenter(){return new Se().setFromObject(this).getCenter(new Ae)}createGraphic(t){let e=new w(this.context,t);return this.add(e),this.graphicMap.set(t.id,e),e}removeGraphic(t){this.remove(t),this.graphicMap.delete(t.options.id),t.dispose()}removeGraphicById(t){this.graphicMap.has(t)&&this.removeGraphic(this.graphicMap.get(t))}getGraphicByNodeId(t){return this.graphicMap.get(t)||null}getGraphicByRaycaster(t){let e={distance:1e4,graphic:null,position:null},i=this.children.reduce((n,s)=>{if(s instanceof w){let c=s.raycast(t);if(c){let{distance:h}=c;if(h<n.distance)return{distance:n.distance,position:n.position,graphic:s}}return n}else return n},e);return i===e?{graphics:[],position:null}:{graphics:[i.graphic],position:i.position}}};import{debounce as ze}from"lodash";var X=class extends F{constructor(t){super(t);o(this,"pois",[]);o(this,"debounceCollisionDetection");o(this,"timer",new M);o(this,"onUpdate",()=>{this.timer.requestAnimationFrame(()=>{this.collisionDetection()})});this.registryEvent(),this.debounceCollisionDetection=ze(this.collisionDetection,10)}clear(){return super.clear(),this.pois=[],this}createPoi(t){let e=new B(this.context,t);return this.add(e),this.pushPoi(e),e.addEventListener("change-level",()=>this.changePoiLevelOrCollisionEnable(e)),e.addEventListener("change-collision_enable",()=>this.changePoiLevelOrCollisionEnable(e)),Promise.resolve().then(()=>{this.debounceCollisionDetection()}),e}changePoiLevelOrCollisionEnable(t){let e=this.pois.findIndex(i=>i===t);e!==-1&&(this.pois.splice(e,1),this.pushPoi(t))}removePoi(t){let e=this.pois.findIndex(i=>i===t);e!==-1&&(this.pois.splice(e,1),this.remove(t),t.dispose())}removePoiById(t){let e=this.pois.find(i=>i.options.id===t);e&&this.removePoi(e)}getPoiById(t){return this.pois.find(i=>i.options.id===t)||null}pushPoi(t){if(!t.options.collision_enable){this.pois.unshift(t);return}if(t.options.level===1){this.pois.push(t);return}for(let e=0;e<this.pois.length;e++){let i=this.pois[e];if(i.options.collision_enable&&i.options.level<=t.options.level){this.pois.splice(e,0,t);return}}this.pois.push(t)}getPoiByDeviceXy(t,e){return this.children.filter(n=>n instanceof B&&n.isContain(t,e))}collisionDetection(){let{clientSize:{width:t,height:e}}=this.context,i=[];this.pois.filter(s=>s.withinDisplayRange).forEach((s,c)=>{let{left:h,right:p,top:l,bottom:u}=s.getBox();if(c===0){i.push({left:h,right:p,top:l,bottom:u});return}let g=i.some(m=>p<m.right&&p>m.left||h>m.left&&h<m.right||h===m.left&&p===m.right?u<=m.bottom&&u>m.top||l>=m.top&&l<m.bottom:!1);s.setVisible(!g),i.push({left:h,right:p,top:l,bottom:u})})}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}dispose(){this.timer.dispose(),this.pois.forEach(t=>t.dispose()),this.pois.length=0,this.debounceCollisionDetection=()=>{},super.dispose(),this.unRegistryEvent()}};import{MeshBasicMaterial as Fe,Object3D as Oe,PlaneGeometry as Te,Texture as Re,DoubleSide as ke,Mesh as Be,Matrix3 as At,Vector2 as He}from"three";import{create as Ie}from"@mars3d/heatmap.js";import{featureCollection as Ve,point as $e,bbox as Ue,center as Ke}from"@turf/turf";var W=class extends Oe{constructor(t){super();this.context=t;o(this,"heatmap");o(this,"div");o(this,"plane");this.div=document.createElement("div")}clearHeatmap(){this.div.firstChild&&this.div.removeChild(this.div.firstChild),this.heatmap=void 0}loadData(t){this.clearHeatmap();let{width:e,height:i,leftTop:n,center:s}=this.getBox(t);this.heatmap=Ie(D({width:e,height:i,container:this.div},this.context.config.heatMap)),this.heatmap.setData(this.transformData(t,n)),this.initPlane(e,i),this.position.set(s[0],s[1],this.position.z)}initPlane(t,e){this.plane&&this.remove(this.plane);let i=new Te(t,e),n=new Re(this.div.firstChild);n.needsUpdate=!0;let s=new Fe({transparent:!0,side:ke,map:n});s.needsUpdate=!0,this.plane=new Be(i,s),this.add(this.plane)}getTransMatrix({x:t,y:e}){return new At().makeScale(1,-1).multiply(new At().makeTranslation(0-t,0-e))}transformData(t,e){let i=this.getTransMatrix(e);return{data:t.data.map(s=>{let c=new He(s.x,s.y).applyMatrix3(i);return{x:c.x,y:c.y,value:s.value}}),max:t.max,min:t.min}}getBox(t){let e=Ve(t.data.map(p=>$e([p.x,p.y]))),i=Ue(e),n=i[2]-i[0],s=i[3]-i[1],c={x:i[0],y:i[3]},h=Ke(e);return{width:n,height:s,leftTop:c,center:h.geometry.coordinates}}dispose(){this.div=null,this.heatmap=void 0}};var Z=class extends zt{constructor(t){super();this.context=t;o(this,"graphicLayer");o(this,"poiLayer");o(this,"grounds",new Set);o(this,"shadow",new K);o(this,"heatmap");o(this,"groundUpper",new zt);o(this,"groundMaxHeight",0);this.graphicLayer=new _(this.context),this.poiLayer=new X(this.context),this.groundUpper.add(this.graphicLayer),this.groundUpper.add(this.poiLayer),this.add(this.groundUpper)}addGrounds(t){t.forEach(e=>{this.grounds.has(e)||(e.options.height+=e.options.zIndex/1e5,this.grounds.add(e),this.groundUpper.add(e))}),this.changeGroundMaxHeight()}changeGroundMaxHeight(){let t=Array.from(this.grounds);this.groundMaxHeight=this.grounds.size>0?Math.max(...t.map(e=>e.options.height+e.options.airHeight)):0,this.graphicLayer.position.z=this.groundMaxHeight}get hasElement(){return!!(this.grounds.size||this.graphicLayer.children.length)}getCenter(){return new mt().setFromObject(this.groundUpper).getCenter(new dt)}addShadow(){let t=new mt().setFromObject(this.groundUpper),e=t.getCenter(new dt),i=t.getSize(new dt);this.shadow.setPosition(e),this.shadow.changeLightCamera(i),this.add(this.shadow)}addGraphic(t){return t.height+=(t.height||0)/1e5,this.graphicLayer.createGraphic(t)}addPoi(t){return this.poiLayer.createPoi(t)}addHeatmap(t){this.heatmap||(this.heatmap=new W(this.context),this.add(this.heatmap)),this.heatmap.loadData(t);let e=new mt().setFromObject(this.graphicLayer);return this.heatmap.position.setZ(e.max.z),this.heatmap}removeHeatMap(){this.heatmap&&(this.remove(this.heatmap),this.heatmap.dispose(),this.heatmap=void 0)}setShadowOpacity(t){this.shadow.setOpacity(t)}setShadowVisible(t){this.shadow.visible=t}dispose(){var t;this.shadow.dispose(),this.graphicLayer.dispose(),this.poiLayer.dispose(),this.grounds.forEach(e=>e.dispose()),(t=this.heatmap)==null||t.dispose(),this.groundUpper.clear(),this.clear()}};import{EventDispatcher as je,Vector3 as _e}from"three";var C=class extends je{constructor(t){super();this.context=t;o(this,"points",[]);o(this,"svg");o(this,"enable",!0);this.svg=Mt(`${t.container.clientWidth}`,`${t.container.clientHeight}`),t.container.appendChild(this.svg)}setEnable(t){this.enable=t,t?this.svg.style.display="block":this.svg.style.display="none"}getIntersectByPointerEvent(t){let{camera:e,renderer:i}=this.context,{offsetX:n,offsetY:s}=t,{clientWidth:c,clientHeight:h}=i.domElement,p=n/c*2-1,l=1-s/h*2;return new _e(p,l,0).unproject(e)}getSvgCoordinate(t){let{camera:e,container:i}=this.context;return v(t,e,i.clientWidth,i.clientHeight)}dispose(){this.context.container.removeChild(this.svg),this.svg=null}};var Y=class extends C{constructor(t){super(t);this.context=t;o(this,"circles");o(this,"line");o(this,"onUpdate",()=>{if(this.points[0]){let t=this.getSvgCoordinate(this.points[0]);A(this.circles[0],t.x,t.y),P(this.line,t)}if(this.points[1]){let t=this.getSvgCoordinate(this.points[1]);A(this.circles[1],t.x,t.y),P(this.line,void 0,t)}});o(this,"onPointermove",t=>{this.points.length===1&&(this.line.style.display="block",P(this.line,void 0,{x:t.offsetX,y:t.offsetY}))});o(this,"onPointerleave",()=>{this.points[1]||(this.line.style.display="none")});o(this,"onPointerdown",t=>{if(this.points[1])return;let e=this.getIntersectByPointerEvent(t);if(e){let{offsetX:i,offsetY:n}=t,s=this.circles[this.points.length];A(s,i,n),this.points.length||P(this.line,{x:i,y:n},{x:i,y:n}),this.addPoint(e)}});let{config:{svg:{circle:e,line:i}}}=t;this.circles=[k(e.radius,e.fill),k(e.radius,e.fill)],this.line=U(i.stroke),this.svg.appendChild(this.circles[0]),this.svg.appendChild(this.circles[1]),this.svg.appendChild(this.line),this.registryEvent()}setEnable(t){super.setEnable(t),t?this.registryEvent():this.unRegistryEvent()}registryEvent(){this.context.container.addEventListener("pointerenter",this.onPointermove),this.context.container.addEventListener("pointermove",this.onPointermove),this.context.container.addEventListener("pointerleave",this.onPointerleave),this.context.container.addEventListener("pointerdown",this.onPointerdown),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerenter",this.onPointermove),this.context.container.removeEventListener("pointermove",this.onPointermove),this.context.container.removeEventListener("pointerleave",this.onPointerleave),this.context.container.removeEventListener("pointerdown",this.onPointerdown),this.context.removeEventListener("update",this.onUpdate)}addPoint(t){if(this.points.push(t),this.points.length>=2){let e=this.calculatedDistance();this.dispatchEvent({type:"distance",distance:e})}}calculatedDistance(){let[{x:t,y:e},{x:i,y:n}]=this.points;return Math.sqrt(b(i-t,2)+b(n-e,2))}dispose(){super.dispose(),this.unRegistryEvent(),this.line=null,this.circles=[]}};var q=class extends C{constructor(t){super(t);o(this,"circles",[]);o(this,"lines",[]);o(this,"isClose",!1);o(this,"onUpdate",()=>{this.points.length&&this.points.forEach((t,e)=>{let i=this.getSvgCoordinate(t);this.circles[e]&&A(this.circles[e],i.x,i.y),e!==0&&P(this.lines[e-1],void 0,i),this.lines[e]&&P(this.lines[e],i)})});o(this,"onPointermove",t=>{!this.lastLine||this.isClose||(this.lastLine.style.display="block",P(this.lastLine,void 0,{x:t.offsetX,y:t.offsetY}))});o(this,"onPointerleave",()=>{this.isClose||(this.lastLine.style.display="none")});o(this,"onPointerdown",t=>{if(this.isClose)return;let e=this.getIntersectByPointerEvent(t);if(e){let{offsetX:i,offsetY:n}=t;this.checkAdsorb(i,n)?(this.isClose=!0,this.addPoint(this.points[0])):this.addPoint(e);let{circle:{fill:s,radius:c},line:{stroke:h}}=this.context.config.svg;if(!this.isClose){let p=k(c,s);A(p,i,n),this.addCircle(p)}if(this.lines.length&&P(this.lastLine,void 0,{x:i,y:n}),!this.isClose){let p=U(h);P(p,{x:i,y:n},{x:i,y:n}),this.addLine(p)}}});this.registryEvent()}setEnable(t){super.setEnable(t),t?this.registryEvent():this.unRegistryEvent()}get lastLine(){return this.lines.slice(-1)[0]}addCircle(t){this.circles.push(t),this.svg.appendChild(t)}addLine(t){this.lines.push(t),this.svg.appendChild(t)}registryEvent(){this.context.container.addEventListener("pointerenter",this.onPointermove),this.context.container.addEventListener("pointermove",this.onPointermove),this.context.container.addEventListener("pointerleave",this.onPointerleave),this.context.container.addEventListener("pointerdown",this.onPointerdown),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerenter",this.onPointermove),this.context.container.removeEventListener("pointermove",this.onPointermove),this.context.container.removeEventListener("pointerleave",this.onPointerleave),this.context.container.removeEventListener("pointerdown",this.onPointerdown),this.context.removeEventListener("update",this.onUpdate)}checkAdsorb(t,e){if(this.points.length<3)return!1;let i=this.circles[0],n=+i.getAttribute("cx"),s=+i.getAttribute("cy");return Math.sqrt(b(t-n,2)+b(e-s,2))<=5}addPoint(t){if(this.points.push(t),this.isClose){let e=this.calculatedArea();this.dispatchEvent({type:"area",area:e})}}calculatedArea(){let t=this.points.map(n=>[n.x,n.y]),e=0,i=t.length;for(let n=0;n<i;n++){let s=(n+1)%i;e+=t[n][0]*t[s][1]-t[s][0]*t[n][1]}return Math.abs(e/2)}dispose(){super.dispose(),this.unRegistryEvent(),this.lines=[],this.circles=[]}};import{Box3 as Xe}from"three";var Ft=class extends C{constructor(t){super(t);this.context=t;o(this,"rect");o(this,"cornerRect",[]);o(this,"centerRect",[]);o(this,"graphic");o(this,"onUpdate",()=>{if(this.graphic){let t=new Xe().setFromObject(this.graphic),{camera:e,container:{clientWidth:i,clientHeight:n}}=this.context,{min:s,max:c}=t,h=v(s,e,i,n),p=v(c,e,i,n);E(this.rect,h.x,p.y,Math.abs(p.x-h.x),Math.abs(p.y-h.y));let{x:l,y:u}=h,{x:g,y:m}=p,d=5,y=[{x:l-d,y:m-d},{x:g-d,y:m-d},{x:l-d,y:u-d},{x:g-d,y:u-d}];for(let x=0;x<y.length;x++)E(this.cornerRect[x],y[x].x,y[x].y,d*2,d*2);let f=4,ot=(l+g)/2,O=(u+m)/2,T=[{x:ot-f,y:m-f},{x:l-f,y:O-f},{x:g-f,y:O-f},{x:ot-f,y:u-f}];for(let x=0;x<T.length;x++)E(this.centerRect[x],T[x].x,T[x].y,f*2,f*2)}else{E(this.rect,0,0,0,0);for(let t=0;t<this.cornerRect.length;t++)E(this.cornerRect[t],0,0,0,0),E(this.centerRect[t],0,0,0,0)}});let{config:{svg:{line:e}}}=t;this.rect=z(e.stroke,"transparent"),this.svg.appendChild(this.rect);for(let i=0;i<4;i++)this.cornerRect[i]=z(e.stroke,"#ffffff"),this.centerRect[i]=z(e.stroke,"#ffffff"),this.svg.appendChild(this.cornerRect[i]),this.svg.appendChild(this.centerRect[i]);this.registryEvent()}setEnable(t){super.setEnable(t),t?this.registryEvent():this.unRegistryEvent()}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}selectGraphic(t){this.graphic=t}dispose(){super.dispose(),this.unRegistryEvent(),this.rect=null,this.cornerRect=[],this.centerRect=[]}};import{Frustum as We}from"three";var N=class extends C{constructor(t){super(t);o(this,"startPoint");o(this,"endPoint");o(this,"rect");o(this,"frustum",new We);o(this,"onPointerDown",t=>{if(!this.enable)return;let e=this.getIntersectByPointerEvent(t);e&&(this.startPoint=e),this.endPoint=void 0});o(this,"onPointerMove",t=>{if(!this.enable||!this.startPoint)return;let e=this.getIntersectByPointerEvent(t);e&&(this.endPoint=e)});o(this,"onPointerUp",t=>{if(!this.enable)return;let e=this.getIntersectByPointerEvent(t);e&&(this.endPoint=e),this.doSelect(),this.startPoint=void 0});o(this,"onUpdate",()=>{if(this.startPoint){let t=this.getSvgCoordinate(this.startPoint),e=D({},t);this.endPoint&&(e=this.getSvgCoordinate(this.endPoint));let i={x:Math.min(t.x,e.x),y:Math.min(t.y,e.y)},n=Math.abs(e.x-t.x),s=Math.abs(e.y-t.y);E(this.rect,i.x,i.y,n,s)}else E(this.rect,0,0,0,0)});let{config:{selectBox:{fill:e,stroke:i}}}=t;this.rect=z(i,e),this.svg.appendChild(this.rect),this.registryEvent()}setEnable(t){super.setEnable(t),E(this.rect,0,0,0,0),t?this.registryEvent():(this.startPoint=void 0,this.unRegistryEvent())}registryEvent(){this.context.container.addEventListener("pointerdown",this.onPointerDown),this.context.container.addEventListener("pointermove",this.onPointerMove),this.context.container.addEventListener("pointerup",this.onPointerUp),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerdown",this.onPointerDown),this.context.container.removeEventListener("pointermove",this.onPointerMove),this.context.container.removeEventListener("pointerup",this.onPointerUp),this.context.removeEventListener("update",this.onUpdate)}doSelect(){if(this.startPoint&&this.endPoint){if(this.startPoint.distanceTo(this.endPoint)<.1)return;let{context:{camera:e,container:{clientWidth:i,clientHeight:n}}}=this,s=v(this.startPoint,e,i,n),c=v(this.endPoint,e,i,n),h={x:Math.min(s.x,c.x),y:Math.min(s.y,c.y)},p={x:Math.max(s.x,c.x),y:Math.max(s.y,c.y)},l=this.searchMapInFrustum(h,p);this.dispatchEvent({type:"selected",list:l})}}searchMapInFrustum(t,e){var n;let{context:i}=this;return((n=i.currentFloor)==null?void 0:n.graphicLayer.children.filter(s=>s instanceof w&&this.searchChildInFrustum(s,t,e)))||[]}searchChildInFrustum(t,e,i){let{context:{camera:n,container:{clientWidth:s,clientHeight:c}}}=this;if(!t)return!1;if(!t.mesh){let m=t.getPosition();if(m){let d=v(m,n,s,c);return I(d,e,i)}return!1}t.mesh.geometry.boundingBox||t.mesh.geometry.computeBoundingBox();let h=t.mesh.geometry.boundingBox;if(!h)return!1;let{min:p,max:l}=h,u=v(p,n,s,c),g=v(l,n,s,c);return!(!I(u,e,i)||!I(g,e,i))}dispose(){this.unRegistryEvent()}};var Q=class extends Ze{constructor(t){super();this.context=t;o(this,"_list",new Set);o(this,"boxSelection");o(this,"prevPanStatus");o(this,"prevRotateStatus");o(this,"downPoint",null);o(this,"onPointerDown",t=>{this.downPoint={x:t.offsetX,y:t.offsetY}});o(this,"onPointerUp",t=>{if(!this.downPoint)return;let{offsetX:e,offsetY:i}=t,{x:n,y:s}=this.downPoint;if(Math.sqrt(b(n-e,2)+b(s-i,2))>3)return;let{graphics:c}=this.context.getGraphicsByDeviceXy(e,i),h=new Set(c.map(l=>l.options.id));this.context.getPoisByDeviceXy(e,i).forEach(l=>{var u;if(!h.has(l.options.id)){let g=((u=this.context.currentFloor)==null?void 0:u.graphicLayer.graphicMap.get(l.options.id))||null;g&&(c.push(g),h.add(l.options.id))}}),t.ctrlKey||this._list.clear(),c.forEach(l=>this._list.add(l)),this.selectEnd(),this.downPoint=null});o(this,"onKeyDown",t=>{t.key==="Control"&&(this.boxSelection.setEnable(!0),this.prevPanStatus=this.context.control.enablePan,this.prevRotateStatus=this.context.control.enableRotate,this.context.control.enablePan=!1,this.context.control.enableRotate=!1)});o(this,"onKeyUp",t=>{t.key==="Control"&&(this.boxSelection.setEnable(!1),this.context.control.enablePan=!!this.prevPanStatus,this.context.control.enableRotate=!!this.prevRotateStatus)});o(this,"onBoxSelected",({list:t})=>{this._list.clear(),t.forEach(e=>{this._list.add(e)}),this.selectEnd()});this.boxSelection=new N(t),this.boxSelection.setEnable(!1),this.registryEvent()}get list(){return this._list}selectEnd(){this.dispatchEvent({type:"select",graphics:[...this._list]})}registryEvent(){this.context.container.addEventListener("pointerdown",this.onPointerDown),this.context.container.addEventListener("pointerup",this.onPointerUp),window.addEventListener("keydown",this.onKeyDown),window.addEventListener("keyup",this.onKeyUp),this.boxSelection.addEventListener("selected",this.onBoxSelected)}unRegistryEvent(){this.context.container.removeEventListener("pointerdown",this.onPointerDown),this.context.container.removeEventListener("pointerup",this.onPointerUp),window.removeEventListener("keydown",this.onKeyDown),window.removeEventListener("keyup",this.onKeyUp),this.boxSelection.removeEventListener("selected",this.onBoxSelected)}clear(){this._list.clear()}remove(t){this._list.delete(t)}dispose(){this.unRegistryEvent()}};import{EventDispatcher as Ye}from"three";var J=class extends Ye{constructor(t){super();this.context=t;o(this,"curGraphics",new Set);o(this,"timer",new M);o(this,"graphicTimerMap",new Map);o(this,"onPointerMove",({graphics:t,pois:e})=>{let i=e.map(h=>{var p;return(p=this.context.currentFloor)==null?void 0:p.graphicLayer.graphicMap.get(h.options.id)});if(!t.length&&!i&&this.curGraphics.size){this.curGraphics.clear(),this.handleHoverGraphicsChange();return}let{time:n}=this.context.config.hover,s=new Set([...t,...i]);s.forEach(h=>{if(this.graphicTimerMap.get(h)||this.curGraphics.has(h))return;let p=this.timer.setTimeout(()=>{this.curGraphics.add(h),this.handleHoverGraphicsChange()},n);this.graphicTimerMap.set(h,p)}),this.graphicTimerMap.forEach((h,p)=>{s.has(p)||(this.timer.clearTimeout(h),this.graphicTimerMap.delete(p))});let c=this.curGraphics.size;this.curGraphics.forEach(h=>{s.has(h)||this.curGraphics.delete(h)}),c!==this.curGraphics.size&&this.handleHoverGraphicsChange()});o(this,"onPointerLevel",()=>{this.curGraphics.clear(),this.handleHoverGraphicsChange()});this.registryEvent()}handleHoverGraphicsChange(t=this.curGraphics){this.dispatchEvent({type:"hover-change",graphics:Array.from(t)})}registryEvent(){this.context.addEventListener("pointer-over",this.onPointerMove),this.context.addEventListener("pointer-move",this.onPointerMove),this.context.addEventListener("pointer-level",this.onPointerLevel)}unRegistryEvent(){this.context.removeEventListener("pointer-over",this.onPointerMove),this.context.removeEventListener("pointer-move",this.onPointerMove),this.context.removeEventListener("pointer-level",this.onPointerLevel)}dispose(){this.unRegistryEvent(),this.timer.dispose()}};var nt=class extends qe{constructor(t,e){super();this.container=t;this.config=e;o(this,"scene",ft());o(this,"renderer",vt());o(this,"camera");o(this,"control");o(this,"lights",xt());o(this,"timer",new M);o(this,"tweenGroup",new ii);o(this,"currentFloor");o(this,"selection");o(this,"hoverHelper");o(this,"basicRatio");o(this,"clientSize",{width:0,height:0});o(this,"onWindowResize",()=>{let{container:t,camera:e,renderer:i}=this,{clientWidth:n,clientHeight:s}=t;e.left=-n/2,e.right=n/2,e.top=s/2,e.bottom=-s/2,e.updateProjectionMatrix(),i.setSize(n,s),this.resizeClientSize(n,s)});o(this,"onClick",t=>{let{graphics:e,position:i}=this.getGraphicsByDeviceXy(t.offsetX,t.offsetY);e.length&&this.dispatchEvent({type:"graphic-click",graphics:e,position:i});let n=this.getPoisByDeviceXy(t.offsetX,t.offsetY);n.length&&this.dispatchEvent({type:"poi-click",pois:n})});o(this,"onPointerover",t=>{let{graphics:e,position:i}=this.getGraphicsByDeviceXy(t.offsetX,t.offsetY),n=this.getPoisByDeviceXy(t.offsetX,t.offsetY);this.dispatchEvent({type:"pointer-over",graphics:e,pois:n,position:i})});o(this,"onPointermove",t=>{let{graphics:e,position:i}=this.getGraphicsByDeviceXy(t.offsetX,t.offsetY),n=this.getPoisByDeviceXy(t.offsetX,t.offsetY);this.dispatchEvent({type:"pointer-move",graphics:e,pois:n,position:i})});o(this,"onPointerleave",()=>{this.dispatchEvent({type:"pointer-level"})});o(this,"onSelectionSelect",({graphics:t})=>{this.dispatchEvent({type:"select-graphic",graphics:t})});o(this,"onHoverChange",({graphics:t})=>{this.dispatchEvent({type:"hover",graphics:t})});this.container.style.position="relative",this.container.style.overflow="hidden",this.init(),this.selection=new Q(this),this.hoverHelper=new J(this),this.resizeClientSize(),this.registryEvent()}resizeClientSize(t,e){this.clientSize={width:t||this.container.clientWidth,height:e||this.container.clientHeight}}init(){let{clientWidth:t,clientHeight:e}=this.container;this.camera=yt(t,e),this.renderer.setSize(t,e),this.control=bt(this.camera,this.renderer.domElement),this.control.maxPolarAngle=this.config.control.maxPolar,this.container.appendChild(this.renderer.domElement),this.scene.add(this.lights),this.basicRatio=this.getRatio(),this.control.addEventListener("change",()=>{var n;let i=this.control.getPolarAngle();(n=this.currentFloor)==null||n.setShadowOpacity(i/this.config.control.maxPolar),this.dispatchEvent({type:"change-ratio",px:(this.basicRatio||0)*this.camera.zoom}),this.dispatchEvent({type:"control-change"})})}getRatio(t=new tt(0,0,0),e=new tt(100,0,0)){let{clientWidth:i,clientHeight:n}=this.container,s=v(t,this.camera,i,n),c=v(e,this.camera,i,n);return Math.ceil(Math.sqrt(b(c.x-s.x,2)+b(c.y-s.y,2)))}changeAmbientLightColor(t){this.lights.children.forEach(e=>{e instanceof ei&&(e.color=new ti(t))})}switchFloor(t){this.currentFloor&&(this.scene.remove(this.currentFloor),this.currentFloor.dispose()),this.currentFloor=t,this.scene.add(t);let e=t.getCenter();e&&(this.lights.position.x=e.x,this.lights.position.y=e.y)}getGraphicsByDeviceXy(t,e){var c;let i=new et;i.x=t/this.container.clientWidth*2-1,i.y=e/this.container.clientHeight*-2+1;let n=new Qe;return n.setFromCamera(i,this.camera),((c=this.currentFloor)==null?void 0:c.graphicLayer.getGraphicByRaycaster(n))||{graphics:[],position:null}}getPoisByDeviceXy(t,e){var n;return((n=this.currentFloor)==null?void 0:n.poiLayer.getPoiByDeviceXy(t,e))||[]}registryEvent(){window.addEventListener("resize",this.onWindowResize),this.container.addEventListener("click",this.onClick),this.container.addEventListener("pointerover",this.onPointerover),this.container.addEventListener("pointermove",this.onPointermove),this.container.addEventListener("pointerleave",this.onPointerleave),this.selection.addEventListener("select",this.onSelectionSelect),this.hoverHelper.addEventListener("hover-change",this.onHoverChange)}unRegistryEvent(){window.removeEventListener("resize",this.onWindowResize),this.container.removeEventListener("click",this.onClick),this.container.removeEventListener("pointerover",this.onPointerover),this.container.removeEventListener("pointermove",this.onPointermove),this.container.removeEventListener("pointerleave",this.onPointerleave),this.selection.removeEventListener("select",this.onSelectionSelect),this.hoverHelper.removeEventListener("hover-change",this.onHoverChange)}setPolarAngle(t,e=500){return e===0?(this.control.maxPolarAngle=t,this.control.minPolarAngle=t,this.control.update(),this.control.maxPolarAngle=this.config.control.maxPolar,this.control.minPolarAngle=0,Promise.resolve()):R(new Promise(i=>{let n={polar:this.control.getPolarAngle()},s={polar:t},c=new it(n,this.tweenGroup).to(s,e).onUpdate(()=>{this.control.maxPolarAngle=n.polar,this.control.minPolarAngle=n.polar,this.control.update()}).onComplete(()=>{this.control.enabled=!0,this.control.maxPolarAngle=this.config.control.maxPolar,this.control.minPolarAngle=0,this.tweenGroup.remove(c),i(!0)}).onStart(()=>{this.control.enabled=!1}).start()}),e+500)}setAzimuthalAngle(t,e=500){return e===0&&(this.control.maxAzimuthAngle=t,this.control.minAzimuthAngle=t,this.control.update(),this.control.maxAzimuthAngle=1/0,this.control.minAzimuthAngle=1/0),R(new Promise(i=>{let n={azimuthal:this.control.getAzimuthalAngle()},s={azimuthal:t},c=new it(n,this.tweenGroup).to(s,e).onUpdate(()=>{this.control.maxAzimuthAngle=n.azimuthal,this.control.minAzimuthAngle=n.azimuthal,this.control.update()}).onComplete(()=>{this.control.enabled=!0,this.control.maxAzimuthAngle=1/0,this.control.minAzimuthAngle=1/0,this.tweenGroup.remove(c),i(!0)}).onStart(()=>{this.control.enabled=!1}).start()}),e+500)}getCameraLookAt(){return new tt().subVectors(this.control.target,this.camera.position)}setZoom(t,e,i=500){let n=this.getCameraLookAt(),s={zoom:this.camera.zoom,target:this.control.target.clone()};return i||(this.camera.position.copy(s.target.clone().sub(n)),this.control.target.copy(s.target),this.camera.zoom=s.zoom),R(new Promise(c=>{let h=new it(s,this.tweenGroup).to({zoom:t,target:e},i).onUpdate(()=>{this.camera.position.copy(s.target.clone().sub(n)),this.control.target.copy(s.target),this.camera.zoom=s.zoom,this.control.update()}).onComplete(()=>{this.tweenGroup.remove(h),this.control.enabled=!0,c(!0)}).onStart(()=>{this.control.enabled=!1}).start()}),i+500)}fitCameraToObject(t,e=[20,20,20,20],i=500){let[n,s,c,h]=e,{clientSize:{width:p,height:l}}=this,u=this.control.getPolarAngle();this.setPolarAngle(0,0);let g=new Je().setFromObject(t);this.setPolarAngle(u,0);let{max:m,min:d}=g,y=v(m,this.camera,p,l),f=v(d,this.camera,p,l),O=new Ne().setFromPoints([new et(y.x,y.y),new et(f.x,f.y)]).getSize(new et),T=(p-s-h)/O.x,x=(l-n-c)/O.y,Rt=Math.min(T,x),kt=new tt((m.x+d.x)/2,(m.y+d.y)/2,m.z);return this.setZoom(Rt*this.camera.zoom,kt,i)}fitCameraToGround(t=[20,20,20,20],e=500){return this.currentFloor&&this.currentFloor.hasElement?this.fitCameraToObject(this.currentFloor.groundUpper,t,e):Promise.resolve(!1)}setCameraPosition(t,e){return R(new Promise(i=>{let n=this.camera.position.clone(),s=this.getCameraLookAt(),c=new it(n,this.tweenGroup).to(t,e).onUpdate(()=>{this.camera.position.copy(n),this.control.target.copy(t.clone().add(s))}).onComplete(()=>{this.tweenGroup.remove(c),this.control.update(),this.control.enabled=!0,i(!0)}).onStart(()=>{this.control.enabled=!1}).start()}),e+500)}render(){this.renderer.render(this.scene,this.camera),this.dispatchEvent({type:"update"}),this.timer.requestAnimationFrame(()=>{this.render()}),this.tweenGroup.update()}dispose(){this.selection.dispose(),this.hoverHelper.dispose(),this.tweenGroup.getAll().forEach(t=>t.stop()),this.tweenGroup.removeAll(),this.unRegistryEvent(),this.container.removeChild(this.renderer.domElement),this.timer.dispose(),this.renderer.dispose(),this.lights.children.forEach(t=>t.dispose()),L(this.scene)}};import{merge as ni}from"lodash";var oi={apiDomain:"",apiInfo:{},apiPath:{floorGraphic:"/api/inception-map/floor/get",floorRange:"/api/inception-map/range/get"},heatMap:{radius:50,gradient:{0:"#8F9FCD",.5:"#6284FF",1:"#F95D5D"}},useFloorCache:!0,control:{maxPolar:.9},svg:{circle:{radius:"2",fill:"#1CADFF"},line:{stroke:"#1CADFF"}},selectBox:{stroke:"#1CADFF",fill:"rgba(28, 173, 255, 0.3)"},hover:{time:500}};function Ot(r){return ni({},oi,r)}var si=(t=>(t[t.D2=0]="D2",t[t.D3=.9]="D3",t))(si||{}),Tt=class extends ri{constructor(t,e={}){super();this.container=t;o(this,"config");o(this,"context");o(this,"polarKeys",[]);o(this,"azimuthalKeys",[]);o(this,"svgLine");o(this,"svgPolygon");o(this,"basicZoom",1);o(this,"prevCameraZoom",1);o(this,"type","2d");o(this,"floorDataMap",new Map);o(this,"buildingGroundMap",new Map);o(this,"currentBuildGround",null);o(this,"onControlChange",()=>{let{camera:{zoom:t}}=this.context;t!==this.prevCameraZoom&&(this.dispatchEvent({type:"zoom-change",basicZoom:this.basicZoom,cameraZoom:this.context.camera.zoom}),this.prevCameraZoom=t)});o(this,"onKeydown",t=>{this.polarKeys.includes(t.code)&&(this.context.control.maxPolarAngle=this.config.control.maxPolar,this.context.control.minPolarAngle=0),this.azimuthalKeys.includes(t.code)&&(this.context.control.maxAzimuthAngle=1/0,this.context.control.minAzimuthAngle=1/0)});o(this,"onKeyUp",t=>{if(this.polarKeys.includes(t.code)){let e=this.context.control.getPolarAngle();this.context.control.maxPolarAngle=e,this.context.control.minPolarAngle=e}if(this.azimuthalKeys.includes(t.code)){let e=this.context.control.getAzimuthalAngle();this.context.control.maxAzimuthAngle=e,this.context.control.minAzimuthAngle=e}});this.config=Ot(e),this.context=new nt(t,this.config),this.registryEvent(),this.context.render()}loadGraphics(p){return G(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:s,ts:c,resource_type_list:h}){let{apiDomain:l,apiPath:{floorGraphic:u},apiInfo:g}=this.config,m=`${l}${u}?brand=${t}&project=${e}&phase=${i}&building=${n}&floor=${s}&ts=${c}&resource_type_list=${h}`;return yield fetch(m,g).then(y=>y.json()).then(y=>y.data).then(y=>((y||[]).map(f=>f.info=JSON.parse(f.info)),y||[]))})}getBuildingKey({brand:t,project:e,phase:i,building:n}){return`${t}-${e}-${i}-${n}`}loadBuildingGround(s){return G(this,arguments,function*({brand:t,project:e,phase:i,building:n}){let c=this.getBuildingKey({brand:t,project:e,phase:i,building:n});if(this.buildingGroundMap.get(c))return this.buildingGroundMap.get(c)||null;let{apiDomain:h,apiPath:{floorRange:p},apiInfo:l}=this.config,u=`${h}${p}?brand=${t}&project=${e}&phase=${i}&building=${n}`,g=yield fetch(u,l).then(m=>m.json()).then(m=>m.data).then(m=>{let d=(m||[])[0];return d&&(d.info=JSON.parse(d.info)),d});return this.buildingGroundMap.set(c,g),g})}getFloorKey({brand:t,project:e,phase:i,building:n,floor:s,ts:c,resource_type_list:h}){return`${t}-${e}-${i}-${n}-${s}-${c}-${h}`}load(p){return G(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:s,ts:c,resource_type_list:h}){let l=this.getFloorKey({brand:t,project:e,phase:i,building:n,floor:s,ts:c,resource_type_list:h});if(this.floorDataMap.get(l))return;let[u,g]=yield Promise.all([this.loadGraphics({brand:t,project:e,phase:i,building:n,floor:s,ts:c,resource_type_list:h}),this.loadBuildingGround({brand:t,project:e,phase:i,building:n})]);if(g){let m=ct(g.info.geometry.cds[0]);u.forEach(d=>{if(d.info.geometry.type==="polygon")d.info.geometry.cds.map(y=>{Array.isArray(y)&&y.forEach(f=>{f[0]-=m[0],f[1]-=m[1]})});else{let[y,f]=d.info.geometry.cds;d.info.geometry.cds=[y-m[0],f-m[1]]}d.info.transformToBuildingGround=!0})}return this.config.useFloorCache||this.floorDataMap.clear(),this.floorDataMap.set(l,u),u})}createFloor(t){let e=new Z(this.context);if(!t.length)return{curFloor:e,graphics:[]};let i=t.filter(p=>p.info.group==="ground");i.forEach(p=>{p.info.fillColor="#F5F7F9",p.info.fillOpacity=1,p.info.strokeOpacity=0,p.info.height=5});let n=i.map(p=>new w(this.context,p.info));e.addGrounds(n);let s=t.filter(p=>p.info.group!=="ground");s.forEach((p,l)=>{p.info.height=5});let c=new Map,h=s.map(p=>{let l=e.addGraphic(p.info);return l.userData.data=p,c.set(p.legacy_id,l),l});return e.addShadow(),e.userData.legacyToGraphicMap=c,{curFloor:e,graphics:h}}switchFloor({brand:t,project:e,phase:i,building:n,floor:s,ts:c,resource_type_list:h}){let p=this.getFloorKey({brand:t,project:e,phase:i,building:n,floor:s,ts:c,resource_type_list:h}),l=this.floorDataMap.get(p);if(this.context.control.removeEventListener("change",this.onControlChange),l){let u=this.getBuildingKey({brand:t,project:e,phase:i,building:n});this.currentBuildGround=this.buildingGroundMap.get(u)||null;let g=this.createFloor(l);g?(this.context.switchFloor(g.curFloor),this.context.control.minZoom=0,this.context.control.maxZoom=1/0,this.context.setAzimuthalAngle(0,0),this.context.fitCameraToGround(void 0,0),this.basicZoom=this.context.camera.zoom,this.context.control.minZoom=this.basicZoom,this.context.control.maxZoom=this.basicZoom*25,this.context.control.addEventListener("change",this.onControlChange),this.onControlChange()):console.warn("[switchFloor error] ["+s+"] \u697C\u5C42\u6CA1\u6709\u6570\u636E")}else console.warn("[switchFloor error] \u6CA1\u6709\u8FD9\u4E2A\u697C\u5C42\uFF0C\u8BF7\u5148\u8C03\u7528load\u65B9\u6CD5\u52A0\u8F7D\u697C\u5C42")}addHeatmap(t){var e;return(e=this.context.currentFloor)==null?void 0:e.addHeatmap(t)}getLegacyToGraphicMap(){var t;return((t=this.context.currentFloor)==null?void 0:t.userData.legacyToGraphicMap)||new Map}getFloorAllGraphics(){var t;return((t=this.context.currentFloor)==null?void 0:t.graphicLayer.children.filter(e=>e instanceof w))||[]}createGraphicPoi(t,e){if(this.context.currentFloor){e.id===void 0&&(e.id=t.options.id);let i=t.getCenter();return this.context.currentFloor.addPoi(st(D({},e),{position:st(D({},i),{z:i.z+t.options.height/2})}))}return null}removeHeatMap(){var t;(t=this.context.currentFloor)==null||t.removeHeatMap()}translateElementToCenter(t,e=500){let i=t.position.clone().setFromMatrixPosition(t.matrixWorld);return this.context.setCameraPosition(i,e)}getElementDeviceCoordinate(t){let e=t.position.clone(),{clientWidth:i,clientHeight:n}=this.container;return v(e,this.context.camera,i,n)}changeMapType(t,e=500){return this.type=t,t==="2d"?this.context.setPolarAngle(0,e):this.context.setPolarAngle(.9,e)}resetView(t=300){return G(this,null,function*(){let e=t/3;yield this.context.setAzimuthalAngle(0,e),yield this.changeMapType(this.type,e),yield this.context.fitCameraToGround(void 0,e)})}reduceMap(t=.5,e=500){let i=this.context.camera.zoom;return this.context.setZoom(i-t,this.context.control.target,e)}enlargeMap(t=.5,e=500){let i=this.context.camera.zoom;return this.context.setZoom(i+t,this.context.control.target,e)}registryEvent(){window.addEventListener("keydown",this.onKeydown),window.addEventListener("keyup",this.onKeyUp)}unRegistryEvent(){window.removeEventListener("keydown",this.onKeydown),window.removeEventListener("keyup",this.onKeyUp)}configurePolarShortcutKeys(t){this.polarKeys=t}configureAzimuthalShortcutKeys(t){this.azimuthalKeys=t}rotateMap(t=.1){let e=this.context.control.getAzimuthalAngle();this.context.control.maxAzimuthAngle=e+t,this.context.control.minAzimuthAngle=e+t,this.context.control.update()}measureDistance(){return G(this,null,function*(){return this.cancelDistance(),new Promise((t,e)=>{this.changeMapType("2d",0),this.context.control.enableRotate=!1,this.svgLine=new Y(this.context);let i=this.svgLine.dispose.bind(this.svgLine);this.svgLine.dispose=function(){i(),e("cancel")},this.svgLine.addEventListener("distance",({distance:n})=>{t(n)})})})}cancelDistance(){this.svgLine&&(this.svgLine.dispose(),this.svgLine=void 0,this.context.control.enableRotate=!0)}measureArea(){return this.cancelArea(),new Promise((t,e)=>{this.changeMapType("2d",0),this.context.control.enableRotate=!1,this.svgPolygon=new q(this.context);let i=this.svgPolygon.dispose.bind(this.svgPolygon);this.svgPolygon.dispose=function(){i(),e("cancel")},this.svgPolygon.addEventListener("area",({area:n})=>{t(n)})})}cancelArea(){this.svgPolygon&&(this.svgPolygon.dispose(),this.svgPolygon=void 0,this.context.control.enableRotate=!0)}getGraphicByNodeId(t){var e;return((e=this.context.currentFloor)==null?void 0:e.graphicLayer.getGraphicByNodeId(t))||null}deleteGraphic(t){var e;(e=this.context.currentFloor)==null||e.graphicLayer.removeGraphic(t)}createGraphicByOptions(t){var e;if(!t.transformToBuildingGround&&this.currentBuildGround){let i=ct(this.currentBuildGround.info.geometry.cds[0]);if(t.geometry.type==="polygon")t.geometry.cds.map(n=>{Array.isArray(n)&&n.forEach(s=>{s[0]-=i[0],s[1]-=i[1]})});else{let[n,s]=t.geometry.cds;t.geometry.cds=[n-i[0],s-i[1]]}}return(e=this.context.currentFloor)==null?void 0:e.graphicLayer.createGraphic(t)}removePoiById(t){var e;return(e=this.context.currentFloor)==null?void 0:e.poiLayer.removePoiById(t)}getPoiById(t){var e;return(e=this.context.currentFloor)==null?void 0:e.poiLayer.getPoiById(t)}getPois(){var t;return((t=this.context.currentFloor)==null?void 0:t.poiLayer.pois)||[]}clearPoi(){this.context.currentFloor&&(this.getPois().forEach(t=>t.dispose()),this.context.currentFloor.poiLayer.clear())}removeSelectGraphic(t){this.context.selection.remove(t)}dispose(){this.context.dispose(),Lt(),Gt(),this.unRegistryEvent()}};export{Tt as BMap,C as BaseSvg,nt as Context,Z as Floor,w as Graphic,_ as GraphicLayer,W as HeatmapElement,J as HoverHelper,F as Layer,si as MapTypePolar,j as Overlay,B as Poi,X as PoiLayer,Ft as SelectBox,Q as Selection,K as Shadow,Y as SvgLine,q as SvgPolygon,M as Timer,Gt as clearCanvas,Lt as clearTextTexture,ne as createCanvas,k as createCircle,U as createLine,z as createRect,Mt as createSvg,$ as createSvgElement,oi as defaultConfig,L as dispose,ct as getCenter,Ot as getConfig,vi as getTextureByText,wt as hasChinese,yt as initCamera,ie as initCanvas,bt as initControl,Et as initDirectionalLight,xt as initLight,vt as initRenderer,ft as initScene,Pt as initShape,I as isContain,V as proxyOptions,A as setCirclePosition,P as setLineStartEnd,E as setRectPosition,ht as sleepOnePromise,Li as strToNumber,R as timeoutPromise,v as vector3ToDevice};
3
3
  //# sourceMappingURL=bmap.esm.min.js.map