iOS GPS定位开发基础知识

jopen 10年前

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

iOS 7 的 四种定位服务

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

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

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

 - (void)viewDidLoad  {      [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类型别名