How much memory should be allocated for the DIB data received from HBITMAP using GetDIBits function?

StackOverflow https://stackoverflow.com/questions/7304749

문제

How much memory should be allocated for the DIB data received from HBITMAP using GetDIBits function?

The GetDIBits function is described in MSDN as follow:

int GetDIBits(
  __in     HDC hdc,
  __in     HBITMAP hbmp,
  __in     UINT uStartScan,
  __in     UINT cScanLines,
  __out    LPVOID lpvBits,
  __inout  LPBITMAPINFO lpbi,
  __in     UINT uUsage
);

However, the buffer to receive data lpvBits must be allocated before calling GetDIBits, because GetDIBits doesn't allocate this automatically.

The question is how much memory should be allocated to receive the DIB data? Supposed that the HBITMAP has width&height as Bmp_Width&Bmp_Height; and the bitmap is 32-bit (RGBA).

도움이 되었습니까?

해결책

I think the simplest way is calling GetObject() function (And BTW to get the image bits):

BITMAP bmpObject;
GetObject(hBitmap, sizeof(BITMAP), &bmpObject);

Then you simply use the Bitmap Fields:

LONG size = bmpObject.bmWidthBytes * bmpObject.bmHeight;

Be aware of alignment whem processing image bytes!

Hope this will be helpful!

다른 팁

The memory pointed to by lpvBits must be the size of one scan line times the height. Each scan line must be aligned on a DWORD boundary.

Since you are using 32 bit colour then each scanline will naturally satisy that requirement, so long as you ensure that the first scanline, i.e. the start of the memory block, is 4 byte aligned.

So the answer, measured in bytes, is 4*width*height, aligned to start on a 4 byte boundary.

라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top