如何在DirectionsRenderer上获取拖动点

时间:2013-09-06 18:42:15

标签: google-maps

我使用谷歌地图绘制我的路线。我只设置了2分(开始和结束)。问题是我必须将路线发送到下一页。

我知道我可以抓住事件:

        google.maps.event.addListener(directionsDisplay, 'directions_changed', function() {
            $("#full-route-json").val(encode64(JSON.stringify(directionsDisplay.directions.routes[0])));
        });

但它将返回所有步骤。 如何仅为我的起点和终点以及拖动点获取数据,如下所示: enter image description here

1 个答案:

答案 0 :(得分:2)

AFAIK没有实现的方法来访问这些点(标记)。

但这些标记存储在DirectionsRenderer-instance的属性中。

以下代码将为您提供这些详细信息(请注意此代码现在可以使用,但是当API更改时可能会失败)

  google.maps.event.addListener(directionsDisplay, 'directions_changed', function() {
    var that=this;
    setTimeout(function(){//we need a short delay
      for(var k in that){//iterate over all properties
        if(typeof that[k].markers!='undefined'){//find the desired property
          var markers=that[k].markers,arr=[];
          for(var i=0;i<markers.length;++i){//collect the data
            arr.push(markers[i].position.toString());
        }
        alert(arr.join(',\n'));
      }
    }},100)
  });