Home JS special effects CSS3 special effects Solar eclipse animation special effects made with CSS3

Solar eclipse animation special effects made with CSS3

Solar eclipse animation special effects made with CSS3

Solar eclipse animation special effects made with CSS3

<head>
<meta charset="utf-8">
<title>逼真的CSS3日食动画特效</title>

<style>
html, body {
  width: 100%;
  overflow-x: hidden;
}

*, *:before, *:after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.universe {
  width: 100vw;
  height: 100vh;
  background: #030613;
  display: block;
  position: relative;
  -webkit-animation: skyDim 4s 8s linear forwards;
          animation: skyDim 4s 8s linear forwards;
}

.universe:before {
  content: "";
  box-shadow: 10vw 1vh #fff, 14vw 29vh 2px #FFF, 23vw 34vh 1px #FFF, 1vw 99vh 1px #FFF, 20vw 80vh #FFF, 90vw 10vh 2px #fff, 55vw 9vh #FFF, 24vw 4vh 1px #FFF, 50vw 99vh 1px #FFF, 74vw 40vh 1px #FFF, 80vw 9vh 1px #FFF, 20vw 80vh #FFF, 85vw 78vh #fff;
  width: 4px;
  height: 4px;
  position: absolute;
  border-radius: 50%;
  -webkit-animation: starsFloating 100s -200s linear both infinite;
          animation: starsFloating 100s -200s linear both infinite;
}

.universe:after {
  content: "";
  box-shadow: 37vw 78vh #fff, 17vw 69vh #FFF, 68vw 4vh 1px #FFF, 98vw 9vh 1px #FFF, 45vw 67vh #FFF, 95vw 1vh 2px #fff, 35vw 75vh 2px #FFF, 44vw 47vh 1px #FFF, 54vw 5vh 1px #FFF, 22vw 29vh 1px #FFF, 39vw 71vh 1px #FFF, 11vw 11vh #FFF, 88vw 82vh #fff;
  width: 2px;
  height: 2px;
  position: absolute;
  border-radius: 50%;
  -webkit-animation: starsFloating 100s 3s linear backwards infinite;
          animation: starsFloating 100s 3s linear backwards infinite;
}

.sun {
  height: 200px;
  width: 200px;
  border-radius: 50%;
  background: #cfcfd4;
  box-shadow: 0 0 60px gold, 0 0 100px #b9a018, inset 0 5px 35px 53px #dbdbdb, inset 48px 8px 34px 25px #c4c4c4;
  left: calc(50% - 100px);
  top: calc(50% - 100px);
  position: absolute;
  -webkit-animation: sunFreakOut 5s 7.1s linear forwards;
          animation: sunFreakOut 5s 7.1s linear forwards;
}

.moon {
  height: 50px;
  width: 50px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.99);
  box-shadow: inset 5px 1px 10px -8px #d4d4d6;
  -webkit-transition: 1s;
  transition: 1s;
  top: calc(40% - 100px);
  position: absolute;
  z-index: 5;
  -webkit-animation: move 20s ease-in-out forwards;
          animation: move 20s ease-in-out forwards;
}

@-webkit-keyframes move {
  0% {
    -webkit-transform: translateX(100vw);
            transform: translateX(100vw);
  }
  40%, 60% {
    top: calc(50% - 100px);
  }
  50%, 50.5% {
    width: 200px;
    height: 200px;
    -webkit-transform: translateX(calc(50vw - 100px));
            transform: translateX(calc(50vw - 100px));
    box-shadow: inset 20px 1px 35px -15px #d4d4d6;
    top: calc(50% - 100px);
  }
  60% {
    box-shadow: inset -20px 1px 35px -15px #d4d4d6;
  }
  100% {
    width: 50px;
    height: 50px;
    -webkit-transform: translateX(calc(-1vw - 60px));
            transform: translateX(calc(-1vw - 60px));
    top: calc(40% - 100px);
    box-shadow: inset -5px 1px 10px -8px #d4d4d6;
  }
}

@keyframes move {
  0% {
    -webkit-transform: translateX(100vw);
            transform: translateX(100vw);
  }
  40%, 60% {
    top: calc(50% - 100px);
  }
  50%, 50.5% {
    width: 200px;
    height: 200px;
    -webkit-transform: translateX(calc(50vw - 100px));
            transform: translateX(calc(50vw - 100px));
    box-shadow: inset 20px 1px 35px -15px #d4d4d6;
    top: calc(50% - 100px);
  }
  60% {
    box-shadow: inset -20px 1px 35px -15px #d4d4d6;
  }
  100% {
    width: 50px;
    height: 50px;
    -webkit-transform: translateX(calc(-1vw - 60px));
            transform: translateX(calc(-1vw - 60px));
    top: calc(40% - 100px);
    box-shadow: inset -5px 1px 10px -8px #d4d4d6;
  }
}
@-webkit-keyframes skyDim {
  0%, 100% {
    background: #030613;
  }
  50%, 70% {
    background: black;
  }
}
@keyframes skyDim {
  0%, 100% {
    background: #030613;
  }
  50%, 70% {
    background: black;
  }
}
@-webkit-keyframes sunFreakOut {
  0%, 100% {
    box-shadow: 0 0 60px gold, 0 0 100px #b9a018, inset 0 5px 35px 53px #dbdbdb, inset 48px 8px 34px 25px #c4c4c4;
  }
  50%, 70% {
    box-shadow: 0 0 50px #e30000, 0 0 0px #b91818, inset 0 5px 35px 53px #dbdbdb, inset 48px 8px 34px 25px #c4c4c4;
  }
}
@keyframes sunFreakOut {
  0%, 100% {
    box-shadow: 0 0 60px gold, 0 0 100px #b9a018, inset 0 5px 35px 53px #dbdbdb, inset 48px 8px 34px 25px #c4c4c4;
  }
  50%, 70% {
    box-shadow: 0 0 50px #e30000, 0 0 0px #b91818, inset 0 5px 35px 53px #dbdbdb, inset 48px 8px 34px 25px #c4c4c4;
  }
}
@-webkit-keyframes starsFloating {
  0% {
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(-100vh);
            transform: translateY(-100vh);
  }
}
@keyframes starsFloating {
  0% {
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(-100vh);
            transform: translateY(-100vh);
  }
}
</style>
</head>

