无法创建自定义MKAnnotationView

时间:2017-08-24 21:21:48

标签: ios swift mapkit mkannotationview mapkitannotation

我很难显示自定义注释视图。具体来说,我试图设置一个名为" pin"成为新的地图引脚。默认引脚始终显示。我已经做了几个小时的微小改动而无济于事,例如更换" pin" to" pin.png"并改变mapView:viewFor方法的结构。这就是我所拥有的。你能看一看,看看有什么突出的吗?

感谢您的帮助!

注释类:

class Annotation: NSObject, MKAnnotation {
    dynamic var coordinate : CLLocationCoordinate2D
    var title: String?
    var subtitle: String?

    init(location coord:CLLocationCoordinate2D) {
        self.coordinate = coord
        super.init()
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}

AnnotationView类:

class AnnotationView : MKAnnotationView {
    override init(annotation:MKAnnotation?, reuseIdentifier: String?) {
        super.init(annotation: annotation,
               reuseIdentifier: reuseIdentifier)
        let im = UIImage(named: "pin")!
        self.frame = CGRect(x: 0, y: 0, width: im.size.width / 3.0 + 5, height: im.size.height / 3.0 + 5)
        self.centerOffset = CGPoint(x: 0, y: -20)
        self.isOpaque = false
    }
    required init (coder: NSCoder) {
        fatalError("NSCoding not supported")
    }
    override func draw(_ rect: CGRect) {
        let im = UIImage(named: "pin")!
       im.draw(in: self.bounds.insetBy(dx: 5, dy: 5))
    }
}

mapView:viewFor:方法:

func mapView(_ mapView: MKMapView, viewFor annotation: MKAnnotation) -> MKAnnotationView? {
    var v : MKAnnotationView! = nil
    let ident = "pin"
    v = mapView.dequeueReusableAnnotationView(withIdentifier: ident)
    if v == nil {
        v = AnnotationView(annotation: annotation, reuseIdentifier: ident)
        v.canShowCallout = true
    }
    v.annotation = annotation
    return v
}

其他相关方法:

@IBAction func submitDog(_ sender: Any) {
    let newDog = Dog(name: newDogName.text!, score: 11, picture: image!, location: location!)
    dogs.append(newDog)
    print(dogs.last!)
    UIView.animate(withDuration: 0.5, animations: {

    }) { _ in
        self.newDogView.animation = "slideUp"
        self.newDogView.animate()
        self.newDogView.isHidden = true
        self.newDogName.text = ""
        self.map.isUserInteractionEnabled = true
    }
    dropNewPin(locatedAt: dogs.last!.location, name: dogs.last!.name, rate: dogs.last!.score)
}

func dropNewPin(locatedAt: CLLocation, name: String, rate: Int) {
    let annotation = Annotation(location: CLLocationCoordinate2D(latitude: locatedAt.coordinate.latitude, longitude: locatedAt.coordinate.longitude))
    annotation.title = name
    annotation.subtitle = "\(rate)/10"
    self.map.addAnnotation(annotation)
}

1 个答案:

答案 0 :(得分:1)

首先,您需要将viewController添加为地图的委托

 self.mapView.delegate = self

之后我建议你使用MKAnnotationView而不是修改并添加带有自定义绘图的图像,如果你需要一个自定义的注释视图,那么你需要添加一个xib文件和你的自定义类作为文件所有者和make适当的调整

 func mapView(_ mapView: MKMapView, viewFor annotation: MKAnnotation) -> MKAnnotationView? {
    //to avoid make a custom Annotation view for your user location
    if(annotation is MKUserLocation){
        return nil
    }

    let ident = "pin"
    var v = mapView.dequeueReusableAnnotationView(withIdentifier: ident)
    if v == nil {
        v = MKAnnotationView(annotation: annotation, reuseIdentifier: ident)
        v?.image = UIImage(named: "pin")
        v?.canShowCallout = true
    }
    v?.annotation = annotation
    return v
}