No changes, just refactor wxMSW background brush methods.

Factor out MSWGetCustomBgBrush() from MSWGetBgBrushForChild(). This is useful
as in the vast majority of cases the parent window will want to use the same
background brush for all of its children so it doesn't really care about the
concrete child passed to MSWGetBgBrushForChild() and we can adjust the brush
to the child origin in the common code instead of asking each derived class
overriding MSWGetBgBrushForChild() to do this.

This doesn't change anything but will make the upcoming changes to wxPanel
background painting simpler.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@67250 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2011-03-20 00:00:29 +00:00
parent 0be027c45b
commit 0a81f13024
4 changed files with 38 additions and 27 deletions

View File

@@ -142,9 +142,6 @@ public:
return true; return true;
} }
// return the themed brush for painting our children
virtual WXHBRUSH MSWGetBgBrushForChild(WXHDC hDC, wxWindow *child);
// draw child background // draw child background
virtual bool MSWPrintChild(WXHDC hDC, wxWindow *win); virtual bool MSWPrintChild(WXHDC hDC, wxWindow *win);
@@ -174,6 +171,9 @@ protected:
void AdjustPageSize(wxNotebookPage *page); void AdjustPageSize(wxNotebookPage *page);
#if wxUSE_UXTHEME #if wxUSE_UXTHEME
// return the themed brush for painting our children
virtual WXHBRUSH MSWGetCustomBgBrush() { return m_hbrBackground; }
// gets the bitmap of notebook background and returns a brush from it // gets the bitmap of notebook background and returns a brush from it
WXHBRUSH QueryBgBitmap(); WXHBRUSH QueryBgBitmap();

View File

@@ -388,6 +388,18 @@ public:
virtual void MSWDestroyWindow(); virtual void MSWDestroyWindow();
// Functions dealing with painting the window background. The derived
// classes should normally only need to reimplement MSWGetBgBrush() if they
// need to use a non-solid brush for erasing their background. This
// function is called by MSWGetBgBrushForChild() which only exists for the
// weird wxToolBar case and MSWGetBgBrushForChild() itself is used by
// MSWGetBgBrush() to actually find the right brush to use.
// The brush returned from here must remain valid at least until the next
// event loop iteration. Returning 0, as is done by default, indicates
// there is no custom background brush.
virtual WXHBRUSH MSWGetCustomBgBrush() { return 0; }
// this function should return the brush to paint the children controls // this function should return the brush to paint the children controls
// background or 0 if this window doesn't impose any particular background // background or 0 if this window doesn't impose any particular background
// on its children // on its children

View File

@@ -1146,28 +1146,6 @@ void wxNotebook::UpdateBgBrush()
} }
} }
WXHBRUSH wxNotebook::MSWGetBgBrushForChild(WXHDC hDC, wxWindow *child)
{
if ( m_hbrBackground )
{
// before drawing with the background brush, we need to position it
// correctly
RECT rc;
::GetWindowRect(GetHwndOf(child), &rc);
::MapWindowPoints(NULL, GetHwnd(), (POINT *)&rc, 1);
if ( !::SetBrushOrgEx((HDC)hDC, -rc.left, -rc.top, NULL) )
{
wxLogLastError(wxT("SetBrushOrgEx(notebook bg brush)"));
}
return m_hbrBackground;
}
return wxNotebookBase::MSWGetBgBrushForChild(hDC, child);
}
bool wxNotebook::MSWPrintChild(WXHDC hDC, wxWindow *child) bool wxNotebook::MSWPrintChild(WXHDC hDC, wxWindow *child)
{ {
// solid background colour overrides themed background drawing // solid background colour overrides themed background drawing

View File

@@ -4884,9 +4884,30 @@ bool wxWindowMSW::DoEraseBackground(WXHDC hDC)
} }
WXHBRUSH WXHBRUSH
wxWindowMSW::MSWGetBgBrushForChild(WXHDC WXUNUSED(hDC), wxWindowMSW::MSWGetBgBrushForChild(WXHDC hDC, wxWindowMSW *child)
wxWindowMSW * WXUNUSED(child))
{ {
// Test for the custom background brush first.
WXHBRUSH hbrush = MSWGetCustomBgBrush();
if ( hbrush )
{
// We assume that this is either a stipple or hatched brush and not a
// solid one as otherwise it would have been enough to set the
// background colour and such brushes need to be positioned correctly
// in order to align when different windows are painted, so do it here.
RECT rc;
::GetWindowRect(GetHwndOf(child), &rc);
::MapWindowPoints(NULL, GetHwnd(), (POINT *)&rc, 1);
if ( !::SetBrushOrgEx((HDC)hDC, -rc.left, -rc.top, NULL) )
{
wxLogLastError(wxT("SetBrushOrgEx(bg brush)"));
}
return hbrush;
}
// Otherwise see if we have a custom background colour.
if ( m_hasBgCol ) if ( m_hasBgCol )
{ {
wxBrush * wxBrush *