前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >线条之美,玩转SVG线条动画

线条之美,玩转SVG线条动画

作者头像
Javanx
发布于 2019-09-05 10:41:09
发布于 2019-09-05 10:41:09
2.1K00
代码可运行
举报
文章被收录于专栏:web秀web秀
运行总次数:0
代码可运行

通常来说web前端实现动画效果主要通过下面几种方案: 1. css动画: 利用css3的样式效果可以将dom元素做出动画的效果来。 2. canvas动画: 利用canvas提供的API,然后利用清除-渲染这样一帧一帧的做出动画效果。 3. svg动画: 同样svg也提供了不少的API来实现动画效果,并且兼容性也不差,本文主要讲解一下如何制作svg线条动画

先来看几个效果:

演示地址

以上这些效果都是利用SVG线条动画实现的,只用了css3和svg,没有使用一行javascript代码,这一点和canvas比起来要容易一些,下面就说明一下实现这些效果的原理。 关于SVG的基础知识,我这里就不再叙述了,大家可以直接在文档中查看相关的API,这里只说一下实现线条动画主要用到的:path (路径) <path> 标签命令

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
M = moveto
L = lineto
H = horizontal lineto
V = vertical lineto
C = curveto
S = smooth curveto
Q = quadratic Belzier curve
T = smooth quadratic Belzier curveto
A = elliptical Arc
Z = closepath

利用path的这些命令我们可以实现我们想要的任何线条组合,以一段简单的线条为例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<path id="path" fill="none" stroke="#000" stroke-width="1px" d="M452,293c0,0,0-61,72-44c0,0-47,117,81,57
    s5-110,10-67s-51,77.979-50,33.989"/>

效果:

呵呵,看起来很简单,但是,如何让这个线条动起来呢?这里就要明白到SVG里的path的一些主要属性: 1. stroke:标识路径的颜色; 2. d:标识路径命令的集合,这个属性主要决定了线条的形状。 3. stroke-width:标识路径的宽度,单位是px; 4. stroke-dasharray:它是一个和数列,数与数之间用逗号或者空白隔开,指定短划线和缺口的长度。如果提供了奇数个值,则这个值的数列重复一次,从而变成偶数个值。因此,5,3,2等同于5,3,2,5,3,2; 5. stroke-dashoffset:标识的是整个路径的偏移值; 以一张图来解释stroke-dasharray和stroke-dashoffset更容易理解一些:

因此,我们之前的路径就会变成这个样子:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#path {
    stroke-dasharray: 3px, 1px;
    stroke-dasharray: 0;
}

效果:

理解了stroke-dasharray的作用之后,下面我们就可以使用css3的animation来让这个路径动起来。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#path {
    animation: move 3s linear forwards;
}
@keyframes move {
  0%{
      stroke-dasharray: 0, 511px;
  }
  100%{
      stroke-dasharray: 511px, 511px;
  }
}

效果:

511这个值是整个路径的长度,可以用js的document.getElementById(‘path’).getTotalLength()得到 stroke-dasharray: 0, 511; 表示实线和空隙的长度分别为 0 和 511,所以一开始整个路径都是空隙,所以是空的。 然后过渡到 stroke-dasharray: 511, 511; 因为整个线条的长度就是 511,而实线的长度也慢慢变成511,所以整个线条就出现了。 同样利用stroke-dashoffset也可以实现这个效果,原理就是最初线条分为511实线,和511空隙,但是由于设置了offset使线条偏移不可见了,当不断修改offset后,线条慢慢出现。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#path {
    animation: move 3s linear forwards;
    stroke-dasharray: 511px,511px;
}

@keyframes move {
  0%{
      stroke-dashoffset: 511px;
  }
  100%{
      stroke-dashoffset: 0;
  }
}

效果:

当我们掌握了上述的方法后,整个利用SVG实现线条动画的原理就已经清楚了,我们需要的就是一个SVG路径了,但是总画一些简单的线条还是不美啊,那我们如何才能得到复杂的svg路径呢? 找UI设计师要一个。 自己利用PS和AI做一个,只需要简单的2步。

以部落LOGO为例: 1,得到部落LOGO的png图片。 2,右键图层,然后点击从选区生成工作路径,我们就可以得到:

3,文件–导出–路径到AI,将路径导出在AI里面打开。

4,在AI里面选择保存成svg格式的文件,然后用sublime打开svg文件,将path的d拷贝出来即可。 5,利用上文介绍的实现动画的方法,我们就可以轻松的得到了下面这个效果。

