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 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
| import KML from 'ol/format/KML.js'; import Map from 'ol/Map.js'; import Polygon from 'ol/geom/Polygon.js'; import Stamen from 'ol/source/Stamen.js'; import VectorSource from 'ol/source/Vector.js'; import View from 'ol/View.js'; import {Fill, Icon, Stroke, Style} from 'ol/style.js'; import {Tile as TileLayer, Vector as VectorLayer} from 'ol/layer.js'; import {toContext} from 'ol/render.js';
const symbol = [ [0, 0], [4, 2], [6, 0], [10, 5], [6, 3], [4, 5], [0, 0], ]; let scale; const scaleFunction = function (coordinate) { return [coordinate[0] * scale, coordinate[1] * scale]; };
const styleCache = {}; const styleFunction = function (feature) { const name = feature.get('name'); const magnitude = parseFloat(name.substr(2)); const size = parseInt(10 + 40 * (magnitude - 5), 10); scale = size / 10; let style = styleCache[size]; if (!style) { const canvas = document.createElement('canvas'); const vectorContext = toContext(canvas.getContext('2d'), { size: [size, size], pixelRatio: 1, }); vectorContext.setStyle( new Style({ fill: new Fill({color: 'rgba(255, 153, 0, 0.4)'}), stroke: new Stroke({color: 'rgba(255, 204, 0, 0.2)', width: 2}), }) ); vectorContext.drawGeometry(new Polygon([symbol.map(scaleFunction)])); style = new Style({ image: new Icon({ img: canvas, imgSize: [size, size], rotation: 1.2, }), }); styleCache[size] = style; } return style; };
const vector = new VectorLayer({ source: new VectorSource({ url: 'data/kml/2012_Earthquakes_Mag5.kml', format: new KML({ extractStyles: false, }), }), style: styleFunction, });
const raster = new TileLayer({ source: new Stamen({ layer: 'toner', }), });
const map = new Map({ layers: [raster, vector], target: 'map', view: new View({ center: [0, 0], zoom: 2, }), });
|