iOS百度地图小结

概述

由于项目需要,近期使用百度地图SDK实现了相关业务需求,主要功能包含定位、地址解析、添加标签、标签聚合、驾车路线规划等。本文除了讲解主要功能的实现之外,也记录了项目过程中遇到的一些问题及解决方案,以避免后续重复踩坑。

 

功能实现

  1. SDK 导入与初始化:采用cocoapods导入,除了pod install耗时比较长之外过程顺利,需要注意的是百度SDK采用bundleID验证机制,如果申请appid时绑定的bundleID与项目对应不上,会导致授权失败。关键授权代码如下

    [[BMKLocationAuth sharedInstance] checkPermisionWithKey:mapKey authDelegate:self]; 
    _mapManager = [[BMKMapManager alloc] init]; 
    BOOL result = [_mapManager start:mapKey generalDelegate:self]; 
    if (!result) { NSLog(@"启动引擎失败");

     

  2. 定位,定位由BMKLocationManager这个类实现,它主要封装了系统的CLLocationManager的一些方法和属性,因此在使用上与CLLocationManager基本无差别,比如设置精确度等等,主要代码

    [self.locationManager requestLocationWithReGeocode:YES withNetworkState:YES completionBlock:^(BMKLocation * _Nullable location, BMKLocationNetworkState state, NSError * _Nullable error){
        if(error){
            // 错误处理
        }else if(location){
         // 定位结果
        }
    }];

     

  3.    地址解析与逆地址解析,主要功能是实现根据地址获取经纬度或者根据经纬度获取具体地址(比如城市名称、区、街道以及cityCode等),调用地图SDK的BMKGeoCodeSearch的geoCode方法实现地址解析,调用reverseGeoCode方法实现逆地址解析,解析后的结果在回调中处理
        // 地址解析
        BMKGeoCodeSearch *search = [[BMKGeoCodeSearch alloc]init];
        search.delegate = self;
        BMKGeoCodeSearchOption *geoCodeSearchOption = [[BMKGeoCodeSearchOption alloc]init];
        geoCodeSearchOption.address = city;
        geoCodeSearchOption.city = city;
        BOOL flag = [search geoCode:geoCodeSearchOption];
        if (flag){
            NSLog(@"geo检索发送成功&
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值