svg文字描边动画

svg动画在网页中是经常见到的,svg动画使得网页看起来清新美观

任何不规则图形都可以由svg绘制完成,当然也包括文字,文字本身就可以看作一个不规则图形??

还是按以前的流程,开始放代码前,先看效果:

很酷炫有木有?!!!

在我发现这个效果的时候,我觉得碉堡了,直到我知道了它的代码

代码真的很简单,很简单。。。

咳咳。不扯了,现在进入正题

在使用网页做svg动画的时候首先我们要有svg文件,这里我使用的是Ai来做svg文件

其实我感觉Ai和PS真的好像,

新建文件-->文字工具-->选自己喜欢的字体和大小

然后选菜单上的 文字-->创建轮廓

这样文字的轮廓就出来了,接下来用svg格式保存文件。

之后又会弹出一个窗口,不管它,直接用默认选项,点确定就行

之后把svg文件导入到文本编辑器中(这里我用的是WebStorm)

导入后是这样的:

这些让人看着眼花缭乱的数字,就是Ai生成的文字的路径

我们只需要path标签里的东西

新建一个html文件,创建一个div里面包着svg,svg里面包着我们获得的path标签

div的css样式:

1 width: 400px;
2 height: 300px;
3 margin: 0 auto;

因为在Ai建立的svg大小就是400*300,所以我这里也弄成一样大小

svg样式:

1 width: 400px;
2 height: 300px;

我给所有的path标签定了一个类名,叫word

1 .word {
2     stroke-dasharray: 500;
3     animation: draw 8s linear forwards;
4 }
stroke-dasharray表示虚线的长度,我这里设的是五百的长度,但一个字母的边框长度显然没有五百,所以看到的也就是实线

接下来设置动画效果:
1 @keyframes draw {
2     0%{
3             stroke-dashoffset: 500;
4     } 100% {
5             stroke-dashoffset: 0;
6     }
7 }

stroke-dashoffset表示绘制点距离起点的距离,由于我不知道字母的宽度,这里我直接用500代替,从500到0,就画出了整个字母边框,

在path标签中添加如下属性

fill-opacity="0" stroke="#FFF" stroke-width="1.5"当然也可以在css中设置

这样一个文字描边的动画就大功告成了如果你想要用虚线描边,就把stroke-dasharray设置小一点,比如我设置10就看到这样的效果:
如果你想要动画永远进行下去
animation: draw 8s linear forwards;

把forwards设置成infinite就可以一直重复动画了

一般svg动画都需要配合javascript一起使用的,比如stroke-dashoffset因为我不知道具体轮廓长度,就只设成500甚至更多,那么在javascript中是可以获取轮廓长度的
1 path.getTotalLength();

这个方法就可以获取字母的轮廓长度。

什么?你不想要这种效果?

你想要把字母一个个按顺序画出来?也可以:

只要给每个path定一个id,在按时间顺序执行动画

1 #st0{animation: draw 2s ease forwards;}
2 #st1{animation: draw 2s ease .5s backwards;}
3 #st2{animation: draw 2s ease 1s backwards;}
4 #st3{animation: draw 2s ease 1.5s backwards;}
5 #st4{animation: draw 2s ease 2s backwards;}
6 #st5{animation: draw 2s ease 2.5s backwards;}
7 #st6{animation: draw 2s ease 3s backwards;}
8 #st7{animation: draw 2s ease 3.5s backwards;}
9 #st8{animation: draw 2s ease 4s backwards;}

效果如下:

效果很不错,代码很简单,只要学懂了,就能起到举一反三的效果。

原文地址:https://www.cnblogs.com/FrankLongger/p/9650781.html

时间: 2024-10-11 10:58:10

svg文字描边动画的相关文章

SVG实现描边动画

说起SVG,我是恨它又爱它,恨它是因为刚开始接触的时候自己傻B地想用代码去写它,其实在web上我们用它做交互也只是用了几个常用的特性而已,其他的标签知道这么一回事就成了,其实说白了它就是一种图片格式,你得去画它,网站上最长用的SVG交互效果就是描边动画了,今天就来实现它 先上效果图: 思路:要实现这种动画,我们要使用的是SVG的路径path标签,其中然后配合两个属性:stroke-dasharray和stroke-dashoffset,至于用什么方式实现动画效果就八仙过海了,我这里使用的是css

