• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 1078
  • Last Modified:

CBitmap

Hi,
    Given a BITMAPINFO struct and a byte array of RGB pixel values (in the proper format with each row aligned to 4 bytes)  void* lp, how do I copy them into a CBitmap object so that it can be displayed in the screen?

Thanks.
0
pcssecure
Asked:
pcssecure
  • 7
  • 4
  • 3
1 Solution
 
SteHCommented:
Use CBitmap::SetBitmapBits (dwSize, lp);
0
 
pcssecureAuthor Commented:
i tried it doesn't work. There is something that i am doing wrong...
0
 
AlexFMCommented:
Do you need code for all possible bitmap types (RGB 24 bits, RGB 32 bits, bitmap with color palette etc.) or for some specific bitmap type? In the last case code is much simpler.
0
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
SteHCommented:
It could be that the aligning is done inside of SetBitmapBits already and you don't need to care but this should not affect the call when it data is aligned and the size is given correctly.

How does the call fail? Or is it the craetion of the CBitmap object not respecting your BITMAPINFO structure? In the latter case you can use CBitmap::CreateBitmapIndirect () using your BITMAPINFO as first part of the BITMAP structure. Leave the rest of the structure unfilled first and use SetBitmapBits afterwards. This should give you a bitmap with the parameters specified in the BITAMPINFO.
0
 
pcssecureAuthor Commented:
Here's my code,


m_BitMap is of type BITMAP
m_BmpInfo is of type BITMAPINFO
m_BmpBits is of type void*

m_BitMap.bmBits      = m_BmpBits;
m_BitMap.bmBitsPixel      = m_BmpInfo->bmiHeader.biBitCount;
m_BitMap.bmHeight      = m_BmpInfo->bmiHeader.biHeight;
m_BitMap.bmPlanes      = m_BmpInfo->bmiHeader.biPlanes;
m_BitMap.bmType      = 0;
m_BitMap.bmWidth      = m_BmpInfo->bmiHeader.biWidth;
m_BitMap.bmWidthBytes = m_BitMap.bmBitsPixel * m_BitMap.bmWidth / 8;

int patchBytes = m_BitMap.bmWidthBytes% 4; //Number of bits to patch.
if (patchBytes > 0)
        m_BitMap.bmWidthBytes += 4 - m_BitMap.bmWidthBytes % 4;


m_Bmp->CreateBitmapIndirect(&m_BitMap);

m_Bmp->SetBitmapBits(m_BmpInfo->bmiHeader.biSizeImage, m_BmpBits);

      
BITMAP bm;
m_Bmp->GetBitmap(&bm);


bm.bmBits points to a NULL pointer. So something is wrong.

      
0
 
pcssecureAuthor Commented:
m_Bmp was created as below:

if (!m_Bmp)
            m_Bmp = new CBitmap;
0
 
AlexFMCommented:
You need to use CreateDIBSection function. It returns HBITMAP, after this attach it to CBitmap:

m_Bmp->Attach(hBitmap);

In this case CBitmap is devide-independent bitmap (DIB). DIB allows using of SetBitmapBits, and bm.bmBits for such bitmap is not NULL.
0
 
pcssecureAuthor Commented:
Does LoadImage method in CBitMap do the same thing (CreateDIBSection and all)?
0
 
SteHCommented:
For CBitmap I only find LoadBitmap as member functions. This will get a resource into a CBitmap. Where do you get your BITAMPINFO and the bits from?
0
 
pcssecureAuthor Commented:
The BITMAPINFO and Byte array pixels are obtained from memory mapped files. I have checked the contents. They are ok.

When using CreatingDIBSection, how do I free the memory allocated for the DIBSection after usage? Will calling
DeleteObject(HBITMAP) do the job?
0
 
AlexFMCommented:
CBitmap class doesn't have LoadImage function. It's LoadBitmap function doesn't do this.
LoadImage API can load bitmap as DIB, if it is used with LR_CREATEDIBSECTION flag. HBITMAP returned by LoadImage may be attached to CBitmap using Attach function.

Internally, LoadImage  with LR_CREATEDIBSECTION flag reads BITMAPINFO structure which comes from file, and creates DIB, calling CreateDIBSection or some other API.
0
 
pcssecureAuthor Commented:
CreateDIBSection Works beautifully..

Thanks a lot to everyone.
0
 
AlexFMCommented:
>> When using CreatingDIBSection, how do I free the memory allocated for the DIBSection after usage?

CreateDIBSection returns HBITMAP. You attach it to CBItmap and don't care to release it since CBitmap is responsible for it. If you want to release CBitmap for reusing, call CBitmap::DeleteObject.

If you don't attach HBITMAP to CBitmap, use DeleteObject API to release it.
0
 
pcssecureAuthor Commented:
Thanks again Alex. You have been a great help over the last two days...

I can now load an image in a delphi process and display the image using another C process via memory mapped file.

Thanks a lot.
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

  • 7
  • 4
  • 3
Tackle projects and never again get stuck behind a technical roadblock.
Join Now