/* */_jsload&&_jsload('mapgl', 'bw.register(function(i){if(i._renderType!=="webgl"||i._destroyed){return}i._webglMapCamera=new gi(i);var e=new ck(i,i._webglMapCamera);i._webglPainter=e;i._webglMapScene=new eM(i,e);new bl(i);if(i.config.showControls===true){this._navigationCtrl=new eR(i)}i.fire(new fA("onglmoduleloaded"))});function gi(i){this._map=i;this._fovy=35;this._fovyRadian=this._fovy*Math.PI/180;this._projectionMatrix=mat4.create();this._modelViewMatrix=mat4.create();this._projectionMatrix3D=mat4.create();this._projectionMatrix3DInverse=mat4.create();this._projectionMatrix3D64=mat4.create(Float64Array);this._projectionMatrix3DInverse64=mat4.create(Float64Array);this._projectionMatrixLabel3D64=mat4.create(Float64Array);this._modelViewMatrix3D=mat4.create();this._modelViewMatrixLineLabel=mat4.create();this._modelViewMatrixMCPlane64=mat4.create(Float64Array);this._modelViewMatrixMCPlaneInverse64=mat4.create(Float64Array);this._modelViewMatrixMCPlane=mat4.create();this._modelViewMatrixMC3D=mat4.create();this._modelViewMatrixPoly=mat4.create();this._modelViewMatrixLayer=mat4.create();this._ray=new dL.Ray();this._tempV4=vec4.create(Float64Array);this._tempRes=vec4.create();this._tempNdc=vec4.create();this._near=10;this._far=4000;this._farLabel=2800;if(!this._map.config.restrictCenter){this._far=3000;var e=this._map.getSize();if(e.height>1500){this._far=e.height*2}this._farLabel=2000}this._frustumSideLen=this._far/Math.cos(this._fovyRadian);this._init()}eP.extend(gi.prototype,{_init:function(){var e=this;e._renderTilt=e._getRenderTilt();e._updateSize();e._updateProjectionMatrix();e._updatePolyMatrix();e._updatePlaneMatrix();e._updatePolyLayerMatrix();this._map.on("updateoverlaymatrix",function(i){e._updatePolyMatrix()})},update:function(T){var i=this;i._renderTilt=i._getRenderTilt();if("onsize_changed" in T.changedStatus){i._updateSize();i._updateProjectionMatrix()}i._updatePolyMatrix();i._updatePlaneMatrix();i._updatePolyLayerMatrix()},_getRenderTilt:function(){var T=this._map;var e=T.getTilt();var i=T.getZoom();if(e!==0&&i=T._enableTiltZoom-2){e=(1-(T._enableTiltZoom-i)/2)*e}else{e=0}}return e},_updateSize:function(){var e=this._map.getSize();this._width=e.width;this._height=e.height;this._widthHeightRatio=this._width/this._height;this._translateZ=Math.round(-this._height/(2*Math.tan(this._fovyRadian/2)));this._farLabel=Math.abs(this._translateZ)+1400},_updateProjectionMatrix:function(){var i=this._map;var e=i.getSize();mat4.ortho(this._projectionMatrix,0,e.width,0,e.height,this._near,this._far);mat4.perspective(this._projectionMatrix3D64,this._fovyRadian,this._widthHeightRatio,this._near,this._far);mat4.invert(this._projectionMatrix3DInverse64,this._projectionMatrix3D64);this._projectionMatrix3D=mat4.clone(this._projectionMatrix3D64);this._projectionMatrix3DInverse=mat4.clone(this._projectionMatrix3DInverse64);mat4.perspective(this._projectionMatrixLabel3D64,this._fovyRadian,this._widthHeightRatio,this._near,this._farLabel)},getProjectionMatrix:function(){return this._projectionMatrix},getProjectionMatrix3D:function(){return this._projectionMatrix3D},getMCPlaneMVMatrix:function(){return this._modelViewMatrixMCPlane},getMC3DMVMatrix:function(){return this._modelViewMatrixMC3D},getXYZCustomModelViewMatrix3D:function(j4,j1){var jX=j4.col;var jW=j4.row;var j9=j4.zoom;var jV=j4.loopOffsetX||0;var j7=this._map;var j2=j7.getZoom();mat4.identity(this._modelViewMatrix3D);var j3=j7.getCenterIn();var T=du.getPointPixelCoor(j3,j9,j4.transform);var j5=Math.pow(2,j9-18);var i=jV*j5;var j0=T[0];var jZ=T[1];var ka=du.getResolutionScale(j9,j4.transform);var e=Math.pow(2,j2-j9);var j6=du.getXYZCellPixelCoor(jX,jW,j9,j4.transform);var jY=this._modelViewMatrix3D;var j8=this._translateZ;if(this._renderTilt!==0){mat4.translate(jY,jY,[0,0,j8]);mat4.rotate(jY,jY,im(this._renderTilt),[-1,0,0]);mat4.translate(jY,jY,[0,0,-j8])}if(j7._heading%360!==0){mat4.rotate(jY,jY,im(j7._heading),[0,0,-1])}mat4.translate(jY,jY,[0,0,j8]);mat4.scale(jY,jY,[e,e,e]);mat4.translate(jY,jY,[0,0,-j8]);mat4.translate(jY,jY,[(j6.x-j0)*ka+i,(j6.y-jZ)*ka,j8]);if(j1!==undefined){mat4.scale(jY,jY,[j1,j1,j1])}return this._modelViewMatrix3D},getModelViewMatrix3D:function(jV){var e=jV.col;var j8=jV.row;var j5=jV.zoom;var j1=jV.loopOffsetX;var j7=jV.baseTileSize;var T=this._map;var jZ=T.getZoom();mat4.identity(this._modelViewMatrix3D);var j6=T.getCenterIn();var j3=Math.pow(2,j5-18);var j0=j1*j3;var j4=j6.lng*j3;var j2=j6.lat*j3;var jW=Math.pow(2,jZ-j5);var jX=new fa(e*j7,j8*j7);var jY=this._modelViewMatrix3D;var i=this._translateZ;if(this._renderTilt!==0){mat4.translate(jY,jY,[0,0,i]);mat4.rotate(jY,jY,im(this._renderTilt),[-1,0,0]);mat4.translate(jY,jY,[0,0,-i])}if(T._heading%360!==0){mat4.rotate(jY,jY,im(T._heading),[0,0,-1])}mat4.translate(jY,jY,[0,0,i]);mat4.scale(jY,jY,[jW,jW,jW]);mat4.translate(jY,jY,[0,0,-i]);mat4.translate(jY,jY,[jX.x-j4+j0,jX.y-j2,i]);return this._modelViewMatrix3D},getModelViewMatrixForLineLabel:function(jV){var i=this._map;if(!i.loaded){return}var jY=this._modelViewMatrixLineLabel;mat4.identity(jY);var T=this._translateZ;var j1=i.centerPoint;var j0=i.zoomLevel;var j2=i.getZoomUnits();var e=jV.col;var j5=jV.row;var j4=jV.baseTileSize;var jW=Math.pow(2,j0-jV.zoom);var jX={x:e*j4*jW,y:j5*j4*jW};var jZ=[jX.x-j1.lng/j2,jX.y-j1.lat/j2,T];if(this._renderTilt!==0){mat4.translate(jY,jY,[0,0,T]);mat4.rotate(jY,jY,im(this._renderTilt),[-1,0,0]);mat4.translate(jY,jY,[0,0,-T])}if(i._heading%360!==0){mat4.rotate(jY,jY,im(i._heading),[0,0,-1])}mat4.translate(jY,jY,jZ);var j3=Math.pow(2,j0-18);mat4.scale(jY,jY,[j3,j3,Math.pow(2,j0-20)]);return this._modelViewMatrixLineLabel},_updatePlaneMatrix:function(){var jZ=this._map;if(!jZ.loaded){return}var jW=this._modelViewMatrixMCPlane64;mat4.identity(jW);var jV=this._translateZ;var T=jZ.centerPoint;var jY=jZ.zoomLevel;var jX=jZ.getZoomUnits();var i=[-T.lng/jX,-T.lat/jX,jV];if(this._renderTilt!==0){mat4.translate(jW,jW,[0,0,jV]);mat4.rotate(jW,jW,im(this._renderTilt),[-1,0,0]);mat4.translate(jW,jW,[0,0,-jV])}if(jZ._heading%360!==0){mat4.rotate(jW,jW,im(jZ._heading),[0,0,-1])}mat4.translate(jW,jW,i);var e=Math.pow(2,jY-18);mat4.scale(jW,jW,[e,e,Math.pow(2,jY-20)]);mat4.invert(this._modelViewMatrixMCPlaneInverse64,jW);this._modelViewMatrixMCPlane=mat4.clone(this._modelViewMatrixMCPlane64)},_updatePolyMatrix:function(){if(!this._map._polyOverlayBasePoint){return}var jZ=this._map;var jY=jZ.getZoom();mat4.identity(this._modelViewMatrixPoly);var jX=jZ.getCenterIn();var i=Math.pow(2,jY-18);var e=jX.sub(jZ._polyOverlayBasePoint).mult(i);var jV=this._translateZ;var T=this._modelViewMatrixPoly;if(this._renderTilt!==0){mat4.translate(T,T,[0,0,jV]);mat4.rotate(T,T,im(this._renderTilt),[-1,0,0]);mat4.translate(T,T,[0,0,-jV])}if(jZ._heading%360!==0){mat4.rotate(T,T,im(jZ._heading),[0,0,-1])}mat4.translate(T,T,[-e.lng,-e.lat,jV]);var jW=i;mat4.scale(T,T,[jW,jW,jW])},_updatePolyLayerMatrix:function(){var jZ=this._map;if(!jZ._normalLayerMgr){return}var jY=jZ.getZoom();mat4.identity(this._modelViewMatrixLayer);var jX=jZ.getCenterIn();var i=Math.pow(2,jY-18);var e=jX.sub(jZ._normalLayerMgr.base).mult(i);var jV=this._translateZ;var T=this._modelViewMatrixLayer;if(this._renderTilt!==0){mat4.translate(T,T,[0,0,jV]);mat4.rotate(T,T,im(this._renderTilt),[-1,0,0]);mat4.translate(T,T,[0,0,-jV])}if(jZ._heading%360!==0){mat4.rotate(T,T,im(jZ._heading),[0,0,-1])}mat4.translate(T,T,[-e.lng,-e.lat,jV]);var jW=i;mat4.scale(T,T,[jW,jW,jW])},getModelViewMatrixPoly:function(){return this._modelViewMatrixPoly},castRay:function(T,jW){var i=this._ray;var e=T.x;var jZ=T.y;var jV=vec3.create(Float64Array);var jX=vec4.set(this._tempV4,e,jZ,-1,1);this._calcV4InCastRay(jX,jW);vec3.scale(jV,jX,1/jX[3]);var jY=vec3.create(Float64Array);jX=vec4.fromValues(e,jZ,1,1,Float64Array);this._calcV4InCastRay(jX,jW);vec3.scale(jX,jX,1/jX[3]);vec3.sub(jY,jX,jV);vec3.normalize(jY,jY);i.set(jV,jY);return i},_calcV4InCastRay:function(jX,T){if(!T||!T.matrixInfo){mat4.multiply(jX,this._projectionMatrix3DInverse64,jX);mat4.multiply(jX,this._modelViewMatrixMCPlaneInverse64,jX)}else{if(T.matrixInfo){var e=T.matrixInfo.projectionMatrix;var jV=mat4.create(Float64Array);if(e){mat4.invert(jV,e)}else{jV=this._projectionMatrix3DInverse64}var i=T.matrixInfo.modelViewMatrix;var jW=mat4.create(Float64Array);if(i){mat4.invert(jW,i)}else{jW=this._projectionMatrix3DInverse64}mat4.multiply(jX,jV,jX);mat4.multiply(jX,jW,jX)}}},fromXYZToNDC:function(jY,jW,T,j0){var jV=vec4.set(this._tempV4,jY,jW,T,1);var i=this._tempRes;j0=j0||{};var e=this._modelViewMatrixMCPlane64;var jX=this._projectionMatrix3D64;if(j0.matrixInfo){e=j0.matrixInfo.modelViewMatrix||e;jX=j0.matrixInfo.projectionMatrix||jX}mat4.multiply(i,e,jV);mat4.multiply(i,jX,i);var jZ=vec4.set(this._tempNdc,i[0]/i[3],i[1]/i[3],i[2]/i[3],1);jZ.outOfFrustum=false;if(j0.frustumTest){if(i[0]<-i[3]||i[0]>i[3]||i[1]<-i[3]||i[1]>i[3]||i[2]<-i[3]||i[2]>i[3]){jZ.outOfFrustum=true}}jZ.w=i[3];return jZ},fromMCToScreenPixel:function(jW,jV,j2){j2=j2||{};var T={matrixInfo:{}};if(j2.center||j2.zoom||typeof j2.heading==="number"||typeof j2.tilt==="number"){var jZ=j2.zoom||this._map.zoomLevel;var e=j2.center||this._map.centerPoint;var j1=typeof j2.heading==="number"?j2.heading:this._map.getHeading();var j0=typeof j2.tilt==="number"?j2.tilt:this._renderTilt;T.matrixInfo.modelViewMatrix=this.generateMVMatrix(e,jZ,j1,j0)}T.frustumTest=j2.frustumTest;if(j2.forLabel){T.matrixInfo.projectionMatrix=this._projectionMatrixLabel3D64}var jY=j2.height||0;var jX=this.fromXYZToNDC(jW,jV,jY,T);if(!jX){return null}var i=new fa(((jX[0]+1)*this._map.width/2),((1-jX[1])*this._map.height/2));i.depth=(jX[2]+1)*0.5;i.w=jX.w;i.outOfFrustum=jX.outOfFrustum;return i},fromScreenPixelToMC:function(j2,jY,j8){var j1=j2*2/this._map.width-1;var jZ=1-jY*2/this._map.height;j8=j8||{};var T=null;if(j8.zoom||j8.center||typeof j8.heading==="number"||typeof j8.tilt==="number"){var i=this._map;var j5=j8.zoom||i.zoomLevel;var e=j8.center||i.centerPoint;var j7=typeof j8.heading==="number"?j8.heading:i.getHeading();var j4=typeof j8.tilt==="number"?j8.tilt:this._renderTilt;T={matrixInfo:{modelViewMatrix:this.generateMVMatrix(e,j5,j7,j4)}}}var j0=this.castRay(new fa(j1,jZ),T);var jV=vec3.fromValues(0,0,1,Float64Array);var jX=vec3.dot(jV,j0.origin);var jW=vec3.dot(jV,j0.direction);var j3=-jX/jW;var j6=vec3.create(Float64Array);vec3.scaleAndAdd(j6,j0.origin,j0.direction,j3);j6[0]=Math.round(j6[0]*100000)/100000;j6[1]=Math.round(j6[1]*100000)/100000;return new cu(j6[0],j6[1])},generateMVMatrix:function(e,jZ,j1,j0){var i=this._map;if(!i.loaded){return}e=e||i.centerPoint;jZ=jZ||i.zoomLevel;j1=typeof j1==="number"?j1:i._heading;j0=typeof j0==="number"?j0:this._renderTilt;var jV=mat4.create(Float64Array);mat4.identity(jV);var T=this._translateZ;var jX=i.getZoomUnits(jZ);var jW=[-e.lng/jX,-e.lat/jX,T];if(j0!==0){mat4.translate(jV,jV,[0,0,T]);mat4.rotate(jV,jV,im(j0),[-1,0,0]);mat4.translate(jV,jV,[0,0,-T])}if(j1%360!==0){mat4.rotate(jV,jV,im(j1),[0,0,-1])}mat4.translate(jV,jV,jW);var jY=Math.pow(2,jZ-18);mat4.scale(jV,jV,[jY,jY,1]);return jV},getPosition:function(e){e=e||this._modelViewMatrixMCPlaneInverse64;return vec3.transformMat4(vec3.create(Float64Array),vec3.fromValues(0,0,0,Float64Array),e)}});function eM(i,e){this._map=i;this._camera=i._webglMapCamera;this._painter=e;this._changedStatus={};this._statusChanged=false;this._rAFStarted=false;this._enabled=true;if(i.getMapType()==="B_EARTH_MAP"){this._enabled=false}this._onEachFrame=(function(T){return function(){T._updateFrame()}})(this);this._init()}eP.extend(eM.prototype,{_init:function(){this._fpsStarted=false;this._mapStatusIdle=true;this._bind();this._statusChanged=true;this.startRenderThread();var e=new N();var T=this;var jV=this._map;jV.on("movestart",function(){if(T._fpsStarted){return}T._fpsStarted=true;e.startFPS()});jV.on("moveend",function(){if(!T._fpsStarted){return}T._fpsStarted=false;e.stopFPS()});jV.on("zoomstart",function(){if(T._fpsStarted){return}T._fpsStarted=true;e.startFPS()});jV.on("zoomend",function(){if(!T._fpsStarted){return}T._fpsStarted=false;e.stopFPS()});function i(){if(!e.fpsStarted){return}if(jV.getMapType()!=="B_NORMAL_MAP"){return}var jY=e.getAverageFPS();var jX=e.getHigherAverageFPS();var jW=new fA("onfpsdata_ready");jW.fps=jY;jW.fpsH=jX;jV.fire(jW);e.clearFPSData()}setTimeout(i,5000);this._fpsInterval=setInterval(i,10000)},_bind:function(){var jV=this._map;var e=this;function jX(jY){e._changedStatus[jY.type]=jY||true;e._statusChanged=true;e.startRenderThread()}jV.on("zoom_changed",jX);jV.on("center_changed",jX);jV.on("heading_changed",jX);jV.on("tilt_changed",jX);jV.on("size_changed",jX);jV.on("displayoptions_changed",jX);jV.on("mapglidle_inner",function(){cancelAnimationFrame(e.renderTimer);e._rAFStarted=false;this.fire(new fA("onrenderthreadstop"));this.fire(new fA("onmapglidle"));e.renderTimer=null});var T=function(jY){e.startRenderThread()};jV.on("refresh",T);function jW(){if(this.mapType==="B_EARTH_MAP"){e._enabled=false;cancelAnimationFrame(e.renderTimer);e._rAFStarted=false;jV.fire(new fA("onrenderthreadstop"));e.renderTimer=null}else{e._enabled=true;e.startRenderThread()}}jV.on("maptypechange",jW);function i(){if(document.hidden){cancelAnimationFrame(e.renderTimer)}else{e.startRenderThread()}}jV.on("destroy",function(){this.off("zoom_changed",jX);this.off("center_changed",jX);this.off("heading_changed",jX);this.off("tilt_changed",jX);this.off("size_changed",jX);this.off("displayoptions_changed",jX);this.off("refresh",T);this.off("maptypechange",jW);document.removeEventListener("visibilitychange",i,false);cancelAnimationFrame(e.renderTimer);clearInterval(e._fpsInterval);e._fpsInterval=null})},startRenderThread:function(){if(!this._enabled){return}var T=this;if(T.idleTimer){clearTimeout(T.idleTimer)}T.idleTimer=setTimeout(function i(){T._map.fire(new fA("onmapglidle_inner"));T.idleTimer=null},200);if(T._statusChanged===true){if(T._mapStatusIdle===true){T._mapStatusIdle=false;T._map.fire(new fA("onmapstatusbusy_inner"))}if(T.statusIdleTimer){clearTimeout(T.statusIdleTimer)}T.statusIdleTimer=setTimeout(function e(){T._mapStatusIdle=true;T._map.fire(new fA("onmapstatusidle_inner"));T.statusIdleTimer=null},100)}if(this._rAFStarted===true){return}this._rAFStarted=true;this.renderTimer=requestAnimationFrame(this._onEachFrame)},_updateFrame:function(){this.renderTimer=requestAnimationFrame(this._onEachFrame);this._map.fire(new fA("onbeforeupdateframe"));if(this._rAFStarted===false){cancelAnimationFrame(this.renderTimer);return}var T=hX();if(this._statusChanged){this._statusChanged=false;var e=new fA("onupdate");e.changedStatus=this._changedStatus;if(this._changedStatus.onsize_changed){this._resizeMap(this._changedStatus.onsize_changed.oldSize)}this._camera.update(e);this._map.fire(e);this._changedStatus={}}this._painter.draw({idle:this._mapStatusIdle});var jV=hX()-T;var i=new fA("onupdateframe");i.frameTime=jV;this._map.fire(i)},_resizeMap:function(e){var T=this._map;var jV=T.getSize();var j0=(jV.width-e.width)/2;var jX=(jV.height-e.height)/2;var i=j0;var jY=jX;if(T._heading!==0){var j2=im(T._heading);i=Math.abs(Math.cos(j2)*j0)+Math.abs(Math.sin(j2)*jX);jY=Math.abs(Math.sin(j2)*j0)+Math.abs(Math.cos(j2)*jX)}var jZ=T.getZoomUnits();var j1=T.centerPoint;if(j1&&!T.config.enableResizeOnCenter){if(T._heading%360!==0||T._tilt>0){var jW=new fa(jV.width/2,jV.height/2);T.centerPoint=T.restrictCenter(T.pixelToPointIn(jW))}else{T.centerPoint=T.restrictCenter(new cu(j1.lng+i*jZ,j1.lat-jY*jZ))}}}});function N(){this._fps=0;this.preFrameTimeStamp=Date.now();this.currentTime=null;this.fpsArr=[];this.averageFPS=0;this.higherAverageFPS=0;this.averageTimeInterval=20;this.fpsStarted=false}N.prototype.startFPS=function(){this.fpsStarted=true;this.preFrameTimeStamp=Date.now();this.initFPS()};N.prototype.initFPS=function(){this._fps++;this.currentTime=Date.now();if(this.currentTime-this.preFrameTimeStamp>500){var i=this._fps*2;i=i>60?60:i;this.fpsArr.push(i);if(this.fpsArr.length===this.averageTimeInterval){this._calcAverageFPS()}this._fps=0;this.preFrameTimeStamp=this.currentTime}var e=this;this.timer=requestAnimationFrame(function(){e.initFPS()})};N.prototype._calcAverageFPS=function(){if(this.fpsArr.length===0){return}var jV=0;var e=0;this.fpsArr.sort(function(jX,i){return i-jX});var jW=Math.round(this.fpsArr.length*0.8);for(var T=0;T60?60:i;this.fpsArr.push(i);this._fps=0}}};N.prototype.clearFPSData=function(){this.averageFPS=0;this.higherAverageFPS=0;this.fpsStarted=false};var jq=(function(){var e={" ":[16,[]],"!":[10,[5,21,5,7,-1,-1,5,2,4,1,5,0,6,1,5,2]],\'"\':[16,[4,21,4,14,-1,-1,12,21,12,14]],"#":[21,[11,25,4,-7,-1,-1,17,25,10,-7,-1,-1,4,12,18,12,-1,-1,3,6,17,6]],"$":[20,[8,25,8,-4,-1,-1,12,25,12,-4,-1,-1,17,18,15,20,12,21,8,21,5,20,3,18,3,16,4,14,5,13,7,12,13,10,15,9,16,8,17,6,17,3,15,1,12,0,8,0,5,1,3,3]],"%":[24,[21,21,3,0,-1,-1,8,21,10,19,10,17,9,15,7,14,5,14,3,16,3,18,4,20,6,21,8,21,10,20,13,19,16,19,19,20,21,21,-1,-1,17,7,15,6,14,4,14,2,16,0,18,0,20,1,21,3,21,5,19,7,17,7]],"&":[26,[23,12,23,13,22,14,21,14,20,13,19,11,17,6,15,3,13,1,11,0,7,0,5,1,4,2,3,4,3,6,4,8,5,9,12,13,13,14,14,16,14,18,13,20,11,21,9,20,8,18,8,16,9,13,11,10,16,3,18,1,20,0,22,0,23,1,23,2]],"(":[14,[11,25,9,23,7,20,5,16,4,11,4,7,5,2,7,-2,9,-5,11,-7]],")":[14,[3,25,5,23,7,20,9,16,10,11,10,7,9,2,7,-2,5,-5,3,-7]],"*":[16,[8,21,8,9,-1,-1,3,18,13,12,-1,-1,13,18,3,12]],"+":[26,[13,18,13,0,-1,-1,4,9,22,9]],",":[10,[6,1,5,0,4,1,5,2,6,1,6,-1,5,-3,4,-4]],"-":[26,[4,9,22,9]],".":[10,[5,2,4,1,5,0,6,1,5,2]],"/":[22,[20,25,2,-7]],"0":[20,[9,21,6,20,4,17,3,12,3,9,4,4,6,1,9,0,11,0,14,1,16,4,17,9,17,12,16,17,14,20,11,21,9,21]],"1":[20,[6,17,8,18,11,21,11,0]],"2":[20,[4,16,4,17,5,19,6,20,8,21,12,21,14,20,15,19,16,17,16,15,15,13,13,10,3,0,17,0]],"3":[20,[5,21,16,21,10,13,13,13,15,12,16,11,17,8,17,6,16,3,14,1,11,0,8,0,5,1,4,2,3,4]],"4":[20,[13,21,3,7,18,7,-1,-1,13,21,13,0]],"5":[20,[15,21,5,21,4,12,5,13,8,14,11,14,14,13,16,11,17,8,17,6,16,3,14,1,11,0,8,0,5,1,4,2,3,4]],"6":[20,[16,18,15,20,12,21,10,21,7,20,5,17,4,12,4,7,5,3,7,1,10,0,11,0,14,1,16,3,17,6,17,7,16,10,14,12,11,13,10,13,7,12,5,10,4,7]],"7":[20,[17,21,7,0,-1,-1,3,21,17,21]],"8":[20,[8,21,5,20,4,18,4,16,5,14,7,13,11,12,14,11,16,9,17,7,17,4,16,2,15,1,12,0,8,0,5,1,4,2,3,4,3,7,4,9,6,11,9,12,13,13,15,14,16,16,16,18,15,20,12,21,8,21]],"9":[20,[16,14,15,11,13,9,10,8,9,8,6,9,4,11,3,14,3,15,4,18,6,20,9,21,10,21,13,20,15,18,16,14,16,9,15,4,13,1,10,0,8,0,5,1,4,3]],":":[10,[5,14,4,13,5,12,6,13,5,14,-1,-1,5,2,4,1,5,0,6,1,5,2]],";":[10,[5,14,4,13,5,12,6,13,5,14,-1,-1,6,1,5,0,4,1,5,2,6,1,6,-1,5,-3,4,-4]],"<":[24,[20,18,4,9,20,0]],"=":[26,[4,12,22,12,-1,-1,4,6,22,6]],">":[24,[4,18,20,9,4,0]],"?":[18,[3,16,3,17,4,19,5,20,7,21,11,21,13,20,14,19,15,17,15,15,14,13,13,12,9,10,9,7,-1,-1,9,2,8,1,9,0,10,1,9,2]],"@":[27,[18,13,17,15,15,16,12,16,10,15,9,14,8,11,8,8,9,6,11,5,14,5,16,6,17,8,-1,-1,12,16,10,14,9,11,9,8,10,6,11,5,-1,-1,18,16,17,8,17,6,19,5,21,5,23,7,24,10,24,12,23,15,22,17,20,19,18,20,15,21,12,21,9,20,7,19,5,17,4,15,3,12,3,9,4,6,5,4,7,2,9,1,12,0,15,0,18,1,20,2,21,3,-1,-1,19,16,18,8,18,6,19,5]],A:[18,[9,21,1,0,-1,-1,9,21,17,0,-1,-1,4,7,14,7]],B:[21,[4,21,4,0,-1,-1,4,21,13,21,16,20,17,19,18,17,18,15,17,13,16,12,13,11,-1,-1,4,11,13,11,16,10,17,9,18,7,18,4,17,2,16,1,13,0,4,0]],C:[21,[18,16,17,18,15,20,13,21,9,21,7,20,5,18,4,16,3,13,3,8,4,5,5,3,7,1,9,0,13,0,15,1,17,3,18,5]],D:[21,[4,21,4,0,-1,-1,4,21,11,21,14,20,16,18,17,16,18,13,18,8,17,5,16,3,14,1,11,0,4,0]],E:[19,[4,21,4,0,-1,-1,4,21,17,21,-1,-1,4,11,12,11,-1,-1,4,0,17,0]],F:[18,[4,21,4,0,-1,-1,4,21,17,21,-1,-1,4,11,12,11]],G:[21,[18,16,17,18,15,20,13,21,9,21,7,20,5,18,4,16,3,13,3,8,4,5,5,3,7,1,9,0,13,0,15,1,17,3,18,5,18,8,-1,-1,13,8,18,8]],H:[22,[4,21,4,0,-1,-1,18,21,18,0,-1,-1,4,11,18,11]],I:[8,[4,21,4,0]],J:[16,[12,21,12,5,11,2,10,1,8,0,6,0,4,1,3,2,2,5,2,7]],K:[21,[4,21,4,0,-1,-1,18,21,4,7,-1,-1,9,12,18,0]],L:[17,[4,21,4,0,-1,-1,4,0,16,0]],M:[24,[4,21,4,0,-1,-1,4,21,12,0,-1,-1,20,21,12,0,-1,-1,20,21,20,0]],N:[22,[4,21,4,0,-1,-1,4,21,18,0,-1,-1,18,21,18,0]],O:[22,[9,21,7,20,5,18,4,16,3,13,3,8,4,5,5,3,7,1,9,0,13,0,15,1,17,3,18,5,19,8,19,13,18,16,17,18,15,20,13,21,9,21]],P:[21,[4,21,4,0,-1,-1,4,21,13,21,16,20,17,19,18,17,18,14,17,12,16,11,13,10,4,10]],Q:[22,[9,21,7,20,5,18,4,16,3,13,3,8,4,5,5,3,7,1,9,0,13,0,15,1,17,3,18,5,19,8,19,13,18,16,17,18,15,20,13,21,9,21,-1,-1,12,4,18,-2]],R:[21,[4,21,4,0,-1,-1,4,21,13,21,16,20,17,19,18,17,18,15,17,13,16,12,13,11,4,11,-1,-1,11,11,18,0]],S:[20,[17,18,15,20,12,21,8,21,5,20,3,18,3,16,4,14,5,13,7,12,13,10,15,9,16,8,17,6,17,3,15,1,12,0,8,0,5,1,3,3]],T:[16,[8,21,8,0,-1,-1,1,21,15,21]],U:[22,[4,21,4,6,5,3,7,1,10,0,12,0,15,1,17,3,18,6,18,21]],V:[18,[1,21,9,0,-1,-1,17,21,9,0]],W:[24,[2,21,7,0,-1,-1,12,21,7,0,-1,-1,12,21,17,0,-1,-1,22,21,17,0]],X:[20,[3,21,17,0,-1,-1,17,21,3,0]],Y:[18,[1,21,9,11,9,0,-1,-1,17,21,9,11]],Z:[20,[17,21,3,0,-1,-1,3,21,17,21,-1,-1,3,0,17,0]],"[":[14,[4,25,4,-7,-1,-1,5,25,5,-7,-1,-1,4,25,11,25,-1,-1,4,-7,11,-7]],"]":[14,[9,25,9,-7,-1,-1,10,25,10,-7,-1,-1,3,25,10,25,-1,-1,3,-7,10,-7]],"^":[16,[6,15,8,18,10,15,-1,-1,3,12,8,17,13,12,-1,-1,8,17,8,0]],_:[16,[0,-2,16,-2]],"`":[10,[6,21,5,20,4,18,4,16,5,15,6,16,5,17]],a:[19,[15,14,15,0,-1,-1,15,11,13,13,11,14,8,14,6,13,4,11,3,8,3,6,4,3,6,1,8,0,11,0,13,1,15,3]],b:[19,[4,21,4,0,-1,-1,4,11,6,13,8,14,11,14,13,13,15,11,16,8,16,6,15,3,13,1,11,0,8,0,6,1,4,3]],c:[18,[15,11,13,13,11,14,8,14,6,13,4,11,3,8,3,6,4,3,6,1,8,0,11,0,13,1,15,3]],d:[19,[15,21,15,0,-1,-1,15,11,13,13,11,14,8,14,6,13,4,11,3,8,3,6,4,3,6,1,8,0,11,0,13,1,15,3]],e:[18,[3,8,15,8,15,10,14,12,13,13,11,14,8,14,6,13,4,11,3,8,3,6,4,3,6,1,8,0,11,0,13,1,15,3]],f:[12,[10,21,8,21,6,20,5,17,5,0,-1,-1,2,14,9,14]],g:[19,[15,14,15,-2,14,-5,13,-6,11,-7,8,-7,6,-6,-1,-1,15,11,13,13,11,14,8,14,6,13,4,11,3,8,3,6,4,3,6,1,8,0,11,0,13,1,15,3]],h:[19,[4,21,4,0,-1,-1,4,10,7,13,9,14,12,14,14,13,15,10,15,0]],i:[8,[3,21,4,20,5,21,4,22,3,21,-1,-1,4,14,4,0]],j:[10,[5,21,6,20,7,21,6,22,5,21,-1,-1,6,14,6,-3,5,-6,3,-7,1,-7]],k:[17,[4,21,4,0,-1,-1,14,14,4,4,-1,-1,8,8,15,0]],l:[8,[4,21,4,0]],m:[30,[4,14,4,0,-1,-1,4,10,7,13,9,14,12,14,14,13,15,10,15,0,-1,-1,15,10,18,13,20,14,23,14,25,13,26,10,26,0]],n:[19,[4,14,4,0,-1,-1,4,10,7,13,9,14,12,14,14,13,15,10,15,0]],o:[19,[8,14,6,13,4,11,3,8,3,6,4,3,6,1,8,0,11,0,13,1,15,3,16,6,16,8,15,11,13,13,11,14,8,14]],p:[19,[4,14,4,-7,-1,-1,4,11,6,13,8,14,11,14,13,13,15,11,16,8,16,6,15,3,13,1,11,0,8,0,6,1,4,3]],q:[19,[15,14,15,-7,-1,-1,15,11,13,13,11,14,8,14,6,13,4,11,3,8,3,6,4,3,6,1,8,0,11,0,13,1,15,3]],r:[13,[4,14,4,0,-1,-1,4,8,5,11,7,13,9,14,12,14]],s:[17,[14,11,13,13,10,14,7,14,4,13,3,11,4,9,6,8,11,7,13,6,14,4,14,3,13,1,10,0,7,0,4,1,3,3]],t:[12,[5,21,5,4,6,1,8,0,10,0,-1,-1,2,14,9,14]],u:[19,[4,14,4,4,5,1,7,0,10,0,12,1,15,4,-1,-1,15,14,15,0]],v:[16,[2,14,8,0,-1,-1,14,14,8,0]],w:[22,[3,14,7,0,-1,-1,11,14,7,0,-1,-1,11,14,15,0,-1,-1,19,14,15,0]],x:[17,[3,14,14,0,-1,-1,14,14,3,0]],y:[16,[2,14,8,0,-1,-1,14,14,8,0,6,-4,4,-6,2,-7,1,-7]],z:[17,[14,14,3,0,-1,-1,3,14,14,14,-1,-1,3,0,14,0]],"{":[14,[9,25,7,24,6,23,5,21,5,19,6,17,7,16,8,14,8,12,6,10,-1,-1,7,24,6,22,6,20,7,18,8,17,9,15,9,13,8,11,4,9,8,7,9,5,9,3,8,1,7,0,6,-2,6,-4,7,-6,-1,-1,6,8,8,6,8,4,7,2,6,1,5,-1,5,-3,6,-5,7,-6,9,-7]],"|":[8,[4,25,4,-7]],"}":[14,[5,25,7,24,8,23,9,21,9,19,8,17,7,16,6,14,6,12,8,10,-1,-1,7,24,8,22,8,20,7,18,6,17,5,15,5,13,6,11,10,9,6,7,5,5,5,3,6,1,7,0,8,-2,8,-4,7,-6,-1,-1,8,8,6,6,6,4,7,2,8,1,9,-1,9,-3,8,-5,7,-6,5,-7]],"~":[24,[3,6,3,8,4,11,6,12,8,12,10,11,14,8,16,7,18,7,20,8,21,10,-1,-1,3,8,4,10,6,11,8,11,10,10,14,7,16,6,18,6,20,7,21,10,21,12]]};return function(j6,T,j2,jW){jW=jW||1;var jY=[];var j0;var j1;var jZ;var jX;var j3;var j5;var j4;var jV;for(j0=0,j1=j6.length;j0=19){jV*=1.8}else{jV*=1.2}if(jX.lastState.scale!==jV){jY.uniform1f(jX.uniforms.u_scale,jV);jX.lastState.scale=jV}j1._state.activeTexture(jY.TEXTURE4);T(jY,j1);if(!jX.uniforms.lastSampler){jY.uniform1i(jX.uniforms.u_image,4);jX.uniforms.lastSampler=true}jW.vao1.bind(jY,jX,jW.vertex,jW.element1);jY.drawElements(jY.TRIANGLES,jW.element1.length,jY.UNSIGNED_SHORT,0)}})();var i5=(function(){return function(e,jV,T,jY,jX){var jZ=e.gl;var i=e.programMgr.useProgram("sky");jZ.depthMask(false);jZ.uniformMatrix4fv(i.uniforms.uPMatrix,false,e.projMatrix2D);jZ.uniformMatrix4fv(i.uniforms.uMVMatrix,false,jV);jZ.uniform4fv(i.uniforms.uGroundColor,jX[0]);jZ.uniform4fv(i.uniforms.uSkyColor,jX[1]||jX[0]);var jW=jY-T;jW=jW<0?0:jW;jZ.uniform1f(i.uniforms.uHorizonY,jW);e.skyVAO.bind(jZ,i,e.skyBuffer);jZ.drawArrays(jZ.TRIANGLES,0,e.skyBuffer.length);jZ.depthMask(true)}})();function fZ(jZ,jV){var T=jZ.gl;var i=jZ.programMgr.useProgram("debug");T.uniform4fv(i.uniforms.u_color,[1,0,0,1]);T.uniform1f(i.uniforms.u_opacity,1);T.uniformMatrix4fv(i.uniforms.u_proj_matrix,false,jZ.projMatrix);T.uniformMatrix4fv(i.uniforms.u_mv_matrix,false,jV.mvMatrix);jZ.debugVAO.bind(T,i,jZ.debugBuffer);T.drawArrays(T.LINE_STRIP,0,jZ.debugBuffer.length);jZ.debugVAO.unbind(T);var jY=mat4.create();jY=mat4.scale(jY,jY,[1,-1,1]);jY=mat4.multiply(jY,jV.mvMatrix,jY);T.uniformMatrix4fv(i.uniforms.u_mv_matrix,false,jY);var e=jV.tileInfo;var j1=jV.tileInfo.col+"-"+jV.tileInfo.row+"-"+jV.tileInfo.zoom;var jW=jq(j1,10,-10,0.5);var jX=new w(new Float32Array(jW),{alignment:1,components:2,members:[{name:"a_pos",components:2,offset:0,type:"Float32"}]},w.BufferType.VERTEX);var j0=new dH();j0.bind(T,i,jX);T.drawArrays(T.LINES,0,jX.length)}var bj=(function(){function jW(j4,j2,j3,j1,jX,jZ,jY){var j0=j4.createTexture();j4.bindTexture(j4.TEXTURE_2D,j0);j4.pixelStorei(j4.UNPACK_FLIP_Y_WEBGL,true);j4.texImage2D(j4.TEXTURE_2D,0,j3||j4.RGBA,j3||j4.RGBA,j4.UNSIGNED_BYTE,j2);j4.texParameteri(j4.TEXTURE_2D,j4.TEXTURE_MAG_FILTER,j1||j4.LINEAR);j4.texParameteri(j4.TEXTURE_2D,j4.TEXTURE_MIN_FILTER,jX||j4.LINEAR);j4.texParameteri(j4.TEXTURE_2D,j4.TEXTURE_WRAP_S,jZ||j4.CLAMP_TO_EDGE);j4.texParameteri(j4.TEXTURE_2D,j4.TEXTURE_WRAP_T,jY||j4.CLAMP_TO_EDGE);j4.bindTexture(j4.TEXTURE_2D,null);return j0}function T(jY,j0){var jX=new Image();jX.onload=function(){jY._smaaInfo.areaTexture=jW(j0,this,j0.RGB,j0.LINEAR,j0.LINEAR,null,null);if(jY._smaaInfo.areaTexture&&jY._smaaInfo.searchTexture){jY._smaaInfo.glDrawSMAAReady=true}};jX.src=i();var jZ=new Image();jZ.onload=function(){jY._smaaInfo.searchTexture=jW(j0,this,null,j0.NEAREST,j0.NEAREST,null,null);if(jY._smaaInfo.areaTexture&&jY._smaaInfo.searchTexture){jY._smaaInfo.glDrawSMAAReady=true}};jZ.src=e()}function jV(jX,jY){if(!jX._smaaInfo.textureBeginToLoad){T(jX,jY);jX._smaaInfo.textureBeginToLoad=true}}return{init:function(jX){jX._smaaInfo={areaTexture:null,searchTexture:null,textureBeginToLoad:false,glDrawSMAAReady:false}},loadTexture:jV,draw:function(j0,jZ,j2,jY,j3,jX){var j4=j0.gl;if(j0._smaaInfo.glDrawSMAAReady===false){return}j0._state.disableCap("blend");j4.bindFramebuffer(j4.FRAMEBUFFER,jY[1].framebuffer);var j1=j0.programMgr.useProgram("smaa1");jZ.vao1.bind(j4,j1,jZ.vertex);j4.uniform2fv(j1.uniforms.resolution,[1/j3,1/jX]);j4.uniformMatrix4fv(j1.uniforms.projectionMatrix,false,j0.projMatrix2D);j4.uniformMatrix4fv(j1.uniforms.modelViewMatrix,false,j2);j0._state.activeTexture(j4.TEXTURE1);j4.bindTexture(j4.TEXTURE_2D,jY[0].texture);j4.uniform1i(j1.uniforms.tDiffuse,1);j4.drawArrays(j4.TRIANGLES,0,jZ.vertex.length);j4.bindFramebuffer(j4.FRAMEBUFFER,null);j4.bindFramebuffer(j4.FRAMEBUFFER,jY[2].framebuffer);j1=j0.programMgr.useProgram("smaa2");jZ.vao2.bind(j4,j1,jZ.vertex);j4.uniform2fv(j1.uniforms.resolution,[1/j3,1/jX]);j4.uniformMatrix4fv(j1.uniforms.projectionMatrix,false,j0.projMatrix2D);j4.uniformMatrix4fv(j1.uniforms.modelViewMatrix,false,j2);j0._state.activeTexture(j4.TEXTURE1);j4.bindTexture(j4.TEXTURE_2D,jY[1].texture);j4.uniform1i(j1.uniforms.tDiffuse,1);j0._state.activeTexture(j4.TEXTURE2);j4.bindTexture(j4.TEXTURE_2D,j0._smaaInfo.areaTexture);j4.uniform1i(j1.uniforms.tArea,2);j0._state.activeTexture(j4.TEXTURE3);j4.bindTexture(j4.TEXTURE_2D,j0._smaaInfo.searchTexture);j4.uniform1i(j1.uniforms.tSearch,3);j4.drawArrays(j4.TRIANGLES,0,jZ.vertex.length);j4.bindFramebuffer(j4.FRAMEBUFFER,null);j1=j0.programMgr.useProgram("smaa3");jZ.vao3.bind(j4,j1,jZ.vertex);j4.uniform2fv(j1.uniforms.resolution,[1/j3,1/jX]);j4.uniformMatrix4fv(j1.uniforms.projectionMatrix,false,j0.projMatrix2D);j4.uniformMatrix4fv(j1.uniforms.modelViewMatrix,false,j2);j0._state.activeTexture(j4.TEXTURE1);j4.bindTexture(j4.TEXTURE_2D,jY[2].texture);j4.uniform1i(j1.uniforms.tDiffuse,1);j0._state.activeTexture(j4.TEXTURE2);j4.bindTexture(j4.TEXTURE_2D,jY[0].texture);j4.uniform1i(j1.uniforms.tColor,2);j4.drawArrays(j4.TRIANGLES,0,jZ.vertex.length);j0._state.enableCap("blend")}};function i(){return""}function e(){return""}})();var c9=(function(){function e(T,jW,i){var jX=T.gl;var jV=T.programMgr.useProgram("overlayblock");i.vao1.bind(jX,jV,i.vertex,i.element1);if(!jV.lastState.projMatrix){jX.uniformMatrix4fv(jV.uniforms.u_proj_matrix,false,T.projMatrix);jV.lastState.projMatrix=true}var jY=T._camera._far||4000;if(jV.lastState.cameraFar!==jY){jX.uniform1f(jV.uniforms.u_camera_far,jY);jV.lastState.cameraFar=jY}jX.uniformMatrix4fv(jV.uniforms.u_mv_matrix,false,jW);jX.uniformMatrix4fv(jV.uniforms.u_normal_matrix,false,T.normalMatrix);jX.drawElements(jX.TRIANGLES,i.element1.length,jX.UNSIGNED_SHORT,0)}return function(T,jW,i,jV){jV=jV||{};e(T,jW.mvMatrix,i)}})();var jJ=(function(){function e(T,jW,jY,j0,i,jX){if(i.length<=0){return}var jZ=T.gl;var jV=T.programMgr.useProgram("marker3d");i.vao.bind(jZ,jV,i.vertex);if(!jV.lastState.projMatrix){jZ.uniformMatrix4fv(jV.uniforms.u_proj_matrix,false,T.projMatrix);jV.lastState.projMatrix=true}jZ.uniform1i(jV.uniforms.u_use_texture,!!i.texture);if(i.texture){T._state.activeTexture(jZ.TEXTURE7);jZ.bindTexture(jZ.TEXTURE_2D,i.texture);if(jV.uniforms.lastSamper!==7){jZ.uniform1i(jV.uniforms.u_Sampler,7);jV.uniforms.lastSamper=7}}jZ.uniform3fv(jV.uniforms.u_camera_pos_high,jY);jZ.uniform3fv(jV.uniforms.u_camera_pos_low,j0);jZ.uniform3fv(jV.uniforms.u_camera_pos_low,j0);jZ.uniformMatrix4fv(jV.uniforms.u_mv_matrix,false,jW);jZ.drawArrays(jZ.POINTS,0,i.vertex.length)}return function(T,jW,jX,jY,i,jV){jV=jV||{};e(T,jW.mvMatrix,jX,jY,i,jV)}})();var eT=(function(){function e(j6,j0,j3,jY,j5,j4,jV){var j1=j6.gl;var jZ=j6.programMgr.useProgram("groundoverlay");if(j4){var jX=j3.overlay;var T={fShader:jX._config.fomularC};jZ=j6.programMgr.useProgram("groundpixeloverlay",T);if(jZ.lastState.fHashcode!==jX.fHashcode){j6.programMgr.removeProgram("groundpixeloverlay");jZ=j6.programMgr.useProgram("groundpixeloverlay",T);jZ.lastState.fHashcode=jX.fHashcode}}if(jZ.lastState.opacity!==j3.opacity){j1.uniform1f(jZ.uniforms.u_opacity,j3.opacity);jZ.lastState.opacity=j3.opacity}if(!jZ.lastState.projMatrix){j1.uniformMatrix4fv(jZ.uniforms.u_proj_matrix,false,j6.projMatrix);jZ.lastState.projMatrix=true}jY.vao1.bind(j1,jZ,jY.vertex,jY.element1);j6._state.activeTexture(j1.TEXTURE0);j1.bindTexture(j1.TEXTURE_2D,j5);j1.uniform1i(jZ.uniforms.u_Sampler,0);if(j4){j6._state.activeTexture(j1.TEXTURE1);j1.bindTexture(j1.TEXTURE_2D,j4);j1.uniform1i(jZ.uniforms.u_ColorMap,1);if(jV){j6._state.activeTexture(j1.TEXTURE2);j1.bindTexture(j1.TEXTURE_2D,jV);j1.uniform1i(jZ.uniforms.u_Mask,2);j1.uniform1i(jZ.uniforms.u_maskLoaded,1)}else{j1.uniform1i(jZ.uniforms.u_maskLoaded,0)}var jW=j3.overlay._config.domain;j1.uniform2f(jZ.uniforms.u_domain,jW[0],jW[1]);var j2=j3.overlay._config.clamp;j1.uniform2f(jZ.uniforms.u_clamp,j2[0],j2[1]);var j8=j3.overlay._config.maskData;j1.uniform1f(jZ.uniforms.u_maskData,j8);var j7=j3.overlay._config.noData;j1.uniform1f(jZ.uniforms.u_noData,j7)}j1.uniformMatrix4fv(jZ.uniforms.u_mv_matrix,false,j0);j1.drawElements(j1.TRIANGLES,jY.element1.length,j1.UNSIGNED_SHORT,0)}return function i(jV,j0,jY,T,jZ,jX,j1,jW){jW=jW||{};e(jV,j0.mvMatrix,jY,T,jZ,jX,j1)}})();function je(j0,j5,k7){var kz=new j0.Int8Array(k7);var ky=new j0.Int16Array(k7);var kx=new j0.Int32Array(k7);var kw=new j0.Uint8Array(k7);var ku=new j0.Uint16Array(k7);var kt=new j0.Uint32Array(k7);var ks=new j0.Float32Array(k7);var kr=new j0.Float64Array(k7);var kp=j5.DYNAMICTOP_PTR|0;var ko=j5.tempDoublePtr|0;var kn=j5.ABORT|0;var km=j5.STACKTOP|0;var kl=j5.STACK_MAX|0;var kj=j5.gb|0;var ki=j5.fb|0;var kh=0;var kg=0;var kf=0;var ke=0;var kd=j0.NaN,kc=j0.Infinity;var kb=0,j9=0,j8=0,j7=0,j6=0;var k4=0;var k3=j0.Math.floor;var k2=j0.Math.abs;var k1=j0.Math.sqrt;var kZ=j0.Math.pow;var kY=j0.Math.cos;var kX=j0.Math.sin;var kW=j0.Math.tan;var kV=j0.Math.acos;var kT=j0.Math.asin;var kS=j0.Math.atan;var kR=j0.Math.atan2;var kQ=j0.Math.exp;var kP=j0.Math.log;var kO=j0.Math.ceil;var kM=j0.Math.imul;var kL=j0.Math.min;var kK=j0.Math.max;var kJ=j0.Math.clz32;var kI=j5.abort;var kH=j5.assert;var kG=j5.enlargeMemory;var kF=j5.getTotalMemory;var kE=j5.abortOnCannotGrowMemory;var kD=j5.setTempRet0;var kC=j5.getTempRet0;var kB=0;function ld(i){i=i|0;var e=0;e=km;km=km+i|0;km=km+15&-16;return e|0}function k8(){return km|0}function kN(e){e=e|0;km=e}function kk(i,e){i=i|0;e=e|0;km=i;kl=e}function j1(i,e){i=i|0;e=e|0;if(!kh){kh=i;kg=e}}function jW(){return kj+1892368|0}function lg(){return kj+1990672|0}function k9(){return kj+0|0}function kU(){return kj+4374544|0}function kq(){return kj+1998864|0}function j2(){return kj+1998864+(kx[kj+32768>>2]<<1)|0}function jX(){return kj+2523152|0}function li(){return kj+2523152+((kx[kj+32772>>2]|0)*20|0)|0}function lc(){return kx[kj+32772>>2]|0}function k0(){kx[kj+32768>>2]=0;kx[kj+32772>>2]=0;return}function kv(){return kj+32776|0}function j3(){return kj+3833872|0}function jY(){kx[kj+40968>>2]=0;kx[kj+40972>>2]=0;return}function lj(){return kj+3842064|0}function le(){return kj+3842064+(kx[kj+40968>>2]<<1)|0}function k5(){return kj+40976|0}function kA(){return kj+40976+((kx[kj+40972>>2]|0)*28|0)|0}function j4(){return kx[kj+40972>>2]|0}function jZ(){return kj+1875984|0}function jV(T,i){T=T|0;i=i|0;var ll=0,lk=0,la=0,ka=0;lk=(i|0)>0;if(lk){ll=0;do{la=kj+1875984+(ll<<2)|0;ks[la>>2]=+ks[la>>2]/100;ll=ll+1|0}while((ll|0)!=(i|0))}if((i|0)>=(T|0)|lk^1){return}else{ll=i}do{lk=0;do{ka=lk+ll|0;la=kj+1875984+(ka<<2)|0;ks[la>>2]=+ks[kj+1875984+(ka-i<<2)>>2]+ +ks[la>>2]/100;lk=lk+1|0}while((lk|0)!=(i|0));ll=ll+i|0}while((ll|0)<(T|0));return}function lf(lK,lJ,lI,lH,lG,lF,lE,lD,lC,lB,lA,lz,lx){lK=lK|0;lJ=lJ|0;lI=lI|0;lH=lH|0;lG=lG|0;lF=+lF;lE=lE|0;lD=lD|0;lC=lC|0;lB=lB|0;lA=lA|0;lz=lz|0;lx=lx|0;var lv=0,lt=0,ls=0,lq=0,lo=0,lm=0,lk=0,ka=0,T=0,ly=0,lw=0,lu=0,lr=0,lp=0,ln=0,ll=0,la=0;lp=(lK|0)/2|0;ln=lA<<24>>24==1;if(ln){ky[kj+4366352>>1]=0;if((lB|0)>2){lv=0;lt=2;do{la=+(kx[kj+0+(lt<<2)>>2]|0);ll=+(kx[kj+0+((lt|1)<<2)>>2]|0);lv=(~~(+k1(+(la*la+ll*ll))/10)<<16>>16)+(lv<<16>>16)|0;ky[kj+4366352+(((lt|0)/2|0)<<1)>>1]=lv;lt=lt+2|0}while((lt|0)<(lB|0));lv=4}}else{lv=4}if((lv|0)==4?(lB|0)>2:0){lv=2;lt=kx[kj+0>>2]|0;do{lu=kj+0+(lv<<2)|0;lt=(kx[lu>>2]|0)+lt|0;kx[lu>>2]=lt;lu=lv|1;lr=kj+0+(lu<<2)|0;kx[lr>>2]=(kx[lr>>2]|0)+(kx[kj+0+(lu+-2<<2)>>2]|0);lv=lv+2|0}while((lv|0)<(lB|0))}if(lC<<24>>24){ky[kj+1892368>>1]=ky[kj+1892368+8>>1]|0;ky[kj+1892368+2>>1]=ky[kj+1892368+10>>1]|0;ky[kj+1892368+4>>1]=ky[kj+1892368+12>>1]|0;ky[kj+1892368+6>>1]=ky[kj+1892368+14>>1]|0;lr=lp<<1;ky[kj+1892368+(lr+-2<<1)>>1]=ky[kj+1892368+(lr+-6<<1)>>1]|0;ky[kj+1892368+(lr+-1<<1)>>1]=ky[kj+1892368+(lr+-5<<1)>>1]|0;ky[kj+1892368+(lr+-4<<1)>>1]=ky[kj+1892368+(lr+-8<<1)>>1]|0;ky[kj+1892368+(lr+-3<<1)>>1]=ky[kj+1892368+(lr+-7<<1)>>1]|0}lu=lx-lz|0;lr=kx[kj+32772>>2]|0;if((lK|0)<=1){k6(lu,lr);return}ly=(lE|0)==0;lw=lp+-2|0;lm=lA<<24>>24==2;lk=lp+-1|0;ka=lp+-4|0;T=lz+1|0;lo=lx+-1|0;ls=0;lv=0;lq=lr;do{if((ls|0)>=4){if((ka|0)>(ls|0)){lB=T+((ls+-4|0)/5|0)|0}else{lB=lo}}else{lB=lz}if(!ly){lv=ky[kj+1990672+(lB<<1)>>1]|0}lK=lB<<1;lx=((kx[kj+0+(lK<<2)>>2]|0)/10|0)&65535;lK=((kx[kj+0+((lK|1)<<2)>>2]|0)/10|0)&65535;lA=ls<<1;lE=~~(+(ky[kj+1892368+(lA<<1)>>1]|0)*lF/10);lA=~~(+(ky[kj+1892368+((lA|1)<<1)>>1]|0)*lF/10);kz:do{if(!((ls|0)==0|(ls|0)==(lw|0))){if((ls|0)==1|(ls|0)==(lk|0)){lC=-1}else{lt=ls+-2|0;switch((lt|0)%5|0|2|0){case 2:lC=1;break kz;case 3:lC=-1;break kz;default:lC=kz[((lt|0)/5|0)+(kj+4374544)>>0]|0;break kz}}}else{lC=1}}while(0);if(ln){lt=ky[kj+4366352+(lB<<1)>>1]|0}else{lt=lm?((lB|0)==0?0:10):0}lB=lq;lq=lq+1|0;ky[kj+2523152+(lB*20|0)>>1]=lx;ky[kj+2523152+(lB*20|0)+2>>1]=lK;ky[kj+2523152+(lB*20|0)+4>>1]=lE;ky[kj+2523152+(lB*20|0)+6>>1]=lA;kz[kj+2523152+(lB*20|0)+8>>0]=lJ;kz[kj+2523152+(lB*20|0)+9>>0]=lI;kz[kj+2523152+(lB*20|0)+10>>0]=lH;kz[kj+2523152+(lB*20|0)+11>>0]=lG;ky[kj+2523152+(lB*20|0)+12>>1]=lC;ky[kj+2523152+(lB*20|0)+14>>1]=lv;ky[kj+2523152+(lB*20|0)+16>>1]=lD;ky[kj+2523152+(lB*20|0)+18>>1]=lt;ls=ls+1|0}while((ls|0)<(lp|0));kx[kj+32772>>2]=lq;k6(lu,lr);return}function k6(lu,lt){lu=lu|0;lt=lt|0;var ls=0,lr=0,lq=0,lp=0,lo=0,ln=0,lm=0,ll=0,lk=0,la=0,ka=0,T=0;ll=lu+-1|0;lm=lu+-2|0;ln=0;ls=1;lr=1;lo=kx[kj+32768>>2]|0;while(1){lu=ls+1|0;la=lu+lt|0;lu=(lu&1|0)==0;lp=lr<<24>>24!=0;ka=la+-2|0;lk=ls+lt|0;lq=lp?ka:lk;ka=lp?lk:ka;ky[kj+1998864+(lo<<1)>>1]=lu?lq:ka;ky[kj+1998864+(lo+1<<1)>>1]=lu?ka:lq;ky[kj+1998864+(lo+2<<1)>>1]=la;la=ls+2|0;lq=la+lt|0;la=(la&1|0)==0;ka=lq+-1|0;lu=lp?lk:ka;lk=lp?ka:lk;ky[kj+1998864+(lo+3<<1)>>1]=la?lu:lk;ky[kj+1998864+(lo+4<<1)>>1]=la?lk:lu;lu=lo+6|0;ky[kj+1998864+(lo+5<<1)>>1]=lq;if((ln|0)>=(ll|0)){break}la=ls+3|0;lq=la+lt|0;la=(la&1|0)==0;lk=lq+-2|0;T=lq+-1|0;ka=lp?lk:T;lk=lp?T:lk;ky[kj+1998864+(lu<<1)>>1]=la?ka:lk;ky[kj+1998864+(lo+7<<1)>>1]=la?lk:ka;ky[kj+1998864+(lo+8<<1)>>1]=lq;lq=ls+4|0;ka=lq+lt|0;lk=(lq&1|0)==0;la=ka+-2|0;T=ka+-1|0;lu=lp?la:T;la=lp?T:la;ky[kj+1998864+(lo+9<<1)>>1]=lk?lu:la;ky[kj+1998864+(lo+10<<1)>>1]=lk?la:lu;lu=lo+12|0;ky[kj+1998864+(lo+11<<1)>>1]=ka;if((ln|0)==(lm|0)){ls=lq}else{ls=ls+5|0;T=ls+lt|0;lk=(ls&1|0)==0;la=T+-2|0;lq=T+-1|0;ka=lp?la:lq;la=lp?lq:la;ky[kj+1998864+(lu<<1)>>1]=lk?ka:la;ky[kj+1998864+(lo+13<<1)>>1]=lk?la:ka;ky[kj+1998864+(lo+14<<1)>>1]=T;lr=lr<<24>>24==0&1;lu=lo+15|0}ln=ln+1|0;lo=lu}kx[kj+32768>>2]=lu;return}function lh(lF,lE,lD,lC,lB,lA,lz,ly,lx,lw,lu){lF=lF|0;lE=lE|0;lD=+lD;lC=lC|0;lB=lB|0;lA=lA|0;lz=lz|0;ly=ly|0;lx=lx|0;lw=lw|0;lu=lu|0;var ls=0,lq=0,lo=0,lm=0,lk=0,la=0,ka=0,T=0,e=0,lv=0,lt=0,lr=0,lp=0,ln=0,ll=0;if((lF|0)>2){ls=2;lq=kx[kj+32776>>2]|0;do{lm=kj+32776+(ls<<2)|0;lq=(kx[lm>>2]|0)+lq|0;kx[lm>>2]=lq;lm=ls|1;lk=kj+32776+(lm<<2)|0;kx[lk>>2]=(kx[lk>>2]|0)+(kx[kj+32776+(lm+-2<<2)>>2]|0);ls=ls+2|0}while((ls|0)<(lF|0))}lm=kx[kj+40972>>2]|0;lk=(lF|0)>0;if(lk){lq=lm+((lF+-1|0)>>>1)|0;ls=0;lo=lm;while(1){la=+(kx[kj+32776+((ls|1)<<2)>>2]|0)/100;ks[kj+40976+(lo*28|0)>>2]=+(kx[kj+32776+(ls<<2)>>2]|0)/100;ks[kj+40976+(lo*28|0)+4>>2]=la;ks[kj+40976+(lo*28|0)+8>>2]=lD;ks[kj+40976+(lo*28|0)+12>>2]=0;ks[kj+40976+(lo*28|0)+16>>2]=0;ks[kj+40976+(lo*28|0)+20>>2]=1;kz[kj+40976+(lo*28|0)+24>>0]=lC;kz[kj+40976+(lo*28|0)+25>>0]=lB;kz[kj+40976+(lo*28|0)+26>>0]=lA;kz[kj+40976+(lo*28|0)+27>>0]=lz;ls=ls+2|0;if((ls|0)>=(lF|0)){break}else{lo=lo+1|0}}ls=lq+1|0;kx[kj+40972>>2]=ls}else{ls=lm}if((lE|0)>0){lC=kx[kj+40968>>2]|0;lq=0;lo=lC;while(1){ky[kj+3842064+(lo<<1)>>1]=(ku[kj+3833872+(lq<<1)>>1]|0)+lm;lq=lq+1|0;if((lq|0)==(lE|0)){break}else{lo=lo+1|0}}kx[kj+40968>>2]=lC+lE}if(!lk){return}lC=lF+-2|0;lo=kx[kj+40968>>2]|0;lA=(lF+-1|0)>>>1;lB=ls+(lA<<2)|0;lA=lo+(lA*6|0)|0;lq=0;while(1){lr=+(kx[kj+32776+(lq<<2)>>2]|0)/100;lt=+(kx[kj+32776+((lq|1)<<2)>>2]|0)/100;lE=lq;lq=lq+2|0;lz=(lE|0)==(lC|0);lv=+(kx[kj+32776+((lz?0:lq)<<2)>>2]|0)/100;e=+(kx[kj+32776+((lz?1:lE+3|0)<<2)>>2]|0)/100;ln=lv-lr;la=e-lt;lp=lr-lr;ll=lt-lt;T=la*lD-ll*0;ka=lp*0-ln*lD;la=ll*ln-lp*la;lE=ls+1|0;ks[kj+40976+(ls*28|0)>>2]=lr;ks[kj+40976+(ls*28|0)+4>>2]=lt;ks[kj+40976+(ls*28|0)+8>>2]=0;ks[kj+40976+(ls*28|0)+12>>2]=T;ks[kj+40976+(ls*28|0)+16>>2]=ka;ks[kj+40976+(ls*28|0)+20>>2]=la;kz[kj+40976+(ls*28|0)+24>>0]=ly;kz[kj+40976+(ls*28|0)+25>>0]=lx;kz[kj+40976+(ls*28|0)+26>>0]=lw;kz[kj+40976+(ls*28|0)+27>>0]=lu;lz=ls+2|0;ks[kj+40976+(lE*28|0)>>2]=lr;ks[kj+40976+(lE*28|0)+4>>2]=lt;ks[kj+40976+(lE*28|0)+8>>2]=lD;ks[kj+40976+(lE*28|0)+12>>2]=T;ks[kj+40976+(lE*28|0)+16>>2]=ka;ks[kj+40976+(lE*28|0)+20>>2]=la;kz[kj+40976+(lE*28|0)+24>>0]=ly;kz[kj+40976+(lE*28|0)+25>>0]=lx;kz[kj+40976+(lE*28|0)+26>>0]=lw;kz[kj+40976+(lE*28|0)+27>>0]=lu;lk=ls+3|0;ks[kj+40976+(lz*28|0)>>2]=lv;ks[kj+40976+(lz*28|0)+4>>2]=e;ks[kj+40976+(lz*28|0)+8>>2]=0;ks[kj+40976+(lz*28|0)+12>>2]=T;ks[kj+40976+(lz*28|0)+16>>2]=ka;ks[kj+40976+(lz*28|0)+20>>2]=la;kz[kj+40976+(lz*28|0)+24>>0]=ly;kz[kj+40976+(lz*28|0)+25>>0]=lx;kz[kj+40976+(lz*28|0)+26>>0]=lw;kz[kj+40976+(lz*28|0)+27>>0]=lu;ks[kj+40976+(lk*28|0)>>2]=lv;ks[kj+40976+(lk*28|0)+4>>2]=e;ks[kj+40976+(lk*28|0)+8>>2]=lD;ks[kj+40976+(lk*28|0)+12>>2]=T;ks[kj+40976+(lk*28|0)+16>>2]=ka;ks[kj+40976+(lk*28|0)+20>>2]=la;kz[kj+40976+(lk*28|0)+24>>0]=ly;kz[kj+40976+(lk*28|0)+25>>0]=lx;kz[kj+40976+(lk*28|0)+26>>0]=lw;kz[kj+40976+(lk*28|0)+27>>0]=lu;lm=ls&65535;ky[kj+3842064+(lo<<1)>>1]=lm;ky[kj+3842064+(lo+1<<1)>>1]=lz;lk=lk&65535;ky[kj+3842064+(lo+2<<1)>>1]=lk;ky[kj+3842064+(lo+3<<1)>>1]=lm;ky[kj+3842064+(lo+4<<1)>>1]=lk;ky[kj+3842064+(lo+5<<1)>>1]=lE;if((lq|0)>=(lF|0)){break}else{lo=lo+6|0;ls=ls+4|0}}kx[kj+40972>>2]=lB+4;kx[kj+40968>>2]=lA+6;return}function lb(){}return{_reset_line:k0,_get_block_index_start:lj,setThrew:j1,_get_line_turnings_address:kU,_get_block_triangle_indices_address:j3,_get_line_vertex_count:lc,stackAlloc:ld,_get_block_vertex_count:j4,_get_block_vertex_start:k5,_get_line_vertex_end:li,_get_feature_points_address:jZ,stackRestore:kN,_get_block_index_end:le,_get_line_altitudes_address:lg,_get_block_vertex_end:kA,stackSave:k8,runPostSets:lb,_get_line_vertex_start:jX,_parse_points:jV,_get_line_points_address:k9,establishStackSpace:kk,_get_line_index_end:j2,_append_line_data:lf,_get_line_index_start:kq,_append_block_data:lh,_get_block_points_address:kv,_reset_block:jY,_get_line_data_address:jW}}var eb;var jD;var iH;var a4;var gl;var dz;var ae;var fw;var gM;var fI;var dv;var b1;var hK;var jh;var ct;var aL;var fe;var f0;if(!ArrayBuffer.prototype.slice){ArrayBuffer.prototype.slice=function(T,i){if(T===undefined){T=0}if(i===undefined){i=this.byteLength}T=Math.floor(T);i=Math.floor(i);if(T<0){T+=this.byteLength}if(i<0){i+=this.byteLength}T=Math.min(Math.max(0,T),this.byteLength);i=Math.min(Math.max(0,i),this.byteLength);if(i-T<=0){return new ArrayBuffer(0)}var e=new ArrayBuffer(i-T);var jW=new Uint8Array(e);var jV=new Uint8Array(this,T,i-T);jW.set(jV);return e}}function gs(i){var e=70;if(eb){i&&i();return}eb=new ArrayBuffer(e*65536);iH=new Float32Array(eb);a4=new Int32Array(eb);jD=new Int8Array(eb);gl=new Int16Array(eb);dz=new Uint16Array(eb);ae=self.createWasmModule(self,{DYNAMICTOP_PTR:0,tempDoublePtr:0,ABORT:0,STACKTOP:0,STACK_MAX:0,gb:0,fb:0},eb);i&&i()}function dw(e){if(!fw){fw=ae._get_line_data_address()>>1}gl.set(e,fw)}function bm(e){if(!gM){gM=ae._get_line_altitudes_address()>>1}gl.set(e,gM)}function gR(e){if(!fI){fI=ae._get_line_points_address()>>2}a4.set(e,fI)}function bN(e){if(!dv){dv=ae._get_line_turnings_address()}jD.set(e,dv)}function cS(e){if(!jh){jh=ae._get_block_points_address()>>2}a4.set(e,jh)}function W(e){if(!ct){ct=ae._get_block_triangle_indices_address()>>1}dz.set(e,ct)}var jt={parseFeature:function(i,T){var e=i.length;T=T||2;if(!f0){f0=ae._get_feature_points_address()>>2}iH.set(i,f0);ae._parse_points(e,T);return new Float32Array(eb.slice(f0<<2,(f0+e)<<2))},getBlockVertices:function(){if(!fe){fe=ae._get_block_vertex_start()}return new Float32Array(eb.slice(fe,ae._get_block_vertex_end()))},getBlockIndices:function(){if(!aL){aL=ae._get_block_index_start()}return new Uint16Array(eb.slice(aL,ae._get_block_index_end()))},getBlockVertexCount:function(){return ae._get_block_vertex_count()},getLineVertices:function(){if(!hK){hK=ae._get_line_vertex_start()}return new Float32Array(eb.slice(hK,ae._get_line_vertex_end()))},getLineIndices:function(){if(!b1){b1=ae._get_line_index_start()}return new Uint16Array(eb.slice(b1,ae._get_line_index_end()))},getLineVertexCount:function(){return ae._get_line_vertex_count()},appendLineData:function(jY,jX,jV,i,j1,e,j3,jZ,j2,T,jW){var j0=0;if(i){j0=i.length;bm(i)}if(jZ&&jZ.length){bN(jZ)}j1=j1||0;T=T||0;jW=jW||j3.length/2;dw(jY);gR(j3);ae._append_line_data(jY.length,jX[0],jX[1],jX[2],jX[3],jV,j0,j1,e?1:0,j3.length,j2,T,jW)},resetLine:function(){ae._reset_line()},appendBlockData:function(j2,j0,jY,jX,j1,e,T,jZ,i,jV,jW){cS(j2);W(j0);return ae._append_block_data(j2.length,j0.length,jY,jX,j1,e,T,jZ,i,jV,jW)},resetBlock:function(){ae._reset_block()},initWasmModule:gs};var bh={block:[["precision highp float;attribute vec4 a_pos;attribute vec4 a_normal;attribute vec4 a_color;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;uniform mat4 u_normal_matrix;uniform vec3 u_side_light_dir;uniform bool u_is_normal;varying vec4 _;varying float a;const vec3 b=vec3(0.06,0.06,0.06);vec3 c=vec3(0.1,0.1,0.1);void main(){vec4 d=u_proj_matrix*u_mv_matrix*a_pos;gl_Position=d;a=-1./500.-a_pos.z/100.;gl_Position.z=gl_Position.z+a;if(!u_is_normal){c=vec3(0.2,0.2,0.2);}if(u_is_normal&&a_normal==vec4(0.,0.,1.,1.)){_=a_color;}else{vec3 e=a_color.rgb;vec3 f=normalize(vec3(u_normal_matrix*a_normal));vec4 g=u_mv_matrix*vec4(0,1,0,0);vec3 h=normalize(g.xyz);float i=max(0.,dot(f,-h));vec4 j=u_mv_matrix*vec4(u_side_light_dir,0);vec3 k=normalize(j.xyz);float l=max(0.,dot(f,-k));if(a_pos.z<2.){float m=(2.-a_pos.z)/5.;l=l-m;}_=vec4(e+e*c*l+e*b*i,a_color.a);}}",""].join("\\n"),["precision highp float;varying vec4 _;varying float a;uniform float u_camera_far;float b=500.0;void main(){float c=(gl_FragCoord.z/gl_FragCoord.w-a);float d=_.a;if(c>u_camera_far-b){d=d*(u_camera_far-c)/b;if(d<=0.){discard;}}gl_FragColor=vec4(_.rgb,d);}",""].join("\\n")],shadow:[["precision highp float;attribute vec3 a_pos;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;uniform vec3 u_light_dir;varying vec4 _;varying float a;const vec4 b=vec4(153.0/255.0,157.0/255.0,170.0/255.0,.15);void main(){float c=u_light_dir.x/u_light_dir.z*a_pos.z;float d=u_light_dir.y/u_light_dir.z*a_pos.z;vec2 e=vec2(a_pos.x+c,a_pos.y+d);a=a_pos.z;gl_Position=u_proj_matrix*u_mv_matrix*vec4(e,0,1);_=b;}",""].join("\\n"),["precision highp float;varying vec4 _;varying float a;uniform float u_camera_far;float b=500.0;void main(){if(a<1.){discard;}else{float c=gl_FragCoord.z/gl_FragCoord.w;float d=_.a;if(c>u_camera_far-b){d=d*(u_camera_far-c)/b;if(d<=0.){discard;}}gl_FragColor=vec4(_.rgb,d);}}",""].join("\\n")],arrow:[["precision highp float;attribute vec3 a_pos;attribute vec2 a_diff;attribute vec2 a_normal;attribute vec2 a_tex;attribute float a_layer_index;varying vec2 _;varying float a;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;uniform float u_scale;uniform bool u_flat;void main(){float b=a_pos.z;vec2 c=(a_pos.xy+a_diff*u_scale)+normalize(a_normal)*2.5*u_scale;float d=-a_layer_index/500.-b/100.;if(u_flat){a=0.;gl_Position=u_proj_matrix*u_mv_matrix*vec4(c,0.,1);vec4 e=u_proj_matrix*u_mv_matrix*vec4(c,b/10.,1);gl_Position.z=e.z+d;}else{a=b;gl_Position=u_proj_matrix*u_mv_matrix*vec4(c,b,1);gl_Position.z=gl_Position.z+d;}_=a_tex;}",""].join("\\n"),["precision mediump float;uniform sampler2D u_image;uniform int u_draw_part;varying vec2 _;varying float a;void main(){if(u_draw_part==1){if(a>0.){discard;}}else if(u_draw_part==2){if(a==0.){discard;}}gl_FragColor=texture2D(u_image,_);}",""].join("\\n")],grid:[["precision highp float;attribute vec2 a_pos;attribute vec2 a_tex;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;uniform float u_tex_scale;varying vec2 _;void main(){vec4 a=u_proj_matrix*u_mv_matrix*vec4(a_pos,0,1);gl_Position=a;_=a_tex*u_tex_scale;}",""].join("\\n"),["precision mediump float;uniform sampler2D u_image;varying vec2 _;void main(){gl_FragColor=texture2D(u_image,_);}",""].join("\\n")],line:[["attribute vec2 a_pos;attribute vec2 a_normal;attribute vec4 a_color;attribute vec4 a_data;uniform mat4 u_mv_matrix;uniform mat4 u_proj_matrix;uniform float u_scale;uniform bool u_flat;varying float _;varying vec4 a;varying float b;varying float c;varying float d;const float e=0.5;void main(){vec2 f=a_normal/10.;_=a_data.x;float g=a_data.y/100.;float h=a_data.z;float i=length(f);float j=1.+e/i;b=1.-(2.*e/(i+e));a=a_color;d=-h/500.-g/100.;vec2 k=a_pos/10.+f*j*u_scale;if(u_flat){gl_Position=u_proj_matrix*u_mv_matrix*vec4(k,0.,1);vec4 l=u_proj_matrix*u_mv_matrix*vec4(k,g/10.,1);gl_Position.z=l.z+d;c=0.;}else{gl_Position=u_proj_matrix*u_mv_matrix*vec4(k,g,1.);gl_Position.z=gl_Position.z+d;c=g;}}",""].join("\\n"),["precision highp float;uniform int u_draw_part;varying float _;varying vec4 a;varying float b;varying float c;varying float d;uniform float u_camera_far;float e=500.0;void main(){if(u_draw_part==1){if(c>0.){discard;}}else if(u_draw_part==2){if(c==0.){discard;}}vec4 f;if(abs(_)>b){float g=1.-(abs(_)-b)/(1.-b);f=vec4(a.rgb,g*a.a);}else{f=a;}float g=(gl_FragCoord.z/gl_FragCoord.w-d);float h=f.a;if(g>u_camera_far-e){h=h*(u_camera_far-g)/e;if(h<=0.){discard;}}f.a=h;gl_FragColor=f;}",""].join("\\n")],dash:[["attribute vec2 a_pos;attribute vec2 a_normal;attribute vec4 a_color;attribute vec4 a_data;uniform mat4 u_mv_matrix;uniform mat4 u_proj_matrix;uniform float u_scale;uniform float u_dash;uniform float u_step_zoom;uniform float u_tile_zoom;uniform bool u_is_single;uniform bool u_flat;varying float _;varying vec2 a;varying vec4 b;varying float c;varying float d;varying float e;const float f=0.2;void main(){vec2 g=a_normal/10.;_=a_data.x;float h=a_data.y/100.;float i=a_data.z;float j=a_data.w/10.;float k=length(g);float l=1.+f/k;c=1.-(2.*f/(k+f));b=vec4(a_color.rgb,floor(a_color.a/10.));float m=0.;if(u_is_single){m=j;}else{m=j/u_dash/pow(2.,u_tile_zoom-u_step_zoom);}if(_==1.){a=vec2(1.,m);}else{a=vec2(0.,m);}e=-i/500.-h/100.;vec2 n=a_pos/10.+g*l*u_scale;if(u_flat){gl_Position=u_proj_matrix*u_mv_matrix*vec4(n,0.,1);vec4 o=u_proj_matrix*u_mv_matrix*vec4(n,h/10.,1);gl_Position.z=o.z+e;d=0.;}else{gl_Position=u_proj_matrix*u_mv_matrix*vec4(n,h,1.);gl_Position.z=gl_Position.z+e;d=h;}}",""].join("\\n"),["precision highp float;uniform sampler2D u_image;uniform float u_dash;uniform int u_draw_part;uniform float u_alpha;varying vec4 b;varying float _;varying vec2 a;varying float d;varying float e;varying float c;uniform float u_camera_far;float f=500.0;void main(){if(u_draw_part==1){if(d>0.){discard;}}else if(u_draw_part==2){if(d==0.){discard;}}vec4 g=texture2D(u_image,a);float h=g.a*u_alpha+b.a;vec4 i;if(abs(_)>c){float j=1.-(abs(_)-c)/(1.-c);i=vec4(g.rgb*j,j*h);}else{i=g*u_alpha;}float j=(gl_FragCoord.z/gl_FragCoord.w-e);float k=i.a;if(j>u_camera_far-f){k=k*(u_camera_far-j)/f;if(k<=0.){discard;}}i.a=k;gl_FragColor=i;}",""].join("\\n")],fill:[["precision highp float;attribute vec3 a_pos;attribute vec4 a_color;attribute float a_layer_index;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;uniform bool u_flat;varying vec4 _;varying float a;varying float b;void main(){float c=a_pos.z;b=-a_layer_index/500.-c/100.;if(u_flat){gl_Position=u_proj_matrix*u_mv_matrix*vec4(a_pos.xy,0.,1);vec4 d=u_proj_matrix*u_mv_matrix*vec4(a_pos.xy,c/10.,1);gl_Position.z=d.z+b;a=0.;}else{gl_Position=u_proj_matrix*u_mv_matrix*vec4(a_pos.xy,c,1);gl_Position.z=gl_Position.z+b;a=c;}_=a_color;}",""].join("\\n"),["precision highp float;uniform int u_draw_part;varying vec4 _;varying float a;varying float b;uniform float u_camera_far;float c=500.0;void main(){if(u_draw_part==1){if(a>0.){discard;}}else if(u_draw_part==2){if(a==0.){discard;}}float d=(gl_FragCoord.z/gl_FragCoord.w-b);float e=_.a/255.;if(d>u_camera_far-c){e=e*(u_camera_far-d)/c;if(e<=0.){discard;}}gl_FragColor=vec4(_.r/255.,_.g/255.,_.b/255.,e);}",""].join("\\n")],debug:[["precision highp float;attribute vec2 a_pos;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;void main(){gl_Position=u_proj_matrix*u_mv_matrix*vec4(a_pos,step(32767.,a_pos.x),1);}",""].join("\\n"),["precision mediump float;uniform vec4 u_color;void main(){gl_FragColor=u_color;}",""].join("\\n")],symbol:[["precision highp float;attribute vec4 aPosition;attribute float aZLevel;attribute vec2 aExtend;attribute vec2 aLoopOffset;attribute vec2 aVertexTextureCoord;varying vec2 _;varying vec2 a;varying vec3 b;uniform bool uUseRound;uniform mat4 uMVMatrix;uniform mat4 uPMatrix;uniform mat4 uOrthoPMatrix;uniform vec2 uMapHalfSize;uniform float uMapZoom;uniform vec3 uCameraPosHigh;uniform vec3 uCameraPosLow;uniform vec3 uFixPositionInfo;void main(){vec4 c;vec3 d=vec3(aPosition.xy,aZLevel);vec3 e=vec3(aPosition.zw,aZLevel);a=vec2(1.,1.);d.x+=aLoopOffset.x;e.x+=aLoopOffset.y;vec4 f=uPMatrix*uMVMatrix*vec4((d-uCameraPosHigh)+(e-uCameraPosLow),1.);float g=f[3]+100.;if((f[0]<-g||f[0]>g||f[1]<-g||f[1]>g||f[2]<-g||f[2]>g)&&uFixPositionInfo[0]!=1.){a=vec2(0.,0.);}vec3 h=vec3(f[0]/f[3],f[1]/f[3],f[2]/f[3]);vec3 i=vec3((h[0]+1.)*uMapHalfSize[0],(1.-h[1])*uMapHalfSize[1],0.5*h[2]+0.5);if(uFixPositionInfo[0]==1.){float j=uMapHalfSize[0]*2.;if(i[0]>j+20.){d.x-=uFixPositionInfo[1];e.x-=uFixPositionInfo[2];f=uPMatrix*uMVMatrix*vec4((d-uCameraPosHigh)+(e-uCameraPosLow),1.);h=vec3(f[0]/f[3],f[1]/f[3],f[2]/f[3]);i=vec3((h[0]+1.)*uMapHalfSize[0],(1.-h[1])*uMapHalfSize[1],0.5*h[2]+0.5);}else if(i[0]<-20.){d.x+=uFixPositionInfo[1];e.x+=uFixPositionInfo[2];f=uPMatrix*uMVMatrix*vec4((d-uCameraPosHigh)+(e-uCameraPosLow),1.);h=vec3(f[0]/f[3],f[1]/f[3],f[2]/f[3]);i=vec3((h[0]+1.)*uMapHalfSize[0],(1.-h[1])*uMapHalfSize[1],0.5*h[2]+0.5);}}c=vec4(i.xy,-100.,1.);c.y=uMapHalfSize[1]*2.-c.y;if(uUseRound==true){c.x=floor(c.x+.5);c.y=floor(c.y+.5);}c.x+=aExtend.x;c.y+=aExtend.y;b=vec3(1.,i.z,1./f[3]);gl_Position=uOrthoPMatrix*c;_=vec2(aVertexTextureCoord.xy);}",""].join("\\n"),["precision highp float;uniform sampler2D uSampler;uniform bool uForRenderPNG8Text;uniform bool uHighlight;uniform float uCameraFar;float c=500.0;varying vec2 _;varying vec2 a;varying vec3 b;void main(){if(a[0]==0.){discard;return;}vec4 d=texture2D(uSampler,_);if(uForRenderPNG8Text==true&&d.a<0.7){d.a=0.;}if(uHighlight==true){float e=d.a;if(e!=0.){float f=d.r;float g=d.g;float h=d.b;float i=floor((f*255.+g*255.+h*255.)/3.+0.5);float j=i-90.;if(j<0.){j=0.;}d.r=(51.+j*1.3)/255.;d.g=(133.+j*0.8)/255.;d.b=1.;}}float e=(b[1]/b[2]);float f=1.;if(e>uCameraFar-c){f=(uCameraFar-e)/c;if(f<=0.){discard;}}gl_FragColor=d*f;}",""].join("\\n")],symbolline:[["precision highp float;attribute vec2 aPosition;attribute float aZLevel;attribute vec2 aExtend;attribute vec2 aVertexTextureCoord;attribute vec2 aRotationCenter;attribute float aRotationAngle;varying vec2 _;varying vec2 a;uniform bool uUseRound;uniform mat4 uMVMatrix;uniform mat4 uPMatrix;uniform vec2 uMapHalfSize;uniform float uMapZoom;uniform bool uIsFlat;float b(float b){return pow(2.,18.-b);}void main(){vec4 c;float d=aZLevel;if(uIsFlat){d=0.;}a=vec2(1.,1.);float e=b(uMapZoom);vec2 f=aPosition.xy+aExtend.xy*e;float g=sin(radians(-aRotationAngle));float h=cos(radians(-aRotationAngle));mat2 i=mat2(h,-g,g,h);vec3 j=vec3(aRotationCenter.xy+i*(f.xy-aRotationCenter.xy),d);c=uMVMatrix*vec4(j,1.);gl_Position=uPMatrix*c;_=vec2(aVertexTextureCoord.xy);}",""].join("\\n"),["precision highp float;uniform sampler2D uSampler;uniform bool uForRenderPNG8Text;uniform float uCameraFar;float b=500.0;varying vec2 _;varying vec2 a;void main(){if(a[0]==0.){discard;return;}vec4 c=texture2D(uSampler,_);if(uForRenderPNG8Text==true&&c.a<0.7){c.a=0.;}float d;bool e=false;d=(gl_FragCoord.z/gl_FragCoord.w);float f=c.a;if(d>uCameraFar-b){f=f*(uCameraFar-d)/b;if(f<1.){discard;}}gl_FragColor=vec4(c.rgb,f);}",""].join("\\n")],raster:[["precision highp float;attribute vec3 aVertexPosition;attribute vec2 aVertexTextureCoord;varying vec2 _;uniform mat4 uMVMatrix;uniform mat4 uPMatrix;void main(){gl_Position=uPMatrix*uMVMatrix*vec4(aVertexPosition,1.);_=aVertexTextureCoord;}",""].join("\\n"),["precision highp float;uniform sampler2D uSampler;uniform bool uRenderPNG8;varying vec2 _;void main(){vec4 _=texture2D(uSampler,_);if(uRenderPNG8==true){_.a=smoothstep(0.7,1.,_.a);}gl_FragColor=_;}",""].join("\\n")],rasterpixel:[["precision highp float;attribute vec3 aVertexPosition;attribute vec2 aVertexTextureCoord;attribute vec4 aVertexMaskCoord;varying vec2 _;varying vec4 a;uniform mat4 uMVMatrix;uniform mat4 uPMatrix;void main(){gl_Position=uPMatrix*uMVMatrix*vec4(aVertexPosition,1.);_=aVertexTextureCoord;a=aVertexMaskCoord;}",""].join("\\n"),["precision highp float;uniform sampler2D uSampler;varying vec2 _;varying vec4 a;uniform sampler2D u_ColorMap;uniform sampler2D u_Mask;uniform float u_maskData;uniform float u_noData;uniform float u_opacity;uniform vec2 u_domain;uniform vec2 u_clamp;uniform bool u_maskLoaded;void main(){vec4 _=texture2D(uSampler,vec2(_.s,_.t));vec4 a=a;vec4 b=texture2D(u_Mask,vec2(a.s,a.t));float c=generateValue(_);if(c!=u_noData&&c>=u_clamp.s&&c<=u_clamp.t){c=(c-u_domain.s)/(u_domain.t-u_domain.s);vec4 d=texture2D(u_ColorMap,vec2(c,0));d.a*=_.a*u_opacity;_=d;}else{_=vec4(0,0,0,0);}if(u_maskLoaded){if(a.s<0.||a.s>1.||a.t<0.||a.t>1.){b.a=0.;}_.a*=b.a;if(u_maskData>0.){float d=b.r*255.;_.a*=(step(u_maskData,d)-step(u_maskData+1.,d));}}gl_FragColor=_;}",""].join("\\n")],sky:[["precision highp float;attribute vec3 aPos;uniform mat4 uPMatrix;uniform mat4 uMVMatrix;uniform float uHorizonY;uniform vec4 uGroundColor;uniform vec4 uSkyColor;varying vec4 _;void main(){vec2 a=aPos.xy;a.y+=uHorizonY;gl_Position=uPMatrix*uMVMatrix*vec4(a.xy,-2900.,1.);float b=aPos.z;if(b==0.){_=uGroundColor;}else{_=uSkyColor;}}",""].join("\\n"),["precision highp float;varying vec4 _;void main(){gl_FragColor=_;}",""].join("\\n")],smaa1:[["precision highp float;attribute vec3 position;attribute vec2 uv;uniform mat4 projectionMatrix;uniform mat4 modelViewMatrix;uniform vec2 resolution;varying vec2 _;varying vec4 a[3];void b(vec2 b){a[0]=b.xyxy+resolution.xyxy*vec4(-1.,0.,0.,1.);a[1]=b.xyxy+resolution.xyxy*vec4(1.,0.,0.,-1.);a[2]=b.xyxy+resolution.xyxy*vec4(-2.,0.,0.,2.);}void main(){_=uv;b(_);gl_Position=projectionMatrix*modelViewMatrix*vec4(position,1.);}",""].join("\\n"),["precision highp float;","#define A 0.1","uniform sampler2D tDiffuse;varying vec2 _;varying vec4 a[3];vec4 b(vec2 _,vec4 a[3],sampler2D b){vec2 c=vec2(A,A);vec4 d;vec3 e=texture2D(b,_).rgb;vec3 f=texture2D(b,a[0].xy).rgb;vec3 g=abs(e-f);d.x=max(max(g.r,g.g),g.b);vec3 h=texture2D(b,a[0].zw).rgb;g=abs(e-h);d.y=max(max(g.r,g.g),g.b);vec2 i=step(c,d.xy);if(dot(i,vec2(1.,1.))==0.)discard;vec3 j=texture2D(b,a[1].xy).rgb;g=abs(e-j);d.z=max(max(g.r,g.g),g.b);vec3 k=texture2D(b,a[1].zw).rgb;g=abs(e-k);d.w=max(max(g.r,g.g),g.b);float l=max(max(max(d.x,d.y),d.z),d.w);vec3 m=texture2D(b,a[2].xy).rgb;g=abs(e-m);d.z=max(max(g.r,g.g),g.b);vec3 n=texture2D(b,a[2].zw).rgb;g=abs(e-n);d.w=max(max(g.r,g.g),g.b);l=max(max(l,d.z),d.w);i.xy*=step(0.5*l,d.xy);return vec4(i,0.,0.);}void main(){gl_FragColor=b(_,a,tDiffuse);}",""].join("\\n")],smaa2:[["precision highp float;","#define A 8","#define B 16","#define C (1.0/vec2(160.0,560.0))","#define D (1.0/7.0)","attribute vec3 position;attribute vec2 uv;uniform vec2 resolution;uniform mat4 projectionMatrix;uniform mat4 modelViewMatrix;varying vec2 _;varying vec4 a[3];varying vec2 b;void c(vec2 c){b=c/resolution;a[0]=c.xyxy+resolution.xyxy*vec4(-0.25,0.125,1.25,0.125);a[1]=c.xyxy+resolution.xyxy*vec4(-0.125,0.25,-0.125,-1.25);a[2]=vec4(a[0].xz,a[1].yw)+vec4(-2.,2.,-2.,2.)*resolution.xxyy*float(A);}void main(){_=uv;c(_);gl_Position=projectionMatrix*modelViewMatrix*vec4(position,1.);}",""].join("\\n"),["precision highp float;","#define A 8","#define B 16","#define C (1.0/vec2(160.0,560.0))","#define D (1.0/7.0)","#define E(tex,coord,offset) texture2D(tex,coord+float(offset)*resolution,0.0)","uniform sampler2D tDiffuse;uniform sampler2D tArea;uniform sampler2D tSearch;uniform vec2 resolution;varying vec2 _;varying vec4 a[3];varying vec2 b;vec2 c(vec2 _){return sign(_)*floor(abs(_)+0.5);}float d(sampler2D d,vec2 e,float f,float g){e.r=f+e.r*g;return 255.*texture2D(d,e,0.).r;}float e(sampler2D e,sampler2D f,vec2 g,float h){vec2 i=vec2(0.,1.);for(int j=0;jh&&i.g>0.8281&&i.r==0.))break;}g.x+=0.25*resolution.x;g.x+=resolution.x;g.x+=2.*resolution.x;g.x-=resolution.x*d(f,i,0.,0.5);return g.x;}float f(sampler2D f,sampler2D g,vec2 h,float i){vec2 j=vec2(0.,1.);for(int k=0;k0.8281&&j.r==0.))break;}h.x-=0.25*resolution.x;h.x-=resolution.x;h.x-=2.*resolution.x;h.x+=resolution.x*d(g,j,0.5,0.5);return h.x;}float g(sampler2D g,sampler2D h,vec2 i,float j){vec2 k=vec2(1.,0.);for(int l=0;lj&&k.r>0.8281&&k.g==0.))break;}i.y-=0.25*resolution.y;i.y-=resolution.y;i.y-=2.*resolution.y;i.y+=resolution.y*d(h,k.gr,0.,0.5);return i.y;}float h(sampler2D h,sampler2D i,vec2 j,float k){vec2 l=vec2(1.,0.);for(int m=0;m0.8281&&l.g==0.))break;}j.y+=0.25*resolution.y;j.y+=resolution.y;j.y+=2.*resolution.y;j.y-=resolution.y*d(i,l.gr,0.5,0.5);return j.y;}vec2 i(sampler2D i,vec2 j,float k,float l,float m){vec2 n=float(B)*c(4.*vec2(k,l))+j;n=C*n+(0.5*C);n.y+=D*m;return texture2D(i,n,0.).rg;}vec4 j(vec2 j,vec2 k,vec4 l[3],sampler2D m,sampler2D n,sampler2D o,ivec4 p){vec4 q=vec4(0.,0.,0.,0.);vec2 r=texture2D(m,j).rg;if(r.g>0.){vec2 s;vec2 t;t.x=e(m,o,l[0].xy,l[2].x);t.y=l[1].y;s.x=t.x;float u=texture2D(m,t,0.).r;t.x=f(m,o,l[0].zw,l[2].y);s.y=t.x;s=s/resolution.x-k.x;vec2 v=sqrt(abs(s));t.y-=1.*resolution.y;float w=E(m,t,ivec2(1,0)).r;q.rg=i(n,v,u,w,float(p.y));}if(r.r>0.){vec2 s;vec2 t;t.y=g(m,o,l[1].xy,l[2].z);t.x=l[0].x;s.x=t.y;float u=texture2D(m,t,0.).g;t.y=h(m,o,l[1].zw,l[2].w);s.y=t.y;s=s/resolution.y-k.y;vec2 v=sqrt(abs(s));t.y-=1.*resolution.y;float w=E(m,t,ivec2(0,1)).g;q.ba=i(n,v,u,w,float(p.x));}return q;}void main(){gl_FragColor=j(_,b,a,tDiffuse,tArea,tSearch,ivec4(0.));}",""].join("\\n")],smaa3:[["precision highp float;uniform vec2 resolution;attribute vec3 position;attribute vec2 uv;uniform mat4 modelViewMatrix;uniform mat4 projectionMatrix;varying vec2 _;varying vec4 a[2];void b(vec2 b){a[0]=b.xyxy+resolution.xyxy*vec4(-1.,0.,0.,1.);a[1]=b.xyxy+resolution.xyxy*vec4(1.,0.,0.,-1.);}void main(){_=uv;b(_);gl_Position=projectionMatrix*modelViewMatrix*vec4(position,1.);}",""].join("\\n"),["precision highp float;uniform sampler2D tDiffuse;uniform sampler2D tColor;uniform vec2 resolution;varying vec2 _;varying vec4 a[2];vec4 b(vec2 _,vec4 a[2],sampler2D b,sampler2D c){vec4 d;d.xz=texture2D(c,_).xz;d.y=texture2D(c,a[1].zw).g;d.w=texture2D(c,a[1].xy).a;if(dot(d,vec4(1.,1.,1.,1.))<1e-5){return texture2D(b,_,0.);}else{vec2 e;e.x=d.a>d.b?d.a:-d.b;e.y=d.g>d.r?-d.g:d.r;if(abs(e.x)>abs(e.y)){e.y=0.;}else{e.x=0.;}vec4 f=texture2D(b,_,0.);_+=sign(e)*resolution;vec4 g=texture2D(b,_,0.);float h=abs(e.x)>abs(e.y)?abs(e.x):abs(e.y);f.xyz=pow(f.xyz,vec3(2.2));g.xyz=pow(g.xyz,vec3(2.2));vec4 i=mix(f,g,h);i.xyz=pow(i.xyz,vec3(1./2.2));return i;}}void main(){gl_FragColor=b(_,a,tColor,tDiffuse);}",""].join("\\n")],overlayfill:[["precision highp float;attribute vec2 a_pos;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;void main(){gl_Position=u_proj_matrix*u_mv_matrix*vec4(a_pos,0,1);}",""].join("\\n"),["precision mediump float;uniform vec4 u_color;void main(){gl_FragColor=u_color;}",""].join("\\n")],overlayblock:[["precision highp float;attribute vec4 a_pos;attribute vec4 a_normal;attribute vec4 a_color;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;uniform mat4 u_normal_matrix;uniform vec3 u_side_light_dir;uniform bool u_is_normal;varying vec4 _;varying float a;varying vec4 b;const vec3 c=vec3(0.06,0.06,0.06);vec3 d=vec3(0.1,0.1,0.1);void main(){vec4 e=u_proj_matrix*u_mv_matrix*a_pos;gl_Position=e;a=-1./500.-a_pos.z/100.;gl_Position.z=gl_Position.z+a;b=a_normal;_=a_color;vec3 f=a_color.rgb;vec3 g=normalize(vec3(u_normal_matrix*a_normal));vec4 h=u_mv_matrix*vec4(0.5,0.5,0,0);vec3 i=normalize(h.xyz);float j=max(0.,dot(g,-i));_=vec4(f+f*c*j,a_color.a);}",""].join("\\n"),["precision highp float;varying vec4 _;varying float a;uniform float u_camera_far;float c=500.0;void main(){float d=(gl_FragCoord.z/gl_FragCoord.w-a);float e=_.a;if(d>u_camera_far-c){e=e*(u_camera_far-d)/c;if(e<=0.){discard;}}gl_FragColor=vec4(_.rgb,e);}",""].join("\\n")],marker3d:[["attribute vec4 a_pos;attribute float a_height;attribute vec4 a_color;attribute float a_shape;attribute float a_size;attribute vec4 a_texture_coord;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;uniform vec3 u_camera_pos_high;uniform vec3 u_camera_pos_low;varying vec4 _;varying vec4 a;varying float b;void main(){if(a_color.w>=0.&&a_color.w<=1.){_=a_color;}else{_=vec4(a_color.xyz,1.);}b=a_shape;a=a_texture_coord;vec3 c=vec3(a_pos.xy,a_height);vec3 d=vec3(a_pos.zw,a_height);vec4 e=u_proj_matrix*u_mv_matrix*vec4((c-u_camera_pos_high)+(d-u_camera_pos_low),1.);gl_Position=e;gl_PointSize=a_size;}",""].join("\\n"),["precision mediump float;varying vec4 _;varying float b;varying vec4 a;uniform bool u_use_texture;uniform sampler2D u_Sampler;void main(){vec4 _=_;if(b==1.){float a=distance(gl_PointCoord,vec2(0.5,0.5));if(a>0.5){discard;}float b=1.;b=1.-smoothstep(0.49,0.5,a);_.a*=b;}if(u_use_texture){vec4 a=a;float b=a.x;float c=a.z-a.x;float d=a.y;float e=a.w-a.y;_=texture2D(u_Sampler,vec2(b+gl_PointCoord.x*c,d+e*(1.-gl_PointCoord.y)));}gl_FragColor=_;}",""].join("\\n")],groundoverlay:[["precision highp float;attribute vec3 a_pos;attribute vec4 a_texture_coord;varying vec4 _;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;void main(){gl_Position=u_proj_matrix*u_mv_matrix*vec4(a_pos.xy,0.,1.);_=a_texture_coord;}",""].join("\\n"),["precision highp float;varying vec4 _;uniform sampler2D u_Sampler;uniform float u_opacity;void main(){vec4 _=texture2D(u_Sampler,vec2(_.s,_.t));_.a*=u_opacity;gl_FragColor=_;}",""].join("\\n")],groundpixeloverlay:[["precision highp float;attribute vec3 a_pos;attribute vec4 a_texture_coord;attribute vec4 a_mask_coord;varying vec4 _;varying vec4 a;uniform mat4 u_proj_matrix;uniform mat4 u_mv_matrix;void main(){gl_Position=u_proj_matrix*u_mv_matrix*vec4(a_pos.xy,0.,1.);_=a_texture_coord;a=a_mask_coord;}",""].join("\\n"),["precision highp float;varying vec4 _;varying vec4 a;uniform sampler2D u_Sampler;uniform sampler2D u_ColorMap;uniform sampler2D u_Mask;uniform float u_noData;uniform float u_opacity;uniform float u_maskData;uniform vec2 u_domain;uniform vec2 u_clamp;uniform bool u_maskLoaded;void main(){vec4 _=texture2D(u_Sampler,vec2(_.s,_.t));vec4 a=a;vec4 b=texture2D(u_Mask,vec2(a.s,a.t));float c=generateValue(_);if(c!=u_noData&&c>=u_clamp.s&&c<=u_clamp.t){c=(c-u_domain.s)/(u_domain.t-u_domain.s);vec4 d=texture2D(u_ColorMap,vec2(c,0));d.a*=_.a*u_opacity;_=d;}else{_=vec4(0,0,0,0);}if(u_maskLoaded){if(a.s<0.||a.s>1.||a.t<0.||a.t>1.){b.a=0.;}_.a*=b.a;if(u_maskData>0.){float d=b.r*255.;_.a*=(step(u_maskData,d)-step(u_maskData+1.,d));}}gl_FragColor=_;}",""].join("\\n")],linelayer:[["precision highp float;attribute vec2 a_pos;attribute vec2 a_normal;attribute vec4 a_color;attribute vec4 a_data;attribute float a_id;uniform mat4 u_mv_matrix;uniform mat4 u_proj_matrix;uniform float u_scale;uniform bool u_flat;uniform float u_dash_length;uniform float u_margin_length;uniform float u_map_zoom;varying float _;varying float a;varying vec4 b;varying float c;varying float d;varying float e;varying float f;varying float g;varying float h;varying vec2 i;const float j=0.5;void main(){_=a_id;vec2 k=a_normal/10.;a=a_data.x;float l=a_data.y/100.;float m=a_data.z;f=a_data.w/10.;float n=length(k);float o=1.+j/n;c=1.-(2.*j/(n+j));b=a_color;e=-m/500.-l/100.;vec2 p=a_pos/10.+k*o*u_scale;g=u_dash_length*pow(2.,18.-u_map_zoom);h=u_margin_length*pow(2.,18.-u_map_zoom);if(u_dash_length>0.){float q=f/g;if(a==1.){i=vec2(1.,q);}else{i=vec2(0.,q);}}if(u_flat){gl_Position=u_proj_matrix*u_mv_matrix*vec4(p,0.,1);vec4 q=u_proj_matrix*u_mv_matrix*vec4(p,l/10.,1);gl_Position.z=q.z+e;d=0.;}else{gl_Position=u_proj_matrix*u_mv_matrix*vec4(p,l,1.);gl_Position.z=gl_Position.z+e;d=l;}}",""].join("\\n"),["precision highp float;uniform int u_draw_part;uniform sampler2D u_image;uniform float u_camera_far;uniform float u_opacity;uniform bool u_sequence;uniform bool u_pick_model;uniform bool u_no_gradual;uniform vec4 u_pick_color;uniform int u_pick_tag;uniform int u_del_tags[100];varying float _;varying float a;varying vec4 b;varying float c;varying float d;varying float e;varying float f;varying float g;varying float h;varying vec2 i;float j=500.0;vec4 k(float k){float l=k+1.;float m=floor(l/65536.);l=l-m*65536.;float n=floor(l/256.);l=l-n*256.;float o=l;return vec4(o/255.,n/255.,m/255.,1.);}bool l(float l){int m=int(l);bool n=false;for(int o=0;o<100;o++){if(u_del_tags[o]==0){break;}else if(u_del_tags[o]==m){n=true;break;}}return n;}void main(){if(u_draw_part==1){if(d>0.){discard;}}else if(u_draw_part==2){if(d==0.){discard;}}bool m=l(_);if(m){discard;}vec4 n=b;int o=int(_);if(o==u_pick_tag-1){n=vec4(u_pick_color.rgb/255.,u_pick_color.a*n.a);}if(u_pick_model){gl_FragColor=k(_);return;}float p=g;float q=h;float r=f;if(u_sequence){float s=q/2.;float t=mod(r,p+q);if(t>=s&&t<=s+p){float u=(t-s)/p;vec4 v=texture2D(u_image,vec2(i.x,u));n=v.a>=0.5?v:n;}}else if(p>0.){n=texture2D(u_image,i);}vec4 s;if(!u_no_gradual&&abs(a)>c){float t=1.-(abs(a)-c)/(1.-c);s=vec4(n.rgb,t*n.a);}else{s=n;}float t=(gl_FragCoord.z/gl_FragCoord.w-e);float u=s.a;if(t>u_camera_far-j){u=u*(u_camera_far-t)/j;if(u<=0.){discard;}}s.a=u*u_opacity;gl_FragColor=s;}",""].join("\\n")],filllayer:[["precision highp float;attribute vec2 a_pos;attribute float a_id;uniform mat4 u_mv_matrix;uniform mat4 u_proj_matrix;uniform bool u_flat;uniform float u_map_zoom;uniform vec2 u_size;uniform vec4 u_bound;uniform float u_scale;varying float _;varying float a;varying float b;varying vec2 c;const float d=0.5;void main(){_=a_id;c=a_pos.xy;float e=0.;a=-e/100.;if(u_flat){gl_Position=u_proj_matrix*u_mv_matrix*vec4(a_pos.xy,0.,1);vec4 f=u_proj_matrix*u_mv_matrix*vec4(a_pos.xy,e/10.,1);gl_Position.z=f.z+a;b=0.;}else{gl_Position=u_proj_matrix*u_mv_matrix*vec4(a_pos.xy,e,1.);gl_Position.z=gl_Position.z+a;b=e;}}",""].join("\\n"),["precision highp float;uniform vec4 u_color;uniform float u_opacity;uniform bool u_pattern;uniform bool u_pattern_mask;uniform sampler2D u_image;uniform float u_map_zoom;uniform vec2 u_size;uniform vec4 u_bound;uniform float u_scale;uniform vec2 u_offset;uniform float u_camera_far;uniform int u_draw_part;uniform bool u_pick_model;uniform vec4 u_pick_color;uniform int u_pick_tag;uniform int u_del_tags[100];varying float _;varying float b;varying float a;varying vec2 c;float d=500.0;bool e=false;vec4 f(float f){float g=f+1.;float h=floor(g/65536.);g=g-h*65536.;float i=floor(g/256.);g=g-i*256.;float j=g;return vec4(j/255.,i/255.,h/255.,1.);}bool g(float g){int h=int(g);bool i=false;for(int j=0;j<100;j++){if(u_del_tags[j]==0){break;}else if(u_del_tags[j]==h){i=true;break;}}return i;}void main(){if(u_draw_part==1){if(b>0.){discard;}}else if(u_draw_part==2){if(b==0.){discard;}}bool h=g(_);if(h){discard;}vec4 i=u_color;int j=int(_);if(j==u_pick_tag-1){i=vec4(u_pick_color.rgb/255.,u_pick_color.a*i.a);e=true;}if(u_pick_model){gl_FragColor=f(_);return;}vec4 k=i;if(u_pattern){vec4 l=u_bound;l.y=u_size.y-(l.y+l.w);vec4 m=l/vec4(u_size,u_size);vec2 n=l.zw*u_scale*pow(2.,18.-u_map_zoom);vec2 o=mod(u_offset+mod(c,n)/n,1.);vec2 p=m.xy+m.zw*o;vec4 q=texture2D(u_image,p);k.a*=q.a;if(!u_pattern_mask&&e==false){k.rgb=q.rgb;}}float l=(gl_FragCoord.z/gl_FragCoord.w-a);float m=k.a;if(l>u_camera_far-d){m=m*(u_camera_far-l)/d;if(m<=0.){discard;}}k.a=m*u_opacity;gl_FragColor=k;}",""].join("\\n")]};function aJ(i,e){this.gl=i;this.map=e;this.cache={};this.bind()}aJ.prototype.bind=function(){var e=this;this.map.on("update",function(T){var jV=T.changedStatus;if(jV&&jV.onsize_changed){for(var i in e.cache){e.cache[i].lastState.projMatrix=false}}})};aJ.prototype._createProgram=function(e,jX){var j3=this.gl;var j2=j3.createProgram();var jY=bh[e];var j9=jY[1];if(jX&&jX.fShader){j9=j9.replace("void main()",jX.fShader+" void main()")}var jZ=j3.createShader(j3.FRAGMENT_SHADER);j3.shaderSource(jZ,j9);j3.compileShader(jZ);j3.attachShader(j2,jZ);var j5=jY[0];if(jX&&jX.vShader){j5=j5.replace("void main()",jX.vShader+" void main()")}var j8=j3.createShader(j3.VERTEX_SHADER);j3.shaderSource(j8,j5);j3.compileShader(j8);j3.attachShader(j2,j8);j3.linkProgram(j2);var j0={};var j6=j3.getProgramParameter(j2,j3.ACTIVE_ATTRIBUTES);for(var j1=0;j11&&this._textRenderType==="image"){this._labelTextTextureSize=[4096,Math.min(4096+1024,e)]}else{this._labelTextTextureSize=[4096,4096]}if(this._textRenderType==="canvas"){this._renderPng8Text=false}else{this._renderPng8Text=true}this._lineLabelBuffer=null;this._fixedLabelBuffer=null;this._iconLabelBuffer=null;this._highlightLabelBuffer=null;this._marker3dVertexBuffer=null;this._markerVertexBuffer=null;this._polylineBufferArray=[{vertex:null,element1:null,vao1:null}];this._polygonBuffer=new Array(20);this._groundBuffer=new Array(20);this._groundoverlayBuffer=new Array(20);this._textTextureManager=new dL.TextTextureManager(jW,{width:this._labelTextTextureSize[0],height:this._labelTextTextureSize[1],unpackAlpha:true});this._iconTextureManager=new dL.TextTextureManager(jW,{width:1024,height:1024,unpackAlpha:true});this._iconTextureAtlas=this._iconTextureManager.getEmptyTexture();this._iconTextureAtlasOffset={};this._iconTextureAtlasCoords={};this._textureAddToJob={};this._isIdle=false;this._identityMatrix=mat4.create();this._initialize();this._handleContextStatus();this._stencilMask=null;this.draw()}eP.extend(ck.prototype,{draw:function(kc){var j3=this.gl;var j8=this;var ke=j8._map;var kb=this.mapZoom=ke.getZoom();if(!this.stepZoom){this.stepZoom=kb}ke.beforeRender&&ke.beforeRender();this.createGridBuffer(Math.floor(kb));this._isIdle=kc?kc.idle:false;if(this._isIdle&&this._useSMAA){bj.loadTexture(this,j3);if(this._frameBufferSizeInvalid===true){this.clearPreviousSMAAFramebuffer();this.initSMAAFrameBuffers();this._frameBufferSizeInvalid=false}}else{this._frameBufferSizeInvalid=true}this.projMatrix=this._camera.getProjectionMatrix3D();this.projMatrix2D=this._camera.getProjectionMatrix();this.cameraPosition=this._camera.getPosition();var ks=ke._featureMgr.getResult();var jY=ks.bkData;var j2=ks.eleData;this._stencilMask=j2[9];var kk=ke.getSize();var e=kk.width;var jX=kk.height;this.mapHalfSize=[e/2,jX/2];this.polyZoomRatio=Math.pow(2,18-kb);this.gridTextureScale=jQ.mapZoomTileSize[Math.floor(kb)]/128;var j6=ke._displayOptions;this.isFlat=j6.isFlat;if(this._isIdle&&this._smaaInfo.glDrawSMAAReady===true){j3.bindFramebuffer(j3.FRAMEBUFFER,this._smaaPasses[0].framebuffer)}this.tileClippintRefer=0;this.showIndoorContour=false;this.currentIndoorUid=null;if(ke._indoorMgr){this.currentIndoorUid=ke._indoorMgr.currentUid}if(this.currentIndoorUid&&kb>=17){this.showIndoorContour=true}j8.clearGLStatus({stencil:true,color:true,depth:true});this._state.enableCap("depthTest");this._state.blendFunc(j3.SRC_ALPHA,j3.ONE_MINUS_SRC_ALPHA,j3.ONE,j3.ONE_MINUS_SRC_ALPHA);this.calShadowPos();j8.clearGLStatus({depth:true});var kg=0;for(var ki=0;ki0&&j6.layer===false){continue}if(kh.ontology instanceof cj){if(kh.ontology.doRender()){this.setLayerDepth(fT);this._state.disableCap("depthTest");var jW=mat4.create(Float64Array);mat4.multiply(jW,this.projMatrix,this._camera._modelViewMatrixLayer);kh.ontology.preRender(j3,jW);kh.ontology.render(j3,jW);kh.ontology.afterRender(j3,jW);this._state.enableCap("depthTest")}}else{if(kh.ontology instanceof d0){this.drawMVT(kh)}else{if(kh.dataType===2){var kd=[0,0,0];for(var kr=0;kr0){this._state.disableCap("depthTest");this.mvMatrixPoly=this._camera.getModelViewMatrixPoly();this.drawPolygon(j2[0]);this._state.enableCap("depthTest")}if(j2[5].length>0){this._state.disableCap("depthTest");this.mvMatrixPoly=this._camera.getModelViewMatrixPoly();this.drawGroundOverlay(j2[5]);this._state.enableCap("depthTest")}if(j2[1].length>0){this._state.disableCap("depthTest");this.mvMatrixPoly=this._camera.getModelViewMatrixPoly();this.drawPolyline(j2[1]);this._state.enableCap("depthTest")}if(j2[6].length>0){this._state.disableCap("depthTest");this.mvMatrixPoly=this._camera.getModelViewMatrixPoly();this.drawPrism(j2[6]);this._state.enableCap("depthTest")}}this._map.drawOverlay&&this._map.drawOverlay(j3);this.draw3D(jY);if(ke.getTilt()>10){var j4=ke.pointToPixelIn(ke.getBoundsIn().pointTopLeft).y+100;if(j4>0&&ke.config.showSky!==false){i5(this,this._identityMatrix,j4,ke.height,this._skyColor)}}ke.insertRender&&ke.insertRender();if(this._useSMAA&&this._isIdle&&this._smaaInfo.glDrawSMAAReady===true){this.drawSMAA()}this._state.disableCap("depthTest");this.mvMatrixMarker=this._camera.getMCPlaneMVMatrix();this.mvMatrixMarker[12]=this.mvMatrixMarker[13]=this.mvMatrixMarker[14]=0;this._checkTextureAtlasUsage();var j1=iv(this.cameraPosition[0]);var j0=iv(this.cameraPosition[1]);var jZ=iv(this.cameraPosition[2]);this.cameraPosHigh=[j1[0],j0[0],jZ[0]];this.cameraPosLow=[j1[1],j0[1],jZ[1]];this._state.blendFunc(j3.ONE,j3.ONE_MINUS_SRC_ALPHA);if(j6.poiText&&j2[2].length>0){for(var kr=0;kr0){for(var kr=0;kr0){for(var kr=0;kr0){this.drawSymbol(j2[8],{fixPosition:kj})}if(j2[7].length>0){this.drawMarker3D(j2[7])}}ke.afterRender&&ke.afterRender();this._map.dispatchEvent(new fA("ondraw"))},drawMVT:function(jV){if(!jV.ontology){return}this.setLayerDepth(fT);this._state.disableCap("depthTest");if(!this._grid3857BufferCache){this.createGrid3857BufferCache(256)}for(var e=0;e<3;e++){for(var i=0;i0&&T[0].isStencilMask){if(e==="on"){if(this._map.stencil.showRegion==="inside"){this.enableStencilMask(T,jV,i)}else{if(this._map.stencil.showRegion==="outside"){this.enableStencilMaskOut(T,i,i)}}}else{if(e==="off"){this.disableStencilMask()}}}},enableStencilMask:function(jV,i,e){var T=this.gl;if(!e){T.clear(T.STENCIL_BUFFER_BIT)}if(!i){T.disable(T.DEPTH_TEST)}T.stencilFunc(T.ALWAYS,1,255);this._state.stencilOp(T.KEEP,T.KEEP,T.REPLACE);T.stencilMask(255);this._state.colorMask(0,0,0,0);this.mvMatrixPoly=this._camera.getModelViewMatrixPoly();this.drawPolygon(jV);this._state.colorMask(1,1,1,1);T.stencilFunc(T.EQUAL,1,255);T.stencilMask(0)},enableStencilMaskOut:function(jV,i,e){var T=this.gl;if(!e){T.clear(T.STENCIL_BUFFER_BIT)}if(!i){T.disable(T.DEPTH_TEST)}T.stencilFunc(T.ALWAYS,1,255);this._state.stencilOp(T.KEEP,T.KEEP,T.REPLACE);T.stencilMask(255);this._state.colorMask(0,0,0,0);this.mvMatrixPoly=this._camera.getModelViewMatrixPoly();this.drawPolygon(jV);this._state.colorMask(1,1,1,1);T.stencilFunc(T.NOTEQUAL,1,255);T.stencilMask(0)},disableStencilMask:function(){var e=this.gl;e.clear(e.STENCIL_BUFFER_BIT);e.stencilMask(255);e.stencilFunc(e.ALWAYS,1,255);e.enable(e.DEPTH_TEST)},enableTileLayerClippingMask:function(T,e){var i=this.gl;i.stencilFunc(i.ALWAYS,1,255);this._state.stencilOp(i.KEEP,i.KEEP,i.REPLACE);i.stencilMask(255);i.clear(i.STENCIL_BUFFER_BIT);this._state.colorMask(0,0,0,0);this.mvMatrixPoly=this._camera.getModelViewMatrixPoly();this.overlayToPolygonGl(T);if(e!=="outside"){i.stencilFunc(i.EQUAL,1,255)}else{i.stencilFunc(i.NOTEQUAL,1,255)}i.stencilMask(0);this._state.colorMask(1,1,1,1)},disableTileLayerClippingMask:function(){var e=this.gl;e.clear(e.STENCIL_BUFFER_BIT);e.stencilMask(255);e.stencilFunc(e.ALWAYS,1,255)},overlayToPolygonGl:function(jZ){var e=[];for(var jX=0;jX0){this.zoomState=1}else{if(e<0){this.zoomState=-1}}this.lastZoom=i;return this.zoomState},calShadowPos:function(){this.isDrawShadow=false;var i=this._map;var e=!(typeof i.config.style==="string");if(e||this.mapZoom<18){return}var T=i.getSolarInfo();if(e1(T.solarAltitude)>1){this.isDrawShadow=true;this._shadowPosVec3[0]=Math.sin(T.solarAzimuth);this._shadowPosVec3[1]=Math.cos(T.solarAzimuth);if(T.centerPosition==="south"){this._shadowPosVec3[1]=-this._shadowPosVec3[1]}this._shadowPosVec3[2]=Math.tan(T.solarAltitude)*0.5+1.5;this._sideLightDirVec3[0]=this._shadowPosVec3[0];this._sideLightDirVec3[1]=this._shadowPosVec3[1];this._sideLightDirVec3[2]=-this._shadowPosVec3[2]}},clearPreviousSMAAFramebuffer:function(){var jV=this.gl;for(var e=0;eT.length){T=new Float32Array(e.length)}T.set(e)}}if(i){return new w(T,{components:eH.overlayLineComponentsCount,members:eH.overlayLine},w.BufferType.VERTEX)}else{return new w(T,{components:eH.lineComponentsCount,members:eH.line},w.BufferType.VERTEX)}},createLineData:function(i){var e={};e.vertex=this.createLineBuffer(null,i[0],false);e.element1=new w(i[1],{components:1},w.BufferType.ELEMENT);e.vao1=new dH();return e},createPolylineData:function(jV){var jZ=[];for(var T=0;Tthis._uint16ArrayForPolyline.length){this._uint16ArrayForPolyline=new Uint16Array(e.length)}this._uint16ArrayForPolyline.set(e);if(!jX.element1){jX.element1=new w(this._uint16ArrayForPolyline,{components:1},w.BufferType.ELEMENT,e.length)}if(!jX.vao1){jX.vao1=new dH()}else{if(jW.length>this._float32ArrayForPolyline.length){this._float32ArrayForPolyline=new Float32Array(jW)}else{this._float32ArrayForPolyline.set(jW)}jX.vao1.update(this.gl,jX.vertex,this._float32ArrayForPolyline,jW.length,jX.element1,this._uint16ArrayForPolyline,e.length)}jZ.push(jX)}if(jZ.length===0){return null}return jZ},createLabelData:function(jY,kc,kb,jX){if(jY.length===0){return}var km=this._labelTextTextureSize;var j5=0;var jV=0;var kh=jY.length;var kf=this.gl;var kk=this[kb];var j6=0;var kn=ep;var ki=bL;if(jX){kn=i9;ki=f}for(var kg=0;kgthis._labelVertexBuffer.length){this._labelVertexBuffer=new Float32Array(j4);if(kk){kk.vao.destroy(kf);kk.destroy(kf);kk=this[kb]=null}}var j1=this._iconLabelBuffer;if(j4>this._labelIconVertexBuffer.length){this._labelIconVertexBuffer=new Float32Array(j4);if(j1){j1.vao.destroy(kf);j1.destroy(kf);j1=this._iconLabelBuffer=null}}for(var kg=0;kg0){if(!kk){var jZ=eH.symbol;if(jX){jZ=eH.symbolline}kk=this[kb]=new w(this._labelVertexBuffer,{components:ki,members:jZ},w.BufferType.VERTEX,j5/ki);this[kb].vao=new dH()}else{this[kb].vao.update(this.gl,kk,this._labelVertexBuffer,j5/ki)}}var j2=null;if(jV>0){j2=new dH();if(!j1){j1=this._iconLabelBuffer=new w(this._labelIconVertexBuffer,{components:bL,members:eH.symbol},w.BufferType.VERTEX,jV/bL);j1.vao=new dH()}else{j1.vao.update(this.gl,j1,this._labelIconVertexBuffer,jV/bL)}}var kl=null;if(this._labelTextTextureAtlas){kl=this._labelTextTextureAtlas.getTexture()}return{vao:this[kb]?this[kb].vao:null,vaoIcon:this._iconLabelBuffer?this._iconLabelBuffer.vao:null,vertex:j5>0?kk:null,texture:kl,iconVertex:jV>0?j1:null,iconTexture:this._iconTextureAtlas.getTexture()}},_addToAsyncJob:function(e){if(this._textureAddToJob[e.id]){return}var T=this;var i=(function(jV){return function(){delete T._textureAddToJob[jV.id];if(T._currentTextureIsFull){return}if(!T._labelTextTextureAtlas&&T._textTextureManager){T._labelTextTextureAtlas=T._textTextureManager.getEmptyTexture()}if(!T._labelTextTextureAtlas){return}var jW=jV.height;var jX=T._labelTextTextureAtlas.addTexture(jV,jW);T._labelTextureAtlasOffset[jV.id]=jX;T._map.dispatchEvent(new fA("onrefresh"))}})(e);this._textureJobScheduler.addJob(i);this._textureAddToJob[e.id]=true},createMarker3dData:function(e){if(e.length===0){return null}var jW=e.length*gK;if(jW>this._labelVertexBuffer3D.length){this._labelVertexBuffer3D=new Float32Array(jW);if(this._marker3dVertexBuffer){this._marker3dVertexBuffer.vao.destroy(this.gl);this._marker3dVertexBuffer.destroy(this.gl);this._marker3dVertexBuffer=null}}var ka=0;for(var j6=0,j2=e.length;j61&&j8.srcSetObject["2x"]){j7=j8.srcSetObject["2x"]}if(!j7&&j8.imageDom){j7=j8.imageDom.id}var T=j0.textureCoordGLMap;if(!T){var j3=this._imageMergedOffset[j7];if(!j3){jV.id=j7;j3=this.textureAtlasMarker.addTexture(jV);this._imageMergedOffset[j7]=j3}var jZ=new iL(jV.width,jV.height);if(j8.imageSize){j8.ratio=jV.width/j8.imageSize.width}T=this._calcTextureCoords(jZ,j8.size,j8.imageOffset,j3,j8.ratio);j0.textureCoordGLMap=T}jY=[T[0],T[1],T[4],T[5]]}for(var j5=0;j5this._labelVertexBuffer.length){this._labelVertexBuffer=new Float32Array(jV);if(this._markerVertexBuffer){this._markerVertexBuffer.vao.destroy(this.gl);this._markerVertexBuffer.destroy(this.gl);this._markerVertexBuffer=null}}var j8=0;for(var j4=0,j1=ka.length;j41&&j6.srcSetObject["2x"]){j5=j6.srcSetObject["2x"]}if(!j5&&j6.imageDom){j5=j6.imageDom.id}if(!j5&&j6.id){j5=j6.id}var e=jX.textureCoordGLMap;if(!e){var j2=this._imageMergedOffset[j5];if(!j2){T.id=j5;j2=this.textureAtlasMarker.addTexture(T);this._imageMergedOffset[j5]=j2}var jZ=new iL(T.width,T.height);if(j6.imageSize){j6.ratio=T.width/j6.imageSize.width}e=this._calcTextureCoords(jZ,j6.size,j6.imageOffset,j2,j6.ratio);jX.textureCoordGLMap=e}if(e&&j6.isReDraw&&j6.render){var jY=j6.render(this._map);if(jY){j6.update();var j9=j6.data;j9.id=T.id;if(j9.width===T.width&&j9.height===T.height){this.textureAtlasMarker.updateTexture(j9)}}}for(var j3=0;j30&&i.indoor){this.drawArea3D(e);this.drawArea3DBorder(e)}this.drawBuildings(e)},drawBuildings:function(T){var jZ=this._map;if(jZ._displayOptions.building===false){return}if(!T[0]){return}var e=false;var jX=T[0].length;for(var jW=0;jW0&&jY[0].isStencilMask&&this._map.stencil.showRegion==="inside"){this.enableStencilMask(jY,true);this._state.colorMask(false,false,false,false);jA(this,this._sideLightDirVec3,true);for(var jW=0;jW0&&jY[0].isStencilMask&&this._map.stencil.showRegion==="outside"){this.enableStencilMaskOut(jY,true);this._state.colorMask(false,false,false,false);jA(this,this._sideLightDirVec3,true);for(var jW=0;jW0){if(i&&i.vertex&&i.texture&&i.vao){h0.symbol(this,i.vertex,i.vao,this.mvMatrixMarker,i.texture,this._renderPng8Text,this.projMatrix,false,this._map._labelProcessor._useRound,this.mapHalfSize,0,this.cameraPosHigh,this.cameraPosLow,this.projMatrix2D,1)}}if(e.poiIcon||T>0){if(i&&i.iconVertex&&i.iconTexture&&i.vaoIcon){h0.symbol(this,i.iconVertex,i.vaoIcon,this.mvMatrixMarker,i.iconTexture,false,this.projMatrix,false,this._map._labelProcessor._useRound,this.mapHalfSize,0,this.cameraPosHigh,this.cameraPosLow,this.projMatrix2D,2)}}},drawLineLabelSymbol:function(jV,T){if(this._map.stencil&&this._map.stencil.isMapMask){this.switchStencilMask("on")}var e=false;var i=this.createLabelData(jV,e,"_lineLabelBuffer",true);if(i&&i.vertex&&i.texture&&i.vao){h0.symbolline(this,i.vertex,i.vao,T,i.texture,this._renderPng8Text,this.projMatrix,this._map._labelProcessor._useRound,this.mapHalfSize,this.mapZoom,this.cameraPosition,1)}if(this._map.stencil&&this._map.stencil.isMapMask){this.switchStencilMask("off")}},drawSymbol:function(jV,T){var i=this.createMarkerData(jV);if(!i){return}T=T||{};var e=T.fixPosition||false;h0.symbol(this,i.vertex,i.vao,this.mvMatrixMarker,i.texture,false,this.projMatrix,false,this._map._overlayMgrGL._useRound,this.mapHalfSize,0,this.cameraPosHigh,this.cameraPosLow,this.projMatrix2D,null,e)},drawMarker3D:function(T){var e=this.createMarker3dData(T);if(!e){return}var i=T[0].overlay._config;h0.marker3d(this,{mvMatrix:this.mvMatrixMarker},this.cameraPosHigh,this.cameraPosLow,e,i)},drawPolyline:function(i,jV){var e=this.createPolylineData(i);if(!e){return}var jW=this.mvMatrixPoly;var T=false;if(jV){jW=jV;T=true}h0.line(this,{mvMatrix:jW,tileOverlay:T},i,e,true)},drawPolygon:function(T,jW){var e;var jX=this.mvMatrixPoly;if(jW){jX=jW}for(var jV=0;jV0&&j2[0].isStencilMask){this.setLayerDepth(40)}else{this.setLayerDepth(fT)}}else{this.setLayerDepth(T)}if(this._map.stencil&&this._map.stencil.isMapMask){this.switchStencilMask("on",true,true)}for(var jV=0;jV0.85){this._currentTextureIsFull=true;this._map.fire(new fA("onmapglidle_inner"))}}},_initialize:function(){var j0=this.gl;var jW=this;this._map.addEventListener("update",function(i){if(i.changedStatus&&i.changedStatus.onsize_changed){jW._resizeHandler()}});var jZ=this._map;jZ.addEventListener("layer_clear",function(j1){jW._cache&&jW._cache.clear();jW._currentTextureIsFull=true;jY&&jY();jW._iconTextureAtlasOffset={};jW._iconTextureAtlasCoords={};var i=new fA("onupdate");jZ.fire(i)});this.tileScale=1;this.stepZoom=jZ.getZoom();this.polyZoomRatio=1;this.normalMatrix=mat4.create();this.background=jZ.config.backgroundColor||dC;var jW=this;jW.updateBackground=function(){var i=jZ.config.mapStyleId;if(typeof jZ.config.style==="string"){jW.background=jZ.config.backgroundColor||dC}else{if(bw["customStyleInfo_"+i]){var j1=bw["customStyleInfo_"+i]["bmapLandColor"];if(j1){jW.background=ho.parseHexToRgbaArray(j1)}else{jW.background=dC}}}jW._state.clearColor(jW.background)};jZ.addEventListener("style_loaded",function(){jW.updateBackground()});jZ._webGLStateId=bw.getGUID("glmap_");this._state=dL.WebGLState.get(j0,jZ._webGLStateId);this._state.clearColor(this.background);this._state.enableCap("stencilTest");this._state.enableCap("depthTest");this._state.enableCap("cullFace");this._state.depthFunc(j0.LEQUAL);this._state.enableCap("blend");this._state.blendFunc(j0.SRC_ALPHA,j0.ONE_MINUS_SRC_ALPHA,j0.ONE,j0.ONE_MINUS_SRC_ALPHA);this._state.depthMask(true);this._needToDestroy=[];bj.init(this);if(this._useSMAA){this.initSMAAFrameBuffers()}this._cache=new ay(eP.Browser.ie?64:128,{clearCallback:function(i){jW._needToDestroy.push(i)}});this._map.on("zoom_changed",function(j1){var i=j1.target.getZoom();jW.stepZoom=Math.floor(i/0.25)*0.25});function jY(){if(!jW._textTextureManager){return}for(var j2=0,j1=jW._needToDestroy.length;j21){this._ratio=2}e._overlayMgrGL=this;this._init()}eP.extend(bl.prototype,{_init:function(){this._bind()},_bind:function(){var i=this;var jV=this._map;function jX(j1){var jZ=j1.overlay||this;var j0=j1.action||"";var jY=true;i._updateGraph(jZ,j0,false,jY);if(j0==="remove"){i._removeOverlay(jZ,jX)}}function T(j1){var jY=j1.overlay||this;var j0=j1.action||"";var jZ=j1.imageUrlChanged||false;i._updateMarker(jY,j0,jZ);if(j0==="remove"){i._removeOverlay(jY,T)}}jV.on("destroy",function(){var jY=[];for(var j1=0;j11&&j5&&j5.hasOwnProperty("srcSetObject")&&j5.srcSetObject["2x"]){j6=j5.srcSetObject["2x"];j5.ratio=2}var j0;var j7;if(j6){j7=this._iconImage[j6]}else{if(jV){j7=this._iconImage[jV.id]}else{if(jX){j7=this._iconImage[jX]}}}if(j7){j0=j7.img}if(j0){jW.textureSource=j0;this._map._featureMgr.setOverlayData(this._renderData[j2],e);return true}jW.textureSource=null;this._removeMarkerFromRenderData(jZ);this._addMarkerToRenderData(jZ);break}}if(!j4&&jY==="setIcon"&&j3){this._renderData[jZ.hashCode]=null;this._addMarkerToRenderData(jZ)}return false},_addMarkerToRenderData:function(jW){if(this._renderData[jW.hashCode]){return false}this._renderData[jW.hashCode]=true;var jZ=this;function jV(kb,j8,j7,kd){var j6=j8 instanceof d8;var ka=j6?4:2;var kc=j6?7:8;if(j8.map&&j8._visible===true&&((j8 instanceof jz&&j8.domElement!==null)||j8 instanceof d8)){if(j7!==null){if(((jZ._ratio===1||!j0.srcSetObject["2x"])&&j8._config.icon.imageUrl!==j7)||(jZ._ratio>1&&j0.srcSetObject["2x"]&&j0.srcSetObject["2x"]!==j7)){return}}else{if(kd!==null){if(kb!==kd){return}}}var j9=j8.getVertexInfoForGL(jZ._useRound);jZ._renderData[ka].push({overlay:j8,hashCode:j8.hashCode,textureSource:kb,renderData:j9});jZ._renderData[j8.hashCode]=true}else{jZ._renderData[j8.hashCode]=null}jZ._renderData[ka].sort(function(kf,ke){return kf.overlay._zIndex-ke.overlay._zIndex});jZ._map._featureMgr.setOverlayData(jZ._renderData[ka],kc)}function jY(j8){var j7=j8 instanceof d8;var j9=j7?4:2;var ka=j7?7:8;jZ._map._featureMgr.setOverlayData(jZ._renderData[j9],ka);var j6=new fA("onrefresh");j6.source="webgloverlaymgr";jZ._map.fire(j6)}var j0=jW._config.icon;if(jW instanceof d8&&!j0){var j2=jW.getVertexInfoForGL(jZ._useRound);jZ._renderData[4].push({overlay:jW,hashCode:jW.hashCode,textureSource:null,renderData:j2});jZ._renderData[jW.hashCode]=true;jZ._map._featureMgr.setOverlayData(jZ._renderData[4],7);var j3=new fA("onrefresh");j3.source="webgloverlaymgr";jZ._map.fire(j3);return true}var j1=j0.imageUrl;var i=j0.imageDom;var T=(j0 instanceof e8?j0.id:null);var jX;var j4;if(this._ratio>1&&j0&&j0.hasOwnProperty("srcSetObject")&&j0.srcSetObject["2x"]){j1=j0.srcSetObject["2x"];j0.ratio=2}if(j1){j4=this._iconImage[j1]}else{if(i){j4=this._iconImage[i.id]}else{if(T){j4=this._iconImage[T]}}}if(j4){jX=j4.img}if(jX){jV(jX,jW,j1,i);return true}if(j4){j4.pendings.push(jW)}else{if(j1){jX=new Image();jX.crossOrigin="anonymous";jX.onload=function(){jZ._iconImage[j1].loaded=true;jZ._iconImage[j1].img=this;for(var j6=0;j61&&jX.srcSetObject["2x"]){e=jX.srcSetObject["2x"]}if(this._iconImage[e]&&this._iconImage[e].pendings){var jW=this._iconImage[e].pendings;for(var jV=jW.length-1;jV>=0;jV--){if(jW[jV]===T){jW.splice(jV,1)}}}}for(var jV=0;jV65536||(jW.styleData[0].length>0&&e===false)||j3===false){j5++;jW=this._renderData[5][j5]={style:[],styleData:[[],[]],texture:null,textureSize:null,zoomWithMap:null,overlay:null};i=jW.styleData[0];j1=jW.styleData[1];j0=0}if(jW.styleData[0].length===0&&e===false){jW.texture=j7.texture;jW.textureSize=j7.textureSize;jW.zoomWithMap=j7.zoomWithMap;jW.overlay=j7.overlay}for(var jZ=0;jZ0&&jV._config.strokeWeight>0){j0=jV.buildVertex(gc,true);this._polylineRenderData[jV.hashCode]={cacheIndex:j0.cacheIndex,hashCode:jV.hashCode,styleData:j0,texture:jV._config.texture,textureSize:jV._config.textureSize,zoomWithMap:jV._config.textureZoomWithMap,overlay:jV}}}else{if(jV instanceof cg){this._lastAddGraphIndex=6;jZ=jV.getFillStyleForGL();var i=jV.buildFillVertex(hp);var T=[jZ,i[0],i[1]];T.overlay=jV;T.isStencilMask=true;T.hashCode=jV.hashCode;T.hasMultipleParts=jV.hasMultipleParts;this._renderData[6].push(T);this._map._featureMgr.setOverlayData(this._renderData[6],9)}else{this._lastAddGraphIndex=5;j0=jV.buildVertex(gc,true);this._polylineRenderData[jV.hashCode]={cacheIndex:j0.cacheIndex,hashCode:jV.hashCode,styleData:j0,texture:jV._config.texture,textureSize:jV._config.textureSize,zoomWithMap:jV._config.textureZoomWithMap,overlay:jV}}}}}this._renderData[jV.hashCode]=true;this._updateOverlayLoopRender();return true},_imageLoad:function(i,jW){var e=new Image();e.crossOrigin="anonymous";e.onload=function jV(){jW&&jW(this,true)};e.onerror=function T(){jW&&jW(null,false)};e.src=i},_removeGraphFromRenderData:function(T){if(!this._renderData[T.hashCode]){return false}if(T instanceof jK){for(var jV=0;jV0){if(this._rafTimer){return}this._rafTimer=requestAnimationFrame(e._loopRender.bind(e))}else{cancelAnimationFrame(this._rafTimer);this._rafTimer=undefined}},_loopRender:function(){this._map._webglMapScene.startRenderThread();this._rafTimer=requestAnimationFrame(this._loopRender.bind(this))},_updateGraphRenderData:function(T,j1){var j0;var jX=false;var jY;if(T instanceof jK){var e=T.buildFillVertex(hp,j1);for(var jW=0;jW