基于CLGeocoder - 地理编码

iOS中CoreLocatio框架中的CLGeocoder为我们提供了地理编码方法:
首先需要导入框架
#import
地理编码方法有三种:

- (void)geocodeAddressDictionary:(NSDictionary *)addressDictionary completionHandler:(CLGeocodeCompletionHandler)completionHandler;
- (void)geocodeAddressString:(NSString *)addressString completionHandler:(CLGeocodeCompletionHandler)completionHandler;
- (void)geocodeAddressString:(NSString *)addressString inRegion:(nullable CLRegion *)region completionHandler:(CLGeocodeCompletionHandler)completionHandler;

下面简单的介绍其中一种常用的方法<上面提到的第二种方法>:步骤:
1、获取用户输入的地理位置
2、创建地理编码对象<CLGeocoder对象>
3、利用地理编码对象编码
3.1、当编码完成时,会调用 completionHandler对象,该对象类型为 CLGeocodeCompletionHandler,实际上是一个 block 对象
这个对象中传递了2个参数,其中placemark:里面装了CLPlacemark对象

基于CLGeocoder - 地理编码_第1张图片
Paste_Image.png
根据文档,可以知道 CLPlacemark对象中包含了 该位置的经纬度以及城市/区域/国家代码/邮编等等...信息
由此我们可以根据返回参数 placemark获取到我们需要的数据
< Demo如下 >:

@interface ViewController ()
#pragma mark - 地理编码
//监听地理编码点击事件
- (IBAction)geocodeBtnClick;

// 需要编码的地址
@property (weak, nonatomic) IBOutlet UITextField *addressField;

//经度
@property (weak, nonatomic) IBOutlet UILabel *longitudeLabel;

//纬度
@property (weak, nonatomic) IBOutlet UILabel *latitudeLabel;

//详情
@property (weak, nonatomic) IBOutlet UILabel *detailAddressLabel;

//地理编码对象
@property (nonatomic ,strong) CLGeocoder *geocoder;

@end
#pragma mark - 地理编码响应
- (void)geocodeBtnClick
{
   
     // 0.获取用户输入的位置
     NSString *addressStr = self.addressField.text;
   
         if (addressStr == nil || addressStr.length == 0) {
            NSLog(@"请输入地址");
            return;
    }

      // 1.创建地理编码对象
      // 2.利用地理编码对象编码
      // 根据传入的地址获取该地址对应的经纬度信息
      [self.geocoder geocodeAddressString:addressStr completionHandler:^(NSArray *placemarks, NSError *error) {
        
          if (placemarks.count == 0 || error != nil) {
              return ;
          }
          // placemarks地标数组, 地标数组中存放着地标, 每一个地标包含了该位置的经纬度以及城市/区域/国家代码/邮编等等...
          // 获取数组中的第一个地标
          CLPlacemark *placemark = [placemarks firstObject];

          self.latitudeLabel.text = [NSString stringWithFormat:@"%f", placemark.location.coordinate.latitude];
          self.longitudeLabel.text = [NSString stringWithFormat:@"%f", placemark.location.coordinate.longitude];
          NSArray *address = placemark.addressDictionary[@"FormattedAddressLines"];
          NSMutableString *strM = [NSMutableString string];
          for (NSString *str in address) {
              [strM appendString:str];
          }
          self.detailAddressLabel.text = strM;
      }];
 }

#pragma mark - 懒加载, 1.创建地理编码对象
- (CLGeocoder *)geocoder
{

    if (!_geocoder) {
        _geocoder = [[CLGeocoder alloc] init];
    }
    return _geocoder;
}

效果图如下:


基于CLGeocoder - 地理编码_第2张图片
Paste_Image.png

你可能感兴趣的