Recently I saw several articles about CSS, pure CSS to achieve a variety of complex effects, and even get the user password and send it to the specified location, it is very shocking. In my spare time, I made use of my existing CSS foundation to achieve this work, while practicing CSS3 skills that I have not used for a long time (technology sharing, regardless of compatibility).

Without further ado, here’s the GIF:

This is the playback effect

It looks complicated, but it’s not. The technical points used are as follows:

  • Transformation transform
  • Animation animation
  • Gradient Linear-gradient and rounded border-radius
  • Box shadow box-shadow

The HTML structure is as follows:

<! DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>flower</title> <link rel="stylesheet" href="gift.css" type="text/css"/> </head> <body> <div id="flower-container"> <div id="bg-star"></div> <div id="flower-outer"> <span class="flower-outer outer1"></span> <span class="flower-outer outer2"></span> <span class="flower-outer outer3"></span> <span class="flower-outer outer4"></span> <span class="flower-outer outer5"></span> <span class="flower-outer outer6"></span> <span class="flower-outer outer7"></span> <span class="flower-outer outer8"></span> <div id="flower-center"> <span class="flower-center center1"></span> <span class="flower-center center2"></span> <span class="flower-center center3"></span> <span class="flower-center center4"></span> <span class="flower-center center5"></span> <span class="flower-center center6"></span> <span class="flower-center center7"></span> <span class="flower-center center8"></span> <div id="flower-inner"> <span class="flower-inner inner1"></span> <span class="flower-inner inner2"></span> <span class="flower-inner inner3"></span> <span class="flower-inner inner4"></span> <span class="flower-inner inner5"></span> <span class="flower-inner inner6"></span> <span class="flower-inner inner7"></span> <span class="flower-inner inner8"></span> </div> </div> </div> </div> </body> </html>Copy the code
The flower-container class is the largest container with two elements: star #bg-star and flower-container #flower-outer. Since the petals have three layers, #flower-outer has two layers nested in sequence. Yes, the span element is the petals, with eight petals per layer.

The CSS code immediately comes out:

body{
font-size: 20px;
height: 100%;
width: 100%;
background:#000;
overflow: hidden;
}
Copy the code

The stars:

#bg-star{ top: 30%; left: 30%; height: 2px; width: 2px; position: absolute; transform-style: preserve-3d; box-shadow: 10EM 10EM yellow, 2.5EM 10EM white, 10EM 5EM yellow, 20EM 0EM white, 0EM 20EM white, 20em 20em white,25em 20em lightyellow, 40em 35em white,25em 40em white, 10em 50em white,60em 0em white, 5em 0em white,15em 40em yellow, 45em 30em white,30em 20em lightyellow, 35em 15em white,15em 35em yellow; transform-origin: -10em 10em; animation: stars 20s linear infinite;Copy the code

} @keyframes stars{ from{ transform: translateZ(0em) rotate(0deg);

}
to{
	transform: translateZ(80em) rotate(360deg);
}
Copy the code

}

To show a sense of dimension and distance

#bg-star:before,#bg-star:after{
content: "";
position: absolute;
width: inherit;
height: inherit;
background-color: white;
box-shadow: inherit;
Copy the code

}

#bg-star:before{ transform: translateZ(-100em); }

#bg-star:after{ transform: translateZ(-50em); }

The most important part of the petals

This is the common style for each layer of petal container (excluding the starry container)

#flower-container div:not(:empty){
position: absolute;
top: 50%;
left: 50%;
box-sizing: border-box;
Copy the code

}

The outermost layer

#flower-outer{ height: inherit; width: inherit; Margin: -12.5em 0 0-12.5em; transform-style: preserve-3d; transform: rotateX(30deg) rotateZ(20deg); animation: outerdiv 10s linear infinite alternate; // This is the animation of the outer containerCopy the code

}

@keyframes outerdiv{
0%{
	transform: rotateX(30deg) rotateZ(20deg);
}
100%{
	transform: rotateX(30deg) rotateZ(380deg);
}
Copy the code

}

In the middle

#flower-center{ height: 18em; width: 18em; margin: -9em 0 0 -9em; transform-style: preserve-3d; The transform: rotateZ (22.5 deg);Copy the code

}

The inner layer

#flower-inner{ height: 10em; width: 10em; margin: -5em 0 0 -5em; transform-style: preserve-3d; The transform: rotateZ (22.5 deg);Copy the code

}

This is the common pattern for each layer of petals

The outer layer

The flower - the outer {top: 0.5 em. height: 12em; width: 5em; Margin - left: 1.5 em. Opacity: 0.6;Copy the code

}

