1. 程式人生 > >定位相關

定位相關

在iOS 8中,蘋果已經強制開發者在請求定位服務時獲得使用者的授權,此外iOS狀態列中還有指示圖示,提示使用者當前應用是否正在使用定位服務。另外在iOS 8中,蘋果進一步改善了定位服務,讓開發者請求定位服務時需要向用戶提供更多的透明。此外,iOS 8中還支援讓應用開發者呼叫全新的“訪問監控”功能,當用戶允許後應用才能獲得更多的定位資料。

                                                        

iOS 8以前使用CoreLocation定位

1、首先定義一個全域性的變數用來記錄CLLocationManager物件,引入CoreLocation.framework使用#import <CoreLocation/CoreLocation.h>

?
1 @property (nonatomic, strong) CLLocationManager  *locationManager;

2、初始化CLLocationManager並開始定位

?
1 2 3 4 5 self.locationManager = [[CLLocationManager alloc]init];
_locationManager.delegate = self; _locationManager.desiredAccuracy = kCLLocationAccuracyBest; _locationManager.distanceFilter = 10; [_locationManager startUpdatingLocation];

3、實現CLLocationManagerDelegate的代理方法

(1)獲取到位置資料,返回的是一個CLLocation的陣列,一般使用其中的一個。

?
1 2 3 4 5 - ( void )locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations {      CLLocation *currLocation = [locations lastObject];      NSLog(@ "經度=%f 緯度=%f 高度=%f" , currLocation.coordinate.latitude, currLocation.coordinate.longitude, currLocation.altitude); }

(2)獲取使用者位置資料失敗的回撥方法,在此通知使用者

