iOS调用高德地图SDK

准备工作:

  1. 安装CocoaPods
  2. 使用下载第三方库相同的方法下载SDK
    方法如下:
    (1)打开终端,cd 文件路径 进入到所创建的项目文件中
    (2)输入pod init为该项目创建Podfile文件
    (3)在Podfile文件中添加pod 'AMap3DMap'pod 'AMap2DMap'
    其中3D的是3D地图,2D的是2D地图,选择其一添加即可,若全选的话会发生冲突致使SDK安装失败
    (4)输入pod install下载SDK(若下载的SDK不是最新版可输入pod repo update进行更新
  3. 下载完成后即可点击.xcworkspace文件进入项目编写代码了
  4. 另外需要注册成为高德地图的个人开发者并前往“高德开放平台控制台”申请 iOS Key。该iOS key在实际的项目编写中需要用到
    其中申请key的方法如下:
    登录或注册

1、如果您还未注册过,请点击此处完成注册。

2、如果您已经注册过,请登录后在申请key,申请与注册的入口如下:
请添加图片描述
创建应用

进入“控制台—应用管理—创建新应用”,点此进入。
请添加图片描述
申请为该应用添加key

1、点击左侧“+”新增Key。
请添加图片描述
2、填写必要字段,此时需要选择正确的key类型。
请添加图片描述
在上图中选择iOS平台,选择后还需要填写安全码Bundle ID: ,该安全码的获取如下图:
请添加图片描述
将一切填好后就可以获取到我们需要的key了

接下来就进入到项目内部的设置了:

  1. iOS9为了增强数据访问安全,将所有的http请求都改为了https,为了能够在iOS9中正常使用地图SDK,需要在"Info.plist"中进行如下配置,否则影响SDK的使用,(见下图):
    在这里插入图片描述
    我们需要在App Transport Security Settings下创建Allow Aebitrary Loads,并将其Type为Boolean类型的Value设置为YES;如本身就没有App Transport Security Settings的话则需要创建一个

2.配置高德key到AppDelegate.m文件:

#import <AMapFoundationKit/AMapFoundationKit.h>
//需要引入AMapFoundationKit.h头文件
……

 (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {  
	//将下方 您的Key 部分修改为刚才所获取到的key就行;
    [AMapServices sharedServices].apiKey = @"您的Key";
     
    ……
}
  1. 加载地图的方法:
    在ViewController.m文件相应的方法中进行地图初始化,初始化的步骤:
    (1) import MAMapKit.h 头文件;
    (2)构造MAMapView对象;
    (3)将MAMapView添加到Subview中。
    对于3D矢量地图,在 viewDidLoad 方法中添加代码:
#import <MAMapKit/MAMapKit.h>

-(void) viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.

	///初始化地图
	MAMapView *_mapView = [[MAMapView alloc] initWithFrame:self.view.bounds];
    
	///把地图添加至view
    [self.view addSubview:_mapView];
}

重要的点:

我们在实现了以上操作之后,是仍然无法成功加载出地图的,此时运行会提示高德地图SDK隐私合规相关的问题,这是由于法律法规对于APP所要求的内容,必须要通过这个检测,否则就无法显示地图视图,不过不用慌,看下面:

在构造MAMapView(MAOfflineMap,MAOfflineMapViewController,MATraceManager等)之前必须进行合规检查,设置接口之前保证隐私政策合规,检查接口如下:

[MAMapView updatePrivacyShow:AMapPrivacyShowStatusDidShow privacyInfo:AMapPrivacyInfoStatusDidContain];
[MAMapView updatePrivacyAgree:AMapPrivacyAgreeStatusDidAgree];

将上述两行接口代码添加到加载地图视图的代码之前即可成功加载地图的视图。

即就是把ViewController.m中的代码写成如下形式:

#import <MAMapKit/MAMapKit.h>

-(void) viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.

	//添加隐私合规接口代码
	[MAMapView updatePrivacyShow:AMapPrivacyShowStatusDidShow privacyInfo:AMapPrivacyInfoStatusDidContain];
	[MAMapView updatePrivacyAgree:AMapPrivacyAgreeStatusDidAgree];

	///初始化地图
	MAMapView *_mapView = [[MAMapView alloc] initWithFrame:self.view.bounds];
    
	///把地图添加至view
    [self.view addSubview:_mapView];
}

此时,我们的全部流程就结束了,实际的运行结果如下:
请添加图片描述
可以看到地图视图已经显示在我们的手机上了。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值