通常我们说的 Web 动画,包含了三大类。
个人认为 3 种动画各有优劣,实际应用中根据掌握情况作出取舍,本文讨论的是我认为 SVG 中在实际项目中非常有应用价值 SVG 线条动画。
举个栗子
SVG 线条动画,在一些特定的场合下可以解决使用 CSS 无法完成的动画。尤其是在进度条方面,看看最近项目里的一个小需求,一个这种形状的进度条:
把里面的进度条单独拿出来,也就是需要实现这样一个效果:
脑洞大开一下,使用 CSS3 如何实现这样一个进度条呢。
CSS3 是可以做到的,就是很麻烦。但是如果采用 SVG 的话,迎刃而解。
See the Pen 不规则进度条 by Chokcoco (@Chokcoco) on CodePen.
我们假定你在阅读本文的时候有了一定的 SVG 基础,上面代码看看就懂了,好了,本文到此结束。
好吧,还是稍微解释下,上面进度条的主要 SVG 代码如下:
- <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" class="circle-load-rect-svg" width="300" height="200" viewbox="0 0 600 400">
- <polyline points="5 5, 575 5, 575 200, 5 200" class="g-rect-path"/>
- <polyline points="5 5, 575 5, 575 200, 5 200" class="g-rect-fill"/>
- </svg>
SVG 为何
可缩放矢量图形,即SVG,是W3C XML的分枝语言之一,用于标记可缩放的矢量图形。(摘自MDN[1])
上面代码中,先谈谈 svg 标签:
有了 svg 标签,我们就可以愉快的在内部添加 SVG 图形了,上面,我在 svg 中定义了两个 polyline 标签。
SVG 基本形状
polyline:是SVG的一个基本形状,用来创建一系列直线连接多个点。
其实,polyline 是一个比较不常用的形状,比较常用的是path,rect,circle 等。这里我使用 polyline 的原因是需要使用 `stroke-linejoin`[2] 和 `stroke-linecap`[3] 属性,在线段连接处创建圆滑过渡角。
SVG 中定义了一些基本形状[4]:
SVG 线条动画
好,终于到本文的重点了。
上面,我们给两个 polyline 都设置了 class,SVG 图形的一个好处就是部分属性样式可以使用 CSS 的方式书写,更重要的是可以配合 CSS 动画一起使用。
上面,主要的 CSS 代码:
- .g-rect-path{
- fill: none;
- stroke-width:10;
- stroke:#d3dce6;
- stroke-linejoin:round;
- stroke-linecap:round;
- }
- .g-rect-fill{
- fill: none;
- stroke-width:10;
- stroke:#ff7700;
- stroke-linejoin:round;
- stroke-linecap:round;
- stroke-dasharray: 0, 1370;
- stroke-dashoffset: 0;
- animation: lineMove 2s ease-out infinite;
- }
- @keyframes lineMove {
- 0%{
- stroke-dasharray: 0, 1350;
- }
- 100%{
- stroke-dasharray: 1350, 1350;
- }
- }
这是什么 CSS?怎么除了 animation 全都不认识?
莫慌,其实很多和 CSS 对比一下非常好理解,只是换了个名字:
重点讲讲能够实现线条动画的关键属性 stroke-dasharray 。
上面,填充进度条,使用了下面这个动画 :
- @keyframes lineMove {
- 0%{
- stroke-dasharray: 0, 1350;
- }
- 100%{
- stroke-dasharray: 1350, 1350;
- }
- }
stroke-dasharray: 0, 1350;,表示线框短划线和缺口的长度分别为 0 和 1350,所以一开始整个图形都是被缺口占据,所以是在视觉效果上长度为 0。
然后过渡到 stroke-dasharray: 1350, 1350,表示线框短划线和缺口的长度分别为 1350 和 1350,因为整个图形的长度就是 1350,所以整个进度条会被慢慢填充满。
掌握了这个技巧后,就可以使用 stroke-dasharray 和 stroke-dashoffset 制作很多不错的交互场景:
SVG 线条动画实现按钮交互
SVG 线条动画实现圆形进度条
各类按钮效果
多 SVG 图形线条动画配合
之前我司一个 h5 里面应用过的,多SVG 图形线条动画配合,可以制作一些比较酷炫的动画,很有科技感。
本文到此结束,我在我的 Github 上,使用 SVG 实现了一些图形 -- SVG奇思妙想[6],Demo可以戳这里[7]。
下篇文章将会详述非规则图形,如何使用 PS + AI 生成 path 路径,实现 SVG 动画,放个 Demo,敬请期待。
参考资料
[1]MDN:
https://developer.mozilla.org/zh-CN/docs/Web/SVG/Tutorial
[2]stroke-linejoin:
https://developer.mozilla.org/zh-CN/docs/Web/SVG/Attribute/stroke-linejoin
[3]stroke-linecap:
https://developer.mozilla.org/zh-CN/docs/Web/SVG/Attribute/stroke-linecap
[4]基本形状:
https://developer.mozilla.org/zh-CN/docs/Web/SVG/Tutorial/Basic_Shapes
[5]设定线段连接处的样式:
https://developer.mozilla.org/zh-CN/docs/Web/SVG/Attribute/stroke-linejoin
[6]SVG奇思妙想:
https://github.com/chokcoco/SVG
[7]Demo可以戳这里:
http://sbco.cc/demo/svg/html/index.html
如何在 云主机 上搭 建网站 ?对站长来说,搭建网站要根据自身情况来定,若不懂...
背景 对于大数据中的大多数存储格式 支持随机更新非常复杂。它需要扫描大型文件 ...
据IDC评述网(idcps.com)报道,ntldstats.com最新数据显示,截止至2016年3月31...
一场疫情,催化了智慧校园的发展,让未来教育的一些设想提前实现。线上课堂云端...
TOP云 (west.cn)2月4日讯,IDC评述网今日报道:根据ntldstats.com发布的最新数据...
本文转载自微信公众号「编程珠玑」,作者守望先生。转载本文请联系编程珠玑(ID:...
随着Kubernetes已经成为容器编排和调度的事实标准,各大公有云厂商都已经基于Kub...
TOP云 (west.cn)10月18日消息,近日多个三字母 域名 在国内外频繁交易,四字母...
公司简介 广州市藏星网络科技有限公司的主要产品是移动互联网应用“上学帮”,产...
说明 JetBrains 全系列产品永久激活教程 适用于 JetBrains 全系列产品 2018、201...