X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/fe404d1afc2ce592e4e6d38af5e1b435b8664a6d..63a3cd7a8c737eb4571f27e5f2af37eda0f1c5cc:/src/msw/renderer.cpp?ds=sidebyside diff --git a/src/msw/renderer.cpp b/src/msw/renderer.cpp index 77f27813ea..98293ee53d 100644 --- a/src/msw/renderer.cpp +++ b/src/msw/renderer.cpp @@ -32,6 +32,7 @@ #include "wx/splitter.h" #include "wx/renderer.h" +#include "wx/settings.h" #include "wx/msw/uxtheme.h" #include "wx/msw/private.h" @@ -44,6 +45,17 @@ #define CBXS_HOT 2 #define CBXS_PRESSED 3 #define CBXS_DISABLED 4 + + #define TVP_GLYPH 2 + + #define GLPS_CLOSED 1 + #define GLPS_OPENED 2 + + #define HP_HEADERITEM 1 + + #define HIS_NORMAL 1 + #define HIS_HOT 2 + #define HIS_PRESSED 3 #endif // ---------------------------------------------------------------------------- @@ -96,6 +108,14 @@ public: wxDC& dc, const wxRect& rect, int flags = 0); + virtual void DrawTreeItemButton(wxWindow *win, + wxDC& dc, + const wxRect& rect, + int flags = 0); + virtual void DrawHeaderButton(wxWindow *win, + wxDC& dc, + const wxRect &rect, + int flags=0); private: DECLARE_NO_COPY_CLASS(wxRendererXP) }; @@ -261,5 +281,59 @@ wxRendererXP::DrawSplitterSash(wxWindow *win, m_rendererNative.DrawSplitterSash(win, dc, size, position, orient, flags); } +void +wxRendererXP::DrawTreeItemButton(wxWindow *win, + wxDC &dc, + const wxRect &rect, + int flags) +{ + wxUxThemeHandle hTheme(win, L"TREEVIEW"); + RECT r; + r.left = rect.x; + r.top = rect.y; + r.right = rect.x + rect.width; + r.bottom = rect.y + rect.height; + int state = (flags & wxCONTROL_EXPANDED) ? GLPS_OPENED : GLPS_CLOSED; + wxUxThemeEngine::Get()->DrawThemeBackground + ( + hTheme, + (HDC) dc.GetHDC(), + TVP_GLYPH, + state, + &r, + NULL + ); +} + +void +wxRendererXP::DrawHeaderButton(wxWindow *win, + wxDC &dc, + const wxRect &rect, + int flags) +{ + wxUxThemeHandle hTheme(win, L"HEADER"); + RECT r; + r.left = rect.x; + r.top = rect.y; + r.right = rect.x + rect.width; + r.bottom = rect.y + rect.height; + int state; + if ( flags & wxCONTROL_PRESSED ) + state = HIS_PRESSED; + else if ( flags & wxCONTROL_CURRENT ) + state = HIS_HOT; + else + state = HIS_NORMAL; + wxUxThemeEngine::Get()->DrawThemeBackground + ( + hTheme, + (HDC) dc.GetHDC(), + HP_HEADERITEM, + state, + &r, + NULL + ); +} + #endif // wxUSE_UXTHEME