动画是 iOS 中非常重要的一部分,它给用户展现出应用灵气的一面。

在动画块中修改 Frame

在原来使用 frame 布局时,在 UIView 的 animate block 中对 view 的布局进行修改,动画即可生效。

[UIView animte ... {
view.frame = ...
}];
复制代码

AutoLayout 没有 Frame 时如何做动画

在 AutoLayout 中,view 的布局等属性都是由约束 constraint 决定,Apple 也不建议在使用 AutoLayout 直接修改 view 的 frame。

在介绍之前,先看一下 UIView 的 layoutIfNeeded 方法:

/**
Allows you to perform layout before the drawing cycle happens.
-layoutIfNeeded forces layout early
*/
- (void)layoutIfNeeded; /**
Lays out the subviews immediately.
Use this method to force the layout of subviews before drawing.
Using the view that receives the message as the root view,
this method lays out the view subtree starting at the root.
*/
复制代码

换而言之,向 view 发送该方法,将 view 作为 root view,开始向下重新布局(即计算 subView 的 frame)。

可以想象一下,在计算布局的过程中,subView 的 frame 发生了变化。

而我们之前使用动画时,是将这些变化的代码放在 UIView Animation Block 中。
所以,在 AutoLayout 中使用 Animation 的正确姿势可以是:

UIView *animationView = [[UIView alloc] init];
// 给 animationView 设置约束
[self.view addSubview:animationView]; [UIView animateWithDuration:10.0f delay:0 options:UIViewAnimationOptionCurveLinear | UIViewAnimationOptionRepeat animations:^{
// 修改 animationView 的宽度约束
animationView.widthConstrint.constant = 100.0f;
// 注意这里要调用 animationView 父视图的 layoutIfNeeded 方法
[self.view layoutIfNeeded];
} completion:^(BOOL finished) { }];
复制代码

[self.view layoutIfNeeded]; 这行代码,其实就是让系统帮我们去做 frame 相关的修改。

约束还有约束

现在,我们学会了在 Animation Block 中修改约束来达到动画的目的。
但是这需要我们持有对该 constraint 的引用才行。如果页面中有大量的动画需求,那么就会出现如下例子:

@interface SSAnchorRankView ()
@property (nonatomic, strong) NSLayoutConstraint *labelWidthCons;
@property (nonatomic, strong) NSLayoutConstraint *labelHeightCons;
@property (nonatomic, strong) NSLayoutConstraint *labelTopCons; ... @end
复制代码

也就是说,实现动画时需要改变的约束,都需要在类中增加属性来引用它。

虽然可以将这些属性单独放在一个 category 中,但是仍然避免不了要大量引用约束的尴尬。

复杂的动画会导致什么

复杂的动画,会让你在设计约束时,考虑的内容太多,也容易出现一些约束的 Bug。

优雅的姿势

其实在布局的过程中,是可以将界面的显示部分做一个抽象的划分。例如在编写一个音乐播放器的界面时,将相似或者耦合的元素包装起来,作为一块单独的内容区域:

  • 歌曲专辑图片、歌曲名、歌手名
  • 歌词、歌词控制
  • 播放暂停、下一首、上一首
  • 喜欢歌曲、不喜欢歌曲

这样,将元素分别装在不同的 container view 中,抽象起来,在之后不管是做约束,还是做动画,都会更加方便。

Masonry 呢?

Masonry 的 make 方法会生成约束,其实,它本身是有返回值,类型为 MASConstraint *,所以也是可以持有 Masonry 生成的约束并改变其值。

