]> git.saurik.com Git - wxWidgets.git/blobdiff - samples/layout/layout.h
include wx/arrstr.h as it's needed by wxImageHandler and may not be implicitly includ...
[wxWidgets.git] / samples / layout / layout.h
index 15fa044a8fe2cbd2f9d1c9eb5708b0fd5ad498c6..d7a8f8ef72449b5264328fb9caf894dbfd55c5ac 100644 (file)
 // Modified by:
 // Created:     04/01/98
 // RCS-ID:      $Id$
-// Copyright:   (c) Julian Smart and Markus Holzem
-// Licence:    wxWindows license
+// Copyright:   (c) Julian Smart
+// Licence:     wxWindows license
 /////////////////////////////////////////////////////////////////////////////
 
 // Define a new application
 class MyApp: public wxApp
 {
-  public:
-    MyApp(void) ;
-    bool OnInit(void);
+public:
+    MyApp(){};
+    bool OnInit();
 };
 
-// Define a new frame
-class MyTextWindow;
-class MyWindow;
+// the main frame class
+class MyFrame : public wxFrame
+{
+public:
+    MyFrame();
+
+    void TestProportions(wxCommandEvent& event);
+    void TestFlexSizers(wxCommandEvent& event);
+    void TestNotebookSizers(wxCommandEvent& event);
+    void TestGridBagSizer(wxCommandEvent& event);
+    void TestNested(wxCommandEvent& event);
+    void TestSetMinimal(wxCommandEvent& event);
+    void TestWrap(wxCommandEvent& event);
+
+    void OnAbout(wxCommandEvent& event);
+    void OnQuit(wxCommandEvent& event);
+
+private:
+    DECLARE_EVENT_TABLE()
+};
+
+// a frame showing the box sizer proportions
+class MyProportionsFrame : public wxFrame
+{
+public:
+    MyProportionsFrame(wxFrame *parent);
+
+protected:
+    void UpdateProportions();
 
-class MyFrame: public wxFrame
+    void OnProportionChanged(wxSpinEvent& event);
+    void OnProportionUpdated(wxCommandEvent& event);
+
+    wxSpinCtrl *m_spins[3]; // size can be changed without changing anything else
+    wxSizer *m_sizer;
+};
+
+// a frame using flex sizers for layout
+class MyFlexSizerFrame : public wxFrame
 {
-  public:
-    wxPanel *panel;
-    MyTextWindow *text_window;
-    MyWindow *canvas;
-    MyFrame(wxFrame *frame, char *title, int x, int y, int w, int h);
-    void OnSize(wxSizeEvent& event);
-    void Draw(wxDC& dc, bool draw_bitmaps = TRUE);
-
-    void LoadFile(wxCommandEvent& event);
-    void Quit(wxCommandEvent& event);
-    void TestSizers(wxCommandEvent& event);
-    void About(wxCommandEvent& event);
-
-  DECLARE_EVENT_TABLE()
+public:
+    MyFlexSizerFrame(const wxString &title, int x, int y );
+
+private:
+    void InitFlexSizer(wxFlexGridSizer *sizer, wxWindow* parent);
 };
 
-// Define a new text subwindow that can respond to drag-and-drop
-class MyTextWindow: public wxTextCtrl
+
+// a dialog using notebook sizer for layout
+class MySizerDialog : public wxDialog
 {
-  public:
-  MyTextWindow(wxFrame *frame, int x=-1, int y=-1, int width=-1, int height=-1,
-               long style=wxTE_MULTILINE):
-    wxTextCtrl(frame, -1, "", wxPoint(x, y), wxSize(width, height), style)
-  {
-  }
+public:
+    MySizerDialog(wxWindow *parent, const wxString &title );
 };
 
-// Define a new canvas which can receive some events
-class MyWindow: public wxWindow
+
+// a frame using wxGridBagSizer for layout
+class MyGridBagSizerFrame : public wxFrame
 {
-  public:
-    MyWindow(wxFrame *frame, int x, int y, int w, int h, long style = wxRETAINED);
-    ~MyWindow(void) ;
-    void OnPaint(wxPaintEvent& event);
+public:
+    MyGridBagSizerFrame(const wxString &title, int x, int y );
+
+    void OnHideBtn(wxCommandEvent&);
+    void OnShowBtn(wxCommandEvent&);
+    void OnMoveBtn(wxCommandEvent&);
+
+private:
+    wxGridBagSizer*     m_gbs;
+    wxPanel*            m_panel;
+    wxButton*           m_hideBtn;
+    wxButton*           m_showBtn;
+    wxTextCtrl*         m_hideTxt;
+
+    wxButton*           m_moveBtn1;
+    wxButton*           m_moveBtn2;
+    wxGBPosition        m_lastPos;
+
+    DECLARE_EVENT_TABLE()
+};
+
+
+// a frame for testing simple setting of "default size"
+class MySimpleSizerFrame : public wxFrame
+{
+public:
+    MySimpleSizerFrame(const wxString &title, int x, int y );
+    
+    void OnSetSmallSize( wxCommandEvent &event);
+    void OnSetBigSize( wxCommandEvent &event);
     
+private:
+    wxTextCtrl  *m_target;
+
     DECLARE_EVENT_TABLE()
 };
 
-class SizerFrame: public wxFrame
+
+// a frame for testing simple setting of a frame containing
+// a sizer containing a panel containing a sizer containing
+// controls
+class MyNestedSizerFrame : public wxFrame
 {
-  public:
-    wxPanel *panel;
-    SizerFrame(wxFrame *frame, char *title, int x, int y, int w, int h);
-    void OnSize(wxSizeEvent& event);
+public:
+    MyNestedSizerFrame(const wxString &title, int x, int y );
+    
+    
+private:
+    wxTextCtrl  *m_target;
+};
+
+// a frame with several wrapping sizers
 
-   DECLARE_EVENT_TABLE()
+class MyWrapSizerFrame: public wxFrame
+{
+public:
+    MyWrapSizerFrame(const wxString &title, int x, int y );
+};
+
+// controls and menu constants
+enum
+{
+    LAYOUT_TEST_SIZER = 101,
+    LAYOUT_TEST_NB_SIZER,
+    LAYOUT_TEST_GB_SIZER,
+    LAYOUT_TEST_PROPORTIONS,
+    LAYOUT_TEST_SET_MINIMAL,
+    LAYOUT_TEST_NESTED,
+    LAYOUT_TEST_WRAP,
+    LAYOUT_QUIT = wxID_EXIT,
+    LAYOUT_ABOUT = wxID_ABOUT
 };
 
-#define LAYOUT_QUIT       100
-#define LAYOUT_TEST       101
-#define LAYOUT_ABOUT      102
-#define LAYOUT_LOAD_FILE  103