资讯专栏INFORMATION COLUMN

使用 GreenSock 来制作 SVG 动画

everfly / 313人阅读

摘要:在制作动画方面也非常强悍,并且还专门提供了用于加强动画制作的相关插件,比如。一个有趣的的动画效果就完成了,代码地址使用配合来制作动画效果如此简单。原文地址,根据自己理解整理了下这个教程,主要是来学习下使用来制作动画效果的思路和方法。

这是我的一个关于SVG的应用的技术分享网站svgtrick.com,会同步一些文章到这里来,更多关于SVG技术应用可以去网站看看。

最近从Dribbble shot 看到@thorstenbeeck发布的一个设计效果图得到灵感。根据这个设计,使用GreenSock这个动画平台实现了一个SVG的动画效果,下面就来聊聊我是怎么实现这个动画效果的。

GreenSock

GreenSock是一个无需多介绍了,是一个专门用来开发动效的平台,并且提供了javascript版本。更多关于GreenSock的一个入门介绍可以去我整理的简明教程看看,这里就不再介绍它的基本知识。

GreenSock在制作SVG动画方面也非常强悍,并且还专门提供了用于加强SVG动画制作的相关插件,比如Greensock DrawSVG plugin。它可以实现任何SVG图形的绘制,也可以操作诸如stroke-dashoffset和stroke-dasharray等CSS属性来制作一些描边的动画效果,下面来一个简单的实例:

详细代码地址

使用SVG来绘制图形

这一步将使用SVG来实现Dribble shot上的效果图。从效果图可以看到整个图形都是由简单的一些几何图形组成的,而绘制图形正是SVG所擅长的,使用SVG来实现这样的形状非常简单。

首先来为整个图形创建一个画布。创建一个SVG元素。然后创建一个跟画布一样大的矩形元素 rect 然后使用一个圆形的 clipPath 元素来遮住整个画布使其内容只显示在圆形的遮罩内。代码如下所示:

















一个基本的布局就完成了。下面是来添加一些样式。当然你可以使用行内样式或者是内联样式也可以是外链样式。



一般样式建议使用外链的方式来引入样式,这样可以保证html的整洁以及可维护性。当然也可以使用诸如SASS等预编译语言来编写CSS,可以利用预编译语言提供的变量功能来管理颜色或者是字号等全局样式,非常方便。

由于我使用的是SASS,我把颜色都在SASS中定义好对应颜色名称的变量里面:

// Color palette

$red: #E9214F;
$burnt-sienna: #F06B4B;

$goldenrod: #F6DA71;
$scooter: #349597;
$midnight-express: #20283B;

$marzipan: #FCDC9F;
$fruit-salad: #49934E;

$goblin: #3D7C42;
$chambray: #44557E;
$port-gore: #384668;

$white: #ffffff;
$silver-sand: #BBBBBB;
// Set background color

body {
background-color: $midnight-express;

}

// Center the svg horizontally and vertically

svg {
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);

width: 500px;
height: 500px;
backface-visibility: hidden;

}

// Color styles

