使用滚动视图通过 Swift 放大图像

Fed*_*esa 1 interface-builder ios swift

我正在从 Apple 的“App Development in Swift”学习 Swift。

我遇到了约束问题,特别是在第 593 页的“我间谍”实验室中。它基本上希望您创建一个滚动视图,其中包含一个图像视图并制作它以便您可以放大图像并滚动它,例如在打开照片时的照片应用程序中。

这本书说要使滚动视图和图像视图与带有约束的屏幕一样大,所以我将顶部、底部、前导和尾随约束添加为 0,并且它工作正常。

当我添加图像视图时,我开始遇到问题。如果我设置与滚动视图相同的约束,它会说它缺少 X 和 Y 位置的约束,并且它不起作用。如果我确实添加了这些约束,因此我将其水平和垂直对齐,图像只会拉伸到屏幕,但我仍然无法缩放或滚动。

视图控制器的代码是:

class ViewController: UIViewController, UIScrollViewDelegate {

@IBOutlet weak var scrollView: UIScrollView!
@IBOutlet weak var imageView: UIImageView!

override func viewDidLoad() {
    super.viewDidLoad()
    scrollView.delegate = ViewController()
    updateZoomFor(size: view.bounds.size)
}

func viewForZooming(in scrollView: UIScrollView) -> UIView? {
    return imageView
}

func updateZoomFor(size: CGSize){
    let widthScale = size.width / imageView.bounds.width
    let heightScale = size.height / imageView.bounds.height
    let scale = min(widthScale,heightScale)
    scrollView.minimumZoomScale = scale
}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
}


}
Run Code Online (Sandbox Code Playgroud)

我试着在互联网上环顾四周,但没有找到任何东西。我希望这不是一个愚蠢的问题,但我试图解决这个问题一天了。

mar*_*arc 7

让我们从约束开始,您的滚动视图已正确添加,现在对于您的 imageView,将其拖放到滚动视图中,按照您想要的方式指定左右顶部和底部约束,并垂直和水平居中您的 imageView,就像下面的屏幕截图

左右上下约束

中心图像视图

让我们继续处理 imageView。

在故事板上选择它,然后在助理编辑器中将内容模式更改为方面适合,如下所示:

方面适合

现在让我们转到代码,

通过键入 scrollView.delegate = ViewController() 您正在创建一个 ViewController 类型的新实例,并且您没有使用现有的实例,这就是为什么您应该将这一行替换为:

scrollView.delegate = self
Run Code Online (Sandbox Code Playgroud)

通过这种方式,您将引用您的超类,即您现有的视图控制器

并考虑添加这个:

scrollView.minimumZoomScale = 1.0
scrollView.maximumZoomScale = 5.0

scrollView.contentSize = .init(width: 2000, height: 2000)
Run Code Online (Sandbox Code Playgroud)

最好的,马克