iOS简单自动布局autoresizing的组合情况研究
iOS简单自动布局autoresizing的组合情况研究
hellofox2000 发表于2年前
iOS简单自动布局autoresizing的组合情况研究
  • 发表于 2年前
  • 阅读 1765
  • 收藏 4
  • 点赞 3
  • 评论 0

腾讯云 学生专属云服务套餐 10元起购>>>   

摘要: autoresizing是UIView的属性,可以用来做一些简单的自动布局实现。网络文章介绍单属性的居多,对组合情况研究的较少。本文对组合情况进行了一些研究。

autoresizing是UIView的属性,可以用来做一些简单的自动布局实现。网络文章介绍单属性的居多,对组合情况研究的较少。本文对组合情况进行了一些研究。

单属性的介绍如下

属性 描述
UIViewAutoresizingNone 不会随父视图的改变而改变 
UIViewAutoresizingFlexibleLeftMargin 自动调整view与父视图左边距,以保证右边距不变
UIViewAutoresizingFlexibleWidth 自动调整view的宽度,保证左边距和右边距不变 
UIViewAutoresizingFlexibleRightMargin 自动调整view与父视图右边距,以保证左边距不变 
UIViewAutoresizingFlexibleTopMargin 自动调整view与父视图上边距,以保证下边距不变
UIViewAutoresizingFlexibleHeight 自动调整view的高度,以保证上边距和下边距不变
UIViewAutoresizingFlexibleBottomMargin 动调整view与父视图的下边距,以保证上边距不变


组合情况:

组合 描述
UIViewAutoresizingFlexibleLeftMargin | UIViewAutoresizingFlexibleWidth  

右边距不变,新的左边距=(新父视图的宽-右边距)*旧左边距/(旧父视图的宽 - 右边距) 

简单来说就是:右边距不变,左边距是按父视图去除右边距后的所占比例,成比例增长。

UIViewAutoresizingFlexibleRightMargin | UIViewAutoresizingFlexibleWidth

和上面的公式一样,左右互换即可

UIViewAutoresizingFlexibleLeftMargin | UIViewAutoresizingFlexibleRightMargin | UIViewAutoresizingFlexibleWidth

新的边距=新父视图的宽/旧父视图的宽*边距
UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleHeight 底部边距不变,新的顶边距=(新父视图的高-底边距)*旧顶边距/(旧父视图的宽 - 顶边距) 
UIViewAutoresizingFlexibleBottomMargin | UIViewAutoresizingFlexibleHeight 和上面的公式一样,顶底互换即可
UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleBottomMargin | UIViewAutoresizingFlexibleHeight 新的边距=新父视图的高/旧父视图的高*边距


下面对组合的第一种情况进行详细演示下。如图:

黑色view的frame为:(10, 100, 200, 100),蓝色view的frame为:(50, 10, 100, 80). 

当把黑色view的宽增加100时,此时新的左边距=(300-50)*50/(200-50)=83.333333333333

当把黑色view的宽增加200时,此时新的左边距=(400-50)*50/(200-50)=116.66666666667.

通过log可以很清楚的看到。



共有 人打赏支持
粉丝 3
博文 5
码字总数 4611
×
hellofox2000
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: