如何用ae表达式快速实现延迟动画

2016-6-12 09:44

如何实现延迟动画 Hi,这次AE技巧分享的关键词是延迟。实现延迟方法各种各样,最简单粗暴的办法就是通过错帧来实现延迟效果,还有刚刚看了@十分钟设计的《制作延迟动画》,也是一种不错的办法。 理论上都可以达 ...

如何实现延迟动画

Hi,这次AE技巧分享的关键词是“延迟”。实现延迟方法各种各样,最简单粗暴的办法就是通过错帧来实现延迟效果,还有刚刚看了@十分钟设计的《制作延迟动画》,也是一种不错的办法。

理论上都可以达到我们想要的效果,而在这里我想分享另一种我觉得更高效,更“科学”的办法。

先用一个小案例来帮助我说明,如下图,如果要蓝色小球跟着紫色小球运动,并带有一定的延迟,你会怎么做呢?

如何用AE表达式快速实现延迟动画

利用错帧的办法来实现,虽然简易,但是最大的问题是,到了后面动画越来越复杂,只要你每次修改就相当于每次都重头做一遍,非常不科学,也容易出问题,如下图。

如何用AE表达式快速实现延迟动画

如何用AE表达式快速实现延迟动画


通过表达式语句实现延迟动画

首先我们先来认识一下这个语句“valueAtTime(t)”。下面是官方说明文档给出的定义:

返回类型:数值或数组。参数类型:t 是数值。返回属性在指定时间(以秒为单位)的值。

不难理解,其作用就是返回某一时刻的值。那么我们应该怎么运用他呢?

我们可以在表达式库中随时调用它:

如何用AE表达式快速实现延迟动画

先举一个栗子:如两个小球动画,先设置好“ball3”的位移多关键帧,然后分别点开“ball3”和“ball1”的位置属性,如下图:

如何用AE表达式快速实现延迟动画

然后把“ball1”都位置属性链接到“ball3”到位置属性上(此步的具体操作可以参照我上一篇Ae文章),图下图:

如何用AE表达式快速实现延迟动画

做好位置属性的链接后,最关键的一步,在表达式窗口“thisComp.layer("ball3").transform.position”后面加上“.valueAtTime(time-0.04)”(注意有他们之间有个小点点“.”,可以简单把这个点理解为“的”)。此时如下图:

 

如何用AE表达式快速实现延迟动画

此时“ball1”的完整表达式应该是这样的“thisComp.layer("ball3").transform.position.valueAtTime(time-0.04)”,用大白话翻译一下,应该是这样的:“这个合成的’ball3’图层的此刻延迟0.04秒的返回值”,简单一句话,“每次返回ball3延迟了0.04秒的值出来”。

效果如下图:

如何用AE表达式快速实现延迟动画

以同样的方法,再添加几个球并设置不同的延迟时间的效果如下:

如何用AE表达式快速实现延迟动画

所有蓝色小球都是链接紫色小球,完全重复紫色小球的动画,因此你可以随时随地的改变紫色小球的动画;想改变延迟时间,只需valueAtTime(time-x),x是你想要的延迟的时间,单位为秒。

这样就可以一劳永逸啦!如下图:

 

如何用AE表达式快速实现延迟动画

利用“空对象”达到随心所欲的链接

 

像上一篇文章提到的那样,直接的属性对属性链接,子图层会被“完全”到父图层,就想上面的演示,所有小球最终都会重叠在一起。

所有我还是利用一个“空对象”,把它的位置属性链接到目标图层的位置属性,之后再把要跟随的图层做个图层子父级链接到空物体上。如下图:

 

如何用AE表达式快速实现延迟动画

如何用AE表达式快速实现延迟动画

当然只要你理解了“valueAtTime”,你还可以把它用在其他属性上面,如缩放,透明等等。如下图:

如何用AE表达式快速实现延迟动画

就是这么简单实用,即学即用的延迟技巧,你学会了吗?

这些都是平时工作琢磨总结的一些小技巧,如果大家觉得有所帮助,那就点个赞吧!让我有动力分享更多好玩实用的内容,还有很多关于Ae表达式的干货哦!谢谢观看!

29教程网提示您本教程已学习完毕!

关注我们新浪官方认证微博,随时随地,想学就能学!新浪认证微博:http://weibo.com/u/3928837770
关闭

站长推荐 上一条 /1 下一条



Powered by Discuz! X3.4© 2001-2013 Comsenz Inc.( 桂ICP备12007517号-1 )