PNG

画像

PNG仕様

 状態:-  閲覧数:2,796  投稿日:2014-04-03  更新日:2014-04-03
Portable Network Graphics (PNG) Specification (Second Edition)
仕様 第2版 日本語訳
・W3Cが定義しているPNG仕様書


正式名称


Portable Network Graphics
・ポータブル・ネットワーク・グラフィックス、PNG


略歴


・1996年登場
・特許使用の解釈に不安のあったGIFに替わるライセンス・フリーの画像形式として開発された
・「ネットワーク経由での使用を想定した機能」や「透過処理」など、多くの機能をサポート


特徴


・フルカラーにも8bitカラーにもすることができる
・圧縮率が高い。同じ内容のGIF画像より10%~30%程度ファイルサイズが小さくなる
・圧縮によってデータが捨てられてしまうことがない可逆圧縮形式を採用
・複数の透過色を指定できる
・ライセンス問題の不安がない

PNG仕様抜粋

 閲覧数:626 投稿日:2014-04-03 更新日:2014-04-03

カラー・タイプ


・それぞれ特徴や格納形式が異なる
0 = グレイスケール
2 = トゥルーカラー(≒RGB)
3 = インデックスカラーモード(パレットカラー)
4 = グレイスケール+アルファ
6 = トゥルーカラー(≒RGB)+アルファ

0 =  グレイスケール PNG (最大 65536 段階)
・グレイスケール 2, 4, 16, 256, 65536 段階の、5種類から選択可能
・最大 16 ビット

2 = トゥルーカラー(≒RGB)(最大 280 兆色)
・1677 万色(24 bit フルカラー)、280 兆色(48 bit トゥルーカラー)の 2 種類から選択可能

3 = インデクスカラー PNG (最大 256 色)
・GIF フォーマットと同じ手法
・パレットを使うことで、トゥルーカラー PNG よりもサイズが小さくなる
・パレット数 2, 4, 16, 256 個 の 4 種類から選択可能
・画像データとは別にパレットテーブルを持つ必要がある
・各パレットは 24 bit カラー(1677 万色)の中から任意に選択可能


透過


A.αチャンネル
・非常に強力な透過設定
・利用すると、画像中のすべてのピクセルは、RGBの情報に加えて透明度を定義するα値の情報を持つようになる(全てのピクセルが透過情報を持つ)
・α=0 … 完全に透明。後ろの背景色がそのまま表示される
・α=MAX … 完全に不透明
・α値が中間の値を取った場合、いわゆる「半透明」が表現できる
・すべてのピクセルが透明度情報を持つから、サイズ増加は免れない
・α値のとりうる範囲は、その画像の色深度と同じ
・例えば、各RGBが 0~255 の範囲を取り得るフルカラー1677万色画像の場合、α値もまた 0~255。(例:R=255、G=234、B=14、α=127)
・グレイスケール PNG とトゥルーカラー PNG で有効

B.透過色
・クロマキーによる透過指定
・透過 GIF のように1色だけを透明にしたい場合に利用
・いくつかの色だけに透明度情報を持たせる「透過色」機能
・「透過色」機能は、カラータイプにより、その機構が少しずつ違う

1. グレイスケール PNG
・グレイスケール 65536 レベルのうち、何種類でも透明定義を行える
・透明定義されたグレイレベルは完全透明(α=0)で、その他のグレイレベルは完全不透明になる
・「半透明」は表現できない

2. インデクスカラー PNG
・最大 256個のパレットにおいて、それぞれα値を設定できる
・α値は 0~255 を取りうり半透明も定義できる
・パレット0から順番に定義するが、定義されなかったパレットはすべてα=255(完全不透明)と定義される

3. トゥルーカラー PNG
・何色でも透明色に定義できる
・透明定義された色は完全透明(α=0)で、定義されなかった色は完全不透明になる
・「半透明」は表現できない


背景色


