Windows Bitmap

Windows Bitmap
Dateiendung:.bmp, .dib
MIME-Type:image/x-ms-bmp, image/x-bmp, image/bmp
Magische Zahl:42, 4D hex
BM
Entwickelt von:Microsoft
Aktuelle Version5
Art:Rastergrafik


Windows Bitmap (BMP) oder device-independent bitmap (DIB) ist ein zweidimensionales Rastergrafikformat, das für die Betriebssysteme Microsoft Windows und OS/2 entwickelt und mit Microsoft Windows 3.0 eingeführt wurde, welches 1990 erschien. Die Dateiendung ist .bmp, seltener .dib.

Merkmale

BMPs gibt es in drei verschiedenen Versionen. Die meisten BMP-Dateien liegen in der Version 3 vor; es gibt keine früheren Versionen. Die späteren Versionen 4 und 5 sind höchst selten anzutreffen.

Windows-Bitmaps (der Version 3) erlauben Farbtiefen von 1, 4, 8, 16, 24 oder 32 bpp (bpp = bits per pixel, Bits je Bildpunkt), wobei bei 16 und 32 bpp nicht alle Bits tatsächlich genutzt werden müssen. Alphakanäle, Farbkorrektur und Metadaten werden nicht unterstützt. Windows-Bitmaps werden entweder unkomprimiert oder verlustfrei mit RLE-Komprimierung (Lauflängenkodierung) gespeichert. Dies ist ein eher schwaches Verfahren, sodass BMP-Dateien wesentlich größer sind als andere Formate wie PNG und kaum für das Internet genutzt werden. Dafür ist das BMP-Format relativ einfach aufgebaut. BMPs sind vor allem im Windows-Umfeld weit verbreitet; gängige Grafiksoftware unterstützt das Format problemlos (mit Ausnahme der eher exotischen Farbtiefen 16 und 32 bpp).

Die maximale Breite/Höhe eines Bildes beträgt theoretisch je 2.147.483.647 Pixel (231 − 1). In der Praxis akzeptieren viele Decoder nur deutlich niedrigere Werte.[1][2]

Dateiformat (Version 3)

Dateikopf
(BITMAPFILEHEADER)
Informationsblock
(BITMAPINFO):
Bitmap-Eigenschaften
(BITMAPINFOHEADER)

Eventuell: Farbmasken

Eventuell: Farbtabelle
Eventuell: Ungenutzter Platz
Bilddaten
Eventuell: Ungenutzter Platz

BMP-Dateien bestehen aus drei Teilen: dem Dateikopf, dem Informationsblock und den Bilddaten (siehe Schema rechts).

Im Folgenden bezeichnet WORD einen 16-Bit-vorzeichenlosen Integer, DWORD einen 32-Bit-vorzeichenlosen Integer und LONG einen im Zweierkomplement kodierten 32-Bit-Integer. BMP verwendet die Little-Endian-Konvention.

Dateikopf

BITMAPFILEHEADER (Größe: 14 Byte)
Offset (Byte)DatentypGrößeNameInhalt
DezHexWindows-StyleC-Style
00WORDuint16_t2 BytebfTypeASCII-Zeichenkette "BM" (Hex: 0x42 0x4D, Dezimal: 66 77).
22DWORDuint32_t4 BytebfSizeGröße der BMP-Datei in Byte. (unzuverlässig)
66DWORDuint32_t4 BytebfReservedReserviert, von der Software abhängig, standardmäßig 0
10ADWORDuint32_t4 BytebfOffBitsOffset der Bilddaten in Byte vom Beginn der Datei an.

Dieser hat nicht immer den Wert 54 (er ergibt sich aus 14 Byte Header + 40 Byte Infoblock) und muss daher dynamisch ausgelesen werden, weil es sonst ggf. zu Fehldarstellungen im Bild kommt.

[3]

Informationsblock

Bitmap-Eigenschaften

Der Informationsblock beginnt mit folgender Struktur, die die Bitmap-Eigenschaften enthält[4][5]

