iOS开发之CoreLocaiton框架使用(定位服务)

前言

在iOS开发中,定位和地图功能是比较常用的功能之一,要想加入这2大功能,必须基于2个框架进行开发。

(1) CoreLocation:用于地理定位,地理编码,区域监听等(着重功能实现)。

(2) MapKit:用于地图展示,例如大头针,路线、覆盖层展示等(着重界面展示)。

这篇文章我们来着重的介绍下CoreLocation框架

简介

CoreLocaiton框架是百度地图的定位也是在苹果API的基础上进行了封装。

CoreLocation框架使用前提

导入框架(Xcode5.0之后可以省略)

一 . iOS8.0之前的定位配置

1. 前台定位

直接引入头文件设置代理即可

2.后台定位

需要在前台定位基础上, 勾选后台模式Location updates

二 . iOS8.0之后的定位配置

1. 前台定位

请求前台定位授权, 并在Info.Plist文件中配置Key ( Nslocationwheninuseusagedescription )

参数类型为字符串 如果输入内容则是提示用户的内容

2.后台定位

第一种解决方案

请求前后台定位授权,并在info.plist文件中配置KEY ( NSLocationAlwaysUsageDescription )

第二种解决方案

需要在前台定位基础上, 勾选后台模式Location updates

导入主头文件

#import<CoreLocation/CoreLocation.h>

CoreLocation框架使用前须知

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

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

定位服务

<CLLocationManagerDelegate>需要遵守这个代理

开始更新用户位置

-(void)startUpdatingLocation;

停止更新用户位置

-(void)stopUpdatingLocation;

当调用了startUpdatingLocation方法后,就开始不断地请求、刷新用户的位置,一旦请求到用户位置就会调用代理的下面方法

-(void)locationManager:(CLLocationManager*)managerdidUpdateLocations:(NSArray*)locations;

locations参数里面装着CLLocation对象(下面我会详细介绍CLLocation对象)

为了严谨起见,最好在使用定位功能之前判断当前应用的定位功能是否可用

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

+(BOOL)locationServicesEnabled;

@property(assign,nonatomic)CLLocationDistancedistanceFilter;

每隔多少米定位一次

@property(assign,nonatomic)CLLocationAccuracydesiredAccuracy;

定位精确度(越精确就越耗电)

CLLocation对象

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

@property(readonly,nonatomic)CLLocationCoordinate2Dcoordinate;  //经纬度

注:

typedef  struct

{

CLLocationDegreeslatitude;//纬度

CLLocationDegreeslongitude;//经度

} CLLocationCoordinate2D

@property(readonly,nonatomic)CLLocationDistancealtitude; //海拔

@property(readonly,nonatomic)CLLocationDirectioncourse; //路线,航向(取值范围是0.0°~359.9°,0.0°代表真北方向)

@property(readonly,nonatomic)CLLocationSpeedspeed; //移动速度(单位是m/s)

调用-(CLLocationDistance)distanceFromLocation:(constCLLocation*)location方法可以计算2个位置之间的距离

实例代码

#import "ViewController.h"#[email protected] ViewController ()//位置管理者

@property (nonatomic,strong) CLLocationManager *locManager;

@end

@implementation ViewController

//懒加载

- (CLLocationManager *)locManager{

if (!_locManager) {

//创建位置管理者

_locManager = [[CLLocationManager alloc] init];

//代理

_locManager.delegate = self;

//每隔多少米定位移一次

_locManager.distanceFilter = 3000;

// 精确度越高, 越耗电, 定位时间越长

_locManager.desiredAccuracy = kCLLocationAccuracyThreeKilometers;

//iOS8.0+定位适配

if ([[UIDevice currentDevice].systemVersion floatValue] >= 8.0) {

// 前台定位授权(默认情况下,不可以在后台获取位置, 勾选后台模式 location update, 但是 会出现蓝条)

[_locManager requestWhenInUseAuthorization];

// 当前的授权状态为前台授权时,此方法也会有效

[_locManager requestAlwaysAuthorization];

}

// 允许后台获取用户位置(iOS9.0)

if([[UIDevice currentDevice].systemVersion floatValue] >= 9.0)

{

// 一定要勾选后台模式 location updates

_locManager.allowsBackgroundLocationUpdates = YES;

}

}

return _locManager;

}

- (void)viewDidLoad {

[super viewDidLoad];

//开始更新用户位置

[self.locManager startUpdatingLocation];

}

