一、簡單說明
CLGeocoder:地理編碼器,其中Geo是地理的英文單詞Geography的簡寫。
1.使用CLGeocoder可以完成“地理編碼”和“反地理編碼”
地理編碼:根據給定的地名,獲得具體的位置信息(比如經緯度、地址的全稱等)
反地理編碼:根據給定的經緯度,獲得具體的位置信息
(1)地理編碼方法
- (void)geocodeAddressString:(NSString *)addressString completionHandler:(CLGeocodeCompletionHandler)completionHandler;
(2)反地理編碼方法
- (void)reverseGeocodeLocation:(CLLocation *)location completionHandler:(CLGeocodeCompletionHandler)completionHandler;
2.CLGeocodeCompletionHandler
當地理\反地理編碼完成時,就會調用CLGeocodeCompletionHandler
這個block傳遞2個參數
error :當編碼出錯時(比如編碼不出具體的信息)有值
placemarks :裡面裝著CLPlacemark對象
3.CLPlacemark
說明:CLPlacemark的字面意思是地標,封裝詳細的地址位置信息
地理位置 @property (nonatomic, readonly) CLLocation *location;
區域 @property (nonatomic, readonly) CLRegion *region;
詳細的地址信息 @property (nonatomic, readonly) NSDictionary *addressDictionary;
地址名稱 @property (nonatomic, readonly) NSString *name;
城市 @property (nonatomic, readonly) NSString *locality;
二、代碼示例:
在storyboard中搭建界面如下:
實現代碼:
YYViewController.m文件
復制代碼
1 //
2 // YYViewController.m
3 // 19-地理編碼
4 //
5 // Created by apple on 14-8-11.
6 // Copyright (c) 2014年 yangyong. All rights reserved.
7 //
8
9 #import "YYViewController.h"
10 #import <CoreLocation/CoreLocation.h>
11
12 @interface YYViewController ()
13 @property(nonatomic,strong)CLGeocoder *geocoder;
14 #pragma mark-地理編碼
15 - (IBAction)geocode;
16 @property (weak, nonatomic) IBOutlet UITextField *addressField;
17 @property (weak, nonatomic) IBOutlet UILabel *longitudeLabel;
18 @property (weak, nonatomic) IBOutlet UILabel *latitudeLabel;
19 @property (weak, nonatomic) IBOutlet UILabel *detailAddressLabel;
20
21 #pragma mark-反地理編碼
22
23 - (IBAction)reverseGeocode;
24 @property (weak, nonatomic) IBOutlet UITextField *longitudeField;
25 @property (weak, nonatomic) IBOutlet UITextField *latitudeField;
26 @property (weak, nonatomic) IBOutlet UILabel *reverdeDetailAddressLabel;
27 @end
28
29 @implementation YYViewController
30
31 #pragma mark-懶加載
32 -(CLGeocoder *)geocoder
33 {
34 if (_geocoder==nil) {
35 _geocoder=[[CLGeocoder alloc]init];
36 }
37 return _geocoder;
38 }
39 - (void)viewDidLoad
40 {
41 [super viewDidLoad];
42 }
43 /**
44 * 地理編碼:地名—>經緯度坐標
45 */
46 - (IBAction)geocode {
47 //1.獲得輸入的地址
48 NSString *address=self.addressField.text;
49 if (address.length==0) return;
50
51 //2.開始地理編碼
52 //說明:調用下面的方法開始編碼,不管編碼是成功還是失敗都會調用block中的方法
53 [self.geocoder geocodeAddressString:address completionHandler:^(NSArray *placemarks, NSError *error) {
54 //如果有錯誤信息,或者是數組中獲取的地名元素數量為0,那麼說明沒有找到
55 if (error || placemarks.count==0) {
56 self.detailAddressLabel.text=@"你輸入的地址沒找到,可能在月球上";
57 }else // 編碼成功,找到了具體的位置信息
58 {
59 //打印查看找到的所有的位置信息
60 /*
61 name:名稱
62 locality:城市
63 country:國家
64 postalCode:郵政編碼
65 */
66 for (CLPlacemark *placemark in placemarks) {
67 NSLog(@"name=%@ locality=%@ country=%@ postalCode=%@",placemark.name,placemark.locality,placemark.country,placemark.postalCode);
68 }
69
70 //取出獲取的地理信息數組中的第一個顯示在界面上
71 CLPlacemark *firstPlacemark=[placemarks firstObject];
72 //詳細地址名稱
73 self.detailAddressLabel.text=firstPlacemark.name;
74 //緯度
75 CLLocationDegrees latitude=firstPlacemark.location.coordinate.latitude;
76 //經度
77 CLLocationDegrees longitude=firstPlacemark.location.coordinate.longitude;
78 self.latitudeLabel.text=[NSString stringWithFormat:@"%.2f",latitude];
79 self.longitudeLabel.text=[NSString stringWithFormat:@"%.2f",longitude];
80 }
81 }];
82 }
83
84 /**
85 * 反地理編碼:經緯度坐標—>地名
86 */
87 - (IBAction)reverseGeocode {
88 //1.獲得輸入的經緯度
89 NSString *longtitudeText=self.longitudeField.text;
90 NSString *latitudeText=self.latitudeField.text;
91 if (longtitudeText.length==0||latitudeText.length==0) return;
92
93 CLLocationDegrees latitude=[latitudeText doubleValue];
94 CLLocationDegrees longitude=[longtitudeText doubleValue];
95
96 CLLocation *location=[[CLLocation alloc]initWithLatitude:latitude longitude:longitude];
97 //2.反地理編碼
98 [self.geocoder reverseGeocodeLocation:location completionHandler:^(NSArray *placemarks, NSError *error) {
99 if (error||placemarks.count==0) {
100 self.reverdeDetailAddressLabel.text=@"你輸入的地址沒找到,可能在月球上";
101 }else//編碼成功
102 {
103 //顯示最前面的地標信息
104 CLPlacemark *firstPlacemark=[placemarks firstObject];
105 self.reverdeDetailAddressLabel.text=firstPlacemark.name;
106 //經緯度
107 CLLocationDegrees latitude=firstPlacemark.location.coordinate.latitude;
108 CLLocationDegrees longitude=firstPlacemark.location.coordinate.longitude;
109 self.latitudeField.text=[NSString stringWithFormat:@"%.2f",latitude];
110 self.longitudeField.text=[NSString stringWithFormat:@"%.2f",longitude];
111 }
112 }];
113 }
114
115 -(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
116 {
117 [self.view endEditing:YES];
118 }
119 @end