PureLayout 是 iOS & OS X Auto Layout 的终极 API——非常简单,又非常强大。PureLayout 通过一个全面的Auto Layout API 扩展了 UIView/NSView, NSArray 和 NSLayoutConstraint,仿照苹果自身的框架, 构建了一个全面的自动布局 API, 这样你再也不用为适配而苦恼啦!!!
添加PureLayout到你的工程里面
- 用CocoaPods安装(
podilfe中加pod 'PureLayout')/GitHub下载PureLayout, 手动添加到你的项目中
- 导入头文件
#import <PureLayout/PureLayout.h> / #import "PureLayout.h"
我们就这个布局来简单说一下

首先新建几个 View
1 2 3 4 5
|
@property (nonatomic, strong) UIView *blueView; @property (nonatomic, strong) UIView *redView; @property (nonatomic, strong) UIView *yellowView; @property (nonatomic, strong) UIView *greenView; @property (nonatomic, assign) BOOL didSetupConstraints; // 判断是否存在约束条件
|
然后在加载试图
1 2 3 4 5 6 7 8 9 10 11
|
- (void)loadView { self.view = [UIView new]; self.view.backgroundColor = [UIColor colorWithWhite:0.1 alpha:1.0];
[self.view addSubview:self.blueView]; [self.view addSubview:self.redView]; [self.view addSubview:self.yellowView]; [self.view addSubview:self.greenView]; [self.view setNeedsUpdateConstraints]; // 设置新的约束天剑 }
|
如果没有试图,那么就重新创建一个
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
|
- (UIView *)blueView { if (!_blueView) { _blueView = [UIView newAutoLayoutView]; _blueView.backgroundColor = [UIColor blueColor]; } return _blueView; }
- (UIView *)redView { if (!_redView) { _redView = [UIView newAutoLayoutView]; _redView.backgroundColor = [UIColor redColor]; } return _redView; }
- (UIView *)yellowView { if (!_yellowView) { _yellowView = [UIView newAutoLayoutView]; _yellowView.backgroundColor = [UIColor yellowColor]; } return _yellowView; }
- (UIView *)greenView { if (!_greenView) { _greenView = [UIView newAutoLayoutView]; _greenView.backgroundColor = [UIColor greenColor]; } return _greenView; }
|
然后再添加试图的约束条件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
|
- (void)updateViewConstraints //更新约束条件 { // 如果没有自动约束条件 if (!self.didSetupConstraints) { // Blue view is centered on screen,(Centers the view in its superview.) with size {50 pt, 50 pt}
//设置蓝色的 view 在父试图的中心, [self.blueView autoCenterInSuperview]; //设置蓝色的 view 的宽和高(50.0 50.0) [self.blueView autoSetDimensionsToSize:CGSizeMake(50.0, 50.0)];
// Red view is positioned at the bottom right corner of the blue view, with the same width, and a height of 40 pt // 设置红色 view 的顶部是蓝色 view 的底部 [self.redView autoPinEdge:ALEdgeTop toEdge:ALEdgeBottom ofView:self.blueView]; //设置红色 view 的左边是蓝色 view 的右边 [self.redView autoPinEdge:ALEdgeLeft toEdge:ALEdgeRight ofView:self.blueView]; //设置红色 view 的宽度就是蓝色 view 的宽度 [self.redView autoMatchDimension:ALDimensionWidth toDimension:ALDimensionWidth ofView:self.blueView]; //设置红色 view 的高度为40.0 [self.redView autoSetDimension:ALDimensionHeight toSize:40.0];
// Yellow view is positioned 10 pt below the red view, extending across the screen with 20 pt insets from the edges, // and with a fixed height of 25 pt //设置黄色 veiw 的顶部距离红色 view 距离为10.0 [self.yellowView autoPinEdge:ALEdgeTop toEdge:ALEdgeBottom ofView:self.redView withOffset:10.0]; //设置黄色 view 的高度为25.0 [self.yellowView autoSetDimension:ALDimensionHeight toSize:25.0]; //设置黄色 view 距离父试图左边的距离为20.0 [self.yellowView autoPinEdgeToSuperviewEdge:ALEdgeLeft withInset:20.0]; //设置黄色 view 距离父试图右边的距离为20.0 [self.yellowView autoPinEdgeToSuperviewEdge:ALEdgeRight withInset:20.0];
// Green view is positioned 10 pt below the yellow view, aligned to the vertical axis of its superview, // with its height twice the height of the yellow view and its width fixed to 150 pt //设置绿色 view 的顶部距离黄色 view 的底部距离为10.0 [self.greenView autoPinEdge:ALEdgeTop toEdge:ALEdgeBottom ofView:self.yellowView withOffset:10.0]; //设置绿色 view 相对父试图竖向居中 [self.greenView autoAlignAxisToSuperviewAxis:ALAxisVertical]; //设置绿色的 view 的高度是黄色 view 高度的2.0倍 [self.greenView autoMatchDimension:ALDimensionHeight toDimension:ALDimensionHeight ofView:self.yellowView withMultiplier:2.0]; //设置绿色 view 的宽度为150.0 [self.greenView autoSetDimension:ALDimensionWidth toSize:150.0];
//设置已经添加过约束了 self.didSetupConstraints = YES; }
[super updateViewConstraints]; }
|
github 地址:https://github.com/smileyborg/PureLayout#
- PureLayout和Masonry比较
一年前那时我做iOS开发,为了自动布局适配多种屏幕,我一般使用Masonry,后来偶然地在一个视频教程中发现老师使用了UIView+Autolayout(现在作者改名为PureLayout)自动布局, ...
- iOS PureLayout使用
PureLayout是iOS Auto Layout的终端API,强大而简单.由UIView.NSArray和NSLayoutConstraint类别组成.PureLayout为大多数Auto Lay ...
- PureLayout,使用纯代码写AutoLayout
为iOS和OS X的自动布局最终的API -- 令人印象深刻的简单,非常强大. PureLayout延伸的UIView /NSView , NSArray,和NSLayoutConstraint与之后 ...
- PureLayout(轻量级自动布局)
直接整理用法 1.设置高度宽度 [view1 autoSetDimension:ALDimensionHeight toSize:70.0]; [view1 autoSetDimension:ALDi ...
- 使用Autolayout实现UITableView的Cell动态布局和高度动态改变
本文翻译自:stackoverflow 有人在stackoverflow上问了一个问题: 1 如何在UITableViewCell中使用Autolayout来实现Cell的内容和子视图自动计算行高,并 ...
- 【转】GitHub 排名前 100 的安卓、iOS项目简介
GitHub Android Libraries Top 100 简介 排名完全是根据 GitHub 搜索 Java 语言选择 (Best Match) 得到的结果, 然后过滤了跟 Android 不 ...
- GitHub iOS-Top 100 简介
GitHub排名前100的iOS第三方汇总简介,方便开发者选择适合的第三方框架. 项目名称 项目信息 1. AFNetworking 作者是 NSHipster 的博主, iOS 开发界的大神级人物, ...
- iOS 开源项目
在 Github 上 Star 太多了,有时候很难找到自己想要的开源库,所以在此记录下来.便于自己开发使用,也顺便分享给大家. 动画 awesome-ios-animation收集了iOS平台下比较主 ...
- Github上关于iOS的各种开源项目集合(强烈建议大家收藏,查看,总有一款你需要)
下拉刷新 EGOTableViewPullRefresh - 最早的下拉刷新控件. SVPullToRefresh - 下拉刷新控件. MJRefresh - 仅需一行代码就可以为UITableVie ...
随机推荐
- PHP控制连接打印机
一.需求 使用PHP控制连接打印机 现场实时连续打印动态数据 二.配置 php运行环境正确安装(Apache|Nginx + PHP) 下载与php版本对应的php_printer.dll扩展 扩展文 ...
- Let's Encrypt(开源SSL证书管理工具)
刚装上一个StartSSL 的证书没几天,却看到官方发出这样的通知: 无聊中看到了网上各种相关的扯淡: http://tieba.baidu.com/p/4801786642 http://www.t ...
- 使用NCoding归档进行存储数据时候报错
问题:Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[Demo1.UserInfo ...
- wampserver使用过程中遇到的问题及相关配置
wampserver集合了Apache+PHP+Mysql 下载地址:点这里 安装过程很方便,一直点下一步就行,中间会提示选择默认的浏览器及文件编辑器 起因: 使用过程中提示: In the http ...
- LeetCode 395. Longest Substring with At Least K Repeating Characters C#
Find the length of the longest substring T of a given string (consists of lowercase letters only) su ...
- 万恶的tileMap
先吐槽下.. 本来,我们准备用tileMap来做地图的,但发现一个问题,就是tileMap层中不能添加cc.Sprite,这导致了tileMap只适合做2D平面没有遮挡的游戏,并且主角是不能有效率的进 ...
- Linux常用命令汇总及使用方法(一)
最近开始学习Linux,但是因为原来没有接触过,所有现在先将Linux中常用的命令记录下来,方便自己后期使用. 1.登陆 通过secureCRT/xshell/ssh等软件远程登陆Linux (1)# ...
- zTree模糊查询人员姓名:getNodesByParamFuzzy
以前使用zTree,不知道有getNodesByParamFuzzy这个模糊查询的方法,所以用了比较笨的方法,比如:功能要求(模糊查询人员姓名),先获得用户输入的名称,然后到数据库或者缓存中去查找,然 ...
- Glide加载圆形图片
方案1:经过验证,可以完美实现 Glide.with(context).load(url).asBitmap().centerCrop().into(new BitmapImageViewTarge ...
- linux命令随记
1.当再Hadoop平台上跑代码的时候,可能会发现有些job是需要被kill重新跑的,此刻,如果一个一个手动去删除会很缓慢,此刻需要使用一个简单的脚本来实现自动全部删除操作: for i in `ha ...