I'm trying to autolayout my stack views and create its arrangedSubView(2 labels and 1 image) in code, but only one set of stack view is appear in simulator. When print the results in console, all labels and image have values, except all stack view's frame is 0.0;0.0
. Why does happen like this? Why the stack view do not appear? Please see my code below:
code
let contentView: UIView = UIView()
let stackView: UIStackView = UIStackView()
var singleStack = Array(count: 6, repeatedValue: UIStackView())
var timeLabel = Array(count: 6, repeatedValue: UILabel())
var iconImage = Array(count: 6, repeatedValue: UIImageView())
var tempLabel = Array(count: 6, repeatedValue: UILabel())
override func viewDidLoad() {
super.viewDidLoad()
for index in 0...5 {
timeLabel[index].text = "0\(index):00"
iconImage[index].image = UIImage(named: "sunny")!
tempLabel[index].text = "0\(index)°"
singleStack[index].addArrangedSubview(timeLabel[index])
singleStack[index].addArrangedSubview(iconImage[index])
singleStack[index].addArrangedSubview(tempLabel[index])
singleStack[index].translatesAutoresizingMaskIntoConstraints = false
singleStack[index].axis = .Vertical
singleStack[index].alignment = .Center
singleStack[index].distribution = .FillEqually
stackView.addArrangedSubview(singleStack[index])
print("\(timeLabel[index].text!)")
print("\(iconImage[index].image!)")
print("\(tempLabel[index].text!)")
print("\(singleStack[index])")
print("\(stackView)")
}
stackView.translatesAutoresizingMaskIntoConstraints = false
stackView.axis = .Horizontal
stackView.alignment = .Fill
stackView.distribution = .FillEqually
contentView.backgroundColor = UIColor.lightGrayColor()
view.addSubview(contentView)
contentView.addSubview(stackView)
contentView.translatesAutoresizingMaskIntoConstraints = false
NSLayoutConstraint.activateConstraints(NSLayoutConstraint.constraintsWithVisualFormat(
"H:|[stackView]|",
options: [],
metrics: nil,
views: ["stackView": stackView]))
NSLayoutConstraint.activateConstraints(NSLayoutConstraint.constraintsWithVisualFormat(
"V:|[stackView]|",
options: [],
metrics: nil,
views: ["stackView": stackView]))
NSLayoutConstraint.activateConstraints(NSLayoutConstraint.constraintsWithVisualFormat(
"H:|-[contentView]-|",
options: [],
metrics: nil,
views: ["contentView": contentView]))
NSLayoutConstraint.activateConstraints(NSLayoutConstraint.constraintsWithVisualFormat(
"V:[contentView(120)]-16-|",
options: [],
metrics: nil,
views: ["contentView": contentView]))
}
The printed results in console (just use one piece for example)
01:00
<UIImage: 0x7fb61944f630>, {32, 32}
01°
<UIStackView: 0x7fb6194462c0; frame = (0 0; 0 0); layer = <CATransformLayer: 0x7fb619445e70>>
<UIStackView: 0x7fb619443b50; frame = (0 0; 0 0); layer = <CATransformLayer: 0x7fb6194433b0>>
As you can see, all labels and image have values, but all stack view's frame is 0.0;0.0
.
Hope anyone can solve my problem, thank you very much in advance!