]> git.saurik.com Git - wxWidgets.git/blobdiff - samples/widgets/widgets.h
more wxFD_XXX renamings (patch 1488371)
[wxWidgets.git] / samples / widgets / widgets.h
index d8e40df3ce335321434a164dd80eb83f79b7bcb4..ca2a8e7cca83e89bd529bc22102d3cd0f18c84c4 100644 (file)
 #ifndef _WX_SAMPLE_WIDGETS_H_
 #define _WX_SAMPLE_WIDGETS_H_
 
 #ifndef _WX_SAMPLE_WIDGETS_H_
 #define _WX_SAMPLE_WIDGETS_H_
 
+#if wxUSE_TREEBOOK && !defined(__WXHANDHELD__)
+    #include "wx/treebook.h"
+    #define USE_TREEBOOK 1
+    #define WidgetsBookCtrl wxTreebook
+    #define WidgetsBookCtrlEvent wxTreebookEvent
+    #define EVT_WIDGETS_PAGE_CHANGED(id,func) EVT_TREEBOOK_PAGE_CHANGED(id,func)
+    #define WidgetBookStyle (wxBK_DEFAULT)
+#else
+    #include "wx/bookctrl.h"
+    #define USE_TREEBOOK 0
+    #define WidgetsBookCtrl wxBookCtrl
+    #define WidgetsBookCtrlEvent wxBookCtrlEvent
+    #define EVT_WIDGETS_PAGE_CHANGED(id,func) EVT_BOOKCTRL_PAGE_CHANGED(id,func)
+    #ifdef __POCKETPC__
+        #define WidgetBookStyle (wxBK_BOTTOM|wxNB_FLAT)
+    #else
+        #define WidgetBookStyle (wxBK_DEFAULT)
+    #endif
+#endif
+
+#if wxUSE_LOG && !defined(__WXHANDHELD__)
+    #define USE_LOG 1
+#else
+    #define USE_LOG 0
+#endif
+
+#if defined(__WXHANDHELD__)
+    #define USE_ICONS_IN_BOOK 0
+#else
+    #define USE_ICONS_IN_BOOK 1
+#endif
+
 class WXDLLEXPORT wxCheckBox;
 class WXDLLEXPORT wxCheckBox;
-class WXDLLEXPORT wxBookCtrlBase;
 class WXDLLEXPORT wxSizer;
 class WXDLLEXPORT wxSizer;
+class WXDLLEXPORT wxImageList;
 class WXDLLEXPORT wxTextCtrl;
 class WXDLLEXPORT wxTextCtrl;
+class WXDLLEXPORT WidgetsBookCtrl;
 
 class WidgetsPageInfo;
 
 #include "wx/panel.h"
 
 
 class WidgetsPageInfo;
 
 #include "wx/panel.h"
 
-// all source files use wxImageList
-#include "wx/imaglist.h"
+// INTRODUCING NEW PAGES DON'T FORGET TO ADD ENTRIES TO 'WidgetsCategories'
+enum
+{
+    // On wxUniversal-based build (wxX11, wxMGL, wxMSWUniv, wxGTKUniv, etc.)
+    // 'native' means 'made with wxUniv port renderer'
+    NATIVE_PAGE = 0,
+    UNIVERSAL_PAGE = NATIVE_PAGE,
+    GENERIC_PAGE,
+    PICKER_PAGE,
+    COMBO_PAGE,
+    WITH_ITEMS_PAGE,
+    EDITABLE_PAGE,
+    BOOK_PAGE,
+    ALL_PAGE,
+    MAX_PAGES
+};
 
 
-#if wxUSE_LOG && !defined(__SMARTPHONE__)
-    #define USE_LOG 1
-#else
-    #define USE_LOG 0
-#endif
+enum
+{
+    NATIVE_CTRLS     = 1 << NATIVE_PAGE,
+    UNIVERSAL_CTRLS  = NATIVE_CTRLS,
+    GENERIC_CTRLS    = 1 << GENERIC_PAGE,
+    PICKER_CTRLS     = 1 << PICKER_PAGE,
+    COMBO_CTRLS      = 1 << COMBO_PAGE,
+    WITH_ITEMS_CTRLS = 1 << WITH_ITEMS_PAGE,
+    EDITABLE_CTRLS   = 1 << EDITABLE_PAGE,
+    BOOK_CTRLS       = 1 << BOOK_PAGE,
+    ALL_CTRLS        = 1 << ALL_PAGE
+};
 
 // ----------------------------------------------------------------------------
 // WidgetsPage: a book page demonstrating some widget
 
 // ----------------------------------------------------------------------------
 // WidgetsPage: a book page demonstrating some widget
