设置自定义MKAnnotationView的中心

时间:2017-07-09 06:17:23

标签: swift3 mapkit mkannotation mkannotationview mapkitannotation

我正在使用自定义MKAnnotationView。我使用工作正常的autolayouts,但注释视图的位置(框架)不合适。

func mapView(_ mapView: MKMapView, didSelect view: MKAnnotationView)
{
    if view.annotation is MKUserLocation
    {
        return
    }

    let starbucksAnnotation = view.annotation as! LiquorLocation
    let views = Bundle.main.loadNibNamed("CustomCalloutView", owner: nil, options: nil)
    let calloutView = views?[0] as! CustomCalloutView
    calloutView.labelLiquorShopName.text = starbucksAnnotation.title
    calloutView.labelLiquorShopAddress.text = starbucksAnnotation.address
    calloutView.labelLiquorShopAwayDistance.text = starbucksAnnotation.locationKmAway
    calloutView.imageViewLiquorShop.image = starbucksAnnotation.liquorShopIcon


    calloutView.translatesAutoresizingMaskIntoConstraints = false
    view.addSubview(calloutView)
    mapView.setCenter((view.annotation?.coordinate)!, animated: true)
}

enter image description here

我做错了什么?我想将注释视图居中放在引脚的顶部。

1 个答案:

答案 0 :(得分:0)

Autolayouts再次拯救我的一天。我在calloutview和view(MKAnnotationView)之间添加了布局约束。我在view.addSubview(calloutView)方法的didSelect下面写下了一行。

let horizontalConstraint = NSLayoutConstraint(item: calloutView, attribute: NSLayoutAttribute.centerX, relatedBy: NSLayoutRelation.equal, toItem: view, attribute: NSLayoutAttribute.centerX, multiplier: 1, constant: 0)
        let verticalConstraint = NSLayoutConstraint(item: calloutView, attribute: NSLayoutAttribute.bottom, relatedBy: NSLayoutRelation.equal, toItem: view, attribute: NSLayoutAttribute.top, multiplier: 1, constant: 0)
        let widthConstraint = NSLayoutConstraint(item: calloutView, attribute: NSLayoutAttribute.width, relatedBy: NSLayoutRelation.equal, toItem: nil, attribute: NSLayoutAttribute.notAnAttribute, multiplier: 1, constant: calloutView.frame.size.width)
        view.addConstraints([horizontalConstraint, verticalConstraint, widthConstraint])