前言:
回想起2013年做iOS开发的时候,那时候并没有采用手写布局代码的方式,而是采用xib文件来编写,如果使用纯代码方式是基于window的size(320,480)计算出一个相对位置进行布局,那个时候windows的size是固定不变的,随着iphone5的发布,windows的size(320,568)也发生了变化,而采用autoresizingMask的方式进行适配,到后来iphone 6之后windows size的宽度也随之变化,开始抛弃autoresizingMask改用autolayout了,使用autolayout进行适配我也是最近重新做iOS开发才接触的,公司使用Masonry框架进行布局适配。所以学习使用这个布局框架对我来说至关重要,它大大提高了开发效率而且最近使用起来很多语法和Android有很大的相似之处。
什么是Masonry?
Masonry是一个轻量级的布局框架,拥有自己的描述语法,采用更优雅的链式语法封装自动布局、简洁明了、 并具有高可读性、 而且同时支持 iOS 和 Max OS X。
如何使用?
1.)引入头文件
我这里是在全局引用pch文件中引用的
#import "Masonry.h"
2.)基本语法
Masonry提供的属性
Masonry提供了三个函数方法
我们根据不同的使用场景来选择使用不同的函数方法。
3.)具体举例
比如一个往父控件中添加一个上下左右与父控件间距为50的子视图
添加约束
UIView *tempView=[[UIView alloc]init]; tempView.backgroundColor=[UIColor greenColor]; [self.view addSubview:tempView]; [tempView mas_makeConstraints:^(MASConstraintMaker *make) { make.left.mas_equalTo(50); make.right.mas_equalTo(-50); make.top.mas_equalTo(50); make.bottom.mas_equalTo(-50); }];
等价于
UIView *tempView=[[UIView alloc]init]; tempView.backgroundColor=[UIColor greenColor]; [self.view addSubview:tempView]; [tempView mas_makeConstraints:^(MASConstraintMaker *make) { make.left.equalTo(self.view.mas_left).offset(50); make.right.equalTo(self.view.mas_right).offset(-50); make.top.equalTo(self.view.mas_top).offset(50); make.bottom.equalTo(self.view.mas_bottom).offset(-50); }];
也可以简化为下面这种
UIView *tempView=[[UIView alloc]init]; tempView.backgroundColor=[UIColor greenColor]; [self.view addSubview:tempView]; [tempView mas_makeConstraints:^(MASConstraintMaker *make) { make.edges.mas_equalTo(UIEdgeInsetsMake(50, 50, 50, 50)); }];
又等价于
UIView *tempView=[[UIView alloc]init]; tempView.backgroundColor=[UIColor greenColor]; [self.view addSubview:tempView]; [tempView mas_makeConstraints:^(MASConstraintMaker *make) { make.edges.equalTo(self.view).insets(UIEdgeInsetsMake(50, 50, 50, 50)); }];
更新约束
[tempView mas_updateConstraints:^(MASConstraintMaker *make) { make.left.mas_equalTo(50); make.right.mas_equalTo(-50); make.top.mas_equalTo(100); make.bottom.mas_equalTo(-100); }];
清除之前的约束保留最新的
[tempView mas_remakeConstraints:^(MASConstraintMaker *make) { make.left.mas_equalTo(100); make.right.mas_equalTo(-100); make.top.mas_equalTo(100); make.bottom.mas_equalTo(-100); }];
特别注意:
声明约束必须在视图添加到父试图上面之后调用。
4.)mas_equalTo与equalTo
上面的举例中分别使用了mas_equalTo和equalTo达到了同样的效果,我在刚开始使用Masonry的时候很容易混淆他们两个,今天特意分析一下他们的区别。mas_equalTo是一个MACRO,比较的是值,equalTo比较的是id类型。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Android布局控件之常用linearlayout布局,包括了Android布局控件之常用linearlayout布局的使用技巧和注意事项,需要的朋友参考一下 LinearLayout是线性布局控件,它包含的子控件将以横向或竖向的方式排列,按照相对位置来排列所有的widgets或者其他的containers,超过边界时,某些控件将缺失或消失。因此一个垂直列表的每一行只会有一个wid
本文向大家介绍iOS App开发中Masonry布局框架的基本用法解析,包括了iOS App开发中Masonry布局框架的基本用法解析的使用技巧和注意事项,需要的朋友参考一下 Masonry是一个轻量级的布局框架,拥有自己的描述语法,采用更优雅的链式语法封装自动布局,简洁明了并具有高可读性,而且同时支持 iOS 和 Max OS X。Masonry是一个用代码写iOS或OS界面的库,可以代替Aut
主要内容:Frame控件,LabelFrame控件,PanedWindow控件,Toplevel控件除了上一节《 Tkinter布局管理方法》中提到的三个常用方法外,Tkinter 还提供了几个常用的布局管理控件,比如 Frame 、LabelFrame 等,这些控件的主要作用是为其他控件提供载体,并将主窗口界面划分成多个区域,从而方便开发者对不同区域进行设计与管理。 在前文讲解其他的 Tkinter 控件时,我们列举的大多数示例都是将控件直接放置在主窗口(即根窗口)内,这样做的目的是为了便于
本文向大家介绍Android布局之表格布局TableLayout详解,包括了Android布局之表格布局TableLayout详解的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android表格布局TableLayout的具体代码,供大家参考,具体内容如下 1.TableLayout TableLayout表格布局模型以行列的形式管理子控件,每一行为一个TableRow的对象, 当
本文向大家介绍深入学习js瀑布流布局,包括了深入学习js瀑布流布局的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了js瀑布流布局学习资料,供大家参考,具体内容如下 特点:等宽不等高。 实现方式:Javascript/Jquery/CSS3多栏布局。 样例网站:花瓣网-->分类 一、JS实现瀑布流 index.html:页面结构 layout.css:页面元素样式 waterf
本文向大家介绍Android布局优化之ViewStub控件,包括了Android布局优化之ViewStub控件的使用技巧和注意事项,需要的朋友参考一下 ViewStub是Android布局优化中一个很不错的标签/控件,直接继承自View。虽然Android开发人员基本上都听说过,但是真正用的可能不多。 ViewStub可以理解成一个非常轻量级的View,与其他的控件一样,有着自己的属性及特定的方法