CSSアニメーションとSVGを組み合わせてエネルギーの流れの効果を作成する

CSSアニメーションとSVGを組み合わせてエネルギーの流れの効果を作成する

最終的な効果は次のようになります。

アニメーションは2つのステップに分かれています

  • ランニング軌道を開発する
  • DOMを作成し、パスに沿ってアニメーションする

ランニング軌道を開発する

まず、エネルギーの流れのパイプラインとして、下部に水色の半透明の道路を描く必要があります。ここでは SVG パスを使用します (実際には、ここで背景画像を直接使用できます)。コードは次のとおりです。

<!-- コードは react で書かれており、トラバーサルと一部のコードは削除されています -->

<svg>
    <!-- ツールの説明プロンプト。フィルタリングやその他の操作の塗りつぶしに使用されます。ボールの下部の輝きはここにあります -->
    <定義>
        <radialGradient id="grad1" cx="50%" cy="50%" r="50%" fx="50%" fy="50%">
            <stop offset="0%" style={{ stopColor: "rgba(2,246,255,.5)" }} />
            <stop offset="100%" style={{ stopColor: "rgba(2,246,255,0)" }} />
        </放射状グラデーション>
    </defs>
    <!-- ここでは、N 本の水色の線のパス d をパスとしてトラバースします -->
    <path d={item.path} ストローク="rgba(29,159,167,0.4)" 塗りつぶし="透明" ストローク幅={5}></path>
    ...
    <!-- 2 つの円を重ねて形成された光るボールです -->
    <g>
        <circle cx={cx} cy={cy} r="15" fill="url(#grad1)"></circle>
        <circle cx={cx} cy={cy} r="5" fill="rgba(2,246,255)"></circle>
    </g>
</svg>

DOMを作成し、パスに沿ってアニメーションする

ここでの核となる原則は、 offset-path プロパティを通じてモーション オフセット パスを設定し、次に offset-distance を通じてオフセットを設定することです。これにより、要素は CSS3 アニメーションを通じて特定の軌道に沿って移動できるようになります。

<!-- ここでは、パス ポイントが一貫しているように、ボックスと SVG ボックスが同じ幅と高さで揃っていることを確認する必要があります -->
<div className={styles.animate}>
    <!-- ここでは N 個の div をトラバースし、各 div を offsetPath (SVG のパスの d の値) に従ってフローさせます -->
    <!-- 負の animationDelay はレンダリング前に実行されることを意味し、レンダリング中にパス全体をカバーできます -->
    <div key={index} className={styles.point3} style={{ "offsetPath": "path('M 105 34 L 5 34')", "animationDelay": `-${index * 1}s`, "animationDuration": '5s', 'animationPlayState': `${stop ? 'paused' : 'running'}` }}></div>
    ...
</div>
.point3 {
    幅: 10px;
    高さ: 2px;
    // オフセットパス: path('M 248 108 L 248 172 L 1510 172');
    オフセット距離: 0%;
    アニメーション: フロー 20 秒 線形 法線 無限;
    背景画像: 線形グラデーション(右へ、rgba(255, 255, 255, 0) 10%、#FEFE02);
    位置: 絶対;
    左: 0;
    右: 0;
}
}

@keyframesフロー{
    から {
        オフセット距離: 0%;
    }

    に {
        オフセット距離: 100%;
    }
}

これで、SVG で CSS アニメーションを使用してエネルギー フロー効果を作成する方法についての説明は終了です。SVG で CSS アニメーションを使用する方法の詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

<<:  MySQL の current_timestamp の落とし穴とその解決策を共有する

>>:  サーバー同時実行数の推定式と計算方法

推薦する

Alibaba Cloud ECS サーバーでポート 8080 を開く方法

セキュリティ上の理由から、Alibaba Cloud Server ECS にはデフォルトで独自のセ...

MySQL でデータの重複挿入を回避する 4 つの方法

最も一般的な方法は、フィールドに主キーまたは一意のインデックスを設定することです。重複データを挿入す...

Linux システム構成 (サービス制御) の詳細な紹介

目次序文1. システムサービス制御1. システムctl 2. ターゲット3. 共通システムサービス4...

vue backtop コンポーネントを実装するための完全なコード

効果: コード: <テンプレート> <div class="back-t...

ウェブページ制作時のコードコメントの書き方

<br />私の仕事で使用しているアノテーションの書き方の基準をまとめました。技術的な内...

CSS3はテキストのレリーフ効果、彫刻効果、炎のテキストを実現します

この効果を実現するには、まず CSS のプロパティを知っておく必要があります。 text-shado...

JavaScript を使用して div の位置をドラッグして入れ替える例

1 実施原則これは、DOM 要素の dragstart/ondragover/ondrop イベント...

JavaScript で動的な QML オブジェクトを作成する方法

1. オブジェクトを動的に作成するJavaScript からオブジェクトを動的に作成する方法は 2 ...

CSS コード省略 div+css レイアウト コード省略仕様

略語を使用すると、CSS ファイルのサイズが小さくなり、読みやすくなります。 CSS 省略形の主なル...

MySQL クエリ キャッシュとバッファ プール

1. キャッシュ - クエリキャッシュ次の図は、MySQL 公式サイトから提供されています: MyS...

html.cssオーバーフローの包括的な理解

html.cssオーバーフローの包括的な理解XML/HTML コードコンテンツをクリップボードにコピ...

Docker ロード後にイメージ名が none になる問題の解決方法

最近、docker load -i コマンドを使用してイメージ パッケージを圧縮した後、イメージ名と...

MySQL 8.0 のユーザーとロールの管理原則と使用方法の詳細

この記事では、MySQL 8.0 のユーザーとロールの管理について例を挙げて説明します。ご参考までに...

offsetWidth、clientWidth、scrollWidth、scrollTop、scrollLeft などのプロパティの図。

注 1: 上の画像の背景全体がこの Web ページのフルサイズであり、中央の小さなボックスがブラウザ...

高度なクローラー - JS 自動レンダリングのための Scrapy_splash コンポーネントの使用

目次1. scrapy_splash とは何ですか? 2. scrapy_splashの役割3. s...