UNPKG

mohsen-angular-leaflet-directive

Version:

angular-leaflet-directive - An AngularJS directive to easily interact with Leaflet maps

71 lines (67 loc) 2.78 kB
<!DOCTYPE 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.markercluster/dist/leaflet.markercluster.js"></script> <script src="../dist/angular-leaflet-directive.js"></script> <link rel="stylesheet" href="../bower_components/leaflet/dist/leaflet.css" /> <link rel="stylesheet" href="../bower_components/leaflet.markercluster/dist/MarkerCluster.css" /> <link rel="stylesheet" href="../bower_components/leaflet.markercluster/dist/MarkerCluster.Default.css" /> <script> var app = angular.module("demoapp", ["leaflet-directive"]); app.controller("MarkersClustering10000MarkersController", [ "$scope", "$http", function($scope, $http) { var addressPointsToMarkers = function(points) { return points.map(function(ap) { return { layer: 'realworld', lat: ap[0], lng: ap[1] }; }); }; angular.extend($scope, { center: { lat: -37.9212959167, lng: 175.5604435167, zoom: 11 }, events: { map: { enable: ['moveend', 'popupopen'], logic: 'emit' }, marker: { enable: [], logic: 'emit' } }, layers: { baselayers: { osm: { name: 'OpenStreetMap', type: 'xyz', url: 'http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png' } }, overlays: { realworld: { name: "Real world data", type: "markercluster", visible: true } } } }); $http.get("json/realworld.10000.json").success(function(data) { $scope.markers = addressPointsToMarkers(data); }); }]); </script> </head> <body ng-controller="MarkersClustering10000MarkersController"> <leaflet lf-center="center" lf-markers="markers" lf-layers="layers" lf-events="events" width="100%" height="480px"></leaflet> <h1>Marker clustering example (10000 markers)</h1> </body> </html>