]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/ribbon/art.h
Allow customizing AUI tab colours in wxAuiTabArt.
[wxWidgets.git] / interface / wx / ribbon / art.h
CommitLineData
3c3ead1d
PC
1///////////////////////////////////////////////////////////////////////////////
2// Name: ribbon/art.h
3// Purpose: interface of wxRibbonArtProvider
4// Author: Peter Cawley
5// RCS-ID: $Id$
6// Licence: wxWindows licence
7///////////////////////////////////////////////////////////////////////////////
8
9/**
10 Identifiers for common settings on ribbon art providers which can be used
11 to tweak the appearance of the art provider.
12
13 @see wxRibbonArtProvider::GetColour()
14 @see wxRibbonArtProvider::GetFont()
15 @see wxRibbonArtProvider::GetMetric()
16 @see wxRibbonArtProvider::SetColour()
17 @see wxRibbonArtProvider::SetFont()
18 @see wxRibbonArtProvider::SetMetric()
19*/
20enum wxRibbonArtSetting
21{
22 wxRIBBON_ART_TAB_SEPARATION_SIZE,
23 wxRIBBON_ART_PAGE_BORDER_LEFT_SIZE,
24 wxRIBBON_ART_PAGE_BORDER_TOP_SIZE,
25 wxRIBBON_ART_PAGE_BORDER_RIGHT_SIZE,
26 wxRIBBON_ART_PAGE_BORDER_BOTTOM_SIZE,
27 wxRIBBON_ART_PANEL_X_SEPARATION_SIZE,
28 wxRIBBON_ART_PANEL_Y_SEPARATION_SIZE,
29 wxRIBBON_ART_TOOL_GROUP_SEPARATION_SIZE,
30 wxRIBBON_ART_GALLERY_BITMAP_PADDING_LEFT_SIZE,
31 wxRIBBON_ART_GALLERY_BITMAP_PADDING_RIGHT_SIZE,
32 wxRIBBON_ART_GALLERY_BITMAP_PADDING_TOP_SIZE,
33 wxRIBBON_ART_GALLERY_BITMAP_PADDING_BOTTOM_SIZE,
34 wxRIBBON_ART_PANEL_LABEL_FONT,
35 wxRIBBON_ART_BUTTON_BAR_LABEL_FONT,
36 wxRIBBON_ART_TAB_LABEL_FONT,
37 wxRIBBON_ART_BUTTON_BAR_LABEL_COLOUR,
38 wxRIBBON_ART_BUTTON_BAR_HOVER_BORDER_COLOUR,
39 wxRIBBON_ART_BUTTON_BAR_HOVER_BACKGROUND_TOP_COLOUR,
40 wxRIBBON_ART_BUTTON_BAR_HOVER_BACKGROUND_TOP_GRADIENT_COLOUR,
41 wxRIBBON_ART_BUTTON_BAR_HOVER_BACKGROUND_COLOUR,
42 wxRIBBON_ART_BUTTON_BAR_HOVER_BACKGROUND_GRADIENT_COLOUR,
43 wxRIBBON_ART_BUTTON_BAR_ACTIVE_BORDER_COLOUR,
44 wxRIBBON_ART_BUTTON_BAR_ACTIVE_BACKGROUND_TOP_COLOUR,
45 wxRIBBON_ART_BUTTON_BAR_ACTIVE_BACKGROUND_TOP_GRADIENT_COLOUR,
46 wxRIBBON_ART_BUTTON_BAR_ACTIVE_BACKGROUND_COLOUR,
47 wxRIBBON_ART_BUTTON_BAR_ACTIVE_BACKGROUND_GRADIENT_COLOUR,
48 wxRIBBON_ART_GALLERY_BORDER_COLOUR,
49 wxRIBBON_ART_GALLERY_HOVER_BACKGROUND_COLOUR,
50 wxRIBBON_ART_GALLERY_BUTTON_BACKGROUND_COLOUR,
51 wxRIBBON_ART_GALLERY_BUTTON_BACKGROUND_GRADIENT_COLOUR,
52 wxRIBBON_ART_GALLERY_BUTTON_BACKGROUND_TOP_COLOUR,
53 wxRIBBON_ART_GALLERY_BUTTON_FACE_COLOUR,
54 wxRIBBON_ART_GALLERY_BUTTON_HOVER_BACKGROUND_COLOUR,
55 wxRIBBON_ART_GALLERY_BUTTON_HOVER_BACKGROUND_GRADIENT_COLOUR,
56 wxRIBBON_ART_GALLERY_BUTTON_HOVER_BACKGROUND_TOP_COLOUR,
57 wxRIBBON_ART_GALLERY_BUTTON_HOVER_FACE_COLOUR,
58 wxRIBBON_ART_GALLERY_BUTTON_ACTIVE_BACKGROUND_COLOUR,
59 wxRIBBON_ART_GALLERY_BUTTON_ACTIVE_BACKGROUND_GRADIENT_COLOUR,
60 wxRIBBON_ART_GALLERY_BUTTON_ACTIVE_BACKGROUND_TOP_COLOUR,
61 wxRIBBON_ART_GALLERY_BUTTON_ACTIVE_FACE_COLOUR,
62 wxRIBBON_ART_GALLERY_BUTTON_DISABLED_BACKGROUND_COLOUR,
63 wxRIBBON_ART_GALLERY_BUTTON_DISABLED_BACKGROUND_GRADIENT_COLOUR,
64 wxRIBBON_ART_GALLERY_BUTTON_DISABLED_BACKGROUND_TOP_COLOUR,
65 wxRIBBON_ART_GALLERY_BUTTON_DISABLED_FACE_COLOUR,
66 wxRIBBON_ART_GALLERY_ITEM_BORDER_COLOUR,
67 wxRIBBON_ART_TAB_LABEL_COLOUR,
68 wxRIBBON_ART_TAB_SEPARATOR_COLOUR,
69 wxRIBBON_ART_TAB_SEPARATOR_GRADIENT_COLOUR,
70 wxRIBBON_ART_TAB_CTRL_BACKGROUND_COLOUR,
71 wxRIBBON_ART_TAB_CTRL_BACKGROUND_GRADIENT_COLOUR,
72 wxRIBBON_ART_TAB_HOVER_BACKGROUND_TOP_COLOUR,
73 wxRIBBON_ART_TAB_HOVER_BACKGROUND_TOP_GRADIENT_COLOUR,
74 wxRIBBON_ART_TAB_HOVER_BACKGROUND_COLOUR,
75 wxRIBBON_ART_TAB_HOVER_BACKGROUND_GRADIENT_COLOUR,
76 wxRIBBON_ART_TAB_ACTIVE_BACKGROUND_TOP_COLOUR,
77 wxRIBBON_ART_TAB_ACTIVE_BACKGROUND_TOP_GRADIENT_COLOUR,
78 wxRIBBON_ART_TAB_ACTIVE_BACKGROUND_COLOUR,
79 wxRIBBON_ART_TAB_ACTIVE_BACKGROUND_GRADIENT_COLOUR,
80 wxRIBBON_ART_TAB_BORDER_COLOUR,
81 wxRIBBON_ART_PANEL_BORDER_COLOUR,
82 wxRIBBON_ART_PANEL_BORDER_GRADIENT_COLOUR,
83 wxRIBBON_ART_PANEL_MINIMISED_BORDER_COLOUR,
84 wxRIBBON_ART_PANEL_MINIMISED_BORDER_GRADIENT_COLOUR,
85 wxRIBBON_ART_PANEL_LABEL_BACKGROUND_COLOUR,
86 wxRIBBON_ART_PANEL_LABEL_BACKGROUND_GRADIENT_COLOUR,
87 wxRIBBON_ART_PANEL_LABEL_COLOUR,
88 wxRIBBON_ART_PANEL_HOVER_LABEL_BACKGROUND_COLOUR,
89 wxRIBBON_ART_PANEL_HOVER_LABEL_BACKGROUND_GRADIENT_COLOUR,
90 wxRIBBON_ART_PANEL_HOVER_LABEL_COLOUR,
91 wxRIBBON_ART_PANEL_MINIMISED_LABEL_COLOUR,
92 wxRIBBON_ART_PANEL_ACTIVE_BACKGROUND_TOP_COLOUR,
93 wxRIBBON_ART_PANEL_ACTIVE_BACKGROUND_TOP_GRADIENT_COLOUR,
94 wxRIBBON_ART_PANEL_ACTIVE_BACKGROUND_COLOUR,
95 wxRIBBON_ART_PANEL_ACTIVE_BACKGROUND_GRADIENT_COLOUR,
96 wxRIBBON_ART_PAGE_BORDER_COLOUR,
97 wxRIBBON_ART_PAGE_BACKGROUND_TOP_COLOUR,
98 wxRIBBON_ART_PAGE_BACKGROUND_TOP_GRADIENT_COLOUR,
99 wxRIBBON_ART_PAGE_BACKGROUND_COLOUR,
100 wxRIBBON_ART_PAGE_BACKGROUND_GRADIENT_COLOUR,
101 wxRIBBON_ART_PAGE_HOVER_BACKGROUND_TOP_COLOUR,
102 wxRIBBON_ART_PAGE_HOVER_BACKGROUND_TOP_GRADIENT_COLOUR,
103 wxRIBBON_ART_PAGE_HOVER_BACKGROUND_COLOUR,
104 wxRIBBON_ART_PAGE_HOVER_BACKGROUND_GRADIENT_COLOUR,
105 wxRIBBON_ART_TOOLBAR_BORDER_COLOUR,
106 wxRIBBON_ART_TOOLBAR_HOVER_BORDER_COLOUR,
107 wxRIBBON_ART_TOOLBAR_FACE_COLOUR,
108 wxRIBBON_ART_TOOL_BACKGROUND_TOP_COLOUR,
109 wxRIBBON_ART_TOOL_BACKGROUND_TOP_GRADIENT_COLOUR,
110 wxRIBBON_ART_TOOL_BACKGROUND_COLOUR,
111 wxRIBBON_ART_TOOL_BACKGROUND_GRADIENT_COLOUR,
112 wxRIBBON_ART_TOOL_HOVER_BACKGROUND_TOP_COLOUR,
113 wxRIBBON_ART_TOOL_HOVER_BACKGROUND_TOP_GRADIENT_COLOUR,
114 wxRIBBON_ART_TOOL_HOVER_BACKGROUND_COLOUR,
115 wxRIBBON_ART_TOOL_HOVER_BACKGROUND_GRADIENT_COLOUR,
116 wxRIBBON_ART_TOOL_ACTIVE_BACKGROUND_TOP_COLOUR,
117 wxRIBBON_ART_TOOL_ACTIVE_BACKGROUND_TOP_GRADIENT_COLOUR,
118 wxRIBBON_ART_TOOL_ACTIVE_BACKGROUND_COLOUR,
119 wxRIBBON_ART_TOOL_ACTIVE_BACKGROUND_GRADIENT_COLOUR,
120};
121
122/**
123 Flags used to describe the direction, state, and/or purpose of a
124 ribbon-style scroll button.
125
126 @see wxRibbonArtProvider::DrawScrollButton()
127 @see wxRibbonArtProvider::GetScrollButtonMinimumSize()
128*/
129enum wxRibbonScrollButtonStyle
130{
131 wxRIBBON_SCROLL_BTN_LEFT = 0, /**< Button will scroll to the left. */
132 wxRIBBON_SCROLL_BTN_RIGHT = 1, /**< Button will scroll to the right. */
133 wxRIBBON_SCROLL_BTN_UP = 2, /**< Button will scroll upward. */
134 wxRIBBON_SCROLL_BTN_DOWN = 3, /**< Button will scroll downward. */
135
136 /** A mask to extract direction from a combination of flags. */
137 wxRIBBON_SCROLL_BTN_DIRECTION_MASK = 3,
138
139 wxRIBBON_SCROLL_BTN_NORMAL = 0, /**< Button is not active or hovered. */
140 wxRIBBON_SCROLL_BTN_HOVERED = 4, /**< Button has a cursor hovering over it. */
141 wxRIBBON_SCROLL_BTN_ACTIVE = 8, /**< Button is being pressed. */
142
143 /** A mask to extract state from a combination of flags. */
144 wxRIBBON_SCROLL_BTN_STATE_MASK = 12,
145
146 wxRIBBON_SCROLL_BTN_FOR_OTHER = 0, /**< Button is not for scrolling tabs nor pages. */
147 wxRIBBON_SCROLL_BTN_FOR_TABS = 16, /**< Button is for scrolling tabs. */
148 wxRIBBON_SCROLL_BTN_FOR_PAGE = 32, /**< Button is for scrolling pages. */
149
150 /** A mask to extract purpose from a combination of flags. */
151 wxRIBBON_SCROLL_BTN_FOR_MASK = 48,
152};
153
154/**
155 Buttons on a ribbon button bar and tools on a ribbon tool bar can each be
156 one of three different kinds.
157*/
158enum wxRibbonButtonKind
159{
160 /**
161 Normal button or tool with a clickable area which causes some generic
162 action.
163 */
164 wxRIBBON_BUTTON_NORMAL = 1 << 0,
165
166 /**
167 Dropdown button or tool with a clickable area which typically causes a
168 dropdown menu.
169 */
170 wxRIBBON_BUTTON_DROPDOWN = 1 << 1,
171
172 /**
173 Button or tool with two clickable areas - one which causes a dropdown
174 menu, and one which causes a generic action.
175 */
176 wxRIBBON_BUTTON_HYBRID = wxRIBBON_BUTTON_NORMAL | wxRIBBON_BUTTON_DROPDOWN,
955bad41
PC
177
178 /**
179 Normal button or tool with a clickable area which toggles the button
180 between a pressed and unpressed state.
181 */
182 wxRIBBON_BUTTON_TOGGLE = 1 << 2
3c3ead1d
PC
183};
184
185/**
186 @class wxRibbonArtProvider
187
188 wxRibbonArtProvider is responsible for drawing all the components of the ribbon
189 interface. This allows a ribbon bar to have a pluggable look-and-feel, while
190 retaining the same underlying behaviour. As a single art provider is used for
191 all ribbon components, a ribbon bar usually has a consistent (though unique)
192 appearance.
193
194 By default, a wxRibbonBar uses an instance of this class called
69aa257b
FM
195 @c wxRibbonDefaultArtProvider, which resolves to @c wxRibbonAUIArtProvider,
196 @c wxRibbonMSWArtProvider, or @c wxRibbonOSXArtProvider - whichever is most appropriate
3c3ead1d
PC
197 to the current platform. These art providers are all slightly configurable with
198 regard to colours and fonts, but for larger modifications, you can derive from
199 one of these classes, or write a completely new art provider class.
200 Call wxRibbonBar::SetArtProvider to change the art provider being used.
201
202 @library{wxribbon}
203 @category{ribbon}
204
205 @see wxRibbonBar
206*/
207class wxRibbonArtProvider
208{
209public:
210 /**
211 Constructor.
212 */
213 wxRibbonArtProvider();
214
215 /**
216 Destructor.
217 */
218 virtual ~wxRibbonArtProvider();
219
220 /**
221 Create a new art provider which is a clone of this one.
222 */
223 virtual wxRibbonArtProvider* Clone() const = 0;
224
225 /**
226 Set the style flags.
227
228 Normally called automatically by wxRibbonBar::SetArtProvider with the ribbon
229 bar's style flags, so that the art provider has the same flags as the bar which
230 it is serving.
231 */
232 virtual void SetFlags(long flags) = 0;
233
234 /**
235 Get the previously set style flags.
236 */
237 virtual long GetFlags() const = 0;
238
239 /**
240 Get the value of a certain integer setting.
241 @a id can be one of the size values of @ref wxRibbonArtSetting.
242 */
243 virtual int GetMetric(int id) const = 0;
244
245 /**
246 Set the value of a certain integer setting to the value @e new_val.
247 @a id can be one of the size values of @ref wxRibbonArtSetting.
248 */
249 virtual void SetMetric(int id, int new_val) = 0;
250
251 /**
252 Set the value of a certain font setting to the value @e font.
253 @a id can be one of the font values of @ref wxRibbonArtSetting.
254 */
255 virtual void SetFont(int id, const wxFont& font) = 0;
256
257 /**
258 Get the value of a certain font setting.
259 @a id can be one of the font values of @ref wxRibbonArtSetting.
260 */
261 virtual wxFont GetFont(int id) const = 0;
262
263 /**
264 Get the value of a certain colour setting.
265 @a id can be one of the colour values of @ref wxRibbonArtSetting.
266 */
267 virtual wxColour GetColour(int id) const = 0;
268
269 /**
270 Set the value of a certain colour setting to the value @e colour.
271 @a id can be one of the colour values of @ref wxRibbonArtSetting, though
57ab6f23 272 not all colour settings will have an effect on every art provider.
3c3ead1d 273
69aa257b 274 @see SetColourScheme()
3c3ead1d
PC
275 */
276 virtual void SetColour(int id, const wxColor& colour) = 0;
277
278 /**
69aa257b 279 @see wxRibbonArtProvider::GetColour()
3c3ead1d
PC
280 */
281 wxColour GetColor(int id) const;
282
283 /**
69aa257b 284 @see wxRibbonArtProvider::SetColour()
3c3ead1d
PC
285 */
286 void SetColor(int id, const wxColour& color);
287
288 /**
289 Get the current colour scheme.
290
291 Returns three colours such that if SetColourScheme() were called with
292 them, the colour scheme would be restored to what it was when
293 SetColourScheme() was last called. In practice, this usually means that
294 the returned values are the three colours given in the last call to
295 SetColourScheme(), however if SetColourScheme() performs an idempotent
296 operation upon the colours it is given (like clamping a component of
297 the colour), then the returned values may not be the three colours
298 given in the last call to SetColourScheme().
299 If SetColourScheme() has not been called, then the returned values
300 should result in a colour scheme similar to, if not identical to, the
301 default colours of the art provider.
302 Note that if SetColour() is called, then GetColourScheme() does not try
303 and return a colour scheme similar to colours being used - it's return
304 values are dependant upon the last values given to SetColourScheme(),
305 as described above.
306
69aa257b 307 @param[out] primary
3c3ead1d 308 Pointer to a location to store the primary colour, or NULL.
69aa257b 309 @param[out] secondary
3c3ead1d 310 Pointer to a location to store the secondary colour, or NULL.
69aa257b 311 @param[out] tertiary
3c3ead1d
PC
312 Pointer to a location to store the tertiary colour, or NULL.
313 */
314 virtual void GetColourScheme(wxColour* primary,
315 wxColour* secondary,
316 wxColour* tertiary) const = 0;
317
318 /**
319 Set all applicable colour settings from a few base colours.
320
321 Uses any or all of the three given colours to create a colour scheme,
322 and then sets all colour settings which are relevant to the art
323 provider using that scheme.
324 Note that some art providers may not use the tertiary colour for
325 anything, and some may not use the secondary colour either.
326
69aa257b
FM
327 @see SetColour()
328 @see GetColourScheme()
3c3ead1d
PC
329 */
330 virtual void SetColourScheme(const wxColour& primary,
331 const wxColour& secondary,
332 const wxColour& tertiary) = 0;
333
334 /**
335 Draw the background of the tab region of a ribbon bar.
336
337 @param dc
338 The device context to draw onto.
339 @param wnd
340 The window which is being drawn onto.
341 @param rect
342 The rectangle within which to draw.
343 */
344 virtual void DrawTabCtrlBackground(
345 wxDC& dc,
346 wxWindow* wnd,
347 const wxRect& rect) = 0;
348
349 /**
350 Draw a single tab in the tab region of a ribbon bar.
351
352 @param dc
353 The device context to draw onto.
354 @param wnd
355 The window which is being drawn onto (not the wxRibbonPage
356 associated with the tab being drawn).
357 @param tab
358 The rectangle within which to draw, and also the tab label, icon,
359 and state (active and/or hovered). The drawing rectangle will be
360 entirely within a rectangle on the same device context previously
361 painted with DrawTabCtrlBackground(). The rectangle's width will
362 be at least the minimum value returned by GetBarTabWidth(), and
363 height will be the value returned by GetTabCtrlHeight().
364 */
365 virtual void DrawTab(wxDC& dc,
366 wxWindow* wnd,
367 const wxRibbonPageTabInfo& tab) = 0;
368
369 /**
370 Draw a separator between two tabs in a ribbon bar.
371
372 @param dc
373 The device context to draw onto.
374 @param wnd
375 The window which is being drawn onto.
376 @param rect
377 The rectangle within which to draw, which will be entirely within a
378 rectangle on the same device context previously painted with
379 DrawTabCtrlBackground().
380 @param visibility
381 The opacity with which to draw the separator. Values are in the range
382 [0, 1], with 0 being totally transparent, and 1 being totally opaque.
383 */
384 virtual void DrawTabSeparator(wxDC& dc,
385 wxWindow* wnd,
386 const wxRect& rect,
387 double visibility) = 0;
388
389 /**
390 Draw the background of a ribbon page.
391
392 @param dc
393 The device context to draw onto.
394 @param wnd
395 The window which is being drawn onto (which is commonly the wxRibbonPage
396 whose background is being drawn, but doesn't have to be).
397 @param rect
398 The rectangle within which to draw.
399
400 @sa GetPageBackgroundRedrawArea
401 */
402 virtual void DrawPageBackground(
403 wxDC& dc,
404 wxWindow* wnd,
405 const wxRect& rect) = 0;
406
407 /**
408 Draw a ribbon-style scroll button.
409
410 @param dc
411 The device context to draw onto.
412 @param wnd
413 The window which is being drawn onto.
414 @param rect
415 The rectangle within which to draw. The size of this rectangle
416 will be at least the size returned by GetScrollButtonMinimumSize()
417 for a scroll button with the same style. For tab scroll buttons,
418 this rectangle will be entirely within a rectangle on the same
419 device context previously painted with DrawTabCtrlBackground(), but
420 this is not guaranteed for other types of button (for example,
421 page scroll buttons will not be painted on an area previously
422 painted with DrawPageBackground()).
423 @param style
424 A combination of flags from @ref wxRibbonScrollButtonStyle, including
425 a direction, a for flag, and one or more states.
426 */
427 virtual void DrawScrollButton(
428 wxDC& dc,
429 wxWindow* wnd,
430 const wxRect& rect,
431 long style) = 0;
432
433 /**
434 Draw the background and chrome for a ribbon panel. This should draw
435 the border, background, label, and any other items of a panel which
436 are outside the client area of a panel.
437
438 Note that when a panel is minimised, this function is not called - only
439 DrawMinimisedPanel() is called, so a background should be explicitly
440 painted by that if required.
441
442 @param dc
443 The device context to draw onto.
444 @param wnd
445 The window which is being drawn onto, which is always the panel
446 whose background and chrome is being drawn. The panel label and
447 other panel attributes can be obtained by querying this.
448 @param rect
449 The rectangle within which to draw.
450 */
451 virtual void DrawPanelBackground(
452 wxDC& dc,
453 wxRibbonPanel* wnd,
454 const wxRect& rect) = 0;
455
456 /**
457 Draw the background and chrome for a wxRibbonGallery control. This
57ab6f23 458 should draw the border, background, scroll buttons, extension button,
3c3ead1d
PC
459 and any other UI elements which are not attached to a specific gallery
460 item.
461
462 @param dc
463 The device context to draw onto.
464 @param wnd
465 The window which is being drawn onto, which is always the gallery
466 whose background and chrome is being drawn. Attributes used during
467 drawing like the gallery hover state and individual button states
468 can be queried from this parameter by wxRibbonGallery::IsHovered(),
469 wxRibbonGallery::GetExtensionButtonState(),
470 wxRibbonGallery::GetUpButtonState(), and
471 wxRibbonGallery::GetDownButtonState().
472 @param rect
473 The rectangle within which to draw. This rectangle is the entire
474 area of the gallery control, not just the client rectangle.
475 */
476 virtual void DrawGalleryBackground(
477 wxDC& dc,
478 wxRibbonGallery* wnd,
479 const wxRect& rect) = 0;
480
481 /**
482 Draw the background of a single item in a wxRibbonGallery control. This
483 is painted on top of a gallery background, and behind the items bitmap.
484 Unlike DrawButtonBarButton() and DrawTool(), it is not expected to draw
485 the item bitmap - that is done by the gallery control itself.
486
487 @param dc
488 The device context to draw onto.
489 @param wnd
490 The window which is being drawn onto, which is always the gallery
491 which contains the item being drawn.
492 @param rect
493 The rectangle within which to draw. The size of this rectangle will
494 be the size of the item's bitmap, expanded by gallery item padding
495 values (wxRIBBON_ART_GALLERY_BITMAP_PADDING_LEFT_SIZE,
496 wxRIBBON_ART_GALLERY_BITMAP_PADDING_RIGHT_SIZE,
497 wxRIBBON_ART_GALLERY_BITMAP_PADDING_TOP_SIZE, and
498 wxRIBBON_ART_GALLERY_BITMAP_PADDING_BOTTOM_SIZE). The drawing
499 rectangle will be entirely within a rectangle on the same device
500 context previously painted with DrawGalleryBackground().
501 @param item
502 The item whose background is being painted. Typically the
503 background will vary if the item is hovered, active, or selected;
504 wxRibbonGallery::GetSelection(), wxRibbonGallery::GetActiveItem(),
505 and wxRibbonGallery::GetHoveredItem() can be called to test if the
506 given item is in one of these states.
507 */
508 virtual void DrawGalleryItemBackground(
509 wxDC& dc,
510 wxRibbonGallery* wnd,
511 const wxRect& rect,
512 wxRibbonGalleryItem* item) = 0;
513
514 /**
515 Draw a minimised ribbon panel.
516
517 @param dc
518 The device context to draw onto.
519 @param wnd
520 The window which is being drawn onto, which is always the panel
521 which is minimised. The panel label can be obtained from this
522 window. The minimised icon obtained from querying the window may
523 not be the size requested by GetMinimisedPanelMinimumSize() - the
524 @a bitmap argument contains the icon in the requested size.
525 @param rect
526 The rectangle within which to draw. The size of the rectangle will
527 be at least the size returned by GetMinimisedPanelMinimumSize().
528 @param bitmap
529 A copy of the panel's minimised bitmap rescaled to the size
530 returned by GetMinimisedPanelMinimumSize().
531 */
532 virtual void DrawMinimisedPanel(
533 wxDC& dc,
534 wxRibbonPanel* wnd,
535 const wxRect& rect,
536 wxBitmap& bitmap) = 0;
537
538 /**
539 Draw the background for a wxRibbonButtonBar control.
540
541 @param dc
542 The device context to draw onto.
543 @param wnd
544 The window which is being drawn onto (which will typically be the
545 button bar itself, though this is not guaranteed).
546 @param rect
547 The rectangle within which to draw.
548 */
549 virtual void DrawButtonBarBackground(
550 wxDC& dc,
551 wxWindow* wnd,
552 const wxRect& rect) = 0;
553
554 /**
555 Draw a single button for a wxRibbonButtonBar control.
556
557 @param dc
558 The device context to draw onto.
559 @param wnd
560 The window which is being drawn onto.
561 @param rect
562 The rectangle within which to draw. The size of this rectangle will
563 be a size previously returned by GetButtonBarButtonSize(), and the
564 rectangle will be entirely within a rectangle on the same device
565 context previously painted with DrawButtonBarBackground().
566 @param kind
567 The kind of button to draw (normal, dropdown or hybrid).
568 @param state
569 Combination of a size flag and state flags from the
570 wxRibbonButtonBarButtonState enumeration.
571 @param label
572 The label of the button.
573 @param bitmap_large
574 The large bitmap of the button (or the large disabled bitmap when
575 wxRIBBON_BUTTONBAR_BUTTON_DISABLED is set in @a state).
576 @param bitmap_small
577 The small bitmap of the button (or the small disabled bitmap when
578 wxRIBBON_BUTTONBAR_BUTTON_DISABLED is set in @a state).
579 */
580 virtual void DrawButtonBarButton(
581 wxDC& dc,
582 wxWindow* wnd,
583 const wxRect& rect,
584 wxRibbonButtonBarButtonKind kind,
585 long state,
586 const wxString& label,
587 const wxBitmap& bitmap_large,
588 const wxBitmap& bitmap_small) = 0;
589
590 /**
591 Draw the background for a wxRibbonToolBar control.
592
593 @param dc
594 The device context to draw onto.
595 @param wnd
596 The which is being drawn onto. In most cases this will be a
597 wxRibbonToolBar, but it doesn't have to be.
598 @param rect
599 The rectangle within which to draw. Some of this rectangle will
600 later be drawn over using DrawToolGroupBackground() and DrawTool(),
601 but not all of it will (unless there is only a single group of
602 tools).
603 */
604 virtual void DrawToolBarBackground(
605 wxDC& dc,
606 wxWindow* wnd,
607 const wxRect& rect) = 0;
608
609 /**
610 Draw the background for a group of tools on a wxRibbonToolBar control.
611
612 @param dc
613 The device context to draw onto.
614 @param wnd
615 The window which is being drawn onto. In most cases this will be a
616 wxRibbonToolBar, but it doesn't have to be.
617 @param rect
618 The rectangle within which to draw. This rectangle is a union of
619 the individual tools' rectangles. As there are no gaps between
620 tools, this rectangle will be painted over exactly once by calls to
621 DrawTool(). The group background could therefore be painted by
622 DrawTool(), though it can be conceptually easier and more efficient
623 to draw it all at once here. The rectangle will be entirely within
624 a rectangle on the same device context previously painted with
625 DrawToolBarBackground().
626 */
627 virtual void DrawToolGroupBackground(
628 wxDC& dc,
629 wxWindow* wnd,
630 const wxRect& rect) = 0;
631
632 /**
633 Draw a single tool (for a wxRibbonToolBar control).
634
635 @param dc
636 The device context to draw onto.
637 @param wnd
638 The window which is being drawn onto. In most cases this will be a
639 wxRibbonToolBar, but it doesn't have to be.
640 @param rect
641 The rectangle within which to draw. The size of this rectangle will
642 at least the size returned by GetToolSize(), and the height of it
643 will be equal for all tools within the same group. The rectangle
644 will be entirely within a rectangle on the same device context
645 previously painted with DrawToolGroupBackground().
646 @param bitmap
647 The bitmap to use as the tool's foreground. If the tool is a hybrid
648 or dropdown tool, then the foreground should also contain a
649 standard dropdown button.
650 @param kind
651 The kind of tool to draw (normal, dropdown, or hybrid).
652 @param state
653 A combination of wxRibbonToolBarToolState flags giving the state of
654 the tool and it's relative position within a tool group.
655 */
656 virtual void DrawTool(
657 wxDC& dc,
658 wxWindow* wnd,
659 const wxRect& rect,
660 const wxBitmap& bitmap,
661 wxRibbonButtonKind kind,
662 long state) = 0;
663
664 /**
665 Calculate the ideal and minimum width (in pixels) of a tab in a ribbon
666 bar.
667
668 @param dc
669 A device context to use when one is required for size calculations.
670 @param wnd
671 The window onto which the tab will eventually be drawn.
672 @param label
673 The tab's label (or wxEmptyString if it has none).
674 @param bitmap
675 The tab's icon (or wxNullBitmap if it has none).
676 @param[out] ideal
677 The ideal width (in pixels) of the tab.
678 @param[out] small_begin_need_separator
679 A size less than the @a ideal size, at which a tab separator should
680 begin to be drawn (i.e. drawn, but still fairly transparent).
681 @param[out] small_must_have_separator
682 A size less than the @a small_begin_need_separator size, at which a
683 tab separator must be drawn (i.e. drawn at full opacity).
684 @param[out] minimum
685 A size less than the @a small_must_have_separator size, and greater
686 than or equal to zero, which is the minimum pixel width for the tab.
687 */
688 virtual void GetBarTabWidth(
689 wxDC& dc,
690 wxWindow* wnd,
691 const wxString& label,
692 const wxBitmap& bitmap,
693 int* ideal,
694 int* small_begin_need_separator,
695 int* small_must_have_separator,
696 int* minimum) = 0;
697
698 /**
699 Calculate the height (in pixels) of the tab region of a ribbon bar.
700 Note that as the tab region can contain scroll buttons, the height
701 should be greater than or equal to the minimum height for a tab scroll
702 button.
703
704 @param dc
705 A device context to use when one is required for size calculations.
706 @param wnd
707 The window onto which the tabs will eventually be drawn.
708 @param pages
709 The tabs which will acquire the returned height.
710 */
711 virtual int GetTabCtrlHeight(
712 wxDC& dc,
713 wxWindow* wnd,
714 const wxRibbonPageTabInfoArray& pages) = 0;
715
716 /**
717 Calculate the minimum size (in pixels) of a scroll button.
718
719 @param dc
720 A device context to use when one is required for size calculations.
721 @param wnd
722 The window onto which the scroll button will eventually be drawn.
723 @param style
724 A combination of flags from @ref wxRibbonScrollButtonStyle, including
725 a direction, and a for flag (state flags may be given too, but
726 should be ignored, as a button should retain a constant size,
727 regardless of its state).
728 */
729 virtual wxSize GetScrollButtonMinimumSize(
730 wxDC& dc,
731 wxWindow* wnd,
732 long style) = 0;
733
734 /**
735 Calculate the size of a panel for a given client size. This should
736 increment the given size by enough to fit the panel label and other
737 chrome.
738
739 @param dc
740 A device context to use if one is required for size calculations.
741 @param wnd
742 The ribbon panel in question.
743 @param client_size
744 The client size.
745 @param[out] client_offset
746 The offset where the client rectangle begins within the panel (may
747 be NULL).
748
749 @sa GetPanelClientSize()
750 */
751 virtual wxSize GetPanelSize(
752 wxDC& dc,
753 const wxRibbonPanel* wnd,
754 wxSize client_size,
755 wxPoint* client_offset) = 0;
756
757 /**
758 Calculate the client size of a panel for a given overall size. This
759 should act as the inverse to GetPanelSize(), and decrement the given
760 size by enough to fit the panel label and other chrome.
761
762 @param dc
763 A device context to use if one is required for size calculations.
764 @param wnd
765 The ribbon panel in question.
766 @param size
767 The overall size to calculate client size for.
768 @param[out] client_offset
769 The offset where the returned client size begins within the given
770 @a size (may be NULL).
771
772 @sa GetPanelSize()
773 */
774 virtual wxSize GetPanelClientSize(
775 wxDC& dc,
776 const wxRibbonPanel* wnd,
777 wxSize size,
778 wxPoint* client_offset) = 0;
779
780 /**
781 Calculate the size of a wxRibbonGallery control for a given client
782 size. This should increment the given size by enough to fit the gallery
783 border, buttons, and any other chrome.
784
785 @param dc
786 A device context to use if one is required for size calculations.
787 @param wnd
788 The gallery in question.
789 @param client_size
790 The client size.
791
792 @sa GetGalleryClientSize()
793 */
794 virtual wxSize GetGallerySize(
795 wxDC& dc,
796 const wxRibbonGallery* wnd,
797 wxSize client_size) = 0;
798
799 /**
800 Calculate the client size of a wxRibbonGallery control for a given
801 size. This should act as the inverse to GetGallerySize(), and decrement
802 the given size by enough to fir the gallery border, buttons, and other
803 chrome.
804
805 @param dc
806 A device context to use if one is required for size calculations.
807 @param wnd
808 The gallery in question.
809 @param size
810 The overall size to calculate the client size for.
811 @param[out] client_offset
812 The position within the given size at which the returned client
813 size begins.
814 @param[out] scroll_up_button
815 The rectangle within the given size which the scroll up button
816 occupies.
817 @param[out] scroll_down_button
818 The rectangle within the given size which the scroll down button
819 occupies.
820 @param[out] extension_button
821 The rectangle within the given size which the extension button
822 occupies.
823 */
824 virtual wxSize GetGalleryClientSize(
825 wxDC& dc,
826 const wxRibbonGallery* wnd,
827 wxSize size,
828 wxPoint* client_offset,
829 wxRect* scroll_up_button,
830 wxRect* scroll_down_button,
831 wxRect* extension_button) = 0;
832
833 /**
834 Calculate the portion of a page background which needs to be redrawn
835 when a page is resized. To optimise the drawing of page backgrounds, as
57ab6f23 836 small an area as possible should be returned. Of course, if the way in
3c3ead1d
PC
837 which a background is drawn means that the entire background needs to
838 be repainted on resize, then the entire new size should be returned.
839
840 @param dc
841 A device context to use when one is required for size calculations.
842 @param wnd
843 The page which is being resized.
844 @param page_old_size
845 The size of the page prior to the resize (which has already been
846 painted).
847 @param page_new_size
848 The size of the page after the resize.
849 */
850 virtual wxRect GetPageBackgroundRedrawArea(
851 wxDC& dc,
852 const wxRibbonPage* wnd,
853 wxSize page_old_size,
854 wxSize page_new_size) = 0;
855
856 /**
857 Calculate the size of a button within a wxRibbonButtonBar.
858
859 @param dc
860 A device context to use when one is required for size calculations.
861 @param wnd
862 The window onto which the button will eventually be drawn (which is
863 normally a wxRibbonButtonBar, though this is not guaranteed).
864 @param kind
865 The kind of button.
866 @param size
867 The size-class to calculate the size for. Buttons on a button bar
868 can have three distinct sizes: wxRIBBON_BUTTONBAR_BUTTON_SMALL,
869 wxRIBBON_BUTTONBAR_BUTTON_MEDIUM, and wxRIBBON_BUTTONBAR_BUTTON_LARGE.
870 If the requested size-class is not applicable, then @false should
871 be returned.
872 @param label
873 The label of the button.
874 @param bitmap_size_large
875 The size of all "large" bitmaps on the button bar.
876 @param bitmap_size_small
877 The size of all "small" bitmaps on the button bar.
878 @param[out] button_size
879 The size, in pixels, of the button.
880 @param[out] normal_region
881 The region of the button which constitutes the normal button.
882 @param[out] dropdown_region
883 The region of the button which constitutes the dropdown button.
884
885 @return @true if a size exists for the button, @false otherwise.
886 */
887 virtual bool GetButtonBarButtonSize(
888 wxDC& dc,
889 wxWindow* wnd,
890 wxRibbonButtonBarButtonKind kind,
891 wxRibbonButtonBarButtonState size,
892 const wxString& label,
893 wxSize bitmap_size_large,
894 wxSize bitmap_size_small,
895 wxSize* button_size,
896 wxRect* normal_region,
897 wxRect* dropdown_region) = 0;
898
899 /**
900 Calculate the size of a minimised ribbon panel.
901
902 @param dc
903 A device context to use when one is required for size calculations.
904 @param wnd
905 The ribbon panel in question. Attributes like the panel label can
906 be queried from this.
907 @param[out] desired_bitmap_size
69aa257b
FM
908 Optional parameter which is filled with the size of the bitmap
909 suitable for a minimised ribbon panel.
910 @param[out] expanded_panel_direction
911 Optional parameter which is filled with the direction of the
912 minimised panel (@c wxEAST or @c wxSOUTH depending on the style).
3c3ead1d
PC
913 */
914 virtual wxSize GetMinimisedPanelMinimumSize(
915 wxDC& dc,
916 const wxRibbonPanel* wnd,
917 wxSize* desired_bitmap_size,
918 wxDirection* expanded_panel_direction) = 0;
919
920 /**
921 Calculate the size of a tool within a wxRibbonToolBar.
922
923 @param dc
924 A device context to use when one is required for size calculations.
925 @param wnd
926 The window onto which the tool will eventually be drawn.
927 @param bitmap_size
928 The size of the tool's foreground bitmap.
929 @param kind
930 The kind of tool (normal, dropdown, or hybrid).
931 @param is_first
932 @true if the tool is the first within its group. @false otherwise.
933 @param is_last
934 @true if the tool is the last within its group. @false otherwise.
935 @param[out] dropdown_region
936 For dropdown and hybrid tools, the region within the returned
937 size which counts as the dropdown part.
938 */
939 virtual wxSize GetToolSize(
940 wxDC& dc,
941 wxWindow* wnd,
942 wxSize bitmap_size,
943 wxRibbonButtonKind kind,
944 bool is_first,
945 bool is_last,
946 wxRect* dropdown_region) = 0;
947};