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:
parent
ac903216d7
commit
cf00cb08ee
@ -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();
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user