PNG

画像

PNG仕様

 状態:-  閲覧数:2,770  投稿日: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仕様抜粋

 閲覧数:618 投稿日: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仕様で勘違いしていたこと

 閲覧数:538 投稿日: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/10/06 15:39 更新
週間人気ページランキング / 9-29 → 10-5
順位 ページタイトル抜粋 アクセス数
1 RGB ⇔ Lab | 色変換(色) 19
2 鉄道会社毎のカラーコード | カラーコード(色) 16
3 「パッケージ化されてない拡張機能を読み込む」でインストールした拡張は、chromeを「更新」すると正常動作しなくなることがあります。 | Chrome 拡張機能 14
4 「:hover」「z-index」を組み合わせて使用すると、正常動作しないことがある | z-index(CSS) 7
4 「東京都」のカラーコード取得は難しい | カラーコード(色) 7
4 RGBの種類 / ビットカラー | RGB(色) 7
5 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 6
5 「overflow」効果を打ち消すスタイルシートは、「overflow: auto;」 6
5 FontAwesomeでアイコンが□(四角)になって表示されない Forbidden  | Font Awesome(フォント) 6
6 max-width: 100%の効果を打ち消すには、max-width: none; | CSS 5
6 「Chrome拡張機能」開発中に遭遇したエラー | Chrome 拡張機能 5
6 「bgcolor」「background-color」「background」の違い | CSS 5
7 黒体 / 色温度 / D65(6500K)/ D50(5000K)/ K | 色 4
7 金融機関ブランドカラー / コーポレートカラー | カラーコード(色) 4
8 aタグで複数のブロック要素を囲むやり方 | CSS 3
8 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない | モバイルデザイン(デザイン) 3
9 「コズミックブルー」は、くすんだ青系全般の色を指す用語だと思います。 | カラーコード(色) 2
9 Design 0 2
9 キャラクター無料作成ジェネレーター / FLASH / オンラインサービス | イラスト参考(デザイン) 2
9 16進数カラーコード / 2進数 2
2024/10/6 1:01 更新