zoukankan      html  css  js  c++  java
  • iOS开发之集成百度地图踩过的那些坑(基于 Xcode7.0/iOS9.2)

    本篇分4步讲述如何在项目中集成百度地图:

    第一步:创建项目

    第二步:利用 cocoaPod 导入百度地图的 SDK(pod 'BaiduMapKit' #百度地图SDK)

    第三步:在 pch 文件中导入头文件和秘钥

    秘钥是在 http://lbsyun.baidu.com/apiconsole/key 百度开放平台申请。

    #define APPKEY @"UzyiXewPsqPhcE1yS8wxqik9"

    在使用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>//只引入所需的单个头文件

    第四步:在AppDelegate.m文件中加载地图管理者

    - (BMKMapManager *)mapManager {
        if (!_mapManager) {
            _mapManager = [[BMKMapManager alloc] init];
            BOOL ret = [_mapManager start:APPKEY generalDelegate:nil];
            if (!ret) {
                NSLog(@"manager start failed!");
            } else {
                NSLog(@"manager start success!");
            }
        }
        return _mapManager;
    }
    
    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
        // Override point for customization after application launch.
        [self mapManager];
        return YES;
    }

    到此步,我们就可以正常运行百度地图了。

    但是,需要注意的是在控制台上会输出以下信息:

    那么我们按照要求一步步来就是了,首先在 plist 文件中配置 Bundle display name,其实这是在Xcode6中需要配置的信息,Xcode7中并没有要求

    <key>CFBundleDisplayName</key>
    <string>$(PRODUCT_NAME)</string>

    再次运行,地图管理者便加载成功了,但是由于iOS9改用更安全的https,为了能够在iOS9中正常使用百度地图SDK,此时还需注入 ATS

    <key>NSAppTransportSecurity</key>
    <dict>
        <key>NSAllowsArbitraryLoads</key>
        <true/>
    </dict>

    此时虽然不会报错,管理者同样加载成功了,地图的网格也有了,但是地图详细信息貌似不能显示出来了。

    这时检查一下你的 key 是否正确,我是犯过一次,一定以保证申请 key 是的安全码与项目的Bundle Identifier保持一致。

    这时百度地图便算是成功集成了。

    注意:本篇文章中为说明的地方均未进行配置。

    app在前后台切换时,需要使用下面的代码停止地图的渲染和openGL的绘制:

    - (void)applicationWillResignActive:(UIApplication *)application {
        [BMKMapView willBackGround];//当应用即将后台时调用,停止一切调用opengl相关的操作
    }
    - (void)applicationDidBecomeActive:(UIApplication *)application {
        [BMKMapView didForeGround];//当应用恢复前台状态时调用,回复地图的渲染和opengl相关的操作
    }
  • 相关阅读:
    react项目建立导入包问题总结
    React中创建组件的3种方式
    export default与export的区别
    vue中的过滤器
    git clone https://chromium.googlesource.com/失败
    typescript 实现函数重载
    Rename a local and remote branch in git
    使用typescript开发react应用
    自己实现一个Promise库
    【翻译】Webpack 4 从0配置到生产模式
  • 原文地址:https://www.cnblogs.com/Jepson1218/p/5285948.html
Copyright © 2011-2022 走看看