中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

純CSS3如何繪制打火機動畫火焰效果

發布時間:2021-05-19 13:49:19 來源:億速云 閱讀:174 作者:小新 欄目:web開發

小編給大家分享一下純CSS3如何繪制打火機動畫火焰效果,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

本文實例為大家分享了純CSS3繪制打火機動畫火焰效果的具體代碼,供大家參考,具體內容如下

主要涉及到了以下屬性:

XML/HTML Code復制內容到剪貼板

<span style="font-family:Comic Sans MS;">animation(webkit-animation),   
@keyframes name (@-webkit-keyframes name),   
transform,   
transform-origin,   
transition,   
box-shadow(spread屬性),   
text-shadow   
z-index   
linear-gradient。   
radial-gradient   
background-image    
</span>

 
首先html代碼如下:

XML/HTML Code復制內容到剪貼板

 <span style="font-family:Comic Sans MS;"><!DOCTYPE html>  
<html>  
 <head>  
  <meta charset="UTF-8">  
  <title>純CSS繪制打火機動畫火焰特效</title>  
  <link rel="stylesheet" href="css/style.css">  
 </head>  
 <body class="keBody">  
  <h2 class="keTitle">純CSS3繪制打火機動畫火焰特效</h2>  
  <div class="kePublic">  
   <div class="playground">  
    <div class="flame"></div>  
    <div class="lighterBody">  
     <div class="hover">hover me</div>  
    </div>  
    <div class="lid"></div>  
   </div>  
   <div class="clear"></div>  
  </div>    
 </body>  
</html></span>

style.css文件如下:

CSS Code復制內容到剪貼板

