Easy BMP User Manual

EasyBMP_UserManual

EasyBMP_UserManual

EasyBMP_UserManual

EasyBMP_UserManual

EasyBMP_UserManual

User Manual: Pdf

Open the PDF directly: View PDF PDF.
Page Count: 17

DownloadEasy BMP User Manual
Open PDF In BrowserView PDF
EasyBMP User Manual

Version 1.06

EasyBMP User Manual (Version 1.06)
Paul Macklin
email: macklin01@users.sourceforge.net
WWW: http://easybmp.sourceforge.net
December 17, 2006
Abstract
We define and document a simple, easy-to-use, cross-platform/cross-architecture Windows bitmap
(BMP) library written in C++. The EasyBMP library will work for input and output on uncompressed
1, 4, 8, 16, 24, and 32 bpp (bits per pixel) Windows BMP files in just about any operating system on just about any 32-bit or higher architecture. EasyBMP has been tested on both little-endian
(Pentium 3, Pentium 4, Celeron, Celeron M, Pentium M) and big-endian (Sun Sparc4) machines in
Linux, Solaris, and Windows on 32-bit and 64-bit CPU’s. Currently, GNU g++ (along with variants and/or frontends such as MinGW and Bloodshed), Intel’s compiler, Borland’s compiler, and
Microsoft’s MSVC++ compilers are fully supported.
EasyBMP is open source software and is licensed under the revised/modifed BSD license. Please see
the BSD (revised) license.txt file for further details. If you use this library in your application, it
is the author’s request that you notify him.

Contents
1 What’s New in this Release
1.1 Changes in Version 1.04 .
1.2 Changes in Version 1.05 .
1.3 Changes in Version 1.06 .

(Version
. . . . . .
. . . . . .
. . . . . .

1.06)
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .

2
2
2
2

2 Introduction to the EasyBMP Library
2.1 Sample Application: Converting a Color Image to Grayscale . . . . . . . . . . . . . . .

3
3

3 What’s EasyBMP Good for?

4

4 Installing and Using the EasyBMP Library

5

5 A Few Words on the BMP file format

6

6 Basic Bitmap Operations

7

7 Advanced Usage: Modifying the Color Table

9

Page 1

EasyBMP User Manual

Version 1.06

8 Tools for Horizontal and Vertical Resolution

11

9 EasyBMP and Warning Messages

11

10 EasyBMP and Metadata

12

11 Extra Goodies: Various Bitmap Utilities

12

12 Hidden Helper Functions

14

13 Known Bugs and Quirks

14

14 Future Changes

14

15 Obtaining Support for EasyBMP or Contacting EasyBMP

15

A Classes and BMP Data Types
A.1 Miscellany . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
A.2 RGBApixel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
A.3 BMP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

15
15
15
15

1

What’s New in this Release (Version 1.06)

Several major changes have been made since Version 1.03, including bugfixes, improved robustness,
code cleanups, and feature enhancements.

1.1

Changes in Version 1.04

Version 1.04 focused on improving compatibility with the Borland compiler. Very few warnings are
generated when compiling; those that remain can be safely ignored and point to quirks of Borland
rather than the code.
This release also added some new functionality: the ability to suppress all EasyBMP warning and
error messages. This new feature should be particularly useful for projects that have no need for
terminal output.

1.2

Changes in Version 1.05

Version 1.05 improved compatibility by adding a copy constructor for the BMP class. A new feature
was also added: bilinear image rescaling to a desired percentage, width, height, or square box fit.

1.3

Changes in Version 1.06

Version 1.06 fixed several minor bugs, particularly in the copy constructor. (Thank you to “redmaya”
in South Korea!) The cctype and cstring includes were added to improve compliance and compatibility. Lastly, GetPixel() and SetPixel() functions were added for future use, where we hope to be
more careful with the const keyword.

Page 2

EasyBMP User Manual

Version 1.06

For further information on the changes made in EasyBMP, please see the EasyBMP ChangeLog.txt
file that is included with every release.

2

Introduction to the EasyBMP Library

