一、简单说明
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
实现效果:
(1)地理编码:(地名->经纬度坐标)
打印输出:
(2)反地理编码:(经纬度—>地名)
(3)注意:调整键盘
点击经纬度textField进行输入的时候,弹出的键盘如下
(4)注意:搜索的所有结果都是在中国境内的,因为苹果在中国的地图服务商是高德地图。