做1个太阳系8大行星的运行动漫,不包含行星的卫星,全部行星紧紧围绕太阳公转,行星选用单色,临时沒有自转。
实际效果静态数据图:
动漫中包含:太阳及各行星,运作路轨,行星公旋转画。
先画好草图,设计方案好尺寸和部位,依据公转周期测算好动漫实行的時间。
html的构造:
1个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,top。
设置色调。
根据把boder-radius转化成50%,把1个正方变形成圆形。
根据box-shadow的4层色调设定完成太阳光晕。
- .sun {
- left:357px;
- top: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,top。
情况色全透明。
根据把boder-radius转化成50%,把1个正方变形成圆形。
boder的种类设成虚线。
boder的色调设成灰色。
宽度设1。
- .mercuryOrbit {
- left:342.5px;
- top: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,top。
设定色调。
根据把boder-radius转化成50%,把1个正方变形成圆形。
将transfrom-origin设置成当今div的左上角相对全部太阳系器皿的管理中心点的横向和纵向的偏位量。再加转动动漫后便是紧紧围绕着管理中心点转动实际效果。
做1个animation,引入rotate重要帧动漫,线形永久性实行,这里的实行时长是依据行星的公转周期测算出来。
- .mercury {
- left:337.5px;
- top: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(⑶60deg);
- }
- }
基础构造进行。
仅在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;
- top:357px;
- height: 90px;
- width: 90px;
- background-color: rgb(248,107,35);
- border-radius: 50%;
- box-shadow: 5px 5px 10px rgb(248,107,35), ⑸px ⑸px 10px rgb(248,107,35), 5px ⑸px 10px rgb(248,107,35), ⑸px 5px 10px rgb(248,107,35);
- position: absolute;
- margin: 0;
- }
- /*水星*/
- .mercury {
- left:337.5px;
- top: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;
- top: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;
- top: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;
- top: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: ⑺5px ⑺5px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
- /*地球*/
- .earth {
- left:266.5px;
- top: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;
- top: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: ⑺5px ⑺5px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
- /*火花*/
- .mars {
- left:222.5px;
- top: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;
- top: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: ⑺5px ⑺5px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
- /*木星*/
- .jupiter {
- left:134px;
- top: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;
- top: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: ⑺5px ⑺5px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
- /*土星*/
- .saturn {
- left:92px;
- top: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;
- top: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: ⑺5px ⑺5px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
- /*天王星*/
- .uranus {
- left:41.5px;
- top: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;
- top: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: ⑺5px ⑺5px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
- /*海王星*/
- .neptune {
- left:10px;
- top: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;
- top: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: ⑺5px ⑺5px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
- @keyframes rotate {
- 100% {
- transform: rotate(⑶60deg);
- }
- }
- </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太阳系行星运行动漫实际效果的完成编码便是网编共享给大伙儿的所有內容了,期待能给大伙儿1个参照,也期待大伙儿多多适用脚本制作之家。