//typedef struct tagBITMAPINFO { // BITMAPINFOHEADER bmiHeader ; // RGBQUAD bmiColors [1]; //} BITMAPINFO, *PBITMAPINFO;
Locks a global memory object and returns a pointer to the firstbyte of the object's memory block.
Note Theglobal functions are slower than other memory management functionsand do not provide as many features. Therefore, new applicationsshould use the heapfunctions . However, the global functions are still used withDDE and the clipboard functions.
LPVOID GlobalLock( HGLOBAL hMem);
Parameters
Return Values
If the function succeeds, the return value is a pointer to thefirst byte of the memory block.
If the function fails, the return value is NULL. To get extendederror information, call GetLastError .
Remarks
The internal data structures for each memory object include alock count that is initially zero. For movable memory objects, GlobalLock increments the count by one, and the GlobalUnlock function decrements the count by one. For eachcall that a process makes to GlobalLock for an object, itmust eventually call GlobalUnlock . Locked memory will not bemoved or discarded, unless the memory object is reallocated byusing the GlobalReAlloc function. The memory block of a locked memoryobject remains locked until its lock count is decremented to zero,at which time it can be moved or discarded.
Memory objects allocated with GMEM_FIXED always have a lockcount of zero. For these objects, the value of the returned pointeris equal to the value of the specified handle.
If the specified memory block has been discarded or if thememory block has a zero-byte size, this function returns NULL.
Discarded objects always have a lock count of zero.
BITMAPINFO
The BITMAPINFO structure defines the dimensions and colorinformation for a DIB.
typedef struct tagBITMAPINFO { BITMAPINFOHEADER bmiHeader ; RGBQUAD bmiColors [1]; } BITMAPINFO, *PBITMAPINFO;
Members
.
- An array of RGBQUAD .The elements of the array that make up the color table.
-
An array of 16-bit unsigned integers that specifies indexesinto the currently realized logical palette. This use of
bmiColors
is allowed for functions that use DIBs. When
bmiColors
elements contain indexes to a realized logicalpalette, they must also call the following bitmap functions:
The i Usage parameter of CreateDIBSection must beset to DIB_PAL_COLORS.
The number of entries in the array depends on the values of the biBitCount and biClrUsed members of the BITMAPINFOHEADER structure.
The colors in the bmiColors table appear in order ofimportance. For more information, see the Remarks section.
Remarks
A DIB consists of two distinct parts: a BITMAPINFO structure describing the dimensions and colors of the bitmap, andan array of bytes defining the pixels of the bitmap. The bits inthe array are packed together, but each scan line must be paddedwith zeroes to end on a LONG data-type boundary. If theheight of the bitmap is positive, the bitmap is a bottom-up DIB andits origin is the lower-left corner. If the height is negative, thebitmap is a top-down DIB and its origin is the upper leftcorner.
A bitmap is packed when the bitmap array immediately follows the BITMAPINFO header. Packed bitmaps are referenced by a singlepointer. For packed bitmaps, the biClrUsed member must beset to an even number when using the DIB_PAL_COLORS mode so thatthe DIB bitmap array starts on a DWORD boundary.
Note The bmiColors member should not contain palette indexes if thebitmap is to be stored in a file or transferred to anotherapplication.
Unless the application has exclusive use andcontrol of the bitmap, the bitmap color table should containexplicit RGB values.