During my studies at the University of Minnesota and the University of California, I needed a simple
method to create and modify images. Because the Windows BMP file format is nearly universally
readable, flexible, and simple, I decided to work with this format. (No compression to worry about,
potential for 8 bits per color channel, etc.)
There are many excellent open- and closed-source BMP and image libraries available, and in no
way do I claim that anything here is even equal to those libraries. However, as I looked about I noticed
that quite a few existing libraries had one or more of the following properties:
•

too feature-rich (and accordingly more difficult to learn);

•

required extensive installation;

•

relied upon Linux or Windows libraries for simple functions;

•

were too poorly documented for the novice programmer;

•

required programming changes when moving code from one platform to another.

At that point, I decided to create my EasyBMP library. My goals included easy inclusion in C++
projects, ease of use, no dependence upon other libraries (totally self-contained), and cross-platform
compatibility.

2.1

Sample Application: Converting a Color Image to Grayscale

Here, we give a first sample application using the EasyBMP library. Notice that inclusion of the library
is simple: we include the EasyBMP.h file. In this application, we see a simple example of opening an
existing BMP file, reading its RGB information, and manipulating and writing that information to
another BMP file. The commands are pretty straightforward. This example should illustrate how
easy the library is for even the novice programmer.
#include "EasyBMP.h"
using namespace std;
int main( int argc, char* argv[] )
{
if( argc != 3 )
{
cout << "Usage: ColorBMPtoGrayscale  "
<< endl << endl;
return 1;
}
// declare and read the bitmap
BMP Input;
Input.ReadFromFile( argv[1] );

Page 3

EasyBMP User Manual

Version 1.06

// convert each pixel to grayscale using RGB->YUV
for( int j=0 ; j < Input.TellHeight() ; j++)
{
for( int i=0 ; i < Input.TellWidth() ; i++)
{
int Temp = (int) floor( 0.299*Input(i,j)->Red +
0.587*Input(i,j)->Green +
0.114*Input(i,j)->Blue );
ebmpBYTE TempBYTE = (ebmpBYTE) Temp;
Input(i,j)->Red
= TempBYTE;
Input(i,j)->Green = TempBYTE;
Input(i,j)->Blue = TempBYTE;
}
}
// Create a grayscale color table if necessary
if( Input.TellBitDepth() < 16 )
{ CreateGrayscaleColorTable( Input ); }
// write the output file
Input.WriteToFile( argv[2] );
return 0;
}
Additional code samples are available for download at
http://easybmp.sourceforge.net

3

What’s EasyBMP Good for?