In the middle

.flower-center{
height: 9em;
width: 4em;
margin-left: -1em;
opacity: 0.8;
Copy the code

}

The inner layer

.flower-inner{ height: 5em; Width: 2.5 em. Margin - left: 0.75 em. Opacity: 0.9;Copy the code

}

Below is a variety of petal position adjustment and animation

.outer1{
transform: rotateZ(0deg) rotateX(-15deg);
animation: flowerouter1 2s ease-in-out 1s backwards;
Copy the code

}

.center1{
transform: rotateZ(0deg) rotateX(-30deg);
animation: flowercenter1 3s ease-in-out 2s backwards;
Copy the code

}

.inner1{
transform: rotateZ(0deg) rotateX(-60deg);
animation: flowerinner1 4s ease-in-out 3s backwards;
Copy the code

}

.outer2{
transform: rotateZ(45deg) rotateX(-15deg);
animation: flowerouter2 2s ease-in-out 1s backwards;
Copy the code

}

.center2{
transform: rotateZ(45deg) rotateX(-30deg);
animation: flowercenter2 3s ease-in-out 2s backwards;
Copy the code

}

.inner2{
transform: rotateZ(45deg) rotateX(-60deg);
animation: flowerinner2 4s ease-in-out 3s backwards;
Copy the code

}

.outer3{
transform: rotateZ(90deg) rotateX(-15deg);
animation: flowerouter3 2s ease-in-out 1s backwards;
Copy the code

}

.center3{
transform: rotateZ(90deg) rotateX(-30deg);
animation: flowercenter3 3s ease-in-out 2s backwards;
Copy the code

}

.inner3{
transform: rotateZ(90deg) rotateX(-60deg);
animation: flowerinner3 4s ease-in-out 3s backwards;
Copy the code

}

.outer4{
transform: rotateZ(135deg) rotateX(-15deg);
animation: flowerouter4 2s ease-in-out 1s backwards;
Copy the code

}

.center4{
transform: rotateZ(135deg) rotateX(-30deg);
animation: flowercenter4 3s ease-in-out 2s backwards;
Copy the code

}

.inner4{
transform: rotateZ(135deg) rotateX(-60deg);
animation: flowerinner4 4s ease-in-out 3s backwards;
Copy the code

}

.outer5{
transform: rotateZ(180deg) rotateX(-15deg);
animation: flowerouter5 2s ease-in-out 1s backwards;
Copy the code

}

.center5{
transform: rotateZ(180deg) rotateX(-30deg);
animation: flowercenter5 3s ease-in-out 2s backwards;
Copy the code

}

.inner5{
transform: rotateZ(180deg) rotateX(-60deg);
animation: flowerinner5 4s ease-in-out 3s backwards;
Copy the code

}

.outer6{
transform: rotateZ(225deg) rotateX(-15deg);
animation: flowerouter6 2s ease-in-out 1s backwards;
Copy the code

}

.center6{
transform: rotateZ(225deg) rotateX(-30deg);
animation: flowercenter6 3s ease-in-out 2s backwards;
Copy the code

}

.inner6{
transform: rotateZ(225deg) rotateX(-60deg);
animation: flowerinner6 4s ease-in-out 3s backwards;
Copy the code

}

.outer7{
transform: rotateZ(270deg) rotateX(-15deg);
animation: flowerouter7 2s ease-in-out 1s backwards;
Copy the code

}

.center7{
transform: rotateZ(270deg) rotateX(-30deg);
animation: flowercenter7 3s ease-in-out 2s backwards;
Copy the code

}

.inner7{
transform: rotateZ(270deg) rotateX(-60deg);
animation: flowerinner7 4s ease-in-out 3s backwards;
Copy the code

}

.outer8{
transform: rotateZ(315deg) rotateX(-15deg);
animation: flowerouter8 2s ease-in-out 1s backwards;
Copy the code

}

.center8{
transform: rotateZ(315deg) rotateX(-30deg);
animation: flowercenter8 3s ease-in-out 2s backwards;
Copy the code

}

.inner8{
transform: rotateZ(315deg) rotateX(-60deg);
animation: flowerinner8 4s ease-in-out 3s backwards;
Copy the code

}

@keyframes flowerouter1{
from{
	transform: rotateZ(0deg) rotateX(-90deg);
}
to{
	transform: rotateZ(0deg) rotateX(-15deg);
}
Copy the code

}

@keyframes flowerouter2{
from{
	transform: rotateZ(45deg) rotateX(-90deg);
}
to{
	transform: rotateZ(45deg) rotateX(-15deg);
}
Copy the code

}

