css animation配合SVG制作能量流动效果


Posted in HTML / CSS onMarch 24, 2021

最终效果如下:

css animation配合SVG制作能量流动效果

动画分成两步

  • 制定运行轨迹
  • 创建DOM并按照轨迹动画

制定运行轨迹

我们先要画一条底部的淡蓝色半透明路劲做为能量流动的管道
这里用SVG的path去做(其实这里可以直接用背景图), 代码如下:

<!-- 代码是用react写的, 删除了遍历以及部分代码 -->
 
<svg>
    <!-- 工具描述提示符,被用在fill里做过滤等操作,这里是小球底部的发光 -->
    <defs>
        <radialGradient id="grad1" cx="50%" cy="50%" r="50%" fx="50%" fy="50%">
            <stop offset="0%" style={{ stopColor: "rgba(2,246,255,.5)" }} />
            <stop offset="100%" style={{ stopColor: "rgba(2,246,255,0)" }} />
        </radialGradient>
    </defs>
    <!-- 这里遍历N个淡蓝色线条路径 d为路径-->
    <path d={item.path} stroke="rgba(29,159,167,0.4)" fill="transparent" strokeWidth={5}></path>
    ...
    <!-- 这里是发光小球 通过两个圆叠加形成 -->
    <g>
        <circle cx={cx} cy={cy} r="15" fill="url(#grad1)"></circle>
        <circle cx={cx} cy={cy} r="5" fill="rgba(2,246,255)"></circle>
    </g>
</svg>

创建DOM并按照轨迹动画

这里的核心原理通过offset-path这个属性设置运动偏移路径,再通过offset-distance来设置偏移量,这样通过css3 animation就可以让元素按照一定的轨迹运动

<!-- 这里要保证盒子跟SVG的盒子位置重合,宽高一致,这样路径点才能一致 -->
<div className={styles.animate}>
    <!-- 这里遍历N个div,让每一个div都按照offsetPath也就是svg内path的d的值进行流动 -->
    <!-- animationDelay 负数表示渲染前就已经执行, 渲染时就可以铺满整个路径 -->
    <div key={index} className={styles.point3} style={{ "offsetPath": "path('M 105 34 L 5 34')", "animationDelay": `-${index * 1}s`, "animationDuration": '5s', 'animationPlayState': `${stop ? 'paused' : 'running'}` }}></div>
    ...
</div>
.point3 {
    width: 10px;
    height: 2px;
    // offset-path: path('M 248 108 L 248 172 L 1510 172');
    offset-distance: 0%;
    animation: flow 20s linear normal infinite;
    background-image: linear-gradient(to right, rgba(255, 255, 255, 0) 10%, #FEFE02);
    position: absolute;
    left: 0;
    right: 0;
}
}
 
@keyframes flow {
    from {
        offset-distance: 0%;
    }
 
    to {
        offset-distance: 100%;
    }
}

 

HTML / CSS 相关文章推荐
纯CSS3实现圆角效果(含IE兼容解决方法)
May 07 HTML / CSS
深入浅析css3 border-image边框图像详解
Nov 24 HTML / CSS
实例讲解CSS3中Transform的perspective属性的用法
Apr 22 HTML / CSS
css3 边框、背景、文本效果的实现代码
Mar 21 HTML / CSS
HTML5之SVG 2D入门3—文本与图像及渲染文本介绍
Jan 30 HTML / CSS
HTML5实现的图片无限加载的瀑布流效果另带边框圆角阴影
Mar 07 HTML / CSS
Html5 语法与规则简要概述
Jul 29 HTML / CSS
HTML5学习心得总结(推荐)
Jul 08 HTML / CSS
HTML利用九宫格原理进行网页布局
Mar 13 HTML / CSS
html5 拖拽及用 js 实现拖拽功能的示例代码
Oct 23 HTML / CSS
Html5通过数据流方式播放视频的实现
Apr 27 HTML / CSS
CSS font-variation 可变字体的魅力(实例详解)
Mar 03 HTML / CSS
如何通过 CSS 写出火焰效果
Html5移动端div固定到底部实现底部导航条的几种方式
Mar 09 #HTML / CSS
HTML5拖拽文件上传的示例代码
Mar 04 #HTML / CSS
html5使用window.postMessage进行跨域实现数据交互的一次实战
Feb 24 #HTML / CSS
Canvas在超级玛丽游戏中的应用详解
Feb 06 #HTML / CSS
Html5移动端网页端适配(js+rem)
Feb 03 #HTML / CSS
使用HTML和CSS实现的标签云效果(附demo)
Feb 03 #HTML / CSS
You might like
php性能优化分析工具XDebug 大型网站调试工具
2011/05/22 PHP
php四种定界符详解
2017/02/16 PHP
使用php自动备份数据库表的实现方法
2017/07/28 PHP
javascript跨域的方法汇总
2015/10/23 Javascript
Nodejs中session的简单使用及通过session实现身份验证的方法
2016/02/04 NodeJs
模拟javascript中的sort排序(简单实例)
2016/08/17 Javascript
Javascript中this绑定的3种方法与比较
2016/10/13 Javascript
vue.js选中动态绑定的radio的指定项
2017/06/02 Javascript
原生js通过一行代码实现简易轮播图
2019/06/05 Javascript
微信小程序判断用户是否需要再次授权获取个人信息
2019/07/18 Javascript
BootstrapValidator验证用户名已存在(ajax)
2019/11/08 Javascript
[40:19]完美世界DOTA2联赛PWL S3 Rebirth vs CPG 第二场 12.18
2020/12/19 DOTA
python Django连接MySQL数据库做增删改查
2013/11/07 Python
python读取几个G的csv文件方法
2019/01/07 Python
python计算阶乘和的方法(1!+2!+3!+...+n!)
2019/02/01 Python
Python实现简单查找最长子串功能示例
2019/02/26 Python
django的settings中设置中文支持的实现
2019/04/28 Python
python搜索包的路径的实现方法
2019/07/19 Python
python列表删除和多重循环退出原理详解
2020/03/26 Python
python中的split、rsplit、splitlines用法说明
2020/10/23 Python
使用Python提取文本中含有特定字符串的方法示例
2020/12/09 Python
css3 transform属性详解
2014/09/30 HTML / CSS
CSS3 分类菜单效果
2019/05/27 HTML / CSS
Grid 宫格常用布局的实现
2020/01/10 HTML / CSS
HTML5通用接口详解
2016/06/12 HTML / CSS
丝芙兰墨西哥官网:Sephora墨西哥
2020/05/30 全球购物
年终晚会主持词
2014/03/25 职场文书
销售团队口号大全
2014/06/06 职场文书
卫生院健康教育实施方案
2014/06/07 职场文书
反腐倡廉标语
2014/06/24 职场文书
解除劳动合同证明书
2014/09/26 职场文书
重阳节活动主持词
2015/07/04 职场文书
英语导游欢迎词
2015/09/30 职场文书
转变工作作风心得体会
2016/01/23 职场文书
Pytest实现setup和teardown的详细使用详解
2021/04/17 Python
利用Python实时获取steam特惠游戏数据
2022/06/25 Python