恭喜你成为UI中国推荐设计师 (详情)
//百度统计 20220402 uicn

您的意见是我们 UI 中国进步的动力!
点击立即反馈按钮,发表您的意见!
立即反馈
QQ群反馈
您也可以加入UI中国官方反馈群进行反馈!
群号:302892100
备注:反馈问题后@管理员能让我们及时了解您的意见

提交需求

赛事与广告咨询合作,请填写需求表单,我们会在第一时间与您联系!

0/20
0/200

设计大赛

  • 设计大赛
  • 发布广告
  • 发布招聘
  • 其它需求

提交完成
感谢您对UI中国的支持和信赖!
【代码实现】只需数行代码即可实现的SVG动画
0.0°
2016-04-16 原创文章 教程 举报 7457 102 84 21

作为设计师,如果能够用代码来实现一些动效,那真是极好的!


SVG这种图片格式今年来真是呈现一个越来越火的节奏,最近“动效”这个词非常的流行,产品们都恨不得能够在自己的所有产品上都加上炫目的动效,设计师们都恨不得在一夜之间都掌握所有制作动效的软件,而SVG的大热,或多或少都是拜这股洪流所赐。SVG与代码能打出非常好的配合,设计师们能够用简单的几行CSS代码就实现出许许多多动效,是的,再也不是做成GIF的“类动效”,而是实打实的代码实现的动效,并且真的非常简单。SVG除了能够很好配合你的CSS代码之外,还有许多别的优秀特性。

  1. 跨设备能力。SVG的全名是(Scalable Vector Graphic),它是矢量的,也就是说无论你怎么东拉西扯,它总是能够保持自己最好的状态,无论在何种尺寸的状态下,无论在那种屏幕里面呈现,它都不会有一丁点模糊,现在响应式的产品是主流,天知道用户会用什么样的设备来使用你的东西。这回设计师爽了,直接输出拿给程序员们就好了,他再也再也不会回来找你了,真的我保证。
  2. 透明通道。SVG是可透明的,好用得就像PNG的透明一样,完全健康、正常。光这一条就少了无数坑了。
  3. 小,小很多很多。大家都知道GIF动画有时候会很大,这就让网页的载入时间变得很长很长,耗费用户太多的流量,要知道现在流量是多么的贵啊,要知道超过五秒的等待时间用户就会把你无情的关掉啊。而且巨大的GIF图片即使在加载完成之后也要耗费非常多的资源来一直进行渲染,这会让整个体验变得非常的卡顿,而且我认为嘛,设计师们应该要在某种程度上做到提升产品性能的能力。
  4. 可交互的。因为我们能用CSS或者Javascript对它进行控制,而且这个非常简单。

这里必须声明的是,在下也才疏学浅,只能为大家列出这几条,SVG的优势或许还有别的许多。


接下来为大家讲解一个用到了SVG和CSS的logo小动画,大家如果感兴趣的可以到我的Github下载全部代码慢慢研究,希望看完这则教程之后你能够立刻用带自己的产品上面去。



See the Pen TextLogoAnimation by Zhuyxuan (@Zyxscientist) on CodePen.

(点击链接看效果,你还能亲自动手修改哦)




看吧,真的非常短小精悍,总体积不过几k。


HTML部分: 首先通过SVG的标签来设置蒙版,这里我们的蒙版是一行文字“Zyxscientist”。这里必须提到的是,我们必须要用来装下以及其之内的所有内容。如果不这样做的话,在某些浏览器中可能会出现动画无法正常运动的状况,在下也不知道为什么。

在一个内定义了六,用clip-path="url(#mask-path)"来指向我们上面用定义好的蒙版,所以我们这六个方块的蒙版就是"Zyxscientisit"这行字,只有经过这行子的区域,我们才能看得到我们的。

HTML部分总体来讲就是这么几种元素,然而配合CSS却可以做出视觉效果并不单调的动画效果,这里体现出了SVG在动画方面的可塑性。


CSS部分: 我们大概可以把整个动画分为三个小部分(详见下面呈上来给大家的timeline)。第一部分:首先看到的是我们的蒙版“Zyxscientist”先保持静止不动,而线面的六个元素由初始状态开始进行时长4s的运动。我们在CSS中设置了这里六个方形的颜色,所以当动画开始,这六个元素路过蒙版的时候可以看到一个上色的效果。第二部分:让第二部分的动效反过来再放一遍,这是通过keyframes来设定的,我尝试过两个部分分开写,但是这会让它们之间存在一些微小的卡顿,将它们一次性写到同一个keyframes里面可以避免这样的情况发生,尽管这样会丧失一些灵活性。第三部分:我们开始让蒙版开向右运动,让蒙版和下面的元素重合的部分只剩下一个'Z'字母,以得到我们看见的最后的效果。

Image title



CSS部分稍微长一些,但是思路还是很简单的。


好了,见天的分享就到这里先啦,如果多人喜欢的话我会继续给大家分享更多关于SVG动画的东西。

重新提一下,你可以到我的Github上面直接下载这段代码,然后自己玩起来。

以后有新文章新作品跟大家分享,除了会首发到ui中国之外还会发布到最近自己搭建的博客之上,希望大家多来逛逛,多交流。

最后的最后,希望有大神能够指出上面代码写得naiev的地方。

更新:2016-04-16

收藏

102人已收藏

zhuyuxuan

✍️知乎专栏:DesignCoder

  • 24

    作品

  • 2046

    粉丝

  • 32

    关注

  • 你是不是对设备的屏幕一无所知
  • 不整虚的,12 条提高产品可用性的动效设计的原理
  • 「冷知识」Sketch还能这样操作?!
  • 「写给设计师」技术,要懂多少才算懂?
相关标签
MG网页设计

    猜你喜欢

      2016-04-16 原创文章 教程 举报 7457 102 84 21

      【代码实现】只需数行代码即可实现的SVG动画

      0.0°

      你确定要举报【代码实现】只需数行代码即可实现的SVG动画

      如果查出恶意举报,十天内禁止提交任何举报申请。

      0/200

      上传证据: 超过10M的附件请使用网盘地址

      点击上传附件

      对谁可见:

      全部设计师
      • 全部设计师
      • 推荐设计师和认证设计师

      您确认要推荐?

      该作品发布时间:2016年03月30日

      评分

      完整度

      启发性

      勤奋性

      排版布局

      推荐心得

      建议20-200字以内

      0/200

      84
      102
      21

      账号或密码错误,请重新输入

      账号或密码错误,请重新输入

      登录

      手机号

      发送验证码 120s 验证码错误

      登录
      第三方账号登录