CSS3 realizes the animation effect of lotus blooming

CSS3 realizes the animation effect of lotus blooming

Let’s look at the effect first:

This effect looks quite dazzling, but the principle is not complicated. If one petal can be moved, then all nine petals can be made. It's just a superposition of effects.

HTML:

<section class="demo">  
  <div class="box">  
     <div class="leaf"></div>  
     <div class="leaf"></div>  
     <div class="leaf"></div>  
     <div class="leaf"></div>  
     <div class="leaf"></div>  
     <div class="leaf"></div> 
     <div class="leaf"></div>  
     <div class="leaf"></div>  
     <div class="leaf"></div>  
  </div>  
</section>

CSS:

View Code 
body {
   background-color: #000;
}      

.demo {
   margin:0px auto;
   width: 500px;
}
/*Container for lotus petals*/
.box {
   position: relative;/*Set relative positioning, because the petals must be absolutely positioned*/   
   height: 400px;
   margin-top:400px
}
/*Absolute positioning of petals*/
.box .leaf {
   position: absolute;
}
/*Draw lotus petals*/
.leaf {
   margin-top:0px;
   width: 200px;
   height: 200px;
   border-radius: 200px 0px;/*Make petal corners*/
   background: -moz-linear-gradient(45deg,rgba(188,190,192,1) 8%,rgba(158,31,99,1) 30%,rgba(158,31,99,1) 100%);/*Make petal color*/
        background: -webkit-linear-gradient(45deg,rgba(188,190,192,1) 8%,rgba(158,31,99,1) 30%,rgba(158,31,99,1) 100%);/*Make petal color*/
   opacity: .6;
   filter:alpha(opacity=50);
   transform: rotate(135deg);/*petals rotate 135deg*/
   transform-origin: top right;/*Reset the petal rotation origin, this is very important*/
}

@keyframes show-2 {
    0% {
     transform: rotate(135deg);
    }
    50% {
     transform: rotate(45deg);
    }
    100%{
     transform: rotate(135deg);
    }
}
@keyframes show-3 {
    0% {
     transform: rotate(135deg);
    }
    50% {
     transform: rotate(65deg);
    }
    100%{
     transform: rotate(135deg);
    }
}
@keyframes show-4 {
    0% {
     transform: rotate(135deg);
    }
    50% {
     transform: rotate(85deg);
    }
    100%{
     transform: rotate(135deg);
    }
}
@keyframes show-5 {
    0% {
     transform: rotate(135deg);
    }
    50% {
     transform: rotate(105deg);
    }
    100%{
     transform: rotate(135deg);
    }
}
@keyframes show-6 {
    0% {
     transform: rotate(135deg);
    }
    50% {
     transform: rotate(165deg);
    }
    100%{
     transform: rotate(135deg);
    }
}
@keyframes show-7 {
    0% {
     transform: rotate(135deg);
    }
    50% {
     transform: rotate(185deg);
    }
    100%{
     transform: rotate(135deg);
    }
}
@keyframes show-8 {
    0% {
     transform: rotate(135deg);
    }
    50% {
     transform: rotate(205deg);
    }
    100%{
     transform: rotate(135deg);
    }
}  

@keyframes show-9 {
    0% {
     transform: rotate(135deg);
    }
    50% {
     transform: rotate(225deg);
    }
    100%{
     transform: rotate(135deg);
    }
}  

.leaf:nth-child(1) {
 background: -moz-linear-gradient(45deg,rgba(250,250,250,1) 8%,rgba(158,31,99,1) 30%,rgba(158,31,99,1) 100%);/*Make the petal color*/
}
.leaf:nth-child(2) {
  animation: show-2 6s ease-in-out infinite;
}
.leaf:nth-child(3) {
  animation: show-3 6s ease-in-out infinite;
}
.leaf:nth-child(4) {
  animation: show-4 6s ease-in-out infinite;
}
.leaf:nth-child(5) {
  animation: show-5 6s ease-in-out infinite;
}
.leaf:nth-child(6) {
  animation: show-6 6s ease-in-out infinite;
}
.leaf:nth-child(7) {
  animation: show-7 6s ease-in-out infinite;
}
.leaf:nth-child(8) {
  animation: show-8 6s ease-in-out infinite;
}
.leaf:nth-child(9) {
  animation: show-9 6s ease-in-out infinite;
}

The above is the details of how to achieve the animation effect of lotus blooming with CSS3. For more information about CSS3 lotus blooming animation, please pay attention to other related articles on 123WORDPRESS.COM!

<<:  Manual and scheduled backup steps for MySQL database

>>:  Some front-end basics (html, css) encountered in practice

Recommend

Tudou.com front-end overview

1. Division of labor and process <br />At T...

How to define data examples in Vue

Preface In the development process, defining vari...

Detailed explanation of the use of the clip-path property in CSS

Use of clip-path polygon The value is composed of...

Design of pop-up windows and floating layers in web design

In the trend of gradual transition from tradition...

Method example of safely getting deep objects of Object in Js

Table of contents Preface text parameter example ...

MySQL 8.0.18 installation and configuration method graphic tutorial

This article records the installation and configu...

Docker installation and configuration image acceleration implementation

Table of contents Docker version Install Docker E...

Exploring the practical value of the CSS property *-gradient

Let me first introduce an interesting property - ...

How to get the real path of the current script in Linux

1. Get the real path of the current script: #!/bi...

How to create an index on a join table in MySQL

This article introduces how to create an index on...

Solution to the inaccessibility of Tencent Cloud Server Tomcat port

I recently configured a server using Tencent Clou...

HTML+CSS to create heartbeat special effects

Today we are going to create a simple heartbeat e...

Pros and Cons of Vite and Vue CLI

There is a new build tool in the Vue ecosystem ca...