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 条评论
登录 后参与评论

相关文章

来自专栏企鹅号快讯

前端学习自学笔记:day10

今天是第十天的笔记,主要是HTML和CSS的,希望大家支持~ ? 在此之前先为大家显示下前端工程师的路线图: 第十天的笔记:HTML AND CSS: 响应式设...

2027
来自专栏守候书阁

canvas入门实战--邀请卡生成与下载

写了很多的javascript和css3的文章,是时候写一篇canvas的了。canvas是html5提供的一个新的功能!至于作用,就是一个画布。然后画笔就是j...

1183
来自专栏Flutter入门到实战

Android适配全面总结(一)----屏幕适配

版权声明:本文为博主原创文章(部分引用他人博文,已加上引用说明),未经博主允许不得转载。https://www.jianshu.com/p/7aa34434ad...

2054
来自专栏编程

java基础知识,font属性css写法,代码详解!

CSS属性值 字体与文本 网页设计中有很多的文字要去处理,标题、段落、文章、列表以及表单中的文本。这一篇章我们讨论一下HTML中的字体与文本 字体 首先要有一...

2018
来自专栏韦弦的偶尔分享

微信小程序分享图片的简易canvas工具类

如有需要请自取:GitHub微信小程序保存图片分享的 canvas 简易自用工具类

2262
来自专栏cnblogs

Bootstrap源码分析之nav、collapse

导航分析(nav): 源码文件: _navs.scss:导航模块 Mixins/_nav-divider.scss:分隔线 Mixins/_nav-vertic...

3218
来自专栏儿童编程

【动画原理续篇】Python Turtle动画不连续难题解决方案

前一段时间发过一篇小文“心中有剑,落叶飞花,皆是兵器”-Python动画原理揭示及案例,在文末提出了一个疑问:画图的速度比较慢。即使speed()调到最大(sp...

4853
来自专栏娱乐心理测试

轻松生成小程序分享海报

小程序分享到朋友圈只能使用小程序码海报来实现,生成小程序码的方式有两种,一种是使用后端方式,一种是使用小程序自带的canvas生成;后端的方式开发难度大,由于生...

5783
来自专栏郭诗雅的专栏

css+js实现左右滑动卡片组件

最近的一个活动页面需要做一个可以左右滑动的抽签效果,故通过用css的transform属性和js结合来模拟可以无限滚动的效果。

1.7K9
来自专栏Coding01

推荐一款快速生成海报的微信小插件

现在很多小程序都有生成海报,分享海报的功能。我们自己的几个小程序 (如:爸妈搜商城、爸妈搜云课堂、幼师大学、跟着外教学英语等) 也都有生成海报的功能。因此技术团...

5553

扫码关注云+社区

领取腾讯云代金券