#if wxUSE_CONTROLS
+#include "wx/control.h"
+
#ifndef WX_PRECOMP
+ #include "wx/msw/wrapcctl.h" // include <commctrl.h> "properly"
#include "wx/event.h"
#include "wx/app.h"
#include "wx/dcclient.h"
#include "wx/settings.h"
#endif
-#include "wx/control.h"
-
#if wxUSE_LISTCTRL
#include "wx/listctrl.h"
#endif // wxUSE_LISTCTRL
#include "wx/msw/private.h"
#include "wx/msw/uxtheme.h"
-// include <commctrl.h> "properly"
-#include "wx/msw/wrapcctl.h"
-
// ----------------------------------------------------------------------------
// wxWin macros
// ----------------------------------------------------------------------------
InheritAttributes();
if ( !m_hasFont )
{
-#if wxUSE_LISTCTRL || wxUSE_TREECTRL
+ bool setFont = true;
+
+ wxFont font = GetDefaultAttributes().font;
+
// if we set a font for {list,tree}ctrls and the font size is changed in
// the display properties then the font size for these controls doesn't
// automatically adjust when they receive WM_SETTINGCHANGE
- if ( wxDynamicCastThis(wxListCtrl) || wxDynamicCastThis(wxTreeCtrl) )
+
+ // FIXME: replace the dynamic casts with virtual function calls!!
+#if wxUSE_LISTCTRL || wxUSE_TREECTRL
+ bool testFont = false;
+#if wxUSE_LISTCTRL
+ if ( wxDynamicCastThis(wxListCtrl) )
+ testFont = true;
+#endif // wxUSE_LISTCTRL
+#if wxUSE_TREECTRL
+ if ( wxDynamicCastThis(wxTreeCtrl) )
+ testFont = true;
+#endif // wxUSE_TREECTRL
+
+ if ( testFont )
{
// not sure if we need to explicitly set the font here for Win95/NT4
// but we definitely can't do it for any newer version
// TODO: test Win95/NT4 to see if this is needed or breaks the
// font resizing as it does on newer versions
- wxFont font = GetDefaultAttributes().font;
- if ( font == wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT) )
+ if ( font != wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT) )
{
- SetFont(font);
+ setFont = false;
}
}
- else
#endif // wxUSE_LISTCTRL || wxUSE_TREECTRL
+
+ if ( setFont )
{
SetFont(GetDefaultAttributes().font);
}
}
// set the size now if no initial size specified
- SetInitialBestSize(size);
+ SetInitialSize(size);
return true;
}
hbr = (WXHBRUSH)brush->GetResourceHandle();
- // if we use custom background, we should set foreground ourselves too
- if ( !m_hasFgCol )
- {
- ::SetTextColor(hdc, ::GetSysColor(COLOR_WINDOWTEXT));
- }
- //else: already set above
}
+ // if we use custom background, we should set foreground ourselves too
+ if ( hbr && !m_hasFgCol )
+ {
+ ::SetTextColor(hdc, ::GetSysColor(COLOR_WINDOWTEXT));
+ }
+ //else: already set above
+
return hbr;
}