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

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

效果预览

904199386-5b6219ad4ab13_articlex.gif

代码解读

定义 dom,spacecraft 表示飞船,容器中包含 1 个表示尾冀的元素 fins

居中显示:

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 个子元素:

定义星星的样式:

.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-duration: calc(var(--duration) * 1s);    animation-delay: calc(var(--delay) * 1s);}.stars span:nth-child(1) {    --duration: 1;    --delay: -0.05;}.stars span:nth-child(2) {    --duration: 1.5;    --delay: -0.1;}.stars span:nth-child(3) {    --duration: 2;    --delay: -0.15;}.stars span:nth-child(4) {    --duration: 2.5;    --delay: -0.2;}

隐藏屏幕外的内容:

body {    overflow: hidden;}

接下来用 d3 批量处理表示星星的 dom 元素和 css 变量。
引入 d3 库:


用 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 变量 --duration--delay 赋值,--duration 的取值范围是 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('--duration', () => Math.random() * 2 + 1)    .style('--delay', (d) => d * -0.05);

刪除掉 html 文件中相关的 dom 声明和 css 文件中的变量声明。

最后,把星星的数量增加到 30 颗:

const COUNT_OF_STARS = 30;

大功告成!

相关文章推荐:

如何使用纯CSS实现一颗土星的效果

如何使用CSS和D3实现无尽六边形空间的效果

以上就是如何用CSS和D3实现宇宙飞船的动态效果的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1610920.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 01:51:20
下一篇 2025年12月24日 01:51:28

