| ←Previous Entry | Next Entry→ | |||||||||
| Pixels and BitmapsThe visual elements of a computer screen are derived from manipulating frame buffers. Each pixel point on the screen has (x,y) coordinates which corresponds to a group of bits, say 32 bits for the front RGBA buffer, another 32 bits for the back RGBA buffer and 32 more for the depth values. There may also be an accumulation buffer, a stencil buffer or extra color buffers. As illustrated below, you can think of these buffers as layers of 1-bit mXn planes, where mn is the resolution of the screen. Groups of planes like this correspond to various OpenGL buffers. All the bits for a given x,y location form the pixel for that location. 
				 As a programmer, typically I'll want to read and write rectangular arrays of pixels, or only specific groups of bits in the generalized pixel that correspond to one of the OpenGL buffers, using a single function execution called a bit block transfer operation, or simply "bitblt." The functions for manipulating bitmaps are quite different. A bitmap, like a pixel, is thought of as a fundamental primitive. While vertices are fundamental to geometric processing, pixels and bitmaps are fundamental to pixel operations and the results of these two separate processing are combined in rasterization and finally, display. At first blush, it may seem that dealing with bitmaps would be fairly simple: you put the rectangular chunk where you want it. Trouble is, you can run into conflicts of format; how the pixels are stored in the bitmap, and the different types of pixels that might be involved. Is the pixel RGB, RGBA, depth or luminance or what? And are the represented by bytes, integers or floats? Do we need to rescale the bitmap or run it through some kind of filter? 
 Bitmaps are also used to construct cursors, mouse pointers and crosshairs. Also, as masks to cause action at a location. To define a bitmap for use in a program, it helps to put the bits in a one-dimensional array. This snippet generates 64*64 = 4096 bits for an 8x8 checkerboard where each square is either and 8x8 block of 1's or and 8x8 block of 0's. 
 To display the board in a 64x64 bitmap use the function call 
 In this instance, 
 Where is the board positioned? The function glRasterPos*() will set the current raster position. The third and fourth parameters are offsets added to the current raster position the lower left corner to determine where to position the bitmap in the color buffer. Then the raster position is incremented by the fifth and sixth parameters--these are all zero in the function call above. The main purpose for these parameters is in creating text we typically want to advance in an orderly, regular fashion. This is not as simple as it might seem at first: some characters extend below the baseline and you may want superscripts, etc. The raster position can be specified in two, three or four dimensions using either floats or integers. As it passes through the geometric pipeline it's transformed by both the model-view and projection matrices before finding its place on the screen. It may actually be outside the viewport, in which case it won't be drawn. Transparency is inherent in that a 1 pixel, the result also depends on the current state of the pixel where it is placed. A zero pixel in a bitmap will be totally transparent. If the color buffer is currently all red and the drawing color is set to green, then the code above will draw a green and red checkerboard. Bitmap and geometric figures can be mixed in the same graphic, but the geometric objects will be rescaled when you resize the window while bitmapped figures will not. The figures below illustrate this. The code follows. Here's an implementation of these ideas so far: 
 Btw, I recall having fussed with this some months ago, though I'm not sure just what entry it was. There are functions for printing letters like 
 
 
 Bringing the mouse into play is simple enough. I'm not sure this is the best way to go here. I added the line 
 to themain() function and then transfer some of the functionality from display() to maotzer() more or less as follows: 
 As the result indicates, the outcome was a little unpredictable?! Anyway, I've been trying to figure out how to bring in existing graphics files in, say, jpeg format, but it's proving to be quite difficult! I found this: http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnopen/html/msdn_gl5.asp My problem at this point is that I'd like to draw .bmp files, but that doesn't seem to be readily facilitated, perhaps due to the complex issues of pixel formats, etc. ImagesThe main limitation of a bitmap, it seems to me, is that it only allows a single bit (get it: bit!!!) per pixel. Most perplexing. For an image, you might want each pixel to contain R,G,B,A color. This is more in the realm of texture maps. | ||||||||||