对象上的 NSLayoutConstraints swift 3.0

Posted

技术标签:

【中文标题】对象上的 NSLayoutConstraints swift 3.0【英文标题】:NSLayoutConstraints on objects swift 3.0 【发布时间】:2017-04-15 18:03:17 【问题描述】:

目前我正在使用这行代码在左上角的 UILabel 上设置原点...

addConstraint(NSLayoutConstraint(item: messageLabel, attribute: .centerY, relatedBy: .equal, toItem: self, attribute: .centerY, multiplier: 1, constant: 0))

但是,如果有意义的话,我希望原点距离左边缘 H 0 像素和高度的一半。

有什么建议吗?我试过更改乘数无济于事。

我要做的是移动原点,使 (0,0) 不是左上角,而是标签的最左侧和标签高度的一半,以便我可以正确居中标签。

【问题讨论】:

我建议你修改你的代码,这样人们就可以阅读它而无需荒谬的滚动。我拒绝按原样阅读。 【参考方案1】:

澄清一下,您需要将标签左对齐并从上到下居中吗?

你看过NSLayoutAnchor吗?

messageLabel = UILabel(/* Initialized somehow */)
messageLabel.translatesAutoresizingMaskIntoConstraints = false

view.addSubview(messageLabel)
view.centerYAnchor.constraint(equalTo: messageLabel.centerYAnchor).isActive = true
view.leadingAnchor.constraint(equalTo: messageLabel.leadingAnchor).isActive = true

【讨论】:

【参考方案2】:

尝试设置标签的来源:

messageLabel.horizontalAlignmentMode = .Left
messageLabel.position = CGPoint(x:0.0, y:self.size.height)

不需要约束!!

希望能帮到你:)

【讨论】:

没有需要约束如果您的应用程序被旋转锁定。这意味着您的应用只有一个 方向设置,横向或纵向。如果您想在您的应用程序中允许方向更改,您确实需要使用自动布局。唯一的其他选择是监听来自系统的方向变化并手动调整你的 UI 元素的位置。这非常乏味,在转换过程中不如自动布局优雅,而且在当今 ios 开发时代,不使用自动布局是一个重大错误。 由于不需要乘数或常数,因此不需要约束。 stefan 只是想将按钮设置为顶部让角落就可以了 如果没有适当的约束,标签框架在方向改变时将保持不变。是的,您可以这样添加,但问题最初是关于 NSLayoutConstraint。【参考方案3】:

首先,您必须将视图添加为其容器的子视图。完成此操作后,您需要将 translatesAutoResizingMaskToConstraints 设置为 false。然后是时候添加你的NSLayoutConstraints

    let labelWidth:CGFloat = 320
    let labelHeight:CGFloat = 30
    // Container is what you are adding label too
    let container = UIView(frame: CGRect(x: 0, y: 0, width: 500, height: 500))
    let label = UILabel(frame: CGRect(x: 0, y: (container.frame.size.height / 2) - (labelHeight / 2), width: labelWidth, height: labelHeight))
    container.addSubview(label)
    label.translatesAutoresizingMaskIntoConstraints = false

    // Add Width and Height (IF is required,
    // if not required, anchor your label to appropriately)
    label.addConstraints([
        NSLayoutConstraint.init(item: label, attribute: .width, relatedBy: .equal, toItem: nil, attribute: .notAnAttribute, multiplier: 1.0, constant: labelWidth),
        NSLayoutConstraint.init(item: label, attribute: .height, relatedBy: .equal, toItem: nil, attribute: .notAnAttribute, multiplier: 1.0, constant: labelHeight),
    ])

    label.layoutIfNeeded()

    // Add left constraint and center in container constraint
    container.addConstraints([
        NSLayoutConstraint.init(item: label, attribute: .left, relatedBy: .equal, toItem: .container, attribute: .left, multiplier: 1.0, constant: 0.0),
        NSLayoutConstraint.init(item: label, attribute: .centerX, relatedBy: .equal, toItem: .container, attribute: .left, multiplier: 1.0, constant: 0.0)
    ])

    container.layoutIfNeeded()

编辑

是的,当您使用点语法时,Xcode 会自动为您提供文档。如果您转到属性的参数并输入一个句点,您将看到所有可能选项的下拉列表。

【讨论】:

你指的是哪个常量?如果您指的是标签的宽度和高度,我将其设置在代码的最顶部。 文档中是否有任何地方可以看到 NSLayoutConstraints 的所有可能属性? 我已经更新了我的问题,以便更好地传达我到底想要做什么

以上是关于对象上的 NSLayoutConstraints swift 3.0的主要内容,如果未能解决你的问题,请参考以下文章

使用 NSLayoutConstraints 调整当前视图的大小

在 UITableView 的标题视图上使用 NSLayoutConstraints

NSLayoutConstraints 的 UIViewPropertyAnimator 使视图消失

Swift 中的尾随和前导约束以编程方式 (NSLayoutConstraints)

Swift 中 NSLayoutConstraints 的奇怪行为

在 Swift 中枚举视图的 NSLayoutConstraints?