X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/862d8041abe9e79695eefe1a564657b305a912e8..8b713759b615fc1530d1f476f37d6d213e7934a5:/src/generic/renderg.cpp diff --git a/src/generic/renderg.cpp b/src/generic/renderg.cpp index c8a103d195..817dd01986 100644 --- a/src/generic/renderg.cpp +++ b/src/generic/renderg.cpp @@ -1,5 +1,5 @@ /////////////////////////////////////////////////////////////////////////////// -// Name: generic/renderg.cpp +// Name: src/generic/renderg.cpp // Purpose: generic implementation of wxRendererNative (for any platform) // Author: Vadim Zeitlin // Modified by: @@ -24,18 +24,19 @@ #pragma hdrstop #endif +#include "wx/renderer.h" + #ifndef WX_PRECOMP #include "wx/string.h" + #include "wx/dc.h" + #include "wx/settings.h" #endif //WX_PRECOMP #include "wx/gdicmn.h" -#include "wx/dc.h" -#include "wx/settings.h" #include "wx/splitter.h" #include "wx/dcmirror.h" #include "wx/module.h" -#include "wx/renderer.h" // ---------------------------------------------------------------------------- // wxRendererGeneric: our wxRendererNative implementation @@ -78,11 +79,21 @@ public: const wxRect& rect, int flags = 0); - virtual void DrawCheckButton(wxWindow *win, - wxDC& dc, - const wxRect& rect, - int flags = 0); - + virtual void DrawCheckBox(wxWindow *win, + wxDC& dc, + const wxRect& rect, + int flags = 0); + + virtual void DrawPushButton(wxWindow *win, + wxDC& dc, + 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); virtual wxRendererVersion GetVersion() const @@ -220,9 +231,10 @@ wxRendererGeneric::DrawTreeItemButton(wxWindow * WXUNUSED(win), const wxRect& rect, int flags) { - // white background - dc.SetPen(*wxGREY_PEN); - dc.SetBrush(*wxWHITE_BRUSH); + // store settings + wxDCPenChanger penChanger(dc, *wxGREY_PEN); + wxDCBrushChanger brushChanger(dc, *wxWHITE_BRUSH); + dc.DrawRectangle(rect); // black lines @@ -360,21 +372,12 @@ void wxRendererGeneric::DrawComboBoxDropButton(wxWindow *win, wxDC& dc, const wxRect& rect, - int WXUNUSED(flags)) + int flags) { - // Creating a generic button background that would actually be - // useful is rather difficult to accomplish. Best compromise - // is to use window's background colour to achieve transparent' - // ish appearance that should look decent in combo box style - // controls. - wxColour col = win->GetBackgroundColour(); - dc.SetBrush(wxBrush(col)); - dc.SetPen(wxPen(col)); - dc.DrawRectangle(rect); - DrawDropArrow(win,dc,rect); + DrawPushButton(win,dc,rect,flags); + DrawDropArrow(win,dc,rect,flags); } - void wxRendererGeneric::DrawDropArrow(wxWindow *win, wxDC& dc, @@ -400,30 +403,68 @@ wxRendererGeneric::DrawDropArrow(wxWindow *win, dc.DrawPolygon(WXSIZEOF(pt), pt, rect.x, rect.y); } -void -wxRendererGeneric::DrawCheckButton(wxWindow *win, - wxDC& dc, - const wxRect& rect, - int flags) +void +wxRendererGeneric::DrawCheckBox(wxWindow *WXUNUSED(win), + wxDC& dc, + const wxRect& rect, + int flags) { - if (flags & wxCONTROL_DISABLED) - dc.SetPen( *wxGREY_PEN ); - else - dc.SetPen( *wxBLACK_PEN ); + dc.SetPen(*(flags & wxCONTROL_DISABLED ? wxGREY_PEN : wxBLACK_PEN)); dc.SetBrush( *wxTRANSPARENT_BRUSH ); - wxRect my_rect = rect; - dc.DrawRectangle( my_rect ); - if (flags & wxCONTROL_CHECKED) + dc.DrawRectangle(rect); + + if ( flags & wxCONTROL_CHECKED ) + { + dc.DrawCheckMark(rect.Deflate(2, 2)); + } +} + +void +wxRendererGeneric::DrawPushButton(wxWindow *win, + wxDC& dc, + const wxRect& rect, + int flags) +{ + // Don't try anything too fancy. It'll just turn out looking + // out-of-place on most platforms. + wxColour bgCol = flags & wxCONTROL_DISABLED ? + wxSystemSettings::GetColour(wxSYS_COLOUR_BTNFACE) : + win->GetBackgroundColour(); + dc.SetBrush(wxBrush(bgCol)); + dc.SetPen(wxPen(bgCol)); + dc.DrawRectangle(rect); +} + +void +wxRendererGeneric::DrawItemSelectionRect(wxWindow * WXUNUSED(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_BTNSHADOW)); + } + } + else // !selected { - my_rect.x += 2; - my_rect.y += 2; - my_rect.width -= 4; - my_rect.height -= 4; - dc.DrawLine( my_rect.x, my_rect.y, my_rect.x+my_rect.width, my_rect.y+my_rect.height ); - dc.DrawLine( my_rect.x+my_rect.width, my_rect.y, my_rect.x, my_rect.y+my_rect.height ); + brush = *wxTRANSPARENT_BRUSH; } + + dc.SetBrush(brush); + dc.SetPen(flags & wxCONTROL_CURRENT ? *wxBLACK_PEN : *wxTRANSPARENT_PEN); + + dc.DrawRectangle( rect ); } + // ---------------------------------------------------------------------------- // A module to allow cleanup of generic renderer. // ---------------------------------------------------------------------------- @@ -438,4 +479,3 @@ public: }; IMPLEMENT_DYNAMIC_CLASS(wxGenericRendererModule, wxModule) -