Lots of things! Okay, so we’re a little biased. :-) EasyBMP was first used to easily load textures in
a homebrew raytracer. Later on, however, its focus shifted to being a simple, intuitive way to get
image data in and out of programs, particularly scientific applications. Some sample application ideas
include:
1. If you have a scientific computation that runs for hours, days, or weeks, you could add a quick
routine that outputs a snapshot of the simulation after every time step. This would provide an
easy way to check the status of your long-running simulation without the overhead of starting
up Matlab, Tecplot, etc. With X-forwarding, you could even check your simulation snapshot
remotely over an SSH shell on free WiFi at Panera! :-)
2. You could write a small program that generates animation frames from your simulation data.
Then, remotely start the program over a command line shell, let it run on its own, and collect
the results later. Again, no overhead of Tecplot or Matlab, and no user interaction required!
(You could then combine the movie frames into an AVI animation using EasyBMPtoAVI. See
http://easybmptoavi.sourceforge.net.)

Page 4

EasyBMP User Manual

Version 1.06

3. Import patient data (e.g., MRI imagery) into a patient-tailored simulation or for medical analysis.
4. Create arbitrary starting shapes for level set methods based on your own hand-drawn BMP files.
This eliminates the artificial restriction of only being able to simulate shapes whose level set
functions that can readily be described with a formula.
5. Interface your science applications with imaging equipment.
6. Use EasyBMP as a quick testbed for new image processing ideas.
7. Import snapshots from a webcam, compare them, and use EasyBMP to remotely detect changes
in a room.
8. Import textures for raytracing and OpenGL programs.
9. Save screenshots of OpenGL programs. Or an X program. Or ...
10. Create nice graphics for a system monitoring utility.

4

Installing and Using the EasyBMP Library

Installing the EasyBMP library is easy. Simply copy all the *.h and *.cpp files to the directory of your
project. Alternatively, copy all the header files anywhere in your compiler’s path. You should have
the following files:
1. EasyBMP.h
2. EasyBMP DataStructures.h
3. EasyBMP BMP.h
4. EasyBMP VariousBMPutilities.h
5. EasyBMP.cpp
along with a code sample in the sample directory.
To use the EasyBMP library, simply include the EasyBMP.h file via
#include "EasyBMP.h"
Note that if you have copied all the EasyBMP source files to your compiler path, you may not need the
quotes, but rather brackets:
#include 
Compile your source code as you normally would along with the single EasyBMP.cpp file; you don’t
have to link to anything. For instance, to compile the code example above with g++, use
g++ -o ColorBMPtoGrayscale ColorBMPtoGrayscale.cpp EasyBMP.cpp
A sample project with a makefile is included in the sample directory. It demonstrates how to compile EasyBMP with a makefile. Please see the project website at http://easybmp.sourceforge.net
for further compiling instructions, particularly for Microsoft Visual Studio and makefile tutorials.

Page 5

EasyBMP User Manual

5

Version 1.06

A Few Words on the BMP file format

Any BMP file begins with a file header, which contains information on the file size and data location.
The file header is followed by an info header, which has information on the dimensions and color depth
of the file. All this information is stored in the first 54 bytes of the file.
After that, the data is stored. There are two basic storage schemes for BMP files. If the bit depth
is 8 or less (256 colors or fewer), the colors are stored in a table of (red,green,blue,alpha) values immediately after the info header. In this indexed format, each pixel in the image refers to the position
of a color in the color table. In essence, this storage technique is “painting by number.” The benefit
is that each pixel requires little space, but each of the 256 colors can attain the full range allowed on
modern machines. (One of 2563 colors with 256 values of transparency.)
The other scheme involves storing the red, green, and blue data at every pixel, along with (possibly) the alpha value. This format is very intuitive and allows for the full range of colors for all pixels.
However, the resulting files are substantially larger than for 1, 4, and 8 bpp (bits per pixel) files.
An intermediate storage scheme is to allocate two consecutive bytes per every pixel (16 bpp bit
depth). In this scheme, 5 bits are allocated to red and blue, and 5 or 6 bits are allocated to green.
The green channel is given preference over the other channels because the human eye is most sensitive
to green, followed by red and then blue; allocating the extra bit to green makes the most rational use
of the space when considering the human viewer.
EasyBMP internally converts all files to 32 bpp for ease and consistency of handling. In particular,
this makes it easy to write add-on functions that work on all bit-depth files. EasyBMP converts back
to the original bit depth when saving the file.
The coordinate system of a BMP file has its origin in the top left corner of the image. The
(i, j)th pixel is i pixels from the left and j pixels from the top. EasyBMP indexes pixels with the same
coordinate system. See Figure 1.

(0,0)
j

(M-1,0)

i
u

(i,j)

(0,N-1)

(M-1,N-1)

Figure 1: Coordinate system for an M × N BMP image. The black circle indicates
the (i,j)th pixel in the coordinate system.

Page 6

EasyBMP User Manual

6

Version 1.06

Basic Bitmap Operations

As of Version 0.55, EasyBMP has a unified interface for all bit depths. To initialize a new BMP object,
simply declare it:
Example:
// Declare a new bitmap object
BMP AnImage;
When you declare a BMP image, you will have a 1 × 1 blank 24 bpp (bits per pixel) bitmap image.
Next, set the size and bit depth of the image. You can do this either by reading an existing bitmap
image or setting this information manually, as below:
Example:
BMP AnImage;
// Set size to 640 × 480
AnImage.SetSize(640,480);
// Set its color depth to 8-bits
AnImage.SetBitDepth(8);
// Declare another BMP image
BMP AnotherImage;
// Read from a file
AnotherImage.ReadFromFile("sample.bmp");
To check the bit depth, width, and height of a BMP object, use:
Example:
BMP AnImage;
AnImage.ReadFromFile("sample.bmp");
cout << "File info:" << endl;
cout << AnImage.TellWidth() << " x " << AnImage.TellHeight()
<< " at " << AnImage.TellBitDepth() << " bpp" << endl;
EasyBMP also provides a simple routine to compute and display the number of colors:
Example:
BMP AnImage;
AnImage.ReadFromFile("sample.bmp");
cout << "colors: " << AnImage.TellNumberOfColors() << endl;
Note that for a 32 bpp file, we don’t regard two colors that differ only in the alpha channel as
different colors; this function will state that 32 bpp and 24 bpp files have the same number of colors.
The bit depth and dimensions of a bitmap can be changed at any time:

Page 7

EasyBMP User Manual

Version 1.06

Example:
BMP AnImage;
AnImage.ReadFromFile("sample.bmp");
// Change the bit-depth
AnImage.SetBitDepth(8);
AnImage.SetBitDepth(24);
// Change the size
AnImage.SetSize(1024,768);
Note that whenever the bit depth is changed, any existing color table is erased. Likewise, whenever
the size is changed, all pixels are deleted.
To access pixels, use RGBApixel* operator()(int,int):
Example:
BMP AnImage;
AnImage.ReadFromFile("sample.bmp");
// show the color of pixel (14,18)
cout << "(" << (int) AnImage(14,18)->Red
<<
<< (int) AnImage(14,18)->Green <<
<< (int) AnImage(14,18)->Blue <<
<< (int) AnImage(14,18)->Alpha <<
// Change this pixel to a blue-grayish color
AnImage(14,18)->Red
= 50;
AnImage(14,18)->Green = 50;
AnImage(14,18)->Blue = 192;
AnImage(14,18)->Alpha = 0;

","
","
","
")" << endl;

You can also access pixels using RGBApixel GetPixel(int,int) and bool SetPixel(int,int,RGBApixel):
Example:
BMP AnImage;
AnImage.ReadFromFile("sample.bmp");
// show the color of pixel (14,18)
RGBApixel Temp = AnImage.GetPixel(14,18);
cout << "(" << (int) Temp.Red
<< ","
<< (int) Temp.Green << ","
<< (int) Temp.Blue << ","
<< (int) Temp.Alpha << ")" << endl;
// Change this pixel to a blue-grayish color
Temp.Red = 50; Temp.Green = 50; Temp.Blue = 192; Temp.Alpha = 0;
AnImage.SetPixel(14,18,Temp);
Lastly, to save to a file, use WriteToFile(char*):

Page 8

EasyBMP User Manual

Version 1.06

Example:
BMP AnImage;
AnImage.ReadFromFile("sample.bmp");
AnImage.WriteToFile("copied.bmp");

7

Advanced Usage: Modifying the Color Table

In EasyBMP, the BMP class will automatically generate a “Windows standard” color table whenever one
is required (for 1, 4, and 8 bpp files). However, it is possible to access and modify individual colors in
the color table. If you want to see what the nth color in the color table and change another, use the
following:
Example:
BMP SomeImage;
// Set the bit depth to 8 bpp
SomeImage.SetBitDepth(8);
// Get the 40th color
RGBApixel SomeColor = SomeImage.GetColor(40);
// Display the color
cout << (int) SomeColor.Red
<< ","
<< (int) SomeColor.Green << ","
<< (int) SomeColor.Blue << ","
<< (int) SomeColor.Alpha << endl;
// Change the 14th color to red
RGBApixel NewColor;
NewColor.Red
= 255;
NewColor.Green = 0;
NewColor.Blue = 0;
NewColor.Alpha = 0;
SomeImage.SetColor(14,NewColor);
You can reset the color table to the “Windows standard” color table at any time:
Example:
BMP SomeImage;
// Set the bit depth to 8 bpp
SomeImage.SetBitDepth(8);
// Change the 14th color to red
RGBApixel NewColor;
NewColor.Red
= 255;
NewColor.Green = 0;
NewColor.Blue = 0;
NewColor.Alpha = 0;
SomeImage.SetColor(14,NewColor);
// Reset the color table
SomeImage.CreateStandardColorTable();

Page 9

EasyBMP User Manual

Version 1.06

To maintain previously-provided functionality, EasyBMP still provides a grayscale color table generator:
Example:
BMP SomeImage;
// Set the bit depth to 8 bpp
SomeImage.SetBitDepth(8);
// Create a grayscale color table
CreateGrayscaleColorTable( SomeImage );
Notice that in the example, the argument is a BMP object.
If you want to modify a color table for a BMP file, you can do so by using the SetColor(int,RGBApixel)
member function. To avoid messy error messages, any color table operation should do nothing when
applied to a 16, 24, or 32 bpp file. Consider this example:
Example:
void CreateRedColorTable( BMP& InputImage )
{
int BitDepth = InputImage.TellBitDepth();
if( BitDepth != 1 && BitDepth != 4 && BitDepth != 8 ){ return; }
int NumberOfColors = IntPow(2,BitDepth); int i;
ebmpBYTE StepSize;
if( BitDepth != 1 )
{ StepSize = 255/(NumberOfColors-1); }
else
{ StepSize = 255; }
for( i=0 ; i < NumberOfColors ; i++)
{
RGBApixel Temp;
Temp.Red
= i*StepSize;
Temp.Green = 0;
Temp.Blue = 0;
Temp.Alpha = 0;
InputImage.SetColor(i,Temp);
}
}
To call this new function, you would do this:
Example:
BMP RedImage;
RedImage.ReadFromFile("sample.bmp");
RedImage.SetBitDepth(8);
CreateRedColorTable( RedImage );

Page 10

EasyBMP User Manual

8

Version 1.06

Tools for Horizontal and Vertical Resolution

In some circumstances, it may be useful to specify the horizontal and vertical resolution of the machine
where a bitmap image was generated. The BMP provides for this possibility with the biXPelsPerMeter
and biYPelsPerMeter data members, although most files simply set these to 0, indicating that the
system default should be used instead.
EasyBMP now supports setting these numbers via the SetDPI() function:
Example:
BMP SomeImage;
SomeImage.ReadFromFile("sample.bmp");
// Set horizontal resolution to 64 DPI and vertical to 32 DPI
SomeImage.SetDPI(64,32);
The default vertical and horizontal resolutions are 96 dpi, and they are indicated by the globals
Example:
int DefaultXPelsPerMeter = 3780;
int DefaultYPelsPerMeter = 3780;
You can change the default behavior by setting these global variables to your own preferred values.
The conversion is pretty simple:
µ

DefaultXPelsPerMeter = (DesiredDefaultDPI dots / inch) ·

1 inches
2.54 cm

¶ µ

·

100 cm
1m

¶

DesiredDefaultDPI
dots / meter.
0.0254
The DefaultYPelsPerMeter can be changed similarly.
=

9

EasyBMP and Warning Messages

You can turn the error and warning messages on or off in EasyBMP; this is most useful for applications
where terminal output is not desired.
Example:
// turn the error messages off
SetEasyBMPwarningsOff();
// The following line would ordinarily give an out-of-range warning.
SomeImage( SomeImage.TellWidth() , SomeImage.TellHeight() )->Red = 0;
// turn the messages back off
SetEasyBMPwarningsOn();
// query the current message status
cout << "EasyBMP warning status: " << GetEasyBMPwarningState() << endl;

Page 11

EasyBMP User Manual

10

Version 1.06

EasyBMP and Metadata

EasyBMP currently supports reading BMP files with metadata by skipping it; in particular, EasyBMP
does not preserve or save metadata. In the future, EasyBMP will preserve metadata occurring before
and after the pixel data, as well as allow for the writing of additional metadata.

11

Extra Goodies: Various Bitmap Utilities

We have provided several sample utilities to make the library more immediately useful. We shall detail
some of these goodies here. :-).
The first several utilities deal with getting file information from existing files.
•