BITMAPINFOHEADER (Größe: 40 Byte)
Offset (Byte)DatentypGrößeNameInhalt
DezHexWindows-StyleC-Style
140EDWORDuint32_t4 BytebiSizeGröße der BITMAPINFOHEADER-Struktur in Byte
1812LONGint32_t4 BytebiWidthBreite der Bitmap in Pixel. Dabei ist das erste Byte niederwertig und das letzte Byte höchstwertig.
2216LONGint32_t4 BytebiHeightDer Betrag gibt die Höhe der Bitmap in Pixel an. Dabei ist das erste Byte niederwertig und das letzte Byte höchstwertig.
  • Ist der Wert positiv, so ist die Bitmap eine sogenannte "bottom-up"-Bitmap (die Bilddaten beginnen mit der untersten und enden mit der obersten Bildzeile). Dies ist die gebräuchlichste Variante.[6]
  • Ist der Wert negativ, so ist die Bitmap eine “top-down”-Bitmap (die Bilddaten beginnen mit der obersten und enden mit der untersten Bildzeile).
261AWORDuint16_t2 BytebiPlanes1 (Stand in einigen älteren Formaten wie PCX für die Anzahl der Farbebenen, wird aber für BMP nicht verwendet)
281CWORDuint16_t2 BytebiBitCountGibt die Farbtiefe der Bitmap in bpp an; muss einer der folgenden Werte sein: 1, 4, 8, 16, 24 oder 32. Bei 1, 4 und 8 bpp sind die Farben indiziert.
301EDWORDuint32_t4 BytebiCompressionEiner der folgenden Werte:
  • 0 (BI_RGB): Bilddaten sind unkomprimiert.
  • 1 (BI_RLE8): Bilddaten sind lauflängenkodiert für 8 bpp. Nur erlaubt wenn biBitCount=8 und biHeight positiv.
  • 2 (BI_RLE4): Bilddaten sind lauflängenkodiert für 4 bpp. Nur erlaubt wenn biBitCount=4 und biHeight positiv.
  • 3 (BI_BITFIELDS): Bilddaten sind unkomprimiert und benutzerdefiniert (mittels Farbmasken) kodiert. Nur erlaubt wenn biBitCount=16 oder 32.
3422DWORDuint32_t4 BytebiSizeImage
  • Wenn biCompression=BI_RGB: Entweder 0 oder die Größe der Bilddaten in Byte.
  • Ansonsten: Größe der Bilddaten in Byte.
3826LONGint32_t4 BytebiXPelsPerMeterHorizontale Auflösung des Zielausgabegerätes in Pixel pro Meter; wird aber für BMP-Dateien meistens auf 0 gesetzt.
422ALONGint32_t4 BytebiYPelsPerMeterVertikale Auflösung des Zielausgabegerätes in Pixel pro Meter; wird aber für BMP-Dateien meistens auf 0 gesetzt.
462EDWORDuint32_t4 BytebiClrUsed
  • Wenn biBitCount=1: 0.
  • Wenn biBitCount=4 oder 8: die Anzahl der Einträge der Farbtabelle; 0 bedeutet die maximale Anzahl (2, 16 oder 256).
  • Ansonsten: Die Anzahl der Einträge der Farbtabelle (0=keine Farbtabelle). Auch wenn sie in diesem Fall nicht notwendig ist, kann dennoch eine für die Farbquantisierung empfohlene Farbtabelle angegeben werden.
5032DWORDuint32_t4 BytebiClrImportant
  • Wenn biBitCount=1, 4 oder 8: Die Anzahl sämtlicher im Bild verwendeten Farben; 0 bedeutet alle Farben der Farbtabelle.
  • Ansonsten:
    • Wenn eine Farbtabelle vorhanden ist und diese sämtliche im Bild verwendeten Farben enthält: deren Anzahl.
    • Ansonsten: 0.

Farbmasken

