您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Links for opening external resources at the WME location and WME from external resources
当前为
// ==UserScript== // @name WME Open Other Maps // @namespace https://greasyfork.org/users/30701-justins83-waze // @version 2019.02.28.02 // @description Links for opening external resources at the WME location and WME from external resources // @author JustinS83 // @include https://www.waze.com/editor* // @include https://www.waze.com/*/editor* // @include https://beta.waze.com* // @exclude https://www.waze.com/user/editor* // @include https://www.google.com/maps* // @include *wv511.org/* // @include http://www.511virginia.org/mobile/?menu_id=incidents // @include https://mdotjboss.state.mi.us/MiDrive/map* // @include http://pkk5.rosreestr.ru* // @include /https?:\/\/www\.511pa\.com\/Traffic\.aspx.*/ // @include http://newengland511.org* // @include https://www.mdottraffic.com* // @include http://www.511nj.org/trafficmap* // @include http://nmroads.com/mapIndex.html* // @include https://gis.transportation.wv.gov/measures* // @include https://www.mapwv.gov/flood/map* // @include https://roadworks.org/* // @exclude https://www.waze.com/*/user/editor* // @require https://greasyfork.org/scripts/24851-wazewrap/code/WazeWrap.js // @require https://greasyfork.org/scripts/13097-proj4js/code/Proj4js.js // @grant none // @contributionURL https://github.com/WazeDev/Thank-The-Authors // ==/UserScript== /* global $ */ /* global OL */ /* global WazeWrap */ /* global I18n */ /* global W */ /* ecmaVersion 2017 */ /* eslint curly: ["warn", "multi-or-nest"] */ (function() { 'use strict'; //var jqUI_CssSrc = GM_getResourceText("jqUI_CSS"); //GM_addStyle(jqUI_CssSrc); const updateMessage = "Small fix for some MyMaps that came with an extra offset - would cause the pins to shift positions based on the WME zoom level.<br><br><h3>.01</h3>Added support to load a Google MyMap data into WME. This is a one-way load - it is not possible to delete the MyMap pins from WME. Don't ask.<br><br>Scroll to the bottom of the OOM tab and paste a Google MyMap URL into the box and press Load MyMap. The MyMap must be publicly accessible."; var settings = {}; var wazerIcon = ""; var gmapsIcon = ""; var mapillaryIcon = ""; var terraIcon = ""; var wikimapiaIcon = ""; var bingIcon = ""; var osmIcon = ""; var yandexIcon = ""; var hereIcon = ""; var midriveIcon = ""; var NYFCIcon = ""; var rosreestrIcon = ""; var PA511Icon = ""; var Miss511Icon = ""; var LAFCIcon = ""; var RoadworksIcon = ""; //var NJ511Icon = ""; var NM511Icon = ""; var WVFloodIcon = ""; var GMDMIcon = ""; var PennDOTIcon = ""; var BogotaIcon = ""; var ZoomEarthIcon = ""; var WI511Icon = ""; var OHGOIcon = ""; function initInterface(){ var $section = $("<div>"); $section.html([ '<div>', "<p>The below maps are legal to use and do not violate Waze's external sources policy</p>", `<div><input type="checkbox" id="chkMiDrive" class="OOMchk"><label for="chkMiDrive"><img src="${midriveIcon}" height="18" width="18">MiDrive</label></div>`, `<div><input type="checkbox" id="chkNYFC" class="OOMchk"><img src="${NYFCIcon}" height="18" width="18">NY FC</div>`, `<div><input type="checkbox" id="chkrosreestr" class="OOMchk"><label for="chkrosreestr"><img src="${rosreestrIcon}" height ="18" width="18">Rosreestr</label></div>`, `<div><input type="checkbox" id="chkPA511" class="OOMchk"><label for="chkPA511"><img src="${PA511Icon}" height = 18 width="18">511PA</label></div>`, `<div><input type="checkbox" id="chkMiss511" class="OOMchk"><label for="chkMiss511"><img src="${Miss511Icon}" height=18 width="18">Mississippi 511</label></div>`, `<div><input type="checkbox" id="chkLAFC" class="OOMchk"><label for="chkLAFC"><img src="${LAFCIcon}" height="18" width="18">Louisiana FC</label></div>`, //`<div><input type="checkbox" id="chkNJ511" class="OOMchk"><label for="chkNJ511"><img src="${NJ511Icon}" height="18" width="18">New Jersey 511</label></div>`,//NJ does not directly use the map at this time `<div><input type="checkbox" id="chkNM511" class="OOMchk"><label for="chkNM511"><img src="${NM511Icon}" height="18" width="18">New Mexico 511</label></div>`, `<div><input type="checkbox" id="chkWVFlood" class="OOMchk"><label for="chkWVFlood"><img src="${WVFloodIcon}" height="18" width="18">WV Flood</label></div>`, `<div><input type="checkbox" id="chkGMDM" class="OOMchk"><label for="chkGMDM"><img src="${GMDMIcon}" height="18" width="18">Gaia - Mexico</label></div>`, `<div><input type="checkbox" id="chkPennDOT" class="OOMchk"><label for="chkPennDOT"><img src="${PennDOTIcon}" height="18" width="18">PennDOT One Map</label></div>`, `<div><input type="checkbox" id="chkBogota" class="OOMchk"><label for="chkBogota"><img src="${BogotaIcon}" height="18" width ="18">Bogota</label></div>`, `<div><input type="checkbox" id="chkWI511" class="OOMchk"><label for="chkWI511"><img src=${WI511Icon} height="18" width="18">WI 511</label></div>`, '</br>', "<p>The below maps are for <span style='color:red; font-weight:bold;'>reference only</span> and <b>no data</b> should be copied from them as it violates Waze's external sources policy.</p>", `<div><input type="checkbox" id="chkGMaps" class="OOMchk"><label for="chkGMaps"><img src="${gmapsIcon}" height="18" width="18">Google Maps</label></div>`, `<div><input type="checkbox" id="chkMapillary" class="OOMchk"><label for="chkMapillary"><img src="${mapillaryIcon}" height="18" width="18">Mapillary</label></div>`, `<div><input type="checkbox" id="chkTerraserver" class="OOMchk"><label for="chkTerraserver"><img src="${terraIcon}" height="18" width="18">Terraserver</label></div>`, `<div><input type="checkbox" id="chkWikimapia" class="OOMchk"><label for="chkWikimapia"><img src="${wikimapiaIcon}" height="18" width="18">Wikimapia</label></div>`, `<div><input type="checkbox" id="chkBing" class="OOMchk"><label for="chkBing"><img src="${bingIcon}" height="18" width="18">Bing Maps</label></div>`, `<div><input type="checkbox" id="chkOSM" class="OOMchk"><label for="chkOSM"><img src="${osmIcon}" height="18" width ="18">Open Street Map</label></div>`, `<div><input type="checkbox" id="chkYandex" class="OOMchk"><label for="chkYandex"><img src="${yandexIcon}" height="18" width ="18">Yandex</label></div>`, `<div><input type="checkbox" id="chkHere" class="OOMchk"><label for="chkHere"><img src="${hereIcon}" height="18" width ="18">Here</label></div>`, `<div><input type="checkbox" id="chkZoomEarth" class="OOMchk"><label for="chkZoomEarth"><img src="${ZoomEarthIcon}" height="18" width ="18">Zoom Earth</label></div>`, `<div title='Roadworks (https://roadworks.org/)'><input type="checkbox" id="chkRoadworks" class="OOMchk"><label for="chkRoadworks"><img src="${RoadworksIcon}" height="18" width ="18">Roadworks</label></div>`, `<div><input type="checkbox" id="chkOHGO" class="OOMchk"><label for="chkOHGO"><img src="${OHGOIcon}" height="18" width="18">OHGO</label></div>`, '</br><div>', '<fieldset style="border: 1px solid silver; padding: 8px; border-radius: 4px;">', '<legend style="margin-bottom:0px; border-bottom-style:none; width:auto;"><h4>Map Language (where applicable)</h4></legend>', '<input type="radio" name="radOOMLanguage" id="radOOMNoLang">Do not set a language</br>', '<input type="radio" name="radOOMLanguage" id="radOOMWMELang">Use WME language</br>', '<input type="radio" name="radOOMLanguage" id="radOOMCustomLang">Custom language <input type="text" name="txtOOMLanguage" id="txtOOMLanguage" style="border: 1px solid #000000;" size="4"/>', '</fieldset>', '</div>', '<div><fieldset style="border: 1px solid silver; padding: 8px; border-radius: 4px;">', '<legend style="margin-bottom: 0px; border-bottom-style:none; width: auto;"><h4>Overlay Google MyMap markers</h4></legend>', 'MyMap link: <input type="text" name="txtOOMMyMapLink" id="txtOOMMyMapLink"/>', '<button id="OOMLoadMyMap">Load MyMap</button>', '</fieldset></div>', '</div>' ].join(' ')); new WazeWrap.Interface.Tab('OOM', $section.html(), init); } function getolControlAttributionDivRightValue(){ return parseInt($('.olControlAttribution').css("right").slice(0,-2));; } function init(){ loadSettings(); setChecked('chkGMaps', settings.GMaps); setChecked('chkMapillary', settings.Mapillary); setChecked('chkTerraserver', settings.Terraserver); setChecked('chkWikimapia', settings.Wikimapia); setChecked('chkBing', settings.Bing); setChecked('chkOSM', settings.OSM); setChecked('chkYandex', settings.Yandex); setChecked('chkHere', settings.Here); setChecked('chkMiDrive', settings.MiDrive); setChecked('chkNYFC', settings.NYFC); setChecked('chkrosreestr', settings.rosreestr); setChecked('chkPA511', settings.PA511); setChecked('chkMiss511', settings.Miss511); setChecked('chkLAFC', settings.LAFC); setChecked('chkNM511', settings.NM511); //setChecked('chkNJ511', settings.NJ511); setChecked('chkWVFlood', settings.WVFlood); setChecked('chkGMDM', settings.GMDM); setChecked('chkBogota', settings.Bogota); setChecked('chkZoomEarth', settings.ZoomEarth); setChecked('chkRoadworks', settings.Roadworks); setChecked('chkWI511', settings.WI511); setChecked('chkOHGO', settings.OHGO); if(settings.LangSetting == 0) setChecked("radOOMNoLang", true); else if(settings.LangSetting == 1) setChecked("radOOMWMELang", true); else setChecked("radOOMCustomLang", true); $('#txtOOMLanguage')[0].value = settings.CustLang; let annoyingDivRight = getolControlAttributionDivRightValue(); $('.olControlAttribution').css("right", `${annoyingDivRight+100}px`); annoyingDivRight = getolControlAttributionDivRightValue(); let checkedBoxes = $('.OOMchk:Checked'); let totalButtonsWidth = 0; for(let i=0; i<checkedBoxes.length;i++){ totalButtonsWidth += parseInt($(`label[for='${$(checkedBoxes[i]).attr('id')}'] img`).css('width').slice(0,-2)); } $('.olControlAttribution').css("right", `${annoyingDivRight+totalButtonsWidth}px`); LoadMapButtons(); $('.OOMchk').change(function() { var settingName = $(this)[0].id.substr(3); settings[settingName] = this.checked; saveSettings(); LoadMapButtons(); let btnWidth = parseInt($(`label[for='${$(this).attr('id')}'] img`).css('width').slice(0,-2)); if(this.checked){ //add button width let annoyingDivRight = getolControlAttributionDivRightValue(); $('.olControlAttribution').css("right", `${annoyingDivRight+btnWidth}px`); } else{ //subtract button width let annoyingDivRight = getolControlAttributionDivRightValue(); $('.olControlAttribution').css("right", `${annoyingDivRight-btnWidth}px`); } }); $("[id^='rad']").change(function() { if(isChecked("radOOMNoLang")) settings.LangSetting = 0; else if(isChecked("radOOMWMELang")) settings.LangSetting = 1; else settings.LangSetting = 2; saveSettings(); }); $('#txtOOMLanguage').focusout(function(){ settings.CustLang = $('#txtOOMLanguage').val(); saveSettings(); }); $('#OOMLoadMyMap').click(loadMyMap); injectOLMyMapKML(); WazeWrap.Interface.ShowScriptUpdate("WME Open Other Maps", GM_info.script.version, updateMessage); } async function getKML(url){ return await $.get(url); } async function loadMyMap(){ let url = $('#txtOOMMyMapLink')[0].value; if(!url.length > 0) return; let patt = new RegExp(/^(?:http(s)?:\/\/)?www.google.com\/maps+[\w\-\._~:\/?#[\]%@!\$&\'\(\)\*\+,;=.]+$/); let res = patt.test(url); if(!res){ //not a google mymap url alert("This is not a valid Google MyMap URL"); return; } let mid = url.match(/mid=(.*?)(&|$)/)[1]; let mapKML = await getKML(`https://www.google.com/maps/d/kml?mid=${mid}&forcekml=1`); let parser = new OL.Format.MyMapKML(); parser.extractStyles = true; parser.internalProjection = W.map.getProjectionObject(); parser.externalProjection = new OL.Projection("EPSG:4326"); if(W.map.getLayersByName("Google MyMap").length > 0) W.map.removeLayer(W.map.getLayersByName("Google MyMap")[0]); var OOMMyMapLayer = new OL.Layer.Vector("Google MyMap", { rendererOptions: { zIndexing: true }, uniqueName: "wme_oommymap", layerGroup: 'wme_oommymap'}); let color = "deepskyblue"; /*var layerStyle = { externalGraphic: 'http://www.gstatic.com/mapspro/images/stock/503-wht-blank_maps.png', graphicOpacity: 1, strokeColor: color, strokeOpacity: 0.1, strokeWidth: 3, fillColor: color, //fillOpacity: 0.1, pointRadius: 15, fontColor: 'white', labelOutlineColor: color, labelOutlineWidth: 4, labelAlign: 'left' };*/ OOMMyMapLayer.setZIndex(-9999); // load geometry files var features = parser.read(new XMLSerializer().serializeToString(mapKML.documentElement)); // check which attribute can be used for labels /*let maxlabels = 5000; var labelname = /^description|description$/; if (features.length <= maxlabels) { for (var attrib in features[0].attributes) { if (labelname.test(attrib.toLowerCase()) === true) { if (typeof features[0].attributes[attrib] == 'string') { //layerStyle.label = '${'+attrib+'}'; break; } } } }*/ //OOMMyMapLayer.styleMap = new OL.StyleMap(layerStyle); // add data to the map OOMMyMapLayer.addFeatures(features); W.map.addLayer(OOMMyMapLayer); } function GetLanguage() { if(isChecked("radOOMNoLang")) return ""; else if(isChecked("radOOMWMELang")) return I18n.currentLocale().replace("en-US", "en"); else //Custom Language return $('#txtOOMLanguage').val(); } function get4326CenterPoint(){ let projI = new OL.Projection("EPSG:900913"); let projE = new OL.Projection("EPSG:4326"); let center_lonlat = (new OL.LonLat(W.map.center.lon, W.map.center.lat)).transform(projI,projE); let lat = Math.round(center_lonlat.lat * 1000000) / 1000000; let lon = Math.round(center_lonlat.lon * 1000000) / 1000000; return new OL.LonLat(lon, lat); } function LoadMapButtons() { $('#OOMMiDrive').remove(); if(settings.MiDrive) { let $section = $("<div>", {style:"padding:8px 16px"}); $section.html([ '<span id="OOMMiDrive">', `<img src="${midriveIcon}" alt="MiDrive" width="18" height="18" id="OOMMiDriveImg" title="Open in MiDrive" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html()); $('#OOMMiDriveImg').click(function(){ var center = W.map.getCenter().transform(W.map.projection, W.map.displayProjection); window.open(`https://mdotjboss.state.mi.us/MiDrive/map?constZone=true&incidents=true&lat=${center.lat}&lon=${center.lon}&zoom=${W.map.zoom + 12}`, 'MiDrive'); }); } $('#OOMGMaps').remove(); if(settings.GMaps) { let $section = $("<div>", {style:"padding:8px 16px"}); $section.html([ '<span id="OOMGMaps">', `<img src="${gmapsIcon}" alt="Google Maps" width="18" height="18" id="OOMGMapsImg" title="Open in Google Maps" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html()); $('#OOMGMapsImg').click(function(){ let latlon = get4326CenterPoint(); let lang = GetLanguage(); window.open('https://www.google.com/maps/@' + latlon.lat + ',' + latlon.lon + ',' + ( W.map.zoom + 12) + 'z' + (lang != "" ? "?hl=" + lang : ""), 'Google Maps'); }); } //************** Mapillary ***************** $('#OOMMapillary').remove(); if(settings.Mapillary){ let $sectionMapillary = $("<div>", {style:"padding:8px 16px"}); $sectionMapillary.html([ '<span id="OOMMapillary">', `<img src="${mapillaryIcon}" alt="Mapillary" width="18" height="18" id="OOMMapillaryImg" title="Open in Mapillary" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionMapillary.html()); $('#OOMMapillaryImg').click(function(){ let latlon = get4326CenterPoint(); window.open(`https://www.mapillary.com/app/?lat=${latlon.lat}&lng=${latlon.lon}&z=${( W.map.zoom + 11)}`, 'Mapillary'); }); } //****************** Terraserver ********************* $('#OOMTerraserver').remove(); if(settings.Terraserver){ var $sectionTerraserver = $("<div>", {style:"padding:8px 16px"}); $sectionTerraserver.html([ '<span id="OOMTerraserver">', `<img src="${terraIcon}" alt="Terraserver" width="18" height="18" id="OOMTerraserverImg" title="Open in Terraserver" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionTerraserver.html()); $('#OOMTerraserverImg').click(function(){ var center_lonlat=OL.Layer.SphericalMercator.inverseMercator(W.map.getCenter().lon,W.map.getCenter().lat); window.open(`http://www.terraserver.com/view?utf8=✓&searchLng=${center_lonlat.lon}&searchLat=${center_lonlat.lat}`); }); } //********************* Wikimapia ********************* $('#OOMWikimapia').remove(); if(settings.Wikimapia){ let $sectionWikimapia = $("<div>", {style:"padding:8px 16px"}); $sectionWikimapia.html([ '<span id="OOMWikimapia">', `<img src="${wikimapiaIcon}" alt="Wikimapia" width="18" height="18" id="OOMWikimapiaImg" title="Open in Wikimapia" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionWikimapia.html()); $('#OOMWikimapiaImg').click(function(){ let latlon = get4326CenterPoint(); let lang = GetLanguage(); if(lang === "") lang = "en"; window.open(`http://wikimapia.org/#${(lang !== "" ? "lang=" + lang : "")}&lat=${latlon.lat}&lon=${latlon.lon}&z=${( W.map.zoom + 12)}&m=b`); }); } $('#OOMBing').remove(); if(settings.Bing) { let $sectionBing = $("<div>", {style:"padding:8px 16px"}); $sectionBing.html([ '<span id="OOMBing">', `<img src="${bingIcon}" alt="Bing Maps" width="18" height="18" id="OOMBingImg" title="Open in Bing Maps" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionBing.html()); $('#OOMBingImg').click(function(){ let latlon = get4326CenterPoint(); //let lang = I18n.currentLocale().replace("en-US", "en"); window.open(`https://www.bing.com/maps?&cp=${latlon.lat}~${latlon.lon}&lvl=${( W.map.zoom + 12)}`); }); } $('#OOMOSM').remove(); if(settings.OSM){ //https://www.openstreetmap.org/#map=16/39.5588/-84.2365 let $sectionOSM = $("<div>", {style:"padding:8px 16px"}); $sectionOSM.html([ '<span id="OOMOSM">', `<img src="${osmIcon}" alt="Open Street Map" width="18" height="18" id="OOMOSMImg" title="Open in Open Street Maps" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionOSM.html()); $('#OOMOSMImg').click(function(){ let latlon = get4326CenterPoint(); //let lang = I18n.currentLocale().replace("en-US", "en"); window.open(`https://www.openstreetmap.org/#map=${(W.map.zoom + 12)}/${latlon.lat}/${latlon.lon}`); }); } $('#OOMYandex').remove(); if(settings.Yandex){ //https://n.maps.yandex.ru/#!/?z=14&ll=46.019795%2C51.505120&l=nk%23sat let $sectionYandex = $("<div>", {style:"padding:8px 16px"}); $sectionYandex.html([ '<span id="OOMYandex">', `<img src="${yandexIcon}" alt="Yandex" width="18" height="18" id="OOMYandexImg" title="Open in Yandex" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionYandex.html()); $('#OOMYandexImg').click(function(){ let latlon = get4326CenterPoint(); //let lang = I18n.currentLocale().replace("en-US", "en"); window.open(`https://n.maps.yandex.ru/#!/?z=${(W.map.zoom + 12)}&ll=${latlon.lon}%2C${latlon.lat}&l=nk%23sat`); }); } $('#OOMHere').remove(); if(settings.Here){ //https://wego.here.com/?map=39.56508,-84.26224,16,normal&x=ep let $sectionHere = $("<div>", {style:"padding:8px 16px"}); $sectionHere.html([ '<span id="OOMHere">', `<img src="${hereIcon}" alt="Here" width="18" height="18" id="OOMHereImg" title="Open in Here" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionHere.html()); $('#OOMHereImg').click(function(){ let latlon = get4326CenterPoint(); window.open(`https://wego.here.com/?map=${latlon.lat},${latlon.lon},${(W.map.zoom + 12)},satellite&x=ep`); }); } $('#OOMNYFC').remove(); if(settings.NYFC){ let $sectionNYFC = $("<div>", {style:"padding:8px 16px"}); $sectionNYFC.html([ '<span id="OOMNYFC">', `<img src="${NYFCIcon}" alt="NY FC" width="18" height="18" id="OOMNYFCImg" title="Open in NY FC" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionNYFC.html()); $('#OOMNYFCImg').click(function(){ let e=W.map.getExtent(); let geoNW=new OL.Geometry.Point(e.left,e.top); let geoSE=new OL.Geometry.Point(e.right,e.bottom); Proj4js.defs["EPSG:26918"] = "+proj=utm +zone=18 +ellps=GRS80 +datum=NAD83 +units=m +no_defs"; let source = new Proj4js.Proj('EPSG:900913'); let dest = new Proj4js.Proj('EPSG:26918'); geoNW = new Proj4js.Point(geoNW.x,geoNW.y); geoSE = new Proj4js.Point(geoSE.x,geoSE.y); Proj4js.transform(source, dest, geoNW); Proj4js.transform(source, dest, geoSE); let mapScale = 36111.909643; switch (W.map.zoom) { case 0: case 1: mapScale = 72223.819286; break; case 2: mapScale = 36111.909643; break; case 3: mapScale = 18055.954822; break; default: mapScale = 9027.977411; break; } let URL='http://gis3.dot.ny.gov/html5viewer/?viewer=FC&scale='+mapScale+'&extent='+geoNW.x+'%2C'+geoNW.y+'%2C'+geoSE.x+'%2C'+geoSE.y; window.open(URL,"_blank"); }); } $('#OOMrosreestr').remove(); if(settings.rosreestr){ let $sectionRosreestr = $("<div>", {style:"padding:8px 16px"}); $sectionRosreestr.html([ '<span id="OOMrosreestr">', `<img src="${rosreestrIcon}" alt="Rosreestr" width="18" height="18" id="OOMrosreestrImg" title="Open in Rosreestr" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionRosreestr.html()); $('#OOMrosreestrImg').click(function(){ window.open(`http://pkk5.rosreestr.ru/#x=${W.map.center.lon}&y=${W.map.center.lat}&z=${(W.map.zoom + 12)}`); }); } $('#OOMPA511').remove(); if(settings.PA511){ let $sectionPA511 = $("<div>", {style:"padding:8px 16px"}); $sectionPA511.html([ '<span id="OOMPA511">', `<img src="${PA511Icon}" alt="511PA" width="18" height="18" id="OOMPA511Img" title="Open in 511PA" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionPA511.html()); $('#OOMPA511Img').click(function(){ let latlon = get4326CenterPoint(); window.open(`http://www.511pa.com/Traffic.aspx?${latlon.lat},${latlon.lon},${(W.map.zoom + 12)}z`); }); } $('#OOMMiss511').remove(); if(settings.Miss511) { let $section = $("<div>", {style:"padding:8px 16px"}); $section.html([ '<span id="OOMMiss511">', `<img src="${Miss511Icon}" alt="Mississippi 511" width="18" height="18" id="OOMMiss511Img" title="Open in Mississippi 511" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html()); $('#OOMMiss511Img').click(function(){ let latlon = get4326CenterPoint(); let lang = GetLanguage(); window.open(`https://www.mdottraffic.com/default.aspx?lat=${latlon.lat}&lon=${latlon.lon}&zoom=${(W.map.zoom + 12)}`, 'Mississippi 511'); }); } $('#OOMLAFC').remove(); if(settings.LAFC){ let $sectionLAFC = $("<div>"); $sectionLAFC.html([ '<span id="OOMLAFC">', `<img src="${LAFCIcon}" alt="LAFC" width="18" height="18" id="OOMLAFCImg" title="Open in Louisiana FC Map" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionLAFC.html()); $('#OOMLAFCImg').click(function(){ let latlon = get4326CenterPoint(); window.open(`http://www.arcgis.com/home/webmap/viewer.html?webmap=a37461260bec43dea7bcbf6b710a662e¢er=${latlon.lon},${latlon.lat}&level=${(W.map.zoom + 12)}`); }); } /*$('#OOMNJ511').remove(); if(settings.NJ511){ let $sectionNJ511 = $("<div>"); $sectionNJ511.html([ '<span id="OOMNJ511">', `<img src="${LAFCIcon}" alt="LAFC" width="18" height="18" id="OOMNJ511Img" title="Open in New Jersey 511 Map" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionNJ511.html()); $('#OOMNJ511Img').click(function(){ let latlon = get4326CenterPoint(); window.open(`http://www.511nj.org/trafficmap.aspx?X=${latlon.lat}&Y=${latlon.lon}&zoom=${(W.map.zoom + 12)}`); }); }*/ $('#OOMNM511').remove(); if(settings.NM511){ let $sectionNM511 = $("<div>"); $sectionNM511.html([ '<span id="OOMNM511">', `<img src="${NM511Icon}" alt="New Mexico 511" width="18" height="18" id="OOMNM511Img" title="Open in New Mexico 511 Map" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionNM511.html()); $('#OOMNM511Img').click(function(){ let latlon = W.map.center; //http://nmroads.com/mapIndex.html? window.open(`http://nmroads.com/mapIndex.html?X=${latlon.lon}&Y=${latlon.lat}&zoom=${(W.map.zoom + 12)}`); }); } $('#OOMWVFlood').remove(); if(settings.WVFlood){ let $sectionWVFlood = $("<div>"); $sectionWVFlood.html([ '<span id="OOMWVFlood">', `<img src="${WVFloodIcon}" alt="WV Flood" width="18" height="18" id="OOMWVFloodImg" title="Open in WV Flood map" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionWVFlood.html()); $('#OOMWVFloodImg').click(function(){ let latlon = W.map.center; //https://www.mapwv.gov/flood/map/?x=-8915274&y=4681300&l=4&v=0 window.open(`https://www.mapwv.gov/flood/map/?x=${latlon.lon}&y=${latlon.lat}&l=${(W.map.zoom+4)}`); }); } $('#OOMGMDM').remove(); if(settings.GMDM){ let $sectionGMDM = $("<div>"); $sectionGMDM.html([ '<span id="OOMGMDM">', `<img src="${GMDMIcon}" alt="Gaia Mexico" width="18" height="18" id="OOMGMDMImg" title="Open in Gaia Digital Mapa de Mexico" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionGMDM.html()); $('#OOMGMDMImg').click(function(){ let latlon = W.map.center.transform(W.map.projection, W.map.displayProjection); window.open(`http://gaia.inegi.org.mx/mdm6/?v=${btoa("lat:"+latlon.lat+",lon:"+latlon.lon+",z:"+(W.map.zoom+8))}`); }); } $('#OOMPennDOT').remove(); if(settings.PennDOT){ let $sectionPennDOT = $("<div>"); $sectionPennDOT.html([ '<span id="OOMPennDOT">', `<img src="${PennDOTIcon}" alt="Pennsylvania OneMap" width="18" height="18" id="OOMPennDOTImg" title="Open in Pennsylvania OneMap" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionPennDOT.html()); $('#OOMPennDOTImg').click(function(){ let latlon = W.map.center.transform(W.map.projection, W.map.displayProjection); window.open(`https://www.dot7.state.pa.us/OneMap?longitude=${latlon.lon}&latitude=${latlon.lat}`); }); } $('#OOMBogota').remove(); if(settings.Bogota){ let $sectionBogota = $("<div>"); $sectionBogota.html([ '<span id="OOMBogota">', `<img src="${BogotaIcon}" alt="Bogota" width="18" height="18" id="OOMBogotaImg" title="Open in Mapas Bogota" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionBogota.html()); $('#OOMBogotaImg').click(function(){ var topleft= (new OL.LonLat(W.map.getExtent().left,W.map.getExtent().top)); var bottomright= (new OL.LonLat(W.map.getExtent().right,W.map.getExtent().bottom)); let source = new Proj4js.Proj('EPSG:900913'); var topleft4686 = new Proj4js.Point(parseFloat(topleft.lon), parseFloat(topleft.lat)); var bottomright4686 = new Proj4js.Point(parseFloat(bottomright.lon), parseFloat(bottomright.lat)); Proj4js.transform(source, Proj4js.WGS84, topleft4686); Proj4js.transform(source, Proj4js.WGS84, bottomright4686); let latlon = W.map.center.transform(W.map.projection, W.map.displayProjection); window.open(`http://mapas.bogota.gov.co/?&e=${topleft4686.x},${bottomright4686.y},${bottomright4686.x},${topleft4686.y},4686&b=261`); }); } $('#OOMZoomEarth').remove(); if(settings.ZoomEarth) { let $section = $("<div>", {style:"padding:8px 16px"}); $section.html([ '<span id="OOMZoomEarth">', `<img src="${ZoomEarthIcon}" alt="Zoom Earth" width="18" height="18" id="OOMZoomEarthImg" title="Open in Zoom Earth" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html()); $('#OOMZoomEarthImg').click(function(){ let latlon = get4326CenterPoint(); let lang = GetLanguage(); window.open(`https://zoom.earth/#${latlon.lat},${latlon.lon},${( W.map.zoom + 12)}z,map`, 'Zoom Earth'); }); } $('#OOMRoadworks').remove(); if(settings.Roadworks) { let $section = $("<div>", {style:"padding:8px 16px"}); $section.html([ '<span id="OOMRoadworks">', `<img src="${RoadworksIcon}" alt="Roadworks" width="18" height="18" id="OOMRoadworksImg" title="Open in Roadworks" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html()); $('#OOMRoadworksImg').click(function(){ let latlon = get4326CenterPoint(); window.open(`https://roadworks.org/?lng=${latlon.lon}&lat=${latlon.lat}&zoom=${( W.map.zoom + 12)}`, 'Roadworks'); }); } $('#OOMWI511').remove(); if(settings.WI511){ let $sectionWI511 = $("<div>", {style:"padding:8px 16px"}); $sectionWI511.html([ '<span id="OOMWI511">', `<img src="${WI511Icon}" alt="511WI" width="18" height="18" id="OOMWI511Img" title="Open in 511WI" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionWI511.html()); $('#OOMWI511Img').click(function(){ let latlon = get4326CenterPoint(); window.open(`https://511wi.gov/?Latitude=${latlon.lat}&Longitude=${latlon.lon}&Zoom=${(W.map.zoom + 12)}&SelectedLayers=WeatherAlerts,Incidents#:Alerts`); }); } $('#OOMOHGO').remove(); if(settings.OHGO){ let $sectionOHGO = $("<div>", {style:"padding:8px 16px"}); $sectionOHGO.html([ '<span id="OOMOHGO">', `<img src="${OHGOIcon}" alt="511WI" width="18" height="18" id="OOMOHGOImg" title="Open in OHGO" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionOHGO.html()); $('#OOMOHGOImg').click(function(){ let latlon = get4326CenterPoint(); window.open(`http://www.ohgo.com/central-ohio?lt=${latlon.lat}&ln=${latlon.lon}&z=${(W.map.zoom + 12)}&ls=incident,construction,camera`); }); } } function loadSettings() { var loadedSettings = $.parseJSON(localStorage.getItem("OOM_Settings")); var defaultSettings = { GMaps: true, Mapillary: true, Terraserver: true, Wikimapia: false, Bing: false, OSM: false, LangSetting: 1, CustLang: "", Yandex: false, Here: false, MiDrive: false, NYFC: false, rosreestr: false, PA511: false, Miss511: false, LAFC: false, NM511: false, WVFlood: false, GMDM: false, PennDOT: false, Bogota: false, ZoomEarth: false, Roadworks: false, WI511: false, OHGO: false //NJ511: false }; settings = loadedSettings ? loadedSettings : defaultSettings; for (var prop in defaultSettings) { if (!settings.hasOwnProperty(prop)) settings[prop] = defaultSettings[prop]; } } function saveSettings() { if (localStorage) { var localsettings = { GMaps: settings.GMaps, Mapillary: settings.Mapillary, Terraserver: settings.Terraserver, Wikimapia: settings.Wikimapia, Bing: settings.Bing, OSM: settings.OSM, LangSetting: settings.LangSetting, CustLang: settings.CustLang, Yandex: settings.Yandex, Here: settings.Here, MiDrive: settings.MiDrive, NYFC: settings.NYFC, rosreestr: settings.rosreestr, PA511: settings.PA511, Miss511: settings.Miss511, LAFC: settings.LAFC, NM511: settings.NM511, WVFlood: settings.WVFlood, GMDM: settings.GMDM, PennDOT: settings.PennDOT, Bogota: settings.Bogota, ZoomEarth: settings.ZoomEarth, Roadworks: settings.Roadworks, WI511: settings.WI511, OHGO: settings.OHGO //NJ511: settings.NJ511 }; localStorage.setItem("OOM_Settings", JSON.stringify(localsettings)); } } function isChecked(checkboxId) { return $('#' + checkboxId).is(':checked'); } function setChecked(checkboxId, checked) { $('#' + checkboxId).prop('checked', checked); } function bootstrapGeneral(initdelegate, tries = 1){ if(document.readyState !== 'complete' ) setTimeout(function() {bootstrapGeneral(initdelegate, tries++);}, 200); else initdelegate(); } let is511PAloaded = false; function bootstrap511PA(tries = 1){ if(iFrameVar.map){ iFrameVar.map.addListener('tilesloaded', function() { //http://www.511pa.com/Traffic.aspx?40.85,-77.6,12z if(!is511PAloaded){ if(location.search.indexOf("?") > -1){ let params = location.search.split("?")[1].slice(0,-1); iFrameVar.recenterMap(params); } is511PAloaded = true; } }); } else{ setTimeout(function(){bootstrap511PA(tries +=1);}, 100); } $(document).ready(function(){ init511PA(); }); } function bootstrapNM511(tries = 1){ if(map && map.extent && map.loaded) initNM511(); else setTimeout(function() {bootstrapNM511(tries++);}, 100); } function bootstrapRoadworks(tries = 1){ if(Elgin && Elgin.map && Elgin.map.tilesloading === false) initRoadworks(); else setTimeout(function(){bootstrapRoadworks(tries++);}, 100); } function bootstrap(tries = 1) { if(location.href.indexOf("google.com/maps") > -1) bootstrapGeneral(initGoogleMaps, 1); else if(location.href.indexOf("wv511.org") > -1) bootstrapGeneral(initWV511, 1); else if(location.href.indexOf("511virginia.org") > -1) bootstrapGeneral(init511virginia, 1); else if(location.href.indexOf("https://mdotjboss.state.mi.us") > -1) bootstrapGeneral(initmiDrive, 1); else if(location.href.indexOf("http://pkk5.rosreestr.ru") > -1) bootstrapRosreestr(1); else if(location.href.indexOf("http://www.511pa.com/Traffic") > -1 || location.href.indexOf("https://www.511pa.com/Traffic") > -1) bootstrap511PA(1);//bootstrapGeneral(init511PA, 1); else if(location.href.indexOf("http://newengland511.org") > -1) bootstrapGeneral(initNE511, 1); else if(location.href.indexOf("https://www.mdottraffic.com") > -1){ if(document.getElementById("map_canvas") != null) initMississipie511(); else if(tries < 1000) setTimeout(function () {bootstrap(tries++);}, 200); } else if(location.href.indexOf("https://gis.transportation.wv.gov/measures") > -1){ bootstrapGeneral(initWVGIS, 1); } else if(location.href.indexOf("http://nmroads.com/mapIndex.html") > -1){ bootstrapNM511(1); } else if(location.href.indexOf("https://www.mapwv.gov/flood/map") > -1){ bootstrapGeneral(initWVFlood, 1); } else if(location.href.indexOf("https://roadworks.org/") > -1){ bootstrapRoadworks(1); } /*else if(location.href.indexOf("http://www.511nj.org/trafficmap") > -1){ bootstrapGeneral(initNJ511, 1); }*/ else{ if (W && W.map && W.model && $ && WazeWrap.Ready) { initInterface(); } else if (tries < 1000) { setTimeout(function () {bootstrap(tries++);}, 200); } } } function RosreestrToWaze(){ let lon, lat, zoom; let curURL = location.href.match(/x=(\d*.\d*)&y=(\d*.\d*)&z=(\d+)/); lon = curURL[1]; lat = curURL[2]; zoom = parseInt(curURL[3]); let source = new Proj4js.Proj('EPSG:900913'); var point = new Proj4js.Point(parseFloat(lon), parseFloat(lat)); Proj4js.transform(source, Proj4js.WGS84, point); return `https://www.waze.com/en-US/editor/?lon=${point.x}&lat=${point.y}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`; } function initRosreestr(){ var observer = new MutationObserver(function(mutations) { mutations.forEach(function(mutation) { if (mutation.type === "attributes" && mutation.target == document.getElementsByClassName("btn btn-default btn-tool-lg js-showList")[0]) insertWMELinkRosreestr(); }); }); observer.observe(document.getElementById("sidebar-region"), { childList: true, subtree: true, attributes:true}); insertWMELinkRosreestr(); } function insertWMELinkRosreestr(){ if(document.getElementById("OOMWazeButton") !== null) document.getElementById("OOMWazeButton").remove(); let $OOMWazeButton = document.createElement("div"); $OOMWazeButton.innerHTML = `<button type="button" class="btn btn-default btn-tool-lg" data-toggle="tooltip" data-placement="right" title="" id="OOMWazeButton" style="background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat: no-repeat; background-position: center;"></button>`; //'<div id="OOMWazeButtonDiv" style="height:30px; width:34px; position: fixed; right:30px; top:75px; cursor: pointer; ></div>'; document.getElementsByClassName('btn-group-vertical js-appList')[0].appendChild($OOMWazeButton); document.getElementById("OOMWazeButton").addEventListener("click", function(){ window.open(RosreestrToWaze()); }); } function bootstrapRosreestr(tries=1){ if (document.getElementsByClassName('btn-group-vertical js-appList').length > 0) { initRosreestr(); } else if (tries < 1000) { setTimeout(function () {bootstrapRosreestr(tries++);}, 200); } } function initGoogleMaps(){ let $OOMWazeButton = document.createElement("div"); $OOMWazeButton.innerHTML = `<div id="OOMWazeButtonDiv" style="height:36px; width:36px; position: fixed; right:30px; top:75px; cursor: pointer; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat: no-repeat;" title="Open in WME"></div>`; let parent = document.getElementById("content-container"); parent.appendChild($OOMWazeButton); document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){ window.open(GMToWaze()); }); document.getElementById('OOMWazeButtonDiv').addEventListener("mouseenter",function(e) { document.addEventListener('keydown', copyPLHotkeyEvent); document.getElementsByClassName('widget-scene-canvas')[0].addEventListener('keydown', copyPLHotkeyEvent); }); document.getElementById('OOMWazeButtonDiv').addEventListener('mouseleave', function() { document.removeEventListener('keydown', copyPLHotkeyEvent); document.getElementsByClassName('widget-scene-canvas')[0].removeEventListener('keydown', copyPLHotkeyEvent); }); } let isMiss511Loaded = false; function initMississipie511(){ map.addListener('tilesloaded', function() { //https://www.mdottraffic.com/default.aspx?lat=32.36435&lon=-88.70366&zoom=15 if(!isMiss511Loaded){ if(location.search.indexOf("?") > -1 && location.search.indexOf("loadAlertid") === -1){ let params = location.search.match(/lat=(-?\d*.\d*)&lon=(-?\d*.\d*)&zoom=(\d+)/); map.setCenter({lat: parseFloat(params[1]), lng: parseFloat(params[2])}); map.setZoom(parseInt(params[3])); } isMiss511Loaded = true; } }); let $OOMWazeButton = document.createElement("div"); $OOMWazeButton.innerHTML = `<div id="OOMWazeButtonDiv" style="height:36px; width:36px; position: fixed; right:40px; top:83px; cursor: pointer; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat: no-repeat;" title="Open in WME"></div>`; //let parent = document.getElementById("content-container"); document.getElementById("map_canvas").appendChild($OOMWazeButton); document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){ let center = map.getCenter(); window.open(`https://www.waze.com/en-US/editor/?lon=${center.lng()}&lat=${center.lat()}&zoom=${(Math.max(0,Math.min(10,(map.getZoom() - 12))))}`); }); } /* function initNJ511(){ $(document).ready(function() { if(location.search.indexOf("?") > -1){ let params = location.search.match(/X=(-?\d*.\d*)&Y=(-?\d*.\d*)&zoom=(\d+)/); $("#EvetnsMap").attr('src', `http://icx1-map21x.lan.511nj.org/mapwidget/mapwidget.aspx?FullScreen=false&fss=0&njlegend=1&search=0&X=${parseFloat(params[1])}Y=${parseFloat(params[2])}&zoom=${parseFloat(params[3])}&maplegend=2&Weather=1&Congestion=1&Construction=1&Incident=1&Detour=1&SpecialEvents=1&AirportParking=0&height=100&width=100&ispercent=1&WinkCamera=2&zoom=14&refershcamera=1&refershevent=1&refershspeed=1`); } }); }*/ function insertWMELinkNM511(){ if(document.getElementById("OOMWazeButton") !== null) document.getElementById("OOMWazeButton").remove(); let $OOMWazeButton = document.createElement("li"); $OOMWazeButton.innerHTML = `<span id="OOMWazeButton" style="background-image: url(${wazerIcon}); background-size: 36px 36px;"></span>`; document.getElementsByClassName('mapSettingsList')[0].appendChild($OOMWazeButton); document.getElementById("OOMWazeButton").addEventListener("click", function(){ let source = new Proj4js.Proj('EPSG:900913'); let center = map.extent.getCenter(); var point = new Proj4js.Point(parseFloat(center.x), parseFloat(center.y)); Proj4js.transform(source, Proj4js.WGS84, point); window.open(`https://www.waze.com/en-US/editor/?lon=${point.x}&lat=${point.y}&zoom=${(Math.max(0,Math.min(10,(map.getZoom() - 12))))}`); }); } function initNM511(){ if(location.search.indexOf("?") > -1){ let params = location.search.match(/X=(-?\d*.\d*)&Y=(-?\d*.\d*)&zoom=(\d+)/); setTimeout(function(){ try{ map.centerAt({x:parseFloat(params[1]), y:parseFloat(params[2])}); setTimeout(function(){map.setLevel(parseInt(params[3]));}, 500); } catch(err) { console.log(err); } }, 1000); } var observer = new MutationObserver(function(mutations) { mutations.forEach(function(mutation) { if (mutation.type === "attributes" && mutation.target == document.getElementsByClassName("mapSettingsList")[0]) insertWMELinkNM511(); }); }); observer.observe(document.getElementsByClassName('mapSettings')[0], { childList: true, subtree: true, attributes:true}); insertWMELinkNM511(); } function insertWMELinkRoadworks(){ if(document.getElementById("OOMWazeButton") !== null) document.getElementById("OOMWazeButton").remove(); let $OOMWazeButton = document.createElement("li"); $OOMWazeButton.style.minHeight = "60px"; $OOMWazeButton.id = "OOMWazeButton"; $OOMWazeButton.innerHTML = `<a href="#"><span style="background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat:no-repeat; background-position:center;"></span></a>`; document.getElementById('nav-main').getElementsByTagName('ul')[0].appendChild($OOMWazeButton); document.getElementById("OOMWazeButton").addEventListener("click", function(){ let source = new Proj4js.Proj('EPSG:900913'); let center = Elgin.map.getCenter(); window.open(`https://www.waze.com/en-US/editor/?lon=${center.lng()}&lat=${center.lat()}&zoom=${(Math.max(0,Math.min(10,(Elgin.map.zoom - 12))))}`); }); } function initRoadworks(){ if(location.search.indexOf("?") > -1){ let params = location.search.match(/lng=(-?\d*.\d*)&lat=(-?\d*.\d*)&zoom=(\d+)/); setTimeout(function(){ try{ Elgin.map.setCenter({lng:parseFloat(params[1]), lat:parseFloat(params[2])}); setTimeout(function(){Elgin.map.setZoom(parseInt(params[3]));}, 500); } catch(err) { console.log(err); } }, 1000); } insertWMELinkRoadworks(); } var copyToClipboard = function(str) { var temp = document.createElement("input"); document.body.append(temp); temp.value = str; temp.select(); document.execCommand('copy'); document.body.removeChild(temp); }; var copyPLHotkeyEvent = function(e) { if ((e.metaKey || e.ctrlKey) && (e.which === 67)) copyToClipboard(GMToWaze()); }; function GMToWaze(){ let lon, lat, zoom; let curURL = location.href.split('@').pop().split(','); lon = curURL[1]; lat = curURL[0]; zoom = parseInt(curURL[2]); return `https://www.waze.com/en-US/editor/?lon=${lon}&lat=${lat}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`; } function init511PA(){ $('#OOMWazeButtonDiv').remove(); let $wazer = $("<div>", {style:"padding:8px 16px"}); $wazer.html([ '<li>', `<div id="OOMWazeButtonDiv" style="height:36px; width:36px; cursor: pointer; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat: no-repeat;" title="Open in WME"></div>`, '</li>' ].join(' ')); $('#optMain').append($wazer.html()); $('#OOMWazeButtonDiv').click(function(){ let lon, lat, zoom; let latlon = iFrameVar.getCenterOfMap().split(','); lon = latlon[1]; lat = latlon[0]; zoom = iFrameVar.zoom; window.open(`https://www.waze.com/en-US/editor/?lon=${lon}&lat=${lat}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`); }); } function init511virginia(){ $('#incident_table_paginate > a').click(insertWazeLinks511Virginia); insertWazeLinks511Virginia(); } function insertWazeLinks511Virginia(){ $('#incident_table > tbody > tr > td > a').parent().append(function(){ if($(this).find("a").length === 1){ let latlons = $(this).find("a")[0].href.match(/lon1=(.*)&lat1=(.*)&lon2=(.*)&lat2=(.*)/); let lonCenter = Math.min(latlons[1],latlons[3]) + (Math.abs(latlons[1] - latlons[3])/2); let latCenter = Math.min(latlons[2], latlons[4]) + (Math.abs(latlons[2] - latlons[4])/2); return ` <a href='https://www.waze.com/editor/?env=usa&lon=${lonCenter}&lat=${latCenter}&zoom=4' target='_blank'>Open in WME</a>`; } return ""; }); } function initNE511(){ var observer = new MutationObserver(function(mutations) { mutations.forEach(function(mutation) { if ($(mutation.target)[0] == $('.ol-overlay-container.ol-selectable')[0] && $(mutation.target).css('display') == "block") { insertWMELinkNE511(); } }); }); observer.observe($('.ol-overlay-container.ol-selectable').parent()[0], { childList: true, subtree: true, attributes:true}); } function insertWMELinkNE511(){ //http://newengland511.org/ let selectedIncident = $('.popover-content > [data-ng-bind="item.Description"]')[0]; let incidentDesc = selectedIncident.innerHTML; let incidents = Leidos.Traffic.Data.events.find(function(e){ return e.Description == incidentDesc;}); $(selectedIncident).append(`<br><a href='https://www.waze.com/en-US/editor/?env=usa&lon=${incidents.StartLongitude}&lat=${incidents.StartLatitude}&zoom=6' target="_blank">Open in WME</a>`); } function initmiDrive(){ var observer = new MutationObserver(function(mutations) { mutations.forEach(function(mutation) { if ($(mutation.target).hasClass('esri-popup__content')) insertWMELinkMiDrive(mutation.target); }); }); observer.observe($('.esri-component.esri-popup')[0], { childList: true, subtree: true }); $('#layerContainer').append(`<button tabindex="0" class="legendIcon layerIcon clickableLegendIcon ui-btn ui-btn-inline" title="Open in WME" id="oomOpenWME"><img tabindex="-1" class="focusRem" src="${wazerIcon}" alt="icons"></button>`); $('#legendIconContainer').css('width', (325)); $('#oomOpenWME').click(function(){ window.open(`https://www.waze.com/en-US/editor/?lon=${mapView.center.longitude}&lat=${mapView.center.latitude}&zoom=${Math.max(mapView.zoom-12,0)}`); }); } function insertWMELinkMiDrive(changedDiv){ for(let i=0; i<incidents.graphics.items.length; i++){ let location = incidents.graphics.items[i].attributes.Message.match(/<strong>Location: <\/strong>(.*?)<\/div>/)[1]; if($(changedDiv).html().indexOf(location) > -1 && $(changedDiv).html().indexOf("Open in WME") === -1){ $('#newItemAdded').append(`<div><a href='https://www.waze.com/en-US/editor/?env=usa&lon=${incidents.graphics.items[i].attributes.XCoord}&lat=${incidents.graphics.items[i].attributes.YCoord}&zoom=6' target="_blank">Open in WME</a></div>`); break; } } } function initWV511(){ if(document.getElementById("OOMWazeButtonDiv") !== null) document.getElementById("OOMWazeButtonDiv").remove(); let $OOMWazeButton = document.createElement("div"); $OOMWazeButton.setAttribute("id", "OOMWazeButtonDiv"); $OOMWazeButton.setAttribute("style", `position:absolute; right:15px; top:190px; height:36px; width:36px; cursor:pointer; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat:no-repeat;`); $OOMWazeButton.setAttribute("title", "Open in WME"); document.body.appendChild($OOMWazeButton); document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){ let lon1, lon2, lonCenter, lat1, lat2, latCenter; let latlon = location.href.split(":"); lon1 = latlon[2]; lat1 = latlon[3]; lon2 = latlon[4]; lat2 = latlon[5]; lonCenter = Math.min(lon1,lon2) + (Math.abs(lon1 - lon2)/2); latCenter = Math.min(lat1, lat2) + (Math.abs(lat1 - lat2)/2); window.open(`https://www.waze.com/en-US/editor/?lon=${lonCenter}&lat=${latCenter}&zoom=5`); }); } function initWVGIS(){ if(document.getElementById("OOMWazeButtonDiv") !== null) document.getElementById("OOMWazeButtonDiv").remove(); $('#RoadLayerList').prepend(`<li><div id="OOMWazeButtonDiv" aria-hidden="true" style="cursor:pointer; margin-top:8px; height:36px; width:36px; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat:no-repeat;"></div></li>`); $('#OOMWazeButtonDiv').click(function(){ let source = new Proj4js.Proj('EPSG:900913'); var point = new Proj4js.Point(parseFloat(view.center.x), parseFloat(view.center.y)); Proj4js.transform(source, Proj4js.WGS84, point); window.open(`https://www.waze.com/en-US/editor/?lon=${point.x}&lat=${point.y}&zoom=${view.zoom-5}`); }); } function initWVFlood(){ if($("#OOMWazeButtonDiv") !== null) $("#OOMWazeButtonDiv").remove(); $('#tools').prepend(`<button type="button" id="btnOpenWaze" class="btn btn-default btn-lg bootstrap_btn2" style="cursor:pointer; margin-left: 0px; min-width:32px; height=32px; background-image: url(${wazerIcon}); background-size: 32px 32px; background-repeat:no-repeat; background-size:100%;" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="click to open in Waze Map Editor"><span ></span></button>`); $('#btnOpenWaze').click(function(){ let source = new Proj4js.Proj('EPSG:900913'); var point = new Proj4js.Point(parseFloat(Flood.map.extent.getCenter().x), parseFloat(Flood.map.extent.getCenter().y)); Proj4js.transform(source, Proj4js.WGS84, point); let zoom = Flood.map.getLevel() - 4; if(zoom < 0) zoom = 0; window.open(`https://www.waze.com/en-US/editor/?lon=${point.x}&lat=${point.y}&zoom=${zoom}`); }); } function injectOLMyMapKML(){ if(!OL.Format.MyMapKML){ OL.Format.MyMapKML = OL.Class(OL.Format.XML,{namespaces:{kml:"http://www.opengis.net/kml/2.2",gx:"http://www.google.com/kml/ext/2.2"},kmlns:"http://earth.google.com/kml/2.0",placemarksDesc:"No description available",foldersName:"OpenLayers export",foldersDesc:"Exported on "+new Date(),extractAttributes:!0,kvpAttributes:!1,extractStyles:!1,extractTracks:!1,trackAttributes:null,internalns:null,features:null,styles:null,styleBaseUrl:"",fetched:null,maxDepth:0,iconColorMap:{"#880e4f":"","#a52714":"","#e65100":"","#f9a825":"","#ffd600":"","#817717":"","#558b2f":"","#097138":"","#006064":"","#01579b":"","#1a237e":"","#673ab7":"","#4e342e":"","#c2185b":"","#ff5252":"","#f57c00":"","#fbc02d":"","#ffea00":"","#afb42b":"","#7cb342":"","#0f9d58":"","#0097a7":"","#0288d1":"","#3949ab":"","#9c27b0":"","#795548":"","#bdbdbd":"","#757575":"","#424242":"","#000000":""},initialize:function(options){this.regExes={trimSpace:(/^\s*|\s*$/g),removeSpace:(/\s*/g),splitSpace:(/\s+/),trimComma:(/\s*,\s*/g),kmlColor:(/(\w{2})(\w{2})(\w{2})(\w{2})/),kmlIconPalette:(/root:\/\/icons\/palette-(\d+)(\.\w+)/),straightBracket:(/\$\[(.*?)\]/g)};this.externalProjection=new OpenLayers.Projection("EPSG:4326");OpenLayers.Format.XML.prototype.initialize.apply(this,[options])},read:function(data){this.features=[];this.styles={};this.fetched={};var options={depth:0,styleBaseUrl:this.styleBaseUrl};return this.parseData(data,options)},parseData:function(data,options){if(typeof data=="string") data=OpenLayers.Format.XML.prototype.read.apply(this,[data]);var types=["Link","NetworkLink","Style","StyleMap","Placemark"];for(var i=0,len=types.length;i<len;++i){var type=types[i];var nodes=this.getElementsByTagNameNS(data,"*",type);if(nodes.length==0) continue;switch(type.toLowerCase()){case "link":case "networklink":this.parseLinks(nodes,options);break;case "style":if(this.extractStyles) this.parseStyles(nodes,options);break;case "stylemap":if(this.extractStyles) this.parseStyleMaps(nodes,options);break;case "placemark":this.parseFeatures(nodes,options);break}} return this.features},parseLinks:function(nodes,options){if(options.depth>=this.maxDepth) return!1;var newOptions=OpenLayers.Util.extend({},options);newOptions.depth++;for(var i=0,len=nodes.length;i<len;i++){var href=this.parseProperty(nodes[i],"*","href");if(href&&!this.fetched[href]){this.fetched[href]=!0;var data=this.fetchLink(href);if(data) this.parseData(data,newOptions)}}},fetchLink:function(href){var request=OpenLayers.Request.GET({url:href,async:!1});if(request) return request.responseText},parseStyles:function(nodes,options){for(var i=0,len=nodes.length;i<len;i++){var style=this.parseStyle(nodes[i]);if(style){var styleName=(options.styleBaseUrl||"")+"#"+style.id;this.styles[styleName]=style}}},parseKmlColor:function(kmlColor){var color=null;if(kmlColor){var matches=kmlColor.match(this.regExes.kmlColor);if(matches){color={color:'#'+matches[4]+matches[3]+matches[2],opacity:parseInt(matches[1],16)/255,r:parseInt(matches[4],16),g:parseInt(matches[3],16),b:parseInt(matches[2],16)}}} return color},parseStyle:function(node){var style={};var types=["LineStyle","PolyStyle","IconStyle","BalloonStyle","LabelStyle"];var type,styleTypeNode,nodeList,geometry,parser;for(var i=0,len=types.length;i<len;++i){type=types[i];styleTypeNode=this.getElementsByTagNameNS(node,"*",type)[0];if(!styleTypeNode) continue;var kmlColor=this.parseProperty(styleTypeNode,"*","color");var color=this.parseKmlColor(kmlColor);switch(type.toLowerCase()){case "linestyle":if(color){style.strokeColor=color.color;style.strokeOpacity=color.opacity} var width=this.parseProperty(styleTypeNode,"*","width");if(width) style.strokeWidth=width;break;case "polystyle":if(color){style.fillOpacity=color.opacity;style.fillColor=color.color} var fill=this.parseProperty(styleTypeNode,"*","fill");if(fill=="0"){style.fillColor="none"} var outline=this.parseProperty(styleTypeNode,"*","outline");if(outline=="0"){style.strokeWidth="0"} break;case "iconstyle":var scale=parseFloat(this.parseProperty(styleTypeNode,"*","scale")||1);var width=32*scale;var height=32*scale;var iconNode=this.getElementsByTagNameNS(styleTypeNode,"*","Icon")[0];if(iconNode){var href=this.parseProperty(iconNode,"*","href");if(href){var w=this.parseProperty(iconNode,"*","w");var h=this.parseProperty(iconNode,"*","h");var google="http://maps.google.com/mapfiles/kml";if(OpenLayers.String.startsWith(href,google)&&!w&&!h){w=64;h=64;scale=scale/2} w=w||h;h=h||w;if(w) width=parseInt(w)*scale;if(h) height=parseInt(h)*scale;var matches=href.match(this.regExes.kmlIconPalette);if(matches){var palette=matches[1];var file_extension=matches[2];var x=this.parseProperty(iconNode,"*","x");var y=this.parseProperty(iconNode,"*","y");var posX=x?x/32:0;var posY=y?(7-y/32):7;var pos=posY*8+posX;href="http://maps.google.com/mapfiles/kml/pal"+palette+"/icon"+pos+file_extension} style.graphicOpacity=1;style.externalGraphic=this.iconColorMap[color.color];style.graphicYOffset=-32}} style.graphicWidth=width;style.graphicHeight=height;break;case "balloonstyle":var balloonStyle=OpenLayers.Util.getXmlNodeValue(styleTypeNode);if(balloonStyle) style.balloonStyle=balloonStyle.replace(this.regExes.straightBracket,"${$1}");break;case "labelstyle":var kmlColor=this.parseProperty(styleTypeNode,"*","color");var color=this.parseKmlColor(kmlColor);if(color){style.fontColor=color.color;style.fontOpacity=color.opacity} break;default:}} if(!style.strokeColor&&style.fillColor) style.strokeColor=style.fillColor;var id=node.getAttribute("id");if(id&&style) style.id=id;return style},parseStyleMaps:function(nodes,options){for(var i=0,len=nodes.length;i<len;i++){var node=nodes[i];var pairs=this.getElementsByTagNameNS(node,"*","Pair");var id=node.getAttribute("id");for(var j=0,jlen=pairs.length;j<jlen;j++){var pair=pairs[j];var key=this.parseProperty(pair,"*","key");var styleUrl=this.parseProperty(pair,"*","styleUrl");if(styleUrl&&key=="normal") this.styles[(options.styleBaseUrl||"")+"#"+id]=this.styles[(options.styleBaseUrl||"")+styleUrl]}}},parseFeatures:function(nodes,options){var features=[];for(var i=0,len=nodes.length;i<len;i++){var featureNode=nodes[i];var feature=this.parseFeature.apply(this,[featureNode]);if(feature){if(this.extractStyles&&feature.attributes&&feature.attributes.styleUrl) feature.style=this.getStyle(feature.attributes.styleUrl,options);if(this.extractStyles){var inlineStyleNode=this.getElementsByTagNameNS(featureNode,"*","Style")[0];if(inlineStyleNode){var inlineStyle=this.parseStyle(inlineStyleNode);if(inlineStyle) feature.style=OpenLayers.Util.extend(feature.style,inlineStyle)}} if(this.extractTracks){var tracks=this.getElementsByTagNameNS(featureNode,this.namespaces.gx,"Track");if(tracks&&tracks.length>0){var track=tracks[0];var container={features:[],feature:feature};this.readNode(track,container);if(container.features.length>0) features.push.apply(features,container.features)}}else{features.push(feature)}}else{throw "Bad Placemark: "+i}} this.features=this.features.concat(features)},readers:{"kml":{"when":function(node,container){container.whens.push(OpenLayers.Date.parse(this.getChildValue(node)))},"_trackPointAttribute":function(node,container){var name=node.nodeName.split(":").pop();container.attributes[name].push(this.getChildValue(node))}},"gx":{"Track":function(node,container){var obj={whens:[],points:[],angles:[]};if(this.trackAttributes){var name;obj.attributes={};for(var i=0,ii=this.trackAttributes.length;i<ii;++i){name=this.trackAttributes[i];obj.attributes[name]=[];if(!(name in this.readers.kml)) this.readers.kml[name]=this.readers.kml._trackPointAttribute}} this.readChildNodes(node,obj);if(obj.whens.length!==obj.points.length){throw new Error("gx:Track with unequal number of when ("+obj.whens.length+") and gx:coord ("+obj.points.length+") elements.")} var hasAngles=obj.angles.length>0;if(hasAngles&&obj.whens.length!==obj.angles.length){throw new Error("gx:Track with unequal number of when ("+obj.whens.length+") and gx:angles ("+obj.angles.length+") elements.")} var feature,point,angles;for(var i=0,ii=obj.whens.length;i<ii;++i){feature=container.feature.clone();feature.fid=container.feature.fid||container.feature.id;point=obj.points[i];feature.geometry=point;if("z" in point){feature.attributes.altitude=point.z} if(this.internalProjection&&this.externalProjection) feature.geometry.transform(this.externalProjection,this.internalProjection);if(this.trackAttributes){for(var j=0,jj=this.trackAttributes.length;j<jj;++j){var name=this.trackAttributes[j];feature.attributes[name]=obj.attributes[name][i]}} feature.attributes.when=obj.whens[i];feature.attributes.trackId=container.feature.id;if(hasAngles){angles=obj.angles[i];feature.attributes.heading=parseFloat(angles[0]);feature.attributes.tilt=parseFloat(angles[1]);feature.attributes.roll=parseFloat(angles[2])} container.features.push(feature)}},"coord":function(node,container){var str=this.getChildValue(node);var coords=str.replace(this.regExes.trimSpace,"").split(/\s+/);var point=new OpenLayers.Geometry.Point(coords[0],coords[1]);if(coords.length>2){point.z=parseFloat(coords[2])} container.points.push(point)},"angles":function(node,container){var str=this.getChildValue(node);var parts=str.replace(this.regExes.trimSpace,"").split(/\s+/);container.angles.push(parts)}}},parseFeature:function(node){var order=["MultiGeometry","Polygon","LineString","Point"];var type,nodeList,geometry,parser;for(var i=0,len=order.length;i<len;++i){type=order[i];this.internalns=node.namespaceURI?node.namespaceURI:this.kmlns;nodeList=this.getElementsByTagNameNS(node,this.internalns,type);if(nodeList.length>0){var parser=this.parseGeometry[type.toLowerCase()];if(parser){geometry=parser.apply(this,[nodeList[0]]);if(this.internalProjection&&this.externalProjection) geometry.transform(this.externalProjection,this.internalProjection)}else throw new TypeError("Unsupported geometry type: "+type);break}} var attributes;if(this.extractAttributes) attributes=this.parseAttributes(node);var feature=new OpenLayers.Feature.Vector(geometry,attributes);var fid=node.getAttribute("id")||node.getAttribute("name");if(fid!=null) feature.fid=fid;return feature},getStyle:function(styleUrl,options){var styleBaseUrl=OpenLayers.Util.removeTail(styleUrl);var newOptions=OpenLayers.Util.extend({},options);newOptions.depth++;newOptions.styleBaseUrl=styleBaseUrl;if(!this.styles[styleUrl]&&!OpenLayers.String.startsWith(styleUrl,"#")&&newOptions.depth<=this.maxDepth&&!this.fetched[styleBaseUrl]){var data=this.fetchLink(styleBaseUrl);if(data) this.parseData(data,newOptions)} var style=OpenLayers.Util.extend({},this.styles[styleUrl]);return style},parseGeometry:{point:function(node){var nodeList=this.getElementsByTagNameNS(node,this.internalns,"coordinates");var coords=[];if(nodeList.length>0){var coordString=nodeList[0].firstChild.nodeValue;coordString=coordString.replace(this.regExes.removeSpace,"");coords=coordString.split(",")} var point=null;if(coords.length>1){if(coords.length==2) coords[2]=null;point=new OpenLayers.Geometry.Point(coords[0],coords[1],coords[2])}else throw "Bad coordinate string: "+coordString;return point},linestring:function(node,ring){var nodeList=this.getElementsByTagNameNS(node,this.internalns,"coordinates");var line=null;if(nodeList.length>0){var coordString=this.getChildValue(nodeList[0]);coordString=coordString.replace(this.regExes.trimSpace,"");coordString=coordString.replace(this.regExes.trimComma,",");var pointList=coordString.split(this.regExes.splitSpace);var numPoints=pointList.length;var points=new Array(numPoints);var coords,numCoords;for(var i=0;i<numPoints;++i){coords=pointList[i].split(",");numCoords=coords.length;if(numCoords>1){if(coords.length==2) coords[2]=null;points[i]=new OpenLayers.Geometry.Point(coords[0],coords[1],coords[2])}else throw "Bad LineString point coordinates: "+pointList[i]} if(numPoints){if(ring) line=new OpenLayers.Geometry.LinearRing(points);else line=new OpenLayers.Geometry.LineString(points)}else throw "Bad LineString coordinates: "+coordString} return line},polygon:function(node){var nodeList=this.getElementsByTagNameNS(node,this.internalns,"LinearRing");var numRings=nodeList.length;var components=new Array(numRings);if(numRings>0){var ring;for(var i=0,len=nodeList.length;i<len;++i){ring=this.parseGeometry.linestring.apply(this,[nodeList[i],!0]);if(ring) components[i]=ring;else throw "Bad LinearRing geometry: "+i}} return new OpenLayers.Geometry.Polygon(components)},multigeometry:function(node){var child,parser;var parts=[];var children=node.childNodes;for(var i=0,len=children.length;i<len;++i){child=children[i];if(child.nodeType==1){var type=(child.prefix)?child.nodeName.split(":")[1]:child.nodeName;var parser=this.parseGeometry[type.toLowerCase()];if(parser) parts.push(parser.apply(this,[child]))}} return new OpenLayers.Geometry.Collection(parts)}},parseAttributes:function(node){var attributes={};var edNodes=node.getElementsByTagName("ExtendedData");if(edNodes.length) attributes=this.parseExtendedData(edNodes[0]);var child,grandchildren,grandchild;var children=node.childNodes;for(var i=0,len=children.length;i<len;++i){child=children[i];if(child.nodeType==1){grandchildren=child.childNodes;if(grandchildren.length>=1&&grandchildren.length<=3){var grandchild;switch(grandchildren.length){case 1:grandchild=grandchildren[0];break;case 2:var c1=grandchildren[0];var c2=grandchildren[1];grandchild=(c1.nodeType==3||c1.nodeType==4)?c1:c2;break;case 3:default:grandchild=grandchildren[1];break} if(grandchild.nodeType==3||grandchild.nodeType==4){var name=(child.prefix)?child.nodeName.split(":")[1]:child.nodeName;var value=OpenLayers.Util.getXmlNodeValue(grandchild);if(value){value=value.replace(this.regExes.trimSpace,"");attributes[name]=value}}}}} return attributes},parseExtendedData:function(node){var attributes={};var i,len,data,key;var dataNodes=node.getElementsByTagName("Data");for(i=0,len=dataNodes.length;i<len;i++){data=dataNodes[i];key=data.getAttribute("name");var ed={};var valueNode=data.getElementsByTagName("value");if(valueNode.length) ed.value=this.getChildValue(valueNode[0]);if(this.kvpAttributes) attributes[key]=ed.value;else{var nameNode=data.getElementsByTagName("displayName");if(nameNode.length) ed.displayName=this.getChildValue(nameNode[0]);attributes[key]=ed}} var simpleDataNodes=node.getElementsByTagName("SimpleData");for(i=0,len=simpleDataNodes.length;i<len;i++){var ed={};data=simpleDataNodes[i];key=data.getAttribute("name");ed.value=this.getChildValue(data);if(this.kvpAttributes) attributes[key]=ed.value;else{ed.displayName=key;attributes[key]=ed}} return attributes},parseProperty:function(xmlNode,namespace,tagName){var value;var nodeList=this.getElementsByTagNameNS(xmlNode,namespace,tagName);try{value=OpenLayers.Util.getXmlNodeValue(nodeList[0])}catch(e){value=null} return value},write:function(features){if(!(OpenLayers.Util.isArray(features))) features=[features];var kml=this.createElementNS(this.kmlns,"kml");var folder=this.createFolderXML();for(var i=0,len=features.length;i<len;++i){folder.appendChild(this.createPlacemarkXML(features[i]))} kml.appendChild(folder);return OpenLayers.Format.XML.prototype.write.apply(this,[kml])},createFolderXML:function(){var folder=this.createElementNS(this.kmlns,"Folder");if(this.foldersName){var folderName=this.createElementNS(this.kmlns,"name");var folderNameText=this.createTextNode(this.foldersName);folderName.appendChild(folderNameText);folder.appendChild(folderName)} if(this.foldersDesc){var folderDesc=this.createElementNS(this.kmlns,"description");var folderDescText=this.createTextNode(this.foldersDesc);folderDesc.appendChild(folderDescText);folder.appendChild(folderDesc)} return folder},createPlacemarkXML:function(feature){var placemarkName=this.createElementNS(this.kmlns,"name");var label=(feature.style&&feature.style.label)?feature.style.label:feature.id;var name=feature.attributes.name||label;placemarkName.appendChild(this.createTextNode(name));var placemarkDesc=this.createElementNS(this.kmlns,"description");var desc=feature.attributes.description||this.placemarksDesc;placemarkDesc.appendChild(this.createTextNode(desc));var placemarkNode=this.createElementNS(this.kmlns,"Placemark");if(feature.fid!=null) placemarkNode.setAttribute("id",feature.fid);placemarkNode.appendChild(placemarkName);placemarkNode.appendChild(placemarkDesc);var geometryNode=this.buildGeometryNode(feature.geometry);placemarkNode.appendChild(geometryNode);if(feature.attributes){var edNode=this.buildExtendedData(feature.attributes);if(edNode) placemarkNode.appendChild(edNode)} return placemarkNode},buildGeometryNode:function(geometry){var className=geometry.CLASS_NAME;var type=className.substring(className.lastIndexOf(".")+1);var builder=this.buildGeometry[type.toLowerCase()];var node=null;if(builder) node=builder.apply(this,[geometry]);return node},buildGeometry:{point:function(geometry){var kml=this.createElementNS(this.kmlns,"Point");kml.appendChild(this.buildCoordinatesNode(geometry));return kml},multipoint:function(geometry){return this.buildGeometry.collection.apply(this,[geometry])},linestring:function(geometry){var kml=this.createElementNS(this.kmlns,"LineString");kml.appendChild(this.buildCoordinatesNode(geometry));return kml},multilinestring:function(geometry){return this.buildGeometry.collection.apply(this,[geometry])},linearring:function(geometry){var kml=this.createElementNS(this.kmlns,"LinearRing");kml.appendChild(this.buildCoordinatesNode(geometry));return kml},polygon:function(geometry){var kml=this.createElementNS(this.kmlns,"Polygon");var rings=geometry.components;var ringMember,ringGeom,type;for(var i=0,len=rings.length;i<len;++i){type=(i==0)?"outerBoundaryIs":"innerBoundaryIs";ringMember=this.createElementNS(this.kmlns,type);ringGeom=this.buildGeometry.linearring.apply(this,[rings[i]]);ringMember.appendChild(ringGeom);kml.appendChild(ringMember)} return kml},multipolygon:function(geometry){return this.buildGeometry.collection.apply(this,[geometry])},collection:function(geometry){var kml=this.createElementNS(this.kmlns,"MultiGeometry");var child;for(var i=0,len=geometry.components.length;i<len;++i){child=this.buildGeometryNode.apply(this,[geometry.components[i]]);if(child) kml.appendChild(child)} return kml}},buildCoordinatesNode:function(geometry){var coordinatesNode=this.createElementNS(this.kmlns,"coordinates");var path;var points=geometry.components;if(points){var point;var numPoints=points.length;var parts=new Array(numPoints);for(var i=0;i<numPoints;++i){point=points[i];parts[i]=this.buildCoordinates(point)} path=parts.join(" ")}else{path=this.buildCoordinates(geometry)} var txtNode=this.createTextNode(path);coordinatesNode.appendChild(txtNode);return coordinatesNode},buildCoordinates:function(point){if(this.internalProjection&&this.externalProjection){point=point.clone();point.transform(this.internalProjection,this.externalProjection)} return point.x+","+point.y},buildExtendedData:function(attributes){var extendedData=this.createElementNS(this.kmlns,"ExtendedData");for(var attributeName in attributes){if(attributes[attributeName]&&attributeName!="name"&&attributeName!="description"&&attributeName!="styleUrl"){var data=this.createElementNS(this.kmlns,"Data");data.setAttribute("name",attributeName);var value=this.createElementNS(this.kmlns,"value");if(typeof attributes[attributeName]=="object"){if(attributes[attributeName].value){value.appendChild(this.createTextNode(attributes[attributeName].value))} if(attributes[attributeName].displayName){var displayName=this.createElementNS(this.kmlns,"displayName");displayName.appendChild(this.getXMLDoc().createCDATASection(attributes[attributeName].displayName));data.appendChild(displayName)}}else value.appendChild(this.createTextNode(attributes[attributeName]));data.appendChild(value);extendedData.appendChild(data)}} if(this.isSimpleContent(extendedData)) return null;else return extendedData},changeImageColor:function(img,r,g,b){function rgbToHsl(r,g,b){r/=255;g/=255;b/=255;let max=Math.max(r,g,b),min=Math.min(r,g,b);let h,s,l=(max+min)/2;if(max==min) h=s=0;else{let d=max-min;s=l>0.5?d/(2-max-min):d/(max+min);switch(max){case r:h=(g-b)/d+(g<b?6:0);break;case g:h=(b-r)/d+2;break;case b:h=(r-g)/d+4;break} h/=6} return({h:h,s:s,l:l,})};let canvas=document.createElement('canvas');let ctx=canvas.getContext("2d");ctx.drawImage(img,0,0);let imgData=ctx.getImageData(0,0,32,32);let data=imgData.data;for(var i=0;i<data.length;i+=4){let red=data[i+0];let green=data[i+1];let blue=data[i+2];let alpha=data[i+3];if(alpha<10) continue;let hsl=rgbToHsl(red,green,blue);let hue=hsl.h*360;if(hue<20){data[i+0]=r;data[i+1]=g;data[i+2]=b}} let mycanvas=document.createElement('canvas');$(mycanvas).attr('width',32);$(mycanvas).attr('height',32);let newctx=mycanvas.getContext('2d');newctx.putImageData(imgData,0,0);return mycanvas.toDataURL()},CLASS_NAME:"OpenLayers.Format.KML"}) } } bootstrap(); })();