First we need a div for the map:
<div id="map"></div>
And second lets add some javascript:
// we rely on OpenLayers
<script src="//puertos.maps.eox.at/dist/ol/OpenLayers.js" type="text/javascript"></script>
// and some custom code
<script type="text/javascript">
// some defaults for eox::maps
eox = {
maps: {
defaults: {
map: {
div: 'map',
layers: [],
zoom: 0,
center: new OpenLayers.LonLat(0,0),
projection: new OpenLayers.Projection('EPSG:4326'),
restrictedExtent: new OpenLayers.Bounds(-720, -85, 720, 90),
},
layer: {
url: [
'//a.tiles.puertos.maps.eox.at/wmts/',
'//b.tiles.puertos.maps.eox.at/wmts/',
'//c.tiles.puertos.maps.eox.at/wmts/',
'//d.tiles.puertos.maps.eox.at/wmts/',
'//e.tiles.puertos.maps.eox.at/wmts/',
'//f.tiles.puertos.maps.eox.at/wmts/',
],
matrixSet: 'WGS84',
style: 'default',
requestEncoding: 'REST',
maxResolution: 0.703125,
wrapDateLine: true,
transitionEffect: 'resize',
isBaseLayer: false,
},
},
layers: {
base: {
's2cloudless-2021': {
name: 'Sentinel-2 cloudless 2021',
layer: 's2cloudless-2021',
numZoomLevels: 14,
attribution: 'Sentinel-2 cloudless - https://s2maps.eu by EOX IT Services GmbH (Contains modified Copernicus Sentinel data 2021)'
},
's2cloudless-2020': {
name: 'Sentinel-2 cloudless 2020',
layer: 's2cloudless-2020',
numZoomLevels: 14,
attribution: 'Sentinel-2 cloudless - https://s2maps.eu by EOX IT Services GmbH (Contains modified Copernicus Sentinel data 2020)'
},
osm: {
name: 'OpenStreetMap',
layer: 'osm',
numZoomLevels: 18,
attribution: 'OpenStreetMap { Data © OpenStreetMap contributors, Rendering © MapServer and EOX }'
},
},
overlays: {
overlay: {
name: 'Overlay',
layer: 'overlay',
numZoomLevels: 18,
attribution: 'Overlay { Data © OpenStreetMap contributors, Rendering © EOX and MapServer }'
},
overlay_bright: {
name: 'Overlay (Bright)',
layer: 'overlay_bright',
numZoomLevels: 18,
visibility: false,
attribution: 'Overlay { Data © OpenStreetMap contributors, Rendering © EOX and MapServer }'
},
}
}
}
}
eox.maps.defaults.base = OpenLayers.Util.applyDefaults({ isBaseLayer: true }, eox.maps.defaults.layer);
eox.maps.defaults.overlay = OpenLayers.Util.applyDefaults({ transitionEffect: 'map-resize' }, eox.maps.defaults.layer);
// define base layers
for (base in eox.maps.layers.base) {
eox.maps.layers.base[base] = new OpenLayers.Layer.WMTS(OpenLayers.Util.applyDefaults(eox.maps.layers.base[base], eox.maps.defaults.base));
eox.maps.defaults.map.layers.push( eox.maps.layers.base[base] )
}
// define overlays
for (overlay in eox.maps.layers.overlays) {
eox.maps.layers.overlays[overlay] = new OpenLayers.Layer.WMTS(OpenLayers.Util.applyDefaults(eox.maps.layers.overlays[overlay], eox.maps.defaults.overlay));
eox.maps.defaults.map.layers.push( eox.maps.layers.overlays[overlay] )
}
// setup the actual map
var map = new OpenLayers.Map(OpenLayers.Util.applyDefaults( {
center: new OpenLayers.LonLat(-3.82, 40.44),
zoom: 6,
controls: [
new OpenLayers.Control.Navigation(),
new OpenLayers.Control.Zoom(),
new OpenLayers.Control.LayerSwitcher(),
new OpenLayers.Control.Attribution()
]
}, eox.maps.defaults.map));
</script>
<style>
#map div.olControlAttribution {
position: absolute;
bottom: 0;
right: 0;
color: #333;
background-color: #fff;
padding: 1px 5px 0 5px;
border: 1px solid #ccc;
border-radius: 3px 0 0 0;
border-width: 1px 0 0 1px;
font-size: .85em;
line-height: 1.5em;
}
</style>