]>
git.saurik.com Git - wxWidgets.git/blob - interface/notebook.h
a83726c0c034043c1a3ea10667b73b4e32b0d2d6
1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: documentation for wxNotebookEvent class
4 // Author: wxWidgets team
6 // Licence: wxWindows license
7 /////////////////////////////////////////////////////////////////////////////
10 @class wxNotebookEvent
13 This class represents the events generated by a notebook control: currently,
14 there are two of them. The PAGE_CHANGING event is sent before the current
15 page is changed. It allows the program to examine the current page (which
17 wxNotebookEvent::GetOldSelection) and to veto the page
18 change by calling wxNotifyEvent::Veto if, for example, the
19 current values in the controls of the old page are invalid.
21 The second event - PAGE_CHANGED - is sent after the page has been changed and
22 the program cannot veto it any more, it just informs it about the page change.
24 To summarize, if the program is interested in validating the page values
25 before allowing the user to change it, it should process the PAGE_CHANGING
26 event, otherwise PAGE_CHANGED is probably enough. In any case, it is probably
27 unnecessary to process both events at once.
35 class wxNotebookEvent
: public wxNotifyEvent
39 Constructor (used internally by wxWidgets only).
41 wxNotebookEvent(wxEventType eventType
= wxEVT_@NULL
, int id
= 0,
46 Returns the page that was selected before the change, -1 if none was selected.
48 int GetOldSelection();
51 Returns the currently selected page, or -1 if none was selected.
53 @b NB: under Windows, GetSelection() will return the same value as
54 GetOldSelection() when called from
55 @c EVT_NOTEBOOK_PAGE_CHANGING handler and not the page which is going to
56 be selected. Also note that the values of selection and old selection returned
57 for an event generated in response to a call to
58 wxNotebook::SetSelection shouldn't be trusted
59 as they are currently inconsistent under different platforms (but in this case
60 you presumably don't need them anyhow as you already have the corresponding
66 Sets the id of the page selected before the change.
68 void SetOldSelection(int page
);
71 Sets the selection member variable.
73 void SetSelection(int page
);
81 This class represents a notebook control, which manages multiple windows with
84 To use the class, create a wxNotebook object and call wxNotebook::AddPage or
85 wxNotebook::InsertPage,
86 passing a window to be used as the page. Do not explicitly delete the window
87 for a page that is currently
88 managed by wxNotebook.
90 @b wxNotebookPage is a typedef for wxWindow.
94 Place tabs on the top side.
96 Place tabs on the left side.
98 Place tabs on the right side.
100 Place tabs under instead of above the notebook pages.
101 @style{wxNB_FIXEDWIDTH}:
102 (Windows only) All tabs will have same width.
103 @style{wxNB_MULTILINE}:
104 (Windows only) There can be several rows of tabs.
105 @style{wxNB_NOPAGETHEME}:
106 (Windows only) Display a solid colour on notebook pages, and not a
107 gradient, which can reduce performance.
109 (Windows CE only) Show tabs in a flat style.
116 wxBookCtrl, wxNotebookEvent, wxImageList, @ref overview_samplenotebook
119 class wxNotebook
: public wxBookCtrl overview
124 Constructs a notebook control.
126 Note that sometimes you can reduce flicker by passing the wxCLIP_CHILDREN
130 The parent window. Must be non-@NULL.
133 The window identifier.
142 The window style. See wxNotebook.
145 The name of the control (used only under Motif).
148 wxNotebook(wxWindow
* parent
, wxWindowID id
,
149 const wxPoint
& pos
= wxDefaultPosition
,
150 const wxSize
& size
= wxDefaultSize
,
152 const wxString
& name
= wxNotebookNameStr
);
156 Destroys the wxNotebook object.
163 The call to this function may generate the page changing events.
166 Specifies the new page.
169 Specifies the text for the new page.
172 Specifies whether the page should be selected.
175 Specifies the optional image index for the new page.
177 @returns @true if successful, @false otherwise.
179 @remarks Do not delete the page, it will be deleted by the notebook.
183 bool AddPage(wxNotebookPage
* page
, const wxString
& text
,
184 bool select
= @
false,
188 Cycles through the tabs.
190 The call to this function generates the page changing events.
192 void AdvanceSelection(bool forward
= @
true);
195 Sets the image list for the page control and takes ownership of
198 @sa wxImageList, SetImageList()
200 void AssignImageList(wxImageList
* imageList
);
203 Changes the selection for the given page, returning the previous selection.
205 The call to this function does not generate the page changing events.
206 This is the only difference with SetSelection().
207 See @ref overview_progevent "this topic" for more info.
209 int ChangeSelection(size_t page
);
212 Creates a notebook control. See wxNotebook() for a description
215 bool Create(wxWindow
* parent
, wxWindowID id
,
216 const wxPoint
& pos
= wxDefaultPosition
,
217 const wxSize
& size
, long style
= 0,
218 const wxString
& name
= wxNotebookNameStr
);
223 bool DeleteAllPages();
226 Deletes the specified page, and the associated window.
228 The call to this function generates the page changing events.
230 bool DeletePage(size_t page
);
233 Returns the currently selected notebook page or @NULL.
235 wxWindow
* GetCurrentPage();
238 Returns the associated image list.
240 @sa wxImageList, SetImageList()
242 wxImageList
* GetImageList();
245 Returns the window at the given page position.
247 wxNotebookPage
* GetPage(size_t page
);
250 Returns the number of pages in the notebook control.
252 size_t GetPageCount();
255 Returns the image index for the given page.
257 int GetPageImage(size_t nPage
);
260 Returns the string for the given page.
262 wxString
GetPageText(size_t nPage
);
265 Returns the number of rows in the notebook control.
270 Returns the currently selected page, or -1 if none was selected.
272 Note that this method may return either the previously or newly selected page
273 when called from the @c EVT_NOTEBOOK_PAGE_CHANGED handler depending on
275 wxNotebookEvent::GetSelection should be
276 used instead in this case.
281 If running under Windows and themes are enabled for the application, this
283 returns a suitable colour for painting the background of a notebook page, and
285 to @c SetBackgroundColour. Otherwise, an uninitialised colour will be returned.
287 wxColour
GetThemeBackgroundColour();
290 Returns the index of the tab at the specified position or @c wxNOT_FOUND
291 if none. If @e flags parameter is non-@NULL, the position of the point
292 inside the tab is returned as well.
295 Specifies the point for the hit test.
298 Return value for detailed information. One of the following values:
303 There was no tab under this point.
308 The point was over an icon (currently wxMSW only).
313 The point was over a label (currently wxMSW only).
318 The point was over an item, but not on the label or icon.
323 The point was over a currently selected page, not over any tab. Note that this
324 flag is present only if wxNOT_FOUND is returned.
326 @returns Returns the zero-based tab index or wxNOT_FOUND if there is no
327 tab is at the specified position.
329 int HitTest(const wxPoint
& pt
, long flags
= @NULL
);
332 Inserts a new page at the specified position.
335 Specifies the position for the new page.
338 Specifies the new page.
341 Specifies the text for the new page.
344 Specifies whether the page should be selected.
347 Specifies the optional image index for the new page.
349 @returns @true if successful, @false otherwise.
351 @remarks Do not delete the page, it will be deleted by the notebook.
355 bool InsertPage(size_t index
, wxNotebookPage
* page
,
356 const wxString
& text
,
357 bool select
= @
false,
361 An event handler function, called when the page selection is changed.
365 void OnSelChange(wxNotebookEvent
& event
);
368 Deletes the specified page, without deleting the associated window.
370 bool RemovePage(size_t page
);
373 Sets the image list for the page control. It does not take
374 ownership of the image list, you must delete it yourself.
376 @sa wxImageList, AssignImageList()
378 void SetImageList(wxImageList
* imageList
);
381 Sets the amount of space around each page's icon and label, in pixels.
383 @b NB: The vertical padding cannot be changed in wxGTK.
385 void SetPadding(const wxSize
& padding
);
388 Sets the image index for the given page. @e image is an index into
389 the image list which was set with SetImageList().
391 bool SetPageImage(size_t page
, int image
);
394 Sets the width and height of the pages.
396 @b NB: This method is currently not implemented for wxGTK.
398 void SetPageSize(const wxSize
& size
);
401 Sets the text for the given page.
403 bool SetPageText(size_t page
, const wxString
& text
);
406 Sets the selection for the given page, returning the previous selection.
408 The call to this function generates the page changing events.
410 This function is deprecated and should not be used in new code. Please use the
411 ChangeSelection() function instead.
415 int SetSelection(size_t page
);