行使SVG + CSS实现动态霓虹灯文字效果

早晨无意进一个网站,看到他们之LOGO效果略屌,如图:
图片 1

正好起认为是gif动画之类的,审查元素发现竟是故SVG +
CSS3动画实现之,顿时激起了自己的(hao)欲(qi)望(xin),决定使一如既往试探究竟,查看代码之后,发现原理居然是这么简约:多只SVG描边动画使用不同的animation-delay即可!

对一个相SVG元素或文本SVG元素,可以动用stroke-dasharray来支配描边的间距样式,并且可就此stroke-dashoffset来决定描边的偏移量,借这个可以实现描边动画效果,更具体的资料可以省张大神的《纯CSS实现帅气的SVG路径描边动画效果》

咱们先实现一个简约的文字描边动画:

<svg width="100%" height="100">
    <text text-anchor="middle" x="50%" y="50%" class="text">
        segmentfault.com
    </text>
</svg> 

.text{
    font-size: 64px;
    font-weight: bold;
    text-transform: uppercase;
    fill: none;
    stroke: #3498db;
    stroke-width: 2px;
    stroke-dasharray: 90 310;
    animation: stroke 6s infinite linear;
}
@keyframes stroke {
  100% {
    stroke-dashoffset: -400;
  }
}

演示地址:http://output.jsbin.com/demic…

下一场我们同时用多单描边动画,并安装不同之animation-delay:

<svg width="100%" height="100">
    <text text-anchor="middle" x="50%" y="50%" class="text text-1">
        segmentfault.com
    </text>
    <text text-anchor="middle" x="50%" y="50%" class="text text-2">
        segmentfault.com
    </text>
    <text text-anchor="middle" x="50%" y="50%" class="text text-3">
        segmentfault.com
    </text>
    <text text-anchor="middle" x="50%" y="50%" class="text text-4">
        segmentfault.com
    </text>
</svg> 

小心:要用多少种颜色,就推广小个text

.text{
    font-size: 64px;
    font-weight: bold;
    text-transform: uppercase;
    fill: none;
    stroke-width: 2px;
    stroke-dasharray: 90 310;
    animation: stroke 6s infinite linear;
}
.text-1{
    stroke: #3498db;
    text-shadow: 0 0 5px #3498db;
    animation-delay: -1.5s;
}
.text-2{
    stroke: #f39c12;
    text-shadow: 0 0 5px #f39c12;
    animation-delay: -3s;
}
.text-3{
    stroke: #e74c3c;
    text-shadow: 0 0 5px #e74c3c;
    animation-delay: -4.5s;
}
.text-4{
    stroke: #9b59b6;
    text-shadow: 0 0 5px #9b59b6;
    animation-delay: -6s;
}

@keyframes stroke {
  100% {
    stroke-dashoffset: -400;
  }
}

居功至伟告成,演示地址:http://output.jsbin.com/vuyuv…
图片 2

急需留意的几只点:

1.一一要素的animation-delay与animation的到底时增长的装要和谐
2.stroke-dashoffset以及stroke-dasharray的装置要协调

https://segmentfault.com/a/1190000010963326

发表评论

电子邮件地址不会被公开。 必填项已用*标注