Wenn biCompression=BI_BITFIELDS, dann folgen 3 DWORDs, die Bitmasken für die Rot-, Grün- und Blauwerte enthalten. Gesetzte Bits bedeuten, dass in den Daten eines Pixels jenes Bit für den jeweiligen Farbkanal verwendet wird. Dabei müssen folgende Bedingungen erfüllt sein:

  • gesetzte Bits müssen direkt nacheinander folgen;
  • für 16 bpp müssen sich die gesetzten Bits in den beiden niederwertigen Bytes befinden;
  • die Bitmasken der einzelnen Farbkanäle dürfen einander nicht überlappen.

Farbtabelle

  • Wenn biClrUsed=0:
    • Wenn biBitCount=1, 4 oder 8: Es folgt eine Farbtabelle mit 2biBitCount Einträgen.
    • Ansonsten: Es folgt keine Farbtabelle.
  • Ansonsten: Es folgt eine Farbtabelle mit biClrUsed Einträgen.

Jeder Eintrag der Farbtabelle ist 4 Byte groß und enthält jeweils ein Byte für den Blau-, Grün- und Rotanteil, sowie ein auf 0 gesetztes Byte (in dieser Reihenfolge!).

Bilddaten

Die Bilddaten beginnen am Offset bfOffBits. Die Größe der Bilddaten beträgt näherungsweise (gilt nur für durch 4 teilbare Bildbreiten) biWidth×biHeight×biBitCount/8 wenn biCompression=BI_RGB, ansonsten biSizeImage.

Die Bilddaten werden Zeile für Zeile gespeichert. Wenn biHeight positiv ist, beginnen die Bilddaten mit der letzten und enden mit der ersten Bildzeile, ansonsten ist es umgekehrt. Bei BI_BITFIELDS und bei BI_RGB ist die Länge jeder Zeile ein Vielfaches von 4 Bytes und wird, falls erforderlich, mit Nullbytes aufgefüllt.

Das weitere Format der Bilddaten hängt vom Wert des biCompression-Felds ab:

  • BI_BITFIELDS
Jede Bildzeile ist durch rechtsseitiges Auffüllen mit Nullen auf ein ganzzahliges Vielfaches von 4 Bytes ausgerichtet. Das Format der Pixel ist in den Farbmasken definiert. Bei 16 bpp werden nur die beiden niederwertigen Bytes der Farbmasken berücksichtigt.
  • BI_RGB
Jede Bildzeile ist durch rechtsseitiges Auffüllen mit Nullen auf ein ganzzahliges Vielfaches von 4 Bytes ausgerichtet.
1, 4 oder 8 bpp:
Die Daten jedes Pixels bestehen aus einem 0-basierten Index auf den Eintrag in der Farbtabelle.
16 bpp:
Das Format ist wie bei BI_BITFIELDS, wenn folgende Farbmasken verwendet würden:
0x00007C00 für den Rot-Kanal
0x000003E0 für den Grün-Kanal
0x0000001F für den Blau-Kanal
Jeder Farbkanal ist 5 Bit pro Pixel groß; insgesamt ergeben sich 32.768 mögliche Farben (ein Bit ist ungenutzt).
24 bpp:
Die Daten jedes Pixels bestehen aus jeweils einem Byte für den Blau-, Grün- und Rot-Kanal (in dieser Reihenfolge!).
32 bpp:
Das Format ist wie bei BI_BITFIELDS, wenn folgende Farbmasken verwendet würden:
0x00FF0000 für den Rot-Kanal
0x0000FF00 für den Grün-Kanal
0x000000FF für den Blau-Kanal
Jeder Farbkanal ist 8 Bit pro Pixel groß; insgesamt ergeben sich 16.777.216 mögliche Farben (8 Bit sind ungenutzt). Einige Programme wie etwa Adobe Photoshop interpretieren die verbleibenden 8 Bits (0xFF000000) als Alphakanal mit 256 möglichen Transparenzstufen. Dies ist jedoch von der Spezifikation nicht vorgesehen.
  • BI_RLE8 und BI_RLE4
