Added support for bitmaps in BPictures.
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@16348 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
36077365d1
commit
3da4d36c6a
@ -5,6 +5,7 @@
|
|||||||
#include "ViewLayer.h"
|
#include "ViewLayer.h"
|
||||||
#include "WindowLayer.h"
|
#include "WindowLayer.h"
|
||||||
|
|
||||||
|
#include <ServerBitmap.h>
|
||||||
#include <ServerProtocol.h>
|
#include <ServerProtocol.h>
|
||||||
#include <TPicture.h>
|
#include <TPicture.h>
|
||||||
|
|
||||||
@ -178,18 +179,23 @@ static void
|
|||||||
draw_pixels(ViewLayer *view, BRect src, BRect dest, int32 width, int32 height,
|
draw_pixels(ViewLayer *view, BRect src, BRect dest, int32 width, int32 height,
|
||||||
int32 bytesPerRow, int32 pixelFormat, int32 flags, void *data)
|
int32 bytesPerRow, int32 pixelFormat, int32 flags, void *data)
|
||||||
{
|
{
|
||||||
/*BBitmap *bitmap = new (nothrow) BBitmap(BRect(0, 0, width - 1, height - 1),
|
// TODO: Review this
|
||||||
flags | B_BITMAP_NO_SERVER_LINK, (color_space)pixelFormat);
|
UtilityBitmap bitmap(BRect(0, 0, width - 1, height - 1), (color_space)pixelFormat, flags, bytesPerRow);
|
||||||
|
|
||||||
if (bitmap == NULL || bitmap->ImportBits(data, bytesPerRow * height,
|
if (!bitmap.IsValid())
|
||||||
bitmap->BytesPerRow(), 0, (color_space)pixelFormat) < B_OK)
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
uint8 *pixels = (uint8 *)data;
|
||||||
|
uint8 *destPixels = (uint8 *)bitmap.Bits();
|
||||||
|
for (int32 h = 0; h < height; h++) {
|
||||||
|
memcpy(destPixels, pixels, bytesPerRow);
|
||||||
|
pixels += bytesPerRow;
|
||||||
|
destPixels += bytesPerRow;
|
||||||
|
}
|
||||||
|
|
||||||
view->ConvertToScreenForDrawing(&dest);
|
view->ConvertToScreenForDrawing(&dest);
|
||||||
|
|
||||||
view->Window()->GetDrawingEngine()->DrawBitmap(bitmap, src, dest, view->CurrentState());
|
view->Window()->GetDrawingEngine()->DrawBitmap(&bitmap, src, dest, view->CurrentState());
|
||||||
|
|
||||||
delete bitmap;*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user