svg描边动画是根据stroke-dasharray
或者stroke-dashoffset
变化来实现的:
如果我们画一个矩形:
<rect x="10" y="10" width="100" height="50" fill="none" stroke="red"/>
data:image/s3,"s3://crabby-images/18c96/18c96df32eeffac7a5324f9358ddbcedcf47f2a8" alt=""
stroke-dasharray,一个或两个甚至多个参数,一个参数代表虚线和间隙宽度,两个以及多个参数时分别代表一个虚线一个间隙如此重复
<rect x="10" y="10" width="100" height="50" fill="none" stroke="red" stroke-dasharray="5"/>
<rect x="10" y="70" width="100" height="50" fill="none" stroke="red" stroke-dasharray="10,10"/>
<rect x="10" y="130" width="100" height="50" fill="none" stroke="red" stroke-dasharray="10,5,5,15"/>
data:image/s3,"s3://crabby-images/3b1a2/3b1a2a4445d22efbde4ea25572551757b2a587ec" alt=""
可以css操作
stroke-dasharray
属性的值来做动画效果:
css:
.ani{
animation: aniMove 1s ease both;
}
@keyframes aniMove {
0%{
stroke-dasharray:0,10
}
100%{
stroke-dasharray:10,10
}
}
<rect class="ani" x="10" y="70" width="100" height="50" fill="none" stroke="red" />
data:image/s3,"s3://crabby-images/37aca/37acad052f417b44106be38e9418969657ff664e" alt=""
同样道理操作path路径描边就可以实现svg图片的描边效果:
data:image/s3,"s3://crabby-images/16841/16841d7e250d85edf3c16ee158acc365631d2dcf" alt=""
在进行路径描边动画之前我们需要获取到动画路径的长度,然后根据长度进行css操作:
let obj = document.querySelectorAll("path");
obj.forEach((item)=>{
console.log(item.getTotalLength())
})
css:
.cls-2{
animation: lineMove 3s ease-out;
}
@keyframes lineMove {
0%{
stroke-dasharray: 0, 70.71565246582031;
}
100%{
stroke-dasharray: 70.71565246582031, 70.71565246582031;
}
}
如何将png图片转为svg矢量图(带path路径)呢?
可以利用AI软件转换:
data:image/s3,"s3://crabby-images/0173c/0173c5887165c7a2448036a60ca8887eed78cc41" alt=""
利用AI软件打开png图片,点击图像描摹下拉框选择高保真度图片,然后导出为SVG格式即可:
data:image/s3,"s3://crabby-images/aeec9/aeec953e5012a0ed1b0d6981c511d4165d4ec6d1" alt=""
点击显示代码就可以看到具体代码了,选择确定也是一样的。
注意红框内最好修改为英文
,这里我的path路径都是填充了,后边为了做描边效果修改为了stroke。data:image/s3,"s3://crabby-images/05752/057525abdd1854c43eac42102ef1d8e598f1f28c" alt=""
over
网友评论