Jeweils zwei aufeinanderfolgende Bytes bilden einen Datensatz. Hat das erste Byte einen anderen Wert als 0, so wird das zweite Byte so oft (bei BI_RLE4: die nächsten 2 Nibbles insgesamt, Beispiel: 05 67 → 6 7 6 7 6) wiederholt, wie das erste Byte angibt. Hat das erste Byte hingegen den Wert 0, so hängt die Bedeutung vom zweiten Byte ab:
0:Ende der Bildzeile.
1:Ende der Bitmap.
2:Verschiebung der aktuellen Pixelposition. Die beiden nächsten Bytes geben die Verschiebung nach rechts und nach unten an.
n=3-255:Die folgenden n Bytes (bei BI_RLE4: die folgenden n Nibbles) werden direkt übernommen; der nächste Datensatz findet sich am darauffolgenden geraden Offset (vom Start der Bilddaten aus gezählt).
Das Resultat wird wie im unkomprimierten Fall interpretiert.

Vor- und Nachteile

Vorteile von Bitmaps sind unter anderem:[7]

  • Die einfache Erstellung aus bereits im Arbeitsspeicher des Computers vorhandenen Pixeldaten.
  • Der effiziente und simple Zugriff auf die Bilddaten auf Grund ihrer rasterartigen Anordnung.
  • Eine Änderung der Farbinformation durch Änderung einer eventuell vorhandenen Palette ist möglich, ohne die Bilddaten selber zu ändern.
  • Die einfache Ausgabe auf rasterbasierte Ausgabegeräte wie Monitore oder Drucker.

Nachteile von Bitmaps sind unter anderem:

  • Die große Dateigröße im Vergleich zu komprimierten Formaten.
  • Sofern die übliche Zeilenanordnung gewählt wird, steht das Bild – verglichen mit der Zeilenfolge auf einem üblichen Bildschirm – auf dem Kopf[8]

Versionen 4 und 5

Microsoft hat mit Windows 95 und Windows 98 neuere Versionen 4 und 5 des BMP-Formates eingeführt, die Alphakanäle und Farbkorrektur ermöglichen und als Containerformat für PNG- und JFIF-Dateien verwendet werden können. Diese neuen Formate sind jedoch nur sehr selten als eigenständige Dateien anzutreffen und werden kaum von Anwendungen unterstützt; sie finden eher als internes Format in Windows-Programmen Verwendung.

Siehe auch

Literatur

  • Thomas W. Lipp: Grafikformate. Microsoft Press, Unterschleißheim 1997, ISBN 3-86063-391-0.
  • John Miano: Compressed Image File Formats. Addison-Wesley, Reading 2000, ISBN 0-201-60443-4.

Einzelnachweise

  1. Quellcode für BMPImageReader.cpp in Chromium. In: chromium.googlesource.com. Archiviert vom Original (nicht mehr online verfügbar) am 8. Dezember 2015; abgerufen am 2. Dezember 2015.  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/chromium.googlesource.com
  2. Quellcode für nsBMPDecoder.cpp in Mozilla Firefox. In: dxr.mozilla.org. Ehemals im Original (nicht mehr online verfügbar); abgerufen am 2. Dezember 2015.@1@2Vorlage:Toter Link/dxr.mozilla.org (Seite nicht mehr abrufbar. Suche in Webarchiven)
  3. BITMAPFILEHEADER Structure
  4. BITMAPINFOHEADER Structure
  5. Bitmap Storage
  6. https://devblogs.microsoft.com/oldnewthing/20210525-00/?p=105250 Why are device-independent bitmaps upside down? by Raymond Chen
  7. Pros and Cons of Bitmap File Formats In: James D. Murray, William VanRyper: Encyclopedia of Graphics File Formats. 2. Auflage. O’Reilly & Associates, Bonn 1996, ISBN 1-56592-161-5.
  8. Bitmap Storage