ホームページ >ウェブフロントエンド >フロントエンドQ&A >CSS を使用して煙の効果を 10 分で実現する方法を教えます

CSS を使用して煙の効果を 10 分で実現する方法を教えます

WBOY
WBOY転載
2022-01-14 18:08:253301ブラウズ

この記事では、CSS を使用して煙の効果を実現する方法を紹介します。皆様のお役に立てれば幸いです。

CSS を使用して煙の効果を 10 分で実現する方法を教えます

#煙のエフェクトを詳しく見てみると、2 つの重要な機能があります:

    #ぼかしエフェクト
  • 粒状感
  • まずぼかし効果を見てみましょう。ぼかしについて考えるとき、ほとんどの学生はフィルター: Blur() の使用を最初に思い浮かべます。

もちろんそれは真実ですが、CSS ではフィルターに加えて、他の種類の手段を使用してぼかし効果をシミュレートすることもできます。

煙アニメーションを実装するための純粋な CSSまずはそのような効果を見てみましょう:

CSS を使用して煙の効果を 10 分で実現する方法を教えますこのようなキャラクターがあるとします:

<span>C</span>

テキストシャドウの不透明度を変更するだけで煙の効果をシミュレートできます:

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

上記に基づいて、ディスプレイスメントを追加できます。回転とスケーリングを行うには、上記のコードを少し変更し、いくつかの変換変換を追加します:

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 を使用して煙の効果を 10 分で実現する方法を教えます 重ね合わせ変換 その後、言葉が吹き飛ばされて煙になったような気がした。これに基づいて、複数の単語をまとめ、アニメーション遅延を使用して各単語を順番に制御するだけでアニメーション効果がトリガーされ、上記の完全な煙効果が得られます。

疑似コードは次のとおりです。

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

SVG 胎児気流フィルターを使用して煙の効果を実現します煙上記の煙のアニメーションはまだ同じですが、比較的荒いです。粒状感が少し足りないのが主な理由でしょうか?煙のテクスチャの一部が欠けています。

より洗練された煙の効果を実現するには、SVG の フィルターを使用する必要があります

次に、filter: Blur() と フィルターを使用して、よりリアルな煙のエフェクト。

簡単な例として、次のような単語がいくつかあるとします。

<div">SMOKE</div>

単純な CSS:

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

次のようなグラデーション色を持つ単語をいくつか取得します。

CSS を使用して煙の効果を 10 分で実現する方法を教えます フィルターを使用して簡単なプロセスを実行します:

<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 を使用して煙の効果を 10 分で実現する方法を教えますこのエフェクトは基本的に煙エフェクトとは何の関係もないと言えますが、ぼかしフィルターを追加するだけで、魔法のようなことが起こります:

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

エフェクト全体が瞬時に煙っぽくなります:

CSS を使用して煙の効果を 10 分で実現する方法を教えますわかりました。ループ アニメーション効果を追加し、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 を使用して煙の効果を 10 分で実現する方法を教えますもちろん、上記の効果は次の方法で実現できます。

のbaseFrequency属性調整を制御します;

のnumOctaves属性調整を制御します

#のscale属性調整を制御のnumOctaves属性を30から70に変更します。完全に霧化されています。次のようなホバー効果を作成できます:

##上記の完全なコードについては、ここをクリックしてください: CodePen CSS SVG Text Smoke Hover Effect

CSS を使用して煙の効果を 10 分で実現する方法を教えますこの方法で フィルターを使用すると、非常にリアルな煙の効果を得ることができます。上記のデモンストレーションに基づいて、多くの興味深い効果を探索することもできますが、この記事では詳しく説明しません

( 学習ビデオ共有:

css ビデオ チュートリアル

)

以上がCSS を使用して煙の効果を 10 分で実現する方法を教えますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjuejin.imで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。