純css製做電閃雷鳴的天氣圖標

效果

效果圖以下
電閃雷鳴天氣圖標css

實現思路

  1. 使用box-shadow屬性寫幾個圓,將這些圓錯落的組合在一塊兒,造成雲朵圖案
  2. after僞元素寫下面的投影樣式
  3. before僞元素寫黃色閃電的樣式

dom結構

  用兩個嵌套的div容器就能夠了,父容器來控制圖標顯示的位置,子容器用來寫烏雲的樣式。而陰影和閃電的樣式都用僞元素就能夠了,這些都是在css中定義的。dom

<div class="container">
    <div class="stormy"></div>
</div>

css樣式

css按照步驟來實現
一、先寫父容器樣式,順便給整個頁面加個背景色,方便預覽動畫

body{
    background: rgba(73,74,95,1);
}
 
.container{
    width: 170px;
    height: 170px;
    position: relative;
    margin: 250px auto;
}

二、寫烏雲的樣式,別忘了烏雲有一個上下移動的動畫效果spa

.stormy{
    width: 50px;
    height: 50px;
    position: absolute;
    left: 80px;
    top: 70px;
    margin-left: -60px;
    background: #222;
    border-radius: 50%;
    box-shadow: #222 64px -15px 0 -5px,
        #222 25px -25px,
        #222 30px 10px,
        #222 60px 15px 0 -10px,
        #222 85px 5px 0 -5px;
    animation: stormy 5s ease-in-out infinite;
}
 
@keyframes stormy{
    50%{
        transform: translateY(-20px);
    }
}

三、陰影樣式,一樣是有動畫的3d

.stormy::after{
    content: '';
    width: 120px;
    height: 15px;
    position: absolute;
    left: 5px;
    bottom: -60px;
    background: #000;
    border-radius: 50%;
    opacity: 0.2;
    transform: scale(0.7);
    animation: stormy_shadow 5s ease-in-out infinite;
}
 
@keyframes stormy_shadow{
    50%{
        transform: translateY(20px) scale(1);
        opacity: 0.05;
    }
}

四、閃電樣式code

.stormy::before{
    display: block;
    content: '';
    width: 0;
    height: 0;
    position: absolute;
    left: 57px;
    top: 70px;
    border-left:  0px solid transparent;
    border-right: 7px solid transparent;
    border-top: 43px solid yellow;
    box-shadow: yellow -7px -32px;
    transform:  rotate(14deg);
    transform-origin: 50% -60px;
    animation: stormy_thunder 2s steps(1, end) infinite;
}
 
@keyframes stormy_thunder{
    0%{
        transform: rotate(20deg);
        opacity: 1;
    }
    5%{
        transform: rotate(-34deg);
        opacity: 1;
    }
    10%{
        transform: rotate(0deg);
        opacity: 1;
    }
    15%{
        transform: rotate(-34deg);
        opacity: 0;
    }
}

OK,搞定。按着步驟來,你也能夠在你的頁面上實現酷炫的電閃雷鳴天氣圖標咯~orm

相關文章
相關標籤/搜索