首页>文档>After Effects帮助文档>9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效

今天来给大家分享 9 个简单又实用的 AE 表达式,随机抖动、无限旋转、双向循环…每个表达式拿来就能用,个个都能让动效制作效率翻倍!(文内附详细的使用方法)

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-1

一、什么是表达式

接触过 AE 的同学肯定都听说过「表达式」这个名词,它是一段基于 JavaScript 的代码,听起来是不是很不明觉历?对于编程小白来讲,看起来好像也不算太友好,不过没关系,只要我们会用它就可以,就好像我们需要冰箱制冷,但并不需要了解其原理一样。

在一些情况下,表达式能够帮助我们快速实现效果,减少了反复 k 关键帧的繁琐工作,因此,可以极大地提高作图效率。接下来我们一起看看如何使用表达式。

二、如何使用表达式

添加表达式非常的简单,先找到需要添加「表达式」的属性,按住「Alt/Option」键点击左边的「码表」,这时候,属性右边的数字会变成红色。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-2

然后,在时间轴面板里,输入「表达式」内容,就可以了。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-3

而在属性旁边的小箭头上,也有一些自带的菜单,可以直接使用。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-4

三、常用的9个表达式

  1. 随机抖动
  1. wiggle(2,30)

这个表达式可以轻松实现抖动效果,例如下图这个小球,我们给它的位置属性添加上抖动表达式,设置为 2,y 设置为30:

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-5

这样,小球就会缓慢的运动起来:

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-6

如果把小球换成小蜜蜂,并且调整随机抖动的范围,:

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-7

又或者,把表达式添加在「旋转」属性上,再把小蜜蜂替换成每周一早晨恨不得砸坏的那个闹钟……有没有感受到迎面扑来的窒息感?

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-8

⬆️ 图作者:优设视觉设计实战营-22-明轩
  1. 万能弹性
  1. freq = 3;
  2. decay = 5;
  3. n = 0;
  4. if (numKeys > 0){
  5. n = nearestKey(time).index;
  6. if (key(n).time > time) n--;
  7. }
  8. if (n > 0){
  9. t = time - key(n).time;
  10. amp = velocityAtTime(key(n).time - .001);
  11. w = freq*Math.PI*2;
  12. value + amp*(Math.sin(t*w)/Math.exp(decay*t)/w);
  13. }else
  14. value

弹性表达式看起来很复杂,不过没关系,我们只要会用它就可以。

先添加「缩放」关键帧,给小球制作一个简单的放大效果。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-9

然后,给关键帧添加上缓动,并且在速度曲线面板,把结尾处的速度曲线拉高。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-10

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-11

接着,复制弹性表达式,粘贴进小球的「缩放」属性里。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-12

小球在放大的时候就会有弹跳效果了。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-13

而我们把小球替换成花瓣,加上茎干跟叶子,再添加上「修剪路径」和「序列图层」,就有了一朵小花的生长动效了。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-14

  1. 循环运动
  1. loopOut(type = "cycle", numKeyframes = 0)

这个表达式可以让物体循环运动起来,还是这个小球,我们先做一个左右移动的效果:

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-15

然后,给位置属性添加上循环表达式:

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-16

这样,小球就会在工作区的范围内,反复左右横跳了。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-17

把小球换大鹅,静谧温馨的场景总是让人很心动:

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-18

⬆️ 图作者:优设视觉设计实战营15期-76-橙子
  1. 挤压拉伸
  1. spd =20;maxDev =10;
  2. decay = 1;
  3. t = time - inPoint;
  4. offset = maxDev*Math.sin(t*spd)/Math.exp(t*decay);
  5. scaleX = scale[0] + offset;scaleY = scale[1] - offset;
  6. [scaleX,scaleY]

可爱的小脸总让人想捏一捏,可爱的小球也是一样。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-19

