经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 软件/图像 » SVG » 查看文章
css animation配合SVG制作能量流动效果_CSS教程_CSS
来源:jb51  时间:2021/3/8 11:19:24  对本文有异议

最终效果如下:

动画分成两步

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

制定运行轨迹

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

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

创建DOM并按照轨迹动画

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

  1. <!-- 这里要保证盒子跟SVG的盒子位置重合,宽高一致,这样路径点才能一致 -->
  2. <div className={styles.animate}>
  3. <!-- 这里遍历N个div,让每一个div都按照offsetPath也就是svg内path的d的值进行流动 -->
  4. <!-- animationDelay 负数表示渲染前就已经执行, 渲染时就可以铺满整个路径 -->
  5. <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>
  6. ...
  7. </div>
  1. .point3 {
  2. width: 10px;
  3. height: 2px;
  4. // offset-path: path('M 248 108 L 248 172 L 1510 172');
  5. offset-distance: 0%;
  6. animation: flow 20s linear normal infinite;
  7. background-image: linear-gradient(to right, rgba(255, 255, 255, 0) 10%, #FEFE02);
  8. position: absolute;
  9. left: 0;
  10. right: 0;
  11. }
  12. }
  13.  
  14. @keyframes flow {
  15. from {
  16. offset-distance: 0%;
  17. }
  18.  
  19. to {
  20. offset-distance: 100%;
  21. }
  22. }

到此这篇关于css animation配合SVG制作能量流动效果的文章就介绍到这了,更多相关css animation配合SVG内容请搜索w3xue以前的文章或继续浏览下面的相关文章,希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号