.canvas {
.bg { fill: $scooter; }

.ground { fill: $marzipan; }

.sky1 { fill: $goldenrod; }

.sky2 { fill: $burnt-sienna; }

.sky3 { fill: $red; }

.tree-left { fill: $fruit-salad; }

.tree-right { fill: $goblin; }

.mountain-left { fill: $chambray; }

.mountain-right { fill: $port-gore; }

.mountain-top-left { fill: $white; }

.mountain-top-right { fill: $silver-sand;

}

现在整个是静态的,我们使用一点点GreenSock代码来实现一个从小到大缩放动画效果:

// 定义好要操作相关元素的变量

const svg = document.querySelector("svg")

const canvas = {

wrapper: svg.querySelector(".canvas"),
mask: svg.querySelector(".canvas .mask")

}

// 创建一个新的GASP的时间轴

const tl = new TimelineMax({

repeat: -1

})

// 使用 GASP的from方法来定义mask元素半径从0到1的缩放动画效果

tl.from(canvas.mask, 1, {

attr: {
r: 0
},
ease: Elastic.easeOut.config(3, 1)

})

几行代码,一个缩放的动画效果就完成了:

详细代码地址

绘制天空

接下来是绘制天空和地面元素。使用SVG中的矩形元素 rect 来绘制,三个用来绘制天空一个用来绘制地面:

































同样这里也需要为它们增加一点动效,首先是地面的动效,地面的动效是从下往上冒出的。

tl.from(canvas.ground, 0.5, {

autoAlpha: 0,
attr: {
y: "+=200"
},
ease: Power4.easeOut
}, 0.1)

天空的动效跟地面一样的。由于天空有3个元素,并且是依次出现而不是同从下往上冒出来,可以使用GreenSock中的 stagger 方法来实现:

tl.staggerFrom([canvas.sky1, canvas.sky2, canvas.sky3], 0.5, {

autoAlpha: 0,
skewY: 0,
attr: {
y: "+=90"
},
ease: Elastic.easeOut.config(1, 3)

}, 0.075, 0.25)

为了使动画更加细腻,做完动画后还需要调整下动画的运动曲线,可以使用GreenSock提供的一个可视化动画曲线调整工具来选择合适的动画曲线 ease visualizer。

详细代码地址

下面添加地面上的树,树由两个三角形组成。因为数是一个一个挨着排列的,所以使用 g 元素来包裹树元素编成一个组,这样方便来布局:







重复复制七份同样的代码,并且使用transform来改变树的位置,从而使之依次排列。然后是使用GreenSock来编写树的动画效果,树的动画效果是从45度旋转到0度旋转的效果并且同时从0到1的缩放效果:

tl.staggerFrom([canvas.tree1, canvas.tree2, canvas.tree3, canvas.tree4, canvas.tree5, canvas.tree6, canvas.tree7], 0.5, {

rotation: 45,
scale: 0,
transformOrigin: "bottom center",

ease: Back.easeOut.config(2, 1.55)

}, 0.05, 0.4)

效果如下所示:

详细代码地址

最后是后面的大山以及大山的动画效果。

大山由四个三角形元素组成,代码如下:











它的动画效果和树的效果差不多,只不过是把旋转的动效变成翻转的效果。

tl.staggerFrom([canvas.mountain], 0.75, {

y: "+=50",
skewX: -200,
scale: 0,
transformOrigin: "bottom center",

ease: Back.easeOut.config(1, .2)

}, 0.0125, 0.5)

一个有趣的SVG的动画效果就完成了,代码地址使用GreenSock 配合 SVG 来制作动画效果如此简单。

原文地址,根据自己理解整理了下这个教程,主要是来学习下使用GreenSock来制作SVG动画效果的思路和方法。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/91331.html

相关文章

  • SVG

    摘要:目前只提供了一些基础功能。中与的区别开发者第一次接触手写那种,虽然很多情况都有设计师使用来完成这项工作,但还是不排除需要利用到的每个元素。轻量级,具备灵活的来自团队,全球非常出名的可视化团队。于是笔者尝试着把移植到中。 使用SVG + CSS实现动态霓虹灯文字效果 早上无意间进入一个网站,看到他们的LOGO效果略屌,如图: 刚开始以为是gif动画之类的,审查元素发现居然是用SVG + ...

    104828720 评论0 收藏0
  • 2018年值得期待11个Javascript动画

    摘要:超过的,是一个动画库,可以处理属性,单个转换,或任何属性以及对象。在,是一个快速的动画引擎,具有与的相同的。在,这个功能和反应动画库只重。由和其他人使用,这个库既流行又令人惊讶地有用。 在浏览网页寻找一个整洁的Javascript动画库时,我发现很多recommended的动画库一段时间都没有维护。 经过一些研究,我收集了11个最好的库,在你的应用程序中使用。我还添加了一些,主要是非维...

    call_me_R 评论0 收藏0
  • 2018年值得期待11个Javascript动画

    摘要:超过的,是一个动画库,可以处理属性,单个转换,或任何属性以及对象。在,是一个快速的动画引擎,具有与的相同的。在,这个功能和反应动画库只重。由和其他人使用,这个库既流行又令人惊讶地有用。 在浏览网页寻找一个整洁的Javascript动画库时,我发现很多recommended的动画库一段时间都没有维护。 经过一些研究,我收集了11个最好的库,在你的应用程序中使用。我还添加了一些,主要是非维...

    teren 评论0 收藏0
  • 2018年值得期待11个Javascript动画

    摘要:超过的,是一个动画库,可以处理属性,单个转换,或任何属性以及对象。在,是一个快速的动画引擎,具有与的相同的。在,这个功能和反应动画库只重。由和其他人使用,这个库既流行又令人惊讶地有用。 在浏览网页寻找一个整洁的Javascript动画库时,我发现很多recommended的动画库一段时间都没有维护。 经过一些研究,我收集了11个最好的库,在你的应用程序中使用。我还添加了一些,主要是非维...

    skinner 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<