・背景色を1色選択可能
この指定は、背景色情報を「PNG画像を開くソフトウエア」に伝えるだけで、実際に背景色をどう扱うかは、個々の ソフトウエアに全面委任されている

グレイスケール PNG
・背景色とするグレイレベルを、1つ指定

インデクスカラー PNG
・背景色とするパレットを、1つ指定

トゥルーカラー PNG
・背景色とする色を、1つ指定

PNG仕様で勘違いしていたこと

 閲覧数:546 投稿日:2014-04-03 更新日:2014-04-03

透過色


透過PNGも、画像自体に背景色を保持している
・透過だから、画像自体には背景色を保持していないと思い込んでいた


何が問題?


・この仕様を知らないと、理解できない場面に遭遇する可能性がある

実際に遭遇した例
・透過PNGなのに、画像ソフトで指定した背景色以外の色が表示される
・透過画像のはずなのに、どうして透過表示されないの?
・もしかして、透過じゃないの?
・もうパニックですよ

結局
・解決するまで2日要した
・ヤレヤレだぜ!

・実際に遭遇した例はこちら



格好が良いロゴを見つけたら、そのページへのリンクを張っていくエントリー

マウスオーバーで「リンク画像」拡大表示をCSSで実装



類似度ページランキング
順位 ページタイトル抜粋
1 PNG 100
2 GIMP 57
3 PNG画像透明化問題 46
4 SVG 33
5 RGB 33
6 Next 29
7 P2VJ 25
8 G'MIC 25
9 PicSvg 22
10 Potrace 20
11 SVGハマった点 18
12 SVG表示サイズ 18
13 ZorroSVG 18
14 XnViewMP 18
15 SVGイラスト素材 17
16 RGB → HSL 17
17 RGB ⇔ Lab 17
18 HSL → RGB 17
19 GIFアニメーション 15
20 SVGアニメーション 15
2024/11/23 2:01 更新
週間人気ページランキング / 11-16 → 11-22
順位 ページタイトル抜粋 アクセス数
1 鉄道会社毎のカラーコード | カラーコード(色) 12
2 FontAwesomeでアイコンが□(四角)になって表示されない Forbidden  | Font Awesome(フォント) 10
3 Design 0 8
3 「パッケージ化されてない拡張機能を読み込む」でインストールした拡張は、chromeを「更新」すると正常動作しなくなることがあります。 | Chrome 拡張機能 8
4 血の色 / #b30000 / #360800 / #ff0000 | カラーコード(色) 6
5 「東京都」のカラーコード取得は難しい | カラーコード(色) 5
5 Fireworks で背景画像透明化 | Fireworks CS3(Fireworks) 5
6 金融機関ブランドカラー / コーポレートカラー | カラーコード(色) 4
7 「:after擬似要素」は、Chromeの「要素を検証」で確認できない | 擬似(CSS) 3
7 「Font Awesome 4」と「Font Awesome 5」の違い(Font Awesome バージョン4からのアップグレード) | Font Awesome(フォント) 3
7 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない | モバイルデザイン(デザイン) 3
7 個人的によく見返すエントリーへのLinkなど | その他 3
7 RGB ⇔ Lab | 色変換(色) 3
7 「Google Chrome」の文字が突然ギザギザで表示されるようになったら、「chrome://flags/#top-chrome-md」へアクセス後、右上の「Reset all」ボタンをクリックします。 | Google Chrome(ブラウザ) 3
7 色モデルイメージ図 | 色変換(色) 3
8 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 2
8 ICCプロファイル | カラーマネージメント(色) 2
8 パッケージ化されてない拡張機能 | Chrome 拡張機能 2
8 空間的 / 可逆な JPEG ファイルの読み込みは実行されません | Photoshop CS3(Photoshop) 2
8 「overflow」効果を打ち消すスタイルシートは、「overflow: auto;」 2
2024/11/23 1:01 更新