#include "wx/wx.h"
#endif
-#include "wx/tab.h"
#include "test.h"
// If 1, use a dialog. Otherwise use a frame.
#else
frame = new MyFrame((wxFrame*) NULL, -1, (char *) "Notebook", wxPoint(-1, -1), wxSize(365, 390), wxDEFAULT_FRAME_STYLE);
+ // Problem with generic wxNotebook implementation whereby it doesn't size properly unless
+ // you set the size again
+#if defined(__WIN16__)
+ int width, height;
+ frame->GetSize(& width, & height);
+ frame->SetSize(-1, -1, width, height);
+#endif
+
return TRUE;
#endif
}
void MyApp::InitTabView(wxNotebook* notebook, wxWindow* window)
{
- int dialogWidth = 365;
- int dialogHeight = 390;
-
m_okButton = new wxButton(window, wxID_OK, "Close", wxPoint(-1, -1), wxSize(80, 25));
- m_cancelButton = new wxButton(window, wxID_CANCEL, "Cancel", wxPoint(-1, -1), wxSize(80, 25));
- m_helpButton = new wxButton(window, wxID_HELP, "Help", wxPoint(-1, -1), wxSize(80, 25));
+ m_cancelButton = new wxButton(window, ID_DELETE_PAGE, "Delete page", wxPoint(-1, -1), wxSize(80, 25));
+ m_addPageButton = new wxButton(window, ID_ADD_PAGE, "Add page", wxPoint(-1, -1), wxSize(80, 25));
m_okButton->SetDefault();
wxLayoutConstraints* c = new wxLayoutConstraints;
c->bottom.SameAs(window, wxBottom, 4);
c->height.AsIs();
c->width.AsIs();
- m_helpButton->SetConstraints(c);
+ m_addPageButton->SetConstraints(c);
c = new wxLayoutConstraints;
- c->right.SameAs(m_helpButton, wxLeft, 4);
+ c->right.SameAs(m_addPageButton, wxLeft, 4);
c->bottom.SameAs(window, wxBottom, 4);
c->height.AsIs();
c->width.AsIs();
(void)new wxButton(panel1, -1, "Press me", wxPoint(10, 10));
(void)new wxTextCtrl(panel1, -1, "1234", wxPoint(10, 40), wxSize(120, 150));
- notebook->AddPage(panel1, "Cat");
+ notebook->AddPage(panel1, "Cat", TRUE);
wxPanel *panel2 = new wxPanel(notebook, -1);
panel2->SetBackgroundColour(wxColour("BLUE"));
wxTE_MULTILINE);
notebook->AddPage(panel2, "Dog");
-
wxPanel *panel3 = new wxPanel(notebook, -1);
panel3->SetBackgroundColour(wxColour("WHITE"));
notebook->AddPage(panel3, "Goat");
wxPanel *panel4 = new wxPanel(notebook, -1);
panel4->SetBackgroundColour(wxColour("YELLOW"));
notebook->AddPage(panel4, "Sheep");
+
+ wxPanel *panel5 = new wxPanel(notebook, -1);
+ panel5->SetBackgroundColour(wxColour("MAGENTA"));
+ (void)new wxStaticText(panel5, -1, "This page has been inserted, not added", wxPoint(10, 10) );
+ notebook->InsertPage(0, panel5, "Sheep");
}
BEGIN_EVENT_TABLE(MyDialog, wxDialog)
void MyDialog::Init(void)
{
- int dialogWidth = 365;
- int dialogHeight = 390;
-
m_notebook = new wxNotebook(this, ID_NOTEBOOK);
wxLayoutConstraints* c = new wxLayoutConstraints;
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
EVT_BUTTON(wxID_OK, MyFrame::OnOK)
- EVT_BUTTON(wxID_CANCEL, MyFrame::OnOK)
+ EVT_BUTTON(ID_DELETE_PAGE, MyFrame::OnDeletePage)
+ EVT_BUTTON(ID_ADD_PAGE, MyFrame::OnAddPage)
EVT_SIZE(MyFrame::OnSize)
END_EVENT_TABLE()
Init();
}
+void MyFrame::OnAddPage(wxCommandEvent& WXUNUSED(event))
+{
+ wxPanel *panel = new wxPanel( m_notebook, -1 );
+ (void)new wxButton( panel, -1, "Button", wxPoint( 10,10 ), wxSize(-1,-1) );
+ m_notebook->AddPage( panel, "Added" );
+// m_notebook->SetSelection( m_notebook->GetPageCount()-1 );
+}
+
+void MyFrame::OnDeletePage(wxCommandEvent& WXUNUSED(event))
+{
+ m_notebook->DeletePage( m_notebook->GetPageCount()-1 );
+}
+
void MyFrame::OnOK(wxCommandEvent& WXUNUSED(event) )
{
this->Destroy();
void MyFrame::Init(void)
{
- int dialogWidth = 365;
- int dialogHeight = 390;
-
m_panel = new wxPanel(this, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL|wxCLIP_CHILDREN);
// Note, omit the wxTAB_STYLE_COLOUR_INTERIOR, so we will guarantee a match