경로 계산 (경로 변경 포함)은 이동하는 데 가장 적은 시간이 걸리는 경로를 기본 최적 경로로 반환합니다. 하지만 대체 경로 중 더 짧은 경로가 대신 반환되도록 라우팅 전략을 변경할 수 있습니다.
더 짧은이란 기본 비용 모델을 기반으로 최적의 경로 중 가장 짧은 경로를 의미합니다. 더 짧은 경로가 최단 경로가 아닐 수도 있습니다. 이 옵션이 최선의 대안이 아닐 수 있기 때문입니다. 예를 들어 가장 짧은 경로가 10km이고 이동하는 데 50분이 걸리며 다른 경로는 15km이지만 이동하는 데 20분밖에 걸리지 않는다면 두 번째 경로가 최적입니다. 5km를 줄이기 위해 30분을 소비하는 것은 좋은 절충안이 아니기 때문입니다.
경로의 라우팅 전략을 설정하면 경로가 완료될 때까지 변경되지 않습니다. 기존 경로의 라우팅 전략을 변경하려면 대상을 삭제하고 새 라우팅 전략으로 다시 재설정해야 합니다.
경로 세부정보 가져오기
지정된 중간 지점에 가장 적합한 경로 전략을 결정하려면 getRouteInfo()
를 호출하여 기본 최적 경로와 절대적으로 더 짧은 경로의 경로 세부정보를 모두 가져옵니다. 세부정보에는 소요 시간과 목적지 경유지까지의 거리가 포함됩니다.
이러한 세부정보는 RouteInfo
에서 가져와 ListenableResultFuture
로 반환됩니다.
예
다음 코드 예는 두 가지 라우팅 전략 각각의 경로 세부정보를 가져오는 방법을 보여줍니다.
ListenableResultFuture<RouteInfo> routeInfoFuture =
navigator.getRouteInfo(waypoint, routingOptions);
라우팅 전략 설정
setDestinations()
를 호출할 때 RoutingOptions.routingStrategy
를 설정하여 라우팅 전략을 구성할 수 있습니다.
RoutingOptions.routingStrategy
는 다음 열거형 값 중 하나를 취합니다.
열거 값 | 설명 |
---|---|
RoutingStrategy.DEFAULT_BEST | Navigation SDK의 기본 비용 모델에 따라 경로를 순위 지정합니다. 이는 기본 라우팅 전략입니다. |
RoutingStrategy.SHORTER | 거리순으로 경로를 정렬합니다. 가장 높은 순위의 경로는 반환된 경로 중 가장 짧습니다. |
예
다음 코드 예는 더 짧은 경로 환경설정을 설정하는 방법을 보여줍니다.
RoutingOptions routingOptions = new RoutingOptions();
routingOptions.routingStrategy(RoutingStrategy.SHORTER);
navigator.setDestinations(destinations, routingOptions, displayOptions);
페리가 포함된 경로
기본적으로 NavSDK는 페리가 포함된 경로를 제외합니다. 경로의 일부로 페리 옵션을 포함하려면 이 라우팅 환경설정을 조정하여 avoidFerries
를 false
로 설정하여 페리 구간으로의 이동을 노출할 수 있습니다.
예
RoutingOptions routingOptions = new RoutingOptions().avoidFerries(true);
// Add additional routing preferences
navigator.setDestination(destination, routingOptions);
경로 콜아웃 형식
짧은 경로 환경설정의 경우 경로의 콜아웃에 거리 세부정보가 표시됩니다. 대신 ETA 콜아웃을 사용할 수 있습니다.
경로 콜아웃 형식 구성
NavigationView
(또는 NavigationFragment
)에서 setRouteCalloutInfoFormat
를 호출하여 경로 번호 형식을 변경할 수 있습니다. setRouteCalloutInfoFormat
는 다음 열거형 값 중 하나를 사용합니다.
열거 값 | 설명 |
---|---|
RouteCalloutInfoFormat.DEFAULT | 기본 최적 경로 라우팅 전략을 사용할 때 남은 시간을 표시합니다. 더 짧은 경로 라우팅 전략을 사용할 때 남은 거리를 표시합니다. |
RouteCalloutInfoFormat.TIME | 남은 시간을 표시합니다. |
RouteCalloutInfoFormat.DISTANCE | 남은 거리를 표시합니다. |
예
다음 코드 예에서는 경로 콜아웃 형식을 구성하는 방법을 보여줍니다.
mNavFragment.setRouteCalloutInfoFormat(RouteCalloutInfoFormat.TIME);