@@ -37,7 +91,9 @@ class WidgetsPageInfo;
 class WidgetsPage : public wxPanel
 {
 public:
 class WidgetsPage : public wxPanel
 {
 public:
-    WidgetsPage(wxBookCtrlBase *book);
+    WidgetsPage(WidgetsBookCtrl *book,
+                wxImageList *imaglist,
+                char* icon[]);
 
     // return the control shown by this page
     virtual wxControl *GetWidget() const = 0;
 
     // return the control shown by this page
     virtual wxControl *GetWidget() const = 0;
@@ -91,14 +147,15 @@ public:
 class WidgetsPageInfo
 {
 public:
 class WidgetsPageInfo
 {
 public:
-    typedef WidgetsPage *(*Constructor)(wxBookCtrlBase *book,
+    typedef WidgetsPage *(*Constructor)(WidgetsBookCtrl *book,
                                         wxImageList *imaglist);
 
     // our ctor
                                         wxImageList *imaglist);
 
     // our ctor
-    WidgetsPageInfo(Constructor ctor, const wxChar *label);
+    WidgetsPageInfo(Constructor ctor, const wxChar *label, int categories);
 
     // accessors
     const wxString& GetLabel() const { return m_label; }
 
     // accessors
     const wxString& GetLabel() const { return m_label; }
+    int GetCategories() const { return m_categories; }
     Constructor GetCtor() const { return m_ctor; }
     WidgetsPageInfo *GetNext() const { return m_next; }
 
     Constructor GetCtor() const { return m_ctor; }
     WidgetsPageInfo *GetNext() const { return m_next; }
 
@@ -108,6 +165,9 @@ private:
     // the label of the page
     wxString m_label;
 
     // the label of the page
     wxString m_label;
 
+    // the list (flags) for sharing page between categories
+    int m_categories;
+
     // the function to create this page
     Constructor m_ctor;
 
     // the function to create this page
     Constructor m_ctor;
 
@@ -124,11 +184,11 @@ private:
             { return &ms_info##classname; }
 
 // and this one must be inserted somewhere in the source file
             { return &ms_info##classname; }
 
 // and this one must be inserted somewhere in the source file
-#define IMPLEMENT_WIDGETS_PAGE(classname, label)                            \
-    WidgetsPage *wxCtorFor##classname(wxBookCtrlBase *book,                 \
+#define IMPLEMENT_WIDGETS_PAGE(classname, label, categories)                \
+    WidgetsPage *wxCtorFor##classname(WidgetsBookCtrl *book,                \
                                       wxImageList *imaglist)                \
         { return new classname(book, imaglist); }                           \
     WidgetsPageInfo classname::                                             \
                                       wxImageList *imaglist)                \
         { return new classname(book, imaglist); }                           \
     WidgetsPageInfo classname::                                             \
-        ms_info##classname(wxCtorFor##classname, label)
+        ms_info##classname(wxCtorFor##classname, label, ALL_CTRLS | categories)
 
 #endif // _WX_SAMPLE_WIDGETS_H_
 
 #endif // _WX_SAMPLE_WIDGETS_H_