Using setZoom() after using fitBounds() with Google Maps API V3

前端 未结 6 1062
一向
一向 2020-12-04 09:28

I\'m using fitBounds() to set the zoom level on my map too include all the markers currently displayed. However, when I have only one marker visible, the zoom level is 100%

相关标签:
6条回答
  • 2020-12-04 10:07

    I found the additional zoom to be a little jarring. If you set the maxZoom option before calling fitBounds (and then unset it in the callback) you can avoid it:

    map.setOptions({
        maxZoom: 10
    });
    
    map.setCenter(new google.maps.LatLng(-89, -179)); // make sure it changes so the idle listener gets called back
    
    map.fitBounds(bounds);
    
    var listener = google.maps.event.addListenerOnce(map, "idle", function()
    {
        map.setOptions({
            maxZoom: 999
        });
    });
    
    0 讨论(0)
  • 2020-12-04 10:11

    I have simple and dirty solution.
    Use If else ...

    var marker = this.map.createMarker(view.latlng, this.markerNumber);
    this.map.bounds.extend(view.latlng);
    this.map.map.setCenter(this.map.bounds.getCenter()); 
    if (this.markerNumber === 1) {
      this.map.map.setZoom(16);
    } else {
       this.map.map.fitBounds(this.map.bounds);
    }       
    this.markerNumber++;
    
    0 讨论(0)
  • 2020-12-04 10:14

    Alright, I've figured it out. Apparently, the fitbounds() happens asynchronously, so you have to wait for a bounds_changed event before setting zoom works.

    map = this.map.map;
    
    map.fitBounds(this.map.bounds);
    zoomChangeBoundsListener = 
        google.maps.event.addListenerOnce(map, 'bounds_changed', function(event) {
            if (this.getZoom()){
                this.setZoom(16);
            }
    });
    setTimeout(function(){google.maps.event.removeListener(zoomChangeBoundsListener)}, 2000);
    

    Update: See @Nequin's answer using addListenerOnce for a better solution that doesn't require a timeout.

    0 讨论(0)
  • 2020-12-04 10:21

    I just added one line to the function addBounds(position) and it fixed it, as the following shows:

        addBounds: function(position) {
            this.get('bounds', new google.maps.LatLngBounds()).extend(this._latLng(position));
            this.get('map').fitBounds(this.get('bounds'));
            this.get('map').setZoom(16);//line added
            return this;
        },
    
    0 讨论(0)
  • 2020-12-04 10:21

    All the solutions with event listeners didn't work for me (this.getZoom() always is undefined in the callback and this.setZoom() has no effect).

    I came up with this solution which worked nicely:

    function set_zoom() {
        if(map.getZoom()) {map.setZoom(map.getZoom() - 1);}
        else {setTimeout(set_zoom, 5);}
    }
    setTimeout(set_zoom, 5);
    
    0 讨论(0)
  • 2020-12-04 10:23
    google.maps.event.addListenerOnce(yourMap, 'bounds_changed', function(event) {
      if (this.getZoom() > 15) {
        this.setZoom(15);
      }
    });
    

    This solution works better… instead of waiting on timeout to remove listener. Call this directly before using fitBounds (I believe calling after will work as well).

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