Masonry的层层进阶1 基础写法:2 进阶写法3 自动装箱的写法4 Masonry的练习4.1 设置居中5. 更新及重建约束6. Masonry的两个宏

Masonry的官方是这么描述自己的。

  • Masonry is a light-weight layout framework which wraps AutoLayout with a nicer syntax. Masonry has its own layout DSL which provides a chainable way of describing your NSLayoutConstraints which results in layout code that is more concise and readable. Masonry supports iOS and Mac OS X.
  • However if you're using Swift in your project, we recommend using SnapKit as it provides better type safety with a simpler API. Masonry : https://github.com/SnapKit/Masonry SnapKit: https://github.com/SnapKit/SnapKit

2.1 Basic Grammar

mas_makeConstraints mas_updateContraints mas_remakeContraints

1 基础写法:

    [redView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.centerX.equalTo(self.view.mas_centerX);
        make.centerY.equalTo(self.view.mas_centerY);
//equalTo 后面要求跟一个OC对象的数据,所以需要对数字进行包装。@将数字变成了NSNumber 类型。
        make.width.equalTo(@200);
        make.height.equalTo(@50);
    }];

make.xxxx属性.equalTo(参照对象.mas_属性【如果相同,可以省略】).offset(常数)

2 进阶写法

  • NSNumber只能装基本数据类型
  • NSValue可以装结构体等数据类型
// 进阶语法
    [redView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.center.equalTo(self.view);
        make.size.equalTo([NSValue valueWithCGSize:CGSizeMake(200, 100)]);
    }];

3 自动装箱的写法

  • 装箱:把一个基本数据类型转换成为对象类型的过程叫做“装箱”,或者“包装”。
    [redView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.center.equalTo(self.view);
        make.size.mas_equalTo(CGSizeMake(100, 200));
    }];

4 Masonry的练习

4.1 设置居中

// create a imageview in the center of scrollview UIImageView *imageView = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"001"]]; [scrollView addSubview:imageView]; [imageView mas_makeConstraints:^(MASConstraintMaker *make) { make.center.equalTo(scrollView); make.size.mas_equalTo(CGSizeMake(140, 140)); }];

4.2 让一个view略小于其superView(边距为20)

  • 假设redView 是View 的子控件
[redView mas_makeConstraints:^(MASConstraintMaker *make) { make.top.equalTo(self.view.mas_top).offset(20); make.left.equalTo(self.view.mas_left).offset(20); make.bottom.equalTo(self.view.mas_bottom).offset(-20); make.right.equalTo(self.view.mas_right).offset(-20); }];
  • 当约束控件属性和参照控件属性相同的时候,参照控件的属性可以不写
    [redView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.top.equalTo(self.view).offset(20);
        make.left.equalTo(self.view).offset(20);
        make.bottom.equalTo(self.view).offset(-20);
        make.right.equalTo(self.view.).offset(-20);
    }];
  • 如果参照的是自己的父控件,参照控件也可以省略不写
[imageView mas_makeConstraints:^(MASConstraintMaker *make) { make.top.offset(20); make.left.offset(20); make.bottom.offset(20); make.right.offset(20); }];
  • 如果多个属性的offset数值一样,属性也可以连写
    [imageView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.top.left.offset(20);
        make.bottom.right.offset(20);
    }];

4.3 通过更简单的内边距形式修改控件的位置和大小

    [imageView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.edges.mas_offset(UIEdgeInsetsMake(20, 20, 20, 20));
    }];

5. 更新及重建约束

  • update是更新约束:如果之前已经添加过,那么就是更新约束。但是如果之前没有设置过,有可能会造成约束冲突。
  • 修改完约束之后,需要让子控件根据约束调整frame才能生效
[imageView mas_updateConstraints:^(MASConstraintMaker *make) {
        make.right.offset(-50);
    }];
    
//    播放两秒动画
    [UIView animateWithDuration:2 animations:^{
        //让这个控件立刻根据约束修改自己的frame
        [imageView layoutIfNeeded];
    }];

6. Masonry的两个宏

  • 如果想在使用Masonry框架时,省略mas_的前缀,需要定义以下宏:
  • #define MAS_SHORTHAND
  • 让equalTo,offset都带有自动装箱功能,需要定义以下宏:
  • #define MAS_SHORTHAND_GLOBALS

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏TechBox

史上最全的iOS之UITextView实现placeHolder占位文字的N种方法前言方法一方法二方法三方法四方法五

1322
来自专栏韩东吉的Unity杂货铺

零基础入门 29:贴图变灰

今天的内容不多,通常在游戏中,大家经常会遇到这样的需求,就是原本一个美术出来的图片,因为某种状态下,需要将他变成灰色代表当前禁用或者未激活一类的提示效果,那么,...

563
来自专栏菩提树下的杨过

Flash/Flex学习笔记(32):播放音乐并同步显示lyc歌词(适用于Silverlight)

题外话:个别朋友总是问我同样的问题,做为一名c#/silverlight程序员为啥还要学flash ? 回 答:看日本片时,就不能对照看欧美的么? 不体会日本的...

1787
来自专栏wym

俄罗斯方块

//*********************************************// //**************  头文件  *****...

571
来自专栏iOS122-移动混合开发研究院

Masonry -- 使用纯代码进行iOS应用的autolayout自适应布局

简介 简化iOS应用使用纯代码机型自适应布局的工作,使用一种简洁高效的语法替代NSLayoutConstraints. 最新示例: 点击下载 项目简议: 如果再...

2005
来自专栏懒人开发

鸿洋AutoLayout代码分析(二):获取Manifest中的值

从AndroidManifest.xml中去取值,自己觉得应该和 PackageManager 或 Manifest 有关 (Manifest 简单是一个容器...

1062
来自专栏菩提树下的杨过

Silverlight Telerik控件学习:TreeView数据绑定并初始化选中状态、PanelBar的Accordion效果、TabPanel、Frame基本使用

实际开发中控件的数据源肯定是动态绑定的,不可能在xaml里写死item项。既然要绑定,就先来几个实体类: ? 上面是类图,各类的代码如下:  Business...

2558
来自专栏wym

俄罗斯方块修复BUG版

//*********************************************// //**************  头文件  ***...

692
来自专栏程序你好

在WPF桌面程序中使用ECharts展示图表

1243
来自专栏GIS讲堂

Arcgis for JS实现台风运动路径与影像范围的显示

1172

扫码关注云+社区