]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/auinotebook.tex
wxBORDER_THEME now means 'use an appropriate themed border' on all plaforms
[wxWidgets.git] / docs / latex / wx / auinotebook.tex
CommitLineData
c0d9896a
BW
1%
2% automatically generated by HelpGen $Revision$ from
3% auibook.h at 11/Nov/06 22:56:01
4%
5
c0d9896a
BW
6\section{\class{wxAuiNotebook}}\label{wxauinotebook}
7
b88d16d3 8wxAuiNotebook is part of the wxAUI class framework.
683b60e9
BW
9See also \helpref{wxAUI overview}{wxauioverview}.
10
8ffbb0f8
JS
11wxAuiNotebook is a notebook control which implements many features common in applications with dockable panes.
12Specifically, wxAuiNotebook implements functionality which allows the user to rearrange tab order via drag-and-drop,
13split the tab window into many different splitter configurations, and toggle through different themes to customize
14the control's look and feel.
574c6e1a
BW
15
16An effort has been made to try to maintain an API as similar to that of wxNotebook.
17
8ffbb0f8
JS
18The default theme that is used is wxAuiDefaultTabArt, which provides a modern, glossy look and feel.
19The theme can be changed by calling \helpref{wxAuiNotebook::SetArtProvider}{wxauinotebooksetartprovider}.
574c6e1a 20
c0d9896a
BW
21\wxheading{Derived from}
22
7376079d
VZ
23\helpref{wxControl}{wxcontrol}\\
24\helpref{wxWindow}{wxwindow}\\
25\helpref{wxEvtHandler}{wxevthandler}\\
26\helpref{wxObject}{wxobject}
c0d9896a
BW
27
28\wxheading{Include files}
29
8ffbb0f8 30<wx/aui/auibook.h>
c0d9896a 31
a7af285d
VZ
32\wxheading{Library}
33
34\helpref{wxAui}{librarieslist}
35
b88d16d3
BW
36
37\wxheading{Window styles}
38
39\twocolwidtha{5cm}%
40\begin{twocollist}\itemsep=0pt
134198f1 41\twocolitem{\windowstyle{wxAUI\_NB\_DEFAULT\_STYLE}}{Defined as wxAUI\_NB\_TOP | wxAUI\_NB\_TAB\_SPLIT | wxAUI\_NB\_TAB\_MOVE | wxAUI\_NB\_SCROLL\_BUTTONS | wxAUI\_NB\_CLOSE\_ON\_ACTIVE\_TAB.}
b88d16d3
BW
42\twocolitem{\windowstyle{wxAUI\_NB\_TAB\_SPLIT}}{Allows the tab control to be split by dragging a tab.}
43\twocolitem{\windowstyle{wxAUI\_NB\_TAB\_MOVE}}{Allows a tab to be moved horizontally by dragging.}
44\twocolitem{\windowstyle{wxAUI\_NB\_TAB\_EXTERNAL\_MOVE}}{Allows a tab to be moved to another tab control.}
45\twocolitem{\windowstyle{wxAUI\_NB\_TAB\_FIXED\_WIDTH}}{With this style, all tabs have the same width.}
46\twocolitem{\windowstyle{wxAUI\_NB\_SCROLL\_BUTTONS}}{With this style, left and right scroll buttons are displayed.}
47\twocolitem{\windowstyle{wxAUI\_NB\_WINDOWLIST\_BUTTON}}{With this style, a drop-down list of windows is available.}
48\twocolitem{\windowstyle{wxAUI\_NB\_CLOSE\_BUTTON}}{With this style, a close button is available on the tab bar.}
49\twocolitem{\windowstyle{wxAUI\_NB\_CLOSE\_ON\_ACTIVE\_TAB}}{With this style, the close button is visible on the active tab.}
50\twocolitem{\windowstyle{wxAUI\_NB\_CLOSE\_ON\_ALL\_TABS}}{With this style, the close button is visible on all tabs.}
134198f1
JS
51\twocolitem{\windowstyle{wxAUI\_NB\_TOP}}{With this style, tabs are drawn along the top of the notebook.}
52\twocolitem{\windowstyle{wxAUI\_NB\_BOTTOM}}{With this style, tabs are drawn along the bottom of the notebook.}
b88d16d3
BW
53\end{twocollist}
54
55
c0d9896a
BW
56\wxheading{Data structures}
57
58\latexignore{\rtfignore{\wxheading{Members}}}
59
c0d9896a
BW
60\membersection{wxAuiNotebook::wxAuiNotebook}\label{wxauinotebookwxauinotebook}
61
62\func{}{wxAuiNotebook}{\void}
63
c0d9896a
BW
64\func{}{wxAuiNotebook}{\param{wxWindow* }{parent}, \param{wxWindowID }{id = wxID\_ANY}, \param{const wxPoint\& }{pos = wxDefaultPosition}, \param{const wxSize\& }{size = wxDefaultSize}, \param{long }{style = wxAUI\_NB\_DEFAULT\_STYLE}}
65
8ffbb0f8 66Constructor. Creates a wxAuiNotebok control.
c0d9896a
BW
67
68\membersection{wxAuiNotebook::AddPage}\label{wxauinotebookaddpage}
69
70\func{bool}{AddPage}{\param{wxWindow* }{page}, \param{const wxString\& }{caption}, \param{bool }{select = false}, \param{const wxBitmap\& }{bitmap = wxNullBitmap}}
71
683b60e9 72Adds a page. If the {\it select} parameter is true, calling this will generate a page change event.
c0d9896a 73
a0c2e4a0
JS
74\membersection{wxAuiNotebook::AdvanceSelection}\label{wxauinotebookadvanceselection}
75
76\func{void}{AdvanceSelection}{\param{bool }{forward = true}}
77
78Sets the selection to the next or previous page.
79
c0d9896a
BW
80\membersection{wxAuiNotebook::Create}\label{wxauinotebookcreate}
81
82\func{bool}{Create}{\param{wxWindow* }{parent}, \param{wxWindowID }{id = wxID\_ANY}, \param{const wxPoint\& }{pos = wxDefaultPosition}, \param{const wxSize\& }{size = wxDefaultSize}, \param{long }{style = 0}}
83
8ffbb0f8 84Creates the notebook window.
c0d9896a
BW
85
86\membersection{wxAuiNotebook::DeletePage}\label{wxauinotebookdeletepage}
87
88\func{bool}{DeletePage}{\param{size\_t }{page}}
89
683b60e9 90Deletes a page at the given index. Calling this method will generate a page change event.
c0d9896a
BW
91
92\membersection{wxAuiNotebook::GetArtProvider}\label{wxauinotebookgetartprovider}
93
94\constfunc{wxAuiTabArt*}{GetArtProvider}{\void}
95
8ffbb0f8 96Returns the associated art provider.
c0d9896a 97
fc17828a
JS
98\membersection{wxAuiNotebook::GetHeightForPageHeight}\label{wxauinotebookgetheightforpageheight}
99
100\func{int}{GetHeightForPageHeight}{\param{int }{pageHeight}}
101
102Returns the desired height of the notebook for the given page height. Use this to fit the notebook to
103a given page size.
104
c0d9896a
BW
105\membersection{wxAuiNotebook::GetPage}\label{wxauinotebookgetpage}
106
107\constfunc{wxWindow*}{GetPage}{\param{size\_t }{page\_idx}}
108
8ffbb0f8 109Returns the page specified by the given index.
c0d9896a 110
c3e016e4
JS
111\membersection{wxAuiNotebook::GetPageBitmap}\label{wxauinotebookgetpagebitmap}
112
113\constfunc{wxBitmap}{GetPageBitmap}{\param{size\_t }{page}}
114
115Returns the tab bitmap for the page.
116
c0d9896a
BW
117\membersection{wxAuiNotebook::GetPageCount}\label{wxauinotebookgetpagecount}
118
119\constfunc{size\_t}{GetPageCount}{\void}
120
b88d16d3 121Returns the number of pages in the notebook.
c0d9896a
BW
122
123\membersection{wxAuiNotebook::GetPageIndex}\label{wxauinotebookgetpageindex}
124
125\constfunc{int}{GetPageIndex}{\param{wxWindow* }{page\_wnd}}
126
e2622169
VZ
127Returns the page index for the specified window. If the window is not found in
128the notebook, wxNOT\_FOUND is returned.
c0d9896a 129
c3e016e4
JS
130\membersection{wxAuiNotebook::GetPageText}\label{wxauinotebookgetpagetext}
131
132\constfunc{wxString}{GetPageText}{\param{size\_t }{page}}
133
134Returns the tab label for the page.
135
fc17828a
JS
136\membersection{wxAuiNotebook::GetTabCtrlHeight}\label{wxauinotebookgettabctrlheight}
137
138\constfunc{int}{GetTabCtrlHeight}{\void}
139
140Returns the height of the tab control.
141
c0d9896a
BW
142\membersection{wxAuiNotebook::GetSelection}\label{wxauinotebookgetselection}
143
144\constfunc{int}{GetSelection}{\void}
145
8ffbb0f8 146Returns the currently selected page.
c0d9896a
BW
147
148\membersection{wxAuiNotebook::InsertPage}\label{wxauinotebookinsertpage}
149
150\func{bool}{InsertPage}{\param{size\_t }{page\_idx}, \param{wxWindow* }{page}, \param{const wxString\& }{caption}, \param{bool }{select = false}, \param{const wxBitmap\& }{bitmap = wxNullBitmap}}
151
b88d16d3
BW
152InsertPage() is similar to AddPage, but allows the ability to specify the insert location.
153If the {\it select} parameter is true, calling this will generate a page change event.
c0d9896a 154
c0d9896a
BW
155\membersection{wxAuiNotebook::RemovePage}\label{wxauinotebookremovepage}
156
157\func{bool}{RemovePage}{\param{size\_t }{page}}
158
683b60e9 159Removes a page, without deleting the window pointer.
c0d9896a
BW
160
161\membersection{wxAuiNotebook::SetArtProvider}\label{wxauinotebooksetartprovider}
162
163\func{void}{SetArtProvider}{\param{wxAuiTabArt* }{art}}
164
8ffbb0f8 165Sets the art provider to be used by the notebook.
c0d9896a 166
fc17828a
JS
167\membersection{wxAuiNotebook::SetFont}\label{wxauinotebooksetfont}
168
169\func{bool}{SetFont}{\param{const wxFont\& }{font}}
170
171Sets the font for drawing the tab labels, using a bold version of the font for selected tab labels.
172
173\membersection{wxAuiNotebook::SetNormalFont}\label{wxauinotebooksetnormalfont}
174
175\func{void}{SetNormalFont}{\param{const wxFont\& }{font}}
176
177Sets the font for drawing unselected tab labels.
178
179\membersection{wxAuiNotebook::SetSelectedFont}\label{wxauinotebooksetselectedfont}
180
181\func{void}{SetSelectedFont}{\param{const wxFont\& }{font}}
182
183Sets the font for drawing selected tab labels.
184
185\membersection{wxAuiNotebook::SetMeasuringFont}\label{wxauinotebooksetmeasuringfont}
186
187\func{void}{SetMeasuringFont}{\param{const wxFont\& }{font}}
188
189Sets the font for measuring tab labels.
190
c0d9896a
BW
191\membersection{wxAuiNotebook::SetPageBitmap}\label{wxauinotebooksetpagebitmap}
192
193\func{bool}{SetPageBitmap}{\param{size\_t }{page}, \param{const wxBitmap\& }{bitmap}}
194
b88d16d3
BW
195Sets the bitmap for the page. To remove a bitmap from the tab caption, pass
196wxNullBitmap.
c0d9896a
BW
197
198\membersection{wxAuiNotebook::SetPageText}\label{wxauinotebooksetpagetext}
199
200\func{bool}{SetPageText}{\param{size\_t }{page}, \param{const wxString\& }{text}}
201
683b60e9 202Sets the tab label for the page.
c0d9896a
BW
203
204\membersection{wxAuiNotebook::SetSelection}\label{wxauinotebooksetselection}
205
206\func{size\_t}{SetSelection}{\param{size\_t }{new\_page}}
207
683b60e9 208Sets the page selection. Calling this method will generate a page change event.
c0d9896a
BW
209
210\membersection{wxAuiNotebook::SetTabCtrlHeight}\label{wxauinotebooksettabctrlheight}
211
212\func{void}{SetTabCtrlHeight}{\param{int }{height}}
213
b88d16d3
BW
214Sets the tab height. By default, the tab control height is calculated
215by measuring the text height and bitmap sizes on the tab captions. Calling this
216method will override that calculation and set the tab control to the specified
217height parameter. A call to this method will override any call to SetUniformBitmapSize().
218Specifying -1 as the height will return the control to its default auto-sizing behaviour.
219
220\membersection{wxAuiNotebook::SetUniformBitmapSize}\label{wxauinotebooksetuniformbitmapsize}
221
222\func{void}{SetUniformBitmapSize}{\param{const wxSize\& }{size}}
c0d9896a 223
b88d16d3
BW
224SetUniformBitmapSize() ensures that all tabs will have the same height, even
225if some tabs don't have bitmaps. Passing wxDefaultSize to this function will
226instruct the control to use dynamic tab height, which is the default behaviour.
227Under the default behaviour, when a tab with a large bitmap is added, the tab control's
228height will automatically increase to accommodate the larger bitmap.
2e56b9d7 229
e2622169 230\func{void}{Split}{\param{size\_t }{page}, \param{int }{direction}}
e319bb30
BW
231
232Split performs a split operation programmatically. The argument \arg{page} indicates
233the page that will be split off. This page will also become the active page after the
234split. The \arg{direction} argument specifies where the pane should go, it should be one
235of the following: wxTOP, wxBOTTOM, wxLEFT, or wxRIGHT.
236
a0c2e4a0 237\membersection{wxAuiNotebook::ShowWindowMenu}\label{wxauinotebookshowwindowmenu}
e319bb30 238
a0c2e4a0 239\func{bool}{ShowWindowMenu}{\void}
e319bb30 240
a0c2e4a0
JS
241Shows the window menu for the active tab control associated with this notebook,
242and returns \true if a selection was made.
e319bb30 243