路线计算(包括重新规划路线)会返回用时最短的路线作为“默认最佳路线”。但是,您可以更改路由策略,以便返回较短的路由备选项。
“较短”一词是指根据默认费用模型计算的最佳路线中最短的路线。较短的路线可能不是绝对最短的路线,因为该选项可能不是最糟糕的备选路线。例如,如果绝对最短的路线是 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 | DDisplay 显示剩余距离。 |
示例
以下代码示例演示了如何配置路线标注格式。
Swift
self.mapView.routeCalloutFormat = .time
Objective-C
_mapView.routeCalloutFormat = GMSNavigationRouteCalloutFormatTime;