拖动和平移完成后获取中心坐标



我想跟踪地图中心的坐标。到目前为止,我一直在使用这个:

// On Drag End
google.maps.event.addListener(map, 'dragend', function() { 
    $('.map_center_coords .latitude').html( map.getCenter().lat() );
    $('.map_center_coords .longitude').html( map.getCenter().lng() );
});

其工作原理是在拖动事件结束时获取坐标。

问题是我现在正在使用map.panTo移动到某个位置。

基本上"whenever the center has *finished* moving in any way"有事件吗?

正如geocodezip所提到的,我忘记了center_changed事件。但是,在拖动/平移地图时,该事件会持续触发。

理想情况下,我正在寻找一个在完成任何拖动/平移后只触发一次的事件。

改为观察空闲事件(当地图在平移或缩放后变为空闲时会触发此事件):

    google.maps.event.addListener(map,'idle',function(){
      if(!this.get('dragging') && this.get('oldCenter') && this.get('oldCenter')!==this.getCenter()) {
        //do what you want to
      }
      if(!this.get('dragging')){
       this.set('oldCenter',this.getCenter())
      }
    });
    google.maps.event.addListener(map,'dragstart',function(){
      this.set('dragging',true);          
    });
    google.maps.event.addListener(map,'dragend',function(){
      this.set('dragging',false);
      google.maps.event.trigger(this,'idle',{});
    });

google.maps.Map center_changed事件。

center_changed | None | This event is fired when the map center property changes.
// On center changed
google.maps.event.addListener(map, 'center_changed', function() { 
  $('.map_center_coords .latitude').html( map.getCenter().lat() );
  $('.map_center_coords .longitude').html( map.getCenter().lng() );
});

尝试使用idle事件。链接到文档。

当地图在平移或缩放。

如果您希望空闲事件仅在dragend之后激发,请尝试下面的代码段。

此代码在dragendidle事件触发后将坐标打印到控制台。

mapObj.addListener('dragend', function () {
    var idleListener = mapObj.addListener('idle', function () {
        google.maps.event.removeListener(idleListener);
        console.log(mapObj.getCenter().lat()); 
        console.log(mapObj.getCenter().lng());
    });
});

最新更新