使用 scrollView 和 imageView 的 bounds.height 属性计算 zoomScaleForHeight
Posted
技术标签:
【中文标题】使用 scrollView 和 imageView 的 bounds.height 属性计算 zoomScaleForHeight【英文标题】:calculating zoomScaleForHeight using scrollView and imageView's bounds.height property 【发布时间】:2016-09-08 02:23:19 【问题描述】:我目前正在学习ios中的坐标系,遇到过如下代码
let zoomScaleForHeight = scrollView.bounds.height / imageView.bounds.height
let zoomScaleForWidth = scrollView.bounds.width / imageView.bounds.width
scrollView.minimumZoomScale = min(zoomScaleForHeight, zoomScaleForWidth)
imageView
是scrollView
的子视图。
我不确定它在计算什么以及如何计算。有人可以澄清这三行代码背后的逻辑吗?
【问题讨论】:
【参考方案1】:minimumZoomScale
表示需要调整图像大小的系数,以便完美适应屏幕而不裁剪任何边缘。这是代表场景的图像:
比例的计算方法是将UIScrollView
的宽度/高度除以UIImageView
的宽度/高度。如果我们现在将UIImageView
的宽度乘以其比例因子,我们将得到与UIScrollView
相同的宽度,这几乎就是我们想要完成的。身高也一样。
需要min()
函数的原因如下图所示:
在这个例子中,只应用了高度的比例,没有考虑宽度的比例。通过这样做,图像完全适合高度但不适合宽度。因此,必须计算两个尺度并使用较小的尺度,以便在不裁剪边缘的情况下拟合图像。
【讨论】:
现在一切都清理了吗?如果您有任何进一步的问题,请询问! :) @Tony Stark,我可以看到你很活跃,还有什么困惑吗? 嗨,克里斯,感谢您提供非常详细的答案!我已投票,接受并为您的答案提供赏金。再次感谢您的帮助! 非常感谢您的帮助。以上是关于使用 scrollView 和 imageView 的 bounds.height 属性计算 zoomScaleForHeight的主要内容,如果未能解决你的问题,请参考以下文章
当 contentMode 为 AspectFill 时在 ScrollView 内平移 ImageView
在 iOS 6 上使用自动布局在 ScrollView 中嵌入 ImageView
Autolayout 使 ScrollView 中的 ImageView 无法滚动