相关推荐

  • 如何解决移动端fixed元素不显示的问题

    这篇文章给大家介绍的内容是关于如何解决移动端fixed元素不显示的问题,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 上几周给公司app做了一个html5嵌套页面,页面并不复杂,展示内容较多,底部有footer html结构如下 .main{ position: absolute;…

    好文分享 2025年12月24日
    000
  • 如何使用CSS实现变色旋转动画的动态效果

    这篇文章给大家介绍的内容是关于如何使用css实现变色旋转动画的动态效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 代码解读 定义 dom,容器中包含 9 个元素: 居中显示: body { margin: 0; height: 100vh; display: flex…

    2025年12月24日
    000
  • CSS样式有哪几种?css样式表的三种方式总结(附代码)

    css样式有哪几种类型?css 样式代码插入的形式来看基本可以分为以下三种:内联式、嵌入式和外部式三种,这三种样式是有优先级的,他们的优先级是:内联式 > 嵌入式 > 外部式,下面我们就来看看css三种样式类型的具体内容及代码。 注意:嵌入式>外部式有一个前提:嵌入式css样式的位…

    2025年12月24日
    000
  • css中单位的使用:选择px还是rem

    这篇文章给大家介绍的文章内容是关于css中单位的使用:选择px还是rem,有很好的参考价值,希望可以帮助到有需要的朋友。 css中的单位很多,%、px、em、rem,以及比较新的vw、vh等。每个单位都有特定的用途,比如当需要设置一个矩形的宽高比为16:9,并且随屏幕宽度自适应时,除了用%,其他单位…

    2025年12月24日
    000
  • 什么是CSS BEM命名规范?BEM命名规范的总结(详细)

    bem 是block(块)、element(元素)和modifier(修饰符)的简写,它是一个很好用的命名约定。能够让你的前端代码变得更加容易理解和严密,接下来我们就来看一看bem命名规范具体是怎样的。 1 什么是 BEM 命名规范 Bem 是块(block)、元素(element)、修饰符(mod…

    好文分享 2025年12月24日
    000
  • 浅析CSS中background背景的用法

    这篇文章给大家介绍的文章内容是关于浅析css中background背景的用法,有很好的参考价值,希望可以帮助到有需要的朋友。 定义和用法 基本属性:color, image, position, repeat 背景颜色 background-color 值为颜色值或transparent二者选其一,…

    好文分享 2025年12月24日
    000
  • 如何使用CSS和D3实现无尽六边形空间的效果

    这篇文章给大家介绍的文章内容是关于如何使用css和d3实现无尽六边形空间的效果,有很好的参考价值,希望可以帮助到有需要的朋友。 效果预览 代码解读 定义 dom,容器中包含 1 个内含 5 个 的 : 居中显示: body { margin: 0; height: 100vh; display: f…

    2025年12月24日
    000
  • 如何使用纯CSS实现一颗土星的效果

    这篇文章给大家介绍的文章内容是关于如何使用纯css实现一颗土星的效果,有很好的参考价值,希望可以帮助到有需要的朋友。 效果预览 代码解读 定义 dom,容器本身表示土星星球,其中的 ring 元素表示土星环: 居中显示: body { margin: 0; height: 100vh; displa…

    2025年12月24日
    000
  • 视频演示:如何用CSS 创作一颗逼真的土星 ?(附代码)

    效果预览 按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。 https://codepen.io/comehope/pen/EpbaQX 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。 请用 chrome, safari, edge 打开观看。 立即学习“…

    2025年12月24日
    000
  • 实例讲解如何用CSS语言创作一根闪电连接线

    效果预览 按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。 https://codepen.io/comehope/pen/RBjdzZ 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。 请用 chrome, safari, edge 打开观看。 立即学习“…

    2025年12月24日
    000
  • css如何自定义滚动条(代码)

    本篇文章给大家分享的是关于css如何自定义滚动条(代码),内容很不错,有需要的朋友可以参考一下,希望可以帮助到大家。 html↓ css↓ .test { display: inline-block; margin: 60px 40%; width: 280px; padding: 5px 4px;…

    2025年12月24日
    000
  • css和js如何实现响应式导航菜单

    这篇文章分享给大家的内容是关于css和js如何实现响应式导航菜单,内容很有参考价值,希望可以帮到有需要的小伙伴。 1.响应式导航菜单 当视口大于640px的时候,导航条会显示在外,当视口小于768px的时候,导航菜单需要隐藏起来!代码如下: 响应式 首页 产品 购买 服务 联系 var btn=do…

    好文分享 2025年12月24日
    000
  • CSS实现响应式布局的方法

    这篇文章分享给大家的内容是关于css实现响应式布局的方法,内容很有参考价值,希望可以帮到有需要的小伙伴。 用CSS实现响应式布局 响应式布局感觉很高大上,很难,但实际上只用CSS也能实现响应式布局要用的就是CSS中的没接查询,下面就介绍一下怎么运用: 使用@media 的三种方法 1.直接在CSS文…

    2025年12月24日
    000
  • 关于css响应式的实现代码及效果

    这篇文章分享给大家的内容是关于css响应式的实现代码及效果,内容很有参考价值,希望可以帮到有需要的小伙伴。 1.CSS 来实现响应式 CSS实现响应式网站的布局要用到的就是CSS中的媒体查询接下来来简单介绍一下: @media 类型 and (条件1) and (条件二){css样式} 我们只需用到…

    2025年12月24日
    000
  • css关于浏览器兼容问题的解析

    这篇文章分享给大家的内容是关于css关于浏览器兼容问题的解析,内容很有参考价值,希望可以帮到有需要的小伙伴。 一、火狐1. 失效hack:采用jquery UI:datepicker插件。(1)下载插件,放置在项目文件夹中;(2)在所需页面引入,如: 此script与页面所需的对应的js位置不分先后…

    好文分享 2025年12月24日
    000
  • 如何理解BFC-块格式化上下文(图文)

    本篇文章分享给大家的内容是关于如何理解bfc-块格式化上下文(图文),内容很详细,接下来我们就来看看具体的内容,希望可以帮助到大家。 BFC概念 BFC(block formatting context)块格式化上下文, 是Web页面块级元素布局及浮动元素彼此交互的区域。BFC是一个独立的布局环境,…

    2025年12月24日 好文分享
    000
  • 如何用纯CSS实现动态行驶的火车

    这篇文章给大家介绍的文章内容是关于如何用纯css实现正在行驶中的火车,有很好的参考价值,希望可以帮助到有需要的朋友。 效果预览 代码解读 定义 dom,容器中包含 2 个元素,train 代表火车,track 代表铁轨,其中包含的 3 个 代表 3 根枕木。 居中显示: body{ margin: …

    2025年12月24日
    000
  • 如何使用CSS实现单元素点阵loader的效果

    这篇文章主要介绍了关于如何使用css实现单元素点阵loader的效果,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-end-daily-challe…

    2025年12月24日
    000
  • 如何使用纯CSS实现一台咖啡机的效果

    这篇文章主要介绍了关于如何使用纯css实现一台咖啡机的效果,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-end-daily-challenges …

    2025年12月24日
    000
  • 如何用纯CSS实现卡通鹦鹉的效果

    这篇文章主要介绍了关于如何用纯css实现卡通鹦鹉的效果,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-end-daily-challenges 代码…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信