+ return m_rendererNative.GetHeaderButtonHeight(win);
+ }
+
+ HRESULT hr;
+ int value = -1;
+
+ hr = wxUxThemeEngine::Get()->GetThemeMetric( hTheme,
+ NULL,
+ HP_HEADERITEM,
+ HIS_NORMAL,
+ TMT_HEIGHT,
+ &value );
+ if ( hr == S_OK )
+ return value;
+ else
+ return 20;
+}
+
+
+void
+wxRendererXP::DrawTreeItemButton(wxWindow *win,
+ wxDC& dc,
+ const wxRect& rect,
+ int flags)
+{
+ wxUxThemeHandle hTheme(win, L"TREEVIEW");
+ if ( !hTheme )
+ {
+ m_rendererNative.DrawTreeItemButton(win, dc, rect, flags);
+ return;
+ }
+
+ RECT r;
+ wxCopyRectToRECT(rect, r);
+
+ int state = flags & wxCONTROL_EXPANDED ? GLPS_OPENED : GLPS_CLOSED;
+ wxUxThemeEngine::Get()->DrawThemeBackground
+ (
+ hTheme,
+ GetHdcOf(dc),
+ TVP_GLYPH,
+ state,
+ &r,
+ NULL
+ );
+}
+
+void
+wxRendererXP::DrawCheckBox(wxWindow *win,
+ wxDC& dc,
+ const wxRect& rect,
+ int flags)
+{
+ wxUxThemeHandle hTheme(win, L"BUTTON");
+ if ( !hTheme )
+ {
+ m_rendererNative.DrawCheckBox(win, dc, rect, flags);
+ return;
+ }
+
+ RECT r;
+ wxCopyRectToRECT(rect, r);
+
+ int state;
+ if ( flags & wxCONTROL_CHECKED )
+ state = CBS_CHECKEDNORMAL;
+ else if ( flags & wxCONTROL_UNDETERMINED )
+ state = CBS_MIXEDNORMAL;
+ else
+ state = CBS_UNCHECKEDNORMAL;
+
+ // CBS_XXX is followed by CBX_XXXHOT, then CBS_XXXPRESSED and DISABLED
+ enum
+ {
+ CBS_HOT_OFFSET = 1,
+ CBS_PRESSED_OFFSET = 2,
+ CBS_DISABLED_OFFSET = 3
+ };
+
+ if ( flags & wxCONTROL_DISABLED )
+ state += CBS_DISABLED_OFFSET;
+ else if ( flags & wxCONTROL_PRESSED )
+ state += CBS_PRESSED_OFFSET;
+ else if ( flags & wxCONTROL_CURRENT )
+ state += CBS_HOT_OFFSET;
+
+ wxUxThemeEngine::Get()->DrawThemeBackground
+ (
+ hTheme,
+ GetHdcOf(dc),
+ BP_CHECKBOX,
+ state,
+ &r,
+ NULL
+ );
+}
+
+void
+wxRendererXP::DrawPushButton(wxWindow * win,
+ wxDC& dc,
+ const wxRect& rect,
+ int flags)
+{
+ wxUxThemeHandle hTheme(win, L"BUTTON");
+ if ( !hTheme )
+ {
+ m_rendererNative.DrawPushButton(win, dc, rect, flags);
+ return;
+ }
+
+ RECT r;
+ wxCopyRectToRECT(rect, r);