f3ff0796cfe008e9fc2b82a4ca597642dde39c60
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/headercol.h
3 // Purpose: interface of wxHeaderColumn
4 // Author: Vadim Zeitlin
7 // Copyright: (c) 2008 Vadim Zeitlin <vadim@wxwidgets.org>
8 // Licence: wxWindows licence
9 /////////////////////////////////////////////////////////////////////////////
12 Column width special values.
16 /// Special value used for column width meaning unspecified or default.
17 wxCOL_WIDTH_DEFAULT
= -1,
20 Size the column automatically to fit all values.
22 @note On OS X, this style is only implemented in the Cocoa build on
23 OS X >= 10.5; it behaves identically to wxCOL_WIDTH_DEFAULT otherwise.
25 wxCOL_WIDTH_AUTOSIZE
= -2
29 Bit flags used as wxHeaderColumn flags.
33 /// Column can be resized (included in default flags).
36 /// Column can be clicked to toggle the sort order by its contents.
39 /// Column can be dragged to change its order (included in default).
40 wxCOL_REORDERABLE
= 4,
42 /// Column is not shown at all.
45 /// Default flags for wxHeaderColumn ctor.
46 wxCOL_DEFAULT_FLAGS
= wxCOL_RESIZABLE
| wxCOL_REORDERABLE
52 Represents a column header in controls displaying tabular data such as
53 wxDataViewCtrl or wxGrid.
55 Notice that this is an abstract base class which is implemented (usually
56 using the information stored in the associated control) by the different
57 controls using wxHeaderCtrl. As the control only needs to retrieve the
58 information about the column, this class defines only the methods for
59 accessing the various column properties but not for changing them as the
60 setters might not be needed at all, e.g. if the column attributes can only
61 be changed via the methods of the main associated control (this is the case
62 for wxGrid for example). If you do want to allow changing them directly
63 using the column itself, you should inherit from wxSettableHeaderColumn
64 instead of this class.
66 Finally, if you don't already store the column information at all anywhere,
67 you should use the concrete wxHeaderColumnSimple class and
77 Get the text shown in the column header.
79 virtual wxString
GetTitle() const = 0;
82 Returns the bitmap in the header of the column, if any.
84 If the column has no associated bitmap, wxNullBitmap should be returned.
86 virtual wxBitmap
GetBitmap() const = 0;
89 Returns the current width of the column.
92 Width of the column in pixels, never wxCOL_WIDTH_DEFAULT or
95 virtual int GetWidth() const = 0;
98 Return the minimal column width.
101 The minimal width such that the user can't resize the column to
102 lesser size (notice that it is still possible to set the column
103 width to smaller value from the program code). Return 0 from here
104 to allow resizing the column to arbitrarily small size.
106 virtual int GetMinWidth() const = 0;
109 Returns the current column alignment.
112 One of wxALIGN_CENTRE, wxALIGN_LEFT or wxALIGN_RIGHT.
114 virtual wxAlignment
GetAlignment() const = 0;
118 Get the column flags.
120 This method retrieves all the flags at once, you can also use HasFlag()
121 to test for any individual flag or IsResizeable(), IsSortable(),
122 IsReorderable() and IsHidden() to test for particular flags.
124 virtual int GetFlags() const = 0;
127 Return @true if the specified flag is currently set for this column.
129 bool HasFlag(int flag
) const;
133 Return true if the column can be resized by the user.
135 Equivalent to HasFlag(wxCOL_RESIZABLE).
137 virtual bool IsResizeable() const;
140 Returns @true if the column can be clicked by user to sort the control
141 contents by the field in this column.
143 This corresponds to wxCOL_SORTABLE flag which is off by default.
145 virtual bool IsSortable() const;
148 Returns @true if the column can be dragged by user to change its order.
150 This corresponds to wxCOL_REORDERABLE flag which is on by default.
152 virtual bool IsReorderable() const;
155 Returns @true if the column is currently hidden.
157 This corresponds to wxCOL_HIDDEN flag which is off by default.
159 virtual bool IsHidden() const;
162 Returns @true if the column is currently shown.
164 This corresponds to the absence of wxCOL_HIDDEN flag.
166 bool IsShown() const;
170 Returns @true if the column is currently used for sorting.
172 virtual bool IsSortKey() const = 0;
175 Returns @true, if the sort order is ascending.
177 Notice that it only makes sense to call this function if the column is
178 used for sorting at all, i.e. if IsSortKey() returns @true.
180 virtual bool IsSortOrderAscending() const = 0;
184 @class wxSettableHeaderColumn
186 Adds methods to set the column attributes to wxHeaderColumn.
188 This class adds setters for the column attributes defined by
189 wxHeaderColumn. It is still an abstract base class and needs to be
190 implemented before using it with wxHeaderCtrl.
195 class wxSettableHeaderColumn
: public wxHeaderColumn
199 Set the text to display in the column header.
201 virtual void SetTitle(const wxString
& title
) = 0;
204 Set the bitmap to be displayed in the column header.
206 Notice that the bitmaps displayed in different columns of the same
207 control must all be of the same size.
209 virtual void SetBitmap(const wxBitmap
& bitmap
) = 0;
212 Set the column width.
215 The column width in pixels or the special wxCOL_WIDTH_DEFAULT
216 (meaning to use default width) or wxCOL_WIDTH_AUTOSIZE (size to
217 fit the content) value.
219 virtual void SetWidth(int width
) = 0;
222 Set the minimal column width.
224 This method can be used with resizable columns (i.e. those for which
225 wxCOL_RESIZABLE flag is set in GetFlags() or, alternatively,
226 IsResizeable() returns @true) to prevent the user from making them
227 narrower than the given width.
230 The minimal column width in pixels, may be 0 to remove any
231 previously set restrictions.
233 virtual void SetMinWidth(int minWidth
) = 0;
236 Set the alignment of the column header.
239 The text alignment in horizontal direction only or wxALIGN_NOT to
240 use the default alignment, The possible values here are
241 wxALIGN_CENTRE, wxALIGN_LEFT or wxALIGN_RIGHT with
242 wxALIGN_CENTRE_HORIZONTAL being also supported as synonym for
243 wxALIGN_CENTRE for consistency (but notice that GetAlignment()
246 virtual void SetAlignment(wxAlignment align
) = 0;
250 Set the column flags.
252 This method allows to set all flags at once, see also generic
253 ChangeFlag(), SetFlag(), ClearFlag() and ToggleFlag() methods below as
254 well as specific SetResizeable(), SetSortable(), SetReorderable() and
258 Combination of wxCOL_RESIZABLE, wxCOL_SORTABLE, wxCOL_REORDERABLE
259 and wxCOL_HIDDEN bit flags.
261 virtual void SetFlags(int flags
) = 0;
264 Set or clear the given flag.
267 The flag to set or clear.
269 If @true, set the flag, i.e. equivalent to calling SetFlag(),
270 otherwise clear it, as ClearFlag().
274 void ChangeFlag(int flag
, bool set
);
277 Set the specified flag for the column.
281 void SetFlag(int flag
);
284 Clear the specified flag for the column.
288 void ClearFlag(int flag
);
291 Toggle the specified flag for the column.
293 If the flag is currently set, equivalent to ClearFlag(), otherwise --
298 void ToggleFlag(int flag
);
302 Call this to enable or disable interactive resizing of the column by
305 By default, the columns are resizable.
307 Equivalent to ChangeFlag(wxCOL_RESIZABLE, resizable).
309 virtual void SetResizeable(bool resizable
);
312 Allow clicking the column to sort the control contents by the field in
315 By default, the columns are not sortable so you need to explicitly call
316 this function to allow sorting by the field corresponding to this
319 Equivalent to ChangeFlag(wxCOL_SORTABLE, sortable).
321 virtual void SetSortable(bool sortable
);
324 Allow changing the column order by dragging it.
326 Equivalent to ChangeFlag(wxCOL_REORDERABLE, reorderable).
328 virtual void SetReorderable(bool reorderable
);
331 Hide or show the column.
333 By default all columns are shown but some of them can be completely
334 hidden from view by calling this function.
336 Equivalent to ChangeFlag(wxCOL_HIDDEN, hidden).
338 virtual void SetHidden(bool hidden
);
342 Don't use this column for sorting.
344 This is the reverse of SetSortOrder() and is called to indicate that
345 this column is not used for sorting any longer.
347 void UnsetAsSortKey();
350 Sets this column as the sort key for the associated control.
352 This function indicates that this column is currently used for sorting
353 the control and also sets the sorting direction. Notice that actual
354 sorting is only done in the control associated with the header, this
355 function doesn't do any sorting on its own.
357 Don't confuse this function with SetSortable() which should be used to
358 indicate that the column @em may be used for sorting while this one is
359 used to indicate that it currently @em is used for sorting. Of course,
360 SetSortOrder() can be only called for sortable columns.
363 If @true, sort in ascending order, otherwise in descending order.
365 virtual void SetSortOrder(bool ascending
) = 0;
368 Inverses the sort order.
370 This function is typically called when the user clicks on a column used
371 for sorting to change sort order from ascending to descending or vice
374 @see SetSortOrder(), IsSortOrderAscending()
376 void ToggleSortOrder();
380 @class wxHeaderColumnSimple
382 Simple container for the information about the column.
384 This is a concrete class implementing all wxSettableHeaderColumn class
385 methods in a trivial way, i.e. by just storing the information in the
386 object itself. It is used by and with wxHeaderCtrlSimple, e.g.
388 wxHeaderCtrlSimple * header = new wxHeaderCtrlSimple(...);
389 wxHeaderColumnSimple col("Title");
391 col.SetSortable(100);
392 header->AppendColumn(col);
398 class wxHeaderColumnSimple
: public wxSettableHeaderColumn
403 Constructor for a column header.
405 The first constructor creates a header showing the given text @a title
406 while the second one creates one showing the specified @a bitmap image.
408 wxHeaderColumnSimple(const wxString
& title
,
409 int width
= wxCOL_WIDTH_DEFAULT
,
410 wxAlignment align
= wxALIGN_NOT
,
411 int flags
= wxCOL_DEFAULT_FLAGS
);
413 wxHeaderColumnSimple(const wxBitmap
&bitmap
,
414 int width
= wxCOL_WIDTH_DEFAULT
,
415 wxAlignment align
= wxALIGN_CENTER
,
416 int flags
= wxCOL_DEFAULT_FLAGS
);
421 /// Trivial implementations of the base class pure virtual functions.
423 virtual void SetTitle(const wxString
& title
);
424 virtual wxString
GetTitle() const;
425 virtual void SetBitmap(const wxBitmap
& bitmap
);
426 virtual wxBitmap
GetBitmap() const;
427 virtual void SetWidth(int width
);
428 virtual int GetWidth() const;
429 virtual void SetMinWidth(int minWidth
);
430 virtual int GetMinWidth() const;
431 virtual void SetAlignment(wxAlignment align
);
432 virtual wxAlignment
GetAlignment() const;
433 virtual void SetFlags(int flags
);
434 virtual int GetFlags() const;
435 virtual bool IsSortKey() const;
436 virtual void SetSortOrder(bool ascending
);
437 virtual bool IsSortOrderAscending() const;