]> git.saurik.com Git - wxWidgets.git/blobdiff - samples/notebook/notebook.h
added wxAtomicInc/Dec() functions (patch 1739486)
[wxWidgets.git] / samples / notebook / notebook.h
index c79f79f980e2f120ddc41ef87ab638d26d715a79..2c1587215bff427dee06c7690af4cdac4415f939 100644 (file)
@@ -9,30 +9,16 @@
 // License:     wxWindows license
 /////////////////////////////////////////////////////////////////////////////
 
-// this sample can be used to test both wxNotebook and wxListbook
-//#define TEST_LISTBOOK
-
-#ifdef TEST_LISTBOOK
-    #include "wx/listbook.h"
-
-    #define wxNotebook wxListbook
-    #define wxNotebookEvent wxListbookEvent
-
-    #define wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGED wxEVT_COMMAND_LISTBOOK_PAGE_CHANGED
-    #define wxEVT_COMMAND_NOTEBOOK_PAGE_CHANGING wxEVT_COMMAND_LISTBOOK_PAGE_CHANGING
-    #define EVT_NOTEBOOK_PAGE_CHANGED EVT_LISTBOOK_PAGE_CHANGED
-    #define EVT_NOTEBOOK_PAGE_CHANGING EVT_LISTBOOK_PAGE_CHANGING
-
-    #undef wxNB_TOP
-    #define wxNB_TOP wxLB_TOP
-    #undef wxNB_BOTTOM
-    #define wxNB_BOTTOM wxLB_BOTTOM
-    #undef wxNB_LEFT
-    #define wxNB_LEFT wxLB_LEFT
-    #undef wxNB_RIGHT
-    #define wxNB_RIGHT wxLB_RIGHT
+#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
 #else
-    #include "wx/notebook.h"
+    #define USE_LOG 0
 #endif
 
 // Define a new application
@@ -44,121 +30,132 @@ public:
 
 DECLARE_APP(MyApp)
 
-//
-class MyNotebook : public wxNotebook
-{
-public:
-    MyNotebook(wxWindow *parent, wxWindowID id = wxID_ANY,
-        const wxPoint& pos = wxDefaultPosition,
-        const wxSize& size = wxDefaultSize, long style = 0);
-
-    void CreateInitialPages();
-
-    wxPanel *CreatePage(const wxString& pageName);
 
-    wxPanel *CreateUserCreatedPage();
-
-    int GetIconIndex() const;
-
-private:
-    wxPanel *CreateInsertPage();
-    wxPanel *CreateRadioButtonsPage();
-    wxPanel *CreateVetoPage();
-    wxPanel *CreateBigButtonPage();
-};
-
-//
 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();
 
-    // Recreates the notebook with the same pages, but with possibly
-    // a different orientation and optionally with images.
-    void ReInitNotebook();
+    void OnType(wxCommandEvent& event);
+    void OnOrient(wxCommandEvent& event);
+    void OnShowImages(wxCommandEvent& event);
+    void OnMulti(wxCommandEvent& event);
+    void OnExit(wxCommandEvent& event);
 
-    void OnCheckOrRadioBox(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 OnGoHome(wxCommandEvent &event);
 
-    void OnButtonAddPage(wxCommandEvent& event);
-    void OnButtonInsertPage(wxCommandEvent& event);
-    void OnButtonDeleteCurPage(wxCommandEvent& event);
-    void OnButtonDeleteLastPage(wxCommandEvent& event);
-    void OnButtonNextPage(wxCommandEvent& event);
-    void OnButtonExit(wxCommandEvent& event);
+    void OnAddSubPage(wxCommandEvent& event);
+    void OnAddPageBefore(wxCommandEvent& event);
 
-    void OnNotebook(wxNotebookEvent& event);
+#if wxUSE_HELP
+    void OnContextHelp(wxCommandEvent& event);
+#endif // wxUSE_HELP
 
-    void OnUpdateUIBtnDeleteCurPage(wxUpdateUIEvent& event);
-    void OnUpdateUIBtnDeleteLastPage(wxUpdateUIEvent& 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);
 
+#if wxUSE_TREEBOOK
+    void OnUpdateTreeMenu(wxUpdateUIEvent& event);
+#endif // wxUSE_TREEBOOK
+
+    wxBookCtrlBase *GetCurrentBook() const { return m_bookCtrl; }
+
 private:
     wxLog *m_logTargetOld;
 
+    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
+    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;
 
     // Controls
 
     wxPanel *m_panel; // Panel containing notebook and other controls
+    wxBookCtrlBase *m_bookCtrl;
 
-    wxRadioBox *m_radioOrient;
-    wxCheckBox *m_chkShowImages,
-               *m_chkMultiLine;
-
-    wxButton *m_btnAddPage;
-    wxButton *m_btnInsertPage;
-    wxButton *m_btnDeleteCurPage;
-    wxButton *m_btnDeleteLastPage;
-    wxButton *m_btnNextPage;
-    wxButton *m_btnExit;
-
-    MyNotebook *m_notebook;
-
+#if USE_LOG
     // Log window
     wxTextCtrl *m_text;
+#endif // USE_LOG
 
-
-    // Sizers
-
-    // The frame's sizer. Consists of m_sizerTop and the log window
-    // at the bottom.
     wxBoxSizer *m_sizerFrame;
 
-    // Sizer that contains the notebook and controls on the left
-    wxBoxSizer *m_sizerTop;
-
-    // Sizer for m_notebook
-    wxBookCtrlSizer *m_sizerNotebook;
-
     wxImageList *m_imageList;
 
     DECLARE_EVENT_TABLE()
 };
 
-enum ID_CONTROLS
+enum ID_COMMANDS
 {
-    ID_RADIO_ORIENT = wxID_HIGHEST,
-    ID_CHK_SHOWIMAGES,
-    ID_CHK_MULTILINE,
-    ID_BTN_ADD_PAGE,
-    ID_BTN_INSERT_PAGE,
-    ID_BTN_DELETE_CUR_PAGE,
-    ID_BTN_DELETE_LAST_PAGE,
-    ID_BTN_NEXT_PAGE,
-    ID_NOTEBOOK
-};
-
-// notebook orientations
-enum ORIENT
-{
-    ORIENT_TOP,
-    ORIENT_BOTTOM,
-    ORIENT_LEFT,
-    ORIENT_RIGHT,
-    ORIENT_MAX
+    // 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,
+    ID_ORIENT_LEFT,
+    ID_ORIENT_RIGHT,
+    ID_ORIENT_MAX,
+    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_ADD_PAGE_BEFORE,
+    ID_ADD_SUB_PAGE,
+    ID_GO_HOME,
+
+#if wxUSE_HELP
+    ID_CONTEXT_HELP,
+#endif // wxUSE_HELP
+    ID_HITTEST
 };
 
 /*
@@ -175,3 +172,7 @@ to decide what type of page it is.
 // Pages that can be added by the user
 #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 ")
+
+