#pragma mark - CLLocationManagerDelegate

/*

更新到位置之后调用

@param manager  位置管理者

@param locations 位置数组

*/

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

{

NSLog(@"定位到了 %@",locations);

//此处locations存储了持续更新的位置坐标值,取最后一个值为最新位置,如果不想让其持续更新位置,

CLLocation *currentLocation = [locations lastObject];

//获取当前所有的城市名

CLGeocoder *geocoder = [[CLGeocoder alloc] init];

//根据经纬度反向地理编译出地址信息

[geocoder reverseGeocodeLocation:currentLocation completionHandler:^(NSArray *array, NSError *error)

{

if (array.count > 0)

{

CLPlacemark *placemark = [array objectAtIndex:0];

//NSLog(@%@,placemark.name);//具体位置

//获取城市

NSString *city = placemark.locality;

if (!city) {

//四大直辖市的城市信息无法通过locality获得,只能通过获取省份的方法来获得(如果city为空,则可知为直辖市)

city = placemark.administrativeArea;

}

CLPlacemark *firstPlacemark=[array firstObject];

//经纬度

CLLocationDegrees latitude=firstPlacemark.location.coordinate.latitude;

CLLocationDegrees longitude=firstPlacemark.location.coordinate.longitude;

//打印定位城市

NSLog(@"定位完成:%@",city);

//打印当前经纬度

NSLog(@"%f,%f",latitude,longitude);

//系统会一直更新数据,直到选择停止更新,因为我们只需要获得一次经纬度即可,所以获取之后就停止更新

[manager stopUpdatingLocation];

}else if (error == nil && [array count] == 0)

{

NSLog(@"No results were returned.");

}else if (error != nil)

{

NSLog(@"An error occurred = %@", error);

}

}];

// 当取得城市位置时候停止更新

[manager stopUpdatingLocation];

}

/*

授权状态发生改变时调用

@param manager 位置管理者

@param status 状态

*/

-(void)locationManager:(CLLocationManager *)manager didChangeAuthorizationStatus:(CLAuthorizationStatus)status

{

switch (status) {

// 用户还未决定

case kCLAuthorizationStatusNotDetermined:

{

NSLog(@"用户还未决定");

break;

}

// 问受限

case kCLAuthorizationStatusRestricted:

{

NSLog(@"访问受限");

break;

}

// 定位关闭时和对此APP授权为never时调用

case kCLAuthorizationStatusDenied:

{

// 定位是否可用(是否支持定位或者定位是否开启)

if([CLLocationManager locationServicesEnabled])

{

NSLog(@"定位开启,但被拒");

}else

{

NSLog(@"定位关闭,不可用");

}

// NSLog(@"被拒");

break;

}

// 获取前后台定位授权

case kCLAuthorizationStatusAuthorizedAlways:

// case kCLAuthorizationStatusAuthorized: // 失效,不建议使用

{

NSLog(@"获取前后台定位授权");

break;

}

// 获得前台定位授权

case kCLAuthorizationStatusAuthorizedWhenInUse:

{

NSLog(@"获得前台定位授权");

break;

}

default:

break;

}

}

// 定位失败

