]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/treectrl.h
Use wxString::t_str() in calls to Windows API functions in wxMSW.
[wxWidgets.git] / interface / wx / treectrl.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: treectrl.h
e54c96f1 3// Purpose: interface of wxTreeItemData
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
526954c5 6// Licence: wxWindows licence
23324ae1
FM
7/////////////////////////////////////////////////////////////////////////////
8
e54c96f1 9
23324ae1
FM
10/**
11 @class wxTreeCtrl
7c913512 12
23324ae1 13 A tree control presents information as a hierarchy, with items that may be
7977b62a
BP
14 expanded to show further items. Items in a tree control are referenced by
15 wxTreeItemId handles, which may be tested for validity by calling
16 wxTreeItemId::IsOk().
03966fcb 17
d13b34d3 18 A similar control with a fully native implementation for GTK+ and OS X
f0871806 19 as well is wxDataViewTreeCtrl.
7c913512 20
7977b62a
BP
21 To intercept events from a tree control, use the event table macros
22 described in wxTreeEvent.
7c913512 23
23324ae1 24 @beginStyleTable
8c6791e4 25 @style{wxTR_EDIT_LABELS}
7977b62a
BP
26 Use this style if you wish the user to be able to edit labels in the
27 tree control.
8c6791e4 28 @style{wxTR_NO_BUTTONS}
7977b62a 29 For convenience to document that no buttons are to be drawn.
8c6791e4 30 @style{wxTR_HAS_BUTTONS}
7977b62a 31 Use this style to show + and - buttons to the left of parent items.
e615d356
VZ
32 @style{wxTR_TWIST_BUTTONS}
33 Selects alternative style of @c +/@c - buttons and shows rotating
34 ("twisting") arrows instead. Currently this style is only implemented
35 under Microsoft Windows Vista and later Windows versions and is ignored
36 under the other platforms. Notice that under Vista this style results
37 in the same appearance as used by the tree control in Explorer and
38 other built-in programs and so using it may be preferable to the
39 default style.
8c6791e4 40 @style{wxTR_NO_LINES}
7977b62a 41 Use this style to hide vertical level connectors.
8c6791e4 42 @style{wxTR_FULL_ROW_HIGHLIGHT}
7977b62a
BP
43 Use this style to have the background colour and the selection highlight
44 extend over the entire horizontal row of the tree control window. (This
45 flag is ignored under Windows unless you specify @c wxTR_NO_LINES as
46 well.)
8c6791e4 47 @style{wxTR_LINES_AT_ROOT}
7977b62a
BP
48 Use this style to show lines between root nodes. Only applicable if @c
49 wxTR_HIDE_ROOT is set and @c wxTR_NO_LINES is not set.
8c6791e4 50 @style{wxTR_HIDE_ROOT}
7977b62a
BP
51 Use this style to suppress the display of the root node, effectively
52 causing the first-level nodes to appear as a series of root nodes.
8c6791e4 53 @style{wxTR_ROW_LINES}
7977b62a 54 Use this style to draw a contrasting border between displayed rows.
8c6791e4 55 @style{wxTR_HAS_VARIABLE_ROW_HEIGHT}
7977b62a
BP
56 Use this style to cause row heights to be just big enough to fit the
57 content. If not set, all rows use the largest row height. The default is
58 that this flag is unset. Generic only.
8c6791e4 59 @style{wxTR_SINGLE}
7977b62a
BP
60 For convenience to document that only one item may be selected at a
61 time. Selecting another item causes the current selection, if any, to be
62 deselected. This is the default.
8c6791e4 63 @style{wxTR_MULTIPLE}
7977b62a
BP
64 Use this style to allow a range of items to be selected. If a second
65 range is selected, the current range, if any, is deselected.
8c6791e4 66 @style{wxTR_DEFAULT_STYLE}
7977b62a
BP
67 The set of flags that are closest to the defaults for the native control
68 for a particular toolkit.
23324ae1 69 @endStyleTable
7c913512 70
3051a44a 71 @beginEventEmissionTable{wxTreeEvent}
98d45c55
RR
72 @event{EVT_TREE_BEGIN_DRAG(id, func)}
73 Begin dragging with the left mouse button.
6d62b2e2 74 If you want to enable left-dragging you need to intercept this event
4c51a665 75 and explicitly call wxTreeEvent::Allow(), as it's vetoed by default.
232fdc63 76 Processes a @c wxEVT_COMMAND_TREE_BEGIN_DRAG event type.
98d45c55
RR
77 @event{EVT_TREE_BEGIN_RDRAG(id, func)}
78 Begin dragging with the right mouse button.
6d62b2e2 79 If you want to enable right-dragging you need to intercept this event
4c51a665 80 and explicitly call wxTreeEvent::Allow(), as it's vetoed by default.
232fdc63 81 Processes a @c wxEVT_COMMAND_TREE_BEGIN_RDRAG event type.
98d45c55
RR
82 @event{EVT_TREE_END_DRAG(id, func)}
83 End dragging with the left or right mouse button.
232fdc63 84 Processes a @c wxEVT_COMMAND_TREE_END_DRAG event type.
98d45c55
RR
85 @event{EVT_TREE_BEGIN_LABEL_EDIT(id, func)}
86 Begin editing a label. This can be prevented by calling Veto().
232fdc63 87 Processes a @c wxEVT_COMMAND_TREE_BEGIN_LABEL_EDIT event type.
98d45c55
RR
88 @event{EVT_TREE_END_LABEL_EDIT(id, func)}
89 Finish editing a label. This can be prevented by calling Veto().
c1d6046e 90 Processes a @c wxEVT_COMMAND_TREE_END_LABEL_EDIT event type.
98d45c55
RR
91 @event{EVT_TREE_DELETE_ITEM(id, func)}
92 An item was deleted.
232fdc63 93 Processes a @c wxEVT_COMMAND_TREE_DELETE_ITEM event type.
98d45c55
RR
94 @event{EVT_TREE_GET_INFO(id, func)}
95 Request information from the application.
232fdc63 96 Processes a @c wxEVT_COMMAND_TREE_GET_INFO event type.
98d45c55
RR
97 @event{EVT_TREE_SET_INFO(id, func)}
98 Information is being supplied.
232fdc63 99 Processes a @c wxEVT_COMMAND_TREE_SET_INFO event type.
98d45c55 100 @event{EVT_TREE_ITEM_ACTIVATED(id, func)}
6873eb5b
FM
101 The item has been activated, i.e. chosen by double clicking it with
102 mouse or from keyboard.
232fdc63 103 Processes a @c wxEVT_COMMAND_TREE_ITEM_ACTIVATED event type.
98d45c55
RR
104 @event{EVT_TREE_ITEM_COLLAPSED(id, func)}
105 The item has been collapsed.
232fdc63 106 Processes a @c wxEVT_COMMAND_TREE_ITEM_COLLAPSED event type.
98d45c55
RR
107 @event{EVT_TREE_ITEM_COLLAPSING(id, func)}
108 The item is being collapsed. This can be prevented by calling Veto().
232fdc63 109 Processes a @c wxEVT_COMMAND_TREE_ITEM_COLLAPSING event type.
98d45c55
RR
110 @event{EVT_TREE_ITEM_EXPANDED(id, func)}
111 The item has been expanded.
232fdc63 112 Processes a @c wxEVT_COMMAND_TREE_ITEM_EXPANDED event type.
98d45c55
RR
113 @event{EVT_TREE_ITEM_EXPANDING(id, func)}
114 The item is being expanded. This can be prevented by calling Veto().
232fdc63 115 Processes a @c wxEVT_COMMAND_TREE_ITEM_EXPANDING event type.
98d45c55
RR
116 @event{EVT_TREE_ITEM_RIGHT_CLICK(id, func)}
117 The user has clicked the item with the right mouse button.
232fdc63 118 Processes a @c wxEVT_COMMAND_TREE_ITEM_RIGHT_CLICK event type.
98d45c55 119 @event{EVT_TREE_ITEM_MIDDLE_CLICK(id, func)}
232fdc63
VZ
120 The user has clicked the item with the middle mouse button. This is
121 only supported by the generic control.
122 Processes a @c wxEVT_COMMAND_TREE_ITEM_MIDDLE_CLICK event type.
98d45c55
RR
123 @event{EVT_TREE_SEL_CHANGED(id, func)}
124 Selection has changed.
232fdc63 125 Processes a @c wxEVT_COMMAND_TREE_SEL_CHANGED event type.
98d45c55
RR
126 @event{EVT_TREE_SEL_CHANGING(id, func)}
127 Selection is changing. This can be prevented by calling Veto().
232fdc63 128 Processes a @c wxEVT_COMMAND_TREE_SEL_CHANGING event type.
98d45c55
RR
129 @event{EVT_TREE_KEY_DOWN(id, func)}
130 A key has been pressed.
232fdc63 131 Processes a @c wxEVT_COMMAND_TREE_KEY_DOWN event type.
98d45c55 132 @event{EVT_TREE_ITEM_GETTOOLTIP(id, func)}
6873eb5b
FM
133 The opportunity to set the item tooltip is being given to the application
134 (call wxTreeEvent::SetToolTip). Windows only.
232fdc63 135 Processes a @c wxEVT_COMMAND_TREE_ITEM_GETTOOLTIP event type.
98d45c55 136 @event{EVT_TREE_ITEM_MENU(id, func)}
6873eb5b
FM
137 The context menu for the selected item has been requested, either by a
138 right click or by using the menu key.
232fdc63 139 Processes a @c wxEVT_COMMAND_TREE_ITEM_MENU event type.
98d45c55
RR
140 @event{EVT_TREE_STATE_IMAGE_CLICK(id, func)}
141 The state image has been clicked. Windows only.
232fdc63 142 Processes a @c wxEVT_COMMAND_TREE_STATE_IMAGE_CLICK event type.
98d45c55
RR
143 @endEventTable
144
145
7977b62a 146 See also @ref overview_windowstyles.
03966fcb 147
7977b62a
BP
148 @b Win32 @b notes:
149
150 wxTreeCtrl class uses the standard common treeview control under Win32
151 implemented in the system library comctl32.dll. Some versions of this
152 library are known to have bugs with handling the tree control colours: the
153 usual symptom is that the expanded items leave black (or otherwise
154 incorrectly coloured) background behind them, especially for the controls
155 using non-default background colour. The recommended solution is to upgrade
156 the comctl32.dll to a newer version: see
157 http://www.microsoft.com/downloads/details.aspx?familyid=cb2cf3a2-8025-4e8f-8511-9b476a8d35d2
158
23324ae1
FM
159 @library{wxcore}
160 @category{ctrl}
7e59b885 161 @appearance{treectrl.png}
7c913512 162
6873eb5b
FM
163 @see wxDataViewTreeCtrl, wxTreeEvent, wxTreeItemData, @ref overview_treectrl,
164 wxListBox, wxListCtrl, wxImageList
23324ae1
FM
165*/
166class wxTreeCtrl : public wxControl
167{
168public:
7977b62a
BP
169 /**
170 Default Constructor.
171 */
172 wxTreeCtrl();
173
23324ae1
FM
174 /**
175 Constructor, creating and showing a tree control.
3c4f71cc 176
7c913512 177 @param parent
4cc4bfaf 178 Parent window. Must not be @NULL.
7c913512 179 @param id
7977b62a 180 Window identifier. The value @c wxID_ANY indicates a default value.
7c913512 181 @param pos
4cc4bfaf 182 Window position.
dc1b07fd 183 If ::wxDefaultPosition is specified then a default position is chosen.
7c913512 184 @param size
dc1b07fd
FM
185 Window size.
186 If ::wxDefaultSize is specified then the window is sized appropriately.
7c913512 187 @param style
4cc4bfaf 188 Window style. See wxTreeCtrl.
7c913512 189 @param validator
4cc4bfaf 190 Window validator.
7c913512 191 @param name
4cc4bfaf 192 Window name.
3c4f71cc 193
4cc4bfaf 194 @see Create(), wxValidator
23324ae1 195 */
cfbe5614 196 wxTreeCtrl(wxWindow* parent, wxWindowID id = wxID_ANY,
7c913512
FM
197 const wxPoint& pos = wxDefaultPosition,
198 const wxSize& size = wxDefaultSize,
cfbe5614 199 long style = wxTR_DEFAULT_STYLE,
7c913512 200 const wxValidator& validator = wxDefaultValidator,
cfbe5614 201 const wxString& name = wxTreeCtrlNameStr);
03966fcb 202
23324ae1
FM
203
204 /**
205 Destructor, destroying the tree control.
206 */
adaaa686 207 virtual ~wxTreeCtrl();
23324ae1
FM
208
209 /**
210 Adds the root node to the tree, returning the new item.
7977b62a
BP
211
212 The @a image and @a selImage parameters are an index within the normal
213 image list specifying the image to use for unselected and selected
214 items, respectively. If @a image -1 and @a selImage is -1, the same
215 image is used for both selected and unselected items.
23324ae1 216 */
adaaa686
FM
217 virtual wxTreeItemId AddRoot(const wxString& text, int image = -1,
218 int selImage = -1,
219 wxTreeItemData* data = NULL);
23324ae1
FM
220
221 /**
7977b62a
BP
222 Appends an item to the end of the branch identified by @a parent, return
223 a new item id.
03966fcb 224
7977b62a
BP
225 The @a image and @a selImage parameters are an index within the normal
226 image list specifying the image to use for unselected and selected
227 items, respectively. If @a image -1 and @a selImage is -1, the same
228 image is used for both selected and unselected items.
23324ae1
FM
229 */
230 wxTreeItemId AppendItem(const wxTreeItemId& parent,
231 const wxString& text,
232 int image = -1,
233 int selImage = -1,
4cc4bfaf 234 wxTreeItemData* data = NULL);
23324ae1
FM
235
236 /**
7977b62a
BP
237 Sets the buttons image list. The button images assigned with this method
238 will be automatically deleted by wxTreeCtrl as appropriate (i.e. it
239 takes ownership of the list).
240
241 Setting or assigning the button image list enables the display of image
242 buttons. Once enabled, the only way to disable the display of button
243 images is to set the button image list to @NULL.
244
23324ae1 245 This function is only available in the generic version.
7977b62a
BP
246
247 @see SetButtonsImageList().
23324ae1
FM
248 */
249 void AssignButtonsImageList(wxImageList* imageList);
250
251 /**
7977b62a
BP
252 Sets the normal image list. The image list assigned with this method
253 will be automatically deleted by wxTreeCtrl as appropriate (i.e. it
254 takes ownership of the list).
255
256 @see SetImageList().
23324ae1
FM
257 */
258 void AssignImageList(wxImageList* imageList);
259
260 /**
7977b62a
BP
261 Sets the state image list. Image list assigned with this method will be
262 automatically deleted by wxTreeCtrl as appropriate (i.e. it takes
263 ownership of the list).
264
265 @see SetStateImageList().
23324ae1
FM
266 */
267 void AssignStateImageList(wxImageList* imageList);
268
269 /**
270 Collapses the given item.
271 */
adaaa686 272 virtual void Collapse(const wxTreeItemId& item);
23324ae1
FM
273
274 /**
275 Collapses the root item.
3c4f71cc 276
4cc4bfaf 277 @see ExpandAll()
23324ae1
FM
278 */
279 void CollapseAll();
280
281 /**
282 Collapses this item and all of its children, recursively.
3c4f71cc 283
4cc4bfaf 284 @see ExpandAllChildren()
23324ae1
FM
285 */
286 void CollapseAllChildren(const wxTreeItemId& item);
287
288 /**
289 Collapses the given item and removes all children.
290 */
adaaa686 291 virtual void CollapseAndReset(const wxTreeItemId& item);
23324ae1
FM
292
293 /**
cfbe5614
FM
294 Creates the tree control.
295 See wxTreeCtrl::wxTreeCtrl() for further details.
23324ae1 296 */
cfbe5614 297 bool Create(wxWindow* parent, wxWindowID id = wxID_ANY,
7977b62a
BP
298 const wxPoint& pos = wxDefaultPosition,
299 const wxSize& size = wxDefaultSize,
cfbe5614 300 long style = wxTR_DEFAULT_STYLE,
7977b62a 301 const wxValidator& validator = wxDefaultValidator,
cfbe5614 302 const wxString& name = wxTreeCtrlNameStr);
23324ae1
FM
303
304 /**
6873eb5b 305 Deletes the specified item. A @c EVT_TREE_DELETE_ITEM event will be
23324ae1 306 generated.
7977b62a
BP
307
308 This function may cause a subsequent call to GetNextChild() to fail.
23324ae1 309 */
adaaa686 310 virtual void Delete(const wxTreeItemId& item);
23324ae1
FM
311
312 /**
313 Deletes all items in the control. Note that this may not generate
6873eb5b 314 @c EVT_TREE_DELETE_ITEM events under some Windows versions although
23324ae1
FM
315 normally such event is generated for each removed item.
316 */
adaaa686 317 virtual void DeleteAllItems();
23324ae1
FM
318
319 /**
7977b62a
BP
320 Deletes all children of the given item (but not the item itself). Note
321 that this will @b not generate any events unlike Delete() method.
322
323 If you have called SetItemHasChildren(), you may need to call it again
324 since DeleteChildren() does not automatically clear the setting.
23324ae1 325 */
adaaa686 326 virtual void DeleteChildren(const wxTreeItemId& item);
23324ae1
FM
327
328 /**
7977b62a 329 Starts editing the label of the given @a item. This function generates a
6873eb5b 330 @c EVT_TREE_BEGIN_LABEL_EDIT event which can be vetoed so that no text
7977b62a
BP
331 control will appear for in-place editing.
332
333 If the user changed the label (i.e. s/he does not press ESC or leave the
6873eb5b 334 text control without changes, a @c EVT_TREE_END_LABEL_EDIT event will be
7977b62a 335 sent which can be vetoed as well.
3c4f71cc 336
4cc4bfaf 337 @see EndEditLabel(), wxTreeEvent
23324ae1 338 */
cfbe5614 339 virtual wxTextCtrl *EditLabel(const wxTreeItemId& item,
b19b28c8 340 wxClassInfo* textCtrlClass = wxCLASSINFO(wxTextCtrl));
23324ae1
FM
341
342 /**
7977b62a
BP
343 Ends label editing. If @a cancelEdit is @true, the edit will be
344 cancelled.
345
346 @note
347 This function is currently supported under Windows only.
3c4f71cc 348
4cc4bfaf 349 @see EditLabel()
23324ae1 350 */
cfbe5614 351 virtual void EndEditLabel(const wxTreeItemId& item, bool discardChanges = false);
23324ae1
FM
352
353 /**
354 Scrolls and/or expands items to ensure that the given item is visible.
355 */
adaaa686 356 virtual void EnsureVisible(const wxTreeItemId& item);
23324ae1
FM
357
358 /**
359 Expands the given item.
360 */
adaaa686 361 virtual void Expand(const wxTreeItemId& item);
23324ae1
FM
362
363 /**
364 Expands all items in the tree.
365 */
366 void ExpandAll();
367
368 /**
369 Expands the given item and all its children recursively.
370 */
371 void ExpandAllChildren(const wxTreeItemId& item);
372
373 /**
7977b62a
BP
374 Retrieves the rectangle bounding the @a item. If @a textOnly is @true,
375 only the rectangle around the item's label will be returned, otherwise
376 the item's image is also taken into account.
377
378 The return value is @true if the rectangle was successfully retrieved or
379 @c @false if it was not (in this case @a rect is not changed) -- for
380 example, if the item is currently invisible.
381
382 Notice that the rectangle coordinates are logical, not physical ones.
383 So, for example, the x coordinate may be negative if the tree has a
384 horizontal scrollbar and its position is not 0.
385
1058f652
MB
386 @beginWxPerlOnly
387 In wxPerl this method only takes the @a item and
388 @a textOnly parameters and returns a @c Wx::Rect (or @c undef).
389 @endWxPerlOnly
23324ae1 390 */
fadc2df6
FM
391 virtual bool GetBoundingRect(const wxTreeItemId& item, wxRect& rect,
392 bool textOnly = false) const;
23324ae1
FM
393
394 /**
7977b62a
BP
395 Returns the buttons image list (from which application-defined button
396 images are taken).
397
23324ae1
FM
398 This function is only available in the generic version.
399 */
328f5751 400 wxImageList* GetButtonsImageList() const;
23324ae1
FM
401
402 /**
4cc4bfaf 403 Returns the number of items in the branch. If @a recursively is @true,
7977b62a
BP
404 returns the total number of descendants, otherwise only one level of
405 children is counted.
23324ae1 406 */
cfbe5614
FM
407 virtual size_t GetChildrenCount(const wxTreeItemId& item,
408 bool recursively = true) const;
23324ae1
FM
409
410 /**
411 Returns the number of items in the control.
412 */
adaaa686 413 virtual unsigned int GetCount() const;
23324ae1
FM
414
415 /**
7977b62a
BP
416 Returns the edit control being currently used to edit a label. Returns
417 @NULL if no label is being edited.
418
419 @note This is currently only implemented for wxMSW.
23324ae1 420 */
adaaa686 421 virtual wxTextCtrl* GetEditControl() const;
23324ae1
FM
422
423 /**
424 Returns the first child; call GetNextChild() for the next child.
7977b62a 425
23324ae1 426 For this enumeration function you must pass in a 'cookie' parameter
7977b62a
BP
427 which is opaque for the application but is necessary for the library to
428 make these functions reentrant (i.e. allow more than one enumeration on
429 one and the same object simultaneously). The cookie passed to
430 GetFirstChild() and GetNextChild() should be the same variable.
431
432 Returns an invalid tree item (i.e. wxTreeItemId::IsOk() returns @false)
433 if there are no further children.
434
1058f652
MB
435 @beginWxPerlOnly
436 In wxPerl this method only takes the @a item parameter, and
437 returns a 2-element list (item, cookie).
438 @endWxPerlOnly
439
4cc4bfaf 440 @see GetNextChild(), GetNextSibling()
23324ae1 441 */
fadc2df6
FM
442 virtual wxTreeItemId GetFirstChild(const wxTreeItemId& item,
443 wxTreeItemIdValue& cookie) const;
23324ae1
FM
444
445 /**
446 Returns the first visible item.
447 */
adaaa686 448 virtual wxTreeItemId GetFirstVisibleItem() const;
23324ae1 449
febebac1
VZ
450 /**
451 Returns the item last clicked or otherwise selected.
452 Unlike GetSelection(), it can be used whether or not
453 the control has the @c wxTR_MULTIPLE style.
454
455 @since 2.9.1
456 */
457 virtual wxTreeItemId GetFocusedItem() const;
458
5708ae18
VZ
459
460 /**
461 Clears the currently focused item
462
463 @since 2.9.1
464 */
465 virtual void ClearFocusedItem();
466
467 /**
468 Sets the currently focused item.
469
470 @param item
471 The item to make the current one. It must be valid.
472 @since 2.9.1
473 */
474 virtual void SetFocusedItem(const wxTreeItemId& item);
475
476
23324ae1
FM
477 /**
478 Returns the normal image list.
479 */
328f5751 480 wxImageList* GetImageList() const;
23324ae1
FM
481
482 /**
483 Returns the current tree control indentation.
484 */
cfbe5614 485 virtual unsigned int GetIndent() const;
23324ae1
FM
486
487 /**
488 Returns the background colour of the item.
489 */
adaaa686 490 virtual wxColour GetItemBackgroundColour(const wxTreeItemId& item) const;
23324ae1 491
23324ae1 492 /**
7977b62a 493 Returns the tree item data associated with the item.
23324ae1 494
483724a1 495 @see wxTreeItemData
23324ae1 496
1058f652
MB
497 @beginWxPerlOnly
498 wxPerl provides the following shortcut method:
499 - GetPlData(item): returns the Perl data
500 associated with the Wx::TreeItemData. It is just the same as
501 tree->GetItemData(item)->GetData().
502 @endWxPerlOnly
483724a1 503 */
adaaa686 504 virtual wxTreeItemData* GetItemData(const wxTreeItemId& item) const;
7977b62a
BP
505
506 /**
507 Returns the font of the item label.
508 */
adaaa686 509 virtual wxFont GetItemFont(const wxTreeItemId& item) const;
23324ae1
FM
510
511 /**
4cc4bfaf 512 Gets the specified item image. The value of @a which may be:
7977b62a
BP
513 - ::wxTreeItemIcon_Normal: to get the normal item image.
514 - ::wxTreeItemIcon_Selected: to get the selected item image (i.e. the
515 image which is shown when the item is currently selected).
516 - ::wxTreeItemIcon_Expanded: to get the expanded image (this only makes
517 sense for items which have children - then this image is shown when
518 the item is expanded and the normal image is shown when it is
519 collapsed).
520 - ::wxTreeItemIcon_SelectedExpanded: to get the selected expanded image
521 (which is shown when an expanded item is currently selected).
23324ae1 522 */
fadc2df6
FM
523 virtual int GetItemImage(const wxTreeItemId& item,
524 wxTreeItemIcon which = wxTreeItemIcon_Normal) const;
23324ae1
FM
525
526 /**
527 Returns the item's parent.
528 */
adaaa686 529 virtual wxTreeItemId GetItemParent(const wxTreeItemId& item) const;
23324ae1 530
03966fcb
RR
531 /**
532 Gets the specified item state.
533 */
534 int GetItemState(const wxTreeItemId& item) const;
535
23324ae1
FM
536 /**
537 Returns the item label.
538 */
adaaa686 539 virtual wxString GetItemText(const wxTreeItemId& item) const;
23324ae1
FM
540
541 /**
542 Returns the colour of the item label.
543 */
adaaa686 544 virtual wxColour GetItemTextColour(const wxTreeItemId& item) const;
23324ae1
FM
545
546 /**
7977b62a
BP
547 Returns the last child of the item (or an invalid tree item if this item
548 has no children).
3c4f71cc 549
7977b62a 550 @see GetFirstChild(), GetNextSibling(), GetLastChild()
23324ae1 551 */
adaaa686 552 virtual wxTreeItemId GetLastChild(const wxTreeItemId& item) const;
23324ae1
FM
553
554 /**
7977b62a
BP
555 Returns the next child; call GetFirstChild() for the first child. For
556 this enumeration function you must pass in a 'cookie' parameter which is
557 opaque for the application but is necessary for the library to make
558 these functions reentrant (i.e. allow more than one enumeration on one
559 and the same object simultaneously). The cookie passed to
560 GetFirstChild() and GetNextChild() should be the same.
561
23324ae1 562 Returns an invalid tree item if there are no further children.
3c4f71cc 563
1058f652
MB
564 @beginWxPerlOnly
565 In wxPerl this method returns a 2-element list
566 (item, cookie) instead of modifying its parameters.
567 @endWxPerlOnly
568
4cc4bfaf 569 @see GetFirstChild()
23324ae1 570 */
fadc2df6
FM
571 virtual wxTreeItemId GetNextChild(const wxTreeItemId& item,
572 wxTreeItemIdValue& cookie) const;
23324ae1
FM
573
574 /**
7977b62a
BP
575 Returns the next sibling of the specified item; call GetPrevSibling()
576 for the previous sibling.
577
23324ae1 578 Returns an invalid tree item if there are no further siblings.
3c4f71cc 579
4cc4bfaf 580 @see GetPrevSibling()
23324ae1 581 */
adaaa686 582 virtual wxTreeItemId GetNextSibling(const wxTreeItemId& item) const;
23324ae1
FM
583
584 /**
7977b62a
BP
585 Returns the next visible item or an invalid item if this item is the
586 last visible one.
587
588 @note The @a item itself must be visible.
23324ae1 589 */
adaaa686 590 virtual wxTreeItemId GetNextVisible(const wxTreeItemId& item) const;
23324ae1
FM
591
592 /**
7977b62a
BP
593 Returns the previous sibling of the specified item; call
594 GetNextSibling() for the next sibling.
595
23324ae1 596 Returns an invalid tree item if there are no further children.
3c4f71cc 597
4cc4bfaf 598 @see GetNextSibling()
23324ae1 599 */
adaaa686 600 virtual wxTreeItemId GetPrevSibling(const wxTreeItemId& item) const;
23324ae1
FM
601
602 /**
7977b62a
BP
603 Returns the previous visible item or an invalid item if this item is the
604 first visible one.
605
606 @note The @a item itself must be visible.
23324ae1 607 */
adaaa686 608 virtual wxTreeItemId GetPrevVisible(const wxTreeItemId& item) const;
23324ae1
FM
609
610 /**
7977b62a
BP
611 Returns @true if the control will use a quick calculation for the best
612 size, looking only at the first and last items. The default is @false.
3c4f71cc 613
4cc4bfaf 614 @see SetQuickBestSize()
23324ae1 615 */
328f5751 616 bool GetQuickBestSize() const;
23324ae1
FM
617
618 /**
619 Returns the root item for the tree control.
620 */
adaaa686 621 virtual wxTreeItemId GetRootItem() const;
23324ae1
FM
622
623 /**
7977b62a
BP
624 Returns the selection, or an invalid item if there is no selection. This
625 function only works with the controls without @c wxTR_MULTIPLE style,
febebac1
VZ
626 use GetSelections() for the controls which do have this style
627 or, if a single item is wanted, use GetFocusedItem().
23324ae1 628 */
adaaa686 629 virtual wxTreeItemId GetSelection() const;
23324ae1
FM
630
631 /**
7977b62a
BP
632 Fills the array of tree items passed in with the currently selected
633 items. This function can be called only if the control has the @c
634 wxTR_MULTIPLE style.
635
23324ae1 636 Returns the number of selected items.
03966fcb 637
1058f652
MB
638 @beginWxPerlOnly
639 In wxPerl this method takes no parameters and returns a list of
640 @c Wx::TreeItemId.
641 @endWxPerlOnly
23324ae1 642 */
cfbe5614 643 virtual size_t GetSelections(wxArrayTreeItemIds& selection) const;
23324ae1
FM
644
645 /**
7977b62a
BP
646 Returns the state image list (from which application-defined state
647 images are taken).
23324ae1 648 */
328f5751 649 wxImageList* GetStateImageList() const;
23324ae1
FM
650
651 /**
7977b62a
BP
652 Calculates which (if any) item is under the given @a point, returning
653 the tree item id at this point plus extra information @a flags. @a flags
654 is a bitlist of the following:
655
656 - @c wxTREE_HITTEST_ABOVE: Above the client area.
657 - @c wxTREE_HITTEST_BELOW: Below the client area.
658 - @c wxTREE_HITTEST_NOWHERE: In the client area but below the last item.
659 - @c wxTREE_HITTEST_ONITEMBUTTON: On the button associated with an item.
660 - @c wxTREE_HITTEST_ONITEMICON: On the bitmap associated with an item.
6873eb5b
FM
661 - @c wxTREE_HITTEST_ONITEMINDENT: In the indentation associated with an item.
662 - @c wxTREE_HITTEST_ONITEMLABEL: On the label (string) associated with an item.
7977b62a
BP
663 - @c wxTREE_HITTEST_ONITEMRIGHT: In the area to the right of an item.
664 - @c wxTREE_HITTEST_ONITEMSTATEICON: On the state icon for a tree view
6873eb5b 665 item that is in a user-defined state.
7977b62a
BP
666 - @c wxTREE_HITTEST_TOLEFT: To the right of the client area.
667 - @c wxTREE_HITTEST_TORIGHT: To the left of the client area.
03966fcb 668
1058f652
MB
669 @beginWxPerlOnly
670 In wxPerl this method only takes the @a point parameter
671 and returns a 2-element list (item, flags).
672 @endWxPerlOnly
23324ae1 673 */
328f5751 674 wxTreeItemId HitTest(const wxPoint& point, int& flags) const;
23324ae1 675
7977b62a 676
23324ae1 677 /**
7977b62a
BP
678 Inserts an item after a given one (@a previous).
679
680 The @a image and @a selImage parameters are an index within the normal
681 image list specifying the image to use for unselected and selected
682 items, respectively. If @a image -1 and @a selImage is -1, the same
683 image is used for both selected and unselected items.
23324ae1
FM
684 */
685 wxTreeItemId InsertItem(const wxTreeItemId& parent,
686 const wxTreeItemId& previous,
687 const wxString& text,
688 int image = -1,
689 int selImage = -1,
4cc4bfaf 690 wxTreeItemData* data = NULL);
7977b62a
BP
691
692 /**
693 Inserts an item before one identified
694 by its position (@a before). @a before must be less than the number of
695 children.
696
697 The @a image and @a selImage parameters are an index within the normal
698 image list specifying the image to use for unselected and selected
699 items, respectively. If @a image -1 and @a selImage is -1, the same
700 image is used for both selected and unselected items.
7977b62a 701 */
7c913512
FM
702 wxTreeItemId InsertItem(const wxTreeItemId& parent,
703 size_t before,
704 const wxString& text,
705 int image = -1,
706 int selImage = -1,
4cc4bfaf 707 wxTreeItemData* data = NULL);
23324ae1
FM
708
709 /**
710 Returns @true if the given item is in bold state.
7977b62a
BP
711
712 @see SetItemBold()
23324ae1 713 */
adaaa686 714 virtual bool IsBold(const wxTreeItemId& item) const;
23324ae1
FM
715
716 /**
7977b62a
BP
717 Returns @true if the control is empty (i.e. has no items, even no root
718 one).
23324ae1 719 */
328f5751 720 bool IsEmpty() const;
23324ae1
FM
721
722 /**
7977b62a
BP
723 Returns @true if the item is expanded (only makes sense if it has
724 children).
23324ae1 725 */
adaaa686 726 virtual bool IsExpanded(const wxTreeItemId& item) const;
23324ae1
FM
727
728 /**
729 Returns @true if the item is selected.
730 */
adaaa686 731 virtual bool IsSelected(const wxTreeItemId& item) const;
23324ae1
FM
732
733 /**
734 Returns @true if the item is visible on the screen.
735 */
adaaa686 736 virtual bool IsVisible(const wxTreeItemId& item) const;
23324ae1
FM
737
738 /**
739 Returns @true if the item has children.
740 */
adaaa686 741 virtual bool ItemHasChildren(const wxTreeItemId& item) const;
23324ae1
FM
742
743 /**
7977b62a
BP
744 Override this function in the derived class to change the sort order of
745 the items in the tree control. The function should return a negative,
746 zero or positive value if the first item is less than, equal to or
747 greater than the second one.
748
b19b28c8
FM
749 Please note that you @b must use wxRTTI macros wxDECLARE_DYNAMIC_CLASS()
750 and wxIMPLEMENT_DYNAMIC_CLASS() if you override this function because
7977b62a
BP
751 otherwise the base class considers that it is not overridden and uses
752 the default comparison, i.e. sorts the items alphabetically, which
23324ae1 753 allows it optimize away the calls to the virtual function completely.
7977b62a
BP
754
755 @see SortChildren()
23324ae1 756 */
fadc2df6
FM
757 virtual int OnCompareItems(const wxTreeItemId& item1,
758 const wxTreeItemId& item2);
23324ae1
FM
759
760 /**
7977b62a
BP
761 Appends an item as the first child of @a parent, return a new item id.
762
763 The @a image and @a selImage parameters are an index within the normal
764 image list specifying the image to use for unselected and selected
765 items, respectively. If @a image -1 and @a selImage is -1, the same
766 image is used for both selected and unselected items.
23324ae1
FM
767 */
768 wxTreeItemId PrependItem(const wxTreeItemId& parent,
769 const wxString& text,
770 int image = -1,
771 int selImage = -1,
4cc4bfaf 772 wxTreeItemData* data = NULL);
23324ae1
FM
773
774 /**
775 Scrolls the specified item into view.
776 */
adaaa686 777 virtual void ScrollTo(const wxTreeItemId& item);
23324ae1
FM
778
779 /**
b22a1070
VZ
780 Selects the given item.
781
782 In multiple selection controls, can be also used to deselect a
783 currently selected item if the value of @a select is @false.
784
785 Notice that calling this method will generate
786 @c wxEVT_COMMAND_TREE_SEL_CHANGING and @c wxEVT_COMMAND_TREE_SEL_CHANGED
787 events and that the change could be vetoed by the former event handler.
23324ae1 788 */
adaaa686 789 virtual void SelectItem(const wxTreeItemId& item, bool select = true);
23324ae1
FM
790
791 /**
7977b62a
BP
792 Sets the buttons image list (from which application-defined button
793 images are taken).
794
795 The button images assigned with this method will @b not be deleted by
796 @ref wxTreeCtrl "wxTreeCtrl"'s destructor, you must delete it yourself.
797 Setting or assigning the button image list enables the display of image
798 buttons. Once enabled, the only way to disable the display of button
799 images is to set the button image list to @NULL.
800
801 @note This function is only available in the generic version.
802
803 @see AssignButtonsImageList().
23324ae1
FM
804 */
805 void SetButtonsImageList(wxImageList* imageList);
806
807 /**
7977b62a
BP
808 Sets the normal image list. The image list assigned with this method
809 will @b not be deleted by @ref wxTreeCtrl "wxTreeCtrl"'s destructor, you
810 must delete it yourself.
811
812 @see AssignImageList().
23324ae1 813 */
adaaa686 814 virtual void SetImageList(wxImageList* imageList);
23324ae1
FM
815
816 /**
817 Sets the indentation for the tree control.
818 */
cfbe5614 819 virtual void SetIndent(unsigned int indent);
23324ae1
FM
820
821 /**
822 Sets the colour of the item's background.
823 */
fadc2df6
FM
824 virtual void SetItemBackgroundColour(const wxTreeItemId& item,
825 const wxColour& col);
23324ae1
FM
826
827 /**
7977b62a
BP
828 Makes item appear in bold font if @a bold parameter is @true or resets
829 it to the normal state.
830
831 @see IsBold()
23324ae1 832 */
adaaa686 833 virtual void SetItemBold(const wxTreeItemId& item, bool bold = true);
23324ae1 834
7977b62a
BP
835 /**
836 Sets the item client data.
837
727539d8
VZ
838 Notice that the client data previously associated with the @a item (if
839 any) is @em not freed by this function and so calling this function
840 multiple times for the same item will result in memory leaks unless you
841 delete the old item data pointer yourself.
842
1058f652
MB
843 @beginWxPerlOnly
844 wxPerl provides the following shortcut method:
845 - SetPlData(item, data): sets the Perl data
846 associated with the @c Wx::TreeItemData. It is just the same as
847 tree->GetItemData(item)->SetData(data).
848 @endWxPerlOnly
7977b62a 849 */
adaaa686 850 virtual void SetItemData(const wxTreeItemId& item, wxTreeItemData* data);
7977b62a
BP
851
852
23324ae1
FM
853 /**
854 Gives the item the visual feedback for Drag'n'Drop actions, which is
855 useful if something is dragged from the outside onto the tree control
856 (as opposed to a DnD operation within the tree control, which already
857 is implemented internally).
858 */
fadc2df6
FM
859 virtual void SetItemDropHighlight(const wxTreeItemId& item,
860 bool highlight = true);
23324ae1
FM
861
862 /**
7977b62a
BP
863 Sets the item's font. All items in the tree should have the same height
864 to avoid text clipping, so the fonts height should be the same for all
865 of them, although font attributes may vary.
3c4f71cc 866
4cc4bfaf 867 @see SetItemBold()
23324ae1 868 */
adaaa686 869 virtual void SetItemFont(const wxTreeItemId& item, const wxFont& font);
23324ae1
FM
870
871 /**
872 Force appearance of the button next to the item. This is useful to
873 allow the user to expand the items which don't have any children now,
874 but instead adding them only when needed, thus minimizing memory
875 usage and loading time.
876 */
fadc2df6
FM
877 virtual void SetItemHasChildren(const wxTreeItemId& item,
878 bool hasChildren = true);
23324ae1
FM
879
880 /**
7977b62a
BP
881 Sets the specified item's image. See GetItemImage() for the description
882 of the @a which parameter.
23324ae1 883 */
fadc2df6
FM
884 virtual void SetItemImage(const wxTreeItemId& item, int image,
885 wxTreeItemIcon which = wxTreeItemIcon_Normal);
23324ae1 886
03966fcb
RR
887 /**
888 Sets the specified item state. The value of @a state may be:
809ca837
RR
889 - @c wxTREE_ITEMSTATE_NONE: to disable the item state (the state image will
890 be not displayed).
891 - @c wxTREE_ITEMSTATE_NEXT: to set the next item state.
892 - @c wxTREE_ITEMSTATE_PREV: to set the previous item state.
03966fcb
RR
893 */
894 void SetItemState(const wxTreeItemId& item, int state);
895
23324ae1
FM
896 /**
897 Sets the item label.
898 */
adaaa686 899 virtual void SetItemText(const wxTreeItemId& item, const wxString& text);
23324ae1
FM
900
901 /**
902 Sets the colour of the item's text.
903 */
fadc2df6
FM
904 virtual void SetItemTextColour(const wxTreeItemId& item,
905 const wxColour& col);
23324ae1
FM
906
907 /**
7977b62a
BP
908 If @true is passed, specifies that the control will use a quick
909 calculation for the best size, looking only at the first and last items.
910 Otherwise, it will look at all items. The default is @false.
3c4f71cc 911
4cc4bfaf 912 @see GetQuickBestSize()
23324ae1
FM
913 */
914 void SetQuickBestSize(bool quickBestSize);
915
916 /**
7977b62a
BP
917 Sets the state image list (from which application-defined state images
918 are taken). Image list assigned with this method will @b not be deleted
919 by @ref wxTreeCtrl "wxTreeCtrl"'s destructor, you must delete it
920 yourself.
921
922 @see AssignStateImageList().
23324ae1 923 */
adaaa686 924 virtual void SetStateImageList(wxImageList* imageList);
23324ae1
FM
925
926 /**
7977b62a
BP
927 Sets the mode flags associated with the display of the tree control. The
928 new mode takes effect immediately.
929
930 @note Generic only; MSW ignores changes.
23324ae1
FM
931 */
932 void SetWindowStyle(long styles);
933
934 /**
7977b62a
BP
935 Sorts the children of the given item using OnCompareItems().
936 You should override that method to change the sort order (the default is
937 ascending case-sensitive alphabetical order).
3c4f71cc 938
4cc4bfaf 939 @see wxTreeItemData, OnCompareItems()
23324ae1 940 */
adaaa686 941 virtual void SortChildren(const wxTreeItemId& item);
23324ae1
FM
942
943 /**
944 Toggles the given item between collapsed and expanded states.
945 */
adaaa686 946 virtual void Toggle(const wxTreeItemId& item);
23324ae1
FM
947
948 /**
949 Toggles the given item between selected and unselected states. For
950 multiselection controls only.
951 */
952 void ToggleItemSelection(const wxTreeItemId& item);
953
954 /**
955 Removes the selection from the currently selected item (if any).
956 */
adaaa686 957 virtual void Unselect();
23324ae1
FM
958
959 /**
7977b62a
BP
960 This function either behaves the same as Unselect() if the control
961 doesn't have @c wxTR_MULTIPLE style, or removes the selection from all
962 items if it does have this style.
23324ae1 963 */
adaaa686 964 virtual void UnselectAll();
23324ae1
FM
965
966 /**
967 Unselects the given item. This works in multiselection controls only.
968 */
969 void UnselectItem(const wxTreeItemId& item);
5cb3a695
VZ
970
971 /**
972 Select all the immediate children of the given parent.
973
974 This function can be used with multiselection controls only.
975
976 @since 2.9.1
977 */
978 virtual void SelectChildren(const wxTreeItemId& parent);
23324ae1
FM
979};
980
981
e54c96f1 982
23324ae1
FM
983/**
984 @class wxTreeEvent
7c913512 985
7977b62a
BP
986 A tree event holds information about events associated with wxTreeCtrl
987 objects.
988
989 To process input from a tree control, use these event handler macros to
990 direct input to member functions that take a wxTreeEvent argument.
991
992 @beginEventTable{wxTreeEvent}
993 @event{EVT_TREE_BEGIN_DRAG(id, func)}
a1e92028 994 Begin dragging with the left mouse button. If you want to enable
4c51a665 995 left-dragging you need to intercept this event and explicitly call
a1e92028
VZ
996 wxTreeEvent::Allow(), as it's vetoed by default. Also notice that the
997 control must have an associated image list (see SetImageList()) to
998 drag its items under MSW.
7977b62a 999 @event{EVT_TREE_BEGIN_RDRAG(id, func)}
a1e92028 1000 Begin dragging with the right mouse button. If you want to enable
4c51a665 1001 right-dragging you need to intercept this event and explicitly call
a1e92028 1002 wxTreeEvent::Allow(), as it's vetoed by default.
7977b62a
BP
1003 @event{EVT_TREE_END_DRAG(id, func)}
1004 End dragging with the left or right mouse button.
1005 @event{EVT_TREE_BEGIN_LABEL_EDIT(id, func)}
1006 Begin editing a label. This can be prevented by calling Veto().
1007 @event{EVT_TREE_END_LABEL_EDIT(id, func)}
1008 Finish editing a label. This can be prevented by calling Veto().
1009 @event{EVT_TREE_DELETE_ITEM(id, func)}
1010 Delete an item.
1011 @event{EVT_TREE_GET_INFO(id, func)}
1012 Request information from the application.
1013 @event{EVT_TREE_SET_INFO(id, func)}
1014 Information is being supplied.
1015 @event{EVT_TREE_ITEM_ACTIVATED(id, func)}
1016 The item has been activated, i.e. chosen by double clicking it with
1017 mouse or from keyboard.
1018 @event{EVT_TREE_ITEM_COLLAPSED(id, func)}
1019 The item has been collapsed.
1020 @event{EVT_TREE_ITEM_COLLAPSING(id, func)}
1021 The item is being collapsed. This can be prevented by calling Veto().
1022 @event{EVT_TREE_ITEM_EXPANDED(id, func)}
1023 The item has been expanded.
1024 @event{EVT_TREE_ITEM_EXPANDING(id, func)}
1025 The item is being expanded. This can be prevented by calling Veto().
1026 @event{EVT_TREE_ITEM_RIGHT_CLICK(id, func)}
1027 The user has clicked the item with the right mouse button.
1028 @event{EVT_TREE_ITEM_MIDDLE_CLICK(id, func)}
1029 The user has clicked the item with the middle mouse button.
1030 @event{EVT_TREE_SEL_CHANGED(id, func)}
1031 Selection has changed.
1032 @event{EVT_TREE_SEL_CHANGING(id, func)}
1033 Selection is changing. This can be prevented by calling Veto().
1034 @event{EVT_TREE_KEY_DOWN(id, func)}
1035 A key has been pressed.
1036 @event{EVT_TREE_ITEM_GETTOOLTIP(id, func)}
1037 The opportunity to set the item tooltip is being given to the
1038 application (call SetToolTip()). Windows only.
1039 @event{EVT_TREE_ITEM_MENU(id, func)}
1040 The context menu for the selected item has been requested, either by a
1041 right click or by using the menu key.
1042 @event{EVT_TREE_STATE_IMAGE_CLICK(id, func)}
809ca837 1043 The state image has been clicked.
7977b62a 1044 @endEventTable
7c913512 1045
23324ae1
FM
1046 @library{wxbase}
1047 @category{events}
7c913512 1048
e54c96f1 1049 @see wxTreeCtrl
23324ae1
FM
1050*/
1051class wxTreeEvent : public wxNotifyEvent
1052{
1053public:
1054 /**
23324ae1
FM
1055 Constructor, used by wxWidgets itself only.
1056 */
cfbe5614
FM
1057 wxTreeEvent(wxEventType commandType, wxTreeCtrl* tree,
1058 const wxTreeItemId& item = wxTreeItemId());
23324ae1
FM
1059
1060 /**
1061 Returns the item (valid for all events).
1062 */
328f5751 1063 wxTreeItemId GetItem() const;
23324ae1
FM
1064
1065 /**
7977b62a
BP
1066 Returns the key code if the event is a key event. Use GetKeyEvent() to
1067 get the values of the modifier keys for this event (i.e. Shift or Ctrl).
23324ae1 1068 */
328f5751 1069 int GetKeyCode() const;
23324ae1
FM
1070
1071 /**
6873eb5b 1072 Returns the key event for @c EVT_TREE_KEY_DOWN events.
23324ae1 1073 */
cfbe5614 1074 const wxKeyEvent& GetKeyEvent() const;
23324ae1
FM
1075
1076 /**
1077 Returns the label if the event is a begin or end edit label event.
1078 */
cfbe5614 1079 const wxString& GetLabel() const;
23324ae1
FM
1080
1081 /**
6873eb5b
FM
1082 Returns the old item index (valid for @c EVT_TREE_ITEM_CHANGING and
1083 @c EVT_TREE_ITEM_CHANGED events).
23324ae1 1084 */
328f5751 1085 wxTreeItemId GetOldItem() const;
23324ae1
FM
1086
1087 /**
1088 Returns the position of the mouse pointer if the event is a drag or
1089 menu-context event.
7977b62a
BP
1090
1091 In both cases the position is in client coordinates - i.e. relative to
1092 the wxTreeCtrl window (so that you can pass it directly to e.g.
1093 wxWindow::PopupMenu()).
23324ae1 1094 */
328f5751 1095 wxPoint GetPoint() const;
23324ae1
FM
1096
1097 /**
7977b62a 1098 Returns @true if the label edit was cancelled. This should be called
6873eb5b 1099 from within an @c EVT_TREE_END_LABEL_EDIT handler.
23324ae1 1100 */
328f5751 1101 bool IsEditCancelled() const;
23324ae1
FM
1102
1103 /**
6873eb5b 1104 Set the tooltip for the item (valid for @c EVT_TREE_ITEM_GETTOOLTIP
7977b62a 1105 events). Windows only.
23324ae1
FM
1106 */
1107 void SetToolTip(const wxString& tooltip);
1108};
2c033d4a
RD
1109
1110
1111wxEventType wxEVT_COMMAND_TREE_BEGIN_DRAG;
1112wxEventType wxEVT_COMMAND_TREE_BEGIN_RDRAG;
1113wxEventType wxEVT_COMMAND_TREE_BEGIN_LABEL_EDIT;
1114wxEventType wxEVT_COMMAND_TREE_END_LABEL_EDIT;
1115wxEventType wxEVT_COMMAND_TREE_DELETE_ITEM;
1116wxEventType wxEVT_COMMAND_TREE_GET_INFO;
1117wxEventType wxEVT_COMMAND_TREE_SET_INFO;
1118wxEventType wxEVT_COMMAND_TREE_ITEM_EXPANDED;
1119wxEventType wxEVT_COMMAND_TREE_ITEM_EXPANDING;
1120wxEventType wxEVT_COMMAND_TREE_ITEM_COLLAPSED;
1121wxEventType wxEVT_COMMAND_TREE_ITEM_COLLAPSING;
1122wxEventType wxEVT_COMMAND_TREE_SEL_CHANGED;
1123wxEventType wxEVT_COMMAND_TREE_SEL_CHANGING;
1124wxEventType wxEVT_COMMAND_TREE_KEY_DOWN;
1125wxEventType wxEVT_COMMAND_TREE_ITEM_ACTIVATED;
1126wxEventType wxEVT_COMMAND_TREE_ITEM_RIGHT_CLICK;
1127wxEventType wxEVT_COMMAND_TREE_ITEM_MIDDLE_CLICK;
1128wxEventType wxEVT_COMMAND_TREE_END_DRAG;
1129wxEventType wxEVT_COMMAND_TREE_STATE_IMAGE_CLICK;
1130wxEventType wxEVT_COMMAND_TREE_ITEM_GETTOOLTIP;
1131wxEventType wxEVT_COMMAND_TREE_ITEM_MENU;
1132