1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
| import GeoJSON from 'ol/format/GeoJSON.js'; import Map from 'ol/Map.js'; import VectorSource from 'ol/source/Vector.js'; import View from 'ol/View.js'; import XYZ from 'ol/source/XYZ.js'; import {Fill, Style, Text} from 'ol/style.js'; import {Tile as TileLayer, Vector as VectorLayer} from 'ol/layer.js'; import {getCenter} from 'ol/extent.js';
const style = new Style({ text: new Text({ font: 'bold 11px "Open Sans", "Arial Unicode MS", "sans-serif"', placement: 'line', fill: new Fill({ color: 'white', }), }), });
const key = 'Get your own API key at https://www.maptiler.com/cloud/'; const attributions = '<a href="https://www.maptiler.com/copyright/" target="_blank">© MapTiler</a> ' + '<a href="https://www.openstreetmap.org/copyright" target="_blank">© OpenStreetMap contributors</a>';
const viewExtent = [1817379, 6139595, 1827851, 6143616]; const map = new Map({ layers: [ new TileLayer({ source: new XYZ({ attributions: attributions, url: 'https://api.maptiler.com/tiles/satellite/{z}/{x}/{y}.jpg?key=' + key, maxZoom: 20, }), }), new VectorLayer({ declutter: true, source: new VectorSource({ format: new GeoJSON(), url: 'data/geojson/vienna-streets.geojson', }), style: function (feature) { style.getText().setText(feature.get('name')); return style; }, }), ], target: 'map', view: new View({ extent: viewExtent, center: getCenter(viewExtent), zoom: 17, minZoom: 14, }), });
|