1、概述
在iOS開發中,要想加入地圖和定位功能這2大功能,必須基於2個框架進行開發
(1)Map Kit :用於地圖展示
(2)Core Location :用於地理定位
2個熱門專業術語:
LBS :Location Based Service
SoLoMo :Social Local Mobile(索羅門)
2、CoreLocation框架的使用
CoreLocation框架使用前提:
導入框架:
導入主頭文件:
#import <CoreLocation/CoreLocation.h>
CoreLocation框架使用須知:
CoreLocation框架中所有數據類型的前綴都是CL
CoreLocation中使用CLLocationManager對象來做用戶定位
3、CLLocationManager
CLLocationManager的常用操作:
(1)開始用戶定位
- (void)startUpdatingLocation;
(2)停止用戶定位
- (void) stopUpdatingLocation;
當調用了startUpdatingLocation方法后,就開始不斷地定位用戶的位置,中途會頻繁地調用代理的下面方法:
- (void)locationManager:(CLLocationManager *)manager
didUpdateLocations:(NSArray *)locations;
locations參數里面裝着CLLocation對象。
例如,取出位置對象:
CLLocation *loc = [locations firstObject];
打印經緯度:
NSLog(@"didUpdateLocations------%f %f", coordinate.latitude, coordinate.longitude);
使用前記得設置代理:
// 創建定位管理者
self.locMgr = [[CLLocationManager alloc] init];
// 設置代理
self.locMgr.delegate = self;
4、CLLocation
CLLocation用來表示某個位置的地理信息,比如經緯度、海拔等等。
@property(readonly, nonatomic) CLLocationCoordinate2D coordinate;
經緯度
@property(readonly, nonatomic) CLLocationDistance altitude;
海拔
@property(readonly, nonatomic) CLLocationDirection course;
路線,航向(取值范圍是0.0° ~ 359.9°,0.0°代表真北方向)
@property(readonly, nonatomic) CLLocationSpeed speed;
行走速度(單位是m/s)
- (CLLocationDistance)distanceFromLocation:(const CLLocation *)location計算2個位置之間的距離
例如:
計算2個經緯度之間的直線距離
CLLocation *loc1 = [[CLLocation alloc] initWithLatitude:40 longitude:116];
CLLocation *loc2 = [[CLLocation alloc] initWithLatitude:41 longitude:116];
CLLocationDistance distance = [loc1 distanceFromLocation:loc2];
NSLog(@"距離為%f", distance);
5、CLLocationManager
@property(assign, nonatomic) CLLocationDistance distanceFilter;
每隔多少米定位一次
@property(assign, nonatomic) CLLocationAccuracy desiredAccuracy;
定位精確度(越精確就越耗電)
6、CLLocationCoordinate2D
CLLocationCoordinate2D是一個用來表示經緯度的結構體,定義如下:
typedef struct {
CLLocationDegrees latitude; // 緯度
CLLocationDegrees longitude; // 經度
} CLLocationCoordinate2D;
一般用CLLocationCoordinate2DMake函數來創建CLLocationCoordinate2D。
7、用戶隱私的保護
開發者可以在Info.plist中設置NSLocationUsageDescription說明定位的目的(Privacy - Location Usage Description)。
一旦用戶選擇了“Don’t Allow”,意味着你的應用以后就無法使用定位功能。為了嚴謹起見,最好在使用定位功能之前判斷當前應用的定位功能是否可用。
CLLocationManager有個類方法可以判斷當前應用的定位功能是否可用:
+ (BOOL)locationServicesEnabled;
8、CLGeocoder
使用CLGeocoder可以完成“地理編碼”和“反地理編碼”:
地理編碼:根據給定的地名,獲得具體的位置信息(比如經緯度、地址的全稱等)。
反地理編碼:根據給定的經緯度,獲得具體的位置信息。
地理編碼方法:
- (void)geocodeAddressString:(NSString *)addressString completionHandler:(CLGeocodeCompletionHandler)completionHandler;
反地理編碼方法:
- (void)reverseGeocodeLocation:(CLLocation *)location completionHandler:(CLGeocodeCompletionHandler)completionHandler;
9、CLGeocodeCompletionHandler
當地理\反地理編碼完成時,就會調用CLGeocodeCompletionHandler:
typedef void (^CLGeocodeCompletionHandler)(NSArray *placemarks, NSError *error);
這個block傳遞2個參數:
error :當編碼出錯時(比如編碼不出具體的信息)有值
placemarks :里面裝着CLPlacemark對象
10、CLPlacemark
CLPlacemark的字面意思是地標,封裝詳細的地址位置信息。
@property (nonatomic, readonly) CLLocation *location;
地理位置
@property (nonatomic, readonly) CLRegion *region;
區域
@property (nonatomic, readonly) NSDictionary *addressDictionary;
詳細的地址信息
@property (nonatomic, readonly) NSString *name;
地址名稱
@property (nonatomic, readonly) NSString *locality;
城市