Rotear para pontos de navegação

O SDK Navigation para Android oferece maneiras aprimoradas de especificar waypoints ou pontos de navegação, proporcionando um roteamento mais preciso e uma melhor experiência de chegada, especialmente para destinos com várias entradas ou pontos de navegação específicos. É possível fazer o roteamento para locais precisos usando um navigationPointToken, que é uma string que codifica um local e um contexto de rota adicional. Você também pode combinar coordenadas de latitude e longitude com um ID de lugar para adicionar contexto.

Contexto

Antes da v7.4, era possível definir um Waypoint usando coordenadas de latitude e longitude ou um ID de lugar. Embora às vezes seja eficaz, o roteamento apenas para uma latitude e longitude pode levar a pontos de desembarque ou embarque abaixo do ideal, principalmente para locais grandes, parques ou edifícios com várias entradas. O resultado pode ser alinhado ao segmento de estrada mais próximo, que pode não ser o ponto de navegação mais conveniente ou correto.

As opções de waypoint aprimoradas resolvem esse problema, permitindo que mais contexto seja fornecido.

Usar um token de ponto de navegação

Para o roteamento mais preciso para pontos de navegação específicos, como entradas, docas de carregamento ou áreas de embarque designadas, use um navigationPointToken. Esse token é obtido chamando o método destinations da API Geocoding. Ele representa um ponto de navegação específico e roteável associado a um lugar.

Para especificar um token de ponto de navegação:

  1. Receba um navigationPointToken do método Destinations da resposta da API Geocoding.
  2. Crie um Waypoint usando o método setNavigationPointToken() no builder.

Observação:ao usar setNavigationPointToken(), não é possível usar setLatLng() ou setPlaceIdString() simultaneamente. Esses métodos são mutuamente exclusivos com setNavigationPointToken().

// Assuming 'navPointToken' is a String obtained from the destinations method of the Geocoding API
// Assuming 'destinationName' is a String title for the waypoint

Waypoint waypointWithToken = Waypoint.builder()
    .setTitle(destinationName)
    .setNavigationPointToken(navPointToken)
    .build();

// Use this waypoint in navigator.setDestinations()

Usar tokens de ponto de navegação e de rota

É possível recuperar um token de ponto de navegação pela API Geocoding, um token de rota da API Routes e, em seguida, transmitir o token de ponto de navegação e o token de rota para o SDK Navigation. Isso é útil em cenários como transporte por aplicativo ou entrega, em que você usa a API Routes para calcular o preço de uma viagem e quer a precisão de um token de ponto de navegação.

O token de rota favorece a rota escolhida pelo SDK Navigation para a rota usada para preços. Isso reduz o risco de rotas mais longas ou mais curtas serem usadas para a viagem, o que pode criar "choques de preços".

Consulte a documentação da API Routes para mais informações sobre como especificar um local usando um token de ponto de navegação e criar um token de rota. Consulte "Planejar uma rota" para saber como planejar uma rota usando um token de rota.

Este diagrama mostra como um app de transporte por aplicativo ou entrega usaria tokens de ponto de navegação e de rota juntos:

Diagrama de caso de uso de carona compartilhada ou entrega
Diagrama de um caso de uso de transporte por aplicativo ou entrega

Combinar ID de lugar e latitude e longitude

A partir da v7.4, é possível fornecer um ID de lugar e coordenadas de latitude e longitude ao criar um Waypoint. Esse método é útil quando você quer especificar um ponto preciso (a latitude/longitude) e ainda fornecer o contexto do lugar geral (o ID de lugar). Isso permite que o SDK Navigation ofereça uma experiência de chegada mais rica, destacando o prédio de destino ou mostrando pontos de interesse próximos relacionados ao ID de lugar.

// Assuming 'placeId' is the Place ID String
// Assuming 'lat' and 'lng' are the double values for latitude and longitude
// Assuming 'destinationName' is a String title for the waypoint

Waypoint waypointWithPlaceIdAndLatLng = Waypoint.builder()
    .setTitle(destinationName)
    .setPlaceIdString(placeId)
    .setLatLng(lat, lng)
    .build();

// Use this waypoint in navigator.setDestinations()

Considerações

Ao fornecer placeId e latlng:

  • A rota tem como destino principal o latlng especificado.
  • O placeId é usado como contexto para melhorar a experiência de chegada.
  • Fallback:se o SDK determinar que o placeId fornecido corresponde a um recurso muito distante do latlng fornecido, o placeId será ignorado. Nesse cenário, o roteamento vai prosseguir apenas para o latlng, e as melhorias na experiência de chegada específicas do lugar não estarão disponíveis.

Resumo das configurações de waypoint válidas

Método setLatLng() setPlaceIdString() setNavigationPointToken() Comportamento de roteamento Destaque do destino
Apenas coordenadas de latitude/longitude set ausente ausente Rotas para o segmento de estrada mais próximo das coordenadas definidas Mostrado se o destino puder ser inferido com alta confiança
Apenas ID de lugar ausente set ausente Rotas para o ponto de navegação padrão do ID de lugar Do ID de lugar
Apenas token de ponto de navegação ausente ausente set Rotas para o ponto de navegação preciso representado pelo token Do destino definido no método de destinos original da solicitação da API Geocoding
Coordenadas de latitude/longitude e ID de lugar combinados set set ausente Rotas para o segmento de estrada mais próximo das coordenadas definidas Do ID de lugar, embora não seja mostrado se o ID de lugar estiver muito longe das coordenadas de latitude/longitude