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

本文详细介绍了 iOS Auto Layout 中 NSLayoutConstraint 的使用方法,包括如何通过该方法定义两个视图之间的约束关系,以及如何设置视图间的距离、大小等属性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[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)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值