1 ///////////////////////////////////////////////////////////////////////////////
2 // Name: wx/univ/stdrend.h
3 // Purpose: wxStdRenderer class declaration
4 // Author: Vadim Zeitlin
7 // Copyright: (c) 2006 Vadim Zeitlin <vadim@wxwindows.org>
8 // Licence: wxWindows licence
9 ///////////////////////////////////////////////////////////////////////////////
11 #ifndef _WX_UNIV_STDREND_H_
12 #define _WX_UNIV_STDREND_H_
14 #include "wx/univ/renderer.h"
17 class WXDLLEXPORT wxColourScheme
;
19 // ----------------------------------------------------------------------------
20 // wxStdRenderer: implements as much of wxRenderer API as possible generically
21 // ----------------------------------------------------------------------------
23 class wxStdRenderer
: public wxRenderer
26 // the renderer will use the given scheme, whose lifetime must be at least
27 // as long as of this object itself, to choose the colours for drawing
28 wxStdRenderer(const wxColourScheme
*scheme
);
30 virtual void DrawBackground(wxDC
& dc
,
34 wxWindow
*window
= NULL
);
35 virtual void DrawButtonSurface(wxDC
& dc
,
41 virtual void DrawFocusRect(wxDC
& dc
, const wxRect
& rect
, int flags
= 0);
42 virtual void DrawLabel(wxDC
& dc
,
43 const wxString
& label
,
46 int alignment
= wxALIGN_LEFT
| wxALIGN_TOP
,
48 wxRect
*rectBounds
= NULL
);
49 virtual void DrawButtonLabel(wxDC
& dc
,
50 const wxString
& label
,
51 const wxBitmap
& image
,
54 int alignment
= wxALIGN_LEFT
| wxALIGN_TOP
,
56 wxRect
*rectBounds
= NULL
);
59 virtual void DrawBorder(wxDC
& dc
,
63 wxRect
*rectIn
= NULL
);
64 virtual void DrawTextBorder(wxDC
& dc
,
68 wxRect
*rectIn
= NULL
);
70 virtual void DrawHorizontalLine(wxDC
& dc
,
71 wxCoord y
, wxCoord x1
, wxCoord x2
);
72 virtual void DrawVerticalLine(wxDC
& dc
,
73 wxCoord x
, wxCoord y1
, wxCoord y2
);
74 virtual void DrawFrame(wxDC
& dc
,
75 const wxString
& label
,
78 int alignment
= wxALIGN_LEFT
,
82 virtual void DrawItem(wxDC
& dc
,
83 const wxString
& label
,
86 virtual void DrawCheckItem(wxDC
& dc
,
87 const wxString
& label
,
88 const wxBitmap
& bitmap
,
92 virtual void DrawCheckButton(wxDC
& dc
,
93 const wxString
& label
,
94 const wxBitmap
& bitmap
,
97 wxAlignment align
= wxALIGN_LEFT
,
99 virtual void DrawRadioButton(wxDC
& dc
,
100 const wxString
& label
,
101 const wxBitmap
& bitmap
,
104 wxAlignment align
= wxALIGN_LEFT
,
105 int indexAccel
= -1);
107 virtual void DrawScrollbarArrow(wxDC
& dc
,
111 virtual void DrawScrollCorner(wxDC
& dc
,
115 virtual void DrawTextLine(wxDC
& dc
,
116 const wxString
& text
,
122 virtual void DrawLineWrapMark(wxDC
& dc
, const wxRect
& rect
);
124 virtual wxRect
GetTextTotalArea(const wxTextCtrl
*text
,
125 const wxRect
& rect
) const;
126 virtual wxRect
GetTextClientArea(const wxTextCtrl
*text
,
128 wxCoord
*extraSpaceBeyond
) const;
129 #endif // wxUSE_TEXTCTRL
131 virtual wxRect
GetBorderDimensions(wxBorder border
) const;
133 virtual bool AreScrollbarsInsideBorder() const;
135 virtual void AdjustSize(wxSize
*size
, const wxWindow
*window
);
137 virtual wxCoord
GetListboxItemHeight(wxCoord fontHeight
);
140 virtual wxRect
GetScrollbarRect(const wxScrollBar
*scrollbar
,
141 wxScrollBar::Element elem
,
142 int thumbPos
= -1) const;
144 virtual wxCoord
GetScrollbarSize(const wxScrollBar
*scrollbar
);
146 virtual wxHitTest
HitTestScrollbar(const wxScrollBar
*scrollbar
,
147 const wxPoint
& pt
) const;
149 virtual wxCoord
ScrollbarToPixel(const wxScrollBar
*scrollbar
,
151 virtual int PixelToScrollbar(const wxScrollBar
*scrollbar
, wxCoord coord
);
152 #endif // wxUSE_SCROLLBAR
155 virtual void DrawStatusField(wxDC
& dc
,
157 const wxString
& label
,
158 int flags
= 0, int style
= 0);
160 virtual wxSize
GetStatusBarBorders() const;
162 virtual wxCoord
GetStatusBarBorderBetweenFields() const;
164 virtual wxSize
GetStatusBarFieldMargins() const;
165 #endif // wxUSE_STATUSBAR
167 virtual wxCoord
GetCheckItemMargin() const { return 0; }
170 virtual void DrawFrameTitleBar(wxDC
& dc
,
172 const wxString
& title
,
175 int specialButton
= 0,
176 int specialButtonFlag
= 0);
177 virtual void DrawFrameBorder(wxDC
& dc
,
180 virtual void DrawFrameBackground(wxDC
& dc
,
183 virtual void DrawFrameTitle(wxDC
& dc
,
185 const wxString
& title
,
187 virtual void DrawFrameIcon(wxDC
& dc
,
191 virtual void DrawFrameButton(wxDC
& dc
,
192 wxCoord x
, wxCoord y
,
196 virtual wxRect
GetFrameClientArea(const wxRect
& rect
, int flags
) const;
198 virtual wxSize
GetFrameTotalSize(const wxSize
& clientSize
, int flags
) const;
200 virtual wxSize
GetFrameMinSize(int flags
) const;
202 virtual wxSize
GetFrameIconSize() const;
204 virtual int HitTestFrame(const wxRect
& rect
,
206 int flags
= 0) const;
224 Arrow_InvertedDisabled
,
231 FrameButton_Minimize
,
232 FrameButton_Maximize
,
242 IndicatorType_MaxCtrl
,
243 IndicatorType_Menu
= IndicatorType_MaxCtrl
,
249 IndicatorState_Normal
,
250 IndicatorState_Pressed
, // this one is for check/radioboxes
251 IndicatorState_Disabled
,
252 IndicatorState_MaxCtrl
,
254 // the rest of the states are valid for menu items only
255 IndicatorState_Selected
= IndicatorState_Pressed
,
256 IndicatorState_SelectedDisabled
= IndicatorState_MaxCtrl
,
257 IndicatorState_MaxMenu
262 IndicatorStatus_Checked
,
263 IndicatorStatus_Unchecked
,
264 IndicatorStatus_Undetermined
,
268 // translate the appropriate bits in flags to the above enum elements
269 static void GetIndicatorsFromFlags(int flags
,
270 IndicatorState
& state
,
271 IndicatorStatus
& status
);
273 // translate wxDirection to ArrowDirection
274 static ArrowDirection
GetArrowDirection(wxDirection dir
);
277 // fill the rectangle with a brush of given colour (must be valid)
278 void DrawSolidRect(wxDC
& dc
, const wxColour
& col
, const wxRect
& rect
);
281 // all the functions in this section adjust the rect parameter to
282 // correspond to the interiour of the drawn area
284 // draw complete rectangle
285 void DrawRect(wxDC
& dc
, wxRect
*rect
, const wxPen
& pen
);
287 // draw the rectange using the first pen for the left and top sides
288 // and the second one for the bottom and right ones
289 void DrawShadedRect(wxDC
& dc
, wxRect
*rect
,
290 const wxPen
& pen1
, const wxPen
& pen2
);
292 // border drawing routines, may be overridden in the derived class
293 virtual void DrawRaisedBorder(wxDC
& dc
, wxRect
*rect
);
294 virtual void DrawSunkenBorder(wxDC
& dc
, wxRect
*rect
);
295 virtual void DrawAntiSunkenBorder(wxDC
& dc
, wxRect
*rect
);
296 virtual void DrawBoxBorder(wxDC
& dc
, wxRect
*rect
);
297 virtual void DrawStaticBorder(wxDC
& dc
, wxRect
*rect
);
298 virtual void DrawExtraBorder(wxDC
& dc
, wxRect
*rect
);
301 // draw the frame with non-empty label inside the given rectText
302 virtual void DrawFrameWithLabel(wxDC
& dc
,
303 const wxString
& label
,
304 const wxRect
& rectFrame
,
305 const wxRect
& rectText
,
310 // draw the (static box) frame without the part corresponding to rectLabel
311 void DrawFrameWithoutLabel(wxDC
& dc
,
312 const wxRect
& rectFrame
,
313 const wxRect
& rectLabel
);
316 // draw the bitmap for a check item (which is by default the same as check
317 // box one but may be different)
318 virtual void DrawCheckItemBitmap(wxDC
& dc
,
319 const wxBitmap
& bitmap
,
323 // common routine for drawing check and radio buttons
324 void DrawCheckOrRadioButton(wxDC
& dc
,
325 const wxString
& label
,
326 const wxBitmap
& bitmap
,
332 // return the check/radio bitmap for the given flags
333 virtual wxBitmap
GetRadioBitmap(int flags
) = 0;
334 virtual wxBitmap
GetCheckBitmap(int flags
) = 0;
336 // return the frame icon bitmap
337 virtual wxBitmap
GetFrameButtonBitmap(FrameButtonType type
) = 0;
339 // get the width of either normal or resizeable frame border depending on
340 // whether flags contains wxTOPLEVEL_RESIZEABLE bit
342 // notice that these methods only make sense with standard border drawing
343 // code which uses the borders of the same width on all sides, this is why
344 // they are only present here and not in wxRenderer itself
345 virtual int GetFrameBorderWidth(int flags
) const;
348 // return the width of the border around the text area in the text control
349 virtual int GetTextBorderWidth(const wxTextCtrl
*text
) const;
350 #endif // wxUSE_TEXTCTRL
352 // return the starting and ending positions, in pixels, of the thumb of a
353 // scrollbar with the given logical position, thumb size and range and the
354 // given physical length
355 static void GetScrollBarThumbSize(wxCoord length
,
362 // GDI objects we often use
368 wxFont m_titlebarFont
;
370 // the colours we use, they never change currently so we don't have to ever
371 // update m_penXXX objects above
372 const wxColourScheme
* const m_scheme
;
374 DECLARE_NO_COPY_CLASS(wxStdRenderer
)
377 #endif // _WX_UNIV_STDREND_H_