72 lines
1.6 KiB
JavaScript
72 lines
1.6 KiB
JavaScript
import Feature from '../src/ol/Feature.js';
|
|
import Map from '../src/ol/Map.js';
|
|
import View from '../src/ol/View.js';
|
|
import Point from '../src/ol/geom/Point.js';
|
|
import {Tile as TileLayer, Vector as VectorLayer} from '../src/ol/layer.js';
|
|
import {fromLonLat} from '../src/ol/proj.js';
|
|
import TileJSON from '../src/ol/source/TileJSON.js';
|
|
import VectorSource from '../src/ol/source/Vector.js';
|
|
import {Icon, Style} from '../src/ol/style.js';
|
|
|
|
|
|
const rome = new Feature({
|
|
geometry: new Point(fromLonLat([12.5, 41.9]))
|
|
});
|
|
|
|
const london = new Feature({
|
|
geometry: new Point(fromLonLat([-0.12755, 51.507222]))
|
|
});
|
|
|
|
const madrid = new Feature({
|
|
geometry: new Point(fromLonLat([-3.683333, 40.4]))
|
|
});
|
|
|
|
rome.setStyle(new Style({
|
|
image: new Icon({
|
|
color: '#8959A8',
|
|
crossOrigin: 'anonymous',
|
|
src: 'data/square.svg'
|
|
})
|
|
}));
|
|
|
|
london.setStyle(new Style({
|
|
image: new Icon({
|
|
color: '#4271AE',
|
|
crossOrigin: 'anonymous',
|
|
src: 'data/dot.png'
|
|
})
|
|
}));
|
|
|
|
madrid.setStyle(new Style({
|
|
image: new Icon({
|
|
color: [113, 140, 0],
|
|
crossOrigin: 'anonymous',
|
|
src: 'data/dot.png'
|
|
})
|
|
}));
|
|
|
|
|
|
const vectorSource = new VectorSource({
|
|
features: [rome, london, madrid]
|
|
});
|
|
|
|
const vectorLayer = new VectorLayer({
|
|
source: vectorSource
|
|
});
|
|
|
|
const rasterLayer = new TileLayer({
|
|
source: new TileJSON({
|
|
url: 'https://a.tiles.mapbox.com/v3/aj.1x1-degrees.json',
|
|
crossOrigin: ''
|
|
})
|
|
});
|
|
|
|
const map = new Map({
|
|
layers: [rasterLayer, vectorLayer],
|
|
target: document.getElementById('map'),
|
|
view: new View({
|
|
center: fromLonLat([2.896372, 44.60240]),
|
|
zoom: 3
|
|
})
|
|
});
|