又又又还是这个小球,不用 k 关键帧,只要给它的「缩放」属性复制上关键帧,就可以了。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-20

  1. 小球回弹
  1. e =0.7;//弹力
  2. g =1000;//重力
  3. nMax = 9;//最大弹跳次数
  4. n = 0;
  5. if (numKeys > 0){
  6. n = nearestKey(time).index;
  7. if (key(n).time > time) n--;
  8. }
  9. if (n > 0){
  10. t = time - key(n).time;
  11. v = -velocityAtTime(key(n).time - .001)*e;
  12. vl = length(v);
  13. if (value instanceof Array){
  14. vu = (vl > 0) ? normalize(v) : [0,0,0];
  15. }else{
  16. vu = (v < 0) ? -1 : 1;
  17. }
  18. tCur = 0;
  19. segDur = 2*vl/g;
  20. tNext = segDur;
  21. nb = 1; // number of bounces
  22. while (tNext < t && nb <= nMax){
  23. vl *= e;
  24. segDur *= e;
  25. tCur = tNext;
  26. tNext += segDur;
  27. nb++
  28. }
  29. if(nb <= nMax){
  30. delta = t - tCur;
  31. value + vu*delta*(vl - g*delta/2);
  32. }else{
  33. value
  34. }
  35. }else
  36. value

看起来好复杂的一个表达式,没关系,只要键盘上有 c 和 v 就可以了。

还是这个小球,先让它做一个落地的动效:

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-21

然后,给位置属性添加上表达式。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-22

这样,它就落地回弹了。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-23

表达式中的弹力和重力都是可以根据需要进行调整的。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-24

⬆️ 图作者:优设视觉设计实战营8期-102-聪明岛
  1. 无限旋转
  1. time*360

数值=每秒旋转多少度

360,也就是每秒旋转一圈,数值也可以根据自己需求进行调整。

还还还是这个小球,哦不,它方了,给它的旋转属性加上表达式吧。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-25

看,它在没有 k 关键帧的情况下旋转起来了。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-26

把小球替换成大风车,有一点点可爱。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-27

⬆️ 图作者:优设视觉设计实战营-40-町

这个表达式还可以用在「分形杂色」里的「演化」属性上:

(关于这个效果的制作,一两句话说不清楚,以后我会专门出教程讲解的,感兴趣的小伙伴请留下你们的 1 )

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-28

这样可以制作水波倒影:

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-29

⬆️ 图作者:优设视觉设计实战营-111-德拉科
  1. 路径循环

前面介绍的这个循环运动,它不肯作用在路径上,咋办!

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-30

那就……给路径换个表达式吧。

  1. valueAtTime(time%key(numKeys).time)

这个就可以!

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-31

同样的方法,给小草调整路径运动,可以制作出风吹摆动的效果,解放双手就是说,再也不用反复 k 帧了!

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-32

⬆️ 图作者:优设视觉设计实战营-152-困困
  1. 双向循环
  1. loopOut(type = "pingPong", numKeyframes = 0);

谁会不喜欢双向奔赴呢?小球也是,先给它制作一个单方面的移动:

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-33

然后,在「位置」属性里粘贴表达式,这样,它就来回循环了!好一场双向奔赴的爱情(bushi

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-34

  1. 随机循环

又又又循环?对,它又来了。

前面我们讲过一个随机抖动,效果是挺好,但……它不能循环起来,如果让小蜜蜂飞出画面,闹钟停下来,都还好说,但是想让它一直在画面中,就很麻烦了。

这时候,就要祭出超实用的「随机循环」表达式了!(哆啦A梦手)

  1. freq = 3; // 频率
  2. amp = 100; // 幅度
  3. loopTime =3; // 循环时间,单位为秒
  4. t = time % loopTime;
  5. wiggle1 = wiggle(freq, amp, 1, 0.5, t);
  6. wiggle2 = wiggle(freq, amp, 1, 0.5, t - loopTime);
  7. linear(t, 0, loopTime, wiggle1, wiggle2)

只要给小球的「位置」属性粘贴上这个表达式,就可以让它在有限的时间里随机循环抖动下去了。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-35

频率、幅度、循环时间都是可以修改的。用它来做萤火虫,也是挺不错的,谁不喜欢这样梦幻的夜晚呢。

9 个拿来就能用的 AE 表达式!一分钟搞定高难度动效-36

0 条回复 A文章作者 M管理员
黑夜无论怎样悠长,白昼总会到来
欢迎您,新朋友,感谢参与互动!
    暂无讨论,说说你的看法吧
个人中心
今日签到
私信列表
搜索