css动画模拟太阳地球月球运动轨迹示例

  发布时间:2023-05-10 14:31:13   作者:佚名   我要评论
这篇文章主要介绍了css动画模拟太阳地球月球运动轨迹示例,调整旋转中心有点困难,大家可以多尝试,先实现动画效果,看动画效果慢慢调整中心,需要的朋友可以参考下
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

先来看看效果吧~

1.结构分析

既然是用动画实现太阳地球月球的轨迹,那必然是太阳居中,地球围绕太阳转,与此同时月球围绕地球转,如下图(嘿嘿,凑合看吧),就应该使用一个大盒子(div),作为背景的太空,然后是太阳和地球,再把月亮嵌套进地球里面。以下代码使用汉语拼音来写类名,方便区分。

<div>
        <div class="beijing">
            <div class="taiyang"></div>
            <div class="diqiu">
                <div class="yueqiu"></div>
            </div>
        </div>
 </div>

2.css样式

然后先给背景,太阳,地球,月亮四个盒子分别设置自己的样式,将其设置为下面图片显示的情况(太阳居于中心的红色,黄色的是地球,而上面蓝色的是月亮),为其设置为圆形,背景颜色,和定位位置来达到这个效果,并且设置一下边框来使以后的动画效果轨迹更清晰可见。具体参考以下代码。

 .beijing {
        background-color: #93b5cf;
        margin: 0, auto;
        height: 400px;
        width: 400px;
        border: 1px black solid;
        border-radius: 50%;
        position: absolute;
        left: 50%;
        margin-left: -200px;
        top: 100px;
        /* background-image: url(?css/picture/xu.gif) */
    }
 
    .taiyang {
        background-color: red;
        height: 40px;
        width: 40px;
        border-radius: 50%;
        /* border: 1px black solid; */
        position: absolute;
        left: 50%;
        margin-left: -20px;
        top: 50%;
        margin-top: -20px;
    }
 
    .diqiu {
        background-color: yellow;
        height: 20px;
        width: 20px;
        border-radius: 50%;
        position: absolute;
        left: 50%;
        margin-left: -10px;
        margin-top: -10.5px;
        transform-origin: 10px 210.5px;
    }
 
    .yueqiu {
        background-color: rgb(47, 0, 255);
        height: 10px;
        width: 10px;
        border-radius: 50%;
        position: absolute;
        left:50%;
        margin-left: -5px;
        margin-top: -10px;
        transform-origin: 5px 20px;
    }

3.动画设置

首先我们要实现地球围绕太阳转的效果,太阳居中心不动,地球的旋转中心改成太阳的位置,然后围绕太阳做旋转动画(transform:rotate(?deg);)。使用transform-origin来调整旋转的中心,具体位置调整参考css样式内代码。

调整旋转中心有点困难,大家可以多尝试,先实现动画效果,看动画效果慢慢调整中心。

月球围绕地球旋转与上同理。

然后我们为其设置鼠标移入的事件效果,在鼠标移入时候,地球就会围绕太阳转,同时月球围绕地球转。记得设置过渡( transition: 7s linear;)。

 
    .beijing:hover > .diqiu {
        transform:rotate(360deg);
        transition: 7s linear;
    }
    .beijing:hover .yueqiu{
        transform: rotate(360deg);
        transition: 7s linear;
    }

这段效果也可以使用css逐帧动画来写。

 @keyframes run{
        0%{
            transform:rotate(0deg);
        }
        100%{
            transform:rotate(360deg);
        }
    }

在css样式地球和月球里面加上下面代码引用动画效果:

        animation: run 6s  infinite;
 

有能力可以写出银河系星系围绕太阳旋转的动画,记得更改样式,设置相应的星星大小颜色背景,配合动画效果,就可以做出很漂亮的星空了。

 

到此这篇关于css动画模拟太阳地球月球运动轨迹示例的文章就介绍到这了,更多相关css动画模拟地球公转轨迹内容请搜索程序员之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持程序员之家!

相关文章

  • CSS实现奔跑的北极熊动画

    这篇文章主要介绍了CSS实现奔跑的北极熊动画,css动画还是很有趣的,本文就用动画实现一个奔跑的北极熊,感兴趣的小伙伴一起来看看吧,需要的朋友可以参考下
    2023-05-10
  • css3鼠标滑过实现动画线条边框

    现如今网页越来越趋近于动画,相信大家平时浏览网页或多或少都能看到一些动画效果,今天我们做一个通过 css3 鼠标滑过实现动画线条边框,下面一起看看吧
    2023-02-22
  • CSS3 Tab动画实例之背景切换动态效果

    这篇文章主要介绍了CSS3 Tab动画实例之背景切换动态效果,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-08-20
  • CSS3常见动画的实现方式

    这篇文章主要介绍了CSS3常见动画的实现方式,帮助大家更好的理解和学习使用CSS3制作特效,感兴趣的朋友可以了解下
    2021-04-14
  • css3制作的背景渐变动画效果

    这篇文章主要介绍了css3实现的加载动画效果,帮助大家更好的利用css3制作网页,感兴趣的朋友可以了解下
    2021-04-07
  • css3实现的天气图标动画效果

    这篇文章主要介绍了css3实现的天气图标动画效果,帮助大家更好的利用css3制作网页,感兴趣的朋友可以了解下
    2021-04-06
  • CSS3通过var()和calc()函数实现动画特效

    这篇文章主要介绍了CSS3通过var()和calc()函数实现动画特效,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-29
  • CSS3过渡旋转透视2d3d动画等效果的实例代码

    这篇文章主要介绍了CSS3过渡旋转透视2d3d动画等效果的实例代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-18
  • 纯CSS3实现圆圈动态发光特效动画的示例代码

    这篇文章主要介绍了纯CSS3实现圆圈动态发光特效动画的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编
    2021-03-08
  • css3动画鼠标放上图片逐渐变大鼠标离开图片逐渐缩小效果

    这篇文章主要介绍了css3动画鼠标放上图片逐渐变大鼠标离开图片逐渐缩小,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-27

最新评论

?


http://www.vxiaotou.com