初识UIStackView

Stack View提供横向和纵向的线性布局功能,管理着所有在它的 arrangedSubviews数组中的所有子视图,会自动对这些子视图进行布局处理。

属性

stackView中的布局情况是根据其axis,alignement,distribution,spacing等其他属性共同决定。

a. Axis:stackview布局的轴向,分为垂直和水平


uistackview-axis

b. Alignment:决定了Stack View如何沿它轴向的垂直方向摆放它的subview,水平轴向和垂直轴向会有所不同。

UIStackViewAlignment 含义 展示
UIStackViewAlignmentFill 在StackView轴向的垂直方向上拉伸所有子view来填充StackView
uistackview-align-fill
UIStackViewAlignmentLeading 用于stackview是垂直轴向时,所有子view靠左对齐
uistackview-align-leading
UIStackViewAlignmentTop 用于stackview是水平轴向时,所有子view靠顶部对齐
uistackview-align-top
UIStackViewAlignmentCenter 在StackView轴向的垂直方向上子视图以中线为基准对齐
uistackview-align-center
UIStackViewAlignmentTrailing 用于stackview是垂直轴向时,所有子view靠右对齐
uistackview-align-trailing
UIStackViewAlignmentBottom 用于stackview是水平轴向时,所有子view靠底部对齐
uistackview-align-bottom
UIStackViewAlignmentFirstBaseline 用于stackview是水平轴向时,按照第一个子视图中文字的第一行对齐
uistackview-align-firstBaseline
UIStackViewAlignmentLastBaseline 用于stackview是水平轴向时,按照最后一个子视图中文字的最后一行对齐
uistackview-align-lastBaseline

c. Distibution:决定子视图的分布比例

UIStackViewDistribution 含义 展示
UIStackViewDistributionFill 默认,在StackView轴向延伸方向上缩放子View,使得所有子View能填充完StackView,如果子Views超出StackView,根据其compression resistance 优先级进行压缩;如果子Views不能填充完StackView,根据于其hugging优先级进行放大;如果相等的话,则按照arrangedSubviews数组中index顺序
uistackview-distrubute-fill
UIStackViewDistributionFillEqually 在StackView延伸方向上使每个子View都一样长
uistackview-distrubute-fillequal
UIStackViewDistributionFillProportionally 在StackView延伸方向上根据子View的实际内容按比例进行缩放
uistackview-distrubute-fillProp
UIStackViewDistributionEqualSpacing 在StackView延伸方向上将子Views间隔相等的空白进行缩放,如果子Views不能填充完StackView,则用空白填充子views之间;如果子Views超出StackView,则根据compression resistance优先级进行压缩;如果相等的话,则按照arrangedSubviews数组中index顺序
uistackview-distrubute-equalSpacing
UIStackViewDistributionEqualCentering 在StackView延伸方向上将子Views的中心线等距进行缩放,如果子View不能填充完StackView,则用空白填充子views之间;如果子View超出StackView,先缩小子views间隔直到其spacing属性定义的最小值;若还是超出,则根据compression resistance优先级进行压缩;如果相等的话,则按照arrangedSubviews数组中index顺序
uistackview-distrubute-equalCenter

d. Spacing:决定子视图的间隔距离
e. 如下图是 水平轴向的stackview属性标注


水平轴向的stackview属性标注

实现

stroyboard中利用stackview

  1. 效果展示


    stackview展示01

    stackview展示02
  2. 屏幕适配Size Classes


    stackview展示03-1

    stackview展示03-2

将屏幕横过来效果并不是很好,可以借用size classes实现成这样:


stackview展示03-3

sizeclass是对设备的一种抽象。它不再有尺寸、横屏和竖屏的概念,把设备分为紧凑Compact、普通Regular,ios设备和对应的size classes如下图:


sizeclass

ipad是 regular width + regular height

横屏的iphone 6 Plus是 regular width + compact height

竖屏的iphone是 compact width + regular height

横屏的iphone是 compact width + compact height

所以实现上述效果需要在compact height时,stackview的由垂直轴向改为水平,如下图所示


modify

ios7兼容

官方的UIStackView是在iOS9以上系统才可以可以使用,但是有开源代码提供了ios7以上的系统实现了相应的功能:
OAStackView 基于objective-c实现

TZStackView 基于swift实现

参考资料

Stack Views 翻译版

size classes design help

初探 iOS8 中的 Size Class

iOS 9 UIStackView Free Tutorial

UIStackView教程:了解Stack View

Auto Layout Tutorial in iOS 9

UIStackView Tutorial: Introducing Stack Views 翻译版

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容