Google Maps API v3: How to remove all markers?

后端 未结 30 2888
悲哀的现实
悲哀的现实 2020-11-22 05:36

In Google Maps API v2, if I wanted to remove all the map markers, I could simply do:

map.clearOverlays();

How do I do this in Google Maps A

相关标签:
30条回答
  • 2020-11-22 06:11
    for (i in markersArray) {
      markersArray[i].setMap(null);
    }
    

    is only working on IE.


    for (var i=0; i<markersArray.length; i++) {
      markersArray[i].setMap(null);
    }
    

    working on chrome, firefox, ie...

    0 讨论(0)
  • 2020-11-22 06:11

    You can do it this way too:

    function clearMarkers(category){ 
      var i;       
    
      for (i = 0; i < markers.length; i++) {                          
        markers[i].setVisible(false);        
      }    
    }
    
    0 讨论(0)
  • 2020-11-22 06:11

    The cleanest way of doing this is to iterate over all the features of the map. Markers (along with polygons, polylines, ect.) are stored in the data layer of the map.

    function removeAllMarkers() {
      map.data.forEach((feature) => {
        feature.getGeometry().getType() === 'Point' ? map.data.remove(feature) : null
      });
    }
    

    In the case that the markers are being added via drawing manager, it's best to create a global array of markers or pushing the markers into the data layer on creation like so:

    google.maps.event.addListener(drawingManager, 'overlaycomplete', (e) => {
        var newShape = e.overlay;
        newShape.type = e.type;
    
        if (newShape.type === 'marker') {
          var pos = newShape.getPosition()
          map.data.add({ geometry: new google.maps.Data.Point(pos) });
    
          // remove from drawing layer
          newShape.setMap(null);
        }
      });
    

    I recommend the second approach as it allows you to use other google.maps.data class methods later.

    0 讨论(0)
  • 2020-11-22 06:11

    just clear Googlemap

    mGoogle_map.clear();
    
    0 讨论(0)
  • 2020-11-22 06:12

    The following from Anon works perfectly, although with flickers when repeatedly clearing the overlays.

    Simply do the following:

    I. Declare a global variable:

    var markersArray = [];
    

    II. Define a function:

    function clearOverlays() {
      if (markersArray) {
        for (i in markersArray) {
          markersArray[i].setMap(null);
        }
      }
    }
    

    III. Push markers in the 'markerArray' before calling the following:

    markersArray.push(marker);
    google.maps.event.addListener(marker,"click",function(){});
    

    IV. Call the clearOverlays() function wherever required.

    That's it!!

    Hope that will help you.

    0 讨论(0)
  • 2020-11-22 06:12

    if you use the gmap V3 plugin: $("#map").gmap("removeAllMarkers");

    see: http://www.smashinglabs.pl/gmap/documentation#after-load

    0 讨论(0)
提交回复
热议问题