/ Published in: JavaScript
data:image/s3,"s3://crabby-images/90b0e/90b0e6a2677ca35d5348c94828b6331437fd25ab" alt=""
[MarkerClusterer](http://googlegeodevelopers.blogspot.com/2009/04/markerclusterer-solution-to-too-many.html) is an awesome marker clustering utility for the Google Maps API. Currently when you click on a cluster, the map is re-centered and zooms in one level. This is sometimes a problem if your markers are very close together and the map is zoomed very far out. It take a few clicks before the markers become unclustered.
This snippet modifies the clusterclick behavior, so that clicking on a cluster zooms in more intelligently. Instead of simply zooming in one level, the bounds of the map are redefined based on the lat/long of the markers that a cluster contains.
Make sure you are using the [dev branch of MarkerClusterer](http://gmaps-utility-library-dev.googlecode.com/svn/tags/markerclusterer/1.0/src/markerclusterer.js), earlier versions do not allow you to override the default clusterclick behavior.
Be sure to set `zoomOnClick: false`.
Also, this script make's use of [jQuery's $.each() function](http://api.jquery.com/jQuery.each/). If you aren't using jQuery, you should find a different way to iterate through the loop.
This snippet modifies the clusterclick behavior, so that clicking on a cluster zooms in more intelligently. Instead of simply zooming in one level, the bounds of the map are redefined based on the lat/long of the markers that a cluster contains.
Make sure you are using the [dev branch of MarkerClusterer](http://gmaps-utility-library-dev.googlecode.com/svn/tags/markerclusterer/1.0/src/markerclusterer.js), earlier versions do not allow you to override the default clusterclick behavior.
Be sure to set `zoomOnClick: false`.
Also, this script make's use of [jQuery's $.each() function](http://api.jquery.com/jQuery.each/). If you aren't using jQuery, you should find a different way to iterate through the loop.
Expand |
Embed | Plain Text
Copy this code and paste it in your HTML
GEvent.addListener(markerCluster, "clusterclick", function (cluster) { var markers = cluster.getMarkers(); var bounds = new GLatLngBounds(); $.each(markers, function(i, marker){ bounds.extend(marker.marker.getLatLng()); }); map.setCenter(bounds.getCenter(), map.getBoundsZoomLevel(bounds)); });
Comments
data:image/s3,"s3://crabby-images/ddb6f/ddb6f8242eb268e53b908f42b5afcd1004e6fcb1" alt="RSS Feed for Comments RSS Icon"