背景すべては、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); } 効果を見てみましょう。比較的大きなぼかしフィルターを使用して、 次に、ぼやけたエッジを削除し、 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 デモ - フィルターとスケールで画像の主な色を取得します デメリットもちろん、この解決策にもいくつか小さな問題があります。 画像の主な色は大まかにしか取得できず、あまり正確ではありません。また、 やっとさて、今回の記事はここまでです。CSSを使って画像のテーマカラーを取得する裏技を紹介しました。参考になれば幸いです😃 この方法を提案してくれたYuewenの学生、XboxYanに感謝します。iCSS WeChatグループは非常に活発で、CSSの専門家が集まっています。技術について議論するためにグループに参加したい学生は、私のWeChat coco1sを追加できます(グループには200人以上がいるので、グループに参加するためにコードをスキャンすることはできません。招待することしかできません) 素晴らしい CSS 技術記事が私の Github -- iCSS に集められています。これらは継続的に更新されています。星をクリックして購読し、収集してください。 CSS を解析して画像のテーマカラーを抽出する方法についてはこれで終わりです。CSS による画像のテーマカラーの抽出についてさらに詳しく知りたい場合は、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続きご覧ください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 |
>>: Web ページでの Unicode 文字の使用の概要 (&#、\u など)
背景 - オンラインアラートオンライン サーバーがアラームを発し、ディスク使用率 disk.util...
データを挿入するとき、以前オフィス システムに取り組んでいたときにはデータベースのパフォーマンスにつ...
XML/HTML コードコンテンツをクリップボードにコピー<ボタンスタイル= "カ...
非直交マージンマージンを使用するとマージが発生します次のプロパティはマージンの結合を防止します。国境...
Linux サーバーのホスト ファイルの構成hosts ファイルは、Linux システム内の IP ...
この記事では、WebSocketを使用して簡単なチャットルームの会話を実装するための具体的なコードを...
序文最近、MySQL に関するメモをいくつか尋ねる人がいたので、ブログ記事を書かなければなりません。...
1. ソフトウェアをダウンロードする1. MySQL の公式サイトにアクセスし、Oracle アカウ...
vue-routerには2つのモードがありますハッシュモード履歴モード1. シングルページアプリケー...
目次1. 共有共通モジュール2. 共有マテリアルモジュール3. 共有確認ダイアログ1. 共有共通モジ...
li はブロックレベル要素であり、デフォルトで 1 行を占めるため、水平方向の配置を実現する場合は、...
Dockerはmysqlをインストールします docker search mysql 検索 dock...
Linux サーバーに GRUB をインストールする方法クラウド移行ツールを使用して、CentOS ...
序文最近 Linux を学び、その後 Win から Ubuntu に変更しました。以前インストールし...
Mac で開発されたプロジェクトがあり、パッケージ npm i がインストールされており、すべて正常...