使用Auto Layout-代码实现自动布局

[NSLayoutConstraint constraintWithItem:(id)itemattribute:(NSLayoutAttribute)attributerelatedBy:(NSLayoutRelation)relationtoItem:(id)otherItemattribute:(NSLayoutAttribute)otherAttributemultiplier:(CGFloat)multiplierconstant:(CGFloat)constant]



参数说明:

第一个参数:指定约束左边的视图view1

第二个参数:指定view1的属性attr1,具体属性见文末。

第三个参数:指定左右两边的视图的关系relation,具体关系见文末。

第四个参数:指定约束右边的视图view2

第五个参数:指定view2的属性attr2,,具体属性见文末。

第六个参数:指定一个与view2属性相乘的乘数multiplier

第七个参数:指定一个与view2属性相加的浮点数constant


这个函数的对照公式为:

view1.attr1 <relation> view2.attr2 * multiplier + constant


注意:

1.如果你想设置的约束里不需要第二个view,要将第四个参数设为nil,第五个参数设为NSLayoutAttributeNotAnAttribute


举例:

[NSLayoutConstraint constraintWithItem:view1attribute:NSLayoutAttributeLeftrelatedBy:NSLayoutRelationEqualtoItem:view2attribute:NSLayoutAttributeRightmultiplier:1constant:10]


翻译过来就是:view1的左侧,在,view2的右侧,再多10个点,的地方。



附视图的属性和关系的值:


typedef NS_ENUM(NSInteger, NSLayoutRelation) {

NSLayoutRelationLessThanOrEqual = -1,//小于等于NSLayoutRelationEqual = 0,//等于NSLayoutRelationGreaterThanOrEqual = 1,//大于等于};typedef NS_ENUM(NSInteger, NSLayoutAttribute) {NSLayoutAttributeLeft = 1,//左侧NSLayoutAttributeRight,//右侧NSLayoutAttributeTop,//上方NSLayoutAttributeBottom,//下方NSLayoutAttributeLeading,//首部NSLayoutAttributeTrailing,//尾部NSLayoutAttributeWidth,//宽度NSLayoutAttributeHeight,//高度NSLayoutAttributeCenterX,//X轴中心NSLayoutAttributeCenterY,//Y轴中心NSLayoutAttributeBaseline,//文本底标线NSLayoutAttributeNotAnAttribute = 0//没有属性};


NSLayoutAttributeLeft/NSLayoutAttributeRight 和 NSLayoutAttributeLeading/NSLayoutAttributeTrailing的区别是left/right永远是指左右,而leading/trailing在某些从右至左习惯的地区会变成,leading是右边,trailing是左边。(大概是⊙﹏⊙b)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值