X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/1d6fcbcc7088e9c104b3dc5b4704a07f728d55ae..d8dd214c1bccfd7a7defdbbedd69aef706a8816b:/include/wx/bookctrl.h?ds=sidebyside diff --git a/include/wx/bookctrl.h b/include/wx/bookctrl.h index 85d769d71a..454e99545a 100644 --- a/include/wx/bookctrl.h +++ b/include/wx/bookctrl.h @@ -42,6 +42,14 @@ enum wxBK_HITTEST_ONPAGE = 8 // not on tab control, but over the selected page }; +// wxBookCtrl flags (common for wxNotebook, wxListbook, wxChoicebook, wxTreebook) +#define wxBK_DEFAULT 0x0000 +#define wxBK_TOP 0x0010 +#define wxBK_BOTTOM 0x0020 +#define wxBK_LEFT 0x0040 +#define wxBK_RIGHT 0x0080 +#define wxBK_ALIGN_MASK (wxBK_TOP | wxBK_BOTTOM | wxBK_LEFT | wxBK_RIGHT) + // ---------------------------------------------------------------------------- // wxBookCtrlBase // ---------------------------------------------------------------------------- @@ -222,22 +230,36 @@ public: virtual bool HasMultiplePages() const { return true; } protected: - // typically, wxBookCtrl-derived classes will use DoSetSelection() function - // to implement SetSelection() and ChangeSelection() functions. - // these flags make DoSetSelection() more readable + // flags for DoSetSelection() enum { SetSelection_SendEvent = 1 }; - // if using DoSetSelection() for implementing [Set|Change]Selection, - // then override UpdateSelectedPage() and MakeChangedEvent() - virtual int DoSetSelection(size_t nPage, int flags, wxBookCtrlBaseEvent &event); + // set the selection to the given page, sending the events (which can + // possibly prevent the page change from taking place) if SendEvent flag is + // included + virtual int DoSetSelection(size_t nPage, int flags = 0); + + // if the derived class uses DoSetSelection() for implementing + // [Set|Change]Selection, it must override UpdateSelectedPage(), + // CreatePageChangingEvent() and MakeChangedEvent(), but as it might not + // use it, these functions are not pure virtual + + // called to notify the control about a new current page virtual void UpdateSelectedPage(size_t WXUNUSED(newsel)) { wxFAIL_MSG(wxT("Override this function!")); } - virtual void MakeChangedEvent(wxBookCtrlBaseEvent &WXUNUSED(event)) + + // create a new "page changing" event + virtual wxBookCtrlBaseEvent* CreatePageChangingEvent() const + { wxFAIL_MSG(wxT("Override this function!")); return NULL; } + + // modify the event created by CreatePageChangingEvent() to "page changed" + // event, usually by just calling SetEventType() on it + virtual void MakeChangedEvent(wxBookCtrlBaseEvent& WXUNUSED(event)) { wxFAIL_MSG(wxT("Override this function!")); } + // Should we accept NULL page pointers in Add/InsertPage()? // // Default is no but derived classes may override it if they can treat NULL