我想跟踪地图中心的坐标。到目前为止,我一直在使用这个:
// 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之后激发,请尝试下面的代码段。
此代码在dragend
和idle
事件触发后将坐标打印到控制台。
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());
});
});