autoresizing是UIView的属性,能够用来作一些简单的自动布局实现。网络文章介绍单属性的居多,对组合状况研究的较少。本文对组合状况进行了一些研究。网络
单属性的介绍以下布局
属性 | 描述 |
UIViewAutoresizingNone | 不会随父视图的改变而改变 |
UIViewAutoresizingFlexibleLeftMargin | 自动调整view与父视图左边距,以保证右边距不变 |
UIViewAutoresizingFlexibleWidth | 自动调整view的宽度,保证左边距和右边距不变 |
UIViewAutoresizingFlexibleRightMargin | 自动调整view与父视图右边距,以保证左边距不变 |
UIViewAutoresizingFlexibleTopMargin | 自动调整view与父视图上边距,以保证下边距不变 |
UIViewAutoresizingFlexibleHeight | 自动调整view的高度,以保证上边距和下边距不变 |
UIViewAutoresizingFlexibleBottomMargin | 动调整view与父视图的下边距,以保证上边距不变 |
组合状况:spa
组合 | 描述 |
UIViewAutoresizingFlexibleLeftMargin | UIViewAutoresizingFlexibleWidth | 右边距不变,新的左边距=(新父视图的宽-右边距)*旧左边距/(旧父视图的宽 - 右边距) orm 简单来讲就是:右边距不变,左边距是按父视图去除右边距后的所占比例,成比例增加。it |
UIViewAutoresizingFlexibleRightMargin | UIViewAutoresizingFlexibleWidthtable |
和上面的公式同样,左右互换便可 |
UIViewAutoresizingFlexibleLeftMargin | UIViewAutoresizingFlexibleRightMargin | UIViewAutoresizingFlexibleWidthword |
新的边距=新父视图的宽/旧父视图的宽*边距 |
UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleHeight | 底部边距不变,新的顶边距=(新父视图的高-底边距)*旧顶边距/(旧父视图的宽 - 顶边距) |
UIViewAutoresizingFlexibleBottomMargin | UIViewAutoresizingFlexibleHeight | 和上面的公式同样,顶底互换便可 |
UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleBottomMargin | UIViewAutoresizingFlexibleHeight | 新的边距=新父视图的高/旧父视图的高*边距 |
下面对组合的第一种状况进行详细演示下。如图:tab
黑色view的frame为:(10, 100, 200, 100),蓝色view的frame为:(50, 10, 100, 80). view
当把黑色view的宽增长100时,此时新的左边距=(300-50)*50/(200-50)=83.333333333333vi
当把黑色view的宽增长200时,此时新的左边距=(400-50)*50/(200-50)=116.66666666667.
经过log能够很清楚的看到。