Когда API маршрутов вычисляет маршрут, он принимает предоставленные вами путевые точки и параметры конфигурации в качестве входных данных. Затем API возвращает ответ, содержащий маршрут по умолчанию и один или несколько альтернативных маршрутов.
Ваш ответ может включать различные типы маршрутов и другие данные в зависимости от запрошенных вами полей:
Чтобы включить это в ответ | См. эту документацию |
---|---|
Самый экономичный маршрут в зависимости от типа двигателя транспортного средства. | Настройте экологически чистые маршруты |
До трех альтернативных маршрутов | Запросить альтернативные маршруты |
Полилиния для всего маршрута, для каждого участка маршрута и для каждого шага участка. | Запросить полилинии маршрута |
Ориентировочная стоимость проезда с учетом любых скидок на оплату проезда или пропусков, доступных водителю или транспортному средству. | Рассчитать стоимость проезда |
Локализованные ответы по языковым кодам и единицам измерения (британская или метрическая). | Запросить локализованные значения |
Чтобы отформатировать инструкции по навигации в виде текстовой строки HTML, добавьте HTML_FORMATTED_NAVIGATION_INSTRUCTIONS в extraComputations . | Дополнительные вычисления |
Полный список параметров ввода см. в разделе Доступные параметры маршрута и в теле запроса .
Используя ответ, вы можете предоставить своим клиентам информацию, необходимую для выбора соответствующего их требованиям маршрута.
О масках полей
Когда вы вызываете метод для вычисления маршрута, вы должны указать маску поля, которая определяет, какие поля вы хотите вернуть в ответе. Не существует списка возвращаемых полей по умолчанию. Если вы опустите этот список, методы вернут ошибку.
В примерах в этом документе показан весь объект ответа без учета масок полей. В производственной среде ваш ответ будет включать только те поля, которые вы явно указали в маске поля.
Дополнительные сведения см. в разделе Выбор информации для возврата .
Об отображении авторских прав
При отображении результатов пользователям необходимо включить следующее заявление об авторских правах:
Powered by Google, © YEAR Google
Например:
Powered by Google, ©2023 Google
О маршрутах, этапах и шагах
Прежде чем просматривать ответ, возвращаемый API маршрутов, вы должны иметь представление о компонентах, составляющих маршрут:
Ваш ответ может содержать информацию о каждом из этих компонентов маршрута:
Маршрут : вся поездка от исходной путевой точки через все промежуточные путевые точки до конечной путевой точки. Маршрут состоит из одного или нескольких этапов .
Этап : Путь от одной путевой точки маршрута до следующей путевой точки маршрута. Каждый этап состоит из одного или нескольких дискретных шагов .
Маршрут содержит отдельный участок пути от каждой путевой точки к следующей. Например, если маршрут содержит одну точку отправления и одну точку назначения, то маршрут содержит один участок. Для каждой дополнительной путевой точки, которую вы добавляете в маршрут после пункта отправления и назначения, называемой промежуточной путевой точкой , API добавляет отдельный участок.
API не добавляет участок для транзитной промежуточной точки. Например, маршрут, который содержит исходную путевую точку, транзитную промежуточную путевую точку и путевую точку назначения, содержит только один участок от исходной точки до пункта назначения при прохождении через путевую точку. Дополнительную информацию о транзитных путевых точках см. в разделе Определение транзитной путевой точки .
Шаг : Одна инструкция на участке маршрута. Шаг — это самая атомарная единица маршрута. Например, шаг может означать «Поверните налево на Мейн-стрит».
Что в ответе
Объект JSON , представляющий ответ API, содержит следующие свойства верхнего уровня:
routes
, массив элементов типа Route . Массивroutes
содержит один элемент для каждого маршрута, возвращаемого API. Массив может содержать максимум пять элементов: маршрут по умолчанию, экологически чистый маршрут и до трех альтернативных маршрутов.geocodingResults
— массив элементов типа GeocodingResults . Для каждого местоположения в запросе (исходная, конечная или промежуточная путевая точка), указанного вами в виде строки адреса или кода Plus , API выполняет поиск по идентификатору места. Каждый элемент этого массива содержит идентификатор места, соответствующий местоположению. Местоположение в запросе, указанное в виде идентификатора места или координат широты/долготы, не включается. Если вы указали все местоположения, используя идентификаторы мест или координаты широты и долготы, этот массив не предоставляется.fallbackInfo
типа FallbackInfo . Если API не может вычислить маршрут на основе всех входных свойств, он может вернуться к использованию другого способа расчета. Если используется резервный режим, это поле содержит подробную информацию о резервном ответе. В противном случае это поле не установлено.
Ответ имеет вид:
{ // The routes array. "routes": [ { object (Route) } ], // The place ID lookup results. "geocodingResults": [ { object (GeocodedWaypoint) } ], // The fallback property. "fallbackInfo": { object (FallbackInfo) } }
Расшифровать массив маршрутов
Ответ содержит массив routes
, где каждый элемент массива имеет тип Route . Каждый элемент массива представляет собой весь маршрут от пункта отправления до пункта назначения. API всегда возвращает хотя бы один маршрут, называемый маршрутом по умолчанию.
Вы можете запросить дополнительные маршруты. Если вы запрашиваете экологически чистый маршрут , то массив может содержать два элемента: маршрут по умолчанию и экологический маршрут. Или задайте для computeAlternativeRoutes
значение true
в запросе, чтобы добавить к ответу до трех альтернативных маршрутов.
Каждый маршрут в массиве идентифицируется свойством массива routeLabels
:
Ценить | Описание |
---|---|
DEFAULT_ROUTE | Определяет маршрут по умолчанию. |
FUEL_EFFICIENT | Определяет экологически чистый маршрут. |
DEFAULT_ROUTE_ALTERNATE | Я указываю альтернативный маршрут. |
Массив legs
содержит определение каждого участка маршрута. Остальные свойства, такие как distanceMeters
, duration
и polyline,
содержат информацию о маршруте в целом:
{ "routeLabels": [ enum (RouteLabel) ], "legs": [ { object (RouteLeg) } ], "distanceMeters": integer, "duration": string, "routeLabels": [string], "staticDuration": string, "polyline": { object (Polyline) }, "description": string, "warnings": [ string ], "viewport": { object (Viewport) }, "travelAdvisory": { object (RouteTravelAdvisory) } "routeToken": string }
Из-за текущих условий вождения и других факторов маршрут по умолчанию и экологически чистый маршрут могут совпадать. В данном случае массив routeLabels
содержит обе метки: DEFAULT_ROUTE
и FUEL_EFFICIENT
.
{ "routes": [ { "routeLabels": [ "DEFAULT_ROUTE", "FUEL_EFFICIENT" ], … } ] }
Понимание массива ног
Каждый route
в ответе содержит массив legs
, где каждый элемент массива legs
имеет тип RouteLeg . Каждый участок в массиве определяет путь от одной путевой точки к следующей путевой точке маршрута. Маршрут всегда содержит хотя бы один участок.
Свойство legs
содержит определение каждого шага вдоль участка в массиве steps
. Остальные свойства, такие как distanceMeters
, duration
и polyline
содержат информацию об участке.
{ "distanceMeters": integer, "duration": string, "staticDuration": string, "polyline": { object (Polyline) }, "startLocation": { object (Location) }, "endLocation": { object (Location) }, "steps": [ { object (RouteLegStep) } ], "travelAdvisory": { object (RouteLegTravelAdvisory) } }
Понимание массива шагов
Каждая часть ответа содержит массив steps
, где каждый элемент массива steps
имеет тип RouteLegStep . Шаг соответствует одной инструкции по ноге. Нога всегда содержит хотя бы один шаг.
Каждый элемент массива steps
включает свойство navigationInstruction
типа NavigationInstruction , которое содержит инструкцию шага. Например:
"navigationInstruction": { "maneuver": "TURN_LEFT", "instructions": "Turn left toward Frontage Rd" }
instructions
могут содержать дополнительную информацию об этом шаге. Например:
"navigationInstruction": { "maneuver": "TURN_SLIGHT_LEFT", "instructions": "Slight left (signs for I-90 W/Worcester)nParts of this road may be closed at certain times or days" }
Остальные свойства шага описывают информацию о шаге, такую как distanceMeters
, duration
и polyline
:
{ "distanceMeters": integer, "staticDuration": string, "polyline": { object (Polyline) }, "startLocation": { object (Location) }, "endLocation": { object (Location) }, "navigationInstruction": { object (NavigationInstruction) } }
Укажите язык пошаговых инструкций
API возвращает информацию о маршруте на местном языке, транслитерированную в скрипт, читаемый пользователем, при необходимости, с соблюдением предпочтительного языка. Все компоненты адреса возвращаются на одном языке.
Используйте параметр
languageCode
запроса , чтобы явно указать язык маршрута из списка поддерживаемых языков . Google часто обновляет поддерживаемые языки, поэтому этот список может быть неполным.Если имя недоступно на указанном языке, API использует наиболее близкое совпадение.
Указанный язык может влиять на набор результатов, которые API выбирает для возврата, и порядок их возврата. Геокодер интерпретирует сокращения по-разному в зависимости от языка, например сокращения типов улиц или синонимы, которые могут быть допустимы для одного языка, но недопустимы для другого. Например, utca и tér на венгерском языке являются синонимами улицы.
Понимание массива geocodingResults
Для каждого местоположения в запросе (исходная, конечная или промежуточная точка маршрута), указанного в виде строки адреса или кода Plus , API пытается найти наиболее подходящее местоположение, имеющее соответствующий идентификатор места. Каждый элемент массива geocodingResults
содержит поле placeID
, содержащее местоположение в качестве идентификатора места, и поле type
, определяющее тип местоположения, например street_address
, premise
или airport
.
Массив geocodingResults
содержит три поля:
origin
: если он был указан в виде строки адреса или кода Plus, идентификатор места происхождения. В противном случае это поле опускается в ответе.destination
: если он был указан в виде строки адреса или кода Plus, идентификатор места пункта назначения. В противном случае это поле опускается в ответе.intermediates
: массив, содержащий идентификатор места любых промежуточных путевых точек, указанных в виде строки адреса или кода Plus. Если вы укажете промежуточную точку, используя идентификатор места или координаты широты и долготы, она будет опущена в ответе. Используйте свойствоintermediateWaypointRequestIndex
в ответе, чтобы определить, какая промежуточная путевая точка в запросе соответствует идентификатору места в ответе.
"geocodingResults": { "origin": { "geocoderStatus": {}, "type": [ enum (Type) ], "placeId": string }, "destination": { "geocoderStatus": {}, "type": [ enum (Type) ], "placeId": string }, "intermediates": [ { "geocoderStatus": {}, "intermediateWaypointRequestIndex": integer, "type": [ enum (Type) ], "placeId": string }, { "geocoderStatus": {}, "intermediateWaypointRequestIndex": integer, "type": [ enum (Type) ], "placeId": string } ] }
Понимание значений локализованных ответов
Значения локализованного ответа — это дополнительное поле ответа, которое предоставляет локализованный текст для возвращаемых значений параметров. Локализованный текст содержит информацию о продолжительности поездки, расстоянии и системе единиц измерения (метрической или британской). Вы запрашиваете локализованные значения, используя маску поля, и можете либо указать язык и систему единиц, либо использовать значения, полученные API. Дополнительные сведения см. в разделе LocalizedValues .
Например, если вы укажете код языка для немецких (de) и имперских единиц, вы получите значение для distanceMeters
49889,7, а также локализованный текст, указывающий это измерение расстояния в немецких и имперских единицах, то есть «31 Meile».
Вот пример того, что вы увидите для локализованных значений:
{ "localized_values": { "distance": { "text": "31,0 Meile/n" }, "duration": { "text": 38 Minuten}. "static_duration": { "text": 36 Minuten}. } }
Если вы не укажете язык или систему единиц, API определит язык и единицы измерения следующим образом:
- Метод
ComputeRoutes
определяет единицы местоположения и расстояния от исходной путевой точки. Таким образом, для запроса маршрутизации в США API определяет языкen-US
иIMPERIAL
единицы измерения. - По умолчанию метод
ComputeRouteMatrix
использует язык en-US и МЕТРИЧЕСКИЕ единицы измерения.
Когда API маршрутов вычисляет маршрут, он принимает предоставленные вами путевые точки и параметры конфигурации в качестве входных данных. Затем API возвращает ответ, содержащий маршрут по умолчанию и один или несколько альтернативных маршрутов.
Ваш ответ может включать различные типы маршрутов и другие данные в зависимости от запрошенных вами полей:
Чтобы включить это в ответ | См. эту документацию |
---|---|
Самый экономичный маршрут в зависимости от типа двигателя транспортного средства. | Настройте экологически чистые маршруты |
До трех альтернативных маршрутов | Запросить альтернативные маршруты |
Полилиния для всего маршрута, для каждого участка маршрута и для каждого шага участка. | Запросить полилинии маршрута |
Ориентировочная стоимость проезда с учетом любых скидок на оплату проезда или пропусков, доступных водителю или транспортному средству. | Рассчитать стоимость проезда |
Локализованные ответы по языковым кодам и единицам измерения (британская или метрическая). | Запросить локализованные значения |
Чтобы отформатировать инструкции по навигации в виде текстовой строки HTML, добавьте HTML_FORMATTED_NAVIGATION_INSTRUCTIONS в extraComputations . | Дополнительные вычисления |
Полный список параметров ввода см. в разделе Доступные параметры маршрута и в теле запроса .
Используя ответ, вы можете предоставить своим клиентам информацию, необходимую для выбора соответствующего их требованиям маршрута.
О масках полей
Когда вы вызываете метод для вычисления маршрута, вы должны указать маску поля, которая определяет, какие поля вы хотите вернуть в ответе. Не существует списка возвращаемых полей по умолчанию. Если вы опустите этот список, методы вернут ошибку.
В примерах в этом документе показан весь объект ответа без учета масок полей. В производственной среде ваш ответ будет включать только те поля, которые вы явно указали в маске поля.
Дополнительные сведения см. в разделе Выбор информации для возврата .
Об отображении авторских прав
При отображении результатов пользователям необходимо включить следующее заявление об авторских правах:
Powered by Google, © YEAR Google
Например:
Powered by Google, ©2023 Google
О маршрутах, этапах и шагах
Прежде чем просматривать ответ, возвращаемый API маршрутов, вы должны иметь представление о компонентах, составляющих маршрут:
Ваш ответ может содержать информацию о каждом из этих компонентов маршрута:
Маршрут : вся поездка от исходной путевой точки через все промежуточные путевые точки до конечной путевой точки. Маршрут состоит из одного или нескольких этапов .
Этап : Путь от одной путевой точки маршрута до следующей путевой точки маршрута. Каждый этап состоит из одного или нескольких дискретных шагов .
Маршрут содержит отдельный участок пути от каждой путевой точки к следующей. Например, если маршрут содержит одну точку отправления и одну точку назначения, то маршрут содержит один участок. Для каждой дополнительной путевой точки, которую вы добавляете в маршрут после пункта отправления и назначения, называемой промежуточной путевой точкой , API добавляет отдельный участок.
API не добавляет участок для транзитной промежуточной точки. Например, маршрут, который содержит исходную путевую точку, транзитную промежуточную путевую точку и путевую точку назначения, содержит только один участок от исходной точки до пункта назначения при прохождении через путевую точку. Дополнительную информацию о транзитных путевых точках см. в разделе Определение транзитной путевой точки .
Шаг : Одна инструкция на участке маршрута. Шаг — это самая атомарная единица маршрута. Например, шаг может означать «Поверните налево на Мейн-стрит».
Что в ответе
Объект JSON , представляющий ответ API, содержит следующие свойства верхнего уровня:
routes
, массив элементов типа Route . Массивroutes
содержит один элемент для каждого маршрута, возвращаемого API. Массив может содержать максимум пять элементов: маршрут по умолчанию, экологически чистый маршрут и до трех альтернативных маршрутов.geocodingResults
— массив элементов типа GeocodingResults . Для каждого местоположения в запросе (исходная, конечная или промежуточная путевая точка), указанного вами в виде строки адреса или кода Plus , API выполняет поиск по идентификатору места. Каждый элемент этого массива содержит идентификатор места, соответствующий местоположению. Местоположение в запросе, указанное в виде идентификатора места или координат широты/долготы, не включается. Если вы указали все местоположения, используя идентификаторы мест или координаты широты и долготы, этот массив не предоставляется.fallbackInfo
типа FallbackInfo . Если API не может вычислить маршрут на основе всех входных свойств, он может вернуться к использованию другого способа расчета. Если используется резервный режим, это поле содержит подробную информацию о резервном ответе. В противном случае это поле не установлено.
Ответ имеет вид:
{ // The routes array. "routes": [ { object (Route) } ], // The place ID lookup results. "geocodingResults": [ { object (GeocodedWaypoint) } ], // The fallback property. "fallbackInfo": { object (FallbackInfo) } }
Расшифровать массив маршрутов
Ответ содержит массив routes
, где каждый элемент массива имеет тип Route . Каждый элемент массива представляет собой весь маршрут от пункта отправления до пункта назначения. API всегда возвращает хотя бы один маршрут, называемый маршрутом по умолчанию.
Вы можете запросить дополнительные маршруты. Если вы запрашиваете экологически чистый маршрут , то массив может содержать два элемента: маршрут по умолчанию и экологический маршрут. Или задайте для computeAlternativeRoutes
значение true
в запросе, чтобы добавить к ответу до трех альтернативных маршрутов.
Каждый маршрут в массиве идентифицируется свойством массива routeLabels
:
Ценить | Описание |
---|---|
DEFAULT_ROUTE | Определяет маршрут по умолчанию. |
FUEL_EFFICIENT | Определяет экологически чистый маршрут. |
DEFAULT_ROUTE_ALTERNATE | Я указываю альтернативный маршрут. |
Массив legs
содержит определение каждого участка маршрута. Остальные свойства, такие как distanceMeters
, duration
и polyline,
содержат информацию о маршруте в целом:
{ "routeLabels": [ enum (RouteLabel) ], "legs": [ { object (RouteLeg) } ], "distanceMeters": integer, "duration": string, "routeLabels": [string], "staticDuration": string, "polyline": { object (Polyline) }, "description": string, "warnings": [ string ], "viewport": { object (Viewport) }, "travelAdvisory": { object (RouteTravelAdvisory) } "routeToken": string }
Из-за текущих условий вождения и других факторов маршрут по умолчанию и экологически чистый маршрут могут совпадать. В данном случае массив routeLabels
содержит обе метки: DEFAULT_ROUTE
и FUEL_EFFICIENT
.
{ "routes": [ { "routeLabels": [ "DEFAULT_ROUTE", "FUEL_EFFICIENT" ], … } ] }
Понимание массива ног
Каждый route
в ответе содержит массив legs
, где каждый элемент массива legs
имеет тип RouteLeg . Каждый участок в массиве определяет путь от одной путевой точки к следующей путевой точке маршрута. Маршрут всегда содержит хотя бы один участок.
Свойство legs
содержит определение каждого шага вдоль участка в массиве steps
. Остальные свойства, такие как distanceMeters
, duration
и polyline
содержат информацию об участке.
{ "distanceMeters": integer, "duration": string, "staticDuration": string, "polyline": { object (Polyline) }, "startLocation": { object (Location) }, "endLocation": { object (Location) }, "steps": [ { object (RouteLegStep) } ], "travelAdvisory": { object (RouteLegTravelAdvisory) } }
Понимание массива шагов
Каждая часть ответа содержит массив steps
, где каждый элемент массива steps
имеет тип RouteLegStep . Шаг соответствует одной инструкции по ноге. Нога всегда содержит хотя бы один шаг.
Каждый элемент массива steps
включает свойство navigationInstruction
типа NavigationInstruction , которое содержит инструкцию шага. Например:
"navigationInstruction": { "maneuver": "TURN_LEFT", "instructions": "Turn left toward Frontage Rd" }
instructions
могут содержать дополнительную информацию об этом шаге. Например:
"navigationInstruction": { "maneuver": "TURN_SLIGHT_LEFT", "instructions": "Slight left (signs for I-90 W/Worcester)nParts of this road may be closed at certain times or days" }
Остальные свойства шага описывают информацию о шаге, такую как distanceMeters
, duration
и polyline
:
{ "distanceMeters": integer, "staticDuration": string, "polyline": { object (Polyline) }, "startLocation": { object (Location) }, "endLocation": { object (Location) }, "navigationInstruction": { object (NavigationInstruction) } }
Укажите язык пошаговых инструкций
API возвращает информацию о маршруте на местном языке, транслитерированную в скрипт, читаемый пользователем, при необходимости, с соблюдением предпочтительного языка. Все компоненты адреса возвращаются на одном языке.
Используйте параметр
languageCode
запроса , чтобы явно указать язык маршрута из списка поддерживаемых языков . Google часто обновляет поддерживаемые языки, поэтому этот список может быть неполным.Если имя недоступно на указанном языке, API использует наиболее близкое совпадение.
Указанный язык может влиять на набор результатов, которые API выбирает для возврата, и порядок их возврата. Геокодер интерпретирует сокращения по-разному в зависимости от языка, например сокращения типов улиц или синонимы, которые могут быть допустимы для одного языка, но недопустимы для другого. Например, utca и tér на венгерском языке являются синонимами улицы.
Понимание массива geocodingResults
Для каждого местоположения в запросе (исходная, конечная или промежуточная точка маршрута), указанного в виде строки адреса или кода Plus , API пытается найти наиболее подходящее местоположение, имеющее соответствующий идентификатор места. Каждый элемент массива geocodingResults
содержит поле placeID
, содержащее местоположение в качестве идентификатора места, и поле type
, определяющее тип местоположения, например street_address
, premise
или airport
.
Массив geocodingResults
содержит три поля:
origin
: если он был указан в виде строки адреса или кода Plus, идентификатор места происхождения. В противном случае это поле опускается в ответе.destination
: если он был указан в виде строки адреса или кода Plus, идентификатор места пункта назначения. В противном случае это поле опускается в ответе.intermediates
: массив, содержащий идентификатор места любых промежуточных путевых точек, указанных в виде строки адреса или кода Plus. Если вы укажете промежуточную точку, используя идентификатор места или координаты широты и долготы, она будет опущена в ответе. Используйте свойствоintermediateWaypointRequestIndex
в ответе, чтобы определить, какая промежуточная путевая точка в запросе соответствует идентификатору места в ответе.
"geocodingResults": { "origin": { "geocoderStatus": {}, "type": [ enum (Type) ], "placeId": string }, "destination": { "geocoderStatus": {}, "type": [ enum (Type) ], "placeId": string }, "intermediates": [ { "geocoderStatus": {}, "intermediateWaypointRequestIndex": integer, "type": [ enum (Type) ], "placeId": string }, { "geocoderStatus": {}, "intermediateWaypointRequestIndex": integer, "type": [ enum (Type) ], "placeId": string } ] }
Понимание значений локализованных ответов
Значения локализованного ответа — это дополнительное поле ответа, которое предоставляет локализованный текст для возвращаемых значений параметров. Локализованный текст содержит информацию о продолжительности поездки, расстоянии и системе единиц измерения (метрической или британской). Вы запрашиваете локализованные значения, используя маску поля, и можете либо указать язык и систему единиц, либо использовать значения, полученные API. Дополнительные сведения см. в разделе LocalizedValues .
Например, если вы укажете код языка для немецких (de) и имперских единиц, вы получите значение для distanceMeters
49889,7, а также локализованный текст, указывающий это измерение расстояния в немецких и имперских единицах, то есть «31 Meile».
Вот пример того, что вы увидите для локализованных значений:
{ "localized_values": { "distance": { "text": "31,0 Meile/n" }, "duration": { "text": 38 Minuten}. "static_duration": { "text": 36 Minuten}. } }
Если вы не укажете язык или систему единиц, API определит язык и единицы измерения следующим образом:
- Метод
ComputeRoutes
определяет единицы местоположения и расстояния от исходной путевой точки. Таким образом, для запроса маршрутизации в США API определяет языкen-US
иIMPERIAL
единицы измерения. - По умолчанию метод
ComputeRouteMatrix
использует язык en-US и МЕТРИЧЕСКИЕ единицы измерения.
Когда API маршрутов вычисляет маршрут, он принимает предоставленные вами путевые точки и параметры конфигурации в качестве входных данных. Затем API возвращает ответ, содержащий маршрут по умолчанию и один или несколько альтернативных маршрутов.
Ваш ответ может включать различные типы маршрутов и другие данные в зависимости от запрошенных вами полей:
Чтобы включить это в ответ | См. эту документацию |
---|---|
Самый экономичный маршрут в зависимости от типа двигателя транспортного средства. | Настройте экологически чистые маршруты |
До трех альтернативных маршрутов | Запросить альтернативные маршруты |
Полилиния для всего маршрута, для каждого участка маршрута и для каждого шага участка. | Запросить полилинии маршрута |
Ориентировочная стоимость проезда с учетом любых скидок на оплату проезда или пропусков, доступных водителю или транспортному средству. | Рассчитать стоимость проезда |
Локализованные ответы по языковым кодам и единицам измерения (британская или метрическая). | Запросить локализованные значения |
Чтобы отформатировать инструкции по навигации в виде текстовой строки HTML, добавьте HTML_FORMATTED_NAVIGATION_INSTRUCTIONS в extraComputations . | Дополнительные вычисления |
Полный список параметров ввода см. в разделе Доступные параметры маршрута и в теле запроса .
Используя ответ, вы можете предоставить своим клиентам информацию, необходимую для выбора соответствующего их требованиям маршрута.
О масках полей
Когда вы вызываете метод для вычисления маршрута, вы должны указать маску поля, которая определяет, какие поля вы хотите вернуть в ответе. Не существует списка возвращаемых полей по умолчанию. Если вы опустите этот список, методы вернут ошибку.
В примерах в этом документе показан весь объект ответа без учета масок полей. В производственной среде ваш ответ будет включать только те поля, которые вы явно указали в маске поля.
Дополнительные сведения см. в разделе Выбор информации для возврата .
Об отображении авторских прав
При отображении результатов пользователям необходимо включить следующее заявление об авторских правах:
Powered by Google, © YEAR Google
Например:
Powered by Google, ©2023 Google
О маршрутах, этапах и шагах
Прежде чем просматривать ответ, возвращаемый API маршрутов, вы должны иметь представление о компонентах, составляющих маршрут:
Ваш ответ может содержать информацию о каждом из этих компонентов маршрута:
Маршрут : вся поездка от исходной путевой точки через все промежуточные путевые точки до конечной путевой точки. Маршрут состоит из одного или нескольких этапов .
Этап : Путь от одной путевой точки маршрута до следующей путевой точки маршрута. Каждый этап состоит из одного или нескольких дискретных шагов .
Маршрут содержит отдельный участок пути от каждой путевой точки к следующей. Например, если маршрут содержит одну точку отправления и одну точку назначения, то маршрут содержит один участок. Для каждой дополнительной путевой точки, которую вы добавляете в маршрут после пункта отправления и назначения, называемой промежуточной путевой точкой , API добавляет отдельный участок.
API не добавляет участок для транзитной промежуточной точки. Например, маршрут, который содержит исходную путевую точку, транзитную промежуточную путевую точку и путевую точку назначения, содержит только один участок от исходной точки до пункта назначения при прохождении через путевую точку. Дополнительную информацию о транзитных путевых точках см. в разделе Определение транзитной путевой точки .
Шаг : Одна инструкция на участке маршрута. Шаг — это самая атомарная единица маршрута. Например, шаг может означать «Поверните налево на Мейн-стрит».
Что в ответе
Объект JSON , представляющий ответ API, содержит следующие свойства верхнего уровня:
routes
, массив элементов типа Route . Массивroutes
содержит один элемент для каждого маршрута, возвращаемого API. Массив может содержать максимум пять элементов: маршрут по умолчанию, экологически чистый маршрут и до трех альтернативных маршрутов.geocodingResults
— массив элементов типа GeocodingResults . Для каждого местоположения в запросе (исходная, конечная или промежуточная путевая точка), указанного вами в виде строки адреса или кода Plus , API выполняет поиск по идентификатору места. Каждый элемент этого массива содержит идентификатор места, соответствующий местоположению. Местоположение в запросе, указанное в виде идентификатора места или координат широты/долготы, не включается. Если вы указали все местоположения, используя идентификаторы мест или координаты широты и долготы, этот массив не предоставляется.fallbackInfo
типа FallbackInfo . Если API не может вычислить маршрут на основе всех входных свойств, он может вернуться к использованию другого способа расчета. Если используется резервный режим, это поле содержит подробную информацию о резервном ответе. В противном случае это поле не установлено.
Ответ имеет вид:
{ // The routes array. "routes": [ { object (Route) } ], // The place ID lookup results. "geocodingResults": [ { object (GeocodedWaypoint) } ], // The fallback property. "fallbackInfo": { object (FallbackInfo) } }
Расшифровать массив маршрутов
Ответ содержит массив routes
, где каждый элемент массива имеет тип Route . Каждый элемент массива представляет собой весь маршрут от пункта отправления до пункта назначения. API всегда возвращает хотя бы один маршрут, называемый маршрутом по умолчанию.
Вы можете запросить дополнительные маршруты. Если вы запрашиваете экологически чистый маршрут , то массив может содержать два элемента: маршрут по умолчанию и экологический маршрут. Или задайте для computeAlternativeRoutes
значение true
в запросе, чтобы добавить к ответу до трех альтернативных маршрутов.
Каждый маршрут в массиве идентифицируется свойством массива routeLabels
:
Ценить | Описание |
---|---|
DEFAULT_ROUTE | Определяет маршрут по умолчанию. |
FUEL_EFFICIENT | Определяет экологически чистый маршрут. |
DEFAULT_ROUTE_ALTERNATE | Я указываю альтернативный маршрут. |
Массив legs
содержит определение каждого участка маршрута. Остальные свойства, такие как distanceMeters
, duration
и polyline,
содержат информацию о маршруте в целом:
{ "routeLabels": [ enum (RouteLabel) ], "legs": [ { object (RouteLeg) } ], "distanceMeters": integer, "duration": string, "routeLabels": [string], "staticDuration": string, "polyline": { object (Polyline) }, "description": string, "warnings": [ string ], "viewport": { object (Viewport) }, "travelAdvisory": { object (RouteTravelAdvisory) } "routeToken": string }
Из-за текущих условий вождения и других факторов маршрут по умолчанию и экологически чистый маршрут могут совпадать. В данном случае массив routeLabels
содержит обе метки: DEFAULT_ROUTE
и FUEL_EFFICIENT
.
{ "routes": [ { "routeLabels": [ "DEFAULT_ROUTE", "FUEL_EFFICIENT" ], … } ] }
Понимание массива ног
Каждый route
в ответе содержит массив legs
, где каждый элемент массива legs
имеет тип RouteLeg . Каждый участок в массиве определяет путь от одной путевой точки к следующей путевой точке маршрута. Маршрут всегда содержит хотя бы один участок.
Свойство legs
содержит определение каждого шага вдоль участка в массиве steps
. Остальные свойства, такие как distanceMeters
, duration
и polyline
содержат информацию об участке.
{ "distanceMeters": integer, "duration": string, "staticDuration": string, "polyline": { object (Polyline) }, "startLocation": { object (Location) }, "endLocation": { object (Location) }, "steps": [ { object (RouteLegStep) } ], "travelAdvisory": { object (RouteLegTravelAdvisory) } }
Понимание массива шагов
Каждая часть ответа содержит массив steps
, где каждый элемент массива steps
имеет тип RouteLegStep . Шаг соответствует одной инструкции по ноге. Нога всегда содержит хотя бы один шаг.
Каждый элемент массива steps
включает свойство navigationInstruction
типа NavigationInstruction , которое содержит инструкцию шага. Например:
"navigationInstruction": { "maneuver": "TURN_LEFT", "instructions": "Turn left toward Frontage Rd" }
instructions
могут содержать дополнительную информацию об этом шаге. Например:
"navigationInstruction": { "maneuver": "TURN_SLIGHT_LEFT", "instructions": "Slight left (signs for I-90 W/Worcester)nParts of this road may be closed at certain times or days" }
Остальные свойства шага описывают информацию о шаге, такую как distanceMeters
, duration
и polyline
:
{ "distanceMeters": integer, "staticDuration": string, "polyline": { object (Polyline) }, "startLocation": { object (Location) }, "endLocation": { object (Location) }, "navigationInstruction": { object (NavigationInstruction) } }
Укажите язык пошаговых инструкций
API возвращает информацию о маршруте на местном языке, транслитерированную в сценарий, читаемый пользователем, при необходимости, с соблюдением предпочтительного языка. Все компоненты адреса возвращаются на одном языке.
Используйте параметр
languageCode
запроса , чтобы явно указать язык маршрута из списка поддерживаемых языков . Google часто обновляет поддерживаемые языки, поэтому этот список может быть неполным.Если имя недоступно на указанном языке, API использует наиболее близкое совпадение.
Указанный язык может влиять на набор результатов, которые API выбирает для возврата, и порядок их возврата. Геокодер интерпретирует сокращения по-разному в зависимости от языка, например сокращения типов улиц или синонимы, которые могут быть допустимы на одном языке, но недопустимы на другом. Например, utca и tér на венгерском языке являются синонимами улицы.
Понимание массива geocodingResults
Для каждого местоположения в запросе (исходная, конечная или промежуточная точка маршрута), указанного в виде строки адреса или кода Plus , API пытается найти наиболее подходящее местоположение, имеющее соответствующий идентификатор места. Каждый элемент массива geocodingResults
содержит поле placeID
, содержащее местоположение в качестве идентификатора места, и поле type
, определяющее тип местоположения, например street_address
, premise
или airport
.
Массив geocodingResults
содержит три поля:
origin
: если он был указан в виде строки адреса или кода Plus, идентификатор места происхождения. В противном случае это поле опускается в ответе.destination
: если он был указан в виде строки адреса или кода Plus, идентификатор места пункта назначения. В противном случае это поле опускается в ответе.intermediates
: массив, содержащий идентификатор места любых промежуточных путевых точек, указанных в виде строки адреса или кода Plus. Если вы укажете промежуточную точку, используя идентификатор места или координаты широты и долготы, она будет опущена в ответе. Используйте свойствоintermediateWaypointRequestIndex
в ответе, чтобы определить, какая промежуточная путевая точка в запросе соответствует идентификатору места в ответе.
"geocodingResults": { "origin": { "geocoderStatus": {}, "type": [ enum (Type) ], "placeId": string }, "destination": { "geocoderStatus": {}, "type": [ enum (Type) ], "placeId": string }, "intermediates": [ { "geocoderStatus": {}, "intermediateWaypointRequestIndex": integer, "type": [ enum (Type) ], "placeId": string }, { "geocoderStatus": {}, "intermediateWaypointRequestIndex": integer, "type": [ enum (Type) ], "placeId": string } ] }
Понять локализованные значения ответа
Локализованные значения ответа - это дополнительное поле ответа, которое предоставляет локализованный текст для возвращаемых значений параметров. Локализованный текст предоставляется для продолжительности поездки, расстояния и единичной системы (метрика или имперства). Вы запросите локализованные значения, используя полевую маску, и можете указать языковую и единичную систему, либо использовать значения, выведенные API. Для получения подробной информации см. LocalizedValues .
Например, если вы указываете языковой код для немецких (DE) и имперских подразделений, вы получаете значение для distanceMeters
49889,7, а также локализованный текст, предоставляя это измерение расстояния в немецких и имперских единицах, так что «31 мл».
Вот пример того, что вы увидите для локализованных значений:
{ "localized_values": { "distance": { "text": "31,0 Meile/n" }, "duration": { "text": 38 Minuten}. "static_duration": { "text": 36 Minuten}. } }
Если вы не указываете языковую или единичную систему, API делает язык и единицы следующим образом:
- Метод
ComputeRoutes
позволяет единицам местоположения и расстояния с исходной путевой точки. Таким образом, для запроса на маршрутизацию в США API делает языкen-US
иIMPERIAL
подразделения. - Метод
ComputeRouteMatrix
по умолчанию по умолчанию языка и метрических единиц.
Когда API Routes вычисляет маршрут, он принимает путевые точки и параметры конфигурации, которые вы предоставляете в качестве ввода. Затем API возвращает ответ, который содержит маршрут по умолчанию и один или несколько альтернативных маршрутов.
Ваш ответ может включать различные типы маршрутов и другие данные, основанные на запрашиваемых полях:
Включить это в ответ | Смотрите эту документацию |
---|---|
Наиболее топливный или энергоэффективный маршрут на основе типа двигателя автомобиля. | Настройте экологически чистые маршруты |
До трех альтернативных маршрутов | Запросить альтернативные маршруты |
Полилина для всего маршрута, для каждой ноги маршрута и для каждого шага ноги. | Запросить маршрут полилинии |
Расчетные платы, с учетом любых скидок или проходов с платной ценой или проходов, доступных для водителя или транспортного средства. | Рассчитайте платные сборы |
Локализованные ответы по языковым кодам и единице измерения (имперская или метрика). | Запросить локализованные значения |
Чтобы форматировать инструкции навигации в виде текстовой строки HTML, добавьте HTML_FORMATTED_NAVIGATION_INSTRUCTIONS в extraComputations . | Дополнительные вычисления |
Для полного списка параметров ввода см. Доступные параметры маршрута и тело запроса .
Используя ответ, вы можете предоставить своим клиентам информацию, необходимую для выбора соответствующего маршрута для их требований.
О полевых масках
Когда вы вызовите метод для вычисления маршрута, вы должны указать полевую маску, которая определяет, какие поля вы хотите возвращать в ответ. Нет списка возвращаемых полей по умолчанию. Если вы опустите этот список, методы возвращают ошибку.
Примеры в этом документе показывают весь объект ответа, не принимая во внимание полевые маски. В производственной среде ваш ответ будет включать только поля, которые вы явно указываете в маске полевых мест.
Для получения дополнительной информации см. Выберите, какую информацию вернуть .
О отображении авторских прав
Вы должны включить следующее заявление об авторском праве при отображении результатов своим пользователям:
Powered by Google, © YEAR Google
Например:
Powered by Google, ©2023 Google
О маршрутах, ногах и шагах
Прежде чем посмотреть на ответ, возвращаемый API Routes, вы должны иметь понимание компонентов, которые составляют маршрут:
Ваш ответ может содержать информацию о каждом из этих компонентов маршрута:
Маршрут : Вся поездка с исходной путевой точки, через любые промежуточные путевые точки, до направления. Маршрут состоит из одной или нескольких ног .
Нога : путь от одной путевой точки на маршруте к следующей путевой точке на маршруте. Каждая нога состоит из одного или нескольких отдельных шагов .
Маршрут содержит отдельную ногу для пути от каждой путевой точки до следующей. Например, если маршрут содержит одну путевую точку происхождения и однолетную точку назначения, то маршрут содержит одну ногу. Для каждой дополнительной путевой точки, которую вы добавляете в маршрут после происхождения и назначения, называемой промежуточной путевой точкой , API добавляет отдельную ногу.
API не добавляет ногу для промежуточной путевой точки. Например, маршрут, который содержит первичную путевую точку, промежуточную промежуточную путевую точку и путевую точку назначения содержит только одну ногу от происхождения до пункта назначения, проходя через путевую точку. Для получения дополнительной информации о прохожденных путевых точках см. Определите проходную путевую точку .
Шаг : единственная инструкция вдоль ноги маршрута. Шаг - самая атомная единица маршрута. Например, шаг может указывать на «повернуть налево на главной улице».
Что в ответ
Объект JSON , представляющий ответ API, содержит следующие свойства верхнего уровня:
routes
, множество элементов типового маршрута . Массивroutes
содержит один элемент для каждого маршрута, возвращаемого API. Массив может содержать максимум пять элементов: маршрут по умолчанию, экологичный маршрут и до трех альтернативных маршрутов.geocodingResults
, множество элементов типового геокодингесфюльди . Для каждого местоположения в запросе (происхождение, назначение или промежуточная путевая точка), которое вы указали в виде адресной строки или в виде кода плюс , API выполняет поиск идентификатора места. Каждый элемент этого массива содержит идентификатор места, соответствующий местоположению. Местоположения в запросе, указанном как идентификатор места или координаты широты/долготы, не включены. Если вы указали все местоположения, используя идентификаторы места или координаты широты и долготы, этот массив не предоставлен.fallbackInfo
, типа SwarkbackInfo . Если API не может вычислять маршрут со всех входных свойств, он может привести к тому, что он использует другой способ вычисления. Когда используется резервный режим, это поле содержит подробную информацию о ответном ответе. В противном случае это поле не является.
Ответ имеет форму:
{ // The routes array. "routes": [ { object (Route) } ], // The place ID lookup results. "geocodingResults": [ { object (GeocodedWaypoint) } ], // The fallback property. "fallbackInfo": { object (FallbackInfo) } }
Расшифровать массив маршрутов
Ответ содержит массив routes
, где каждый элемент массива имеет маршрут типа. Каждый элемент массива представляет весь маршрут от происхождения до пункта назначения. API всегда возвращает хотя бы один маршрут, называемый маршрутом по умолчанию.
Вы можете запросить дополнительные маршруты. Если вы запросите экологичный маршрут , то массив может содержать два элемента: маршрут по умолчанию и экологичный маршрут. Или установите computeAlternativeRoutes
true
в запросе, чтобы добавить до трех альтернативных маршрутов в ответ.
Каждый маршрут в массиве идентифицируется со свойством массива routeLabels
:
Ценить | Описание |
---|---|
DEFAULT_ROUTE | Идентифицирует маршрут по умолчанию. |
FUEL_EFFICIENT | Определяет экологичный маршрут. |
DEFAULT_ROUTE_ALTERNATE | Я выбираю альтернативный маршрут. |
Массив legs
содержит определение каждой ноги маршрута. Оставшиеся свойства, такие как distanceMeters
, duration
и polyline,
содержат информацию о маршруте в целом:
{ "routeLabels": [ enum (RouteLabel) ], "legs": [ { object (RouteLeg) } ], "distanceMeters": integer, "duration": string, "routeLabels": [string], "staticDuration": string, "polyline": { object (Polyline) }, "description": string, "warnings": [ string ], "viewport": { object (Viewport) }, "travelAdvisory": { object (RouteTravelAdvisory) } "routeToken": string }
Из-за текущих условий вождения и других факторов маршрут по умолчанию и экологически чистый маршрут могут быть одинаковыми. В этом случае массив routeLabels
содержит обе этикетки: DEFAULT_ROUTE
и FUEL_EFFICIENT
.
{ "routes": [ { "routeLabels": [ "DEFAULT_ROUTE", "FUEL_EFFICIENT" ], … } ] }
Понять массив ног
Каждый route
в ответе содержит массив legs
, где каждый элемент массива legs
имеет типа Routeleg . Каждая нога в массиве определяет путь от одной путевой точки до следующей путевой точки вдоль маршрута. Маршрут всегда содержит хотя бы одну ногу.
Свойство legs
содержит определение каждого шага вдоль ноги в массиве steps
. Оставшиеся свойства, такие как distanceMeters
, duration
и polyline
содержат информацию о ноге.
{ "distanceMeters": integer, "duration": string, "staticDuration": string, "polyline": { object (Polyline) }, "startLocation": { object (Location) }, "endLocation": { object (Location) }, "steps": [ { object (RouteLegStep) } ], "travelAdvisory": { object (RouteLegTravelAdvisory) } }
Понять массив шагов
Каждая нога в ответе содержит массив steps
, где каждый элемент массива steps
имеет тип RoutelegStep . Шаг соответствует одной инструкции вдоль ноги. Нога всегда содержит хотя бы один шаг.
Каждый элемент в массиве steps
включает в себя свойство navigationInstruction
, типа NavigationInstruction , которая содержит инструкцию Step. Например:
"navigationInstruction": { "maneuver": "TURN_LEFT", "instructions": "Turn left toward Frontage Rd" }
instructions
могут содержать дополнительную информацию о шаге. Например:
"navigationInstruction": { "maneuver": "TURN_SLIGHT_LEFT", "instructions": "Slight left (signs for I-90 W/Worcester)nParts of this road may be closed at certain times or days" }
Оставшиеся свойства в шаге описывают информацию о шаге, такую как distanceMeters
, duration
и polyline
:
{ "distanceMeters": integer, "staticDuration": string, "polyline": { object (Polyline) }, "startLocation": { object (Location) }, "endLocation": { object (Location) }, "navigationInstruction": { object (NavigationInstruction) } }
Укажите язык инструкций по этапам
API возвращает информацию о маршруте на локальном языке, транслитерированный на сценарий, читаемый пользователем, при необходимости, наблюдая за предпочтительным языком. Все компоненты адресов возвращаются на одном языке.
Используйте параметр
languageCode
запроса , чтобы явно установить язык маршрута из списка поддерживаемых языков . Google часто обновляет поддерживаемые языки, поэтому этот список не может быть исчерпывающим.Если имя недоступно на указанном языке, API использует самое близкое совпадение.
Указанный язык может повлиять на набор результатов, которые API выбирает для возврата, и порядок, в котором они возвращаются. Геокодер интерпретирует сокращения по -разному в зависимости от языка, таких как сокращения для типов улиц или синонимы, которые могут быть действительными на одном языке, но не на другом. Например, UTCA и Tér являются синонимами для улицы в Венгрии.
Понять массив геокодинг -раз
Для каждого местоположения в запросе (происхождение, назначение или промежуточная путевая точка), которое было указано как адресная строка или как код плюс , API пытается найти наиболее релевантное местоположение, которое имеет соответствующий идентификатор места. Каждый элемент массива geocodingResults
содержит поле placeID
содержащее местоположение в качестве идентификатора места, и поле type
, в котором указан тип местоположения, например, street_address
, premise
или airport
.
Массив geocodingResults
содержит три поля:
origin
: если он был указан как адресная строка или как код плюс, идентификатор места происхождения. В противном случае это поле исключено из ответа.destination
: если он был указан как адресная строка или как код плюс, идентификатор места назначения. В противном случае это поле исключено из ответа.intermediates
: массив, содержащий идентификатор места любых промежуточных путевых точек, указанных в виде адресной строки или кода плюс. Если вы указываете промежуточную путевую точку, используя идентификатор места или координаты широты и долготы, она исключена из ответа. Используйте свойствоintermediateWaypointRequestIndex
в ответе, чтобы определить, какая промежуточная путевая точка в запросе соответствует идентификатору места в ответе.
"geocodingResults": { "origin": { "geocoderStatus": {}, "type": [ enum (Type) ], "placeId": string }, "destination": { "geocoderStatus": {}, "type": [ enum (Type) ], "placeId": string }, "intermediates": [ { "geocoderStatus": {}, "intermediateWaypointRequestIndex": integer, "type": [ enum (Type) ], "placeId": string }, { "geocoderStatus": {}, "intermediateWaypointRequestIndex": integer, "type": [ enum (Type) ], "placeId": string } ] }
Понять локализованные значения ответа
Локализованные значения ответа - это дополнительное поле ответа, которое предоставляет локализованный текст для возвращаемых значений параметров. Локализованный текст предоставляется для продолжительности поездки, расстояния и единичной системы (метрика или имперства). Вы запросите локализованные значения, используя полевую маску, и можете указать языковую и единичную систему, либо использовать значения, выведенные API. Для получения подробной информации см. LocalizedValues .
Например, если вы указываете языковой код для немецких (DE) и имперских подразделений, вы получаете значение для distanceMeters
49889,7, а также локализованный текст, предоставляя это измерение расстояния в немецких и имперских единицах, так что «31 мл».
Вот пример того, что вы увидите для локализованных значений:
{ "localized_values": { "distance": { "text": "31,0 Meile/n" }, "duration": { "text": 38 Minuten}. "static_duration": { "text": 36 Minuten}. } }
Если вы не указываете языковую или единичную систему, API делает язык и единицы следующим образом:
- Метод
ComputeRoutes
позволяет единицам местоположения и расстояния с исходной путевой точки. Таким образом, для запроса на маршрутизацию в США API делает языкen-US
иIMPERIAL
подразделения. - Метод
ComputeRouteMatrix
по умолчанию по умолчанию языка и метрических единиц.