5

我想在手机方向改变时重新计算高度约束。我正在使用这些功能uninstall()install()实现这一点。但是,它没有按预期工作。我是否错误地使用它们?

class ActionOverlayViewController: UIViewController {
    private var tableView = UITableView()
    private var heightConstraint: Constraint?

    override func viewDidLoad() {
        super.viewDidLoad()

        tableView.snp_makeConstraints { make in
            self.heightConstraint = make.height.lessThanOrEqualTo(UIScreen.mainScreen().bounds.size.height).priorityHigh().constraint
            make.height.equalTo(242).priorityLow()
        }
    }

    override func updateViewConstraints() {
        tableView.snp_updateConstraints { make in
            self.heightConstraint.uninstall()
            self.heightConstraint.install()
        }
        super.updateViewConstraints()
    }

    override func traitCollectionDidChange(previousTraitCollection: UITraitCollection?) {
        super.traitCollectionDidChange(previousTraitCollection)
        updateViewConstraints()
    }
}
4

1 回答 1

3

如果您想让您tableView的横向和纵向方向具有不同的高度,您可以使用 2 种不同的方法:

1.横向高度为200,纵向高度为400:

class ViewController: UIViewController {

    let tableView = UITableView()
    var heightConstraint: Constraint?

    override func viewDidLoad() {
        super.viewDidLoad()

        view.addSubview(tableView)

        tableView.snp.makeConstraints { (make) in
            make.top.left.right.equalTo(0)
            self.heightConstraint = make.height.equalTo(0).constraint
        }
    }

    override func traitCollectionDidChange(_ previousTraitCollection: UITraitCollection?) {
        super.traitCollectionDidChange(previousTraitCollection)
        let height = UIDevice.current.orientation.isLandscape ? 200 : 400
        heightConstraint?.update(offset: height)
    }
}

在这里你只需要调用update(offset:)约束。无需经过updateViewConstraints()。如果您有静态高度,这很有效。

2. 高度应该是纵向屏幕高度的一半,横向是全屏高度:

在这里,您必须更新整个约束,因为您不使用静态高度。因此,您不需要保留对约束的引用,但您必须通过updateViewConstraint()

class ViewController: UIViewController {

    let tableView = UITableView()

    override func viewDidLoad() {
        super.viewDidLoad()

        view.addSubview(tableView)
    }

    override func updateViewConstraints() {
        super.updateViewConstraints()
        tableView.snp.remakeConstraints { (make) in
            make.top.left.right.equalTo(0)
            if UIDevice.current.orientation.isLandscape {
                make.bottom.equalTo(0)
            } else {
                make.bottom.equalTo(view.snp.centerY)
            }
        }
    }

    override func traitCollectionDidChange(_ previousTraitCollection: UITraitCollection?) {
        super.traitCollectionDidChange(previousTraitCollection)
        view.setNeedsUpdateConstraints()
    }
}
于 2017-02-26T16:33:51.830 回答