以编程方式快速添加约束

时间:2015-07-07 07:55:46

标签: ios swift constraints nslayoutconstraint

我正在尝试为facebook sdk登录按钮添加约束。

我在滚动视图中有按钮,我正在尝试将顶部约束添加到也在滚动视图中的标签。我能够成功添加高度约束,没有运行时错误,但实际约束似乎没有应用于按钮。

@IBOutlet weak var orLbl: UILabel!
@IBOutlet weak var scrollView: UIScrollView!

override func viewDidLoad() {
    super.viewDidLoad()
    var loginFBButton = FBSDKLoginButton()
    loginFBButton.readPermissions = ["public_profile", "email"]

    let heightConstraint = NSLayoutConstraint(
        item: loginFBButton,
        attribute: NSLayoutAttribute.Height,
        relatedBy: NSLayoutRelation.Equal,
        toItem: nil,
        attribute: NSLayoutAttribute.NotAnAttribute,
        multiplier: 1,
        constant: 41)
    let topConstraint = NSLayoutConstraint(
        item: loginFBButton,
        attribute: NSLayoutAttribute.TopMargin,
        relatedBy: NSLayoutRelation.Equal,
        toItem: self.orLbl,
        attribute: NSLayoutAttribute.BottomMargin,
        multiplier: 1,
        constant: 31)
    let leadingConstraint = NSLayoutConstraint(
        item: loginFBButton,
        attribute: NSLayoutAttribute.Leading,
        relatedBy: NSLayoutRelation.Equal,
        toItem: self.registerButton,
        attribute: NSLayoutAttribute.Left,
        multiplier: 1,
        constant: 0)
    let trailingConstraint = NSLayoutConstraint(
        item: loginFBButton,
        attribute: NSLayoutAttribute.Leading,
        relatedBy: NSLayoutRelation.Equal,
        toItem: self.registerButton,
        attribute: NSLayoutAttribute.Right,
        multiplier: 1,
        constant: 0)

    self.scrollView.addSubview(loginFBButton)
    //loginFBButton.center = self.scrollView.center

    loginFBButton.addConstraints([heightConstraint, topConstraint])

}

然后,当我添加顶部约束时,我收到运行时错误:

添加到视图时,约束的项必须是该视图的后代(或视图本身)。如果在组装视图层次结构之前需要解析约束,则会崩溃。

由于未捕获的异常'NSGenericException'而终止应用程序,原因:'无法在视图上安装约束。约束是否引用了视图子树之外的内容?那是违法的。

标签和facebook按钮都在我的滚动视图中?我甚至打印出了orLbl.superview和loginFBButton.superview,我得到了两者的可选uiscrollview

1 个答案:

答案 0 :(得分:29)

有一个新的(iOS8,OS 10.10),更简单的激活约束的方法,不涉及找出添加它们的视图。约束已经知道它们属于哪些视图,因此首先要确保您的视图已添加为子视图,然后调用activateConstraints上的类方法NSLayoutConstraint来激活它们:

 NSLayoutConstraint.activateConstraints([heightConstraint, topConstraint])

以编程方式创建UI元素时,需要告诉iOS不要将其框架变为约束。要做到这一点,请在创建loginFBButton之后执行:

对于Swift 1.2:

loginFBButton.setTranslatesAutoresizingMaskIntoConstraints(false)

对于Swift 2.0& 3.0:

loginFBButton.translatesAutoresizingMaskIntoConstraints = false

最后,您将需要更多约束。我建议为loginFBButton设置宽度约束,并添加约束以水平定位按钮。