#define min(a,b) (((a) < (b)) ? (a) : (b))
#endif
+#include "wx/dcgraph.h"
#include "gdiplus.h"
using namespace Gdiplus;
-#endif
+#endif // wxUSE_GRAPHICS_CONTEXT
// tmschema.h is in Win32 Platform SDK and might not be available with earlier
// compilers
}
else
#endif
- m_hdc = GetHdcOf(*dc);
+ m_hdc = GetHdcOf(*((wxMSWDCImpl*)dc->GetImpl()));
}
~GraphicsHDC()
m_graphics->ReleaseHDC(m_hdc);
#endif
}
-
+
operator HDC() const { return m_hdc; }
private:
#define DFCS_HOT 0x1000
#endif
+// ----------------------------------------------------------------------------
+// methods common to wxRendererMSW and wxRendererXP
+// ----------------------------------------------------------------------------
+
+class wxRendererMSWBase : public wxDelegateRendererNative
+{
+public:
+ wxRendererMSWBase() { }
+ wxRendererMSWBase(wxRendererNative& rendererNative)
+ : wxDelegateRendererNative(rendererNative) { }
+
+ void DrawFocusRect(wxWindow * win,
+ wxDC& dc,
+ const wxRect& rect,
+ int flags = 0);
+
+ void DrawItemSelectionRect(wxWindow *win,
+ wxDC& dc,
+ const wxRect& rect,
+ int flags = 0);
+};
+
// ----------------------------------------------------------------------------
// wxRendererMSW: wxRendererNative implementation for "old" Win32 systems
// ----------------------------------------------------------------------------
-class WXDLLEXPORT wxRendererMSW : public wxDelegateRendererNative
+class wxRendererMSW : public wxRendererMSWBase
{
public:
wxRendererMSW() { }
const wxRect& rect,
int flags = 0);
- virtual void DrawFocusRect(wxWindow* win,
- wxDC& dc,
- const wxRect& rect,
- int flags = 0);
-
- virtual void DrawChoice(wxWindow* win,
- wxDC& dc,
- const wxRect& rect,
+ virtual void DrawChoice(wxWindow* win,
+ wxDC& dc,
+ const wxRect& rect,
int flags=0);
- virtual void DrawComboBox(wxWindow* win,
- wxDC& dc,
- const wxRect& rect,
+ virtual void DrawComboBox(wxWindow* win,
+ wxDC& dc,
+ const wxRect& rect,
int flags=0);
- virtual void DrawTextCtrl(wxWindow* win,
- wxDC& dc,
- const wxRect& rect,
+ virtual void DrawTextCtrl(wxWindow* win,
+ wxDC& dc,
+ const wxRect& rect,
int flags=0);
- virtual void DrawRadioButton(wxWindow* win,
- wxDC& dc,
- const wxRect& rect,
+ virtual void DrawRadioButton(wxWindow* win,
+ wxDC& dc,
+ const wxRect& rect,
int flags=0);
virtual wxSize GetCheckBoxSize(wxWindow *win);
virtual int GetHeaderButtonHeight(wxWindow *win);
private:
- DECLARE_NO_COPY_CLASS(wxRendererMSW)
+ wxDECLARE_NO_COPY_CLASS(wxRendererMSW);
};
// ----------------------------------------------------------------------------
#if wxUSE_UXTHEME
-class WXDLLEXPORT wxRendererXP : public wxDelegateRendererNative
+class wxRendererXP : public wxRendererMSWBase
{
public:
- wxRendererXP() : wxDelegateRendererNative(wxRendererMSW::Get()) { }
+ wxRendererXP() : wxRendererMSWBase(wxRendererMSW::Get()) { }
static wxRendererNative& Get();
const wxRect& rect,
int flags = 0);
- virtual void DrawItemSelectionRect(wxWindow *win,
- wxDC& dc,
- const wxRect& rect,
- int flags = 0 );
-
-
virtual wxSplitterRenderParams GetSplitterParams(const wxWindow *win);
private:
- DECLARE_NO_COPY_CLASS(wxRendererXP)
+ wxDECLARE_NO_COPY_CLASS(wxRendererXP);
};
#endif // wxUSE_UXTHEME
+
+// ============================================================================
+// wxRendererMSWBase implementation
+// ============================================================================
+
+void wxRendererMSWBase::DrawFocusRect(wxWindow * WXUNUSED(win),
+ wxDC& dc,
+ const wxRect& rect,
+ int WXUNUSED(flags))
+{
+ RECT rc;
+ wxCopyRectToRECT(rect, rc);
+
+ ::DrawFocusRect(GraphicsHDC(&dc), &rc);
+}
+
+void wxRendererMSWBase::DrawItemSelectionRect(wxWindow *win,
+ wxDC& dc,
+ const wxRect& rect,
+ int flags)
+{
+ wxBrush brush;
+ if ( flags & wxCONTROL_SELECTED )
+ {
+ if ( flags & wxCONTROL_FOCUSED )
+ {
+ brush = wxBrush(wxSystemSettings::GetColour(wxSYS_COLOUR_HIGHLIGHT));
+ }
+ else // !focused
+ {
+ brush = wxBrush(wxSystemSettings::GetColour(wxSYS_COLOUR_BTNFACE));
+ }
+ }
+ else // !selected
+ {
+ brush = *wxTRANSPARENT_BRUSH;
+ }
+
+ dc.SetBrush(brush);
+ dc.SetPen(*wxTRANSPARENT_PEN);
+ dc.DrawRectangle( rect );
+
+ if ((flags & wxCONTROL_FOCUSED) && (flags & wxCONTROL_CURRENT))
+ DrawFocusRect( win, dc, rect, flags );
+}
+
+
// ============================================================================
// wxRendererNative and wxRendererMSW implementation
// ============================================================================
if ( flags & wxCONTROL_PRESSED )
style |= DFCS_PUSHED | DFCS_FLAT;
- ::DrawFrameControl(GraphicsHDC((wxMSWDCImpl*)dc.GetImpl()).HDC(), &r, DFC_SCROLL, style);
+ ::DrawFrameControl(GraphicsHDC(&dc), &r, DFC_SCROLL, style);
}
void
if ( flags & wxCONTROL_CURRENT )
style |= DFCS_HOT;
- ::DrawFrameControl(GraphicsHDC((wxMSWDCImpl*)dc.GetImpl()).HDC(), &r, DFC_BUTTON, style);
+ ::DrawFrameControl(GraphicsHDC(&dc), &r, DFC_BUTTON, style);
}
void
RECT rc;
wxCopyRectToRECT(rect, rc);
- ::DrawFrameControl(GraphicsHDC((wxMSWDCImpl*)dc.GetImpl()).HDC(), &rc, DFC_BUTTON, style);
-}
-
-void wxRendererMSW::DrawFocusRect(wxWindow * WXUNUSED(win),
- wxDC& dc,
- const wxRect& rect,
- int WXUNUSED(flags))
-{
- RECT rc;
- wxCopyRectToRECT(rect, rc);
-
- ::DrawFocusRect(GraphicsHDC((wxMSWDCImpl*)dc.GetImpl()).HDC(), &rc);
+ ::DrawFrameControl(GraphicsHDC(&dc), &rc, DFC_BUTTON, style);
}
wxSize wxRendererMSW::GetCheckBoxSize(wxWindow * WXUNUSED(win))
wxColour fill;
wxColour bdr;
COLORREF cref;
-
+
#if wxUSE_UXTHEME
wxUxThemeHandle hTheme(win, L"EDIT");
if (hTheme)
etsState = ETS_DISABLED;
else
etsState = ETS_NORMAL;
-
+
wxUxThemeEngine::Get()->GetThemeColor(hTheme, EP_EDITTEXT,
etsState, TMT_BORDERCOLOR, &cref);
- bdr = wxRGBToColour(cref);
+ bdr = wxRGBToColour(cref);
}
else
#endif
fill = wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW);
bdr = *wxBLACK;
}
-
+
dc.SetPen( bdr );
dc.SetBrush( fill );
dc.DrawRectangle(rect);
void wxRendererMSW::DrawComboBox(wxWindow* win, wxDC& dc, const wxRect& rect, int flags)
{
// Draw the main part of the control same as TextCtrl
- DrawTextCtrl(win, dc, rect, flags);
-
+ DrawTextCtrl(win, dc, rect, flags);
+
// Draw the button inside the border, on the right side
wxRect br(rect);
br.height -= 2;
DrawComboBox(win, dc, rect, flags);
}
-
+
// Draw a themed radio button
void wxRendererMSW::DrawRadioButton(wxWindow* win, wxDC& dc, const wxRect& rect, int flags)
{
wxUxThemeEngine::Get()->DrawThemeBackground
(
hTheme,
- GraphicsHDC(&dc).HDC(),
+ GraphicsHDC(&dc),
BP_RADIOBUTTON,
state,
&r,
);
}
-void
-wxRendererXP::DrawItemSelectionRect(wxWindow *win,
- wxDC& dc,
- const wxRect& rect,
- int flags)
-{
- wxBrush brush;
- if ( flags & wxCONTROL_SELECTED )
- {
- if ( flags & wxCONTROL_FOCUSED )
- {
- brush = wxBrush(wxSystemSettings::GetColour(wxSYS_COLOUR_HIGHLIGHT));
- }
- else // !focused
- {
- brush = wxBrush(wxSystemSettings::GetColour(wxSYS_COLOUR_BTNFACE));
- }
- }
- else // !selected
- {
- brush = *wxTRANSPARENT_BRUSH;
- }
-
- dc.SetBrush(brush);
- dc.SetPen(*wxTRANSPARENT_PEN);
- dc.DrawRectangle( rect );
-
- if ((flags & wxCONTROL_FOCUSED) && (flags & wxCONTROL_CURRENT))
- DrawFocusRect( win, dc, rect, flags );
-}
-
-
// ----------------------------------------------------------------------------
// splitter drawing