- 一.进入百度地图官方(注册应用)
- 1.1.百度地图官方
-
1.2.创建应用
1.3.具体的应用填写
- 1.4.安全码(也就是百度地图的安全码)
二.iOS地图开发
-
2.1.地图开发的选择类型(根据自己的需求选择)
2.2.相关下载
![相关下载](http://upload-images.jianshu.io/upload_images/1728484-c3bbc6b87c9df233.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
三.下面真正的进行开发(先实现地图的展示)
- 3.1申请秘钥直接在应用里面获取就好了
3.2.注意事项(一共12项)
-
3.2.1.静态库中采用ObjectC++实现,因此需要您保证您工程中至少有一个.mm后缀的源文件(您可以将任意一个.m后缀的文件改名为.mm),或者在工程属性中指定编译方式,即在Xcode的Project -> Edit Active Target -> Build Setting 中找到 Compile Sources As,并将其设置为"Objective-C++"
- 3.2.2.如果您只在Xib文件中使用了BMKMapView,没有在代码中使用BMKMapView,编译器在链接时不会链接对应符号,需要在工程属性中显式设定:在Xcode的Project -> Edit Active Target -> Build Setting -> Other Linker Flags中添加-ObjC
3.2.3.授权Key的申请:新、旧Key之间不可通用,即新Key只可以使用在v2.0.2及后续版本的SDK中,旧的Key只适用于v2.0.1及之前版本的SDK;如果还没有授权Key,请 申请密钥(前面已经申请过,在此就不再重复了)
3.2.4.由于iOS9改用更安全的https,为了能够在iOS9中正常使用地图SDK,请在"Info.plist"中进行如下配置,否则影响SDK的使用。
-
3.2.5.如果在iOS9中使用了调起百度地图客户端功能,必须在"Info.plist"中进行如下配置,否则不能调起百度地图客户端。
<key>LSApplicationQueriesSchemes</key> <array> <string>baidumap</string> </array>
3.2.6.管理地图的生命周期:自2.0.0起,BMKMapView新增viewWillAppear、viewWillDisappear方法来控制BMKMapView的生命周期,并且在一个时刻只能有一个BMKMapView接受回调消息,因此在使用BMKMapView的viewController中需要在viewWillAppear、viewWillDisappear方法中调用BMKMapView的对应的方法,并处理delegate
-
3.2.7.自iOS SDK v2.5.0起,为了对iOS8的定位能力做兼容,做了相应的修改,开发者在使用过程中注意事项如下: 需要在info.plist里添加(以下二选一,两个都添加默认使用NSLocationWhenInUseUsageDescription):
NSLocationWhenInUseUsageDescription ,允许在前台使用时获取GPS的描述
NSLocationAlwaysUsageDescription ,允许永久使用GPS的描述 3.2.8.在使用Xcode6进行SDK开发过程中,需要在info.plist中添加:Bundle display name ,且其值不能为空(Xcode6新建的项目没有此配置,若没有会造成manager start failed)
3.2.9.百度地图iOS SDK v2.5.0起,对arm64进行了支持适配,开发包体积有所增加。但根据开发者在研发过程中的选择,最终生成的APP体积并不会发生较大的变化。
3.2.10.确认项目中添加mapapi.bundle文件以及添加方法正确,不能删除或随意更改其中files文件夹下的内容:
注:mapapi.bundle中存储了定位、默认大头针标注View及路线关键点的资源图片,还存储了矢量地图绘制必需的资源文件。如果您不需要使用内置的图片显示功能,则可以删除bundle文件中的image文件夹。您也可以根据具体需求任意替换或删除该bundle中image文件夹的图片文件。添加方式:将mapapi.bundle拷贝到您的工程目录,直接将该bundle文件托拽至Xcode工程左侧的Groups&Files中即可。若您需要替换定位、指南针的图标,请保留原文件名称,否则不显示替换的新图片,默认大头针标注与路线关键点的新图片名称可自定义名称。
注意:如果采用的cocopods集成的SDK就不需要导入
- 3.2.11、注意BMKManager对象的生命周期管理,在使用地图SDK期间不能释放该对象,尤其在arc情况下注意避免提前被自动释放,否则,该对象一旦被释放,网络模块将不可用,地图无法加载,检索失败。
答: 也就是我们在定义BMKManager对象的时候用strong就好,强引用,防止对象被释放掉
-
3.2.12、app在前后台切换时,需要使用下面的代码停止地图的渲染和openGL的绘制(V2.10.0后不需要再调用):
- (void)applicationWillResignActive:(UIApplication *)application { //当应用即将后台时调用,停止一切调用opengl相关的操作 [BMKMapView willBackGround]; } - (void)applicationDidBecomeActive:(UIApplication *)application { //当应用恢复前台状态时调用,回复地图的渲染和opengl相关的操作 [BMKMapView didForeGround]; }
-
3.3.配置开发环境(cocopods导入和手动任选一个)
-
** 第一种cocopods导入**(比较简单)
pod 'BaiduMapKit', '~> 3.1.0'
成功后这些会被自动生成
- 第二种: 手动配置.framework形式开发包
[这个自己看官方文档](http://lbsyun.baidu.com/index.php?title=iossdk/guide/buildproject)
-
-
3.4.集成结束,下面咱们就使用一下
- 3.4.1.初始化BMKMapManager
里面包含所有的类名
导入 #import <BaiduMapAPI_Map/BMKMapComponent.h>
-
3.4.2.在您的AppDelegate.h文件中添加
BMKMapManager
的定义
@interface AppDelegate () <UIApplicationDelegate>
{
BMKMapManager* _mapManager;
}- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { /** * 注册百度地图 */ // 要使用百度地图,请先启动BaiduMapManager _mapManager = [[BMKMapManager alloc]init]; // 如果要关注网络及授权验证事件,请设定 generalDelegate参数 BOOL ret = [_mapManager start:@"35WfYq1UDlQoGLgUnHYoK1bklZIYxjeV" generalDelegate:nil]; if (!ret) { NSLog(@"开启失败"); }
运行之后可能会报错
解决办法:
再次运行就不会报错了,但是可能会开启失败
- 3.4.3.开启成功之后的事(自己创建一个控制器作为
window
的根控制器)
- 3.4.1.初始化BMKMapManager
(1).导入 #import <BaiduMapAPI_Map/BMKMapComponent.h>
(2). 创建BMKMapView对象
//宽高的设置
#define WIDTH [UIScreen mainScreen].bounds.size.width
#define HEIGHT [UIScreen mainScreen].bounds.size.height
@property(nonatomic,strong) BMKMapView *bMKMapView;
-(BMKMapView *)bMKMapView
{
if (!_bMKMapView) {
_bMKMapView = [[BMKMapView alloc]initWithFrame:CGRectMake(0, 0, WIDTH, HEIGHT)];
}
return _bMKMapView;
}
-(void)viewWillAppear:(BOOL)animated
{
[self.bMKMapView viewWillAppear];
self.bMKMapView.delegate = self; // 此处记得不用的时候需要置nil,否则影响内存的释放
}
-(void)viewWillDisappear:(BOOL)animated
{
[self.bMKMapView viewWillDisappear];
self.bMKMapView.delegate = nil; // 不用时,置nil
}
(3).加载地图
[self.view addSubview:self.bMKMapView];
到此最简单的地图展示就可以出来了
最简单的地图展示 密码: srbp
四.实现百度地图的周边搜做功能
简单的展示:
-
4.1.导入静态库里面的类
#import <BaiduMapAPI_Search/BMKPoiSearch.h> 俩代理 一个地图代理,一个搜索代理 <BMKMapViewDelegate,BMKPoiSearchDelegate>
-
4.2.加入方法发起检索(检索方法必须放到地图显示出来以后)
否则回报如下的错
- 4.3.把检索的方法写在地图显示之后的代理方法里面
#pragma mark 长按地图发起检索
-(void)mapview:(BMKMapView *)mapView onLongClick:(CLLocationCoordinate2D)coordinate
{
//1.初始化检索对象(在懒加载里面)
//2.发起检索
BMKNearbySearchOption *option = [[BMKNearbySearchOption alloc]init];
//当前页码
option.pageIndex = 0;
//每页显示的数据
option.pageCapacity = 10;
option.location = (CLLocationCoordinate2D){39.915, 116.404};
option.keyword = @"小吃";
BOOL flag = [self.searcher poiSearchNearBy:option];
//这mrc的情况,arc不需要
//[option release];
if(flag)
{
NSLog(@"周边检索发送成功");
}
else
{
NSLog(@"周边检索发送失败");
}
}
有可能错
-
4.4.数据检索成功之后打印出来
-
4.5.以大头阵的形式展示出来
/** * 4.添加大头针 */ // 添加一个PointAnnotation BMKPointAnnotation* annotation = [[BMKPointAnnotation alloc]init]; //经纬度传进来 annotation.coordinate = poiInfo.pt; //名字传进来 annotation.title = poiInfo.name; //地址传进来 annotation.subtitle = poiInfo.address; //添加大头针 [self.bMKMapView addAnnotation:annotation];
处理办法:
/**
* 3.1.修改当前显示区域
*/
//跨度
BMKCoordinateSpan span = BMKCoordinateSpanMake(0.014383, 0.012235);
//区域范围
BMKCoordinateRegion coordinateRegion = BMKCoordinateRegionMake(coordinate, span);
//在地图上添加区域
[self.bMKMapView setRegion:coordinateRegion animated:YES];
封装好的百度地图:实现定位,POI搜索 密码: xi53
提醒在导入相关百度地图的类时,一共有以下几个
#import <BaiduMapAPI_Map/BMKAnnotationView.h>
#import <BaiduMapAPI_Base/BMKBaseComponent.h>
#import "BaiduMapAPI_Cloud/BMKCloudSearchComponent.h"
#import "BaiduMapAPI_Location/BMKLocationComponent.h"
#import <BaiduMapAPI_Radar/BMKRadarComponent.h>
#import <BaiduMapAPI_Utils/BMKUtilsComponent.h>
#import <BaiduMapAPI_Map/BMKMapComponent.h>
#import <BaiduMapAPI_Search/BMKSearchComponent.h>
- 有问题一起交流,路过的给个喜欢,谢谢!!!