CSS マスクを使用して PNG 画像のサイズを大幅に最適化します (推奨)

CSS マスクを使用して PNG 画像のサイズを大幅に最適化します (推奨)

この記事は共有および集約することを歓迎します。全文を転載する必要はありません。著作権を尊重してください。サークルはとても小さいです。緊急に必要な場合は、許可を得るためにご連絡ください。

1. それ以上圧縮できないPNG画像

たとえば、以下に示す PNG 画像 (1/2 サイズで表示) は、トップの PNG ツールを使用して圧縮した後でも 122K のままです。

元の画像のアドレスはこちらです: https://image.zhangxinxu.com/image/blog/202005/card.png

PNGのサイズは次のとおりです。

プロジェクトにこのような画像が 1 つだけであれば問題ありません。ただし、ページにこのサイズの PNG が一度に多数ある場合、最初の読み込みでパフォーマンスへの影響が非常に顕著になります。たとえば、下の図の 4 つのカード画像は 500K です。

カードの背景も複雑なグラフィックなので、端や角は透明にする必要があります。JPG 形式に変更しても確実に機能しません (端や角が単色になります)。さらに最適化する方法はありませんか?

はい、CSS マスクの助けを借りて PNG 画像のサイズを大幅に最適化します。

2. マスク画像とPNGサイズの最適化

mask-imageマスクは、マスク画像が存在する領域のみを表示する機能を持っています。そのため、透明な角を持つ任意のマスク画像であれば、JPG 画像の白い角を透明にすることができます。

この方法は実行可能です。デモはここにあります。

具体的な手順は以下のとおりです。

1.PNGをJPGに変換する

まず、PNG 画像を JPG に保存します。以下に示すように、画像品質の 50% で十分です。

この時点で、画像サイズは 50% 以上削減できます。

2. PNGアウトラインに基づいて単色のPNGを作成する

PNG画像のサイズが大きいのは、色が濃すぎるからです。単色にすれば、サイズは100分の1以下に縮小できます。

現時点では、純黒で塗りつぶされた PNG 画像のサイズは 1K 未満です。

3.マスクを使用してJPGの角を白く透明にする

JPG カード画像が<img>要素を使用していると仮定すると、HTML コードは次のようになります。

<img src="カード.jpg">

次の CSS コードを使用します。

画像 {
    -webkit-マスクイメージ: url(card-mask.png);
    マスク画像: url(card-mask.png);
}

角が透明でサイズが小さい、元の 122K PNG 画像と同じ効果が得られます。

card-mask.png の四隅は透明なので、card.jpg が card-mask.png をマスク画像として適用すると、四隅も透明になります。

4. マスク画像のクロスドメイン制限

Chrome などのブラウザのセキュリティ アップグレードにより、現在マスク画像へのクロスドメイン アクセスが制限されており、次のようなエラー プロンプトが表示されます。

'https://image.zhangxinxu.com/…/card-mask.png' にある画像へのアクセス (オリジン 'https://www.zhangxinxu.com') は CORS ポリシーによってブロックされました: 要求されたリソースに 'Access-Control-Allow-Origin' ヘッダーが存在しません。

ソリッドカラーマスクイメージを base64 形式に変換できます。次に例を示します。

画像 {
-webkit-mask-image: url();
}

百聞は一見にしかず、こちらをクリックしてください: CSSマスクを使用したPNG画像サイズの最適化デモ

JPG 形式のカードの最終的な効果は次の図に示されています (4 つの角は透明です)。

3. 最適化された効果の比較

最適化前後の 4 つの画像のサイズ比較は次のとおりです。

4 枚の画像の元のサイズは 458K ですが、最適化された画像のサイズは 197K+1K となり、サイズが56.8%削減されました。

クィア〜

mask-imageモバイル端末でも以前からサポートされており、ここでは従来の構文が使われています。互換性の問題も全くないので、安心して使えます。

要約する

CSS マスクを使用して PNG 画像のサイズを大幅に最適化する方法についての記事はこれで終わりです。CSS マスクに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

<<:  Docker で MySQL マスター スレーブ レプリケーションを実装するためのサンプル コード

>>:  iFrameは背景を覆うポップアップレイヤーとして使うのに最適です

推薦する

Linux のパスワードを紛失した場合にリセットする方法

1. スタートアップメニューでは、カーソルを最初の行に移動します - eを押します 2. UTF-8...

MySQL スケジュールタスク (EVENT イベント) を詳細に設定する方法

目次1. イベントとは何ですか? 2. 「イベント」機能を有効にする1. 機能が有効になっているかど...

Webフロントエンドインターフェースの設計に必須のスキル

[必須] ユーザーインターフェースPhotoShop/花火デザインアーティストと協力して、スケッチを...

デカルト積原理を使用してMySQLで複数のテーブルをクエリする方法を簡単に説明します。

MySQL マルチテーブルクエリ (直積原理)まず、データが使用するテーブルを決定します。デカルト...

Windows での Apache+Tomcat7 負荷分散構成方法の詳細な説明

準備Windows Server 2008 R2 Enterprise (2.40GH、8GB、64...

Javascript サンプル プロジェクトでの虫眼鏡効果の実装プロセス

目次序文事例: JD.com の虫眼鏡効果の模倣オフセットシリーズクライアントシリーズスクロールシリ...

MySQL ツリー構造テーブルの設計と最適化に関する簡単な説明

序文多くの管理・オフィスシステムでは、ツリー構造がいたるところで見られます。たとえば、「部門」や「機...

Alibaba Cloud OSS によってアップロードされた Nginx プロキシ転送実装コード

序文ミニプログラムのアップロードには https が必要なので、サーバーの https は lets...

ウェブデザインにおけるインタラクション: ページングの問題に関する簡単な説明

機能: 前のページまたは次のページにジャンプします。要素: ページングの基本要素は、前のページ + ...

mysql8.0.23 Linux (centos7) のインストールの完全かつ詳細なチュートリアル

目次リレーショナルデータベースとは何ですか?非リレーショナルデータベースとは何ですか? MySQL ...

ウェブデザイナーのための超便利なツール 50 選

ウェブデザイナーになるのは簡単ではありません。デザインやアーキテクチャを考慮するだけでなく、さまざま...

JavaScript の非同期処理で待機時間を節約できますか?

JavaScriptで非同期実行の結果を同期的に取得するには、 for ループ内でawaitを使用...

Linux xargsコマンドの使用

1. 機能: xargs は、stdin 内のスペースまたは改行で区切られたデータをスペースで区切ら...

Vueカスタムコンポーネントは双方向バインディングを実装します

シナリオ:一般的に使用される親コンポーネントと子コンポーネント間の相互作用方法は次のとおりです。親コ...

Linux ファイアウォール設定の詳細な手順 (yum ウェアハウス設定に基づく)

序文この実験では、デバッグ用に2つの仮想マシン(CentOs6とRed Hat 6)を準備します。 ...