iOS动画系列之三:Core Animation1. 介绍2. 支持的平台3. Core Animation 的继承结构图4. 常见属性和使用步骤

1. 介绍

  • Core Animation是一个非常强大的动画处理 API,使用它能做出非常绚丽的动画效果,而且往往是事半功倍,也就是说,使用少量的代码就可以实现非常强大的功能。
  • 苹果封装的 UIView 的 block 动画就是对核心动画的封装,使用起来更加简单。
  • 绝大多数情况下,使用 UIView 的 block 动画能够满足开发中的日常需求。
  • 一些很酷炫的动画,还是需要通过核心动画来完成的。

2. 支持的平台

  • Core Animation 同时支持 MAC OS 和 iOS 平台
  • Core Animation 是直接作用在 CALayer 的,并非 UIView。所以这个系列,咱们是从CALayer开始的。
  • Core Animation 的动画执行过程都是在后台操作的,不会阻塞主线程。

3. Core Animation 的继承结构图

  • 是所有动画对象的父类,负责控制动画的持续时间和速度、是个抽象类,不能直接使用,应该使用具体子类。需要注意的是CAAnimationCAPropertyAnimation 都是抽象类。
  • view是负责响应事件的,layer是负责显示的。

下面盗用了一张网络上的图片用来解释继承结构。

继承结构图

黄色的区块是常用的属性、方法或者需要遵守的协议,灰色的是名称。

其中CAAnimationGroup、CABasicAnimation、CAKeyFramkeAnimation咱们会在下次更新中写一些小例子。

4. 常见属性和使用步骤

4.1 使用步骤

通常分成三部完成: 1,创建核心动画对象; 2,设置动画属性; 3,添加到要作用的layer上。 就想把大象放进冰箱需要三步一样。哈哈~

4.2 常用属性

就是咱们上面图片中的小黄图显示的。

  • duration:持续时间,默认值是0.25秒
  • repeatCount:重复次数,无线循环可以设置HUGE_VALF或者CGFLOAT_MAX
  • repeatDuration:重复时间
  • removeOnCompletion: 默认为YES,代表动画执行完毕后就从图层上移除,图形会恢复到执行动画之前的状态。如果想要图层保持显示动画执行后的状态,那就设置为NO,同时设置fillMode为kCAFillModeForwards
  • fillMode:决定当前对象在非active时间段的行为
  • beginTime:可以用来设置动画延时执行,若想延迟2s,就设置为CACurrentMediaTIme() + 2
  • CACurrentMediaTIme():图层的当前时间
  • timingFunction:速度控制函数,控制动画运行节奏
  • delegate:动画代理

4.3 animationWithKeyPath中,常用的keyPath

属性名称

类型

作用

transform.rotation.x

CGFloat或float

绕X轴坐标旋转 角度

transform.rotation.y

CGFloat或float

绕Y轴坐标旋转 角度

transform.rotation.z

CGFloat或float

绕Z轴坐标旋转 角度

transform.rotation

CGFloat或float

作用与transform.tation.z一样

----

----

----

transform.scale

CGFloat

整个layer的比例

transform.scale.x

CGFloat

x轴坐标比例变化

transform.scale.y

CGFloat

y轴坐标比例变化

transform.scale.z

CGFloat

z轴坐标比例变化

----

----

----

transform.translation

CGMutablePathRef

整个layer的xyz轴都进行移动

transform.translation.x

CGMutablePathRef

横向移动

transform.translation.y

CGMutablePathRef

纵向移动

transform.translation.z

CGMutablePathRef

纵深移动

----

----

----

opacity

CGFloat

透明度,闪烁等动画用 。范围是0~1

backgroundColor

CGColor

背景颜色

cornerRadius

CGFloat

圆角

4.4 动画填充模式

  • kCAFillModeForwards:当动画结束后,layer会一直保持着动画最后的状态
  • kCAFillModeBackwards:在动画开始前,只需要将动画加入了一个layer,layer便立即进入动画的初始状态并等待动画开始
  • kCAFillModeBoth:这个其实就是上面两个合成,动画加入后,开始之前,layer便处于动画初始状态,动画结束后layer保持动画最后的状态
  • kCAFillModeRemoved:这个是默认值,也就是说当动画开始前和动画结束后,动画对layer都没有影响,动画结束后,layer会恢复到之前的状态
    keyArc.calculationMode = kCAAnimationPaced;

4.5 速度控制函数

  • kCAMediaTimingFunctionLinear(线性):匀速,给你一个相对静态的感觉
  • kCAMediaTimingFunctionEaseIn(渐进):动画缓慢进入,然后加速离开
  • kCAMediaTimingFunctionEaseOut(渐出):动画全速进入,然后减速的到达目的地
  • kCAMediaTimingFunctionEaseInEaseOut(渐进渐出):动画缓慢的进入,中间加速,然后减速的到达目的地。这个是默认的动画行为。
    keyArc.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];

是不是确实很枯燥?但是这条路本身就是大部分时间都很枯燥的啦~想逃也逃不掉。

这些属性和方法也的确记不住,所以这一篇其实也就是自己总结整理了一下。以后再用的时候,看看自己总结的就好了。省得每次用的时候还要再去看一下文档或者搜索了。

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏小蠢驴iOS专题

MBProgressHUD && SVProgressHUD 在实际开发中运用

1876
来自专栏自动化测试实战

HTML第五课——css盒子模型【2】

753
来自专栏tkokof 的技术,小趣及杂念

HGE系列之九 管中窥豹(精灵动画)

这次的HGE之旅,让我们来看看精灵及动画的实现,毕竟对于一款2D游戏引擎来说,恐怕精灵和动画不是最重要的,也可算是最重要之一了吧:)

792
来自专栏Flutter入门

Flutter开发实战分析-animation_demo瞎复写总结

以下代码基本参考于 flutter_gallery中的animation_demo示例。(可以结合本文看源码)

1633
来自专栏hbbliyong

WPF文字修饰——上、中、下划线与基线

       我们知道,文字的修饰包括:空心字、立体字、划线字、阴影字、加粗、倾斜等。这里只说划线字的修饰方式,按划线的位置,我们可将之分为:上划线、中划线、基...

2585
来自专栏糊一笑

移动端效果之Swiper

写在前面 最近在做移动端方面运用到了饿了么的vue前端组件库,因为不想单纯用组件而使用它,故想深入了解一下实现原理。后续将会继续研究一下其他的组件实现原理,有兴...

2948
来自专栏编程

CSS遮罩的过渡效果有趣的幻灯片

今天,我们想向您展示如何使用CSS Masks创建一个有趣而简单却引人注目的过渡效果。与裁剪一起,遮罩是定义可见性和与元素合成的另一种方式。在下面的教程中,我们...

1779
来自专栏向治洪

ios动画

在iOS开发中,动画是提高用户体验重要的环节之一。一个设计严谨、精细的动画效果能给用户耳目一新的效果,这对于app而言是非常重要的。 简介 iOS动画主要是指C...

1915
来自专栏五毛程序员

五毛的cocos2d-x学习笔记04-触摸点

1243
来自专栏Android知识点总结

开源计划之--Android绘图库--LogicCanvas

Painter采用单例模式 优化原型模式,各Shape采用深拷贝来解决构造较长、繁琐的情况 比较new 对象和拷贝的效率问题,拷贝一点。具体见文:来谈谈Ja...

703

扫码关注云+社区