Files
openlayers/examples/wmts-hidpi.js
Frederic Junod 79c8afdba8 Simplify import path in examples
To have the same path (starting with `ol/`, without `.js`) as in the documentation.
The support was added in the webpack config in #8928
2018-11-26 17:18:52 +01:00

40 lines
1.2 KiB
JavaScript

import Map from 'ol/Map';
import View from 'ol/View';
import WMTSCapabilities from 'ol/format/WMTSCapabilities';
import {DEVICE_PIXEL_RATIO} from 'ol/has';
import TileLayer from 'ol/layer/Tile';
import WMTS, {optionsFromCapabilities} from 'ol/source/WMTS';
const capabilitiesUrl = 'https://www.basemap.at/wmts/1.0.0/WMTSCapabilities.xml';
// HiDPI support:
// * Use 'bmaphidpi' layer (pixel ratio 2) for device pixel ratio > 1
// * Use 'geolandbasemap' layer (pixel ratio 1) for device pixel ratio == 1
const hiDPI = DEVICE_PIXEL_RATIO > 1;
const layer = hiDPI ? 'bmaphidpi' : 'geolandbasemap';
const tilePixelRatio = hiDPI ? 2 : 1;
const map = new Map({
target: 'map',
view: new View({
center: [1823849, 6143760],
zoom: 11
})
});
fetch(capabilitiesUrl).then(function(response) {
return response.text();
}).then(function(text) {
const result = new WMTSCapabilities().read(text);
const options = optionsFromCapabilities(result, {
layer: layer,
matrixSet: 'google3857',
style: 'normal'
});
options.tilePixelRatio = tilePixelRatio;
map.addLayer(new TileLayer({
source: new WMTS(/** @type {!module:ol/source/WMTS~Options} */ (options))
}));
});