new example
This commit is contained in:
1
examples/data/openweather/weather.json
Normal file
1
examples/data/openweather/weather.json
Normal file
File diff suppressed because one or more lines are too long
13
examples/wind-arrows.html
Normal file
13
examples/wind-arrows.html
Normal file
@@ -0,0 +1,13 @@
|
||||
---
|
||||
layout: example.html
|
||||
title: Wind Arrows
|
||||
shortdesc: Example of Wind Arrows styled using Regular Shapes.
|
||||
docs: >
|
||||
This example shows wind arrows styled using regular shapes for the
|
||||
arrow shaft and head. The shaft is scaled based on the wind speed
|
||||
and a corresponding displacement is used to position the unscaled
|
||||
arrow head at the end of the scaled shaft.
|
||||
The weather data is provided by <a href="https://openweathermap.org/current">OpenWeather</a>.
|
||||
tags: "vector, symbol, regularshape, style, arrow"
|
||||
---
|
||||
<div id="map" class="map"></div>
|
||||
80
examples/wind-arrows.js
Normal file
80
examples/wind-arrows.js
Normal file
@@ -0,0 +1,80 @@
|
||||
import Feature from '../src/ol/Feature.js';
|
||||
import Map from '../src/ol/Map.js';
|
||||
import OSM from '../src/ol/source/OSM.js';
|
||||
import Point from '../src/ol/geom/Point.js';
|
||||
import TileLayer from '../src/ol/layer/Tile.js';
|
||||
import VectorLayer from '../src/ol/layer/Vector.js';
|
||||
import VectorSource from '../src/ol/source/Vector.js';
|
||||
import View from '../src/ol/View.js';
|
||||
import {Fill, RegularShape, Stroke, Style} from '../src/ol/style.js';
|
||||
import {fromLonLat} from '../src/ol/proj.js';
|
||||
|
||||
const shaft = new RegularShape({
|
||||
points: 2,
|
||||
radius: 20,
|
||||
stroke: new Stroke({
|
||||
width: 2,
|
||||
color: 'rgba(0,0,0,0.5)',
|
||||
}),
|
||||
rotateWithView: true,
|
||||
});
|
||||
|
||||
const head = new RegularShape({
|
||||
points: 3,
|
||||
radius: 10,
|
||||
fill: new Fill({
|
||||
color: 'rgba(0,0,0,0.5)',
|
||||
}),
|
||||
rotateWithView: true,
|
||||
});
|
||||
|
||||
const styles = [new Style({image: shaft}), new Style({image: head})];
|
||||
|
||||
const source = new VectorSource();
|
||||
|
||||
const map = new Map({
|
||||
layers: [
|
||||
new TileLayer({
|
||||
source: new OSM(),
|
||||
}),
|
||||
new VectorLayer({
|
||||
source: source,
|
||||
style: function (feature) {
|
||||
const wind = feature.get('wind');
|
||||
// rotate arrow away from wind origin
|
||||
const angle = ((wind.deg - 180) * Math.PI) / 180;
|
||||
const scale = wind.speed / 10;
|
||||
shaft.setScale([1, scale]);
|
||||
shaft.setRotation(angle);
|
||||
head.setDisplacement([
|
||||
0,
|
||||
head.getRadius() / 2 + shaft.getRadius() * scale,
|
||||
]);
|
||||
head.setRotation(angle);
|
||||
return styles;
|
||||
},
|
||||
}),
|
||||
],
|
||||
target: 'map',
|
||||
view: new View({
|
||||
center: [0, 0],
|
||||
zoom: 2,
|
||||
}),
|
||||
});
|
||||
|
||||
fetch('data/openweather/weather.json')
|
||||
.then(function (response) {
|
||||
return response.json();
|
||||
})
|
||||
.then(function (data) {
|
||||
const features = [];
|
||||
data.list.forEach(function (report) {
|
||||
const feature = new Feature(
|
||||
new Point(fromLonLat([report.coord.lon, report.coord.lat]))
|
||||
);
|
||||
feature.setProperties(report);
|
||||
features.push(feature);
|
||||
});
|
||||
source.addFeatures(features);
|
||||
map.getView().fit(source.getExtent());
|
||||
});
|
||||
Reference in New Issue
Block a user