rewrote some sizer code using wxSizerFlags
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@29182 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -105,56 +105,47 @@ MyFrame::MyFrame()
|
|||||||
// 1) top: create wxStaticText with minimum size equal to its default size
|
// 1) top: create wxStaticText with minimum size equal to its default size
|
||||||
topsizer->Add(
|
topsizer->Add(
|
||||||
new wxStaticText( this, wxID_ANY, _T("An explanation (wxALIGN_RIGHT).") ),
|
new wxStaticText( this, wxID_ANY, _T("An explanation (wxALIGN_RIGHT).") ),
|
||||||
0, // make vertically unstretchable
|
wxSizerFlags().Align(wxALIGN_RIGHT).Border(wxALL & ~wxBOTTOM, 5));
|
||||||
wxALIGN_RIGHT | // right align text
|
|
||||||
wxTOP | wxLEFT | wxRIGHT, // make border all around except wxBOTTOM
|
|
||||||
5 ); // set border width to 5
|
|
||||||
|
|
||||||
// 2) top: create wxTextCtrl with minimum size (100x60)
|
// 2) top: create wxTextCtrl with minimum size (100x60)
|
||||||
topsizer->Add(
|
topsizer->Add(
|
||||||
new wxTextCtrl( this, wxID_ANY, _T("My text (wxEXPAND)."), wxDefaultPosition, wxSize(100,60), wxTE_MULTILINE),
|
new wxTextCtrl( this, wxID_ANY, _T("My text (wxEXPAND)."), wxDefaultPosition, wxSize(100,60), wxTE_MULTILINE),
|
||||||
1, // make vertically stretchable
|
wxSizerFlags(1).Expand().Border(wxALL, 5));
|
||||||
wxEXPAND | // make horizontally stretchable
|
|
||||||
wxALL, // and make border all around
|
|
||||||
5 ); // set border width to 5
|
|
||||||
|
|
||||||
// 2.5) Gratuitous test of wxStaticBoxSizers
|
// 2.5) Gratuitous test of wxStaticBoxSizers
|
||||||
wxBoxSizer *statsizer = new wxStaticBoxSizer(
|
wxBoxSizer *statsizer = new wxStaticBoxSizer(
|
||||||
new wxStaticBox(this, wxID_ANY, _T("A wxStaticBoxSizer")),
|
new wxStaticBox(this, wxID_ANY, _T("A wxStaticBoxSizer")), wxVERTICAL );
|
||||||
wxVERTICAL );
|
|
||||||
statsizer->Add(
|
statsizer->Add(
|
||||||
new wxStaticText(this, wxID_ANY, _T("And some TEXT inside it")),
|
new wxStaticText(this, wxID_ANY, _T("And some TEXT inside it")),
|
||||||
0,
|
wxSizerFlags().Center().Border(wxALL, 30));
|
||||||
wxCENTER |
|
topsizer->Add(
|
||||||
wxALL,
|
statsizer,
|
||||||
30);
|
wxSizerFlags(1).Expand().Border(wxALL, 10));
|
||||||
topsizer->Add(statsizer, 1, wxEXPAND | wxALL, 10);
|
|
||||||
|
|
||||||
// 2.7) And a test of wxGridSizer
|
// 2.7) And a test of wxGridSizer
|
||||||
wxGridSizer *gridsizer = new wxGridSizer(2, 5, 5);
|
wxGridSizer *gridsizer = new wxGridSizer(2, 5, 5);
|
||||||
gridsizer->Add(new wxStaticText(this, wxID_ANY, _T("Label")), 0,
|
gridsizer->Add(new wxStaticText(this, wxID_ANY, _T("Label")),
|
||||||
wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL);
|
wxSizerFlags().Align(wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL));
|
||||||
gridsizer->Add(new wxTextCtrl(this, wxID_ANY, _T("Grid sizer demo")), 1,
|
gridsizer->Add(new wxTextCtrl(this, wxID_ANY, _T("Grid sizer demo")),
|
||||||
wxGROW | wxALIGN_CENTER_VERTICAL);
|
wxSizerFlags(1).Align(wxGROW | wxALIGN_CENTER_VERTICAL));
|
||||||
gridsizer->Add(new wxStaticText(this, wxID_ANY, _T("Another label")), 0,
|
gridsizer->Add(new wxStaticText(this, wxID_ANY, _T("Another label")),
|
||||||
wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL);
|
wxSizerFlags().Align(wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL));
|
||||||
gridsizer->Add(new wxTextCtrl(this, wxID_ANY, _T("More text")), 1,
|
gridsizer->Add(new wxTextCtrl(this, wxID_ANY, _T("More text")),
|
||||||
wxGROW | wxALIGN_CENTER_VERTICAL);
|
wxSizerFlags(1).Align(wxGROW | wxALIGN_CENTER_VERTICAL));
|
||||||
gridsizer->Add(new wxStaticText(this, wxID_ANY, _T("Final label")), 0,
|
gridsizer->Add(new wxStaticText(this, wxID_ANY, _T("Final label")),
|
||||||
wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL);
|
wxSizerFlags().Align(wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL));
|
||||||
gridsizer->Add(new wxTextCtrl(this, wxID_ANY, _T("And yet more text")), 1,
|
gridsizer->Add(new wxTextCtrl(this, wxID_ANY, _T("And yet more text")),
|
||||||
wxGROW | wxALIGN_CENTER_VERTICAL);
|
wxSizerFlags().Align(wxGROW | wxALIGN_CENTER_VERTICAL));
|
||||||
topsizer->Add(gridsizer, 1, wxGROW | wxALL, 10);
|
topsizer->Add(
|
||||||
|
gridsizer,
|
||||||
|
wxSizerFlags().Proportion(1).Expand().Border(wxALL, 10));
|
||||||
|
|
||||||
|
|
||||||
#if wxUSE_STATLINE
|
#if wxUSE_STATLINE
|
||||||
// 3) middle: create wxStaticLine with minimum size (3x3)
|
// 3) middle: create wxStaticLine with minimum size (3x3)
|
||||||
topsizer->Add(
|
topsizer->Add(
|
||||||
new wxStaticLine( this, wxID_ANY, wxDefaultPosition, wxSize(3,3), wxHORIZONTAL),
|
new wxStaticLine( this, wxID_ANY, wxDefaultPosition, wxSize(3,3), wxHORIZONTAL),
|
||||||
0, // make vertically unstretchable
|
wxSizerFlags().Expand());
|
||||||
wxEXPAND | // make horizontally stretchable
|
|
||||||
wxALL, // and make border all around
|
|
||||||
5 ); // set border width to 5
|
|
||||||
#endif // wxUSE_STATLINE
|
#endif // wxUSE_STATLINE
|
||||||
|
|
||||||
|
|
||||||
@@ -162,19 +153,12 @@ MyFrame::MyFrame()
|
|||||||
wxBoxSizer *button_box = new wxBoxSizer( wxHORIZONTAL );
|
wxBoxSizer *button_box = new wxBoxSizer( wxHORIZONTAL );
|
||||||
button_box->Add(
|
button_box->Add(
|
||||||
new wxButton( this, wxID_ANY, _T("Two buttons in a box") ),
|
new wxButton( this, wxID_ANY, _T("Two buttons in a box") ),
|
||||||
0, // make horizontally unstretchable
|
wxSizerFlags().Border(wxALL, 7));
|
||||||
wxALL, // make border all around
|
|
||||||
7 ); // set border width to 7
|
|
||||||
button_box->Add(
|
button_box->Add(
|
||||||
new wxButton( this, wxID_ANY, _T("(wxCENTER)") ),
|
new wxButton( this, wxID_ANY, _T("(wxCENTER)") ),
|
||||||
0, // make horizontally unstretchable
|
wxSizerFlags().Border(wxALL, 7));
|
||||||
wxALL, // make border all around
|
|
||||||
7 ); // set border width to 7
|
|
||||||
|
|
||||||
topsizer->Add(
|
topsizer->Add(button_box, wxSizerFlags().Center());
|
||||||
button_box,
|
|
||||||
0, // make vertically unstretchable
|
|
||||||
wxCENTER ); // no border and centre horizontally
|
|
||||||
|
|
||||||
// don't allow frame to get smaller than what the sizers tell it and also set
|
// don't allow frame to get smaller than what the sizers tell it and also set
|
||||||
// the initial size as calculated by the sizers
|
// the initial size as calculated by the sizers
|
||||||
|
Reference in New Issue
Block a user