<!-- Teemo -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>CSS實(shí)現(xiàn)天氣</title>
<style type="text/css">
.weather{
position: relative;
display: inline-block;
width: 180px;
height: 240px;
background: #23b7e5;
border-radius: 8px;
}
.sunny:before{
content: "";
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%,-50%); /*定位、旋轉(zhuǎn)等*/
width: 60px;
height: 60px;
background: #F6D963;
border-radius: 50%;
box-shadow: 0 0 20px #ff0; /*陰影-外發(fā)光效果;水平-上下-大小-顏色*/
z-index: 2;/*設(shè)置元素的堆疊順序。擁有更高堆疊順序的元素總是會(huì)處于堆疊順序較低的元素的前面;分層顯示*/
}
.sunny:after{
content: "";
position: absolute;
top: 50%;
left: 50%;
margin: -45px 0 0 -45px;
width: 90px;
height: 90px;
background: #FFEB3B;
clip-path: polygon(? /*繪制圖形*/
50% 0%,
65.43% 25%,
93.3% 25%,
78.87% 50%,
93.3% 75%,
64.43% 75%,
50% 100%,
35.57% 75%,
6.7% 75%,
21.13% 50%,
6.7% 25%,
35.57% 25%
);
z-index: 1;
animation: sunScale 2s linear infinite;/*實(shí)現(xiàn)動(dòng)畫*/
}
@keyframes sunScale {
0%{
transform: scale(1);
}
50%{
transform: scale(1.1);
}
100%{
transform: scale(1);
}
}
.cloudy:before,.rainy:before,.snowy:before{
content: "";
position: absolute;
top: 50%;
left: 25%;
transform: translate(-50%,-50%);
width: 36px;
height: 36px;
background: #fff;
border-radius: 50%;
z-index: 2;
box-shadow: #fff 22px -15px 0 6px,
#fff 57px -6px 0 2px,
#fff 87px 4px 0 -4px,
#fff 33px 6px 0 6px,
#fff 61px 6px 0 2px,
#ccc 29px -23px 0 6px,
#ccc 64px -14px 0 2px,
#ccc 94px -4px 0 -4px;
}
/*box-shadow: h-shadow v-shadow blur spread color inset;
參數(shù)詳解:
h-shadow: 陰影的水平偏移量。
v-shadow: 陰影的垂直偏移量。
blur: 模糊距離(就是漸變的距離,設(shè)為0就沒有漸變)。
spread: 投影的尺寸,通過這個(gè)控制“影分身”的大小。
color: 投影顏色,通過這個(gè)實(shí)現(xiàn)后方的烏云。
inset: 改為內(nèi)陰影。這里用不到。*/
.cloudy:before{
animation: cloudMove 2s linear infinite;
}
@keyframes cloudMove {
0%{
transform: translate(-50%,-50%);
}
50%{
transform: translate(-50%,-60%);
}
100%{
transform: translate(-50%,-50%);
}
}
.rainy:after {
/*這里使用 :after 偽類實(shí)現(xiàn)雨滴。
先實(shí)現(xiàn)一個(gè)雨滴(為方便觀看,暫時(shí)隱藏云朵):*/
? content: "";
? ? position: absolute;
top:50%;
left: 25%;
width: 4px;
height: 14px;
background: #fff;
border-radius: 2px;
/*然后通過box-shadow“影分身”:*/
box-shadow:
#fff 25px -10px 0,
#fff 50px 0 0,
#fff 75px -10px 0,
#fff 0 25px 0,? ? ? ?
#fff 25px 15px 0,? ? ? ?
#fff 50px 25px 0,? ? ? ?
#fff 75px 15px 0,
#fff 0 50px 0,
#fff 25px 40px 0,
#fff 50px 50px 0,
#fff 75px 40px 0;
animation: rainDrop 2s linear infinite;
}
@keyframes rainDrop {
0% {
transform: translate(0,0) rotate(10deg);
}
100% {
transform: translate(-4px,24px) rotate(10deg);
box-shadow:
#fff 25px -10px 0,
#fff 50px 0 0,
#fff 75px -10px 0,
#fff 0 25px 0,
#fff 25px 15px 0,
#fff 50px 25px 0,
#fff 75px 15px 0,
rgba(255,255,255,0) 0 50px 0,
rgba(255,255,255,0) 25px 40px 0,
rgba(255,255,255,0) 50px 50px 0,
rgba(255,255,255,0) 75px 40px 0;
? ? }
}
.snowy:after {
content: "";
position: absolute;
top: 50%;
left: 25%;
width: 8px;
height: 8px;
background: #fff;
border-radius: 50%;
box-shadow:
#fff 25px -10px 0,
#fff 50px 0 0,
#fff 75px -10px 0,
#fff 0 25px 0,
#fff 25px 15px 0,
#fff 50px 25px 0,
#fff 75px 15px 0,
#fff 0 50px 0,
#fff 25px 40px 0,
#fff 50px 50px 0,
#fff 75px 40px 0;
animation: snowDrop 2s linear infinite;
}
@keyframes snowDrop {
0% {
transform: translateY(0);
}
100% {
transform: translateY(25px);
box-shadow:
#fff 25px -10px 0,
#fff 50px 0 0,
#fff 75px -10px 0,
#fff 0 25px 0,
#fff 25px 15px 0,
#fff 50px 25px 0,
#fff 75px 15px 0,
rgba(255,255,255,0) 0 50px 0,
rgba(255,255,255,0) 25px 40px 0,
rgba(255,255,255,0) 50px 50px 0,
rgba(255,255,255,0) 75px 40px 0;
}
}
</style>
</head>
<body>
<!-- 晴 -->
<div class="weather sunny"></div>
<!-- 陰 -->
<div class="weather cloudy"></div>
<!-- 雨 -->
<div class="weather rainy"></div>
<!-- 雪 -->
<div class="weather snowy"></div>
</body>
</html>