BR.Map = { initMap: function() { var map, layersControl; BR.keys = BR.keys || {}; var maxZoom = 19; // Layer attribution here only as short link to original site, // to keep current position use placeholders: {zoom}/{lat}/{lon} // Copyright attribution in index.html #credits var osm = L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', { maxZoom: maxZoom, attribution: 'OpenStreetMap' }); var osmde = L.tileLayer('https://{s}.tile.openstreetmap.de/tiles/osmde/{z}/{x}/{y}.png', { maxNativeZoom: 19, maxZoom: maxZoom, attribution: 'OpenStreetMap.de' }); var topo = L.tileLayer('https://{s}.tile.opentopomap.org/{z}/{x}/{y}.png', { maxNativeZoom: 17, maxZoom: maxZoom, attribution: 'OpenTopoMap' }); var thunderforestAuth = BR.keys.thunderforest ? '?apikey=' + BR.keys.thunderforest : ''; var cycle = L.tileLayer('https://{s}.tile.thunderforest.com/cycle/{z}/{x}/{y}.png' + thunderforestAuth, { maxNativeZoom: 18, maxZoom: maxZoom, attribution: 'OpenCycleMap' }); var outdoors = L.tileLayer('https://{s}.tile.thunderforest.com/outdoors/{z}/{x}/{y}.png' + thunderforestAuth, { maxNativeZoom: 18, maxZoom: maxZoom, attribution: 'Outdoors' }); var esri = L.tileLayer('https://{s}.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}', { maxNativeZoom: 19, maxZoom: maxZoom, subdomains: ['server', 'services'], attribution: 'Esri World Imagery' }); var cycling = L.tileLayer('https://tile.waymarkedtrails.org/cycling/{z}/{x}/{y}.png', { maxNativeZoom: 18, opacity: 0.7, maxZoom: maxZoom, attribution: 'Cycling' }); var hiking = L.tileLayer('https://tile.waymarkedtrails.org/hiking/{z}/{x}/{y}.png', { maxNativeZoom: 18, opacity: 0.7, maxZoom: maxZoom, attribution: 'Hiking' }); map = new L.Map('map', { worldCopyJump: true }); if (!map.restoreView()) { map.setView([50.99, 9.86], 6); } // two attribution lines by adding two controls, prevents ugly wrapping on // small screens, better separates static from layer-specific attribution map.attributionControl.setPrefix( '© OpenStreetMap' + ($(map.getContainer()).outerWidth() >= 400 ? ' contributers' : '') + ' · Copyright' + ' · Privacy'); new L.Control.PermalinkAttribution().addTo(map); map.attributionControl.setPrefix(false); var baseLayers = { 'OpenStreetMap': osm, 'OpenStreetMap.de': osmde, 'OpenTopoMap': topo, 'OpenCycleMap (Thunderf.)': cycle, 'Outdoors (Thunderforest)': outdoors, 'Esri World Imagery': esri }; var overlays = { 'Cycling (Waymarked Trails)': cycling, 'Hiking (Waymarked Trails)': hiking }; if (BR.keys.bing) { baseLayers['Bing Aerial'] = new BR.BingLayer(BR.keys.bing); } if (BR.keys.digitalGlobe) { var recent = new L.tileLayer('https://{s}.tiles.mapbox.com/v4/digitalglobe.nal0g75k/{z}/{x}/{y}.png?access_token=' + BR.keys.digitalGlobe, { minZoom: 1, maxZoom: 19, attribution: '© DigitalGlobe (' + 'Terms of Use)' }); baseLayers['DigitalGlobe Recent Imagery'] = recent; } if (BR.conf.clearBaseLayers) { baseLayers = {}; } for (i in BR.conf.baseLayers) { if (BR.conf.baseLayers.hasOwnProperty(i)) { baseLayers[i] = L.tileLayer(BR.conf.baseLayers[i]); } } for (i in BR.conf.overlays) { if (BR.conf.overlays.hasOwnProperty(i)) { overlays[i] = L.tileLayer(BR.conf.overlays[i]); } } // after applying custom base layer configurations, add configured base layer to map var defaultLayer = baseLayers[Object.keys(baseLayers)[BR.conf.defaultBaseLayerIndex || 0]]; if (defaultLayer) { map.addLayer(defaultLayer); } layersControl = BR.layersTab(baseLayers, overlays).addTo(map); var secureContext = 'isSecureContext' in window ? isSecureContext : location.protocol === 'https:'; if (secureContext) { L.control.locate({ icon: 'fa fa-location-arrow', iconLoading: 'fa fa-spinner fa-pulse', }).addTo(map); } L.control.scale().addTo(map); new BR.Layers().init(map, layersControl, baseLayers, overlays); // expose map instance for console debugging BR.debug = BR.debug || {}; BR.debug.map = map; var layersAndOverlays = baseLayers; for (var o in overlays) { layersAndOverlays[o] = overlays[o]; } return { map: map, layersControl: layersControl, layers: layersAndOverlays }; } };