1 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
3 %% Purpose: wxTreebook documentation
4 %% Author: Evgeniy Tarassov
8 %% Copyright: (c) 2005 Vadim Zeitlin <vadim@wxwindows.org>
9 %% License: wxWindows license
10 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
12 \section{\class{wxTreebook
}}\label{wxtreebook
}
14 This class is an extension of the Notebook class that allows a tree structured
15 set of pages to be shown in a control.
16 A classic example is a netscape preferences dialog that shows a tree
17 of preference sections on the left and select section page on the right.
19 To use the class simply create it and populate with pages using
20 \helpref{InsertPage
}{wxtreebookinsertpage
},
21 \helpref{InsertSubPage
}{wxtreebookinsertsubpage
},
22 \helpref{AddPage
}{wxtreebookaddpage
},
23 \helpref{AddSubPage
}{wxtreebookaddsubpage
}.
25 If your tree is no more than $
1$ level in depth then you could
26 simply use
\helpref{AddPage
}{wxtreebookaddpage
} and
27 \helpref{AddSubPage
}{wxtreebookaddsubpage
} to sequentially populate your tree
28 by adding at every step a page or a subpage to the end of the tree.
31 \wxheading{Derived from
}
33 wxBookCtrlBase (see
\helpref{wxBookCtrl overview
}{wxbookctrloverview
})\\
34 \helpref{wxControl
}{wxcontrol
}\\
35 \helpref{wxWindow
}{wxwindow
}\\
36 \helpref{wxEvtHandler
}{wxevthandler
}\\
37 \helpref{wxObject
}{wxobject
}
40 \wxheading{Include files
}
44 \input treebookevt.inc
49 \helpref{wxNotebook
}{wxnotebook
},
\helpref{wxTreebookEvent
}{wxtreebookevent
},
\helpref{wxImageList
}{wximagelist
},
\helpref{notebook sample
}{samplenotebook
}
53 \latexignore{\rtfignore{\wxheading{Members
}}}
56 \membersection{wxTreebook::wxTreebook
}\label{wxtreebookwxtreebook
}
58 \func{}{wxTreebook
}{\void}
64 \param{wxWindow*
}{parent
},
65 \param{wxWindowID
}{id
},
66 \param{const wxPoint\&
}{pos = wxDefaultPosition
},
67 \param{const wxSize\&
}{size = wxDefaultSize
},
68 \param{long
}{style = wxTBK
\_DEFAULT},
69 \param{const wxString\&
}{name = wxEmptyString
}}
71 Creates an empty TreeBook control.
73 \wxheading{Parameters
}
75 \docparam{parent
}{The parent window. Must be non-NULL.
}
77 \docparam{id
}{The window identifier.
}
79 \docparam{pos
}{The window position.
}
81 \docparam{size
}{The window size.
}
83 \docparam{style
}{The window style. See
\helpref{wxNotebook
}{wxnotebook
}.
}
85 \docparam{name
}{The name of the control (used only under Motif).
}
89 \membersection{wxTreebook::
\destruct{wxTreebook
}}\label{wxtreebookdtor
}
91 \func{}{\destruct{wxTreebook
}}{\void}
93 Destroys the wxTreebook object.
95 Also deletes all the pages owned by the control (inserted previously into it).
99 \membersection{wxTreebook::AddPage
}\label{wxtreebookaddpage
}
101 \func{bool
}{AddPage
}{
102 \param{wxWindow*
}{page
},
103 \param{const wxString\&
}{text
},
104 \param{bool
}{bSelect = false
},
105 \param{int
}{imageId = wxNOT
\_FOUND}}
107 Adds a new page. The page is placed at the topmost level after all other pages.
108 \NULL could be specified for page to create an empty page.
112 \membersection{wxTreebook::AddSubPage
}\label{wxtreebookaddsubpage
}
114 \func{bool
}{AddSubPage
}{\param{wxWindow*
}{page
},
\param{const wxString\&
}{text
},
\param{bool
}{bSelect = false
},
\param{int
}{imageId = wxNOT
\_FOUND}}
116 Adds a new child-page to the last top-level page.
117 \NULL could be specified for page to create an empty page.
121 \membersection{wxTreebook::AssignImageList
}\label{wxtreebookassignimagelist
}
123 \func{void
}{AssignImageList
}{\param{wxImageList*
}{imageList
}}
125 Sets the image list for the page control and takes ownership of the list.
129 \helpref{wxImageList
}{wximagelist
},
\helpref{SetImageList
}{wxtreebooksetimagelist
}
133 \membersection{wxTreebook::CollapseNode
}\label{wxtreebookcollapsenode
}
135 \func{bool
}{CollapseNode
}{\param{size
\_t }{pageId
}}
137 Shortcut for
\helpref{ExpandNode
}{wxtreebookexpandnode
}(pageId, false).
141 \membersection{wxTreebook::Create
}\label{wxtreebookcreate
}
143 \func{bool
}{Create
}{\param{wxWindow*
}{parent
},
\param{wxWindowID
}{id
},
\param{const wxPoint\&
}{pos = wxDefaultPosition
},
\param{const wxSize\&
}{size = wxDefaultSize
},
\param{long
}{style = wxTBK
\_DEFAULT},
\param{const wxString\&
}{name = wxEmptyString
}}
145 Creates a treebook control. See
\helpref{wxTreebook::wxTreebook
}{wxtreebookwxtreebook
} for the description of the parameters.
149 \membersection{wxTreebook::DeleteAllPages
}\label{wxtreebookdeleteallpages
}
151 \func{bool
}{DeleteAllPages
}{\void}
153 Deletes all pages inserted into the treebook. No event is generated.
157 \membersection{wxTreebook::DeletePage
}\label{wxtreebookdeletepage
}
159 \func{bool
}{DeletePage
}{\param{size
\_t }{pagePos
}}
161 Deletes the page at the specified position and all its children. Could trigger page selection change
162 in a case when selected page is removed. In that case its parent is selected
163 (or the next page if no parent).
167 \membersection{wxTreebook::ExpandNode
}\label{wxtreebookexpandnode
}
169 \func{bool
}{ExpandNode
}{\param{size
\_t }{pageId
},
\param{bool
}{expand = true
}}
171 Expands (collapses) the pageId node. Returns the previous state.
172 May generate page changing events (if selected page
173 is under the collapsed branch, then its parent is autoselected).
176 \membersection{wxTreebook::GetPageImage
}\label{wxtreebookgetpageimage
}
178 \constfunc{int
}{GetPageImage
}{\param{size
\_t }{n
}}
180 Returns the image index for the given page.
183 \membersection{wxTreebook::GetPageParent
}\label{wxtreebookgetpageparent
}
185 \constfunc{int
}{GetPageParent
}{\param{size
\_t }{page
}}
187 Returns the parent page of the given one or
\texttt{wxNOT
\_FOUND} if this is a
191 \membersection{wxTreebook::GetPageText
}\label{wxtreebookgetpagetext
}
193 \constfunc{wxString
}{GetPageText
}{\param{size
\_t }{n
}}
195 Returns the string for the given page.
199 \membersection{wxTreebook::GetSelection
}\label{wxtreebookgetselection
}
201 \constfunc{int
}{GetSelection
}{\void}
203 Returns the currently selected page, or wxNOT
\_FOUND if none was selected.
205 Note that this method may return either the previously or newly selected page
206 when called from the EVT
\_TREEBOOK\_PAGE\_CHANGED handler
207 depending on the platform and so wxTreebookEvent::GetSelection should be used instead in this case.
211 \membersection{wxTreebook::InsertPage
}\label{wxtreebookinsertpage
}
213 \func{bool
}{InsertPage
}{\param{size
\_t }{pagePos
},
\param{wxWindow*
}{page
},
\param{const wxString\&
}{text
},
\param{bool
}{bSelect = false
},
\param{int
}{imageId = wxNOT
\_FOUND}}
215 Inserts a new page just before the page indicated by pagePos.
216 The new page is placed before pagePos page and on the same level.
217 \NULL could be specified for page to create an empty page.
220 \membersection{wxTreebook::InsertSubPage
}\label{wxtreebookinsertsubpage
}
222 \func{bool
}{InsertSubPage
}{\param{size
\_t }{pagePos
},
\param{wxWindow*
}{page
},
\param{const wxString\&
}{text
},
\param{bool
}{bSelect = false
},
\param{int
}{imageId = wxNOT
\_FOUND}}
224 Inserts a sub page under the specified page.
226 \NULL could be specified for page to create an empty page.
229 \membersection{wxTreebook::IsNodeExpanded
}\label{wxtreebookisnodeexpanded
}
231 \constfunc{bool
}{IsNodeExpanded
}{\param{size
\_t }{pageId
}}
233 Gets the pagePos page state -- whether it is expanded or collapsed
237 \membersection{wxTreebook::SetImageList
}\label{wxtreebooksetimagelist
}
239 \func{void
}{SetImageList
}{\param{wxImageList*
}{imageList
}}
241 Sets the image list for the page control. It does not take ownership of the image list, you must delete it yourself.
245 \helpref{wxImageList
}{wximagelist
},
\helpref{AssignImageList
}{wxtreebookassignimagelist
}
249 \membersection{wxTreebook::SetPageImage
}\label{wxtreebooksetpageimage
}
251 \func{bool
}{SetPageImage
}{\param{size
\_t }{page
},
\param{int
}{imageId
}}
253 Sets the image index for the given page. ImageId is an index into the image list
254 which was set with
\helpref{SetImageList
}{wxtreebooksetimagelist
}.
258 \membersection{wxTreebook::SetPageText
}\label{wxtreebooksetpagetext
}
260 \func{bool
}{SetPageText
}{\param{size
\_t }{page
},
\param{const wxString\&
}{text
}}
262 Sets the text for the given page.
266 \membersection{wxTreebook::SetSelection
}\label{wxtreebooksetselection
}
268 \func{int
}{SetSelection
}{\param{size
\_t }{n
}}
270 Sets the selection for the given page, returning the previous selection.
272 The call to this function generates the page changing events.
274 This function is deprecated and should not be used in new code. Please use the
275 \helpref{ChangeSelection
}{wxtreebookchangeselection
} function instead.
279 \helpref{wxTreebook::GetSelection
}{wxtreebookgetselection
}
283 \membersection{wxTreebook::ChangeSelection
}\label{wxtreebookchangeselection
}
285 \func{int
}{ChangeSelection
}{\param{size
\_t}{ page
}}
287 Changes the selection for the given page, returning the previous selection.
289 The call to this function
\emph{does not
} generate the page changing events.
290 This is the only difference with
\helpref{SetSelection
}{wxtreebooksetselection
}.
291 See
\helpref{this topic
}{progevent
} for more info.