NSLayoutConstraint-代码实现自动布局的函数用法说明

转载 2015年11月18日 22:07:41

转自:http://rainbownight.blog.51cto.com/1336585/1316181


1
2
3
4
5
6
7
[NSLayoutConstraint constraintWithItem:(id)item
                             attribute:(NSLayoutAttribute)attribute
                             relatedBy:(NSLayoutRelation)relation
                                toItem:(id)otherItem
                             attribute:(NSLayoutAttribute)otherAttribute
                            multiplier:(CGFloat)multiplier
                              constant:(CGFloat)constant]



参数说明:

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

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

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

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

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

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

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


这个函数的对照公式为:

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


注意:

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


举例:

1
2
3
4
5
6
7
[NSLayoutConstraint constraintWithItem:view1
                             attribute:NSLayoutAttributeLeft
                             relatedBy:NSLayoutRelationEqual
                                toItem:view2
                             attribute:NSLayoutAttributeRight
                            multiplier:1
                              constant:10]


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


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


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
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)


相关文章推荐

[IOS]NSLayoutConstraint-代码实现自动布局的函数用法说明

//转载:http://zhuhaibobb.blog.163.com/blog/static/2744006720143712913273/ 1 2 3 ...

NSLayoutConstraint-代码实现自动布局的函数用法说明

1 2 3 4 5 6 7 [NSLayoutConstraint constraintWithItem:(id)item                         ...

NSLayoutConstraint-代码实现自动布局的函数用法说明

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://rainbownight.blog.51cto.com/1336585/13161...

NSLayoutConstraint-代码实现自动布局的函数用法说明

NSLayoutConstraint-代码实现自动布局的函数用法说明 来源:互联网 作者:佚名 时间:2013-10-30 09:28 [NSLayoutConstraintconstra...

自动布局之 NSLayoutConstraint-函数用法说明

1 2 3 4 5 6 7 [NSLayoutConstraint constraintWithItem:(id)item       ...

NSLayoutConstraint-代码实现自动布局的函数用法

[NSLayoutConstraint constraintWithItem:(id)item attribute:(NSLayoutAttribute)attribute relatedBy:(NS...

自动布局:AutoLayout代码实现:NSLayoutConstraint、VFL、Mansony

一、注意事项 1、使用AutoLayout自动布局,全程都不要出现和frame相关的代码了。 2、设置 AutoLayout 约束,之前先禁用AutoResizing ,在代码里只需要针对某一个视图决...

mansory使用记录&&NSLayoutConstraint-代码实现自动布局

在代码自动布局时,我们经常使用mansory来取代系统自带的autoLayout,mansory使用有如下注意点: mas_makeConstraints 是给view添加约束,约束有几种,分别是边...

Swift开发:NSLayoutConstraint纯代码实现自动布局-初级篇

要求 宽高200的view,通过代码,使得view在距离父控件的右下角20边距处 /* 约束的设置,控件内部约束由自己添加,比如宽高,如果是与其他的            控件约束那么有父控件...
  • taoerit
  • taoerit
  • 2016年05月04日 18:35
  • 6438
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:NSLayoutConstraint-代码实现自动布局的函数用法说明
举报原因:
原因补充:

(最多只允许输入30个字)