///////////////////////////////////////////////////////////////////////////// // Program: wxWidgets Widgets Sample // Name: widgets.h // Purpose: Common stuff for all widgets project files // Author: Vadim Zeitlin // Created: 27.03.01 // Id: $Id$ // Copyright: (c) 2001 Vadim Zeitlin // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #ifndef _WX_SAMPLE_WIDGETS_H_ #define _WX_SAMPLE_WIDGETS_H_ class WXDLLEXPORT wxCheckBox; class WXDLLEXPORT wxBookCtrlBase; class WXDLLEXPORT wxSizer; class WXDLLEXPORT wxTextCtrl; class WidgetsPageInfo; #include "wx/panel.h" // all source files use wxImageList #include "wx/imaglist.h" #if wxUSE_LOG && !defined(__SMARTPHONE__) #define USE_LOG 1 #else #define USE_LOG 0 #endif // ---------------------------------------------------------------------------- // WidgetsPage: a book page demonstrating some widget // ---------------------------------------------------------------------------- class WidgetsPage : public wxPanel { public: WidgetsPage(wxBookCtrlBase *book); // return the control shown by this page virtual wxControl *GetWidget() const = 0; // some pages show 2 controls, in this case override this one as well virtual wxControl *GetWidget2() const { return NULL; } // recreate the control shown by this page // // this is currently used only to take into account the border flags virtual void RecreateWidget() = 0; // the default flags for the widget, currently only contains border flags static int ms_defaultFlags; protected: // several helper functions for page creation // create a horz sizer containing the given control and the text ctrl // (pointer to which will be saved in the provided variable if not NULL) // with the specified id wxSizer *CreateSizerWithText(wxControl *control, wxWindowID id = wxID_ANY, wxTextCtrl **ppText = NULL); // create a sizer containing a label and a text ctrl wxSizer *CreateSizerWithTextAndLabel(const wxString& label, wxWindowID id = wxID_ANY, wxTextCtrl **ppText = NULL); // create a sizer containing a button and a text ctrl wxSizer *CreateSizerWithTextAndButton(wxWindowID idBtn, const wxString& labelBtn, wxWindowID id = wxID_ANY, wxTextCtrl **ppText = NULL); // create a checkbox and add it to the sizer wxCheckBox *CreateCheckBoxAndAddToSizer(wxSizer *sizer, const wxString& label, wxWindowID id = wxID_ANY); public: // the head of the linked list containinginfo about all pages static WidgetsPageInfo *ms_widgetPages; }; // ---------------------------------------------------------------------------- // dynamic WidgetsPage creation helpers // ---------------------------------------------------------------------------- class WidgetsPageInfo { public: typedef WidgetsPage *(*Constructor)(wxBookCtrlBase *book, wxImageList *imaglist); // our ctor WidgetsPageInfo(Constructor ctor, const wxChar *label); // accessors const wxString& GetLabel() const { return m_label; } Constructor GetCtor() const { return m_ctor; } WidgetsPageInfo *GetNext() const { return m_next; } void SetNext(WidgetsPageInfo *next) { m_next = next; } private: // the label of the page wxString m_label; // the function to create this page Constructor m_ctor; // next node in the linked list or NULL WidgetsPageInfo *m_next; }; // to declare a page, this macro must be used in the class declaration #define DECLARE_WIDGETS_PAGE(classname) \ private: \ static WidgetsPageInfo ms_info##classname; \ public: \ const WidgetsPageInfo *GetPageInfo() const \ { 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, \ wxImageList *imaglist) \ { return new classname(book, imaglist); } \ WidgetsPageInfo classname:: \ ms_info##classname(wxCtorFor##classname, label) #endif // _WX_SAMPLE_WIDGETS_H_