fixed some bugs and workarrounds

added support for resolution change - in fact, fixed it


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@7159 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Adi Oanca 2004-04-04 20:24:59 +00:00
parent ac903216d7
commit cf00cb08ee
2 changed files with 37 additions and 19 deletions

View File

@ -73,6 +73,7 @@ VDWIN_SETCURSOR,
extern RGBColor workspace_default_color; extern RGBColor workspace_default_color;
bool is_initialized = false; bool is_initialized = false;
BPoint offset(100,50);
VDView::VDView(BRect bounds) VDView::VDView(BRect bounds)
: BView(bounds,"viewdriver_view",B_FOLLOW_ALL, B_WILL_DRAW) : BView(bounds,"viewdriver_view",B_FOLLOW_ALL, B_WILL_DRAW)
@ -242,8 +243,8 @@ void VDView::MessageReceived(BMessage *msg)
} }
} }
VDWindow::VDWindow(void) VDWindow::VDWindow(BRect frame)
: BWindow(BRect(100,60,740,540),"OpenBeOS App Server",B_TITLED_WINDOW, : BWindow(frame, "OpenBeOS App Server", B_TITLED_WINDOW,
B_NOT_ZOOMABLE | B_NOT_RESIZABLE) B_NOT_ZOOMABLE | B_NOT_RESIZABLE)
{ {
view=new VDView(Bounds()); view=new VDView(Bounds());
@ -461,23 +462,18 @@ void VDWindow::WindowActivated(bool active)
ViewDriver::ViewDriver(void) ViewDriver::ViewDriver(void)
{ {
screenwin=new VDWindow();
framebuffer=screenwin->view->viewbmp;
serverlink=screenwin->view->serverlink;
hide_cursor=0;
_displaymode.virtual_width=640; _displaymode.virtual_width=640;
_displaymode.virtual_height=480; _displaymode.virtual_height=480;
_displaymode.space=B_RGBA32; _displaymode.space=B_RGBA32;
// We add this because if we see the default workspace color, then we have at least screenwin=new VDWindow(BRect(0,0,_displaymode.virtual_width-1,_displaymode.virtual_height-1).OffsetToCopy(offset));
// a reasonable idea that everything is kosher. framebuffer=screenwin->view->viewbmp;
serverlink=screenwin->view->serverlink;
hide_cursor=0;
framebuffer->Lock(); framebuffer->Lock();
drawview=new BView(framebuffer->Bounds(),"drawview",B_FOLLOW_ALL, B_WILL_DRAW); drawview=new BView(framebuffer->Bounds(),"drawview",B_FOLLOW_ALL, B_WILL_DRAW);
framebuffer->AddChild(drawview); framebuffer->AddChild(drawview);
drawview->SetHighColor(workspace_default_color.GetColor32());
drawview->FillRect(drawview->Bounds());
drawview->Sync();
framebuffer->Unlock(); framebuffer->Unlock();
} }
@ -494,8 +490,14 @@ ViewDriver::~ViewDriver(void)
bool ViewDriver::Initialize(void) bool ViewDriver::Initialize(void)
{ {
Lock(); Lock();
drawview=new BView(framebuffer->Bounds(),"drawview",B_FOLLOW_ALL, B_WILL_DRAW);
framebuffer->AddChild(drawview); // the screen should start black
framebuffer->Lock();
rgb_color c; c.red = 0; c.blue = 0; c.green = 0; c.alpha = 255;
drawview->SetHighColor(c);
drawview->FillRect(drawview->Bounds());
drawview->Sync();
framebuffer->Unlock();
hide_cursor=0; hide_cursor=0;
obscure_cursor=false; obscure_cursor=false;
@ -521,13 +523,24 @@ void ViewDriver::SetMode(const display_mode &mode)
if(!is_initialized) if(!is_initialized)
return; return;
if (_displaymode.virtual_width==mode.virtual_width &&
_displaymode.virtual_height==mode.virtual_height &&
_displaymode.space==mode.space)
{
return;
}
screenwin->Lock(); screenwin->Lock();
BBitmap *tempbmp=new BBitmap(BRect(0,0,mode.virtual_width-1, mode.virtual_height-1), BBitmap *tempbmp=new BBitmap(BRect(0,0,mode.virtual_width-1, mode.virtual_height-1),
(color_space)mode.space,true); (color_space)mode.space,true);
if(!tempbmp) if(!tempbmp)
{
screenwin->Unlock();
delete tempbmp;
return; return;
}
if(!tempbmp->IsValid()) if(!tempbmp->IsValid())
{ {
@ -538,13 +551,18 @@ void ViewDriver::SetMode(const display_mode &mode)
delete framebuffer; delete framebuffer;
screenwin->ResizeTo(mode.virtual_width-1, mode.virtual_height-1);
screenwin->view->viewbmp=tempbmp; screenwin->view->viewbmp=tempbmp;
framebuffer=screenwin->view->viewbmp; framebuffer=screenwin->view->viewbmp;
drawview=new BView(framebuffer->Bounds(),"drawview",B_FOLLOW_ALL, B_WILL_DRAW); drawview=new BView(framebuffer->Bounds(),"drawview",B_FOLLOW_ALL, B_WILL_DRAW);
framebuffer->AddChild(drawview); framebuffer->AddChild(drawview);
// the screen should start black
framebuffer->Lock(); framebuffer->Lock();
drawview->SetHighColor(workspace_default_color.GetColor32()); rgb_color c; c.red = 0; c.blue = 0; c.green = 0; c.alpha = 255;
drawview->SetHighColor(c);//workspace_default_color.GetColor32());
drawview->FillRect(drawview->Bounds()); drawview->FillRect(drawview->Bounds());
drawview->Sync(); drawview->Sync();
framebuffer->Unlock(); framebuffer->Unlock();

View File

@ -69,7 +69,7 @@ public:
class VDWindow : public BWindow class VDWindow : public BWindow
{ {
public: public:
VDWindow(void); VDWindow(BRect frame);
~VDWindow(void); ~VDWindow(void);
void MessageReceived(BMessage *msg); void MessageReceived(BMessage *msg);
bool QuitRequested(void); bool QuitRequested(void);