当前位置: 移动技术网 > IT编程>移动开发>IOS > iOS实现设备判断是否安装相关地图(百度、高德等)

iOS实现设备判断是否安装相关地图(百度、高德等)

2019年07月24日  | 移动技术网IT编程  | 我要评论

小学语文课堂实录,管家婆软件在线学习,掐菜苔

前言

最近项目关于地图的,和朋友一起做的,他们用的高德地图,他做到半路有事,我来接手,结果我手机上没有安装高德地图,到我这边点击导航没啥反应,后来就查了一下,简单处理下,最终实现以下的需求:

点击导航,底部弹框,显示用户设备上所有的地图(一般就苹果自带的地图、百度地图、高德地图,当然了还有其他地图,个人感觉就这几个用的人比较多,其他的其实也类似),下面话不多说了,来一起看看详细的介绍吧。

具体做法如下:

1、plist文件进行相关的配置

lsapplicationqueriesschemes (这个一定不要写错,一定不要写错,一定不要写错,这个我是有教训的,说多了都是泪)这是一个数组,可以添加各地图的相关url scheme

常见的地图对应如下:

  • 百度地图:baidumap
  • 高德地图:iosamap
  • 谷歌地图:comgooglemaps
  • 腾讯地图:qqmap

你也可以直接直接复制以下代码到plist文件

<key>lsapplicationqueriesschemes</key>
 <array>
  <string>baidumap</string>
  <string>iosamap</string>
  <string>comgooglemaps</string>
  <string>qqmap</string>
 </array>

2.使用系统的api判断设备是否安装相关的地图应用程序

- (bool)canopenurl:(nsurl *)url ns_available_ios(3_0);

具体写发如下:

百度地图

 [[uiapplication sharedapplication] canopenurl:[nsurl urlwithstring:@"baidumap://"]]

高德地图

[[uiapplication sharedapplication] canopenurl:[nsurl urlwithstring:@"iosamap://"]]

谷歌地图

[[uiapplication sharedapplication] canopenurl:[nsurl urlwithstring:@"comgooglemaps://"]]

腾讯地图

[[uiapplication sharedapplication] canopenurl:[nsurl urlwithstring:@"qqmap://"]]

该方法返回的bool值即可判断该设备有没有安装相关的地图应用

备注:苹果自带的地图是不需要判断的

这里贴一段代码,需要的时候稍微修改下即可

-(void)donavigationwithendlocation:(nsarray *)endlocation
{
 nsmutablearray *maps = [nsmutablearray array];
 //苹果原生地图-苹果原生地图方法和其他不一样
 nsmutabledictionary *iosmapdic = [nsmutabledictionary dictionary];
 iosmapdic[@"title"] = @"苹果地图";
 [maps addobject:iosmapdic];
 //百度地图
 if ([[uiapplication sharedapplication] canopenurl:[nsurl urlwithstring:@"baidumap://"]]) {
  nsmutabledictionary *baidumapdic = [nsmutabledictionary dictionary];
  baidumapdic[@"title"] = @"百度地图";
  nsstring *urlstring = [[nsstring stringwithformat:@"baidumap://map/direction?origin={{我的位置}}&destination=latlng:%@,%@|name=北京&mode=driving&coord_type=gcj02",endlocation[0],endlocation[1]] stringbyaddingpercentescapesusingencoding:nsutf8stringencoding];
  baidumapdic[@"url"] = urlstring;
  [maps addobject:baidumapdic];
 } 
 //高德地图
 if ([[uiapplication sharedapplication] canopenurl:[nsurl urlwithstring:@"iosamap://"]]) {
  nsmutabledictionary *gaodemapdic = [nsmutabledictionary dictionary];
  gaodemapdic[@"title"] = @"高德地图";
  nsstring *urlstring = [[nsstring stringwithformat:@"iosamap://navi?sourceapplication=%@&backscheme=%@&lat=%@&lon=%@&dev=0&style=2",@"导航功能",@"nav123456",endlocation[0],endlocation[1]] stringbyaddingpercentescapesusingencoding:nsutf8stringencoding];
  gaodemapdic[@"url"] = urlstring;
  [maps addobject:gaodemapdic];
 } 
 //谷歌地图
 if ([[uiapplication sharedapplication] canopenurl:[nsurl urlwithstring:@"comgooglemaps://"]]) {
  nsmutabledictionary *googlemapdic = [nsmutabledictionary dictionary];
  googlemapdic[@"title"] = @"谷歌地图";
  nsstring *urlstring = [[nsstring stringwithformat:@"comgooglemaps://?x-source=%@&x-success=%@&saddr=&daddr=%@,%@&directionsmode=driving",@"导航测试",@"nav123456",endlocation[0], endlocation[1]] stringbyaddingpercentescapesusingencoding:nsutf8stringencoding];
  googlemapdic[@"url"] = urlstring;
  [maps addobject:googlemapdic];
 } 
 //腾讯地图
 if ([[uiapplication sharedapplication] canopenurl:[nsurl urlwithstring:@"qqmap://"]]) {
  nsmutabledictionary *qqmapdic = [nsmutabledictionary dictionary];
  qqmapdic[@"title"] = @"腾讯地图";
  nsstring *urlstring = [[nsstring stringwithformat:@"qqmap://map/routeplan?from=我的位置&type=drive&tocoord=%@,%@&to=终点&coord_type=1&policy=0",endlocation[0], endlocation[1]] stringbyaddingpercentescapesusingencoding:nsutf8stringencoding];
  qqmapdic[@"url"] = urlstring;
  [maps addobject:qqmapdic];
 } 
 //选择
 uialertcontroller * alert = [uialertcontroller alertcontrollerwithtitle:@"选择地图" message:nil preferredstyle:uialertcontrollerstyleactionsheet]; 
 nsinteger index = maps.count; 
 for (int i = 0; i < index; i++) {  
  nsstring * title = maps[i][@"title"];
  //苹果原生地图方法
  if (i == 0) {
   uialertaction * action = [uialertaction actionwithtitle:title style:(uialertactionstyledefault) handler:^(uialertaction * _nonnull action) {
    [self navapplemapnavapplemapwitharray:endlocation];
   }];
   [alert addaction:action];
   continue;
  }  
  uialertaction * action = [uialertaction actionwithtitle:title style:uialertactionstyledefault handler:^(uialertaction * _nonnull action) {
   nsstring *urlstring = maps[i][@"url"];
   [[uiapplication sharedapplication] openurl:[nsurl urlwithstring:urlstring]];
  }];  
  [alert addaction:action];
 } 
 uialertaction * action = [uialertaction actionwithtitle:@"取消" style:uialertactionstylecancel handler:^(uialertaction * _nonnull action) {  
 }]; 
 [alert addaction:action]; 
 [[cpbaseviewcontroller getcurrentvc] presentviewcontroller:alert animated:yes completion:nil];
// [self presentviewcontroller:alert animated:yes completion:nil]; 
}

