101 lines
2.1 KiB
JavaScript
101 lines
2.1 KiB
JavaScript
import Feature from '../src/ol/Feature.js';
|
|
import Map from '../src/ol/Map.js';
|
|
import Point from '../src/ol/geom/Point.js';
|
|
import TileJSON from '../src/ol/source/TileJSON.js';
|
|
import VectorSource from '../src/ol/source/Vector.js';
|
|
import View from '../src/ol/View.js';
|
|
import {Icon, Style} from '../src/ol/style.js';
|
|
import {Tile as TileLayer, Vector as VectorLayer} from '../src/ol/layer.js';
|
|
import {fromLonLat} from '../src/ol/proj.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])),
|
|
});
|
|
const paris = new Feature({
|
|
geometry: new Point(fromLonLat([2.353, 48.8566])),
|
|
});
|
|
const berlin = new Feature({
|
|
geometry: new Point(fromLonLat([13.3884, 52.5169])),
|
|
});
|
|
|
|
rome.setStyle(
|
|
new Style({
|
|
image: new Icon({
|
|
color: '#BADA55',
|
|
crossOrigin: 'anonymous',
|
|
src: 'data/square.svg',
|
|
}),
|
|
})
|
|
);
|
|
|
|
london.setStyle(
|
|
new Style({
|
|
image: new Icon({
|
|
color: 'rgba(255, 0, 0, .5)',
|
|
crossOrigin: 'anonymous',
|
|
src: 'data/bigdot.png',
|
|
scale: 0.2,
|
|
}),
|
|
})
|
|
);
|
|
|
|
madrid.setStyle(
|
|
new Style({
|
|
image: new Icon({
|
|
crossOrigin: 'anonymous',
|
|
src: 'data/bigdot.png',
|
|
scale: 0.2,
|
|
}),
|
|
})
|
|
);
|
|
|
|
paris.setStyle(
|
|
new Style({
|
|
image: new Icon({
|
|
color: '#8959A8',
|
|
crossOrigin: 'anonymous',
|
|
src: 'data/dot.svg',
|
|
}),
|
|
})
|
|
);
|
|
|
|
berlin.setStyle(
|
|
new Style({
|
|
image: new Icon({
|
|
crossOrigin: 'anonymous',
|
|
src: 'data/dot.svg',
|
|
}),
|
|
})
|
|
);
|
|
const vectorSource = new VectorSource({
|
|
features: [rome, london, madrid, paris, berlin],
|
|
});
|
|
|
|
const vectorLayer = new VectorLayer({
|
|
source: vectorSource,
|
|
});
|
|
|
|
const rasterLayer = new TileLayer({
|
|
source: new TileJSON({
|
|
url: 'https://a.tiles.mapbox.com/v3/aj.1x1-degrees.json?secure=1',
|
|
crossOrigin: '',
|
|
}),
|
|
});
|
|
|
|
const map = new Map({
|
|
layers: [rasterLayer, vectorLayer],
|
|
target: document.getElementById('map'),
|
|
view: new View({
|
|
center: fromLonLat([2.896372, 44.6024]),
|
|
zoom: 3,
|
|
}),
|
|
});
|