void DisplayBitmapInfo( char* szFileNameIn ): This routine displays the bitmap information from an existing bitmap. All information is given. (width and height of image, bit depth,
etc.)

•

BMFH GetBMFH( char* szFileNameIn ): This returns a BMFH based on the file. See Section A
for more information on the data structure.

•

BMIH GetBMIH( char* szFileNameIn ): This returns a BMIH based on the file. See Section A
for more information on the data structure.

•

int GetBitmapColorDepth( char* szFileNameIn ): This routine returns the bit depth of the
file.

Other provided functions are “cut ‘n’ paste” functions: they copy pixels from one BMP object to
another, with or without transparency.
•

void PixelToPixelCopy( BMP& From, int FromX, int FromY,
BMP& To, int ToX, int ToY)
This function copies the (FromX,FromY) pixel of the BMP object From to pixel (ToX,ToY) of the
BMP object To.

•

void PixelToPixelCopyTransparent( BMP& From, int FromX, int FromY,
BMP& To, int ToX, int ToY,
RGBApixel& Transparent )
This function copies the (FromX,FromY) pixel of the BMP object From to pixel (ToX,ToY) of the
BMP object To, and it treats the input pixel as transparent if its color is Transparent. Here’s an
example:
Example:
BMP Image1;
BMP Image2;
Image1.ReadFromFile("Blah.bmp");
Image2.SetSize(10,10);
RGBApixel TransparentColor;
TransparentColor.Red = 255;
TransparentColor.Green = 255;
TransparentColor.Blue = 255;
PixelToPixelCopyTransparent(Image1,3,5,Image2,0,0,TransparentColor);

