iOS는 경위도에 따라 지명을 얻고 지명에 따라 경위도를 얻는다

1847 단어
1. 경위도에 따라 지명 얻기
    CLGeocoder *clGeoCoder = [[CLGeocoder alloc] init];
    [clGeoCoder reverseGeocodeLocation:newLocation completionHandler: ^(NSArray *placemarks,NSError *error) {
         for (CLPlacemark *placeMark in placemarks)
         {
             NSDictionary *addressDic=placeMark.addressDictionary;
             
             NSString *state=[addressDic objectForKey:@"State"];
             NSString *city=[addressDic objectForKey:@"City"];
             NSString *subLocality=[addressDic objectForKey:@"SubLocality"];
             NSString *street=[addressDic objectForKey:@"Street"];
             
             [self stopLocation];
             [_chooseCityBtn setTitle:city forState:UIControlStateNormal];
             [_activityIndicator stopAnimating];
         }
         
     }];

2. 지명에 따라 경위도 얻기
    NSString *oreillyAddress = @"1005 Gravenstein Highway North, Sebastopol, CA 95472, USA";
    CLGeocoder *myGeocoder = [[CLGeocoder alloc] init];
    [myGeocoder geocodeAddressString:oreillyAddress completionHandler:^(NSArray *placemarks, NSError *error) {
        if ([placemarks count] > 0 && error == nil) {
            NSLog(@"Found %lu placemark(s).", (unsigned long)[placemarks count]);
            CLPlacemark *firstPlacemark = [placemarks objectAtIndex:0];
            NSLog(@"Longitude = %f", firstPlacemark.location.coordinate.longitude);
            NSLog(@"Latitude = %f", firstPlacemark.location.coordinate.latitude);
        }
        else if ([placemarks count] == 0 && error == nil) {
            NSLog(@"Found no placemarks.");
        } else if (error != nil) {
            NSLog(@"An error occurred = %@", error);
        }
    }];

좋은 웹페이지 즐겨찾기