extended support for BPicture, still not working
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@16006 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
af675e2c03
commit
92071609a1
@ -8,6 +8,8 @@
|
|||||||
#include <ServerProtocol.h>
|
#include <ServerProtocol.h>
|
||||||
#include <TPicture.h>
|
#include <TPicture.h>
|
||||||
|
|
||||||
|
#include <Bitmap.h>
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
|
||||||
@ -162,13 +164,15 @@ fill_shape(ViewLayer *view, BShape *shape)
|
|||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
draw_string(ViewLayer *view, char *string, float deltax, float deltay)
|
draw_string(ViewLayer *view, char *string, float deltaSpace, float deltaNonSpace)
|
||||||
{
|
{
|
||||||
//int32 len = string ? strlen(string) : 0;
|
BPoint location = view->CurrentState()->PenLocation();
|
||||||
|
escapement_delta delta = {deltaSpace, deltaNonSpace };
|
||||||
|
view->ConvertToScreenForDrawing(&location);
|
||||||
|
view->Window()->GetDrawingEngine()->DrawString(string, strlen(string), location,
|
||||||
|
view->CurrentState(), &delta);
|
||||||
|
// TODO: Update pen location ?
|
||||||
|
|
||||||
//view->DrawString(string, len, NULL);
|
|
||||||
|
|
||||||
printf("DrawString(\"%s\", %.2f, %.2f)\n", string, deltax, deltay);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -176,19 +180,18 @@ 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)
|
||||||
{
|
{
|
||||||
//ServerBitmap bitmap(BRect(0, 0, width - 1, height - 1),
|
/*BBitmap *bitmap = new (nothrow) BBitmap(BRect(0, 0, width - 1, height - 1),
|
||||||
// (color_space)pixelFormat);
|
flags | B_BITMAP_NO_SERVER_LINK, (color_space)pixelFormat);
|
||||||
|
|
||||||
//bitmap.SetBits(data, bytesPerRow * height, 0, (color_space)pixelFormat);
|
if (bitmap == NULL || bitmap->ImportBits(data, bytesPerRow * height,
|
||||||
|
bitmap->BytesPerRow(), 0, (color_space)pixelFormat) < B_OK)
|
||||||
|
return;
|
||||||
|
|
||||||
//view->DrawBitmap(&bitmap, src, dest);
|
view->ConvertToScreenForDrawing(&dest);
|
||||||
|
|
||||||
printf("DrawPixels(BRect(%.2f, %.2f, %.2f, %.2f),\n"
|
view->Window()->GetDrawingEngine()->DrawBitmap(bitmap, src, dest, view->CurrentState());
|
||||||
"BRect(%.2f, %.2f, %.2f, %.2f),\n"
|
|
||||||
"%ld, %ld, %ld, %ld, %ld)\n",
|
delete bitmap;*/
|
||||||
src.left, src.top, src.right, src.bottom,
|
|
||||||
dest.left, dest.top, dest.right, dest.bottom,
|
|
||||||
width, height, bytesPerRow, pixelFormat, flags);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2258,6 +2258,32 @@ ServerWindow::_DispatchPictureMessage(int32 code, BPrivate::LinkReceiver &link)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case AS_DRAW_STRING:
|
||||||
|
{
|
||||||
|
char* string;
|
||||||
|
int32 length;
|
||||||
|
BPoint location;
|
||||||
|
escapement_delta delta;
|
||||||
|
|
||||||
|
link.Read<int32>(&length);
|
||||||
|
link.Read<BPoint>(&location);
|
||||||
|
link.Read<escapement_delta>(&delta);
|
||||||
|
link.ReadString(&string);
|
||||||
|
|
||||||
|
picture->BeginOp(B_PIC_MOVE_PEN_BY);
|
||||||
|
picture->AddCoord(location - fCurrentLayer->CurrentState()->PenLocation());
|
||||||
|
picture->EndOp();
|
||||||
|
|
||||||
|
picture->BeginOp(B_PIC_DRAW_STRING);
|
||||||
|
picture->AddInt32(length);
|
||||||
|
picture->AddData(string, length);
|
||||||
|
picture->AddFloat(delta.space);
|
||||||
|
picture->AddFloat(delta.nonspace);
|
||||||
|
picture->EndOp();
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case AS_LAYER_DRAW_BITMAP:
|
case AS_LAYER_DRAW_BITMAP:
|
||||||
{
|
{
|
||||||
int32 token;
|
int32 token;
|
||||||
|
Loading…
Reference in New Issue
Block a user