定位及耗电

iOS-GPS定位基础知识

iOS -GPS定位服务和地图应用是两套完全不同的API

iOS7 的四种定位服务
-GPS卫星 优点最为准确,缺点 耗电量大,不能遮挡(建筑物内不行)
-WI-FI通过WIFI路由器定位 优点比较省电,经济实惠
-蜂窝式移动电话基站。通过移动运营商基站定位 误差比较大
-iBeacon微定位。 苹果公司自己研发的iBeacon,使用低功耗的蓝牙。
iOS 定位服务开发不需要指定定位途径(除了微定位外)ios 会根据设备的情况采用最佳方案,如果能接受GPS优先采用GPS定位,次之是Wi-Fi ,最后是蜂窝式基站定位;

iOS 7 定位服务使用Core Location框架

CLLocationManager 用于定位管理的类,他提供位置信息和高度信息,也可以监控设备进入或者离开某个区域,还可以获得设备的运行方向;
CLLocationManagerDelegate。CLLocationManager类的委托协议;
CLLocation 封装了位置和高度信息;
第一次请求定位信息时,系统会提示用户是否允许开启定位服务。

{  
    [super viewDidLoad];  
    locationManager = [[CLLocationManager alloc]init];  
    locationManager.delegate = self;  
    locationManager.desiredAccuracy = kCLLocationAccuracyBest;  
    locationManager.distanceFilter = 1000.f;  
}

初始化一个定位管理器设置好代理
desireAccuracy这个属性用来设置经度的:

kCLLocationAccuracyBest; 电池供电的最高精度  
kCLLocationAccuracyNearestTenMeters; 精确到10米  
kCLLocationAccuracyHundredMeters;精确到100米  
kCLLocationAccuracyKilometer;精确到1000米  
kCLLocationAccuracyThreeKilometers;精确到3000米

经度越高获得信息时间越短。耗电越多。
distabceFilter 属性定义了设备移动后获得位置信息的最小距离,单位是米;
设置距离筛选器distanceFilter,表示设备至少移动1000米,才通知委托更新
在视图展现的时候分别开启和关闭定位服务

- (void)viewWillAppear:(BOOL)animated  
{  
    [super viewWillAppear:animated];  
    [locationManager startUpdatingLocation];  
}  
- (void)viewWillDisappear:(BOOL)animated  
{  
    [super viewWillDisappear:animated];  
    [locationManager stopUpdatingLocation];  
} 

当获取位置成功的时候进行调用代理来获取数据

- (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations  
{  
    CLLocation * currentLocation = [locations lastObject];  
    double  altitude = currentLocation.altitude;//高度  
    double  latitude = currentLocation.coordinate.latitude;  
    double  longitude = currentLocation.coordinate.longitude;  
} 

代理中得lication是位置数据数组,最后一个是当前位置 ;

cllocation类

初始化函数  
  
– initWithLatitude:longitude:  
– initWithCoordinate:altitude:horizontalAccuracy:verticalAccuracy:timestamp:  
– initWithCoordinate:altitude:horizontalAccuracy:verticalAccuracy:course:speed:timestamp:  
属性:  
   coordinate  property             地理坐标  
   altitude  property               高度  
   horizontalAccuracy  property     地图中显示圆的半径  
   verticalAccuracy  property       垂直高度的精确度  
   timestamp  property              位置确定的时间  
– distanceFromLocation:   指定位置到当前位置的距离  
   speed  property              运动的速度  
   course  property         设备的方向  
CLLocation 封装了位置、高度等信息    
    altitude是高度值 coordinate是封装的经纬度的结构体 CLLocationCoordinate2D  
    typedef struct {  
    CLLocationDegrees latitude;     //经度  
    CLLocationDegrees longitude;    //纬度  
    } CLLocationCoordinate2D;  
      
    CLLocationDegrees 是double类型别名  

你可能感兴趣的:(定位及耗电)