目录[-]
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° ~ 359.9°, 0.0°代表真北方向)
@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;
//城市
|