Autolayout:缩放到填充不起作用

时间:2016-04-20 18:50:43

标签: ios swift uiview autolayout

我试图以编程方式将UIView courseView添加到我在Storyboard中的Interface Builder中绘制的容器视图(称为容器)。 我希望courseView能够扩展以适应容器。没有显示以下代码 - courseView不会出现。我错过了什么?

var courseView:UIView?

@IBOutlet weak var container: UIView!

override func viewDidLoad() {
    super.viewDidLoad()

    courseView = UIView(frame: CGRectMake(0, 0, 1000, 1000))
    courseView?.backgroundColor = UIColor.blueColor()
    view.addSubview(courseView!)

    courseView!.translatesAutoresizingMaskIntoConstraints = false

    let courseWidthConstraint = NSLayoutConstraint(item: courseView!, attribute: .Width, relatedBy: .LessThanOrEqual, toItem: container, attribute: .Width, multiplier: 1.0, constant: 0)

    let courseHeightConstraint = NSLayoutConstraint(item: courseView!, attribute: .Height, relatedBy: .LessThanOrEqual, toItem: container, attribute: .Height, multiplier: 1.0, constant: 0)

    let courseViewConstraint = NSLayoutConstraint(item: courseView!, attribute: .Height , relatedBy: .Equal , toItem: courseView!, attribute: .Width, multiplier: 2.0, constant: 0)

    self.view.addConstraints([courseWidthConstraint, courseHeightConstraint, courseViewConstraint])

}

1 个答案:

答案 0 :(得分:0)

我不清楚你在这里想要实现的目标。但作为第一个建议,请尝试将.LessThanOrEqual替换为.Equal作为宽度约束。

你的约束需要做的另一件事是container的一些顶级和主要约束(顶部只是一个建议你可能想要一些高度的其他对齐)

let courseLeadingConstraint = NSLayoutConstraint(item: courseView!, attribute: .Leading, relatedBy: .Equal, toItem: container, attribute: .Leading, multiplier: 1.0, constant: 0)
let courseTopConstraint = NSLayoutConstraint(item: courseView!, attribute: .Top, relatedBy: .Equal, toItem: container, attribute: .Top, multiplier: 1.0, constant: 0)

高度的一半宽度的宽高比限制将是以下

let courseViewConstraint = NSLayoutConstraint(item: courseView!, attribute: . Width , relatedBy: .Equal , toItem: courseView!, attribute: .Height, multiplier: 2.0, constant: 0)

让我知道它是否成功。