路線計算 (包括重新規劃路線) 會傳回導航時間最短的路線,做為預設最佳路線。不過,您可以變更路徑策略,改為傳回較短的替代路徑。
「較短」是指根據預設費用模型,在最佳路徑中距離最短的路徑。較短路線可能不是絕對最短路線,因為該選項可能不是理想的替代路線。舉例來說,如果最短路線為 10 公里,導航時間為 50 分鐘,而另一條路線為 15 公里,導航時間僅 20 分鐘,則後者是最佳選擇,因為花費 30 分鐘減少 5 公里並非划算的交易。
行程的路線策略一經設定,在行程完成前不會變更。如要變更現有行程的路線規劃策略,請清除目的地,然後使用新的路線規劃策略重新設定目的地。
取得路線詳細資料
如要判斷特定中途點的最佳路徑策略,請呼叫 getRouteInfoForDestination()
,取得預設最佳路徑和絕對最短路徑的路徑詳細資料。詳細資料包括抵達目的地路線控點所需的時間和距離。
這些詳細資料來自回呼中的 GMSNavigationRouteInfo
。
範例
以下程式碼範例示範如何取得兩種路徑規劃策略的路徑詳細資料。
Swift
let routingOptions = GMSNavigationRoutingOptions()
navigator?.getRouteInfoForDestination(destination,
routingOptions: routingOptions) { routeInfo in
...
}
Objective-C
GMSNavigationRoutingOptions *routingOptions =
[[GMSNavigationRoutingOptions alloc] init];
[navigator getRouteInfoForDestination:destination
withRoutingOptions:routingOptions
callback:^(GMSNavigationRouteInfo *routeInfo){...}];
設定轉送策略
您可以透過 GMSNavigationRoutingOptions
設定轉送策略,
並在呼叫 setDestinations()
時設定 routingStrategy
。
routingStrategy
採用下列其中一個列舉值:
列舉值 | 說明 |
---|---|
GMSNavigationRoutingStrategyDefaultBest | 依據 Navigation SDK 預設費用模型排列路線。這是預設的轉送策略。 |
GMSNavigationRoutingStrategyShorter | 依距離排序路線。排名最高的路線是傳回的路線中最短的路線。 |
範例
以下程式碼範例示範如何設定較短路徑的路線規劃策略。
Swift
let routingOptions = GMSNavigationRoutingOptions(routingStrategy: .shorter)
navigator?.setDestinations(destinations,
routingOptions: routingOptions) { routeStatus in
...
}
Objective-C
GMSNavigationRoutingOptions *routingOptions = [[GMSNavigationRoutingOptions alloc] initWithRoutingStrategy:GMSNavigationRoutingStrategyShorter];
[navigator setDestinations:destinations
routingOptions:routingOptions
callback:^(GMSRouteStatus routeStatus){...}];
包含渡輪的路線
根據預設,Navigation SDK for iOS 會排除包含渡輪的路徑。如要將渡輪選項納入路線,請將 avoidsFerries
設為 false
,調整這項路線偏好設定,顯示渡輪路段的行程。
範例
Swift
self.mapView.navigator?.avoidsFerries = false
Objective-C
self.mapView.navigator.avoidsFerries = NO
路線摘要格式
如果使用較短路線的路線規劃策略,路線上的標註會顯示距離詳細資料。但你可以改用預估到達時間註解。
設定路線標註格式
您可以在 GMSMapView
中設定 routeCalloutFormat
,變更路線標註格式。routeCalloutFormat
採用下列其中一個列舉值:
列舉值 | 說明 |
---|---|
GMSNavigationRouteCalloutFormatDefault | 使用預設最佳路線路徑策略時,會顯示剩餘時間。使用較短路徑的路線規劃策略時,顯示剩餘距離 |
GMSNavigationRouteCalloutFormatTime | 顯示剩餘時間。 |
GMSNavigationRouteCalloutFormatDistance | 顯示剩餘距離。 |
範例
下列程式碼範例示範如何設定路線標註格式。
Swift
self.mapView.routeCalloutFormat = .time
Objective-C
_mapView.routeCalloutFormat = GMSNavigationRouteCalloutFormatTime;