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

打印查看:

  

代碼說明

1.關於代理方法

  需要設置代理,通過代理告訴用戶當前的位置,有兩個代理方法:

  locations參數里面裝着CLLocation對象

其中后者是一個過期的方法,在新的方法(第一個)中使用了一個數組來替代。
說明:該方法在當定位到用戶的位置時就會調用,調用比較頻繁
注意:不要使用局部變量(創建位置管理器),因為局部變量的方法結束它就被銷毀了。建議使用一個全局的變量,且只創建一次就可以了(使用懶加載)。
 
2.定位的精度
  
3.如果發現自己的定位服務沒有打開,那么應該提醒用戶打開定位服務功能。
4.定位服務是比較耗電的,如果是做定位服務(沒必要實時更新的話),那么定位了用戶位置后,應該停止更新位置。
 
三、用戶隱私的保護

1.權限設置說明

從iOS 6開始,蘋果在保護用戶隱私方面做了很大的加強,以下操作都必須經過用戶批准授權

(1)要想獲得用戶的位置

(2)想訪問用戶的通訊錄、日歷、相機、相冊等

當想訪問用戶的隱私信息時,系統會自動彈出一個對話框讓用戶授權

注意:一旦用戶選擇了“Don’t Allow”,意味着你的應用以后就無法使用定位功能,且當用戶第一次選擇了之后,以后就再也不會提醒進行設置。

因此在程序中應該進行判斷,如果發現自己的定位服務沒有打開,那么應該提醒用戶打開定位服務功能。

CLLocationManager有個類方法可以判斷當前應用的定位功能是否可用+ (BOOL)locationServicesEnabled;

  常用的方法: 截圖告訴用戶,應該怎么打開授權
  

2.開發者可以在Info.plist中設置NSLocationUsageDescription說明定位的目的(Privacy - Location Usage Description)

  

說明:這里的定位服務是基於網絡的。通常定位服務可以是基於GPS、基站或者是網絡的。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM