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属性box-sizing使用指南
Dec 09 HTML / CSS
使用CSS3创建动态菜单效果
Jul 10 HTML / CSS
使用CSS3中的calc()属性来以算式表达尺寸数值
Jun 06 HTML / CSS
HTML5+CSS3网页加载进度条的实现,下载进度条的代码实例
Dec 30 HTML / CSS
html5定制表单_动力节点Java学院整理
Jul 11 HTML / CSS
详解FireFox下Canvas使用图像合成绘制SVG的Bug
Jul 10 HTML / CSS
html5 音乐播放器 audio 标签使用概述
Jul 15 HTML / CSS
HTML5 embed标签定义和用法详解
May 09 HTML / CSS
简单介绍HTML5中的文件导入
May 08 HTML / CSS
详解如何用HTML5 Canvas API控制图片的缩放变换
Mar 22 HTML / CSS
HTML5 weui使用笔记
Nov 21 HTML / CSS
浅谈由position属性引申的css进阶讨论
May 25 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将对象转换成数组的方法(兼容多维数组类型)
2013/06/21 PHP
下拉列表多级联动dropDownList示例代码
2013/06/27 PHP
解析将多维数组转换为支持curl提交的一维数组格式
2013/07/08 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(十五)
2014/06/30 PHP
以文件形式缓存php变量的方法
2015/06/26 PHP
JS加ASP二级域名转向的代码
2007/05/17 Javascript
javascript之解决IE下不渲染的bug
2007/06/29 Javascript
基于jQuery的消息提示插件 DivAlert之旅(二)
2010/04/01 Javascript
js相册效果代码(点击创建即可)
2013/04/16 Javascript
Javascript合并表格中具有相同内容单元格示例
2013/08/11 Javascript
Javascript Objects详解
2014/09/04 Javascript
angularJS提交表单(form)
2015/02/09 Javascript
JavaScript搜索字符串并将搜索结果返回到字符串的方法
2015/04/06 Javascript
bootstrap栅格系统示例代码分享
2017/05/22 Javascript
详解Vue2.0 事件派发与接收
2017/09/05 Javascript
Vue 进阶之路(三)
2019/04/18 Javascript
利用原生JS实现欢乐水果机小游戏
2020/04/23 Javascript
js实现自定义滚动条的示例
2020/10/27 Javascript
python logging类库使用例子
2014/11/22 Python
python3.4用函数操作mysql5.7数据库
2017/06/23 Python
Python将多个excel文件合并为一个文件
2018/01/03 Python
Python 中的Selenium异常处理实例代码
2018/05/03 Python
Python基础之字符串操作常用函数集合
2020/02/09 Python
Python实现给PDF添加水印的方法
2021/01/25 Python
python自动化办公操作PPT的实现
2021/02/05 Python
Java servlet面试题
2012/03/04 面试题
应届大学毕业生找工作的求职信范文
2013/11/29 职场文书
竞争性谈判邀请书
2014/02/06 职场文书
外国人聘用意向书
2014/04/01 职场文书
优秀研究生主要事迹
2014/06/03 职场文书
中级会计大学生职业生涯规划书
2014/09/16 职场文书
青年文明号申报材料
2014/12/23 职场文书
感谢师恩主题班会
2015/08/17 职场文书
2016企业先进集体事迹材料
2016/02/25 职场文书
自荐信范文
2019/05/20 职场文书
导游词之临安白水涧
2019/11/05 职场文书