X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4b94ddc44ced056bb862938d069d9148c4c782b1..a58e5dad46a1a80bdb630d9c94a53696c6c59a19:/src/generic/renderg.cpp diff --git a/src/generic/renderg.cpp b/src/generic/renderg.cpp index 6f84f6b904..2991a11d95 100644 --- a/src/generic/renderg.cpp +++ b/src/generic/renderg.cpp @@ -46,16 +46,18 @@ class WXDLLEXPORT wxRendererGeneric : public wxRendererNative public: wxRendererGeneric(); - virtual void DrawHeaderButton(wxWindow *win, + virtual int DrawHeaderButton(wxWindow *win, wxDC& dc, const wxRect& rect, int flags = 0, + wxHeaderSortIconType sortArrow = wxHDR_SORT_ICON_NONE, wxHeaderButtonParams* params = NULL); - virtual void DrawHeaderButtonContents(wxWindow *win, + virtual int DrawHeaderButtonContents(wxWindow *win, wxDC& dc, const wxRect& rect, int flags = 0, + wxHeaderSortIconType sortArrow = wxHDR_SORT_ICON_NONE, wxHeaderButtonParams* params = NULL); virtual int GetHeaderButtonHeight(wxWindow *win); @@ -202,11 +204,12 @@ wxRendererGeneric::DrawShadedRect(wxDC& dc, // tree/list ctrl drawing // ---------------------------------------------------------------------------- -void +int wxRendererGeneric::DrawHeaderButton(wxWindow* win, wxDC& dc, const wxRect& rect, int flags, + wxHeaderSortIconType sortArrow, wxHeaderButtonParams* params) { const int CORNER = 1; @@ -236,16 +239,20 @@ wxRendererGeneric::DrawHeaderButton(wxWindow* win, dc.DrawLine( x, y+h-1, x+1, y+h-1 ); dc.DrawLine( x+w-1, y, x+w-1, y+1 ); - DrawHeaderButtonContents(win, dc, rect, flags, params); + return DrawHeaderButtonContents(win, dc, rect, flags, sortArrow, params); } -void + +int wxRendererGeneric::DrawHeaderButtonContents(wxWindow *win, wxDC& dc, const wxRect& rect, int flags, + wxHeaderSortIconType sortArrow, wxHeaderButtonParams* params) { + int labelWidth = 0; + // Mark this item as selected. For the generic version we'll just draw an // underline if ( flags & wxCONTROL_SELECTED ) @@ -264,7 +271,7 @@ wxRendererGeneric::DrawHeaderButtonContents(wxWindow *win, // Draw an up or down arrow int arrowSpace = 0; - if (flags & (wxCONTROL_UPICON | wxCONTROL_DOWNICON) ) + if (sortArrow != wxHDR_SORT_ICON_NONE ) { wxRect ar = rect; @@ -276,7 +283,7 @@ wxRendererGeneric::DrawHeaderButtonContents(wxWindow *win, arrowSpace = 3*ar.width/2; // space to preserve when drawing the label wxPoint triPt[3]; - if ( flags & wxCONTROL_UPICON ) + if ( sortArrow & wxHDR_SORT_ICON_UP ) { triPt[0].x = ar.width / 2; triPt[0].y = 0; @@ -301,14 +308,17 @@ wxRendererGeneric::DrawHeaderButtonContents(wxWindow *win, dc.SetBrush(wxBrush(c)); dc.DrawPolygon( 3, triPt, ar.x, ar.y); } - + labelWidth += arrowSpace; + const int margin = 5; // number of pixels to reserve on either side of the label int bmpWidth = 0; int txtEnd = 0; if ( params && params->m_labelBitmap.Ok() ) bmpWidth = params->m_labelBitmap.GetWidth() + 2; - + + labelWidth += bmpWidth + 2*margin; + // Draw a label if one is given if ( params && !params->m_labelText.empty() ) { @@ -325,8 +335,9 @@ wxRendererGeneric::DrawHeaderButtonContents(wxWindow *win, int tw, th, td, x, y; dc.GetTextExtent( label, &tw, &th, &td); + labelWidth += tw; y = rect.y + wxMax(0, (rect.height - (th+td)) / 2); - + // truncate and add an ellipsis (...) if the text is too wide. int targetWidth = rect.width - arrowSpace - bmpWidth - 2*margin; if ( tw > targetWidth ) @@ -392,6 +403,7 @@ wxRendererGeneric::DrawHeaderButtonContents(wxWindow *win, } dc.DrawBitmap(params->m_labelBitmap, x, y, true); } + return labelWidth; }