Make an animation of the eight planets in the solar system, excluding their satellites. All planets revolve around the sun. The planets are solid colors and do not rotate for the time being. Effect static picture: 
The animation includes: the sun and planets, their orbits, and planetary revolution animation. First draw a sketch, design the size and position, and calculate the animation execution time based on the orbital period. The structure of html: A div with class solarsys as the container element of the solar system. The position of this div is relative. Both planetary orbits and planets use div, and position is absolute. The container uses relative and the internal elements use absolute positioning, which is relatively simple to achieve the effect. The disadvantage is that the size is fixed. XML/HTML CodeCopy content to clipboard - < 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 >
CSS of the solar system container div: Fixed width, fixed height, relative positioning, and center alignment within the page. CSS CodeCopy content to clipboard - .solarsys{
- width : 800px ;
- height : 800px ;;
- position : relative ;
- margin : 0 auto ;
- background-color : #000000 ;
- padding : 0;
- transform: scale(1);
- }
CSS for the sun div: Set the width, height, left, and top according to the size and position of the design. Set the color. By increasing the boder-radius by 50%, we can turn a square into a circle. The sun halo is achieved through the 4-layer color setting of box-shadow. CSS CodeCopy content to clipboard - .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;
- }
CSS for the planet orbit div: Assume the orbit of Mercury. Set the width, height, left, and top according to the size and position of the design. The background color is transparent. By increasing the boder-radius by 50%, we can turn a square into a circle. The boder type is set to a dotted line. The color of the boder is set to gray. Set the width to 1. CSS CodeCopy content to clipboard - .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 ;
- }
CSS for the planet div: Let's say it's Mercury. Set the width, height, left, and top according to the size and position of the design. Set the color. By increasing the boder-radius by 50%, we can turn a square into a circle. Set transfrom-origin to the horizontal and vertical offset of the upper left corner of the current div relative to the center point of the entire solar system container. After adding the rotation animation, the effect is rotation around the center point. Make an animation, reference the rotate keyframe animation, and execute it linearly forever. The execution time here is calculated based on the planet's revolution period. CSS CodeCopy content to clipboard - .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 keyframe animation: Rotate counterclockwise. CSS CodeCopy content to clipboard - @keyframes rotate {
- 100% {
- transform: rotate(-360deg);
- }
- }
The basic structure is completed. Only tested in chrome. Full code: XML/HTML CodeCopy content to clipboard - < html >
- < head >
- < style >
- .solarsys{
- width: 800px;
- height: 800px;;
- position: relative;
- margin: 0 auto;
- background-color: #000000;
- padding: 0;
- transform: scale(1);
- }
-
- /*sun*/
- .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;
- }
-
- /*Mercury*/
- .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;
- }
-
- /* Mercury orbit */
- .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*/
- .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;
- }
-
- /* Orbit of Venus */
- .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: -75px -75px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
-
- /*Earth*/
- .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;
- }
-
- /*Earth orbit*/
- .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: -75px -75px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
-
- /*Mars*/
- .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;
- }
-
- /*Mars orbit*/
- .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: -75px -75px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
-
- /*Jupiter*/
- .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;
- }
-
- /*Jupiter orbit*/
- .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: -75px -75px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
-
- /*Saturn*/
- .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;
- }
-
- /*Saturn orbit*/
- .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: -75px -75px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
-
- /*Uranus*/
- .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;
- }
-
- /* Orbit of Uranus */
- .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: -75px -75px;*/
- /*animation: rotate 4s infinite linear;*/
- margin: 0px;
- padding: 0px;
- }
-
- /*Neptune*/
- .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;
- }
-
- /* Orbit of Neptune */
- .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: -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 >
The above html+css3 code to implement the animation effect of the solar system planets is all the content that the editor shares with you. I hope it can give you a reference. I also hope that you will support 123WORDPRESS.COM. |