]> git.saurik.com Git - wxWidgets.git/blobdiff - samples/layout/layout.h
Mac sockets events must be added to the RunLoop in the main thread, very similar...
[wxWidgets.git] / samples / layout / layout.h
index e70addbe1ade1073e008a38f08875e13d285b010..1a4923d4e9d3e819f007bbf3a98892482ab355a7 100644 (file)
@@ -5,7 +5,7 @@
 // Modified by:
 // Created:     04/01/98
 // RCS-ID:      $Id$
-// Copyright:   (c) Julian Smart and Markus Holzem
+// Copyright:   (c) Julian Smart
 // Licence:     wxWindows license
 /////////////////////////////////////////////////////////////////////////////
 
@@ -17,58 +17,77 @@ public:
     bool OnInit();
 };
 
-// Define a new frame
-class MyTextWindow;
-class MyWindow;
-
-class MyFrame: public wxFrame
+// the main frame class
+class MyFrame : public wxFrame
 {
 public:
-    MyFrame(wxFrame *frame, const char *title, int x, int y, int w, int h);
-
-    void OnQuit(wxCommandEvent& event);
+    MyFrame();
 
-    void TestSizers(wxCommandEvent& event);
+    void TestFlexSizers(wxCommandEvent& event);
     void TestNotebookSizers(wxCommandEvent& event);
-    void About(wxCommandEvent& event);
+    void TestGridBagSizer(wxCommandEvent& event);
+    
+    void OnAbout(wxCommandEvent& event);
+    void OnQuit(wxCommandEvent& event);
 
 private:
     DECLARE_EVENT_TABLE()
 };
 
-// Define a new text subwindow that can respond to drag-and-drop
-class MyTextWindow: public wxTextCtrl
+// a frame using flex sizers for layout
+class MyFlexSizerFrame : public wxFrame
 {
 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)
-    {
-    }
+    MyFlexSizerFrame(const wxChar *title, int x, int y );
 
+private:
+    void InitFlexSizer(wxFlexGridSizer *sizer);
 };
 
-// Define a new canvas which can receive some events
-class MyWindow: public wxWindow
+
+// a dialog using notebook sizer for layout
+class MySizerDialog : public wxDialog
 {
 public:
-    MyWindow(wxFrame *frame, int x, int y, int w, int h, long style = wxRETAINED);
-    ~MyWindow();
-    void OnPaint(wxPaintEvent& event);
+    MySizerDialog(wxWindow *parent, const wxChar *title);
+};
 
+
+// a frame using wxGridBagSizer for layout
+class MyGridBagSizerFrame : public wxFrame
+{
+public:
+    MyGridBagSizerFrame(const wxChar *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()
 };
 
-class MySizerFrame: public wxFrame
+
+
+
+
+// controls and menu constants
+enum
 {
-public:
-    wxPanel *panel;
-    MySizerFrame(wxFrame *frame, char *title, int x, int y );
+    LAYOUT_QUIT = 100,
+    LAYOUT_ABOUT,
+    LAYOUT_TEST_SIZER,
+    LAYOUT_TEST_NB_SIZER,
+    LAYOUT_TEST_GB_SIZER
 };
 
-#define LAYOUT_QUIT       100
-#define LAYOUT_TEST       101
-#define LAYOUT_ABOUT      102
-#define LAYOUT_TEST_SIZER 104
-#define LAYOUT_TEST_NB    105