1、概述

在iOS开发中,要想加入地图和定位功能这2大功能,必须基于2个框架进行开发

(1)Map Kit :用于地图展示

(2)Core Location :用于地理定位

2个热门专业术语:

LBS :Location Based Service

SoLoMo :Social Local Mobile

2CoreLocation框架的使用

CoreLocation框架使用前提:

导入框架:

导入主头文件:

#import <CoreLocation/CoreLocation.h>

CoreLocation框架使用须知:

CoreLocation框架中所有数据类型的前缀都是CL

CoreLocation中使用CLLocationManager对象来做用户定位

3CLLocationManager

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;

4CLLocation

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);

5CLLocationManager

@property(assign, nonatomic) CLLocationDistance distanceFilter;

每隔多少米定位一次

 

@property(assign, nonatomic) CLLocationAccuracy desiredAccuracy;

定位精确度(越精确就越耗电)

6CLLocationCoordinate2D

CLLocationCoordinate2D是一个用来表示经纬度的结构体,定义如下:

typedef struct {

        CLLocationDegrees latitude; // 纬度

        CLLocationDegrees longitude; // 经度

} CLLocationCoordinate2D;

一般用CLLocationCoordinate2DMake函数来创建CLLocationCoordinate2D。

7、用户隐私的保护

开发者可以在Info.plist中设置NSLocationUsageDescription说明定位的目的(Privacy - Location Usage Description)。

一旦用户选择了“Don’t Allow”,意味着你的应用以后就无法使用定位功能。为了严谨起见,最好在使用定位功能之前判断当前应用的定位功能是否可用。

CLLocationManager有个类方法可以判断当前应用的定位功能是否可用:

+ (BOOL)locationServicesEnabled;

8CLGeocoder

使用CLGeocoder可以完成“地理编码”和“反地理编码”:

地理编码:根据给定的地名,获得具体的位置信息(比如经纬度、地址的全称等)。

反地理编码:根据给定的经纬度,获得具体的位置信息。

地理编码方法:

- (void)geocodeAddressString:(NSString *)addressString completionHandler:(CLGeocodeCompletionHandler)completionHandler;

反地理编码方法:

- (void)reverseGeocodeLocation:(CLLocation *)location completionHandler:(CLGeocodeCompletionHandler)completionHandler;

9CLGeocodeCompletionHandler

当地理\反地理编码完成时,就会调用CLGeocodeCompletionHandler:

typedef void (^CLGeocodeCompletionHandler)(NSArray *placemarks, NSError *error);

这个block传递2个参数:

error :当编码出错时(比如编码不出具体的信息)有值

placemarks :里面装着CLPlacemark对象

10CLPlacemark

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;

城市