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 など)

推薦する

Win10にnginxをインストールする方法

会社から、負荷を実装するためにnginxをベースにFordプロジェクトのWebServiceサーバー...

CSSスタイルで実現されるHTML背景色のグラデーション効果

エフェクトのスクリーンショット:実装コード:コードをコピーコードは次のとおりです。 <!DOC...

モバイルレイアウト用の動的REMの実装

ダイナミックレム1. まず、現在の長さの単位を紹介しましょうpx em Mの幅 / 漢字の幅 1em...

ウェブサイトの画像にグレー効果を加える3つの方法

私はグレースケールの画像の方が芸術的に見えると思うので、いつもグレースケールの画像を好んで使っていま...

MySQLでデータベースデータ保存ディレクトリを変更する方法

序文MySQL データベースのデフォルトのデータベース ファイルは /var/lib/mysql に...

魔法のMySQLデッドロックトラブルシューティング記録

背景MySQL のデッドロックについて言えば、私は以前 MySQL のロックに関する基本的な紹介記事...

<td></td> タグの境界線スタイルがブラウザに表示されない問題の解決方法

質問: 360ブラウザの互換モードなど、一部のブラウザでは、 <td style="...

MySQL 最適化のケーススタディ

1. 背景Youzan の各 OLTP データベース インスタンスには、実行時間が特定のしきい値を超...

CSS変換ページめくりアニメーションレコードの実装

ページめくりの問題のシナリオBとCは同じページ(表と裏)にありますページをめくって A をカバーした...

MySQL 8.0.22 winx64 のインストールと設定方法のグラフィックチュートリアル

MySQL-8.0.22-winx64のデータベースインストールチュートリアルは参考になります。具体...

ServerSocketのデフォルトIPバインディングの実装プロセスの詳細な説明

開発中にサーバーを起動する必要がある場合、ローカルテストではポートを直接書き込み、実際の環境ではバイ...

iframe を使用して Web ページに他の Web ページを埋め込む方法

iframe の使い方:コードをコピーコードは次のとおりです。 <DIV align=cent...

MySQL 8.0.12 の詳細なインストールおよびアンインストール チュートリアル

1. MySQL 8.0.12 バージョンのインストール手順。 1. ダウンロードhttps://d...

CSSポジションの5つの異なる値の使い方の詳細な説明

位置プロパティposition プロパティは、要素に使用する配置方法のタイプ (静的、相対的、固定、...

MySQL での Truncate の使用法の詳細な説明

序文:テーブルをクリアしたいときは、truncate ステートメントをよく使用します。ほとんどの場合...