* make sure that fTopLayer is NULL when the top layer is deleted
* make sure layers are removed from the token space when the WindowLayer is deleted git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@15852 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
fb82d189d0
commit
1e1b86ef54
@ -84,6 +84,9 @@ ViewLayer::~ViewLayer()
|
|||||||
|
|
||||||
delete fDrawState;
|
delete fDrawState;
|
||||||
|
|
||||||
|
if (fWindow && this == fWindow->TopLayer())
|
||||||
|
fWindow->SetTopLayer(NULL);
|
||||||
|
|
||||||
// TODO: Don't know yet if we should also delete fPicture
|
// TODO: Don't know yet if we should also delete fPicture
|
||||||
|
|
||||||
// iterate over children and delete each one
|
// iterate over children and delete each one
|
||||||
|
@ -159,6 +159,9 @@ WindowLayer::WindowLayer(const BRect& frame, const char *name,
|
|||||||
|
|
||||||
WindowLayer::~WindowLayer()
|
WindowLayer::~WindowLayer()
|
||||||
{
|
{
|
||||||
|
if (fTopLayer)
|
||||||
|
fTopLayer->DetachedFromWindow();
|
||||||
|
|
||||||
delete fTopLayer;
|
delete fTopLayer;
|
||||||
delete fDecorator;
|
delete fDecorator;
|
||||||
}
|
}
|
||||||
@ -501,23 +504,25 @@ WindowLayer::CopyContents(BRegion* region, int32 xOffset, int32 yOffset)
|
|||||||
void
|
void
|
||||||
WindowLayer::SetTopLayer(ViewLayer* topLayer)
|
WindowLayer::SetTopLayer(ViewLayer* topLayer)
|
||||||
{
|
{
|
||||||
// the top layer is special, it has a coordinate system
|
|
||||||
// as if it was attached directly to the desktop, therefor,
|
|
||||||
// the coordinate conversion through the layer tree works
|
|
||||||
// as expected, since the top layer has no "parent" but has
|
|
||||||
// fFrame as if it had
|
|
||||||
|
|
||||||
fTopLayer = topLayer;
|
fTopLayer = topLayer;
|
||||||
|
|
||||||
// make sure the location of the top layer on screen matches ours
|
if (fTopLayer) {
|
||||||
fTopLayer->MoveBy(fFrame.left - fTopLayer->Frame().left,
|
// the top layer is special, it has a coordinate system
|
||||||
fFrame.top - fTopLayer->Frame().top, NULL);
|
// as if it was attached directly to the desktop, therefor,
|
||||||
|
// the coordinate conversion through the layer tree works
|
||||||
// make sure the size of the top layer matches ours
|
// as expected, since the top layer has no "parent" but has
|
||||||
fTopLayer->ResizeBy(fFrame.Width() - fTopLayer->Frame().Width(),
|
// fFrame as if it had
|
||||||
fFrame.Height() - fTopLayer->Frame().Height(), NULL);
|
|
||||||
|
// make sure the location of the top layer on screen matches ours
|
||||||
fTopLayer->AttachedToWindow(this);
|
fTopLayer->MoveBy(fFrame.left - fTopLayer->Frame().left,
|
||||||
|
fFrame.top - fTopLayer->Frame().top, NULL);
|
||||||
|
|
||||||
|
// make sure the size of the top layer matches ours
|
||||||
|
fTopLayer->ResizeBy(fFrame.Width() - fTopLayer->Frame().Width(),
|
||||||
|
fFrame.Height() - fTopLayer->Frame().Height(), NULL);
|
||||||
|
|
||||||
|
fTopLayer->AttachedToWindow(this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1329,7 +1334,7 @@ WindowLayer::Backmost(WindowLayer* window, int32 workspace)
|
|||||||
/*!
|
/*!
|
||||||
\brief Returns the windows that's in front of the frontmost position
|
\brief Returns the windows that's in front of the frontmost position
|
||||||
this window can get.
|
this window can get.
|
||||||
Returns NULL is this window can be the frontmost window.
|
Returns NULL if this window can be the frontmost window.
|
||||||
*/
|
*/
|
||||||
WindowLayer*
|
WindowLayer*
|
||||||
WindowLayer::Frontmost(WindowLayer* first, int32 workspace)
|
WindowLayer::Frontmost(WindowLayer* first, int32 workspace)
|
||||||
|
Loading…
Reference in New Issue
Block a user