CoreLocation定位

定位

-在iOS開發(fā)中想要加入定位和地圖功能,那么必須基于CoreLocationMapKit2個(gè)框架進(jìn)行開發(fā)
-CoreLocation:地理定位,地理編碼,區(qū)域監(jiān)聽
-MapKit:地圖展示,規(guī)劃路線

定位

-CLLocation對象
-1.coordinate經(jīng)緯度數(shù)據(jù)
-2.altitude海拔
-3.speed當(dāng)前速度
-4.course航向
-5.- (CLLocationDistance)distanceFromLocation:(CLLocation *)location可以通過此方法來獲取兩個(gè)位置對象之間的物理距離

-iOS8.0之前的前臺(tái)定位
//ios 8.0前臺(tái)定位 CLLocationManager *locM = [[CLLocationManager alloc] init]; locM.delegate = self; //開始跟新 [locM startUpdatingLocation]; //-(void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray<CLLocation *> *)locations代理方法中可以獲取位置請求信息

  • iOS8.0之前的后臺(tái)定位:只需要在前臺(tái)模式下的基礎(chǔ)上勾選后臺(tái)模式location updatas或者直接設(shè)置info.plist文件
    -iOS8.0之后的前臺(tái)定位:
    -1.在iOS8.0的前臺(tái)定位基礎(chǔ)上主動(dòng)請求前臺(tái)定位授權(quán).并且在info.plist文件中配置對應(yīng)的key
    [self.locationM requestWhenInUseAuthorization];//->Nslocationwheninuseusagedescription
    

-iOS8.0后臺(tái)定位:只需要在前臺(tái)定位的基礎(chǔ)上,勾選后臺(tái)模式location updates
-iOS8.0之前的前后臺(tái)定位授權(quán):
[self.locationM requestAlwaysAuthorization];//強(qiáng)求前后臺(tái)定位授權(quán) KEY: NSLocationAlwaysUsageDescription//配置對應(yīng)的key

  • iOS9.0之后的前臺(tái)定位:與iOS8.0保持一致
  • iOS9.0之后的后臺(tái)定位:
    -1.前臺(tái)定位授權(quán)
    -2.勾選后臺(tái)模式
    -3.設(shè)置屬性allowsBackgroundLocationUpdates = YES;
  • iOS9.0之后的前后臺(tái)定位:直接請求前后臺(tái)定位授權(quán),和iOS8.0之后一致
定位-設(shè)置定位精確度

-通過 desiredAccuracy來設(shè)置定位精確度,定位本省非常耗電,定位的精確度越高,越耗電,為了省電盡量在滿足需求的情況下低精確度
kCLLocationAccuracyBestForNavigation -> 最適合導(dǎo)航 kCLLocationAccuracyBest -> 精度最好的 kCLLocationAccuracyNearestTenMeters -> 附近10米 kCLLocationAccuracyHundredMeters -> 附近100米 kCLLocationAccuracyKilometer -> 附近1000米 kCLLocationAccuracyThreeKilometers -> 附近3000米

定位-監(jiān)聽用戶授權(quán)狀態(tài)

-可以在CLLocationManager的代理方法-locationManager: didChangeAuthorizationStatus:來獲取當(dāng)前的授權(quán)狀態(tài)

kCLAuthorizationStatusNotDetermined 用戶未決定
kCLAuthorizationStatusRestricted 訪問受限制
kCLAuthorizationStatusDenied     定位被拒絕
kCLAuthorizationStatusAuthorizedAlways  前后臺(tái)定位授權(quán)
kCLAuthorizationStatusAuthorizedWhenInUse 前臺(tái)定位授權(quán)
地理編碼/反地理編碼

-地理編碼:根據(jù)地質(zhì)關(guān)鍵字,將其轉(zhuǎn)換成為對應(yīng)的經(jīng)緯度等信息
-1.導(dǎo)入頭文件#import <CoreLocation/CoreLocation.h>
-2.創(chuàng)建CLGeocoder對象
-3.根據(jù)地址關(guān)鍵字進(jìn)行地理編碼
[self.geocoder geocodeAddressString:地址 completionHandler:^(NSArray<CLPlacemark *> * __nullable placemarks, NSError * __nullable error)
-反地理編碼:根據(jù)經(jīng)緯度信息,將其轉(zhuǎn)換成為對應(yīng)的省市區(qū)街道等信息
-1.導(dǎo)入框架#import <CoreLocation/CoreLocation.h>
-2.創(chuàng)建CLGeocoder對象
-3.根據(jù)經(jīng)緯度信息進(jìn)行反地理編碼
[self.geocoder reverseGeocodeLocation:[[CLLocation alloc] initWithLatitude:21 longitude:123] completionHandler:^(NSArray<CLPlacemark *> * __nullable placemarks, NSError * __nullable error)
-CLPlacemark:地址對象
location : CLLocation 類型, 位置對象信息, 里面包含經(jīng)緯度, 海拔等等 region: CLRegion 類型, 地標(biāo)對象對應(yīng)的區(qū)域 addressDictionary : NSDictionary 類型, 存放街道,省市等信息 name: NSString 類型, 地址全稱 thoroughfare: NSString 類型, 街道名稱 locality: NSString 類型, 城市名稱 administrativeArea : NSString 類型, 省名稱 country: NSString 類型, 國家名稱

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容