Page 12

EasyBMP User Manual

Version 1.06

Note that the alpha channel is ignored when considering transparency.
•

void RangedPixelToPixelCopy( BMP& From, int FromL , int FromR, int FromB, int FromT,
BMP& To, int ToX, int ToY )
This function copies a range of pixels from one image to another. It copies the rectangle
[FromL , FromR] × [FromB , FromT] in image From to the rectangle whose top left corner
is (ToX , ToY) in image To. When using this function, don’t forget that the top left corner
of the image is (0,0) in the coordinate system! Also, FromB denotes the bottom edge of the
rectangle, so FromB > FromT. However, if the algorithm detects that you accidentally reversed
these numbers, it will automatically swap them for you. Lastly, if the rectangle you chose to
copy from image From overlaps the boundary of image To, it will truncate the the copy selection,
rather than give a nasty segmentation fault. :-)

•

void RangedPixelToPixelCopyTransparent(
BMP& From, int FromL , int FromR, int FromB, int FromT,
BMP& To, int ToX, int ToY ,
RGBApixel& Transparent )
This function does the same thing as the previous function, but with support for transparency.
As in the example for the pixel-to-pixel copy above, you specify a transparent color of type
RGBApixel.
To maintain backward compatibility, we provide a function to generate a grayscale color table.