@keyframes flowerouter3{
from{
	transform: rotateZ(90deg) rotateX(-90deg);
}
to{
	transform: rotateZ(90deg) rotateX(-15);
}
Copy the code

}

@keyframes flowerouter4{
from{
	transform: rotateZ(135deg) rotateX(-90deg);
}
to{
	transform: rotateZ(135deg) rotateX(-15deg);
}
Copy the code

}

@keyframes flowerouter5{
from{
	transform:rotateZ(180deg) rotateX(-90deg);
}
to{
	transform:rotateZ(180) rotateX(-15deg);
}
Copy the code

}

@keyframes flowerouter6{
from{
	transform:rotateZ(225deg) rotateX(-90deg);
}
to{
	transform:rotateZ(225deg) rotateX(-15deg);
}
Copy the code

}

@keyframes flowerouter7{
from{
	transform:rotateZ(270deg) rotateX(-90deg);
}
to{
	transform:rotateZ(270deg) rotateX(-15deg);
}
Copy the code

}

@keyframes flowerouter8{
from{
	transform:rotateZ(315deg) rotateX(-90deg);
}
to{
	transform:rotateZ(315deg) rotateX(-15deg);
}
Copy the code

}

@keyframes flowercenter1{
from{
	transform:rotateZ(0deg) rotateX(-90deg);
}
to{
	transform:rotateZ(0deg) rotateX(-30deg);
}
Copy the code

}

@keyframes flowercenter2{
from{
	transform:rotateZ(45deg) rotateX(-90deg);
}
to{
	transform:rotateZ(45deg) rotateX(-30deg);
}
Copy the code

}

@keyframes flowercenter3{
from{
	transform:rotateZ(90deg) rotateX(-90deg);
}
to{
	transform:rotateZ(90deg) rotateX(-30deg);
}
Copy the code

}

@keyframes flowercenter4{
from{
	transform:rotateZ(135deg) rotateX(-90deg);
}
to{
	transform:rotateZ(135deg) rotateX(-30deg);
}
Copy the code

}

@keyframes flowercenter5{
from{
	transform:rotateZ(180deg) rotateX(-90deg);
}
to{
	transform:rotateZ(180deg) rotateX(-30deg);
}
Copy the code

}

@keyframes flowercenter6{
from{
	transform:rotateZ(225deg) rotateX(-90deg);
}
to{
	transform:rotateZ(225deg) rotateX(-30deg);
}
Copy the code

}

@keyframes flowercenter7{
from{
	transform:rotateZ(270deg) rotateX(-90deg);
}
to{
	transform:rotateZ(270deg) rotateX(-30deg);
}
Copy the code

}

@keyframes flowercenter8{
from{
	transform:rotateZ(315deg) rotateX(-90deg);
}
to{
	transform:rotateZ(315deg) rotateX(-30deg);
}
Copy the code

}

@keyframes flowerinner1{
from{
	transform:rotateZ(0deg) rotateX(-90deg);
}
to{
	transform:rotateZ(0deg) rotateX(-60deg);
}
Copy the code

}

@keyframes flowerinner2{
from{
	transform:rotateZ(45deg) rotateX(-90deg);
}
to{
	transform:rotateZ(45deg) rotateX(-60deg);
}
Copy the code

}

@keyframes flowerinner3{
from{
	transform:rotateZ(90deg) rotateX(-90deg);
}
to{
	transform:rotateZ(90deg) rotateX(-60deg);
}
Copy the code

}

@keyframes flowerinner4{
from{
	transform:rotateZ(135deg) rotateX(-90deg);
}
to{
	transform:rotateZ(135deg) rotateX(-60deg);
}
Copy the code

}

@keyframes flowerinner5{
from{
	transform:rotateZ(180deg) rotateX(-90deg);
}
to{
	transform:rotateZ(180deg) rotateX(-60deg);
}
Copy the code

}

@keyframes flowerinner6{
from{
	transform:rotateZ(225deg) rotateX(-90deg);
}
to{
	transform:rotateZ(225deg) rotateX(-60deg);
}
Copy the code

}

@keyframes flowerinner7{
from{
	transform:rotateZ(270deg) rotateX(-90deg);
}
to{
	transform:rotateZ(270deg) rotateX(-60deg);
}
Copy the code

}

@keyframes flowerinner8{
from{
	transform:rotateZ(315deg) rotateX(-90deg);
}
to{
	transform:rotateZ(315deg) rotateX(-60deg);
}
Copy the code

}

The following code is a lot of repetition, only the adjustment of the value, the principle is to make different petals stand up from the plane, rotate around different axes so that their relative positions can be combined into the desired effect.