HTML制作一个太阳、地球、月球之间的绕转动画

2024-06-12 09:12

本文主要是介绍HTML制作一个太阳、地球、月球之间的绕转动画,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大家好,今天制作一个太阳、地球、月球之间的绕转动画!

先看具体效果:
在这里插入图片描述

要制作一个太阳、地球、月球之间的绕转动画,我们需要结合HTML、CSS和JavaScript。由于CSS动画和JavaScript动画各有优缺点,这里我将给出一个使用CSS关键帧动画(@keyframes)的例子,来模拟太阳、地球和月球的绕转。

首先,我们需要在HTML中定义太阳、地球和月球的元素:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>太阳系绕转动画</title>
<link rel="stylesheet" href="styles.css">
</head>
<body><div class="solar-system"><div class="sun"></div><div class="earth-orbit"><div class="earth"><div class="moon-orbit"><div class="moon"></div></div></div></div>
</div></body>
</html>

接下来,在CSS中定义样式和动画:

body {  margin: 0;  display: flex;  justify-content: center;  align-items: center;  height: 100vh;  background: radial-gradient(circle, #fff, #000); /* 渐变背景 */  overflow: hidden;  
}  /* styles.css */  
.solar-system {  position: relative;  width: 400px;  height: 400px;  margin: 0 auto;  
}  .sun {  position: absolute;  width: 100px;  height: 100px;  background: yellow;  border-radius: 50%;  top: 50%;  left: 50%;  transform: translate(-50%, -50%);  box-shadow: 0 0 50px yellow, 0 0 100px yellow, 0 0 150px yellow; /* 增加光影效果 */  
}  .earth-orbit {  position: absolute;  top: 50%;  left: 50%;  width: 300px;  height: 300px;  border: 1px solid #ccc;  border-radius: 50%;  animation: earthOrbit 10s linear infinite;  transform-origin: 50% 200px; /* 这里的值取决于你的设计,这里假设太阳中心到地球轨道的距离为200px */  border: none; /* 去掉边框,用阴影代替 */  box-shadow: 0 0 50px rgba(0, 0, 255, 0.5); /* 轨道的阴影效果 */  animation: earthOrbit 12s cubic-bezier(0.55, 0.085, 0.68, 0.53) infinite; /* 更复杂的动画缓动函数 */
}  @keyframes earthOrbit {  from {  transform: rotate(0deg) translateX(-50%) translateY(-50%);  }  to {  transform: rotate(360deg) translateX(-50%) translateY(-50%);  }  
}  .earth {  position: absolute;  top: 50%;  left: 50%;  width: 50px;  height: 50px;  background: blue;  border-radius: 50%;  transform: translate(-50%, -50%);  animation: earthRotation 10s linear infinite;  box-shadow: 0 0 10px rgba(0, 0, 255, 0.8); /* 地球的阴影效果 */
}  @keyframes earthRotation {  from {  transform: translate(-50%, -50%) rotate(0deg);  }  to {  transform: translate(-50%, -50%) rotate(360deg);  }  
}  .moon-orbit {  position: absolute;  top: 50%;  left: 50%;  width: 70px; /* 根据实际情况调整月球轨道大小 */  height: 70px;  border: 1px solid #999;  border-radius: 50%;  animation: moonOrbit 5s linear infinite;  transform-origin: 50% 100%; /* 这里的值取决于你的设计,这里假设地球中心到月球轨道的距离为月球轨道半径 */  box-shadow: 0 0 20px rgba(128, 128, 128, 0.5); /* 月球轨道的阴影效果 */  animation: moonOrbit 7s linear infinite; /* 月球轨道的动画时间可以不同于地球 */ 
}  @keyframes moonOrbit {  from {  transform: rotate(0deg) translateX(-50%) translateY(-50%);  }  to {  transform: rotate(360deg) translateX(-50%) translateY(-50%);  }  
}  .moon {  position: absolute;  top: 50%;  left: 50%;  width: 20px;  height: 20px;  background: gray;  border-radius: 50%;  transform: translate(-50%, -50%);  box-shadow: 0 0 5px rgba(128, 128, 128, 0.8); /* 月球的阴影效果 */  
}

这个例子中,.earth-orbit.moon-orbit 分别代表地球和月球的轨道,它们分别围绕

注意事项

  1. 渐变背景:使用radial-gradient为页面添加了从白色到黑色的渐变背景,使整体效果更加炫酷。
  2. 光影效果:通过box-shadow属性为太阳、地球和月球添加了光影效果,使它们看起来更加立体和真实。
  3. 复杂的轨道动画:可以调整动画的缓动函数(如cubic-bezier)来创建更复杂的轨道动画效果。也可以添加更多的关键帧来模拟椭圆轨道或其他复杂轨迹。
  4. 动画时间:地球和月球的轨道动画时间可以不同,以模拟它们实际绕转速度的差异。
  5. 其他行星和卫星:可以类似地添加其他行星和卫星的轨道和动画效果,以构建更完整的太阳系模型。

这篇关于HTML制作一个太阳、地球、月球之间的绕转动画的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1053790

相关文章

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

使用Python制作一个PDF批量加密工具

《使用Python制作一个PDF批量加密工具》PDF批量加密‌是一种保护PDF文件安全性的方法,通过为多个PDF文件设置相同的密码,防止未经授权的用户访问这些文件,下面我们来看看如何使用Python制... 目录1.简介2.运行效果3.相关源码1.简介一个python写的PDF批量加密工具。PDF批量加密

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

Qt QWidget实现图片旋转动画

《QtQWidget实现图片旋转动画》这篇文章主要为大家详细介绍了如何使用了Qt和QWidget实现图片旋转动画效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、效果展示二、源码分享本例程通过QGraphicsView实现svg格式图片旋转。.hpjavascript