首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >向MKMapView添加路由

向MKMapView添加路由
EN

Stack Overflow用户
提问于 2010-09-06 21:52:44
回答 2查看 5.5K关注 0票数 4

我正在尝试为我正在开发的应用程序添加路由功能。我找到了Craig Spitzkoff关于如何在MKMapView上画线的article,它工作得很好。但由于我没有道路上的点的坐标,这对我没有帮助。有没有办法确定给定点之间的坐标,比如我的当前位置和另一个地址?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-09-07 12:23:36

基本上,您需要创建一个到Google Directions APIHTTP request。服务条款规定你必须在谷歌地图上显示结果,但我认为因为你使用的是MKMapView,所以你会很好:

方向应用程序接口只能与在谷歌地图上显示结果结合使用;禁止在不显示请求方向数据的地图的情况下使用方向数据。

有关需要在Directions Request上传递的参数的详细信息,请查看该URL:

http://maps.google.com/maps/api/directions/output?parameters

您得到的数据将是JSONXML,这取决于您请求(输出)的内容,因此您需要对其进行解析,以获得描述方向的点集。

票数 4
EN

Stack Overflow用户

发布于 2019-04-18 02:21:30

我知道这是一个古老的问题,但现在你也可以使用MapKit的MKDirections。例如,下面是一个例程,它搜索一些searchString,然后在地图视图中添加指向第一个命中的your的方向:

代码语言:javascript
运行
复制
let request = MKLocalSearch.Request()
request.region = mapView.region
request.naturalLanguageQuery = searchString

let search = MKLocalSearch(request: request)
search.start { response, _ in
    guard let mapItem = response?.mapItems.first else { return }

    let request = MKDirections.Request()
    request.source = MKMapItem.forCurrentLocation()
    request.destination = mapItem
    let directions = MKDirections(request: request)
    directions.calculate { response, error in
        guard let routes = response?.routes else { return }

        let overlays = routes.map { $0.polyline }
        self.mapView.addOverlays(overlays)
    }
}

为确保在地图上进行渲染,请确保设置地图视图的delegate属性(在IB中或以编程方式),然后实现mapView(_:rendererFor:)

代码语言:javascript
运行
复制
extension MapViewController: MKMapViewDelegate {
    func mapView(_ mapView: MKMapView, rendererFor overlay: MKOverlay) -> MKOverlayRenderer {
        let renderer = MKPolylineRenderer(overlay: overlay)
        renderer.strokeColor = .init(red: 0, green: 0, blue: 1, alpha: 0.7)
        return renderer
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3651999

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档