最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

利用CSS3繪制打火機動畫火焰的效果

來源:懂視網(wǎng) 責(zé)編:小OO 時間:2020-11-27 18:48:23
文檔

利用CSS3繪制打火機動畫火焰的效果

本文實例為大家分享了純CSS3繪制打火機動畫火焰效果的具體代碼,供大家參考,具體內(nèi)容如下:主要涉及到了以下屬性。<;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代碼如下:
推薦度:
導(dǎo)讀本文實例為大家分享了純CSS3繪制打火機動畫火焰效果的具體代碼,供大家參考,具體內(nèi)容如下:主要涉及到了以下屬性。<;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代碼如下:
這篇文章主要為大家詳細介紹了純CSS3繪制打火機動畫火焰效果的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

主要涉及到了以下屬性:

<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代碼如下:

 <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">
 <h1 class="keTitle">純CSS3繪制打火機動畫火焰特效</h1>
 <p class="kePublic">
 <p class="playground">
 <p class="flame"></p>
 <p class="lighterBody">
 <p class="hover">hover me</p>
 </p>
 <p class="lid"></p>
 </p>
 <p class="clear"></p>
 </p>
 </body>
</html></span>

style.css文件如下:

<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>

初始照片:

動態(tài)照片

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

 <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>

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

<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)實現(xiàn)的。
當(dāng)打火機打開時出現(xiàn)的圓球和白色的小正方形,是由:after :before 配合z-index實現(xiàn)的效果。

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

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

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

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

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

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

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

利用CSS3繪制打火機動畫火焰的效果

本文實例為大家分享了純CSS3繪制打火機動畫火焰效果的具體代碼,供大家參考,具體內(nèi)容如下:主要涉及到了以下屬性。<;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代碼如下:
推薦度:
標(biāo)簽: 利用 火焰 動畫
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top