import Map from '../src/ol/Map.js'; import View from '../src/ol/View.js'; import KML from '../src/ol/format/KML.js'; import Polygon from '../src/ol/geom/Polygon.js'; import TileLayer from '../src/ol/layer/Tile.js'; import VectorLayer from '../src/ol/layer/Vector.js'; import {toContext} from '../src/ol/render.js'; import Stamen from '../src/ol/source/Stamen.js'; import VectorSource from '../src/ol/source/Vector.js'; import Fill from '../src/ol/style/Fill.js'; import Icon from '../src/ol/style/Icon.js'; import Stroke from '../src/ol/style/Stroke.js'; import Style from '../src/ol/style/Style.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) { // 2012_Earthquakes_Mag5.kml stores the magnitude of each earthquake in a // standards-violating tag in each Placemark. We extract it from // the Placemark's name instead. 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 = /** @type {HTMLCanvasElement} */ (document.createElement('canvas')); const vectorContext = toContext( /** @type {CanvasRenderingContext2D} */ (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 }) });