Swift 跳轉到地圖導航

1,生成schemes
在這裏插入圖片描述

2 實現

//地圖類型
enum MapForm {
    enum MapURI:String {
        //百度
        case baiduMap = "baidumap://"
        //高德
        case gaodeMap = "iosamap://"
        //蘋果
        case appleMap = "http://maps.apple.com/"
        //谷歌
        case googleMap = "comgooglemaps://"
        //騰訊
        case qqMap = "qqmap://"
    }
    enum MapName:String {
        //百度
        case baiduMap = "百度地圖"
        //高德
        case gaodeMap = "高德地圖"
        //蘋果
        case appleMap = "系統地圖"
        //谷歌
        case googleMap = "谷歌地圖"
        //騰訊
        case qqMap = "騰訊地圖"
    }
}
//檢測地圖是否存在然後打開
struct CCMapGuide {
    static func judgeMapAppInPhoneAndJumpInto(targetLat:Double,targetLong:Double,targetName:String,VC:UIViewController) {
        //盛放地圖元素的數組
        var maps = [[String: String]]()
        //判斷地圖
        //自帶地圖
        if UIApplication.shared.canOpenURL(URL(string: MapForm.MapURI.appleMap.rawValue)!) {
            var iosMap = [String: String]()
            iosMap["title"] = MapForm.MapName.appleMap.rawValue
            maps.append(iosMap)
        }
        //百度地圖
        if UIApplication.shared.canOpenURL(URL(string: MapForm.MapURI.baiduMap.rawValue)!) {
            var baiduDic = [String: String]()
            baiduDic["title"] = MapForm.MapName.baiduMap.rawValue
            //\(self.pointDetailView.pointTitle.text ?? "")
            let retcoordinate:CLLocationCoordinate2D = FMToolsFunction.shared.getBaiduCoordinateByGaodeCoordinate(scoordinate: CLLocationCoordinate2D(latitude: targetLat, longitude: targetLong))
            let urlString = MapInfo.baiDuUrlString(targetLat: retcoordinate.latitude, targetLon: retcoordinate.longitude, targetName: targetName)
            baiduDic["url"] = urlString
            maps.append(baiduDic)
        }
        //高德地圖
        if UIApplication.shared.canOpenURL(URL(string: MapForm.MapURI.gaodeMap.rawValue)!) {
            var gaodeDic = [String: String]()
            gaodeDic["title"] = MapForm.MapName.gaodeMap.rawValue
            let urlString = MapInfo.gaoDeUrlString(targetLat: targetLat, targetLon: targetLong, targetName: targetName)
            let escapedString = urlString.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
            gaodeDic["url"] = escapedString
            maps.append(gaodeDic)
        }
        //谷歌地圖
//        if UIApplication.shared.canOpenURL(URL(string: MapForm.MapURI.googleMap.rawValue)!) {
//            var googleDic = [String: String]()
//            googleDic["title"] = MapForm.MapName.googleMap.rawValue
//            let urlString = MapInfo.googleUrlString(targetLat: targetLat, targetLon: targetLong, targetName: targetName)
//            let escapedString = urlString.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
//            googleDic["url"] = escapedString
//            maps.append(googleDic)
//        }
        //騰訊地圖
        if UIApplication.shared.canOpenURL(URL(string: MapForm.MapURI.qqMap.rawValue)!) {
            var qqDic = [String: String]()
            qqDic["title"] = MapForm.MapName.qqMap.rawValue
            let urlString = MapInfo.qqDuUrlString(targetLat: targetLat, targetLon: targetLong, targetName: targetName)
            let escapedString = urlString.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
            qqDic["url"] = escapedString
            maps.append(qqDic)
        }
        if maps.count == 0 {
            return
        }
        let alertVC = UIAlertController.init(title: "請選擇導航應用程序", message: nil, preferredStyle: .actionSheet)
        for i in 0..<maps.count {
            let title = maps[i]["title"]
            let action = UIAlertAction(title: title, style: .default) { (_) in
                if i == 0 {
                    let loc = CLLocationCoordinate2DMake(targetLat, targetLong)
                    let currentLocation = MKMapItem.forCurrentLocation()
                    let toLocation = MKMapItem(placemark: MKPlacemark(coordinate: loc, addressDictionary: nil))
                    toLocation.name = targetName
                    MKMapItem.openMaps(with: [currentLocation, toLocation], launchOptions: [MKLaunchOptionsDirectionsModeKey: MKLaunchOptionsDirectionsModeDriving, MKLaunchOptionsShowsTrafficKey: true])
                } else {
                    let urlString = maps[i]["url"]! as NSString
                    let url = NSURL(string: urlString.addingPercentEncoding(withAllowedCharacters: CharacterSet.urlQueryAllowed)!)
                    UIApplication.shared.openURL(url! as URL)
                }
            }
            alertVC.addAction(action)
        }
        let cancelAction = UIAlertAction(title: "取消", style: .cancel, handler: nil)
        alertVC.addAction(cancelAction)
        alertVC.popoverPresentationController?.sourceView = VC.view
        alertVC.popoverPresentationController?.sourceRect = CGRect(origin:VC.view.center, size: CGSize(width:1, height: 1))
        VC.present(alertVC, animated: true, completion: nil)
//        VC.present(alertVC, animated: true, completion: nil)
    }
}


//地圖信息
struct MapInfo {
    static func baiDuUrlString(targetLat:Double,targetLon:Double,targetName:String) -> String {
        //return "baidumap://map/direction?origin={{我的位置}}&destination=\(targetName)&mode=driving&src=\(targetName)&coord_type=gcj02"
        /*
         注意:此處destination後面有三種寫法:
         1,destination=\(targetLat),\(targetLon)
         2,destination=\(targetName)
         3,destination=name:\(targetName)|latlng:\(targetLat),\(targetLon)
         
         */
        return "baidumap://map/direction?origin={{我的位置}}&destination=\(targetLat),\(targetLon)&mode=driving&src=\(targetName)&coord_type=gcj02"
    }
    static func gaoDeUrlString(targetLat:Double,targetLon:Double,targetName:String) -> String {
        return "iosamap://navi?sourceApplication=導航功能&backScheme=iosamap&poiname=\(targetName)&poiid=BGVIS&lat=\(targetLat)&lon=\(targetLon)&dname=\(targetName)&dev=0&m=0&style=2"
    }
    static func googleUrlString(targetLat:Double,targetLon:Double,targetName:String) -> String {
        return "comgooglemaps://?x-source=appDisplayName)&x-success=urlSchem&saddr=&daddr=\(targetLat),\(targetLon)&directionsmode=driving"
    }
    static func qqDuUrlString(targetLat:Double,targetLon:Double,targetName:String) -> String {
        return "qqmap://map/routeplan?type=drive&from=我的位置&fromcoord=&to=\(targetName)&tocoord=\(targetLat),\(targetLon)&policy=1&referer=appDisplayName)"
    }
}`

3 使用

   CCMapGuide.judgeMapAppInPhoneAndJumpInto(targetLat: location!.latitude, targetLong: location!.longitude, targetName: "", VC: self)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章