欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

iOS 百度地图SDK-配置开发环境

程序员文章站 2022-06-10 13:15:34
...

虽然百度地图应经用了很多次了,但是每次都浪费很长时间来配置,所以今天把配置百度地图SDK的过程记录下来,也方便日后查看。

第一步、导入百度SDK

百度地图SDK支持手动和使用CocoaPods自动配置

自动配置.framework形式开发包(使用CocoaPods)

1、进入工程所在根目录执行:

 pod init   // 初始化后,会自动创建`Podfile`文件

2、搜索百度地图SDK在CocoaPods的版本号:

 pod search  BaiduMapKit 

3、编辑Podfile内容如下:

 pod 'BaiduMapKit', '3.3.0'   // 3.3.0是当前最新的版本号

4.在Podfile所在的文件夹下输入命令:

 pod install

成功以后,会出现如下记录:

Analyzing dependencies
Downloading dependencies
Installing BaiduMapKit (3.3.0)
Generating Pods project
Integrating client project
[!] Please close any current Xcode sessions and use BaiDuPoiSearch.xcworkspace for this project from now on

手动配置.framework形式开发包

1、根据需要导入 .framework包,将所需要的BaiduMapAPI_**.framework拷贝到工程所在文件夹下,BaiduMapAPI_Base.framework为基础包,使用SDK任何功能都需导入,其他分包可按需导入

2、在TARGETS->Build Phases->Link Binary With Libaries中点击“+”按钮,在弹出的窗口中点击Add Other按钮,选择BaiduMapAPI_**.framework添加到工程中

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

第二步、引入所需的系统依赖库

百度地图SDK中提供了定位功能和动画效果,v2.0.0版本开始使用OpenGL渲染因此您需要在您的Xcode工程中引入:
CoreLocation.frameworkQuartzCore.frameworkOpenGLES.frameworkSystemConfiguration.frameworkCoreGraphics.frameworkSecurity.frameworklibsqlite3.0.tbdCoreTelephony.frameworklibstdc++.6.0.9.tbd

添加方法:在Xcode的Project -> Active Target ->Build Phases ->Link Binary With Libraries,添加这几个系统库即可

第三步、引入所需的第三方openssl库

添加支持HTTPS所需的penssl静态库:libssl.alibcrypto.a(SDK打好的包存放于thirdlib目录下

添加方法:TARGETS->Build Phases->Link Binary With Libaries中点击“+”按钮,在弹出的窗口中点击Add Other按钮,选择libssl.a和libcrypto.a添加到工程中

第四步、环境配置

TARGETS->Build Settings->Other Linker Flags 中添加-ObjC

第五步、引入mapapi.bundle资源文件

如果使用了基础地图功能,需要添加该资源,否则地图不能正常显示mapapi.bundle中存储了定位、默认大头针标注View及路线关键点的资源图片,还存储了矢量地图绘制必需的资源文件。如果您不需要使用内置的图片显示功能,则可以删除bundle文件中的image文件夹。您也可以根据具体需求任意替换或删除该bundleimage文件夹的图片文件。

添加方法:选中工程名,在右键菜单中选择Add Files to …,从BaiduMapAPI_Map.framework||Resources文件中选择mapapi.bundle文件,并勾选Copy items if needed复选框,单击Add按钮,将资源文件添加到工程中。

第六步、引入头文件

在使用SDK的类 按需 引入下边的头文件:

#import <BaiduMapAPI_Base/BMKBaseComponent.h>//引入base相关所有的头文件
#import <BaiduMapAPI_Map/BMKMapComponent.h>//引入地图功能所有的头文件
#import <BaiduMapAPI_Search/BMKSearchComponent.h>//引入检索功能所有的头文件
#import <BaiduMapAPI_Cloud/BMKCloudSearchComponent.h>//引入云检索功能所有的头文件
#import <BaiduMapAPI_Location/BMKLocationComponent.h>//引入定位功能所有的头文件
#import <BaiduMapAPI_Utils/BMKUtilsComponent.h>//引入计算工具所有的头文件
#import <BaiduMapAPI_Radar/BMKRadarComponent.h>//引入周边雷达功能所有的头文件
#import <BaiduMapAPI_Map/BMKMapView.h>//只引入所需的单个头文件

第七步、调用客户端

如果在iOS9中使用了调起百度地图客户端功能,必须在Info.plist中进行如下配置,否则不能调起百度地图客户端。

    <key>LSApplicationQueriesSchemes</key>
    <array>
        <string>baidumap</string>
    </array>

第八步、开启定位提醒

自iOS SDK v2.5.0起,为了对iOS8的定位能力做兼容,做了相应的修改,开发者在使用过程中注意事项如下:

需要在info.plist里添加(以下二选一,两个都添加默认使用NSLocationWhenInUseUsageDescription):

  • NSLocationWhenInUseUsageDescription // 允许在前台使用时获取GPS的描述

  • NSLocationAlwaysUsageDescription // 允许永久使用GPS的描述

第九步、验证key和应用名称是否相符

在使用Xcode6进行SDK开发过程中,需要在info.plist中添加:Bundle display name ,且其值不能为空(Xcode6新建的项目没有此配置,若没有会造成manager start failed)

第十步、APPDelegate配置

.h文件

#import <BaiduMapAPI_Base/BMKBaseComponent.h>
@interface AppDelegate : UIResponder <UIApplicationDelegate,BMKGeneralDelegate>
@property (nonatomic,strong) BMKMapManager* mapManager;

.m文件

-(void)setUpBaiMap {
    //百度地图
    if ([[UIDevice currentDevice].systemVersion floatValue] >= 8) {
        //由于IOS8中定位的授权机制改变 需要进行手动授权
        CLLocationManager  *locationManager = [[CLLocationManager alloc] init];
        //获取授权认证
        [locationManager requestAlwaysAuthorization];
        [locationManager requestWhenInUseAuthorization];
        [locationManager startUpdatingLocation];
    }
    _mapManager = [[BMKMapManager alloc]init];
    // 如果要关注网络及授权验证事件,请设定     generalDelegate参数
    BOOL ret = [_mapManager start:BaiDu_MapKey  generalDelegate:self];
    if (!ret) {
        DLog(@"manager start failed!");
    }
}

#pragma mark - 百度地图
- (void)onGetNetworkState:(int)iError {
    if (0 == iError) {
        NSLog(@"联网成功");
    } else{
        NSLog(@"onGetNetworkState %d",iError);
    }
}

- (void)onGetPermissionState:(int)iError {
    if (0 == iError) {
        NSLog(@"授权成功");
        self.isMapPermission = YES;
    } else {
        NSLog(@"onGetPermissionState %d",iError);
    }
}

第十一步、管理地图的生命周期

自2.0.0起,BMKMapView新增viewWillAppear、viewWillDisappear方法来控制BMKMapView的生命周期,并且在一个时刻只能有一个`BMKMapView接受回调消息,因此在使用BMKMapView的viewController中需要在viewWillAppear、viewWillDisappear方法中调用BMKMapView的对应的方法,并处理delegate,代码如下:

-(void)viewWillAppear:(BOOL)animated
{
    [_mapView viewWillAppear];
    _mapView.delegate = self; // 此处记得不用的时候需要置nil,否则影响内存的释放
}
-(void)viewWillDisappear:(BOOL)animated
{
      [_mapView viewWillDisappear];
      _mapView.delegate = nil; // 不用时,置nil
}

总结

本文借鉴百度地图SDK-配置开发环境,只是对百度地图的配置进行了一下总结,仅供开发百度地图参考使用,如有侵权行为,请联系我并及时删除。