mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	git-subtree-dir: lib/Leaflet.markercluster git-subtree-mainline:1218d227begit-subtree-split:e96388d6cb
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | |
| <html>
 | |
| <head>
 | |
| 	<title>Leaflet debug page</title>
 | |
| 
 | |
| 	<link rel="stylesheet" href="http://cdn.leafletjs.com/leaflet-0.7/leaflet.css" />
 | |
| 	<script src="http://cdn.leafletjs.com/leaflet-0.7/leaflet.js"></script>
 | |
| 	<meta name="viewport" content="width=device-width, initial-scale=1.0">
 | |
| 	<link rel="stylesheet" href="screen.css" />
 | |
| 
 | |
| 	<link rel="stylesheet" href="../dist/MarkerCluster.css" />
 | |
| 	<link rel="stylesheet" href="../dist/MarkerCluster.Default.css" />
 | |
| 	<script src="../dist/leaflet.markercluster-src.js"></script>
 | |
| </head>
 | |
| <body>
 | |
| 
 | |
| 	<div id="map"></div>
 | |
| 	<button id="populate">Populate 1 marker</button>
 | |
| 	<button id="remove">Remove 1 marker</button>
 | |
| 
 | |
| 	<script type="text/javascript">
 | |
| 
 | |
| 		var tiles = L.tileLayer('http://{s}.tile.osm.org/{z}/{x}/{y}.png', {
 | |
| 				maxZoom: 18,
 | |
| 				attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
 | |
| 			}),
 | |
| 			latlng = L.latLng(50.5, 30.51);
 | |
| 
 | |
| 		var map = L.map('map', {center: latlng, zoom: 15, layers: [tiles]});
 | |
| 
 | |
| 		var markers = L.markerClusterGroup({ spiderfyOnMaxZoom: false, showCoverageOnHover: false, zoomToBoundsOnClick: false });
 | |
| 
 | |
| 		function populate() {
 | |
| 			for (var i = 0; i < 100; i++) {
 | |
| 				var m = L.marker(getRandomLatLng(map));
 | |
| 				markers.addLayer(m);
 | |
| 			}
 | |
| 			return false;
 | |
| 		}
 | |
| 		function getRandomLatLng(map) {
 | |
| 			var bounds = map.getBounds(),
 | |
| 				southWest = bounds.getSouthWest(),
 | |
| 				northEast = bounds.getNorthEast(),
 | |
| 				lngSpan = northEast.lng - southWest.lng,
 | |
| 				latSpan = northEast.lat - southWest.lat;
 | |
| 
 | |
| 			return L.latLng(
 | |
| 					southWest.lat + latSpan * Math.random(),
 | |
| 					southWest.lng + lngSpan * Math.random());
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		var polygon;
 | |
| 		markers.on('clustermouseover', function (a) {
 | |
| 			if (polygon) {
 | |
| 				map.removeLayer(polygon);
 | |
| 			}
 | |
| 			polygon = L.polygon(a.layer.getConvexHull());
 | |
| 			map.addLayer(polygon);
 | |
| 		});
 | |
| 
 | |
| 		markers.on('clustermouseout', function (a) {
 | |
| 			if (polygon) {
 | |
| 				map.removeLayer(polygon);
 | |
| 				polygon = null;
 | |
| 			}
 | |
| 		});
 | |
| 
 | |
| 		map.on('zoomend', function () {
 | |
| 			if (polygon) {
 | |
| 				map.removeLayer(polygon);
 | |
| 				polygon = null;
 | |
| 			}
 | |
| 		});
 | |
| 
 | |
| 
 | |
| 		populate();
 | |
| 		map.addLayer(markers);
 | |
| 	</script>
 | |
| </body>
 | |
| </html>
 |