Dlaczego warto przejść na interfejs Routes API?

Deweloperzy z Europejskiego Obszaru Gospodarczego (EOG)

Interfejs Routes API zapewnia większą wydajność obliczania trasy, odległości i czasu podróży, dzięki czemu warto zastąpić nim aplikacje korzystające z interfejsów Directions API i Distance Matrix API. Większość funkcji interfejsu Routes API jest wstecznie zgodna z interfejsami Directions API i Distance Matrix API.

Z tego przewodnika dowiesz się, jakie są najważniejsze różnice między interfejsem Routes API a produktami, które zastępuje, oraz jak wprowadzić niezbędne zmiany. Więcej informacji o innych funkcjach interfejsu Routes API znajdziesz w omówieniu usługi.

Najważniejsze ulepszenia

W tej sekcji opisujemy niektóre ulepszenia, których możesz się spodziewać podczas korzystania z interfejsu Routes API w swoich aplikacjach.

Zwiększone limity żądań

Routes API Compute Route Matrix
  • Maksymalnie 625 elementów, chyba że określisz TRAFFIC_AWARE_OPTIMAL.
  • Maksymalnie 100 elementów z TRAFFIC_AWARE_OPTIMAL. Zobacz Ulepszone ustawienia routingu.
  • Maksymalnie 50 punktów pośrednich (miejsc początkowych i docelowych) przy użyciu identyfikatora miejsca.
Distance Matrix API
  • Maksymalnie 25 punktów początkowych lub 25 miejsc docelowych na żądanie.
  • Maksymalnie 100 elementów (liczba punktów początkowych × liczba punktów docelowych) na żądanie po stronie serwera.

Szybsze odpowiedzi na prośby

Funkcja Macierz wyznaczania tras oferuje te ulepszenia w zakresie opóźnień:

  • Otrzymywać elementy strumieniowe odpowiedzi, zanim cała macierz zostanie obliczona.
  • Używaj masek pól, aby dostosowywać szczegóły odpowiedzi, żądając tylko potrzebnych danych. Jest to sprawdzona metoda, która pomaga też obniżyć koszty.
  • Ulepszone obliczanie tras na podstawie danych o ruchu, dzięki czemu możesz dokonać wyboru między jakością danych a czasem odpowiedzi.

Ulepszenia routingu

Funkcja obliczania trasy oferuje te ulepszenia routingu:

  • informacje o opłatach, a także odległość i szacowany czas dotarcia na miejsce;
  • Trasy dla pojazdów dwukołowych
  • Sprawdź bezpieczeństwo punktów przesiadkowych.
  • Zwiększona dokładność szacowanego czasu dotarcia na miejsce dzięki ustawieniu kierunku podróży i strony drogi dla punktów pośrednich.

Proś tylko o dane, których potrzebujesz

Możesz teraz określić, które pola mają być zwracane, co skróci czas przetwarzania i obniży opłaty.

Routes API
Compute Routes
Compute Route Matrix
W żądaniach musisz używać maski pola, aby określić, które pola mają być zwracane w odpowiedzi. Maskowanie pól zapewnia, że nie będziesz żądać niepotrzebnych danych, co pozwala uniknąć niepotrzebnego czasu przetwarzania i opłat.
Więcej informacji znajdziesz w artykule Wybieranie pól do zwrócenia.
Directions API
Distance Matrix API
Zwraca domyślną listę pól, nawet jeśli aplikacja nie potrzebuje ich w ścisłym tego słowa znaczeniu. Może to spowodować niepotrzebne wydłużenie czasu przetwarzania i naliczenie opłat.

Ulepszone obliczanie tras na podstawie danych o ruchu

Interfejs Routes API obsługuje 3 ustawienia routingu, których możesz używać, aby zachować równowagę między opóźnieniem odpowiedzi a jakością danych podczas wysyłania żądań informacji o ruchu.

Więcej informacji znajdziesz w artykule Konfigurowanie jakości w porównaniu z opóźnieniem.

TRAFFIC_UNAWARE
(domyślnie)
Do obliczania trasy używa średnich danych o ruchu niezależnych od czasu, a nie danych o ruchu na żywo, co zapewnia najmniejsze opóźnienie odpowiedzi. To ustawienie jest równoważne sytuacji, w której w interfejsach Directions API i Distance Matrix API nie jest używany ruch.
TRAFFIC_AWARE
(nowość)
Jakość ruchu na żywo zoptymalizowana pod kątem wydajności, aby zmniejszyć opóźnienie. W przeciwieństwie do TRAFFIC_AWARE_OPTIMAL to ustawienie stosuje optymalizacje, które znacznie zmniejszają czas oczekiwania. To ustawienie jest też nowe w przypadku interfejsu Routes API i nie ma odpowiednika w interfejsach Directions API ani Distance Matrix API.
TRAFFIC_AWARE_OPTIMAL Wysokiej jakości, kompleksowe dane o ruchu. To ustawienie powoduje największe opóźnienie i jest odpowiednikiem ustawienia departure_time w interfejsach Directions API i Distance Matrix API.
To ustawienie jest odpowiednikiem trybu używanego przez maps.google.com i aplikację mobilną Mapy Google.

Porównanie obliczania trasy

W tabeli poniżej porównaliśmy opcje routingu w usługach Routes API, Directions APIDistance Matrix API.