<span style="font-family:Comic Sans MS;">@charset "utf-8";   
body{   
 margin:0;   
 padding:0;   
 color:#333;   
 text-align:center;   
 font:12px "微軟雅黑";   
}   
:before,:after{   
 position:absolute;   
 content:"";   
}   
.keBody{   
 background:url(../images/bodyBg.jpg) repeat #333;   
}   
.keTitle{   
 height:100px;   
 line-height:100px;   
 font-size:30px;   
 font-family:'微軟雅黑';   
 color:#fff;   
 text-align:center;   
 background:url(../images/bodyBg3.jpg) repeat-x bottombottom left;   
 font-weight:normal;   
 margin-bottom:0;   
}   
.kePublic{   
 background:#cccccc;   
 padding:50px;   
}   
.playground{   
 position:relative;   
 width:140px;   
 height:400px;   
 left:50%;   
 margin-left:-70px;   
}   
.flame{   
   opacity: 0;   
   position: absolute;   
   bottombottom: 60%;   
   left: 42%;   
   width: 14px;   
   height: 70px;   
   background-color: white;   
   border-radius: 100% 100% 0 0;   
   box-shadow: 0 0 20px #FFFEF0, 0 0 20px #FFFEE6, 0 0 20px #fefcc9,  10px -10px 30px #feec85,  -20px -20px 40px #ffae34,  20px -40px 50px #ec760c,  -20px -60px 60px #cd4606,  0 -80px 70px #973716,  10px -90px 80px #451b0e;   
      
}   
.playground:hover .flame {   
 opacity:1;   
 transition:opacity 3s linear;   
 -webkit-animation:flame 1s infinite linear;   
  
}   
.playground:hover .lid{   
 -webkit-animation:lidoff 1s linear;   
 /*把物體動畫地從一個地方移動到另一個地方,并讓它停留在那里:*/  
 -webkit-animation-fill-mode:forwards;   
}   
.lighterBody{   
 position:absolute;   
 width:140px;   
 height:130px;   
 top:200px;   
 left:0;   
 background-image:linear-gradient(to rightright,#959595 0%,#0d0d0d 46%,#010101 50%,#0a0a0a 53%,   
     #4e4e4e 76%,#383838 87%,#1b1b1b 100%);   
 border-radius:2% 2% 8% 8%;   
 box-shadow:inset 0 0 5px 5px #333;   
}   
.lighterBody:before{   
 width:47px;   
 height:47px;   
 top:-50px;   
 left: 42px;   
 content:"...";   
 color:#e6e6e6;   
 border-radius:6% 6% 0 0;   
 background-image:linear-gradient(to rightright,#f5f5f5 0%,#dbdce2 21%,#b8bac6 49%,#dddfe3 80%,#f5f6f6 100%);   
 font-size:30px;   
 font-weight:bold;   
 letter-spacing:7px;   
 line-height:16px;   
 text-shadow:0 0 5px black;   
 padding-top:3px;   
 padding-left:4px;   
}   
.lighterBody:after{   
 width:33px;   
 height:33px;   
 background-image:radial-gradient(ellipse at center,#7d737d 0%,#0e0e0e 100%);   
 border-radius:100%;   
 top:-33px;   
 left:10px;   
 box-shadow:inset 0 0 1px 2px gray;   
}   
.lid{   
 z-index:2;   
 position:absolute;   
 width:140px;   
 height:75px;   
 top:125px;   
 left:0;   
 background:linear-gradient(to rightright,#959595 0%,#0d0d0d 46%, #010101 50%, #0a0a0a 53%, #4e4e4e 76%, #383838 87%, #1b1b1b 100%);   
 border-radius:8% 8% 2% 2%;   
 box-shadow:inset 0 0 5px 5px #333;   
 /*border-bottom:3px solid #f2f2f2;*/  
}   
.lid:before{   
 width:10px;   
 height:10px;   
 top:70px;   
 left:133px;   
 background-image:radial-gradient(ellipse at center, #959595 0%, #0d0d0d 46%, #010101 50%, #0a0a0a 53%, #4e4e4e 76%, #383838 87%, #1b1b1b 100%);   
 border-radius:100%;   
}   
  
.hover{   
 z-index:1;   
 text-align:center;   
 margin-top:30%;   
 color:rgba(255,255,255,0.9);   
 text-shadow:0 1px 1px rgba(0,0,0,0.8);   
 font: 20px "微軟雅黑";   
}   
.hover:before{   
 content:"";   
 z-index:1;   
 width:0;   
 height:0;   
 top:-50px;   
 left:20px;   
 border-bottom:35px solid #f2f2f2;   
 /*border-left:10px solid transparent;*/  
}   
@-webkit-keyframes flame{   
 0%{   
  height:70px;   
  transform:skewY(0deg);   
  border-radius:100% 100% 0 0;   
 }   
 25%{   
  height:60px;   
  transform:skewY(40deg);   
  border-radius:10% 100% 0 0;   
 }   
 60%{   
  height:65px;   
  transform:skewY(-20deg);   
  border-radius:90% 10% 0 0;   
 }   
 70%{   
  height:50px;   
  transform:skewY(10deg);   
  border-radius:10% 100% 0 0;   
 }   
 100%{   
  height:70px;   
  tranform:skewY(0deg);   
 }   
}   
@-webkit-keyframes lidoff{   
 from{   
  transform:rotate(0deg);   
  transform-origin:100% 100%;   
 }   
 to{   
  transform:rotate(130deg);   
  transform-origin:100% 100%;   
 }   
}</span>

初始照片:

純CSS3如何繪制打火機動畫火焰效果

動態照片

純CSS3如何繪制打火機動畫火焰效果

動畫效果主要有兩個,一是當鼠標懸停在“hover me”上面時打火機蓋子打開的情形,由下面的動畫代碼實現:

XML/HTML Code復制內容到剪貼板

 <span style="font-family:Comic Sans MS;font-size:12px;">@-webkit-keyframes lidoff{     注意這里要加上-webkit-   
     from{   
          transform:rotate(0deg);   
          transform-origin:100% 100%;   
     }   
     to{   
          transform:rotate(130deg);   
          transform-origin:100% 100%;   
     }   
}    
</span>

 第二個動畫是蠟燭燈光效果的實現:蠟燭由按變量是由transition:opacity 3s linear; 實現的,
 
蠟燭燈光的隨風擺動效果是由下面的代碼實現的:

XML/HTML Code復制內容到剪貼板

<span style="font-family:Comic Sans MS;font-size:12px;">@-webkit-keyframes lidoff{   
    from{   
         transform:rotate(0deg);   
         transform-origin:100% 100%;   
    }   
    to{   
         transform:rotate(130deg);   
         transform-origin:100% 100%;   
    }   
</span>

 將打火機蓋與軀干分離的效果是由:box-shadow:inset 0 0 5px 5px #333; 主要是這里的inset(注意不要寫成了insert)實現的。
 
當打火機打開時出現的圓球和白色的小正方形,是由:after :before 配合z-index實現的效果。 

下面來介紹通過這個例子我的學到的幾個屬性需要注意的地方。

transform-origin:  默認的初始位置是圖像的中心,100% 100%相當于 right bottom.  0% 0%相當于  left top.

before  和:after  : 注入的內容是有關聯的目標元素的字子元素,但它會被置于這個元素任何內容的“前” 或"后"。插入的內容在頁面的源碼里是看不見的,只能在css里看見。同時插入的元素在默認情況是內聯元素。因此,為了給插入的元素賦予高度、填充、邊距等等,通常必須顯示的定義一個塊級元素(display:block)。
 
此外,雖然可能不會插入任何內容,但是content必須寫上,如果不插入任何內容,那么content寫成    content:"";
 
IE6和IE7不兼容這兩個為元素

偽元素(雙冒號),css3中的偽類是(單冒號)

animation-fill-mode: none|forwards|backwards|both|initial|inherit;
 
規定當動畫不播放時(當動畫完成時,或當動畫有一個延遲未開始播放時),要應用到元素的樣式。

background-image:解決了div只能設置一個背景的問題,使一個div可以設置多個背景圖片。
 
box-shadow:一個經常被遺忘的參數--spread(擴展陰影半徑),這個曾經被遺忘的spread改變陰影的大小---其值可以是正負值,如果值為正,則整個陰影都延展擴大,反之是負值,則縮小。有了這個參數后可以使用box-shadow像photoshop中的陰影工作一樣,制作單邊陰影效果。這里注意一點,這個擴展陰影值需要和陰影模糊半徑配合使用,一般情況是“擴展陰影半徑一般設置為和模糊半徑大小,并去其負值”

以上是“純CSS3如何繪制打火機動畫火焰效果”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宁南县| 肇源县| 广南县| 鸡西市| 宜黄县| 镇江市| 垦利县| 怀仁县| 贡觉县| 绥中县| 皋兰县| 云南省| 沙河市| 会昌县| 仁化县| 景泰县| 维西| 扎鲁特旗| 黑龙江省| 开平市| 安顺市| 都安| 冕宁县| 阆中市| 麻城市| 沙坪坝区| 来宾市| 庄河市| 海晏县| 东莞市| 郴州市| 怀宁县| 和田市| 邓州市| 浮山县| 峨眉山市| 云霄县| 淳化县| 东港市| 雷波县| 镇安县|