//苹果地图
- (void)navapplemapnavapplemapwitharray:(nsarray*) array
{
 float lat = [nsstring stringwithformat:@"%@", array[0]].floatvalue;
 float lon = [nsstring stringwithformat:@"%@", array[1]].floatvalue;
 //终点坐标
 cllocationcoordinate2d loc = cllocationcoordinate2dmake(lat, lon); 
 //用户位置
 mkmapitem *currentloc = [mkmapitem mapitemforcurrentlocation];
 //终点位置
 mkmapitem *tolocation = [[mkmapitem alloc]initwithplacemark:[[mkplacemark alloc]initwithcoordinate:loc addressdictionary:nil] ]; 
 nsarray *items = @[currentloc,tolocation];
 //第一个
 nsdictionary *dic = @{       mklaunchoptionsdirectionsmodekey : mklaunchoptionsdirectionsmodedriving,       mklaunchoptionsmaptypekey : @(mkmaptypestandard),       mklaunchoptionsshowstraffickey : @(yes)
       };
 //第二个,都可以用
 // nsdictionary * dic = @{mklaunchoptionsdirectionsmodekey: mklaunchoptionsdirectionsmodedriving,
 //       mklaunchoptionsshowstraffickey: [nsnumber numberwithbool:yes]}; 
 [mkmapitem openmapswithitems:items launchoptions:dic]; 
}

使用记得导入需要的头文件,比如苹果自带地图

import <mapkit/mapkit.h>
...

备注:

-(void)donavigationwithendlocation:(nsarray *)endlocation;该方法中的数组传的其实就是经纬度,到时候根据自己的需求修改下就可以直接使用

基本的使用就只这样,希望可以帮到有需求的小伙伴。。。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对移动技术网的支持。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

  • ios uicollectionview实现横向滚动

    现在使用卡片效果的app很多,之前公司让实现一种卡片效果,就写了一篇关于实现卡片的文章。文章最后附有demo实现上我选择了使用uicollectionview ... [阅读全文]
  • iOS UICollectionView实现横向滑动

    本文实例为大家分享了ios uicollectionview实现横向滑动的具体代码,供大家参考,具体内容如下uicollectionview的横向滚动,目前我使... [阅读全文]
  • iOS13适配深色模式(Dark Mode)的实现

    iOS13适配深色模式(Dark Mode)的实现

    好像大概也许是一年前, mac os系统发布了深色模式外观, 看着挺刺激, 时至今日用着也还挺爽的终于, 随着iphone11等新手机的发售, ios 13系统... [阅读全文]
  • ios 使用xcode11 新建项目工程的步骤详解

    ios 使用xcode11 新建项目工程的步骤详解

    xcode11新建项目工程,新增了scenedelegate这个类,转而将原appdelegate负责的对ui生命周期的处理担子接了过来。故此可以理解为:ios... [阅读全文]
  • iOS实现转盘效果

    本文实例为大家分享了ios实现转盘效果的具体代码,供大家参考,具体内容如下demo下载地址: ios转盘效果功能:实现了常用的ios转盘效果,轮盘抽奖效果的实现... [阅读全文]
  • iOS开发实现转盘功能

    本文实例为大家分享了ios实现转盘功能的具体代码,供大家参考,具体内容如下今天给同学们讲解一下一个转盘选号的功能,直接上代码直接看viewcontroller#... [阅读全文]
  • iOS实现轮盘动态效果

    本文实例为大家分享了ios实现轮盘动态效果的具体代码,供大家参考,具体内容如下一个常用的绘图,主要用来打分之类的动画,效果如下。主要是ios的绘图和动画,本来想... [阅读全文]
  • iOS实现九宫格连线手势解锁

    本文实例为大家分享了ios实现九宫格连线手势解锁的具体代码,供大家参考,具体内容如下demo下载地址:效果图:核心代码://// clockview.m// 手... [阅读全文]
  • iOS实现卡片堆叠效果

    本文实例为大家分享了ios实现卡片堆叠效果的具体代码,供大家参考,具体内容如下如图,这就是最终效果。去年安卓5.0发布的时候,当我看到安卓全新的material... [阅读全文]
  • iOS利用余弦函数实现卡片浏览工具

    iOS利用余弦函数实现卡片浏览工具

    本文实例为大家分享了ios利用余弦函数实现卡片浏览工具的具体代码,供大家参考,具体内容如下一、实现效果通过拖拽屏幕实现卡片移动,左右两侧的卡片随着拖动变小,中间... [阅读全文]
验证码:
移动技术网