搜尋
首頁web前端前端問答十分鐘教你使用css實現煙霧效果

這篇文章跟大家分享如何利用css實現煙霧的效果,希望對大家有幫助。

十分鐘教你使用css實現煙霧效果

仔細觀察煙霧效果,有兩個比較重要的特點:

  • 模糊效果

  • #顆粒感

先看模糊效果,想到模糊,大部分同學會先想到要使用filter: blur() 。

當然沒錯,不過在 CSS 中,除了濾鏡,我們還能用其他方法一類來模擬模糊的效果。

純CSS 實作煙霧動畫

我們先來看這樣一個效果:

十分鐘教你使用css實現煙霧效果

假設,我們有這樣一個字元:

<span>C</span>

我們只是透過text-shadow opacity 的變化,就能模擬煙霧的效果:

span {
  text-shadow: 0 0 0 whitesmoke;
  animation: smoky 5s;
}
@keyframes smoky {
  to {
    text-shadow: 0 0 20px whitesmoke;
    opacity: 0;
  }
}

在上述的基礎上,我們可以加上位移、旋轉、縮放,稍微改造一下上述程式碼,加入一些transform 變換:

span {
  text-shadow: 0 0 0 whitesmoke;
  animation: smoky 5s;
}
@keyframes smoky {
  to {
    transform:
      translate3d(200px, -80px, 0)
      rotate(-40deg)
      skewX(70deg)
      scale(1.5);
    text-shadow: 0 0 20px whitesmoke;
    opacity: 0;
  }
}

就可以得到以下效果:

十分鐘教你使用css實現煙霧效果

##疊加了transform之後,就很有一個字被吹跑,變成煙霧的感覺。在此基礎之上,我們只需要將多個字放在一起,利用 animation-delay 順序控制每個字觸發動畫效果,即可得到上述的完整煙霧效果。

偽代碼如下:

<span>C</span> S S // ...
// ... 上述所有 CSS 代码
@for $item from 1 through 21 {
  span:nth-of-type(#{$item}){ 
    animation-delay: #{(($item/10))}s; 
  }
}

借助SVG feturbulence 濾鏡實現煙霧效果

上述的煙霧動畫的煙霧還是比較粗糙的。主要是缺少了一點顆粒感?缺少了一些煙霧的質感。

想要實現更精緻的煙霧效果,我們還得借助SVG 的 濾鏡

接下來會使用filter: blur() 配合 濾鏡,得到更逼真的煙霧效果。

舉個簡單的例子,假設有這樣幾個字:

<div">SMOKE</div>

簡單的CSS:

div {
    background: linear-gradient(#fff, #999, #ddd, #888);
    background-clip: text;
}

得到這樣幾個帶漸變色字:

十分鐘教你使用css實現煙霧效果

我們利用 濾鏡簡單處理一下:

<div>SMOKE</div>
<svg width="0">
  <filter id="filter">
    <feTurbulence id="turbulence" type="fractalNoise" baseFrequency=".03" numOctaves="20" />
    <feDisplacementMap in="SourceGraphic" scale="30" />
  </filter>
</svg>

CSS 的中利用filter: url() 引入該濾鏡,這裡為了效果更好,我直接在 上引入了該濾鏡:

body {
    filter: url(&#39;#filter&#39;);
}
div {
    background: linear-gradient(#fff, #999, #ddd, #888);
    background-clip: text;
}

我們的字體就被 濾鏡賦予了一種流體的感覺:

十分鐘教你使用css實現煙霧效果

這個效果可以說和煙霧效果基本上沒什麼關係,不過只需要再添加一個模糊濾鏡,神奇的事情就發生了:

body {
    filter: url(&#39;#filter&#39;);
}
div {
    background: linear-gradient(#fff, #999, #ddd, #888);
    background-clip: text;
    filter: blur(5px);
}

整個效果就瞬間煙霧化了很多:

十分鐘教你使用css實現煙霧效果

好,為它加上上迴圈的動畫效果,簡單的借助JavaScript 處理一下:

const filter = document.querySelector("#turbulence");
let frames = 1;
let rad = Math.PI / 180;
let bfx, bfy;
function freqAnimation() {
    frames += .2
    bfx = 0.03;
    bfy = 0.03;
    bfx += 0.005 * Math.cos(frames * rad);
    bfy += 0.005 * Math.sin(frames * rad);
    bf = bfx.toString() + " " + bfy.toString();
    filter.setAttributeNS(null, "baseFrequency", bf);
    window.requestAnimationFrame(freqAnimation);
}
window.requestAnimationFrame(freqAnimation);

看看效果:

十分鐘教你使用css實現煙霧效果

當然,上述效果可以透過:

控制 的baseFrequency 屬性調節

控制 的numaves 屬性來調節#Oct

控制 的scale 屬性調節

的numOctaves 屬性由30 改成70,基本上就看不到文字的輪廓了,文字整個霧化。我們可以製作類似這樣的hover 效果:

十分鐘教你使用css實現煙霧效果

上述完整程式碼,你可以猛擊這裡:CodePen CSS SVG Text Smoke Hover Effect

#這樣,基於filter: blur() 配合 濾鏡,我們可以得到非常逼真的煙霧效果,基於上述的演示,我們還可以再挖掘非常多有意思的效果,本文就不再贅述

(學習影片分享:

css影片教學

以上是十分鐘教你使用css實現煙霧效果的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:掘金。如有侵權,請聯絡admin@php.cn刪除
課程和ID選擇器之間的差異是什麼?課程和ID選擇器之間的差異是什麼?May 12, 2025 am 12:13 AM

classSelectorSareVersAtileAndReusable,whileIdSelectorSareEctorAreNiqueAndspecific.1)USECLASSSELECTORS(表示)forStylingmultilemtsswithsharedCharacteristics.2)UseIdSelectors.2)UseIdSelectors(eustotedBy#)

CSS IDS vs類:真正的差異CSS IDS vs類:真正的差異May 12, 2025 am 12:10 AM

IDSareuniqueIdentifiersForsingLelements,而LileclassesstyLemultiplelements.1)useidsforuniquelementsand andjavascripthooks.2)useclassesforporporporblesable,flexiblestylestylestylinglingactossmultiplelements。

CSS:如果我只使用課程怎麼辦?CSS:如果我只使用課程怎麼辦?May 12, 2025 am 12:09 AM

使用僅類選擇器可以提高代碼的重用性和可維護性,但需要管理類名和優先級。 1.提高重用性和靈活性,2.組合多個類創建複雜樣式,3.可能導致冗長類名和優先級問題,4.性能影響微小,5.遵循最佳實踐如簡潔命名和使用約定。

CSS中的ID和類選擇器:初學者指南CSS中的ID和類選擇器:初學者指南May 12, 2025 am 12:06 AM

ID和class選擇器在CSS中分別用於唯一和多元素的樣式設置。 1.ID選擇器(#)適用於單一元素,如特定導航菜單。 2.Class選擇器(.)用於多元素,如統一按鈕樣式。應謹慎使用ID,避免過度特異性,並優先使用class以提高樣式複用性和靈活性。

了解HTML5規範:關鍵目標和利益了解HTML5規範:關鍵目標和利益May 12, 2025 am 12:06 AM

HTML5的關鍵目標和優勢包括:1)增強網頁語義結構,2)改進多媒體支持,3)促進跨平台兼容性。這些目標帶來更好的可訪問性、更豐富的用戶體驗和更高效的開發流程。

HTML5的目標:網絡未來的開發人員指南HTML5的目標:網絡未來的開發人員指南May 11, 2025 am 12:14 AM

HTML5的目標是簡化開發過程、提升用戶體驗和確保網絡的動態性和可訪問性。 1)通過原生支持音視頻元素簡化多媒體內容的開發;2)引入語義元素如、等,提升內容結構和SEO友好性;3)通過應用緩存增強離線功能;4)使用元素提高頁面交互性;5)優化移動兼容性,支持響應式設計;6)改進表單功能,簡化驗證過程;7)提供性能優化工具如async和defer屬性。

HTML5:使用新功能和功能轉換網絡HTML5:使用新功能和功能轉換網絡May 11, 2025 am 12:12 AM

html5transformswebdevelopmentbyIntroducingSemanticlements,多種型,功能強大,功能性和表現性影響力圖。 1)semanticelementslike,,, andenhanceseoandAcccostibility.2)多層次andablawlyementsandablowemediaelementsandallawallawaldawallawaldawallawallawallawallawallawallawallawallallownallownallownallownallownallowembedembbeddingwithingwithingwithoutplugins iff inform

ID與CSS中的課程:全面比較ID與CSS中的課程:全面比較May 11, 2025 am 12:12 AM

TherealdifferencebetweenusinganIDversusaclassinCSSisthatIDsareuniqueandhavehigherspecificity,whileclassesarereusableandbetterforstylingmultipleelements.UseIDsforJavaScripthooksoruniqueelements,anduseclassesforstylingpurposes,especiallywhenapplyingsty

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境