/** * @file map.js * @version 20170906 ms * @use internet.js, mapmath.js, win.js * * KIG-Kartenmodul */ /// @var KUrl var KUrl="https://www.kig.gmbh/libs/"; /** * @class KMap * @constructor * @param o * @param opts */ var KMap=function(o,opts){ var m=this; if(typeof opts=="undefined") opts={}; m.opts=opts; m.untiled;m.untiledimg=null; m.cmenu=[];m.cmenuo=null; m.cursor=""; m.expanse=null; m.xmin=0;m.ymin=0;m.xmax=0;m.ymax=0; m.lx=0;m.ly=0; m.mapw=0;m.maph=0; m.unon=false; m.tiles=[]; m.History=[]; m.labels=[]; m.ButtonsLeft=[]; m.ButtonsRight=[]; m.MouseIn=false; m.mx=0;m.my=0; m.ex=0;m.ey=0;m.eb=0; m.timerID=0; m.LinkO=null;m.LinkClickable=false;m.Immediately=false; m.MouseKey=0; m.Rectangling=false;m.Dragging=false;m.Zooming=false; m.StartX=0;m.StartY=0; m.Version=Math.floor((Math.random()*9999999)); m.tmrMap; m.ReqID=0; m.o=o; var st=o.style;st.backgroundColor="transparent";st.userSelect="none";st.MozUserSelect="none";st.webkitUserSelect="none";st.msUserSelect="none"; m.mapback=document.createElement("div"); st=m.mapback.style;st.position="absolute";st.left=st.top="0";st.zIndex="1";st.overflow="hidden";st.backgroundColor="#F4F5F6"; o.appendChild(m.mapback); m.untiled=document.createElement("div"); st=m.untiled.style;st.position="absolute";st.overflow="hidden";st.display="none"; m.mapback.appendChild(m.untiled); m.untiledimg=document.createElement("img"); m.untiledimg.style.position="absolute"; m.untiled.appendChild(m.untiledimg); /// addDOMEvent img.onload m.untiledimg.onload=function(){m.untiled.style.backgroundColor="white";m.untiled.style.display=""}; m.rect=document.createElement("div"); st=m.rect.style;st.position="absolute";st.zIndex="1007";st.display="none"; o.appendChild(m.rect); m.mapal=document.createElement("div"); st=m.mapal.style;st.position="absolute";st.left=st.top="0";st.zIndex="1009";st.overflow="hidden";st.backgroundColor="#000000";st.opacity=0;st.cursor=m.cursor; o.appendChild(m.mapal); /// addDOMEvent div.wheel m.mapal.addEventListener('wheel',function(e){m.MouseWheel(e)}); if("ontouchstart" in m.mapal){ m.mapal.addEventListener("touchstart",function(e){m.TouchStart(e)}); // necessary to activate touch events for all document elements /// addEvent touchmove = this.TouchMove(e) m.mapal.addEventListener("touchmove",function(e){m.TouchMove(e)}); /// addEvent touched = this.TouchEnd(e) m.mapal.addEventListener("touchend",function(e){m.TouchEnd(e)}); } m.mapal.addEventListener("mousemove",function(e){m.MouseMove(e)}); m.mapal.addEventListener("mousedown",function(e){m.MouseDown(e)}); m.mapal.addEventListener("mouseup",function(e){m.MouseUp(e)}); m.mapal.addEventListener("dblclick",function(e){m.MouseDbl()}); m.mapal.addEventListener("mouseout",function(e){m.MouseOut()}); m.mapal.addEventListener("contextmenu",function(e){e.preventDefault()}); m.mapal.addEventListener("dragenter",function(e){e.preventDefault();e.dataTransfer.dropEffect="none";m.DragEnter(e)}); m.mapal.addEventListener("dragover",function(e){e.preventDefault()}); m.mapal.addEventListener("drop",function(e){e.preventDefault();m.Drop(e)}); document.addEventListener("keydown",function(e){if(m.MouseIn) m.KeyDown(e)}); /// @var {HTMLElement::div} this.impr m.impr=document.createElement("div"); st=m.impr.style;st.position="absolute";st.top="8px";st.zIndex="1009";st.fontSize="9px";st.cursor="pointer"; m.o.appendChild(m.impr); /// @var {HTMLElement::div} this.copyr m.copyr=document.createElement("div"); st=m.copyr.style;st.position="absolute";st.zIndex="1009";st.fontSize="9px";st.color="#73808D";st.whiteSpace="nowrap"; o.appendChild(m.copyr); /// @var {HTMLElement::div} this.ButtonsLeftO m.ButtonsLeftO=document.createElement("div"); st=m.ButtonsLeftO.style;st.position="absolute";st.zIndex="1011"; o.appendChild(m.ButtonsLeftO); /// @var {HTMLElement::div} this.ButtonsRightO m.ButtonsRightO=document.createElement("div"); st=m.ButtonsRightO.style;st.position="absolute";st.zIndex="1011"; o.appendChild(m.ButtonsRightO); if(opts.expanse){ m.expanse={xmin:opts.expanse[0],ymin:opts.expanse[1],xmax:opts.expanse[2],ymax:opts.expanse[3]}; m.ButtonsLeftAdd("zoomall",KMap.ImgZoomAll,"ZoomAll",function(){m.ZoomAll()}); } m.ButtonsLeftAdd("zoomin",KMap.ImgZoomIn,"ZoomIn",function(){m.ZoomIn()}); m.ButtonsLeftAdd("zoomout",KMap.ImgZoomOut,"ZoomOut",function(){m.ZoomOut()}); m.ButtonsLeftAdd("zoomback",KMap.ImgZoomBack,"ZoomBack",function(){m.ZoomBack()}); // TODO (map.js) Geolocation: erweitert um Karten-Button ZoomPos => an Maik senden if(opts.geolocation) { var buttonObj; buttonObj = m.ButtonsLeftAdd("zoompos",KMap.ImgZoomPos,"ZoomPos",function(){m.ZoomPos(buttonObj)}); } m.ButtonsLeftAddGap(); if(opts.search){ m.ButtonsLeftAdd("find",KMap.ImgSearch,"Search",function(c){m.FindShow(c)},true,false); m.ButtonsLeftAddGap(); } if(opts.measure) m.ButtonsLeftAdd("measure",KMap.ImgMeasure,"Measure",function(c){if(c) m.MeasShow();else m.EdgebarClose()},true,false); if(opts.printout){ m.ButtonsLeftAdd("printout",KMap.ImgPrint,"Printout",function(){m.PrintDlgShow()}); if(!m.win) m.win=new KWin(); } if(opts.weblink) m.ButtonsLeftAdd("weblink",KMap.ImgLink,"WebLink",function(){m.WebLink()}); if(opts.printout || opts.weblink) m.ButtonsLeftAddGap(); m.SetBasemap(m.Basemap); if(!opts.hideLayers){ m.ButtonsRightAdd("map",KMap.ImgLayers,"Basemap",function(c){m.LyShow(c)},true,false,"sidebar"); var d=document.createElement("div");var st=d.style;st.position="absolute";st.width=st.height="0";st.overflow="hidden";document.body.appendChild(d); m.LyFileInput=document.createElement("input");m.LyFileInput.type="file";m.LyFileInput.multiple=true;d.appendChild(m.LyFileInput); m.LyFileInput.onchange=function(){m.LyImportFiles(this.files)}; if(!m.win) m.win=new KWin(); } m.DigiCanvas=document.createElement("canvas"); var st=m.DigiCanvas.style;st.position="absolute";st.left="0";st.top="0";st.zIndex="1008"; m.mapback.appendChild(m.DigiCanvas); m.DigiCtx=m.DigiCanvas.getContext("2d"); m.DigiCtx.lineJoin="round"; var d=document.createElement("div");var st=d.style;st.position="absolute";st.width=st.height="0";st.overflow="hidden";document.body.appendChild(d); m.DigiFileInput=document.createElement("input");m.DigiFileInput.type="file";d.appendChild(m.DigiFileInput); m.Measuring=0; m.MeasType=0; m.MeasShowXY=false; m.MeasLine=[[0,0]]; m.AfterConstruct(); // TODO (map.js) das Laden der custom basemaps und layers auskommentiert, weil jetzt in userRecord.settings // var l=localStorage.getItem(m.localStorageNamespace+"kigmapBasemaps"); // if(l){l=JSON.parse(l);for(var a=0;a0.000000001); return [Math.atan(Pt[1]/Pt[0]),f,Math.sqrt(Pt[0]*Pt[0]+Pt[1]*Pt[1])/Math.cos(f1)-a/Math.sqrt(1-eq*Math.sin(f1)*Math.sin(f1))]; } KMap.neuF=function(f,x,y,p,a,eq){ var zw=a/Math.sqrt(1-eq*Math.sin(f)*Math.sin(f)); var nnq=1-eq*zw/(Math.sqrt(x*x+y*y)/Math.cos(f)); return Math.atan(p/nnq); } KMap.Merc2LL=function(x,y,Prj){ var eq=(Prj.ella*Prj.ella-Prj.ellb*Prj.ellb)/(Prj.ellb*Prj.ellb); var ellc=(Prj.ella*Prj.ella)/Prj.ellb*(1-3*eq/4+45/64*eq*eq-175/256*eq*eq*eq+11025/16384*eq*eq*eq*eq); var lon=Prj.lon0*Math.PI/180+(x-Prj.x0)/ellc/Prj.sc; var lat=((y-Prj.y0)/Prj.sc+Prj.northing0)/ellc; lat=(Math.pow(Math.E,lat)-Math.pow(Math.E,-lat))/2; lat=Math.atan(lat); return [lon,lat]; } KMap.UTM2LL=function(x,y,Prj){ var zone=Prj.zone; if(Prj.autozone) zone=Math.floor((x-Prj.x0+500000)/1000000); var eq=(Prj.ella*Prj.ella-Prj.ellb*Prj.ellb)/(Prj.ellb*Prj.ellb); var ellc=(Prj.ella*Prj.ella)/Prj.ellb*(1-3*eq/4+45/64*eq*eq-175/256*eq*eq*eq+11025/16384*eq*eq*eq*eq); var d2=(x-Prj.x0-zone*1000000)/Prj.sc; var d3=((y-Prj.y0)/Prj.sc+Prj.northing0)/ellc; var d9=(Prj.ella-Prj.ellb)/(Prj.ella+Prj.ellb); var d13=d3+(((3*d9)/2-(27*d9*d9*d9)/32)*Math.sin(2*d3)+(21*d9*d9*Math.sin(4*d3))/16+1*d9*d9*d9*Math.sin(6*d3)); var d4=Math.cos(d13); var d5=Math.tan(d13); var d7=1+eq*d4*d4; var d8=Math.sqrt(d7); var d18=(Prj.ella*Prj.ella)/(Prj.ellb*d8); var d11=eq*d4*d4; var d15=(-d5/(2*d18*d18))*(1+d11); var d16=(d5/(24*d18*d18*d18*d18))*(5+3*d5*d5+6*d11*(1-d5*d5)); var d17=(-d5/(720*d18*d18*d18*d18*d18*d18))*(61+90*d5*d5+45*d5*d5*d5*d5); var lat=d13+d15*d2*d2+d16*d2*d2*d2*d2+d17*d2*d2*d2*d2*d2*d2; var d20=1/(d18*d4); var d21=(-1/(6*d18*d18*d18*d4))*(1+2*d5*d5+d11); var d22=(1/(120*d18*d18*d18*d18*d18*d4))*(5+28*d5*d5+24*d5*d5*d5*d5); var lon=(Prj.lon0+zone*Prj.zonewidth)*Math.PI/180+d20*d2+d21*d2*d2*d2+d22*d2*d2*d2*d2*d2; return [lon,lat]; } KMap.Lambert2LL=function(x,y,Prj){ var lat0=Prj.lat0*Math.PI/180;var lat1=Prj.lat1*Math.PI/180;var lat2=Prj.lat2*Math.PI/180; x-=Prj.x0;y-=Prj.y0; var eq=(Prj.ella*Prj.ella-Prj.ellb*Prj.ellb)/(Prj.ella*Prj.ella); var e=Math.sqrt(eq); var m1=Math.cos(lat1)/Math.sqrt(1-eq*Math.sin(lat1)*Math.sin(lat1)); var m2=Math.cos(lat2)/Math.sqrt(1-eq*Math.sin(lat2)*Math.sin(lat2)); var aux1=Math.sqrt((1-e*Math.sin(lat1))/(1+e*Math.sin(lat1))); var aux2=Math.sqrt((1-e*Math.sin(lat2))/(1+e*Math.sin(lat2))); var aux0=Math.sqrt((1-e*Math.sin(lat0))/(1+e*Math.sin(lat0))); var t1=((1-Math.tan(lat1/2))/(1+Math.tan(lat1/2)))/Math.pow(aux1,e); var t2=((1-Math.tan(lat2/2))/(1+Math.tan(lat2/2)))/Math.pow(aux2,e); var t0=((1-Math.tan(lat0/2))/(1+Math.tan(lat0/2)))/Math.pow(aux0,e); if(lat1== lat2) var n=Math.sin(lat1); else var n=(Math.log(m1)-Math.log(m2))/(Math.log(t1)-Math.log(t2)); var efe=m1/(n*Math.pow(t1,n)); var ro0=Prj.ella*efe*Math.pow(t0,n); var sinal=(n/Math.abs(n)); var ro=Math.sqrt(x*x+(ro0-y)*(ro0-y)); ro*=sinal; var teta=Math.atan(x/(ro0-y)); var t=Math.pow(ro/(Prj.ella*efe),1/n); var XX=Math.PI/2-2*Math.atan(t); var aux3=eq/2+5*eq*eq/24+eq*eq*eq/12; var aux4=7*eq*eq/48+29*eq*eq*eq/240; var aux5=(7*eq*eq*eq/120)*Math.sin(12*Math.atan(t)); var lon=teta/n+Prj.lon0*Math.PI/180; var lat=XX+aux3*Math.sin(4*Math.atan(t))-aux4*Math.sin(8*Math.atan(t))+aux5; return [lon,lat]; } KMap.LL2Lambert=function(lon,lat,Prj){ var lat0=Prj.lat0*Math.PI/180;var lat1=Prj.lat1*Math.PI/180;var lat2=Prj.lat2*Math.PI/180; var eq=(Prj.ella*Prj.ella-Prj.ellb*Prj.ellb)/(Prj.ella*Prj.ella); var e=Math.sqrt(eq); var m1=Math.cos(lat1)/Math.sqrt(1-eq*Math.pow(Math.sin(lat1),2)); var m2=Math.cos(lat2)/Math.sqrt(1-eq*Math.pow(Math.sin(lat2),2)); var aux1=Math.sqrt((1-e*Math.sin(lat1))/(1+e*Math.sin(lat1))); var aux2=Math.sqrt((1-e*Math.sin(lat2))/(1+e*Math.sin(lat2))); var aux0=Math.sqrt((1-e*Math.sin(lat0))/(1+e*Math.sin(lat0))); var t1=((1-Math.tan(lat1/2))/(1+Math.tan(lat1/2)))/Math.pow(aux1,e); var t2=((1-Math.tan(lat2/2))/(1+Math.tan(lat2/2)))/Math.pow(aux2,e); var t0=((1-Math.tan(lat0/2))/(1+Math.tan(lat0/2)))/Math.pow(aux0,e); if(lat1==lat2) var n=Math.sin(lat1); else var n=(Math.log(m1)-Math.log(m2))/(Math.log(t1)-Math.log(t2)); var efe=m1/(n*Math.pow(t1,n)); var ro0=Prj.ella*efe*Math.pow(t0,n); var aux=Math.sqrt((1-e*Math.sin(lat))/(1+e*Math.sin(lat))); var t=((1-Math.tan(lat/2))/(1+Math.tan(lat/2)))/Math.pow(aux,e); var ro=Prj.ella*efe*Math.pow(t,n); var teta=n*(lon-Prj.lon0*Math.PI/180); var x=ro*Math.sin(teta)+Prj.x0; var y=ro0-ro*Math.cos(teta)+Prj.y0; return [x,y]; } // --- MapModule Functions --- /// @vars {?} Prj, zoomlevels, x,y, mpp KMap.prototype.Prj=KMap.Prj.EPSG3857; KMap.prototype.zoomlevels=[0.298582,0.597164,1.194329,2.388657,4.777314,9.554629,19.109257,38.218514,76.437028,152.874057,305.748113,611.496226,1222.992453,2445.984905]; KMap.prototype.x=1470000; KMap.prototype.y=7100000; KMap.prototype.mpp=152.874057; /// @vars mapl,mapt,mapr,mapb KMap.prototype.mapl=0; KMap.prototype.mapt=0; KMap.prototype.mapr=0; KMap.prototype.mapb=0; /// @vars MapTipImageSize, MapTipBgColor, MapTipHooverColor, MapTipImgSrc KMap.prototype.MapTipImageSize=144; KMap.prototype.MapTipBgColor="#FEF4CB"; KMap.prototype.MapTipHooverColor="#FFA155"; KMap.prototype.MaptipColor="black"; KMap.prototype.MapTipImgSrc={}; /// @vars {string::color} FontSize, {string::color} FontSizeBig, {string::color} FontWeightBig, {string::color} TitleBarTextColor KMap.prototype.FontSize=""; KMap.prototype.FontSizeBig="120%"; KMap.prototype.FontWeightBig="bold"; KMap.prototype.TitleBarTextColor="#000000"; /// @var {array} DefaultPrintoutBasemap KMap.prototype.DefaultPrintoutBasemap={ url:"https://www.kig.gmbh/osm-wms/?Dither=true&FORMAT=image/png;mode=24bit", copyright:"© OSM contributors (ODbL 1.0)", copyrightlong:"© OpenStreetMap contributors (ODbL 1.0)", opacity:75 } /// @var {array} Basemaps KMap.prototype.Basemaps=[{ token:"OSM", caption:"OpenStreetMap", type:"tiles", scmin:1000, //url:"http://c.tile.openstreetmap.de/tiles/osmde/{z}/{x}/{y}.png", url:"https://c.tile.openstreetmap.org/{z}/{x}/{y}.png", copyright:"© OSM contributors (ODbL 1.0)", copyright_link:"http://www.openstreetmap.org/copyright", opacity:85, tilesize:256, yshift:0, size:1, printout:KMap.prototype.DefaultPrintoutBasemap } /*,{ token:"DOP", caption:"Sat", type:"tiles", scmin:30000, url:"http://maps.kulturlandschaft-informatik.de/sat/{z}/{x}/{y}.jpg", copyright:"NASA/KIG", opacity:100, tilesize:256, drawlabels:1, printout:KMap.prototype.DefaultPrintoutBasemap }*/ ]; /// @var Basemap KMap.prototype.Basemap=KMap.prototype.Basemaps[0]; /// @var {array} Layers KMap.prototype.Layers=[]; /* KMap.CoorTrans=function(Pt,Prj1,Prj2){ if(Prj1==Prj2) return Pt; if(Prj1==KMap.Prj.EPSG4326) return [Pt[0]*20037508.34/180,Math.log(Math.tan((90+Pt[1])*Math.PI/360))/(Math.PI/180)*20037508.34/180]; else return [Pt[0]/20037508.34*180,180/Math.PI*(2*Math.atan(Math.exp(Pt[1]/20037508.34*Math.PI))-Math.PI/2)]; }; */ /** * @fn ProjectExtent( e, Prj1, Prj2 ) */ KMap.ProjectExtent=function(e,Prj1,Prj2){ p1=KMap.CoorTrans([e[0],e[1]],Prj1,Prj2); p2=KMap.CoorTrans([e[0],e[3]],Prj1,Prj2); p3=KMap.CoorTrans([e[2],e[3]],Prj1,Prj2); p4=KMap.CoorTrans([e[2],e[1]],Prj1,Prj2); var xmin=Math.min(p1[0],p2[0]); var ymin=Math.min(p1[1],p4[1]); var xmax=Math.max(p3[0],p4[0]); var ymax=Math.max(p2[1],p3[1]); return [xmin,ymin,xmax,ymax]; }; /** * @fn Hash(s) * @memberof KMap * @param {string} s * @return {int} */ KMap.Hash=function(s){ var h=0; var f=1; for(var a=0;a999999999999){h-=999999999999;f=1;} } return h; }; /** * @fn RemoveArrayElement(A,E) * @memberof KMap * @param {array} array * @param {any} item */ KMap.RemoveArrayElement=function(array,item){ out=[]; for(var i=0;i-1){ var n="";var f=root.attributes; for(var a=0;a-1?ev.createNSResolver(root):null; var iterator=ev.evaluate(path,node,ns,XPathResult.ORDERED_NODE_ITERATOR_TYPE,null); var n,nodes=[];while(n=iterator.iterateNext()) nodes.push(n); return nodes; } }; /** * @fn ExtentsOverlap * @memberof KMap * @param {object} e1 * @param {object} e2 * @return {bool} */ KMap.ExtentsOverlap=function(e1,e2){ return e1.xmin<=e2.xmax && e1.xmax>=e2.xmin && e1.ymin<=e2.ymax && e1.ymax>=e2.ymin; }; /** * @fn ExtentsOverlapArea * @memberof KMap * @param {object} e1 * @param {object} e2 * @return {float} overlapping area in square units */ KMap.ExtentsOverlapArea=function(e1,e2){ var dx=Math.min(e1.xmax,e2.xmax)-Math.max(e1.xmin,e2.xmin); var dy=Math.min(e1.ymax,e2.ymax)-Math.max(e1.ymin,e2.ymin); return Math.sqrt(dx*dx+dy*dy); }; /** * @fn ExtentsArea * @memberof KMap * @param {object} e * @return {float} area of extent in square units */ KMap.ExtentsArea=function(e){ var dx=e.xmax-e.xmin;var dy=e.ymax-e.ymin;return Math.sqrt(dx*dx+dy*dy); }; /** * @fn s * @memberof KMap * @param {string} resource id * @return {string} localized resource string */ KMap.prototype.s=function(id){ var r=KRes[id]; if(r && Object.keys(r).length) return r[this.Lang] || r[this.DefaultLang] || r[Object.keys(r)[0]]; else return "["+id+"]"; }; /** * @fn LangChange * @memberof KMap * @param {string:language id} l * Public method. */ KMap.prototype.LangChange=function(l){ if(this.Lang!=l){this.Lang=l;this.LangChanged()} }; /** * @fn LangChanged * @memberof KMap */ KMap.prototype.LangChanged=function(){ this.ButtonsRefresh(); this.RefreshBasemapCopyr(); }; /** * @fn Px2Geo * @memberof KMap * @param {float[2]} xy: pixel coordinates * @return {float[2]} map coordinates */ KMap.prototype.Px2Geo=function(xy){ return [this.xmin+xy[0]*this.mpp,this.ymax-xy[1]*this.mpp]; }; /** * @fn Geo2Px * @memberof KMap * @param {float[2]} xy: map coordinates * @return {float[2]} pixel coordinates */ KMap.prototype.Geo2Px=function(xy){ return [(xy[0]-this.xmin)/this.mpp,(this.ymax-xy[1])/this.mpp]; }; /** * @fn RealScaleFac * @memberof KMap * @param y * @return */ KMap.prototype.RealScaleFac=function(y){ if(this.Prj==KMap.Prj.EPSG3857){ var lat=y/6378137; lat=Math.atan((Math.pow(Math.E,lat)-Math.pow(Math.E,-lat))/2); return Math.cos(lat); }else return 1; }; KMap.prototype.RealMPP=function(){ return this.mpp*this.RealScaleFac(this.y); }; KMap.prototype.GetScale=function(){ return this.RealMPP()/0.00028; }; KMap.prototype.SetMPP=function(mpp){ this.mpp=mpp;this.RoundMPP(); this.CleanOverlays(); }; KMap.prototype.RoundMPP=function(mpp){ var out=false; if(typeof mpp=="undefined") mpp=this.mpp; else out=true; if(mpp<=this.zoomlevels[0]) mpp=this.zoomlevels[0]; else if(mpp>this.zoomlevels[this.zoomlevels.length-1]) mpp=this.zoomlevels[this.zoomlevels.length-1]; else for(var a=0;athis.zoomlevels[a] && mpp<=this.zoomlevels[a+1]) mpp=this.zoomlevels[a+1]; if(out) return mpp; else this.mpp=mpp; }; KMap.prototype.Placing=function(){ var m=this; if(m.o.clientWidth==0 || m.o.clientHeight==0) return; m.mapw=m.o.clientWidth-m.mapl-m.mapr; m.maph=m.o.clientHeight-m.mapt-m.mapb; var st=m.mapback.style;st.left=m.mapl+"px";st.top=m.mapt+"px";st.width=m.mapw+"px";st.height=m.maph+"px"; st=m.mapal.style;st.left=m.mapl+"px";st.top=m.mapt+"px";st.width=m.mapw+"px";st.height=m.maph+"px"; if(m.scalebar){m.scalebar.style.left=(m.mapl+6)+"px";m.scalebar.style.bottom=(m.mapb+6)+"px"}; m.copyr.style.left=(m.mapl+m.mapw-m.copyr.offsetWidth-10)+"px"; m.copyr.style.top=(m.mapt+m.maph-18)+"px"; m.impr.style.left=(m.mapl+m.mapw-m.impr.offsetWidth-10-(m.ButtonsRight.length ? m.ButtonSize:0))+"px"; m.impr.style.top=(m.mapt+8)+"px"; if(m.sidebar){ st=m.sidebar.style; // TODO (Maik) jetzt wird die Start- bzw. mit dem Divider eingestellte Breite verwendet: if(m.sidebarAlign=="right") st.left=(m.mapw - m.sidebarSettings[m.sidebarId].width)+"px"; else st.right=(m.mapw - m.sidebarSettings[m.sidebarId].width)+"px"; // st.left=(m.mapl+(m.sidebarAlign=="right"?m.mapw-m.sidebar.offsetWidth:0))+"px"; st.top=m.mapt+"px"; st.height=m.maph+"px"; m.sidebarContainer.style.height=(m.maph-m.sidebarTitle.offsetHeight)+"px"; } // TODO (Maik) Musste wegen Divider die Button-Left/Right-Platzierung hierher nach die Sidebar-Platzierung verschieben: st=m.ButtonsLeftO.style;st.left=(m.mapl+(m.sidebar && m.sidebarAlign=="left"? m.sidebar.offsetWidth:0))+"px";st.top=(m.mapt+m.ButtonGapSize)+"px"; st=m.ButtonsRightO.style;st.left=(m.mapl+m.mapw-m.ButtonSize-(m.sidebar && m.sidebarAlign=="right"? m.sidebar.offsetWidth:0))+"px";st.top=(m.mapt+m.ButtonGapSize)+"px"; if(m.edgebar){ st=m.edgebar.style; st.left=m.mapl+"px"; // TODO (Maik) In M-V soll die Edgebar (Geom-Editor und Mess-Funktion) nicht die KO-Anzeige verdecken: // st.top=(m.mapt+m.maph-m.edgebar.offsetHeight)+"px"; st.bottom=m.mapb+(m.scalebar?46:0)+"px"; } m.DigiCanvas.width=m.mapw; m.DigiCanvas.height=m.maph; }; KMap.prototype.Scalebar=function(){ var m=this; if(m.scalebar) m.o.removeChild(m.scalebar); m.scalebar=document.createElement("div"); var st=m.scalebar.style; st.position="absolute";st.left=(m.mapl+6)+"px";st.bottom="6px";st.padding="2px";st.zIndex="1007";st.background="rgba(255,255,255,0.7)"; m.o.appendChild(m.scalebar); if(m.opts.coordinates){ m.lblCoor=document.createElement("div");var st=m.lblCoor.style;st.fontSize=m.FontSize; m.scalebar.appendChild(m.lblCoor); m.lblCoor.onmousemove=function(){m.CoorShow()}; m.lblCoor.onmouseout=function(){m.CMenuLeave()}; } var t=document.createElement("table");m.scalebar.appendChild(t);t.style.borderSpacing="0";t.style.borderCollapse="collapse"; var r=m.RealMPP(); var w=String(Math.floor(160*r)); var v=w.substr(0,1); switch(v){case "6":case "7":case "8":case "9":v="5";} w=parseInt(v+Array(w.length).join("0")); var tr=t.insertRow(); var td=tr.insertCell();td.style.padding="0";td.style.width=(w/r)+"px";td.style.height="6px";td.style.fontSize="1pt";td.style.borderBottom="2px solid #333333";td.style.borderLeft="2px solid #333333";td.style.borderRight="2px solid #333333"; td=tr.insertCell();td.rowSpan="2";td.style.padding="0";td.style.paddingLeft="4px";td.style.fontSize=m.FontSize;td.style.color="#333333";td.style.verticalAlign="middle"; if(String(w).substr(String(w).length-3,3)=="000") td.innerHTML=(w/1000)+" km"; else td.innerHTML=w+" m"; tr=t.insertRow(); td=tr.insertCell();td.style.padding="0";td.style.width=(w/r)+"px";td.style.height="6px";td.style.fontSize="1pt";td.style.borderLeft="2px solid #333333";td.style.borderRight="2px solid #333333"; m.scalebar.style.bottom=(m.mapb+6)+"px"; }; KMap.prototype.CoorUpdate=function(e){ var m=this; if(!m.lblCoor) return; var pt=[m.xmin+m.ex*m.mpp,m.ymax-m.ey*m.mpp]; pt=KMap.CoorTrans(pt,m.Prj,m.PrjEx); if(m.PrjEx.proj=="none"){pt[0]=pt[0].toFixed(5);pt[1]=pt[1].toFixed(5);}else{pt[0]=pt[0].toFixed(0);pt[1]=pt[1].toFixed(0);} m.lblCoor.innerHTML=pt[0]+";"+pt[1]; if(e){ var r=m.lblCoor.getBoundingClientRect(); var ex=e.clientX-r.left,ey=e.clientY-r.top; if(ex>=0 && ey>=0 && ex"+v.caption+"":v.caption; tr.myPrj=v; tr.onclick=function(){ m.PrjEx=this.myPrj; m.CoorUpdate(); m.CMenuHide(); m.PrjExChanged(); }; } m.o.appendChild(m.cmenuo); m.cmenuo.onmousemove=function(){m.CMenuHold()}; m.cmenuo.onmouseout=function(){m.CMenuLeave()}; }; KMap.prototype.CleanLabels=function(){ this.labels=[];this.DrawLabels(); }; KMap.prototype.DrawLabel=function(o,x,y,t,a){ if(a){var m=document.createElement("div");o.appendChild(m);} var l=document.createElement("div"); l.innerHTML=t; l.style.position="absolute"; o.appendChild(l); l.style.left=(x-l.offsetWidth/(a?1:2))+"px"; l.style.top=(y-l.offsetHeight/(a?1:2))+"px"; if(a){var st=m.style;st.fontSize="8px";st.background="#FFFFFF";st.opacity=.7;st.position="absolute";st.left=l.offsetLeft+"px";st.top=l.offsetTop+"px";st.width=l.offsetWidth+"px";st.height=l.offsetHeight+"px"}; }; KMap.prototype.DrawLabels=function(){ if(this.labelplane) this.mapback.removeChild(this.labelplane); this.labelplane=document.createElement("div"); var st=this.labelplane.style;st.position="absolute";st.zIndex="1006";st.left=this.mapl+"px";st.top=this.mapt+"px";st.width=this.mapw+"px";st.height=this.maph+"px";st.overflow="hidden"; this.mapback.appendChild(this.labelplane); for(var a=0;a"+t[3]+"",c); } }; KMap.prototype.LoadLabels=function(){ // DEPRECATED !!! if(this.Basemap.drawlabels){ var m=this; /** @call extern URL */ KInternet.HTTPRequest(KUrl+"annos.php?MPP="+this.mpp+"&BBOX="+this.xmin+","+this.ymin+","+this.xmax+","+this.ymax,function(r){ m.labels=r.split("\n"); if(!m.Dragging) m.DrawLabels(); }); }else this.labels=[]; this.DrawLabels(); }; KMap.prototype.OverlayClean=function(sameMPP){ }; KMap.prototype.OverlayPlace=function(){ }; KMap.prototype.OverlayLoad=function(){ }; KMap.prototype.GetTile=function(layer,kx,ky,mpp){ for(var i=0;i=0;i--) if(this.tiles[i].layer==layer){var t=this.tiles[i];this.mapback.removeChild(t.d);t.d=t.b=null;this.tiles.splice(i,1)} }; KMap.prototype.ReloadTiles=function(layer){ for(var i=this.tiles.length-1;i>=0;i--) if(this.tiles[i].layer==layer) this.LoadTileDo(layer,this.tiles[i]); }; KMap.prototype.CleanTiles=function(){ for(var i=0;i0) y1-=layer.yshift*t.mpp; else y2-=layer.yshift*t.mpp; var e=KMap.ProjectExtent([t.xmin,y1,t.xmax,y2],this.Prj,layer.prj); var url=KMap.LayerUrlWithAuth(layer)+"&SERVICE=WMS&VERSION="+(layer.v ? layer.v:"1.1.1")+"&REQUEST=GetMap&"+(layer.v=="1.3.0"?"CRS":"SRS")+"="+layer.prj.crs+"&BBOX="+e.join(",")+"&WIDTH="+layer.tilesize*layer.size+"&HEIGHT="+(layer.tilesize+Math.abs(layer.yshift))*layer.size; if(url!=t.b.src){ t.b.src=KMap.dummyImg; t.b.style.opacity=layer.opacity/100; if(layer.size==1){ t.b.style.msInterpolationMode="nearest-neighbor"; if(t.b.style.setProperty) t.b.style.setProperty("image-rendering","optimizeSpeed",null); } t.b.src=url; if(t.layer.snapable) this.DigiSnapSetLoadParams(layer,t,e); // store snap-params/geoms in t(ile) } }else if(layer.drawFunc) layer.drawFunc(t); }; KMap.LayerUrlWithAuth=function(layer){ var url=layer.url; if(layer.authUser && layer.authPw){ var i=url.indexOf("://"); if(i>-1){i+=3;url=url.substr(0,i)+encodeURIComponent(layer.authUser)+":"+encodeURIComponent(layer.authPw)+"@"+url.substr(i);} } return url; }; /** * @fn LoadGTiles() */ KMap.prototype.LoadGTiles=function(){ var zs=[0.298582,0.597164,1.194329,2.388657,4.777314,9.554629,19.109257,38.218514,76.437028,152.874057,305.748113,611.496226,1222.992453,2445.984905,4891.969810,9783.939621,19567.879241,39135.758482]; var l=0;while(zs[l]<=this.mpp){var mpp=zs[l];l++};l=20-l; var e=KMap.ProjectExtent([this.xmin,this.ymin,this.xmax,this.ymax],this.Prj,KMap.Prj.EPSG4326); for(var kx=KMap.osm_long2tile(e[0],l);kx<=KMap.osm_long2tile(e[2],l);kx++) for(var ky=KMap.osm_lat2tile(e[3],l);ky<=KMap.osm_lat2tile(e[1],l);ky++) this.LoadGTile(kx,ky,mpp,l); }; /** * @fn LoadGTile(kx,ky,mpp,l) * @param kx * @param ky * @param mpp * @param l */ KMap.prototype.LoadGTile=function(kx,ky,mpp,l){ var t=this.GetTile(this.Basemap,kx,ky,mpp); if(t){ if(t.d) this.mapback.removeChild(t.d); }else{ var b=KMap.ProjectExtent([KMap.osm_tile2long(kx,l),KMap.osm_tile2lat(ky+1,l),KMap.osm_tile2long(kx+1,l),KMap.osm_tile2lat(ky,l)],KMap.Prj.EPSG4326,this.Prj); t={layer:this.Basemap,kx:kx,ky:ky,mpp:mpp,xmin:b[0],xmax:b[2],ymin:b[1],ymax:b[3]} this.tiles.push(t); } if(!t.d){ t.d=document.createElement("div"); var st=t.d.style;st.zIndex="1";st.position="absolute";st.overflow="hidden"; t.b=document.createElement("img"); if(this.Basemap.opacity<100){var m=this;t.b.onload=function(){m.TileLoaded(m.Basemap,kx,ky,t.mpp)}}; t.b.style.position="absolute";t.b.style.opacity=this.Basemap.opacity/100; t.d.appendChild(t.b); } t.b.src=KMap.LayerUrlWithAuth(this.Basemap).replace(/{z}/g,l).replace(/{x}/g,kx).replace(/{y}/g,ky); this.mapback.appendChild(t.d); }; /** * @fn osm_long2tile * @memberof KMap * @param lon * @param z * @return */ KMap.osm_long2tile=function(lon,z){return (Math.floor((lon+180)/360*Math.pow(2,z)));} /** * @fn osm_lat2tile * @memberof KMap * @param lat * @param z * @return */ KMap.osm_lat2tile=function(lat,z){return (Math.floor((1-Math.log(Math.tan(lat*Math.PI/180)+1/Math.cos(lat*Math.PI/180))/Math.PI)/2*Math.pow(2,z)));} /** * @fn osm_tile2long * @memberof KMap * @param x * @param z * @return */ KMap.osm_tile2long=function(x,z){return (x/Math.pow(2,z)*360-180);} /** * @fn osm_tile2lat(y,z) * @memberof KMap * @param y * @param z * @return */ KMap.osm_tile2lat=function(y,z){var n=Math.PI-2*Math.PI*y/Math.pow(2,z);return (180/Math.PI*Math.atan(0.5*(Math.exp(n)-Math.exp(-n))));} /** * @fn LayerAvailable(v) * @memberof KMap * @param v */ KMap.prototype.LayerAvailable=function(v){ return (!v.bbox || !v.bbox[0] || this.xmin<=v.bbox[2] && this.xmax>=v.bbox[0] && this.ymin<=v.bbox[3] && this.ymax>=v.bbox[1]) && (this.GetScale()>=v.scmin || !v.scmin) && (this.GetScale()<=v.scmax || !v.scmax); }; /** * @fn FindSuitableBasemap() * @memberof KMap */ KMap.prototype.FindSuitableBasemap=function(){ var a,i=-1; for(a=0;a-1) this.SetBasemap(this.Basemaps[i]); }; /** * @fn LoadSoon() * @memberof KMap */ KMap.prototype.LoadSoon=function(){ var m=this; if(m.tmrMap) clearTimeout(m.tmrMap); m.tmrMap=setTimeout(function(){m.Load()},1500); }; /** * @fn Load * @memberof KMap * @param NoHistory * @param NewVersion */ KMap.prototype.Load=function(NoHistory,NewVersion){ var m=this; if(!m.maph) return; if(NewVersion) m.Version+=1; m.RoundMPP(); m.xmin=m.x-(m.mapw*m.mpp)/2; m.xmax=m.x+(m.mapw*m.mpp)/2; m.ymin=m.y-(m.maph*m.mpp)/2; m.ymax=m.y+(m.maph*m.mpp)/2; if(!NoHistory){ m.AddHistory(); m.Scalebar(); if(!m.LayerAvailable(m.Basemap)) m.FindSuitableBasemap(); for(var i=m.tiles.length-1;i>=0;i--){ var t=m.tiles[i]; if(t.isLayer || !KMap.ExtentsOverlap(t,this) || Math.max(m.mpp,t.mpp)/Math.min(m.mpp,t.mpp)>2.001){ m.mapback.removeChild(t.d); t.d=t.b=null; m.tiles.splice(i,1); } } m.untiled.style.display="none"; if(!m.Basemap.yshift) m.Basemap.yshift=0; if(!m.Basemap.size) m.Basemap.size=1; if(m.Basemap.type=="tiles") m.LoadGTiles(); else if(m.unon){ var y1=m.ymin,y2=m.ymax; if(m.Basemap.yshift<0) y2-=m.Basemap.yshift*m.mpp; if(m.Basemap.yshift>0) y1-=m.Basemap.yshift*m.mpp; var e=KMap.ProjectExtent([m.xmin,y1,m.xmax,y2],m.Prj,m.Basemap.prj); m.untiledimg.src=KMap.LayerUrlWithAuth(m.Basemap)+"&SERVICE=WMS&VERSION="+(m.Basemap.v? m.Basemap.v:"1.1.1")+"&REQUEST=GetMap&"+(m.Basemap.v=="1.3.0" ? "CRS":"SRS")+"="+m.Basemap.prj.crs+"&BBOX="+e.join(",")+"&WIDTH="+m.mapw*m.Basemap.size+"&HEIGHT="+(m.maph+Math.abs(m.Basemap.yshift))*m.Basemap.size; var st=m.untiledimg.style; st.left="0"; st.top=Math.min(0,m.Basemap.yshift)+"px"; st.width=m.mapw+"px"; st.height=(m.maph+Math.abs(m.Basemap.yshift))+"px"; st.opacity=m.Basemap.opacity/100; st.msInterpolationMode="nearest-neighbor"; if(m.untiledimg.style.setProperty) st.setProperty("image-rendering","optimizeSpeed",null); m.untiled.style.width=m.mapw+"px"; m.untiled.style.height=m.maph+"px"; if(m.Basemap.snapable) this.DigiSnapSetLoadParams(m.Basemap,m,e); // store snap-params/geoms in m(this) }else{ m.untiledimg.src=KMap.dummyImg; m.TileQueue=[]; for(var kx=Math.floor(m.xmin/m.mpp/m.Basemap.tilesize);kx<=Math.floor(m.xmax/m.mpp/m.Basemap.tilesize);kx++) for(var ky=Math.floor(m.ymin/m.mpp/m.Basemap.tilesize);ky<=Math.floor(m.ymax/m.mpp/m.Basemap.tilesize);ky++) m.TileQueueAdd(kx,ky); m.TileQueue.sort(KMap.TileQueueSort); for(i=0;i=1){ this.mpp=mpp2; this.x=xx; this.y=yy; var m=this;this.tmrMap=setTimeout(function(){m.Zooming=false;m.Load()},50); }else{ var m=this;setTimeout(function(){m.ZoomEffect(x,y,mpp1,mpp2,f)},50); } }; /** * @fn Zoom * @memberof KMap * @param x * @param y * @param mpp1 * @param mpp2 */ KMap.prototype.Zoom=function(x,y,mpp1,mpp2){ if(this.timerID){clearTimeout(this.timerID);this.timerID=0} if(this.tmrMap){clearTimeout(this.tmrMap);this.tmrMap=0} this.CleanOverlays(); this.MapTipHide(); this.Zooming=true; this.ZoomEffect(x,y,mpp1,mpp2,0); }; /** * @fn ZoomIn(x,y) * @memberof KMap * @param x * @param y */ KMap.prototype.ZoomIn=function(x,y){ if(typeof y=="undefined"){x=this.x;y=this.y} var i; for(var a=0;a0) this.Zoom(x,y,this.zoomlevels[i],this.zoomlevels[i-1]); }; /** * @fn ZoomOut(x,y) * @memberof KMap * @param x * @param y */ KMap.prototype.ZoomOut=function(x,y){ if(typeof y=="undefined"){x=this.x;y=this.y} var i; for(var a=0;a1) { this.History.shift(); this.x=this.History[0]["x"];this.y=this.History[0]["y"]; if(this.mpp!=this.History[0]["mpp"]){this.mpp=this.History[0]["mpp"];this.CleanOverlays()}else this.OverlayClean(true); this.History.shift(); this.Load(); } }; /** * @fn ZoomAll() * @memberof KMap */ KMap.prototype.ZoomAll=function(){ this.x=(this.expanse.xmin+this.expanse.xmax)/2;this.y=(this.expanse.ymin+this.expanse.ymax)/2; this.SetMPP(0.9*Math.max((this.expanse.xmax-this.expanse.xmin)/this.mapw,(this.expanse.ymax-this.expanse.ymin)/this.maph)); this.CleanOverlays(); this.Load(); }; // TODO (map.js) Geolocation: erweitert um Methode ZoomPos => an Maik senden /** * @fn ZoomPos(o) * @memberof KMap * @param o is the button object with button definitions and the inner DIV element of the button */ KMap.prototype.ZoomPos=function(o){ if (this.geolocationWatchPositionId !== undefined) return; var zoomLevel = Infinity; this.geolocationWatchPositionId = navigator.geolocation.watchPosition( // better use of GPS than getCurrentPosition // Firefox uses the mobile location service only sometimes! // Chrome uses the mobile location service always on watching the position! function(pos){ //console.log(pos); //console.log(new Date(pos.timestamp)); var zoomLevelNew = Math.max(0.5, pos.coords.accuracy/50); // Zoom level according to returned accuracy - more accurate coords = more zoom, but not too much! if (zoomLevelNew < zoomLevel) { //console.log(`watchPosition #${id} better accuracy ${pos.coords.accuracy}`); zoomLevel = zoomLevelNew; Map.Localize(KMap.CoorTrans([pos.coords.longitude,pos.coords.latitude], KMap.Prj.EPSG4326,KMap.Prj.EPSG5650), // transform from WGS84 to internal DenkmalGIS crs zoomLevel, "POINT(0 0)"); // This dummy WKT is needed, that Map.Localize applies mpp (zoom level)! } },function(err){ // err.code: // 0 = UNKNOWN_ERROR // 1 = PERMISSION_DENIED // 2 = POSITION_UNAVAILABLE // 3 = TIMEOUT console.log(`ERROR(${err.code}): ${err.message}`); },{ // With maximumAge:0 and enableHighAccuracy:true FFmobile activates location icon some times, // Chrome-Mobile does not! maximumAge:0, // 0 = always aquire new position otherwise set milliseconds timeout:10*1000, enableHighAccuracy:true } ); o.innerDiv.style.backgroundImage="url('"+KMap.ImgZoomPosWait+"')"; //console.log(`watchPosition #${id} started`); setTimeout((function(){ navigator.geolocation.clearWatch(this.geolocationWatchPositionId); o.innerDiv.style.backgroundImage="url('"+o.img+"')"; delete this.geolocationWatchPositionId; //console.log(`watchPosition #${id} stopped`); }).bind(this),15*1000); // give GPS time to respond before stop watching }; //KMap.prototype.Pan=function(dx,dy){ // this.x+=dx*(this.xmax-this.xmin)/2; // this.y+=dy*(this.ymax-this.ymin)/2; // this.Load(); //}; /** * @fn CleanOverlays() * @memberof KMap * @use this.CleanTiles(), this.CleanLabels(), this.OverlayClean() */ KMap.prototype.CleanOverlays=function(){ this.CleanTiles();this.CleanLabels();this.OverlayClean(); }; /** * @fn MapTipRequest() * @memberof KMap */ KMap.prototype.MapTipRequest=function(){ // to be overwritten this.BasemapTipRequest(); }; /** * @fn BasemapTipRequest() * @memberof KMap */ KMap.prototype.BasemapTipRequest=function(){ var m=this,layers=[],i=-1; if(this.Basemap.queryable) layers.push(this.Basemap); for(var a=0;a-1){ i=t.indexOf("{",j); if(i>-1){ o+=t.substr(j+1,i-j-1); j=t.indexOf("}",i); var xpath=t.substr(i+1,j-i-1); var n=KMap.XMLSelectNodes(d.documentElement,xpath); var s=n[0].nodeValue; if(n.length) o+=s; }else o+=t.substr(j+1); } tips=[{tip:o}]; }else if(r && r!=" ") tips=[{tip:r}]; func(tips); }); } }; KMap.prototype.WmsGetFeatureInfo=function(layer,bbox,func){ var m=this; var url=layer.url+"&SERVICE=WMS&VERSION="+(layer.v?layer.v:"1.1.1")+"&REQUEST=GetFeatureInfo&QUERY_LAYERS="+layer.querylayers+"&INFO_FORMAT="+layer.queryformat+"&"+(layer.v=="1.3.0"?"CRS":"SRS")+"="+layer.prj.crs+"&"+(layer.v=="1.3.0"?"I":"X")+"="+m.ex+"&"+(layer.v=="1.3.0"?"J":"Y")+"="+m.ey+"&WIDTH="+m.mapw+"&HEIGHT="+m.maph+"&BBOX="+bbox.join(","); var xhr=new XMLHttpRequest(); xhr.open("GET",url,true,layer.authUser?layer.authUser:null,layer.authPw?layer.authPw:null); xhr.withCredentials=!!layer.authUser; xhr.onload=function(){ if(xhr.readyState===4){ if(xhr.status===200) func(this.responseText,this.responseXML);else alert(this.statusText); } }; xhr.onerror=function(){ // probably cross-domain error, retry via server KInternet.HTTPRequest(KUrl+"map-getwmsfeatureinfo.php?url="+encodeURIComponent(url)+"&user="+encodeURIComponent(layer.authUser?layer.authUser:"")+"&pw="+encodeURIComponent(layer.authPw?layer.authPw:""),function(r,d){ func(r,d); }); }; xhr.send(null); }; //KMap.prototype.MapTipRec=function(tip,topic,type,id,clickable,imgSrc,imgW,imgH,imgXXL){ // return {tip:tip,topic:topic,type:type,id:id,clickable:clickable,imgSrc:imgSrc,imgW:imgW,imgH:imgH,imgXXL:imgXXL} //}; /** * @fn MapTipShow(recs,mainRec) * @memberof KMap * @param recs * @param mainRec */ KMap.prototype.MapTipShow=function(recs,mainRec){ if(this.cmenuo) return; this.MapTipHide(); this.maptip=document.createElement("div"); var st=this.maptip.style;st.position="absolute";st.left=st.top="0";st.zIndex="1012";st.padding="3px";st.border="1px #000000 solid";st.backgroundColor=this.MapTipBgColor;borderRadius="4px 4px 4px 4px";st.boxShadow="2px 2px 2px 0 black"; var inner=document.createElement("div"); this.maptip.appendChild(inner); var t=document.createElement("table");inner.appendChild(t);st=t.style;st.borderSpacing=0;st.borderCollapse="collapse"; var clickables=[]; var xxlNum=0,xxl=false; var m=this; for(var a=0;amaxw){imgH=Math.round(imgH*maxw/imgW);imgW=maxw;} var maxh=KMap.WindowHeight();if(imgH>maxh){imgW=Math.round(imgW*maxh/imgH);imgH=maxh;} var imgSrc=r.img.src.replace(/{w}/g,imgW).replace(/{h}/g,imgH); td.innerHTML="
"+r.tip+"
"; }else{ td.style.padding="6px 0 6px 6px"; if(r.img){ var f=this.MapTipImageSize/Math.max(r.img.w,r.img.h); var imgW=Math.round(r.img.w*f); var imgH=Math.round(r.img.h*f); var i=document.createElement("img");i.width=imgW;i.height=imgH;i.src=r.img.src.replace(/{w}/g,imgW).replace(/{h}/g,imgH);td.appendChild(i); st=i.style;st.marginRight="6px";st.float="left"; } td=tr.insertCell(1); td.style.padding="6px 6px 6px 0"; var t2=document.createElement("table");td.appendChild(t2);st=t2.style;st.borderSpacing=0;st.borderCollapse="collapse"; if(typeof(r.topic)=="string"){ var items=r.topic.split("\n"); for(var b=0;b1) st.whiteSpace="nowrap"; td2.innerHTML=items[b]; } } if(typeof(r.tip)=="string"){ items=r.tip.split("\n"); for(b=0;bwh*.8){ st=inner.style;st.height=(wh*.8)+"px";st.overflowY="scroll"; dh=this.maptip.offsetHeight; } } if(mxww) mx=ww-dw; if(my<0) my=0; if(my+dh>wh) my=wh-dh; this.maptip.style.left=(mx-dl)+"px"; this.maptip.style.top=(my-dt)+"px"; if(clickables.length>1){ var al=this.mapal.getBoundingClientRect(); var mt=this.maptip.getBoundingClientRect(); this.maptipBox=[Math.min(this.mx-5,mt.left-al.left),Math.min(this.my-5,mt.top-al.top),Math.max(this.mx+5,mt.right-al.left),Math.max(this.my+5,mt.bottom-al.top)]; } if(this.Immediately) this.MouseUp(); }; /** * @fn MapTipHookEvent * @memberof KMap * @params o,eventName,target,funcName,funcParam */ KMap.MapTipHookEvent=function(o,eventName,target,funcName,funcParam){ o.addEventListener(eventName,function(e){target[funcName](funcParam,e.button+1)},false); }; KMap.prototype.MapTipHide=function(){ if(this.maptip){this.o.removeChild(this.maptip);delete this.maptip;delete this.maptipBox;} if(!this.Dragging) this.mapal.style.cursor=this.cursor; }; /** * @fn MapTipClick * @memberof KMap * @params rec,button */ KMap.prototype.MapTipClick=function(rec,button){ // to be overwritten }; /** * @fn TouchStart * @memberof KMap * @param e */ KMap.prototype.TouchStart=function(e){ e.button=0;e.clientX=e.touches[0].clientX;e.clientY=e.touches[0].clientY;this.MouseMove(e);this.MouseDown(e); }; /** * @fn TouchMove * @memberof KMap * @param e */ KMap.prototype.TouchMove=function(e){ if(e.touches.length==1){ e.button=0;e.clientX=e.touches[0].clientX;e.clientY=e.touches[0].clientY;this.MouseMove(e);this.MouseDown(e); }else{ var dx=e.touches[0].clientX-e.touches[1].clientX;var dy=e.touches[0].clientY-e.touches[1].clientY;var d=Math.sqrt(dx*dx+dy*dy); if(this.TouchZoom){ if(!this.Zooming){ var r=this.mapal.getBoundingClientRect(); var x=this.xmin+((e.touches[0].clientX+e.touches[1].clientX)/2-r.left)*this.mpp; var y=this.ymax-((e.touches[0].clientY+e.touches[1].clientY)/2-r.top)*this.mpp; var mpp=this.RoundMPP(this.TouchMPP*Math.pow(this.TouchDist/d,1.5)); if(mppthis.mpp) this.ZoomOut(x,y); } }else{ this.TouchZoom=true;this.TouchDist=d;this.TouchMPP=this.mpp; } } }; /** * @fn TouchEnd * @memberof KMap * @param e */ KMap.prototype.TouchEnd=function(e){ if(!this.TouchZoom) this.MouseUp(e); this.TouchZoom=false; }; /** * @fn MouseWheel * @memberof KMap * @param e */ KMap.prototype.MouseWheel=function(e){ e.stopPropagation();e.preventDefault(); var x=this.xmin+this.ex*this.mpp; var y=this.ymax-this.ey*this.mpp; if(!this.Zooming && !this.Rectangling && !this.Dragging) if(e.deltaY<0) this.ZoomIn(x,y); else if(e.deltaY>0) this.ZoomOut(x,y); }; /** * @fn MouseMove * @memberof KMap * @param e * EventListener */ KMap.prototype.MouseMove=function(e){ this.MouseIn=true; var r=this.mapal.getBoundingClientRect(); this.ex=e.clientX-r.left; this.ey=e.clientY-r.top; e.stopPropagation(); e.preventDefault(); // prevent image drag&drop if(this.MouseKey){ if(this.timerID){clearTimeout(this.timerID);this.timerID=0} this.MapTipHide();this.CMenuHide(); } this.MouseMoveDo(); this.CoorUpdate(e); }; /** * @fn MouseMoveDo * @memberof KMap */ KMap.prototype.MouseMoveDo=function(){ var m=this; if(m.Digitizer){ if(!m.MouseKey || !(m.Dragging || m.Rectangling)) if(m.DigiMouseMove()) return; } if(m.Measuring){ if(!m.MouseKey || !(m.Dragging || m.Rectangling)) if(m.MeasMouseMove()) return; } if(m.MouseKey){ if(!m.Dragging && !m.Rectangling){ if(Math.abs(m.mx-m.ex)>9 || Math.abs(m.my-m.ey)>9){ if(m.MouseKey==1){ m.Dragging=true;m.mapal.style.cursor="move";m.StartX=m.x;m.StartY=m.y; }else m.Rectangling=true; } } if(m.Rectangling){ var startX=Math.max(0,Math.min(m.mx,m.ex)); var startY=Math.max(0,Math.min(m.my,m.ey)); var rectW=Math.min(m.mapw-startX,Math.max(m.mx,m.ex)-startX); var rectH=Math.min(m.maph-startY,Math.max(m.my,m.ey)-startY); var R=m.rect; if(rectW>9 || rectH>9){ R.style.display="block";R.style.left=(startX+m.mapl)+"px";R.style.top=(startY+m.mapt)+"px"; R.innerHTML="
"; }else R.style.display="none"; }else if(m.Dragging){ m.x=m.StartX+(m.mx-m.ex)*m.mpp; m.y=m.StartY-(m.my-m.ey)*m.mpp; m.Load(1); } }else{ if((Math.abs(m.mx-m.ex)>5 || Math.abs(m.my-m.ey)>5) && (!m.maptipBox || m.exm.maptipBox[2] || m.ey>m.maptipBox[3])){ if(m.timerID){clearTimeout(m.timerID);m.timerID=0;} m.MapTipHide(); m.LinkO=false; m.mx=m.ex;m.my=m.ey; m.timerID=setTimeout(function(){m.MapTipRequest();},250); m.CMenuLeave(); } } }; /** * @fn MouseDown * @memberof KMap * @param e */ KMap.prototype.MouseDown=function(e){ var m=this; var r=m.mapal.getBoundingClientRect(); m.ex=e.clientX-r.left; m.ey=e.clientY-r.top; m.eb=e.button+1; e.stopPropagation();e.preventDefault(); if(m.MouseKey==0){m.MouseKey=m.eb;m.mx=m.ex;m.my=m.ey;if(m.timerID){clearTimeout(m.timerID);m.timerID=0}}; if(m.Digitizer) m.DigiMouseDown(); }; /** * @fn MouseUp * @memberof KMap * @param e * EventListener */ KMap.prototype.MouseUp=function(e){ var m=this,b=this.MouseKey; m.MouseKey=0; if(m.Digitizer && !m.Rectangling && !m.Dragging){ m.DigiMouseUp(); }else if(this.Measuring && !this.Rectangling && !this.Dragging){ m.MeasAdd(); }else if(m.Rectangling){ m.Rectangling=false;m.rect.style.display="none"; var startX=Math.max(0,Math.min(m.mx,m.ex)); var startY=Math.max(0,Math.min(m.my,m.ey)); var rectW=Math.min(m.mapw-startX,Math.max(m.mx,m.ex)-startX); var rectH=Math.min(m.maph-startY,Math.max(m.my,m.ey)-startY); if(rectW>9 || rectH>9){m.x=m.xmin+(startX+rectW/2)*m.mpp;m.y=m.ymax-(startY+rectH/2)*m.mpp;m.mpp*=Math.max(rectW/m.mapw,rectH/m.maph);m.Load()} }else if(m.Dragging){ m.Dragging=false;m.mapal.style.cursor=m.cursor;m.Load(); }else if(m.LinkO){ if(m.LinkClickable) m.MapTipClick(m.LinkO,b);else if(m.CMenuPrepare()) m.CMenuPop(m.mx,m.my); }else if((b>1 || m.popCMenuOnLeftButton) && m.CMenuPrepare()){ m.CMenuPop(m.mx,m.my); }else{ // SN: only of triggered by event and not called by code (otherwise recursion!): if (e !== undefined) { m.MapTipRequest(); m.Immediately=true; } } }; /** * @fn MouseDbl * @memberof KMap */ KMap.prototype.MouseDbl=function(){ if(this.Digitizer) this.DigiMouseDbl(); else if(this.Digitizable()){ this.Digitize(); } }; /** * @fn MouseOut * @memberof KMap */ KMap.prototype.MouseOut=function(){ if(this.timerID){clearTimeout(this.timerID);this.timerID=0}; if(this.Dragging) this.MouseUp(); this.MouseIn=false; this.DigiCanvasRedraw(); if(this.Measuring) this.MeasDraw(); }; /** * @fn KeyDown * @memberof KMap * @param e */ KMap.prototype.KeyDown=function(e){ if(this.Digitizer) this.DigiKey(e.key); if(this.Measuring) this.MeasKey(e.key); }; /** * @fn * @memberof KMap * @param e */ KMap.prototype.DragEnter=function(e){ }; /** * @fn * @memberof KMap * @param e */ KMap.prototype.Drop=function(e){ var m=this; if(m.LyEditable && m.LyImportFiles(e.dataTransfer.files)) return; if(typeof Exif!="undefined"){ for(var a=0;athis.mapl+this.mapw) this.cmenuo.style.left=(x-w-3)+"px"; else this.cmenuo.style.left=(x+3)+"px"; if(y+h>this.mapt+this.maph) this.cmenuo.style.top=(this.mapt+this.maph-h)+"px"; }; /** * @fn CMenuLeave * @memberof KMap */ KMap.prototype.CMenuLeave=function(){ var m=this; if(!m.CMenuPopTimer) m.CMenuPopTimer=setTimeout(function(){m.CMenuHide()},400); }; /** * @fn CMenuHold * @memberof KMap */ KMap.prototype.CMenuHold=function(){ var m=this; if(m.CMenuPopTimer){clearTimeout(m.CMenuPopTimer);m.CMenuPopTimer=0;} }; /** * @fn CmenuHide * @memberof KMap */ KMap.prototype.CMenuHide=function(){ this.CMenuHold(); if(this.cmenuo){this.o.removeChild(this.cmenuo);this.cmenuo=null} }; /** * @fn Resize * @memberof KMap * @param w * @param h */ KMap.prototype.Resize=function(w,h){ this.o.style.width=w+"px";this.o.style.height=h+"px"; this.Placing(); this.Load(); }; /** * @fn LayerOn * @memberof KMap * @param i * @param on */ KMap.prototype.LayerOn=function(i,on){ if(typeof i!=="number") i=this.Layers.indexOf(i); this.Layers[i].on=!!on; if(on) this.Load();else this.RemoveTiles(this.Layers[i]); }; /** * @fn DeleteLayer * @memberof KMap * @param i */ KMap.prototype.DeleteLayer=function(i){ this.RemoveTiles(this.Layers[i]); this.Layers.splice(i,1); }; /** * @fn DeleteBasemap * @memberof KMap * @param i */ KMap.prototype.DeleteBasemap=function(i){ var d=(this.Basemap==this.Basemaps[i]); this.Basemaps.splice(i,1); if(d) this.FindSuitableBasemap(); this.Load(); }; /** * @fn SetBasemap * @memberof KMap * @param s */ KMap.prototype.SetBasemap=function(s){ this.RemoveTiles(this.Basemap); this.Basemap=s; this.RefreshBasemapCopyr(); this.unon=s.untiled; }; /** * @fn RefreshBasemapCopyr * @memberof KMap */ KMap.prototype.RefreshBasemapCopyr=function(){ var l=this.Basemap.copyright; if(this.Basemap.copyright_link) l=""+l+""; this.copyr.innerHTML=this.s("Basemap")+": "+l; try{this.copyr.style.left=(this.mapw-this.copyr.offsetWidth-10)+"px"}catch(err){} }; /** * @fn SetBasemapByToken * @memberof KMap * @param t * @return {null} */ KMap.prototype.SetBasemapByToken=function(t){ for(var i=0;i0 && !this.ButtonsLeft[a].id && !this.ButtonsLeft[a-1].id))){ btns.push(this.ButtonsLeft[a]); if(this.ButtonsLeft[a].gapAfter) btns.push({id:false}); } for(a=0;a0 && !this.ButtonsRight[a].id && !this.ButtonsRight[a-1].id))){ btns.push(this.ButtonsRight[a]); if(this.ButtonsRight[a].gapAfter) btns.push({id:false}); } for(a=0;a", bar:"
{title}
{close}
", close:"
X
", body:"
{body}
" }; // TODO (Maik) Startbreite der sidebars (hier wird dynamisch auch die mit dem Divider eingestellte Breite gespeichert): KMap.prototype.sidebarSettings={maps:{minWidth:200,width:200},search:{minWidth:200,width:200}}; /** * @fn SidebarOpen * @memberof KMap * @params title,callback,align * @return {DOMelement::div} winBody * * createElement div as sidebar * createElement div as sidebaContainer * createElement div as winBody * createElement img as CloseImg with onclick-listener in td with img call SidebarClose() */ KMap.prototype.SidebarOpen=function(id,title,callback,align){ var m=this; // TODO (Maik) ID der Sidebar um auf sidebarSettings zuzugreifen: m.sidebarId=id; m.SidebarClose(); m.sidebarCallback=callback; m.sidebarAlign=align?align:"right"; m.sidebar=document.createElement("div");m.o.appendChild(m.sidebar); var st=m.sidebar.style;st.position="absolute";st.zIndex="1010";st.backgroundColor="white";st.boxShadow="0 0 6px 0 #73808D"; // TODO (Maik) add splitter-div and some styles to in preperation to the above container: st.display="flex";st.flexDirection="row"; if(align!="right") st.left="0px"; // splitter: var splitter=document.createElement("div"); splitter.style.cssText="height:100%;box-sizing:border-box;cursor:ew-resize;flex:0 0 4px"; m.sidebarDivider = new KSplitter(splitter,function(active){ splitter.style.backgroundColor=active?"#c8c8c8":"#e8e8e8"; var border=active?"none":"1px solid #e0e0e0"; splitter.style.borderRight=border; splitter.style.borderLeft=border; },function(e){ // console.log("mousemove clientX="+e.clientX); var w; if(align=="right") w = m.mapl + m.mapw - e.clientX; else w = e.clientX - m.mapl; if(w > m.mapw / 2) w=m.mapw/2; if(w < m.sidebarSettings[m.sidebarId].minWidth) w = m.sidebarSettings[m.sidebarId].minWidth; m.sidebarSettings[m.sidebarId].width = w; m.Placing(); }); if(align=="right") m.sidebar.appendChild(splitter); // title bar: var t=document.createElement("table"); st=t.style;st.cellPadding="0";st.cellSpacing="0";st.border="0";st.borderCollapse="collapse"; // TODO (Maik) because of splitter-div add flex style: st.flexGrow="1"; m.sidebar.appendChild(t); // TODO (Maik) for align left add splitter after table: if(align!="right") m.sidebar.appendChild(splitter); // title caption: var tr=t.insertRow(); m.sidebarTitle=tr; var td=tr.insertCell();st=td.style;st.border=st.padding="0";st.paddingLeft=st.paddingTop=st.paddingBottom="8px";st.fontSize=m.FontSizeBig;st.fontWeight=m.FontWeightBig;st.color=m.TitleBarTextColor;st.textAlign="left";st.verticalAlign="middle"; // TODO (Maik) habe die Borders der Sidebar entfernt, weil sie nicht mehr zum Slider-DIV passen: st.borderBottom="1px solid #ddd"; td.innerHTML=title; // separator and close button: td=tr.insertCell();st=td.style;st.border=st.padding="0";st.width="16px"; // TODO (Maik) habe die Borders der Sidebar entfernt, weil sie nicht mehr zum Slider-DIV passen: st.borderBottom=st.borderRight="1px solid #ddd"; td.innerHTML=" "; td=tr.insertCell();st=td.style;st.border=st.padding="0";st.paddingLeft=st.paddingRight="8px";st.width="24px";st.verticalAlign="middle"; // TODO (Maik) habe die Borders der Sidebar entfernt, weil sie nicht mehr zum Slider-DIV passen: st.borderBottom="1px solid #ddd"; var closeImg=document.createElement("img");st=closeImg.style;st.verticalAlign="middle";st.cursor="pointer"; closeImg.src=m.ImgCloseBig;closeImg.width=closeImg.height="24"; td.appendChild(closeImg); td.onclick=function(){m.SidebarClose()}; // body: tr=t.insertRow(); td=tr.insertCell();td.colSpan="3"; m.sidebarContainer=document.createElement("div");m.sidebarContainer.style.overflowY="auto"; td.appendChild(m.sidebarContainer); var winBody=document.createElement("div");st=winBody.style; st.margin="8px"; m.sidebarContainer.appendChild(winBody); return winBody; }; /** * @fn SidebarClose * @memberof KMap */ KMap.prototype.SidebarClose=function(){ if(this.sidebar){ this.sidebarDivider.remove(); this.o.removeChild(this.sidebar); this.sidebar=null; this.Placing(); if(this.sidebarCallback) this.sidebarCallback(); } }; /** * @fn EdgebarOpen * @memberof KMap * @param callback * @return * * createElement div as edgebar * createElement table * createElement img from this.ImgClose as CloseImg with onclick-listener call EdgebarClose() */ KMap.prototype.EdgebarOpen=function(callback){ var m=this; m.EdgebarClose(); m.edgebarCallback=callback; m.edgebar=document.createElement("div");m.o.appendChild(m.edgebar); var st=m.edgebar.style;st.position="absolute";st.zIndex="1010";st.backgroundColor="white"; // TODO (Maik) Bei M-V soll die Edgebar (Geometrie-Editor bzw. Mess-Funktion) nicht die KO-Anzeige verdecken: // Deshalb hier den Shadow anpassen, damit er auch unterhalb des Fensters ist: st.boxShadow="0 0 3px 3px #73808D"; var t=document.createElement("table");m.edgebar.appendChild(t); st=t.style;st.borderSpacing="0";st.borderCollapse="collapse";st.margin="8px"; var tr=t.insertRow(0); var td=tr.insertCell(0); var o=document.createElement("div");td.appendChild(o); td=tr.insertCell(1); var c=document.createElement("img");td.appendChild(c); c.src=m.ImgClose;c.width="14";c.height="14"; c.style.cursor="pointer"; c.onclick=function(){m.EdgebarClose()} return o; }; /** * @fn EdgebarClose * @memberof KMap */ KMap.prototype.EdgebarClose=function(){ if(this.edgebar){ if(this.edgebar) this.o.removeChild(this.edgebar); this.edgebar=null; this.Placing(); if(this.edgebarCallback) this.edgebarCallback(); } }; /** @var {int} FindReqID */ KMap.prototype.FindReqID=0; /** * @var {string} FindURL * @memberof KMap * link to extern URL www.kig.gmbh/gazetteer */ KMap.prototype.FindURL="https://www.kig.gmbh/gazetteer/?q="; /** * @fn FindShow * @memberof KMap * @param c */ KMap.prototype.FindShow=function(c){ var m=this; if(c){ var so=this.SidebarOpen("search",m.s("Search"),function(){m.ButtonCheck("find",false)},"left"); // TODO (Maik) Habe width=100% statt 220px und box-sizing:border-box gesetzt wegen Divider: var fi=document.createElement("input");fi.type="text";fi.placeholder=m.s("SearchPlaceholder");fi.value="";var st=fi.style;st.boxSizing="border-box";st.width="100%";st.border="#73808D solid 1px";so.appendChild(fi); setTimeout(function(){m.Placing();fi.focus()},0); var loader=document.createElement("div");var st=loader.style;st.width="100%";st.height="3px";st.marginTop="6px";so.appendChild(loader); var tmrLoader,valLoader=0; var findXY=function(s){ var pt=s.split(";"); m.Loc=KMap.CoorTrans([parseFloat(pt[0]),parseFloat(pt[1])],m.PrjEx,m.Prj); m.LocDraw(); }; var list; var showResults=function(hits){ if(tmrLoader){clearInterval(tmrLoader);tmrLoader=null;} loader.style.backgroundImage=""; if(list){so.removeChild(list);list=null;} if(Array.isArray(hits) && hits.length){ list=document.createElement("table");so.appendChild(list);var st=list.style;st.borderSpacing="0";st.borderCollapse="collapse";st.marginTop="2px";st.maxWidth="350px"; for(var a=0;a-1) findXY(q); else{ tmrLoader=setInterval(function(){ valLoader+=1;if(valLoader==40) valLoader=0; loader.style.backgroundImage="linear-gradient(90deg, #3b99fc "+(-40+valLoader)+"%,white "+(-20+valLoader)+"%, #3b99fc "+(0+valLoader)+"%, white "+(20+valLoader)+"%, #3b99fc "+(40+valLoader)+"%, white "+(60+valLoader)+"%, #3b99fc "+(80+valLoader)+"%, white "+(100+valLoader)+"%, #3b99fc "+(120+valLoader)+"%)"; },25); m.FindReqID++;var myID=m.FindReqID; KInternet.HTTPRequest(m.FindURL+encodeURIComponent(q),function(r,json){ if(myID==m.FindReqID) showResults(r?json:null,fi); }); } }; fi.oninput=function(e){ if(m.FindTmr) clearTimeout(m.FindTmr); m.FindTmr=setTimeout(function(){findDo(fi.value)},500); }; ///addDOMEvent td.onkeyup fi.onkeyup=function(e){ if(e.key=="Enter"){ if(fi.value.indexOf(";")>-1){ findXY(fi.value); m.x=m.Loc[0];m.y=this.Loc[1]; m.Load(); }else findDo(fi.value); } }; }else{ m.SidebarClose(); m.LocDel(); } }; /// @var Loc KMap.prototype.Loc=null; /// @var LocShp KMap.prototype.LocShp=null; /** * @fn LocDraw() * @memeberof KMap */ KMap.prototype.LocDraw=function(){ var m=this; if(m.LocV){m.mapback.removeChild(m.LocV);m.mapback.removeChild(m.LocH);m.LocV=m.LocH=null;} m.LocV=document.createElement("div");m.mapback.appendChild(m.LocV); var st=m.LocV.style;st.zIndex="1007";st.position="absolute";st.left=((m.Loc[0]-m.xmin)/m.mpp)+"px";st.top="0";st.width="1px";st.height=m.maph+"px";st.backgroundColor="red"; m.LocH=document.createElement("div");m.mapback.appendChild(m.LocH); st=m.LocH.style;st.zIndex="1007";st.position="absolute";st.left="0";st.top=((m.ymax-m.Loc[1])/m.mpp)+"px";st.width=m.mapw+"px";st.height="1px";st.lineHeight="1px";st.overflow="hidden";st.backgroundColor="red"; } /** * @fn LocDel * @memberof KMap */ KMap.prototype.LocDel=function(){ var m=this; if(m.LocV){m.mapback.removeChild(m.LocV);m.mapback.removeChild(m.LocH);m.LocV=m.LocH=null;} m.Loc=null; if(m.LocShp){m.LocShp=null;m.Load();} } KMap.prototype.TbLocalize=function(xy,mpp,wkt){ // DEPRECATED !!! console.warn("Using deprecated KMap.TbLocalize() - use KMap.Localize() instead!"); this.Localize(xy,mpp,wkt); }; /** * @fn Localize(xy,mpp,wkt) * @memberof KMap * @param xy * @param mpp * @param wkt */ KMap.prototype.Localize=function(xy,mpp,wkt){ var m=this; m.Loc=xy; if(wkt){ var shp=KShape.createFromWkt(wkt,m.DigiPrecision===undefined?0:m.DigiPrecision); if(shp.type==KShape.stLine || shp.type==KShape.stPolygon){ m.LocShp=shp.toKShp(); m.LocShp.penWidth=4; m.LocShp.penColor="rgba(0,255,0,0.7)"; m.LocShp.fillColor="rgba(0,0,0,0)"; }else m.LocShp=null; var ext=shp.extent(); if(!ext.isNull){ // SN: mpp now sets the minimum! m.SetMPP(Math.max(mpp,1.5*Math.max((ext.xmax-ext.xmin)/m.mapw,(ext.ymax-ext.ymin)/m.maph))); if(!xy) m.Loc=[(ext.xmin+ext.xmax)/2,(ext.ymin+ext.ymax)/2]; } }else{ m.LocShp=null; var n=20;if(mpp && mpp<=2) n=2.5; if(m.mpp>n) m.SetMPP(n); } if(m.Loc){ m.x=parseFloat(m.Loc[0]);m.y=parseFloat(m.Loc[1]); m.Load(); } }; KMap.generateUUID = function() { return ([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g, c => (c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16)); } /// @var {int} LyEditable =1; KMap.prototype.LyEditable=1; /** * @fn LyShow(c) * @memberof KMap * @param c */ KMap.prototype.LyShow=function(c){ var m=this; if(c){ m.LyO=this.SidebarOpen("maps",m.s("Maps"),function(){m.ButtonCheck("map",false)},"right"); m.LyRefresh(); }else{ m.LyO=null; m.SidebarClose(); } }; // TODO (map.js) Erweiterungen für GeoPackages noch in Maik's Original-Quellcode einbauen /** * @fn LyRefresh() * @memberof KMap */ KMap.prototype.LyRefresh=function(reloadGeoPackages){ var m=this; while(m.LyO.children.length) m.LyO.removeChild(m.LyO.firstChild); // Make parent a flexbox and set height to 100%, but margin must be moved to the children: var st=m.LyO.style;st.display="flex";st.flexDirection="column";st.removeProperty("margin");st.height="100%"; var div=document.createElement("div");m.LyO.appendChild(div); div.style.cssText="flex: 0 1 auto; overflow-x: hidden; overflow-y: auto; margin: 10px 8px 0 8px; transition: height 0.5s ease-in-out;"; // TODO (Maik) Habe die Breite der Layerliste auf 100% gesetzt, um die Breite des Kartenreiters anpassen zu können (in den ist ein text-overflow ergänzt): var t=div.appendChild(document.createElement("table"));t.style.cssText="border-spacing: 0px; border-collapse: collapse; table-layout: fixed; width: 100%;"; for(var a=0;a'); td=tr.insertCell(2);td.style.cssText="vertical-align: middle; width: 20px;"; if(m.LyEditable && v.deletable){ var i=document.createElement("img");i.src=m.ImgClose;i.style.cssText="width: 14px; height: 14px; vertical-align: middle; margin: 0 3px; position: relative; top: -1px; cursor: pointer;";td.appendChild(i); //addDOMEvent img.mousedown -> this.LyDelBasemap() m.LyHookEvent(i,"mousedown",m,"LyDelBasemap",a); } } } for(a=0;a this.LyHit() m.LyHookEvent(i,"click",m,"LyHit",a); } td=tr.insertCell(1);td.style.cssText="vertical-align: middle; cursor: default; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;"; if(!av) td.style.color="#73808D"; td.innerHTML=v.caption; // TODO (map.js) In SidebarOpen (Kartenreiter) verdeckt die Scrollbar die X-Symbole zum Löschen der Nutzer-Karten/Layer! // Deshalb hier padding-right ergänzt als Platzhalter für den Scrollbar: td=tr.insertCell(2);td.style.cssText="vertical-align: middle; width: 20px; padding-right: 20px;"; if(m.LyEditable&& v.deletable){ var i=document.createElement("img");i.src=m.ImgClose;i.style.cssText="width: 14px; height: 14px; vertical-align: middle; margin: 0 3px; position: relative; top: -1px; cursor: pointer;";td.appendChild(i); /// addDOMEvent img.mousedown -> this.LyDel() m.LyHookEvent(i,"mousedown",m,"LyDel",a); } } } if(m.LyEditable){ var div=document.createElement("div"); div.style.cssText="flex: 0 0 auto; margin: 10px 8px;"; m.LyO.appendChild(div); var b=document.createElement("button");b.style.whiteSpace="nowrap";b.innerHTML=m.s("LyAddWms"); div.appendChild(b); b.onclick=function(){m.LyWmsDialog()}; b=document.createElement("button");b.style.whiteSpace="nowrap";b.innerHTML=m.s("LyAddFile"); div.appendChild(b); b.onclick=function(){m.LyFileInput.click()}; // Button GeoPackage: if (m.LyGeoPackageEnabled){ b=document.createElement("button");b.id="LyAddGeoPackage";b.style.whiteSpace="nowrap";b.innerHTML=""+m.s("LyAddGeoPackage"); div.appendChild(b); b.onclick=function(){m.LyGeoPackagesList(true)}; } } m.Placing(true); if (m.LyGeoPackagesList.active) m.LyGeoPackagesList(reloadGeoPackages); }; // --- GeoPackage functions --- // TODO (Baustein 9b GeoPackages) Anforderung von Hr. Bergmann bezüglich Gitternetze - siehe Maiks Mail vom 12.06.2019 07:55 KMap.prototype.LyGeoPackageEnabled=false; KMap.prototype.LyGeoPackageEdit=false; KMap.prototype.LyGeoPackageBtnAdd=""; KMap.prototype.LyGeoPackageImgPen=""; KMap.prototype.LyGeoPackageBtnColor="rgba(91,103,109,0.65)"; /** * @fn LyGeoPackagesList() * @memberof KMap */ KMap.prototype.LyGeoPackagesList=function(reload){ var m=this; var id = "LyGeoPackagesList"; var e = document.querySelector("#LyAddGeoPackage span"); if (document.getElementById(id)) { // Remove the GeoPackage container: this.LyO.removeChild(this.LyO.lastChild); // Let the layer-list grow: this.LyO.firstChild.style.removeProperty("max-height"); // Enable the other buttons: this.LyO.children[1].children[0].disabled=false; this.LyO.children[1].children[1].disabled=false; e.style.removeProperty("transform"); this.LyGeoPackagesList.active=false; } else { this.LyGeoPackagesList.active=true; // Rotate the GeoPackage button arrow: e.style.display="inline-block"; e.style.transition="transform 0.5s linear"; e.style.transform="rotate(180deg)" // Shrink the layer-list - transition not working, may be because of settings in LyO container: this.LyO.firstChild.style.maxHeight="150px"; // Disable the other buttons: this.LyO.children[1].children[0].disabled=true; this.LyO.children[1].children[1].disabled=true; // Add GeoPackage container: var container=document.createElement("div");container.id=id;this.LyO.appendChild(container); container.style.cssText="flex: 1 1 auto; display: flex; flex-direction: column; margin: 0 8px 10px 8px; transition: height 0.5s ease-in-out;"; // Create GeoPackage button: if(m.LyGeoPackageEdit){ var span=container.appendChild(document.createElement("span")); span.style.cssText="flex: 0 0 auto; margin: 0 0 8px 4px; display: inline-block; border-radius: 4px; text-align: center; vertical-align: middle; cursor: pointer;"; var st=span.style;st.width=st.height=st.lineHeight="30px";st.backgroundColor=this.LyGeoPackageBtnColor; span.title=this.s("LyGeoPackageCreate"); this.LyHookEvent(span,"click",m,"LyGeoPackageUploadShow",0); var d=span.appendChild(document.createElement("div")); st=d.style;st.width=st.height="100%";st.opacity="1";st.backgroundImage="url('"+m.LyGeoPackageBtnAdd+"')";st.backgroundRepeat="no-repeat";st.backgroundPosition="center"; } // Add table of server side GeoPackages: div=container.appendChild(document.createElement("div"));div.style.cssText="flex: 1 1 200px; overflow-x: hidden; overflow-y: auto;"; var t=div.appendChild(document.createElement("table"));t.style.cssText="border-spacing: 0px; border-collapse: collapse; table-layout: fixed; width: 100%;"; this.LyGeoPackageUpload=new KUpload(); // Print the list of available GeoPackage-Layers: var print=function(json){ if (json) m.LyGeoPackageList=json; else json=m.LyGeoPackageList; for(var a=0;a-1)); win.appendChild(document.createElement("br")); win.appendChild(document.createElement("br")); /// addHTMLElement font "LyWmsLayer" d=document.createElement("font");win.appendChild(d); d.innerHTML=this.s("LyWmsLayer")+":"; win.appendChild(document.createElement("br")); /// addHTMLElement select var layerList=document.createElement("select");layerList.multiple=true;layerList.size=10;layerList.style.width="300px";layerList.style.border="#73808D solid 1px";win.appendChild(layerList); if(wmsO.layers){ for(var a=0;a"" && wmsO.layers[a].crs>"") o.value=a; else o.disabled=true; layerList.options.add(o); } } win.appendChild(document.createElement("br")); /// addHTMLElement button "LyAdd" b=document.createElement("button");win.appendChild(b);b.style.whiteSpace="nowrap";b.innerHTML=this.s("LyAdd"); /// addDOMEvent button.onclick -> this.LyAdd() b.onclick=function(){m.LyWmsAdd(wmsO,layerList,false)}; /// addHTMLElement button "LyAddBasemap" b=document.createElement("button");win.appendChild(b);b.style.whiteSpace="nowrap";b.innerHTML=this.s("LyAddBasemap"); /// addDOMEvent button.onclick -> this.LyAdd(true) b.onclick=function(){m.LyWmsAdd(wmsO,layerList,true)}; win.appendChild(document.createElement("br")); } }; /** * @fn LyMapsRequire() * @memberof KMap */ KMap.prototype.LyWmsRequire=function(url,user,pw){ var m=this; m.LyWmsGetCapabilities(url,user,pw,function(d){ var o={}; o.version=d.documentElement.getAttribute("version"); var service=d.getElementsByTagName("Service")[0]; o.copyright=o.title=service.querySelectorAll("Title")[0].childNodes[0].nodeValue; var c=service.querySelectorAll("OnlineResource");if(c.length) o.copyright_link=c[0].getAttribute("xlink:href"); c=service.querySelectorAll("MaxWidth");if(c.length) o.maxwidth=Number(c[0].childNodes[0].nodeValue); c=service.querySelectorAll("MaxHeight");if(c.length) o.maxheight=Number(c[0].childNodes[0].nodeValue); var getMap=d.getElementsByTagName("GetMap")[0]; o.url=getMap.querySelectorAll("Get")[0].querySelectorAll("OnlineResource")[0].getAttribute("xlink:href"); if(user && pw){o.authUser=user;o.authPw=pw;} o.formats=[]; var fs=KMap.XMLGetChildValues(getMap,"Format"); for(var a=0;a0) cs=cs[0].split(" "); } for(var a=0;a-1?"text/plain":o.infoFormats[0]; } o.layers.push(l); var layers=KMap.XMLGetChilds(layer,"Layer"); for(var a=0;a Maik fragen KMap.prototype.LayersChanged=function(){ // to be overwritten }; /** * @fn LyHit(i) * @memberof KMap */ KMap.prototype.LyHit=function(i){ this.LayerOn(i,!this.Layers[i].on); }; /** * @fn LyDelBasemap * @memberof KMap * @param i */ KMap.prototype.LyDelBasemap=function(i){ this.DeleteBasemap(i); this.LyChanged(); }; /** * @fn LyDel(i) * @memberof KMap */ KMap.prototype.LyDel=function(i){ this.DeleteLayer(i); this.LyRefresh(); this.LyChanged(); }; /** * @fn LyAddLocalLayer * @memberof KMap */ KMap.prototype.LyAddLocalLayer=function(fields,recs,title){ // calc extent: var m=this,e=new KExtent(); for(var a=0;a -1) topic.push(line); else tip.push(line); } tips.push({topic: topic.join("\n"),tip: tip.join("\n")}); } } if (tips.length) func(tips); }, //queryable:L.queryable fields:fields, recs:recs, // For DenkmalGIS M-V use an other color instead of yellow "rgba(255,255,0,...)": symbol:{penWidth:10,penColor:"rgba(255,150,0,.66)",fillColor:"rgba(255,150,0,.33)"}, drawFunc:function(t){m.LyDrawLocalLayer(t)} }; m.Layers.push(layer); m.Load(); m.LyChanged(); }; /** * @fn LyDrawLocalLayer * @memberof KMap * @param t */ KMap.prototype.LyDrawLocalLayer=function(t){ var m=this; ///addHTMLElement canvas var canvas=document.createElement("canvas"); canvas.width=canvas.height=t.layer.tilesize; var ctx=canvas.getContext("2d"); // TODO (Maik) map.js::KMap::LyDrawLocalLayer: Optimierung - aus der Schleife hierher verlegt: var penColor = t.layer.symbol.penColor? t.layer.symbol.penColor : null; var penWidth = t.layer.symbol.penWidth? t.layer.symbol.penWidth : 1; var fillColor = t.layer.symbol.fillColor? t.layer.symbol.fillColor : null; for(var c=0;c1){ ctx.beginPath(); for(var a=0;a-1){ var base=files[a].name.substr(0,i).toLowerCase(),ext=files[a].name.substr(i+1).toLowerCase(); if(exts.indexOf(ext)>-1){ if(!bundles[base]) bundles[base]={}; bundles[base][ext]=files[a]; } } } var out=[]; for(var key in bundles) out.push(bundles[key]); return out; }; /** * @fn LyAddShapefile * @memberof KMap * @param shpFile * @param dbfFile */ KMap.prototype.LyAddShapefile=function(shpFile,dbfFile){ var m=this,r=new FileReader(); r.onload=function(){ if(dbfFile){ var r2=new FileReader(); r2.onload=function(){m.LyAddShapefileDo(shpFile.name,r.result,r2.result)}; r2.readAsArrayBuffer(dbfFile); }else m.LyAddShapefileDo(shpFile.name,r.result); }; r.readAsArrayBuffer(shpFile); }; /** * @fn LyAddShapefileDo * @memberof KMap * @param title * @param bShp * @param bDbf */ KMap.prototype.LyAddShapefileDo=function(title,bShp,bDbf){ var shapefile; // TODO (map.js) show shapefile import error message to user try { shapefile=Shapefile.open(bShp); } catch(e) { alert(e); } var dbase=bDbf?DBase.open(bDbf):null; var fields=[];recs=[],i=0; if(dbase){ for(var a=0;a1){this.MeasLine[this.MeasLine.length-2]=this.MeasLine[this.MeasLine.length-1];this.MeasLine.pop();this.MeasDraw()} } }; /** * @fn MeasAdd * @memberof KMap */ KMap.prototype.MeasAdd=function(){ this.MeasLine.push(this.MeasLine[this.MeasLine.length-1]); this.MeasDraw(); }; /** * @fn MeasDot * @memberof KMap * @param {array} xy */ KMap.prototype.MeasDot=function(xy){ with(this.DigiCtx){ beginPath(); arc(xy[0],xy[1],4,0,2*Math.PI,true); fillStyle="rgba(0,255,0,0.3)";fill(); strokeStyle="rgb(0,192,0)";lineWidth=1.5;stroke(); } }; /** * @fn MeasDraw * @memberof KMap */ KMap.prototype.MeasDraw=function(){ this.DigiCtx.clearRect(0,0,this.DigiCanvas.offsetWidth,this.DigiCanvas.offsetHeight); this.DigiCtx.lineJoin="round"; this.DigiCtx.beginPath(); for(var b=0;b1+this.MeasType){ var s; if(this.MeasType==0){ var m=this.MeasLength()*this.RealScaleFac(this.MeasCY()); if(m<1000) s=m.toFixed(0)+" m"; else if(m<100000) s=(m/1000).toFixed(2)+" km"; else s=(m/1000).toFixed(0)+" km"; }else{ var qm=this.MeasArea()*Math.pow(this.RealScaleFac(this.MeasCY()),2); if(qm<10000) s=qm.toFixed(0)+" m²"; else if(qm<1000000) s=(qm/10000).toFixed(2)+" ha"; else if(qm<100000000) s=(qm/1000000).toFixed(2)+" km²"; else s=(qm/1000000).toFixed(0)+" km²"; } with(this.DigiCtx){font="bold 12px sans-serif";textBaseline="bottom"} var xy=this.MeasLine[this.MeasLine.length-1-(this.MouseIn? 0:1)]; var cr=this.Geo2Px(xy); this.DigiCtx.fillText(s,cr[0]+10,cr[1]); } }; /** * @fn MeasDel * @memberof KMap */ KMap.prototype.MeasDel=function(){ this.MeasLine=[[0,0]]; this.MeasDraw(); }; /** * @fn MeasShow * @memberof KMap */ KMap.prototype.MeasShow=function(){ var m=this; var mo=m.EdgebarOpen(function(){ if(m.Measuring){ m.Measuring=0; m.ButtonCheck("measure",false); m.DigiCtx.clearRect(0,0,m.DigiCanvas.offsetWidth,m.DigiCanvas.offsetHeight); } }); m.Measuring=1; m.MeasDraw(); m.MapTipHide(); m.CMenuHide(); var t=document.createElement("table");mo.appendChild(t);t.style.borderSpacing="0";t.style.borderCollapse="collapse"; var tr=t.insertRow(); var td=tr.insertCell();td.style.padding="0";td.style.whiteSpace="nowrap"; var i=document.createElement("input");i.type="radio";i.name="MeasType";i.style.verticalAlign="middle";td.appendChild(i);if(m.MeasType==0) i.checked="true"; i.onclick=function(){m.MeasType=0;m.MeasDraw()}; var a=document.createElement("font");a.innerHTML=this.s("MeasTypeLine");var st=a.style;st.verticalAlign="middle";st.cursor="default";td.appendChild(a); i=document.createElement("input");i.type="radio";i.name="MeasType";i.style.verticalAlign="middle";td.appendChild(i);if(m.MeasType==1) i.checked="true"; i.onclick=function(){m.MeasType=1;m.MeasDraw()}; var a=document.createElement("font");a.innerHTML=this.s("MeasTypeArea");st=a.style;st.verticalAlign="middle";st.cursor="default";td.appendChild(a); tr=t.insertRow(); td=tr.insertCell();st=td.style;st.padding="0";st.verticalAlign="middle";st.whiteSpace="nowrap"; i=document.createElement("input");i.type="checkbox";i.style.verticalAlign="middle";td.appendChild(i);i.checked=m.MeasShowXY; i.onclick=function(){m.MeasShowXY=this.checked;m.MeasDraw()}; a=document.createElement("font");a.innerHTML=m.s("MeasShowXY");st=a.style;st.verticalAlign="middle";st.cursor="default";td.appendChild(a); tr=t.insertRow(); td=tr.insertCell();td.style.padding="0";td.colSpan="2"; var b=document.createElement("button");td.appendChild(b);b.innerHTML=this.s("MeasClear"); b.onclick=function(){m.MeasDel()}; m.Placing(); m.MeasDraw(); }; /** * @vars {string} PrintTitle, {string} PrintPaperSize, {string}PrintPaperFormat, {int} PrintScale, {boolean} PrintUseScale, {boolean} PrintScalebar */ KMap.prototype.PrintTitle=""; KMap.prototype.PrintPaperSize="A4"; KMap.prototype.PrintPaperFormat="L"; KMap.prototype.PrintScale=25000; KMap.prototype.PrintUseScale=false; KMap.prototype.PrintScalebar=true; /** * @fn PrintDlgShow * @memberof KMap */ KMap.prototype.PrintDlgShow=function(){ var m=this; m.PrintDlgO=m.win.Open("print",0,{title:m.s("Printout"),modal:true}).o; var t=document.createElement("table");this.PrintDlgO.appendChild(t);t.style.borderSpacing=0;t.style.borderCollapse="collapse"; var tr=t.insertRow(0); var td=tr.insertCell(0);with(td.style){verticalAlign="middle";padding="4px";cursor="default"} td.innerHTML=this.s("PrintoutTitle")+": "; var td=tr.insertCell(1);with(td.style){padding="4px";verticalAlign="middle"}; var i=document.createElement("input");i.type="text";i.style.width="180px";i.style.border="#73808D solid 1px";i.value=this.PrintTitle;td.appendChild(i); i.onkeyup=function(){m.PrintTitle=this.value;}; var tr=t.insertRow(); var td=tr.insertCell(0);with(td.style){verticalAlign="middle";padding="4px";cursor="default"} td.innerHTML=this.s("PrintoutPaperSize")+": "; var td=tr.insertCell(1);td.style.padding="4px"; var i=document.createElement("input");i.type="radio";i.name="PrintPaperSize";i.value="A4";i.style.verticalAlign="middle";td.appendChild(i);if(this.PrintPaperSize=="A4") i.checked="true"; i.onclick=function(){m.PrintPaperSize=this.value;}; var a=document.createElement("font");a.innerHTML="A4";with(a.style){verticalAlign="middle";cursor="default";};td.appendChild(a); var i=document.createElement("input");i.type="radio";i.name="PrintPaperSize";i.value="A3";i.style.verticalAlign="middle";td.appendChild(i);if(this.PrintPaperSize=="A3") i.checked="true"; i.onclick=function(){m.PrintPaperSize=this.value;}; var a=document.createElement("font");a.innerHTML="A3";with(a.style){verticalAlign="middle";cursor="default";};td.appendChild(a); var tr=t.insertRow(); var td=tr.insertCell(0);with(td.style){verticalAlign="middle";padding="4px";cursor="default"} td.innerHTML=this.s("PrintoutPaperFormat")+": "; var td=tr.insertCell(1);td.style.padding="4px"; var i=document.createElement("input");i.type="radio";i.name="PrintPaperFormat";i.value="P";i.style.verticalAlign="middle";td.appendChild(i);if(this.PrintPaperFormat=="P") i.checked="true"; i.onclick=function(){m.PrintPaperFormat=this.value;}; var a=document.createElement("font");a.innerHTML=this.s("PrintoutPortrait");with(a.style){verticalAlign="middle";cursor="default";};td.appendChild(a); var i=document.createElement("input");i.type="radio";i.name="PrintPaperFormat";i.value="L";i.style.verticalAlign="middle";td.appendChild(i);if(this.PrintPaperFormat=="L") i.checked="true"; i.onclick=function(){m.PrintPaperFormat=this.value;}; var a=document.createElement("font");a.innerHTML=this.s("PrintoutLandscape");with(a.style){verticalAlign="middle";cursor="default";};td.appendChild(a); var tr=t.insertRow(); var td=tr.insertCell(0);with(td.style){verticalAlign="middle";padding="4px";cursor="default"} td.innerHTML=this.s("Scale")+": "; var td=tr.insertCell(1);with(td.style){padding="4px";verticalAlign="middle";} var i2=document.createElement("input");i2.type="text";i2.style.width="55px";i2.style.border="#73808D solid 1px";i2.style.verticalAlign="middle";i2.value=this.PrintScale;i2.disabled=!this.PrintUseScale; var i=document.createElement("input");i.type="checkbox";i.style.verticalAlign="middle";td.appendChild(i);i.checked=this.PrintUseScale; i.onclick=function(){i2.disabled=!this.checked;m.PrintUseScale=this.checked;if(this.checked) i2.focus();}; var a=document.createElement("font");a.innerHTML=" 1:";with(a.style){verticalAlign="middle";cursor="default";};td.appendChild(a); td.appendChild(i2); i2.onkeyup=function(){m.PrintScale=parseFloat(this.value);}; var tr=t.insertRow(); var td=tr.insertCell(0);td.style.padding="4px";td.colSpan=2; td.appendChild(document.createElement("br")); var b=document.createElement("button");td.appendChild(b);b.innerHTML=this.s("GeneratePDF"); b.onclick=function(){m.Printout()}; }; KMap.dummyImg=""; KMap.ImgZoomAll=""; KMap.ImgZoomIn=""; KMap.ImgZoomOut=""; KMap.ImgZoomBack=""; // TODO (map.js) Geolocation: Image ZoomPos und Ajax-Loader ergänzt KMap.ImgZoomPos=""; KMap.ImgZoomPosWait=""; KMap.ImgSearch=""; KMap.ImgLayers=""; KMap.ImgMeasure=""; KMap.ImgPrint=""; KMap.ImgLink=""; KMap.prototype.ImgClose=""; KMap.prototype.ImgCloseBig=""; // --- Digitizer Functions --- KMap.prototype.DigiPrecision=1; KMap.prototype.DigiBtnColor="rgba(91,103,109,0.65)"; KMap.prototype.DigiBtnSelColor="#FF9632"; KMap.prototype.DigiBtnSnapSelColor="#3296D0"; KMap.prototype.DigiBtnOkColor="#90AD1B"; KMap.prototype.DigiBtnSize="30px"; KMap.prototype.DigiBtnMargin="4px"; KMap.prototype.DigiBtnOkMargin="16px"; KMap.prototype.DigiImgPoint=""; KMap.prototype.DigiImgLine=""; KMap.prototype.DigiImgPolygon=""; KMap.prototype.DigiImgImport=""; KMap.prototype.DigiImgOK=""; KMap.prototype.DigiImgNewVertex=""; KMap.prototype.DigiImgSnap=""; KMap.prototype.DigiImgSnapLoading=""; KMap.prototype.DigiCreate=function(types,type){ if(!types) types=1+2+4; var m=this,d,i,st; if(m.DigiO) m.DigiClose(); m.DigiO=this.EdgebarOpen(function(){if(m.Digitizer) m.DigiClose(true)}); if(types & 256){ d=document.createElement("div");m.DigiO.appendChild(d); m.DigiAddOkControl(types,d,true); d=document.createElement("div");m.DigiO.appendChild(d); d.style.marginTop="12px"; i=document.createElement("select");d.appendChild(i); i.style.border="#73808D solid 1px"; i.onchange=function(){ var i=Number(this.selectedIndex); if(m.DigiShp!=m.DigiMShp.shapes[i]) m.DigiStartShp(i); }; i.onclick=function(){this.onchange()}; i.onkeyup=function(){this.onchange()}; m.DigiIndexBox=i; i=document.createElement("button");d.appendChild(i); i.innerHTML=" + "; i.onclick=function(e){ m.DigiAddNew(type) m.DigiStartShp(m.DigiMShp.shapes.length-1); }; i=document.createElement("button");d.appendChild(i); i.innerHTML=" - "; i.onclick=function(e){ if(m.DigiMShp.shapes.length>1){ var i=Number(m.DigiIndexBox.selectedIndex); m.DigiMShp.shapes.splice(i,1); m.DigiStartShp(Math.min(i,m.DigiMShp.shapes.length-1)); } }; d=document.createElement("div");m.DigiO.appendChild(d); d.style.marginTop="12px"; m.DigiAddTypeControl(types,d); }else{ d=document.createElement("div");m.DigiO.appendChild(d); m.DigiAddTypeControl(types,d); m.DigiSnapAddControl(d); m.DigiAddOkControl(types,d,false); m.DigiIndexBox=null; } d=document.createElement("div");m.DigiO.appendChild(d); st=d.style;st.marginTop="12px";//st.verticalAlign="middle"; // TODO (map.js) Erweiterung des MapDigitizers um CRS-Eingabe => Maik senden m.DigiInput=d; i=document.createElement("input");i.style.width="97px";i.style.border="#73808D solid 1px";d.appendChild(i); i.onkeyup=function(){m.DigiSetXY()}; m.DigiInputX=i; a=document.createElement("font");a.innerHTML=" ; ";d.appendChild(a); i=document.createElement("input");i.style.width="97px";i.style.border="#73808D solid 1px";d.appendChild(i); i.onkeyup=function(){m.DigiSetXY()}; m.DigiInputY=i; d=document.createElement("div");m.DigiO.appendChild(d); st=d.style;st.marginTop="12px";d.style.display="none"; m.DigiExtended=d; i=document.createElement("select");d.appendChild(i); i.size="10";i.style.display="block";i.style.width="170px";i.style.border="#73808D solid 1px"; i.onchange=function(){m.DigiListBoxClick()}; i.onclick=function(){m.DigiListBoxClick()}; m.DigiListBox=i; i.onkeydown=function(e){ //if(!e) e=window.event; m.DigiKey(e.key); e.stopPropagation();e.preventDefault(); }; i=document.createElement("button");d.appendChild(i);i.style.fontSize="8pt";i.style.marginTop="12px"; i.innerHTML=m.s("DigiPathFlip"); i.onclick=function(e){m.DigiPathFlip()}; i=document.createElement("button");d.appendChild(i);i.style.fontSize="8pt";i.style.marginTop="12px"; i.innerHTML=m.s("DigiPartAdd"); i.onclick=function(e){m.DigiPartAdd()}; // TODO (map.js) Erweiterung des MapDigitizers um CRS-Eingabe => Maik senden d=document.createElement("div");m.DigiO.appendChild(d); st=d.style;st.marginTop="12px";d.style.display="none"; var t=document.createElement("table");d.appendChild(t);t.style.borderSpacing="0";t.style.borderCollapse="collapse"; // TODO (map.js) Neuer Resource-String in map.csv für Erweiterung des MapDigitizers => Maik senden var tr = t.insertRow(); var td=tr.insertCell();st=td.style;st.padding="2px 0";st.fontSize=m.FontSize;st.fontWeight="bold";st.textAlign="center"; td.innerHTML=m.s("DigiImportCoorSelect"); for(var a=0;a1){ i=document.createElement("span");o.appendChild(i); st=i.style;st.display="inline-block";st.width=st.height=st.lineHeight=this.DigiBtnSize;if(!fromMulti) st.marginLeft=this.DigiBtnMargin;st.cursor="pointer";st.textAlign="center";st.verticalAlign="middle"; i.title=m.s("DigiImport"); i.onclick=function(){m.DigiImport(types)}; d=document.createElement("div");i.appendChild(d); st=d.style;st.width=st.height="100%";st.opacity="1";st.backgroundImage="url('"+m.DigiImgImport+"')";st.backgroundRepeat="no-repeat";st.backgroundPosition="center"; } o.style.position="relative"; i=document.createElement("span");o.appendChild(i); st=i.style;st.display="inline-block";st.position="absolute";st.right="8px";st.width=st.height=st.lineHeight=this.DigiBtnSize;st.borderRadius="4px";st.marginLeft=this.DigiBtnOkMargin;st.marginRight=this.DigiBtnMargin;st.backgroundColor=this.DigiBtnOkColor;st.cursor="pointer";st.textAlign="center";st.verticalAlign="middle"; i.title=m.s("DigiOK"); i.onclick=function(){m.DigiFinish()}; d=document.createElement("div");i.appendChild(d); st=d.style;st.width=st.height="100%";st.opacity="1";st.backgroundImage="url('"+m.DigiImgOK+"')";st.backgroundRepeat="no-repeat";st.backgroundPosition="center"; }; KMap.prototype.DigiIndexBoxRefresh=function(){ var m=this; if(!m.DigiIndexBox) return; while(m.DigiIndexBox.options.length) m.DigiIndexBox.remove(0); for(var a=0;a1){ var o=document.createElement("option"); o.text="_______"+this.s("DigiLBPart")+" "+(a+1)+"_______"; o.value=-(a+1); this.DigiListBox.options.add(o); if(a==this.DigiCurPart && b==-1) o.selected=true; } for(var b=0;b-1){ var l=this.DigiShp.lines[this.DigiCurPart].points.length; if(this.DigiCurPt0) this.DigiInputSet(this.DigiShp.lines[this.DigiCurPart].points[l-1]); else this.DigiInputSet(); this.DigiInputX.disabled=this.DigiInputY.disabled=false; }else{ this.DigiInputSet(); this.DigiInputX.disabled=this.DigiInputY.disabled=true; } this.DigiCanvasRedraw(); this.DigiListBoxSetCur(); }; KMap.prototype.DigiMovePt=function(xy,NoInput){ this.DigiShp.lines[this.DigiCurPart].points[this.DigiCurPt]=new KPoint(xy[0],xy[1]).snapToGrid(1/Math.pow(10,this.DigiPrecision)); this.DigiCanvasRedraw(); this.DigiListBox.options[this.DigiListBox.selectedIndex].text=this.DigiListBoxFormat(xy); if(!NoInput) this.DigiInputSet(xy); }; KMap.prototype.DigiSetXY=function(){ var xy=this.DigiShp.lines[this.DigiCurPart].points[this.DigiCurPt]; xy=[parseFloat(this.DigiInputX.value),parseFloat(this.DigiInputY.value)]; xy=KMap.CoorTrans(xy,this.PrjEx,this.Prj); this.DigiMovePt(xy,true); }; KMap.prototype.DigiStart=function(geom,types,callback,type){ // types (combinable flags): 1=point, 2=line, 4=polygon, 256=multi geometry; type: 1=point, 2=line, 3=polygon var m=this; switch(type){ case 1:type=KShape.stPoint;break; case 2:type=KShape.stLine;break; case 3:type=KShape.stPolygon;break; default:type=(types & 1)?KShape.stPoint:((types & 4)?KShape.stPolygon:KShape.stLine); } m.DigiCallback=callback; m.DigiMShp=new KMultiShape(); if(geom) m.DigiLoad(geom); if(m.DigiMShp.shapes.length==0) m.DigiAddNew(type); m.DigiCreate(types,type); m.MapTipHide();m.CMenuHide(); m.Digitizer=true; m.DigiStartShp(0); m.DigiSnapLoad(); m.DigiSnapDisabled=false; m.DigiSnapControlRefresh(); }; KMap.prototype.DigiStartShp=function(index){ var m=this; m.DigiShp=m.DigiMShp.shapes[index]; if(m.DigiShp.type==KShape.stPolygon) for(var a=0;ampp*2){ m.SetMPP(mpp); m.x=(ext.xmin+ext.xmax)/2;m.y=(ext.ymin+ext.ymax)/2; m.Load(); } } }; KMap.prototype.DigiAddNew=function(type){ var g=new KShape(type);g.lines.push(new KLine()); this.DigiMShp.shapes.push(g); }; KMap.prototype.DigiSetShapeType=function(t){ var m=this; m.DigiShp.type=t; m.DigiP.style.backgroundColor=(t==KShape.stPoint?m.DigiBtnSelColor:m.DigiBtnColor); m.DigiL.style.backgroundColor=(t==KShape.stLine?m.DigiBtnSelColor:m.DigiBtnColor); m.DigiF.style.backgroundColor=(t==KShape.stPolygon?m.DigiBtnSelColor:m.DigiBtnColor); m.DigiExtended.style.display=(t==KShape.stPoint?"none":""); m.Placing(); if(t==KShape.stPoint){ if(m.DigiShp.lines[0].points.length>1) m.DigiShp.lines[0].points=[m.DigiShp.lines[0].points[0]]; if(m.DigiShp.lines.length>1) m.DigiShp.lines=[m.DigiShp.lines[0]]; m.DigiSetCur(0,0); } m.DigiCanvasRedraw(); m.DigiIndexBoxRefresh(); m.DigiListBoxRefresh(); }; KMap.prototype.DigiFinish=function(){ if(this.DigiIndexBox || this.DigiShp.lines[this.DigiCurPart].points.length) this.DigiClose(true,true); }; KMap.prototype.DigiClose=function(inform,ok){ this.Digitizer=false; if(this.edgebar) this.EdgebarClose(); this.DigiO=null; this.DigiCanvasRedraw(); if(inform && this.DigiCallback) this.DigiCallback(!!ok); delete this.DigiCallback; }; KMap.prototype.DigiPathFlip=function(){ this.DigiShp.lines[this.DigiCurPart].flip(); this.DigiListBoxRefresh(); if(this.DigiCurPt1){ var n=this.DigiCurPart; this.DigiShp.lines.splice(n,1); if(n==this.DigiShp.lines.length) n=this.DigiShp.lines.length-1; this.DigiSetCur(0,n); this.DigiListBoxRefresh(); } }; KMap.prototype.DigiClosestVertex=function(xy){ var dmin=Number.MAX_VALUE,v=[-1,0]; for(var a=0;a6 || Math.abs(m.my-m.ey)>6) m.DigiVertexDrag=2; if(m.DigiVertexDrag==2){m.DigiMovePt(m.Px2Geo(m.DigiSnapPt()));succ=true}; }else{ if(m.DigiVertexDrag) m.DigiVertexDrag=0; else{ var c="auto"; var v=m.DigiClosestVertex([m.ex,m.ey]); if(v[0]>-1) c="pointer";else{var k=m.DigiClosestEdge([m.ex,m.ey]);if(k[0]>-1) c="url('"+m.DigiImgNewVertex+"'),crosshair";succ=true}; m.mapal.style.cursor=c; } } }else m.DigiCanvasRedraw(); return succ; }; KMap.prototype.DigiMouseDown=function(){ this.DigiMouseKey=this.MouseKey; if(this.DigiCurPt-1){ this.DigiVertexDrag=1; this.DigiSetCur(v[1],v[0]); }else{ var k=this.DigiClosestEdge([this.ex,this.ey]);if(k[0]>-1){this.DigiShp.lines[k[0]].points.splice(k[1],0,new KPoint(k[2][0],k[2][1]).snapToGrid(1/Math.pow(10,this.DigiPrecision)));this.DigiSetCur(k[1],k[0]);this.DigiListBoxRefresh();this.mapal.style.cursor="auto"}; } } }; KMap.prototype.DigiMouseUp=function(){ if(!this.DigiSnapMouseUp(this.DigiMouseKey) && (this.DigiCurPt==this.DigiShp.lines[this.DigiCurPart].points.length)){ var xy=this.Px2Geo(this.DigiSnapPt()); var pt=new KPoint(xy[0],xy[1]).snapToGrid(1/Math.pow(10,this.DigiPrecision)); var pts=this.DigiShp.lines[this.DigiCurPart].points; if(!(pts.length && pts[pts.length-1].equals(pt))){ pts.push(pt); if(this.DigiShp.type==KShape.stPoint && !this.DigiIndexBox) this.DigiFinish(); else if(this.DigiShp.type!=KShape.stPoint){this.DigiListBoxRefresh();this.DigiSetCur(pts.length)} else this.DigiCanvasRedraw(); } } this.DigiMouseKey=0; }; KMap.prototype.DigiMouseDbl=function(){ if(this.DigiCurPt==this.DigiShp.lines[this.DigiCurPart].points.length && this.DigiShp.lines.length==1) this.DigiFinish(); }; KMap.prototype.DigiKey=function(k){ if(k=="Backspace" || k=="Delete"){ if(this.DigiCurPt==-1) this.DigiPartDel(); else if(this.DigiShp.lines[this.DigiCurPart].points.length>this.DigiShp.type==KShape.stPoint?1:(this.DigiShp.type==KShape.stLine?2:3)){ if(this.DigiCurPt==this.DigiShp.lines[this.DigiCurPart].points.length){ this.DigiShp.lines[this.DigiCurPart].points.pop(); this.DigiSetCur(this.DigiShp.lines[this.DigiCurPart].points.length); this.DigiListBoxRefresh(); }else if(this.DigiCurPt>-1){ var n=this.DigiCurPt;if(n==this.DigiShp.lines[this.DigiCurPart].points.length-1) n-=1;this.DigiShp.lines[this.DigiCurPart].points.splice(this.DigiCurPt,1);this.DigiSetCur(n);this.DigiListBoxRefresh(); } } } }; KMap.prototype.DigiDot=function(xy,sel){ this.DigiCtx.beginPath(); this.DigiCtx.arc(xy[0],xy[1],6,0,2*Math.PI,true); this.DigiCtx.fillStyle="rgba(255,"+(sel?255:0)+",0,0.3)";this.DigiCtx.fill(); this.DigiCtx.strokeStyle="red";this.DigiCtx.lineWidth=2;this.DigiCtx.stroke(); }; // TODO (Maik) DigiMakePath hat ungenutztes Argument shp - evtl. ein historisches Überbleibsel? KMap.prototype.DigiMakePath=function(shp){ this.DigiCtx.beginPath(); for(var a=0;a an Maik senden KMap.prototype.DigiImportCoorSelect=function(callback){ this.DigiImportCoorSelected=(function(prj){ // this.DigiCoorSelect.removeChild(t);t=null; this.DigiInput.style.display=""; this.DigiCoorSelect.style.display="none"; callback(prj); }).bind(this); this.DigiInput.style.display="none"; this.DigiExtended.style.display="none"; this.DigiCoorSelect.style.display=""; this.Placing(); }; KMap.prototype.DigiImportShapefile=function(file,geomTypes){ var m=this,r=new FileReader(); r.onload=function(){ var ms=new KMultiShape(); var shapefile=Shapefile.open(r.result); // TODO (map.js) select crs here is better than using the map-crs-selection => Maik senden m.DigiImportCoorSelect(function(prj){ while(!shapefile.eof()){ var shp=shapefile.get(); var type=0; switch(shp.type){ case KShape.stPoint:type=1;break; case KShape.stLine:type=2;break; case KShape.stPolygon:type=4;break; } m.DigiTransform(shp,prj,m.Prj); if(geomTypes & type) ms.shapes.push(shp); if(!m.DigiIndexBox) break; } if(ms.shapes.length){ m.DigiMShp=ms; m.DigiStartShp(0); } }); }; r.readAsArrayBuffer(file); }; KMap.prototype.DigiImportGpx=function(file,geomTypes){ var m=this,r=new FileReader(); r.onload=function(){ var doc=KMap.LoadXML(r.result); var segs=KMap.XMLSelectNodes(doc,"//*[local-name()='trkseg']"),recs=[]; var shp=new KShape(KShape.stLine); for(var a=0;a