本节书摘来自异步社区《iOS组件与框架——iOS SDK高级特性剖析》一书中的第2章,第2.7节获取线路,作者 【美】Kyle Richter , Joe Keeley,更多章节内容可以访问云栖社区“异步社区”公众号查看
2.7 获取线路
iOS组件与框架——iOS SDK高级特性剖析
iOS 6改进了标准应用“地图”,使其除提供线路外还进行分步导航;另外,还可在其他应用中启动“地图”,并指定要显示的内容。应用可请求“地图”显示一系列内容、显示两个位置之间的线路或显示从当前位置出发的线路。还可对应用“地图”进行配置:指定中心、跨度和地图类型(标准地图、卫星地图或混合地图)。在iOS 7中,MapKit包含MKDirectionRequest类,这个类提供可在应用中直接使用的线路。使用MKDirectionRequest可获取一个数组,其中包含表示线路的折线以及可显示在表视图中的具体步骤。示例应用演示了如何显示折线和具体步骤。
要打开应用“地图”,可使用MKMapItem的类方法openMapsWithItems:launchOptions:,也可使用其实例方法openInMapsWithlaunchOptions:。在示例应用中,ICFFavoritePlaceViewController包含一个按钮,可用于获取前往喜欢地点的线路。用户轻按这个按钮时,将调用方法getDirectionsButtonTouched:。在这个方法中,根据喜欢的地点创建一个MKMapItem实例。
应用“地图”将启动,并显示前往喜欢的地点的线路。如果发生错误,openMapsWithItems: launchOptions:将返回NO。
要获取可在应用中显示的线路,需要实例化一个MKDirectionsRequest对象,并指定用MKMapItem实例表示的起点和终点,再使用这个MKDirectionsRequest实例化一个MKDirections对象。
然后调用方法calculateDirectionsWithCompletionHandler:,并指定一个结束块。这个结束块应处理可能发生的错误,并查看提供给它的MKDirectionsResponse。在这里,这个方法确保至少返回了一条线路(MKRoute实例),再选择使用第一条线路。这个方法迭代第一条线路的属性steps(这个属性包含一系列MKRouteStep实例),并以字符串的方式显示每个步骤的距离和说明。然后,这个方法调用委托的方法将线路添加到地图中。
在委托的方法中,将表示线路的折线添加到地图覆盖层中,再关闭对话框。
方法mapView:viewForOverlay:检查覆盖层的类型,并据此为覆盖层创建相应类型的覆盖层视图。对于折线覆盖层,这个方法将其转换为折线,再根据这条折线创建一个MKPolylineRenderer实例,并设置线宽以及填充色和描边色(蓝色),这将在地图上使用折线显示从起点到终点的线路,如图2.15所示。
图2.15 示例应用FavoritePlaces:在地图上显示表示线路的折线