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)