GetImageBits
int GetImageBits (int panelHandle, int controlID, int imageID, int *bytesPerRow, int *pixelDepth, int *width, int *height, int colorTable[], unsigned char bits[], unsigned char mask[]);
Purpose
![]() |
Note This function has been superseded by GetBitmapDataEx, which you can use to get alpha-channel data. |
Obtains the bit values that define an image. You can modify the bit values and then apply them back to the image using SetImageBits.
Before calling GetImageBits, you must perform the following actions:
- Call GetImageInfo to get the size of the buffers, and then allocate the buffers.
- Call AllocImageBits.
You can use this function on images you create using functions such as DisplayImageFile, InsertListItem, ReplaceListItem, PlotBitmap, SetImageBits, or SetCtrlAttribute with the ATTR_IMAGE_FILE attribute.
Supported Controls
You can use GetImageBits with the following controls:
Parameters
Input | ||
Name | Type | Description |
panelHandle | int | Specifier for a particular panel that is currently in memory. You can obtain this handle from functions such as LoadPanel and NewPanel. |
controlID | int | The defined constant, located in the .uir header file, that you assigned to the control in the User Interface Editor, or the ID returned by functions such as NewCtrl and DuplicateCtrl. |
imageID | int | For picture rings, the zero-based index of an image in the ring. For graphs, the plot handle you obtain from PlotBitmap. For picture controls, picture buttons, and canvas controls, this parameter is ignored. |
Output | ||
Name | Type | Description |
bytesPerRow | int | Number of bytes on each scan line of the image. You can pass NULL for this parameter. |
pixelDepth | int | Number of bits per pixel. The valid values for the pixelDepth parameter are 1, 4, 8, 24, or 32. You can pass NULL for this parameter. |
width | int | Width of the image, in pixels. If no image exists, this parameter is set to –1. For images originally rendered from a Windows metafile (.wmf or .emf), you can determine the size of the bitmap obtained by this function as follows:
|
height | int | Height of the image, in pixels. If no image exists, this parameter is set to –1. For images originally rendered from a Windows metafile (.wmf or .emf), you can determine the size of the bitmap obtained by this function as follows:
|
colorTable | int [] | Array of RGB color values, or NULL if pixelDepth is greater than 8. If pixelDepth is 8 or less, the bits array contains indices into the colorTable array. The number of entries in the colorTable array must equal 2n, where n is the value of the pixelDepth parameter. If pixelDepth is greater than 8, the colorTable parameter is not used. The bits array contains actual RGB color values rather than indices into the colorTable array. If GetBitmapInfo sets the colorSize parameter to 0, this array is not filled in. You can pass NULL for this parameter. |
bits | unsigned char [] | Array of bits that determines the colors to display on each pixel in the image. The number of bits per pixel is equal to the pixelDepth value. The first pixel in the bits array is at the upper-left corner of the image. The pixels in the array are stored in row-major order. If pixelDepth is 8 or less, the bits array contains indices into the colorTable array. If pixelDepth is greater than 8, the colorTable array is not used, and the bits array contains the actual RGB values. If pixelDepth is 24, each pixel is represented by a 24-bit RGB value of the form RRGGBB, where RR, GG, and BB represent the red, green, and blue components of the color value. The RR byte is at the lowest memory address of the three bytes. If pixelDepth is 32, each pixel is represented by a 32-bit RGB value of the form 0x00RRGGBB, where RR, GG, and BB represent the red, green, and blue components of the color value. The 32-bit value is treated as a native 32-bit integer value. The BB byte is in the least significant byte and, therefore, is at the lowest memory address of the four bytes. The most significant byte of this integer is ignored. Notice that this byte ordering scheme differs from the byte ordering scheme when pixelDepth is 24. You can pass NULL for this parameter. |
mask | unsigned char [] | Array that determines which pixels in the image to draw. Use the mask array to achieve binary transparency. The mask array contains one bit for each pixel in the image. A mask array bit value of 1 indicates that the pixel is drawn; a mask array bit value of 0 indicates that the pixel is not drawn. When pixelDepth is 1, the pixels that have a bits array value of 1 are always drawn, regardless of the mask array value. In this case, the mask array affects only the pixels that have a bits array value of 0. You must pad each row of the mask array to the nearest even-byte boundary. For example, if the width of the image is 21 pixels, then each row of the mask array must have 32 bits (four bytes) of data. If GetBitmapInfo sets the maskSize parameter to 0, this array is not filled in. You can pass NULL for this parameter. |
Return Value
Name | Type | Description |
status | int | Return value indicating whether the function was successful. A negative number indicates that an error occurred. |
Additional Information
Library: User Interface Library
Include file: userint.h
LabWindows/CVI compatibility: LabWindows/CVI 4.0 and later