-(void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error

{

NSLog(@"定位失败 %@",error);

}

@end

时间: 2024-08-05 23:24:31

iOS开发之CoreLocaiton框架使用(定位服务)的相关文章

ioS开发之CoreLocation(GPS定位)

1.概述 在iOS开发中,要想加入地图和定位功能这2大功能,必须基于2个框架进行开发 (1)Map Kit :用于地图展示 (2)Core Location :用于地理定位 2个热门专业术语: LBS :Location Based Service SoLoMo :Social Local Mobile(索罗门) 2.CoreLocation框架的使用 CoreLocation框架使用前提: 导入框架: 导入主头文件: #import <CoreLocation/CoreLocation.h>

iOS开发之Masonry框架源码深度解析

Masonry是iOS在控件布局中经常使用的一个轻量级框架,Masonry让NSLayoutConstraint使用起来更为简洁.Masonry简化了NSLayoutConstraint的使用方式,让我们可以以链式的方式为我们的控件指定约束.本篇博客的主题不是教你如何去使用Masonry框架的,而是对Masonry框架的源码进行解析,让你明白Masonry是如何对NSLayoutConstraint进行封装的,以及Masonry框架中的各个部分所扮演的角色是什么样的.在Masonry框架中,仔细

iOS开发之Masonry框架源码解析

Masonry是iOS在控件布局中经常使用的一个轻量级框架,Masonry让NSLayoutConstraint使用起来更为简洁.Masonry简化了NSLayoutConstraint的使用方式,让我们可以以链式的方式为我们的控件指定约束.本篇博客的主题不是教你如何去使用Masonry框架的,而是对Masonry框架的源码进行解析,让你明白Masonry是如何对NSLayoutConstraint进行封装的,以及Masonry框架中的各个部分所扮演的角色是什么样的.在Masonry框架中,仔细

iOS开发之SceneKit框架--SCNLight.h

1.SCNLight简介 用于添加光源,连接到一个节点照亮现场,可以给场景添加不同的灯光,模拟逼真的环境. 2.四种灯光的简介 添加一个box立方体.一个tube圆柱管道和一个地板floor,没有灯光的时候物体都是白色的模型图: 四种灯光分别为环境光.全方位光.定向光和点光源,另外还有一个光域网和荧光探针.添加不同灯光后效果如下: //灯光类型 枚举 @property(nonatomic, copy) SCNLightType type; FOUNDATION_EXTERN SCNLightT

李洪强iOS开发之Foundation框架—集合

Foundation框架—集合 一.NSArray和NSMutableArray (一)NSArray不可变数组 (1)NSArray的基本介绍 NSArray是OC中使用的数组,是面向对象的,以面向对象的形式操纵对象,是不可变数组. C语言数组有一个缺点即数组中只能存放同种数据类型的元素. OC数组只能存放OC对象,不能存放非OC对象,如int,结构体和枚举等. (2)NSArray的创建 (3)NSArray的访问 (4)NSArray的遍历 数组的遍历有以下几种方式: 首先创建一个数组 第

iOS开发之SceneKit框架--SCNGeometry.h

1.SCNGeometry简介 SCNGeometry负责呈现三维模型的类,它管理者物体的形状.纹理等.它可以由SCNGeometrySource和SCNGeometryElement来构造, 一个SCNGeometry 可以包含多个SCNGeometrySource和SCNGeometryElement对象. 还可以通过SCNMaterial定义几何形状表面的颜色或者纹理, SCNLight 定义光照效果, SCNProgram 设计OpenGL或者Metal着色语言等等. SCNGeomet

李洪强iOS开发之iOS好文章收集

李洪强iOS开发之iOS好文章收集 该文收集朋友们转发或自己的写的技术文章,如果你也有相关的好文章,欢迎留言,当好文章多的时候,我会对这些好文章进行分门别类 文章 简述 日期 直播服务配置 使用 nginx 和 rtmp 插件搭建视频直播和点播服务器 2015-05-12 20:13:00 iOS9适配技巧 图iOS9适配新技巧 2015-09-29 09:01 TextKit分页效果 图文混排 2015年6月1日 iPhone 6 / 6 Plus 设计·适配方案 屏幕适配 2014-11-2

iOS开发之MVVM在项目中的应用

今天写这篇博客是想达到抛砖引玉的作用,想与大家交流一下思想,相互学习,博文中有不足之处还望大家批评指正.本篇博客的内容沿袭以往博客的风格,也是以干货为主,偶尔扯扯咸蛋(哈哈~不好好工作又开始发表博客啦~). 由于本人项目经验有限,关于架构设计方面的东西理解有限,我个人对MVVM的理解主要是借鉴于之前的用过的MVC的Web框架~在学校的时候用过ThinkPHP框架,和SSH框架,都是MVC的架构模式,今天MVVM与传统的MVC可谓是极为相似,也可以说是兄弟关系,也就是一家人了. 说到架构设计和团队

李洪强iOS开发之RunLoop的原理和核心机制

李洪强iOS开发之RunLoop的原理和核心机制 搞iOS之后一直没有深入研究过RunLoop,非常的惭愧.刚好前一阵子负责性能优化项目,需要利用RunLoop做性能优化和性能检测,趁着这个机会深入研究了RunLoop的原理和特性. RunLoop的定义 当有持续的异步任务需求时,我们会创建一个独立的生命周期可控的线程.RunLoop就是控制线程生命周期并接收事件进行处理的机制. RunLoop是iOS事件响应与任务处理最核心的机制,它贯穿iOS整个系统. Foundation: NSRunLo