CoreLocation


摘要  本文主要介绍在在iOS开发中Core Location的定位功能.详细分析了CLLocationCoordinate2D, CLGeocoder 及 CLPlacemark 的具体使用方法.

CoreLocation

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

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

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

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

    Map Kit :用于地图展示;

    Core Location :用于地理定位;

注意两个热门专业术语:

    LBS : Location Based Service. 基于位置的服务(定位服务)

    SoLoMo : Social Local Mobile. 社交+本地化+移动

CoreLocation框架的使用:

CoreLocation框架使用前提:

    导入 CoreLocation.framework框架;    导入主头文件#import<CoreLocation/CoreLocation.h>.

CoreLocation框架使用须知:

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

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

CLLocationManager的常用操作:

    开始用户定位:

?
1
-( void )startUpdatingLocation;

    停止用户定位:

?
1
- ( void )stopUpdatingLocation;

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

?
1
- ( void )locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations;

    locations参数里面装着CLLocation对象.

CLLocation:

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

?
1
2
3
4
5
6
7
8
@property(readonly, nonatomic) CLLocationCoordinate2D coordinate;  //经纬度 
@property(readonly, nonatomic) CLLocationDistance altitude;        //海拔 
@property(readonly, nonatomic) CLLocationDirection course;         //路线,航向(取值范围是0.0&deg; ~ 359.9&deg;,                                                                                0.0&deg;代表真北方向) 
@property(readonly, nonatomic) CLLocationSpeed speed;              //行走速度(单位是m/s) 
/*计算2个位置之间的距离*/
- (CLLocationDistance)distanceFromLocation:( const  CLLocation *)location
@property(assign, nonatomic) CLLocationDistance distanceFilter;    //每隔多少米定位一次 
@property(assign, nonatomic) CLLocationAccuracy desiredAccuracy;   //定位精确度(越精确就越耗电)

CLLocationCoordinate2D:

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

?
1
2
3
4
typedef  struct  {
         CLLocationDegrees latitude;  // 纬度
         CLLocationDegrees longitude;  // 经度
} CLLocationCoordinate2D;

    一般用CLLocationCoordinate2DMake函数来创建CLLocationCoordinate2D;

用户隐私保护:

    从iOS6开始,苹果在保护隐私方面做了很大的加强,以下操作都必须经过用户批准授权:

    1> 想获得用户的位置;

    2> 想访问用户的通讯录, 日历, 相机, 相册等.

    当想访问用户的隐私信息时,系统会自动弹出一个对话框让用户选择.

    开发者可以在Info.plist中设置NSLocationUserDescription说明定位的目的(Infomation Property list / Privacy-Location Usage Description).

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

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

?
1
+( BOOL )locationServicesEnabled

CLGeocoder:

    使用CLGeocoder可以完成"地理编码"和"反地理编码".

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

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

地理编码方法:

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

反地理编码方法:

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

CLGeocoderCompletionHandler:

    当地理/反地理编码完成时,就会调用CLGeocoderCompletionHandler.

?
1
typedef  void  (^CLGeocoderCompletionHandler)(NSArray *placemarks, NSError *error);

这个block传递两个参数:

    placemarks : 里面装着CLPlacemark对象;

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

CLPlacemark

    CLPlacemark的字面意思是地标,封装详细的地址位置信息.

?
1
2
3
4
5
@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;      //城市
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值