•

bool CreateGrayscaleColorTable( BMP& InputImage ): This function creates a grayscale
color table for any 1, 4, or 8 bpp BMP object. It returns true when successful and false
otherwise. An example is given in Section 7.
The last function rescales an image:

•

bool Rescale( BMP& InputImage, char mode, int NewDimension );
There are several different modes of operation available, which are probably best explained by
example. All scaling is done by bilinear interpolation. Note that the mode input is not casesensitive.
Example:
BMP AnImage;
AnImage.ReadFromFile("sample.bmp");
// rescale to 42% of original size
Rescale( AnImage , ’p’, 42 );
// rescale (preserving aspect ratio) to width 100
Rescale( AnImage , ’W’, 100 );
// rescale (preserving aspect ratio) to height 100
Rescale( AnImage , ’H’, 100 );
// rescale (preserving aspect ratio) to fit in a 100 x 100 box
Rescale( AnImage , ’f’, 100 );

Page 13

EasyBMP User Manual

12

Version 1.06

Hidden Helper Functions

EasyBMP has a few helper functions that are intended primarily for internal use, but may also be
helpful for your code.
•

double Square( double number ): This routine gives the square of the double number. It is
much faster than using the standard library pow(double,2.0).

•

int IntSquare( int number ): This does the same as the above, but with faster integer operations.

•

int IntPow( int base, int exponent ): Instead of calling pow(x,n) where x and n are integers, use this function. It’s much faster. Beware against using negative exponents, as they aren’t
supported.

13

Known Bugs and Quirks

