Вопрос по javascript, google-maps, google-maps-api-3 – полилинии привязать к дороге с помощью Google Maps API v3

26

В Google Maps API v2 это было легко,

<code>var map = new GMap2(document.getElementById("map"));
    map.setCenter(new GLatLng(53.7877, -2.9832),13)
//    map.addControl(new GLargeMapControl());
//    map.addControl(new GMapTypeControl());
    var dirn = new GDirections();

//      var firstpoint = true;
    var gmarkers = [];
    var gpolys = [];
    var dist = 0;

// == When the user clicks on a the map, get directiobns from that point to itself ==

gmarkers.push(new google.maps.LatLng(53.7877, -2.9832));
gmarkers.push(new google.maps.LatLng(53.9007, -2.9832));
gmarkers.push(new GLatLng(53.600, -2.700));



for (var i = 0; i < gmarkers.length-1; i++) {
    console.log(gmarkers[i]);
                dirn.loadFromWaypoints([gmarkers[i].toUrlValue(6),gmarkers[i+1].toUrlValue(6)],{getPolyline:true});

}


// == when the load event completes, plot the point on the street ==
    GEvent.addListener(dirn,"load", function() {
// snap to last vertex in the polyline
        var n = dirn.getPolyline().getVertexCount();
            map.addOverlay(dirn.getPolyline());
            gpolys.push(dirn.getPolyline());
            dist += dirn.getPolyline().getDistance();
            document.getElementById("distance").innerHTML="Path length: "+(dist/1000).toFixed(2)+" km. "+(dist/1609.344).toFixed(2)+" miles.";
           });
    GEvent.addListener(dirn,"error", function() {
        GLog.write("Failed: "+dirn.getStatus().code);
    });
console.log(dirn);
</code>

В Google API V3 этот способ просто не работает. Есть что-то вроде сервиса маршрутов, но я понятия не имею, как я могу рисовать полилинию через мои точки, и полилиния будет привязана к дороге.

Ваш Ответ

2   ответа
1

Лучше использовать API Snap to Roads и установить для интерполяции значение true, чтобы получить идеальную привязанную полилинию. https://developers.google.com/maps/documentation/roads/snap

Как добавить маркеры (например, & amp; markers = color: red | label: D | 54.5661310, -1.2505580) в URL статической карты?
68

Вы были на правильном пути со службой маршрутов. Вот пример кода:

var map, path = new google.maps.MVCArray(),
    service = new google.maps.DirectionsService(), poly;

function Init() {
  var myOptions = {
    zoom: 17,
    center: new google.maps.LatLng(37.2008385157313, -93.2812106609344),
    mapTypeId: google.maps.MapTypeId.HYBRID,
    mapTypeControlOptions: {
      mapTypeIds: [google.maps.MapTypeId.ROADMAP, google.maps.MapTypeId.HYBRID,
          google.maps.MapTypeId.SATELLITE]
    },
    disableDoubleClickZoom: true,
    scrollwheel: false,
    draggableCursor: "crosshair"
  }

  map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
  poly = new google.maps.Polyline({ map: map });
  google.maps.event.addListener(map, "click", function(evt) {
    if (path.getLength() === 0) {
      path.push(evt.latLng);
      poly.setPath(path);
    } else {
      service.route({
        origin: path.getAt(path.getLength() - 1),
        destination: evt.latLng,
        travelMode: google.maps.DirectionsTravelMode.DRIVING
      }, function(result, status) {
        if (status == google.maps.DirectionsStatus.OK) {
          for (var i = 0, len = result.routes[0].overview_path.length;
              i < len; i++) {
            path.push(result.routes[0].overview_path[i]);
          }
        }
      });
    }
  });
}

Также посмотрите мой рабочий пример:http://people.missouristate.edu/chadkillingsworth/mapsexamples/snaptoroad.htm

Извините, не обращайте внимания на 2-ю половину вышеуказанного вопроса; нашел ответ здесь:stackoverflow.com/questions/2698112/… .. не совсем просто и похоже, что его нужно переработать для v3, но выглядит выполнимо ...
Спасибо, чисто и лаконично.
Если я дважды щелкну по карте, линии начнут хорошо рисоваться. Классная карта, молодец.
@ chad-killingsworth, поэтому, если я правильно читаю это, вы обойдете ограничение максимум в 8 путевых точек, вызывая DirectionsService при каждом щелчке, а затем сохраняя все эти результаты в массиве? Допустим, я хотел автоматически показывать маркер при каждом приращении в 1 милю, аналогично gmaps-pedometer.com; Любая идея, как это сделать с помощью API?
Чад. Возможно, я что-то упустил, но ваш рабочий пример, кажется, не позволяет рисовать какие-либо линии (Левый щелчок перемещает точку обзора карты; Правый щелчок вызывает контекстное меню браузера).

Похожие вопросы