From 023816f43bd47a48bd4c95c45c8c338bad92a3b3 Mon Sep 17 00:00:00 2001 From: Frederic Junod Date: Thu, 12 Mar 2015 11:33:28 +0100 Subject: [PATCH] Add new line-arrows example --- examples/data/arrow.png | Bin 0 -> 398 bytes examples/line-arrows.html | 51 +++++++++++++++++++++++++++++ examples/line-arrows.js | 67 ++++++++++++++++++++++++++++++++++++++ 3 files changed, 118 insertions(+) create mode 100644 examples/data/arrow.png create mode 100644 examples/line-arrows.html create mode 100644 examples/line-arrows.js diff --git a/examples/data/arrow.png b/examples/data/arrow.png new file mode 100644 index 0000000000000000000000000000000000000000..a0d3834586169c71ca1e2fec8d23a4235e1a950d GIT binary patch literal 398 zcmeAS@N?(olHy`uVBq!ia0vp^JU}eW!3-oPYs<_AQq09po*^6@9Je3(KLBz$3p^r= z85p>QL70(Y)*K0-pk#?_L`iUdT1k0gQ7S`udAVL@UUqSEVnM22eo^}DcQ#T$MMVKV zA+G;HfB}S7h5p~~@c)eQ|Et>nFY5h2Vhv(n(*1wZ48%QU`u~DHh&*Qq5=Ta-O+Z`- z2^UA>!o|-RFV0N33$$IeB*-tAfsu)sg_Vt)mtRm=OhQ`L*=_cMB`epi+q8Ax;p3;z zUAlVh=ACcW5zeoH8e%a=h5HS477;B)78&qol`;+0Q0M`nE(I) literal 0 HcmV?d00001 diff --git a/examples/line-arrows.html b/examples/line-arrows.html new file mode 100644 index 0000000000..6338653387 --- /dev/null +++ b/examples/line-arrows.html @@ -0,0 +1,51 @@ + + + + + + + + + + + LineString arrows example + + + + + +
+ +
+
+
+
+
+ +
+ +
+

LineString arrows example

+

Example of drawing arrows for each line string segment.

+
+

See the line-arrows.js source to see how this is done.

+
+
draw, vector, arrow
+
+ +
+ +
+ + + + + + + diff --git a/examples/line-arrows.js b/examples/line-arrows.js new file mode 100644 index 0000000000..90f810acfa --- /dev/null +++ b/examples/line-arrows.js @@ -0,0 +1,67 @@ +goog.require('ol.Map'); +goog.require('ol.View'); +goog.require('ol.geom.Point'); +goog.require('ol.interaction.Draw'); +goog.require('ol.layer.Tile'); +goog.require('ol.layer.Vector'); +goog.require('ol.source.MapQuest'); +goog.require('ol.source.Vector'); +goog.require('ol.style.Icon'); +goog.require('ol.style.Stroke'); +goog.require('ol.style.Style'); + +var raster = new ol.layer.Tile({ + source: new ol.source.MapQuest({layer: 'sat'}) +}); + +var source = new ol.source.Vector(); + +var styleFunction = function(feature, resolution) { + var geometry = feature.getGeometry(); + var styles = [ + // linestring + new ol.style.Style({ + stroke: new ol.style.Stroke({ + color: '#ffcc33', + width: 2 + }) + }) + ]; + + geometry.forEachSegment(function(start, end) { + var dx = end[0] - start[0]; + var dy = end[1] - start[1]; + var rotation = Math.atan2(dy, dx); + // arrows + styles.push(new ol.style.Style({ + geometry: new ol.geom.Point(end), + image: new ol.style.Icon({ + src: 'data/arrow.png', + anchor: [0.75, 0.5], + rotateWithView: false, + rotation: -rotation + }) + })); + }); + + return styles; +}; +var vector = new ol.layer.Vector({ + source: source, + style: styleFunction +}); + +var map = new ol.Map({ + layers: [raster, vector], + renderer: exampleNS.getRendererFromQueryString(), + target: 'map', + view: new ol.View({ + center: [-11000000, 4600000], + zoom: 4 + }) +}); + +map.addInteraction(new ol.interaction.Draw({ + source: source, + type: /** @type {ol.geom.GeometryType} */ ('LineString') +}));