As of Version 1.06, there is one known quirk: there is no operator= operator defined for the BMP class.
This means that you can’t do code operations like this:
Example:
BMP Sample1;
Sample1.ReadFromFile("sample1.bmp");
BMP Sample2;
Sample2.ReadFromFile("sample2.bmp");
Sample1 = Sample2;
AFAIK, the biggest implication of this is that you won’t want to make functions that return a BMP
object. Instead, if you want to modify a BMP object in a function, you should pass it by reference to
the function. An example of this can be seen in the CreateRedColorTable(BMP&) sample function
given in an earlier section.
operator= functionality may be added to EasyBMP at a later date, but only if they do not interfere
with stability and robustness.
The other “quirk” in EasyBMP is that writing 8 bpp images is very slow. This is a consequence of
the fact that 8 bpp images can be operated on just like 24 bpp images, and so the write routine must
search for the best fit color for each pixel when saving. This may be improved in future versions of
EasyBMP.

14

Future Changes

Future changes may include:
1. an optimal color table GenerateOptimalColorTable() generator function;
2. eliminating the use of ceil and floor functions, as well conversions from double to int wherever
possible.
3. adding support for metadata before and after the pixel data
4. improving file write speeds for 8 bpp files.

Page 14

EasyBMP User Manual

15

Version 1.06

Obtaining Support for EasyBMP or Contacting EasyBMP

If you need support, have a feature request, or have other feedback on EasyBMP, please open a new
support tracker item at http://easybmp.sourceforge.net. (See the “support” link on that page.)
If you also desire email support, you can email Paul Macklin at macklin01@users.sourceforge.net
or indicate your email address in your tracker item. However, please still open a tracker item in such
a case.
Lastly, Paul would love to hear back from people who have successfully used EasyBMP in their own
projects.

A

Classes and BMP Data Types

Here, we detail the various classes and data types and how to interface with them.

A.1

Miscellany

Some of the data types that are used in the construction of more complex data types are:
Type:
ebmpBYTE
ebmpWORD
ebmpDWORD
BMFH
BMIH

Info:
an unsigned character of 8 bits
an unsigned short of 16 bits
an unsigned long of 32 bits
a specific header format for a BMP file
provides additional information on the BMP file

For additional information on the BMFH and BMIH classes, I highly recommend that you visit
http://www.fortunecity.com/skyscraper/windows/364/bmpffrmt.html.

A.2

RGBApixel

This data structure is exactly as their its suggests: a single pixel of (red,green,blue,alpha) data. This
data structure is used both for individual pixels within an image and the color table in the palette.
Here are the details on the data structure:
Member:
Blue
Green
Red
Alpha

A.3

blue
green
red
alpha

pixel
pixel
pixel
pixel

info
info
info
info

of
of
of
of

Function:
type BYTE
type BYTE
type BYTE
type BYTE

BMP

The BMP class consists of all the necessary pixel information for a Windows bitmap file, along with file
I/O routines.
•

int BitDepth: This gives the number of bits per pixel, i.e., the color depth. This data member
is private and can only be accessed through TellBitDepth and SetBitDepth.

Page 15

EasyBMP User Manual

Version 1.06

•

int Width: This gives the width of the bitmap in pixels. This data member is private and can
only be accessed through TellWidth and SetSize.

•

int Height: This gives the height of the bitmap in pixels. This data member is private and can
only be accessed through TellHeight and SetSize.

•

RGBApixel** Pixels: This is the actual Width × Height array of RGBApixel’s. This data
member is private and can only be accessed through operator().

•

RGBApixel* Colors: This is the table of colors, stored as RGBApixel’s. If the BMP object is
24-bits or 32-bits, then Colors = NULL. This data member is private and can only be accessed
through GetColor and SetColor.

•

int XPelsPerMeter: This records the horizontal resolution in pixels per meter. This private
data member can only be accessed through SetDPI(). This value defaults to 3780, i.e., 96 dpi.

•

int YPelsPerMeter: This records the vertical resolution in pixels per meter. This private data
member can only be accessed through SetDPI(). This value defaults to 3780, i.e., 96 dpi.

•

BYTE* MetaData1: This is a placeholder for future metadata before the pixel data. This data
member is private. This is currently a placeholder.

