html+css3太阳系行星运转动画效果的实现代码
做一个太阳系八大行星的运转动画,不包括行星的卫星,所有行星围绕太阳公转,行星采用纯色,暂时没有自转。
效果静态图
动画中包括太阳及各行星,运行轨道,行星公转动画。
先画好草图,设计好大小和位置,根据公转周期计算好动画执行的时间。
html的结构:
一个class为solarsys的div,作为太阳系容器元素,该div的position为relative。
行星轨道和行星都用div,position为absolute。
容器用relative和内部元素采用absolute的定位方式,比较简单的能实现效果,缺点就是大小是固定的。
- <div class="solarsys">
- <!--太阳-->
- <div class='sun'></div>
- <!--水星轨道-->
- <div class='mercuryOrbit'></div>
- <!--水星-->
- <div class='mercury'></div>
- <!--金星轨道-->
- <div class='venusOrbit'></div>
- <!--金星-->
- <div class='venus'></div>
- <!--地球轨道-->
- <div class='earthOrbit'></div>
- <!--地球-->
- <div class='earth'></div>
- <!--火星轨道-->
- <div class='marsOrbit'></div>
- <!--火星-->
- <div class='mars'></div>
- <!--木星轨道-->
- <div class='jupiterOrbit'></div>
- <!--木星-->
- <div class='jupiter'></div>
- <!--土星轨道-->
- <div class='saturnOrbit'></div>
- <!--土星-->
- <div class='saturn'></div>
- <!--天王星轨道-->
- <div class='uranusOrbit'></div>
- <!--天王星-->
- <div class='uranus'></div>
- <!--海王星轨道-->
- <div class='neptuneOrbit'></div>
- <!--海王星-->
- <div class='neptune'></div>
- </div>
太阳系容器div的css
定宽,定高,relative定位,页面内剧中对齐。
- .solarsys{
- width: 800px;
- height: 800px;;
- position: relative;
- margin: 0 auto;
- background-color: #000000;
- padding: 0;
- transform: scale(1);
- }
太阳div的css
按照设计的大小和位置,设定宽高,left,。
设定颜色。
通过把boder-radius生成50%,把一个正方形变成圆形。
通过box-shadow的4层颜色设置实现太阳光晕。
- .sun {
- left:357px;
- :357px;
- height: 90px;
- width: 90px;
- background-color: rgb(248,107,35);
- border-radius: 50%;
- box-shadow: 5px 5px 10px rgb(248,107,35), -5px -5px 10px rgb(248,107,35), 5px -5px 10px rgb(248,107,35), -5px 5px 10px rgb(248,107,35);
- position: absolute;
- margin: 0;
- }
行星轨道div的css
假设是水星轨道。
按照设计的大小和位置,设定宽高,left,。
背景色透明。
通过把boder-radius生成50%,把一个正方形变成圆形。
boder的类型设成虚线。
boder的颜色设成灰色。
宽度设1。
- .mercuryOrbit {
- left:342.5px;
- :342.5px;
- height: 115px;
- width: 115px;
- background-color: transparent;
- border-radius: 50%;
- border-style: dashed;
- border-color: gray;
- position: absolute;
- border-width: 1px;
- margin: 0px;
- padding: 0px;
- }
行星div的css
假设是水星。
按照设计的大小和位置,设定宽高,left,。
设置颜色。
通过把boder-radius生成50%,把一个正方形变成圆形。
将transfrom-origin设定成当前div的左上角相对于整个太阳系容器的中心点的横向和纵向的偏移量。加上旋转动画后就是围绕着中心点旋转效果。
做一个animation,引用rotate关键帧动画,线性永久执行,这里的执行时长是根据行星的公转周期计算出来。
- .mercury {
- left:337.5px;
- :395px;
- height: 10px;
- width: 10px;
- background-color: rgb(166,138,56);
- border-radius: 50%;
- position: absolute;
- transform-origin: 62.5px 5px;
- animation: rotate 1.5s infinite linear;
- }
rotate关键帧动画
逆时针旋转。
- @keyframes rotate {
- 100% {
- transform: rotate(-360deg);
- }
- }
基本结构完成。
仅在chrome中测试过。
全部代码
- <html>
- <head>
- <style>
- .solarsys{
- width: 800px;
- height: 800px;;
- position: relative;
- margin: 0 auto;
- background-color: #000000;
- padding: 0;
- transform: scale(1);
- }
- /太阳/
- .sun {
- left:357px;
- :357px;
- height: 90px;
- width: 90px;
- background-color: rgb(248,107,35);
- border-radius: 50%;
- box-shadow: 5px 5px 10px rgb(248,107,35), -5px -5px 10px rgb(248,107,35), 5px -5px 10px rgb(248,107,35), -5px 5px 10px rgb(248,107,35);
- position: absolute;
- margin: 0;
- }
- /水星/
- .mercury {
- left:337.5px;
- :395px;
- height: 10px;
- width: 10px;
- background-color: rgb(166,138,56);
- border-radius: 50%;
- position: absolute;
- transform-origin: 62.5px 5px;
- animation: rotate 1.5s infinite linear;
- }
- /水星轨道/
- .mercuryOrbit {
- left:342.5px;
- :342.5px;
- height: 115px;
- width: 115px;
- background-color: transparent;
- border-radius: 50%;
- border-style: dashed;
- border-color: gray;
- position: absolute;
- border-width: 1px;
- margin: 0px;
- padding: 0px;
- }
- /金星/
- .venus {
- left:309px;
- :389px;
- height: 22px;
- width: 22px;
- background-color: rgb(246,157,97);
- border-radius: 50%;
- position: absolute;
- transform-origin: 91px 11px;
- animation: rotate 3.84s infinite linear;
- }
- /金星轨道/
- .venusOrbit {
- left:320px;
- :320px;
- height: 160px;
- width: 160px;
- background-color: transparent;
- border-radius: 50%;
- border-style: dashed;
- border-color: gray;
- position: absolute;
- border-width: 1px;
- /margin: 100px;/
- /transform-origin: -75px -75px;/
- /animation: rotate 4s infinite linear;/
- margin: 0px;
- padding: 0px;
- }
- /地球/
- .earth {
- left:266.5px;
- :391px;
- height: 18px;
- width: 18px;
- background-color: rgb(115,114,174);
- border-radius: 50%;
- position: absolute;
- transform-origin: 134px 9px;
- animation: rotate 6.25s infinite linear;
- }
- /地球轨道/
- .earthOrbit {
- left:275px;
- :275px;
- height: 250px;
- width: 250px;
- background-color: transparent;
- border-radius: 50%;
- border-style: dashed;
- border-color: gray;
- position: absolute;
- border-width: 1px;
- /margin: 100px;/
- /transform-origin: -75px -75px;/
- /animation: rotate 4s infinite linear;/
- margin: 0px;
- padding: 0px;
- }
- /火星/
- .mars {
- left:222.5px;
- :392.5px;
- height: 15px;
- width: 15px;
- background-color: rgb(140,119,63);
- border-radius: 50%;
- position: absolute;
- transform-origin: 177.5px 7.5px;
- animation: rotate 11.75s infinite linear;
- }
- /火星轨道/
- .marsOrbit {
- left:230px;
- :230px;
- height: 340px;
- width: 340px;
- background-color: transparent;
- border-radius: 50%;
- border-style: dashed;
- border-color: gray;
- position: absolute;
- border-width: 1px;
- /margin: 100px;/
- /transform-origin: -75px -75px;/
- /animation: rotate 4s infinite linear;/
- margin: 0px;
- padding: 0px;
- }
- /木星/
- .jupiter {
- left:134px;
- :379px;
- height: 42px;
- width: 42px;
- background-color: rgb(156,164,143);
- border-radius: 50%;
- position: absolute;
- transform-origin: 266px 21px;
- animation: rotate 74.04s infinite linear;
- }
- /木星轨道/
- .jupiterOrbit {
- left:155px;
- :155px;
- height: 490px;
- width: 490px;
- background-color: transparent;
- border-radius: 50%;
- border-style: dashed;
- border-color: gray;
- position: absolute;
- border-width: 1px;
- /margin: 100px;/
- /transform-origin: -75px -75px;/
- /animation: rotate 4s infinite linear;/
- margin: 0px;
- padding: 0px;
- }
- /土星/
- .saturn {
- left:92px;
- :387px;
- height: 26px;
- width: 26px;
- background-color: rgb(215,171,68);
- border-radius: 50%;
- position: absolute;
- transform-origin: 308px 13px;
- animation: rotate 183.92s infinite linear;
- }
- /土星轨道/
- .saturnOrbit {
- left:105px;
- :105px;
- height: 590px;
- width: 590px;
- background-color: transparent;
- border-radius: 50%;
- border-style: dashed;
- border-color: gray;
- position: absolute;
- border-width: 1px;
- /margin: 100px;/
- /transform-origin: -75px -75px;/
- /animation: rotate 4s infinite linear;/
- margin: 0px;
- padding: 0px;
- }
- /天王星/
- .uranus {
- left:41.5px;
- :386.5px;
- height: 27px;
- width: 27px;
- background-color: rgb(164,192,206);
- border-radius: 50%;
- position: absolute;
- transform-origin: 358.5px 13.5px;
- animation: rotate 524.46s infinite linear;
- }
- /天王星轨道/
- .uranusOrbit {
- left:55px;
- :55px;
- height: 690px;
- width: 690px;
- background-color: transparent;
- border-radius: 50%;
- border-style: dashed;
- border-color: gray;
- position: absolute;
- border-width: 1px;
- /margin: 100px;/
- /transform-origin: -75px -75px;/
- /animation: rotate 4s infinite linear;/
- margin: 0px;
- padding: 0px;
- }
- /海王星/
- .neptune {
- left:10px;
- :390px;
- height: 20px;
- width: 20px;
- background-color: rgb(133,136,180);
- border-radius: 50%;
- position: absolute;
- transform-origin: 390px 10px;
- animation: rotate 1028.76s infinite linear;
- }
- /海王星轨道/
- .neptuneOrbit {
- left:20px;
- :20px;
- height: 760px;
- width: 760px;
- background-color: transparent;
- border-radius: 50%;
- border-style: dashed;
- border-color: gray;
- position: absolute;
- border-width: 1px;
- /margin: 100px;/
- /transform-origin: -75px -75px;/
- /animation: rotate 4s infinite linear;/
- margin: 0px;
- padding: 0px;
- }
- @keyframes rotate {
- 100% {
- transform: rotate(-360deg);
- }
- }
- </style>
- </head>
- <body>
- <div class="solarsys">
- <!--太阳-->
- <div class='sun'></div>
- <!--水星轨道-->
- <div class='mercuryOrbit'></div>
- <!--水星-->
- <div class='mercury'></div>
- <!--金星轨道-->
- <div class='venusOrbit'></div>
- <!--金星-->
- <div class='venus'></div>
- <!--地球轨道-->
- <div class='earthOrbit'></div>
- <!--地球-->
- <div class='earth'></div>
- <!--火星轨道-->
- <div class='marsOrbit'></div>
- <!--火星-->
- <div class='mars'></div>
- <!--木星轨道-->
- <div class='jupiterOrbit'></div>
- <!--木星-->
- <div class='jupiter'></div>
- <!--土星轨道-->
- <div class='saturnOrbit'></div>
- <!--土星-->
- <div class='saturn'></div>
- <!--天王星轨道-->
- <div class='uranusOrbit'></div>
- <!--天王星-->
- <div class='uranus'></div>
- <!--海王星轨道-->
- <div class='neptuneOrbit'></div>
- <!--海王星-->
- <div class='neptune'></div>
- </div>
- </body>
- </html>
以上这篇html+css3太阳系行星运转动画效果的实现代码就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
长沙网站设计
- 如何进行东阳SEO关键词优化?
- 边坝哪有关键词排名优化:提升你的网站流量与
- 安国百度优化服务:提升您的在线可见性
- 阜康新手做SEO怎么做
- 山西seo网站排名关键词优化:提升您网站曝光率
- 临沂seo网站排名关键词优化:提高你的网站可见
- 广西SEO网站推广怎样付费比较合理
- 双辽SEO网站推广:提升你的网站可见性与流量
- 辽宁企业网站优化购买方式有哪些
- 提升宝清百度SEO排名的实用技巧与策略
- 静宁百度SEO排名:提升您网站曝光率的关键策略
- 彭州百度SEO排名的提升策略和实施指南
- 广南百度关键词SEO:提升网站排名的关键策略
- 辽宁关键词优化怎么做论坛营销
- 吉林百度seo排名如何做到让用户满意
- 内黄百度优化服务:提升在线可见性的关键