@aibee/crc-bmap 0.6.12 → 0.6.13

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.
@@ -7531,5 +7531,5 @@ three/build/three.module.js:
7531
7531
  * along with MarchingSquaresJS. If not, see <http://www.gnu.org/licenses/>.
7532
7532
  *)
7533
7533
  */
7534
- `)}var Dn=class extends Jr.EventDispatcher{worker=Nn();initRoadStatus=!1;constructor(){super()}async setRoadData(e){this.initRoadStatus=!1,this.dispatchEvent({type:"init-road-status",status:!1}),await lt(this.worker,"set_road_info",{roadData:e}),this.initRoadStatus=!0,this.dispatchEvent({type:"init-road-status",status:!0})}async getPath(e,t,n=""){return new Promise((r,i)=>{let o=()=>{console.log("initRoadStatus",this.initRoadStatus),lt(this.worker,"get_path",{start:e,end:t,type:n}).then(a=>{a?typeof a=="string"?i(a):r(a):i("no-path")})};if(this.initRoadStatus)o();else{let a=({status:l})=>{l&&(this.removeEventListener("init-road-status",a),o())};this.addEventListener("init-road-status",a)}})}getDirectionPath(e){return lt(this.worker,"get_direction_path",e)}async dispose(){lt(this.worker,"clear",""),this.worker.terminate()}};var Qr=require("three"),Ve=class extends J{startPoint;endPoint;rect;frustum=new Qr.Frustum;constructor(e){super(e);let{config:{selectBox:{fill:t,stroke:n}}}=e;this.rect=mt(n,t),this.svg.appendChild(this.rect),this.registryEvent()}setEnable(e){super.setEnable(e),B(this.rect,0,0,0,0),e?this.registryEvent():(this.startPoint=void 0,this.unRegistryEvent())}onPointerDown=e=>{if(!this.enable)return;let t=this.getIntersectByPointerEvent(e);t&&(this.startPoint=t),this.endPoint=void 0};onPointerMove=e=>{if(!this.enable||!this.startPoint)return;let t=this.getIntersectByPointerEvent(e);t&&(this.endPoint=t)};onPointerUp=e=>{if(!this.enable)return;let t=this.getIntersectByPointerEvent(e);t&&(this.endPoint=t),this.doSelect(),this.startPoint=void 0};onUpdate=()=>{if(this.startPoint){let e=this.getSvgCoordinate(this.startPoint),t={...e};this.endPoint&&(t=this.getSvgCoordinate(this.endPoint));let n={x:Math.min(e.x,t.x),y:Math.min(e.y,t.y)},r=Math.abs(t.x-e.x),i=Math.abs(t.y-e.y);B(this.rect,n.x,n.y,r,i)}else B(this.rect,0,0,0,0)};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:t,container:{clientWidth:n,clientHeight:r}}}=this,i=y(this.startPoint,t,n,r),o=y(this.endPoint,t,n,r),a={x:Math.min(i.x,o.x),y:Math.min(i.y,o.y)},l={x:Math.max(i.x,o.x),y:Math.max(i.y,o.y)},u=this.searchMapInFrustum(a,l);this.dispatchEvent({type:"selected",list:u})}}searchMapInFrustum(e,t){let{context:n}=this;return n.currentFloor?.graphicLayer.children.filter(r=>r instanceof R&&this.searchChildInFrustum(r,e,t))||[]}searchChildInFrustum(e,t,n){let{context:{camera:r,container:{clientWidth:i,clientHeight:o}}}=this;if(!e)return!1;if(!e.mesh){let p=e.getPosition();if(p){let d=y(p,r,i,o);return gt(d,t,n)}return!1}e.mesh.geometry.boundingBox||e.mesh.geometry.computeBoundingBox();let a=e.mesh.geometry.boundingBox;if(!a)return!1;let{min:l,max:u}=a,c=y(l,r,i,o),h=y(u,r,i,o);return!(!gt(c,t,n)||!gt(h,t,n))}dispose(){this.unRegistryEvent()}};var ji={boxSelection:!1,elements:["graphic","poi"]},On=class extends dt{options;_list=new Set;_poiList=new Set;boxSelection;prevPanStatus;prevRotateStatus;downPoint=null;isMultipleSelect=!1;constructor(e,t={}){super(e),this.options={...ji,...t},this.boxSelection=new Ve(this.bmap.context),this.boxSelection.setEnable(!1),this.registryEvent()}get list(){return this._list}enableBoxSelection(){this.isMultipleSelect||!this.options.boxSelection||(this.isMultipleSelect=!0,this.boxSelection.setEnable(!0),this.prevPanStatus=this.bmap.context.control.enablePan,this.prevRotateStatus=this.bmap.context.control.enableRotate,this.bmap.context.control.enablePan=!1,this.bmap.context.control.enableRotate=!1)}disableBoxSelection(){this.isMultipleSelect&&(this.isMultipleSelect=!1,this.boxSelection.setEnable(!1),this.bmap.context.control.enablePan=!!this.prevPanStatus,this.bmap.context.control.enableRotate=!!this.prevRotateStatus)}onPointerDown=e=>{this.downPoint={x:e.offsetX,y:e.offsetY}};onPointerUp=e=>{if(!this.downPoint)return;let{offsetX:t,offsetY:n}=e,{x:r,y:i}=this.downPoint;if(Math.sqrt((r-t)**2+(i-n)**2)>3)return;let o=new Set,a=[],l=[];if(this.options.elements.includes("graphic")){let{graphics:u}=this.bmap.context.getGraphicsByDeviceXy(t,n);u.map(c=>o.add(c.options.id)),a.push(...u)}if(this.options.elements.includes("poi")){let u=this.bmap.context.getPoisByDeviceXy(t,n);l.push(...u),u.forEach(c=>{if(!o.has(c.options.id)){let h=this.bmap.context.currentFloor?.graphicLayer.graphicMap.get(c.options.id)||null;h&&(o.add(c.options.id),a.push(h))}})}(!this.options.boxSelection||!(It?e.metaKey:e.ctrlKey))&&(this._list.clear(),this._poiList.clear()),a.forEach(u=>this._list.add(u)),l.forEach(u=>this._poiList.add(u)),this.selectEnd(),this.downPoint=null};onPointerOut=e=>{this.disableBoxSelection()};onKeyDown=e=>{Rt(e.key)&&this.enableBoxSelection()};onKeyUp=e=>{Rt(e.key)&&this.disableBoxSelection()};onBoxSelected=({list:e})=>{this._list.clear(),this._poiList.clear(),e.forEach(t=>{if(this.options.elements.includes("graphic")&&this._list.add(t),this.options.elements.includes("poi")){let n=this.bmap.getPoiById(t.options.id);n&&this._poiList.add(n)}}),this.selectEnd()};selectEnd(){this.dispatchEvent({type:"select",graphics:[...this._list],pois:[...this._poiList],isMultipleSelect:this.isMultipleSelect})}registryEvent(){this.bmap.context.container.addEventListener("pointerdown",this.onPointerDown),this.bmap.context.container.addEventListener("pointerup",this.onPointerUp),this.bmap.context.container.addEventListener("pointerout",this.onPointerOut),this.bmap.context.container.addEventListener("pointercancel",this.onPointerOut),window.addEventListener("keydown",this.onKeyDown),window.addEventListener("keyup",this.onKeyUp),this.boxSelection.addEventListener("selected",this.onBoxSelected)}unRegistryEvent(){this.bmap.context.container.removeEventListener("pointerdown",this.onPointerDown),this.bmap.context.container.removeEventListener("pointerup",this.onPointerUp),this.bmap.context.container.removeEventListener("pointerout",this.onPointerOut),this.bmap.context.container.removeEventListener("pointercancel",this.onPointerOut),window.removeEventListener("keydown",this.onKeyDown),window.removeEventListener("keyup",this.onKeyUp),this.boxSelection.removeEventListener("selected",this.onBoxSelected)}clear(){this._list.clear()}remove(e){this._list.delete(e)}dispose(){this.unRegistryEvent()}};var Y=require("lodash");var ei=require("three");var Yi={time:1e3,elements:["compass","deviceMotion","acceleration","gps"]},Ee=class extends ei.EventDispatcher{options;gpsTimer=null;data=[];timer=new D;dispatchTimer=null;constructor(e={}){super(),this.options={...Yi,...e}}start(){this.options.elements.some(e=>["deviceMotion","compass"].includes(e))&&this.listenDeviceOrientation(),this.options.elements.includes("acceleration")&&this.listenAcceleration(),this.options.elements.includes("gps")&&this.listenGps(),this.dispatchEvent({type:"start"}),this.dispatchTimer=this.timer.setInterval(()=>{this.dispatchEvent({type:"sensor-data",data:(0,Y.cloneDeep)(this.data)}),this.data=[]},this.options.time)}addDataItem(e){this.data.push(e),this.dispatchEvent({type:"add-data-item",item:e})}addAcceleration=(0,Y.throttle)(e=>{this.addDataItem(e)},20);deviceOrientationAbsHandler=(0,Y.throttle)(e=>{let t=Date.now(),{alpha:n,beta:r,gamma:i}=e;if((0,Y.isNil)(n)||(0,Y.isNil)(r)||(0,Y.isNil)(i))return;let o;Ht?o=e.webkitCompassHeading:o=360-n,this.options.elements.includes("deviceMotion")&&this.addDataItem({type:"deviceMotion",timestamp:t,res:[n,r,i]}),this.options.elements.includes("compass")&&this.addDataItem({type:"compass",timestamp:t,res:o})},200);listenDeviceOrientation(){Ht?window.addEventListener("deviceorientation",this.deviceOrientationAbsHandler,!1):window.addEventListener("deviceorientationabsolute",this.deviceOrientationAbsHandler,{absolute:!0})}handleAcceleration=e=>{let t=e.accelerationIncludingGravity;(0,Y.isNil)(t)||(0,Y.isNil)(t.x)||(0,Y.isNil)(t.y)||(0,Y.isNil)(t.z)||this.addAcceleration({type:"acceleration",timestamp:Date.now(),res:[t.x,t.y,t.z]})};listenAcceleration(){window.addEventListener("devicemotion",this.handleAcceleration,!1)}listenGps(){this.gpsTimer=navigator.geolocation.watchPosition(e=>{e.coords.accuracy<=10&&this.addDataItem({type:"gps",timestamp:Date.now(),res:[e.coords.longitude,e.coords.latitude,e.coords.accuracy]})})}async checkSensor(){return{deviceOrientation:await this.checkDeviceOrientation()}}async checkDeviceOrientation(){if(!Ht)return!0;if(typeof window.DeviceOrientationEvent<"u"&&typeof window.DeviceOrientationEvent?.requestPermission=="function")try{return await window.DeviceOrientationEvent?.requestPermission()==="granted"}catch{return!1}return!1}stop(){window.removeEventListener("devicemotion",this.handleAcceleration,!1),Ht?window.removeEventListener("deviceorientation",this.deviceOrientationAbsHandler,!1):window.removeEventListener("deviceorientationabsolute",this.deviceOrientationAbsHandler,{absolute:!0}),(0,Y.isNil)(this.gpsTimer)||navigator.geolocation.clearWatch(this.gpsTimer),this.dispatchTimer&&this.timer.clearInterval(this.dispatchTimer),this.data=[],this.dispatchEvent({type:"stop"})}};var ri=require("three");function He(s,e){return 1/Math.sqrt(2*Math.PI*Math.pow(e,2))*Math.exp(-Math.pow(s,2)/(2*Math.pow(e,2)))}function be(s){return(s+360)%360}function ni(s,e){let n=6378137*s*Math.PI/180,r=6378137*Math.log(Math.tan(Math.PI/4+e*Math.PI/180/2));return{x:n,y:r}}function $t(s,e,t,n){return Math.sqrt(Math.pow(Math.abs(s-t),2)+Math.pow(Math.abs(e-n),2))}var Xe=Zt(require("mathjs"),1),We=class{NumParticle;reSampNumParticle;initial_xy_uncertainty;initial_yaw_uncertainty;step_noise_sigma;yaw_noise_sigma;compass_update_interval;sigmaCompass;delta_yaw;sigmaBeacon;unaccess_weight;particle_PosInitFlag;particle_yawInitFlag;xEst;particleX;particleWeight;last_compass_time;last_yaw_compass=0;compass_consecutive_offset_count=0;constructor(e){this.NumParticle=e.NumParticle,this.reSampNumParticle=e.reSampNumParticle,this.initial_xy_uncertainty=e.initial_xy_uncertainty,this.initial_yaw_uncertainty=e.initial_yaw_uncertainty,this.step_noise_sigma=e.step_noise_sigma,this.yaw_noise_sigma=e.yaw_noise_sigma,this.compass_update_interval=e.compass_update_interval,this.sigmaCompass=e.sigmaCompass,this.delta_yaw=e.delta_yaw,this.sigmaBeacon=e.sigmaBeacon,this.unaccess_weight=e.unaccess_weight,this.particle_PosInitFlag=!1,this.particle_yawInitFlag=!1,this.xEst=[[0],[0],[0]],this.particleX=Array.from({length:3},()=>Array(this.NumParticle).fill(0)),this.particleWeight=Array.from({length:1},()=>Array(this.NumParticle).fill(1/this.NumParticle)),this.last_compass_time=0}motionModelRotYaw(e){if(!(Math.abs(e)<.001)){this.last_yaw_compass=be(this.last_yaw_compass+e);for(let t=0;t<this.NumParticle;t++){let n=Math.random()*this.yaw_noise_sigma;this.particleX[2][t]=this.particleX[2][t]+e+n,this.particleX[2][t]=be(this.particleX[2][t])}}}motionModelStepLength(e,t){if(e===0)return;for(let r=0;r<this.NumParticle;r++){let i=Math.random()*this.step_noise_sigma;this.particleX[0][r]+=(.65+i)*Math.sin(-this.particleX[2][r]/180*Math.PI),this.particleX[1][r]+=(.65+i)*Math.cos(this.particleX[2][r]/180*Math.PI),t(this.particleX[0][r],this.particleX[1][r])||(this.particleWeight[0][r]*=this.unaccess_weight)}let n=this.particleWeight[0].reduce((r,i)=>r+i,0);this.particleWeight[0]=this.particleWeight[0].map(r=>r/n)}motionModelCompassYaw(e,t){if(t-this.last_compass_time>this.compass_update_interval){let n=360-e;n+=this.delta_yaw,n=be(n),Math.abs(n-this.last_yaw_compass)>60?this.compass_consecutive_offset_count++:this.compass_consecutive_offset_count=0;for(let i=0;i<this.NumParticle;i++){let o=Math.abs(this.particleX[2][i]-n);o>180&&(o=360-o),this.particleWeight[0][i]*=He(o,this.sigmaCompass)}let r=this.particleWeight[0].reduce((i,o)=>i+o,0);this.particleWeight[0]=this.particleWeight[0].map(i=>i/r),this.setLastCompassTime(t)}}resampling(){if(1/this.particleWeight[0].reduce((t,n)=>t+n*n,0)<this.reSampNumParticle){let t=this.particleWeight[0].reduce((a,l,u)=>a.concat(a[u]+l),[0]),r=this.particleWeight[0].map(()=>1/this.NumParticle).map((a,l)=>a+Math.random()/this.NumParticle),i=[],o=0;for(let a=0;a<this.NumParticle;a++){for(;r[a]>t[o];)o++;i.push(o)}this.particleX=this.particleX.map((a,l)=>i.map(u=>a[u])),this.particleWeight[0]=Array(this.NumParticle).fill(1/this.NumParticle)}}update(e,t){for(let r=0;r<this.NumParticle;r++){let i=$t(this.particleX[0][r],this.particleX[1][r],e.x,e.y);this.particleWeight[0][r]=Math.max(1e-7,this.particleWeight[0][r]*He(i,t))}let n=this.particleWeight[0].reduce((r,i)=>r+i,0);this.particleWeight[0]=this.particleWeight[0].map(r=>r/n)}updateCar(e,t){let n=e.x-this.xEst[0][0],r=e.y-this.xEst[1][0];for(let o=0;o<this.NumParticle;o++){let a=$t(this.particleX[0][o],this.particleX[1][o],e.x,e.y);this.particleWeight[0][o]=Math.max(1e-7,this.particleWeight[0][o]*He(a,t)),this.particleX[0][o]+=n,this.particleX[1][o]+=r}let i=this.particleWeight[0].reduce((o,a)=>o+a,0);this.particleWeight[0]=this.particleWeight[0].map(o=>o/i)}getPosInitFlag(){return this.particle_PosInitFlag}getYawInitFlag(){return this.particle_yawInitFlag}setPosInitFlag(e){this.particle_PosInitFlag=e}setYawInitFlag(e){this.particle_yawInitFlag=e}getResultX(){let e=Xe.reshape(this.particleWeight,[this.NumParticle,1]),t=Xe.multiply(this.particleX,e);return this.xEst=t,this.xEst[0][0]}getResultY(){return this.xEst[1][0]}getResultYaw(){let e=this.particleWeight[0].indexOf(Math.max(...this.particleWeight[0]));return this.particleX[2][e]}getEstConfidence(){let e=this.particleWeight[0].indexOf(Math.max(...this.particleWeight[0])),t=this.particleWeight[0].indexOf(Math.min(...this.particleWeight[0])),n=[this.particleX[0][e],this.particleX[1][e]],r=[this.particleX[0][t],this.particleX[1][t]],i=$t(n[0],n[1],r[0],r[1]),o=i*.67;return console.log(i,o),o}getParticleNum(){return this.NumParticle}getParticleX(){return this.particleX}setLastCompassTime(e){this.last_compass_time=e}getLastCompassTime(){return this.last_compass_time}initParticlesByPos(e,t,n){if(!this.particle_PosInitFlag){this.particleWeight[0]=Array(this.NumParticle).fill(1/this.NumParticle);let r=0;for(;r<this.NumParticle;){let o=(2*Math.random()-1)*this.initial_xy_uncertainty,a=(2*Math.random()-1)*this.initial_xy_uncertainty;n(e+o,t+a)||(this.particleWeight[0][r]*=this.unaccess_weight),this.particleX[0][r]=e+o,this.particleX[1][r]=t+a,r++}let i=this.particleWeight[0].reduce((o,a)=>o+a,0);this.particleWeight[0]=this.particleWeight[0].map(o=>o/i),this.particle_PosInitFlag=!0,this.xEst[0][0]=e,this.xEst[1][0]=t,this.xEst[2][0]=0}}initParticlesByCompass(e){console.log(`Init compass: ${e}`);let t=360-e;t+=this.delta_yaw,t=be(t),console.log(`Init Yaw: ${t}`);for(let n=0;n<this.NumParticle;n++){let r=(2*Math.random()-1)*this.initial_yaw_uncertainty;this.particleX[2][n]=t+r}this.particle_yawInitFlag=!0,this.xEst[2][0]=t,this.last_yaw_compass=t,this.compass_consecutive_offset_count=0}};var je=Zt(require("mathjs"),1),qe=class{fre=100;accH_fifo=[];accH_time_fifo=[];accH_fifo_len=Math.floor(1*this.fre)+1;step_count=0;state_count=0;last_valley_time=0;last_peak_time=0;last_step_time=0;min_step_time=.3;max_step_time=1;min_peak=10.5;max_valley=9.5;peak_num=0;valley_num=0;fft_min_amp=.3;fft_min_fre=0;fft_max_fre=4;last_fft_amp=0;abnor_start_time=0;abnor_fft_detected=!1;abnor_time_threshold=4;abnor_peak_time=0;abnor_peak_accH=0;const_step_length=.65;last_rot=[];delta_rot=[];last_yaw=0;delta_yaw=null;delta_rot_sum_fifo=[];delta_rot_sum_time_fifo=[];delta_yaw_accum=0;delta_yaw_accum_timestamp=0;delta_yaw_time_threshold=.5;last_px=0;last_py=0;delta_px=0;delta_py=0;init(){this.fre=100,this.accH_fifo=[],this.accH_time_fifo=[],this.accH_fifo_len=Math.floor(1*this.fre)+1,this.step_count=0,this.state_count=0,this.last_valley_time=0,this.last_peak_time=0,this.last_step_time=0,this.min_step_time=.3,this.max_step_time=1,this.min_peak=10+.5,this.max_valley=10-.5,this.peak_num=0,this.valley_num=0,this.fft_min_amp=.3,this.fft_min_fre=0,this.fft_max_fre=4,this.last_fft_amp=0,this.abnor_start_time=0,this.abnor_fft_detected=!1,this.abnor_peak_time=0,this.abnor_peak_accH=0,this.const_step_length=.65,this.last_rot=[0,0,0],this.delta_rot=[0,0,0],this.last_yaw=0,this.delta_yaw=null,this.delta_rot_sum_fifo=[],this.delta_rot_sum_time_fifo=[],this.delta_yaw_accum=0,this.delta_yaw_accum_timestamp=0,this.delta_yaw_time_threshold=.5,this.last_px=0,this.last_py=0,this.delta_px=0,this.delta_py=0}reset(){this.init()}setInitPose(e=[0,0]){this.last_px=e[0],this.last_py=e[1],console.info(`pdr init pos: ${this.last_px}, ${this.last_py}`)}setInitYaw(e=0){this.last_yaw=e}getPos(e,t,n){let r=0;return n.length===3&&(this.delta_yaw=this.getDeltaYawFromRot(e,n)),t.length===3&&(r=this.getStepLength(e,t)),r!==0&&(this.last_px+=this.delta_px,this.last_py+=this.delta_py),[this.last_px,this.last_py]}getDeltaPose(){return[this.delta_px,this.delta_py]}getStepLength(e,t){if(t.length<3)return console.warn("acc data less than 3"),0;let n=!1,r=Math.sqrt(Math.pow(t[0],2)+Math.pow(t[1],2)+Math.pow(t[2],2));if(this.accH_fifo.push(r),this.accH_time_fifo.push(e),this.imuFreUpdate(),this.accH_fifo.length<this.accH_fifo_len+1)n=!1;else{for(;this.accH_fifo.length>=this.accH_fifo_len+1;)this.accH_fifo.shift(),this.accH_time_fifo.shift();let i=this.PVStepDetec(),o=this.FFTStepDetec(),a=this.recheckState(),l=this.accH_time_fifo[Math.floor(this.accH_time_fifo.length*3/4)];Math.abs(this.abnor_start_time)<.001&&this.abnor_fft_detected?this.abnor_start_time=l:this.abnor_fft_detected||(this.abnor_start_time=0),i&&o&&a?(this.step_count+=1,this.last_step_time=l,n=!0):Math.abs(this.abnor_start_time)>.001&&this.abnor_peak_time-this.abnor_start_time>this.abnor_time_threshold&&this.step_count>1&&this.abnor_peak_time-this.last_step_time>1?(this.step_count+=1,this.last_step_time=l,n=!0):(l-this.last_step_time>2&&(this.state_count=0),n=!1)}if(n){let i=this.last_yaw/180*Math.PI;return this.delta_px=this.const_step_length*Math.cos(i),this.delta_py=this.const_step_length*Math.sin(i),this.const_step_length}else return 0}imuFreUpdate(){if(this.accH_time_fifo.length>2&&(this.accH_time_fifo[this.accH_time_fifo.length-1]-this.accH_time_fifo[this.accH_time_fifo.length-2]<0||this.accH_time_fifo[this.accH_time_fifo.length-1]-this.accH_time_fifo[this.accH_time_fifo.length-2]>10||this.accH_time_fifo[this.accH_time_fifo.length-1]===this.accH_time_fifo[0])&&(console.warn(`pdr reset last one time ${this.accH_time_fifo[this.accH_time_fifo.length-1]} last two time ${this.accH_time_fifo[this.accH_time_fifo.length-2]}`),this.reset()),this.accH_fifo.length>9||this.fre<15){let e=(this.accH_fifo.length-1)/(this.accH_time_fifo[this.accH_time_fifo.length-1]-this.accH_time_fifo[0]);Math.abs(this.fre-e)>8&&(this.fre=Math.round((e-3)/10)*10,(this.fre<=10||this.fre>=100)&&(console.warn(`Frequency Error ${this.fre}`),this.fre=100),console.debug(`Frequency change to ${this.fre}`),this.accH_fifo_len=Math.floor(1*this.fre)+1)}}recheckState(){return!0}PVStepDetec(){let e=!1,t=this.accH_fifo.slice(Math.floor(this.accH_fifo_len/2)),n=this.accH_time_fifo.slice(Math.floor(this.accH_fifo_len/2)),r=t[Math.floor(t.length/2)],i=n[Math.floor(n.length/2)],o=Math.max(...t),a=Math.min(...t),l=!1,u=!1;return Math.abs(r-a)<.01&&r<this.max_valley&&this.valley_num<=this.peak_num&&(this.last_valley_time===0?u=!0:u=i-this.last_valley_time>this.min_step_time,u&&(this.last_valley_time=i,this.valley_num+=1)),Math.abs(r-o)<.01&&r>this.min_peak&&this.peak_num<=this.valley_num&&(this.last_peak_time===0?l=!0:l=i-this.last_peak_time>this.min_step_time,l&&(this.last_peak_time=i,this.peak_num+=1)),r===o&&r>this.min_peak&&(this.abnor_peak_time=i,this.abnor_peak_accH=r),this.peak_num===this.valley_num&&(l||u)&&(e=!0),e}FFTStepDetec(){return!0}getDeltaYawFromRot(e,t){if(t.length<3)return console.warn("rot data less than 3"),0;let n=[0,0,0];this.last_rot.length===3&&(n=t.map((a,l)=>a-this.last_rot[l]));for(let a=0;a<t.length;a++)n[a]<-180?n[a]+=360:n[a]>180&&(n[a]-=360);let r=.2;this.delta_rot.length===3?this.delta_rot=this.delta_rot.map((a,l)=>r*a+(1-r)*n[l]):this.delta_rot=n,this.last_rot=t,this.delta_yaw=this.delta_rot[0],this.last_yaw+=this.delta_yaw,this.last_yaw=this.limitYaw(this.last_yaw);let i=this.delta_rot.reduce((a,l)=>a+Math.abs(l),0);this.delta_rot_sum_fifo.push(i),this.delta_rot_sum_time_fifo.push(e),Math.abs(this.delta_rot_sum_time_fifo[this.delta_rot_sum_time_fifo.length-1]-this.delta_rot_sum_time_fifo[0])>1&&(this.delta_rot_sum_fifo.shift(),this.delta_rot_sum_time_fifo.shift()),this.delta_yaw_accum+=this.delta_yaw;let o=0;return Math.abs(this.delta_yaw_accum_timestamp-e)>this.delta_yaw_time_threshold?(o=this.delta_yaw_accum,this.delta_yaw_accum=0,this.delta_yaw_accum_timestamp=e,o):null}limitYaw(e){for(;e<-180;)e+=360;for(;e>180;)e-=360;return e}};var Ye=class{particleFilter;pdr;sigmaBeacon=5;gps_horizontalAccuracy=10;using_gps=!0;last_beacon_time=null;last_pos_time;position_count=0;gps_max_horizontalAccuracy=20;MaxEstimateErr=5;outTrustRegionNum=0;TrustNum=4;cacheSensorData=[];constructor(){this.particleFilter=new We({NumParticle:200,reSampNumParticle:.65,initial_xy_uncertainty:12,initial_yaw_uncertainty:100,step_noise_sigma:.5,yaw_noise_sigma:2,compass_update_interval:3e3,sigmaCompass:80,delta_yaw:2,sigmaBeacon:5,unaccess_weight:.7}),this.pdr=new qe}pfFusionPDRiBeacon(e){let{type:t,timestamp:n,res:r}=e,i=!1;if(this.particleFilter.getPosInitFlag()&&this.particleFilter.getYawInitFlag()){if(t==="acceleration"){let o=r,a=this.pdr.getStepLength(n/1e3,o);a!==0&&(this.particleFilter.motionModelStepLength(a,()=>!0),this.particleFilter.resampling(),this.position_count+=1,i=!0)}if(this.using_gps&&t==="gps"&&(this.last_beacon_time===null||n-this.last_beacon_time>5e3)){let o=this.getGpsPosition(r);i=o!==null,o&&(this.particleFilter.update(o,this.gps_horizontalAccuracy),this.resetParticleFilterDist(o),this.particleFilter.resampling(),this.position_count+=1)}if(t==="deviceMotion"){let o=this.pdr.getDeltaYawFromRot(n/1e3,r);o!==null&&this.particleFilter.motionModelRotYaw(o)}t==="compass"&&this.particleFilter.motionModelCompassYaw(r,n),this.last_pos_time&&n-this.last_pos_time>500&&(this.position_count+=1,i=!0)}else if(!this.particleFilter.getPosInitFlag()&&this.using_gps&&t==="gps"){let o=this.getGpsPosition(r);i=o!==null,o?(this.particleFilter.initParticlesByPos(o.x,o.y,()=>!0),this.last_pos_time=n,console.log(`init Pos by gps success time ${n}`),this.cacheSensorData.length=0):console.log(`init Pos by gps fail time ${n}`)}else if(!this.particleFilter.getYawInitFlag()&&t==="compass"){let o=r;this.particleFilter.initParticlesByCompass(o),this.particleFilter.setLastCompassTime(n),console.log(`init yaw by compass success time ${n}`)}else this.cacheSensorData.push(e);return i&&(this.last_pos_time=n),[i,this.particleFilter.getResultX(),this.particleFilter.getResultY()]}setBeaconPosition(e,t){return this.last_beacon_time=t,this.particleFilter.getPosInitFlag()?this.particleFilter.update(e,this.sigmaBeacon):this.particleFilter.initParticlesByPos(e.x,e.y,()=>!0),this.resetParticleFilterDist(e),this.particleFilter.resampling(),this.position_count+=1,this.cacheSensorData.filter(r=>r.timestamp>t).map(r=>this.pfFusionPDRiBeacon(r)),this.cacheSensorData.length=0,[this.particleFilter.getResultX(),this.particleFilter.getResultY()]}getGpsPosition(e){return e[2]>this.gps_max_horizontalAccuracy?null:ni(e[0],e[1])}resetParticleFilterDist(e){let t=this.particleFilter.getResultX(),n=this.particleFilter.getResultY();$t(t,n,e.x,e.y)>this.MaxEstimateErr?(this.outTrustRegionNum+=1,this.outTrustRegionNum>=this.TrustNum&&(console.info(`\u8D85\u51FA\u53EF\u4FE1\u533A\u57DF\uFF0C\u91CD\u7F6E\u7C92\u5B50\u8FC7\u6EE4\u5668\u5230: ${e.x}, ${e.y}`),this.particleFilter.setPosInitFlag(!1),this.particleFilter.setYawInitFlag(!1),this.outTrustRegionNum=0)):this.outTrustRegionNum=0}};var Fn=class extends ri.EventDispatcher{sensor;pdr;_pause=!1;constructor(e={}){super(),this.sensor=new Ee(e.sensor),this.pdr=new Ye}checkSensor(){return this.sensor.checkSensor()}start(){this.sensor.start(),this.sensor.addEventListener("add-data-item",({item:e})=>{this.getPositionBySensorItem(e,!this._pause)})}pause(){this._pause=!0}continue(){this._pause=!1}getPositionBySensorItem(e,t=!0){let[n,r,i]=this.pdr.pfFusionPDRiBeacon(e);return n&&t&&this.dispatchEvent({type:"position",x:r,y:i,_type:e.type==="gps"?"gps":"pdr"}),[n,r,i]}setBeaconPosition(e,t){let[n,r]=this.pdr.setBeaconPosition(e,t);this.dispatchEvent({type:"position",x:n,y:r,_type:"beacon"})}dispose(){this.sensor.stop()}};async function Un({brand:s,project:e},t){let{apiDomain:n,apiPath:{floorRange:r},apiInfo:i}=t,o=`${n}${r}?brand=${s}&project=${e}&phase=${e}&building=${e}`;return await fetch(o,i).then(l=>l.json()).then(l=>l.data).then(l=>{let u=(l||[])[0];return u&&(u.info=JSON.parse(u.info)),u})}async function Bn({brand:s,project:e,floor:t,ts:n,resource_type_list:r},i){let{apiDomain:o,apiPath:{floorGraphic:a},apiInfo:l}=i,u=`${o}${a}?brand=${s}&project=${e}&phase=${e}&building=${e}&floor=${t}&ts=${n}&resource_type_list=${r}`;return await fetch(u,l).then(h=>h.json()).then(h=>h.data).then(h=>((h||[]).map(p=>p.info=JSON.parse(p.info)),h||[]))}async function $i({project:s,floor:e},t){let{apiDomain:n,apiInfo:r}=t,i=`${n}/api/inception-map/external_street/get?projectCode=${s}&floorCode=${e}`;return await fetch(i,r).then(a=>a.json()).then(a=>a.data).then(a=>JSON.parse(a[0].streetInfo||"{}")).then(a=>a.fileId?Ki(a.fileId,t):null)}async function Ki(s,e){let{apiDomain:t,apiInfo:n}=e;return fetch(`${t}/api/inception-map/file/getFileStream?fileId=${s}`,n).then(r=>r.arrayBuffer()).then(r=>{let o=new TextDecoder("utf-8").decode(r);return o?JSON.parse(o):null})}var ht;function ii(s="aibee_map",e=1){return new Promise((t,n)=>{if(ht)return t({db:ht,type:"success"});let r=indexedDB.open(s,e);r.onupgradeneeded=function(i){ht=i.target.result,console.log("onupgradeneeded"),t({db:ht,type:"onupgradeneeded"})},r.onsuccess=i=>{ht=i.target.result,t({db:ht,type:"success"})},r.onerror=i=>{n(i)}})}function Gn(s,e,t=ht){return new Promise((n,r)=>{t||r("\u6CA1\u6709db");let o=t.transaction([s],"readonly").objectStore(s).get(e);o.onsuccess=()=>{o.result?n(o.result.value):n(null)},o.onerror=a=>{console.log("[getVersionByKey]",a),n(null)}})}function oi(s,e,t,n=ht){return new Promise((r,i)=>(n||i("\u6CA1\u6709db"),new Promise(async(o,a)=>{let l=await Gn(s,e),u=n.transaction([s],"readwrite").objectStore(s),c=l!==null?u.put({key:e,value:t}):u.add({key:e,value:t});c.onsuccess=function(h){o(h)},c.onerror=function(h){a(h)}})))}function zt(s,e=ht){e&&(e.objectStoreNames.contains(s)||e.createObjectStore(s,{keyPath:"key"}))}function si(){ht?.close(),ht=null}var ai="";var li="";var ui="";var ci='data:image/svg+xml,<svg viewBox="12 22 54 38" xmlns="http://www.w3.org/2000/svg">%0A%09<g fill="%23ffffff">%0A%09%09<path fill-opacity="1" stroke-width="0.2" stroke-linejoin="round" d="M 14.25,32.165L 20.479,49.0255L 25.7981,49.0255L 32.1671,32.165L 26.568,32.165L 24.3633,39.9922C 23.9959,41.4233 23.681,42.8056 23.4185,44.139L 23.3135,44.139C 23.0569,42.8182 22.7303,41.4454 22.3337,40.0207L 20.0241,32.165L 14.25,32.165 Z "/>%0A%09%09<path fill-opacity="1" stroke-width="0.2" stroke-linejoin="round" d="M 39.915,49.0255L 39.915,32.165L 34.6763,32.165L 34.6763,49.0255L 39.915,49.0255 Z M 37.4891,24.4171C 36.6275,24.4336 35.946,24.6849 35.4446,25.1711C 34.9433,25.6573 34.6872,26.2791 34.6763,27.0366C 34.6865,27.7789 34.9353,28.3964 35.4229,28.8889C 35.9105,29.3814 36.5761,29.637 37.4196,29.6557C 38.3131,29.637 39.0091,29.3814 39.5075,28.8889C 40.006,28.3964 40.2592,27.7789 40.2677,27.0366C 40.2426,26.2791 39.9879,25.6573 39.5032,25.1711C 39.0185,24.6849 38.3471,24.4336 37.4891,24.4171 Z "/>%0A%09%09<path fill-opacity="1" stroke-width="0.2" stroke-linejoin="round" d="M 44.1851,56.0691L 49.4238,56.0691L 49.4238,47.5447L 49.4957,47.5447C 49.8997,48.0793 50.4949,48.5157 51.2811,48.854C 52.0674,49.1922 52.9953,49.3668 54.0649,49.3777C 56.0656,49.3912 57.8266,48.6768 59.3479,47.2346C 60.8692,45.7923 61.6699,43.5413 61.75,40.4814C 61.6918,37.7576 60.9918,35.6378 59.6502,34.122C 58.3085,32.6062 56.6746,31.8365 54.7485,31.8126C 52.1604,31.842 50.213,32.7675 48.9065,34.5891L 48.8375,34.5891L 48.5963,32.165L 44.0443,32.165C 44.1264,33.761 44.1734,35.6713 44.1851,37.8958L 44.1851,56.0691 Z M 49.4238,39.5729C 49.4238,39.272 49.4598,38.971 49.5317,38.6699C 49.7288,37.8746 50.1261,37.2334 50.7235,36.7462C 51.3209,36.2591 52.0149,36.0087 52.8057,35.9949C 54.0304,36.0239 54.9538,36.4784 55.576,37.3585C 56.1981,38.2386 56.5099,39.3704 56.5114,40.7541C 56.5024,42.2152 56.1696,43.3745 55.513,44.2321C 54.8564,45.0896 53.93,45.5282 52.7337,45.5477C 51.9302,45.5325 51.2437,45.2937 50.674,44.8313C 50.1044,44.3689 49.7236,43.774 49.5317,43.0467C 49.4598,42.7109 49.4238,42.3404 49.4238,41.9352L 49.4238,39.5729 Z "/>%0A%09</g>%0A</svg>%0A';var pi=require("three"),eo={loadRoadNetwork:!1},zn="map_version",kn="route_version",Vn="facility_version",Hn="map_data",$e="road_network_data",Wn="facility_data",hi={half:ai,power:li,mechanical:ui,vip:ci},Xn=class{constructor(e){this.bmap=e;this.initDbPromise=this.initDb()}floors=[];initDbPromise=Promise.resolve();db=null;async initDb(){try{let{db:e,type:t}=await ii("aibee_map",2);t==="onupgradeneeded"&&(zt(zn),zt(kn),zt(Vn),zt(Hn),zt($e),zt(Wn)),this.db=e}catch(e){console.log("[\u6253\u5F00indexDb\u9519\u8BEF]",e)}}async load(e){if(Array.isArray(e))this.floors=e;else{let t=await fetch(e).then(n=>n.json());t.code==="0"&&(this.floors=t.data.list)}}setCacheData(e,t,n){return this.initDbPromise.then(()=>oi(e,`${t}`,n,this.db))}getCacheData(e,t){return this.initDbPromise.then(()=>Gn(e,`${t}`,this.db))}getFloorCacheKey(e){return`${e.floor_id}`}async getFloorData(e){let t=this.floors.find(r=>r.floor===e);if(!t)return null;let n=this.getFloorCacheKey(t);try{if(await this.getCacheData(zn,n)===t.version_id){let i=await this.getCacheData(Hn,n);if(i)return this.getDataByJson(i)}return this.getFloorDataByFloorInfo(t)}catch(r){return console.log("[get floor data error]",r),this.getFloorDataByFloorInfo(t)}}async getFloorDataByFloorInfo(e){let t=this.getFloorCacheKey(e);console.time("zstd_json");let n=await fetch(e.map_url).then(r=>r.json());return n.floor=e.floor,console.timeEnd("zstd_json"),this.setCacheData(Hn,t,n),this.setCacheData(zn,t,e.version_id),this.getDataByJson(n)}async getRoadNetworkData(){return(await Promise.all(this.floors.map(async t=>{let n=this.getFloorCacheKey(t);try{if(await this.getCacheData(kn,n)===t.version_id){let o=await this.getCacheData($e,n);if(o)return o}let i=await fetch(t.route_url).then(o=>o.json());return this.setCacheData($e,n,i),this.setCacheData(kn,n,t.version_id),i}catch{let r=await fetch(t.route_url).then(i=>i.json());return this.setCacheData($e,n,r),r}}))).filter(t=>t.points)}async getFacilitiesData(){let e=this.floors[0];if(!e)return null;let t=this.getFloorCacheKey(e),n=async()=>{let r=await fetch(e.entry_infra_url).then(i=>i.json());return r&&(this.setCacheData(Wn,t,r),this.setCacheData(Vn,t,e.version_id)),r};try{if(await this.getCacheData(Vn,t)===e.version_id){let i=await this.getCacheData(Wn,t);if(i)return i}return n()}catch(r){return console.log("[get facility error]",r),n()}}async getOtherDataByFreeTime(){}async getMulFloorsData(e){return Promise.all(e.map(t=>this.getFloorData(t))).then(t=>t.filter(n=>n))}async getDataByUrl(e){let t=await fetch(e).then(n=>n.json());return this.getDataByJson(t)}getDataByJson(e){let t=new ct(this.bmap.context);t.userData.graphics=[],t.userData.graphicMap=new Map;let n=[0,0];return e.layers.forEach(r=>{switch(r.l_type){case"range":let i=r.elements[0];n=[i.center_x,i.center_y];break;case"graph":X(r.elements,n);let o=[];r.elements.forEach(f=>{f.group==="ground"?t.createGround(f):o.push(f)});let a=o.reduce((f,g)=>{let{fillColor:E,fillOpacity:x,strokeColor:z,strokeOpacity:b,height:T,airHeight:k}=g,$=`${E.toLowerCase()}-${x}-${z.toLowerCase()}-${b}-${T}-${k}`;return b===0&&($=`${E.toLowerCase()}-${x}-${T}-${k}`),f[$]?f[$].push(g):f[$]=[g],f},{});Object.values(a).forEach(f=>{let g=new fe(this.bmap.context,f);t.mergeGraphicLayer.add(g)});break;case"ground":X(r.elements,n);let l=r.elements.map(f=>new R(this.bmap.context,f));t.addGrounds(l);break;case"wall":X(r.elements,n);let u=r.elements.reduce((f,g)=>{let{fillColor:E,fillOpacity:x,strokeColor:z,strokeOpacity:b,height:T}=g,k=`${E.toLowerCase()}-${x}-${z.toLowerCase()}-${b}-${T}`;return b===0&&(k=`${E.toLowerCase()}-${x}-${T}`),f[k]?f[k].push(g):f[k]=[g],f},{});Object.values(u).forEach(f=>{let g=new ce(this.bmap.context,f);t.wallLayer.add(g)});break;case"lane":X(r.elements,n);let c=r.elements.reduce((f,g)=>{let{fillColor:E,fillOpacity:x,strokeColor:z,strokeOpacity:b}=g,T=`${E.toLowerCase()}-${x}-${z.toLowerCase()}-${b}`;return b===0&&(T=`${E.toLowerCase()}-${x}`),f[T]?f[T].push(g):f[T]=[g],f},{});Object.values(c).forEach(f=>{let g=new pe(this.bmap.context,f);t.laneLayer.add(g)});break;case"texture2d":case"texture3d":if(X(r.elements,n),r.elements.length){let f=new qt(this.bmap.context,r.elements);t.textureLayer.add(f)}break;case"glb":X(r.elements,n),r.elements.forEach(f=>{let g=rt([f.center_x,f.center_y],n),E=new he(this.bmap.context,{...f,url:f.secondUrl,rotate:f.secondRotate,width:f.secondWidth,center_x:g[0],center_y:g[1]});t.glbModelLayer.add(E)});break;case"store":X(r.elements,n),r.elements.map(f=>{let g=rt([f.center_x,f.center_y],n),E=t.addGraphic(f);t.userData.graphics.push(E),t.userData.graphicMap.set(f.id,E);try{let x=new q(this.bmap.context,{id:f.id,icon:f.poi_info.icon,text:f.poi_info.showName||f.store_name||f.poi_info.text,position:{x:g[0],y:g[1],z:f.airHeight+f.height},icon_size:[18,18],level:f.poi_info.level||0});t.poiLayer2.pushPoi(x),x&&(x.userData.type="store",x.userData.data=f)}catch(x){console.log("\u521B\u5EFA\u5E97\u94FApoi\u5931\u8D25",x,f)}});break;case"facility":X(r.elements,n),r.elements.map(f=>{let g=rt([f.center_x,f.center_y],n),E=t.addGraphic(f);if(t.userData.graphics.push(E),t.userData.graphicMap.set(f.id,E),f.poi_info){let x=new q(this.bmap.context,{id:f.id,icon:f.poi_info.icon,text:f.poi_info.showName||f.store_name||f.poi_info.text,position:{x:g[0],y:g[1],z:f.airHeight+f.height},icon_size:[18,18],level:f.poi_info.level||0});t.poiLayer2.pushPoi(x),x.userData.type="facility",x.userData.data=f}else console.log("\u6DFB\u52A0facility\u5931\u8D25\u6CA1\u6709poi_info",f)});break;case"parkingSpace":X(r.elements,n);let h=[],p=new Map;r.elements.forEach(f=>{let g=t.addGraphic(f);h.push(g),p.set(f.id,g);let E=rt([f.center_x,f.center_y],n);if(f.texts[0]){let x=new q(this.bmap.context,{id:f.id,text:f.texts[0],position:{x:E[0],y:E[1],z:f.airHeight+f.height}});x&&(x.userData.type="parkingSpace",x.userData.data=f),t.poiLayer2.pushPoi(x)}});let d=r.elements.filter(f=>hi[f.parkingType]).map(f=>{let g=rt([f.center_x,f.center_y],n),E=en(f.geometry.coords,g);return{uuid:f.id,iconUrl:hi[f.parkingType],name:f.texts[0],deltaHeight:f.deltaHeight,airHeight:f.airHeight,height:f.height,geometry:{...f.geometry,coords:E},opacity:f.fillOpacity,visible:!0}});if(d.length){let f=new qt(this.bmap.context,d);t.textureLayer.add(f)}t.userData.parkingSpaces=h,t.userData.parkingSpacesGraphicMap=p;break;case"text":X(r.elements,n);let m=new de(this.bmap.context,r.elements.map(f=>{let g=rt([f.center_x,f.center_y],n);return{...f,center_x:g[0],center_y:g[1]}}));t.textTextureLayer.add(m);break}}),t.updateBox(),t.userData.center=n,t.userData.height=t.box.getSize(new pi.Vector3).z+e.floorHeight*10,t.name=e.floor,t.userData.data=e,t}async clear(){await this.initDbPromise.then(()=>si())}dispose(){this.clear()}};var qn=class{constructor(e){this.bmap=e}cacheData=new Map;floorDataLengthMap=new Map;buildingGroundMap=new Map;externalStreetMap=new Map;async load(e){let t=Lt(e);if(this.cacheData.has(t))return this.cacheData.get(t);let[,n]=await Promise.all([this.loadBuildGround(e),Bn(e,this.bmap.config)]),r=Lt({floor:e.floor,ts:e.ts});X(n.map(o=>o.info),this.bmap.buildingCenter,this.floorDataLengthMap.get(r)||0),n.forEach(o=>o.info.transformToBuildingGround=!1),this.cacheData.set(t,n);let i=this.floorDataLengthMap.get(r)||0;return this.floorDataLengthMap.set(r,i+n.length),this.loadExternalStreet(e),n}async loadExternalStreet(e){}switchFloorByData(e,t){if(!e.length)return;let n=t.userData.legacyToGraphicMap||new Map,r=t.userData.graphicMap||new Map,{ground:i,markGraphic:o,graphic:a}=this.bmap.config;for(let l=0;l<e.length;l++){let u=e[l];u.info.group==="ground"?(u.info.fillColor=i.color,u.info.fillOpacity=i.opacity,u.info.height=i.height,u.info.stroke=i.stroke,u.info.strokeColor=i.strokeColor,u.info.strokeOpacity=i.strokeOpacity):u.info.userData.mark?(u.info.height=o.height,u.info.fillColor=o.color,u.info.fillOpacity=o.opacity,u.info.stroke=o.stroke,u.info.strokeColor=o.strokeColor,u.info.strokeOpacity=o.strokeOpacity):(u.info.fillOpacity=a.fillOpacity,this.bmap.config.initTransToMark&&(u.info.height=o.height,u.info.fillColor=o.color,u.info.stroke=o.stroke,u.info.strokeColor=o.strokeColor,u.info.strokeOpacity=o.strokeOpacity))}for(let l of e){if(l.info.group==="ground")t.createGround(l.info);else{let u=t.addGraphic(l.info);u.userData.data=l,n.set(l.legacy_id,u)}r.set(l.element_uuid,l)}t.userData.legacyToGraphicMap=n,t.userData.graphicMap=r,t.updateBox(),t===this.bmap.context.currentFloor?(this.bmap.triggerHooks("switch_floor_before",{curFloor:t,graphics:t.graphicLayer.children}),this.bmap.initialFloorCamera(),this.bmap.triggerHooks("switch_floor_after",{curFloor:t,graphics:t.graphicLayer.children})):this.bmap.switchFloorByFloor(t)}filterData(e,t){let n=t.userData.graphicMap||new Map;return e.filter(r=>!n.has(r.element_uuid))}async switchFloorByStoreData(e,t){let n=await this.load({...e,resource_type_list:"6"}),r=this.filterData(n,t);this.switchFloorByData(r,t)}async switchFloorByOtherData(e,t){let n=await this.load({...e,resource_type_list:"1,2,3,4"}),r=this.filterData(n,t);this.switchFloorByData(r,t)}async loadBuildGround({brand:e,project:t}){let n=await this.loadBuildingGround({brand:e,project:t});return this.bmap.currentBuildGround=n,this.bmap.changeBuildingCenter(n,{brand:e,project:t}),this.bmap.currentBuildGround}async loadBuildingGround({brand:e,project:t}){let n=Lt({brand:e,project:t});if(this.buildingGroundMap.has(n))return this.buildingGroundMap.get(n);let r=Un({brand:e,project:t},this.bmap.config).then(i=>(this.buildingGroundMap.set(n,i),i));return this.buildingGroundMap.set(n,r),r}async switchFloor(e){let t=new ct(this.bmap.context);t.name=e.floor;try{await Promise.all([this.switchFloorByStoreData(e,t),this.switchFloorByOtherData(e,t)])}catch(n){console.log(n)}return t}dispose(){this.cacheData.clear(),this.floorDataLengthMap.clear(),this.buildingGroundMap.clear()}};
7534
+ `)}var Dn=class extends Jr.EventDispatcher{worker=Nn();initRoadStatus=!1;constructor(){super()}async setRoadData(e){this.initRoadStatus=!1,this.dispatchEvent({type:"init-road-status",status:!1}),await lt(this.worker,"set_road_info",{roadData:e}),this.initRoadStatus=!0,this.dispatchEvent({type:"init-road-status",status:!0})}async getPath(e,t,n=""){return new Promise((r,i)=>{let o=()=>{console.log("initRoadStatus",this.initRoadStatus),lt(this.worker,"get_path",{start:e,end:t,type:n}).then(a=>{a?typeof a=="string"?i(a):r(a):i("no-path")})};if(this.initRoadStatus)o();else{let a=({status:l})=>{l&&(this.removeEventListener("init-road-status",a),o())};this.addEventListener("init-road-status",a)}})}getDirectionPath(e){return lt(this.worker,"get_direction_path",e)}async dispose(){lt(this.worker,"clear",""),this.worker.terminate()}};var Qr=require("three"),Ve=class extends J{startPoint;endPoint;rect;frustum=new Qr.Frustum;constructor(e){super(e);let{config:{selectBox:{fill:t,stroke:n}}}=e;this.rect=mt(n,t),this.svg.appendChild(this.rect),this.registryEvent()}setEnable(e){super.setEnable(e),B(this.rect,0,0,0,0),e?this.registryEvent():(this.startPoint=void 0,this.unRegistryEvent())}onPointerDown=e=>{if(!this.enable)return;let t=this.getIntersectByPointerEvent(e);t&&(this.startPoint=t),this.endPoint=void 0};onPointerMove=e=>{if(!this.enable||!this.startPoint)return;let t=this.getIntersectByPointerEvent(e);t&&(this.endPoint=t)};onPointerUp=e=>{if(!this.enable)return;let t=this.getIntersectByPointerEvent(e);t&&(this.endPoint=t),this.doSelect(),this.startPoint=void 0};onUpdate=()=>{if(this.startPoint){let e=this.getSvgCoordinate(this.startPoint),t={...e};this.endPoint&&(t=this.getSvgCoordinate(this.endPoint));let n={x:Math.min(e.x,t.x),y:Math.min(e.y,t.y)},r=Math.abs(t.x-e.x),i=Math.abs(t.y-e.y);B(this.rect,n.x,n.y,r,i)}else B(this.rect,0,0,0,0)};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:t,container:{clientWidth:n,clientHeight:r}}}=this,i=y(this.startPoint,t,n,r),o=y(this.endPoint,t,n,r),a={x:Math.min(i.x,o.x),y:Math.min(i.y,o.y)},l={x:Math.max(i.x,o.x),y:Math.max(i.y,o.y)},u=this.searchMapInFrustum(a,l);this.dispatchEvent({type:"selected",list:u})}}searchMapInFrustum(e,t){let{context:n}=this;return n.currentFloor?.graphicLayer.children.filter(r=>r instanceof R&&this.searchChildInFrustum(r,e,t))||[]}searchChildInFrustum(e,t,n){let{context:{camera:r,container:{clientWidth:i,clientHeight:o}}}=this;if(!e)return!1;if(!e.mesh){let p=e.getPosition();if(p){let d=y(p,r,i,o);return gt(d,t,n)}return!1}e.mesh.geometry.boundingBox||e.mesh.geometry.computeBoundingBox();let a=e.mesh.geometry.boundingBox;if(!a)return!1;let{min:l,max:u}=a,c=y(l,r,i,o),h=y(u,r,i,o);return!(!gt(c,t,n)||!gt(h,t,n))}dispose(){this.unRegistryEvent()}};var ji={boxSelection:!1,elements:["graphic","poi"]},On=class extends dt{options;_list=new Set;_poiList=new Set;boxSelection;prevPanStatus;prevRotateStatus;downPoint=null;isMultipleSelect=!1;constructor(e,t={}){super(e),this.options={...ji,...t},this.boxSelection=new Ve(this.bmap.context),this.boxSelection.setEnable(!1),this.registryEvent()}get list(){return this._list}enableBoxSelection(){this.isMultipleSelect||!this.options.boxSelection||(this.isMultipleSelect=!0,this.boxSelection.setEnable(!0),this.prevPanStatus=this.bmap.context.control.enablePan,this.prevRotateStatus=this.bmap.context.control.enableRotate,this.bmap.context.control.enablePan=!1,this.bmap.context.control.enableRotate=!1)}disableBoxSelection(){this.isMultipleSelect&&(this.isMultipleSelect=!1,this.boxSelection.setEnable(!1),this.bmap.context.control.enablePan=!!this.prevPanStatus,this.bmap.context.control.enableRotate=!!this.prevRotateStatus)}onPointerDown=e=>{this.downPoint={x:e.offsetX,y:e.offsetY}};onPointerUp=e=>{if(!this.downPoint)return;let{offsetX:t,offsetY:n}=e,{x:r,y:i}=this.downPoint;if(Math.sqrt((r-t)**2+(i-n)**2)>3)return;let o=new Set,a=[],l=[];if(this.options.elements.includes("graphic")){let{graphics:u}=this.bmap.context.getGraphicsByDeviceXy(t,n);u.map(c=>o.add(c.options.id)),a.push(...u)}if(this.options.elements.includes("poi")){let u=this.bmap.context.getPoisByDeviceXy(t,n);l.push(...u),u.forEach(c=>{if(!o.has(c.options.id)){let h=this.bmap.context.currentFloor?.graphicLayer.graphicMap.get(c.options.id)||null;h&&(o.add(c.options.id),a.push(h))}})}(!this.options.boxSelection||!(It?e.metaKey:e.ctrlKey))&&(this._list.clear(),this._poiList.clear()),a.forEach(u=>this._list.add(u)),l.forEach(u=>this._poiList.add(u)),this.selectEnd(),this.downPoint=null};onPointerOut=e=>{this.disableBoxSelection()};onKeyDown=e=>{Rt(e.key)&&this.enableBoxSelection()};onKeyUp=e=>{Rt(e.key)&&this.disableBoxSelection()};onBoxSelected=({list:e})=>{this._list.clear(),this._poiList.clear(),e.forEach(t=>{if(this.options.elements.includes("graphic")&&this._list.add(t),this.options.elements.includes("poi")){let n=this.bmap.getPoiById(t.options.id);n&&this._poiList.add(n)}}),this.selectEnd()};selectEnd(){this.dispatchEvent({type:"select",graphics:[...this._list],pois:[...this._poiList],isMultipleSelect:this.isMultipleSelect})}registryEvent(){this.bmap.context.container.addEventListener("pointerdown",this.onPointerDown),this.bmap.context.container.addEventListener("pointerup",this.onPointerUp),this.bmap.context.container.addEventListener("pointerout",this.onPointerOut),this.bmap.context.container.addEventListener("pointercancel",this.onPointerOut),window.addEventListener("keydown",this.onKeyDown),window.addEventListener("keyup",this.onKeyUp),this.boxSelection.addEventListener("selected",this.onBoxSelected)}unRegistryEvent(){this.bmap.context.container.removeEventListener("pointerdown",this.onPointerDown),this.bmap.context.container.removeEventListener("pointerup",this.onPointerUp),this.bmap.context.container.removeEventListener("pointerout",this.onPointerOut),this.bmap.context.container.removeEventListener("pointercancel",this.onPointerOut),window.removeEventListener("keydown",this.onKeyDown),window.removeEventListener("keyup",this.onKeyUp),this.boxSelection.removeEventListener("selected",this.onBoxSelected)}clear(){this._list.clear()}remove(e){this._list.delete(e)}dispose(){this.unRegistryEvent()}};var Y=require("lodash");var ei=require("three");var Yi={time:1e3,elements:["compass","deviceMotion","acceleration","gps"]},Ee=class extends ei.EventDispatcher{options;gpsTimer=null;data=[];timer=new D;dispatchTimer=null;constructor(e={}){super(),this.options={...Yi,...e}}start(){this.options.elements.some(e=>["deviceMotion","compass"].includes(e))&&this.listenDeviceOrientation(),this.options.elements.includes("acceleration")&&this.listenAcceleration(),this.options.elements.includes("gps")&&this.listenGps(),this.dispatchEvent({type:"start"}),this.dispatchTimer=this.timer.setInterval(()=>{this.dispatchEvent({type:"sensor-data",data:(0,Y.cloneDeep)(this.data)}),this.data=[]},this.options.time)}addDataItem(e){this.data.push(e),this.dispatchEvent({type:"add-data-item",item:e})}addAcceleration=(0,Y.throttle)(e=>{this.addDataItem(e)},20);deviceOrientationAbsHandler=(0,Y.throttle)(e=>{let t=Date.now(),{alpha:n,beta:r,gamma:i}=e;if((0,Y.isNil)(n)||(0,Y.isNil)(r)||(0,Y.isNil)(i))return;let o;Ht?o=e.webkitCompassHeading:o=360-n,this.options.elements.includes("deviceMotion")&&this.addDataItem({type:"deviceMotion",timestamp:t,res:[n,r,i]}),this.options.elements.includes("compass")&&this.addDataItem({type:"compass",timestamp:t,res:o})},200);listenDeviceOrientation(){Ht?window.addEventListener("deviceorientation",this.deviceOrientationAbsHandler,!1):window.addEventListener("deviceorientationabsolute",this.deviceOrientationAbsHandler,{absolute:!0})}handleAcceleration=e=>{let t=e.accelerationIncludingGravity;(0,Y.isNil)(t)||(0,Y.isNil)(t.x)||(0,Y.isNil)(t.y)||(0,Y.isNil)(t.z)||this.addAcceleration({type:"acceleration",timestamp:Date.now(),res:[t.x,t.y,t.z]})};listenAcceleration(){window.addEventListener("devicemotion",this.handleAcceleration,!1)}listenGps(){this.gpsTimer=navigator.geolocation.watchPosition(e=>{e.coords.accuracy<=10&&this.addDataItem({type:"gps",timestamp:Date.now(),res:[e.coords.longitude,e.coords.latitude,e.coords.accuracy]})})}async checkSensor(){return{deviceOrientation:await this.checkDeviceOrientation()}}async checkDeviceOrientation(){if(!Ht)return!0;if(typeof window.DeviceOrientationEvent<"u"&&typeof window.DeviceOrientationEvent?.requestPermission=="function")try{return await window.DeviceOrientationEvent?.requestPermission()==="granted"}catch{return!1}return!1}stop(){window.removeEventListener("devicemotion",this.handleAcceleration,!1),Ht?window.removeEventListener("deviceorientation",this.deviceOrientationAbsHandler,!1):window.removeEventListener("deviceorientationabsolute",this.deviceOrientationAbsHandler,{absolute:!0}),(0,Y.isNil)(this.gpsTimer)||navigator.geolocation.clearWatch(this.gpsTimer),this.dispatchTimer&&this.timer.clearInterval(this.dispatchTimer),this.data=[],this.dispatchEvent({type:"stop"})}};var ri=require("three");function He(s,e){return 1/Math.sqrt(2*Math.PI*Math.pow(e,2))*Math.exp(-Math.pow(s,2)/(2*Math.pow(e,2)))}function be(s){return(s+360)%360}function ni(s,e){let n=6378137*s*Math.PI/180,r=6378137*Math.log(Math.tan(Math.PI/4+e*Math.PI/180/2));return{x:n,y:r}}function $t(s,e,t,n){return Math.sqrt(Math.pow(Math.abs(s-t),2)+Math.pow(Math.abs(e-n),2))}var Xe=Zt(require("mathjs"),1),We=class{NumParticle;reSampNumParticle;initial_xy_uncertainty;initial_yaw_uncertainty;step_noise_sigma;yaw_noise_sigma;compass_update_interval;sigmaCompass;delta_yaw;sigmaBeacon;unaccess_weight;particle_PosInitFlag;particle_yawInitFlag;xEst;particleX;particleWeight;last_compass_time;last_yaw_compass=0;compass_consecutive_offset_count=0;constructor(e){this.NumParticle=e.NumParticle,this.reSampNumParticle=e.reSampNumParticle,this.initial_xy_uncertainty=e.initial_xy_uncertainty,this.initial_yaw_uncertainty=e.initial_yaw_uncertainty,this.step_noise_sigma=e.step_noise_sigma,this.yaw_noise_sigma=e.yaw_noise_sigma,this.compass_update_interval=e.compass_update_interval,this.sigmaCompass=e.sigmaCompass,this.delta_yaw=e.delta_yaw,this.sigmaBeacon=e.sigmaBeacon,this.unaccess_weight=e.unaccess_weight,this.particle_PosInitFlag=!1,this.particle_yawInitFlag=!1,this.xEst=[[0],[0],[0]],this.particleX=Array.from({length:3},()=>Array(this.NumParticle).fill(0)),this.particleWeight=Array.from({length:1},()=>Array(this.NumParticle).fill(1/this.NumParticle)),this.last_compass_time=0}motionModelRotYaw(e){if(!(Math.abs(e)<.001)){this.last_yaw_compass=be(this.last_yaw_compass+e);for(let t=0;t<this.NumParticle;t++){let n=Math.random()*this.yaw_noise_sigma;this.particleX[2][t]=this.particleX[2][t]+e+n,this.particleX[2][t]=be(this.particleX[2][t])}}}motionModelStepLength(e,t){if(e===0)return;for(let r=0;r<this.NumParticle;r++){let i=Math.random()*this.step_noise_sigma;this.particleX[0][r]+=(.65+i)*Math.sin(-this.particleX[2][r]/180*Math.PI),this.particleX[1][r]+=(.65+i)*Math.cos(this.particleX[2][r]/180*Math.PI),t(this.particleX[0][r],this.particleX[1][r])||(this.particleWeight[0][r]*=this.unaccess_weight)}let n=this.particleWeight[0].reduce((r,i)=>r+i,0);this.particleWeight[0]=this.particleWeight[0].map(r=>r/n)}motionModelCompassYaw(e,t){if(t-this.last_compass_time>this.compass_update_interval){let n=360-e;n+=this.delta_yaw,n=be(n),Math.abs(n-this.last_yaw_compass)>60?this.compass_consecutive_offset_count++:this.compass_consecutive_offset_count=0;for(let i=0;i<this.NumParticle;i++){let o=Math.abs(this.particleX[2][i]-n);o>180&&(o=360-o),this.particleWeight[0][i]*=He(o,this.sigmaCompass)}let r=this.particleWeight[0].reduce((i,o)=>i+o,0);this.particleWeight[0]=this.particleWeight[0].map(i=>i/r),this.setLastCompassTime(t)}}resampling(){if(1/this.particleWeight[0].reduce((t,n)=>t+n*n,0)<this.reSampNumParticle){let t=this.particleWeight[0].reduce((a,l,u)=>a.concat(a[u]+l),[0]),r=this.particleWeight[0].map(()=>1/this.NumParticle).map((a,l)=>a+Math.random()/this.NumParticle),i=[],o=0;for(let a=0;a<this.NumParticle;a++){for(;r[a]>t[o];)o++;i.push(o)}this.particleX=this.particleX.map((a,l)=>i.map(u=>a[u])),this.particleWeight[0]=Array(this.NumParticle).fill(1/this.NumParticle)}}update(e,t){for(let r=0;r<this.NumParticle;r++){let i=$t(this.particleX[0][r],this.particleX[1][r],e.x,e.y);this.particleWeight[0][r]=Math.max(1e-7,this.particleWeight[0][r]*He(i,t))}let n=this.particleWeight[0].reduce((r,i)=>r+i,0);this.particleWeight[0]=this.particleWeight[0].map(r=>r/n)}updateCar(e,t){let n=e.x-this.xEst[0][0],r=e.y-this.xEst[1][0];for(let o=0;o<this.NumParticle;o++){let a=$t(this.particleX[0][o],this.particleX[1][o],e.x,e.y);this.particleWeight[0][o]=Math.max(1e-7,this.particleWeight[0][o]*He(a,t)),this.particleX[0][o]+=n,this.particleX[1][o]+=r}let i=this.particleWeight[0].reduce((o,a)=>o+a,0);this.particleWeight[0]=this.particleWeight[0].map(o=>o/i)}getPosInitFlag(){return this.particle_PosInitFlag}getYawInitFlag(){return this.particle_yawInitFlag}setPosInitFlag(e){this.particle_PosInitFlag=e}setYawInitFlag(e){this.particle_yawInitFlag=e}getResultX(){let e=Xe.reshape(this.particleWeight,[this.NumParticle,1]),t=Xe.multiply(this.particleX,e);return this.xEst=t,this.xEst[0][0]}getResultY(){return this.xEst[1][0]}getResultYaw(){let e=this.particleWeight[0].indexOf(Math.max(...this.particleWeight[0]));return this.particleX[2][e]}getEstConfidence(){let e=this.particleWeight[0].indexOf(Math.max(...this.particleWeight[0])),t=this.particleWeight[0].indexOf(Math.min(...this.particleWeight[0])),n=[this.particleX[0][e],this.particleX[1][e]],r=[this.particleX[0][t],this.particleX[1][t]],i=$t(n[0],n[1],r[0],r[1]),o=i*.67;return console.log(i,o),o}getParticleNum(){return this.NumParticle}getParticleX(){return this.particleX}setLastCompassTime(e){this.last_compass_time=e}getLastCompassTime(){return this.last_compass_time}initParticlesByPos(e,t,n){if(!this.particle_PosInitFlag){this.particleWeight[0]=Array(this.NumParticle).fill(1/this.NumParticle);let r=0;for(;r<this.NumParticle;){let o=(2*Math.random()-1)*this.initial_xy_uncertainty,a=(2*Math.random()-1)*this.initial_xy_uncertainty;n(e+o,t+a)||(this.particleWeight[0][r]*=this.unaccess_weight),this.particleX[0][r]=e+o,this.particleX[1][r]=t+a,r++}let i=this.particleWeight[0].reduce((o,a)=>o+a,0);this.particleWeight[0]=this.particleWeight[0].map(o=>o/i),this.particle_PosInitFlag=!0,this.xEst[0][0]=e,this.xEst[1][0]=t,this.xEst[2][0]=0}}initParticlesByCompass(e){console.log(`Init compass: ${e}`);let t=360-e;t+=this.delta_yaw,t=be(t),console.log(`Init Yaw: ${t}`);for(let n=0;n<this.NumParticle;n++){let r=(2*Math.random()-1)*this.initial_yaw_uncertainty;this.particleX[2][n]=t+r}this.particle_yawInitFlag=!0,this.xEst[2][0]=t,this.last_yaw_compass=t,this.compass_consecutive_offset_count=0}};var je=Zt(require("mathjs"),1),qe=class{fre=100;accH_fifo=[];accH_time_fifo=[];accH_fifo_len=Math.floor(1*this.fre)+1;step_count=0;state_count=0;last_valley_time=0;last_peak_time=0;last_step_time=0;min_step_time=.3;max_step_time=1;min_peak=10.5;max_valley=9.5;peak_num=0;valley_num=0;fft_min_amp=.3;fft_min_fre=0;fft_max_fre=4;last_fft_amp=0;abnor_start_time=0;abnor_fft_detected=!1;abnor_time_threshold=4;abnor_peak_time=0;abnor_peak_accH=0;const_step_length=.65;last_rot=[];delta_rot=[];last_yaw=0;delta_yaw=null;delta_rot_sum_fifo=[];delta_rot_sum_time_fifo=[];delta_yaw_accum=0;delta_yaw_accum_timestamp=0;delta_yaw_time_threshold=.5;last_px=0;last_py=0;delta_px=0;delta_py=0;init(){this.fre=100,this.accH_fifo=[],this.accH_time_fifo=[],this.accH_fifo_len=Math.floor(1*this.fre)+1,this.step_count=0,this.state_count=0,this.last_valley_time=0,this.last_peak_time=0,this.last_step_time=0,this.min_step_time=.3,this.max_step_time=1,this.min_peak=10+.5,this.max_valley=10-.5,this.peak_num=0,this.valley_num=0,this.fft_min_amp=.3,this.fft_min_fre=0,this.fft_max_fre=4,this.last_fft_amp=0,this.abnor_start_time=0,this.abnor_fft_detected=!1,this.abnor_peak_time=0,this.abnor_peak_accH=0,this.const_step_length=.65,this.last_rot=[0,0,0],this.delta_rot=[0,0,0],this.last_yaw=0,this.delta_yaw=null,this.delta_rot_sum_fifo=[],this.delta_rot_sum_time_fifo=[],this.delta_yaw_accum=0,this.delta_yaw_accum_timestamp=0,this.delta_yaw_time_threshold=.5,this.last_px=0,this.last_py=0,this.delta_px=0,this.delta_py=0}reset(){this.init()}setInitPose(e=[0,0]){this.last_px=e[0],this.last_py=e[1],console.info(`pdr init pos: ${this.last_px}, ${this.last_py}`)}setInitYaw(e=0){this.last_yaw=e}getPos(e,t,n){let r=0;return n.length===3&&(this.delta_yaw=this.getDeltaYawFromRot(e,n)),t.length===3&&(r=this.getStepLength(e,t)),r!==0&&(this.last_px+=this.delta_px,this.last_py+=this.delta_py),[this.last_px,this.last_py]}getDeltaPose(){return[this.delta_px,this.delta_py]}getStepLength(e,t){if(t.length<3)return console.warn("acc data less than 3"),0;let n=!1,r=Math.sqrt(Math.pow(t[0],2)+Math.pow(t[1],2)+Math.pow(t[2],2));if(this.accH_fifo.push(r),this.accH_time_fifo.push(e),this.imuFreUpdate(),this.accH_fifo.length<this.accH_fifo_len+1)n=!1;else{for(;this.accH_fifo.length>=this.accH_fifo_len+1;)this.accH_fifo.shift(),this.accH_time_fifo.shift();let i=this.PVStepDetec(),o=this.FFTStepDetec(),a=this.recheckState(),l=this.accH_time_fifo[Math.floor(this.accH_time_fifo.length*3/4)];Math.abs(this.abnor_start_time)<.001&&this.abnor_fft_detected?this.abnor_start_time=l:this.abnor_fft_detected||(this.abnor_start_time=0),i&&o&&a?(this.step_count+=1,this.last_step_time=l,n=!0):Math.abs(this.abnor_start_time)>.001&&this.abnor_peak_time-this.abnor_start_time>this.abnor_time_threshold&&this.step_count>1&&this.abnor_peak_time-this.last_step_time>1?(this.step_count+=1,this.last_step_time=l,n=!0):(l-this.last_step_time>2&&(this.state_count=0),n=!1)}if(n){let i=this.last_yaw/180*Math.PI;return this.delta_px=this.const_step_length*Math.cos(i),this.delta_py=this.const_step_length*Math.sin(i),this.const_step_length}else return 0}imuFreUpdate(){if(this.accH_time_fifo.length>2&&(this.accH_time_fifo[this.accH_time_fifo.length-1]-this.accH_time_fifo[this.accH_time_fifo.length-2]<0||this.accH_time_fifo[this.accH_time_fifo.length-1]-this.accH_time_fifo[this.accH_time_fifo.length-2]>10||this.accH_time_fifo[this.accH_time_fifo.length-1]===this.accH_time_fifo[0])&&(console.warn(`pdr reset last one time ${this.accH_time_fifo[this.accH_time_fifo.length-1]} last two time ${this.accH_time_fifo[this.accH_time_fifo.length-2]}`),this.reset()),this.accH_fifo.length>9||this.fre<15){let e=(this.accH_fifo.length-1)/(this.accH_time_fifo[this.accH_time_fifo.length-1]-this.accH_time_fifo[0]);Math.abs(this.fre-e)>8&&(this.fre=Math.round((e-3)/10)*10,(this.fre<=10||this.fre>=100)&&(console.warn(`Frequency Error ${this.fre}`),this.fre=100),console.debug(`Frequency change to ${this.fre}`),this.accH_fifo_len=Math.floor(1*this.fre)+1)}}recheckState(){return!0}PVStepDetec(){let e=!1,t=this.accH_fifo.slice(Math.floor(this.accH_fifo_len/2)),n=this.accH_time_fifo.slice(Math.floor(this.accH_fifo_len/2)),r=t[Math.floor(t.length/2)],i=n[Math.floor(n.length/2)],o=Math.max(...t),a=Math.min(...t),l=!1,u=!1;return Math.abs(r-a)<.01&&r<this.max_valley&&this.valley_num<=this.peak_num&&(this.last_valley_time===0?u=!0:u=i-this.last_valley_time>this.min_step_time,u&&(this.last_valley_time=i,this.valley_num+=1)),Math.abs(r-o)<.01&&r>this.min_peak&&this.peak_num<=this.valley_num&&(this.last_peak_time===0?l=!0:l=i-this.last_peak_time>this.min_step_time,l&&(this.last_peak_time=i,this.peak_num+=1)),r===o&&r>this.min_peak&&(this.abnor_peak_time=i,this.abnor_peak_accH=r),this.peak_num===this.valley_num&&(l||u)&&(e=!0),e}FFTStepDetec(){return!0}getDeltaYawFromRot(e,t){if(t.length<3)return console.warn("rot data less than 3"),0;let n=[0,0,0];this.last_rot.length===3&&(n=t.map((a,l)=>a-this.last_rot[l]));for(let a=0;a<t.length;a++)n[a]<-180?n[a]+=360:n[a]>180&&(n[a]-=360);let r=.2;this.delta_rot.length===3?this.delta_rot=this.delta_rot.map((a,l)=>r*a+(1-r)*n[l]):this.delta_rot=n,this.last_rot=t,this.delta_yaw=this.delta_rot[0],this.last_yaw+=this.delta_yaw,this.last_yaw=this.limitYaw(this.last_yaw);let i=this.delta_rot.reduce((a,l)=>a+Math.abs(l),0);this.delta_rot_sum_fifo.push(i),this.delta_rot_sum_time_fifo.push(e),Math.abs(this.delta_rot_sum_time_fifo[this.delta_rot_sum_time_fifo.length-1]-this.delta_rot_sum_time_fifo[0])>1&&(this.delta_rot_sum_fifo.shift(),this.delta_rot_sum_time_fifo.shift()),this.delta_yaw_accum+=this.delta_yaw;let o=0;return Math.abs(this.delta_yaw_accum_timestamp-e)>this.delta_yaw_time_threshold?(o=this.delta_yaw_accum,this.delta_yaw_accum=0,this.delta_yaw_accum_timestamp=e,o):null}limitYaw(e){for(;e<-180;)e+=360;for(;e>180;)e-=360;return e}};var Ye=class{particleFilter;pdr;sigmaBeacon=5;gps_horizontalAccuracy=10;using_gps=!0;last_beacon_time=null;last_pos_time;position_count=0;gps_max_horizontalAccuracy=20;MaxEstimateErr=5;outTrustRegionNum=0;TrustNum=4;cacheSensorData=[];constructor(){this.particleFilter=new We({NumParticle:200,reSampNumParticle:.65,initial_xy_uncertainty:12,initial_yaw_uncertainty:100,step_noise_sigma:.5,yaw_noise_sigma:2,compass_update_interval:3e3,sigmaCompass:80,delta_yaw:2,sigmaBeacon:5,unaccess_weight:.7}),this.pdr=new qe}pfFusionPDRiBeacon(e){let{type:t,timestamp:n,res:r}=e,i=!1;if(this.particleFilter.getPosInitFlag()&&this.particleFilter.getYawInitFlag()){if(t==="acceleration"){let o=r,a=this.pdr.getStepLength(n/1e3,o);a!==0&&(this.particleFilter.motionModelStepLength(a,()=>!0),this.particleFilter.resampling(),this.position_count+=1,i=!0)}if(this.using_gps&&t==="gps"&&(this.last_beacon_time===null||n-this.last_beacon_time>5e3)){let o=this.getGpsPosition(r);i=o!==null,o&&(this.particleFilter.update(o,this.gps_horizontalAccuracy),this.resetParticleFilterDist(o),this.particleFilter.resampling(),this.position_count+=1)}if(t==="deviceMotion"){let o=this.pdr.getDeltaYawFromRot(n/1e3,r);o!==null&&this.particleFilter.motionModelRotYaw(o)}t==="compass"&&this.particleFilter.motionModelCompassYaw(r,n),this.last_pos_time&&n-this.last_pos_time>500&&(this.position_count+=1,i=!0)}else if(!this.particleFilter.getPosInitFlag()&&this.using_gps&&t==="gps"){let o=this.getGpsPosition(r);i=o!==null,o?(this.particleFilter.initParticlesByPos(o.x,o.y,()=>!0),this.last_pos_time=n,console.log(`init Pos by gps success time ${n}`),this.cacheSensorData.length=0):console.log(`init Pos by gps fail time ${n}`)}else if(!this.particleFilter.getYawInitFlag()&&t==="compass"){let o=r;this.particleFilter.initParticlesByCompass(o),this.particleFilter.setLastCompassTime(n),console.log(`init yaw by compass success time ${n}`)}else this.cacheSensorData.push(e);return i&&(this.last_pos_time=n),[i,this.particleFilter.getResultX(),this.particleFilter.getResultY()]}setBeaconPosition(e,t){return this.last_beacon_time=t,this.particleFilter.getPosInitFlag()?this.particleFilter.update(e,this.sigmaBeacon):this.particleFilter.initParticlesByPos(e.x,e.y,()=>!0),this.resetParticleFilterDist(e),this.particleFilter.resampling(),this.position_count+=1,this.cacheSensorData.filter(r=>r.timestamp>t).map(r=>this.pfFusionPDRiBeacon(r)),this.cacheSensorData.length=0,[this.particleFilter.getResultX(),this.particleFilter.getResultY()]}getGpsPosition(e){return e[2]>this.gps_max_horizontalAccuracy?null:ni(e[0],e[1])}resetParticleFilterDist(e){let t=this.particleFilter.getResultX(),n=this.particleFilter.getResultY();$t(t,n,e.x,e.y)>this.MaxEstimateErr?(this.outTrustRegionNum+=1,this.outTrustRegionNum>=this.TrustNum&&(console.info(`\u8D85\u51FA\u53EF\u4FE1\u533A\u57DF\uFF0C\u91CD\u7F6E\u7C92\u5B50\u8FC7\u6EE4\u5668\u5230: ${e.x}, ${e.y}`),this.particleFilter.setPosInitFlag(!1),this.particleFilter.setYawInitFlag(!1),this.outTrustRegionNum=0)):this.outTrustRegionNum=0}};var Fn=class extends ri.EventDispatcher{sensor;pdr;_pause=!1;constructor(e={}){super(),this.sensor=new Ee(e.sensor),this.pdr=new Ye}checkSensor(){return this.sensor.checkSensor()}start(){this.sensor.start(),this.sensor.addEventListener("add-data-item",({item:e})=>{this.getPositionBySensorItem(e,!this._pause)})}pause(){this._pause=!0}continue(){this._pause=!1}getPositionBySensorItem(e,t=!0){let[n,r,i]=this.pdr.pfFusionPDRiBeacon(e);return n&&t&&this.dispatchEvent({type:"position",x:r,y:i,_type:e.type==="gps"?"gps":"pdr"}),[n,r,i]}setBeaconPosition(e,t){let[n,r]=this.pdr.setBeaconPosition(e,t);this.dispatchEvent({type:"position",x:n,y:r,_type:"beacon"})}dispose(){this.sensor.stop()}};async function Un({brand:s,project:e},t){let{apiDomain:n,apiPath:{floorRange:r},apiInfo:i}=t,o=`${n}${r}?brand=${s}&project=${e}&phase=${e}&building=${e}`;return await fetch(o,i).then(l=>l.json()).then(l=>l.data).then(l=>{let u=(l||[])[0];return u&&(u.info=JSON.parse(u.info)),u})}async function Bn({brand:s,project:e,floor:t,ts:n,resource_type_list:r},i){let{apiDomain:o,apiPath:{floorGraphic:a},apiInfo:l}=i,u=`${o}${a}?brand=${s}&project=${e}&phase=${e}&building=${e}&floor=${t}&ts=${n}&resource_type_list=${r}`;return await fetch(u,l).then(h=>h.json()).then(h=>h.data).then(h=>((h||[]).map(p=>p.info=JSON.parse(p.info)),h||[]))}async function $i({project:s,floor:e},t){let{apiDomain:n,apiInfo:r}=t,i=`${n}/api/inception-map/external_street/get?projectCode=${s}&floorCode=${e}`;return await fetch(i,r).then(a=>a.json()).then(a=>a.data).then(a=>JSON.parse(a[0].streetInfo||"{}")).then(a=>a.fileId?Ki(a.fileId,t):null)}async function Ki(s,e){let{apiDomain:t,apiInfo:n}=e;return fetch(`${t}/api/inception-map/file/getFileStream?fileId=${s}`,n).then(r=>r.arrayBuffer()).then(r=>{let o=new TextDecoder("utf-8").decode(r);return o?JSON.parse(o):null})}var ht;function ii(s="aibee_map",e=1){return new Promise((t,n)=>{if(ht)return t({db:ht,type:"success"});let r=indexedDB.open(s,e);r.onupgradeneeded=function(i){ht=i.target.result,console.log("onupgradeneeded"),t({db:ht,type:"onupgradeneeded"})},r.onsuccess=i=>{ht=i.target.result,t({db:ht,type:"success"})},r.onerror=i=>{n(i)}})}function Gn(s,e,t=ht){return new Promise((n,r)=>{t||r("\u6CA1\u6709db");let o=t.transaction([s],"readonly").objectStore(s).get(e);o.onsuccess=()=>{o.result?n(o.result.value):n(null)},o.onerror=a=>{console.log("[getVersionByKey]",a),n(null)}})}function oi(s,e,t,n=ht){return new Promise((r,i)=>(n||i("\u6CA1\u6709db"),new Promise(async(o,a)=>{let l=await Gn(s,e),u=n.transaction([s],"readwrite").objectStore(s),c=l!==null?u.put({key:e,value:t}):u.add({key:e,value:t});c.onsuccess=function(h){o(h)},c.onerror=function(h){a(h)}})))}function zt(s,e=ht){e&&(e.objectStoreNames.contains(s)||e.createObjectStore(s,{keyPath:"key"}))}function si(s=ht){s?.close(),ht=null}var ai="";var li="";var ui="";var ci='data:image/svg+xml,<svg viewBox="12 22 54 38" xmlns="http://www.w3.org/2000/svg">%0A%09<g fill="%23ffffff">%0A%09%09<path fill-opacity="1" stroke-width="0.2" stroke-linejoin="round" d="M 14.25,32.165L 20.479,49.0255L 25.7981,49.0255L 32.1671,32.165L 26.568,32.165L 24.3633,39.9922C 23.9959,41.4233 23.681,42.8056 23.4185,44.139L 23.3135,44.139C 23.0569,42.8182 22.7303,41.4454 22.3337,40.0207L 20.0241,32.165L 14.25,32.165 Z "/>%0A%09%09<path fill-opacity="1" stroke-width="0.2" stroke-linejoin="round" d="M 39.915,49.0255L 39.915,32.165L 34.6763,32.165L 34.6763,49.0255L 39.915,49.0255 Z M 37.4891,24.4171C 36.6275,24.4336 35.946,24.6849 35.4446,25.1711C 34.9433,25.6573 34.6872,26.2791 34.6763,27.0366C 34.6865,27.7789 34.9353,28.3964 35.4229,28.8889C 35.9105,29.3814 36.5761,29.637 37.4196,29.6557C 38.3131,29.637 39.0091,29.3814 39.5075,28.8889C 40.006,28.3964 40.2592,27.7789 40.2677,27.0366C 40.2426,26.2791 39.9879,25.6573 39.5032,25.1711C 39.0185,24.6849 38.3471,24.4336 37.4891,24.4171 Z "/>%0A%09%09<path fill-opacity="1" stroke-width="0.2" stroke-linejoin="round" d="M 44.1851,56.0691L 49.4238,56.0691L 49.4238,47.5447L 49.4957,47.5447C 49.8997,48.0793 50.4949,48.5157 51.2811,48.854C 52.0674,49.1922 52.9953,49.3668 54.0649,49.3777C 56.0656,49.3912 57.8266,48.6768 59.3479,47.2346C 60.8692,45.7923 61.6699,43.5413 61.75,40.4814C 61.6918,37.7576 60.9918,35.6378 59.6502,34.122C 58.3085,32.6062 56.6746,31.8365 54.7485,31.8126C 52.1604,31.842 50.213,32.7675 48.9065,34.5891L 48.8375,34.5891L 48.5963,32.165L 44.0443,32.165C 44.1264,33.761 44.1734,35.6713 44.1851,37.8958L 44.1851,56.0691 Z M 49.4238,39.5729C 49.4238,39.272 49.4598,38.971 49.5317,38.6699C 49.7288,37.8746 50.1261,37.2334 50.7235,36.7462C 51.3209,36.2591 52.0149,36.0087 52.8057,35.9949C 54.0304,36.0239 54.9538,36.4784 55.576,37.3585C 56.1981,38.2386 56.5099,39.3704 56.5114,40.7541C 56.5024,42.2152 56.1696,43.3745 55.513,44.2321C 54.8564,45.0896 53.93,45.5282 52.7337,45.5477C 51.9302,45.5325 51.2437,45.2937 50.674,44.8313C 50.1044,44.3689 49.7236,43.774 49.5317,43.0467C 49.4598,42.7109 49.4238,42.3404 49.4238,41.9352L 49.4238,39.5729 Z "/>%0A%09</g>%0A</svg>%0A';var pi=require("three"),eo={loadRoadNetwork:!1},zn="map_version",kn="route_version",Vn="facility_version",Hn="map_data",$e="road_network_data",Wn="facility_data",hi={half:ai,power:li,mechanical:ui,vip:ci},Xn=class{constructor(e){this.bmap=e;this.initDbPromise=this.initDb()}floors=[];initDbPromise=Promise.resolve();db=null;async initDb(){try{let{db:e,type:t}=await ii("aibee_map",2);t==="onupgradeneeded"&&(zt(zn),zt(kn),zt(Vn),zt(Hn),zt($e),zt(Wn)),this.db=e}catch(e){console.log("[\u6253\u5F00indexDb\u9519\u8BEF]",e)}}async load(e){if(Array.isArray(e))this.floors=e;else{let t=await fetch(e).then(n=>n.json());t.code==="0"&&(this.floors=t.data.list)}}setCacheData(e,t,n){return this.initDbPromise.then(()=>oi(e,`${t}`,n,this.db))}getCacheData(e,t){return this.initDbPromise.then(()=>Gn(e,`${t}`,this.db))}getFloorCacheKey(e){return`${e.floor_id}`}async getFloorData(e){let t=this.floors.find(r=>r.floor===e);if(!t)return null;let n=this.getFloorCacheKey(t);try{if(await this.getCacheData(zn,n)===t.version_id){let i=await this.getCacheData(Hn,n);if(i)return this.getDataByJson(i)}return this.getFloorDataByFloorInfo(t)}catch(r){return console.log("[get floor data error]",r),this.getFloorDataByFloorInfo(t)}}async getFloorDataByFloorInfo(e){let t=this.getFloorCacheKey(e);console.time("zstd_json");let n=await fetch(e.map_url).then(r=>r.json());return n.floor=e.floor,console.timeEnd("zstd_json"),this.setCacheData(Hn,t,n),this.setCacheData(zn,t,e.version_id),this.getDataByJson(n)}async getRoadNetworkData(){return(await Promise.all(this.floors.map(async t=>{let n=this.getFloorCacheKey(t);try{if(await this.getCacheData(kn,n)===t.version_id){let o=await this.getCacheData($e,n);if(o)return o}let i=await fetch(t.route_url).then(o=>o.json());return this.setCacheData($e,n,i),this.setCacheData(kn,n,t.version_id),i}catch{let r=await fetch(t.route_url).then(i=>i.json());return this.setCacheData($e,n,r),r}}))).filter(t=>t.points)}async getFacilitiesData(){let e=this.floors[0];if(!e)return null;let t=this.getFloorCacheKey(e),n=async()=>{let r=await fetch(e.entry_infra_url).then(i=>i.json());return r&&(this.setCacheData(Wn,t,r),this.setCacheData(Vn,t,e.version_id)),r};try{if(await this.getCacheData(Vn,t)===e.version_id){let i=await this.getCacheData(Wn,t);if(i)return i}return n()}catch(r){return console.log("[get facility error]",r),n()}}async getOtherDataByFreeTime(){}async getMulFloorsData(e){return Promise.all(e.map(t=>this.getFloorData(t))).then(t=>t.filter(n=>n))}async getDataByUrl(e){let t=await fetch(e).then(n=>n.json());return this.getDataByJson(t)}getDataByJson(e){let t=new ct(this.bmap.context);t.userData.graphics=[],t.userData.graphicMap=new Map;let n=[0,0];return e.layers.forEach(r=>{switch(r.l_type){case"range":let i=r.elements[0];n=[i.center_x,i.center_y];break;case"graph":X(r.elements,n);let o=[];r.elements.forEach(f=>{f.group==="ground"?t.createGround(f):o.push(f)});let a=o.reduce((f,g)=>{let{fillColor:E,fillOpacity:x,strokeColor:z,strokeOpacity:b,height:T,airHeight:k}=g,$=`${E.toLowerCase()}-${x}-${z.toLowerCase()}-${b}-${T}-${k}`;return b===0&&($=`${E.toLowerCase()}-${x}-${T}-${k}`),f[$]?f[$].push(g):f[$]=[g],f},{});Object.values(a).forEach(f=>{let g=new fe(this.bmap.context,f);t.mergeGraphicLayer.add(g)});break;case"ground":X(r.elements,n);let l=r.elements.map(f=>new R(this.bmap.context,f));t.addGrounds(l);break;case"wall":X(r.elements,n);let u=r.elements.reduce((f,g)=>{let{fillColor:E,fillOpacity:x,strokeColor:z,strokeOpacity:b,height:T}=g,k=`${E.toLowerCase()}-${x}-${z.toLowerCase()}-${b}-${T}`;return b===0&&(k=`${E.toLowerCase()}-${x}-${T}`),f[k]?f[k].push(g):f[k]=[g],f},{});Object.values(u).forEach(f=>{let g=new ce(this.bmap.context,f);t.wallLayer.add(g)});break;case"lane":X(r.elements,n);let c=r.elements.reduce((f,g)=>{let{fillColor:E,fillOpacity:x,strokeColor:z,strokeOpacity:b}=g,T=`${E.toLowerCase()}-${x}-${z.toLowerCase()}-${b}`;return b===0&&(T=`${E.toLowerCase()}-${x}`),f[T]?f[T].push(g):f[T]=[g],f},{});Object.values(c).forEach(f=>{let g=new pe(this.bmap.context,f);t.laneLayer.add(g)});break;case"texture2d":case"texture3d":if(X(r.elements,n),r.elements.length){let f=new qt(this.bmap.context,r.elements);t.textureLayer.add(f)}break;case"glb":X(r.elements,n),r.elements.forEach(f=>{let g=rt([f.center_x,f.center_y],n),E=new he(this.bmap.context,{...f,url:f.secondUrl,rotate:f.secondRotate,width:f.secondWidth,center_x:g[0],center_y:g[1]});t.glbModelLayer.add(E)});break;case"store":X(r.elements,n),r.elements.map(f=>{let g=rt([f.center_x,f.center_y],n),E=t.addGraphic(f);t.userData.graphics.push(E),t.userData.graphicMap.set(f.id,E);try{let x=new q(this.bmap.context,{id:f.id,icon:f.poi_info.icon,text:f.poi_info.showName||f.store_name||f.poi_info.text,position:{x:g[0],y:g[1],z:f.airHeight+f.height},icon_size:[18,18],level:f.poi_info.level||0});t.poiLayer2.pushPoi(x),x&&(x.userData.type="store",x.userData.data=f)}catch(x){console.log("\u521B\u5EFA\u5E97\u94FApoi\u5931\u8D25",x,f)}});break;case"facility":X(r.elements,n),r.elements.map(f=>{let g=rt([f.center_x,f.center_y],n),E=t.addGraphic(f);if(t.userData.graphics.push(E),t.userData.graphicMap.set(f.id,E),f.poi_info){let x=new q(this.bmap.context,{id:f.id,icon:f.poi_info.icon,text:f.poi_info.showName||f.store_name||f.poi_info.text,position:{x:g[0],y:g[1],z:f.airHeight+f.height},icon_size:[18,18],level:f.poi_info.level||0});t.poiLayer2.pushPoi(x),x.userData.type="facility",x.userData.data=f}else console.log("\u6DFB\u52A0facility\u5931\u8D25\u6CA1\u6709poi_info",f)});break;case"parkingSpace":X(r.elements,n);let h=[],p=new Map;r.elements.forEach(f=>{let g=t.addGraphic(f);h.push(g),p.set(f.id,g);let E=rt([f.center_x,f.center_y],n);if(f.texts[0]){let x=new q(this.bmap.context,{id:f.id,text:f.texts[0],position:{x:E[0],y:E[1],z:f.airHeight+f.height}});x&&(x.userData.type="parkingSpace",x.userData.data=f),t.poiLayer2.pushPoi(x)}});let d=r.elements.filter(f=>hi[f.parkingType]).map(f=>{let g=rt([f.center_x,f.center_y],n),E=en(f.geometry.coords,g);return{uuid:f.id,iconUrl:hi[f.parkingType],name:f.texts[0],deltaHeight:f.deltaHeight,airHeight:f.airHeight,height:f.height,geometry:{...f.geometry,coords:E},opacity:f.fillOpacity,visible:!0}});if(d.length){let f=new qt(this.bmap.context,d);t.textureLayer.add(f)}t.userData.parkingSpaces=h,t.userData.parkingSpacesGraphicMap=p;break;case"text":X(r.elements,n);let m=new de(this.bmap.context,r.elements.map(f=>{let g=rt([f.center_x,f.center_y],n);return{...f,center_x:g[0],center_y:g[1]}}));t.textTextureLayer.add(m);break}}),t.updateBox(),t.userData.center=n,t.userData.height=t.box.getSize(new pi.Vector3).z+e.floorHeight*10,t.name=e.floor,t.userData.data=e,t}async clear(){si(this.db??void 0)}dispose(){this.clear()}};var qn=class{constructor(e){this.bmap=e}cacheData=new Map;floorDataLengthMap=new Map;buildingGroundMap=new Map;externalStreetMap=new Map;async load(e){let t=Lt(e);if(this.cacheData.has(t))return this.cacheData.get(t);let[,n]=await Promise.all([this.loadBuildGround(e),Bn(e,this.bmap.config)]),r=Lt({floor:e.floor,ts:e.ts});X(n.map(o=>o.info),this.bmap.buildingCenter,this.floorDataLengthMap.get(r)||0),n.forEach(o=>o.info.transformToBuildingGround=!1),this.cacheData.set(t,n);let i=this.floorDataLengthMap.get(r)||0;return this.floorDataLengthMap.set(r,i+n.length),this.loadExternalStreet(e),n}async loadExternalStreet(e){}switchFloorByData(e,t){if(!e.length)return;let n=t.userData.legacyToGraphicMap||new Map,r=t.userData.graphicMap||new Map,{ground:i,markGraphic:o,graphic:a}=this.bmap.config;for(let l=0;l<e.length;l++){let u=e[l];u.info.group==="ground"?(u.info.fillColor=i.color,u.info.fillOpacity=i.opacity,u.info.height=i.height,u.info.stroke=i.stroke,u.info.strokeColor=i.strokeColor,u.info.strokeOpacity=i.strokeOpacity):u.info.userData.mark?(u.info.height=o.height,u.info.fillColor=o.color,u.info.fillOpacity=o.opacity,u.info.stroke=o.stroke,u.info.strokeColor=o.strokeColor,u.info.strokeOpacity=o.strokeOpacity):(u.info.fillOpacity=a.fillOpacity,this.bmap.config.initTransToMark&&(u.info.height=o.height,u.info.fillColor=o.color,u.info.stroke=o.stroke,u.info.strokeColor=o.strokeColor,u.info.strokeOpacity=o.strokeOpacity))}for(let l of e){if(l.info.group==="ground")t.createGround(l.info);else{let u=t.addGraphic(l.info);u.userData.data=l,n.set(l.legacy_id,u)}r.set(l.element_uuid,l)}t.userData.legacyToGraphicMap=n,t.userData.graphicMap=r,t.updateBox(),t===this.bmap.context.currentFloor?(this.bmap.triggerHooks("switch_floor_before",{curFloor:t,graphics:t.graphicLayer.children}),this.bmap.initialFloorCamera(),this.bmap.triggerHooks("switch_floor_after",{curFloor:t,graphics:t.graphicLayer.children})):this.bmap.switchFloorByFloor(t)}filterData(e,t){let n=t.userData.graphicMap||new Map;return e.filter(r=>!n.has(r.element_uuid))}async switchFloorByStoreData(e,t){let n=await this.load({...e,resource_type_list:"6"}),r=this.filterData(n,t);this.switchFloorByData(r,t)}async switchFloorByOtherData(e,t){let n=await this.load({...e,resource_type_list:"1,2,3,4"}),r=this.filterData(n,t);this.switchFloorByData(r,t)}async loadBuildGround({brand:e,project:t}){let n=await this.loadBuildingGround({brand:e,project:t});return this.bmap.currentBuildGround=n,this.bmap.changeBuildingCenter(n,{brand:e,project:t}),this.bmap.currentBuildGround}async loadBuildingGround({brand:e,project:t}){let n=Lt({brand:e,project:t});if(this.buildingGroundMap.has(n))return this.buildingGroundMap.get(n);let r=Un({brand:e,project:t},this.bmap.config).then(i=>(this.buildingGroundMap.set(n,i),i));return this.buildingGroundMap.set(n,r),r}async switchFloor(e){let t=new ct(this.bmap.context);t.name=e.floor;try{await Promise.all([this.switchFloorByStoreData(e,t),this.switchFloorByOtherData(e,t)])}catch(n){console.log(n)}return t}dispose(){this.cacheData.clear(),this.floorDataLengthMap.clear(),this.buildingGroundMap.clear()}};
7535
7535
  //# sourceMappingURL=bmap.cjs.min.js.map