首页 > 代码库 > CoreLocation详解

CoreLocation详解

简介:

* 在移动互联网时代,移动app能解决用户的很多生活琐事,比如

  > 导航:去任意陌生的地方

  > 周边:找餐馆,找酒店,找银行,找电影院

* 在上述应用中,都用到了地图和定位功能,在iOS开发中,要想加入这2大功能,必须基于2个框架进行开发

  > Map Kit : 用于地图展示

  > Core Location : 用于地理定位

 

CoreLocation框架的使用:

* CoreLocation框架使用前提

   > 导入框架

      

 

   > 导入主头文件

     #import <CoreLocation/CoreLocation.h>

* CoreLocation框架使用须知

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

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

1.CLLocationManager:

*CLLocationManger的常用操作

  > 开始用户定位  - (void)startUpdatingLocation;

// 检测定位服务是否可用(可能是程序第一次访问用户位置时,被用户点击了Don‘t Allow导致定位服务不可用)    if ([CLLocationManager locationServicesEnabled]) { // 如果定位服务能用,开始定位        [self.manager startUpdatingLocation]; // 通过代理告诉用户的位置            }else    {// 不能定位用户的位置        // 1.告诉用户检查网络状况        // 2.提醒用户打开定位开关    } 

  > 停止用户定位

      - (void) stopUpdatingLocation;

* 当调用了startUpdatingLocation方法后,就开始不断地定位用户的位置,中途会频繁地调用代理的下面方法 

// locations参数里面装着CLLocation对象
- (void) locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations;

常用属性:

// 每隔多少米定位一次@property(assign, nonatomic) CLLocationDistance distanceFilter;//定位精确度(越精确就越耗电)@property(assign, nonatomic) CLLocationAccuracy desiredAccuracy;

2.CLLocation:用来表示某个位置的地理信息,比如经纬度,海拔等等

属性: 

// 坐标(不是X,Y值,而是经纬度)@property(readonly, nonatomic) CLLocationCoordinate2D coordinate;// 海拔@property(readonly, nonatomic) CLLocationDistance altitude;// 路线,航向(取值范围是0.0° ~ 359.9°,0.0°代表真北方向)@property(readonly, nonatomic) CLLocationDirection course;// 行走速度(单位是m/s)@property(readonly, nonatomic) CLLocationSpeed speed;

方法:

// 计算2个位置之间的距离- (CLLocationDistance)distanceFromLocation:(const CLLocation *)location

3.经纬度(CLLocationCoordinate2D)

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

typedef struct {        CLLocationDegrees latitude; // 纬度        CLLocationDegrees longitude; // 经度} CLLocationCoordinate2D;

* 一般用CLLocationCoordinate2DMake函数来创建CLLocationCoordinate2D

 初始化方法1:CLLocationCoordinate2D startPt = (CLLocationCoordinate2D){0, 0};    //纬度,经度CLLocationCoordinate2D endPt = (CLLocationCoordinate2D){0, 0};
初始化方法2:CLLocationCoordinate2D coords
= CLLocationCoordinate2DMake(39.915352,116.397105);//纬度,经度

  > 横跨经度\纬度越大(1° ≈ 111km),表示的范围就越大,在地图上看到的东西就越小

使用模拟器模拟位置:

  *如果是模拟器,需要设置模拟位置(经纬度)

    *天朝帝都的经纬度是:北纬40°,东经119°

用户隐私保护:


4.CLGeocoder

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

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

     反地理编码:根据给定的经纬度,获得具体的位置信息
地理编码方法- (void)geocodeAddressString:(NSString *)addressString completionHandler:(CLGeocodeCompletionHandler)completionHandler;反地理编码方法- (void)reverseGeocodeLocation:(CLLocation *)location completionHandler:(CLGeocodeCompletionHandler)completionHandler;

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

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

*这个block传递2个参数

error :当编码出错时(比如编码不出具体的信息)有值
  placemarks :里面装着CLPlacemark对象

5.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;

 


  

 

CoreLocation详解