PNG

画像

PNG仕様

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

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

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

透過色


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


何が問題?


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

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

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

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


Twitter検索結果。「PNG」に関する最新ツイート

rimaokaki @rimaokaki
Jet「確かめなくても間違いないことは」「君に出逢えてホントにホントによかった」 @Jet0o

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

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



類似度ページランキング
順位 ページタイトル抜粋
1 GIMP 57
2 PNG画像透明化問題 46
3 RGB 33
4 SVG 33
5 Next 29
6 P2VJ 25
7 G'MIC 25
8 PicSvg 22
9 Potrace 20
10 SVGハマった点 18
11 ZorroSVG 18
12 XnViewMP 18
13 SVG表示サイズ 18
14 SVGイラスト素材 17
15 RGB → HSL 17
16 HSL → RGB 17
17 RGB ⇔ Lab 17
18 SVGアニメーション 15
19 GIFアニメーション 15
20 SVGアイコンを探す旅 14
2021/8/02 7:46 更新
週間人気ページランキング / 7-26 → 8-1
順位 ページタイトル抜粋 アクセス数
1 画面キャプチャ | Chrome 拡張機能(ブラウザ) 51
2 RGB ⇔ Lab | 色変換(色) 46
3 血の色 / #b30000 / #360800 / #ff0000 | 色 31
4 「マウスオーバー」「ロールオーバー」「ホバー」の違い | CSS 25
5 RGBの種類 / ビットカラー | RGB(色) 24
6 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 23
7 「属性」「プロパティ」「アトリビュート」の違い | CSS 21
8 Design 0 20
9 「bgcolor」「background-color」「background」の違い | CSS 15
10 コズミックブルーが何色か分からない | 色 12
10 「overflow」効果を打ち消すスタイルシートは、「overflow: auto;」 12
11 使用していないCSSをチェックする、標準的な方法を知りたい | CSS 11
11 HSLとHSVの違い | 色変換(色) 11
12 ページ内リンクの位置を微調整するためには、Negative margin を使用する | CSS 10
13 キャラクター無料着せ替えジェネレーター Rinmaru Games / オンラインサービス | イラスト素材(デザイン) 9
13 「Bootstrapデザイン」✕「グラフ」 | 2系(Bootstrap) 9
13 アドベンチャーゲーム系の素材をどうやって用意するの? | イラスト素材(デザイン) 9
13 キャラクター無料作成ジェネレーター / FLASH / オンラインサービス | イラスト参考(デザイン) 9
13 「:hover」「z-index」を組み合わせて使用すると、正常動作しないことがある | z-index(CSS) 9
14 黒体 / 色温度 / D65(6500K)/ D50(5000K)/ K | 色 8
2021/8/2 1:01 更新