ビットマップ ストレージ
ビットマップは、確立されたビットマップ ファイル形式を使用し、拡張子が 3 文字の名前.bmp割り当てられたファイルに保存する必要があります。 確立されたビットマップ ファイル形式は、 BITMAPFILEHEADER 構造体の後に BITMAPINFOHEADER、 BITMAPV4HEADER、または BITMAPV5HEADER 構造体が続きます。 RGBQUAD 構造体 (カラー テーブルとも呼ばれます) の配列は、ビットマップ情報ヘッダー構造に従います。 カラー テーブルの後に、カラー テーブル (実際のビットマップ データ) へのインデックスの 2 番目の配列が続きます。
ビットマップ ファイルの形式を次の図に示します。
BITMAPFILEHEADER 構造体のメンバーは、ファイルを識別します。ファイルのサイズをバイト単位で指定します。ヘッダーの最初のバイトからビットマップ データの最初のバイトまでのオフセットを指定します。 BITMAPINFOHEADER、BITMAPV4HEADER、または BITMAPV5HEADER 構造体のメンバーは、ビットマップの幅と高さをピクセル単位で指定します。 ビットマップが作成されたディスプレイ デバイスのカラー形式 (カラー プレーンの数とピクセルあたりの色ビット数)。ビットマップ データがストレージの前に圧縮されたかどうか、および使用される圧縮の種類。ビットマップ データのバイト数。ビットマップが作成されたディスプレイ デバイスの解像度。とデータで表される色の数。 RGBQUAD 構造体は、デバイスのパレット内の各色の RGB 強度値を指定します。
color-index 配列は、インデックスの形式で色を RGBQUAD 構造体に関連付け、ビットマップ内の各ピクセルに関連付けます。 したがって、color-index 配列内のビット数は、 RGBQUAD 構造体のインデックス作成に必要なビット数のピクセル数と等しくなります。 たとえば、8 x 8 の白黒ビットマップのカラー インデックス配列は 8 * 8 * 1 = 64 ビットです。2 色のインデックスを作成するには 1 ビットが必要であるためです。 「 ビットマップについて」で説明されているRedbrick.bmpは、16 色の 32 x 32 ビットマップです。その色インデックス配列は 32 * 32 * 4 = 4096 ビットです。4 ビットインデックスは 16 色であるためです。
トップダウン ビットマップの色インデックス配列を作成するには、ビットマップの先頭行から開始します。 左端のピクセルの色に対する RGBQUAD のインデックスは、カラー インデックス配列の最初の n ビットです ( n は 、すべての RGBQUAD 構造体を示すために必要なビット数です)。 右側の次のピクセルの色は、配列内の次の n ビットなどです。 行の右端のピクセルに達したら、次の行の左端のピクセルを続行します。 ビットマップ全体で終了するまで続行します。 一番下のビットマップの場合は、上の行ではなくビットマップの下の行から開始し、左から右に進み、ビットマップの上の行に進みます。
次の 16 進数出力は、ファイル Redbrick.bmpの内容を示しています。
0000 42 4d 76 02 00 00 00 00 00 00 76 00 00 00 28 00
0010 00 00 20 00 00 00 20 00 00 00 01 00 04 00 00 00
0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
0030 00 00 00 00 00 00 00 00 00 00 00 00 80 00 00 80
0040 00 00 00 80 80 00 80 00 00 00 80 00 80 00 80 80
0050 00 00 80 80 80 00 c0 c0 c0 00 00 00 ff 00 00 ff
0060 00 00 00 ff ff 00 ff 00 00 00 ff 00 ff 00 ff ff
0070 00 00 ff ff ff 00 00 00 00 00 00 00 00 00 00 00
0080 00 00 00 00 00 00 00 00 00 00 00 00 00 00 09 00
0090 00 00 00 00 00 00 11 11 01 19 11 01 10 10 09 09
00a0 01 09 11 11 01 90 11 01 19 09 09 91 11 10 09 11
00b0 09 11 19 10 90 11 19 01 19 19 10 10 11 10 09 01
00c0 91 10 91 09 10 10 90 99 11 11 11 11 19 00 09 01
00d0 91 01 01 19 00 99 11 10 11 91 99 11 09 90 09 91
00e0 01 11 11 11 91 10 09 19 01 00 11 90 91 10 09 01
00f0 11 99 10 01 11 11 91 11 11 19 10 11 99 10 09 10
0100 01 11 11 11 19 10 11 09 09 10 19 10 10 10 09 01
0110 11 19 00 01 10 19 10 11 11 01 99 01 11 90 09 19
0120 11 91 11 91 01 11 19 10 99 00 01 19 09 10 09 19
0130 10 91 11 01 11 11 91 01 91 19 11 00 99 90 09 01
0140 01 99 19 01 91 10 19 91 91 09 11 99 11 10 09 91
0150 11 10 11 91 99 10 90 11 01 11 11 19 11 90 09 11
0160 00 19 10 11 01 11 99 99 99 99 99 99 99 99 09 99
0170 99 99 99 99 99 99 00 00 00 00 00 00 00 00 00 00
0180 00 00 00 00 00 00 90 00 00 00 00 00 00 00 00 00
0190 00 00 00 00 00 00 99 11 11 11 19 10 19 19 11 09
01a0 10 90 91 90 91 00 91 19 19 09 01 10 09 01 11 11
01b0 91 11 11 11 10 00 91 11 01 19 10 11 10 01 01 11
01c0 90 11 11 11 91 00 99 09 19 10 11 90 09 90 91 01
01d0 19 09 91 11 01 00 90 10 19 11 00 11 11 00 10 11
01e0 01 10 11 19 11 00 90 19 10 91 01 90 19 99 00 11
01f0 91 01 11 01 91 00 99 09 09 01 10 11 91 01 10 91
0200 99 11 10 90 91 00 91 11 00 10 11 01 10 19 19 09
0210 10 00 99 01 01 00 91 01 19 91 19 91 11 09 10 11
0220 00 91 00 10 90 00 99 01 11 10 09 10 10 19 09 01
0230 91 90 11 09 11 00 90 99 11 11 11 90 19 01 19 01
0240 91 01 01 19 09 00 91 10 11 91 99 09 09 90 11 91
0250 01 19 11 11 91 00 91 19 01 00 11 00 91 10 11 01
0260 11 11 10 01 11 00 99 99 99 99 99 99 99 99 99 99
0270 99 99 99 99 99 90
次の表は、ビットマップ ファイル内の構造体に関連付けられているデータ バイトを示しています。
構造 | 対応するバイト数 |
---|---|
BITMAPFILEHEADER | 0x00 0x0D |
BITMAPINFOHEADER | 0x0E 0x35 |
RGBQUAD 配列 | 0x36 0x75 |
色インデックス配列 | 0x76 0x275 |
フィードバック
https://aka.ms/ContentUserFeedback」を参照してください。
以下は間もなく提供いたします。2024 年を通じて、コンテンツのフィードバック メカニズムとして GitHub の issue を段階的に廃止し、新しいフィードバック システムに置き換えます。 詳細については、「フィードバックの送信と表示