0

我想提供地理位置和可编辑的地图标记,通过 Google Maps API 向用户返回 lat/lng。我已经通过此处描述的方法成功地弄清楚了如何进行地理定位部分:

<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=true"></script>
<script>
function success(position) {
  var mapcanvas = document.createElement('div');
  mapcanvas.id = 'mapcontainer';
  mapcanvas.style.height = '400px';
  mapcanvas.style.width = '600px';

  document.querySelector('article').appendChild(mapcanvas);

  coords = new google.maps.LatLng(position.coords.latitude, position.coords.longitude);

  var options = {
    zoom: 15,
    center: coords,
    mapTypeControl: false,
    navigationControlOptions: {
        style: google.maps.NavigationControlStyle.SMALL
    },
    mapTypeId: google.maps.MapTypeId.ROADMAP
  };
  var map = new google.maps.Map(document.getElementById("mapcontainer"), options);

  var marker = new google.maps.Marker({
      position: coords,
      map: map,
      title:"You are here!"
  });
}

if (navigator.geolocation) {
  navigator.geolocation.getCurrentPosition(success);
} else {
  error('Geo Location is not supported');
}
</script>

但是,我还希望能够允许用户移动地图并通过地图标记选择另一个位置,并捕获他们选择的纬度/经度。此处描述的方法可以满足我的要求,但我不确定如何让两个脚本一起工作以添加我需要的功能。如果这有助于解释目标,我正在尝试创建一些在这方面像 über 一样有效的东西。

如何制作以地理位置为中心的谷歌地图,而且其地图标记可以移动并记录最终标记的纬度/经度?谢谢你的想法!

4

1 回答 1

0

您想首先在标记选项中设置标记的draggable属性。true

然后监听dragend标记上的事件 - 您可以使用google.maps.event.addListener(marker, 'dragend', callback);.

然后在您的函数中,使用该方法callback获取标记的位置。getPosition()

正如@geocodezip 所提到的,请参阅API 文档以获取更多参考。

于 2013-09-25T20:05:09.197 回答