2

我正在使用MKUserTrackingBarButtonItemMKMapView上定位。我以编程方式将它作为 navigationItem 添加到导航控制器上。我的问题是:

  1. 我可以自定义 MKUserTrackingBarButtonItem 吗?示例:我的导航控制器有蓝色背景,我需要设置我的 MKUserTrackingBarButtonItem 外观符合导航控制器。相反,它在箭头周围显示一个白色方块。我会改变这一点。
  2. 是否可以从导航控制器中移动我的 MKUserTrackingBarButtonItem 并将其直接放在我的地图上?

谢谢

4

2 回答 2

2

据我所知,您自定义用户跟踪按钮的能力有限。你可以改变颜色。为了让按钮离开导航栏,您必须将 UIToolbar 添加到 mapView,设置工具栏的框架大小,使其显示在您的首选位置,然后将 mkusertrackingbutton 作为项目添加到工具栏,具有灵活的空间根据需要添加以正确居中按钮。

这是我实现它的方式(到目前为止):

    func setupUserTrackingButton() {
      let trackingButton: MKUserTrackingBarButtonItem = MKUserTrackingBarButtonItem.init(mapView: mapView)
      trackingButton.customView?.tintColor = UIColor.black
      trackingButton.style = UIBarButtonItemStyle.plain
      trackingButton.customView?.size = CGSize(width: 50, height: 50)
      let originPoint: CGPoint = CGPoint(x: mapView.width-70,y: mapView.height-85)
      let lighterGreyColor: UIColor = UIColor(colorLiteralRed: 125, green: 125, blue: 125, alpha: 1.0)

//need to implement this rounded view in order to get the box to look consistent with the mkusertracking button API
      let roundedSquare: UIView = UIView(frame: CGRect(origin: originPoint, size: CGSize(width: 50, height: 50)))
      roundedSquare.backgroundColor = lighterGreyColor
      roundedSquare.layer.cornerRadius = 5
      roundedSquare.layer.masksToBounds = true

      let toolBarFrame = CGRect(origin: CGPoint(x: 3, y: 3) , size: CGSize(width: 44, height: 44))
//You may have to subclass toolbar in order to get the right coloring
      let toolbar = UIToolbar.init(frame: toolBarFrame)
      let flex: UIBarButtonItem = UIBarButtonItem(barButtonSystemItem: .flexibleSpace, target: self, action: nil)
      toolbar.items = [flex, trackingButton, flex]

      roundedSquare.addSubview(toolbar)
      mapView.addSubview(roundedSquare)

}

否则,您可能必须对按钮进行子类化并基本上构建其他功能,包括核心图形动画,这将是一些工作。希望这可以帮助。

编辑: 从 iOS 11.0+ 开始,现在有一个 MKUserTrackingButton,它是 UIView 的子类。因此,如果您在 iOS 11 下不需要任何东西,只需使用按钮和子类或自定义您想要的一切。 MKUserTrackingButton 的 Apple 文档

于 2017-01-10T17:11:03.260 回答
0

这会将 mapView 动画化回用户当前位置。您可以从您创建的任何自定义按钮调用此函数。

@IBAction func resetMapCurrentLocation(sender: AnyObject) {
    mapView.userTrackingMode = RMUserTrackingModeFollow
}
于 2015-04-27T20:50:03.550 回答