CSS を解析して画像のテーマカラー機能を抽出する (ヒント)

CSS を解析して画像のテーマカラー機能を抽出する (ヒント)

背景

すべては、WeChat 技術グループのクラスメートが「写真の主な色を取得する方法はあるか」と尋ねたことから始まりました。写真があります。そのメインカラーを取得します。

取得した色の値を使用して、次のような関数を実装します。コンテナー内に画像があり、背景色を画像の主な色と一致させたい場合、次のようになります。

全員が提案してくれました。計算には Canvas を使うことを提案する人もいれば、専用のオープンソース ライブラリを推奨する人もいました。どちらも良かったです。

では、この機能は CSS を使用して実現できるのでしょうか?

夢物語のようです。CSS でこの効果を実現できるのでしょうか?えーと、CSS を使うと、確かに画像のおおよそのメインカラーを満足のいく形で得ることができます。メインカラーの要件が特に厳密でない場合は、これは良い方法です。一緒に見ていきましょう。

画像のテーマカラーを取得するには、filter: blur() と transform: sacle() を使用します。

ここでは、ぼかしフィルターと拡大効果を使用して、画像のテーマカラーを大まかに取得します。

次のような画像があるとします。

<div></div>

画像にぼかしフィルターを適用します。

div {
    背景: url("https://i0.wp.com/airlinkalaska.com/wp-content/uploads//aurora-2.jpg?resize=1024%2C683&ssl=1");
    背景サイズ: カバー;
    フィルター: ぼかし(50px);
}

効果を見てみましょう。比較的大きなぼかしフィルターを使用して、 blur(50px) 。ぼかした画像はそれっぽい感じがしますが、ぼやけたエッジがいくつかあります。 overflowを使用してトリミングしてみてください。

次に、ぼやけたエッジを削除し、 transform: scale()で効果を増幅して、色に再び焦点を当てる必要があります。コードを少し変更します。

div {
    位置: 相対的;
    幅: 320ピクセル;
    高さ: 200px;
    オーバーフロー: 非表示;
}

div::before {
    コンテンツ: "";
    位置: 絶対;
    上: 0;
    左: 0;
    右: 0;
    下部: 0;
    背景: url("https://i0.wp.com/airlinkalaska.com/wp-content/uploads//aurora-2.jpg?resize=1024%2C683&ssl=1");
    背景サイズ: カバー;
    // コアコード:
    フィルター: ぼかし(50px);
    変換: スケール(3);
}

結果は次のとおりです。

このように、CSS を使用して画像の主な色を取得すると、効果はかなり良好になります。

完全なコードはここにあります: CodePen デモ - フィルターとスケールで画像の主な色を取得します

デメリット

もちろん、この解決策にもいくつか小さな問題があります。

画像の主な色は大まかにしか取得できず、あまり正確ではありません。また、 filter: blur(50px) 50pxデバッグが必要です。blur フィルター自体がパフォーマンスを消費します。ページにこの方法で取得した複数の背景がある場合、パフォーマンスに一定の影響を与える可能性があります。実際に使用する場合は、一定のトレードオフを行う必要があります。

やっと

さて、今回の記事はここまでです。CSSを使って画像のテーマカラーを取得する裏技を紹介しました。参考になれば幸いです😃

この方法を提案してくれたYuewenの学生、XboxYanに感謝します。iCSS WeChatグループは非常に活発で、CSSの専門家が集まっています。技術について議論するためにグループに参加したい学生は、私のWeChat coco1sを追加できます(グループには200人以上がいるので、グループに参加するためにコードをスキャンすることはできません。招待することしかできません)

素晴らしい CSS 技術記事が私の Github -- iCSS に集められています。これらは継続的に更新されています。星をクリックして購読し、収集してください。

CSS を解析して画像のテーマカラーを抽出する方法についてはこれで終わりです。CSS による画像のテーマカラーの抽出についてさらに詳しく知りたい場合は、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続きご覧ください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

<<:  HTMLでカメラを読み込む方法

>>:  Web ページでの Unicode 文字の使用の概要 (&#、\u など)

推薦する

Windows 10 の仮想マシンに Mac システムをインストールするグラフィック チュートリアル

1. 仮想マシンバージョン15.5.1をダウンロードする公式サイトから直接最新バージョンをダウンロー...

Vueは画像のドラッグアンドドロップ機能を実装します

この記事の例では、画像のドラッグアンドドロップ機能を実現するためのVueの具体的なコードを参考までに...

JavaScript 配列メソッド - 体系的な概要と詳細な説明

目次一般的な配列メソッド配列要素の追加と削除配列ヘッダーの操作配列の末尾を操作する任意の場所に追加ま...

MySQL の instr を使用したファジー クエリ メソッドの紹介

MySQL の内部関数instrを使用すると、従来の like クエリ メソッドを置き換えることがで...

Linuxでシンボリックリンクを削除(削除)するコマンド

Linux では、シンボリック リンクを作成または削除する必要がある場合があります。もしそうなら、何...

Windows で MySQL 5.7.17 をインストールし、エンコードを utf8 に設定する方法

ダウンロードMySQL 公式ダウンロード、Windows (x86、64 ビット)、ZIP アーカイ...

Vue フロントエンドと Django バックエンドを使用して、一定期間内のデータをクエリする方法

序文開発プロセスでは、すべてのデータではなく特定の期間内のデータをクエリするなど、クエリのフィルタリ...

Linux での MySQL 5.7.16 無料インストール バージョンのグラフィック チュートリアル

この記事では、参考までにMySQL 5.7.16の無料インストール版のチュートリアルを紹介します。具...

HTMLはシンプルで美しいログインページを作成します

まずは見てみましょう。 HTML ソースコード: XML/HTML コードコンテンツをクリップボード...

IframeとFRAMEの違いの分析

1. Iframe タグの使用<br />Iframe については、「忘れられた隅」に放...

フィボナッチ数列のJavaScript出力を実装する方法

目次トピック分析する基本的な解決策基本的な再帰再帰最適化要約するトピック私たちが答えなければならない...

Vue におけるキープアライブ マルチレベル ルーティング キャッシュの問題

目次1. 問題の説明2. 原因分析3. 解決策4. 処理1. 問題の説明調整センターでは、最後の 2...

CSS属性のデフォルト値width: autoとwidth: 100%の違いの詳細な説明

幅: 自動子要素(コンテンツ+パディング+境界線+余白を含む)は、親要素のコンテンツ領域全体を埋めま...

DockerでGPUを使用するプロセスの詳細な説明

目次tf-gpu をダウンロード取得したtf-gpuイメージに基づいて独自のイメージを構築するイメー...

Vue3とTypeScriptを組み合わせたプロジェクト開発の実践の概要

目次概要1. コンポジションAPI 1. ref と reactive の違いは何ですか? 2. 周...