SVG中stroke-dasharray及stroke-dashoffset属性

stroke-dasharray属性用来设置描边的点划线的图案范式。就是设置实线和虚线的宽度

比如:
stroke-dasharray: 50 20;
效果就是:
这里写图片描述
50和20分别对应了实线和虚线的长度

stroke-dashoffset则指定了dash模式到路径开始的距离,就是实线虚线绘制的起点距路径开始的距离

比如:
stroke-dashoffset: 30;
效果:
这里写图片描述
由于向左移动30像素,这样左边的实线就跟虚线一样长了。

我们可以设置stroke-dashoffsetstroke-dasharray相同的值实现“画线”的效果:
代码:

<style>
path{
    stroke-dasharray: 1000;
    stroke-dashoffset: 1000;
    animation: draw 5s ease 3;
}
@keyframes draw{
    0%{
        stroke-dashoffset: 1000;
    }
    100%{
        stroke-dashoffset: 0;
    }
}
</style>
<path d="M153 334
C153 334 151 334 151 334
C151 339 153 344 156 344
C164 344 171 339 171 334
C171 322 164 314 156 314
C142 314 131 322 131 334
C131 350 142 364 156 364
C175 364 191 350 191 334
C191 311 175 294 156 294
C131 294 111 311 111 334
C111 361 131 384 156 384
C186 384 211 361 211 334
C211 300 186 274 156 274"
style="fill:white;stroke:red;stroke-width:2"/>

由于实线起始距离从1000变为0,所以效果就是线在“绘图”一样。

效果:
这里写图片描述

关于stroke还有很多属性,参考:https://developer.mozilla.org/zh-CN/docs/Web/SVG/Tutorial/Fills_and_Strokes

本文参考:https://wcc723.github.io/svg/2014/06/15/svg-css-stroke-animation/

https://css-tricks.com/almanac/properties/s/stroke-dasharray/

https://css-tricks.com/almanac/properties/s/stroke-linecap/

https://stackoverflow.com/questions/46944523/how-to-change-start-point-of-svg-line-animation

  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值