这是一款非常逼真的使用纯CSS3实现的一个天狗食月日食动画特效,当日全食时,还有背景星星闪烁动画特效,效果很漂亮

Disclaimer

All resources on this site are contributed by netizens or reprinted by major download sites. Please check the integrity of the software yourself! All resources on this site are for learning reference only. Please do not use them for commercial purposes. Otherwise, you will be responsible for all consequences! If there is any infringement, please contact us to delete it. Contact information: admin@php.cn

Related Article

How to skillfully use CSS3 special effects to improve the user experience of web pages How to skillfully use CSS3 special effects to improve the user experience of web pages

09 Sep 2023

How to skillfully use CSS3 special effects to improve the user experience of web pages. With the development of the Internet, web design and user experience have become important links in website development. The application of CSS3 special effects can add dynamics and visual effects to web pages and improve user experience. This article will introduce several common CSS3 special effects and their code examples to help developers become more proficient in using CSS3 special effects and improve the user experience of web pages. Transition effect (Transition) Transition effect is one of the most basic special effects in CSS3. By changing a certain attribute

Implementation of css3 visual effects Implementation of css3 visual effects

22 Mar 2018

This time I will bring you the implementation of CSS3 visual special effects. What are the precautions for realizing CSS3 visual special effects? The following is a practical case, let’s take a look.

Sharing of 7 eye-catching jQuery/CSS3 special effects examples_jquery Sharing of 7 eye-catching jQuery/CSS3 special effects examples_jquery

16 May 2016

jQuery and CSS3 are definitely used a lot for web front-end development. Next, I will share some special effects made by jQuery and CSS3. I hope it will be helpful to friends who like to learn special effects.

How to use css3 to achieve 3D stereoscopic effects How to use css3 to achieve 3D stereoscopic effects

14 Mar 2018

This time I will show you how to use css3 to achieve 3D stereoscopic special effects. What are the precautions for using css3 to achieve 3D stereoscopic special effects? The following is a practical case, let’s take a look.

CSS3 3D special effects video data sharing CSS3 3D special effects video data sharing

31 Aug 2017

"CSS3 3D Special Effects Video Tutorial" uses the transition attribute, perspective attribute, and transform attribute in CSS3 to create real and usable three-dimensional effects.

Various special effects of filter in css3 Various special effects of filter in css3

09 Oct 2016

Various special effects of filter in css3

css3 effect rotation css3 effect rotation

27 May 2023

Rotation of CSS3 special effects In web design, dynamic special effects can increase the interactivity and artistry of web pages, making users browse web pages more happily. Among them, the rotation effect is a relatively common special effect. In CSS3, rotation effects can be achieved through the transform attribute. 1. Use transform to achieve rotation. The transform attribute in CSS3 is used to achieve deformation effects of elements, such as rotation, movement, scaling, etc. When realizing the element rotation effect, you can use the rotate rotation function. The specific syntax is as follows: tra

Animated loading effects implemented in pure css3_html/css_WEB-ITnose Animated loading effects implemented in pure css3_html/css_WEB-ITnose

24 Jun 2016

Animation loading special effects implemented in pure css3

Pure css3 3D picture cube rotation animation special effects Pure css3 3D picture cube rotation animation special effects

21 Jul 2016

Pure css3 3D picture cube rotation animation special effects

See all articles See all articles

Hot Tools

CSS text is combined into a heart-shaped animation special effect

CSS text is combined into a heart-shaped animation special effect

CSS text is combined into a heart-shaped animation special effect

CSS3 SVG expression flower animation special effects

CSS3 SVG expression flower animation special effects

SS3 SVG confession flower animation special effect is a Valentine's Day animation special effect.

CSS shopping mall websites commonly use left category drop-down navigation menu code

CSS shopping mall websites commonly use left category drop-down navigation menu code

CSS shopping mall websites commonly use left category drop-down navigation menu code

jQuery+CSS3 Valentine's Day love special effects

jQuery+CSS3 Valentine's Day love special effects

jQuery+CSS3 Valentine's Day Love Special Effect is a Valentine's Day hanging swinging heart animation special effect.

css3 spoon scooping up glutinous rice balls animation special effects

css3 spoon scooping up glutinous rice balls animation special effects

A bowl of cute glutinous rice balls expression, a spoon scooping up a glutinous rice balls animation special effects