X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/9133965ef55aa16091bfb3bed910357720dd4810..519d7f238ce17ab2de6f5fb57d35add84ce47e4c:/samples/notebook/notebook.h diff --git a/samples/notebook/notebook.h b/samples/notebook/notebook.h index 28cf666261..e92a039bc4 100644 --- a/samples/notebook/notebook.h +++ b/samples/notebook/notebook.h @@ -6,12 +6,14 @@ // Created: 25/10/98 // RCS-ID: $Id$ // Copyright: (c) 1998-2002 wxWidgets team -// License: wxWindows license +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #include "wx/choicebk.h" #include "wx/listbook.h" +#include "wx/treebook.h" #include "wx/notebook.h" +#include "wx/toolbook.h" #if wxUSE_LOG && !defined( __SMARTPHONE__ ) #define USE_LOG 1 @@ -28,12 +30,11 @@ public: DECLARE_APP(MyApp) + class MyFrame : public wxFrame { public: - MyFrame(const wxString& title, const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, long style = wxDEFAULT_FRAME_STYLE|wxCLIP_CHILDREN|wxNO_FULL_REPAINT_ON_RESIZE); - + MyFrame(); virtual ~MyFrame(); void OnType(wxCommandEvent& event); @@ -43,28 +44,66 @@ public: void OnExit(wxCommandEvent& event); void OnAddPage(wxCommandEvent& event); + void OnAddPageNoSelect(wxCommandEvent& event); void OnInsertPage(wxCommandEvent& event); void OnDeleteCurPage(wxCommandEvent& event); void OnDeleteLastPage(wxCommandEvent& event); void OnNextPage(wxCommandEvent& event); + void OnChangeSelection(wxCommandEvent &event); + void OnSetSelection(wxCommandEvent &event); + + void OnAddSubPage(wxCommandEvent& event); + void OnAddPageBefore(wxCommandEvent& event); + +#if wxUSE_HELP + void OnContextHelp(wxCommandEvent& event); +#endif // wxUSE_HELP - void OnNotebook(wxNotebookEvent& event); - void OnChoicebook(wxChoicebookEvent& event); - void OnListbook(wxListbookEvent& event); + void OnHitTest(wxCommandEvent& event); + + void OnBookCtrl(wxBookCtrlBaseEvent& event); +#if wxUSE_NOTEBOOK + void OnNotebook(wxNotebookEvent& event) { OnBookCtrl(event); } +#endif +#if wxUSE_CHOICEBOOK + void OnChoicebook(wxChoicebookEvent& event) { OnBookCtrl(event); } +#endif +#if wxUSE_LISTBOOK + void OnListbook(wxListbookEvent& event) { OnBookCtrl(event); } +#endif +#if wxUSE_TREEBOOK + void OnTreebook(wxTreebookEvent& event) { OnBookCtrl(event); } +#endif +#if wxUSE_TOOLBOOK + void OnToolbook(wxToolbookEvent& event) { OnBookCtrl(event); } +#endif void OnIdle(wxIdleEvent& event); - wxBookCtrl *GetCurrentBook(); +#if wxUSE_TREEBOOK + void OnUpdateTreeMenu(wxUpdateUIEvent& event); +#endif // wxUSE_TREEBOOK + + wxBookCtrlBase *GetCurrentBook() const { return m_bookCtrl; } private: wxLog *m_logTargetOld; - int SelectFlag(int id, int nb, int lb, int chb); - void ShowCurrentBook(); - void RecreateBooks(); + void RecreateBook(); + wxPanel *CreateNewPage() const; + int TranslateBookFlag(int nb, int lb, int chb, int tbk, int toolbk) const; + void AddFlagStrIfFlagPresent(wxString & flagStr, long flags, long flag, const wxChar * flagName) const; // Sample setup - int m_type; + enum BookType + { + Type_Notebook, + Type_Listbook, + Type_Choicebook, + Type_Treebook, + Type_Toolbook, + Type_Max + } m_type; int m_orient; bool m_chkShowImages; bool m_multi; @@ -72,10 +111,7 @@ private: // Controls wxPanel *m_panel; // Panel containing notebook and other controls - - wxNotebook *m_notebook; - wxChoicebook *m_choicebook; - wxListbook *m_listbook; + wxBookCtrlBase *m_bookCtrl; #if USE_LOG // Log window @@ -91,10 +127,14 @@ private: enum ID_COMMANDS { + // these should be in the same order as Type_XXX elements above ID_BOOK_NOTEBOOK = wxID_HIGHEST, ID_BOOK_LISTBOOK, ID_BOOK_CHOICEBOOK, + ID_BOOK_TREEBOOK, + ID_BOOK_TOOLBOOK, ID_BOOK_MAX, + ID_ORIENT_DEFAULT, ID_ORIENT_TOP, ID_ORIENT_BOTTOM, @@ -104,26 +144,38 @@ enum ID_COMMANDS ID_SHOW_IMAGES, ID_MULTI, ID_ADD_PAGE, + ID_ADD_PAGE_NO_SELECT, ID_INSERT_PAGE, ID_DELETE_CUR_PAGE, ID_DELETE_LAST_PAGE, ID_NEXT_PAGE, - ID_NOTEBOOK, - ID_LISTBOOK, - ID_CHOICEBOOK + ID_ADD_PAGE_BEFORE, + ID_ADD_SUB_PAGE, + ID_CHANGE_SELECTION, + ID_SET_SELECTION, + +#if wxUSE_HELP + ID_CONTEXT_HELP, +#endif // wxUSE_HELP + ID_HITTEST }; + /* -Name of each notebook page. -Used as a label for a page, and used when cloning the notebook -to decide what type of page it is. + Name of each notebook page. + Used as a label for a page, and used when cloning the notebook + to decide what type of page it is. */ -#define I_WAS_INSERTED_PAGE_NAME wxT("Inserted") -#define RADIOBUTTONS_PAGE_NAME wxT("Radiobuttons") -#define VETO_PAGE_NAME wxT("Veto") -#define MAXIMIZED_BUTTON_PAGE_NAME wxT("Maximized button") +#define I_WAS_INSERTED_PAGE_NAME wxT("Inserted") +#define RADIOBUTTONS_PAGE_NAME wxT("Radiobuttons") +#define VETO_PAGE_NAME wxT("Veto") +#define MAXIMIZED_BUTTON_PAGE_NAME wxT("Maximized button") // Pages that can be added by the user -#define INSERTED_PAGE_NAME wxT("Inserted ") -#define ADDED_PAGE_NAME wxT("Added ") +#define INSERTED_PAGE_NAME wxT("Inserted ") +#define ADDED_PAGE_NAME wxT("Added ") +#define ADDED_PAGE_NAME_BEFORE wxT(" Inserted before ") +#define ADDED_SUB_PAGE_NAME wxT(" Inserted sub-page ") + +