前言
自从小tan上次出了一篇关于用Sketch制作自定义的APP下拉刷新GIF动画后,有不少小伙伴说期待出一篇关于Sketch制作GIF动画的详细教程。由于前段时间小tan都在忙于私人的家事,一直都没有及时的更新文章。正好趁着这举国同庆,作为技术宅的我们都在家里百无聊赖的时间里为大家走一波,献上大家期待已久的一篇文章。请叫我好先生!
使用sketch不仅能够制作静态的UI图,也能制作炫酷的GIF动图。这功劳还是要仰仗强大的AnimateMate插件。这边文章讲述了AnimateMate插件的安装和使用,并结合实践讲述了常用动画的基本使用,目的就是为了能让大家快速上手。下一遍文章将会讲述更高级的动画实现。
AnimateMate插件的安装
sketch有两种安装插件的方法,一种是传统的安装方式,即将插件解压后放到Plugins文件目录下,重启sketch即可。但是这种安装方法需要一个个的去找插件,非常麻烦。
我这里给大家介绍第二种安装插件的方法,就是先下载一个sketch插件管理工具sktch toolbox,通过sketch toolbox可以很方便的对插件进行安装和卸载,就像xcode下的Alcatraz一样。这里贴上sketch toolbox的下载地址。下载并安装后即可使用。打开sketch toolbox,然后搜索AimateMate插件,点击install即可安装,是不是很简单。
AnimateMate插件使用
1. 功能介绍
插件的功能还是比较简单明了的,AnimateMate总共提供了三种创建动画的方式,分别是Create Animateion(基本动画),Offect Animation(偏移动画),Random Animation(随机动画)。这里我们只讲解基本动画的使用,剩下两种会在接下来的进阶篇中进行讲解。
-
Create Animation:
创建基本动画,包括Postion,Size,Transform,Opacity等属性的动画。 -
Edit Animation:
编辑动画,对动画的属性值进行编辑。 -
Delete Animation:
删除动画,如果动画不需要了,可以通过该功能进行删除。 -
Retrun Keyframe:
返回某一刻的关键帧layer的状态,比如一个矩形第0个关键帧的横坐标为10,第10个关键帧的横坐标为100,那么我们返回这个矩形第0个关键帧的状态,此刻该矩形就会回到横坐标为10的位置。这样一个功能的好处就是方便查看各个关键帧的状态。 -
Reverse Keyframe:
反转一个范围内关键帧的动画。比如从0到10这10个关键帧中一个矩形的动画是从横坐标为10变为100。那么反转这个矩形0到10关键帧之间的动画之后,该矩形的动画就变成了从横坐标为100变为10。一般这个功能比较少用到。 -
Export Animation:
导出动画,选择对应的画板把动画导出。导出动画如果选择单个图层来导出,那么将只会导出这个图层的动画效果,其他图层的动画将被忽略,所以我们一般选择对应的画板来导出整个画板的动画。导出动画可以既可以导出png图片集合也可以导出gif动画。
2. 创建动画原理
AnimateMate创建基本动画只需要设置三个值,分别是Properties(属性值)、Keyframe Number(关键帧个数)、Easing Type(动画过度效果)。
-
Properties:
属性的变化。AnimateMate支持Position(x和y)、Size(Width和Height)、Trasform(Rotate)、Opacity等属性的动画。 -
Keyframe Number:
Keyframe Number即为关键帧的个数。关键帧的个数决定着动画执行的长短。 -
Easing Type:
Easing Type即为动画过度效果。Easing是jQuery自定义动画用来设置动画过度效果的一个参数,在jQuery Easing Plugin中提供了像linearEase、easeOutExpo、easeOutBounce等30多种效果。AnimateMate插件同样也提供了所有的效果供大家使用,大家可以点击这里去看每一种easing的演示效果。
AnimateMate实践演示
1. Position动画
1.1 position动画最终实现的效果
data:image/s3,"s3://crabby-images/3fc43/3fc439e09645565dedf7810ddf7fa3f56395b599" alt=""
1.2 首先创建一个200x200的画板,命名为position,然后画一个大小为140x140的圆,命名为out_layer,填充颜色为#F6F6F6;Borders大小为6,颜色为#F4F7F8。再画一个大小为26x26大小的圆,命名为in_layer,填充颜色为白色。
data:image/s3,"s3://crabby-images/428fb/428fb2441fd6a6ff6c506951c0ce1f2c5c9665ac" alt=""
1.3 选择in_layer,设置横坐标和纵坐标都为60,然后选择Plugins->AnimateMate->Create Animation
data:image/s3,"s3://crabby-images/a3a03/a3a033dbe94451e7e47b1e2a78e246cec721e0e1" alt=""
1.4 创建第0帧的动画。keyframe Number为0,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/7afda/7afda12b73b821117e6856b2f244161197c5a0a3" alt=""
1.5 选择in_layer,设置横坐标为114,纵坐标都为60,然后选择Plugins->AnimateMate->Create Animation
data:image/s3,"s3://crabby-images/23907/23907cd799ef47e0e3b5ebba9f7f6e67e22db972" alt=""
1.6 创建第10帧的动画(我总共设置了40帧动画,每一次转折为10个帧,如果你觉得10个帧运动太快,可以添加关键帧的个数)。keyframe Number为10,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/cec06/cec06578b5b8837755d79dde4032d12bd1243f7f" alt=""
1.7 选择in_layer,设置横坐标和纵坐标都为114,然后选择Plugins->AnimateMate->Create Animation
data:image/s3,"s3://crabby-images/881a2/881a20fcc6a768d16fbab320ae2aeba9996233d4" alt=""
1.8 创建第20帧的动画。keyframe Number为20,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/a0e47/a0e47315ea822436d4a5175f62b5aa50265d59b3" alt=""
1.9 选择in_layer,设置横坐标为60,纵坐标为114,然后选择Plugins->AnimateMate->Create Animation
data:image/s3,"s3://crabby-images/ea54d/ea54d0b16f8424f59ae05379555d9ca474c7a27e" alt=""
1.10 创建第30帧的动画。keyframe Number为30,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/40ce2/40ce2996c9f01009a4a69e568f81267c0aa952f5" alt=""
1.11 选择in_layer,设置横坐标和纵坐标都为60,然后选择Plugins->AnimateMate->Create Animation
data:image/s3,"s3://crabby-images/8b71a/8b71a325df9efedfa766ee0a65581421fa4b7750" alt=""
1.12 创建第40帧的动画。keyframe Number为40,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/88d1f/88d1f5804a6aa281b22e12f1b5ad7192a3f64454" alt=""
1.13 选中position画板,选择Plugins->AnimateMate->Export Animation导出动画即可。
2. Size动画
2.1 size动画最终实现的效果
data:image/s3,"s3://crabby-images/7c2bf/7c2bf0c90c224dc3d67d18ad837314b32cbbb868" alt=""
2.2 copy一份position画板,并命名为size。
data:image/s3,"s3://crabby-images/038ec/038ec586d1abc712bb2d786b668c03f486127263" alt=""
2.3 选中in_layer,选择Plugins->AnimateMate->Delete Animation删除in_layer上的动画效果。
data:image/s3,"s3://crabby-images/55ac4/55ac453f076a1035617ea55c7e014f1a667f9065" alt=""
2.4 选择in_layer,设置in_layer的大小为26x26。选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/a846c/a846c40b24b8012c948b173de0159f02a08905da" alt=""
2.5 创建第0帧的动画。keyframe Number为0,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/63925/63925d753552077e28c5844c76e9c5e0662e5d6b" alt=""
2.6 选择in_layer,设置in_layer的大小为75x75。选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/9badc/9badc46b2da6c046af12fa69ffc60a125ae7b20f" alt=""
2.7 创建第30帧的动画。keyframe Number为30,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/53416/53416cf176444b49564d56d117d1e48468d1f795" alt=""
2.8 选中size画板,选择Plugins->AnimateMate->Export Animation导出动画即可。
3. Transform动画
3.1 transform动画最终实现效果
data:image/s3,"s3://crabby-images/306cc/306cca65ef0cd8b77164c32f6a77382f6d50e502" alt=""
3.2 copy一份position画板,命名为transform。
data:image/s3,"s3://crabby-images/aa46a/aa46a90567e66c233c198a12025f5a80ebbb432f" alt=""
3.3 选中in_layer和out_layer建成组Group。
data:image/s3,"s3://crabby-images/73ce9/73ce977cec13f84870f09530f059754c2216497e" alt=""
3.4 选中Group,设置Rorate为0°,选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/1d4ef/1d4ef5042d4da14b7e5aa14926f8e32dddd24e13" alt=""
3.5 创建第0帧的动画。keyframe Number为0,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/3a779/3a7798333198f124b32e4333a871b7546fb318e4" alt=""
3.6 选中Group,设置Rorate为359°,选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/528eb/528ebc936867c63b1b64c5605cddf69407074535" alt=""
3.7 创建第40帧的动画。keyframe Number为40,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/8fe9e/8fe9e1ce479a53edadf8b8a92a083da77bc7d9b2" alt=""
3.8 选中transform画板,选择Plugins->AnimateMate->Export Animation导出动画即可。
4. Opacity动画
4.1 opacity动画最终实现效果
data:image/s3,"s3://crabby-images/bf584/bf584ef16f2b8b8aeb43559ed380a2d9e4f8c5be" alt=""
4.2 copy一份size画板,命名为opacity。
data:image/s3,"s3://crabby-images/e91f8/e91f8d91d14419ef098f9fe778b76714a51a462e" alt=""
4.3 选中in_layer,设置其Opacity为100%,选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/1215b/1215b2a7d7af1dc21ba865272619a14bf151d886" alt=""
4.4 创建第0帧的动画。keyframe Number为0,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/3b1d7/3b1d7fb99e9ba6260c93e87670697dcfeb935de5" alt=""
4.5 选中in_layer,设置其Opacity为20%,选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/fb7e4/fb7e47ecc48be455c1f3d7657b6e333e1cedf8cd" alt=""
4.6 创建第30帧的动画。keyframe Number为30,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/f03f4/f03f49544f14ff242d9113f07992a4e732bd1ddb" alt=""
4.7 选中opacity画板,选择Plugins->AnimateMate->Export Animation导出动画即可。
5. 组合动画
以上所有的动画中都是单个图层在进行动画,那么问题来了,当我们要设置多个图层一起进行动画该如何处理。
有两种情况,一种是多个图层之间做的动画是相同的;一种是多个图层之间做的动画是不同的。
当多个图层所做的动画是相同的时候,那么我们在设置动画的时候可以同时选中多个图层。当多个图层所做的动画不相同时,比如我要让两个圆一个做放大动画一个做缩小动画,那么我们就可以分别对这两个圆设置动画即可。
5.1 group动画的最终实现效果
data:image/s3,"s3://crabby-images/7a948/7a948e189e12a95ae121bb3ac4095fbd2173c1b5" alt=""
5.2 copy一份position画板,命名为group。将in_layer放到中间位置,设置其填充颜色为红色。
data:image/s3,"s3://crabby-images/003ae/003ae7c2b39fb7205e2911d5df24e29a5546e6bc" alt=""
5.3 选择in_layer,设置其大小为26x26,选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/88a80/88a802a590e6a39965847f019faeea5a1ac1826b" alt=""
5.4 创建in_layer的第0帧的动画。keyframe Number为0,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/1aa4d/1aa4d59f93b4e61efd788056d6af125312f950dc" alt=""
5.5 选择in_layer,设置其大小为70x70,选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/2aea6/2aea624b0d9decfec64b26b275057ea606a1d62e" alt=""
5.6 创建in_layer的第20帧的动画。keyframe Number为20,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/e2692/e26924d908fcea155cbd2b992c44ae8ebd9e5f6f" alt=""
5.7 选择out_layer,设置其大小为140x140,选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/f7635/f76352caa495402529d1b3151067a0c7abb41e42" alt=""
5.8 创建out_layer的第0帧的动画。keyframe Number为0,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/5665d/5665d5f71b7b2ee3f37d3ca6d6f7dfc809d4d5d7" alt=""
5.9 选择out_layer,设置其大小为78x78,选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/2f061/2f061953c5d5dbdc09bff9bbd4298283e9827dff" alt=""
5.10 创建out_layer的第20帧的动画。keyframe Number为20,Easing Type保持默认值linearEase。
data:image/s3,"s3://crabby-images/6b306/6b3066150b81f4b8d549e803620560954dd4e551" alt=""
5.11 选中group画板,选择Plugins->AnimateMate->Export Animation导出动画即可。
6. Easing Type的使用
给我们的动画设置合理的easing type可以让我们的动画更富有新意,更接近真实。比如我们要制作一个弹簧的动画,那么单单只靠线性过度效果是无法实现的,借助easing type中
的easeOutElastic
过度效果则可以轻松实现。
6.1 easing动画的最终实现效果
data:image/s3,"s3://crabby-images/37f46/37f4637d3e716bc0b5078fe5a2bdf31a8afc02f0" alt=""
6.2 copy一份position画板,命名为easing。将in_layer放到中间位置。
data:image/s3,"s3://crabby-images/b434a/b434a8a2847c2ca84be3bbfd2627090b4a3816b3" alt=""
6.3 选择in_layer,设置其大小为26x26,选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/d0f4c/d0f4cca0e4b0ac7858259abab4cb5019ce1beb3e" alt=""
6.4 创建第0帧的动画。keyframe Number为0,Easing Type设置为easeOutElastic。
data:image/s3,"s3://crabby-images/d9fc7/d9fc7a37086d5c0f1d614e6be8aa0cffada7d891" alt=""
6.5 选择in_layer,设置其大小为75x75,选择Plugins->AnimateMate->Create Animation。
data:image/s3,"s3://crabby-images/5fe3d/5fe3daeda263aee2258801a2cd9d95425e0d4647" alt=""
6.6 创建第30帧的动画。keyframe Number为30,Easing Type这里可以随意设置。
data:image/s3,"s3://crabby-images/af108/af108bfc31d347ff27f2a9284fe624a7b2c0a173" alt=""
6.7 选中easing画板,选择Plugins->AnimateMate->Export Animation导出动画即可。
总结
本篇文章讲述了AnimateMate插件制作GIF动画的原理和功能介绍,并结合实际讲述了常见属性动画的实现和Easing Type的使用,目的是让大家能够快速上手。记住一点,动画的制作方法是很简单的,缺乏的还是想象力。不过AnimateMate制作动画也是有其局限性的,对于非线性动画AnimateMate还是无能为力的。下一篇文章将会讲述一些更高级的动画实现以及在使用AnimateMate制作动画过程中可能会遇到的一些问题。
这里我把文中所有的 sketch源文件 也提供出来,供大家参考。有什么问题可以在评论区贴出来,也可以微博私信我。祝大家节日愉快。
网友评论
我导出动画都是很模糊的,这是为什么