CoreLocation

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的常用操作:

    开始用户定位:

-(void)startUpdatingLocation;

    停止用户定位:

- (void)stopUpdatingLocation;

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

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

    locations参数里面装着CLLocation对象.

CLLocation:

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

@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是一个用来表示经纬度的结构体,定义如下:

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有个类方法可以判断当前应用的定位功能是否可用:

+(BOOL)locationServicesEnabled

CLGeocoder:

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

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

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

地理编码方法:

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

反地理编码方法:

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

CLGeocoderCompletionHandler:

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

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

这个block传递两个参数:

    placemarks : 里面装着CLPlacemark对象;

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

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,CLGeocoder,CLPlacemark)