使用snapjs实现svg路径描边动画

一,snap.svg插件在近几天,突然接到一个需求,内容是要在网页上写一个路径的动画,还需要可以随意控制动画的速度,开始于结束,本来是一个图片可以解决的问题,结果就这样变难了呀,在网上查一会之后,突然就发现了svg,他有两个神奇属性stroke-dasharray(控制虚线和空白大小)和stroke-dashoffset(控制虚线偏移),通过改变stroke-dashoffset便可以轻松实现路径动画. 路径是这样滴  一开始没有注意后边路径上的阴影,我写到阴影时候才发现,svg的阴影竟然是用矩

segment-实现SVG路径描边绘制与动画的轻量库

今天来一起了解一个实现SVG路径描边绘制与动画的轻量级类库segment,我们从轻松上手.使用详解.资源和案例.源码解读等几个方面进行介绍. 1. 轻松上手 html方面添加segment,定义path. <script src="/dist/segment.min.js"></script> <svg> <path id="my-path" ...> </svg> JS方面利用path实例化一个segme

超酷创意分段式SVG文字动画特效

这是一款基于segment.js制作的非常有创意的分段式SVG文字动画特效.这个文字动画特效通过动画SVG的描边路径来制作各种文字的动画效果,效果非常的赞. 这个SVG文字动画特效的第一个DEMO中的最后几个例子使用了mo.js插件,一款由Oleg Solomka编写的用于制作网页图形动画的JavaScript库插件.通过mo.js,可以制作出效果更为震撼的文字动画效果. 在线预览   源码下载 特效中使用的字体是exquisite lowercase font,一套极富创意的WEB字体. 使用

SVG描边动画原理

SVG描边动画原理其实很简单,主要利用以下两个属性 stroke-dasharray 制作虚线,使得黑白相间, stroke-dashoffset 使得虚线向开头偏移,这里的1500不精确,是我随便取的,下文介绍通过JS获取长度. 动画就是减少虚线偏移,那么实线就会慢慢漏出来了 JS获取长度 var path = document.querySelector('path'); var length = path.getTotalLength(); 然后改变path.style.strokeDas

超级强大的SVG SMIL animation动画详解

本文花费精力惊人,具有先驱前瞻性,转载规则以及申明见文末,当心予以追究.本文地址:http://www.zhangxinxu.com/wordpress/?p=4333 //zxx: 本文的SVG在有缓存时候是无动画效果,此时您可以试着[右键-新标签页打开图片]. 一.SVG SMIL animation概览 1. SMIL是什么?SMIL不是指「水蜜梨」,而是Synchronized Multimedia Integration Language(同步多媒体集成语言)的首字母缩写简称,是有标准

自定义进度条\文字描边样式\文字上下滚动TextSwithcher的应用

一.自定义进度条 1.<ProgressBar         android:id="@+id/patch_progress"         style="@style/gxProgressStyle"         android:layout_width="match_parent"         android:layout_height="12dp"         android:layout_alig

用svg制作loading动画

首先说明:由于各浏览器对svg动画事件支持不统一,此loading动画在Firefox,Opera,Chrome中均没有问题,IE和Safari中有问题,可能是不支持SIML写动画的语法, 但是用Canvas写的话,在颜色的渐变方面会有问题: 线性渐变需要传递四个参数 xstart:渐变开始点x坐标       ystart:渐变开始点y坐标       xEnd:渐变结束点x坐标       yEnd:渐变结束点y坐标 这样画出来的渐变只能用于矩形之类的图形,无法应用在诸如扇形内,此loadi

ps怎么给文字描边

在设计的时候,单一的文字,往往对人没有多少的吸引力,这就需要我们在文字上加一些文字特效,比如说外发光,描边,投影,等等.在这里我们详细的介绍一下文字的输入,和文字描边的怎么增加,删除的经验.(这些方法不只适用于文字,图片也可以的) 步骤阅读 百度经验:jingyan.baidu.com 工具/原料 电脑 photoshop 百度经验:jingyan.baidu.com 方法/步骤 1 首先我们要新建一个图层,文件>新建,建一个属于自己的文档. 步骤阅读 2 然后利用左侧的T(文字工具),输入自己