问题描述:
如下图所示,需要label1的左边距离屏幕左边间距为15单位,label5的右边距屏幕右边距为15单位,然后label1、label2、label3、label4和label5之间的距离相等。
解决方案:
目前笔者亲试可行的思路有三个:
思路1、使用UIStackVIew方式对label1~label5进行布局(最低支持版本为iOS 9)
思路2、使用AutoLayout对label1~label5的间距进行控制(最低支持版本为iOS 6)
思路3、在两个label之间插入控件,通过控件宽度对label间的距离进行控制(最朴素的方法,好处是不需要考虑版本兼容,且约束设计合理就不需要写一行代码,缺点是写约束时很痛苦,尤其是label数量比较大时)
以下将对思路1和思路2的主要实现步骤进行叙述:
1、使用UIStackVIew方式对label1~label5进行布局
step1.首先在storyboard中对label1~label5的长度和高度进行约束设置,在此不再赘述。
step2.将label1~label5添加到stackview中,首先选中5个label,然后点击step 2选中的“Embed in stack”,由于需要5个label在同一水平方向,所以选中step 3的Axis为Horizonal。
然后就能在左侧的structure中就能看到5个label已经被添加到stackview中了。
step3.由于需要label1的左边距离屏幕左边距为15个单位,label5的右边距屏幕右边为15单位,所以需要给stackview添加相应的约束。需要注意的是对stackview设置约束(例如距stackview上边控件的间距),会对stackview中的所有label都生效,而且如果在给label添加到stackview前对label的间距设置约束,添加到stackview后这些间距约束便不在生效。
step4.经过step3的操作后label的布局便如下图所示:
然后在storyboard中选中stackview并将Distribution设置为Equal Spacing,便能将label间距设为图1所示效果。
2、使用AutoLayout对label1~label5的间距进行控制
思路1的好处就是实现简单,但是当APP需要兼容iOS 9以下版本时就不适用了,所以可以考虑使用AutoLayout自动布局对label之间的距离进行控制,主要实现步骤如下:
step1.在对应ViewController文件中添加如下约束,其中labelSpacing是各个label之间的间距约束,leadSpacing是label1距离屏幕左侧间距的约束,labelWidth是label宽度的约束。
step2.在storyboard中将添加的属性与相应的约束进行关联。
step3.为了更新约束,需要重写-(void)updateViewConstraints方法,并在该方法中对需要修改的约束进行重新设置,这种思路在label之间的距离不是完全等分的时候,更为合适。
参考文献:
http://andrew-anlu.github.io/blog/2016/04/04/tong-guo-%5B%3F%5D-ge-demoxiang-jie-uistackview/
https://my.oschina.net/u/1418722/blog/353437