iOS - MKMapView使用地址而不是lat / long来放置注释

时间:2012-03-07 17:07:58

标签: ios mkmapview geocoding core-location cllocationmanager

我可以使用纬度和经度在我的MKMapView上添加注释,但是,我需要使用位置的Feed是使用街道地址而不是Lat和Long。例如1234 west 1234 east,San Francisco,CA ...

这是否与CLLocationManager

有关

有人曾尝试过这个吗?

7 个答案:

答案 0 :(得分:76)

基于 psoft 的优秀信息,我能够通过此代码实现我的目标。

NSString *location = @"some address, state, and zip";
CLGeocoder *geocoder = [[CLGeocoder alloc] init];
            [geocoder geocodeAddressString:location 
                 completionHandler:^(NSArray* placemarks, NSError* error){
                     if (placemarks && placemarks.count > 0) {
                         CLPlacemark *topResult = [placemarks objectAtIndex:0];
                         MKPlacemark *placemark = [[MKPlacemark alloc] initWithPlacemark:topResult];

                         MKCoordinateRegion region = self.mapView.region;
                         region.center = placemark.region.center;
                         region.span.longitudeDelta /= 8.0;
                         region.span.latitudeDelta /= 8.0;

                         [self.mapView setRegion:region animated:YES];
                         [self.mapView addAnnotation:placemark];
                     }
                 }
             ];

答案 1 :(得分:13)

重构Swift版本:

let location = "some address, state, and zip"
let geocoder = CLGeocoder()
geocoder.geocodeAddressString(location) { [weak self] placemarks, error in
    if let placemark = placemarks?.first, let location = placemark.location {
        let mark = MKPlacemark(placemark: placemark)

        if var region = self?.mapView.region {
            region.center = location.coordinate
            region.span.longitudeDelta /= 8.0
            region.span.latitudeDelta /= 8.0
            self?.mapView.setRegion(region, animated: true)
            self?.mapView.addAnnotation(mark)
        }
    }
}

答案 2 :(得分:10)

您所追求的是地理编码前向地理编码反向地理编码是将纬度/经度转换为街道地址的过程。

iOS5为地理编码提供了CLGeocoder类。 MKPlacemark支持iOS> = 3.0中的反向编码。当然涉及的数据非常大,因此您的应用通常需要网络访问功能。

一个好的起点是Apple的Location Awareness Programming Guide。此外,SO上有很多关于这方面的问题。 https://stackoverflow.com/search?q=geocoding

祝你好运!

答案 3 :(得分:8)

Swift版

        let location = self.txtLocation.text;
        let geocoder:CLGeocoder = CLGeocoder();
        geocoder.geocodeAddressString(location!) { (placemarks: [CLPlacemark]?, error: NSError?) -> Void in
            if placemarks?.count > 0 {
                let topResult:CLPlacemark = placemarks![0];
                let placemark: MKPlacemark = MKPlacemark(placemark: topResult);

                var region: MKCoordinateRegion = self.mkMapView.region;
                region.center = (placemark.location?.coordinate)!;
                region.span.longitudeDelta /= 8.0;
                region.span.latitudeDelta /= 8.0;
                self.mkMapView.setRegion(region, animated: true);
                self.mkMapView.addAnnotation(placemark);

            }
        }

答案 4 :(得分:7)

自iOS 7起, placemark.region.center 已弃用。现在需要使用:

region.center = [(CLCircularRegion *)placemark.region center];

您也可以阅读Apple文档about thishere

答案 5 :(得分:5)

这是另一个版本......

- Swift 2017语法

- 显示该点的地名,位于底部

- 选择任何尺寸,例如5 km,如图所示

func map() {
    let 5km:CLLocationDistance = 5000

    let a= "100 smith avenue some town 90210 SD"
    let g = CLGeocoder()

    g.geocodeAddressString(a) { [weak self] placemarks, error in
        if let p = placemarks?.first, let l = placemark.location {

            let p = MKPlacemark(coordinate: l.coordinate, addressDictionary: nil)

            let cr = MKCoordinateRegionMakeWithDistance(l.coordinate, 5km, 5km)
            let options = [
                MKLaunchOptionsMapCenterKey: NSValue(mkCoordinate: cr.center),
                MKLaunchOptionsMapSpanKey: NSValue(mkCoordinateSpan: cr.span)
            ]

            let m = MKMapItem(placemark: p)
            m.name = "Your House"
            m.openInMaps(launchOptions: options)
        }
    }


}

答案 6 :(得分:1)

这是不可能的。但是您可以使用CLGeocoder类从地址获取long / lat。