[label mas_remakeConstraints:^(MASConstraintMaker *make) {
self.labelWidthCons = make.width.equalTo(self.view).offset(200);
}
复制代码

进阶

Constraint 本身可以修改的属性并不多,有时候需要转换一种思路,比如 install 两条约束,在不同的 case 下激活其中一条即可。

Constraint 本身有很多方法还可以继续研究,当然这个就是后话了。

转载于:https://juejin.im/post/5a30f248f265da43310dd008

在 AutoLayout 和 Masonry 中使用动画的更多相关文章

  1. iOS Core Animation具体解释(四)AutoLayout中的动画

    原创blog.转载请注明出处 blog.csdn.net/hello_hwc 欢迎关注我的iOS SDK具体解释专栏 http://blog.csdn.net/column/details/huang ...

  2. AutoLayout框架Masonry使用心得

    AutoLayout框架Masonry使用心得 字数1769 阅读1481 评论1 喜欢17 我们组分享会上分享了页面布局的一些写法,中途提到了AutoLayout,会后我决定将很久前挖的一个坑给填起 ...

  3. iOS开发通过代码方式使用AutoLayout (NSLayoutConstraint + Masonry)

    iOS开发通过代码方式使用AutoLayout (NSLayoutConstraint + Masonry) 随着iPhone6/6+设备的上市,如何让手头上的APP适配多种机型多种屏幕尺寸变得尤为迫 ...

  4. 代码方式使用AutoLayout (NSLayoutConstraint + Masonry)

    随着iPhone6/6+设备的上市,如何让手头上的APP适配多种机型多种屏幕尺寸变得尤为迫切和必要.(包括:iPhone4/4s,iPhone5/5s,iPhone6/6s,iPhone 6p/6ps ...

  5. iOS — Autolayout之Masonry解读

    前言 1 MagicNumber -> autoresizingMask -> autolayout 以上是纯手写代码所经历的关于页面布局的三个时期 在iphone1-iphone3gs时 ...

  6. CSS3中的动画效果记录

    今天要记录的是CSS3中的三种属性transform.transition以及animation,这三个属性大大提升了css处理动画的能力. 一.Transform 变形 CSS中transform ...

  7. Android中矢量动画

    Android中矢量动画 Android中用<path> 标签来创建SVG,就好比控制着一支画笔,从一点到一点,动一条线. <path> 标签 支持一下属性 M = (Mx, ...

  8. 初识android中的动画

    动画效果可以大大提高界面的交互效果,因此,动画在移动开发中的应用场景较为普遍.掌握基本的动画效果在成熟的软件开发中不可或缺.除此之外,用户对于动画的接受程度远高于文字和图片,利用动画效果可以加深用户对 ...

  9. CSS3中的动画功能(一)

    css3中的动画功能分为transitions功能和animations功能,这两种功能都可以通过改变css属性值来产生动画效果.今天带大家一起来看看css3动画功能中的transitions的用法. ...

随机推荐

  1. Shell:Day07.笔记

    函数:1.函数介绍function 为了避免代码重复使用,我们一般通过函数编写代码块,而这一个代码块用来实现某种功能. 且,这个功能在后面的代码中,会重复调用:  def 2.函数的语法格式 函数的写 ...

  2. Navicat安装教程

    Navicat安装教程 1.下载: 链接:https://pan.baidu.com/s/1uLlstPYrsjaNhZqVu9aFfQ 提取码:393r 2.下载完成之后如图所示: 首先安装第二个, ...

  3. Vulnhub webdeveloper靶机渗透

    信息搜集 nmap -sP 192.168.146.0/24 #主机发现 nmap -A 192.168.146.148 #综合扫描 访问一下发现是wordpress,wp直接上wpscan wpsc ...

  4. django发送邮件的坑

    django发送邮件的坑 配置django发邮件的时候本地发送时好好的,但是放到阿里云的服务器上却不能发送. 经过一系列的排查后终于发现是阿里云把25端口给封了. 后来改用smtps的方式发送,更改d ...

  5. Git常用指令整理(Git Cheat Sheet)

    [Toc] 1. 创建 复制一个已创建的仓库:git clone ssh://user@domain.com/repo.git 创建一个新的本地仓库:git init 2. 本地修改 显示工作路径下已 ...

  6. canvas 实现光线沿不规则路径运动

    canvas 实现光线沿不规则路径运动 此文章为原创,请勿转载 1.svg实现 2.canvas实现 3.坑点 svg让动画沿着不规则路径运动 查阅svg文档后发现,svg动画运动有两种实现方式,且都 ...

  7. Go语言 命令行解析(一)

    命令行启动服务的方式,在后端使用非常广泛,如果有写过C语言的同学相信不难理解这一点!在C语言中,我们可以根据argc和argv来获取和解析命令行的参数,从而通过不同的参数调取不同的方法,同时也可以用U ...

  8. pgsql中的事务隔离

    pgsql中的事务隔离级别 前言 事物隔离级别 在各个级别上被禁止出现的现象是 脏读 不可重复读 幻读 序列化异常 读已提交隔离级别 可重复读隔离级别 可序列化隔离级别 摘录 pgsql中的事务隔离级 ...

  9. Pytest系列(23)- allure打标记,@allure.feature()、@allure.story()、@allure.severity()的详细使用

    如果你还想从头学起Pytest,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1690628.html 前言 前面几篇文章主要介绍了all ...

  10. 挑战全网最幽默的Vuex系列教程:第二讲 Vuex旗下的State和Getter

    先说两句 上一讲 「Vuex 到底是个什么鬼」,已经完美诠释了 Vuex 的牛逼技能之所在(纯属自嗨).如果把 Vuex 比喻成农药里面的刘备,那就相当于你现在已经知道了刘备他是一个会打枪的力量型英雄 ...