slightly cleaned up the sample code -- but it (still) really needs a rewrite
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/branches/WX_2_4_BRANCH@17476 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -45,7 +45,7 @@ MyApp::MyApp()
|
|||||||
bool MyApp::OnInit()
|
bool MyApp::OnInit()
|
||||||
{
|
{
|
||||||
// Create the main frame window
|
// Create the main frame window
|
||||||
frame = new MyFrame((MyFrame *) NULL, (char *) "wxWindows Layout Demo", 0, 0, 550, 500);
|
frame = new MyFrame(NULL, "wxWindows Layout Demo", -1, -1, 400, 300);
|
||||||
|
|
||||||
frame->SetAutoLayout(TRUE);
|
frame->SetAutoLayout(TRUE);
|
||||||
|
|
||||||
@@ -55,7 +55,6 @@ bool MyApp::OnInit()
|
|||||||
// Make a menubar
|
// Make a menubar
|
||||||
wxMenu *file_menu = new wxMenu;
|
wxMenu *file_menu = new wxMenu;
|
||||||
|
|
||||||
file_menu->Append(LAYOUT_LOAD_FILE, "&Load file", "Load a text file");
|
|
||||||
file_menu->Append(LAYOUT_TEST_SIZER, "&Test sizers", "Test sizer");
|
file_menu->Append(LAYOUT_TEST_SIZER, "&Test sizers", "Test sizer");
|
||||||
file_menu->Append(LAYOUT_TEST_NB, "&Test notebook sizers", "Test notebook sizer");
|
file_menu->Append(LAYOUT_TEST_NB, "&Test notebook sizers", "Test notebook sizer");
|
||||||
|
|
||||||
@@ -74,21 +73,19 @@ bool MyApp::OnInit()
|
|||||||
frame->SetMenuBar(menu_bar);
|
frame->SetMenuBar(menu_bar);
|
||||||
|
|
||||||
// Make a panel
|
// Make a panel
|
||||||
frame->panel = new wxPanel(frame, 0, 0, 1000, 500, wxTAB_TRAVERSAL);
|
wxPanel *panel = new wxPanel(frame);
|
||||||
frame->panel->SetBackgroundColour(wxSystemSettings::GetColour(wxSYS_COLOUR_3DFACE));
|
|
||||||
// frame->panel->SetAutoLayout(TRUE);
|
|
||||||
|
|
||||||
// Create some panel items
|
// Create some panel items
|
||||||
wxButton *btn1 = new wxButton(frame->panel, -1, "A button (1)") ;
|
wxButton *btn1 = new wxButton(panel, -1, "A button (1)") ;
|
||||||
|
|
||||||
wxLayoutConstraints *b1 = new wxLayoutConstraints;
|
wxLayoutConstraints *b1 = new wxLayoutConstraints;
|
||||||
b1->centreX.SameAs (frame->panel, wxCentreX);
|
b1->centreX.SameAs (panel, wxCentreX);
|
||||||
b1->top.SameAs (frame->panel, wxTop, 5);
|
b1->top.SameAs (panel, wxTop, 5);
|
||||||
b1->width.PercentOf (frame->panel, wxWidth, 80);
|
b1->width.PercentOf (panel, wxWidth, 80);
|
||||||
b1->height.PercentOf (frame->panel, wxHeight, 10);
|
b1->height.AsIs ();
|
||||||
btn1->SetConstraints(b1);
|
btn1->SetConstraints(b1);
|
||||||
|
|
||||||
wxListBox *list = new wxListBox(frame->panel, -1,
|
wxListBox *list = new wxListBox(panel, -1,
|
||||||
wxPoint(-1, -1), wxSize(200, 100));
|
wxPoint(-1, -1), wxSize(200, 100));
|
||||||
list->Append("Apple");
|
list->Append("Apple");
|
||||||
list->Append("Pear");
|
list->Append("Pear");
|
||||||
@@ -98,28 +95,24 @@ bool MyApp::OnInit()
|
|||||||
|
|
||||||
wxLayoutConstraints *b2 = new wxLayoutConstraints;
|
wxLayoutConstraints *b2 = new wxLayoutConstraints;
|
||||||
b2->top.Below (btn1, 5);
|
b2->top.Below (btn1, 5);
|
||||||
b2->left.SameAs (frame->panel, wxLeft, 5);
|
b2->left.SameAs (panel, wxLeft, 5);
|
||||||
b2->width.PercentOf (frame->panel, wxWidth, 40);
|
b2->width.PercentOf (panel, wxWidth, 40);
|
||||||
b2->bottom.SameAs (frame->panel, wxBottom, 5);
|
b2->bottom.SameAs (panel, wxBottom, 5);
|
||||||
list->SetConstraints(b2);
|
list->SetConstraints(b2);
|
||||||
|
|
||||||
wxTextCtrl *mtext = new wxTextCtrl(frame->panel, -1, "Some text",
|
wxTextCtrl *mtext = new wxTextCtrl(panel, -1, "Some text");
|
||||||
wxPoint(-1, -1), wxSize(150, 100));
|
|
||||||
|
|
||||||
wxLayoutConstraints *b3 = new wxLayoutConstraints;
|
wxLayoutConstraints *b3 = new wxLayoutConstraints;
|
||||||
b3->top.Below (btn1, 5);
|
b3->top.Below (btn1, 5);
|
||||||
b3->left.RightOf (list, 5);
|
b3->left.RightOf (list, 5);
|
||||||
b3->right.SameAs (frame->panel, wxRight, 5);
|
b3->right.SameAs (panel, wxRight, 5);
|
||||||
b3->bottom.SameAs (frame->panel, wxBottom, 5);
|
b3->bottom.SameAs (panel, wxBottom, 5);
|
||||||
mtext->SetConstraints(b3);
|
mtext->SetConstraints(b3);
|
||||||
|
|
||||||
frame->canvas = new MyWindow(frame, 0, 0, 400, 400, wxRETAINED);
|
MyWindow *canvas = new MyWindow(frame, 0, 0, 400, 400, wxRETAINED);
|
||||||
|
|
||||||
// Give it scrollbars: the virtual canvas is 20 * 50 = 1000 pixels in each direction
|
|
||||||
// canvas->SetScrollbars(20, 20, 50, 50, 4, 4);
|
|
||||||
|
|
||||||
// Make a text window
|
// Make a text window
|
||||||
frame->text_window = new MyTextWindow(frame, 0, 250, 400, 250);
|
MyTextWindow *text_window = new MyTextWindow(frame, 0, 250, 400, 150);
|
||||||
|
|
||||||
// Set constraints for panel subwindow
|
// Set constraints for panel subwindow
|
||||||
wxLayoutConstraints *c1 = new wxLayoutConstraints;
|
wxLayoutConstraints *c1 = new wxLayoutConstraints;
|
||||||
@@ -129,32 +122,33 @@ bool MyApp::OnInit()
|
|||||||
c1->right.PercentOf (frame, wxWidth, 50);
|
c1->right.PercentOf (frame, wxWidth, 50);
|
||||||
c1->height.PercentOf (frame, wxHeight, 50);
|
c1->height.PercentOf (frame, wxHeight, 50);
|
||||||
|
|
||||||
frame->panel->SetConstraints(c1);
|
panel->SetConstraints(c1);
|
||||||
|
|
||||||
// Set constraints for canvas subwindow
|
// Set constraints for canvas subwindow
|
||||||
wxLayoutConstraints *c2 = new wxLayoutConstraints;
|
wxLayoutConstraints *c2 = new wxLayoutConstraints;
|
||||||
|
|
||||||
c2->left.SameAs (frame->panel, wxRight);
|
c2->left.SameAs (panel, wxRight);
|
||||||
c2->top.SameAs (frame, wxTop);
|
c2->top.SameAs (frame, wxTop);
|
||||||
c2->right.SameAs (frame, wxRight);
|
c2->right.SameAs (frame, wxRight);
|
||||||
c2->height.PercentOf (frame, wxHeight, 50);
|
c2->height.PercentOf (frame, wxHeight, 50);
|
||||||
|
|
||||||
frame->canvas->SetConstraints(c2);
|
canvas->SetConstraints(c2);
|
||||||
|
|
||||||
// Set constraints for text subwindow
|
// Set constraints for text subwindow
|
||||||
wxLayoutConstraints *c3 = new wxLayoutConstraints;
|
wxLayoutConstraints *c3 = new wxLayoutConstraints;
|
||||||
c3->left.SameAs (frame, wxLeft);
|
c3->left.SameAs (frame, wxLeft);
|
||||||
c3->top.Below (frame->panel);
|
c3->top.Below (panel);
|
||||||
c3->right.SameAs (frame, wxRight);
|
c3->right.SameAs (frame, wxRight);
|
||||||
c3->bottom.SameAs (frame, wxBottom);
|
c3->bottom.SameAs (frame, wxBottom);
|
||||||
|
|
||||||
frame->text_window->SetConstraints(c3);
|
text_window->SetConstraints(c3);
|
||||||
|
|
||||||
frame->Show(TRUE);
|
frame->Show(TRUE);
|
||||||
|
|
||||||
frame->SetStatusText("wxWindows layout demo");
|
frame->SetStatusText("wxWindows layout demo");
|
||||||
|
|
||||||
SetTopWindow(frame);
|
SetTopWindow(frame);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -163,43 +157,26 @@ bool MyApp::OnInit()
|
|||||||
//-----------------------------------------------------------------
|
//-----------------------------------------------------------------
|
||||||
|
|
||||||
// Define my frame constructor
|
// Define my frame constructor
|
||||||
MyFrame::MyFrame(wxFrame *frame, char *title, int x, int y, int w, int h):
|
MyFrame::MyFrame(wxFrame *frame, const char *title, int x, int y, int w, int h)
|
||||||
wxFrame(frame, -1, title, wxPoint(x, y), wxSize(w, h))
|
: wxFrame(frame, -1, title, wxPoint(x, y), wxSize(w, h))
|
||||||
{
|
{
|
||||||
panel = (wxPanel *) NULL;
|
|
||||||
text_window = (MyTextWindow *) NULL;
|
|
||||||
canvas = (MyWindow *) NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
||||||
EVT_MENU(LAYOUT_LOAD_FILE, MyFrame::LoadFile)
|
EVT_MENU(LAYOUT_QUIT, MyFrame::OnQuit)
|
||||||
EVT_MENU(LAYOUT_QUIT, MyFrame::Quit)
|
|
||||||
EVT_MENU(LAYOUT_TEST_SIZER, MyFrame::TestSizers)
|
EVT_MENU(LAYOUT_TEST_SIZER, MyFrame::TestSizers)
|
||||||
EVT_MENU(LAYOUT_TEST_NB, MyFrame::TestNotebookSizers)
|
EVT_MENU(LAYOUT_TEST_NB, MyFrame::TestNotebookSizers)
|
||||||
EVT_MENU(LAYOUT_ABOUT, MyFrame::About)
|
EVT_MENU(LAYOUT_ABOUT, MyFrame::About)
|
||||||
EVT_SIZE(MyFrame::OnSize)
|
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
void MyFrame::LoadFile(wxCommandEvent& WXUNUSED(event) )
|
void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event) )
|
||||||
{
|
{
|
||||||
wxString s = wxFileSelector( _T("Load text file"), (const wxChar *) NULL,
|
Close(TRUE);
|
||||||
(const wxChar *) NULL, (const wxChar *) NULL, _T("*.txt") );
|
|
||||||
if (s != "")
|
|
||||||
{
|
|
||||||
#ifdef __WXMSW__
|
|
||||||
frame->text_window->LoadFile(s);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MyFrame::Quit(wxCommandEvent& WXUNUSED(event) )
|
|
||||||
{
|
|
||||||
this->Close(TRUE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyFrame::TestSizers(wxCommandEvent& WXUNUSED(event) )
|
void MyFrame::TestSizers(wxCommandEvent& WXUNUSED(event) )
|
||||||
{
|
{
|
||||||
MySizerFrame *newFrame = new MySizerFrame((MyFrame *) NULL, "Sizer Test Frame", 50, 50 );
|
MySizerFrame *newFrame = new MySizerFrame(NULL, "Sizer Test Frame", 50, 50);
|
||||||
newFrame->Show(TRUE);
|
newFrame->Show(TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -256,14 +233,28 @@ void MyFrame::About(wxCommandEvent& WXUNUSED(event) )
|
|||||||
"About Layout Demo", wxOK|wxCENTRE);
|
"About Layout Demo", wxOK|wxCENTRE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Size the subwindows when the frame is resized
|
//-----------------------------------------------------------------
|
||||||
void MyFrame::OnSize(wxSizeEvent& WXUNUSED(event) )
|
// MyWindow
|
||||||
|
//-----------------------------------------------------------------
|
||||||
|
|
||||||
|
BEGIN_EVENT_TABLE(MyWindow, wxWindow)
|
||||||
|
EVT_PAINT(MyWindow::OnPaint)
|
||||||
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
|
// Define a constructor for my canvas
|
||||||
|
MyWindow::MyWindow(wxFrame *frame, int x, int y, int w, int h, long style)
|
||||||
|
: wxWindow(frame, -1, wxPoint(x, y), wxSize(w, h), style)
|
||||||
{
|
{
|
||||||
Layout();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyFrame::Draw(wxDC& dc, bool WXUNUSED(draw_bitmaps) )
|
MyWindow::~MyWindow()
|
||||||
{
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
// Define the repainting behaviour
|
||||||
|
void MyWindow::OnPaint(wxPaintEvent& WXUNUSED(event) )
|
||||||
|
{
|
||||||
|
wxPaintDC dc(this);
|
||||||
dc.SetPen(* wxGREEN_PEN);
|
dc.SetPen(* wxGREEN_PEN);
|
||||||
dc.DrawLine(0, 0, 200, 200);
|
dc.DrawLine(0, 0, 200, 200);
|
||||||
dc.DrawLine(200, 0, 0, 200);
|
dc.DrawLine(200, 0, 0, 200);
|
||||||
@@ -284,37 +275,12 @@ void MyFrame::Draw(wxDC& dc, bool WXUNUSED(draw_bitmaps) )
|
|||||||
dc.DrawArc(50, 300, 100, 250, 100, 300 );
|
dc.DrawArc(50, 300, 100, 250, 100, 300 );
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------
|
|
||||||
// MyWindow
|
|
||||||
//-----------------------------------------------------------------
|
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE(MyWindow, wxWindow)
|
|
||||||
EVT_PAINT(MyWindow::OnPaint)
|
|
||||||
END_EVENT_TABLE()
|
|
||||||
|
|
||||||
// Define a constructor for my canvas
|
|
||||||
MyWindow::MyWindow(wxFrame *frame, int x, int y, int w, int h, long style):
|
|
||||||
wxWindow(frame, -1, wxPoint(x, y), wxSize(w, h), style)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
MyWindow::~MyWindow()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
// Define the repainting behaviour
|
|
||||||
void MyWindow::OnPaint(wxPaintEvent& WXUNUSED(event) )
|
|
||||||
{
|
|
||||||
wxPaintDC dc(this);
|
|
||||||
frame->Draw(dc,TRUE);
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------
|
//-----------------------------------------------------------------
|
||||||
// MySizerFrame
|
// MySizerFrame
|
||||||
//-----------------------------------------------------------------
|
//-----------------------------------------------------------------
|
||||||
|
|
||||||
MySizerFrame::MySizerFrame(wxFrame *frame, char *title, int x, int y ):
|
MySizerFrame::MySizerFrame(wxFrame *frame, char *title, int x, int y )
|
||||||
wxFrame(frame, -1, title, wxPoint(x, y) )
|
: wxFrame(frame, -1, title, wxPoint(x, y) )
|
||||||
{
|
{
|
||||||
// we want to get a dialog that is stretchable because it
|
// we want to get a dialog that is stretchable because it
|
||||||
// has a text ctrl in the middle. at the bottom, we have
|
// has a text ctrl in the middle. at the bottom, we have
|
||||||
@@ -394,12 +360,8 @@ MySizerFrame::MySizerFrame(wxFrame *frame, char *title, int x, int y ):
|
|||||||
0, // make vertically unstretchable
|
0, // make vertically unstretchable
|
||||||
wxCENTER ); // no border and centre horizontally
|
wxCENTER ); // no border and centre horizontally
|
||||||
|
|
||||||
SetAutoLayout( TRUE );
|
// don't allow frame to get smaller than what the sizers tell it and also set
|
||||||
|
// the initial size as calculated by the sizers
|
||||||
// set frame to minimum size
|
|
||||||
topsizer->Fit( this );
|
|
||||||
|
|
||||||
// don't allow frame to get smaller than what the sizers tell ye
|
|
||||||
topsizer->SetSizeHints( this );
|
topsizer->SetSizeHints( this );
|
||||||
|
|
||||||
SetSizer( topsizer );
|
SetSizer( topsizer );
|
||||||
|
@@ -24,15 +24,10 @@ class MyWindow;
|
|||||||
class MyFrame: public wxFrame
|
class MyFrame: public wxFrame
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
wxPanel *panel;
|
MyFrame(wxFrame *frame, const char *title, int x, int y, int w, int h);
|
||||||
MyTextWindow *text_window;
|
|
||||||
MyWindow *canvas;
|
void OnQuit(wxCommandEvent& event);
|
||||||
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 TestSizers(wxCommandEvent& event);
|
||||||
void TestNotebookSizers(wxCommandEvent& event);
|
void TestNotebookSizers(wxCommandEvent& event);
|
||||||
void About(wxCommandEvent& event);
|
void About(wxCommandEvent& event);
|
||||||
@@ -61,7 +56,7 @@ public:
|
|||||||
~MyWindow();
|
~MyWindow();
|
||||||
void OnPaint(wxPaintEvent& event);
|
void OnPaint(wxPaintEvent& event);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -75,6 +70,5 @@ public:
|
|||||||
#define LAYOUT_QUIT 100
|
#define LAYOUT_QUIT 100
|
||||||
#define LAYOUT_TEST 101
|
#define LAYOUT_TEST 101
|
||||||
#define LAYOUT_ABOUT 102
|
#define LAYOUT_ABOUT 102
|
||||||
#define LAYOUT_LOAD_FILE 103
|
|
||||||
#define LAYOUT_TEST_SIZER 104
|
#define LAYOUT_TEST_SIZER 104
|
||||||
#define LAYOUT_TEST_NB 105
|
#define LAYOUT_TEST_NB 105
|
||||||
|
Reference in New Issue
Block a user