iOS 百度地圖v2.9.1 API 的詳細(xì)使用(一)

一、概述

百度地圖 iOS SDK是一套基于iOS 5.0及以上版本設(shè)備的應(yīng)用程序接口熄赡,不僅提供展示地圖的基本接口猾普,還提供POI檢索、路徑規(guī)劃本谜、地圖標(biāo)注初家、離線(xiàn)地圖、定位乌助、周邊雷達(dá)等豐富的LBS能力 溜在。目前最新版本為 v2.9.1。

二他托、引入百度地圖API

1.?申請(qǐng)密鑰?在使用SDK之前需要獲取百度地圖移動(dòng)版開(kāi)發(fā)密鑰(Key)掖肋,該key與你的百度賬戶(hù)相關(guān)聯(lián)。你必須先有百度帳戶(hù)赏参,才能獲得key志笼。并且,該key與引用SDK的程序包名有關(guān), 地圖初始化時(shí)需要用到Key把篓。

2.注意事項(xiàng)

1). 靜態(tài)庫(kù)中采用ObjectC++實(shí)現(xiàn)纫溃,因此需要您保證您工程中至少有一個(gè).mm后綴的源文件(您可以將任意一個(gè).m后綴的文件改名為.mm),或者在工程屬性中指定編譯方式韧掩,即將 Xcode 的 Project -> Edit Active Target -> Build -> GCC4.2 - Language -> Compile Sources As設(shè)置為"Objective-C++"

2). 如果您只在Xib文件中使用了BMKMapView紊浩,沒(méi)有在代碼中使用BMKMapView,編譯器在鏈接時(shí)不會(huì)鏈接對(duì)應(yīng)符號(hào),需要在工程屬性中顯式設(shè)定:在Xcode的Project -> Edit Active Target -> Build -> Linking -> Other Linker Flags中添加-ObjC

3). 由于iOS9改用更安全的https坊谁,為了能夠在iOS9中正常使用地圖SDK费彼,請(qǐng)?jiān)?Info.plist"中進(jìn)行如下配置,否則影響SDK的使用口芍。

4). 如果在iOS9中使用了調(diào)起百度地圖客戶(hù)端功能箍铲,必須在"Info.plist"中進(jìn)行如下配置,否則不能調(diào)起百度地圖客戶(hù)端鬓椭。

5). 管理地圖的生命周期:自2.0.0起虹钮,BMKMapView新增viewWillAppear、viewWillDisappear方法來(lái)控制BMKMapView的生命周期膘融,并且在一個(gè)時(shí)刻只能有一個(gè)BMKMapView接受回調(diào)消息芙粱,因此在使用BMKMapView的viewController中需要在viewWillAppear、viewWillDisappear方法中調(diào)用BMKMapView的對(duì)應(yīng)的方法氧映,并處理delegate春畔,代碼如下:

6). 自iOS SDK v2.5.0起,為了對(duì)iOS8的定位能力做兼容岛都,做了相應(yīng)的修改律姨,開(kāi)發(fā)者在使用過(guò)程中注意事項(xiàng)如下:需要在info.plist里添加(以下二選一,兩個(gè)都添加默認(rèn)使用NSLocationWhenInUseUsageDescription):

NSLocationWhenInUseUsageDescription 臼疫,允許在前臺(tái)使用時(shí)獲取GPS的描述

NSLocationAlwaysUsageDescription 择份,允許永久使用GPS的描述

7). 在使用Xcode 6進(jìn)行SDK開(kāi)發(fā)過(guò)程中,需要在info.plist中添加:Bundle?display?name?烫堤,且其值不能為空(Xcode 6新建的項(xiàng)目沒(méi)有此配置荣赶,若沒(méi)有會(huì)造成manager?start?failed)

8). 百度地圖iOS SDK v2.5.0起,對(duì)arm64進(jìn)行了支持適配鸽斟,開(kāi)發(fā)包體積有所增加拔创。但根據(jù)開(kāi)發(fā)者在研發(fā)過(guò)程中的選擇,最終生成的APP體積并不會(huì)發(fā)生較大的變化富蓄。

9). 確認(rèn)項(xiàng)目中添加mapapi.bundle文件以及添加方法正確剩燥,不能刪除或隨意更改其中files文件夾下的內(nèi)容:

注:mapapi.bundle中存儲(chǔ)了定位、默認(rèn)大頭針標(biāo)注View及路線(xiàn)關(guān)鍵點(diǎn)的資源圖片立倍,還存儲(chǔ)了矢量地圖繪制必需的資源文件灭红。如果您不需要使用內(nèi)置的圖片顯示功能,則可以刪除bundle文件中的image文件夾口注。您也可以根據(jù)具體需求任意替換或刪除該bundle中image文件夾的圖片文件变擒。添加方式:將mapapi.bundle拷貝到您的工程目錄,直接將該bundle文件托拽至Xcode工程左側(cè)的Groups&Files中即可疆导。若您需要替換定位赁项、指南針的圖標(biāo)葛躏,請(qǐng)保留原文件名稱(chēng)澈段,否則不顯示替換的新圖片悠菜,默認(rèn)大頭針標(biāo)注與路線(xiàn)關(guān)鍵點(diǎn)的新圖片名稱(chēng)可自定義名稱(chēng)。

10). 注意BMKManager對(duì)象的生命周期管理败富,在使用地圖SDK期間不能釋放該對(duì)象悔醋,尤其在arc情況下注意避免提前被自動(dòng)釋放,否則兽叮,該對(duì)象一旦被釋放芬骄,網(wǎng)絡(luò)模塊將不可用,地圖無(wú)法加載鹦聪,檢索失敗账阻。

11). app在前后臺(tái)切換時(shí),需要使用下面的代碼停止地圖的渲染和openGL的繪制:

3. 導(dǎo)入 SDK 開(kāi)發(fā)包

百度地圖iOS SDK自v2.7.0版本起泽本,向廣大開(kāi)發(fā)者提供了 .framework形式的SDK開(kāi)發(fā)包淘太,這種形式的開(kāi)發(fā)包配置簡(jiǎn)單,使用方便规丽,推薦大家使用蒲牧。開(kāi)發(fā)包有以下兩種配置方式:

1). 自動(dòng)配置.framework形式開(kāi)發(fā)包(使用CocoaPods)

注:此種方式只支持導(dǎo)入全量包的SDK,包含百度地圖iOS SDK所有功能

a. 前提:安裝CocoaPods

在終端輸入

sudo gem install cocoapods

如果安裝成功赌莺,會(huì)有一個(gè)提示

Successfully installed cocoaPods

b. 使用CocoaPods導(dǎo)入地圖SDK

在當(dāng)前工程文件(.xcodeproj)所在文件夾下冰抢,打開(kāi)terminal

I.創(chuàng)建Podfile:

$ touch Podfile

II.然后使用vim編輯Podfile文件,使用命令:

$ vim Podfile

III.編輯Podfile內(nèi)容如下:

pod ‘BaiduMapKit‘, ‘~> 2.9.1‘

在編輯完成后按“esc”艘狭,再按“:”,這個(gè)時(shí)候輸入wq,點(diǎn)擊回車(chē)挎扰,保存并退出。

IV.在Podfile所在的文件夾下輸入命令:

$ pod install (這個(gè)可能比較慢巢音,請(qǐng)耐心等待……)

成功以后鼓鲁,會(huì)出現(xiàn)如下記錄:

恭喜你已成功導(dǎo)入百度地圖iOS SDK,現(xiàn)在就可以打開(kāi)xcworkspace文件港谊,在你的項(xiàng)目中使用百度地圖SDK了.

2). 手動(dòng)配置.framework形式開(kāi)發(fā)包

a. 根據(jù)需要導(dǎo)入 .framework包

百度地圖 iOS SDK 采用分包的形式提供 .framework包骇吭,請(qǐng)廣大開(kāi)發(fā)者使用時(shí)確保各分包的版本保持一致。其中BaiduMapAPI_Base.framework為基礎(chǔ)包歧寺,使用SDK任何功能都需導(dǎo)入燥狰,其他分包可按需導(dǎo)入。將所需的BaiduMapAPI_**.framework拷貝到工程所在文件夾下斜筐。

在 TARGETS->Build Phases-> Link Binary With Libaries中點(diǎn)擊“+”按鈕龙致,在彈出的窗口中點(diǎn)擊“Add Other”按鈕,選擇BaiduMapAPI_**.framework添加到工程中顷链。

注: 靜態(tài)庫(kù)中采用Objective-C++實(shí)現(xiàn)目代,因此需要您保證您工程中至少有一個(gè).mm后綴的源文件(您可以將任意一個(gè).m后綴的文件改名為.mm),或者在工程屬性中指定編譯方式,即將Xcode的Project -> Edit Active Target -> Build -> GCC4.2 - Language -> Compile Sources As設(shè)置為"Objective-C++"

b. 引入所需的系統(tǒng)庫(kù)

百度地圖SDK中提供了定位功能和動(dòng)畫(huà)效果榛了,v2.0.0版本開(kāi)始使用OpenGL渲染在讶,因此您需要在您的Xcode工程中引入?

CoreLocation.framework?

QuartzCore.framework

OpenGLES.framework

SystemConfiguration.framework

CoreGraphics.framework

Security.framework

