* disable caching of the clipping region,
there can be no notification when it changes in the server. Note that GetClippingRegion() gets the actually effective clipping, not only the user defined clipping. * when removing ourself, set the last mouse moved view of the parent window to NULL in case it was pointing to this view * round the frame rectangle passed to the constructor, I have not actually compared this with R5 behaviour though. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@14844 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
b2cc1487d1
commit
d28b9f6540
@ -2154,14 +2154,11 @@ BView::GetClippingRegion(BRegion* region) const
|
|||||||
if (!region)
|
if (!region)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// TODO: I think this implementation is wrong,
|
// TODO: For now, the clipping bit is ignored, since the client has no
|
||||||
// since on R5, you really get the currently active
|
// idea when the clipping in the server changed. -Stephan
|
||||||
// clipping region, overlapping windows and all.
|
|
||||||
// I don't think we inform the client in the app_server
|
|
||||||
// when the clipping changes, so that B_VIEW_CLIP_REGION_BIT
|
|
||||||
// is set. -Stephan
|
|
||||||
|
|
||||||
if (!fState->IsValid(B_VIEW_CLIP_REGION_BIT) && do_owner_check()) {
|
// if (!fState->IsValid(B_VIEW_CLIP_REGION_BIT) && fOwner && do_owner_check()) {
|
||||||
|
if (fOwner && do_owner_check()) {
|
||||||
fOwner->fLink->StartMessage(AS_LAYER_GET_CLIP_REGION);
|
fOwner->fLink->StartMessage(AS_LAYER_GET_CLIP_REGION);
|
||||||
|
|
||||||
int32 code;
|
int32 code;
|
||||||
@ -2180,6 +2177,8 @@ BView::GetClippingRegion(BRegion* region) const
|
|||||||
}
|
}
|
||||||
fState->valid_flags |= B_VIEW_CLIP_REGION_BIT;
|
fState->valid_flags |= B_VIEW_CLIP_REGION_BIT;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
fState->clipping_region.MakeEmpty();
|
||||||
}
|
}
|
||||||
|
|
||||||
*region = fState->clipping_region;
|
*region = fState->clipping_region;
|
||||||
@ -3387,6 +3386,9 @@ BView::RemoveSelf()
|
|||||||
if (fOwner->fKeyMenuBar == this)
|
if (fOwner->fKeyMenuBar == this)
|
||||||
fOwner->fKeyMenuBar = NULL;
|
fOwner->fKeyMenuBar = NULL;
|
||||||
|
|
||||||
|
if (fOwner->fLastMouseMovedView == this)
|
||||||
|
fOwner->fLastMouseMovedView = NULL;
|
||||||
|
|
||||||
if (fOwner->fLastViewToken == _get_object_token_(this))
|
if (fOwner->fLastViewToken == _get_object_token_(this))
|
||||||
fOwner->fLastViewToken = B_NULL_TOKEN;
|
fOwner->fLastViewToken = B_NULL_TOKEN;
|
||||||
|
|
||||||
@ -3745,6 +3747,12 @@ BView::InitData(BRect frame, const char *name, uint32 resizingMode, uint32 flags
|
|||||||
// initialize members
|
// initialize members
|
||||||
fFlags = (resizingMode & _RESIZE_MASK_) | (flags & ~_RESIZE_MASK_);
|
fFlags = (resizingMode & _RESIZE_MASK_) | (flags & ~_RESIZE_MASK_);
|
||||||
|
|
||||||
|
// handle rounding
|
||||||
|
frame.left = roundf(frame.left);
|
||||||
|
frame.top = roundf(frame.top);
|
||||||
|
frame.right = roundf(frame.right);
|
||||||
|
frame.bottom = roundf(frame.bottom);
|
||||||
|
|
||||||
fParentOffset.Set(frame.left, frame.top);
|
fParentOffset.Set(frame.left, frame.top);
|
||||||
|
|
||||||
fOwner = NULL;
|
fOwner = NULL;
|
||||||
|
Loading…
Reference in New Issue
Block a user