]> git.saurik.com Git - wxWidgets.git/blob - interface/wx/treebase.h
84ffd78598027b862e1c26260ffd45f82475f588
[wxWidgets.git] / interface / wx / treebase.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: treebase.h
3 // Purpose: interface of wxTreeItemId
4 // Author: wxWidgets team
5 // RCS-ID: $Id$
6 // Licence: wxWindows license
7 /////////////////////////////////////////////////////////////////////////////
8
9 /**
10 @class wxTreeItemId
11 @wxheader{treebase.h}
12
13 An opaque reference to a tree item.
14
15 @library{wxcore}
16 @category{misc}
17
18 @see wxTreeCtrl, wxTreeItemData, @ref overview_treectrl
19 */
20 class wxTreeItemId
21 {
22 public:
23 /**
24 Default constructor. A wxTreeItemId is not meant to be constructed
25 explicitly by the user; only those returned by the wxTreeCtrl functions
26 should be used.
27 */
28 wxTreeItemId();
29
30 /**
31 Returns @true if this instance is referencing a valid tree item.
32 */
33 bool IsOk() const;
34
35 //@{
36 /**
37 Operators for comparison between wxTreeItemId objects.
38 */
39 bool operator ==(const wxTreeItemId& item) const;
40 bool operator !=(const wxTreeItemId& item) const;
41 //@}
42
43 /**
44 Antonym of IsOk(), i.e. returns @true only if the item is not valid.
45 */
46 bool operator !() const;
47 };
48
49 /**
50 @class wxTreeItemData
51 @wxheader{treebase.h}
52
53 wxTreeItemData is some (arbitrary) user class associated with some item. The
54 main advantage of having this class is that wxTreeItemData objects are
55 destroyed automatically by the tree and, as this class has virtual
56 destructor, it means that the memory and any other resources associated with
57 a tree item will be automatically freed when it is deleted. Note that we
58 don't use wxObject as the base class for wxTreeItemData because the size of
59 this class is critical: in many applications, each tree leaf will have
60 wxTreeItemData associated with it and the number of leaves may be quite big.
61
62 Also please note that because the objects of this class are deleted by the
63 tree using the operator @c delete, they must always be allocated on the heap
64 using @c new.
65
66 @library{wxcore}
67 @category{containers}
68
69 @see wxTreeCtrl
70 */
71 class wxTreeItemData : public wxClientData
72 {
73 public:
74 /**
75 Default constructor.
76
77 @beginWxPythonOnly
78 The following methods are added in wxPython for accessing the object:
79 - GetData(): Returns a reference to the Python Object.
80 - SetData(obj): Associates a new Python Object with the wxTreeItemData.
81 @endWxPythonOnly
82 */
83 wxTreeItemData();
84
85 /**
86 Virtual destructor.
87 */
88 ~wxTreeItemData();
89
90 /**
91 Returns the item associated with this node.
92 */
93 const wxTreeItemId GetId();
94
95 /**
96 Sets the item associated with this node.
97 */
98 void SetId(const wxTreeItemId& id);
99 };
100
101 /**
102 Indicates which type to associate an image with a wxTreeCtrl item.
103
104 @see wxTreeCtrl::GetItemImage(), wxTreeCtrl::SetItemImage()
105 */
106 enum wxTreeItemIcon
107 {
108 /**
109 To get/set the item image for when the item is
110 @b not selected and @b not expanded.
111 */
112 wxTreeItemIcon_Normal,
113 /**
114 To get/set the item image for when the item is
115 @b selected and @b not expanded.
116 */
117 wxTreeItemIcon_Selected,
118 /**
119 To get/set the item image for when the item is
120 @b not selected and @b expanded.
121 */
122 wxTreeItemIcon_Expanded,
123 /**
124 To get/set the item image for when the item is
125 @b selected and @b expanded.
126 */
127 wxTreeItemIcon_SelectedExpanded,
128 wxTreeItemIcon_Max
129 };