在使用UIScrollView将contentView嵌套在一个UIView上时,正确的约束非常重要。
以下是一些关键约束:
ContentView必须在UIScrollView内部贴边,以便正确确定其滚动范围。
UIImageView需要正确的宽度和高度约束。如果你只设置了宽度或高度,那么它会按其原始纵横比缩放。对于UIImageView,你可以设置宽和高(这通常是最简单的),或者你可以设置在UIImageView上的两个相等(或固定)的大小约束。
如果UIImageView被嵌套在contentView上,集中布局的方式是使用leading和trailing约束,而不是左右对齐。
下面是一些包含上述约束的示例代码:
class ViewController: UIViewController {
@IBOutlet weak var scrollView: UIScrollView!
@IBOutlet weak var contentView: UIView!
@IBOutlet weak var imageView: UIImageView!
override func viewDidLoad() {
super.viewDidLoad()
imageView.translatesAutoresizingMaskIntoConstraints = false
contentView.translatesAutoresizingMaskIntoConstraints = false
contentView.widthAnchor.constraint(equalTo: scrollView.widthAnchor).isActive = true
contentView.heightAnchor.constraint(equalToConstant: 1000).isActive = true
contentView.topAnchor.constraint(equalTo: scrollView.topAnchor).isActive = true
contentView.leadingAnchor.constraint(equalTo: scrollView.leadingAnchor).isActive = true
contentView.trailingAnchor.constraint(equalTo: scrollView.trailingAnchor).isActive = true
contentView.bottomAnchor.constraint(equalTo: scrollView.bottomAnchor).isActive = true
imageView.widthAnchor.constraint(equalToConstant: 200).isActive = true
imageView.heightAnchor.constraint(equalToConstant: 200).isActive = true
let centerX = imageView.centerXAnchor.constraint(equalTo: contentView.centerXAnchor)
let imageViewTop = imageView.topAnchor.constraint(equalTo: contentView.topAnchor, constant: 50)
NSLayoutConstraint.activate([centerX, imageViewTop])
}
}