PNG

画像

PNG仕様

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

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

 閲覧数:509 投稿日: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/4/25 16:25 更新
週間人気ページランキング / 4-18 → 4-24
順位 ページタイトル抜粋 アクセス数
1 16進数カラーコード / 2進数 25
2 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 13
2 「マウスオーバー」「ロールオーバー」「ホバー」の違い | CSS 13
2 「Font Awesome 4」と「Font Awesome 5」の違い(Font Awesome バージョン4からのアップグレード) | Font Awesome(フォント) 13
3 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない | モバイルデザイン(デザイン) 11
4 RGB ⇔ Lab | 色変換(色) 10
5 血の色 / #b30000 / #360800 / #ff0000 | カラーコード(色) 9
6 Design 0 8
7 「Chrome拡張機能」開発中に遭遇したエラー | Chrome 拡張機能 7
8 「bgcolor」「background-color」「background」の違い | CSS 4
8 「z-index」効果を打ち消すスタイルシートは、「z-index:auto;」 4
8 Chrome でキャッシュを効かさない | Google Chrome(ブラウザ) 4
8 max-width: 100%の効果を打ち消すには、max-width: none; | CSS 4
9 「line-height」効果を打ち消すスタイルシートは、「line-height:normal; 3
9 「群青色」「瑠璃色」「ウルトラマリンブルー」の違い 3
10 iframe経由で読み込んでいるページへ直接アクセスした場合は、トップページへリダイレクト | HTML5(HTML) 2
10 ユーザー個別の設定情報が格納されているレジストリキーを削除 2
10 カラーコード / 色コード | カラーコード(色) 2
10 CSSで出来ないこと | CSS 2
10 RGBの種類 / ビットカラー | RGB(色) 2
2024/4/25 1:01 更新