使一个div绕着另一个移动的div旋转

3

我正在尝试学习CSS3中的动画关键帧,我想知道如何让#moon-orbit绕着#earth轨道运行?就像在现实生活中一样,你知道的。

html, body {
    background-color : #000000;
    height : 90%;
    width : 90%;
}

#sun {
    background-color : #ba8f27;
    border-radius : 200px;
    box-shadow : 0 0 128px red;
    margin-top : -100px; 
    margin-left : -100px;
    left : 50%;
    height : 200px;
    position : absolute;
    top : 50%;
    width : 200px;
}

#earth-orbit {
    border: 2px solid #373737;
    border-radius: 50%;
    left: 50%;
    height: 500px;
    margin-top: -250px;
    margin-left: -250px;
    position: absolute;
    top: 50%;
    width: 500px;

    -webkit-animation: spin-right 10s linear infinite;
    -moz-animation: spin-right 10s linear infinite;
    -ms-animation: spin-right 10s linear infinite;
    -o-animation: spin-right 10s linear infinite;
    animation: spin-right 10s linear infinite;
}

#moon-orbit {
    border-radius: 50%;
    left: 50%;
    height: 500px;
    margin-top: -250px;
    margin-left: -250px;
    position: absolute;
    top: 50%;
    width: 500px;

    transform: rotate(360deg);
    transform-origin: 50% 100%;
}

#earth {
    background-color : #2d7ddc;
    border-radius : 50px;
    margin-left : -25px;
    margin-top : -25px;
    height : 50px;
    left : 50%;
    position : absolute;
    top : 0%;
    width : 50px;
}

#moon {
    background-color : #b2b2b2;
    border-radius : 50px;
    margin-left : -25px;
    margin-top : -25px;
    height : 16px;
    left : 43%;
    position : absolute;
    top : 0%;
    width : 16px;
}



@-webkit-keyframes spin-right {
    100% {
        -webkit-transform: rotate(360deg);
    }
}



<div id="sun"></div>

<div id="earth-orbit">
    <div id="earth"></div>

    <div id="moon-orbit">
        <div id="moon"></div>
    </div>
</div>

jsFiddle demo


请具体说明您的问题。目前来看,这个问题很可能会被关闭,因为实际上并没有明确的问题或疑问。 - Emil Lundberg
问题非常明确:我如何让#moon-orbit绕着#earth轨道运行?问题在于我不知道如何实现。我已经搜索过谷歌,但没有找到解决方案,只有一个div如何围绕另一个div旋转的方法。而不是一个div如何绕着另一个div轨道运行,这些div已经绕着另一个div运行了。 - Airikr
1个回答

5
你可以添加一个容器来放置月球,并将其定位在地球的中心,然后旋转该div: 示例 添加的内容:
HTML:
<div class="moon-holder">
    <div id="moon"></div>
</div>

CSS:

.moon-holder {
    position: absolute;
    left: 50%;
    top: 0;
    width: 50px;
    height: 50px;
    margin: -25px 0 0 -25px;
    -webkit-animation: spin-right 5s linear infinite;
    -moz-animation: spin-right 5s linear infinite;
    -ms-animation: spin-right 5s linear infinite;
    -o-animation: spin-right 5s linear infinite;
    animation: spin-right 5s linear infinite;
}

下降吧,勇敢的旅行者,进入斯纳菲尔冰川的火山口... ;) - 抱歉,我忍不住了 - user123444555621

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接