webentwicklung-frage-antwort-db.com.de

MapKit zeigt auf iOS9 kein benutzerdefiniertes Anmerkungs-Pin-Image an

Mein Code funktionierte gut von iOS 7 bis 8. Mit dem gestrigen Update wurden die benutzerdefinierten Bilder auf meinen Pins durch das Standard-Pin-Image ersetzt Vorschläge?

Mein Code:

extension ViewController: MKMapViewDelegate {

    func mapView(mapView: MKMapView, viewForAnnotation annotation: MKAnnotation) -> MKAnnotationView! {

        if annotation is MKUserLocation {
            return nil
        }

        let reuseId = String(stringInterpolationSegment: annotation.coordinate.longitude)

        var pinView = mapView.dequeueReusableAnnotationViewWithIdentifier(reuseId) as? MKPinAnnotationView

        if pinView == nil {

            pinView = MKPinAnnotationView(annotation: annotation, reuseIdentifier: reuseId)
            pinView!.canShowCallout = true
            pinView!.image = getRightImage(annotation.title!!) 
        }

        let button = UIButton(type: UIButtonType.DetailDisclosure) 
        pinView?.rightCalloutAccessoryView = button

        return pinView
    }
}

Die Funktion zum Abrufen des Bildes gibt eine UIImage basierend auf dem Namen zurück:

func getRightImage (shopName:String)-> UIImage{

    var correctImage = UIImage()

    switch shopName
    {
    case "Kaisers":
        correctImage = UIImage(named: "Kaisers.jpg")!
    default:
        correctImage = UIImage(named: "sopiconsmall.png")!

    }

    return correctImage
}

Nein, die Karte sieht folgendermaßen aus:  ios9 without images

35
Felix Weber

Anstatt eineMKPinAnnotationViewzu erstellen, erstellen Sie eine EbeneMKAnnotationView.

Die UnterklasseMKPinAnnotationViewignoriert tendenziell die image -Eigenschaft, da nur die standardmäßigen roten, grünen und violetten Pins (über die pinColor-Eigenschaft) angezeigt werden.

Wenn Sie zuMKAnnotationViewwechseln, müssen Sie auch die Zeile animatesDrop auskommentieren, da diese Eigenschaft fürMKPinAnnotationViewspezifisch ist.

75

Der folgende Code funktioniert auf allen iOS 6 bis iOS 9-Geräten einwandfrei:

    - (MKAnnotationView *)mapView:(MKMapView *)mapView viewForAnnotation:(id<MKAnnotation>)annotation
{
    // create a proper annotation view, be lazy and don't use the reuse identifier
    MKAnnotationView *view = [[MKAnnotationView alloc] initWithAnnotation:annotation
                                                                reuseIdentifier:@"identifier"];

    // create a disclosure button for map kit
    UIButton *disclosure = [UIButton buttonWithType:UIButtonTypeContactAdd];

    [disclosure addGestureRecognizer:[[UITapGestureRecognizer alloc] initWithTarget:self
                                                                             action:@selector(disclosureTapped)]];
    view.rightCalloutAccessoryView = disclosure;

       view.enabled = YES;
       view.image = [UIImage imageNamed:@"map_pin"];


    return view;
}
4
Harshal Wani

Für Swift 4

func mapView(mapView: MKMapView, viewFor annotation: MKAnnotation) -> MKAnnotationView? {

    if annotation is MKUserLocation {
        return nil
    }

    let reuseId = String(stringInterpolationSegment: annotation.coordinate.longitude)

    var pinView = mapView.dequeueReusableAnnotationView(withIdentifier: reuseId)

    if pinView == nil {

        pinView = MKAnnotationView(annotation: annotation, reuseIdentifier: reuseId)
        pinView!.canShowCallout = true
        pinView!.image = getRightImage(annotation.title!!) 
    }

    let button = UIButton(type: UIButtonType.DetailDisclosure) 
    pinView?.rightCalloutAccessoryView = button

    return pinView
}
0
Sebastian Esser