mohsen-angular-leaflet-directive
Version:
angular-leaflet-directive - An AngularJS directive to easily interact with Leaflet maps
88 lines (85 loc) • 3.86 kB
HTML
<html ng-app="demoapp">
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<script src="../bower_components/angular/angular.min.js"></script>
<script src="../bower_components/leaflet/dist/leaflet.js"></script>
<script src="../bower_components/Leaflet.PolylineDecorator/leaflet.polylineDecorator.js"></script>
<script src="../dist/angular-leaflet-directive.min.js"></script>
<link rel="stylesheet" href="../bower_components/leaflet/dist/leaflet.css" />
<script>
var app = angular.module("demoapp", ["leaflet-directive"]);
app.controller('PathsDecorationsSimpleController', [ '$scope', function($scope) {
angular.extend($scope, {
london: {
lat: 51.505,
lng: -0.09,
zoom: 8
},
decorations: {
markers: {
coordinates: [[51.9, -0.4], [51.505, -0.09], [51.0, -0.4]],
patterns: [
{ offset: 12, repeat: 25, symbol: L.Symbol.dash({pixelSize: 10, pathOptions: {color: '#f00', weight: 2}}) },
{ offset: 0, repeat: 25, symbol: L.Symbol.dash({pixelSize: 0}) }
]
}
}
});
$scope.changePattern = function(type) {
if (type === 'dot') {
$scope.decorations.markers.patterns = [
{
offset: 0,
repeat: 10,
symbol: L.Symbol.dash({pixelSize: 0})
}
];
} else if (type === 'slash') {
$scope.decorations.markers.patterns = [
{
offset: 12,
repeat: 25,
symbol: L.Symbol.dash({pixelSize: 10, pathOptions: {color: '#f00', weight: 2}})
}
];
} else if (type === 'slashdot') {
$scope.decorations.markers.patterns = [
{
offset: 12,
repeat: 25,
symbol: L.Symbol.dash({pixelSize: 10, pathOptions: {color: '#f00', weight: 2}})
},
{
offset: 0,
repeat: 25,
symbol: L.Symbol.dash({pixelSize: 0})
}
];
} else if (type === 'arrow') {
$scope.decorations.markers.patterns = [
{
offset: 12,
repeat: 25,
symbol: L.Symbol.dash({pixelSize: 18, pathOptions: {color: '#f00', weight: 4}})
},
{
offset: '10%',
repeat: 25,
symbol: L.Symbol.arrowHead({pixelSize: 10, polygon: false, pathOptions: {stroke: true}})
}
];
}
};
} ]);
</script>
</head>
<body ng-controller="PathsDecorationsSimpleController">
<leaflet lf-center="london" lf-decorations="decorations" height="480px" width="640px"></leaflet>
<h1>Path decoration example</h1>
<button ng-click="changePattern('slash')">Slash pattern</button>
<button ng-click="changePattern('dot')">Dot pattern</button>
<button ng-click="changePattern('slashdot')">Slashdot pattern</button>
<button ng-click="changePattern('arrow')">Arrow pattern</button>
</body>
</html>