]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/notebook.tex
clarified alpha support status (bug 1710013)
[wxWidgets.git] / docs / latex / wx / notebook.tex
CommitLineData
3972fb49
JS
1\section{\class{wxNotebook}}\label{wxnotebook}
2
3This class represents a notebook control, which manages multiple windows with associated tabs.
4
5To use the class, create a wxNotebook object and call \helpref{AddPage}{wxnotebookaddpage} or \helpref{InsertPage}{wxnotebookinsertpage},
6passing a window to be used as the page. Do not explicitly delete the window for a page that is currently
7managed by wxNotebook.
8
9{\bf wxNotebookPage} is a typedef for wxWindow.
10
11\wxheading{Derived from}
12
2d9152d5 13wxBookCtrlBase (see \helpref{wxBookCtrl overview}{wxbookctrloverview})\\
3972fb49
JS
14\helpref{wxControl}{wxcontrol}\\
15\helpref{wxWindow}{wxwindow}\\
16\helpref{wxEvtHandler}{wxevthandler}\\
17\helpref{wxObject}{wxobject}
18
954b8ae6
JS
19\wxheading{Include files}
20
21<wx/notebook.h>
22
da27bd0b
VZ
23\wxheading{Window styles}
24
25\twocolwidtha{5cm}
26\begin{twocollist}\itemsep=0pt
1d3f4b50 27\twocolitem{\windowstyle{wxNB\_TOP}}{Place tabs on the top side.}
df10208f
VZ
28\twocolitem{\windowstyle{wxNB\_LEFT}}{Place tabs on the left side.}
29\twocolitem{\windowstyle{wxNB\_RIGHT}}{Place tabs on the right side.}
30\twocolitem{\windowstyle{wxNB\_BOTTOM}}{Place tabs under instead of above the notebook pages.}
2b5f62a0
VZ
31\twocolitem{\windowstyle{wxNB\_FIXEDWIDTH}}{(Windows only) All tabs will have same width.}
32\twocolitem{\windowstyle{wxNB\_MULTILINE}}{(Windows only) There can be several rows of tabs.}
25057aba 33\twocolitem{\windowstyle{wxNB\_NOPAGETHEME}}{(Windows only) Display a solid colour on notebook pages, and not a gradient, which can reduce performance.}
03d77609 34\twocolitem{\windowstyle{wxNB\_FLAT}}{(Windows CE only) Show tabs in a flat style.}
f6bcfd97 35
da27bd0b
VZ
36\end{twocollist}
37
df10208f
VZ
38The styles \texttt{wxNB\_LEFT}, \texttt{RIGHT} and \texttt{BOTTOM} are not
39supported under Microsoft Windows XP when using visual themes.
40
f6bcfd97
BP
41See also \helpref{window styles overview}{windowstyles}.
42
1d2bd847 43\input noteevt.inc
3972fb49 44
25057aba
JS
45\wxheading{Page backgrounds}
46
47On Windows XP, the default theme paints a gradient on the notebook's pages.
48If you wish to suppress this theme, for aesthetic or performance reasons,
49there are three ways of doing it. You can use wxNB\_NOPAGETHEME to disable
9804d540 50themed drawing for a particular notebook, you can call {\tt wxSystemOptions::SetOption}
25057aba
JS
51to disable it for the whole application, or you can disable it for individual
52pages by using {\tt SetBackgroundColour}.
53
54To disable themed pages globally:
55
56\begin{verbatim}
57 wxSystemOptions::SetOption(wxT("msw.notebook.themed-background"), 0);
58\end{verbatim}
59
60Set the value to 1 to enable it again.
61
62To give a single page a solid background that more or less fits in with the
63overall theme, use:
64
65\begin{verbatim}
66 wxColour col = notebook->GetThemeBackgroundColour();
67 if (col.Ok())
68 {
69 page->SetBackgroundColour(col);
70 }
71\end{verbatim}
72
73On platforms other than Windows, or if the application is not using Windows
74themes, {\tt GetThemeBackgroundColour} will return an uninitialised colour object,
75and the above code will therefore work on all platforms.
76
3972fb49
JS
77\wxheading{See also}
78
b742a43b 79\helpref{wxBookCtrl}{wxbookctrloverview}, \helpref{wxNotebookEvent}{wxnotebookevent}, \helpref{wxImageList}{wximagelist}, \helpref{notebook sample}{samplenotebook}\rtfsp
3972fb49
JS
80
81\latexignore{\rtfignore{\wxheading{Members}}}
82
dcbd177f 83\membersection{wxNotebook::wxNotebook}\label{wxnotebookctor}
3972fb49
JS
84
85\func{}{wxNotebook}{\void}
86
87Default constructor.
88
89\func{}{wxNotebook}{\param{wxWindow*}{ parent}, \param{wxWindowID }{id}, \param{const wxPoint\&}{ pos = wxDefaultPosition},
630ad6c6 90 \param{const wxSize\&}{ size = wxDefaultSize}, \param{long}{ style = 0}, \param{const wxString\& }{name = wxNotebookNameStr}}
3972fb49
JS
91
92Constructs a notebook control.
93
5fa399c9
JS
94Note that sometimes you can reduce flicker by passing the wxCLIP\_CHILDREN window style.
95
3972fb49
JS
96\wxheading{Parameters}
97
98\docparam{parent}{The parent window. Must be non-NULL.}
99
100\docparam{id}{The window identifier.}
101
102\docparam{pos}{The window position.}
103
104\docparam{size}{The window size.}
105
f6bcfd97 106\docparam{style}{The window style. See \helpref{wxNotebook}{wxnotebook}.}
3972fb49 107
8c517ddd
VZ
108\docparam{name}{The name of the control (used only under Motif).}
109
21db32c1 110
dcbd177f 111\membersection{wxNotebook::\destruct{wxNotebook}}\label{wxnotebookdtor}
3972fb49
JS
112
113\func{}{\destruct{wxNotebook}}{\void}
114
115Destroys the wxNotebook object.
116
21db32c1 117
3972fb49
JS
118\membersection{wxNotebook::AddPage}\label{wxnotebookaddpage}
119
120\func{bool}{AddPage}{\param{wxNotebookPage*}{ page},
121 \param{const wxString\&}{ text},
cc81d32f 122 \param{bool}{ select = false},
3972fb49
JS
123 \param{int}{ imageId = -1}}
124
125Adds a new page.
126
f65a450a
VZ
127The call to this function may generate the page changing events.
128
3972fb49
JS
129\wxheading{Parameters}
130
131\docparam{page}{Specifies the new page.}
132
133\docparam{text}{Specifies the text for the new page.}
134
135\docparam{select}{Specifies whether the page should be selected.}
136
137\docparam{imageId}{Specifies the optional image index for the new page.}
138
139\wxheading{Return value}
140
cc81d32f 141true if successful, false otherwise.
3972fb49
JS
142
143\wxheading{Remarks}
144
145Do not delete the page, it will be deleted by the notebook.
146
147\wxheading{See also}
148
149\helpref{wxNotebook::InsertPage}{wxnotebookinsertpage}
150
21db32c1 151
3972fb49
JS
152\membersection{wxNotebook::AdvanceSelection}\label{wxnotebookadvanceselection}
153
cc81d32f 154\func{void}{AdvanceSelection}{\param{bool}{ forward = true}}
3972fb49
JS
155
156Cycles through the tabs.
157
f65a450a
VZ
158The call to this function generates the page changing events.
159
21db32c1 160
b656febd
VS
161\membersection{wxNotebook::AssignImageList}\label{wxnotebookassignimagelist}
162
163\func{void}{AssignImageList}{\param{wxImageList*}{ imageList}}
164
165Sets the image list for the page control and takes ownership of
166the list.
167
168\wxheading{See also}
169
170\helpref{wxImageList}{wximagelist},
171\helpref{SetImageList}{wxnotebooksetimagelist}
172
21db32c1 173
3972fb49
JS
174\membersection{wxNotebook::Create}\label{wxnotebookcreate}
175
176\func{bool}{Create}{\param{wxWindow*}{ parent}, \param{wxWindowID }{id}, \param{const wxPoint\&}{ pos = wxDefaultPosition},
630ad6c6 177 \param{const wxSize\&}{ size}, \param{long}{ style = 0}, \param{const wxString\& }{name = wxNotebookNameStr}}
3972fb49 178
dcbd177f 179Creates a notebook control. See \helpref{wxNotebook::wxNotebook}{wxnotebookctor} for a description
3972fb49
JS
180of the parameters.
181
21db32c1 182
3972fb49
JS
183\membersection{wxNotebook::DeleteAllPages}\label{wxnotebookdeleteallpages}
184
185\func{bool}{DeleteAllPages}{\void}
186
187Deletes all pages.
188
21db32c1 189
3972fb49
JS
190\membersection{wxNotebook::DeletePage}\label{wxnotebookdeletepage}
191
74f8518b 192\func{bool}{DeletePage}{\param{size\_t}{ page}}
3972fb49 193
621793f4 194Deletes the specified page, and the associated window.
3972fb49 195
f65a450a
VZ
196The call to this function generates the page changing events.
197
21db32c1
VZ
198
199\membersection{wxNotebook::GetCurrentPage}\label{wxnotebookgetcurrentpage}
200
201\constfunc{wxWindow *}{GetCurrentPage}{\void}
202
93664d1b 203Returns the currently selected notebook page or \NULL.
21db32c1
VZ
204
205
3972fb49
JS
206\membersection{wxNotebook::GetImageList}\label{wxnotebookgetimagelist}
207
208\constfunc{wxImageList*}{GetImageList}{\void}
209
210Returns the associated image list.
211
212\wxheading{See also}
213
214\helpref{wxImageList}{wximagelist}, \helpref{wxNotebook::SetImageList}{wxnotebooksetimagelist}
215
21db32c1 216
3972fb49
JS
217\membersection{wxNotebook::GetPage}\label{wxnotebookgetpage}
218
74f8518b 219\func{wxNotebookPage*}{GetPage}{\param{size\_t}{ page}}
3972fb49
JS
220
221Returns the window at the given page position.
222
21db32c1 223
3972fb49
JS
224\membersection{wxNotebook::GetPageCount}\label{wxnotebookgetpagecount}
225
74f8518b 226\constfunc{size\_t}{GetPageCount}{\void}
3972fb49
JS
227
228Returns the number of pages in the notebook control.
229
21db32c1 230
3972fb49
JS
231\membersection{wxNotebook::GetPageImage}\label{wxnotebookgetpageimage}
232
74f8518b 233\constfunc{int}{GetPageImage}{\param{size\_t }{nPage}}
3972fb49
JS
234
235Returns the image index for the given page.
236
21db32c1 237
3972fb49
JS
238\membersection{wxNotebook::GetPageText}\label{wxnotebookgetpagetext}
239
74f8518b 240\constfunc{wxString}{GetPageText}{\param{size\_t }{nPage}}
3972fb49
JS
241
242Returns the string for the given page.
243
21db32c1 244
3972fb49
JS
245\membersection{wxNotebook::GetRowCount}\label{wxnotebookgetrowcount}
246
247\constfunc{int}{GetRowCount}{\void}
248
249Returns the number of rows in the notebook control.
250
21db32c1 251
3972fb49
JS
252\membersection{wxNotebook::GetSelection}\label{wxnotebookgetselection}
253
254\constfunc{int}{GetSelection}{\void}
255
f0125ede
VZ
256Returns the currently selected page, or $-1$ if none was selected.
257
258Note that this method may return either the previously or newly selected page
259when called from the {\tt EVT\_NOTEBOOK\_PAGE\_CHANGED} handler depending on
260the platform and so\rtfsp
261\helpref{wxNotebookEvent::GetSelection}{wxnotebookeventgetselection} should be
262used instead in this case.
3972fb49 263
25057aba
JS
264\membersection{wxNotebook::GetThemeBackgroundColour}\label{wxnotebookgetthemebackgroundcolour}
265
266\constfunc{wxColour}{GetThemeBackgroundColour}{\void}
267
268If running under Windows and themes are enabled for the application, this function
269returns a suitable colour for painting the background of a notebook page, and can be passed
270to {\tt SetBackgroundColour}. Otherwise, an uninitialised colour will be returned.
21db32c1 271
e450aa69
VZ
272\membersection{wxNotebook::HitTest}\label{wxnotebookhittest}
273
274\func{int}{HitTest}{\param{const wxPoint\&}{ pt}, \param{long}{ *flags = {\tt NULL}}}
275
630ad6c6 276Returns the index of the tab at the specified position or {\tt wxNOT\_FOUND}
154b6b0f 277if none. If {\it flags} parameter is non-{\tt NULL}, the position of the point
e450aa69
VZ
278inside the tab is returned as well.
279
e450aa69
VZ
280\wxheading{Parameters}
281
282\docparam{pt}{Specifies the point for the hit test.}
283
284\docparam{flags}{Return value for detailed information. One of the following values:
285\twocolwidtha{7cm}
286\begin{twocollist}\itemsep=0pt
9804d540
WS
287\twocolitem{{\bf wxBK\_HITTEST\_NOWHERE}}{There was no tab under this point.}
288\twocolitem{{\bf wxBK\_HITTEST\_ONICON}}{The point was over an icon (currently wxMSW only).}
289\twocolitem{{\bf wxBK\_HITTEST\_ONLABEL}}{The point was over a label (currently wxMSW only).}
290\twocolitem{{\bf wxBK\_HITTEST\_ONITEM}}{The point was over an item, but not on the label or icon.}
291\twocolitem{{\bf wxBK\_HITTEST\_ONPAGE}}{The point was over a currently selected page, not over any tab. Note that this flag is present only if {\tt wxNOT\_FOUND} is returned.}
e450aa69
VZ
292\end{twocollist}
293}
294
295\wxheading{Return value}
296
297Returns the zero-based tab index or {\tt wxNOT\_FOUND} if there is no tab is at
298the specified position.
299
300
21db32c1 301
3972fb49
JS
302\membersection{wxNotebook::InsertPage}\label{wxnotebookinsertpage}
303
74f8518b 304\func{bool}{InsertPage}{\param{size\_t}{ index}, \param{wxNotebookPage*}{ page},
3972fb49 305 \param{const wxString\&}{ text},
cc81d32f 306 \param{bool}{ select = false},
3972fb49
JS
307 \param{int}{ imageId = -1}}
308
309Inserts a new page at the specified position.
310
311\wxheading{Parameters}
312
313\docparam{index}{Specifies the position for the new page.}
314
315\docparam{page}{Specifies the new page.}
316
317\docparam{text}{Specifies the text for the new page.}
318
319\docparam{select}{Specifies whether the page should be selected.}
320
321\docparam{imageId}{Specifies the optional image index for the new page.}
322
323\wxheading{Return value}
324
cc81d32f 325true if successful, false otherwise.
3972fb49
JS
326
327\wxheading{Remarks}
328
329Do not delete the page, it will be deleted by the notebook.
330
331\wxheading{See also}
332
333\helpref{wxNotebook::AddPage}{wxnotebookaddpage}
334
21db32c1 335
3972fb49
JS
336\membersection{wxNotebook::OnSelChange}\label{wxnotebookonselchange}
337
338\func{void}{OnSelChange}{\param{wxNotebookEvent\&}{ event}}
339
340An event handler function, called when the page selection is changed.
341
342\wxheading{See also}
343
344\helpref{wxNotebookEvent}{wxnotebookevent}
345
21db32c1 346
621793f4
JS
347\membersection{wxNotebook::RemovePage}\label{wxnotebookremovepage}
348
74f8518b 349\func{bool}{RemovePage}{\param{size\_t}{ page}}
621793f4
JS
350
351Deletes the specified page, without deleting the associated window.
352
21db32c1 353
3972fb49
JS
354\membersection{wxNotebook::SetImageList}\label{wxnotebooksetimagelist}
355
356\func{void}{SetImageList}{\param{wxImageList*}{ imageList}}
357
b656febd
VS
358Sets the image list for the page control. It does not take
359ownership of the image list, you must delete it yourself.
3972fb49
JS
360
361\wxheading{See also}
362
b656febd
VS
363\helpref{wxImageList}{wximagelist},
364\helpref{AssignImageList}{wxnotebookassignimagelist}
3972fb49 365
21db32c1 366
3972fb49
JS
367\membersection{wxNotebook::SetPadding}\label{wxnotebooksetpadding}
368
369\func{void}{SetPadding}{\param{const wxSize\&}{ padding}}
370
371Sets the amount of space around each page's icon and label, in pixels.
372
b318dc42
JS
373{\bf NB:} The vertical padding cannot be changed in wxGTK.
374
21db32c1 375
3972fb49
JS
376\membersection{wxNotebook::SetPageSize}\label{wxnotebooksetpagesize}
377
378\func{void}{SetPageSize}{\param{const wxSize\&}{ size}}
379
380Sets the width and height of the pages.
381
b318dc42
JS
382{\bf NB:} This method is currently not implemented for wxGTK.
383
21db32c1 384
3972fb49
JS
385\membersection{wxNotebook::SetPageImage}\label{wxnotebooksetpageimage}
386
74f8518b 387\func{bool}{SetPageImage}{\param{size\_t}{ page}, \param{int }{image}}
3972fb49
JS
388
389Sets the image index for the given page. {\it image} is an index into
390the image list which was set with \helpref{wxNotebook::SetImageList}{wxnotebooksetimagelist}.
391
21db32c1 392
3972fb49
JS
393\membersection{wxNotebook::SetPageText}\label{wxnotebooksetpagetext}
394
74f8518b 395\func{bool}{SetPageText}{\param{size\_t}{ page}, \param{const wxString\& }{text}}
3972fb49
JS
396
397Sets the text for the given page.
398
21db32c1 399
3972fb49
JS
400\membersection{wxNotebook::SetSelection}\label{wxnotebooksetselection}
401
74f8518b 402\func{int}{SetSelection}{\param{size\_t}{ page}}
3972fb49
JS
403
404Sets the selection for the given page, returning the previous selection.
405
f65a450a
VZ
406The call to this function generates the page changing events.
407
1d6fcbcc
VZ
408This function is deprecated and should not be used in new code. Please use the
409\helpref{ChangeSelection}{wxnotebookchangeselection} function instead.
410
3972fb49
JS
411\wxheading{See also}
412
413\helpref{wxNotebook::GetSelection}{wxnotebookgetselection}
414
415
1d6fcbcc
VZ
416\membersection{wxNotebook::ChangeSelection}\label{wxnotebookchangeselection}
417
418\func{int}{ChangeSelection}{\param{size\_t}{ page}}
419
420Changes the selection for the given page, returning the previous selection.
421
422The call to this function \emph{does not} generate the page changing events.
423This is the only difference with \helpref{SetSelection}{wxnotebooksetselection}.
424See \helpref{this topic}{progevent} for more info.
62a268cc 425