Skip to content
This repository has been archived by the owner on Jun 16, 2019. It is now read-only.

Commit

Permalink
Merge pull request #33 from ortic/fix/ignore-hidden-markers
Browse files Browse the repository at this point in the history
ignore hidden markers in cluster
  • Loading branch information
skarEE committed Jan 17, 2016
2 parents b24cb49 + a52aa4a commit 1edfec3
Showing 1 changed file with 25 additions and 5 deletions.
30 changes: 25 additions & 5 deletions src/markerclusterer.js
Original file line number Diff line number Diff line change
Expand Up @@ -859,7 +859,8 @@ Cluster.prototype.addMarker = function(marker) {
marker.isAdded = true;
this.markers_.push(marker);

var len = this.markers_.length;
var visibleMarkers = this.getVisibleMarkers();
var len = visibleMarkers.length;
if (len < this.minClusterSize_ && marker.getMap() != this.map_) {
// Min cluster size not reached so show the marker.
marker.setMap(this.map_);
Expand All @@ -868,7 +869,7 @@ Cluster.prototype.addMarker = function(marker) {
if (len == this.minClusterSize_) {
// Hide the markers that were showing.
for (var i = 0; i < len; i++) {
this.markers_[i].setMap(null);
visibleMarkers[i].setMap(null);
}
}

Expand Down Expand Up @@ -936,6 +937,23 @@ Cluster.prototype.getMarkers = function() {
};


/**
* Returns the array of markers in the cluster.
*
* @return {Array.<google.maps.Marker>} The markers.
*/
Cluster.prototype.getVisibleMarkers = function() {
var visibleMarkers = [];
for (var i in this.markers_) {
var marker = this.markers_[i];
if (marker.visible) {
visibleMarkers.push(marker);
}
}
return visibleMarkers;
};


/**
* Returns the center of the cluster.
*
Expand Down Expand Up @@ -984,23 +1002,24 @@ Cluster.prototype.getMap = function() {
Cluster.prototype.updateIcon = function() {
var zoom = this.map_.getZoom();
var mz = this.markerClusterer_.getMaxZoom();
var markers = this.getVisibleMarkers();

if (mz && zoom > mz) {
// The zoom is greater than our max zoom so show all the markers in cluster.
for (var i = 0, marker; marker = this.markers_[i]; i++) {
for (var i = 0, marker; marker = markers[i]; i++) {
marker.setMap(this.map_);
}
return;
}

if (this.markers_.length < this.minClusterSize_) {
if (markers_.length < this.minClusterSize_) {

This comment has been minimized.

Copy link
@Evgenus

Evgenus Jan 18, 2016

ReferenceError: markers_ is not defined

// Min cluster size not yet reached.
this.clusterIcon_.hide();
return;
}

var numStyles = this.markerClusterer_.getStyles().length;
var sums = this.markerClusterer_.getCalculator()(this.markers_, numStyles);
var sums = this.markerClusterer_.getCalculator()(markers, numStyles);
this.clusterIcon_.setCenter(this.center_);
this.clusterIcon_.setSums(sums);
this.clusterIcon_.show();
Expand Down Expand Up @@ -1298,6 +1317,7 @@ MarkerClusterer.prototype['draw'] = MarkerClusterer.prototype.draw;
Cluster.prototype['getCenter'] = Cluster.prototype.getCenter;
Cluster.prototype['getSize'] = Cluster.prototype.getSize;
Cluster.prototype['getMarkers'] = Cluster.prototype.getMarkers;
Cluster.prototype['getVisibleMarkers'] = Cluster.prototype.getVisibleMarkers;

ClusterIcon.prototype['onAdd'] = ClusterIcon.prototype.onAdd;
ClusterIcon.prototype['draw'] = ClusterIcon.prototype.draw;
Expand Down

0 comments on commit 1edfec3

Please sign in to comment.