•

int SizeOfMetaData1: This private data member gives the size of MetaData1 in bytes. This is
currently a placeholder.

•

BYTE* MetaData2: This is a placeholder for future metadata after the pixel data. This data
member is private. This is currently a placeholder.

•

int SizeOfMetaData2: This private data member gives the size of MetaData2 in bytes. This is
currently a placeholder.

•

void SetDPI( int HorizontalDPI, int VerticalDPI ): This function sets the private data
members XPelsPerMeter and YPelsPerMeter such that the image has horizontal and vertical
resolutions HorizontalDPI and VerticalDPI dots per inch, respectively.

•

int TellBitDepth( void ): This function outputs the bit depth of the BMP object.

•

int TellWidth( void ): This function outputs the width of the BMP object.

•

int TellHeight( void ): This function outputs the height of the BMP object.

•

int TellNumberOfColors( void ): This function outputs the number of colors of the BMP object.

•

BMP(): This constructor creates a 1 × 1, 24 bpp BMP object.

•

BMP( BMP& Input ): This the copy constructor, which is used when BMP objects are passed by
value, rather than reference.

•

~BMP(): This is the destructor. You should never call this; it is automatically called when a BMP
object goes out of scope.

•

RGBApixel GetPixel( int i, int j ) const: This is used to get the contents of the (i,j)
pixel while respecting const, using a syntax similar to the color table functions below. Primarily
for future use.

•

bool SetPixel( int i, int j, RGBApixel NewPixel ): This is used to set the contents of
the (i,j) pixel in a syntax similar to the color table functions below. Primarily for future use.

•

RGBApixel* operator()(int i, int j): This returns a pointer to the (i,j) pixel.

Page 16

EasyBMP User Manual

Version 1.06

Example:
BMP Sample;
Sample.SetSize(10,10);
Sample(3,4)->Red = 255;
Sample(3,4)->Alpha = 0;
Sample(3,4)->Blue = Sample(3,4)->Red;
If operator() is used on a pixel that is out of range, it warns the user and automatically
truncates the range.
•

bool SetSize( int NewWidth, int NewHeight ): Use this to change the size of the object to
NewWidth × NewHeight. See the example above. If NewWidth or NewHeight is non-positive, this
function gives a warning and does nothing. Returns true or false to indicate success or failure.

•

bool SetBitDepth( int NewDepth ): This function changes the bit depth to NewDepth bits
per pixel. It also automatically creates and/or resizes the color table, if necessary. If NewDepth
is not one of 1, 4, 8, 24, or 32, the function gives an error and does nothing. Returns true or
false to indicate success or failure.

•

bool WriteToFile( char* FileName ): This function writes the current BMP object to the file
FileName. Returns true or false to indicate success or failure.

•

bool ReadFromFile( char* FileName ): This function reads the file FileName into the current
BMP object. Returns true or false to indicate success or failure.

•

RGBApixel GetColor( int ColorNumber ): This function returns color number ColorNumber
in the color table of the current BMP object. If ColorNumber is out of range or the BMP does not
have a color table (e.g., in the case of a 24-bit file), this function gives a warning and returns a
black pixel.

•

bool SetColor( int ColorNumber , RGBApixel NewColor): This function sets color number
ColorNumber in the color table of the current BMP object to NewColor. If ColorNumber is out of
range or the BMP does not have a color table (e.g., in the case of a 24-bit file), this function gives
a warning and does nothing. Returns true or false to indicate success or failure.

•

bool CreateStandardColorTable( void ): This function creates a “Windows standard” color
table for the BMP object. If the bit depth is 24 or 32, the function gives a warning and does
nothing. Returns true or false to indicate success or failure.

Page 17



Source Exif Data:
File Type                       : PDF
File Type Extension             : pdf
MIME Type                       : application/pdf
PDF Version                     : 1.2
Linearized                      : No
Page Count                      : 17
Creator                         :  TeX output 2006.12.17:0034
Producer                        : dvipdfm 0.13.2c, Copyright © 1998, by Mark A. Wicks
Create Date                     : 2006:12:17 00:34:41-08:00
EXIF Metadata provided by EXIF.tools

Navigation menu