Opcja ruchu Routes API Directions API
Distance Matrix API
Czas oczekiwania
Brak danych o ruchu w czasie rzeczywistym TRAFFIC_UNAWARE departure_time usługa nie jest skonfigurowana Najkrótszy czas oczekiwania spośród 3 trybów.
Zastosowano aktualne warunki na drogach TRAFFIC_AWARE Brak odpowiednika

Nowy tryb dodany przez interfejs Routes API. Zapewnia nieco większe opóźnienie niż TRAFFIC_UNAWARE, ale kosztem niewielkiego pogorszenia jakości ETA.

Ma znacznie mniejsze opóźnienie niż TRAFFIC_AWARE_OPTIMAL.

Zastosowanie wysokiej jakości, kompleksowych danych o natężeniu ruchu na żywo TRAFFIC_AWARE_OPTIMAL departure_time zestaw usług

Odpowiada trybowi używanemu przez maps.google.com i aplikację mobilną Mapy Google.

W przypadku Compute Route Matrix liczba elementów w żądaniu (liczba punktów początkowych × liczba punktów docelowych) nie może przekraczać 100.

Najważniejsze różnice

W tej sekcji znajdziesz najważniejsze różnice między interfejsem Routes API a usługami, które zastępuje, oraz sposoby radzenia sobie z tymi różnicami podczas migracji z tych usług w dotychczasowych aplikacjach.

Dzwonienie do jednej usługi zamiast do dwóch

Routes API Włącz w konsoli interfejsów API tylko jedną usługę, aby aplikacja mogła korzystać z interfejsów Compute Routes i Compute Route Matrix.
Więcej informacji znajdziesz w artykule Konfigurowanie w konsoli interfejsów API Google.
Directions API
Distance Matrix API
Włącz w konsoli interfejsów API 2 usługi: Directions API i Distance Matrix API.

Zużyjesz HTTPS POST

Routes API Przekaż parametry w treści żądania lub w nagłówkach w ramach żądania HTTP POST.
Przykłady znajdziesz w tych artykułach:
Wyznaczanie trasy
Obliczanie macierzy tras
Directions API
Distance Matrix API
Przekazuj parametry adresu URL za pomocą żądania HTTP GET.

Różnice w odpowiedziach dotyczących szacowanego czasu oczekiwania

Interfejs Routes API zwraca szacowany czas przyjazdu i używa właściwości odpowiedzi duration inaczej niż interfejs Directions API i usługi Distance Matrix API, co pokazano w tabeli poniżej.

Rodzaj szacowanego czasu dotarcia na miejsce Routes API Directions API
Distance Matrix API
Szacowany czas dotarcia niezależny od natężenia ruchu.

Ustaw za pomocą TRAFFIC_UNAWARE.

  • Szacowany czas dotarcia zawarty we właściwości odpowiedzi duration.
  • Właściwości odpowiedzi duration i staticDuration zawierają tę samą wartość.

Odpowiada sytuacji, w której w żądaniu nie ustawiono parametru departure_time.

  • Szacowany czas dotarcia zawarty we właściwości odpowiedzi duration.
  • Właściwość odpowiedzi duration_in_traffic nie jest zwracana.
szacowany czas dotarcia na miejsce, który uwzględnia natężenie ruchu w czasie rzeczywistym;

Ustaw za pomocą TRAFFIC_AWARE lub TRAFFIC_AWARE_OPTIMAL.

  • Szacowany czas dotarcia uwzględniający natężenie ruchu w czasie rzeczywistym znajduje się w polu odpowiedzi duration.
  • Właściwość odpowiedzi staticDuration zawiera czas podróży po trasie bez uwzględniania warunków drogowych.
  • Właściwość duration_in_traffic nie jest już zwracana.

Ustaw za pomocą parametru departure_time w żądaniu.

  • Szacowany czas dotarcia uwzględniający natężenie ruchu w czasie rzeczywistym znajduje się w polu odpowiedzi duration_in_traffic.

Punkty pośrednie linii łamanej

Dzięki tej usłudze nie musisz już konwertować współrzędnych geograficznych na punkty pośrednie w formacie linii łamanej. Usługa obsługuje treść żądania POST, więc nie obowiązują już w niej limity długości ciągu URL. Niektórzy użytkownicy interfejsu Distance Matrix API rozwiązali problem z limitami żądań, przekształcając punkty szerokości i długości geograficznej w punkty pośrednie polilinii.

Sformatowane adresy (odwrotne geokodowanie)

Interfejs Routes API nie podaje w odpowiedzi sformatowanych adresów. Aby uzyskać sformatowane adresy, użyj interfejsu Geocoding API, który został stworzony do tego celu i zapewnia wyniki o wyższej jakości.

Dostępne środki transportu

Podobnie jak w przypadku interfejsu Directions API, interfejs Routes API używa trybu DRIVE jako domyślnego, gdy żądanie trasy nie określa trybu podróży. Jeśli jednak żądanie określa tryb podróży dla trasy, interfejs Routes API nie zwraca tablicy dostępnych trybów podróży jako alternatywnych opcji dla żądania. Jeśli Twój przypadek użycia zależy od tej funkcji, zgłoś problem, opisując, jak z niej korzystasz, abyśmy mogli podjąć odpowiednie działania.

XML jako format odpowiedzi

Interfejs Routes API nie udostępnia formatu XML jako formatu odpowiedzi. W internecie znajdziesz wiele konwerterów JSON na XML, które powinny spełnić Twoje oczekiwania.