2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: notebook.h
|
2008-08-01 13:46:46 +00:00
|
|
|
// Purpose: interface of wxNotebook
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
2010-07-13 13:29:13 +00:00
|
|
|
// Licence: wxWindows licence
|
2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2011-10-22 02:31:03 +00:00
|
|
|
enum
|
|
|
|
{
|
|
|
|
wxNB_HITTEST_NOWHERE = wxBK_HITTEST_NOWHERE,
|
|
|
|
wxNB_HITTEST_ONICON = wxBK_HITTEST_ONICON,
|
|
|
|
wxNB_HITTEST_ONLABEL = wxBK_HITTEST_ONLABEL,
|
|
|
|
wxNB_HITTEST_ONITEM = wxBK_HITTEST_ONITEM,
|
|
|
|
wxNB_HITTEST_ONPAGE = wxBK_HITTEST_ONPAGE
|
|
|
|
};
|
|
|
|
|
|
|
|
#define wxNB_DEFAULT wxBK_DEFAULT
|
|
|
|
#define wxNB_TOP wxBK_TOP
|
|
|
|
#define wxNB_BOTTOM wxBK_BOTTOM
|
|
|
|
#define wxNB_LEFT wxBK_LEFT
|
|
|
|
#define wxNB_RIGHT wxBK_RIGHT
|
|
|
|
|
|
|
|
#define wxNB_FIXEDWIDTH 0x0100
|
|
|
|
#define wxNB_MULTILINE 0x0200
|
|
|
|
#define wxNB_NOPAGETHEME 0x0400
|
|
|
|
|
2013-04-25 10:11:03 +00:00
|
|
|
wxEventType wxEVT_NOTEBOOK_PAGE_CHANGED;
|
|
|
|
wxEventType wxEVT_NOTEBOOK_PAGE_CHANGING;
|
2012-06-20 17:10:23 +00:00
|
|
|
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxNotebook
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This class represents a notebook control, which manages multiple windows with
|
|
|
|
associated tabs.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-08-01 13:46:46 +00:00
|
|
|
To use the class, create a wxNotebook object and call wxNotebook::AddPage
|
2008-10-13 10:27:19 +00:00
|
|
|
or wxNotebook::InsertPage, passing a window to be used as the page.
|
|
|
|
Do not explicitly delete the window for a page that is currently managed by
|
2008-08-01 13:46:46 +00:00
|
|
|
wxNotebook.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@b wxNotebookPage is a typedef for wxWindow.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@beginStyleTable
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxNB_TOP}
|
2008-03-08 13:52:38 +00:00
|
|
|
Place tabs on the top side.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxNB_LEFT}
|
2008-03-08 13:52:38 +00:00
|
|
|
Place tabs on the left side.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxNB_RIGHT}
|
2008-03-08 13:52:38 +00:00
|
|
|
Place tabs on the right side.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxNB_BOTTOM}
|
2008-03-08 13:52:38 +00:00
|
|
|
Place tabs under instead of above the notebook pages.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxNB_FIXEDWIDTH}
|
2008-03-08 13:52:38 +00:00
|
|
|
(Windows only) All tabs will have same width.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxNB_MULTILINE}
|
2008-03-08 13:52:38 +00:00
|
|
|
(Windows only) There can be several rows of tabs.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxNB_NOPAGETHEME}
|
2008-03-08 13:52:38 +00:00
|
|
|
(Windows only) Display a solid colour on notebook pages, and not a
|
|
|
|
gradient, which can reduce performance.
|
|
|
|
@endStyleTable
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-10-13 10:27:19 +00:00
|
|
|
The styles wxNB_LEFT, RIGHT and BOTTOM are not supported under
|
2015-08-31 07:57:53 +00:00
|
|
|
Microsoft Windows when using visual themes.
|
2008-10-13 10:27:19 +00:00
|
|
|
|
2009-02-18 17:58:51 +00:00
|
|
|
@beginEventEmissionTable{wxBookCtrlEvent}
|
2008-10-13 10:27:19 +00:00
|
|
|
@event{EVT_NOTEBOOK_PAGE_CHANGED(id, func)}
|
|
|
|
The page selection was changed.
|
2013-04-25 10:11:03 +00:00
|
|
|
Processes a @c wxEVT_NOTEBOOK_PAGE_CHANGED event.
|
2008-10-13 10:27:19 +00:00
|
|
|
@event{EVT_NOTEBOOK_PAGE_CHANGING(id, func)}
|
|
|
|
The page selection is about to be changed.
|
2013-04-25 10:11:03 +00:00
|
|
|
Processes a @c wxEVT_NOTEBOOK_PAGE_CHANGING event.
|
2008-10-13 10:27:19 +00:00
|
|
|
This event can be vetoed.
|
|
|
|
@endEventTable
|
|
|
|
|
|
|
|
|
|
|
|
@section notebook_bg Page backgrounds
|
|
|
|
|
2015-08-31 07:57:53 +00:00
|
|
|
On Windows, the default theme paints a background on the notebook's pages.
|
2008-10-13 10:27:19 +00:00
|
|
|
If you wish to suppress this theme, for aesthetic or performance reasons,
|
|
|
|
there are three ways of doing it.
|
|
|
|
You can use @c wxNB_NOPAGETHEME to disable themed drawing for a particular
|
|
|
|
notebook, you can call wxSystemOptions::SetOption to disable it for the
|
|
|
|
whole application, or you can disable it for individual pages by using
|
|
|
|
SetBackgroundColour().
|
|
|
|
|
|
|
|
To disable themed pages globally:
|
|
|
|
@code
|
2009-01-18 21:46:46 +00:00
|
|
|
wxSystemOptions::SetOption("msw.notebook.themed-background", 0);
|
2008-10-13 10:27:19 +00:00
|
|
|
@endcode
|
|
|
|
|
|
|
|
Set the value to 1 to enable it again.
|
|
|
|
To give a single page a solid background that more or less fits in with the
|
|
|
|
overall theme, use:
|
|
|
|
@code
|
|
|
|
wxColour col = notebook->GetThemeBackgroundColour();
|
2009-01-10 18:00:53 +00:00
|
|
|
if (col.IsOk())
|
2008-10-13 10:27:19 +00:00
|
|
|
{
|
|
|
|
page->SetBackgroundColour(col);
|
|
|
|
}
|
|
|
|
@endcode
|
|
|
|
|
|
|
|
On platforms other than Windows, or if the application is not using Windows
|
|
|
|
themes, GetThemeBackgroundColour() will return an uninitialised colour object,
|
|
|
|
and the above code will therefore work on all platforms.
|
|
|
|
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
2009-02-20 11:34:52 +00:00
|
|
|
@category{bookctrl}
|
2012-11-03 18:32:50 +00:00
|
|
|
@appearance{notebook}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-10-13 08:55:12 +00:00
|
|
|
@see wxBookCtrl, wxBookCtrlEvent, wxImageList, @ref page_samples_notebook
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-10-13 10:27:19 +00:00
|
|
|
class wxNotebook : public wxBookCtrlBase
|
2008-03-08 13:52:38 +00:00
|
|
|
{
|
|
|
|
public:
|
2008-07-04 08:02:33 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Constructs a notebook control.
|
|
|
|
*/
|
|
|
|
wxNotebook();
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
Constructs a notebook control.
|
|
|
|
Note that sometimes you can reduce flicker by passing the wxCLIP_CHILDREN
|
|
|
|
window style.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param parent
|
2008-03-09 12:33:59 +00:00
|
|
|
The parent window. Must be non-@NULL.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param id
|
2008-03-09 12:33:59 +00:00
|
|
|
The window identifier.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param pos
|
2008-03-09 12:33:59 +00:00
|
|
|
The window position.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param size
|
2008-03-09 12:33:59 +00:00
|
|
|
The window size.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param style
|
2008-03-09 12:33:59 +00:00
|
|
|
The window style. See wxNotebook.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param name
|
2008-10-13 08:55:12 +00:00
|
|
|
The name of the control.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
wxNotebook(wxWindow* parent, wxWindowID id,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = 0,
|
|
|
|
const wxString& name = wxNotebookNameStr);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Destroys the wxNotebook object.
|
|
|
|
*/
|
2008-03-25 12:22:08 +00:00
|
|
|
virtual ~wxNotebook();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-10-13 08:55:12 +00:00
|
|
|
Creates a notebook control.
|
|
|
|
See wxNotebook() for a description of the parameters.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
bool Create(wxWindow* parent, wxWindowID id,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
2008-03-25 12:22:08 +00:00
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = 0,
|
2008-03-08 13:52:38 +00:00
|
|
|
const wxString& name = wxNotebookNameStr);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the number of rows in the notebook control.
|
|
|
|
*/
|
2008-03-25 12:22:08 +00:00
|
|
|
virtual int GetRowCount() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
If running under Windows and themes are enabled for the application, this
|
2008-10-13 08:55:12 +00:00
|
|
|
function returns a suitable colour for painting the background of a notebook
|
|
|
|
page, and can be passed to SetBackgroundColour().
|
|
|
|
|
|
|
|
Otherwise, an uninitialised colour will be returned.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-25 12:22:08 +00:00
|
|
|
virtual wxColour GetThemeBackgroundColour() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
An event handler function, called when the page selection is changed.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-08-01 13:46:46 +00:00
|
|
|
@see wxBookCtrlEvent
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-08-01 13:46:46 +00:00
|
|
|
void OnSelChange(wxBookCtrlEvent& event);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the amount of space around each page's icon and label, in pixels.
|
2008-10-13 08:55:12 +00:00
|
|
|
|
2008-03-28 16:19:12 +00:00
|
|
|
@note The vertical padding cannot be changed in wxGTK.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
virtual void SetPadding(const wxSize& padding);
|
2011-10-22 02:31:03 +00:00
|
|
|
|
|
|
|
// implementations of pure virtuals
|
|
|
|
virtual int GetPageImage(size_t nPage) const;
|
|
|
|
virtual bool SetPageImage(size_t page, int image);
|
|
|
|
virtual wxString GetPageText(size_t nPage) const;
|
|
|
|
virtual bool SetPageText(size_t page, const wxString& text);
|
|
|
|
virtual int GetSelection() const;
|
|
|
|
virtual int SetSelection(size_t page);
|
|
|
|
virtual int ChangeSelection(size_t page);
|
|
|
|
virtual bool InsertPage(size_t index, wxWindow * page, const wxString & text,
|
|
|
|
bool select = false, int imageId = NO_IMAGE);
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|