自动布局是:有了这玩意,我们可以少写一些代码,或者少拉一些约束。
而且对于3等分啊,什么的布局很是方便。
虽然它是继承UIView 的,但是并不会实际渲染,再布局时也不用给几个控件拉一个真的contentView了。
创建
NSArray *stackSubViews = @[self.view1,self.view2,self.view3];
self.stackView = [[UIStackView alloc] initWithArrangedSubviews:stackSubViews];
[self.view addSubview:self.stackView];
属性
self.stackView.axis = UILayoutConstraintAxisHorizontal;// 布局方向
self.stackView.distribution = UIStackViewDistributionFillEqually;// 填充方式
/*
UIStackViewDistributionFill = 0, // 自定义宽高
UIStackViewDistributionFillEqually, // 布局方向均分:宽或高自己写
UIStackViewDistributionFillProportionally, // 布局方向排布,超出的截断
UIStackViewDistributionEqualSpacing, // 间距一致
UIStackViewDistributionEqualCentering, // center 均分
// 一般只需要设置内容的 宽 或 高
*/
self.stackView.alignment = UIStackViewAlignmentFill;// 对齐方式
/*
UIStackViewAlignmentFill,// 充满,不需要设置宽高,会冲突
UIStackViewAlignmentCenter,// 居中
UIStackViewAlignmentLeading,
UIStackViewAlignmentTop = UIStackViewAlignmentLeading,
UIStackViewAlignmentTrailing,
UIStackViewAlignmentBottom = UIStackViewAlignmentTrailing,
UIStackViewAlignmentFirstBaseline,
UIStackViewAlignmentLastBaseline,
// 对齐方式,需要对应少量设置
*/
self.stackView.spacing = 20.;// 间距。 某几种布局有效,优先级不是很高,
其他
// self.stackView.layoutMarginsRelativeArrangement = YES;// ??
// self.stackView.baselineRelativeArrangement = YES;// ??