39.iOS百度地图(手把手教)

  • 一.进入百度地图官方(注册应用)
  • 1.1.百度地图官方
  • 1.2.创建应用

    39.iOS百度地图(手把手教)_第1张图片
    FBABCE88-01DC-4183-A8D9-1A84DD0A94AA.png
  • 1.3.具体的应用填写

39.iOS百度地图(手把手教)_第2张图片
具体的应用填写
  • 1.4.安全码(也就是百度地图的安全码)
39.iOS百度地图(手把手教)_第3张图片
.安全码(也就是百度地图的安全码)

二.iOS地图开发

  • 2.1.地图开发的选择类型(根据自己的需求选择)


    39.iOS百度地图(手把手教)_第4张图片
    下载地图的有关things
  • 2.2.相关下载

![相关下载](http://upload-images.jianshu.io/upload_images/1728484-c3bbc6b87c9df233.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

三.下面真正的进行开发(先实现地图的展示)

39.iOS百度地图(手把手教)_第5张图片
下面的操作按着这6部分来做
  • 3.1申请秘钥直接在应用里面获取就好了
39.iOS百度地图(手把手教)_第6张图片
应用秘钥
  • 3.2.注意事项(一共12项)

  • 3.2.1.静态库中采用ObjectC++实现,因此需要您保证您工程中至少有一个.mm后缀的源文件(您可以将任意一个.m后缀的文件改名为.mm),或者在工程属性中指定编译方式,即在Xcode的Project -> Edit Active Target -> Build Setting 中找到 Compile Sources As,并将其设置为"Objective-C++"

    39.iOS百度地图(手把手教)_第7张图片
    3.2.1静态库中采用ObjectC++实现
    • 3.2.2.如果您只在Xib文件中使用了BMKMapView,没有在代码中使用BMKMapView,编译器在链接时不会链接对应符号,需要在工程属性中显式设定:在Xcode的Project -> Edit Active Target -> Build Setting -> Other Linker Flags中添加-ObjC
    39.iOS百度地图(手把手教)_第8张图片
    工程属性中显式设定
    • 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的使用。

    39.iOS百度地图(手把手教)_第9张图片
    安全的https
    • 3.2.5.如果在iOS9中使用了调起百度地图客户端功能,必须在"Info.plist"中进行如下配置,否则不能调起百度地图客户端。

        LSApplicationQueriesSchemes
          
             baidumap
         
      
      39.iOS百度地图(手把手教)_第10张图片
      调起百度地图客户端功能
    • 3.2.6.管理地图的生命周期:自2.0.0起,BMKMapView新增viewWillAppear、viewWillDisappear方法来控制BMKMapView的生命周期,并且在一个时刻只能有一个BMKMapView接受回调消息,因此在使用BMKMapView的viewController中需要在viewWillAppear、viewWillDisappear方法中调用BMKMapView的对应的方法,并处理delegate

    39.iOS百度地图(手把手教)_第11张图片
    管理地图的生命周期
    • 3.2.7.自iOS SDK v2.5.0起,为了对iOS8的定位能力做兼容,做了相应的修改,开发者在使用过程中注意事项如下: 需要在info.plist里添加(以下二选一,两个都添加默认使用NSLocationWhenInUseUsageDescription):
      NSLocationWhenInUseUsageDescription ,允许在前台使用时获取GPS的描述
      NSLocationAlwaysUsageDescription ,允许永久使用GPS的描述

      39.iOS百度地图(手把手教)_第12张图片
      GPS定位请求
    • 3.2.8.在使用Xcode6进行SDK开发过程中,需要在info.plist中添加:Bundle display name ,且其值不能为空(Xcode6新建的项目没有此配置,若没有会造成manager start failed)

    39.iOS百度地图(手把手教)_第13张图片
    3.2.8.Bundle display name
    • 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中即可。若您需要替换定位、指南针的图标,请保留原文件名称,否则不显示替换的新图片,默认大头针标注与路线关键点的新图片名称可自定义名称。

    39.iOS百度地图(手把手教)_第14张图片
    3.2.10.mapapi.bundle文件以及添加方法

    注意:如果采用的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'
      

    成功后这些会被自动生成


    39.iOS百度地图(手把手教)_第15张图片
    成功后这些会被自动生成
    • 第二种: 手动配置.framework形式开发包
    [这个自己看官方文档](http://lbsyun.baidu.com/index.php?title=iossdk/guide/buildproject)
    
  • 3.4.集成结束,下面咱们就使用一下


    39.iOS百度地图(手把手教)_第16张图片
    百度地图的调用
    • 3.4.1.初始化BMKMapManager
      里面包含所有的类名
      导入 #import
    39.iOS百度地图(手把手教)_第17张图片
    BMKMapComponent.h包含所有的类名
    • 3.4.2.在您的AppDelegate.h文件中添加BMKMapManager的定义
      @interface AppDelegate ()
      {
      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(@"开启失败");
          }
      

    运行之后可能会报错

    39.iOS百度地图(手把手教)_第18张图片
    cocopods导入运行之后可能会报错

    解决办法:

    39.iOS百度地图(手把手教)_第19张图片
    解决办法:

    再次运行就不会报错了,但是可能会开启失败

    39.iOS百度地图(手把手教)_第20张图片
    开启失败的解决办法
    • 3.4.3.开启成功之后的事(自己创建一个控制器作为window的根控制器)
39.iOS百度地图(手把手教)_第21张图片
自己创建一个存放mapView的控制器

(1).导入 #import

(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];

到此最简单的地图展示就可以出来了

39.iOS百度地图(手把手教)_第22张图片
最简单的地图展示

最简单的地图展示 密码: srbp

四.实现百度地图的周边搜做功能

简单的展示:

39.iOS百度地图(手把手教)_第23张图片
百度地图的周边搜做功能
  • 4.1.导入静态库里面的类

     #import 
     俩代理 一个地图代理,一个搜索代理 
    
39.iOS百度地图(手把手教)_第24张图片
静态库里面的类导入
  • 4.2.加入方法发起检索(检索方法必须放到地图显示出来以后)
    否则回报如下的错


    39.iOS百度地图(手把手教)_第25张图片
    放在地图之前报错
  • 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(@"周边检索发送失败");
   }
}

有可能错
39.iOS百度地图(手把手教)_第26张图片
报错处理
  • 4.4.数据检索成功之后打印出来


    39.iOS百度地图(手把手教)_第27张图片
    数据检索成功之后打印出来
  • 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];
    
39.iOS百度地图(手把手教)_第28张图片
以大头阵的形式展示出来

处理办法:

/**
 *  3.1.修改当前显示区域
 */
//跨度
BMKCoordinateSpan span = BMKCoordinateSpanMake(0.014383, 0.012235);
//区域范围
BMKCoordinateRegion coordinateRegion = BMKCoordinateRegionMake(coordinate, span);
//在地图上添加区域
[self.bMKMapView setRegion:coordinateRegion animated:YES];
39.iOS百度地图(手把手教)_第29张图片
完整的地图

封装好的百度地图:实现定位,POI搜索 密码: xi53

提醒在导入相关百度地图的类时,一共有以下几个

  #import 
  #import 
  #import "BaiduMapAPI_Cloud/BMKCloudSearchComponent.h"
  #import "BaiduMapAPI_Location/BMKLocationComponent.h"
  #import 
  #import 
  #import 
  #import 
  • 有问题一起交流,路过的给个喜欢,谢谢!!!

你可能感兴趣的:(39.iOS百度地图(手把手教))