@aibee/crc-bmap 0.0.29 → 0.0.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/example/src/main.ts +25 -25
- package/lib/bmap.cjs.min.js +2 -2
- package/lib/bmap.cjs.min.js.map +3 -3
- package/lib/bmap.esm.js +125 -24
- package/lib/bmap.esm.js.map +2 -2
- package/lib/bmap.esm.min.js +2 -2
- package/lib/bmap.esm.min.js.map +3 -3
- package/lib/bmap.min.js +2 -2
- package/lib/bmap.min.js.map +3 -3
- package/lib/src/bmap.d.ts +1 -0
- package/lib/src/context.d.ts +6 -0
- package/lib/src/elements/overlay.d.ts +5 -0
- package/lib/src/elements/poi.d.ts +20 -1
- package/lib/src/layer/poi-layer.d.ts +1 -0
- package/lib/src/operations/selection/selection.d.ts +4 -0
- package/package.json +1 -1
package/example/src/main.ts
CHANGED
|
@@ -93,32 +93,32 @@ bmap.context.addEventListener('change-ratio', ({ px }) => {
|
|
|
93
93
|
// 添加poi
|
|
94
94
|
document.getElementById("createPoi")?.addEventListener('click', () => {
|
|
95
95
|
// 获取legacyId 和 图元 的map
|
|
96
|
-
const graphic = bmap.getGraphicByNodeId("712be555")!
|
|
97
|
-
const poi = bmap.createGraphicPoi(graphic, {
|
|
98
|
-
|
|
99
|
-
})
|
|
100
|
-
// const graphics: Graphic[] = bmap.getFloorAllGraphics()
|
|
101
|
-
// bmap.context.control.zoomSpeed = 2
|
|
102
|
-
// graphics.slice(0, 30).forEach(graphic => {
|
|
103
|
-
// // 在图元上添加poi
|
|
104
|
-
// const poi = bmap.createGraphicPoi(graphic, {
|
|
105
|
-
// text: "店铺名称"
|
|
106
|
-
// })
|
|
107
|
-
// // 监听放大缩小的变化
|
|
108
|
-
// bmap.context.control.addEventListener("change", () => {
|
|
109
|
-
// const zoomScale = bmap.context.camera.zoom / bmap.basicZoom
|
|
110
|
-
// console.log(zoomScale, bmap.basicZoom, bmap.context.camera.zoom)
|
|
111
|
-
// if (zoomScale > 2.5) {
|
|
112
|
-
// poi!.options.text = "店铺名称\r\n店铺名称\r\n店铺名称\r\n店铺名称"
|
|
113
|
-
// } else if (zoomScale > 1.8) {
|
|
114
|
-
// poi!.options.text = "店铺名称\r\n店铺名称\r\n店铺名称"
|
|
115
|
-
// } else if (zoomScale > 1.3) {
|
|
116
|
-
// poi!.options.text = "店铺名称\r\n店铺名称"
|
|
117
|
-
// } else {
|
|
118
|
-
// poi!.options.text = "店铺名称"
|
|
119
|
-
// }
|
|
120
|
-
// })
|
|
96
|
+
// const graphic = bmap.getGraphicByNodeId("712be555")!
|
|
97
|
+
// const poi = bmap.createGraphicPoi(graphic, {
|
|
98
|
+
// text: "店铺名称"
|
|
121
99
|
// })
|
|
100
|
+
const graphics: Graphic[] = bmap.getFloorAllGraphics()
|
|
101
|
+
bmap.context.control.zoomSpeed = 2
|
|
102
|
+
graphics.forEach(graphic => {
|
|
103
|
+
// 在图元上添加poi
|
|
104
|
+
const poi = bmap.createGraphicPoi(graphic, {
|
|
105
|
+
text: "店铺名称"
|
|
106
|
+
})
|
|
107
|
+
// 监听放大缩小的变化
|
|
108
|
+
// bmap.context.control.addEventListener("change", () => {
|
|
109
|
+
// const zoomScale = bmap.context.camera.zoom / bmap.basicZoom
|
|
110
|
+
// console.log(zoomScale, bmap.basicZoom, bmap.context.camera.zoom)
|
|
111
|
+
// if (zoomScale > 2.5) {
|
|
112
|
+
// poi!.options.text = "店铺名称\r\n店铺名称\r\n店铺名称\r\n店铺名称"
|
|
113
|
+
// } else if (zoomScale > 1.8) {
|
|
114
|
+
// poi!.options.text = "店铺名称\r\n店铺名称\r\n店铺名称"
|
|
115
|
+
// } else if (zoomScale > 1.3) {
|
|
116
|
+
// poi!.options.text = "店铺名称\r\n店铺名称"
|
|
117
|
+
// } else {
|
|
118
|
+
// poi!.options.text = "店铺名称"
|
|
119
|
+
// }
|
|
120
|
+
// })
|
|
121
|
+
})
|
|
122
122
|
})
|
|
123
123
|
// 删除poi
|
|
124
124
|
document.getElementById("removePoi")?.addEventListener('click', () => {
|
package/lib/bmap.cjs.min.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";var pt=Object.defineProperty;var Qt=Object.getOwnPropertyDescriptor;var Nt=Object.getOwnPropertyNames,Tt=Object.getOwnPropertySymbols;var Rt=Object.prototype.hasOwnProperty,Jt=Object.prototype.propertyIsEnumerable;var O=Math.pow,vt=(o,r,t)=>r in o?pt(o,r,{enumerable:!0,configurable:!0,writable:!0,value:t}):o[r]=t,lt=(o,r)=>{for(var t in r||(r={}))Rt.call(r,t)&&vt(o,t,r[t]);if(Tt)for(var t of Tt(r))Jt.call(r,t)&&vt(o,t,r[t]);return o};var te=(o,r)=>{for(var t in r)pt(o,t,{get:r[t],enumerable:!0})},ee=(o,r,t,e)=>{if(r&&typeof r=="object"||typeof r=="function")for(let i of Nt(r))!Rt.call(o,i)&&i!==t&&pt(o,i,{get:()=>r[i],enumerable:!(e=Qt(r,i))||e.enumerable});return o};var ie=o=>ee(pt({},"__esModule",{value:!0}),o);var s=(o,r,t)=>(vt(o,typeof r!="symbol"?r+"":r,t),t);var I=(o,r,t)=>new Promise((e,i)=>{var n=h=>{try{c(t.next(h))}catch(p){i(p)}},a=h=>{try{c(t.throw(h))}catch(p){i(p)}},c=h=>h.done?e(h.value):Promise.resolve(h.value).then(n,a);c((t=t.apply(o,r)).next())});var se={};te(se,{BMap:()=>At,BaseSvg:()=>S,Context:()=>ct,Floor:()=>nt,Graphic:()=>M,GraphicLayer:()=>tt,HeatmapElement:()=>it,HoverHelper:()=>at,Layer:()=>z,Overlay:()=>J,Poi:()=>U,PoiLayer:()=>et,SelectBox:()=>Ft,Selection:()=>st,Shadow:()=>N,SvgLine:()=>ot,SvgPolygon:()=>rt,Timer:()=>R,clearCanvas:()=>Dt,clearTextTexture:()=>Mt,createCanvas:()=>Ht,createCircle:()=>K,createLine:()=>Q,createRect:()=>H,createSvg:()=>St,createSvgElement:()=>q,defaultConfig:()=>Yt,dispose:()=>F,getCenter:()=>mt,getConfig:()=>Ot,getTextureByText:()=>ne,hasChinese:()=>Ct,initCamera:()=>Et,initCanvas:()=>Bt,initControl:()=>Pt,initDirectionalLight:()=>Lt,initLight:()=>bt,initRenderer:()=>xt,initScene:()=>yt,initShape:()=>wt,isContain:()=>W,proxyOptions:()=>Y,setCirclePosition:()=>A,setLineStartEnd:()=>L,setRectPosition:()=>C,timeoutPromise:()=>Z,vector3ToDevice:()=>x});module.exports=ie(se);var Zt=require("three");var R=class{constructor(){s(this,"tasks",{requestAnimation:new Set,timeout:new Set,interval:new Set})}requestAnimationFrame(r){let t=window.requestAnimationFrame(()=>{this.tasks.requestAnimation.delete(t),r()});return this.tasks.requestAnimation.add(t),t}cancelAnimationFrame(r){this.tasks.requestAnimation.delete(r),window.cancelAnimationFrame(r)}setTimeout(r,t){let e=window.setTimeout(()=>{this.tasks.timeout.delete(e),r()},t);return this.tasks.timeout.add(e),e}clearTimeout(r){this.tasks.timeout.delete(r),window.clearTimeout(r)}setInterval(r,t){let e=window.setInterval(()=>{this.tasks.interval.delete(e),r()},t);return this.tasks.interval.add(e),e}clearInterval(r){this.tasks.interval.delete(r),window.clearInterval(r)}dispose(){this.tasks.requestAnimation.forEach(r=>{window.cancelAnimationFrame(r)}),this.tasks.requestAnimation.clear(),this.tasks.timeout.forEach(r=>{window.clearTimeout(r)}),this.tasks.timeout.clear(),this.tasks.interval.forEach(r=>{window.clearInterval(r)}),this.tasks.interval.clear()}};var u=require("three"),kt=require("three/examples/jsm/controls/MapControls");function yt(){let o=new u.Scene;return o.background=new u.Color(16777215),o}function xt(){let o=new u.WebGLRenderer({antialias:!0});return o.setClearColor(16777215),o.setPixelRatio(window.devicePixelRatio),o.shadowMap.enabled=!0,o.shadowMap.autoUpdate=!0,o.shadowMap.type=u.PCFSoftShadowMap,o}function Et(o,r){let t=new u.OrthographicCamera(-o/2,o/2,r/2,-r/2,-1e3,5e3);return t.up.set(0,0,1),t.position.set(0,0,100),t.lookAt(0,0,0),t}function bt(){let o=new u.Group,r=new u.HemisphereLight(16777215,15658734,1);r.intensity=1,r.position.set(0,0,10),r.up.set(0,0,1),o.add(r);let t=new u.AmbientLight(16777215);return o.add(t),o}function Pt(o,r){let t=new kt.MapControls(o,r);return t.enableDamping=!1,t.maxPolarAngle=0,t.minPolarAngle=0,t}function wt(o,r=[]){let t=new u.Shape(o.map(e=>new u.Vector2(...e)));return r.length&&r.forEach(e=>{var i=new u.Path(e.map(n=>new u.Vector2(...n)));t.holes.push(i)}),t}function Lt(o=16777215,r=1){let t=new u.DirectionalLight(o,r);return t.castShadow=!0,t.shadow.radius=8,t.shadow.bias=-.001,t.shadow.mapSize.set(256,256),t.shadow.camera.left=-200,t.shadow.camera.right=200,t.shadow.camera.top=200,t.shadow.camera.bottom=-200,t}function F(o,r){var t;if(r&&o.children&&o.children.length&&o.children.forEach(e=>{F(e,r)}),o.isMesh){let e=o;e.geometry&&e.geometry.dispose(),e.material&&(Array.isArray(e.material)?e.material.forEach(i=>{i.dispose()}):e.material.dispose())}o.isLight&&((t=o.dispose)==null||t.call(o))}function Ct(o){return/[\u4E00-\u9FA5]+/g.test(o)}var B=require("three");var dt=new Map;function Bt(){let o=document.createElement("canvas");o.width=1024,o.height=64;let r=o.getContext("2d",{willReadFrequently:!0});return r.font="54px sans-serif",r.textBaseline="hanging",r.lineWidth=12,r.fillStyle="rgba(0,0,0,1)",r.strokeStyle="white",{canvas:o,ctx:r}}var Gt,k;function Ht(){if(!Gt){let{canvas:o,ctx:r}=Bt();Gt=o,k=r}}function ne(o){if(dt.has(o))return dt.get(o);Ht(),k.clearRect(0,0,1024,64);let r=Ct(o)?4:8;k.strokeText(o,2,r),k.fillText(o,2,r);let t=Math.ceil(k.measureText(o).width);t=t%2===0?t:t+1,t+=2;let e=k.getImageData(0,0,t,64),i=new B.DataTexture(Uint8Array.from(e.data),t,64,B.RGBAFormat);return i.flipY=!0,i.minFilter=B.LinearFilter,i.magFilter=B.LinearFilter,dt.set(o,i),i}function Mt(){dt.clear()}function Dt(){k=null,Gt=null}var $=require("@turf/turf");function x(o,r,t,e){let i=o.clone().project(r),n=t/2,a=e/2,c=Math.round(i.x*n+n),h=Math.round(-i.y*a+a);return{x:c,y:h}}function mt(o){let r=(0,$.featureCollection)(o.map(e=>(0,$.point)(e)));return(0,$.center)(r).geometry.coordinates}function W(o,r,t){return o.x>=r.x&&o.x<=t.x&&o.y>=r.y&&o.y<=t.y}function Y(o,r){return new Proxy(o,{get:(t,e,i)=>Reflect.get(t,e,i),set:(t,e,i,n)=>{let a=Reflect.set(t,e,i,n);return r.dispatchEvent({type:`change-${e}`,value:i}),a}})}function Z(o,r){return Promise.race([o,new Promise((t,e)=>{setTimeout(()=>e(new Error("Promise timeout")),r)})])}function q(o){return document.createElementNS("http://www.w3.org/2000/svg",o)}function St(o,r){let t=q("svg");return t.setAttribute("width",o),t.setAttribute("height",r),t.style.cssText="position: absolute; left: 0; top: 0; pointer-events: none;",t}function K(o="2",r){let t=q("circle");return t.setAttribute("r",o),t.setAttribute("fill",r),t}function Q(o){let r=q("line");return r.setAttribute("stroke",o),r}function H(o,r){let t=q("rect");return t.setAttribute("stroke",o),t.setAttribute("fill",r),t}function A(o,r,t){o.setAttribute("cx",`${r}`),o.setAttribute("cy",`${t}`)}function L(o,r,t){r&&(o.setAttribute("x1",`${r.x}`),o.setAttribute("y1",`${r.y}`)),t&&(o.setAttribute("x2",`${t.x}`),o.setAttribute("y2",`${t.y}`))}function C(o,r,t,e,i){o.setAttribute("x",`${r}`),o.setAttribute("y",`${t}`),o.setAttribute("width",`${e}`),o.setAttribute("height",`${i}`)}var y=require("three"),j=require("@tweenjs/tween.js");var Xt=require("three");var g=require("three");var Vt=require("lodash");var oe={id:"",height:.1,airHeight:0,area:0,group:"",fillColor:"#EFF4FB",strokeColor:"#ffffff",fillOpacity:1,strokeOpacity:1,doors:[],locked:!1,visible:!0,geometry:{type:"polygon",cds:[],curveCpt:[],curveIndex:[]},layerType:"",zIndex:0},M=class extends g.Object3D{constructor(t,e){super();this.context=t;s(this,"geometry");s(this,"material");s(this,"mesh");s(this,"line");s(this,"options");if(this.options=Y((0,Vt.merge)({},oe,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 g.Color(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 g.Color(i)}),this.addEventListener("change-strokeOpacity",({value:i})=>{this.line.material.opacity=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 g.Vector3,e=new g.Box3;return e.setFromObject(this),e.getCenter(t),t}getSize(){if(this.options.geometry.type==="point")return new g.Vector3(0,0,0);let t=new g.Box3,e=new g.Vector3;return t.setFromObject(this),t.getSize(e),e}getPosition(){return this.getCenter()}init(){this.geometry=this.initGeometry(),this.material=this.initMaterial(),this.mesh=this.initMesh(),this.mesh.position.z=this.options.airHeight+this.options.height/2,this.mesh.castShadow=!0,this.add(this.mesh),this.line=this.createBorder(),this.add(this.line)}initGeometry(){let t=wt(this.options.geometry.cds[0],this.options.geometry.cds.slice(1));return new g.ExtrudeGeometry(t,{steps:1,bevelEnabled:!1,depth:this.options.height,curveSegments:4})}initMaterial(){return new g.MeshStandardMaterial({color:this.options.fillColor,roughness:1,transparent:!0,opacity:this.options.fillOpacity,depthWrite:!0})}initLineMaterial(){return new g.LineBasicMaterial({color:this.options.strokeColor,opacity:this.options.strokeOpacity,transparent:!0,depthWrite:!0})}initMesh(){return new g.Mesh(this.geometry,this.material)}createBorder(){let t=this.initLineMaterial(),e=new g.EdgesGeometry(this.geometry),i=new g.LineSegments(e,t);return i.position.z=this.options.airHeight+this.options.height/2,i}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(){F(this),this.clear()}};var G=require("three");var N=class extends G.Object3D{constructor(){super();s(this,"directionalLight");s(this,"plane");s(this,"basicOpacity",.39);this.directionalLight=this.initLight(),this.initPlane()}initLight(){let t=Lt(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 G.Color(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 G.PlaneGeometry(t,e),n=new G.ShadowMaterial({transparent:!0,opacity:0,side:G.DoubleSide}),a=new G.Mesh(i,n);return a.receiveShadow=!0,a.position.z=-5,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(){F(this,!0)}};var zt=require("three"),It=require("lodash");var V=require("three");var J=class extends V.EventDispatcher{constructor(t){super();this.context=t;s(this,"div");s(this,"element");s(this,"position",new V.Vector3);s(this,"onUpdate",()=>{let t=this.getPosition(),{clientWidth:e,clientHeight:i}=this.context.container,{x:n,y:a}=x(t,this.context.camera,e,i);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}unBindElement(){this.element=void 0}setVisible(t,e="block"){this.div.style.display=t?e:"none"}setOpacity(t){this.div.style.opacity=`${t}`}getPosition(){return this.element?typeof this.element.getPosition=="function"?this.element.getPosition():new V.Box3().setFromObject(this.element).getCenter(new V.Vector3):this.position}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 re={text:"",level:1,collision_enable:!0,opacity:1,id:""},U=class extends zt.Object3D{constructor(t,e){super();this.context=t;s(this,"textDiv");s(this,"img");s(this,"overlay");s(this,"options");s(this,"_changePosition",()=>{this.overlay.div.style.transform=`translate3d(-50%, ${this.options.icon?"-100%":"-50%"}, 0)`});this.options=Y((0,It.merge)({},re,e),this),this.overlay=new J(this.context),this.overlay.bindElement(this),this._changePosition(),this.registryEvent(),this.initDiv(),this.addEventListener("change-icon",({value:i})=>{i?this.img?this.img.setAttribute("src",i):this.overlay.div.appendChild(this.initIcon()):(this.img&&this.overlay.div.removeChild(this.img),this.img=void 0)}),this.addEventListener("change-text",({value:i})=>{this.overlay.div.removeChild(this.textDiv),this.overlay.div.appendChild(this.initText())}),this.addEventListener("change-opacity",({value:i})=>{this.overlay.setOpacity(i)})}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),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`,this.img=t,t}registryEvent(){this.context.addEventListener("update",this._changePosition)}unRegistryEvent(){this.context.removeEventListener("update",this._changePosition)}setVisible(t){this.overlay.setVisible(t,"flex")}getBox(){return this.overlay.div.getBoundingClientRect()}isContain(t,e){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()}};var D=require("three");var ut=require("three");var $t=require("three");var z=class extends $t.Object3D{constructor(t){super();this.context=t}dispose(){F(this),this.clear()}};var tt=class extends z{constructor(t){super(t);s(this,"graphicMap",new Map)}getCenter(){return new ut.Box3().setFromObject(this).getCenter(new ut.Vector3)}createGraphic(t){let e=new M(this.context,t);return this.add(e),this.graphicMap.set(t.id,e),e}getGraphicByRaycaster(t){let e={distance:1e4,graphic:null,position:null},i=this.children.reduce((n,a)=>{if(a instanceof M){let c=a.raycast(t);if(c){let{distance:h}=c;if(h<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}}};var et=class extends z{constructor(t){super(t);s(this,"pois",[]);s(this,"onUpdate",()=>{this.collisionDetection()});this.registryEvent()}clear(){return super.clear(),this.pois=[],this}createPoi(t){let e=new U(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)),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 U&&n.isContain(t,e))}collisionDetection(){let t=[];this.pois.forEach((e,i)=>{e.setVisible(!0);let{left:n,right:a,top:c,bottom:h}=e.getBox();if(i===0){t.push({left:n,right:a,top:c,bottom:h});return}let p=t.some(l=>{let v=a<l.left||n>l.right,f=c>l.bottom||h<l.top;return v||f});e.setVisible(p)})}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}dispose(){this.pois.forEach(t=>t.dispose()),this.pois.length=0,super.dispose(),this.unRegistryEvent()}};var P=require("three"),Kt=require("@mars3d/heatmap.js"),T=require("@turf/turf");var it=class extends P.Object3D{constructor(t){super();this.context=t;s(this,"heatmap");s(this,"div");s(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=(0,Kt.create)(lt({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 P.PlaneGeometry(t,e),n=new P.Texture(this.div.firstChild);n.needsUpdate=!0;let a=new P.MeshBasicMaterial({transparent:!0,side:P.DoubleSide,map:n});a.needsUpdate=!0,this.plane=new P.Mesh(i,a),this.add(this.plane)}getTransMatrix({x:t,y:e}){return new P.Matrix3().makeScale(1,-1).multiply(new P.Matrix3().makeTranslation(0-t,0-e))}transformData(t,e){let i=this.getTransMatrix(e);return{data:t.data.map(a=>{let c=new P.Vector2(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=(0,T.featureCollection)(t.data.map(p=>(0,T.point)([p.x,p.y]))),i=(0,T.bbox)(e),n=i[2]-i[0],a=i[3]-i[1],c={x:i[0],y:i[3]},h=(0,T.center)(e);return{width:n,height:a,leftTop:c,center:h.geometry.coordinates}}dispose(){this.div=null,this.heatmap=void 0}};var nt=class extends D.Object3D{constructor(t){super();this.context=t;s(this,"graphicLayer");s(this,"poiLayer");s(this,"grounds",new Set);s(this,"shadow",new N);s(this,"heatmap");s(this,"groundUpper",new D.Object3D);this.graphicLayer=new tt(this.context),this.poiLayer=new et(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))})}get hasElement(){return!!(this.grounds.size||this.graphicLayer.children.length)}getCenter(){return new D.Box3().setFromObject(this.groundUpper).getCenter(new D.Vector3)}addShadow(){let t=new D.Box3().setFromObject(this.groundUpper),e=t.getCenter(new D.Vector3),i=t.getSize(new D.Vector3);this.shadow.setPosition(e),this.shadow.changeLightCamera(i),this.add(this.shadow)}addGraphic(t){return this.graphicLayer.createGraphic(t)}addPoi(t){return this.poiLayer.createPoi(t)}addHeatmap(t){this.heatmap||(this.heatmap=new it(this.context),this.add(this.heatmap)),this.heatmap.loadData(t);let e=new D.Box3().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()}};var gt=require("three");var S=class extends gt.EventDispatcher{constructor(t){super();this.context=t;s(this,"points",[]);s(this,"svg");s(this,"enable",!0);this.svg=St(`${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:h}=i.domElement,p=n/c*2-1,l=1-a/h*2;return new gt.Vector3(p,l,0).unproject(e)}getSvgCoordinate(t){let{camera:e,container:i}=this.context;return x(t,e,i.clientWidth,i.clientHeight)}dispose(){this.context.container.removeChild(this.svg),this.svg=null}};var ot=class extends S{constructor(t){super(t);this.context=t;s(this,"circles");s(this,"line");s(this,"onUpdate",()=>{if(this.points[0]){let t=this.getSvgCoordinate(this.points[0]);A(this.circles[0],t.x,t.y),L(this.line,t)}if(this.points[1]){let t=this.getSvgCoordinate(this.points[1]);A(this.circles[1],t.x,t.y),L(this.line,void 0,t)}});s(this,"onPointermove",t=>{this.points.length===1&&(this.line.style.display="block",L(this.line,void 0,{x:t.offsetX,y:t.offsetY}))});s(this,"onPointerleave",()=>{this.points[1]||(this.line.style.display="none")});s(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];A(a,i,n),this.points.length||L(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=Q(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(O(i-t,2)+O(n-e,2))}dispose(){super.dispose(),this.unRegistryEvent(),this.line=null,this.circles=[]}};var rt=class extends S{constructor(t){super(t);s(this,"circles",[]);s(this,"lines",[]);s(this,"isClose",!1);s(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&&L(this.lines[e-1],void 0,i),this.lines[e]&&L(this.lines[e],i)})});s(this,"onPointermove",t=>{!this.lastLine||this.isClose||(this.lastLine.style.display="block",L(this.lastLine,void 0,{x:t.offsetX,y:t.offsetY}))});s(this,"onPointerleave",()=>{this.isClose||(this.lastLine.style.display="none")});s(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:h}}=this.context.config.svg;if(!this.isClose){let p=K(c,a);A(p,i,n),this.addCircle(p)}if(this.lines.length&&L(this.lastLine,void 0,{x:i,y:n}),!this.isClose){let p=Q(h);L(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"),a=+i.getAttribute("cy");return Math.sqrt(O(t-n,2)+O(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=[]}};var Ut=require("three");var Ft=class extends S{constructor(t){super(t);this.context=t;s(this,"rect");s(this,"cornerRect",[]);s(this,"centerRect",[]);s(this,"graphic");s(this,"onUpdate",()=>{if(this.graphic){let t=new Ut.Box3().setFromObject(this.graphic),{camera:e,container:{clientWidth:i,clientHeight:n}}=this.context,{min:a,max:c}=t,h=x(a,e,i,n),p=x(c,e,i,n);C(this.rect,h.x,p.y,Math.abs(p.x-h.x),Math.abs(p.y-h.y));let{x:l,y:v}=h,{x:f,y:d}=p,m=5,b=[{x:l-m,y:d-m},{x:f-m,y:d-m},{x:l-m,y:v-m},{x:f-m,y:v-m}];for(let w=0;w<b.length;w++)C(this.cornerRect[w],b[w].x,b[w].y,m*2,m*2);let E=4,X=(l+f)/2,ht=(v+d)/2,_=[{x:X-E,y:d-E},{x:l-E,y:ht-E},{x:f-E,y:ht-E},{x:X-E,y:v-E}];for(let w=0;w<_.length;w++)C(this.centerRect[w],_[w].x,_[w].y,E*2,E*2)}else{C(this.rect,0,0,0,0);for(let t=0;t<this.cornerRect.length;t++)C(this.cornerRect[t],0,0,0,0),C(this.centerRect[t],0,0,0,0)}});let{config:{svg:{line:e}}}=t;this.rect=H(e.stroke,"transparent"),this.svg.appendChild(this.rect);for(let i=0;i<4;i++)this.cornerRect[i]=H(e.stroke,"#ffffff"),this.centerRect[i]=H(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=[]}};var jt=require("three");var ft=class extends S{constructor(t){super(t);s(this,"startPoint");s(this,"endPoint");s(this,"rect");s(this,"frustum",new jt.Frustum);s(this,"onPointerDown",t=>{if(!this.enable)return;let e=this.getIntersectByPointerEvent(t);e&&(this.startPoint=e),this.endPoint=void 0});s(this,"onPointerMove",t=>{if(!this.enable||!this.startPoint)return;let e=this.getIntersectByPointerEvent(t);e&&(this.endPoint=e)});s(this,"onPointerUp",t=>{if(!this.enable)return;let e=this.getIntersectByPointerEvent(t);e&&(this.endPoint=e),this.doSelect(),this.startPoint=void 0});s(this,"onUpdate",()=>{if(this.startPoint){let t=this.getSvgCoordinate(this.startPoint),e=lt({},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);C(this.rect,i.x,i.y,n,a)}else C(this.rect,0,0,0,0)});let{config:{selectBox:{fill:e,stroke:i}}}=t;this.rect=H(i,e),this.svg.appendChild(this.rect),this.registryEvent()}setEnable(t){super.setEnable(t),C(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=x(this.startPoint,e,i,n),c=x(this.endPoint,e,i,n),h={x:Math.min(a.x,c.x),y:Math.min(a.y,c.y)},p={x:Math.max(a.x,c.x),y:Math.max(a.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(a=>a instanceof M&&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 d=t.getPosition();if(d){let m=x(d,n,a,c);return W(m,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,v=x(p,n,a,c),f=x(l,n,a,c);return!(!W(v,e,i)||!W(f,e,i))}dispose(){this.unRegistryEvent()}};var st=class extends Xt.EventDispatcher{constructor(t){super();this.context=t;s(this,"_list",new Set);s(this,"boxSelection");s(this,"prevPanStatus");s(this,"prevRotateStatus");s(this,"onPointerDown",t=>{let{graphics:e}=this.context.getGraphicsByDeviceXy(t.offsetX,t.offsetY),i=new Set(e.map(a=>a.options.id));this.context.getPoisByDeviceXy(t.clientX,t.clientY).forEach(a=>{var c;if(!i.has(a.options.id)){let h=((c=this.context.currentFloor)==null?void 0:c.graphicLayer.graphicMap.get(a.options.id))||null;h&&(e.push(h),i.add(a.options.id))}}),t.ctrlKey||this._list.clear(),e.forEach(a=>this._list.add(a)),this.selectEnd()});s(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)});s(this,"onKeyUp",t=>{t.key==="Control"&&(this.boxSelection.setEnable(!1),this.context.control.enablePan=!!this.prevPanStatus,this.context.control.enableRotate=!!this.prevRotateStatus)});s(this,"onBoxSelected",({list:t})=>{this._list.clear(),t.forEach(e=>{this._list.add(e)}),this.selectEnd()});this.boxSelection=new ft(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),window.addEventListener("keydown",this.onKeyDown),window.addEventListener("keyup",this.onKeyUp),this.boxSelection.addEventListener("selected",this.onBoxSelected)}unRegistryEvent(){this.context.container.removeEventListener("pointerdown",this.onPointerDown),window.removeEventListener("keydown",this.onKeyDown),window.removeEventListener("keyup",this.onKeyUp),this.boxSelection.removeEventListener("selected",this.onBoxSelected)}dispose(){this.unRegistryEvent()}};var _t=require("three");var at=class extends _t.EventDispatcher{constructor(t){super();this.context=t;s(this,"curGraphics",new Set);s(this,"timer",new R);s(this,"graphicTimerMap",new Map);s(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()});s(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 ct=class extends y.EventDispatcher{constructor(t,e){super();this.container=t;this.config=e;s(this,"scene",yt());s(this,"renderer",xt());s(this,"camera");s(this,"control");s(this,"lights",bt());s(this,"timer",new R);s(this,"tweenGroup",new j.Group);s(this,"currentFloor");s(this,"selection");s(this,"hoverHelper");s(this,"basicRatio");s(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)});s(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.clientX,t.clientY);n.length&&this.dispatchEvent({type:"poi-click",pois:n})});s(this,"onPointerover",t=>{let{graphics:e,position:i}=this.getGraphicsByDeviceXy(t.offsetX,t.offsetY),n=this.getPoisByDeviceXy(t.clientX,t.clientY);this.dispatchEvent({type:"pointer-over",graphics:e,pois:n,position:i})});s(this,"onPointermove",t=>{let{graphics:e,position:i}=this.getGraphicsByDeviceXy(t.offsetX,t.offsetY),n=this.getPoisByDeviceXy(t.clientX,t.clientY);this.dispatchEvent({type:"pointer-move",graphics:e,pois:n,position:i})});s(this,"onPointerleave",()=>{this.dispatchEvent({type:"pointer-level"})});s(this,"onSelectionSelect",({graphics:t})=>{this.dispatchEvent({type:"select-graphic",graphics:t})});s(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 st(this),this.hoverHelper=new at(this),this.registryEvent()}init(){let{clientWidth:t,clientHeight:e}=this.container;this.camera=Et(t,e),this.renderer.setSize(t,e),this.control=Pt(this.camera,this.renderer.domElement),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})})}getRatio(t=new y.Vector3(0,0,0),e=new y.Vector3(100,0,0)){let{clientWidth:i,clientHeight:n}=this.container,a=x(t,this.camera,i,n),c=x(e,this.camera,i,n);return Math.ceil(Math.sqrt(O(c.x-a.x,2)+O(c.y-a.y,2)))}changeAmbientLightColor(t){this.lights.children.forEach(e=>{e instanceof y.AmbientLight&&(e.color=new y.Color(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 y.Vector2;i.x=t/this.container.clientWidth*2-1,i.y=e/this.container.clientHeight*-2+1;let n=new y.Raycaster;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 Z(new Promise(i=>{let n={polar:this.control.getPolarAngle()},a={polar:t},c=new j.Tween(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.tweenGroup.remove(c),i(!0)}).onStart(()=>{this.control.enabled=!1}).start()}),e+500)}getCameraLookAt(){return new y.Vector3().subVectors(this.control.target,this.camera.position)}setZoom(t,e,i=500){return Z(new Promise(n=>{let a={zoom:this.camera.zoom,target:this.control.target.clone()},c=this.getCameraLookAt(),h=new j.Tween(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(h),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,h]=e,{clientWidth:p,clientHeight:l}=this.container,v=new y.Box3().setFromObject(t),{max:f,min:d}=v,m=x(f,this.camera,p,l),b=x(d,this.camera,p,l),X=new y.Box2().setFromPoints([new y.Vector2(m.x,m.y),new y.Vector2(b.x,b.y)]).getSize(new y.Vector2),ht=(p-a-h)/X.x,_=(l-n-c)/X.y,w=Math.min(ht,_),qt=new y.Vector3((f.x+d.x)/2,(f.y+d.y)/2,f.z);return this.setZoom(w*this.camera.zoom,qt,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 Z(new Promise(i=>{let n=this.camera.position.clone(),a=this.getCameraLookAt(),c=new j.Tween(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()),F(this.scene)}};var Wt=require("lodash"),Yt={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:1.2},svg:{circle:{radius:"2",fill:"#1CADFF"},line:{stroke:"#1CADFF"}},selectBox:{stroke:"#1CADFF",fill:"rgba(28, 173, 255, 0.3)"},hover:{time:500}};function Ot(o){return(0,Wt.merge)({},Yt,o)}var At=class extends Zt.EventDispatcher{constructor(t,e={}){super();this.container=t;s(this,"config");s(this,"context");s(this,"polarKeys",[]);s(this,"azimuthalKeys",[]);s(this,"svgLine");s(this,"svgPolygon");s(this,"basicZoom",1);s(this,"floorDataMap",new Map);s(this,"buildingGroundMap",new Map);s(this,"currentBuildGround",null);s(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)});s(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 ct(t,this.config),this.registryEvent(),this.context.render()}loadGraphics(p){return I(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}){let{apiDomain:l,apiPath:{floorGraphic:v},apiInfo:f}=this.config,d=`${l}${v}?brand=${t}&project=${e}&phase=${i}&building=${n}&floor=${a}&ts=${c}&resource_type_list=${h}`;return yield fetch(d,f).then(b=>b.json()).then(b=>b.data).then(b=>((b||[]).map(E=>E.info=JSON.parse(E.info)),b||[]))})}getBuildingKey({brand:t,project:e,phase:i,building:n}){return`${t}-${e}-${i}-${n}`}loadBuildingGround(a){return I(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,v=`${h}${p}?brand=${t}&project=${e}&phase=${i}&building=${n}`,f=yield fetch(v,l).then(d=>d.json()).then(d=>d.data).then(d=>{let m=(d||[])[0];return m&&(m.info=JSON.parse(m.info)),m});return this.buildingGroundMap.set(c,f),f})}getFloorKey({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}){return`${t}-${e}-${i}-${n}-${a}-${c}-${h}`}load(p){return I(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}){let l=this.getFloorKey({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h});if(this.floorDataMap.get(l))return;let[v,f]=yield Promise.all([this.loadGraphics({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}),this.loadBuildingGround({brand:t,project:e,phase:i,building:n})]);if(f){let d=mt(f.info.geometry.cds[0]);v.forEach(m=>{if(m.info.geometry.type==="polygon")m.info.geometry.cds.map(b=>{Array.isArray(b)&&b.forEach(E=>{E[0]-=d[0],E[1]-=d[1]})});else{let[b,E]=m.info.geometry.cds;m.info.geometry.cds=[b-d[0],E-d[1]]}m.info.transformToBuildingGround=!0})}return this.config.useFloorCache||this.floorDataMap.clear(),this.floorDataMap.set(l,v),v})}createFloor(t){let e=new nt(this.context);if(!t.length)return{curFloor:e,graphics:[]};let n=t.filter(p=>p.info.group==="ground").map(p=>new M(this.context,p.info));e.addGrounds(n);let a=t.filter(p=>p.info.group!=="ground"),c=new Map,h=a.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(p){return I(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}){let l=this.getFloorKey({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}),v=this.floorDataMap.get(l);if(v){let f=this.getBuildingKey({brand:t,project:e,phase:i,building:n});this.currentBuildGround=this.buildingGroundMap.get(f)||null;let d=this.createFloor(v);d?(this.context.switchFloor(d.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):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 M))||[]}createGraphicPoi(t,e){if(this.context.currentFloor){e.id===void 0&&(e.id=t.options.id);let i=this.context.currentFloor.addPoi(e),n=t.getCenter();return n.z+=t.options.height/2,i.position.copy(n),i.position.z=i.position.z+t.options.height/2,i}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 x(e,this.context.camera,i,n)}changeMapType(t,e=500){t==="2d"?this.context.setPolarAngle(0):this.context.setPolarAngle(1.2)}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 I(this,null,function*(){return this.cancelDistance(),new Promise((t,e)=>{this.changeMapType("2d",0),this.context.control.enableRotate=!1,this.svgLine=new ot(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 rt(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){return this.context.currentFloor&&this.context.currentFloor.graphicLayer.graphicMap.get(t)||null}deleteGraphic(t){this.context.currentFloor&&(this.context.currentFloor.graphicLayer.remove(t),t.dispose(),this.context.currentFloor.graphicLayer.graphicMap.delete(t.options.id))}createGraphicByOptions(t){var e;if(!t.transformToBuildingGround&&this.currentBuildGround){let i=mt(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())}dispose(){this.context.dispose(),Mt(),Dt(),this.unRegistryEvent()}};
|
|
1
|
+
"use strict";var lt=Object.defineProperty,Jt=Object.defineProperties,te=Object.getOwnPropertyDescriptor,ee=Object.getOwnPropertyDescriptors,ie=Object.getOwnPropertyNames,Rt=Object.getOwnPropertySymbols;var kt=Object.prototype.hasOwnProperty,ne=Object.prototype.propertyIsEnumerable;var C=Math.pow,vt=(o,s,t)=>s in o?lt(o,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):o[s]=t,R=(o,s)=>{for(var t in s||(s={}))kt.call(s,t)&&vt(o,t,s[t]);if(Rt)for(var t of Rt(s))ne.call(s,t)&&vt(o,t,s[t]);return o},yt=(o,s)=>Jt(o,ee(s));var oe=(o,s)=>{for(var t in s)lt(o,t,{get:s[t],enumerable:!0})},re=(o,s,t,e)=>{if(s&&typeof s=="object"||typeof s=="function")for(let i of ie(s))!kt.call(o,i)&&i!==t&<(o,i,{get:()=>s[i],enumerable:!(e=te(s,i))||e.enumerable});return o};var se=o=>re(lt({},"__esModule",{value:!0}),o);var r=(o,s,t)=>(vt(o,typeof s!="symbol"?s+"":s,t),t);var $=(o,s,t)=>new Promise((e,i)=>{var n=h=>{try{c(t.next(h))}catch(p){i(p)}},a=h=>{try{c(t.throw(h))}catch(p){i(p)}},c=h=>h.done?e(h.value):Promise.resolve(h.value).then(n,a);c((t=t.apply(o,s)).next())});var pe={};oe(pe,{BMap:()=>Tt,BaseSvg:()=>F,Context:()=>ht,Floor:()=>ot,Graphic:()=>D,GraphicLayer:()=>et,HeatmapElement:()=>nt,HoverHelper:()=>ct,Layer:()=>I,Overlay:()=>tt,Poi:()=>j,PoiLayer:()=>it,SelectBox:()=>Ot,Selection:()=>at,Shadow:()=>J,SvgLine:()=>rt,SvgPolygon:()=>st,Timer:()=>k,clearCanvas:()=>St,clearTextTexture:()=>Dt,createCanvas:()=>Ht,createCircle:()=>U,createLine:()=>N,createRect:()=>H,createSvg:()=>Ft,createSvgElement:()=>Q,defaultConfig:()=>Zt,dispose:()=>O,getCenter:()=>mt,getConfig:()=>At,getTextureByText:()=>ae,hasChinese:()=>Gt,initCamera:()=>Et,initCanvas:()=>zt,initControl:()=>wt,initDirectionalLight:()=>Lt,initLight:()=>Pt,initRenderer:()=>bt,initScene:()=>xt,initShape:()=>Ct,isContain:()=>Y,proxyOptions:()=>q,setCirclePosition:()=>A,setLineStartEnd:()=>L,setRectPosition:()=>G,timeoutPromise:()=>Z,vector3ToDevice:()=>x});module.exports=se(pe);var Qt=require("three");var k=class{constructor(){r(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()}};var f=require("three"),Bt=require("three/examples/jsm/controls/MapControls");function xt(){let o=new f.Scene;return o.background=new f.Color(16777215),o}function bt(){let o=new f.WebGLRenderer({antialias:!0});return o.setClearColor(16777215),o.setPixelRatio(window.devicePixelRatio),o.shadowMap.enabled=!0,o.shadowMap.autoUpdate=!0,o.shadowMap.type=f.PCFSoftShadowMap,o}function Et(o,s){let t=new f.OrthographicCamera(-o/2,o/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 Pt(){let o=new f.Group,s=new f.HemisphereLight(16777215,15658734,1);s.intensity=1,s.position.set(0,0,10),s.up.set(0,0,1),o.add(s);let t=new f.AmbientLight(16777215);return o.add(t),o}function wt(o,s){let t=new Bt.MapControls(o,s);return t.enableDamping=!1,t.maxPolarAngle=0,t.minPolarAngle=0,t}function Ct(o,s=[]){let t=new f.Shape(o.map(e=>new f.Vector2(...e)));return s.length&&s.forEach(e=>{var i=new f.Path(e.map(n=>new f.Vector2(...n)));t.holes.push(i)}),t}function Lt(o=16777215,s=1){let t=new f.DirectionalLight(o,s);return t.castShadow=!0,t.shadow.radius=8,t.shadow.bias=-.001,t.shadow.mapSize.set(256,256),t.shadow.camera.left=-200,t.shadow.camera.right=200,t.shadow.camera.top=200,t.shadow.camera.bottom=-200,t}function O(o,s){var t;if(s&&o.children&&o.children.length&&o.children.forEach(e=>{O(e,s)}),o.isMesh){let e=o;e.geometry&&e.geometry.dispose(),e.material&&(Array.isArray(e.material)?e.material.forEach(i=>{i.dispose()}):e.material.dispose())}o.isLight&&((t=o.dispose)==null||t.call(o))}function Gt(o){return/[\u4E00-\u9FA5]+/g.test(o)}var z=require("three");var dt=new Map;function zt(){let o=document.createElement("canvas");o.width=1024,o.height=64;let s=o.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:o,ctx:s}}var Mt,B;function Ht(){if(!Mt){let{canvas:o,ctx:s}=zt();Mt=o,B=s}}function ae(o){if(dt.has(o))return dt.get(o);Ht(),B.clearRect(0,0,1024,64);let s=Gt(o)?4:8;B.strokeText(o,2,s),B.fillText(o,2,s);let t=Math.ceil(B.measureText(o).width);t=t%2===0?t:t+1,t+=2;let e=B.getImageData(0,0,t,64),i=new z.DataTexture(Uint8Array.from(e.data),t,64,z.RGBAFormat);return i.flipY=!0,i.minFilter=z.LinearFilter,i.magFilter=z.LinearFilter,dt.set(o,i),i}function Dt(){dt.clear()}function St(){B=null,Mt=null}var K=require("@turf/turf");function x(o,s,t,e){let i=o.clone().project(s),n=t/2,a=e/2,c=Math.round(i.x*n+n),h=Math.round(-i.y*a+a);return{x:c,y:h}}function mt(o){let s=(0,K.featureCollection)(o.map(e=>(0,K.point)(e)));return(0,K.center)(s).geometry.coordinates}function Y(o,s,t){return o.x>=s.x&&o.x<=t.x&&o.y>=s.y&&o.y<=t.y}function q(o,s){return new Proxy(o,{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 Z(o,s){return Promise.race([o,new Promise((t,e)=>{setTimeout(()=>e(new Error("Promise timeout")),s)})])}function Q(o){return document.createElementNS("http://www.w3.org/2000/svg",o)}function Ft(o,s){let t=Q("svg");return t.setAttribute("width",o),t.setAttribute("height",s),t.style.cssText="position: absolute; left: 0; top: 0; pointer-events: none;",t}function U(o="2",s){let t=Q("circle");return t.setAttribute("r",o),t.setAttribute("fill",s),t}function N(o){let s=Q("line");return s.setAttribute("stroke",o),s}function H(o,s){let t=Q("rect");return t.setAttribute("stroke",o),t.setAttribute("fill",s),t}function A(o,s,t){o.setAttribute("cx",`${s}`),o.setAttribute("cy",`${t}`)}function L(o,s,t){s&&(o.setAttribute("x1",`${s.x}`),o.setAttribute("y1",`${s.y}`)),t&&(o.setAttribute("x2",`${t.x}`),o.setAttribute("y2",`${t.y}`))}function G(o,s,t,e,i){o.setAttribute("x",`${s}`),o.setAttribute("y",`${t}`),o.setAttribute("width",`${e}`),o.setAttribute("height",`${i}`)}var y=require("three"),X=require("@tweenjs/tween.js");var Wt=require("three");var v=require("three");var Vt=require("lodash");var ce={id:"",height:.1,airHeight:0,area:0,group:"",fillColor:"#EFF4FB",strokeColor:"#ffffff",fillOpacity:1,strokeOpacity:1,doors:[],locked:!1,visible:!0,geometry:{type:"polygon",cds:[],curveCpt:[],curveIndex:[]},layerType:"",zIndex:0},D=class extends v.Object3D{constructor(t,e){super();this.context=t;r(this,"geometry");r(this,"material");r(this,"mesh");r(this,"line");r(this,"options");if(this.options=q((0,Vt.merge)({},ce,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 v.Color(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 v.Color(i)}),this.addEventListener("change-strokeOpacity",({value:i})=>{this.line.material.opacity=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 v.Vector3,e=new v.Box3;return e.setFromObject(this),e.getCenter(t),t}getSize(){if(this.options.geometry.type==="point")return new v.Vector3(0,0,0);let t=new v.Box3,e=new v.Vector3;return t.setFromObject(this),t.getSize(e),e}getPosition(){return this.getCenter()}init(){this.geometry=this.initGeometry(),this.material=this.initMaterial(),this.mesh=this.initMesh(),this.mesh.position.z=this.options.airHeight+this.options.height/2,this.mesh.castShadow=!0,this.add(this.mesh),this.line=this.createBorder(),this.add(this.line)}initGeometry(){let t=Ct(this.options.geometry.cds[0],this.options.geometry.cds.slice(1));return new v.ExtrudeGeometry(t,{steps:1,bevelEnabled:!1,depth:this.options.height,curveSegments:4})}initMaterial(){return new v.MeshStandardMaterial({color:this.options.fillColor,roughness:1,transparent:!0,opacity:this.options.fillOpacity,depthWrite:!0})}initLineMaterial(){return new v.LineBasicMaterial({color:this.options.strokeColor,opacity:this.options.strokeOpacity,transparent:!0,depthWrite:!0})}initMesh(){return new v.Mesh(this.geometry,this.material)}createBorder(){let t=this.initLineMaterial(),e=new v.EdgesGeometry(this.geometry),i=new v.LineSegments(e,t);return i.position.z=this.options.airHeight+this.options.height/2,i}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(){O(this),this.clear()}};var M=require("three");var J=class extends M.Object3D{constructor(){super();r(this,"directionalLight");r(this,"plane");r(this,"basicOpacity",.39);this.directionalLight=this.initLight(),this.initPlane()}initLight(){let t=Lt(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 M.Color(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 M.PlaneGeometry(t,e),n=new M.ShadowMaterial({transparent:!0,opacity:0,side:M.DoubleSide}),a=new M.Mesh(i,n);return a.receiveShadow=!0,a.position.z=-5,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(){O(this,!0)}};var It=require("three"),$t=require("lodash");var V=require("three");var tt=class extends V.EventDispatcher{constructor(t){super();this.context=t;r(this,"div");r(this,"element");r(this,"position",new V.Vector3);r(this,"clientPos",{x:0,y:0});r(this,"visible",!0);r(this,"onUpdate",()=>{let t=this.getPosition(),{width:e,height:i}=this.context.clientSize,{x:n,y:a}=x(t,this.context.camera,e,i);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 V.Box3().setFromObject(this.element).getCenter(new V.Vector3):this.position}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 he={text:"",level:1,collision_enable:!0,opacity:1,id:"",position:{x:0,y:0,z:0}},j=class extends It.Object3D{constructor(t,e){var i,n,a;super();this.context=t;r(this,"textDiv");r(this,"img");r(this,"overlay");r(this,"options");r(this,"size",{width:0,height:0});r(this,"_changePosition",()=>{this.overlay.div.style.transform=`translate3d(-50%, ${this.options.icon?"-100%":"-50%"}, 0)`});this.options=q((0,$t.merge)({},he,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 tt(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())})}resetSize(){let{width:t,height:e}=this.overlay.div.getBoundingClientRect();this.size={width:t,height:e},this._changePosition()}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()}};var S=require("three");var ut=require("three");var Kt=require("three");var I=class extends Kt.Object3D{constructor(t){super();this.context=t}dispose(){O(this),this.clear()}};var et=class extends I{constructor(t){super(t);r(this,"graphicMap",new Map)}getCenter(){return new ut.Box3().setFromObject(this).getCenter(new ut.Vector3)}createGraphic(t){let e=new D(this.context,t);return this.add(e),this.graphicMap.set(t.id,e),e}getGraphicByRaycaster(t){let e={distance:1e4,graphic:null,position:null},i=this.children.reduce((n,a)=>{if(a instanceof D){let c=a.raycast(t);if(c){let{distance:h}=c;if(h<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}}};var Ut=require("lodash");var it=class extends I{constructor(t){super(t);r(this,"pois",[]);r(this,"debounceCollisionDetection");r(this,"onUpdate",()=>{Promise.resolve().then(()=>{this.collisionDetection()})});this.registryEvent(),this.debounceCollisionDetection=(0,Ut.debounce)(this.collisionDetection,10)}clear(){return super.clear(),this.pois=[],this}createPoi(t){let e=new j(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 j&&n.isContain(t,e))}collisionDetection(){let{clientSize:{width:t,height:e}}=this.context,i=[];this.pois.filter(a=>{let{x:c,y:h}=a.clientPos;return!(c<0||c>t||h<0||h>e)}).forEach((a,c)=>{let{left:h,right:p,top:l,bottom:m}=a.getBox();if(c===0){i.push({left:h,right:p,top:l,bottom:m});return}let g=i.some(d=>p<d.right&&p>d.left||h>d.left&&h<d.right||h===d.left&&p===d.right?m<=d.bottom&&m>d.top||l>=d.top&&l<d.bottom:!1);a.setVisible(!g),i.push({left:h,right:p,top:l,bottom:m})})}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}dispose(){this.pois.forEach(t=>t.dispose()),this.pois.length=0,this.debounceCollisionDetection=()=>{},super.dispose(),this.unRegistryEvent()}};var P=require("three"),jt=require("@mars3d/heatmap.js"),T=require("@turf/turf");var nt=class extends P.Object3D{constructor(t){super();this.context=t;r(this,"heatmap");r(this,"div");r(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=(0,jt.create)(R({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 P.PlaneGeometry(t,e),n=new P.Texture(this.div.firstChild);n.needsUpdate=!0;let a=new P.MeshBasicMaterial({transparent:!0,side:P.DoubleSide,map:n});a.needsUpdate=!0,this.plane=new P.Mesh(i,a),this.add(this.plane)}getTransMatrix({x:t,y:e}){return new P.Matrix3().makeScale(1,-1).multiply(new P.Matrix3().makeTranslation(0-t,0-e))}transformData(t,e){let i=this.getTransMatrix(e);return{data:t.data.map(a=>{let c=new P.Vector2(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=(0,T.featureCollection)(t.data.map(p=>(0,T.point)([p.x,p.y]))),i=(0,T.bbox)(e),n=i[2]-i[0],a=i[3]-i[1],c={x:i[0],y:i[3]},h=(0,T.center)(e);return{width:n,height:a,leftTop:c,center:h.geometry.coordinates}}dispose(){this.div=null,this.heatmap=void 0}};var ot=class extends S.Object3D{constructor(t){super();this.context=t;r(this,"graphicLayer");r(this,"poiLayer");r(this,"grounds",new Set);r(this,"shadow",new J);r(this,"heatmap");r(this,"groundUpper",new S.Object3D);this.graphicLayer=new et(this.context),this.poiLayer=new it(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))})}get hasElement(){return!!(this.grounds.size||this.graphicLayer.children.length)}getCenter(){return new S.Box3().setFromObject(this.groundUpper).getCenter(new S.Vector3)}addShadow(){let t=new S.Box3().setFromObject(this.groundUpper),e=t.getCenter(new S.Vector3),i=t.getSize(new S.Vector3);this.shadow.setPosition(e),this.shadow.changeLightCamera(i),this.add(this.shadow)}addGraphic(t){return this.graphicLayer.createGraphic(t)}addPoi(t){return this.poiLayer.createPoi(t)}addHeatmap(t){this.heatmap||(this.heatmap=new nt(this.context),this.add(this.heatmap)),this.heatmap.loadData(t);let e=new S.Box3().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()}};var gt=require("three");var F=class extends gt.EventDispatcher{constructor(t){super();this.context=t;r(this,"points",[]);r(this,"svg");r(this,"enable",!0);this.svg=Ft(`${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:h}=i.domElement,p=n/c*2-1,l=1-a/h*2;return new gt.Vector3(p,l,0).unproject(e)}getSvgCoordinate(t){let{camera:e,container:i}=this.context;return x(t,e,i.clientWidth,i.clientHeight)}dispose(){this.context.container.removeChild(this.svg),this.svg=null}};var rt=class extends F{constructor(t){super(t);this.context=t;r(this,"circles");r(this,"line");r(this,"onUpdate",()=>{if(this.points[0]){let t=this.getSvgCoordinate(this.points[0]);A(this.circles[0],t.x,t.y),L(this.line,t)}if(this.points[1]){let t=this.getSvgCoordinate(this.points[1]);A(this.circles[1],t.x,t.y),L(this.line,void 0,t)}});r(this,"onPointermove",t=>{this.points.length===1&&(this.line.style.display="block",L(this.line,void 0,{x:t.offsetX,y:t.offsetY}))});r(this,"onPointerleave",()=>{this.points[1]||(this.line.style.display="none")});r(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];A(a,i,n),this.points.length||L(this.line,{x:i,y:n},{x:i,y:n}),this.addPoint(e)}});let{config:{svg:{circle:e,line:i}}}=t;this.circles=[U(e.radius,e.fill),U(e.radius,e.fill)],this.line=N(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(C(i-t,2)+C(n-e,2))}dispose(){super.dispose(),this.unRegistryEvent(),this.line=null,this.circles=[]}};var st=class extends F{constructor(t){super(t);r(this,"circles",[]);r(this,"lines",[]);r(this,"isClose",!1);r(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&&L(this.lines[e-1],void 0,i),this.lines[e]&&L(this.lines[e],i)})});r(this,"onPointermove",t=>{!this.lastLine||this.isClose||(this.lastLine.style.display="block",L(this.lastLine,void 0,{x:t.offsetX,y:t.offsetY}))});r(this,"onPointerleave",()=>{this.isClose||(this.lastLine.style.display="none")});r(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:h}}=this.context.config.svg;if(!this.isClose){let p=U(c,a);A(p,i,n),this.addCircle(p)}if(this.lines.length&&L(this.lastLine,void 0,{x:i,y:n}),!this.isClose){let p=N(h);L(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"),a=+i.getAttribute("cy");return Math.sqrt(C(t-n,2)+C(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=[]}};var Xt=require("three");var Ot=class extends F{constructor(t){super(t);this.context=t;r(this,"rect");r(this,"cornerRect",[]);r(this,"centerRect",[]);r(this,"graphic");r(this,"onUpdate",()=>{if(this.graphic){let t=new Xt.Box3().setFromObject(this.graphic),{camera:e,container:{clientWidth:i,clientHeight:n}}=this.context,{min:a,max:c}=t,h=x(a,e,i,n),p=x(c,e,i,n);G(this.rect,h.x,p.y,Math.abs(p.x-h.x),Math.abs(p.y-h.y));let{x:l,y:m}=h,{x:g,y:d}=p,u=5,b=[{x:l-u,y:d-u},{x:g-u,y:d-u},{x:l-u,y:m-u},{x:g-u,y:m-u}];for(let w=0;w<b.length;w++)G(this.cornerRect[w],b[w].x,b[w].y,u*2,u*2);let E=4,_=(l+g)/2,pt=(m+d)/2,W=[{x:_-E,y:d-E},{x:l-E,y:pt-E},{x:g-E,y:pt-E},{x:_-E,y:m-E}];for(let w=0;w<W.length;w++)G(this.centerRect[w],W[w].x,W[w].y,E*2,E*2)}else{G(this.rect,0,0,0,0);for(let t=0;t<this.cornerRect.length;t++)G(this.cornerRect[t],0,0,0,0),G(this.centerRect[t],0,0,0,0)}});let{config:{svg:{line:e}}}=t;this.rect=H(e.stroke,"transparent"),this.svg.appendChild(this.rect);for(let i=0;i<4;i++)this.cornerRect[i]=H(e.stroke,"#ffffff"),this.centerRect[i]=H(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=[]}};var _t=require("three");var ft=class extends F{constructor(t){super(t);r(this,"startPoint");r(this,"endPoint");r(this,"rect");r(this,"frustum",new _t.Frustum);r(this,"onPointerDown",t=>{if(!this.enable)return;let e=this.getIntersectByPointerEvent(t);e&&(this.startPoint=e),this.endPoint=void 0});r(this,"onPointerMove",t=>{if(!this.enable||!this.startPoint)return;let e=this.getIntersectByPointerEvent(t);e&&(this.endPoint=e)});r(this,"onPointerUp",t=>{if(!this.enable)return;let e=this.getIntersectByPointerEvent(t);e&&(this.endPoint=e),this.doSelect(),this.startPoint=void 0});r(this,"onUpdate",()=>{if(this.startPoint){let t=this.getSvgCoordinate(this.startPoint),e=R({},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);G(this.rect,i.x,i.y,n,a)}else G(this.rect,0,0,0,0)});let{config:{selectBox:{fill:e,stroke:i}}}=t;this.rect=H(i,e),this.svg.appendChild(this.rect),this.registryEvent()}setEnable(t){super.setEnable(t),G(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=x(this.startPoint,e,i,n),c=x(this.endPoint,e,i,n),h={x:Math.min(a.x,c.x),y:Math.min(a.y,c.y)},p={x:Math.max(a.x,c.x),y:Math.max(a.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(a=>a instanceof D&&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 d=t.getPosition();if(d){let u=x(d,n,a,c);return Y(u,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,m=x(p,n,a,c),g=x(l,n,a,c);return!(!Y(m,e,i)||!Y(g,e,i))}dispose(){this.unRegistryEvent()}};var at=class extends Wt.EventDispatcher{constructor(t){super();this.context=t;r(this,"_list",new Set);r(this,"boxSelection");r(this,"prevPanStatus");r(this,"prevRotateStatus");r(this,"downPoint",null);r(this,"onPointerDown",t=>{this.downPoint={x:t.offsetX,y:t.offsetY}});r(this,"onPointerUp",t=>{if(!this.downPoint)return;let{offsetX:e,offsetY:i}=t,{x:n,y:a}=this.downPoint;if(Math.sqrt(C(n-e,2)+C(a-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 m;if(!h.has(l.options.id)){let g=((m=this.context.currentFloor)==null?void 0:m.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});r(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)});r(this,"onKeyUp",t=>{t.key==="Control"&&(this.boxSelection.setEnable(!1),this.context.control.enablePan=!!this.prevPanStatus,this.context.control.enableRotate=!!this.prevRotateStatus)});r(this,"onBoxSelected",({list:t})=>{this._list.clear(),t.forEach(e=>{this._list.add(e)}),this.selectEnd()});this.boxSelection=new ft(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()}};var Yt=require("three");var ct=class extends Yt.EventDispatcher{constructor(t){super();this.context=t;r(this,"curGraphics",new Set);r(this,"timer",new k);r(this,"graphicTimerMap",new Map);r(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()});r(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 ht=class extends y.EventDispatcher{constructor(t,e){super();this.container=t;this.config=e;r(this,"scene",xt());r(this,"renderer",bt());r(this,"camera");r(this,"control");r(this,"lights",Pt());r(this,"timer",new k);r(this,"tweenGroup",new X.Group);r(this,"currentFloor");r(this,"selection");r(this,"hoverHelper");r(this,"basicRatio");r(this,"clientSize",{width:0,height:0});r(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)});r(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}),console.log("onClick",t.offsetX,t.offsetY);let n=this.getPoisByDeviceXy(t.offsetX,t.offsetY);n.length&&this.dispatchEvent({type:"poi-click",pois:n})});r(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})});r(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})});r(this,"onPointerleave",()=>{this.dispatchEvent({type:"pointer-level"})});r(this,"onSelectionSelect",({graphics:t})=>{this.dispatchEvent({type:"select-graphic",graphics:t})});r(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 at(this),this.hoverHelper=new ct(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=Et(t,e),this.renderer.setSize(t,e),this.control=wt(this.camera,this.renderer.domElement),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 y.Vector3(0,0,0),e=new y.Vector3(100,0,0)){let{clientWidth:i,clientHeight:n}=this.container,a=x(t,this.camera,i,n),c=x(e,this.camera,i,n);return Math.ceil(Math.sqrt(C(c.x-a.x,2)+C(c.y-a.y,2)))}changeAmbientLightColor(t){this.lights.children.forEach(e=>{e instanceof y.AmbientLight&&(e.color=new y.Color(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 y.Vector2;i.x=t/this.container.clientWidth*2-1,i.y=e/this.container.clientHeight*-2+1;let n=new y.Raycaster;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 Z(new Promise(i=>{let n={polar:this.control.getPolarAngle()},a={polar:t},c=new X.Tween(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.tweenGroup.remove(c),i(!0)}).onStart(()=>{this.control.enabled=!1}).start()}),e+500)}getCameraLookAt(){return new y.Vector3().subVectors(this.control.target,this.camera.position)}setZoom(t,e,i=500){return Z(new Promise(n=>{let a={zoom:this.camera.zoom,target:this.control.target.clone()},c=this.getCameraLookAt(),h=new X.Tween(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(h),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,h]=e,{clientWidth:p,clientHeight:l}=this.container,m=new y.Box3().setFromObject(t),{max:g,min:d}=m,u=x(g,this.camera,p,l),b=x(d,this.camera,p,l),_=new y.Box2().setFromPoints([new y.Vector2(u.x,u.y),new y.Vector2(b.x,b.y)]).getSize(new y.Vector2),pt=(p-a-h)/_.x,W=(l-n-c)/_.y,w=Math.min(pt,W),Nt=new y.Vector3((g.x+d.x)/2,(g.y+d.y)/2,g.z);return this.setZoom(w*this.camera.zoom,Nt,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 Z(new Promise(i=>{let n=this.camera.position.clone(),a=this.getCameraLookAt(),c=new X.Tween(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()),O(this.scene)}};var qt=require("lodash"),Zt={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:1.2},svg:{circle:{radius:"2",fill:"#1CADFF"},line:{stroke:"#1CADFF"}},selectBox:{stroke:"#1CADFF",fill:"rgba(28, 173, 255, 0.3)"},hover:{time:500}};function At(o){return(0,qt.merge)({},Zt,o)}var Tt=class extends Qt.EventDispatcher{constructor(t,e={}){super();this.container=t;r(this,"config");r(this,"context");r(this,"polarKeys",[]);r(this,"azimuthalKeys",[]);r(this,"svgLine");r(this,"svgPolygon");r(this,"basicZoom",1);r(this,"floorDataMap",new Map);r(this,"buildingGroundMap",new Map);r(this,"currentBuildGround",null);r(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)});r(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=At(e),this.context=new ht(t,this.config),this.registryEvent(),this.context.render()}loadGraphics(p){return $(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}){let{apiDomain:l,apiPath:{floorGraphic:m},apiInfo:g}=this.config,d=`${l}${m}?brand=${t}&project=${e}&phase=${i}&building=${n}&floor=${a}&ts=${c}&resource_type_list=${h}`;return yield fetch(d,g).then(b=>b.json()).then(b=>b.data).then(b=>((b||[]).map(E=>E.info=JSON.parse(E.info)),b||[]))})}getBuildingKey({brand:t,project:e,phase:i,building:n}){return`${t}-${e}-${i}-${n}`}loadBuildingGround(a){return $(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,m=`${h}${p}?brand=${t}&project=${e}&phase=${i}&building=${n}`,g=yield fetch(m,l).then(d=>d.json()).then(d=>d.data).then(d=>{let u=(d||[])[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:h}){return`${t}-${e}-${i}-${n}-${a}-${c}-${h}`}load(p){return $(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}){let l=this.getFloorKey({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h});if(this.floorDataMap.get(l))return;let[m,g]=yield Promise.all([this.loadGraphics({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}),this.loadBuildingGround({brand:t,project:e,phase:i,building:n})]);if(g){let d=mt(g.info.geometry.cds[0]);m.forEach(u=>{if(u.info.geometry.type==="polygon")u.info.geometry.cds.map(b=>{Array.isArray(b)&&b.forEach(E=>{E[0]-=d[0],E[1]-=d[1]})});else{let[b,E]=u.info.geometry.cds;u.info.geometry.cds=[b-d[0],E-d[1]]}u.info.transformToBuildingGround=!0})}return this.config.useFloorCache||this.floorDataMap.clear(),this.floorDataMap.set(l,m),m})}createFloor(t){let e=new ot(this.context);if(!t.length)return{curFloor:e,graphics:[]};let n=t.filter(p=>p.info.group==="ground").map(p=>new D(this.context,p.info));e.addGrounds(n);let a=t.filter(p=>p.info.group!=="ground"),c=new Map,h=a.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(p){return $(this,arguments,function*({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}){let l=this.getFloorKey({brand:t,project:e,phase:i,building:n,floor:a,ts:c,resource_type_list:h}),m=this.floorDataMap.get(l);if(m){let g=this.getBuildingKey({brand:t,project:e,phase:i,building:n});this.currentBuildGround=this.buildingGroundMap.get(g)||null;let d=this.createFloor(m);d?(this.context.switchFloor(d.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):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 D))||[]}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(yt(R({},e),{position:yt(R({},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 x(e,this.context.camera,i,n)}changeMapType(t,e=500){t==="2d"?this.context.setPolarAngle(0):this.context.setPolarAngle(1.2)}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 $(this,null,function*(){return this.cancelDistance(),new Promise((t,e)=>{this.changeMapType("2d",0),this.context.control.enableRotate=!1,this.svgLine=new rt(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 st(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){return this.context.currentFloor&&this.context.currentFloor.graphicLayer.graphicMap.get(t)||null}deleteGraphic(t){this.context.currentFloor&&(this.context.currentFloor.graphicLayer.remove(t),t.dispose(),this.context.currentFloor.graphicLayer.graphicMap.delete(t.options.id))}createGraphicByOptions(t){var e;if(!t.transformToBuildingGround&&this.currentBuildGround){let i=mt(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(),Dt(),St(),this.unRegistryEvent()}};
|
|
3
3
|
//# sourceMappingURL=bmap.cjs.min.js.map
|