线条动画进阶: 可以看到上面的动画效果和文章最初显示的动画效果还是有区别的,要想实现文章最初的动画效果,需要用到SVG的<symbol><use>来实现,读者可以在网上查一下这两个标签的用法。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<symbol id="pathSymbol">
    <path  class="path" stroke="#00adef"  d="M281.221,261.806c0,2.756-2.166,4.922-4.922,4.922l0,0h-33.964c-11.715-24.119-31.503-59.855-47.156-68.026
  c-15.751,7.974-35.637,43.907-47.451,68.026h-33.865l0,0c-2.756,0-4.922-2.166-4.922-4.922l0,0l0,0c0-0.295,0-0.689,0.098-0.984
  c0,0,14.078-69.109,79.15-129.161c-2.953-2.56-5.907-5.119-8.959-7.58c-1.87-1.575-2.166-4.233-0.591-6.104
  c1.575-1.772,4.43-2.166,6.497-0.689c3.347,2.461,6.694,5.218,9.746,8.073c3.15-2.953,6.497-5.71,10.041-8.368
  c2.067-1.378,4.922-1.083,6.497,0.689c1.575,1.87,1.28,4.529-0.591,6.104c-3.052,2.56-6.104,5.218-9.155,7.876
  c65.27,59.953,79.446,129.161,79.446,129.161C281.221,261.117,281.221,261.412,281.221,261.806L281.221,261.806L281.221,261.806z"/>
    <path  class="path" stroke="#00adef"  d="M194.589,212.583h0.984l0,0c19.886,28.451,31.503,54.145,31.503,54.145h-63.99C163.086,266.728,174.703,241.034,194.589,212.583
L194.589,212.583z"/>
</symbol>
<g>
  <use xlink:href="#pathSymbol"
    id="path1"></use>
    <use xlink:href="#pathSymbol"
      id="path2"></use>
</g>
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#path1 {
    stroke-dashoffset: 7% 7%;
    stroke-dasharray: 0 35%;
    animation: animation 3s linear forwards;
}

@keyframes animation {
  100% {
    stroke-dasharray: 7% 7%;
    stroke-dashoffset: 7%;
  }
}

#path2 {
    stroke-dashoffset: 7% 7%;
    stroke-dasharray: 0 35%;
    animation: animation2 3s linear forwards;
}
@keyframes animation2 {
  100% {
      stroke-dasharray: 7% 7%;
      stroke-dashoffset: 14%;
  }
}

思路就是: 1,将原来只有一条path的路径替换成两条,并且这两条的路径是完全重合的。 2,分别设置两条路径的stroke-dasharray和stroke-dashoffset的css3的animation动画,注意两条路径的动画不能完全一样要有差值。 3,设置成功之后就可以利用animation动画触发的时机和改变程度来实现多条动画效果。 效果:

那么如何实现alloyteam的文字动画呢,其实原理也是利用了stroke-dasharray和stroke-dashoffset,这两个属性不仅可以作用在path上,同样可以作用在text上。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<symbol id="text">
    <text x="30%" y="35%" class="text">QQ</text>
  </symbol>
  <g>
    <use xlink:href="#text"
      class="use-text"></use>
      <use xlink:href="#text"
        class="use-text"></use>
        <use xlink:href="#text"
          class="use-text"></use>
          <use xlink:href="#text"
            class="use-text"></use>
            <use xlink:href="#text"
              class="use-text"></use>
  </g>
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
.use-text:nth-child(1) {
  stroke: #360745;
  animation: animation1 8s infinite ease-in-out forwards;
}
.use-text:nth-child(2) {
  stroke: #D61C59;
  animation: animation2 8s infinite ease-in-out forwards;
}

.use-text:nth-child(3) {
   stroke: #E7D84B;
   animation: animation3 8s infinite ease-in-out forwards;
}

.use-text:nth-child(4) {
   stroke: #EFEAC5;
   animation: animation4 8s infinite ease-in-out forwards;
}
.use-text:nth-child(5) {
  stroke: #1B8798;
  animation: animation5 8s infinite ease-in-out forwards;
}
@keyframes animation1 {
   50%{
        stroke-dasharray: 7% 28%;
        stroke-dashoffset: 7%;
   }
   70%{
         stroke-dasharray: 7% 28%;
         stroke-dashoffset: 7%;
   }
}
@keyframes animation2 {
   50%{
       stroke-dasharray: 7% 28%;
       stroke-dashoffset: 14%;
   }
   70%{
        stroke-dasharray: 7% 28%;
        stroke-dashoffset: 14%;
   }
}
@keyframes animation3 {
     50%{
         stroke-dasharray: 7% 28%;
         stroke-dashoffset: 21%;
    }
    70%{
         stroke-dasharray: 7% 28%;
         stroke-dashoffset: 21%;
    }
}
@keyframes animation4 {
   50%{
        stroke-dasharray: 7% 28%;
        stroke-dashoffset: 28%;
   }
   70%{
        stroke-dasharray: 7% 28%;
        stroke-dashoffset: 28%;
   }
}
@keyframes animation5 {
  50%{
       stroke-dasharray: 7% 28%;
       stroke-dashoffset: 35%;
  }
  70%{
       stroke-dasharray: 7% 28%;
       stroke-dashoffset: 35%;
  }
}

