现在我有以下视图层次结构:
我的视图层次结构有点复杂,因为我需要缩放和旋转,并且我还需要保持地图和箭头的位置关系,我已经解决了很长时间并找到了这个解决方案。
现在我的问题是当我缩放时如何将Arrow Image View
始终保持在屏幕的中心?
以下是我的一些代码:
func viewForZooming(in scrollView: UIScrollView) -> UIView? {
return Container For Scale View
}
func scrollViewDidZoom(_ scrollView: UIScrollView) {
let imageViewSize = MapImageView.frame.size
let scrollViewSize = scrollView.bounds.size
let verticalPadding = imageViewSize.height < scrollViewSize.height ? (scrollViewSize.height - imageViewSize.height) / 2 : 0
let horizontalPadding = imageViewSize.width < scrollViewSize.width ? (scrollViewSize.width - imageViewSize.width) / 2 : 0
scrollView.contentInset = UIEdgeInsets(top: verticalPadding, left: horizontalPadding, bottom: verticalPadding, right: horizontalPadding)
}
答案 0 :(得分:2)
这里你需要一些数学
由于您的缩放容器视图根据缩放比例较大,因此需要将center
点相对于超级UIView
转换
假设您的容量缩放视图为viewBase
var center = self.view.center
之后转换图像点相同
let convertedImagePoint = self.viewBase.convert(imageView.center, to: self.view)
现在得到Difff
let diff = convertedImagePoint.y - center.y
DispatchQueue.main.async {
self.scrollView1.contentOffset.y += diff
}
希望有帮助