如何添加约束,以便在方向改变时视图的尺寸不会改变?

时间:2019-01-06 09:58:22

标签: ios swift autolayout

我希望我的视图具有以下属性(数字是任意选择的):

  • 宽度等于高度除以1.2
  • 停留在屏幕右下方
  • 高度为纵向时屏幕高度的1/7
  • 宽度和高度在方向改变时不会改变

前三个要求可以轻松转换为UILayoutConstraint。我之所以使用SnapKit来做,只是因为它读起来更清晰。即使您以前从未使用过SnapKit,也应该明白我的意思。

let myView = UIView(frame: .zero)
myView.backgroundColor = .green
view.addSubview(myView)
myView.snp.makeConstraints { (make) in
    make.right.equalToSuperview().offset(-8)
    make.bottom.equalToSuperview().offset(-8)
    make.width.equalTo(myView.snp.height).dividedBy(1.2)
    make.height.equalTo(view.snp.height).dividedBy(7) // *
}

问题是最后一个要点。当我将设备从纵向旋转到横向时,旋转之前的原始宽度变为旋转之后的高度。结果导致我的视​​线变小。

基本上,我想用以下内容替换标记为*的约束:

make.height.equalTo(max(view.snp.height, view.snp.width)).dividedBy(7)

但是我不认为max(a, b)是SnapKit或UILayoutConstraint API中的东西。

当然还有其他表达“等于更长的长度”的方法,对吗?

P.S。我没有用标记它,因为我也会接受使用UILayoutConstraint API的答案。

1 个答案:

答案 0 :(得分:1)

您似乎有2个选择:

  1. 对高度值进行硬编码。
  2. 尝试使用nativeBounds
  

此矩形基于设备的纵向放置。该值不会随着设备旋转而改变。

在这种情况下,height始终是纵向模式。

myView.snp.makeConstraints { make in
    make.right.bottom.equalToSuperview().offset(-8)
    let screenHeight = UIScreen.main.nativeBounds.height / UIScreen.main.nativeScale
    let height = screenHeight / 7
    make.width.equalTo(height).dividedBy(1.2)
    make.height.equalTo(height)
}