路线计算(包括重新规划路线)会返回导航时间最短的路线,作为默认最佳路线。不过,您可以更改路线规划策略,以便系统返回较短的备选路线。
较短是指根据我们的默认费用模型,在最佳路线中最短的路线。较短的路线可能不是绝对最短的路线,因为该选项可能不是理想的替代方案。例如,如果绝对最短路线为 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;