这里用了5条完全重合的路径,并且每个路径的颜色和动画效果都不一样。 效果:

演示地址 源码下载

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018年10月10日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
SVG 线条动画基础入门知识
1、CSS3 动画 2、javascript 动画(canvas) 3、html 动画(SVG)
Javanx
2019/09/04
3.1K0
SVG 线条动画基础入门知识
巧用 CSS 实现动态线条 Loading 动画
所以,这里的的难点也就转变为了,如何动态的实现弧形线段的长短变化?解决了这个问题,也就基本上解决了上述的线条变换 Loading 动画。
Sb_Coco
2022/03/10
1.2K0
巧用 CSS 实现动态线条 Loading 动画
【动画进阶】巧用 CSS/SVG 实现复杂线条光效动画
简单而言,就是线条沿着不规则路径的行进动画,其中的线条动画可以理解为是特殊的光效。
Sb_Coco
2024/05/07
1K0
【动画进阶】巧用 CSS/SVG 实现复杂线条光效动画
SVG 动画精髓
TL;DR 本文主要是讲解关于 SVG 的一些高级动画特效,比如 SVG 动画标签,图形渐变,路径动画,线条动画,SVG 裁剪等。 例如:路径动画 图形渐变: 线条动画: 以及,相关的动画的矩阵知识,
villainhr
2018/07/03
3.5K0
初窥 SVG Path 动画
本文主要介绍了如何使用 SVG Path 实现绘制可循环播放的动画,包括动画的起点、终点和循环路径,以及如何使用 CSS3 的 keyframes 和 animation 实现动画效果。同时,还介绍了一些 SVG Path 的常见属性,包括 stroke-dasharray、stroke-dashoffset 等,以及如何通过修改这些属性来实现动画效果。
IMWeb前端团队
2017/12/29
3K0
初窥 SVG Path 动画
【Web动画】SVG 线条动画入门
通常我们说的 Web 动画,包含了三大类。 CSS3 动画 javascript 动画(canvas) html 动画(SVG) 个人认为 3 种动画各有优劣,实际应用中根据掌握情况作出取舍,本文讨论
Sb_Coco
2018/05/28
2.4K0
SVG 动画精髓(下)
本文作者:ivweb villainthr 接SVG 动画精髓(上) 线条动画 SVG 中的线条动画常常用作过渡屏(splash screen)中。例如: 或者,一些比较炫酷的 LOGO 中,比如
腾讯IVWEB团队
2017/07/07
1.9K0
SVG 动画精髓(下)
三种 Loading 制作方案
Loading几乎是每个应用都会用到的一个组件。很多组件库都会提供相应的Loading组件,但是有的时候我们可能需要自定义Loading效果,掌握Loading组件制作的基础知识将变得非常必要。Loading主要就是一个旋转的圆环,而旋转部分则比较简单,直接通过CSS动画即可实现,所以关键部分就是得到Loading的圆环。
落落落洛克
2021/01/08
3.5K0
三种 Loading 制作方案
【动画进阶】当路径动画遇到滚动驱动!
在一年前,我介绍了 CSS 中非常新奇有趣的一个新特性 -- @scroll-timeline:革命性创新,动画杀手锏 @scroll-timeline。
Sb_Coco
2023/09/15
7060
【动画进阶】当路径动画遇到滚动驱动!
前端面试CSS相关(二)
如何实现一个loading动画; 要求: 用css或svg实现一个loading动画; 本文完整源代码地址:https://gitee.com/duanweidong/interview-question-code.git html结构(css) <div class="loading-block"> <div class="loading-part"></div> <div class="loading-part"></div> <div class="loading-p
用户7572539
2022/11/21
2180
SVG 路径动画简易指南
任何有开发经验的前端工程师都会考虑到不成体系的设备生态所带来的挑战。设备间不同的屏幕尺寸、分辨率和比例使得产品难以提供一致的体验,对于那些对产品有着像素级完美追求的人这种体验差异尤其显著! SVG(可缩放的矢量图形)完美地解决了上文中提到的部分问题。尽管 SVG 有它的局限性,但是在某些场景下是非常有用的,如果你有一个好的设计团队,你也可以基于SVG创建一些震撼的视觉体验,而不必担心给浏览器带来过重的渲染负担或阻碍页面的加载时间。
疯狂的技术宅
2019/03/27
3.8K0
SVG 路径动画简易指南
【效果高能】你不知道的 Animation 动画技巧
在大多数需求中,css3 的 transition / animation 都能满足我们的需求,并且相对于 js 实现,可以大大提升我们的开发效率,降低开发成本。
一只图雀
2020/11/03
1.7K0
【效果高能】你不知道的 Animation 动画技巧
每日分享html之3个logo、1个背景、1个button
动态效果,如缩放,覆盖,滑出网页或单个视觉元素,可帮助用户理解网页信息架构。通常是通过转场和菜单来展开网页。
淼学派对
2022/11/20
4830
每日分享html之3个logo、1个背景、1个button
「css基础」Transforms 属性在实际项目中如何应用?
关于Transform变形属性大家都不陌生吧,可以通过此属性实现元素的位移translate(x,y),缩放scale(x,y),2d旋转rotate(angle),3d旋转rotate3d(angle),倾斜变换skew(x-angle,y-angle)等,你也许已经很熟悉了这些属性,或许你也会有这样的困惑,这些属性在实际项目中如何应用呢?
前端达人
2019/07/21
2.7K0
「css基础」Transforms 属性在实际项目中如何应用?
【拓展】SVG实现环形进度条的原理
之前在项目中遇到一个环形进度条的需求,要求能实时更新进度,脑海中瞬间便蹦出css,svg,canvas3中方案,对于3种方案个人更偏向于svg,用法简单,代码量也很少,同时也便于实时控制。具体效果如下图:
pingan8787
2020/11/03
1.3K0
【拓展】SVG实现环形进度条的原理
一个比想象中更骚气的圆-svg实现
之前写了一篇Canvas画图-一个比想象中更骚气的圆(渐变圆环),其实SVG也可以实现类似的效果,而且两者api惊人的相似。 关于SVG SVG是一种矢量图形,在图形改变尺寸的情况下质量不会损失。 相比canvas,svg有一个很大的优势就是内联进html的时候可以像操作dom一样操作svg,这样做起动画来非常方便。 本文不会介绍svg的基础知识,不过也没涉及什么复杂的东西,基于xml的语法还是比较好理解的。 期望实现的效果和Canvas一样是颜色非对称的沿着圆周进行渐变。 SVG的渐变 和之前讲ca
Bob.Chen
2018/05/02
3.4K0
一个比想象中更骚气的圆-svg实现
回顾css的animation属性
异名新接一个需求,实现一个文字的切换,结果发现太久没写css动画,对animation属性已经很陌生,尤其是对steps()函数的理解已经丢掉了。
异名
2020/12/18
1K0
回顾css的animation属性
CSS 奇技淫巧 | 妙用 drop-shadow 实现线条光影效果
本文将介绍一种利用 CSS 滤镜 filter 的 drop-shadow(),实现对 HTML 元素及 SVG 元素的部分添加阴影效果,以实现一种酷炫的光影效果,用于各种不同的场景之中。通过本文,你可以学到:
Sb_Coco
2021/10/09
1.3K0
一步步教你用实现HTML5 SVG动画效果 [每日前端夜话(0x16)]
SVG是一种基于XML的,用于定义缩放矢量图形的标记语言。 它允许你通过在2D平面中确定的一组点来绘制路径、曲线和形状。 此外你还可以通过在这些路径上添加动态属性(例如笔触,颜色,粗细,填充等)来生成动画。
疯狂的技术宅
2019/03/27
2.6K0
一步步教你用实现HTML5 SVG动画效果 [每日前端夜话(0x16)]
svg描边绘制动画实现方式
0写在前面 这篇文章主要讲利用SVG来实现web页面上的描边绘制动画的两种原理。同时涉及到从AI软件导出SVG的方法。 1案例效果 扫光效果和描边效果,如图: 2SVG的导出方法 首页需要设计师做一个相同或者等比文字矢量图,也就是AI文件。 用AI打开文件之后利用左侧工具栏里的“直接选择工具”,全选之后右击“转化成复合路径”,然后菜单里选择“将文档存储为SVG”。 这样导出来的就是path路径代码了。如图所示: 举例: 导出之后的代码片段,比如案例“hello”代码片段里有些属性是AI软件自动
用户1097444
2022/06/29
1.6K0
svg描边绘制动画实现方式
相关推荐
SVG 线条动画基础入门知识
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验