?
1 2 3 4 5 6 7 8 9 10 - ( void )locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error {      if  ([error code] == kCLErrorDenied)      {          //訪問被拒絕      }      if  ([error code] == kCLErrorLocationUnknown) {          //無法獲取位置資訊      } }

4、在viewWillDisappear關閉定位

?
1 2 3 4 5 - ( void )viewWillDisappear:( BOOL )animated {      [super viewWillDisappear:animated];      [_locationManager stopUpdatingLocation]; }

iOS 8中使用CoreLocation定位

1、在使用CoreLocation前需要呼叫如下函式【iOS 8專用】:

iOS 8對定位進行了一些修改,其中包括定位授權的方法,CLLocationManager增加了下面的兩個方法:

(1)始終允許訪問位置資訊

- (void)requestAlwaysAuthorization;

(2)使用應用程式期間允許訪問位置資料

- (void)requestWhenInUseAuthorization;

示例如下:

?
1 2 3 4 5 6 self.locationManager = [[CLLocationManager alloc]init]; _locationManager.delegate = self; _locationManager.desiredAccuracy = kCLLocationAccuracyBest; _locationManager.distanceFilter = 10; [_locationManager requestAlwaysAuthorization]; //新增這句 [_locationManager startUpdatingLocation];

2、在Info.plist檔案中新增如下配置:

(1)NSLocationAlwaysUsageDescription

(2)NSLocationWhenInUseUsageDescription

這兩個鍵的值就是授權alert的描述,示例配置如下[勾選Show Raw Keys/Values後進行新增]:


總結:

iOS 8對定位進行了一些修改,其中包括定位授權的方法,CLLocationManager增加了以下兩個方法:

Added -[CLLocationManager requestAlwaysAuthorization]

Added -[CLLocationManager requestWhenInUseAuthorization]

在使用定位服務前需要通過上面兩個方法申請授權:

[CLLocationManager requestAlwaysAuthorization] 授權使應用在前臺後臺都能使用定位服務

-[CLLocationManager requestWhenInUseAuthorization] 授權則與之前的一樣

另外,在使用這兩個方法授權前,必須在info.plist中增加相應的鍵值( NSLocationAlwaysUsageDescription、NSLocationWhenInUseUsageDescription),這兩個鍵的值就是授權alert的描述。








文頂頂

iOS開發拓展篇—CoreLocation定位服務

iOS開發拓展篇—CoreLocation定位服務 一、簡單說明

1.CLLocationManager

CLLocationManager的常用操作和屬性

開始使用者定位- (void)startUpdatingLocation;

停止使用者定位- (void) stopUpdatingLocation;

說明:當呼叫了startUpdatingLocation方法後,就開始不斷地定位使用者的位置,中途會頻繁地呼叫代理的下面方法

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

每隔多少米定位一次

  @property(assign, nonatomic) CLLocationDistance distanceFilter;

定位精確度(越精確就越耗電)

  @property(assign, nonatomic) CLLocationAccuracy desiredAccuracy;

 

2.CLLocation

CLLocation用來表示某個位置的地理資訊,比如經緯度、海拔等等

(1)經緯度 

  @property(readonly, nonatomic) CLLocationCoordinate2D coordinate;

(2)海拔 

  @property(readonly, nonatomic) CLLocationDistance altitude;

(3)路線,航向(取值範圍是0.0° ~ 359.9°,0.0°代表真北方向)

  @property(readonly, nonatomic) CLLocationDirection course;

(4)行走速度(單位是m/s)

   @property(readonly, nonatomic) CLLocationSpeed speed;

(5)計算2個位置之間的距離

  - (CLLocationDistance)distanceFromLocation:(const CLLocation *)location方法

 

3.CLLocationCoordinate2D

CLLocationCoordinate2D是一個用來表示經緯度的結構體,定義如下

typedef struct {

        CLLocationDegrees latitude; // 緯度

        CLLocationDegrees longitude; // 經度

} CLLocationCoordinate2D;

一般用CLLocationCoordinate2DMake函式來建立CLLocationCoordinate2D

 

二、程式碼示例

複製程式碼
 1 //
 2 //  YYViewController.m
 3 //  18-定位服務
 4 //
 5 //  Created by apple on 14-8-9.
 6 //  Copyright (c) 2014年 yangyong. All rights reserved.
 7 //
 8 
 9 #import "YYViewController.h"
10 #import <CoreLocation/CoreLocation.h>
11 
12 //需要遵守CLLocationManagerDelegate協議
13 @interface YYViewController ()<CLLocationManagerDelegate>
14 @property(nonatomic,strong)CLLocationManager *locMgr;
15 @end
16 
17 @implementation YYViewController
18 #pragma mark-懶載入
19 -(CLLocationManager *)locMgr
20 {
21     if (_locMgr==nil) {
22         //1.建立位置管理器(定位使用者的位置)
23         self.locMgr=[[CLLocationManager alloc]init];
24         //2.設定代理
25         self.locMgr.delegate=self;
26     }
27     return _locMgr;
28 }
29 - (void)viewDidLoad
30 {
31     [super viewDidLoad];
32     
33     //判斷使用者定位服務是否開啟
34     if ([CLLocationManager locationServicesEnabled]) {
35         //開始定位使用者的位置
36         [self.locMgr startUpdatingLocation];
37         //每隔多少米定位一次(這裡的設定為任何的移動)
38         self.locMgr.distanceFilter=kCLDistanceFilterNone;
39         //設定定位的精準度,一般精準度越高,越耗電(這裡設定為精準度最高的,適用於導航應用)
40         self.locMgr.desiredAccuracy=kCLLocationAccuracyBestForNavigation;
41     }else
42     {//不能定位使用者的位置
43         //1.提醒使用者檢查當前的網路狀況
44         //2.提醒使用者開啟定位開關
45     }
46     
47     //測試方法,計算兩個位置之間的距離
48     [self countDistance];
49 }
50 
51 #pragma mark-CLLocationManagerDelegate
52 /**
53  *  當定位到使用者的位置時,就會呼叫(呼叫的頻率比較頻繁)
54  */
55 -(void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations
56 {
57     //locations數組裡邊存放的是CLLocation物件,一個CLLocation物件就代表著一個位置
58    CLLocation *loc = [locations firstObject];
59     
60     //維度:loc.coordinate.latitude
61     //經度:loc.coordinate.longitude
62     NSLog(@"緯度=%f,經度=%f",loc.coordinate.latitude,loc.coordinate.longitude);
63     NSLog(@"%d",locations.count);
64     
65     //停止更新位置(如果定位服務不需要實時更新的話,那麼應該停止位置的更新)
66 //    [self.locMgr stopUpdatingLocation];
67  
68 }
69 
70 //計算兩個位置之間的距離
71 -(void)countDistance
72 {
73     //根據經緯度建立兩個位置物件
74     CLLocation *loc1=[[CLLocation alloc]initWithLatitude:40 longitude:116];
75     CLLocation *loc2=[[CLLocation alloc]initWithLatitude:41 longitude:116];
76     //計算兩個位置之間的距離
77     CLLocationDistance distance=[loc1 distanceFromLocation:loc2];
78     NSLog(@"(%@)和(%@)的距離=%fM",loc1,loc2,distance);
79 }
80 
81 @end