效果预览

在线演示

按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。

https://codepen.io/comehope/pen/xJdVxx

可交互视频

此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。

请用 chrome, safari, edge 打开观看。

https://scrimba.com/p/pEgDAM/cP6LRSk

源代码下载

本地下载

每日前端实战系列的全部源代码请从 github 下载:

https://github.com/comehope/front-end-daily-challenges

代码解读

定义 dom,容器中包含 3 个元素,每个元素代表组成火焰的 1 个火苗:

<div class="flame">
<span></span>
<span></span>
<span></span>
</div>

居中显示:

body {
margin: 0;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(black, maroon);
}

定义容器尺寸:

.flame {
width: 10em;
height: 12em;
font-size: 24px;
}

画出火苗:

.flame {
position: relative;
} .flame span {
position: absolute;
width: 5em;
height: 5em;
background: radial-gradient(
orangered 20%,
rgba(255, 69, 0, 0) 70%
);
border-radius: 50%;
bottom: 0;
}

用变量画出多个火苗,其中 --particles 是火苗的数量:

.flame {
--particles: 3;
} .flame span {
left: calc((var(--n) - 1) * 5em / var(--particles));
} .flame span:nth-child(1) {
--n: 1;
} .flame span:nth-child(2) {
--n: 2;
} .flame span:nth-child(3) {
--n: 3;
}

修改混合模式,使火苗重叠的部分变亮:

.flame span {
mix-blend-mode: screen;
}

增加火焰升腾的动画效果:

.flame span {
animation: rise 1s ease-in infinite;
} @keyframes rise {
from {
transform: translateY(0) scale(1);
filter: opacity(0);
} 25% {
filter: opacity(1);
} to {
transform: translateY(-10em) scale(0);
filter: opacity(0);
}
}

用变量设置火苗升起的延时时间,使火苗陆续升起:

.flame span {
animation-delay: calc(var(--rnd) * 1s);
} .flame span:nth-child(1) {
--n: 1;
--rnd: 0.1234;
} .flame span:nth-child(2) {
--n: 2;
--rnd: 0.3456;
} .flame span:nth-child(3) {
--n: 3;
--rnd: 0.6789;
}

接下来用 d3 来批量处理 dom。
引用 d3 库:

<script src="https://d3js.org/d3.v5.min.js"></script>

用 d3 为 css 中的 --particles 变量赋值:

const COUNT_OF_PARTICLES = 3;

d3.select('.flame')
.style('--particles', COUNT_OF_PARTICLES);

用 d3 创建 dom 中的火苗元素:

d3.select('.flame')
.style('--particles', COUNT_OF_PARTICLES)
.selectAll('span')
.data(d3.range(COUNT_OF_PARTICLES))
.enter()
.append('span');

用 d3 为火苗元素的 css 中的 --n 和 --rnd 变量赋值:

d3.select('.flame')
.style('--particles', COUNT_OF_PARTICLES)
.selectAll('span')
.data(d3.range(COUNT_OF_PARTICLES))
.enter()
.append('span')
.style('--n', (d) => d + 1)
.style('--rnd', () => Math.random());

删除掉 dom 中的火苗元素,删除掉 css 中的变量声明。

最后,把火苗元素设置为 100 个,形成火焰效果:

const COUNT_OF_PARTICLES = 100;

大功告成!

原文地址:https://segmentfault.com/a/1190000015740846

如何用 CSS 和 D3 创作火焰动画的更多相关文章

  1. 如何用 CSS 和 D3 创作旋臂粒子动画

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/xJrOqd 可交互视频 ...

  2. 前端每日实战:89# 视频演示如何用 CSS 和 D3 创作旋臂粒子动画

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/xJrOqd 可交互视频 此视频是可 ...

  3. 如何用 CSS 和 D3 创作一个无尽的六边形空间

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/NBvrWL 可交互视频 此视频是可 ...

  4. 如何用纯 CSS 和 D3 创作一艘遨游太空的宇宙飞船

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/oMqNmv 可交互视频 ...

  5. 前端每日实战:96# 视频演示如何用纯 CSS 和 D3 创作一艘遨游太空的宇宙飞船

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/oMqNmv 可交互视频 此视频是可 ...

  6. 如何用纯 CSS 和 D3 创作一只扭动的蠕虫

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/QBQJMg 可交互视频 ...

  7. 前端每日实战:133# 视频演示如何用 CSS 和 GSAP 创作有多个关键帧的连续动画

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/eLMKJG 可交互视频 此视频是可 ...

  8. 前端每日实战:134# 视频演示如何用 CSS 和 GSAP 创作一个树枝发芽的 loader

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/LJmpXZ 可交互视频 此视频是可 ...

  9. 用 CSS 实现酷炫的动画充电效果

    巧用 CSS 实现酷炫的充电动画 循序渐进,看看只使用 CSS ,可以鼓捣出什么样的充电动画效果. 画个电池 当然,电池充电,首先得用 CSS 画一个电池,这个不难,随便整一个: 欧了,勉强就是它了. ...

随机推荐

  1. CUBE 隐藏维度中的Unknown

     纬度,属性里面有个unknowmember设置为hidden   

  2. node-amqp 使用fanout发布订阅rabbitmq消息

    publisher代码 const amqp = require('amqp'); let option = { host: 'server-ip', port: 5672, login: 'gues ...

  3. HDP和包围曝光

    摄影笔记:http://mp.weixin.qq.com/s/6xgTtAcLAPkWY9FjqrfvtA 我们通过观察直方图曝光,尽量要直方图两边的纯黑和纯白区域不要有信息,就是亮的地方不死白,暗的 ...

  4. storm中的topology-worker-executor-task

    调度角色 调度方法 自定义调度 1 调度角色   任务角色结构 上图是JStorm中一个topology对应的任务执行结构,其中worker是进程,executor对应于线程,task对应着spout ...

  5. <img/>标签属性

    属性        属性值               描述 src            url               图像的路径 alt             文本            ...

  6. js获取当前的年月日时分秒周期

    function timeNow(){ var date = new Date(); this.year = date.getFullYear(); this.month = date.getMont ...

  7. CSS font-family 字体名称一览表

    windows常见内置中文字体 字体中文名 字体英文名 宋体                      SimSun(浏览器默认) 黑体                      SimHei 微软雅 ...

  8. Android篇---Styles和Themes常见用法可能疑点小结

    1.style和theme的区别: 简而言之,style指的就是安卓中一个UI控件的样式,而themes指的是安卓中一个activity界面或者整个安卓应用整体的样式.theme的范围比style的范 ...

  9. CRC检错技术原理

    一.题外话 说来惭愧,一开始是考虑写关于CRC检错技术更深层次数学原理的,然而在翻看<Basic Algebra>后,我果断放弃了这种不切实际的想法.个人觉得不是因为本人数学水平差或者能力 ...

  10. SQL Server数据库log shipping 灾备(Part1 )

    1.概述 Log Shipping为SQL Server提供的数据库备份过程.它可以将数据库整个复制到另一台服务器上.在这种情况下,交易日志也会定期发送到备份服务器上供恢复数据使用,这使得服务器一直处 ...