当用户点击某个引脚时,MKAnnotationView会出现,但它非常有限。我创建了一个自定义按钮,但有没有办法自定义从引脚出来的整个视图?这是我到目前为止所拥有的。
func mapView(mapView: MKMapView, viewForAnnotation annotation: MKAnnotation) -> MKAnnotationView? {
let annotationView = MKPinAnnotationView(annotation: annotation, reuseIdentifier: "location")
annotationView.canShowCallout = true
let btn = UIButton(type: .Custom) as UIButton
btn.frame = CGRectMake(50, 60, 60, 50)
btn.setTitle("button", forState: .Normal)
btn.titleLabel?.textAlignment = NSTextAlignment.Center
btn.contentHorizontalAlignment = UIControlContentHorizontalAlignment.Center
btn.layer.borderColor = UIColor.blueColor().CGColor
btn.layer.borderWidth = 0.5
btn.backgroundColor = UIColor.redColor()
annotationView.rightCalloutAccessoryView = btn
return annotationView
}
答案 0 :(得分:2)
您应该能够以编程方式构建自己的UIView并将它们分配给MKPinAnnotationView的leftCalloutAccessoryView
,rightCalloutAccessoryView
和detailCalloutAccessoryView
属性。 UIButton是UIView的子类,所以你到目前为止理论上应该有效。
如果您坚持使用这3个属性并使用每个UIView的frame属性,您应该能够执行大量的自定义。另外请记住,每个UIView都可以有多个子视图。
如果您真的想要制作完全可自定义的标注,您可能需要在图钉本身上设置点按手势识别器,这会导致您的自定义标注视图出现。但是,我建议不要使用这种更“hacky”的方法,因为它可能会导致标注更加不清楚。不幸的是,我不相信有一种方法可以直接分配自定义标注视图。
编辑:正如Rob建议的那样,您可以在MKMapViewDelegate中实现didSelectAnnotationView
以生成自定义标注视图,而不是点击手势识别器。这是一个更好但仍然“hacky”的解决方案 - 它会比股票标注视图更加小问题。