问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

如何用CSS和D3实现宇宙飞船的动态效果

发布网友 发布时间:2023-08-12 10:49

我来回答

1个回答

热心网友 时间:2023-08-24 00:04


这篇文章给大家介绍的内容是关于如何用CSS和D3实现宇宙飞船的动态效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果预览
代码解读定义 dom,spacecraft 表示飞船,容器中包含 1 个表示尾冀的元素 fins:
<div class="spacecraft">
<div class="fins"></div>
</div>居中显示:
body {
margin: 0;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(black, midnightblue);
}画出飞船的船舱:
.spacecraft {
width: 7em;
height: 11em;
font-size: 16px;
background:
linear-gradient(whitesmoke, darkgray);
border-radius: 50% / 70% 70% 5% 5%;
}用伪元素画出飞船尾部的火焰:
.spacecraft::before {
content: '';
position: absolute;
width: 6em;
height: 2em;
background-color: #444;
border-radius: 20%;
top: 10em;
left: 0.5em;
z-index: -1;
}
.spacecraft::after {
content: '';
position: absolute;
box-sizing: border-box;
width: 4em;
height: 4em;
background: gold;
top: 10em;
left: 1.5em;
border-radius: 80% 0 50% 45% / 50% 0 80% 45%;
transform: rotate(135deg);
border: 0.5em solid orange;
z-index: -2;
}画出飞船两侧的尾冀:
.fins::before,
.fins::after {
content: '';
position: absolute;
width: 2em;
height: 6em;
background: linear-gradient(tomato, darkred);
top: 7em;
}
.fins::before {
left: -2em;
border-radius: 3em 0 50% 100%;
}
.fins::after {
right: -2em;
border-radius: 0 3em 100% 50%;
}用径向渐变画出飞船的舷窗:
.spacecraft {
background:
radial-gradient(
circle at 3.5em 5em,
transparent 1.5em,
lightslategray 1.5em, lightslategray 2em,
transparent 2em
),
radial-gradient(
circle at 3.3em 5.2em,
deepskyblue 1.4em,
transparent 1.6em
),
radial-gradient(
circle at 3.5em 5em,
white 1.5em,
transparent 1.5em
),
linear-gradient(whitesmoke, darkgray);
}增加飞船火焰喷射的动画效果:
.spacecraft::after {
animation: flame-spout 0.3s infinite;
}
@keyframes flame-spout {
0%, 100% {
filter: opacity(0.1);
}
50% {
filter: opacity(1);
}
}接下来画星空。
在 dom 中增加 stars 容器,其中包含表示星星的 4 个子元素:
<div class="stars">
<span></span>
<span></span>
<span></span>
<span></span>
</div>
<div class="rocket">
<div class="fins"></div>
</div>定义星星的样式:
.stars span {
position: absolute;
width: 2px;
height: 8px;
border-radius: 50%;
background-color: white;
top: calc(50% - 7em);
}用变量使星星分布在水平方向的不同位置:
.stars span {
left: calc(var(--left) * 1vw);
}
.stars span:nth-child(1) {
--left: 20;
}
.stars span:nth-child(2) {
--left: 40;
}
.stars span:nth-child(3) {
--left: 60;
}
.stars span:nth-child(4) {
--left: 80;
}用变量设置星星的尺寸和不透明度,使每颗星星看起来稍有差异:
.stars span {
width: calc(var(--size) * 1px);
height: calc(var(--size) * 4px);
filter: opacity(var(--opacity));
}
.stars span:nth-child(1) {
--size: 0.8;
--opacity: 0.5;
}
.stars span:nth-child(2) {
--size: 1.25;
--opacity: 0.6;
}
.stars span:nth-child(3) {
--size: 1.5;
--opacity: 0.7;
}
.stars span:nth-child(4) {
--size: 2;
--opacity: 0.8;
}定义星星从太空中飘过的动画效果:
.stars span {
top: -5vh;
animation: star-move linear infinite;
}
@keyframes star-move {
to {
top: 100vh;
}
}用变量设置动画的时长和延时时间:
.stars span {
animation-ration: calc(var(--ration) * 1s);
animation-delay: calc(var(--delay) * 1s);
}
.stars span:nth-child(1) {
--ration: 1;
--delay: -0.05;
}
.stars span:nth-child(2) {
--ration: 1.5;
--delay: -0.1;
}
.stars span:nth-child(3) {
--ration: 2;
--delay: -0.15;
}
.stars span:nth-child(4) {
--ration: 2.5;
--delay: -0.2;
}隐藏屏幕外的内容:
body {
overflow: hidden;
}接下来用 d3 批量处理表示星星的 dom 元素和 css 变量。
引入 d3 库:
<script src="https://d3js.org/d3.v5.min.js"></script>用 d3 创建表示星星的 dom 元素:
const COUNT_OF_STARS = 4;
d3.select('.stars')
.selectAll('span')
.data(d3.range(COUNT_OF_STARS))
.enter()
.append('span');用 d3 为 css 变量 --left, --size, --opacity 赋值,--left 的取值范围是 1 到 100,--size 的取值范围是 1 到 2.5,'--opacity' 的取值范围是 0.5 到 0.8:
d3.select('.stars')
.selectAll('span')
.data(d3.range(COUNT_OF_STARS))
.enter()
.append('span')
.style('--left', () => Math.ceil(Math.random() * 100))
.style('--size', () => Math.random() * 1.5 + 1)
.style('--opacity', () => Math.random() * 0.3 + 0.5);用 d3 为 css 变量 --ration 和 --delay 赋值,--ration 的取值范围是 1 到 3,--delay 的取值是依次减少 0.05:
d3.select('.stars')
.selectAll('span')
.data(d3.range(COUNT_OF_STARS))
.enter()
.append('span')
.style('--left', () => Math.ceil(Math.random() * 100))
.style('--size', () => Math.random() * 1.5 + 1)
.style('--opacity', () => Math.random() * 0.3 + 0.5)
.style('--ration', () => Math.random() * 2 + 1)
.style('--delay', (d) => d * -0.05);_除掉 html 文件中相关的 dom 声明和 css 文件中的变量声明。
最后,把星星的数量增加到 30 颗:
const COUNT_OF_STARS = 30;大功告成!
相关文章推荐:
如何使用纯CSS实现一颗土星的效果
如何使用CSS和D3实现无尽六边形空间的效果
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
小红书怎么修改ID 专属ID更改方法 Win11如何更改字体视觉效果 Win11字体视觉效果修改方法介绍 华为团队管理模式 通信工程这个专业主要是学什么 专注力差的孩子该如何纠正 三岁的孩子专注力不好,怎么培养她的专注力呀!。 镇江关周围有什么玩的,镇江及周边旅游景点 大港南站去镇江汽车站怎么走 镇江汽车站到大港南站有多远 出国去澳大利亚留学都需要注意哪些事项呢? 澳大利亚留学条件及注意事项有哪些 宽松裤与直筒裤有什么分别 ...她说暂时还没有想法,不好意思还加一个笑脸,她是什么意思?_百度... 请问大日本大正三十年的五十钱值钱吗 轮胎废料哪里回收 华擎b85极限玩家开机进不去系统,win7那四个点出来就黑屏了 华擎G31MVS2+R7350 黑屏 长相思反派是谁 长相思演员名单 长相思檀健次是男主吗 长相思的主演都有谁? 艾灸盒里烧出来的灰正常是什么颜色的? 艾灰是黑灰色的吗? 翡翠镯子里有气泡是什么意思 哈弗神兽升级失败全车断电启动不了怎么办 《画中有诗》提到了哪个成语中国诗词大会 睡觉时戴耳罩和眼罩对耳朵眼睛有什么伤害 小学教育专业就业方向是什么 陈学冬身高 660和99的最大公因数和最小公倍数 33和99的最小公倍数(用短除法) 求教:洛阳市哪个超市有卖那种罐头瓶装的甜玉米粒? 某公司在申请股票公开发行时,必须递交的文件有:( )。 A.发起人协议 B... 为什么光宗耀祖模式是游戏空间 有没有什么特别好吃、简单的甜品做法推荐呢? 从昭通鲁甸县到昭通市中心客运站怎么走? 空调制热耗电量是多少 夏季汽车怎样防晒 网上怎么查保安证真假? 怎么查询自己有没有保安证 小学五年级作文500字:美丽的天堂鸟 刚买了不到一周的天梭机械表出了问题能换新的吗? 厨卫电器品牌介绍,厨卫电器怎么选 你们的歌词 介休市一中录取分数线 介休一中录取三中人数 介休一中一个班多少人 2010年介休中考人数 考兽医资格证都考什么内容? 执业兽医资格证预防科目 水循环中水的物态变化