定位
-在iOS開發(fā)中想要加入定位和地圖功能,那么必須基于CoreLocation
和MapKit
2個框架進(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
可以通過此方法來獲取兩個位置對象之間的物理距離
-iOS8.0之前的前臺定位
//ios 8.0前臺定位 CLLocationManager *locM = [[CLLocationManager alloc] init]; locM.delegate = self; //開始跟新 [locM startUpdatingLocation]; //-(void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray<CLLocation *> *)locations代理方法中可以獲取位置請求信息
- iOS8.0之前的后臺定位:只需要在前臺模式下的基礎(chǔ)上勾選后臺模式location updatas或者直接設(shè)置info.plist文件
-iOS8.0之后的前臺定位:
-1.在iOS8.0的前臺定位基礎(chǔ)上主動請求前臺定位授權(quán).并且在info.plist文件中配置對應(yīng)的key[self.locationM requestWhenInUseAuthorization];//->Nslocationwheninuseusagedescription
-iOS8.0后臺定位:只需要在前臺定位的基礎(chǔ)上,勾選后臺模式location updates
-iOS8.0之前的前后臺定位授權(quán):
[self.locationM requestAlwaysAuthorization];//強(qiáng)求前后臺定位授權(quán) KEY: NSLocationAlwaysUsageDescription//配置對應(yīng)的key
- iOS9.0之后的前臺定位:與iOS8.0保持一致
- iOS9.0之后的后臺定位:
-1.前臺定位授權(quán)
-2.勾選后臺模式
-3.設(shè)置屬性allowsBackgroundLocationUpdates = YES;
- iOS9.0之后的前后臺定位:直接請求前后臺定位授權(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 前后臺定位授權(quán)
kCLAuthorizationStatusAuthorizedWhenInUse 前臺定位授權(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 類型, 國家名稱