在视图中使用文本视图的自动布局[Swift]。

问题描述 投票:0回答:1

我试图在一个主视图中创建两个视图,这些视图由一个文本视图自动调整大小,我想先添加一个视图,然后通过点击按钮添加秒,但我有一些错误.但我不想把等高约束到主视图,它必须根据其2个子视图中的文本视图调整大小。

        @objc func buttonAction() {
            print("action")

            mainView.addSubview(secondView)

            firstView.topAnchor.constraint(equalTo: mainView.topAnchor).isActive = false
            // I've tried to disable it to change the topAnchor of firstView 

            NSLayoutConstraint.activate([

                secondView.bottomAnchor.constraint(equalTo: firstView.topAnchor),
                secondView.leadingAnchor.constraint(equalTo: mainView.leadingAnchor),
                secondView.trailingAnchor.constraint(equalTo: mainView.trailingAnchor),
                secondView.topAnchor.constraint(equalTo: mainView.topAnchor)
            ])
        }

        func addConstraints() {

            NSLayoutConstraint.activate([

                firstView.topAnchor.constraint(equalTo: mainView.topAnchor),
                firstView.bottomAnchor.constraint(equalTo: mainView.bottomAnchor),
                firstView.leadingAnchor.constraint(equalTo: mainView.leadingAnchor),
                firstView.trailingAnchor.constraint(equalTo: mainView.trailingAnchor),
            ])

            NSLayoutConstraint.activate([
                mainView.centerYAnchor.constraint(equalTo: view.centerYAnchor),
                mainView.centerXAnchor.constraint(equalTo: view.centerXAnchor)
            ])
        }

        class View1: UIView { // the same as View2 class

        lazy var textView: UITextView = {
           let tv = UITextView()
            tv.backgroundColor = .red
            tv.isScrollEnabled = false
            tv.font = UIFont(name: "Avenir", size: 16)
            tv.text = "First"
            tv.translatesAutoresizingMaskIntoConstraints = false
            return tv
        }()

        init() {
            super.init(frame: .zero)
            setup()
        }

        required init?(coder: NSCoder) {
            fatalError()
        }

        func setup() {
            addSubview(textView)

            textView.fillSuperview(padding: .init(top: 4, left: 4, bottom: 4, right: 4))
            // fillSuperview() put 4 in top,left,right,bottom of superview

        }
    }

这里是我的意思的图片。enter image description here

swift uiview autolayout constraints
1个回答
1
投票

你需要保存一个对firstView顶部约束的引用,并停用该引用。你是想停用对firstView顶部约束的新引用。

class ViewController: UIViewController {

    var firstViewTop: NSLayoutConstraint!

    func addConstraints() {

        firstViewTop = firstView.topAnchor.constraint(equalTo: mainView.topAnchor)
        NSLayoutConstraint.activate([
            firstViewTop,
            firstView.bottomAnchor.constraint(equalTo: mainView.bottomAnchor),
            firstView.leadingAnchor.constraint(equalTo: mainView.leadingAnchor),
            firstView.trailingAnchor.constraint(equalTo: mainView.trailingAnchor),
        ])

        NSLayoutConstraint.activate([
            mainView.centerYAnchor.constraint(equalTo: view.centerYAnchor),
            mainView.centerXAnchor.constraint(equalTo: view.centerXAnchor)
        ])
    }

    @objc func buttonAction() {
        mainView.addSubview(secondView)
        firstViewTop.isActive = false

        NSLayoutConstraint.activate([
            secondView.bottomAnchor.constraint(equalTo: firstView.topAnchor),
            secondView.leadingAnchor.constraint(equalTo: mainView.leadingAnchor),
            secondView.trailingAnchor.constraint(equalTo: mainView.trailingAnchor),
            secondView.topAnchor.constraint(equalTo: mainView.topAnchor)
        ])
    }

}
© www.soinside.com 2019 - 2024. All rights reserved.