libsqlite3.0.tbd(xcode7以前為 libsqlite3.0.dylib)

CoreTelephony.framework?

libstdc++.6.0.9.tbd(xcode7以前為 libstdc++.6.0.9.dylib)

(注:紅色標(biāo)識(shí)的系統(tǒng)庫(kù)為v2.9.0新增的系統(tǒng)庫(kù),使用v2.9.0及以上版本的地圖SDK霜大,務(wù)必增加導(dǎo)入這3個(gè)系統(tǒng)庫(kù)构哺。)

添加方式:在Xcode的Project -> Active Target ->Build Phases ->Link Binary With Libraries,添加這幾個(gè)系統(tǒng)庫(kù)即可战坤。

c. 環(huán)境配置

在TARGETS->Build Settings->Other Linker Flags 中添加-ObjC曙强。

d. 引入mapapi.bundle資源文件

如果使用了基礎(chǔ)地圖功能,需要添加該資源途茫,否則地圖不能正常顯示mapapi.bundle中存儲(chǔ)了定位碟嘴、默認(rèn)大頭針標(biāo)注View及路線(xiàn)關(guān)鍵點(diǎn)的資源圖片,還存儲(chǔ)了矢量地圖繪制必需的資源文件囊卜。如果您不需要使用內(nèi)置的圖片顯示功能娜扇,則可以刪除bundle文件中的image文件夾。您也可以根據(jù)具體需求任意替換或刪除該bundle中image文件夾的圖片文件边败。

方法:選中工程名袱衷,在右鍵菜單中選擇Add Files to “工程名”…,從BaiduMapAPI_Map.framework||Resources文件中選擇mapapi.bundle文件笑窜,并勾選“Copy items if needed”復(fù)選框致燥,單擊“Add”按鈕,將資源文件添加到工程中排截。

e. 引入頭文件

4.初始化地圖

a. 初始化BMKMapManager

在AppDelegate.h文件中添加BMKMapManager的定義.

在AppDelegate.m文件中添加對(duì)BMKMapManager的初始化嫌蚤,并填入申請(qǐng)的授權(quán)Key,示例如下:

b. 創(chuàng)建BMKMapView

在ViewController.m文件中添加BMKMapView的創(chuàng)建代碼断傲,示例如下:

自2.0.0起脱吱,BMKMapView新增viewWillAppear、viewWillDisappear方法來(lái)控制BMKMapView的生命周期认罩,并且在一個(gè)時(shí)刻只能有一個(gè)BMKMapView接受回調(diào)消息箱蝠,因此在使用BMKMapView的viewController中需要在viewWillAppear、viewWillDisappear方法中調(diào)用BMKMapView的對(duì)應(yīng)的方法垦垂,并處理delegate宦搬,代碼如下:

編譯,運(yùn)行劫拗,效果如下圖所示:

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末间校,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子页慷,更是在濱河造成了極大的恐慌憔足,老刑警劉巖胁附,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異滓彰,居然都是意外死亡控妻,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門(mén)找蜜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)饼暑,“玉大人稳析,你說(shuō)我怎么就攤上這事洗做。” “怎么了彰居?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵诚纸,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我陈惰,道長(zhǎng)畦徘,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任抬闯,我火速辦了婚禮井辆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘溶握。我一直安慰自己杯缺,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布睡榆。 她就那樣靜靜地躺著萍肆,像睡著了一般。 火紅的嫁衣襯著肌膚如雪胀屿。 梳的紋絲不亂的頭發(fā)上塘揣,一...
    開(kāi)封第一講書(shū)人閱讀 49,166評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音宿崭,去河邊找鬼亲铡。 笑死,一個(gè)胖子當(dāng)著我的面吹牛葡兑,可吹牛的內(nèi)容都是我干的奖蔓。 我是一名探鬼主播,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼铁孵,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼锭硼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起蜕劝,我...
    開(kāi)封第一講書(shū)人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤檀头,失蹤者是張志新(化名)和其女友劉穎轰异,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體暑始,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡搭独,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了廊镜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片牙肝。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖嗤朴,靈堂內(nèi)的尸體忽然破棺而出配椭,到底是詐尸還是另有隱情,我是刑警寧澤雹姊,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布股缸,位于F島的核電站,受9級(jí)特大地震影響吱雏,放射性物質(zhì)發(fā)生泄漏敦姻。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一歧杏、第九天 我趴在偏房一處隱蔽的房頂上張望镰惦。 院中可真熱鬧,春花似錦犬绒、人聲如沸旺入。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)眨业。三九已至,卻和暖如春沮协,著一層夾襖步出監(jiān)牢的瞬間龄捡,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工慷暂, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留聘殖,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓行瑞,卻偏偏與公主長(zhǎng)得像奸腺,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子血久,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容